From f4600e1223de95e1ac031adf109d470f920ad3c1 Mon Sep 17 00:00:00 2001 From: GACB-Ar Date: Tue, 24 Aug 2021 15:35:29 -0300 Subject: [PATCH 01/11] first commit of telebot --- venv/bin/Activate.ps1 | 241 + venv/bin/activate | 76 + venv/bin/activate.csh | 37 + venv/bin/activate.fish | 75 + venv/bin/easy_install | 8 + venv/bin/easy_install-3.8 | 8 + venv/bin/normalizer | 8 + venv/bin/pip | 8 + venv/bin/pip3 | 8 + venv/bin/pip3.8 | 8 + venv/bin/python | 1 + venv/bin/python3 | 1 + .../__pycache__/easy_install.cpython-38.pyc | Bin 0 -> 281 bytes .../certifi-2021.5.30.dist-info/INSTALLER | 1 + .../certifi-2021.5.30.dist-info/LICENSE | 21 + .../certifi-2021.5.30.dist-info/METADATA | 83 + .../certifi-2021.5.30.dist-info/RECORD | 13 + .../certifi-2021.5.30.dist-info/WHEEL | 6 + .../certifi-2021.5.30.dist-info/top_level.txt | 1 + .../site-packages/certifi/__init__.py | 3 + .../site-packages/certifi/__main__.py | 12 + .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 227 bytes .../__pycache__/__main__.cpython-38.pyc | Bin 0 -> 392 bytes .../certifi/__pycache__/core.cpython-38.pyc | Bin 0 -> 1108 bytes .../site-packages/certifi/cacert.pem | 4257 +++++++++ .../python3.8/site-packages/certifi/core.py | 60 + .../INSTALLER | 1 + .../LICENSE | 21 + .../METADATA | 275 + .../charset_normalizer-2.0.3.dist-info/RECORD | 33 + .../charset_normalizer-2.0.3.dist-info/WHEEL | 5 + .../entry_points.txt | 3 + .../top_level.txt | 1 + .../charset_normalizer/__init__.py | 31 + .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 1855 bytes .../__pycache__/api.cpython-38.pyc | Bin 0 -> 9516 bytes .../__pycache__/cd.cpython-38.pyc | Bin 0 -> 7134 bytes .../__pycache__/constant.cpython-38.pyc | Bin 0 -> 13110 bytes .../__pycache__/legacy.cpython-38.pyc | Bin 0 -> 1419 bytes .../__pycache__/md.cpython-38.pyc | Bin 0 -> 13350 bytes .../__pycache__/models.cpython-38.pyc | Bin 0 -> 12394 bytes .../__pycache__/utils.cpython-38.pyc | Bin 0 -> 6050 bytes .../__pycache__/version.cpython-38.pyc | Bin 0 -> 238 bytes .../site-packages/charset_normalizer/api.py | 421 + .../charset_normalizer/assets/__init__.py | 52 + .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 6042 bytes .../site-packages/charset_normalizer/cd.py | 261 + .../charset_normalizer/cli/__init__.py | 0 .../cli/__pycache__/__init__.cpython-38.pyc | Bin 0 -> 158 bytes .../cli/__pycache__/normalizer.cpython-38.pyc | Bin 0 -> 5765 bytes .../charset_normalizer/cli/normalizer.py | 210 + .../charset_normalizer/constant.py | 343 + .../charset_normalizer/legacy.py | 38 + .../site-packages/charset_normalizer/md.py | 451 + .../charset_normalizer/models.py | 355 + .../site-packages/charset_normalizer/py.typed | 0 .../site-packages/charset_normalizer/utils.py | 248 + .../charset_normalizer/version.py | 6 + .../python3.8/site-packages/easy_install.py | 5 + .../idna-3.2.dist-info/INSTALLER | 1 + .../idna-3.2.dist-info/LICENSE.md | 29 + .../site-packages/idna-3.2.dist-info/METADATA | 225 + .../site-packages/idna-3.2.dist-info/RECORD | 23 + .../site-packages/idna-3.2.dist-info/WHEEL | 5 + .../idna-3.2.dist-info/top_level.txt | 1 + .../python3.8/site-packages/idna/__init__.py | 44 + .../idna/__pycache__/__init__.cpython-38.pyc | Bin 0 -> 869 bytes .../idna/__pycache__/codec.cpython-38.pyc | Bin 0 -> 2830 bytes .../idna/__pycache__/compat.cpython-38.pyc | Bin 0 -> 636 bytes .../idna/__pycache__/core.cpython-38.pyc | Bin 0 -> 9126 bytes .../idna/__pycache__/idnadata.cpython-38.pyc | Bin 0 -> 22090 bytes .../idna/__pycache__/intranges.cpython-38.pyc | Bin 0 -> 1812 bytes .../__pycache__/package_data.cpython-38.pyc | Bin 0 -> 163 bytes .../idna/__pycache__/uts46data.cpython-38.pyc | Bin 0 -> 177435 bytes .../lib/python3.8/site-packages/idna/codec.py | 117 + .../python3.8/site-packages/idna/compat.py | 16 + venv/lib/python3.8/site-packages/idna/core.py | 409 + .../python3.8/site-packages/idna/idnadata.py | 2050 ++++ .../python3.8/site-packages/idna/intranges.py | 58 + .../site-packages/idna/package_data.py | 2 + .../lib/python3.8/site-packages/idna/py.typed | 0 .../python3.8/site-packages/idna/uts46data.py | 8438 +++++++++++++++++ .../pip-20.0.2.dist-info/INSTALLER | 1 + .../pip-20.0.2.dist-info/LICENSE.txt | 20 + .../pip-20.0.2.dist-info/METADATA | 84 + .../site-packages/pip-20.0.2.dist-info/RECORD | 246 + .../site-packages/pip-20.0.2.dist-info/WHEEL | 6 + .../pip-20.0.2.dist-info/entry_points.txt | 5 + .../pip-20.0.2.dist-info/top_level.txt | 1 + .../python3.8/site-packages/pip/__init__.py | 18 + .../python3.8/site-packages/pip/__main__.py | 19 + .../pip/__pycache__/__init__.cpython-38.pyc | Bin 0 -> 629 bytes .../pip/__pycache__/__main__.cpython-38.pyc | Bin 0 -> 422 bytes .../site-packages/pip/_internal/__init__.py | 18 + .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 678 bytes .../__pycache__/build_env.cpython-38.pyc | Bin 0 -> 7483 bytes .../__pycache__/cache.cpython-38.pyc | Bin 0 -> 8700 bytes .../__pycache__/configuration.cpython-38.pyc | Bin 0 -> 10645 bytes .../__pycache__/exceptions.cpython-38.pyc | Bin 0 -> 12482 bytes .../__pycache__/legacy_resolve.cpython-38.pyc | Bin 0 -> 9898 bytes .../__pycache__/locations.cpython-38.pyc | Bin 0 -> 4492 bytes .../_internal/__pycache__/main.cpython-38.pyc | Bin 0 -> 615 bytes .../__pycache__/pep425tags.cpython-38.pyc | Bin 0 -> 3584 bytes .../__pycache__/pyproject.cpython-38.pyc | Bin 0 -> 3732 bytes .../self_outdated_check.cpython-38.pyc | Bin 0 -> 5493 bytes .../__pycache__/wheel_builder.cpython-38.pyc | Bin 0 -> 6699 bytes .../site-packages/pip/_internal/build_env.py | 221 + .../site-packages/pip/_internal/cache.py | 329 + .../pip/_internal/cli/__init__.py | 4 + .../cli/__pycache__/__init__.cpython-38.pyc | Bin 0 -> 236 bytes .../__pycache__/autocompletion.cpython-38.pyc | Bin 0 -> 4953 bytes .../__pycache__/base_command.cpython-38.pyc | Bin 0 -> 5847 bytes .../cli/__pycache__/cmdoptions.cpython-38.pyc | Bin 0 -> 20328 bytes .../command_context.cpython-38.pyc | Bin 0 -> 1311 bytes .../cli/__pycache__/main.cpython-38.pyc | Bin 0 -> 1406 bytes .../__pycache__/main_parser.cpython-38.pyc | Bin 0 -> 2159 bytes .../cli/__pycache__/parser.cpython-38.pyc | Bin 0 -> 8977 bytes .../__pycache__/req_command.cpython-38.pyc | Bin 0 -> 8289 bytes .../__pycache__/status_codes.cpython-38.pyc | Bin 0 -> 365 bytes .../pip/_internal/cli/autocompletion.py | 164 + .../pip/_internal/cli/base_command.py | 226 + .../pip/_internal/cli/cmdoptions.py | 957 ++ .../pip/_internal/cli/command_context.py | 36 + .../site-packages/pip/_internal/cli/main.py | 75 + .../pip/_internal/cli/main_parser.py | 99 + .../site-packages/pip/_internal/cli/parser.py | 265 + .../pip/_internal/cli/req_command.py | 333 + .../pip/_internal/cli/status_codes.py | 8 + .../pip/_internal/commands/__init__.py | 114 + .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 2852 bytes .../commands/__pycache__/check.cpython-38.pyc | Bin 0 -> 1312 bytes .../__pycache__/completion.cpython-38.pyc | Bin 0 -> 3013 bytes .../__pycache__/configuration.cpython-38.pyc | Bin 0 -> 6575 bytes .../commands/__pycache__/debug.cpython-38.pyc | Bin 0 -> 4089 bytes .../__pycache__/download.cpython-38.pyc | Bin 0 -> 3921 bytes .../__pycache__/freeze.cpython-38.pyc | Bin 0 -> 2929 bytes .../commands/__pycache__/hash.cpython-38.pyc | Bin 0 -> 1990 bytes .../commands/__pycache__/help.cpython-38.pyc | Bin 0 -> 1186 bytes .../__pycache__/install.cpython-38.pyc | Bin 0 -> 16661 bytes .../commands/__pycache__/list.cpython-38.pyc | Bin 0 -> 9042 bytes .../__pycache__/search.cpython-38.pyc | Bin 0 -> 4484 bytes .../commands/__pycache__/show.cpython-38.pyc | Bin 0 -> 6325 bytes .../__pycache__/uninstall.cpython-38.pyc | Bin 0 -> 2694 bytes .../commands/__pycache__/wheel.cpython-38.pyc | Bin 0 -> 5246 bytes .../pip/_internal/commands/check.py | 45 + .../pip/_internal/commands/completion.py | 96 + .../pip/_internal/commands/configuration.py | 233 + .../pip/_internal/commands/debug.py | 142 + .../pip/_internal/commands/download.py | 147 + .../pip/_internal/commands/freeze.py | 103 + .../pip/_internal/commands/hash.py | 58 + .../pip/_internal/commands/help.py | 41 + .../pip/_internal/commands/install.py | 727 ++ .../pip/_internal/commands/list.py | 315 + .../pip/_internal/commands/search.py | 145 + .../pip/_internal/commands/show.py | 180 + .../pip/_internal/commands/uninstall.py | 82 + .../pip/_internal/commands/wheel.py | 197 + .../pip/_internal/configuration.py | 422 + .../pip/_internal/distributions/__init__.py | 24 + .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 812 bytes .../__pycache__/base.cpython-38.pyc | Bin 0 -> 1928 bytes .../__pycache__/installed.cpython-38.pyc | Bin 0 -> 1208 bytes .../__pycache__/sdist.cpython-38.pyc | Bin 0 -> 3471 bytes .../__pycache__/wheel.cpython-38.pyc | Bin 0 -> 1560 bytes .../pip/_internal/distributions/base.py | 45 + .../pip/_internal/distributions/installed.py | 24 + .../pip/_internal/distributions/sdist.py | 104 + .../pip/_internal/distributions/wheel.py | 36 + .../site-packages/pip/_internal/exceptions.py | 308 + .../pip/_internal/index/__init__.py | 2 + .../index/__pycache__/__init__.cpython-38.pyc | Bin 0 -> 190 bytes .../__pycache__/collector.cpython-38.pyc | Bin 0 -> 14156 bytes .../__pycache__/package_finder.cpython-38.pyc | Bin 0 -> 25749 bytes .../pip/_internal/index/collector.py | 544 ++ .../pip/_internal/index/package_finder.py | 1013 ++ .../pip/_internal/legacy_resolve.py | 430 + .../site-packages/pip/_internal/locations.py | 194 + .../site-packages/pip/_internal/main.py | 16 + .../pip/_internal/models/__init__.py | 2 + .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 224 bytes .../__pycache__/candidate.cpython-38.pyc | Bin 0 -> 1421 bytes .../__pycache__/format_control.cpython-38.pyc | Bin 0 -> 2416 bytes .../models/__pycache__/index.cpython-38.pyc | Bin 0 -> 1146 bytes .../models/__pycache__/link.cpython-38.pyc | Bin 0 -> 6659 bytes .../models/__pycache__/scheme.cpython-38.pyc | Bin 0 -> 862 bytes .../__pycache__/search_scope.cpython-38.pyc | Bin 0 -> 3253 bytes .../selection_prefs.cpython-38.pyc | Bin 0 -> 1596 bytes .../__pycache__/target_python.cpython-38.pyc | Bin 0 -> 3219 bytes .../models/__pycache__/wheel.cpython-38.pyc | Bin 0 -> 3182 bytes .../pip/_internal/models/candidate.py | 36 + .../pip/_internal/models/format_control.py | 84 + .../pip/_internal/models/index.py | 31 + .../pip/_internal/models/link.py | 227 + .../pip/_internal/models/scheme.py | 25 + .../pip/_internal/models/search_scope.py | 114 + .../pip/_internal/models/selection_prefs.py | 47 + .../pip/_internal/models/target_python.py | 107 + .../pip/_internal/models/wheel.py | 78 + .../pip/_internal/network/__init__.py | 2 + .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 212 bytes .../network/__pycache__/auth.cpython-38.pyc | Bin 0 -> 6978 bytes .../network/__pycache__/cache.cpython-38.pyc | Bin 0 -> 2691 bytes .../__pycache__/download.cpython-38.pyc | Bin 0 -> 4370 bytes .../__pycache__/session.cpython-38.pyc | Bin 0 -> 8851 bytes .../network/__pycache__/utils.cpython-38.pyc | Bin 0 -> 706 bytes .../network/__pycache__/xmlrpc.cpython-38.pyc | Bin 0 -> 1574 bytes .../pip/_internal/network/auth.py | 298 + .../pip/_internal/network/cache.py | 81 + .../pip/_internal/network/download.py | 200 + .../pip/_internal/network/session.py | 405 + .../pip/_internal/network/utils.py | 48 + .../pip/_internal/network/xmlrpc.py | 44 + .../pip/_internal/operations/__init__.py | 0 .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 160 bytes .../__pycache__/check.cpython-38.pyc | Bin 0 -> 3656 bytes .../__pycache__/freeze.cpython-38.pyc | Bin 0 -> 5803 bytes .../__pycache__/prepare.cpython-38.pyc | Bin 0 -> 11162 bytes .../_internal/operations/build/__init__.py | 0 .../build/__pycache__/__init__.cpython-38.pyc | Bin 0 -> 166 bytes .../build/__pycache__/metadata.cpython-38.pyc | Bin 0 -> 1208 bytes .../metadata_legacy.cpython-38.pyc | Bin 0 -> 3268 bytes .../build/__pycache__/wheel.cpython-38.pyc | Bin 0 -> 1306 bytes .../__pycache__/wheel_legacy.cpython-38.pyc | Bin 0 -> 2567 bytes .../_internal/operations/build/metadata.py | 40 + .../operations/build/metadata_legacy.py | 122 + .../pip/_internal/operations/build/wheel.py | 46 + .../operations/build/wheel_legacy.py | 115 + .../pip/_internal/operations/check.py | 163 + .../pip/_internal/operations/freeze.py | 265 + .../_internal/operations/install/__init__.py | 2 + .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 224 bytes .../editable_legacy.cpython-38.pyc | Bin 0 -> 1302 bytes .../install/__pycache__/legacy.cpython-38.pyc | Bin 0 -> 3048 bytes .../install/__pycache__/wheel.cpython-38.pyc | Bin 0 -> 14582 bytes .../operations/install/editable_legacy.py | 52 + .../_internal/operations/install/legacy.py | 129 + .../pip/_internal/operations/install/wheel.py | 615 ++ .../pip/_internal/operations/prepare.py | 591 ++ .../site-packages/pip/_internal/pep425tags.py | 167 + .../site-packages/pip/_internal/pyproject.py | 196 + .../pip/_internal/req/__init__.py | 92 + .../req/__pycache__/__init__.cpython-38.pyc | Bin 0 -> 2194 bytes .../__pycache__/constructors.cpython-38.pyc | Bin 0 -> 10363 bytes .../req/__pycache__/req_file.cpython-38.pyc | Bin 0 -> 12702 bytes .../__pycache__/req_install.cpython-38.pyc | Bin 0 -> 21338 bytes .../req/__pycache__/req_set.cpython-38.pyc | Bin 0 -> 6021 bytes .../__pycache__/req_tracker.cpython-38.pyc | Bin 0 -> 4041 bytes .../__pycache__/req_uninstall.cpython-38.pyc | Bin 0 -> 17427 bytes .../pip/_internal/req/constructors.py | 436 + .../pip/_internal/req/req_file.py | 546 ++ .../pip/_internal/req/req_install.py | 830 ++ .../pip/_internal/req/req_set.py | 209 + .../pip/_internal/req/req_tracker.py | 150 + .../pip/_internal/req/req_uninstall.py | 644 ++ .../pip/_internal/self_outdated_check.py | 242 + .../pip/_internal/utils/__init__.py | 0 .../utils/__pycache__/__init__.cpython-38.pyc | Bin 0 -> 155 bytes .../utils/__pycache__/appdirs.cpython-38.pyc | Bin 0 -> 1351 bytes .../utils/__pycache__/compat.cpython-38.pyc | Bin 0 -> 6120 bytes .../__pycache__/deprecation.cpython-38.pyc | Bin 0 -> 2826 bytes .../__pycache__/distutils_args.cpython-38.pyc | Bin 0 -> 1139 bytes .../utils/__pycache__/encoding.cpython-38.pyc | Bin 0 -> 1247 bytes .../__pycache__/entrypoints.cpython-38.pyc | Bin 0 -> 1299 bytes .../__pycache__/filesystem.cpython-38.pyc | Bin 0 -> 4035 bytes .../__pycache__/filetypes.cpython-38.pyc | Bin 0 -> 556 bytes .../utils/__pycache__/glibc.cpython-38.pyc | Bin 0 -> 1708 bytes .../utils/__pycache__/hashes.cpython-38.pyc | Bin 0 -> 4144 bytes .../inject_securetransport.cpython-38.pyc | Bin 0 -> 932 bytes .../utils/__pycache__/logging.cpython-38.pyc | Bin 0 -> 9159 bytes .../__pycache__/marker_files.cpython-38.pyc | Bin 0 -> 928 bytes .../utils/__pycache__/misc.cpython-38.pyc | Bin 0 -> 23778 bytes .../utils/__pycache__/models.cpython-38.pyc | Bin 0 -> 1924 bytes .../__pycache__/packaging.cpython-38.pyc | Bin 0 -> 2608 bytes .../__pycache__/pkg_resources.cpython-38.pyc | Bin 0 -> 1822 bytes .../setuptools_build.cpython-38.pyc | Bin 0 -> 2927 bytes .../__pycache__/subprocess.cpython-38.pyc | Bin 0 -> 5598 bytes .../utils/__pycache__/temp_dir.cpython-38.pyc | Bin 0 -> 6711 bytes .../utils/__pycache__/typing.cpython-38.pyc | Bin 0 -> 1437 bytes .../utils/__pycache__/ui.cpython-38.pyc | Bin 0 -> 11802 bytes .../__pycache__/unpacking.cpython-38.pyc | Bin 0 -> 6075 bytes .../utils/__pycache__/urls.cpython-38.pyc | Bin 0 -> 1465 bytes .../__pycache__/virtualenv.cpython-38.pyc | Bin 0 -> 3280 bytes .../utils/__pycache__/wheel.cpython-38.pyc | Bin 0 -> 6325 bytes .../pip/_internal/utils/appdirs.py | 44 + .../pip/_internal/utils/compat.py | 269 + .../pip/_internal/utils/deprecation.py | 104 + .../pip/_internal/utils/distutils_args.py | 48 + .../pip/_internal/utils/encoding.py | 42 + .../pip/_internal/utils/entrypoints.py | 31 + .../pip/_internal/utils/filesystem.py | 171 + .../pip/_internal/utils/filetypes.py | 16 + .../pip/_internal/utils/glibc.py | 98 + .../pip/_internal/utils/hashes.py | 131 + .../_internal/utils/inject_securetransport.py | 36 + .../pip/_internal/utils/logging.py | 398 + .../pip/_internal/utils/marker_files.py | 25 + .../site-packages/pip/_internal/utils/misc.py | 904 ++ .../pip/_internal/utils/models.py | 42 + .../pip/_internal/utils/packaging.py | 94 + .../pip/_internal/utils/pkg_resources.py | 44 + .../pip/_internal/utils/setuptools_build.py | 181 + .../pip/_internal/utils/subprocess.py | 278 + .../pip/_internal/utils/temp_dir.py | 250 + .../pip/_internal/utils/typing.py | 38 + .../site-packages/pip/_internal/utils/ui.py | 428 + .../pip/_internal/utils/unpacking.py | 272 + .../site-packages/pip/_internal/utils/urls.py | 54 + .../pip/_internal/utils/virtualenv.py | 115 + .../pip/_internal/utils/wheel.py | 225 + .../pip/_internal/vcs/__init__.py | 15 + .../vcs/__pycache__/__init__.cpython-38.pyc | Bin 0 -> 448 bytes .../vcs/__pycache__/bazaar.cpython-38.pyc | Bin 0 -> 3747 bytes .../vcs/__pycache__/git.cpython-38.pyc | Bin 0 -> 9559 bytes .../vcs/__pycache__/mercurial.cpython-38.pyc | Bin 0 -> 4888 bytes .../vcs/__pycache__/subversion.cpython-38.pyc | Bin 0 -> 8487 bytes .../__pycache__/versioncontrol.cpython-38.pyc | Bin 0 -> 19216 bytes .../site-packages/pip/_internal/vcs/bazaar.py | 120 + .../site-packages/pip/_internal/vcs/git.py | 395 + .../pip/_internal/vcs/mercurial.py | 155 + .../pip/_internal/vcs/subversion.py | 333 + .../pip/_internal/vcs/versioncontrol.py | 700 ++ .../pip/_internal/wheel_builder.py | 305 + .../site-packages/pip/_vendor/__init__.py | 119 + .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 3037 bytes .../pkg_resources-0.0.0.dist-info/AUTHORS.txt | 562 ++ .../pkg_resources-0.0.0.dist-info/INSTALLER | 1 + .../pkg_resources-0.0.0.dist-info/LICENSE.txt | 20 + .../pkg_resources-0.0.0.dist-info/METADATA | 13 + .../pkg_resources-0.0.0.dist-info/RECORD | 38 + .../pkg_resources-0.0.0.dist-info/WHEEL | 6 + .../site-packages/pkg_resources/__init__.py | 3296 +++++++ .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 100356 bytes .../__pycache__/py31compat.cpython-38.pyc | Bin 0 -> 600 bytes .../pkg_resources/_vendor/__init__.py | 0 .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 157 bytes .../__pycache__/appdirs.cpython-38.pyc | Bin 0 -> 20510 bytes .../__pycache__/pyparsing.cpython-38.pyc | Bin 0 -> 201634 bytes .../_vendor/__pycache__/six.cpython-38.pyc | Bin 0 -> 24430 bytes .../pkg_resources/_vendor/appdirs.py | 608 ++ .../_vendor/packaging/__about__.py | 21 + .../_vendor/packaging/__init__.py | 14 + .../__pycache__/__about__.cpython-38.pyc | Bin 0 -> 707 bytes .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 545 bytes .../__pycache__/_compat.cpython-38.pyc | Bin 0 -> 981 bytes .../__pycache__/_structures.cpython-38.pyc | Bin 0 -> 2763 bytes .../__pycache__/markers.cpython-38.pyc | Bin 0 -> 8919 bytes .../__pycache__/requirements.cpython-38.pyc | Bin 0 -> 3878 bytes .../__pycache__/specifiers.cpython-38.pyc | Bin 0 -> 19787 bytes .../__pycache__/utils.cpython-38.pyc | Bin 0 -> 466 bytes .../__pycache__/version.cpython-38.pyc | Bin 0 -> 10634 bytes .../_vendor/packaging/_compat.py | 30 + .../_vendor/packaging/_structures.py | 68 + .../_vendor/packaging/markers.py | 301 + .../_vendor/packaging/requirements.py | 127 + .../_vendor/packaging/specifiers.py | 774 ++ .../pkg_resources/_vendor/packaging/utils.py | 14 + .../_vendor/packaging/version.py | 393 + .../pkg_resources/_vendor/pyparsing.py | 5742 +++++++++++ .../pkg_resources/_vendor/six.py | 868 ++ .../pkg_resources/extern/__init__.py | 73 + .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 2406 bytes .../site-packages/pkg_resources/py31compat.py | 23 + .../requests-2.26.0.dist-info/INSTALLER | 1 + .../requests-2.26.0.dist-info/LICENSE | 175 + .../requests-2.26.0.dist-info/METADATA | 120 + .../requests-2.26.0.dist-info/RECORD | 42 + .../requests-2.26.0.dist-info/WHEEL | 6 + .../requests-2.26.0.dist-info/top_level.txt | 1 + .../site-packages/requests/__init__.py | 152 + .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 3850 bytes .../__pycache__/__version__.cpython-38.pyc | Bin 0 -> 507 bytes .../_internal_utils.cpython-38.pyc | Bin 0 -> 1272 bytes .../__pycache__/adapters.cpython-38.pyc | Bin 0 -> 16863 bytes .../requests/__pycache__/api.cpython-38.pyc | Bin 0 -> 6647 bytes .../requests/__pycache__/auth.cpython-38.pyc | Bin 0 -> 8291 bytes .../requests/__pycache__/certs.cpython-38.pyc | Bin 0 -> 573 bytes .../__pycache__/compat.cpython-38.pyc | Bin 0 -> 1667 bytes .../__pycache__/cookies.cpython-38.pyc | Bin 0 -> 18786 bytes .../__pycache__/exceptions.cpython-38.pyc | Bin 0 -> 5341 bytes .../requests/__pycache__/help.cpython-38.pyc | Bin 0 -> 2845 bytes .../requests/__pycache__/hooks.cpython-38.pyc | Bin 0 -> 944 bytes .../__pycache__/models.cpython-38.pyc | Bin 0 -> 24428 bytes .../__pycache__/packages.cpython-38.pyc | Bin 0 -> 651 bytes .../__pycache__/sessions.cpython-38.pyc | Bin 0 -> 19887 bytes .../__pycache__/status_codes.cpython-38.pyc | Bin 0 -> 4199 bytes .../__pycache__/structures.cpython-38.pyc | Bin 0 -> 4412 bytes .../requests/__pycache__/utils.cpython-38.pyc | Bin 0 -> 23213 bytes .../site-packages/requests/__version__.py | 14 + .../site-packages/requests/_internal_utils.py | 42 + .../site-packages/requests/adapters.py | 533 ++ .../python3.8/site-packages/requests/api.py | 159 + .../python3.8/site-packages/requests/auth.py | 305 + .../python3.8/site-packages/requests/certs.py | 18 + .../site-packages/requests/compat.py | 75 + .../site-packages/requests/cookies.py | 549 ++ .../site-packages/requests/exceptions.py | 127 + .../python3.8/site-packages/requests/help.py | 135 + .../python3.8/site-packages/requests/hooks.py | 34 + .../site-packages/requests/models.py | 966 ++ .../site-packages/requests/packages.py | 26 + .../site-packages/requests/sessions.py | 781 ++ .../site-packages/requests/status_codes.py | 123 + .../site-packages/requests/structures.py | 105 + .../python3.8/site-packages/requests/utils.py | 1013 ++ .../setuptools-44.0.0.dist-info/AUTHORS.txt | 562 ++ .../setuptools-44.0.0.dist-info/INSTALLER | 1 + .../setuptools-44.0.0.dist-info/LICENSE.txt | 20 + .../setuptools-44.0.0.dist-info/METADATA | 82 + .../setuptools-44.0.0.dist-info/RECORD | 163 + .../setuptools-44.0.0.dist-info/WHEEL | 6 + .../dependency_links.txt | 2 + .../entry_points.txt | 68 + .../setuptools-44.0.0.dist-info/top_level.txt | 3 + .../setuptools-44.0.0.dist-info/zip-safe | 1 + .../site-packages/setuptools/__init__.py | 228 + .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 7768 bytes .../_deprecation_warning.cpython-38.pyc | Bin 0 -> 516 bytes .../__pycache__/_imp.cpython-38.pyc | Bin 0 -> 1890 bytes .../__pycache__/archive_util.cpython-38.pyc | Bin 0 -> 5128 bytes .../__pycache__/build_meta.cpython-38.pyc | Bin 0 -> 8495 bytes .../__pycache__/config.cpython-38.pyc | Bin 0 -> 17896 bytes .../__pycache__/dep_util.cpython-38.pyc | Bin 0 -> 819 bytes .../__pycache__/depends.cpython-38.pyc | Bin 0 -> 5216 bytes .../__pycache__/dist.cpython-38.pyc | Bin 0 -> 42326 bytes .../__pycache__/errors.cpython-38.pyc | Bin 0 -> 816 bytes .../__pycache__/extension.cpython-38.pyc | Bin 0 -> 1961 bytes .../__pycache__/glob.cpython-38.pyc | Bin 0 -> 3733 bytes .../__pycache__/installer.cpython-38.pyc | Bin 0 -> 4102 bytes .../__pycache__/launch.cpython-38.pyc | Bin 0 -> 824 bytes .../__pycache__/lib2to3_ex.cpython-38.pyc | Bin 0 -> 2411 bytes .../__pycache__/monkey.cpython-38.pyc | Bin 0 -> 4644 bytes .../__pycache__/msvc.cpython-38.pyc | Bin 0 -> 39631 bytes .../__pycache__/namespaces.cpython-38.pyc | Bin 0 -> 3616 bytes .../__pycache__/package_index.cpython-38.pyc | Bin 0 -> 32970 bytes .../__pycache__/py27compat.cpython-38.pyc | Bin 0 -> 1749 bytes .../__pycache__/py31compat.cpython-38.pyc | Bin 0 -> 1191 bytes .../__pycache__/py33compat.cpython-38.pyc | Bin 0 -> 1408 bytes .../__pycache__/py34compat.cpython-38.pyc | Bin 0 -> 450 bytes .../__pycache__/sandbox.cpython-38.pyc | Bin 0 -> 15536 bytes .../__pycache__/site-patch.cpython-38.pyc | Bin 0 -> 1474 bytes .../__pycache__/ssl_support.cpython-38.pyc | Bin 0 -> 6855 bytes .../__pycache__/unicode_utils.cpython-38.pyc | Bin 0 -> 1151 bytes .../__pycache__/version.cpython-38.pyc | Bin 0 -> 292 bytes .../__pycache__/wheel.cpython-38.pyc | Bin 0 -> 7383 bytes .../windows_support.cpython-38.pyc | Bin 0 -> 989 bytes .../setuptools/_deprecation_warning.py | 7 + .../site-packages/setuptools/_imp.py | 73 + .../setuptools/_vendor/__init__.py | 0 .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 154 bytes .../__pycache__/ordered_set.cpython-38.pyc | Bin 0 -> 16412 bytes .../__pycache__/pyparsing.cpython-38.pyc | Bin 0 -> 201631 bytes .../_vendor/__pycache__/six.cpython-38.pyc | Bin 0 -> 24427 bytes .../setuptools/_vendor/ordered_set.py | 488 + .../setuptools/_vendor/packaging/__about__.py | 27 + .../setuptools/_vendor/packaging/__init__.py | 26 + .../__pycache__/__about__.cpython-38.pyc | Bin 0 -> 704 bytes .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 542 bytes .../__pycache__/_compat.cpython-38.pyc | Bin 0 -> 978 bytes .../__pycache__/_structures.cpython-38.pyc | Bin 0 -> 2760 bytes .../__pycache__/markers.cpython-38.pyc | Bin 0 -> 8927 bytes .../__pycache__/requirements.cpython-38.pyc | Bin 0 -> 3995 bytes .../__pycache__/specifiers.cpython-38.pyc | Bin 0 -> 19734 bytes .../packaging/__pycache__/tags.cpython-38.pyc | Bin 0 -> 10811 bytes .../__pycache__/utils.cpython-38.pyc | Bin 0 -> 1435 bytes .../__pycache__/version.cpython-38.pyc | Bin 0 -> 12065 bytes .../setuptools/_vendor/packaging/_compat.py | 31 + .../_vendor/packaging/_structures.py | 68 + .../setuptools/_vendor/packaging/markers.py | 296 + .../_vendor/packaging/requirements.py | 138 + .../_vendor/packaging/specifiers.py | 749 ++ .../setuptools/_vendor/packaging/tags.py | 404 + .../setuptools/_vendor/packaging/utils.py | 57 + .../setuptools/_vendor/packaging/version.py | 420 + .../setuptools/_vendor/pyparsing.py | 5742 +++++++++++ .../site-packages/setuptools/_vendor/six.py | 868 ++ .../site-packages/setuptools/archive_util.py | 173 + .../site-packages/setuptools/build_meta.py | 257 + .../site-packages/setuptools/cli-32.exe | Bin 0 -> 65536 bytes .../site-packages/setuptools/cli-64.exe | Bin 0 -> 74752 bytes .../site-packages/setuptools/cli.exe | Bin 0 -> 65536 bytes .../setuptools/command/__init__.py | 17 + .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 712 bytes .../command/__pycache__/alias.cpython-38.pyc | Bin 0 -> 2392 bytes .../__pycache__/bdist_egg.cpython-38.pyc | Bin 0 -> 14182 bytes .../__pycache__/bdist_rpm.cpython-38.pyc | Bin 0 -> 1784 bytes .../__pycache__/bdist_wininst.cpython-38.pyc | Bin 0 -> 954 bytes .../__pycache__/build_clib.cpython-38.pyc | Bin 0 -> 2437 bytes .../__pycache__/build_ext.cpython-38.pyc | Bin 0 -> 9895 bytes .../__pycache__/build_py.cpython-38.pyc | Bin 0 -> 8641 bytes .../__pycache__/develop.cpython-38.pyc | Bin 0 -> 6501 bytes .../__pycache__/dist_info.cpython-38.pyc | Bin 0 -> 1361 bytes .../__pycache__/easy_install.cpython-38.pyc | Bin 0 -> 66694 bytes .../__pycache__/egg_info.cpython-38.pyc | Bin 0 -> 21773 bytes .../__pycache__/install.cpython-38.pyc | Bin 0 -> 4016 bytes .../install_egg_info.cpython-38.pyc | Bin 0 -> 2900 bytes .../__pycache__/install_lib.cpython-38.pyc | Bin 0 -> 5083 bytes .../install_scripts.cpython-38.pyc | Bin 0 -> 2273 bytes .../__pycache__/py36compat.cpython-38.pyc | Bin 0 -> 4610 bytes .../__pycache__/register.cpython-38.pyc | Bin 0 -> 811 bytes .../command/__pycache__/rotate.cpython-38.pyc | Bin 0 -> 2520 bytes .../__pycache__/saveopts.cpython-38.pyc | Bin 0 -> 889 bytes .../command/__pycache__/sdist.cpython-38.pyc | Bin 0 -> 7859 bytes .../command/__pycache__/setopt.cpython-38.pyc | Bin 0 -> 4537 bytes .../command/__pycache__/test.cpython-38.pyc | Bin 0 -> 8475 bytes .../command/__pycache__/upload.cpython-38.pyc | Bin 0 -> 784 bytes .../__pycache__/upload_docs.cpython-38.pyc | Bin 0 -> 6140 bytes .../site-packages/setuptools/command/alias.py | 80 + .../setuptools/command/bdist_egg.py | 502 + .../setuptools/command/bdist_rpm.py | 43 + .../setuptools/command/bdist_wininst.py | 21 + .../setuptools/command/build_clib.py | 98 + .../setuptools/command/build_ext.py | 327 + .../setuptools/command/build_py.py | 270 + .../setuptools/command/develop.py | 221 + .../setuptools/command/dist_info.py | 36 + .../setuptools/command/easy_install.py | 2402 +++++ .../setuptools/command/egg_info.py | 717 ++ .../setuptools/command/install.py | 125 + .../setuptools/command/install_egg_info.py | 82 + .../setuptools/command/install_lib.py | 147 + .../setuptools/command/install_scripts.py | 65 + .../setuptools/command/launcher manifest.xml | 15 + .../setuptools/command/py36compat.py | 136 + .../setuptools/command/register.py | 18 + .../setuptools/command/rotate.py | 66 + .../setuptools/command/saveopts.py | 22 + .../site-packages/setuptools/command/sdist.py | 252 + .../setuptools/command/setopt.py | 149 + .../site-packages/setuptools/command/test.py | 279 + .../setuptools/command/upload.py | 17 + .../setuptools/command/upload_docs.py | 206 + .../site-packages/setuptools/config.py | 659 ++ .../site-packages/setuptools/dep_util.py | 23 + .../site-packages/setuptools/depends.py | 176 + .../site-packages/setuptools/dist.py | 1274 +++ .../site-packages/setuptools/errors.py | 16 + .../site-packages/setuptools/extension.py | 57 + .../setuptools/extern/__init__.py | 73 + .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 2420 bytes .../site-packages/setuptools/glob.py | 174 + .../site-packages/setuptools/gui-32.exe | Bin 0 -> 65536 bytes .../site-packages/setuptools/gui-64.exe | Bin 0 -> 75264 bytes .../site-packages/setuptools/gui.exe | Bin 0 -> 65536 bytes .../site-packages/setuptools/installer.py | 150 + .../site-packages/setuptools/launch.py | 35 + .../site-packages/setuptools/lib2to3_ex.py | 62 + .../site-packages/setuptools/monkey.py | 179 + .../site-packages/setuptools/msvc.py | 1679 ++++ .../site-packages/setuptools/namespaces.py | 107 + .../site-packages/setuptools/package_index.py | 1136 +++ .../site-packages/setuptools/py27compat.py | 60 + .../site-packages/setuptools/py31compat.py | 32 + .../site-packages/setuptools/py33compat.py | 59 + .../site-packages/setuptools/py34compat.py | 13 + .../site-packages/setuptools/sandbox.py | 491 + .../setuptools/script (dev).tmpl | 6 + .../site-packages/setuptools/script.tmpl | 3 + .../site-packages/setuptools/site-patch.py | 74 + .../site-packages/setuptools/ssl_support.py | 260 + .../site-packages/setuptools/unicode_utils.py | 44 + .../site-packages/setuptools/version.py | 6 + .../site-packages/setuptools/wheel.py | 220 + .../setuptools/windows_support.py | 29 + .../urllib3-1.26.6.dist-info/INSTALLER | 1 + .../urllib3-1.26.6.dist-info/LICENSE.txt | 21 + .../urllib3-1.26.6.dist-info/METADATA | 1388 +++ .../urllib3-1.26.6.dist-info/RECORD | 84 + .../urllib3-1.26.6.dist-info/WHEEL | 6 + .../urllib3-1.26.6.dist-info/top_level.txt | 1 + .../site-packages/urllib3/__init__.py | 85 + .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 2141 bytes .../__pycache__/_collections.cpython-38.pyc | Bin 0 -> 10654 bytes .../__pycache__/_version.cpython-38.pyc | Bin 0 -> 165 bytes .../__pycache__/connection.cpython-38.pyc | Bin 0 -> 13332 bytes .../__pycache__/connectionpool.cpython-38.pyc | Bin 0 -> 24404 bytes .../__pycache__/exceptions.cpython-38.pyc | Bin 0 -> 11598 bytes .../urllib3/__pycache__/fields.cpython-38.pyc | Bin 0 -> 8135 bytes .../__pycache__/filepost.cpython-38.pyc | Bin 0 -> 2722 bytes .../__pycache__/poolmanager.cpython-38.pyc | Bin 0 -> 15080 bytes .../__pycache__/request.cpython-38.pyc | Bin 0 -> 5578 bytes .../__pycache__/response.cpython-38.pyc | Bin 0 -> 20678 bytes .../site-packages/urllib3/_collections.py | 337 + .../site-packages/urllib3/_version.py | 2 + .../site-packages/urllib3/connection.py | 539 ++ .../site-packages/urllib3/connectionpool.py | 1067 +++ .../site-packages/urllib3/contrib/__init__.py | 0 .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 151 bytes .../_appengine_environ.cpython-38.pyc | Bin 0 -> 1375 bytes .../__pycache__/appengine.cpython-38.pyc | Bin 0 -> 8200 bytes .../__pycache__/ntlmpool.cpython-38.pyc | Bin 0 -> 3594 bytes .../__pycache__/pyopenssl.cpython-38.pyc | Bin 0 -> 15528 bytes .../securetransport.cpython-38.pyc | Bin 0 -> 21573 bytes .../contrib/__pycache__/socks.cpython-38.pyc | Bin 0 -> 5589 bytes .../urllib3/contrib/_appengine_environ.py | 36 + .../contrib/_securetransport/__init__.py | 0 .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 168 bytes .../__pycache__/bindings.cpython-38.pyc | Bin 0 -> 10689 bytes .../__pycache__/low_level.cpython-38.pyc | Bin 0 -> 9056 bytes .../contrib/_securetransport/bindings.py | 519 + .../contrib/_securetransport/low_level.py | 396 + .../urllib3/contrib/appengine.py | 314 + .../site-packages/urllib3/contrib/ntlmpool.py | 130 + .../urllib3/contrib/pyopenssl.py | 511 + .../urllib3/contrib/securetransport.py | 922 ++ .../site-packages/urllib3/contrib/socks.py | 216 + .../site-packages/urllib3/exceptions.py | 323 + .../python3.8/site-packages/urllib3/fields.py | 274 + .../site-packages/urllib3/filepost.py | 98 + .../urllib3/packages/__init__.py | 5 + .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 265 bytes .../packages/__pycache__/six.cpython-38.pyc | Bin 0 -> 27547 bytes .../urllib3/packages/backports/__init__.py | 0 .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 162 bytes .../__pycache__/makefile.cpython-38.pyc | Bin 0 -> 1266 bytes .../urllib3/packages/backports/makefile.py | 51 + .../site-packages/urllib3/packages/six.py | 1077 +++ .../packages/ssl_match_hostname/__init__.py | 24 + .../__pycache__/__init__.cpython-38.pyc | Bin 0 -> 528 bytes .../_implementation.cpython-38.pyc | Bin 0 -> 3263 bytes .../ssl_match_hostname/_implementation.py | 160 + .../site-packages/urllib3/poolmanager.py | 536 ++ .../site-packages/urllib3/request.py | 170 + .../site-packages/urllib3/response.py | 821 ++ .../site-packages/urllib3/util/__init__.py | 49 + .../util/__pycache__/__init__.cpython-38.pyc | Bin 0 -> 1061 bytes .../__pycache__/connection.cpython-38.pyc | Bin 0 -> 3407 bytes .../util/__pycache__/proxy.cpython-38.pyc | Bin 0 -> 1305 bytes .../util/__pycache__/queue.cpython-38.pyc | Bin 0 -> 1016 bytes .../util/__pycache__/request.cpython-38.pyc | Bin 0 -> 3410 bytes .../util/__pycache__/response.cpython-38.pyc | Bin 0 -> 2309 bytes .../util/__pycache__/retry.cpython-38.pyc | Bin 0 -> 15804 bytes .../util/__pycache__/ssl_.cpython-38.pyc | Bin 0 -> 11336 bytes .../__pycache__/ssltransport.cpython-38.pyc | Bin 0 -> 7406 bytes .../util/__pycache__/timeout.cpython-38.pyc | Bin 0 -> 8903 bytes .../util/__pycache__/url.cpython-38.pyc | Bin 0 -> 10706 bytes .../util/__pycache__/wait.cpython-38.pyc | Bin 0 -> 3063 bytes .../site-packages/urllib3/util/connection.py | 150 + .../site-packages/urllib3/util/proxy.py | 56 + .../site-packages/urllib3/util/queue.py | 22 + .../site-packages/urllib3/util/request.py | 143 + .../site-packages/urllib3/util/response.py | 107 + .../site-packages/urllib3/util/retry.py | 602 ++ .../site-packages/urllib3/util/ssl_.py | 495 + .../urllib3/util/ssltransport.py | 221 + .../site-packages/urllib3/util/timeout.py | 268 + .../site-packages/urllib3/util/url.py | 432 + .../site-packages/urllib3/util/wait.py | 153 + venv/lib64 | 1 + venv/pyvenv.cfg | 3 + .../CacheControl-0.12.6-py2.py3-none-any.whl | Bin 0 -> 28023 bytes .../appdirs-1.4.3-py2.py3-none-any.whl | Bin 0 -> 18776 bytes .../certifi-2019.11.28-py2.py3-none-any.whl | Bin 0 -> 164552 bytes .../chardet-3.0.4-py2.py3-none-any.whl | Bin 0 -> 141487 bytes .../colorama-0.4.3-py2.py3-none-any.whl | Bin 0 -> 25094 bytes .../contextlib2-0.6.0-py2.py3-none-any.whl | Bin 0 -> 17188 bytes .../distlib-0.3.0-py2.py3-none-any.whl | Bin 0 -> 152027 bytes .../distro-1.4.0-py2.py3-none-any.whl | Bin 0 -> 23898 bytes .../html5lib-1.0.1-py2.py3-none-any.whl | Bin 0 -> 120020 bytes .../idna-2.8-py2.py3-none-any.whl | Bin 0 -> 66836 bytes .../ipaddr-2.2.0-py2.py3-none-any.whl | Bin 0 -> 24287 bytes .../lockfile-0.12.2-py2.py3-none-any.whl | Bin 0 -> 21972 bytes .../msgpack-0.6.2-py2.py3-none-any.whl | Bin 0 -> 92927 bytes .../packaging-20.3-py2.py3-none-any.whl | Bin 0 -> 42242 bytes .../pep517-0.8.2-py2.py3-none-any.whl | Bin 0 -> 26686 bytes .../pip-20.0.2-py2.py3-none-any.whl | Bin 0 -> 262434 bytes .../pkg_resources-0.0.0-py2.py3-none-any.whl | Bin 0 -> 127312 bytes .../progress-1.5-py2.py3-none-any.whl | Bin 0 -> 17547 bytes .../pyparsing-2.4.6-py2.py3-none-any.whl | Bin 0 -> 77093 bytes .../requests-2.22.0-py2.py3-none-any.whl | Bin 0 -> 67470 bytes .../retrying-1.3.3-py2.py3-none-any.whl | Bin 0 -> 16358 bytes .../setuptools-44.0.0-py2.py3-none-any.whl | Bin 0 -> 477446 bytes .../six-1.14.0-py2.py3-none-any.whl | Bin 0 -> 20256 bytes .../toml-0.10.0-py2.py3-none-any.whl | Bin 0 -> 24106 bytes .../urllib3-1.25.8-py2.py3-none-any.whl | Bin 0 -> 127041 bytes .../webencodings-0.5.1-py2.py3-none-any.whl | Bin 0 -> 20484 bytes .../wheel-0.34.2-py2.py3-none-any.whl | Bin 0 -> 35611 bytes 677 files changed, 97677 insertions(+) create mode 100644 venv/bin/Activate.ps1 create mode 100644 venv/bin/activate create mode 100644 venv/bin/activate.csh create mode 100644 venv/bin/activate.fish create mode 100755 venv/bin/easy_install create mode 100755 venv/bin/easy_install-3.8 create mode 100755 venv/bin/normalizer create mode 100755 venv/bin/pip create mode 100755 venv/bin/pip3 create mode 100755 venv/bin/pip3.8 create mode 120000 venv/bin/python create mode 120000 venv/bin/python3 create mode 100644 venv/lib/python3.8/site-packages/__pycache__/easy_install.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/certifi-2021.5.30.dist-info/INSTALLER create mode 100644 venv/lib/python3.8/site-packages/certifi-2021.5.30.dist-info/LICENSE create mode 100644 venv/lib/python3.8/site-packages/certifi-2021.5.30.dist-info/METADATA create mode 100644 venv/lib/python3.8/site-packages/certifi-2021.5.30.dist-info/RECORD create mode 100644 venv/lib/python3.8/site-packages/certifi-2021.5.30.dist-info/WHEEL create mode 100644 venv/lib/python3.8/site-packages/certifi-2021.5.30.dist-info/top_level.txt create mode 100644 venv/lib/python3.8/site-packages/certifi/__init__.py create mode 100644 venv/lib/python3.8/site-packages/certifi/__main__.py create mode 100644 venv/lib/python3.8/site-packages/certifi/__pycache__/__init__.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/certifi/__pycache__/__main__.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/certifi/__pycache__/core.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/certifi/cacert.pem create mode 100644 venv/lib/python3.8/site-packages/certifi/core.py create mode 100644 venv/lib/python3.8/site-packages/charset_normalizer-2.0.3.dist-info/INSTALLER create mode 100644 venv/lib/python3.8/site-packages/charset_normalizer-2.0.3.dist-info/LICENSE create mode 100644 venv/lib/python3.8/site-packages/charset_normalizer-2.0.3.dist-info/METADATA create mode 100644 venv/lib/python3.8/site-packages/charset_normalizer-2.0.3.dist-info/RECORD create mode 100644 venv/lib/python3.8/site-packages/charset_normalizer-2.0.3.dist-info/WHEEL create mode 100644 venv/lib/python3.8/site-packages/charset_normalizer-2.0.3.dist-info/entry_points.txt create mode 100644 venv/lib/python3.8/site-packages/charset_normalizer-2.0.3.dist-info/top_level.txt create mode 100644 venv/lib/python3.8/site-packages/charset_normalizer/__init__.py create mode 100644 venv/lib/python3.8/site-packages/charset_normalizer/__pycache__/__init__.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/charset_normalizer/__pycache__/api.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/charset_normalizer/__pycache__/cd.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/charset_normalizer/__pycache__/constant.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/charset_normalizer/__pycache__/legacy.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/charset_normalizer/__pycache__/md.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/charset_normalizer/__pycache__/models.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/charset_normalizer/__pycache__/utils.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/charset_normalizer/__pycache__/version.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/charset_normalizer/api.py create mode 100644 venv/lib/python3.8/site-packages/charset_normalizer/assets/__init__.py create mode 100644 venv/lib/python3.8/site-packages/charset_normalizer/assets/__pycache__/__init__.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/charset_normalizer/cd.py create mode 100644 venv/lib/python3.8/site-packages/charset_normalizer/cli/__init__.py create mode 100644 venv/lib/python3.8/site-packages/charset_normalizer/cli/__pycache__/__init__.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/charset_normalizer/cli/__pycache__/normalizer.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/charset_normalizer/cli/normalizer.py create mode 100644 venv/lib/python3.8/site-packages/charset_normalizer/constant.py create mode 100644 venv/lib/python3.8/site-packages/charset_normalizer/legacy.py create mode 100644 venv/lib/python3.8/site-packages/charset_normalizer/md.py create mode 100644 venv/lib/python3.8/site-packages/charset_normalizer/models.py create mode 100644 venv/lib/python3.8/site-packages/charset_normalizer/py.typed create mode 100644 venv/lib/python3.8/site-packages/charset_normalizer/utils.py create mode 100644 venv/lib/python3.8/site-packages/charset_normalizer/version.py create mode 100644 venv/lib/python3.8/site-packages/easy_install.py create mode 100644 venv/lib/python3.8/site-packages/idna-3.2.dist-info/INSTALLER create mode 100644 venv/lib/python3.8/site-packages/idna-3.2.dist-info/LICENSE.md create mode 100644 venv/lib/python3.8/site-packages/idna-3.2.dist-info/METADATA create mode 100644 venv/lib/python3.8/site-packages/idna-3.2.dist-info/RECORD create mode 100644 venv/lib/python3.8/site-packages/idna-3.2.dist-info/WHEEL create mode 100644 venv/lib/python3.8/site-packages/idna-3.2.dist-info/top_level.txt create mode 100644 venv/lib/python3.8/site-packages/idna/__init__.py create mode 100644 venv/lib/python3.8/site-packages/idna/__pycache__/__init__.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/idna/__pycache__/codec.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/idna/__pycache__/compat.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/idna/__pycache__/core.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/idna/__pycache__/idnadata.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/idna/__pycache__/intranges.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/idna/__pycache__/package_data.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/idna/__pycache__/uts46data.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/idna/codec.py create mode 100644 venv/lib/python3.8/site-packages/idna/compat.py create mode 100644 venv/lib/python3.8/site-packages/idna/core.py create mode 100644 venv/lib/python3.8/site-packages/idna/idnadata.py create mode 100644 venv/lib/python3.8/site-packages/idna/intranges.py create mode 100644 venv/lib/python3.8/site-packages/idna/package_data.py create mode 100644 venv/lib/python3.8/site-packages/idna/py.typed create mode 100644 venv/lib/python3.8/site-packages/idna/uts46data.py create mode 100644 venv/lib/python3.8/site-packages/pip-20.0.2.dist-info/INSTALLER create mode 100644 venv/lib/python3.8/site-packages/pip-20.0.2.dist-info/LICENSE.txt create mode 100644 venv/lib/python3.8/site-packages/pip-20.0.2.dist-info/METADATA create mode 100644 venv/lib/python3.8/site-packages/pip-20.0.2.dist-info/RECORD create mode 100644 venv/lib/python3.8/site-packages/pip-20.0.2.dist-info/WHEEL create mode 100644 venv/lib/python3.8/site-packages/pip-20.0.2.dist-info/entry_points.txt create mode 100644 venv/lib/python3.8/site-packages/pip-20.0.2.dist-info/top_level.txt create mode 100644 venv/lib/python3.8/site-packages/pip/__init__.py create mode 100644 venv/lib/python3.8/site-packages/pip/__main__.py create mode 100644 venv/lib/python3.8/site-packages/pip/__pycache__/__init__.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/__pycache__/__main__.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/__init__.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/__pycache__/__init__.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/__pycache__/build_env.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/__pycache__/cache.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/__pycache__/configuration.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/__pycache__/exceptions.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/__pycache__/legacy_resolve.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/__pycache__/locations.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/__pycache__/main.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/__pycache__/pep425tags.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/__pycache__/pyproject.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/__pycache__/self_outdated_check.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/__pycache__/wheel_builder.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/build_env.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/cache.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/cli/__init__.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/cli/__pycache__/__init__.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/cli/__pycache__/autocompletion.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/cli/__pycache__/base_command.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/cli/__pycache__/cmdoptions.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/cli/__pycache__/command_context.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/cli/__pycache__/main.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/cli/__pycache__/main_parser.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/cli/__pycache__/parser.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/cli/__pycache__/req_command.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/cli/__pycache__/status_codes.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/cli/autocompletion.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/cli/base_command.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/cli/cmdoptions.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/cli/command_context.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/cli/main.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/cli/main_parser.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/cli/parser.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/cli/req_command.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/cli/status_codes.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/commands/__init__.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/__init__.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/check.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/completion.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/configuration.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/debug.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/download.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/freeze.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/hash.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/help.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/install.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/list.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/search.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/show.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/uninstall.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/wheel.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/commands/check.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/commands/completion.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/commands/configuration.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/commands/debug.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/commands/download.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/commands/freeze.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/commands/hash.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/commands/help.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/commands/install.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/commands/list.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/commands/search.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/commands/show.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/commands/uninstall.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/commands/wheel.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/configuration.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/distributions/__init__.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/distributions/__pycache__/__init__.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/distributions/__pycache__/base.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/distributions/__pycache__/installed.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/distributions/__pycache__/sdist.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/distributions/__pycache__/wheel.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/distributions/base.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/distributions/installed.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/distributions/sdist.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/distributions/wheel.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/exceptions.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/index/__init__.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/index/__pycache__/__init__.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/index/__pycache__/collector.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/index/__pycache__/package_finder.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/index/collector.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/index/package_finder.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/legacy_resolve.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/locations.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/main.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/models/__init__.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/models/__pycache__/__init__.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/models/__pycache__/candidate.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/models/__pycache__/format_control.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/models/__pycache__/index.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/models/__pycache__/link.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/models/__pycache__/scheme.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/models/__pycache__/search_scope.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/models/__pycache__/selection_prefs.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/models/__pycache__/target_python.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/models/__pycache__/wheel.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/models/candidate.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/models/format_control.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/models/index.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/models/link.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/models/scheme.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/models/search_scope.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/models/selection_prefs.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/models/target_python.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/models/wheel.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/network/__init__.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/network/__pycache__/__init__.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/network/__pycache__/auth.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/network/__pycache__/cache.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/network/__pycache__/download.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/network/__pycache__/session.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/network/__pycache__/utils.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/network/__pycache__/xmlrpc.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/network/auth.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/network/cache.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/network/download.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/network/session.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/network/utils.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/network/xmlrpc.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/operations/__init__.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/operations/__pycache__/__init__.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/operations/__pycache__/check.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/operations/__pycache__/freeze.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/operations/__pycache__/prepare.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/operations/build/__init__.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/operations/build/__pycache__/__init__.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/operations/build/__pycache__/metadata.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/operations/build/__pycache__/metadata_legacy.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/operations/build/__pycache__/wheel.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/operations/build/__pycache__/wheel_legacy.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/operations/build/metadata.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/operations/build/metadata_legacy.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/operations/build/wheel.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/operations/build/wheel_legacy.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/operations/check.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/operations/freeze.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/operations/install/__init__.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/operations/install/__pycache__/__init__.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/operations/install/__pycache__/editable_legacy.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/operations/install/__pycache__/legacy.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/operations/install/__pycache__/wheel.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/operations/install/editable_legacy.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/operations/install/legacy.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/operations/install/wheel.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/operations/prepare.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/pep425tags.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/pyproject.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/req/__init__.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/req/__pycache__/__init__.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/req/__pycache__/constructors.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/req/__pycache__/req_file.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/req/__pycache__/req_install.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/req/__pycache__/req_set.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/req/__pycache__/req_tracker.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/req/__pycache__/req_uninstall.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/req/constructors.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/req/req_file.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/req/req_install.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/req/req_set.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/req/req_tracker.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/req/req_uninstall.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/self_outdated_check.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/__init__.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/__init__.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/appdirs.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/compat.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/deprecation.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/distutils_args.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/encoding.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/entrypoints.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/filesystem.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/filetypes.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/glibc.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/hashes.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/inject_securetransport.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/logging.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/marker_files.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/misc.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/models.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/packaging.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/pkg_resources.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/setuptools_build.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/subprocess.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/temp_dir.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/typing.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/ui.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/unpacking.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/urls.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/virtualenv.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/wheel.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/appdirs.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/compat.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/deprecation.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/distutils_args.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/encoding.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/entrypoints.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/filesystem.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/filetypes.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/glibc.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/hashes.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/inject_securetransport.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/logging.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/marker_files.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/misc.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/models.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/packaging.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/pkg_resources.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/setuptools_build.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/subprocess.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/temp_dir.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/typing.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/ui.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/unpacking.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/urls.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/virtualenv.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/wheel.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/vcs/__init__.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/vcs/__pycache__/__init__.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/vcs/__pycache__/bazaar.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/vcs/__pycache__/git.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/vcs/__pycache__/mercurial.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/vcs/__pycache__/subversion.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/vcs/__pycache__/versioncontrol.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/vcs/bazaar.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/vcs/git.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/vcs/mercurial.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/vcs/subversion.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/vcs/versioncontrol.py create mode 100644 venv/lib/python3.8/site-packages/pip/_internal/wheel_builder.py create mode 100644 venv/lib/python3.8/site-packages/pip/_vendor/__init__.py create mode 100644 venv/lib/python3.8/site-packages/pip/_vendor/__pycache__/__init__.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pkg_resources-0.0.0.dist-info/AUTHORS.txt create mode 100644 venv/lib/python3.8/site-packages/pkg_resources-0.0.0.dist-info/INSTALLER create mode 100644 venv/lib/python3.8/site-packages/pkg_resources-0.0.0.dist-info/LICENSE.txt create mode 100644 venv/lib/python3.8/site-packages/pkg_resources-0.0.0.dist-info/METADATA create mode 100644 venv/lib/python3.8/site-packages/pkg_resources-0.0.0.dist-info/RECORD create mode 100644 venv/lib/python3.8/site-packages/pkg_resources-0.0.0.dist-info/WHEEL create mode 100644 venv/lib/python3.8/site-packages/pkg_resources/__init__.py create mode 100644 venv/lib/python3.8/site-packages/pkg_resources/__pycache__/__init__.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pkg_resources/__pycache__/py31compat.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pkg_resources/_vendor/__init__.py create mode 100644 venv/lib/python3.8/site-packages/pkg_resources/_vendor/__pycache__/__init__.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pkg_resources/_vendor/__pycache__/appdirs.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pkg_resources/_vendor/__pycache__/pyparsing.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pkg_resources/_vendor/__pycache__/six.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pkg_resources/_vendor/appdirs.py create mode 100644 venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__about__.py create mode 100644 venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__init__.py create mode 100644 venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/__about__.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/__init__.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/_compat.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/_structures.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/markers.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/requirements.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/specifiers.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/utils.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/version.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/_compat.py create mode 100644 venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/_structures.py create mode 100644 venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/markers.py create mode 100644 venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/requirements.py create mode 100644 venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/specifiers.py create mode 100644 venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/utils.py create mode 100644 venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/version.py create mode 100644 venv/lib/python3.8/site-packages/pkg_resources/_vendor/pyparsing.py create mode 100644 venv/lib/python3.8/site-packages/pkg_resources/_vendor/six.py create mode 100644 venv/lib/python3.8/site-packages/pkg_resources/extern/__init__.py create mode 100644 venv/lib/python3.8/site-packages/pkg_resources/extern/__pycache__/__init__.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/pkg_resources/py31compat.py create mode 100644 venv/lib/python3.8/site-packages/requests-2.26.0.dist-info/INSTALLER create mode 100644 venv/lib/python3.8/site-packages/requests-2.26.0.dist-info/LICENSE create mode 100644 venv/lib/python3.8/site-packages/requests-2.26.0.dist-info/METADATA create mode 100644 venv/lib/python3.8/site-packages/requests-2.26.0.dist-info/RECORD create mode 100644 venv/lib/python3.8/site-packages/requests-2.26.0.dist-info/WHEEL create mode 100644 venv/lib/python3.8/site-packages/requests-2.26.0.dist-info/top_level.txt create mode 100644 venv/lib/python3.8/site-packages/requests/__init__.py create mode 100644 venv/lib/python3.8/site-packages/requests/__pycache__/__init__.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/requests/__pycache__/__version__.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/requests/__pycache__/_internal_utils.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/requests/__pycache__/adapters.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/requests/__pycache__/api.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/requests/__pycache__/auth.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/requests/__pycache__/certs.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/requests/__pycache__/compat.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/requests/__pycache__/cookies.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/requests/__pycache__/exceptions.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/requests/__pycache__/help.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/requests/__pycache__/hooks.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/requests/__pycache__/models.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/requests/__pycache__/packages.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/requests/__pycache__/sessions.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/requests/__pycache__/status_codes.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/requests/__pycache__/structures.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/requests/__pycache__/utils.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/requests/__version__.py create mode 100644 venv/lib/python3.8/site-packages/requests/_internal_utils.py create mode 100644 venv/lib/python3.8/site-packages/requests/adapters.py create mode 100644 venv/lib/python3.8/site-packages/requests/api.py create mode 100644 venv/lib/python3.8/site-packages/requests/auth.py create mode 100644 venv/lib/python3.8/site-packages/requests/certs.py create mode 100644 venv/lib/python3.8/site-packages/requests/compat.py create mode 100644 venv/lib/python3.8/site-packages/requests/cookies.py create mode 100644 venv/lib/python3.8/site-packages/requests/exceptions.py create mode 100644 venv/lib/python3.8/site-packages/requests/help.py create mode 100644 venv/lib/python3.8/site-packages/requests/hooks.py create mode 100644 venv/lib/python3.8/site-packages/requests/models.py create mode 100644 venv/lib/python3.8/site-packages/requests/packages.py create mode 100644 venv/lib/python3.8/site-packages/requests/sessions.py create mode 100644 venv/lib/python3.8/site-packages/requests/status_codes.py create mode 100644 venv/lib/python3.8/site-packages/requests/structures.py create mode 100644 venv/lib/python3.8/site-packages/requests/utils.py create mode 100644 venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/AUTHORS.txt create mode 100644 venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/INSTALLER create mode 100644 venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/LICENSE.txt create mode 100644 venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/METADATA create mode 100644 venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/RECORD create mode 100644 venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/WHEEL create mode 100644 venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/dependency_links.txt create mode 100644 venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/entry_points.txt create mode 100644 venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/top_level.txt create mode 100644 venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/zip-safe create mode 100644 venv/lib/python3.8/site-packages/setuptools/__init__.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/__pycache__/__init__.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/__pycache__/_deprecation_warning.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/__pycache__/_imp.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/__pycache__/archive_util.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/__pycache__/build_meta.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/__pycache__/config.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/__pycache__/dep_util.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/__pycache__/depends.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/__pycache__/dist.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/__pycache__/errors.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/__pycache__/extension.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/__pycache__/glob.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/__pycache__/installer.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/__pycache__/launch.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/__pycache__/lib2to3_ex.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/__pycache__/monkey.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/__pycache__/msvc.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/__pycache__/namespaces.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/__pycache__/package_index.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/__pycache__/py27compat.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/__pycache__/py31compat.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/__pycache__/py33compat.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/__pycache__/py34compat.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/__pycache__/sandbox.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/__pycache__/site-patch.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/__pycache__/ssl_support.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/__pycache__/unicode_utils.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/__pycache__/version.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/__pycache__/wheel.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/__pycache__/windows_support.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/_deprecation_warning.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/_imp.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/_vendor/__init__.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/_vendor/__pycache__/__init__.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/_vendor/__pycache__/ordered_set.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/_vendor/__pycache__/pyparsing.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/_vendor/__pycache__/six.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/_vendor/ordered_set.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__about__.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__init__.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/__about__.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/__init__.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/_compat.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/_structures.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/markers.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/requirements.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/specifiers.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/tags.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/utils.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/version.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/_compat.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/_structures.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/markers.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/requirements.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/specifiers.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/tags.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/utils.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/version.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/_vendor/pyparsing.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/_vendor/six.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/archive_util.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/build_meta.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/cli-32.exe create mode 100644 venv/lib/python3.8/site-packages/setuptools/cli-64.exe create mode 100644 venv/lib/python3.8/site-packages/setuptools/cli.exe create mode 100644 venv/lib/python3.8/site-packages/setuptools/command/__init__.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/command/__pycache__/__init__.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/command/__pycache__/alias.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/command/__pycache__/bdist_egg.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/command/__pycache__/bdist_rpm.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/command/__pycache__/bdist_wininst.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/command/__pycache__/build_clib.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/command/__pycache__/build_ext.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/command/__pycache__/build_py.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/command/__pycache__/develop.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/command/__pycache__/dist_info.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/command/__pycache__/easy_install.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/command/__pycache__/egg_info.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/command/__pycache__/install.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/command/__pycache__/install_egg_info.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/command/__pycache__/install_lib.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/command/__pycache__/install_scripts.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/command/__pycache__/py36compat.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/command/__pycache__/register.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/command/__pycache__/rotate.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/command/__pycache__/saveopts.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/command/__pycache__/sdist.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/command/__pycache__/setopt.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/command/__pycache__/test.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/command/__pycache__/upload.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/command/__pycache__/upload_docs.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/command/alias.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/command/bdist_egg.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/command/bdist_rpm.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/command/bdist_wininst.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/command/build_clib.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/command/build_ext.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/command/build_py.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/command/develop.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/command/dist_info.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/command/easy_install.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/command/egg_info.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/command/install.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/command/install_egg_info.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/command/install_lib.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/command/install_scripts.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/command/launcher manifest.xml create mode 100644 venv/lib/python3.8/site-packages/setuptools/command/py36compat.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/command/register.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/command/rotate.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/command/saveopts.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/command/sdist.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/command/setopt.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/command/test.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/command/upload.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/command/upload_docs.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/config.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/dep_util.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/depends.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/dist.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/errors.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/extension.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/extern/__init__.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/extern/__pycache__/__init__.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/setuptools/glob.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/gui-32.exe create mode 100644 venv/lib/python3.8/site-packages/setuptools/gui-64.exe create mode 100644 venv/lib/python3.8/site-packages/setuptools/gui.exe create mode 100644 venv/lib/python3.8/site-packages/setuptools/installer.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/launch.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/lib2to3_ex.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/monkey.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/msvc.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/namespaces.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/package_index.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/py27compat.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/py31compat.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/py33compat.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/py34compat.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/sandbox.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/script (dev).tmpl create mode 100644 venv/lib/python3.8/site-packages/setuptools/script.tmpl create mode 100644 venv/lib/python3.8/site-packages/setuptools/site-patch.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/ssl_support.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/unicode_utils.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/version.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/wheel.py create mode 100644 venv/lib/python3.8/site-packages/setuptools/windows_support.py create mode 100644 venv/lib/python3.8/site-packages/urllib3-1.26.6.dist-info/INSTALLER create mode 100644 venv/lib/python3.8/site-packages/urllib3-1.26.6.dist-info/LICENSE.txt create mode 100644 venv/lib/python3.8/site-packages/urllib3-1.26.6.dist-info/METADATA create mode 100644 venv/lib/python3.8/site-packages/urllib3-1.26.6.dist-info/RECORD create mode 100644 venv/lib/python3.8/site-packages/urllib3-1.26.6.dist-info/WHEEL create mode 100644 venv/lib/python3.8/site-packages/urllib3-1.26.6.dist-info/top_level.txt create mode 100644 venv/lib/python3.8/site-packages/urllib3/__init__.py create mode 100644 venv/lib/python3.8/site-packages/urllib3/__pycache__/__init__.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/urllib3/__pycache__/_collections.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/urllib3/__pycache__/_version.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/urllib3/__pycache__/connection.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/urllib3/__pycache__/connectionpool.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/urllib3/__pycache__/exceptions.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/urllib3/__pycache__/fields.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/urllib3/__pycache__/filepost.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/urllib3/__pycache__/poolmanager.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/urllib3/__pycache__/request.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/urllib3/__pycache__/response.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/urllib3/_collections.py create mode 100644 venv/lib/python3.8/site-packages/urllib3/_version.py create mode 100644 venv/lib/python3.8/site-packages/urllib3/connection.py create mode 100644 venv/lib/python3.8/site-packages/urllib3/connectionpool.py create mode 100644 venv/lib/python3.8/site-packages/urllib3/contrib/__init__.py create mode 100644 venv/lib/python3.8/site-packages/urllib3/contrib/__pycache__/__init__.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/urllib3/contrib/__pycache__/_appengine_environ.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/urllib3/contrib/__pycache__/appengine.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/urllib3/contrib/__pycache__/ntlmpool.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/urllib3/contrib/__pycache__/pyopenssl.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/urllib3/contrib/__pycache__/securetransport.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/urllib3/contrib/__pycache__/socks.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/urllib3/contrib/_appengine_environ.py create mode 100644 venv/lib/python3.8/site-packages/urllib3/contrib/_securetransport/__init__.py create mode 100644 venv/lib/python3.8/site-packages/urllib3/contrib/_securetransport/__pycache__/__init__.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/urllib3/contrib/_securetransport/__pycache__/bindings.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/urllib3/contrib/_securetransport/__pycache__/low_level.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/urllib3/contrib/_securetransport/bindings.py create mode 100644 venv/lib/python3.8/site-packages/urllib3/contrib/_securetransport/low_level.py create mode 100644 venv/lib/python3.8/site-packages/urllib3/contrib/appengine.py create mode 100644 venv/lib/python3.8/site-packages/urllib3/contrib/ntlmpool.py create mode 100644 venv/lib/python3.8/site-packages/urllib3/contrib/pyopenssl.py create mode 100644 venv/lib/python3.8/site-packages/urllib3/contrib/securetransport.py create mode 100644 venv/lib/python3.8/site-packages/urllib3/contrib/socks.py create mode 100644 venv/lib/python3.8/site-packages/urllib3/exceptions.py create mode 100644 venv/lib/python3.8/site-packages/urllib3/fields.py create mode 100644 venv/lib/python3.8/site-packages/urllib3/filepost.py create mode 100644 venv/lib/python3.8/site-packages/urllib3/packages/__init__.py create mode 100644 venv/lib/python3.8/site-packages/urllib3/packages/__pycache__/__init__.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/urllib3/packages/__pycache__/six.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/urllib3/packages/backports/__init__.py create mode 100644 venv/lib/python3.8/site-packages/urllib3/packages/backports/__pycache__/__init__.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/urllib3/packages/backports/__pycache__/makefile.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/urllib3/packages/backports/makefile.py create mode 100644 venv/lib/python3.8/site-packages/urllib3/packages/six.py create mode 100644 venv/lib/python3.8/site-packages/urllib3/packages/ssl_match_hostname/__init__.py create mode 100644 venv/lib/python3.8/site-packages/urllib3/packages/ssl_match_hostname/__pycache__/__init__.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/urllib3/packages/ssl_match_hostname/__pycache__/_implementation.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/urllib3/packages/ssl_match_hostname/_implementation.py create mode 100644 venv/lib/python3.8/site-packages/urllib3/poolmanager.py create mode 100644 venv/lib/python3.8/site-packages/urllib3/request.py create mode 100644 venv/lib/python3.8/site-packages/urllib3/response.py create mode 100644 venv/lib/python3.8/site-packages/urllib3/util/__init__.py create mode 100644 venv/lib/python3.8/site-packages/urllib3/util/__pycache__/__init__.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/urllib3/util/__pycache__/connection.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/urllib3/util/__pycache__/proxy.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/urllib3/util/__pycache__/queue.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/urllib3/util/__pycache__/request.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/urllib3/util/__pycache__/response.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/urllib3/util/__pycache__/retry.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/urllib3/util/__pycache__/ssl_.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/urllib3/util/__pycache__/ssltransport.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/urllib3/util/__pycache__/timeout.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/urllib3/util/__pycache__/url.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/urllib3/util/__pycache__/wait.cpython-38.pyc create mode 100644 venv/lib/python3.8/site-packages/urllib3/util/connection.py create mode 100644 venv/lib/python3.8/site-packages/urllib3/util/proxy.py create mode 100644 venv/lib/python3.8/site-packages/urllib3/util/queue.py create mode 100644 venv/lib/python3.8/site-packages/urllib3/util/request.py create mode 100644 venv/lib/python3.8/site-packages/urllib3/util/response.py create mode 100644 venv/lib/python3.8/site-packages/urllib3/util/retry.py create mode 100644 venv/lib/python3.8/site-packages/urllib3/util/ssl_.py create mode 100644 venv/lib/python3.8/site-packages/urllib3/util/ssltransport.py create mode 100644 venv/lib/python3.8/site-packages/urllib3/util/timeout.py create mode 100644 venv/lib/python3.8/site-packages/urllib3/util/url.py create mode 100644 venv/lib/python3.8/site-packages/urllib3/util/wait.py create mode 120000 venv/lib64 create mode 100644 venv/pyvenv.cfg create mode 100644 venv/share/python-wheels/CacheControl-0.12.6-py2.py3-none-any.whl create mode 100644 venv/share/python-wheels/appdirs-1.4.3-py2.py3-none-any.whl create mode 100644 venv/share/python-wheels/certifi-2019.11.28-py2.py3-none-any.whl create mode 100644 venv/share/python-wheels/chardet-3.0.4-py2.py3-none-any.whl create mode 100644 venv/share/python-wheels/colorama-0.4.3-py2.py3-none-any.whl create mode 100644 venv/share/python-wheels/contextlib2-0.6.0-py2.py3-none-any.whl create mode 100644 venv/share/python-wheels/distlib-0.3.0-py2.py3-none-any.whl create mode 100644 venv/share/python-wheels/distro-1.4.0-py2.py3-none-any.whl create mode 100644 venv/share/python-wheels/html5lib-1.0.1-py2.py3-none-any.whl create mode 100644 venv/share/python-wheels/idna-2.8-py2.py3-none-any.whl create mode 100644 venv/share/python-wheels/ipaddr-2.2.0-py2.py3-none-any.whl create mode 100644 venv/share/python-wheels/lockfile-0.12.2-py2.py3-none-any.whl create mode 100644 venv/share/python-wheels/msgpack-0.6.2-py2.py3-none-any.whl create mode 100644 venv/share/python-wheels/packaging-20.3-py2.py3-none-any.whl create mode 100644 venv/share/python-wheels/pep517-0.8.2-py2.py3-none-any.whl create mode 100644 venv/share/python-wheels/pip-20.0.2-py2.py3-none-any.whl create mode 100644 venv/share/python-wheels/pkg_resources-0.0.0-py2.py3-none-any.whl create mode 100644 venv/share/python-wheels/progress-1.5-py2.py3-none-any.whl create mode 100644 venv/share/python-wheels/pyparsing-2.4.6-py2.py3-none-any.whl create mode 100644 venv/share/python-wheels/requests-2.22.0-py2.py3-none-any.whl create mode 100644 venv/share/python-wheels/retrying-1.3.3-py2.py3-none-any.whl create mode 100644 venv/share/python-wheels/setuptools-44.0.0-py2.py3-none-any.whl create mode 100644 venv/share/python-wheels/six-1.14.0-py2.py3-none-any.whl create mode 100644 venv/share/python-wheels/toml-0.10.0-py2.py3-none-any.whl create mode 100644 venv/share/python-wheels/urllib3-1.25.8-py2.py3-none-any.whl create mode 100644 venv/share/python-wheels/webencodings-0.5.1-py2.py3-none-any.whl create mode 100644 venv/share/python-wheels/wheel-0.34.2-py2.py3-none-any.whl diff --git a/venv/bin/Activate.ps1 b/venv/bin/Activate.ps1 new file mode 100644 index 0000000..2fb3852 --- /dev/null +++ b/venv/bin/Activate.ps1 @@ -0,0 +1,241 @@ +<# +.Synopsis +Activate a Python virtual environment for the current PowerShell session. + +.Description +Pushes the python executable for a virtual environment to the front of the +$Env:PATH environment variable and sets the prompt to signify that you are +in a Python virtual environment. Makes use of the command line switches as +well as the `pyvenv.cfg` file values present in the virtual environment. + +.Parameter VenvDir +Path to the directory that contains the virtual environment to activate. The +default value for this is the parent of the directory that the Activate.ps1 +script is located within. + +.Parameter Prompt +The prompt prefix to display when this virtual environment is activated. By +default, this prompt is the name of the virtual environment folder (VenvDir) +surrounded by parentheses and followed by a single space (ie. '(.venv) '). + +.Example +Activate.ps1 +Activates the Python virtual environment that contains the Activate.ps1 script. + +.Example +Activate.ps1 -Verbose +Activates the Python virtual environment that contains the Activate.ps1 script, +and shows extra information about the activation as it executes. + +.Example +Activate.ps1 -VenvDir C:\Users\MyUser\Common\.venv +Activates the Python virtual environment located in the specified location. + +.Example +Activate.ps1 -Prompt "MyPython" +Activates the Python virtual environment that contains the Activate.ps1 script, +and prefixes the current prompt with the specified string (surrounded in +parentheses) while the virtual environment is active. + +.Notes +On Windows, it may be required to enable this Activate.ps1 script by setting the +execution policy for the user. You can do this by issuing the following PowerShell +command: + +PS C:\> Set-ExecutionPolicy -ExecutionPolicy RemoteSigned -Scope CurrentUser + +For more information on Execution Policies: +https://go.microsoft.com/fwlink/?LinkID=135170 + +#> +Param( + [Parameter(Mandatory = $false)] + [String] + $VenvDir, + [Parameter(Mandatory = $false)] + [String] + $Prompt +) + +<# Function declarations --------------------------------------------------- #> + +<# +.Synopsis +Remove all shell session elements added by the Activate script, including the +addition of the virtual environment's Python executable from the beginning of +the PATH variable. + +.Parameter NonDestructive +If present, do not remove this function from the global namespace for the +session. + +#> +function global:deactivate ([switch]$NonDestructive) { + # Revert to original values + + # The prior prompt: + if (Test-Path -Path Function:_OLD_VIRTUAL_PROMPT) { + Copy-Item -Path Function:_OLD_VIRTUAL_PROMPT -Destination Function:prompt + Remove-Item -Path Function:_OLD_VIRTUAL_PROMPT + } + + # The prior PYTHONHOME: + if (Test-Path -Path Env:_OLD_VIRTUAL_PYTHONHOME) { + Copy-Item -Path Env:_OLD_VIRTUAL_PYTHONHOME -Destination Env:PYTHONHOME + Remove-Item -Path Env:_OLD_VIRTUAL_PYTHONHOME + } + + # The prior PATH: + if (Test-Path -Path Env:_OLD_VIRTUAL_PATH) { + Copy-Item -Path Env:_OLD_VIRTUAL_PATH -Destination Env:PATH + Remove-Item -Path Env:_OLD_VIRTUAL_PATH + } + + # Just remove the VIRTUAL_ENV altogether: + if (Test-Path -Path Env:VIRTUAL_ENV) { + Remove-Item -Path env:VIRTUAL_ENV + } + + # 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 + } + + # Leave deactivate function in the global namespace if requested: + if (-not $NonDestructive) { + Remove-Item -Path function:deactivate + } +} + +<# +.Description +Get-PyVenvConfig parses the values from the pyvenv.cfg file located in the +given folder, and returns them in a map. + +For each line in the pyvenv.cfg file, if that line can be parsed into exactly +two strings separated by `=` (with any amount of whitespace surrounding the =) +then it is considered a `key = value` line. The left hand string is the key, +the right hand is the value. + +If the value starts with a `'` or a `"` then the first and last character is +stripped from the value before being captured. + +.Parameter ConfigDir +Path to the directory that contains the `pyvenv.cfg` file. +#> +function Get-PyVenvConfig( + [String] + $ConfigDir +) { + Write-Verbose "Given ConfigDir=$ConfigDir, obtain values in pyvenv.cfg" + + # Ensure the file exists, and issue a warning if it doesn't (but still allow the function to continue). + $pyvenvConfigPath = Join-Path -Resolve -Path $ConfigDir -ChildPath 'pyvenv.cfg' -ErrorAction Continue + + # An empty map will be returned if no config file is found. + $pyvenvConfig = @{ } + + if ($pyvenvConfigPath) { + + Write-Verbose "File exists, parse `key = value` lines" + $pyvenvConfigContent = Get-Content -Path $pyvenvConfigPath + + $pyvenvConfigContent | ForEach-Object { + $keyval = $PSItem -split "\s*=\s*", 2 + if ($keyval[0] -and $keyval[1]) { + $val = $keyval[1] + + # Remove extraneous quotations around a string value. + if ("'""".Contains($val.Substring(0, 1))) { + $val = $val.Substring(1, $val.Length - 2) + } + + $pyvenvConfig[$keyval[0]] = $val + Write-Verbose "Adding Key: '$($keyval[0])'='$val'" + } + } + } + return $pyvenvConfig +} + + +<# Begin Activate script --------------------------------------------------- #> + +# Determine the containing directory of this script +$VenvExecPath = Split-Path -Parent $MyInvocation.MyCommand.Definition +$VenvExecDir = Get-Item -Path $VenvExecPath + +Write-Verbose "Activation script is located in path: '$VenvExecPath'" +Write-Verbose "VenvExecDir Fullname: '$($VenvExecDir.FullName)" +Write-Verbose "VenvExecDir Name: '$($VenvExecDir.Name)" + +# Set values required in priority: CmdLine, ConfigFile, Default +# First, get the location of the virtual environment, it might not be +# VenvExecDir if specified on the command line. +if ($VenvDir) { + Write-Verbose "VenvDir given as parameter, using '$VenvDir' to determine values" +} +else { + Write-Verbose "VenvDir not given as a parameter, using parent directory name as VenvDir." + $VenvDir = $VenvExecDir.Parent.FullName.TrimEnd("\\/") + Write-Verbose "VenvDir=$VenvDir" +} + +# Next, read the `pyvenv.cfg` file to determine any required value such +# as `prompt`. +$pyvenvCfg = Get-PyVenvConfig -ConfigDir $VenvDir + +# Next, set the prompt from the command line, or the config file, or +# just use the name of the virtual environment folder. +if ($Prompt) { + Write-Verbose "Prompt specified as argument, using '$Prompt'" +} +else { + Write-Verbose "Prompt not specified as argument to script, checking pyvenv.cfg value" + if ($pyvenvCfg -and $pyvenvCfg['prompt']) { + Write-Verbose " Setting based on value in pyvenv.cfg='$($pyvenvCfg['prompt'])'" + $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 " Got leaf-name of $VenvDir='$(Split-Path -Path $venvDir -Leaf)'" + $Prompt = Split-Path -Path $venvDir -Leaf + } +} + +Write-Verbose "Prompt = '$Prompt'" +Write-Verbose "VenvDir='$VenvDir'" + +# Deactivate any currently active virtual environment, but leave the +# deactivate function in place. +deactivate -nondestructive + +# Now set the environment variable VIRTUAL_ENV, used by many tools to determine +# that there is an activated venv. +$env:VIRTUAL_ENV = $VenvDir + +if (-not $Env:VIRTUAL_ENV_DISABLE_PROMPT) { + + Write-Verbose "Setting prompt to '$Prompt'" + + # Set the prompt to include the env name + # Make sure _OLD_VIRTUAL_PROMPT is global + function global:_OLD_VIRTUAL_PROMPT { "" } + Copy-Item -Path function:prompt -Destination function:_OLD_VIRTUAL_PROMPT + New-Variable -Name _PYTHON_VENV_PROMPT_PREFIX -Description "Python virtual environment prompt prefix" -Scope Global -Option ReadOnly -Visibility Public -Value $Prompt + + function global:prompt { + Write-Host -NoNewline -ForegroundColor Green "($_PYTHON_VENV_PROMPT_PREFIX) " + _OLD_VIRTUAL_PROMPT + } +} + +# Clear PYTHONHOME +if (Test-Path -Path Env:PYTHONHOME) { + Copy-Item -Path Env:PYTHONHOME -Destination Env:_OLD_VIRTUAL_PYTHONHOME + Remove-Item -Path Env:PYTHONHOME +} + +# Add the venv to the PATH +Copy-Item -Path Env:PATH -Destination Env:_OLD_VIRTUAL_PATH +$Env:PATH = "$VenvExecDir$([System.IO.Path]::PathSeparator)$Env:PATH" diff --git a/venv/bin/activate b/venv/bin/activate new file mode 100644 index 0000000..c161d2a --- /dev/null +++ b/venv/bin/activate @@ -0,0 +1,76 @@ +# This file must be used with "source bin/activate" *from bash* +# you cannot run it directly + +deactivate () { + # reset old environment variables + if [ -n "${_OLD_VIRTUAL_PATH:-}" ] ; then + PATH="${_OLD_VIRTUAL_PATH:-}" + export PATH + unset _OLD_VIRTUAL_PATH + fi + if [ -n "${_OLD_VIRTUAL_PYTHONHOME:-}" ] ; then + PYTHONHOME="${_OLD_VIRTUAL_PYTHONHOME:-}" + export PYTHONHOME + unset _OLD_VIRTUAL_PYTHONHOME + fi + + # This should detect bash and zsh, which have a hash command that must + # be called to get it to forget past commands. Without forgetting + # past commands the $PATH changes we made may not be respected + if [ -n "${BASH:-}" -o -n "${ZSH_VERSION:-}" ] ; then + hash -r + fi + + if [ -n "${_OLD_VIRTUAL_PS1:-}" ] ; then + PS1="${_OLD_VIRTUAL_PS1:-}" + export PS1 + unset _OLD_VIRTUAL_PS1 + fi + + unset VIRTUAL_ENV + if [ ! "${1:-}" = "nondestructive" ] ; then + # Self destruct! + unset -f deactivate + fi +} + +# unset irrelevant variables +deactivate nondestructive + +VIRTUAL_ENV="/home/angel/Documents/workspace/telebot/venv" +export VIRTUAL_ENV + +_OLD_VIRTUAL_PATH="$PATH" +PATH="$VIRTUAL_ENV/bin:$PATH" +export PATH + +# unset PYTHONHOME if set +# this will fail if PYTHONHOME is set to the empty string (which is bad anyway) +# could use `if (set -u; : $PYTHONHOME) ;` in bash +if [ -n "${PYTHONHOME:-}" ] ; then + _OLD_VIRTUAL_PYTHONHOME="${PYTHONHOME:-}" + unset PYTHONHOME +fi + +if [ -z "${VIRTUAL_ENV_DISABLE_PROMPT:-}" ] ; then + _OLD_VIRTUAL_PS1="${PS1:-}" + if [ "x(venv) " != x ] ; then + PS1="(venv) ${PS1:-}" + else + if [ "`basename \"$VIRTUAL_ENV\"`" = "__" ] ; then + # special case for Aspen magic directories + # see https://aspen.io/ + PS1="[`basename \`dirname \"$VIRTUAL_ENV\"\``] $PS1" + else + PS1="(`basename \"$VIRTUAL_ENV\"`)$PS1" + fi + fi + export PS1 +fi + +# This should detect bash and zsh, which have a hash command that must +# be called to get it to forget past commands. Without forgetting +# past commands the $PATH changes we made may not be respected +if [ -n "${BASH:-}" -o -n "${ZSH_VERSION:-}" ] ; then + hash -r +fi diff --git a/venv/bin/activate.csh b/venv/bin/activate.csh new file mode 100644 index 0000000..420f69c --- /dev/null +++ b/venv/bin/activate.csh @@ -0,0 +1,37 @@ +# This file must be used with "source bin/activate.csh" *from csh*. +# You cannot run it directly. +# Created by Davide Di Blasi . +# Ported to Python 3.3 venv by Andrew Svetlov + +alias deactivate 'test $?_OLD_VIRTUAL_PATH != 0 && setenv PATH "$_OLD_VIRTUAL_PATH" && unset _OLD_VIRTUAL_PATH; rehash; test $?_OLD_VIRTUAL_PROMPT != 0 && set prompt="$_OLD_VIRTUAL_PROMPT" && unset _OLD_VIRTUAL_PROMPT; unsetenv VIRTUAL_ENV; test "\!:*" != "nondestructive" && unalias deactivate' + +# Unset irrelevant variables. +deactivate nondestructive + +setenv VIRTUAL_ENV "/home/angel/Documents/workspace/telebot/venv" + +set _OLD_VIRTUAL_PATH="$PATH" +setenv PATH "$VIRTUAL_ENV/bin:$PATH" + + +set _OLD_VIRTUAL_PROMPT="$prompt" + +if (! "$?VIRTUAL_ENV_DISABLE_PROMPT") then + if ("venv" != "") then + set env_name = "venv" + else + if (`basename "VIRTUAL_ENV"` == "__") then + # special case for Aspen magic directories + # see https://aspen.io/ + set env_name = `basename \`dirname "$VIRTUAL_ENV"\`` + else + set env_name = `basename "$VIRTUAL_ENV"` + endif + endif + set prompt = "[$env_name] $prompt" + unset env_name +endif + +alias pydoc python -m pydoc + +rehash diff --git a/venv/bin/activate.fish b/venv/bin/activate.fish new file mode 100644 index 0000000..d99efba --- /dev/null +++ b/venv/bin/activate.fish @@ -0,0 +1,75 @@ +# This file must be used with ". bin/activate.fish" *from fish* (http://fishshell.org) +# you cannot run it directly + +function deactivate -d "Exit virtualenv and return to normal shell environment" + # reset old environment variables + if test -n "$_OLD_VIRTUAL_PATH" + set -gx PATH $_OLD_VIRTUAL_PATH + set -e _OLD_VIRTUAL_PATH + end + if test -n "$_OLD_VIRTUAL_PYTHONHOME" + set -gx PYTHONHOME $_OLD_VIRTUAL_PYTHONHOME + set -e _OLD_VIRTUAL_PYTHONHOME + end + + if test -n "$_OLD_FISH_PROMPT_OVERRIDE" + functions -e fish_prompt + set -e _OLD_FISH_PROMPT_OVERRIDE + functions -c _old_fish_prompt fish_prompt + functions -e _old_fish_prompt + end + + set -e VIRTUAL_ENV + if test "$argv[1]" != "nondestructive" + # Self destruct! + functions -e deactivate + end +end + +# unset irrelevant variables +deactivate nondestructive + +set -gx VIRTUAL_ENV "/home/angel/Documents/workspace/telebot/venv" + +set -gx _OLD_VIRTUAL_PATH $PATH +set -gx PATH "$VIRTUAL_ENV/bin" $PATH + +# unset PYTHONHOME if set +if set -q PYTHONHOME + set -gx _OLD_VIRTUAL_PYTHONHOME $PYTHONHOME + set -e PYTHONHOME +end + +if test -z "$VIRTUAL_ENV_DISABLE_PROMPT" + # fish uses a function instead of an env var to generate the prompt. + + # save the current fish_prompt function as the function _old_fish_prompt + functions -c fish_prompt _old_fish_prompt + + # with the original prompt function renamed, we can override with our own. + function fish_prompt + # Save the return status of the last command + set -l old_status $status + + # Prompt override? + if test -n "(venv) " + printf "%s%s" "(venv) " (set_color normal) + else + # ...Otherwise, prepend env + set -l _checkbase (basename "$VIRTUAL_ENV") + if test $_checkbase = "__" + # special case for Aspen magic directories + # see https://aspen.io/ + printf "%s[%s]%s " (set_color -b blue white) (basename (dirname "$VIRTUAL_ENV")) (set_color normal) + else + printf "%s(%s)%s" (set_color -b blue white) (basename "$VIRTUAL_ENV") (set_color normal) + end + end + + # Restore the return status of the previous command. + echo "exit $old_status" | . + _old_fish_prompt + end + + set -gx _OLD_FISH_PROMPT_OVERRIDE "$VIRTUAL_ENV" +end diff --git a/venv/bin/easy_install b/venv/bin/easy_install new file mode 100755 index 0000000..6fb8da2 --- /dev/null +++ b/venv/bin/easy_install @@ -0,0 +1,8 @@ +#!/home/angel/Documents/workspace/telebot/venv/bin/python3 +# -*- coding: utf-8 -*- +import re +import sys +from setuptools.command.easy_install import main +if __name__ == '__main__': + sys.argv[0] = re.sub(r'(-script\.pyw|\.exe)?$', '', sys.argv[0]) + sys.exit(main()) diff --git a/venv/bin/easy_install-3.8 b/venv/bin/easy_install-3.8 new file mode 100755 index 0000000..6fb8da2 --- /dev/null +++ b/venv/bin/easy_install-3.8 @@ -0,0 +1,8 @@ +#!/home/angel/Documents/workspace/telebot/venv/bin/python3 +# -*- coding: utf-8 -*- +import re +import sys +from setuptools.command.easy_install import main +if __name__ == '__main__': + sys.argv[0] = re.sub(r'(-script\.pyw|\.exe)?$', '', sys.argv[0]) + sys.exit(main()) diff --git a/venv/bin/normalizer b/venv/bin/normalizer new file mode 100755 index 0000000..1ad3ed6 --- /dev/null +++ b/venv/bin/normalizer @@ -0,0 +1,8 @@ +#!/home/angel/Documents/workspace/telebot/venv/bin/python3 +# -*- coding: utf-8 -*- +import re +import sys +from charset_normalizer.cli.normalizer import cli_detect +if __name__ == '__main__': + sys.argv[0] = re.sub(r'(-script\.pyw|\.exe)?$', '', sys.argv[0]) + sys.exit(cli_detect()) diff --git a/venv/bin/pip b/venv/bin/pip new file mode 100755 index 0000000..746b9dd --- /dev/null +++ b/venv/bin/pip @@ -0,0 +1,8 @@ +#!/home/angel/Documents/workspace/telebot/venv/bin/python3 +# -*- coding: utf-8 -*- +import re +import sys +from pip._internal.cli.main import main +if __name__ == '__main__': + sys.argv[0] = re.sub(r'(-script\.pyw|\.exe)?$', '', sys.argv[0]) + sys.exit(main()) diff --git a/venv/bin/pip3 b/venv/bin/pip3 new file mode 100755 index 0000000..746b9dd --- /dev/null +++ b/venv/bin/pip3 @@ -0,0 +1,8 @@ +#!/home/angel/Documents/workspace/telebot/venv/bin/python3 +# -*- coding: utf-8 -*- +import re +import sys +from pip._internal.cli.main import main +if __name__ == '__main__': + sys.argv[0] = re.sub(r'(-script\.pyw|\.exe)?$', '', sys.argv[0]) + sys.exit(main()) diff --git a/venv/bin/pip3.8 b/venv/bin/pip3.8 new file mode 100755 index 0000000..746b9dd --- /dev/null +++ b/venv/bin/pip3.8 @@ -0,0 +1,8 @@ +#!/home/angel/Documents/workspace/telebot/venv/bin/python3 +# -*- coding: utf-8 -*- +import re +import sys +from pip._internal.cli.main import main +if __name__ == '__main__': + sys.argv[0] = re.sub(r'(-script\.pyw|\.exe)?$', '', sys.argv[0]) + sys.exit(main()) diff --git a/venv/bin/python b/venv/bin/python new file mode 120000 index 0000000..b8a0adb --- /dev/null +++ b/venv/bin/python @@ -0,0 +1 @@ +python3 \ No newline at end of file diff --git a/venv/bin/python3 b/venv/bin/python3 new file mode 120000 index 0000000..ae65fda --- /dev/null +++ b/venv/bin/python3 @@ -0,0 +1 @@ +/usr/bin/python3 \ No newline at end of file diff --git a/venv/lib/python3.8/site-packages/__pycache__/easy_install.cpython-38.pyc b/venv/lib/python3.8/site-packages/__pycache__/easy_install.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..9756c319f6a1b1919071a2ac30a7eba8b0e11675 GIT binary patch literal 281 zcmYj}y-veG5QOi?5DSqfKmrRXg$vtM&>%!ZK|=weakD!4Hj2sp#b+xD1r1NbE4iiO z6{uJPMMjz#jkNnc&*w*sbalB`ukqy^FmvCTqO4%IPr$u&Q+cUxZ^hACqZ5>> import certifi + + >>> certifi.where() + '/usr/local/lib/python3.7/site-packages/certifi/cacert.pem' + +Or from the command line:: + + $ python -m certifi + /usr/local/lib/python3.7/site-packages/certifi/cacert.pem + +Enjoy! + +1024-bit Root Certificates +~~~~~~~~~~~~~~~~~~~~~~~~~~ + +Browsers and certificate authorities have concluded that 1024-bit keys are +unacceptably weak for certificates, particularly root certificates. For this +reason, Mozilla has removed any weak (i.e. 1024-bit key) certificate from its +bundle, replacing it with an equivalent strong (i.e. 2048-bit or greater key) +certificate from the same CA. Because Mozilla removed these certificates from +its bundle, ``certifi`` removed them as well. + +In previous versions, ``certifi`` provided the ``certifi.old_where()`` function +to intentionally re-add the 1024-bit roots back into your bundle. This was not +recommended in production and therefore was removed at the end of 2018. + +.. _`Certifi`: https://certifiio.readthedocs.io/en/latest/ +.. _`Requests`: https://requests.readthedocs.io/en/master/ + +Addition/Removal of Certificates +-------------------------------- + +Certifi does not support any addition/removal or other modification of the +CA trust store content. This project is intended to provide a reliable and +highly portable root of trust to python deployments. Look to upstream projects +for methods to use alternate trust. + + diff --git a/venv/lib/python3.8/site-packages/certifi-2021.5.30.dist-info/RECORD b/venv/lib/python3.8/site-packages/certifi-2021.5.30.dist-info/RECORD new file mode 100644 index 0000000..f2d2621 --- /dev/null +++ b/venv/lib/python3.8/site-packages/certifi-2021.5.30.dist-info/RECORD @@ -0,0 +1,13 @@ +certifi-2021.5.30.dist-info/INSTALLER,sha256=zuuue4knoyJ-UwPPXg8fezS7VCrXJQrAP7zeNuwvFQg,4 +certifi-2021.5.30.dist-info/LICENSE,sha256=vp2C82ES-Hp_HXTs1Ih-FGe7roh4qEAEoAEXseR1o-I,1049 +certifi-2021.5.30.dist-info/METADATA,sha256=RDzuah_IZxjVhKootR1Ha1BrDovPSA-xF-rcaD90PTo,2994 +certifi-2021.5.30.dist-info/RECORD,, +certifi-2021.5.30.dist-info/WHEEL,sha256=ADKeyaGyKF5DwBNE0sRE5pvW-bSkFMJfBuhzZ3rceP4,110 +certifi-2021.5.30.dist-info/top_level.txt,sha256=KMu4vUCfsjLrkPbSNdgdekS-pVJzBAJFO__nI8NF6-U,8 +certifi/__init__.py,sha256=-b78tXibbl0qtgCzv9tc9v6ozwcNX915lT9Tf4a9lds,62 +certifi/__main__.py,sha256=xBBoj905TUWBLRGANOcf7oi6e-3dMP4cEoG9OyMs11g,243 +certifi/__pycache__/__init__.cpython-38.pyc,, +certifi/__pycache__/__main__.cpython-38.pyc,, +certifi/__pycache__/core.cpython-38.pyc,, +certifi/cacert.pem,sha256=3i-hfE2K5o3CBKG2tYt6ehJWk2fP64o6Th83fHPoPp4,259465 +certifi/core.py,sha256=V0uyxKOYdz6ulDSusclrLmjbPgOXsD0BnEf0SQ7OnoE,2303 diff --git a/venv/lib/python3.8/site-packages/certifi-2021.5.30.dist-info/WHEEL b/venv/lib/python3.8/site-packages/certifi-2021.5.30.dist-info/WHEEL new file mode 100644 index 0000000..6d38aa0 --- /dev/null +++ b/venv/lib/python3.8/site-packages/certifi-2021.5.30.dist-info/WHEEL @@ -0,0 +1,6 @@ +Wheel-Version: 1.0 +Generator: bdist_wheel (0.35.1) +Root-Is-Purelib: true +Tag: py2-none-any +Tag: py3-none-any + diff --git a/venv/lib/python3.8/site-packages/certifi-2021.5.30.dist-info/top_level.txt b/venv/lib/python3.8/site-packages/certifi-2021.5.30.dist-info/top_level.txt new file mode 100644 index 0000000..963eac5 --- /dev/null +++ b/venv/lib/python3.8/site-packages/certifi-2021.5.30.dist-info/top_level.txt @@ -0,0 +1 @@ +certifi diff --git a/venv/lib/python3.8/site-packages/certifi/__init__.py b/venv/lib/python3.8/site-packages/certifi/__init__.py new file mode 100644 index 0000000..eebdf88 --- /dev/null +++ b/venv/lib/python3.8/site-packages/certifi/__init__.py @@ -0,0 +1,3 @@ +from .core import contents, where + +__version__ = "2021.05.30" diff --git a/venv/lib/python3.8/site-packages/certifi/__main__.py b/venv/lib/python3.8/site-packages/certifi/__main__.py new file mode 100644 index 0000000..8945b5d --- /dev/null +++ b/venv/lib/python3.8/site-packages/certifi/__main__.py @@ -0,0 +1,12 @@ +import argparse + +from certifi import contents, where + +parser = argparse.ArgumentParser() +parser.add_argument("-c", "--contents", action="store_true") +args = parser.parse_args() + +if args.contents: + print(contents()) +else: + print(where()) diff --git a/venv/lib/python3.8/site-packages/certifi/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/certifi/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..651c23a00a4338214cb90471edd0549eaaf831b1 GIT binary patch literal 227 zcmWIL<>g`kf^tjML^~k;7{oyaOhAqU5En}Ti4=wu#vF!R#wf;IrYI&xh7_hK<`m{& z22GZij6i8krdu4z`FSO&c_qcSSj#g~i&Cq&j0}tn^$bk)j1BxWS#Gf;=NF|GfebBT z1`@ZpWHa^HWN5Qtd#_DF#_1zytszC^lmN literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/certifi/__pycache__/__main__.cpython-38.pyc b/venv/lib/python3.8/site-packages/certifi/__pycache__/__main__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..c6f65d2324d5a0b8debf4720bd5b89a6156b7338 GIT binary patch literal 392 zcmYk0u};G<5Qc51PEFKSeF=sPAxMA(5<;*tR7eO3Wr?i#C@HaHIgTp2cIF+*$SZke zVrFB)4hV6Q|GWF|{MmQYX@Y#L&-VGJ&+no6AJjLO{&e?V1QNJGMaZPVk`zQnMT8Nc z-RKn+6zD1zkr)Xo;+Npl-PrpK*ov5I*aNafTa1xPd>#GN0^g!^{Nd?nkrKzMR#{NC zb9DU(1~w$CHc6KK*-2+x1En=Rq}av0vURJ{#4&D`nwt*XxB_GAhuRR&G?5oKyE4mO zdhAWuFfJZ8jhk>GN`G;fxnyud-?`DCRGV7aH)Li373AwUw^HZ2)>*GKubx0;{-e-j t>%-H&J&{NG@AG+CN?xn7JkZaMoy%7A4P0Q)=mLn5IbnE?8Hw?Pd;|FiYoGuC literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/certifi/__pycache__/core.cpython-38.pyc b/venv/lib/python3.8/site-packages/certifi/__pycache__/core.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..67ac3bb65b9f8152b00eae69c4616c10b8b8a0ae GIT binary patch literal 1108 zcmZuv&2G~`5Z+zeiQ^uh587UumzLc!geI)=p?aOf-|39q-Qf&CI)Y+aoA@PaZ_STta@B;IiNud4XDR zG@J|xr<|p9NcZofXQgan4eg0DbSU90s-f1o&7EU1bhk+M&?cg>>%n_U%#XKtox8_$ z=jsF3he~`_ zu}NGO3xghNaSx5cF6_E+S5ec6BNj1bDRyel$PtY&iwvy3uFn~qdlwJ_N4LV>dT(QM z5WZd?ywvWtP+?iTxj63)K4_~@pc`R`Fa?C+8G$C&EzS9AS55M6p5!ajERW({!B_Ui zLZmButBT({}b7K1kW+KGxdNn%5AAvQW@B}&4p z=qRG-5sv+Uadu*TyK!h8Sf^}8wg@9@C^`m2V#)hnZP0)&~c_z;Q5H07F;Tc>-B95!wyIQId)<)b@@{vVdwj`WKGr+#2c} zPK*781QWzOUm{sT2Nwnxg?tB+sgmJ-6^;aUG3aa~Y${%%(PL-CA=3.5.0 +Description-Content-Type: text/markdown +Provides-Extra: unicode_backport +Requires-Dist: unicodedata2 ; extra == 'unicode_backport' + + +

Charset Detection, for Everyone 👋

+ +

+ The Real First Universal Charset Detector
+ + + + + + + + Code Quality Badge + + + + + + Documentation Status + + + Download Count Total + +

+ +> A library that helps you read text from an unknown charset encoding.
Motivated by `chardet`, +> I'm trying to resolve the issue by taking a new approach. +> All IANA character set names for which the Python core library provides codecs are supported. + +

+ >>>>> 👉 Try Me Online Now, Then Adopt Me 👈 <<<<< +

+ +This project offers you an alternative to **Universal Charset Encoding Detector**, also known as **Chardet**. + +| Feature | [Chardet](https://github.com/chardet/chardet) | Charset Normalizer | [cChardet](https://github.com/PyYoshi/cChardet) | +| ------------- | :-------------: | :------------------: | :------------------: | +| `Fast` | ❌
| ✅
| ✅
| +| `Universal**` | ❌ | ✅ | ❌ | +| `Reliable` **without** distinguishable standards | ❌ | ✅ | ✅ | +| `Reliable` **with** distinguishable standards | ✅ | ✅ | ✅ | +| `Free & Open` | ✅ | ✅ | ✅ | +| `License` | LGPL-2.1 | MIT | MPL-1.1 +| `Native Python` | ✅ | ✅ | ❌ | +| `Detect spoken language` | ❌ | ✅ | N/A | +| `Supported Encoding` | 30 | :tada: [93](https://charset-normalizer.readthedocs.io/en/latest/support.html) | 40 + +

+Reading Normalized TextCat Reading Text + +*\*\* : They are clearly using specific code for a specific encoding even if covering most of used one*
+ +## ⚡ Performance + +This package offer better performance than its counterpart Chardet. Here are some numbers. + +| Package | Accuracy | Mean per file (ns) | File per sec (est) | +| ------------- | :-------------: | :------------------: | :------------------: | +| [chardet](https://github.com/chardet/chardet) | 93.0 % | 67 ms | 15.38 file/sec | +| charset-normalizer | **95.0 %** | **37 ms** | 27.77 file/sec | + +| Package | 99th percentile | 95th percentile | 50th percentile | +| ------------- | :-------------: | :------------------: | :------------------: | +| [chardet](https://github.com/chardet/chardet) | 424 ms | 234 ms | 26 ms | +| charset-normalizer | 335 ms | 186 ms | 17 ms | + +Chardet's performance on larger file (1MB+) are very poor. Expect huge difference on large payload. + +> Stats are generated using 400+ files using default parameters. More details on used files, see GHA workflows. +> And yes, these results might change at any time. The dataset can be updated to include more files. + +[cchardet](https://github.com/PyYoshi/cChardet) is a non-native (cpp binding) faster alternative. If speed is the most important factor, +you should try it. + +## Your support + +Please ⭐ this repository if this project helped you! + +## ✨ Installation + +Using PyPi for latest stable +```sh +pip install charset-normalizer +``` +Or directly from dev-master for latest preview +```sh +pip install git+https://github.com/Ousret/charset_normalizer.git +``` + +If you want a more up-to-date `unicodedata` than the one available in your Python setup. +```sh +pip install charset-normalizer[unicode_backport] +``` + +## 🚀 Basic Usage + +### CLI +This package comes with a CLI. + +``` +usage: normalizer [-h] [-v] [-a] [-n] [-m] [-r] [-f] [-t THRESHOLD] + file [file ...] + +The Real First Universal Charset Detector. Discover originating encoding used +on text file. Normalize text to unicode. + +positional arguments: + files File(s) to be analysed + +optional arguments: + -h, --help show this help message and exit + -v, --verbose Display complementary information about file if any. + Stdout will contain logs about the detection process. + -a, --with-alternative + Output complementary possibilities if any. Top-level + JSON WILL be a list. + -n, --normalize Permit to normalize input file. If not set, program + does not write anything. + -m, --minimal Only output the charset detected to STDOUT. Disabling + JSON output. + -r, --replace Replace file when trying to normalize it instead of + creating a new one. + -f, --force Replace file without asking if you are sure, use this + flag with caution. + -t THRESHOLD, --threshold THRESHOLD + Define a custom maximum amount of chaos allowed in + decoded content. 0. <= chaos <= 1. + --version Show version information and exit. +``` + +```bash +normalizer ./data/sample.1.fr.srt +``` + +:tada: Since version 1.4.0 the CLI produce easily usable stdout result in JSON format. + +```json +{ + "path": "/home/default/projects/charset_normalizer/data/sample.1.fr.srt", + "encoding": "cp1252", + "encoding_aliases": [ + "1252", + "windows_1252" + ], + "alternative_encodings": [ + "cp1254", + "cp1256", + "cp1258", + "iso8859_14", + "iso8859_15", + "iso8859_16", + "iso8859_3", + "iso8859_9", + "latin_1", + "mbcs" + ], + "language": "French", + "alphabets": [ + "Basic Latin", + "Latin-1 Supplement" + ], + "has_sig_or_bom": false, + "chaos": 0.149, + "coherence": 97.152, + "unicode_path": null, + "is_preferred": true +} +``` + +### Python +*Just print out normalized text* +```python +from charset_normalizer import from_path + +results = from_path('./my_subtitle.srt') + +print(str(results.best())) +``` + +*Normalize any text file* +```python +from charset_normalizer import normalize +try: + normalize('./my_subtitle.srt') # should write to disk my_subtitle-***.srt +except IOError as e: + print('Sadly, we are unable to perform charset normalization.', str(e)) +``` + +*Upgrade your code without effort* +```python +from charset_normalizer import detect +``` + +The above code will behave the same as **chardet**. We ensure that we offer the best (reasonable) BC result possible. + +See the docs for advanced usage : [readthedocs.io](https://charset-normalizer.readthedocs.io/en/latest/) + +## 😇 Why + +When I started using Chardet, I noticed that it was not suited to my expectations, and I wanted to propose a +reliable alternative using a completely different method. Also! I never back down on a good challenge ! + +I **don't care** about the **originating charset** encoding, because **two different tables** can +produce **two identical files.** +What I want is to get readable text, the best I can. + +In a way, **I'm brute forcing text decoding.** How cool is that ? 😎 + +Don't confuse package **ftfy** with charset-normalizer or chardet. ftfy goal is to repair unicode string whereas charset-normalizer to convert raw file in unknown encoding to unicode. + +## 🍰 How + + - Discard all charset encoding table that could not fit the binary content. + - Measure chaos, or the mess once opened (by chunks) with a corresponding charset encoding. + - Extract matches with the lowest mess detected. + - Finally, if there is too much match left, we measure coherence. + +**Wait a minute**, what is chaos/mess and coherence according to **YOU ?** + +*Chaos :* I opened hundred of text files, **written by humans**, with the wrong encoding table. **I observed**, then +**I established** some ground rules about **what is obvious** when **it seems like** a mess. + I know that my interpretation of what is chaotic is very subjective, feel free to contribute in order to + improve or rewrite it. + +*Coherence :* For each language there is on earth, we have computed ranked letter appearance occurrences (the best we can). So I thought +that intel is worth something here. So I use those records against decoded text to check if I can detect intelligent design. + +## ⚡ Known limitations + + - Language detection is unreliable when text contains two or more languages sharing identical letters. (eg. HTML (english tags) + Turkish content (Sharing Latin characters)) + - Every charset detector heavily depends on sufficient content. In common cases, do not bother run detection on very tiny content. + +## 👤 Contributing + +Contributions, issues and feature requests are very much welcome.
+Feel free to check [issues page](https://github.com/ousret/charset_normalizer/issues) if you want to contribute. + +## 📝 License + +Copyright © 2019 [Ahmed TAHRI @Ousret](https://github.com/Ousret).
+This project is [MIT](https://github.com/Ousret/charset_normalizer/blob/master/LICENSE) licensed. + +Characters frequencies used in this project © 2012 [Denny Vrandečić](http://denny.vrandecic.de) + + diff --git a/venv/lib/python3.8/site-packages/charset_normalizer-2.0.3.dist-info/RECORD b/venv/lib/python3.8/site-packages/charset_normalizer-2.0.3.dist-info/RECORD new file mode 100644 index 0000000..7cc9928 --- /dev/null +++ b/venv/lib/python3.8/site-packages/charset_normalizer-2.0.3.dist-info/RECORD @@ -0,0 +1,33 @@ +../../../bin/normalizer,sha256=73BGDYHJdrSug4_ba5piGJQZJXD6k9x8QQnzrq7ldtI,284 +charset_normalizer-2.0.3.dist-info/INSTALLER,sha256=zuuue4knoyJ-UwPPXg8fezS7VCrXJQrAP7zeNuwvFQg,4 +charset_normalizer-2.0.3.dist-info/LICENSE,sha256=6zGgxaT7Cbik4yBV0lweX5w1iidS_vPNcgIT0cz-4kE,1070 +charset_normalizer-2.0.3.dist-info/METADATA,sha256=RZIpCo9OAmNF71ZG8QWXqf6AbVu68_-PYP4MZKp_wnw,11716 +charset_normalizer-2.0.3.dist-info/RECORD,, +charset_normalizer-2.0.3.dist-info/WHEEL,sha256=OqRkF0eY5GHssMorFjlbTIq072vpHpF60fIQA6lS9xA,92 +charset_normalizer-2.0.3.dist-info/entry_points.txt,sha256=5AJq_EPtGGUwJPgQLnBZfbVr-FYCIwT0xP7dIEZO3NI,77 +charset_normalizer-2.0.3.dist-info/top_level.txt,sha256=7ASyzePr8_xuZWJsnqJjIBtyV8vhEo0wBCv1MPRRi3Q,19 +charset_normalizer/__init__.py,sha256=i8FSr9cSFIrh16O8h7com8LKtd9nsLY8wiEhSpk1_aY,1673 +charset_normalizer/__pycache__/__init__.cpython-38.pyc,, +charset_normalizer/__pycache__/api.cpython-38.pyc,, +charset_normalizer/__pycache__/cd.cpython-38.pyc,, +charset_normalizer/__pycache__/constant.cpython-38.pyc,, +charset_normalizer/__pycache__/legacy.cpython-38.pyc,, +charset_normalizer/__pycache__/md.cpython-38.pyc,, +charset_normalizer/__pycache__/models.cpython-38.pyc,, +charset_normalizer/__pycache__/utils.cpython-38.pyc,, +charset_normalizer/__pycache__/version.cpython-38.pyc,, +charset_normalizer/api.py,sha256=Ca_7jRyYMRWktz_Vlc0C7QvNjSJ3-a1wlaaGLLX9-2E,15319 +charset_normalizer/assets/__init__.py,sha256=JTs2XX9qbYSBhS4EEI93IqEOnzzrHhVmX1gp2vKjZdE,6938 +charset_normalizer/assets/__pycache__/__init__.cpython-38.pyc,, +charset_normalizer/cd.py,sha256=_HLe1wgJAifJPl4dlBctjK5yIvH0ja67jePw36OrrhI,9223 +charset_normalizer/cli/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 +charset_normalizer/cli/__pycache__/__init__.cpython-38.pyc,, +charset_normalizer/cli/__pycache__/normalizer.cpython-38.pyc,, +charset_normalizer/cli/normalizer.py,sha256=qG1z783dgpUfllxLIkyLFfSsz1QKMh2T2VlHMr8Cvjg,7773 +charset_normalizer/constant.py,sha256=YA8r7rNGeuLlnqWLs2MISs1mFLmaralG99HNevHuUuo,18390 +charset_normalizer/legacy.py,sha256=L3Qn-DSLjRQoYPtDIzkXcqO0mnFIjOl0p6-gAzYUY54,1640 +charset_normalizer/md.py,sha256=QV0YU1ciDm3VSMrlabl9bXIHxOt7C5-uiLQpJZiJ-4A,14662 +charset_normalizer/models.py,sha256=ZYcD6qEsX00SHUJ7XwPScxESWLNIYpDw1JZ0JKQU2EU,12391 +charset_normalizer/py.typed,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 +charset_normalizer/utils.py,sha256=m8EVpWxu3RRORZYqxdFxWSK1osS22oIGP9wACVRl6Mk,7239 +charset_normalizer/version.py,sha256=Ejou22hb6JfMu7pp3axnqZP-xGcsS0KsJVRe5yRrvOQ,79 diff --git a/venv/lib/python3.8/site-packages/charset_normalizer-2.0.3.dist-info/WHEEL b/venv/lib/python3.8/site-packages/charset_normalizer-2.0.3.dist-info/WHEEL new file mode 100644 index 0000000..385faab --- /dev/null +++ b/venv/lib/python3.8/site-packages/charset_normalizer-2.0.3.dist-info/WHEEL @@ -0,0 +1,5 @@ +Wheel-Version: 1.0 +Generator: bdist_wheel (0.36.2) +Root-Is-Purelib: true +Tag: py3-none-any + diff --git a/venv/lib/python3.8/site-packages/charset_normalizer-2.0.3.dist-info/entry_points.txt b/venv/lib/python3.8/site-packages/charset_normalizer-2.0.3.dist-info/entry_points.txt new file mode 100644 index 0000000..a67f60b --- /dev/null +++ b/venv/lib/python3.8/site-packages/charset_normalizer-2.0.3.dist-info/entry_points.txt @@ -0,0 +1,3 @@ +[console_scripts] +normalizer = charset_normalizer.cli.normalizer:cli_detect + diff --git a/venv/lib/python3.8/site-packages/charset_normalizer-2.0.3.dist-info/top_level.txt b/venv/lib/python3.8/site-packages/charset_normalizer-2.0.3.dist-info/top_level.txt new file mode 100644 index 0000000..66958f0 --- /dev/null +++ b/venv/lib/python3.8/site-packages/charset_normalizer-2.0.3.dist-info/top_level.txt @@ -0,0 +1 @@ +charset_normalizer diff --git a/venv/lib/python3.8/site-packages/charset_normalizer/__init__.py b/venv/lib/python3.8/site-packages/charset_normalizer/__init__.py new file mode 100644 index 0000000..f14a90b --- /dev/null +++ b/venv/lib/python3.8/site-packages/charset_normalizer/__init__.py @@ -0,0 +1,31 @@ +""" +Charset-Normalizer +~~~~~~~~~~~~~~ +The Real First Universal Charset Detector. +A library that helps you read text from an unknown charset encoding. +Motivated by chardet, This package is trying to resolve the issue by taking a new approach. +All IANA character set names for which the Python core library provides codecs are supported. + +Basic usage: + >>> from charset_normalizer import from_bytes + >>> results = from_bytes('Bсеки човек има право на образование. Oбразованието трябва да бъде безплатно, поне що се отнася до началното и основното образование.'.encode('utf_8')) + >>> "utf_8" in results + True + >>> best_result = results.best() + >>> str(best_result) + 'Bсеки човек има право на образование. Oбразованието трябва да бъде безплатно, поне що се отнася до началното и основното образование.' + +Others methods and usages are available - see the full documentation +at . +:copyright: (c) 2021 by Ahmed TAHRI +:license: MIT, see LICENSE for more details. +""" +from charset_normalizer.api import from_fp, from_path, from_bytes, normalize +from charset_normalizer.legacy import detect +from charset_normalizer.version import __version__, VERSION +from charset_normalizer.models import CharsetMatch, CharsetMatches + +# Backward-compatible v1 imports +from charset_normalizer.models import CharsetNormalizerMatch +import charset_normalizer.api as CharsetDetector +CharsetNormalizerMatches = CharsetDetector diff --git a/venv/lib/python3.8/site-packages/charset_normalizer/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/charset_normalizer/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..2a5b6111577c49fb102d90c6ce4cda021f3a3389 GIT binary patch literal 1855 zcmd^APj4GV6kq>I9B-U71ZqA3D|!6>zu$X1@9op2CDXv?*+=h_ zm-B}4yJBuXWn@0ZpYZYU4BPNZUO6a*WxE_!>`GX*tKpnIS5opyFdx?Jnx?D4LRh!! zp=q0%p9>blhTRC4>?O_5Bfo4fYr2Ncu=H z0sDq>^V@$sX5Xi$qzJgV~<6Lmbn{Cc1$GoU@+2ZkID_``%FMW+#_;G z0ZGY6Xbm#P*dh*&DW+5kky7O+$&peMi0BEBB;he}eFPW;u+!~zbzI^~$^naqh=f$Y zFy?ULGuPLlz8XnCMtm`+H&tPnW9FeLVx_JCf;y2VNz4(hWtxwPU@oKrF?LJ<*xK5f z6g;iciEg?KEL3heeifad~Ck>>4k8kPL*B^ zy~&?vW0YM%cB%NQ>`Y5uYs)bTFS2tB_GXFm7wDG1$e-u0vNMc+DVTOEyN^%j{|c6Jp>?ROT<0Ga|#BS~<>7^H(au1PWpuqa!-$G>9IlQ^jMZ8|iGg zYnHwfbbT$AL+9aIvw7X2`&w`xSfpOQYL?RUc}lM>22@CAqQgE;jVvWyzlkCwU%zFi z<^RVvo8}&l4i^woyzw61>d2ei;mHLj$AkrB5Kw60uuSG`nBpLLv73f8l0>pNGI8D? z`BEmL({3L!>8AtBjl=d{Dmazxw+CR$GCOXZj5s^=We3*XCOp`D@PQiMt{>v`_q$*0 z@0gu{xik{A1G_u@4GrMSohRG9gKa&pp&CzI5C~CN<{!8~jb^o|sV(CSlcKJPgh;^0vhYL0_#avXd0?G9KZVO%YLUQq{bV}sA(VZS@WHlT;Z9dZ1A81{QJ^i$xx zrlKtTSCkOs?8L5vFU&N!RAQ1b`w213%Zr_^<{#6wfKNx&j`Ksg3Puem}+6hZq zX{6RO^;#!Br9q22$tEEmZq9i1ZO35|la6C0qhjF^f=UCrRl;yW#jLL0D>X_hrIktp G|NjD+5CE+J literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/charset_normalizer/__pycache__/api.cpython-38.pyc b/venv/lib/python3.8/site-packages/charset_normalizer/__pycache__/api.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..da9c8029902708c8d592561327b174a5ffc73a1d GIT binary patch literal 9516 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 z RR~FY+R$p6rY31cA`!A%xU335d literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/charset_normalizer/__pycache__/constant.cpython-38.pyc b/venv/lib/python3.8/site-packages/charset_normalizer/__pycache__/constant.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..0d440206f1c1ddfb159ee9d5e943de8917464f20 GIT binary patch literal 13110 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 F`+syE&cy%# literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/charset_normalizer/__pycache__/legacy.cpython-38.pyc b/venv/lib/python3.8/site-packages/charset_normalizer/__pycache__/legacy.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..449cb297c2095323f15b020338d9f2c5fefc442b GIT binary patch literal 1419 zcmZuxPj4eN6t_KpGRdYZ?P^tRfrBqdM51YhR${66t2PoyC`H}$GMC61JIQQj?7{Xl z&604Se2hJGk4St3PJ9esIdS8Rgy4CSWh;TDd47J+e((2we&fr%y$*tL{n5K@9wYRd zU)&unSbPqj8G+!4;{ug9#n|hlAZ3sSjUE(X8KqGfr*YXzTNsH%M4~NX(E{0-k^^*r zyyW3a!XqC47^e4l>lx}Lze8ly!>%*csvJ*NRv1|ApMLqp#o1sqK0Uv<7(Dyte0Vk( zo(_6}3(xY*y5zjFxst4K(WL~XM_l61j*ZnW*230WX4r?`jR-;!0~Npqcyt0uka220dM^`M1Nq3w{DP){e0Vcg*JGNIa##z*K7Pdk%W^C*;(db zY4cza=tcuyxCwT??|B5?&STV^2zS=oHR17s=v(mJ14(%6Lj>`N?JipS=QWYB?XH2l zb+8V3@-hI{+U!>-u0vsDbEdhlv=B3vt!OFiT=B+pCalOTwR1s*%oNY%jH+p~p5<3U zQcoBK!obm|Us-DAsxCO42wEy*ixr))Y_Wv!hnXrXX7foQ`c3G;>v)otf-du-pe3`} zoSyE`sHLP!om-!CITun~2~8_yOcR5?H&m7?`36@Lr&G=er%#sw2q>HrMANc*?LVf|*4 zz7Lk4kbVr)pPwArvO22r>adm-w3*fFaMj{lB>4o*myJjCzd{cs;A!9z?i`AfeAdxpJky8qv>eOBd7 zRq5ORjE3+P^2-L(mUExWK#^HtCu|?}!7xDfzfmye`D2 O{&6z?a2I#+qu?L*Yny2R literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/charset_normalizer/__pycache__/md.cpython-38.pyc b/venv/lib/python3.8/site-packages/charset_normalizer/__pycache__/md.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..cda1d7f595961c34a1d9b7d17e60ef57f647b6cd GIT binary patch literal 13350 zcmc&*TWlQHd7hb_y>PjtRy3{qWh~3KwzVZCaa+5VWyz9gIkqU*lHz!6cRJiNBv;&< z&dgfYdKm{Zrpl>aLVvv`jK@9!5thBA~{ zGwNp9G?}+*Ry|ct)$Ot^a=t!Uo~#$jh5A%^syHms0!G z{=0Vhpl_-J>fj%m>X^UZKja_q52+*fY;{yQchhTT`LKHGno)ZC5$COBMiVvNb}L?G z*)Lg9?rJNnHXB|ovfr)-AzmN7G5_X;s~0c1*DhVSI)Cx}yYIX2o}Yi?lKa-B_usqv z?!{6rnyvI= zO4*o^jBjJ*Sk9;{%2||h_e@zYyPWeU{JfO8UN&ZEQl&9NQ_;*7KL{@RptrPcl=L6zo8rtSGC@%`E^W>vsC@qZ=j`cxv7#*A6n5wWf@aa34P3o_QSSrR4fd= z_hTOW-nf7($RP=h-!+wqu~?mR(miSCfONgu@SW;n(oerxCs=N_Ysy*hokfhM+K8#< zXY&uu=!yAe_-2nrUtQ9=sX>+<__ak{M28Ozy$84TmrsTD)~Qyt^+LPR@+vF7dg1o6 z@7G@N-PUQ(d-3!sb{Y7g+i2>#SF3h>eX6cbw(dkZzgAtUF4X*89EA+e?i}2@5+{50 z=65^?f6$+U>&w1V_o@v?H`~~Lz7sY%X8#kv(#FPg+ASrtnKI7o3jcQo+YEBS> zPdAf|j!EBU!qd{&A-w6W+P)E#OQjvt{GC3{7n=1JmPV-KbOsKvp^8-lCn^W4b$i(h zojc98#?JNCiITJI1y11mLtFStI|!ZmtJk^IwdQSKqcyMLoId%AGcR)y>S~1$<}8JH z+V4AAt%D;6O)8G{2c7AR95gGH3Q^8=8(!Ua-6-$6^`>gqm@l~Qt+rQ7-eg@@H7j_W z0=h)@LbF-Z``Gh-CY;_V*V4@v_TilAr-i!y->!>~eRAt>Y5>QP6L;#ZpUGu*20E2#L5}zllL7(bT z;36C8*GLl^F?K@Bc$7_{1z8q_OxLiDn^>0LFf1%j7YlRKTuJG2*HqR@R+mGoYp$94 zC8?K6>ZKaTK)?OKP^pz1>ZGMkS?XkzEp27kmJ7*_g-y>t;=-0D*UdBQ=Gk@g)pheX z*UeMw=CkYOE0OtWWUj88AFP`n%{}4(OIcmQP5%m$43p=OMA>SfAYwvIZBd_KG6IN& z-(JGYfJ|hV)7FfcGmGXda-C32A2e1?EN*Hgt)K5g#bAw+ z9h3bz>EQ44ugUMnZ5PKc)bzGjp#1LqLu+vs9z@yY$0PC2BvuC=9eaDc|ww1k0*T`*9NRku>*BvM1MPA*B9|EM3D(SgZc#YA?O@A zY$^)SKV9s-xlxc5=3L<`_kcAU)F-mRT(&x0u9B$=Wm6}Zi`#_Kj zr#>Q=fk9;|WKu?vMPd0ZT=9H}jP8sg?eVNQhZgE=MeG$TM^;Qvr@)GQ^QExj(QECX zRjpK;?cid&RjXED5yw(?JI36i-(h}fuJpugD%$M^Z3yfjfVU?Ru$<-S$=CuB*Vw>3 z8Hwg(+TZ7l#S(=!M(4yfByYpS{f)wf55Zb%VB|y!Ywp&OqKy*xk4Q+eFSjLP2b|4C zmz`>?Oz1O-5au0TQIA zQYtzIDCptLFe-@Sd>9+Hcqi!N8o6Bv4S&rU8`>`WHj(_ZKta#fAW)#`+8D_?1cJX| zw+Rqz>2fsVQ|X{I77^7#Mpzk=Q3N(&08RiA>wSj+2(lg+!B@kSXy<3d6C|#J&}RKL zbJaqQ_Y|B9RyVa~=|yQble9bJUWg$gaT#0(0kk**c(47~cR)0Z93D*c7pewt&;Yur9pFr<`)q8MRZl||!aW*&x=vsx*ixiR- zsjX5-(~{4KXD$&Da}j)Q(WE#=6KCo!cfnJ`4`yAS=Cw7PsbTya6=H|Otkm7?j?KCY z?ZrhLdEvEW61T)Q9*G}v4W^OA9x=LJ#r=AC)MRV}gImlReHraO-mdvC_MbrD=sri| zATf|wD10)Do@3b6FDmms6(2ZKm#ha|1}nk6(}HNWvIHr`2hMuISuPE}P6H#q5d!Jf zOx&}Al@V)bq%ewd$(Olsf=`K>@;u*-Tf|-beBZ}gyK5aZlnt-n_f;A+Oyb$3{x_*# zNZKh#X{y(nP&K78tSwsxCkDvdjbDe+mRrew*VIK&ISsQdvyx*e+(jCh>-9m?tvlp( zDNW4lGM9h`+apewehta>Il+jt^5Cm@ux`GfPxI|pkd%u0B5sj=vsrCumybmg{2k_Q zFrlE-)Gzc0NTO5?l2y!}kNE6ECcn+(43jJpAZ8!v%Tvkr#8*q<@@9k~s{a^Q@H`R& zu4KBCr%juvZXQ7{Z%tc!WRFh6$;`c)Gmp`mwtwV~-2vR6Ku0p;Fo-eZFols~Es>@q z?J+X;34OPm(Rc<+nRtE%VTU9IRBn84vN_#M{BCS{Y|nDut6Z1S|MB?!ZYJ!%J|IhTw&)lyho=XK5(q@0k)# zVwVxD;7>}K;Uo-KD5xyfZ&x&X;pWPljgN7fuC9g6Rt)p)zelHXlKIB#CoU}GtUK^a z$*HN|Kx{^}vE(!t5rTlj;0BJX<%BiB_c#QuGy&6 z=q%zSnXwBMoTTDh)%Sub>c`;^zKRb~ulb&?pzkG#k6<&1_0R~IK+n!|KmP1H&q))= z-F+_pV!SHNMNc+0K~U7a#BB|G`nGO1mRypb$e&q8jtp$*ZG^@iZV#e|xUmn9n$TZ@ zs5ro0d!k}wpQA+uKcTn~QSl-&;swj-0|LNc`dD?Q7)WgASX5Za8}UWpxU^)o*$mbp zx!>(M!m4v*2p5q&q z?!d_2caAtXIv+wDxU=CxpvxJ$rp$y)%qUU_GABq%A7tRx98C;CrZlzrbm}P%lBSzJ z#^h-xGz13c|N1zK&oE(cLkl8HBdfB67e$gm4TuN-;!4YkSDWuDxHkN_>CfQ`sP_** z>i_lVfA4vqfLE>DXh9u)n*kWxsiIpXSgeXN?VtD~pB5!FHQy6nkxf-GI=Y$f-2j;8 z$Idl`mqmw%&9^qGawRS#!H%aN``TTsB2X^YT#Ip=az2H?wZ|CbU*V!q#Q?%siBf8H zoG~-A4cHI>g!#!cv7XqP#@%E{fTp5>{VJNxMdU}aFSpjKq={|81wWRO9YD}Mv=I9X z^+`x>y5zBo1&pv_H+!!4!Rk?;g}w^s-rZPF)nDh6`x$7gAL0q_`djh@I;`Zf5-RYq zw29z80l3tyyQ0lx8yV3Tp7)zL28+F^&!>jjHl`Gs@n=WJjJ%ig0RjDVx4E9y73M4$oFv5RMg_&I^hbG z_)Fs=ObW-njYhg0S}uU~!n>Z0B}SLSbyNy55%5B-WMH|$2PJntgVnT>2`=K!XO~&8 zYutzJ1Dno_@0PJ@t){xxMdPDGt9I88S+jL(p=)cZFGDrYXE-*&AtiI`sme8yi-4n?h%({qSn4bVn9 z!1++9xlh1*{hd@UuK0HtD;6XkC~wP?g~;-2LxNmn_&3lF*4hYYZW?wG-Y9ycc;~eT zrJQNu%BA9G{S>fcr%u3%w0T*YEme&i$U+!J-TNd!yzS?)`|Mv|n=9E-QTYthR*+q{ z+As_JXg8`=>+QM=OV&qJa7{&N?(%pvz0Y^hcjJxN8r-{%G~;=Tjj2$eH_s4&e4+2+71c3wJ^oOugwn>0E~qluR+~s$_~|t4fTo*w$jq zD*>&6t*&cTU&s4cjNU3u1w@ce9yXN1COad;_#VjCHAv*@^oaWaMQkw@@H!J-+&4Na?k!9wl5_+GCv`4*D$L~Mv6*dG7gq2h0%Ozfd4@2dM= z!yOP^ehLwvh>iAD)zf$IV#8bflSHi|QSMQ?3QPHuDA#LTudzeXz9k|1M)^U*f6QsR zh=)enwhG`%`-_a7v&hf%@??*6y%^<)Ge?QecmxRrx zKgE5nbR?QsWC$(dgagerjxyn$7HnDFAF@HZA}F literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/charset_normalizer/__pycache__/models.cpython-38.pyc b/venv/lib/python3.8/site-packages/charset_normalizer/__pycache__/models.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..ace03a4cbb98b0a3ce45eb4f3bb7133abb4552ed GIT binary patch literal 12394 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 literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/charset_normalizer/__pycache__/utils.cpython-38.pyc b/venv/lib/python3.8/site-packages/charset_normalizer/__pycache__/utils.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..5d32466ffd874254e1e2283654d79bc812da5bf5 GIT binary patch literal 6050 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 literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/charset_normalizer/__pycache__/version.cpython-38.pyc b/venv/lib/python3.8/site-packages/charset_normalizer/__pycache__/version.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..51cdc8a6025b9de9f0b977708a413316c8bff043 GIT binary patch literal 238 zcmWIL<>g`kf(lF3M1LUt7{oya%s`F<5EqL9i4=w?h7`sq##F`yOestY8Kam}n1dNK zS*irMTq_Fli&GWKQj3Z+^Ygf>SdH`y^o(yY>iKE1++vT9PsvY?kH5to9}iUl2KczG$)s7M5b`~JP!otD`0AkZW AVE_OC literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/charset_normalizer/api.py b/venv/lib/python3.8/site-packages/charset_normalizer/api.py new file mode 100644 index 0000000..7ad912c --- /dev/null +++ b/venv/lib/python3.8/site-packages/charset_normalizer/api.py @@ -0,0 +1,421 @@ +from os.path import splitext, basename +from typing import List, BinaryIO, Optional, Set, Union + +try: + from os import PathLike +except ImportError: + PathLike = Union[str, 'os.PathLike[str]'] # type: ignore + +from charset_normalizer.constant import TOO_SMALL_SEQUENCE, TOO_BIG_SEQUENCE, IANA_SUPPORTED +from charset_normalizer.md import mess_ratio +from charset_normalizer.models import CharsetMatches, CharsetMatch +from warnings import warn +import logging + +from charset_normalizer.utils import any_specified_encoding, is_multi_byte_encoding, identify_sig_or_bom, \ + should_strip_sig_or_bom, is_cp_similar, iana_name +from charset_normalizer.cd import coherence_ratio, encoding_languages, mb_encoding_languages, merge_coherence_ratios + +logger = logging.getLogger("charset_normalizer") +logger.setLevel(logging.DEBUG) + +handler = logging.StreamHandler() +handler.setFormatter(logging.Formatter('%(asctime)s | %(levelname)s | %(message)s')) +logger.addHandler(handler) + + +def from_bytes( + sequences: bytes, + steps: int = 5, + chunk_size: int = 512, + threshold: float = 0.2, + cp_isolation: List[str] = None, + cp_exclusion: List[str] = None, + preemptive_behaviour: bool = True, + explain: bool = False +) -> CharsetMatches: + """ + Given a raw bytes sequence, return the best possibles charset usable to render str objects. + If there is no results, it is a strong indicator that the source is binary/not text. + By default, the process will extract 5 blocs of 512o each to assess the mess and coherence of a given sequence. + And will give up a particular code page after 20% of measured mess. Those criteria are customizable at will. + + The preemptive behavior DOES NOT replace the traditional detection workflow, it prioritize a particular code page + but never take it for granted. Can improve the performance. + + You may want to focus your attention to some code page or/and not others, use cp_isolation and cp_exclusion for that + purpose. + + This function will strip the SIG in the payload/sequence every time except on UTF-16, UTF-32. + """ + + if not explain: + logger.setLevel(logging.CRITICAL) + else: + logger.setLevel(logging.INFO) + + length = len(sequences) # type: int + + if length == 0: + logger.warning("Given content is empty, stopping the process very early, returning empty utf_8 str match") + return CharsetMatches( + [ + CharsetMatch( + sequences, + "utf_8", + 0., + False, + [], + "" + ) + ] + ) + + if cp_isolation is not None: + logger.warning('cp_isolation is set. use this flag for debugging purpose. ' + 'limited list of encoding allowed : %s.', + ', '.join(cp_isolation)) + cp_isolation = [iana_name(cp, False) for cp in cp_isolation] + else: + cp_isolation = [] + + if cp_exclusion is not None: + logger.warning( + 'cp_exclusion is set. use this flag for debugging purpose. ' + 'limited list of encoding excluded : %s.', + ', '.join(cp_exclusion)) + cp_exclusion = [iana_name(cp, False) for cp in cp_exclusion] + else: + cp_exclusion = [] + + if length <= (chunk_size * steps): + logger.warning( + 'override steps (%i) and chunk_size (%i) as content does not fit (%i byte(s) given) parameters.', + steps, chunk_size, length) + steps = 1 + chunk_size = length + + if steps > 1 and length / steps < chunk_size: + chunk_size = int(length / steps) + + is_too_small_sequence = len(sequences) < TOO_SMALL_SEQUENCE # type: bool + is_too_large_sequence = len(sequences) >= TOO_BIG_SEQUENCE # type: bool + + if is_too_small_sequence: + warn('Trying to detect encoding from a tiny portion of ({}) byte(s).'.format(length)) + + prioritized_encodings = [] # type: List[str] + + specified_encoding = any_specified_encoding(sequences) if preemptive_behaviour is True else None # type: Optional[str] + + if specified_encoding is not None: + prioritized_encodings.append(specified_encoding) + logger.info('Detected declarative mark in sequence. Priority +1 given for %s.', specified_encoding) + + tested = set() # type: Set[str] + tested_but_hard_failure = [] # type: List[str] + tested_but_soft_failure = [] # type: List[str] + + fallback_ascii = None # type: Optional[CharsetMatch] + fallback_u8 = None # type: Optional[CharsetMatch] + + single_byte_hard_failure_count = 0 # type: int + single_byte_soft_failure_count = 0 # type: int + + results = CharsetMatches() # type: CharsetMatches + + sig_encoding, sig_payload = identify_sig_or_bom(sequences) + + if sig_encoding is not None: + prioritized_encodings.append(sig_encoding) + logger.info('Detected a SIG or BOM mark on first %i byte(s). Priority +1 given for %s.', len(sig_payload), sig_encoding) + + prioritized_encodings.append("ascii") + + if "utf_8" not in prioritized_encodings: + prioritized_encodings.append("utf_8") + + for encoding_iana in prioritized_encodings+IANA_SUPPORTED: + + if cp_isolation and encoding_iana not in cp_isolation: + continue + + if cp_exclusion and encoding_iana in cp_exclusion: + continue + + if encoding_iana in tested: + continue + + tested.add(encoding_iana) + + decoded_payload = None # type: Optional[str] + bom_or_sig_available = sig_encoding == encoding_iana # type: bool + strip_sig_or_bom = bom_or_sig_available and should_strip_sig_or_bom(encoding_iana) # type: bool + + if encoding_iana in {"utf_16", "utf_32"} and bom_or_sig_available is False: + logger.info("Encoding %s wont be tested as-is because it require a BOM. Will try some sub-encoder LE/BE.", encoding_iana) + continue + + try: + is_multi_byte_decoder = is_multi_byte_encoding(encoding_iana) # type: bool + except (ModuleNotFoundError, ImportError): + logger.debug("Encoding %s does not provide an IncrementalDecoder", encoding_iana) + continue + + try: + if is_too_large_sequence and is_multi_byte_decoder is False: + str( + sequences[:int(50e4)] if strip_sig_or_bom is False else sequences[len(sig_payload):int(50e4)], + encoding=encoding_iana + ) + else: + decoded_payload = str( + sequences if strip_sig_or_bom is False else sequences[len(sig_payload):], + encoding=encoding_iana + ) + except UnicodeDecodeError as e: + logger.warning('Code page %s does not fit given bytes sequence at ALL. %s', encoding_iana, str(e)) + tested_but_hard_failure.append(encoding_iana) + if not is_multi_byte_decoder: + single_byte_hard_failure_count += 1 + continue + except LookupError: + tested_but_hard_failure.append(encoding_iana) + if not is_multi_byte_decoder: + single_byte_hard_failure_count += 1 + continue + + similar_soft_failure_test = False # type: bool + + for encoding_soft_failed in tested_but_soft_failure: + if is_cp_similar(encoding_iana, encoding_soft_failed): + similar_soft_failure_test = True + break + + if similar_soft_failure_test: + logger.warning("%s is deemed too similar to code page %s and was consider unsuited already. Continuing!", encoding_iana, encoding_soft_failed) + continue + + r_ = range( + 0 if bom_or_sig_available is False else len(sig_payload), + length, + int(length / steps) + ) + + multi_byte_bonus = is_multi_byte_decoder and decoded_payload is not None and len(decoded_payload) < length # type: bool + + if multi_byte_bonus: + logger.info('Code page %s is a multi byte encoding table and it appear that at least one character was encoded using n-bytes. Should not be a coincidence. Priority +1 given.', encoding_iana) + + max_chunk_gave_up = int(len(r_) / 4) # type: int + + if max_chunk_gave_up < 2: + max_chunk_gave_up = 2 + + early_stop_count = 0 # type: int + + md_chunks = [] # type: List[str] + md_ratios = [] + + for i in r_: + cut_sequence = sequences[i:i + chunk_size] + + if bom_or_sig_available and strip_sig_or_bom is False: + cut_sequence = sig_payload+cut_sequence + + chunk = cut_sequence.decode(encoding_iana, errors="ignore") # type: str + + md_chunks.append(chunk) + + md_ratios.append( + mess_ratio( + chunk, + threshold + ) + ) + + if md_ratios[-1] >= threshold: + early_stop_count += 1 + + if (early_stop_count >= max_chunk_gave_up) or (bom_or_sig_available and strip_sig_or_bom is False): + break + + if md_ratios: + mean_mess_ratio = sum(md_ratios) / len(md_ratios) # type: float + else: + mean_mess_ratio = 0. + + if mean_mess_ratio >= threshold or early_stop_count >= max_chunk_gave_up: + tested_but_soft_failure.append(encoding_iana) + if not is_multi_byte_decoder: + single_byte_soft_failure_count += 1 + logger.warning('%s was excluded because of initial chaos probing. Gave up %i time(s). ' + 'Computed mean chaos is %f %%.', + encoding_iana, + early_stop_count, + round(mean_mess_ratio * 100, ndigits=3)) + # Preparing those fallbacks in case we got nothing. + if encoding_iana in ["ascii", "utf_8"]: + fallback_entry = CharsetMatch( + sequences, + encoding_iana, + threshold, + False, + [], + decoded_payload + ) + if encoding_iana == "ascii": + fallback_ascii = fallback_entry + else: + fallback_u8 = fallback_entry + continue + + logger.info( + '%s passed initial chaos probing. Mean measured chaos is %f %%', + encoding_iana, + round(mean_mess_ratio * 100, ndigits=3) + ) + + if not is_multi_byte_decoder: + target_languages = encoding_languages(encoding_iana) # type: List[str] + else: + target_languages = mb_encoding_languages(encoding_iana) + + if target_languages: + logger.info("{} should target any language(s) of {}".format(encoding_iana, str(target_languages))) + + cd_ratios = [] + + for chunk in md_chunks: + chunk_languages = coherence_ratio(chunk, 0.1, ",".join(target_languages) if target_languages else None) + + cd_ratios.append( + chunk_languages + ) + + cd_ratios_merged = merge_coherence_ratios(cd_ratios) + + if cd_ratios_merged: + logger.info("We detected language {} using {}".format(cd_ratios_merged, encoding_iana)) + + results.append( + CharsetMatch( + sequences, + encoding_iana, + mean_mess_ratio, + bom_or_sig_available, + cd_ratios_merged, + decoded_payload + ) + ) + + if encoding_iana in [specified_encoding, "ascii", "utf_8"] and mean_mess_ratio < 0.1: + logger.info("%s is most likely the one. Stopping the process.", encoding_iana) + return CharsetMatches( + [results[encoding_iana]] + ) + + if encoding_iana == sig_encoding: + logger.info( + "%s is most likely the one as we detected a BOM or SIG within the beginning of the sequence.", + encoding_iana + ) + return CharsetMatches( + [results[encoding_iana]] + ) + + if results[-1].languages: + logger.info( + "Using %s code page we detected the following languages: %s", + encoding_iana, + results[-1]._languages + ) + + if len(results) == 0: + if fallback_u8 or fallback_ascii: + logger.warning("Nothing got out of the detection process. Using ASCII/UTF-8 fallback.") + + if (fallback_u8 and fallback_ascii is None) or (fallback_u8 and fallback_u8.fingerprint != fallback_ascii.fingerprint): + logger.warning("utf_8 will be used as a fallback match") + results.append(fallback_u8) + elif fallback_ascii: + logger.warning("ascii will be used as a fallback match") + results.append(fallback_ascii) + + return results + + +def from_fp( + fp: BinaryIO, + steps: int = 5, + chunk_size: int = 512, + threshold: float = 0.20, + cp_isolation: List[str] = None, + cp_exclusion: List[str] = None, + preemptive_behaviour: bool = True, + explain: bool = False +) -> CharsetMatches: + """ + Same thing than the function from_bytes but using a file pointer that is already ready. + Will not close the file pointer. + """ + return from_bytes( + fp.read(), + steps, + chunk_size, + threshold, + cp_isolation, + cp_exclusion, + preemptive_behaviour, + explain + ) + + +def from_path( + path: PathLike, + steps: int = 5, + chunk_size: int = 512, + threshold: float = 0.20, + cp_isolation: List[str] = None, + cp_exclusion: List[str] = None, + preemptive_behaviour: bool = True, + explain: bool = False +) -> CharsetMatches: + """ + Same thing than the function from_bytes but with one extra step. Opening and reading given file path in binary mode. + Can raise IOError. + """ + with open(path, 'rb') as fp: + return from_fp(fp, steps, chunk_size, threshold, cp_isolation, cp_exclusion, preemptive_behaviour, explain) + + +def normalize(path: PathLike, steps: int = 5, chunk_size: int = 512, threshold: float = 0.20, cp_isolation: List[str] = None, cp_exclusion: List[str] = None, preemptive_behaviour: bool = True) -> CharsetMatch: + """ + Take a (text-based) file path and try to create another file next to it, this time using UTF-8. + """ + results = from_path( + path, + steps, + chunk_size, + threshold, + cp_isolation, + cp_exclusion, + preemptive_behaviour + ) + + filename = basename(path) + target_extensions = list(splitext(filename)) + + if len(results) == 0: + raise IOError('Unable to normalize "{}", no encoding charset seems to fit.'.format(filename)) + + result = results.best() + + target_extensions[0] += '-' + result.encoding # type: ignore + + with open('{}'.format(path.replace(filename, ''.join(target_extensions))), 'wb') as fp: + fp.write( + result.output() # type: ignore + ) + + return result # type: ignore diff --git a/venv/lib/python3.8/site-packages/charset_normalizer/assets/__init__.py b/venv/lib/python3.8/site-packages/charset_normalizer/assets/__init__.py new file mode 100644 index 0000000..2d93773 --- /dev/null +++ b/venv/lib/python3.8/site-packages/charset_normalizer/assets/__init__.py @@ -0,0 +1,52 @@ +""" +This submodule purpose is to load attached JSON asset. +Will be loaded once per package import / python init. + +The file 'frequencies.json' is mandatory for language/coherence detection. Not having it will weaker considerably +the core detection. +""" +from collections import OrderedDict + + +FREQUENCIES = OrderedDict( + [ + ('English', ['e', 'a', 't', 'i', 'o', 'n', 's', 'r', 'h', 'l', 'd', 'c', 'u', 'm', 'f', 'p', 'g', 'w', 'y', 'b', 'v', 'k', 'x', 'j', 'z', 'q']), + ('German', ['e', 'n', 'i', 'r', 's', 't', 'a', 'd', 'h', 'u', 'l', 'g', 'o', 'c', 'm', 'b', 'f', 'k', 'w', 'z', 'p', 'v', 'ü', 'ä', 'ö', 'j']), + ('French', ['e', 'a', 's', 'n', 'i', 't', 'r', 'l', 'u', 'o', 'd', 'c', 'p', 'm', 'é', 'v', 'g', 'f', 'b', 'h', 'q', 'à', 'x', 'è', 'y', 'j']), + ('Dutch', ['e', 'n', 'a', 'i', 'r', 't', 'o', 'd', 's', 'l', 'g', 'h', 'v', 'm', 'u', 'k', 'c', 'p', 'b', 'w', 'j', 'z', 'f', 'y', 'x', 'ë']), + ('Italian', ['e', 'i', 'a', 'o', 'n', 'l', 't', 'r', 's', 'c', 'd', 'u', 'p', 'm', 'g', 'v', 'f', 'b', 'z', 'h', 'q', 'è', 'à', 'k', 'y', 'ò']), + ('Polish', ['a', 'i', 'o', 'e', 'n', 'r', 'z', 'w', 's', 'c', 't', 'k', 'y', 'd', 'p', 'm', 'u', 'l', 'j', 'ł', 'g', 'b', 'h', 'ą', 'ę', 'ó']), + ('Spanish', ['e', 'a', 'o', 'n', 's', 'r', 'i', 'l', 'd', 't', 'c', 'u', 'm', 'p', 'b', 'g', 'v', 'f', 'y', 'ó', 'h', 'q', 'í', 'j', 'z', 'á']), + ('Russian', ['о', 'а', 'е', 'и', 'н', 'с', 'т', 'р', 'в', 'л', 'к', 'м', 'д', 'п', 'у', 'г', 'я', 'ы', 'з', 'б', 'й', 'ь', 'ч', 'х', 'ж', 'ц']), + ('Japanese', ['の', 'に', 'る', 'た', 'は', 'ー', 'と', 'し', 'を', 'で', 'て', 'が', 'い', 'ン', 'れ', 'な', '年', 'ス', 'っ', 'ル', 'か', 'ら', 'あ', 'さ', 'も', 'り']), + ('Portuguese', ['a', 'e', 'o', 's', 'i', 'r', 'd', 'n', 't', 'm', 'u', 'c', 'l', 'p', 'g', 'v', 'b', 'f', 'h', 'ã', 'q', 'é', 'ç', 'á', 'z', 'í']), + ('Swedish', ['e', 'a', 'n', 'r', 't', 's', 'i', 'l', 'd', 'o', 'm', 'k', 'g', 'v', 'h', 'f', 'u', 'p', 'ä', 'c', 'b', 'ö', 'å', 'y', 'j', 'x']), + ('Chinese', ['的', '一', '是', '不', '了', '在', '人', '有', '我', '他', '这', '个', '们', '中', '来', '上', '大', '为', '和', '国', '地', '到', '以', '说', '时', '要', '就', '出', '会']), + ('Ukrainian', ['о', 'а', 'н', 'і', 'и', 'р', 'в', 'т', 'е', 'с', 'к', 'л', 'у', 'д', 'м', 'п', 'з', 'я', 'ь', 'б', 'г', 'й', 'ч', 'х', 'ц', 'ї']), + ('Norwegian', ['e', 'r', 'n', 't', 'a', 's', 'i', 'o', 'l', 'd', 'g', 'k', 'm', 'v', 'f', 'p', 'u', 'b', 'h', 'å', 'y', 'j', 'ø', 'c', 'æ', 'w']), + ('Finnish', ['a', 'i', 'n', 't', 'e', 's', 'l', 'o', 'u', 'k', 'ä', 'm', 'r', 'v', 'j', 'h', 'p', 'y', 'd', 'ö', 'g', 'c', 'b', 'f', 'w', 'z']), + ('Vietnamese', ['n', 'h', 't', 'i', 'c', 'g', 'a', 'o', 'u', 'm', 'l', 'r', 'à', 'đ', 's', 'e', 'v', 'p', 'b', 'y', 'ư', 'd', 'á', 'k', 'ộ', 'ế']), + ('Czech', ['o', 'e', 'a', 'n', 't', 's', 'i', 'l', 'v', 'r', 'k', 'd', 'u', 'm', 'p', 'í', 'c', 'h', 'z', 'á', 'y', 'j', 'b', 'ě', 'é', 'ř']), + ('Hungarian', ['e', 'a', 't', 'l', 's', 'n', 'k', 'r', 'i', 'o', 'z', 'á', 'é', 'g', 'm', 'b', 'y', 'v', 'd', 'h', 'u', 'p', 'j', 'ö', 'f', 'c']), + ('Korean', ['이', '다', '에', '의', '는', '로', '하', '을', '가', '고', '지', '서', '한', '은', '기', '으', '년', '대', '사', '시', '를', '리', '도', '인', '스', '일']), + ('Indonesian', ['a', 'n', 'e', 'i', 'r', 't', 'u', 's', 'd', 'k', 'm', 'l', 'g', 'p', 'b', 'o', 'h', 'y', 'j', 'c', 'w', 'f', 'v', 'z', 'x', 'q']), + ('Turkish', ['a', 'e', 'i', 'n', 'r', 'l', 'ı', 'k', 'd', 't', 's', 'm', 'y', 'u', 'o', 'b', 'ü', 'ş', 'v', 'g', 'z', 'h', 'c', 'p', 'ç', 'ğ']), + ('Romanian', ['e', 'i', 'a', 'r', 'n', 't', 'u', 'l', 'o', 'c', 's', 'd', 'p', 'm', 'ă', 'f', 'v', 'î', 'g', 'b', 'ș', 'ț', 'z', 'h', 'â', 'j']), + ('Farsi', ['ا', 'ی', 'ر', 'د', 'ن', 'ه', 'و', 'م', 'ت', 'ب', 'س', 'ل', 'ک', 'ش', 'ز', 'ف', 'گ', 'ع', 'خ', 'ق', 'ج', 'آ', 'پ', 'ح', 'ط', 'ص']), + ('Arabic', ['ا', 'ل', 'ي', 'م', 'و', 'ن', 'ر', 'ت', 'ب', 'ة', 'ع', 'د', 'س', 'ف', 'ه', 'ك', 'ق', 'أ', 'ح', 'ج', 'ش', 'ط', 'ص', 'ى', 'خ', 'إ']), + ('Danish', ['e', 'r', 'n', 't', 'a', 'i', 's', 'd', 'l', 'o', 'g', 'm', 'k', 'f', 'v', 'u', 'b', 'h', 'p', 'å', 'y', 'ø', 'æ', 'c', 'j', 'w']), + ('Serbian', ['а', 'и', 'о', 'е', 'н', 'р', 'с', 'у', 'т', 'к', 'ј', 'в', 'д', 'м', 'п', 'л', 'г', 'з', 'б', 'a', 'i', 'e', 'o', 'n', 'ц', 'ш']), + ('Lithuanian', ['i', 'a', 's', 'o', 'r', 'e', 't', 'n', 'u', 'k', 'm', 'l', 'p', 'v', 'd', 'j', 'g', 'ė', 'b', 'y', 'ų', 'š', 'ž', 'c', 'ą', 'į']), + ('Slovene', ['e', 'a', 'i', 'o', 'n', 'r', 's', 'l', 't', 'j', 'v', 'k', 'd', 'p', 'm', 'u', 'z', 'b', 'g', 'h', 'č', 'c', 'š', 'ž', 'f', 'y']), + ('Slovak', ['o', 'a', 'e', 'n', 'i', 'r', 'v', 't', 's', 'l', 'k', 'd', 'm', 'p', 'u', 'c', 'h', 'j', 'b', 'z', 'á', 'y', 'ý', 'í', 'č', 'é']), + ('Hebrew', ['י', 'ו', 'ה', 'ל', 'ר', 'ב', 'ת', 'מ', 'א', 'ש', 'נ', 'ע', 'ם', 'ד', 'ק', 'ח', 'פ', 'ס', 'כ', 'ג', 'ט', 'צ', 'ן', 'ז', 'ך']), + ('Bulgarian', ['а', 'и', 'о', 'е', 'н', 'т', 'р', 'с', 'в', 'л', 'к', 'д', 'п', 'м', 'з', 'г', 'я', 'ъ', 'у', 'б', 'ч', 'ц', 'й', 'ж', 'щ', 'х']), + ('Croatian', ['a', 'i', 'o', 'e', 'n', 'r', 'j', 's', 't', 'u', 'k', 'l', 'v', 'd', 'm', 'p', 'g', 'z', 'b', 'c', 'č', 'h', 'š', 'ž', 'ć', 'f']), + ('Hindi', ['क', 'र', 'स', 'न', 'त', 'म', 'ह', 'प', 'य', 'ल', 'व', 'ज', 'द', 'ग', 'ब', 'श', 'ट', 'अ', 'ए', 'थ', 'भ', 'ड', 'च', 'ध', 'ष', 'इ']), + ('Estonian', ['a', 'i', 'e', 's', 't', 'l', 'u', 'n', 'o', 'k', 'r', 'd', 'm', 'v', 'g', 'p', 'j', 'h', 'ä', 'b', 'õ', 'ü', 'f', 'c', 'ö', 'y']), + ('Simple English', ['e', 'a', 't', 'i', 'o', 'n', 's', 'r', 'h', 'l', 'd', 'c', 'm', 'u', 'f', 'p', 'g', 'w', 'b', 'y', 'v', 'k', 'j', 'x', 'z', 'q']), + ('Thai', ['า', 'น', 'ร', 'อ', 'ก', 'เ', 'ง', 'ม', 'ย', 'ล', 'ว', 'ด', 'ท', 'ส', 'ต', 'ะ', 'ป', 'บ', 'ค', 'ห', 'แ', 'จ', 'พ', 'ช', 'ข', 'ใ']), + ('Greek', ['α', 'τ', 'ο', 'ι', 'ε', 'ν', 'ρ', 'σ', 'κ', 'η', 'π', 'ς', 'υ', 'μ', 'λ', 'ί', 'ό', 'ά', 'γ', 'έ', 'δ', 'ή', 'ω', 'χ', 'θ', 'ύ']), + ('Tamil', ['க', 'த', 'ப', 'ட', 'ர', 'ம', 'ல', 'ன', 'வ', 'ற', 'ய', 'ள', 'ச', 'ந', 'இ', 'ண', 'அ', 'ஆ', 'ழ', 'ங', 'எ', 'உ', 'ஒ', 'ஸ']), + ('Classical Chinese', ['之', '年', '為', '也', '以', '一', '人', '其', '者', '國', '有', '二', '十', '於', '曰', '三', '不', '大', '而', '子', '中', '五', '四'])] +) diff --git a/venv/lib/python3.8/site-packages/charset_normalizer/assets/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/charset_normalizer/assets/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..8a10fe2976f6f87e466cd70b8d0d2d76d65d8b47 GIT binary patch literal 6042 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 BN-F>W literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/charset_normalizer/cd.py b/venv/lib/python3.8/site-packages/charset_normalizer/cd.py new file mode 100644 index 0000000..c4fc1ba --- /dev/null +++ b/venv/lib/python3.8/site-packages/charset_normalizer/cd.py @@ -0,0 +1,261 @@ +from codecs import IncrementalDecoder +from functools import lru_cache +from typing import List, Set, Optional, Tuple, Dict +import importlib + +from charset_normalizer.models import CoherenceMatches +from charset_normalizer.utils import unicode_range, is_unicode_range_secondary, is_multi_byte_encoding +from charset_normalizer.md import is_suspiciously_successive_range +from charset_normalizer.assets import FREQUENCIES +from collections import Counter + + +def encoding_unicode_range(iana_name: str) -> List[str]: + """ + Return associated unicode ranges in a single byte code page. + """ + if is_multi_byte_encoding(iana_name): + raise IOError("Function not supported on multi-byte code page") + + decoder = importlib.import_module('encodings.{}'.format(iana_name)).IncrementalDecoder # type: ignore + + p = decoder(errors="ignore") # type: IncrementalDecoder + seen_ranges = set() # type: Set[str] + + for i in range(48, 255): + chunk = p.decode( + bytes([i]) + ) # type: str + + if chunk: + character_range = unicode_range(chunk) # type: Optional[str] + + if character_range is None: + continue + + if is_unicode_range_secondary(character_range) is False: + seen_ranges.add(character_range) + + return sorted(list(seen_ranges)) + + +def unicode_range_languages(primary_range: str) -> List[str]: + """ + Return inferred languages used with a unicode range. + """ + languages = [] # type: List[str] + + for language, characters in FREQUENCIES.items(): + for character in characters: + if unicode_range(character) == primary_range: + languages.append(language) + break + + return languages + + +@lru_cache() +def encoding_languages(iana_name: str) -> List[str]: + """ + Single-byte encoding language association. Some code page are heavily linked to particular language(s). + This function does the correspondence. + """ + unicode_ranges = encoding_unicode_range(iana_name) # type: List[str] + primary_range = None # type: Optional[str] + + for specified_range in unicode_ranges: + if "Latin" not in specified_range: + primary_range = specified_range + break + + if primary_range is None: + return ["Latin Based"] + + return unicode_range_languages(primary_range) + + +def mb_encoding_languages(iana_name: str) -> List[str]: + """ + Multi-byte encoding language association. Some code page are heavily linked to particular language(s). + This function does the correspondence. + """ + if iana_name.startswith("shift_") or iana_name.startswith("iso2022_jp") or iana_name.startswith("euc_j") or iana_name in {"cp932"}: + return ["Japanese"] + if iana_name.startswith("gb") or iana_name in {"big5", "cp950", "big5hkscs"}: + return ["Chinese", "Classical Chinese"] + if iana_name.startswith("iso2022_kr") or iana_name in {"johab", "cp949", "euc_kr"}: + return ["Korean"] + + return [] + + +def alphabet_languages(characters: List[str]) -> List[str]: + """ + Return associated languages associated to given characters. + """ + languages = [] # type: List[str] + + for language, language_characters in FREQUENCIES.items(): + character_match_count = 0 # type: int + character_count = len(language_characters) # type: int + + for character in language_characters: + if character in characters: + character_match_count += 1 + + if character_match_count / character_count >= 0.2: + languages.append(language) + + return languages + + +def characters_popularity_compare(language: str, ordered_characters: List[str]) -> float: + """ + Determine if a ordered characters list (by occurrence from most appearance to rarest) match a particular language. + The result is a ratio between 0. (absolutely no correspondence) and 1. (near perfect fit). + Beware that is function is not strict on the match in order to ease the detection. (Meaning close match is 1.) + """ + if language not in FREQUENCIES: + raise ValueError("{} not available".format(language)) + + character_approved_count = 0 # type: int + + for character in ordered_characters: + if character not in FREQUENCIES[language]: + continue + + characters_before_source = FREQUENCIES[language][0:FREQUENCIES[language].index(character)] # type: List[str] + characters_after_source = FREQUENCIES[language][FREQUENCIES[language].index(character):] # type: List[str] + + characters_before = ordered_characters[0:ordered_characters.index(character)] # type: List[str] + characters_after = ordered_characters[ordered_characters.index(character):] # type: List[str] + + before_match_count = [e in characters_before for e in characters_before_source].count(True) # type: int + after_match_count = [e in characters_after for e in characters_after_source].count(True) # type: int + + if len(characters_before_source) == 0 and before_match_count <= 4: + character_approved_count += 1 + continue + + if len(characters_after_source) == 0 and after_match_count <= 4: + character_approved_count += 1 + continue + + if before_match_count / len(characters_before_source) >= 0.4 or after_match_count / len(characters_after_source) >= 0.4: + character_approved_count += 1 + continue + + return character_approved_count / len(ordered_characters) + + +def alpha_unicode_split(decoded_sequence: str) -> List[str]: + """ + Given a decoded text sequence, return a list of str. Unicode range / alphabet separation. + Ex. a text containing English/Latin with a bit a Hebrew will return two items in the resulting list; + One containing the latin letters and the other hebrew. + """ + layers = {} # type: Dict[str, str] + + for character in decoded_sequence: + if character.isalpha() is False: + continue + + character_range = unicode_range(character) # type: str + + layer_target_range = None # type: Optional[str] + + for discovered_range in layers: + if is_suspiciously_successive_range(discovered_range, character_range) is False: + layer_target_range = discovered_range + break + + if layer_target_range is None: + layer_target_range = character_range + + if layer_target_range not in layers: + layers[layer_target_range] = character.lower() + continue + + layers[layer_target_range] += character.lower() + + return list(layers.values()) + + +def merge_coherence_ratios(results: List[CoherenceMatches]) -> CoherenceMatches: + """ + This function merge results previously given by the function coherence_ratio. + The return type is the same as coherence_ratio. + """ + per_language_ratios = {} # type: Dict[str, List[float]] + merge = [] # type: CoherenceMatches + + for result in results: + for sub_result in result: + language, ratio = sub_result + if language not in per_language_ratios: + per_language_ratios[language] = [ratio] + continue + per_language_ratios[language].append( + ratio + ) + + for language in per_language_ratios: + merge.append( + ( + language, + round( + sum( + per_language_ratios[language] + ) / len(per_language_ratios[language]), + 4 + ) + ) + ) + + return sorted(merge, key=lambda x: x[1], reverse=True) + + +@lru_cache(maxsize=2048) +def coherence_ratio(decoded_sequence: str, threshold: float = 0.1, lg_inclusion: Optional[str] = None) -> CoherenceMatches: + """ + Detect ANY language that can be identified in given sequence. The sequence will be analysed by layers. + A layer = Character extraction by alphabets/ranges. + """ + + results = [] # type: List[Tuple[str, float]] + + sufficient_match_count = 0 # type: int + + if lg_inclusion is not None: + lg_inclusion = lg_inclusion.split(",") + + if lg_inclusion is not None and "Latin Based" in lg_inclusion: + lg_inclusion.remove("Latin Based") + + for layer in alpha_unicode_split(decoded_sequence): + sequence_frequencies = Counter(layer) # type: Counter + most_common = sequence_frequencies.most_common() + + character_count = sum([o for c, o in most_common]) # type: int + + if character_count <= 32: + continue + + popular_character_ordered = [c for c, o in most_common] # type: List[str] + + for language in lg_inclusion or alphabet_languages(popular_character_ordered): + ratio = characters_popularity_compare(language, popular_character_ordered) # type: float + + if ratio < threshold: + continue + elif ratio >= 0.8: + sufficient_match_count += 1 + + results.append( + (language, round(ratio, 4)) + ) + + if sufficient_match_count >= 3: + break + + return sorted(results, key=lambda x: x[1], reverse=True) diff --git a/venv/lib/python3.8/site-packages/charset_normalizer/cli/__init__.py b/venv/lib/python3.8/site-packages/charset_normalizer/cli/__init__.py new file mode 100644 index 0000000..e69de29 diff --git a/venv/lib/python3.8/site-packages/charset_normalizer/cli/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/charset_normalizer/cli/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..023eb07522e7672c786b227373d29ec05eb860ac GIT binary patch literal 158 zcmWIL<>g`kf(lF3L=gQLL?8o3AjbiSi&=m~3PUi1CZpd%JwC literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/charset_normalizer/cli/__pycache__/normalizer.cpython-38.pyc b/venv/lib/python3.8/site-packages/charset_normalizer/cli/__pycache__/normalizer.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..2c0780cd98a389a9141e33277fb59e9568102d0c GIT binary patch literal 5765 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. + It must be "yes" (the default), "no" or None (meaning + an answer is required of the user). + + The "answer" return value is True for "yes" or False for "no". + + Credit goes to (c) https://stackoverflow.com/questions/3041986/apt-command-line-interface-like-yes-no-input + """ + valid = {"yes": True, "y": True, "ye": True, + "no": False, "n": False} + if default is None: + prompt = " [y/n] " + elif default == "yes": + prompt = " [Y/n] " + elif default == "no": + prompt = " [y/N] " + else: + raise ValueError("invalid default answer: '%s'" % default) + + while True: + sys.stdout.write(question + prompt) + choice = input().lower() + if default is not None and choice == '': + return valid[default] + elif choice in valid: + return valid[choice] + else: + sys.stdout.write("Please respond with 'yes' or 'no' " + "(or 'y' or 'n').\n") + + +def cli_detect(argv=None): + """ + CLI assistant using ARGV and ArgumentParser + :param argv: + :return: 0 if everything is fine, anything else equal trouble + """ + parser = argparse.ArgumentParser( + description="The Real First Universal Charset Detector. " + "Discover originating encoding used on text file. " + "Normalize text to unicode." + ) + + parser.add_argument('files', type=argparse.FileType('rb'), nargs='+', help='File(s) to be analysed') + parser.add_argument('-v', '--verbose', action="store_true", default=False, dest='verbose', + help='Display complementary information about file if any. Stdout will contain logs about the detection process.') + parser.add_argument('-a', '--with-alternative', action="store_true", default=False, dest='alternatives', + help='Output complementary possibilities if any. Top-level JSON WILL be a list.') + parser.add_argument('-n', '--normalize', action="store_true", default=False, dest='normalize', + help='Permit to normalize input file. If not set, program does not write anything.') + parser.add_argument('-m', '--minimal', action="store_true", default=False, dest='minimal', + help='Only output the charset detected to STDOUT. Disabling JSON output.') + parser.add_argument('-r', '--replace', action="store_true", default=False, dest='replace', + help='Replace file when trying to normalize it instead of creating a new one.') + parser.add_argument('-f', '--force', action="store_true", default=False, dest='force', + help='Replace file without asking if you are sure, use this flag with caution.') + parser.add_argument('-t', '--threshold', action="store", default=0.1, type=float, dest='threshold', + help="Define a custom maximum amount of chaos allowed in decoded content. 0. <= chaos <= 1.") + parser.add_argument( + "--version", + action="version", + version="Charset-Normalizer {} - Python {}".format(__version__, python_version()), + help="Show version information and exit." + ) + + args = parser.parse_args(argv) + + if args.replace is True and args.normalize is False: + print('Use --replace in addition of --normalize only.', file=sys.stderr) + return 1 + + if args.force is True and args.replace is False: + print('Use --force in addition of --replace only.', file=sys.stderr) + return 1 + + if args.threshold < 0. or args.threshold > 1.: + print('--threshold VALUE should be between 0. AND 1.', file=sys.stderr) + return 1 + + for my_file in args.files: + + matches = from_fp( + my_file, + threshold=args.threshold, + explain=args.verbose + ) + + if len(matches) == 0: + print('Unable to identify originating encoding for "{}". {}'.format(my_file.name, 'Maybe try increasing maximum amount of chaos.' if args.threshold < 1. else ''), file=sys.stderr) + if my_file.closed is False: + my_file.close() + continue + + x_ = [] + + r_ = matches.best() + p_ = r_.first() + + x_.append( + CliDetectionResult( + abspath(my_file.name), + p_.encoding, + p_.encoding_aliases, + [cp for cp in p_.could_be_from_charset if cp != p_.encoding], + p_.language, + p_.alphabets, + p_.bom, + p_.percent_chaos, + p_.percent_coherence, + None, + True + ) + ) + + if len(matches) > 1 and args.alternatives: + for el in matches: + if el != p_: + x_.append( + CliDetectionResult( + abspath(my_file.name), + el.encoding, + el.encoding_aliases, + [cp for cp in el.could_be_from_charset if cp != el.encoding], + el.language, + el.alphabets, + el.bom, + el.percent_chaos, + el.percent_coherence, + None, + False + ) + ) + + if args.normalize is True: + + if p_.encoding.startswith('utf') is True: + print('"{}" file does not need to be normalized, as it already came from unicode.'.format(my_file.name), file=sys.stderr) + if my_file.closed is False: + my_file.close() + continue + + o_ = my_file.name.split('.') # type: list[str] + + if args.replace is False: + o_.insert(-1, p_.encoding) + if my_file.closed is False: + my_file.close() + else: + if args.force is False and query_yes_no( + 'Are you sure to normalize "{}" by replacing it ?'.format(my_file.name), 'no') is False: + if my_file.closed is False: + my_file.close() + continue + + try: + x_[0].unicode_path = './{}'.format('.'.join(o_)) + + with open(x_[0].unicode_path, 'w', encoding='utf-8') as fp: + fp.write( + str(p_) + ) + except IOError as e: + print(str(e), file=sys.stderr) + if my_file.closed is False: + my_file.close() + return 2 + + if my_file.closed is False: + my_file.close() + + if args.minimal is False: + print( + dumps( + [ + el.__dict__ for el in x_ + ] if args.alternatives else x_[0].__dict__, + ensure_ascii=True, + indent=4 + ) + ) + else: + print( + ', '.join( + [ + el.encoding for el in x_ + ] + ) + ) + + return 0 + + +if __name__ == '__main__': + cli_detect() diff --git a/venv/lib/python3.8/site-packages/charset_normalizer/constant.py b/venv/lib/python3.8/site-packages/charset_normalizer/constant.py new file mode 100644 index 0000000..c9c9655 --- /dev/null +++ b/venv/lib/python3.8/site-packages/charset_normalizer/constant.py @@ -0,0 +1,343 @@ +from codecs import BOM_UTF8, BOM_UTF16_BE, BOM_UTF16_LE, BOM_UTF32_BE, BOM_UTF32_LE +from typing import Dict, List, Union +from encodings.aliases import aliases +from re import compile as re_compile, IGNORECASE +from collections import OrderedDict + +# Contain for each eligible encoding a list of/item bytes SIG/BOM +ENCODING_MARKS = OrderedDict([ + ('utf_8', BOM_UTF8), + ('utf_7', [ + b'\x2b\x2f\x76\x38', + b'\x2b\x2f\x76\x39', + b'\x2b\x2f\x76\x2b', + b'\x2b\x2f\x76\x2f', + b'\x2b\x2f\x76\x38\x2d' + ]), + ('gb18030', b'\x84\x31\x95\x33'), + ('utf_32', [ + BOM_UTF32_BE, + BOM_UTF32_LE + ]), + ('utf_16', [ + BOM_UTF16_BE, + BOM_UTF16_LE + ]), +]) # type: Dict[str, Union[bytes, List[bytes]]] + +TOO_SMALL_SEQUENCE = 32 # type: int +TOO_BIG_SEQUENCE = int(10e6) # type: int + +UTF8_MAXIMAL_ALLOCATION = 1112064 # type: int + +UNICODE_RANGES_COMBINED = {'Control character': range(0, 31+1), 'Basic Latin': range(32, 127+1), 'Latin-1 Supplement': range(128, 255+1), 'Latin Extended-A': range(256, 383+1), 'Latin Extended-B': range(384, 591+1), 'IPA Extensions': range(592, 687+1), 'Spacing Modifier Letters': range(688, 767+1), 'Combining Diacritical Marks': range(768, 879+1), 'Greek and Coptic': range(880, 1023+1), 'Cyrillic': range(1024, 1279+1), 'Cyrillic Supplement': range(1280, 1327+1), 'Armenian': range(1328, 1423+1), 'Hebrew': range(1424, 1535+1), 'Arabic': range(1536, 1791+1), 'Syriac': range(1792, 1871+1), 'Arabic Supplement': range(1872, 1919+1), 'Thaana': range(1920, 1983+1), 'NKo': range(1984, 2047+1), 'Samaritan': range(2048, 2111+1), 'Mandaic': range(2112, 2143+1), 'Syriac Supplement': range(2144, 2159+1), 'Arabic Extended-A': range(2208, 2303+1), 'Devanagari': range(2304, 2431+1), 'Bengali': range(2432, 2559+1), 'Gurmukhi': range(2560, 2687+1), 'Gujarati': range(2688, 2815+1), 'Oriya': range(2816, 2943+1), 'Tamil': range(2944, 3071+1), 'Telugu': range(3072, 3199+1), 'Kannada': range(3200, 3327+1), 'Malayalam': range(3328, 3455+1), 'Sinhala': range(3456, 3583+1), 'Thai': range(3584, 3711+1), 'Lao': range(3712, 3839+1), 'Tibetan': range(3840, 4095+1), 'Myanmar': range(4096, 4255+1), 'Georgian': range(4256, 4351+1), 'Hangul Jamo': range(4352, 4607+1), 'Ethiopic': range(4608, 4991+1), 'Ethiopic Supplement': range(4992, 5023+1), 'Cherokee': range(5024, 5119+1), 'Unified Canadian Aboriginal Syllabics': range(5120, 5759+1), 'Ogham': range(5760, 5791+1), 'Runic': range(5792, 5887+1), 'Tagalog': range(5888, 5919+1), 'Hanunoo': range(5920, 5951+1), 'Buhid': range(5952, 5983+1), 'Tagbanwa': range(5984, 6015+1), 'Khmer': range(6016, 6143+1), 'Mongolian': range(6144, 6319+1), 'Unified Canadian Aboriginal Syllabics Extended': range(6320, 6399+1), 'Limbu': range(6400, 6479+1), 'Tai Le': range(6480, 6527+1), 'New Tai Lue': range(6528, 6623+1), 'Khmer Symbols': range(6624, 6655+1), 'Buginese': range(6656, 6687+1), 'Tai Tham': range(6688, 6831+1), 'Combining Diacritical Marks Extended': range(6832, 6911+1), 'Balinese': range(6912, 7039+1), 'Sundanese': range(7040, 7103+1), 'Batak': range(7104, 7167+1), 'Lepcha': range(7168, 7247+1), 'Ol Chiki': range(7248, 7295+1), 'Cyrillic Extended C': range(7296, 7311+1), 'Sundanese Supplement': range(7360, 7375+1), 'Vedic Extensions': range(7376, 7423+1), 'Phonetic Extensions': range(7424, 7551+1), 'Phonetic Extensions Supplement': range(7552, 7615+1), 'Combining Diacritical Marks Supplement': range(7616, 7679+1), 'Latin Extended Additional': range(7680, 7935+1), 'Greek Extended': range(7936, 8191+1), 'General Punctuation': range(8192, 8303+1), 'Superscripts and Subscripts': range(8304, 8351+1), 'Currency Symbols': range(8352, 8399+1), 'Combining Diacritical Marks for Symbols': range(8400, 8447+1), 'Letterlike Symbols': range(8448, 8527+1), 'Number Forms': range(8528, 8591+1), 'Arrows': range(8592, 8703+1), 'Mathematical Operators': range(8704, 8959+1), 'Miscellaneous Technical': range(8960, 9215+1), 'Control Pictures': range(9216, 9279+1), 'Optical Character Recognition': range(9280, 9311+1), 'Enclosed Alphanumerics': range(9312, 9471+1), 'Box Drawing': range(9472, 9599+1), 'Block Elements': range(9600, 9631+1), 'Geometric Shapes': range(9632, 9727+1), 'Miscellaneous Symbols': range(9728, 9983+1), 'Dingbats': range(9984, 10175+1), 'Miscellaneous Mathematical Symbols-A': range(10176, 10223+1), 'Supplemental Arrows-A': range(10224, 10239+1), 'Braille Patterns': range(10240, 10495+1), 'Supplemental Arrows-B': range(10496, 10623+1), 'Miscellaneous Mathematical Symbols-B': range(10624, 10751+1), 'Supplemental Mathematical Operators': range(10752, 11007+1), 'Miscellaneous Symbols and Arrows': range(11008, 11263+1), 'Glagolitic': range(11264, 11359+1), 'Latin Extended-C': range(11360, 11391+1), 'Coptic': range(11392, 11519+1), 'Georgian Supplement': range(11520, 11567+1), 'Tifinagh': range(11568, 11647+1), 'Ethiopic Extended': range(11648, 11743+1), 'Cyrillic Extended-A': range(11744, 11775+1), 'Supplemental Punctuation': range(11776, 11903+1), 'CJK Radicals Supplement': range(11904, 12031+1), 'Kangxi Radicals': range(12032, 12255+1), 'Ideographic Description Characters': range(12272, 12287+1), 'CJK Symbols and Punctuation': range(12288, 12351+1), 'Hiragana': range(12352, 12447+1), 'Katakana': range(12448, 12543+1), 'Bopomofo': range(12544, 12591+1), 'Hangul Compatibility Jamo': range(12592, 12687+1), 'Kanbun': range(12688, 12703+1), 'Bopomofo Extended': range(12704, 12735+1), 'CJK Strokes': range(12736, 12783+1), 'Katakana Phonetic Extensions': range(12784, 12799+1), 'Enclosed CJK Letters and Months': range(12800, 13055+1), 'CJK Compatibility': range(13056, 13311+1), 'CJK Unified Ideographs Extension A': range(13312, 19903+1), 'Yijing Hexagram Symbols': range(19904, 19967+1), 'CJK Unified Ideographs': range(19968, 40959+1), 'Yi Syllables': range(40960, 42127+1), 'Yi Radicals': range(42128, 42191+1), 'Lisu': range(42192, 42239+1), 'Vai': range(42240, 42559+1), 'Cyrillic Extended-B': range(42560, 42655+1), 'Bamum': range(42656, 42751+1), 'Modifier Tone Letters': range(42752, 42783+1), 'Latin Extended-D': range(42784, 43007+1), 'Syloti Nagri': range(43008, 43055+1), 'Common Indic Number Forms': range(43056, 43071+1), 'Phags-pa': range(43072, 43135+1), 'Saurashtra': range(43136, 43231+1), 'Devanagari Extended': range(43232, 43263+1), 'Kayah Li': range(43264, 43311+1), 'Rejang': range(43312, 43359+1), 'Hangul Jamo Extended-A': range(43360, 43391+1), 'Javanese': range(43392, 43487+1), 'Myanmar Extended-B': range(43488, 43519+1), 'Cham': range(43520, 43615+1), 'Myanmar Extended-A': range(43616, 43647+1), 'Tai Viet': range(43648, 43743+1), 'Meetei Mayek Extensions': range(43744, 43775+1), 'Ethiopic Extended-A': range(43776, 43823+1), 'Latin Extended-E': range(43824, 43887+1), 'Cherokee Supplement': range(43888, 43967+1), 'Meetei Mayek': range(43968, 44031+1), 'Hangul Syllables': range(44032, 55215+1), 'Hangul Jamo Extended-B': range(55216, 55295+1), 'High Surrogates': range(55296, 56191+1), 'High Private Use Surrogates': range(56192, 56319+1), 'Low Surrogates': range(56320, 57343+1), 'Private Use Area': range(57344, 63743+1), 'CJK Compatibility Ideographs': range(63744, 64255+1), 'Alphabetic Presentation Forms': range(64256, 64335+1), 'Arabic Presentation Forms-A': range(64336, 65023+1), 'Variation Selectors': range(65024, 65039+1), 'Vertical Forms': range(65040, 65055+1), 'Combining Half Marks': range(65056, 65071+1), 'CJK Compatibility Forms': range(65072, 65103+1), 'Small Form Variants': range(65104, 65135+1), 'Arabic Presentation Forms-B': range(65136, 65279+1), 'Halfwidth and Fullwidth Forms': range(65280, 65519+1), 'Specials': range(65520, 65535+1), 'Linear B Syllabary': range(65536, 65663+1), 'Linear B Ideograms': range(65664, 65791+1), 'Aegean Numbers': range(65792, 65855+1), 'Ancient Greek Numbers': range(65856, 65935+1), 'Ancient Symbols': range(65936, 65999+1), 'Phaistos Disc': range(66000, 66047+1), 'Lycian': range(66176, 66207+1), 'Carian': range(66208, 66271+1), 'Coptic Epact Numbers': range(66272, 66303+1), 'Old Italic': range(66304, 66351+1), 'Gothic': range(66352, 66383+1), 'Old Permic': range(66384, 66431+1), 'Ugaritic': range(66432, 66463+1), 'Old Persian': range(66464, 66527+1), 'Deseret': range(66560, 66639+1), 'Shavian': range(66640, 66687+1), 'Osmanya': range(66688, 66735+1), 'Osage': range(66736, 66815+1), 'Elbasan': range(66816, 66863+1), 'Caucasian Albanian': range(66864, 66927+1), 'Linear A': range(67072, 67455+1), 'Cypriot Syllabary': range(67584, 67647+1), 'Imperial Aramaic': range(67648, 67679+1), 'Palmyrene': range(67680, 67711+1), 'Nabataean': range(67712, 67759+1), 'Hatran': range(67808, 67839+1), 'Phoenician': range(67840, 67871+1), 'Lydian': range(67872, 67903+1), 'Meroitic Hieroglyphs': range(67968, 67999+1), 'Meroitic Cursive': range(68000, 68095+1), 'Kharoshthi': range(68096, 68191+1), 'Old South Arabian': range(68192, 68223+1), 'Old North Arabian': range(68224, 68255+1), 'Manichaean': range(68288, 68351+1), 'Avestan': range(68352, 68415+1), 'Inscriptional Parthian': range(68416, 68447+1), 'Inscriptional Pahlavi': range(68448, 68479+1), 'Psalter Pahlavi': range(68480, 68527+1), 'Old Turkic': range(68608, 68687+1), 'Old Hungarian': range(68736, 68863+1), 'Rumi Numeral Symbols': range(69216, 69247+1), 'Brahmi': range(69632, 69759+1), 'Kaithi': range(69760, 69839+1), 'Sora Sompeng': range(69840, 69887+1), 'Chakma': range(69888, 69967+1), 'Mahajani': range(69968, 70015+1), 'Sharada': range(70016, 70111+1), 'Sinhala Archaic Numbers': range(70112, 70143+1), 'Khojki': range(70144, 70223+1), 'Multani': range(70272, 70319+1), 'Khudawadi': range(70320, 70399+1), 'Grantha': range(70400, 70527+1), 'Newa': range(70656, 70783+1), 'Tirhuta': range(70784, 70879+1), 'Siddham': range(71040, 71167+1), 'Modi': range(71168, 71263+1), 'Mongolian Supplement': range(71264, 71295+1), 'Takri': range(71296, 71375+1), 'Ahom': range(71424, 71487+1), 'Warang Citi': range(71840, 71935+1), 'Zanabazar Square': range(72192, 72271+1), 'Soyombo': range(72272, 72367+1), 'Pau Cin Hau': range(72384, 72447+1), 'Bhaiksuki': range(72704, 72815+1), 'Marchen': range(72816, 72895+1), 'Masaram Gondi': range(72960, 73055+1), 'Cuneiform': range(73728, 74751+1), 'Cuneiform Numbers and Punctuation': range(74752, 74879+1), 'Early Dynastic Cuneiform': range(74880, 75087+1), 'Egyptian Hieroglyphs': range(77824, 78895+1), 'Anatolian Hieroglyphs': range(82944, 83583+1), 'Bamum Supplement': range(92160, 92735+1), 'Mro': range(92736, 92783+1), 'Bassa Vah': range(92880, 92927+1), 'Pahawh Hmong': range(92928, 93071+1), 'Miao': range(93952, 94111+1), 'Ideographic Symbols and Punctuation': range(94176, 94207+1), 'Tangut': range(94208, 100351+1), 'Tangut Components': range(100352, 101119+1), 'Kana Supplement': range(110592, 110847+1), 'Kana Extended-A': range(110848, 110895+1), 'Nushu': range(110960, 111359+1), 'Duployan': range(113664, 113823+1), 'Shorthand Format Controls': range(113824, 113839+1), 'Byzantine Musical Symbols': range(118784, 119039+1), 'Musical Symbols': range(119040, 119295+1), 'Ancient Greek Musical Notation': range(119296, 119375+1), 'Tai Xuan Jing Symbols': range(119552, 119647+1), 'Counting Rod Numerals': range(119648, 119679+1), 'Mathematical Alphanumeric Symbols': range(119808, 120831+1), 'Sutton SignWriting': range(120832, 121519+1), 'Glagolitic Supplement': range(122880, 122927+1), 'Mende Kikakui': range(124928, 125151+1), 'Adlam': range(125184, 125279+1), 'Arabic Mathematical Alphabetic Symbols': range(126464, 126719+1), 'Mahjong Tiles': range(126976, 127023+1), 'Domino Tiles': range(127024, 127135+1), 'Playing Cards': range(127136, 127231+1), 'Enclosed Alphanumeric Supplement': range(127232, 127487+1), 'Enclosed Ideographic Supplement': range(127488, 127743+1), 'Miscellaneous Symbols and Pictographs': range(127744, 128511+1), 'Emoticons range(Emoji)': range(128512, 128591+1), 'Ornamental Dingbats': range(128592, 128639+1), 'Transport and Map Symbols': range(128640, 128767+1), 'Alchemical Symbols': range(128768, 128895+1), 'Geometric Shapes Extended': range(128896, 129023+1), 'Supplemental Arrows-C': range(129024, 129279+1), 'Supplemental Symbols and Pictographs': range(129280, 129535+1), 'CJK Unified Ideographs Extension B': range(131072, 173791+1), 'CJK Unified Ideographs Extension C': range(173824, 177983+1), 'CJK Unified Ideographs Extension D': range(177984, 178207+1), 'CJK Unified Ideographs Extension E': range(178208, 183983+1), 'CJK Unified Ideographs Extension F': range(183984, 191471+1), 'CJK Compatibility Ideographs Supplement': range(194560, 195103+1), 'Tags': range(917504, 917631+1), 'Variation Selectors Supplement': range(917760, 917999+1)} # type: Dict[str, range] + +UNICODE_SECONDARY_RANGE_KEYWORD = [ + 'Supplement', + 'Extended', + 'Extensions', + 'Modifier', + 'Marks', + 'Punctuation', + 'Symbols', + 'Forms', + 'Operators', + 'Miscellaneous', + 'Drawing', + 'Block', + 'Shapes', + 'Supplemental', + 'Tags' +] # type: List[str] + +RE_POSSIBLE_ENCODING_INDICATION = re_compile( + r'(?:(?:encoding)|(?:charset)|(?:coding))(?:[\:= ]{1,10})(?:[\"\']?)([a-zA-Z0-9\-_]+)(?:[\"\']?)', + IGNORECASE +) + +IANA_SUPPORTED = sorted( + filter( + lambda x: x.endswith("_codec") is False and x not in {"rot_13", "tactis", "mbcs"}, + list(set(aliases.values())) + ) +) # type: List[str] + +IANA_SUPPORTED_COUNT = len(IANA_SUPPORTED) # type: int + +# pre-computed code page that are similar using the function cp_similarity. +IANA_SUPPORTED_SIMILAR = { + "cp037": [ + "cp1026", + "cp1140", + "cp273", + "cp500" + ], + "cp1026": [ + "cp037", + "cp1140", + "cp273", + "cp500" + ], + "cp1125": [ + "cp866" + ], + "cp1140": [ + "cp037", + "cp1026", + "cp273", + "cp500" + ], + "cp1250": [ + "iso8859_2" + ], + "cp1251": [ + "kz1048", + "ptcp154" + ], + "cp1252": [ + "cp1258", + "iso8859_15", + "iso8859_9", + "latin_1" + ], + "cp1253": [ + "iso8859_7" + ], + "cp1254": [ + "cp1258", + "iso8859_15", + "iso8859_9", + "latin_1" + ], + "cp1257": [ + "iso8859_13" + ], + "cp1258": [ + "cp1252", + "cp1254", + "iso8859_9", + "latin_1" + ], + "cp273": [ + "cp037", + "cp1026", + "cp1140", + "cp500" + ], + "cp437": [ + "cp850", + "cp858", + "cp860", + "cp861", + "cp862", + "cp863", + "cp865" + ], + "cp500": [ + "cp037", + "cp1026", + "cp1140", + "cp273" + ], + "cp850": [ + "cp437", + "cp857", + "cp858", + "cp865" + ], + "cp857": [ + "cp850", + "cp858", + "cp865" + ], + "cp858": [ + "cp437", + "cp850", + "cp857", + "cp865" + ], + "cp860": [ + "cp437", + "cp861", + "cp862", + "cp863", + "cp865" + ], + "cp861": [ + "cp437", + "cp860", + "cp862", + "cp863", + "cp865" + ], + "cp862": [ + "cp437", + "cp860", + "cp861", + "cp863", + "cp865" + ], + "cp863": [ + "cp437", + "cp860", + "cp861", + "cp862", + "cp865" + ], + "cp865": [ + "cp437", + "cp850", + "cp857", + "cp858", + "cp860", + "cp861", + "cp862", + "cp863" + ], + "cp866": [ + "cp1125" + ], + "iso8859_10": [ + "iso8859_14", + "iso8859_15", + "iso8859_4", + "iso8859_9", + "latin_1" + ], + "iso8859_11": [ + "tis_620" + ], + "iso8859_13": [ + "cp1257" + ], + "iso8859_14": [ + "iso8859_10", + "iso8859_15", + "iso8859_16", + "iso8859_3", + "iso8859_9", + "latin_1" + ], + "iso8859_15": [ + "cp1252", + "cp1254", + "iso8859_10", + "iso8859_14", + "iso8859_16", + "iso8859_3", + "iso8859_9", + "latin_1" + ], + "iso8859_16": [ + "iso8859_14", + "iso8859_15", + "iso8859_2", + "iso8859_3", + "iso8859_9", + "latin_1" + ], + "iso8859_2": [ + "cp1250", + "iso8859_16", + "iso8859_4" + ], + "iso8859_3": [ + "iso8859_14", + "iso8859_15", + "iso8859_16", + "iso8859_9", + "latin_1" + ], + "iso8859_4": [ + "iso8859_10", + "iso8859_2", + "iso8859_9", + "latin_1" + ], + "iso8859_7": [ + "cp1253" + ], + "iso8859_9": [ + "cp1252", + "cp1254", + "cp1258", + "iso8859_10", + "iso8859_14", + "iso8859_15", + "iso8859_16", + "iso8859_3", + "iso8859_4", + "latin_1" + ], + "kz1048": [ + "cp1251", + "ptcp154" + ], + "latin_1": [ + "cp1252", + "cp1254", + "cp1258", + "iso8859_10", + "iso8859_14", + "iso8859_15", + "iso8859_16", + "iso8859_3", + "iso8859_4", + "iso8859_9" + ], + "mac_iceland": [ + "mac_roman", + "mac_turkish" + ], + "mac_roman": [ + "mac_iceland", + "mac_turkish" + ], + "mac_turkish": [ + "mac_iceland", + "mac_roman" + ], + "ptcp154": [ + "cp1251", + "kz1048" + ], + "tis_620": [ + "iso8859_11" + ] +} # type: Dict[str, List[str]] + + +CHARDET_CORRESPONDENCE = { + 'iso2022_kr': 'ISO-2022-KR', + 'iso2022_jp': 'ISO-2022-JP', + 'euc_kr': 'EUC-KR', + 'tis_620': 'TIS-620', + 'utf_32': 'UTF-32', + 'euc_jp': 'EUC-JP', + 'koi8_r': 'KOI8-R', + 'iso8859_1': 'ISO-8859-1', + 'iso8859_2': 'ISO-8859-2', + 'iso8859_5': 'ISO-8859-5', + 'iso8859_6': 'ISO-8859-6', + 'iso8859_7': 'ISO-8859-7', + 'iso8859_8': 'ISO-8859-8', + 'utf_16': 'UTF-16', + 'cp855': 'IBM855', + 'mac_cyrillic': 'MacCyrillic', + 'gb2312': 'GB2312', + 'gb18030': 'GB18030', + 'cp932': 'CP932', + 'cp866': 'IBM866', + 'utf_8': 'utf-8', + 'utf_8_sig': 'UTF-8-SIG', + 'shift_jis': 'SHIFT_JIS', + 'big5': 'Big5', + 'cp1250': 'windows-1250', + 'cp1251': 'windows-1251', + 'cp1252': 'Windows-1252', + 'cp1253': 'windows-1253', + 'cp1255': 'windows-1255', + 'cp1256': 'windows-1256', + 'cp1254': 'Windows-1254', + 'cp949': 'CP949' +} # type: Dict[str, str] diff --git a/venv/lib/python3.8/site-packages/charset_normalizer/legacy.py b/venv/lib/python3.8/site-packages/charset_normalizer/legacy.py new file mode 100644 index 0000000..7b28cb4 --- /dev/null +++ b/venv/lib/python3.8/site-packages/charset_normalizer/legacy.py @@ -0,0 +1,38 @@ +from charset_normalizer.api import from_bytes +from charset_normalizer.constant import CHARDET_CORRESPONDENCE +from typing import Dict, Optional, Union + + +def detect(byte_str: bytes) -> Dict[str, Optional[Union[str, float]]]: + """ + chardet legacy method + Detect the encoding of the given byte string. It should be mostly backward-compatible. + Encoding name will match Chardet own writing whenever possible. (Not on encoding name unsupported by it) + This function is deprecated and should be used to migrate your project easily, consult the documentation for + further information. Not planned for removal. + + :param byte_str: The byte sequence to examine. + """ + if not isinstance(byte_str, (bytearray, bytes)): + raise TypeError('Expected object of type bytes or bytearray, got: ' + '{0}'.format(type(byte_str))) + + if isinstance(byte_str, bytearray): + byte_str = bytes(byte_str) + + r = from_bytes(byte_str).best() + + encoding = r.encoding if r is not None else None + language = r.language if r is not None and r.language != 'Unknown' else '' + confidence = 1. - r.chaos if r is not None else None + + # Note: CharsetNormalizer does not return 'UTF-8-SIG' as the sig get stripped in the detection/normalization process + # but chardet does return 'utf-8-sig' and it is a valid codec name. + if r is not None and encoding == 'utf_8' and r.bom: + encoding += '_sig' + + return { + 'encoding': encoding if encoding not in CHARDET_CORRESPONDENCE else CHARDET_CORRESPONDENCE[encoding], + 'language': language, + 'confidence': confidence + } diff --git a/venv/lib/python3.8/site-packages/charset_normalizer/md.py b/venv/lib/python3.8/site-packages/charset_normalizer/md.py new file mode 100644 index 0000000..4f9c714 --- /dev/null +++ b/venv/lib/python3.8/site-packages/charset_normalizer/md.py @@ -0,0 +1,451 @@ +from functools import lru_cache +from typing import Optional, List + +from charset_normalizer.constant import UNICODE_SECONDARY_RANGE_KEYWORD +from charset_normalizer.utils import is_punctuation, is_symbol, unicode_range, is_accentuated, is_latin, \ + remove_accent, is_separator, is_cjk + + +class MessDetectorPlugin: + """ + Base abstract class used for mess detection plugins. + All detectors MUST extend and implement given methods. + """ + + def eligible(self, character: str) -> bool: + """ + Determine if given character should be fed in. + """ + raise NotImplementedError # pragma: nocover + + def feed(self, character: str) -> None: + """ + The main routine to be executed upon character. + Insert the logic in witch the text would be considered chaotic. + """ + raise NotImplementedError # pragma: nocover + + def reset(self) -> None: + """ + Permit to reset the plugin to the initial state. + """ + raise NotImplementedError # pragma: nocover + + @property + def ratio(self) -> float: + """ + Compute the chaos ratio based on what your feed() has seen. + Must NOT be lower than 0.; No restriction gt 0. + """ + raise NotImplementedError # pragma: nocover + + +class TooManySymbolOrPunctuationPlugin(MessDetectorPlugin): + + def __init__(self): + self._punctuation_count = 0 # type: int + self._symbol_count = 0 # type: int + self._character_count = 0 # type: int + + self._last_printable_char = None # type: Optional[str] + self._frenzy_symbol_in_word = False # type: bool + + def eligible(self, character: str) -> bool: + return character.isprintable() + + def feed(self, character: str) -> None: + self._character_count += 1 + + if character != self._last_printable_char and character not in ["<", ">", "=", ":", "/", "&", ";", "{", "}", "[", "]"]: + if is_punctuation(character): + self._punctuation_count += 1 + elif character.isdigit() is False and is_symbol(character): + self._symbol_count += 2 + + self._last_printable_char = character + + def reset(self) -> None: + self._punctuation_count = 0 + self._character_count = 0 + self._symbol_count = 0 + + @property + def ratio(self) -> float: + if self._character_count == 0: + return 0. + + ratio_of_punctuation = (self._punctuation_count + self._symbol_count) / self._character_count # type: float + + return ratio_of_punctuation if ratio_of_punctuation >= 0.3 else 0. + + +class TooManyAccentuatedPlugin(MessDetectorPlugin): + + def __init__(self): + self._character_count = 0 # type: int + self._accentuated_count = 0 # type: int + + def eligible(self, character: str) -> bool: + return character.isalpha() + + def feed(self, character: str) -> None: + self._character_count += 1 + + if is_accentuated(character): + self._accentuated_count += 1 + + def reset(self) -> None: + self._character_count = 0 + self._accentuated_count = 0 + + @property + def ratio(self) -> float: + if self._character_count == 0: + return 0. + ratio_of_accentuation = self._accentuated_count / self._character_count # type: float + return ratio_of_accentuation if ratio_of_accentuation >= 0.35 else 0. + + +class UnprintablePlugin(MessDetectorPlugin): + + def __init__(self): + self._unprintable_count = 0 # type: int + self._character_count = 0 # type: int + + def eligible(self, character: str) -> bool: + return True + + def feed(self, character: str) -> None: + if character not in {'\n', '\t', '\r'} and character.isprintable() is False: + self._unprintable_count += 1 + self._character_count += 1 + + def reset(self) -> None: + self._unprintable_count = 0 + + @property + def ratio(self) -> float: + if self._character_count == 0: + return 0. + + return (self._unprintable_count * 8) / self._character_count + + +class SuspiciousDuplicateAccentPlugin(MessDetectorPlugin): + + def __init__(self): + self._successive_count = 0 # type: int + self._character_count = 0 # type: int + + self._last_latin_character = None # type: Optional[str] + + def eligible(self, character: str) -> bool: + return is_latin(character) + + def feed(self, character: str) -> None: + if self._last_latin_character is not None: + if is_accentuated(character) and is_accentuated(self._last_latin_character): + if remove_accent(character) == remove_accent(self._last_latin_character): + self._successive_count += 1 + self._last_latin_character = character + + def reset(self) -> None: + self._successive_count = 0 + self._character_count = 0 + self._last_latin_character = None + + @property + def ratio(self) -> float: + if self._character_count == 0: + return 0. + + return (self._successive_count * 2) / self._character_count + + +class SuspiciousRange(MessDetectorPlugin): + + def __init__(self): + self._suspicious_successive_range_count = 0 # type: int + self._character_count = 0 # type: int + self._last_printable_seen = None # type: Optional[str] + + def eligible(self, character: str) -> bool: + return character.isprintable() + + def feed(self, character: str) -> None: + self._character_count += 1 + + if self._last_printable_seen is None: + self._last_printable_seen = character + return + + if character.isspace() or is_punctuation(character): + self._last_printable_seen = None + return + + unicode_range_a = unicode_range(self._last_printable_seen) # type: Optional[str] + unicode_range_b = unicode_range(character) # type: Optional[str] + + if is_suspiciously_successive_range(unicode_range_a, unicode_range_b): + self._suspicious_successive_range_count += 1 + + self._last_printable_seen = character + + def reset(self) -> None: + self._character_count = 0 + self._suspicious_successive_range_count = 0 + self._last_printable_seen = None + + @property + def ratio(self) -> float: + if self._character_count == 0: + return 0. + + ratio_of_suspicious_range_usage = (self._suspicious_successive_range_count * 2) / self._character_count # type: float + + if ratio_of_suspicious_range_usage < 0.1: + return 0. + + return ratio_of_suspicious_range_usage + + +class SuperWeirdWordPlugin(MessDetectorPlugin): + + def __init__(self): + self._word_count = 0 # type: int + self._bad_word_count = 0 # type: int + self._is_current_word_bad = False # type: bool + + self._character_count = 0 # type: int + self._bad_character_count = 0 # type: int + + self._buffer = "" # type: str + self._buffer_accent_count = 0 # type: int + + def eligible(self, character: str) -> bool: + return True + + def feed(self, character: str) -> None: + if character.isalpha(): + self._buffer = "".join([self._buffer, character]) + if is_accentuated(character): + self._buffer_accent_count += 1 + return + if not self._buffer: + return + if (character.isspace() or is_punctuation(character) or is_separator(character)) and self._buffer: + self._word_count += 1 + buffer_length = len(self._buffer) # type: int + + self._character_count += buffer_length + + if buffer_length >= 4 and self._buffer_accent_count / buffer_length >= 0.3: + self._is_current_word_bad = True + + if self._is_current_word_bad: + self._bad_word_count += 1 + self._bad_character_count += len(self._buffer) + self._is_current_word_bad = False + + self._buffer = "" + self._buffer_accent_count = 0 + elif character not in {"<", ">", "-", "="} and character.isdigit() is False and is_symbol(character): + self._is_current_word_bad = True + self._buffer += character + + def reset(self) -> None: + self._buffer = "" + self._is_current_word_bad = False + self._bad_word_count = 0 + self._word_count = 0 + self._character_count = 0 + self._bad_character_count = 0 + + @property + def ratio(self) -> float: + if self._word_count <= 16: + return 0. + + return self._bad_character_count / self._character_count + + +class CjkInvalidStopPlugin(MessDetectorPlugin): + """ + GB(Chinese) based encoding often render the stop incorrectly when the content does not fit and can be easily detected. + Searching for the overuse of '丅' and '丄'. + """ + + def __init__(self): + self._wrong_stop_count = 0 # type: int + self._cjk_character_count = 0 # type: int + + def eligible(self, character: str) -> bool: + return True + + def feed(self, character: str) -> None: + if character in ["丅", "丄"]: + self._wrong_stop_count += 1 + return + if is_cjk(character): + self._cjk_character_count += 1 + + def reset(self) -> None: + self._wrong_stop_count = 0 + self._cjk_character_count = 0 + + @property + def ratio(self) -> float: + if self._cjk_character_count < 16: + return 0. + return self._wrong_stop_count / self._cjk_character_count + + +class ArchaicUpperLowerPlugin(MessDetectorPlugin): + + def __init__(self): + self._buf = False # type: bool + + self._character_count_since_last_sep = 0 # type: int + + self._successive_upper_lower_count = 0 # type: int + self._successive_upper_lower_count_final = 0 # type: int + + self._character_count = 0 # type: int + + self._last_alpha_seen = None # type: Optional[str] + + def eligible(self, character: str) -> bool: + return character.isspace() or character.isalpha() + + def feed(self, character: str) -> None: + if is_separator(character): + if self._character_count_since_last_sep < 24: + self._successive_upper_lower_count_final += self._successive_upper_lower_count + self._successive_upper_lower_count = 0 + self._character_count_since_last_sep = 0 + + if self._last_alpha_seen is not None: + if (character.isupper() and self._last_alpha_seen.islower()) or (character.islower() and self._last_alpha_seen.isupper()): + if self._buf is True: + self._successive_upper_lower_count += 1 + else: + self._buf = True + else: + self._buf = False + + self._character_count += 1 + self._last_alpha_seen = character + + def reset(self) -> None: + self._character_count = 0 + self._character_count_since_last_sep = 0 + self._successive_upper_lower_count = 0 + self._successive_upper_lower_count_final = 0 + self._last_alpha_seen = None + + @property + def ratio(self) -> float: + if self._character_count == 0: + return 0. + + return (self._successive_upper_lower_count_final * 2) / self._character_count + + +def is_suspiciously_successive_range(unicode_range_a: Optional[str], unicode_range_b: Optional[str]) -> bool: + """ + Determine if two Unicode range seen next to each other can be considered as suspicious. + """ + if unicode_range_a is None or unicode_range_b is None: + return True + + if unicode_range_a == unicode_range_b: + return False + + if "Latin" in unicode_range_a and "Latin" in unicode_range_b: + return False + + if "Emoticons" in unicode_range_a or "Emoticons" in unicode_range_b: + return False + + keywords_range_a, keywords_range_b = unicode_range_a.split(" "), unicode_range_b.split(" ") + + for el in keywords_range_a: + if el in UNICODE_SECONDARY_RANGE_KEYWORD: + continue + if el in keywords_range_b: + return False + + # Japanese Exception + if unicode_range_a in ['Katakana', 'Hiragana'] and unicode_range_b in ['Katakana', 'Hiragana']: + return False + + if unicode_range_a in ['Katakana', 'Hiragana'] or unicode_range_b in ['Katakana', 'Hiragana']: + if "CJK" in unicode_range_a or "CJK" in unicode_range_b: + return False + + if "Hangul" in unicode_range_a or "Hangul" in unicode_range_b: + if "CJK" in unicode_range_a or "CJK" in unicode_range_b: + return False + if unicode_range_a == "Basic Latin" or unicode_range_b == "Basic Latin": + return False + + # Chinese/Japanese use dedicated range for punctuation and/or separators. + if ('CJK' in unicode_range_a or 'CJK' in unicode_range_b) or (unicode_range_a in ['Katakana', 'Hiragana'] and unicode_range_b in ['Katakana', 'Hiragana']): + if 'Punctuation' in unicode_range_a or 'Punctuation' in unicode_range_b: + return False + if 'Forms' in unicode_range_a or 'Forms' in unicode_range_b: + return False + + return True + + +@lru_cache(maxsize=2048) +def mess_ratio(decoded_sequence: str, maximum_threshold: float = 0.2, debug: bool = False) -> float: + """ + Compute a mess ratio given a decoded bytes sequence. The maximum threshold does stop the computation earlier. + """ + detectors = [] # type: List[MessDetectorPlugin] + + for md_class in MessDetectorPlugin.__subclasses__(): + detectors.append( + md_class() + ) + + length = len(decoded_sequence) # type: int + + mean_mess_ratio = 0. # type: float + + if length < 512: + intermediary_mean_mess_ratio_calc = 32 # type: int + elif length <= 1024: + intermediary_mean_mess_ratio_calc = 64 + else: + intermediary_mean_mess_ratio_calc = 128 + + for character, index in zip(decoded_sequence, range(0, length)): + for detector in detectors: + if detector.eligible(character): + detector.feed(character) + + if (index > 0 and index % intermediary_mean_mess_ratio_calc == 0) or index == length-1: + mean_mess_ratio = sum( + [ + dt.ratio for dt in detectors + ] + ) + + if mean_mess_ratio >= maximum_threshold: + break + + if debug: + for dt in detectors: # pragma: nocover + print( + dt.__class__, + dt.ratio + ) + + return round( + mean_mess_ratio, + 3 + ) + diff --git a/venv/lib/python3.8/site-packages/charset_normalizer/models.py b/venv/lib/python3.8/site-packages/charset_normalizer/models.py new file mode 100644 index 0000000..2bf75a4 --- /dev/null +++ b/venv/lib/python3.8/site-packages/charset_normalizer/models.py @@ -0,0 +1,355 @@ +import warnings +from encodings.aliases import aliases +from hashlib import sha256 +from json import dumps +from typing import Optional, List, Tuple, Set +from collections import Counter +from re import sub, compile as re_compile + +from charset_normalizer.constant import TOO_BIG_SEQUENCE +from charset_normalizer.md import mess_ratio +from charset_normalizer.utils import iana_name, is_multi_byte_encoding, unicode_range + + +class CharsetMatch: + def __init__( + self, + payload: bytes, + guessed_encoding: str, + mean_mess_ratio: float, + has_sig_or_bom: bool, + languages: "CoherenceMatches", + decoded_payload: Optional[str] = None + ): + self._payload = payload # type: bytes + + self._encoding = guessed_encoding # type: str + self._mean_mess_ratio = mean_mess_ratio # type: float + self._languages = languages # type: CoherenceMatches + self._has_sig_or_bom = has_sig_or_bom # type: bool + self._unicode_ranges = None # type: Optional[List[str]] + + self._leaves = [] # type: List[CharsetMatch] + self._mean_coherence_ratio = 0. # type: float + + self._output_payload = None # type: Optional[bytes] + self._output_encoding = None # type: Optional[str] + + self._string = decoded_payload # type: Optional[str] + + def __eq__(self, other) -> bool: + if not isinstance(other, CharsetMatch): + raise TypeError('__eq__ cannot be invoked on {} and {}.'.format(str(other.__class__), str(self.__class__))) + return self.encoding == other.encoding and self.fingerprint == other.fingerprint + + def __lt__(self, other) -> bool: + """ + Implemented to make sorted available upon CharsetMatches items. + """ + if not isinstance(other, CharsetMatch): + raise ValueError + + chaos_difference = abs(self.chaos - other.chaos) # type: float + + # Bellow 1% difference --> Use Coherence + if chaos_difference < 0.01: + return self.coherence > other.coherence + + return self.chaos < other.chaos + + @property + def chaos_secondary_pass(self) -> float: + """ + Check once again chaos in decoded text, except this time, with full content. + Use with caution, this can be very slow. + Notice: Will be removed in 3.0 + """ + warnings.warn("chaos_secondary_pass is deprecated and will be removed in 3.0", DeprecationWarning) + return mess_ratio( + str(self), + 1. + ) + + @property + def coherence_non_latin(self) -> float: + """ + Coherence ratio on the first non-latin language detected if ANY. + Notice: Will be removed in 3.0 + """ + warnings.warn("coherence_non_latin is deprecated and will be removed in 3.0", DeprecationWarning) + return 0. + + @property + def w_counter(self) -> Counter: + """ + Word counter instance on decoded text. + Notice: Will be removed in 3.0 + """ + warnings.warn("w_counter is deprecated and will be removed in 3.0", DeprecationWarning) + not_printable_pattern = re_compile(r'[0-9\W\n\r\t]+') + string_printable_only = sub(not_printable_pattern, ' ', str(self).lower()) + + return Counter(string_printable_only.split()) + + def __str__(self) -> str: + # Lazy Str Loading + if self._string is None: + self._string = str(self._payload, self._encoding, "strict") + return self._string + + def __repr__(self) -> str: + return "".format(self.encoding, self.fingerprint) + + def add_submatch(self, other: "CharsetMatch") -> None: + if not isinstance(other, CharsetMatch) or other == self: + raise ValueError("Unable to add instance <{}> as a submatch of a CharsetMatch".format(other.__class__)) + + other._string = None # Unload RAM usage; dirty trick. + self._leaves.append(other) + + @property + def encoding(self) -> str: + return self._encoding + + @property + def encoding_aliases(self) -> List[str]: + """ + Encoding name are known by many name, using this could help when searching for IBM855 when it's listed as CP855. + """ + also_known_as = [] # type: List[str] + for u, p in aliases.items(): + if self.encoding == u: + also_known_as.append(p) + elif self.encoding == p: + also_known_as.append(u) + return also_known_as + + @property + def bom(self) -> bool: + return self._has_sig_or_bom + + @property + def byte_order_mark(self) -> bool: + return self._has_sig_or_bom + + @property + def languages(self) -> List[str]: + """ + Return the complete list of possible languages found in decoded sequence. + Usually not really useful. Returned list may be empty even if 'language' property return something != 'Unknown'. + """ + return [e[0] for e in self._languages] + + @property + def language(self) -> str: + """ + Most probable language found in decoded sequence. If none were detected or inferred, the property will return + "Unknown". + """ + if not self._languages: + # Trying to infer the language based on the given encoding + # Its either English or we should not pronounce ourselves in certain cases. + if "ascii" in self.could_be_from_charset: + return "English" + + # doing it there to avoid circular import + from charset_normalizer.cd import mb_encoding_languages, encoding_languages + + languages = mb_encoding_languages(self.encoding) if is_multi_byte_encoding(self.encoding) else encoding_languages(self.encoding) + + if len(languages) == 0 or "Latin Based" in languages: + return "Unknown" + + return languages[0] + + return self._languages[0][0] + + @property + def chaos(self) -> float: + return self._mean_mess_ratio + + @property + def coherence(self) -> float: + if not self._languages: + return 0. + return self._languages[0][1] + + @property + def percent_chaos(self) -> float: + return round(self.chaos * 100, ndigits=3) + + @property + def percent_coherence(self) -> float: + return round(self.coherence * 100, ndigits=3) + + @property + def raw(self) -> bytes: + """ + Original untouched bytes. + """ + return self._payload + + @property + def submatch(self) -> List["CharsetMatch"]: + return self._leaves + + @property + def has_submatch(self) -> bool: + return len(self._leaves) > 0 + + @property + def alphabets(self) -> List[str]: + if self._unicode_ranges is not None: + return self._unicode_ranges + detected_ranges = set() # type: Set[str] + for character in str(self): + detected_ranges.add( + unicode_range(character) + ) + self._unicode_ranges = sorted(list(detected_ranges)) + return self._unicode_ranges + + @property + def could_be_from_charset(self) -> List[str]: + """ + The complete list of encoding that output the exact SAME str result and therefore could be the originating + encoding. + This list does include the encoding available in property 'encoding'. + """ + return [self._encoding] + [m.encoding for m in self._leaves] + + def first(self) -> "CharsetMatch": + """ + Kept for BC reasons. Will be removed in 3.0. + """ + return self + + def best(self) -> "CharsetMatch": + """ + Kept for BC reasons. Will be removed in 3.0. + """ + return self + + def output(self, encoding: str = "utf_8") -> bytes: + """ + Method to get re-encoded bytes payload using given target encoding. Default to UTF-8. + Any errors will be simply ignored by the encoder NOT replaced. + """ + if self._output_encoding is None or self._output_encoding != encoding: + self._output_encoding = encoding + self._output_payload = str(self).encode(encoding, "replace") + + return self._output_payload # type: ignore + + @property + def fingerprint(self) -> str: + """ + Retrieve the unique SHA256 computed using the transformed (re-encoded) payload. Not the original one. + """ + return sha256(self.output()).hexdigest() + + +class CharsetMatches: + """ + Container with every CharsetMatch items ordered by default from most probable to the less one. + Act like a list(iterable) but does not implements all related methods. + """ + def __init__(self, results: List[CharsetMatch] = None): + self._results = sorted(results) if results else [] # type: List[CharsetMatch] + + def __iter__(self): + for result in self._results: + yield result + + def __getitem__(self, item) -> CharsetMatch: + """ + Retrieve a single item either by its position or encoding name (alias may be used here). + Raise KeyError upon invalid index or encoding not present in results. + """ + if isinstance(item, int): + return self._results[item] + if isinstance(item, str): + item = iana_name(item, False) + for result in self._results: + if item in result.could_be_from_charset: + return result + raise KeyError + + def __len__(self) -> int: + return len(self._results) + + def append(self, item: CharsetMatch) -> None: + """ + Insert a single match. Will be inserted accordingly to preserve sort. + Can be inserted as a submatch. + """ + if not isinstance(item, CharsetMatch): + raise ValueError("Cannot append instance '{}' to CharsetMatches".format(str(item.__class__))) + # We should disable the submatch factoring when the input file is too heavy (conserve RAM usage) + if len(item.raw) <= TOO_BIG_SEQUENCE: + for match in self._results: + if match.fingerprint == item.fingerprint: + match.add_submatch(item) + return + self._results.append(item) + self._results = sorted(self._results) + + def best(self) -> Optional["CharsetMatch"]: + """ + Simply return the first match. Strict equivalent to matches[0]. + """ + if not self._results: + return None + return self._results[0] + + def first(self) -> Optional["CharsetMatch"]: + """ + Redundant method, call the method best(). Kept for BC reasons. + """ + return self.best() + + +CoherenceMatch = Tuple[str, float] +CoherenceMatches = List[CoherenceMatch] + + +class CliDetectionResult: + + def __init__(self, path: str, encoding: str, encoding_aliases: List[str], alternative_encodings: List[str], language: str, alphabets: List[str], has_sig_or_bom: bool, chaos: float, coherence: float, unicode_path: Optional[str], is_preferred: bool): + self.path = path # type: str + self.unicode_path = unicode_path # type: Optional[str] + self.encoding = encoding # type: str + self.encoding_aliases = encoding_aliases # type: List[str] + self.alternative_encodings = alternative_encodings # type: List[str] + self.language = language # type: str + self.alphabets = alphabets # type: List[str] + self.has_sig_or_bom = has_sig_or_bom # type: bool + self.chaos = chaos # type: float + self.coherence = coherence # type: float + self.is_preferred = is_preferred # type: bool + + @property + def __dict__(self): + return { + 'path': self.path, + 'encoding': self.encoding, + 'encoding_aliases': self.encoding_aliases, + 'alternative_encodings': self.alternative_encodings, + 'language': self.language, + 'alphabets': self.alphabets, + 'has_sig_or_bom': self.has_sig_or_bom, + 'chaos': self.chaos, + 'coherence': self.coherence, + 'unicode_path': self.unicode_path, + 'is_preferred': self.is_preferred + } + + def to_json(self) -> str: + return dumps( + self.__dict__, + ensure_ascii=True, + indent=4 + ) + + +CharsetNormalizerMatch = CharsetMatch diff --git a/venv/lib/python3.8/site-packages/charset_normalizer/py.typed b/venv/lib/python3.8/site-packages/charset_normalizer/py.typed new file mode 100644 index 0000000..e69de29 diff --git a/venv/lib/python3.8/site-packages/charset_normalizer/utils.py b/venv/lib/python3.8/site-packages/charset_normalizer/utils.py new file mode 100644 index 0000000..db59739 --- /dev/null +++ b/venv/lib/python3.8/site-packages/charset_normalizer/utils.py @@ -0,0 +1,248 @@ +try: + import unicodedata2 as unicodedata +except ImportError: + import unicodedata + +from codecs import IncrementalDecoder +from re import findall +from typing import Optional, Tuple, Union, List, Set +import importlib +from _multibytecodec import MultibyteIncrementalDecoder # type: ignore + +from encodings.aliases import aliases +from functools import lru_cache + +from charset_normalizer.constant import UNICODE_RANGES_COMBINED, UNICODE_SECONDARY_RANGE_KEYWORD, \ + RE_POSSIBLE_ENCODING_INDICATION, ENCODING_MARKS, UTF8_MAXIMAL_ALLOCATION, IANA_SUPPORTED_SIMILAR + + +@lru_cache(maxsize=UTF8_MAXIMAL_ALLOCATION) +def is_accentuated(character: str) -> bool: + try: + description = unicodedata.name(character) # type: str + except ValueError: + return False + return "WITH GRAVE" in description or "WITH ACUTE" in description or "WITH CEDILLA" in description + + +@lru_cache(maxsize=UTF8_MAXIMAL_ALLOCATION) +def remove_accent(character: str) -> str: + decomposed = unicodedata.decomposition(character) # type: str + if not decomposed: + return character + + codes = decomposed.split(" ") # type: List[str] + + return chr( + int( + codes[0], + 16 + ) + ) + + +@lru_cache(maxsize=UTF8_MAXIMAL_ALLOCATION) +def unicode_range(character: str) -> Optional[str]: + """ + Retrieve the Unicode range official name from a single character. + """ + character_ord = ord(character) # type: int + + for range_name, ord_range in UNICODE_RANGES_COMBINED.items(): + if character_ord in ord_range: + return range_name + + return None + + +@lru_cache(maxsize=UTF8_MAXIMAL_ALLOCATION) +def is_latin(character: str) -> bool: + try: + description = unicodedata.name(character) # type: str + except ValueError: + return False + return "LATIN" in description + + +@lru_cache(maxsize=UTF8_MAXIMAL_ALLOCATION) +def is_punctuation(character: str) -> bool: + character_category = unicodedata.category(character) # type: str + + if "P" in character_category: + return True + + character_range = unicode_range(character) # type: Optional[str] + + if character_range is None: + return False + + return "Punctuation" in character_range + + +@lru_cache(maxsize=UTF8_MAXIMAL_ALLOCATION) +def is_symbol(character: str) -> bool: + character_category = unicodedata.category(character) # type: str + + if "S" in character_category or "N" in character_category: + return True + + character_range = unicode_range(character) # type: Optional[str] + + if character_range is None: + return False + + return "Forms" in character_range + + +@lru_cache(maxsize=UTF8_MAXIMAL_ALLOCATION) +def is_separator(character: str) -> bool: + if character.isspace() or character in ["|", "+"]: + return True + + character_category = unicodedata.category(character) # type: str + + return "Z" in character_category + + +def is_private_use_only(character: str) -> bool: + character_category = unicodedata.category(character) # type: str + + return "Co" == character_category + + +def is_cjk(character: str) -> bool: + try: + character_name = unicodedata.name(character) + except ValueError: + return False + + return "CJK" in character_name + + +@lru_cache(maxsize=len(UNICODE_RANGES_COMBINED)) +def is_unicode_range_secondary(range_name: str) -> bool: + for keyword in UNICODE_SECONDARY_RANGE_KEYWORD: + if keyword in range_name: + return True + + return False + + +def any_specified_encoding(sequence: bytes, search_zone: int = 4096) -> Optional[str]: + """ + Extract using ASCII-only decoder any specified encoding in the first n-bytes. + """ + if not isinstance(sequence, bytes): + raise TypeError + + seq_len = len(sequence) # type: int + + results = findall( + RE_POSSIBLE_ENCODING_INDICATION, + sequence[:seq_len if seq_len <= search_zone else search_zone].decode('ascii', errors='ignore') + ) # type: List[str] + + if len(results) == 0: + return None + + for specified_encoding in results: + specified_encoding = specified_encoding.lower().replace('-', '_') + + for encoding_alias, encoding_iana in aliases.items(): + if encoding_alias == specified_encoding: + return encoding_iana + if encoding_iana == specified_encoding: + return encoding_iana + + return None + + +@lru_cache(maxsize=128) +def is_multi_byte_encoding(name: str) -> bool: + """ + Verify is a specific encoding is a multi byte one based on it IANA name + """ + return name in {"utf_8", "utf_8_sig", "utf_16", "utf_16_be", "utf_16_le", "utf_32", "utf_32_le", "utf_32_be", "utf_7"} or issubclass( + importlib.import_module('encodings.{}'.format(name)).IncrementalDecoder, # type: ignore + MultibyteIncrementalDecoder + ) + + +def identify_sig_or_bom(sequence: bytes) -> Tuple[Optional[str], bytes]: + """ + Identify and extract SIG/BOM in given sequence. + """ + + for iana_encoding in ENCODING_MARKS: + marks = ENCODING_MARKS[iana_encoding] # type: Union[bytes, List[bytes]] + + if isinstance(marks, bytes): + marks = [marks] + + for mark in marks: + if sequence.startswith(mark): + return iana_encoding, mark + + return None, b"" + + +def should_strip_sig_or_bom(iana_encoding: str) -> bool: + return iana_encoding not in {"utf_16", "utf_32"} + + +def iana_name(cp_name: str, strict: bool = True) -> str: + cp_name = cp_name.lower().replace('-', '_') + + for encoding_alias, encoding_iana in aliases.items(): + if cp_name == encoding_alias or cp_name == encoding_iana: + return encoding_iana + + if strict: + raise ValueError("Unable to retrieve IANA for '{}'".format(cp_name)) + + return cp_name + + +def range_scan(decoded_sequence: str) -> List[str]: + ranges = set() # type: Set[str] + + for character in decoded_sequence: + character_range = unicode_range(character) # type: Optional[str] + + if character_range is None: + continue + + ranges.add( + character_range + ) + + return list(ranges) + + +def cp_similarity(iana_name_a: str, iana_name_b: str) -> float: + + if is_multi_byte_encoding(iana_name_a) or is_multi_byte_encoding(iana_name_b): + return 0. + + decoder_a = importlib.import_module('encodings.{}'.format(iana_name_a)).IncrementalDecoder # type: ignore + decoder_b = importlib.import_module('encodings.{}'.format(iana_name_b)).IncrementalDecoder # type: ignore + + id_a = decoder_a(errors="ignore") # type: IncrementalDecoder + id_b = decoder_b(errors="ignore") # type: IncrementalDecoder + + character_match_count = 0 # type: int + + for i in range(0, 255): + to_be_decoded = bytes([i]) # type: bytes + if id_a.decode(to_be_decoded) == id_b.decode(to_be_decoded): + character_match_count += 1 + + return character_match_count / 254 + + +def is_cp_similar(iana_name_a: str, iana_name_b: str) -> bool: + """ + Determine if two code page are at least 80% similar. IANA_SUPPORTED_SIMILAR dict was generated using + the function cp_similarity. + """ + return iana_name_a in IANA_SUPPORTED_SIMILAR and iana_name_b in IANA_SUPPORTED_SIMILAR[iana_name_a] diff --git a/venv/lib/python3.8/site-packages/charset_normalizer/version.py b/venv/lib/python3.8/site-packages/charset_normalizer/version.py new file mode 100644 index 0000000..12f4b34 --- /dev/null +++ b/venv/lib/python3.8/site-packages/charset_normalizer/version.py @@ -0,0 +1,6 @@ +""" +Expose version +""" + +__version__ = "2.0.3" +VERSION = __version__.split('.') diff --git a/venv/lib/python3.8/site-packages/easy_install.py b/venv/lib/python3.8/site-packages/easy_install.py new file mode 100644 index 0000000..d87e984 --- /dev/null +++ b/venv/lib/python3.8/site-packages/easy_install.py @@ -0,0 +1,5 @@ +"""Run the EasyInstall command""" + +if __name__ == '__main__': + from setuptools.command.easy_install import main + main() diff --git a/venv/lib/python3.8/site-packages/idna-3.2.dist-info/INSTALLER b/venv/lib/python3.8/site-packages/idna-3.2.dist-info/INSTALLER new file mode 100644 index 0000000..a1b589e --- /dev/null +++ b/venv/lib/python3.8/site-packages/idna-3.2.dist-info/INSTALLER @@ -0,0 +1 @@ +pip diff --git a/venv/lib/python3.8/site-packages/idna-3.2.dist-info/LICENSE.md b/venv/lib/python3.8/site-packages/idna-3.2.dist-info/LICENSE.md new file mode 100644 index 0000000..b6f8732 --- /dev/null +++ b/venv/lib/python3.8/site-packages/idna-3.2.dist-info/LICENSE.md @@ -0,0 +1,29 @@ +BSD 3-Clause License + +Copyright (c) 2013-2021, Kim Davies +All rights reserved. + +Redistribution and use in source and binary forms, with or without +modification, are permitted provided that the following conditions are met: + +1. Redistributions of source code must retain the above copyright notice, this + list of conditions and the following disclaimer. + +2. Redistributions in binary form must reproduce the above copyright notice, + this list of conditions and the following disclaimer in the documentation + and/or other materials provided with the distribution. + +3. Neither the name of the copyright holder nor the names of its + contributors may be used to endorse or promote products derived from + this software without specific prior written permission. + +THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" +AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE +IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE +DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE +FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL +DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR +SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER +CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, +OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE +OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. diff --git a/venv/lib/python3.8/site-packages/idna-3.2.dist-info/METADATA b/venv/lib/python3.8/site-packages/idna-3.2.dist-info/METADATA new file mode 100644 index 0000000..808eebb --- /dev/null +++ b/venv/lib/python3.8/site-packages/idna-3.2.dist-info/METADATA @@ -0,0 +1,225 @@ +Metadata-Version: 2.1 +Name: idna +Version: 3.2 +Summary: Internationalized Domain Names in Applications (IDNA) +Home-page: https://github.com/kjd/idna +Author: Kim Davies +Author-email: kim@cynosure.com.au +License: BSD-3-Clause +Platform: UNKNOWN +Classifier: Development Status :: 5 - Production/Stable +Classifier: Intended Audience :: Developers +Classifier: Intended Audience :: System Administrators +Classifier: License :: OSI Approved :: BSD License +Classifier: Operating System :: OS Independent +Classifier: Programming Language :: Python +Classifier: Programming Language :: Python :: 3 +Classifier: Programming Language :: Python :: 3 :: Only +Classifier: Programming Language :: Python :: 3.5 +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 +Classifier: Topic :: Internet :: Name Service (DNS) +Classifier: Topic :: Software Development :: Libraries :: Python Modules +Classifier: Topic :: Utilities +Requires-Python: >=3.5 + +Internationalized Domain Names in Applications (IDNA) +===================================================== + +Support for the Internationalised Domain Names in Applications +(IDNA) protocol as specified in `RFC 5891 `_. +This is the latest version of the protocol and is sometimes referred to as +“IDNA 2008”. + +This library also provides support for Unicode Technical Standard 46, +`Unicode IDNA Compatibility Processing `_. + +This acts as a suitable replacement for the “encodings.idna” module that +comes with the Python standard library, but which only supports the +old, deprecated IDNA specification (`RFC 3490 `_). + +Basic functions are simply executed: + +.. code-block:: pycon + + >>> import idna + >>> idna.encode('ドメイン.テスト') + b'xn--eckwd4c7c.xn--zckzah' + >>> print(idna.decode('xn--eckwd4c7c.xn--zckzah')) + ドメイン.テスト + +Packages +-------- + +The latest tagged release version is published in the PyPI repository: + +.. image:: https://badge.fury.io/py/idna.svg + :target: https://badge.fury.io/py/idna + + +Installation +------------ + +To install this library, you can use pip: + +.. code-block:: bash + + $ pip install idna + +Alternatively, you can install the package using the bundled setup script: + +.. code-block:: bash + + $ python setup.py install + +This library works with Python 3.4 or later. Earlier versions of this +library support Python 2 - use "idna<3" in your requirements file if +you need this library for a Python 2 application. + + +Usage +----- + +For typical usage, the ``encode`` and ``decode`` functions will take a domain +name argument and perform a conversion to A-labels or U-labels respectively. + +.. code-block:: pycon + + >>> import idna + >>> idna.encode('ドメイン.テスト') + b'xn--eckwd4c7c.xn--zckzah' + >>> print(idna.decode('xn--eckwd4c7c.xn--zckzah')) + ドメイン.テスト + +You may use the codec encoding and decoding methods using the +``idna.codec`` module: + +.. code-block:: pycon + + >>> import idna.codec + >>> print('домена.испытание'.encode('idna')) + b'xn--80ahd1agd.xn--80akhbyknj4f' + >>> print(b'xn--80ahd1agd.xn--80akhbyknj4f'.decode('idna')) + домена.испытание + +Conversions can be applied at a per-label basis using the ``ulabel`` or ``alabel`` +functions if necessary: + +.. code-block:: pycon + + >>> idna.alabel('测试') + b'xn--0zwm56d' + +Compatibility Mapping (UTS #46) ++++++++++++++++++++++++++++++++ + +As described in `RFC 5895 `_, the IDNA +specification does not normalize input from different potential ways a user +may input a domain name. This functionality, known as a “mapping”, is +considered by the specification to be a local user-interface issue distinct +from IDNA conversion functionality. + +This library provides one such mapping, that was developed by the Unicode +Consortium. Known as `Unicode IDNA Compatibility Processing `_, +it provides for both a regular mapping for typical applications, as well as +a transitional mapping to help migrate from older IDNA 2003 applications. + +For example, “Königsgäßchen” is not a permissible label as *LATIN CAPITAL +LETTER K* is not allowed (nor are capital letters in general). UTS 46 will +convert this into lower case prior to applying the IDNA conversion. + +.. code-block:: pycon + + >>> import idna + >>> idna.encode('Königsgäßchen') + ... + idna.core.InvalidCodepoint: Codepoint U+004B at position 1 of 'Königsgäßchen' not allowed + >>> idna.encode('Königsgäßchen', uts46=True) + b'xn--knigsgchen-b4a3dun' + >>> print(idna.decode('xn--knigsgchen-b4a3dun')) + königsgäßchen + +Transitional processing provides conversions to help transition from the older +2003 standard to the current standard. For example, in the original IDNA +specification, the *LATIN SMALL LETTER SHARP S* (ß) was converted into two +*LATIN SMALL LETTER S* (ss), whereas in the current IDNA specification this +conversion is not performed. + +.. code-block:: pycon + + >>> idna.encode('Königsgäßchen', uts46=True, transitional=True) + 'xn--knigsgsschen-lcb0w' + +Implementors should use transitional processing with caution, only in rare +cases where conversion from legacy labels to current labels must be performed +(i.e. IDNA implementations that pre-date 2008). For typical applications +that just need to convert labels, transitional processing is unlikely to be +beneficial and could produce unexpected incompatible results. + +``encodings.idna`` Compatibility +++++++++++++++++++++++++++++++++ + +Function calls from the Python built-in ``encodings.idna`` module are +mapped to their IDNA 2008 equivalents using the ``idna.compat`` module. +Simply substitute the ``import`` clause in your code to refer to the +new module name. + +Exceptions +---------- + +All errors raised during the conversion following the specification should +raise an exception derived from the ``idna.IDNAError`` base class. + +More specific exceptions that may be generated as ``idna.IDNABidiError`` +when the error reflects an illegal combination of left-to-right and +right-to-left characters in a label; ``idna.InvalidCodepoint`` when +a specific codepoint is an illegal character in an IDN label (i.e. +INVALID); and ``idna.InvalidCodepointContext`` when the codepoint is +illegal based on its positional context (i.e. it is CONTEXTO or CONTEXTJ +but the contextual requirements are not satisfied.) + +Building and Diagnostics +------------------------ + +The IDNA and UTS 46 functionality relies upon pre-calculated lookup +tables for performance. These tables are derived from computing against +eligibility criteria in the respective standards. These tables are +computed using the command-line script ``tools/idna-data``. + +This tool will fetch relevant codepoint data from the Unicode repository +and perform the required calculations to identify eligibility. There are +three main modes: + +* ``idna-data make-libdata``. Generates ``idnadata.py`` and ``uts46data.py``, + the pre-calculated lookup tables using for IDNA and UTS 46 conversions. Implementors + who wish to track this library against a different Unicode version may use this tool + to manually generate a different version of the ``idnadata.py`` and ``uts46data.py`` + files. + +* ``idna-data make-table``. Generate a table of the IDNA disposition + (e.g. PVALID, CONTEXTJ, CONTEXTO) in the format found in Appendix B.1 of RFC + 5892 and the pre-computed tables published by `IANA `_. + +* ``idna-data U+0061``. Prints debugging output on the various properties + associated with an individual Unicode codepoint (in this case, U+0061), that are + used to assess the IDNA and UTS 46 status of a codepoint. This is helpful in debugging + or analysis. + +The tool accepts a number of arguments, described using ``idna-data -h``. Most notably, +the ``--version`` argument allows the specification of the version of Unicode to use +in computing the table data. For example, ``idna-data --version 9.0.0 make-libdata`` +will generate library data against Unicode 9.0.0. + + +Testing +------- + +The library has a test suite based on each rule of the IDNA specification, as +well as tests that are provided as part of the Unicode Technical Standard 46, +`Unicode IDNA Compatibility Processing `_. + + diff --git a/venv/lib/python3.8/site-packages/idna-3.2.dist-info/RECORD b/venv/lib/python3.8/site-packages/idna-3.2.dist-info/RECORD new file mode 100644 index 0000000..9605bcd --- /dev/null +++ b/venv/lib/python3.8/site-packages/idna-3.2.dist-info/RECORD @@ -0,0 +1,23 @@ +idna-3.2.dist-info/INSTALLER,sha256=zuuue4knoyJ-UwPPXg8fezS7VCrXJQrAP7zeNuwvFQg,4 +idna-3.2.dist-info/LICENSE.md,sha256=otbk2UC9JNvnuWRc3hmpeSzFHbeuDVrNMBrIYMqj6DY,1523 +idna-3.2.dist-info/METADATA,sha256=L6eIrqdmpRK2oKwBFd8CcID4FQ8h2SYKf2fg7KEQLG0,8638 +idna-3.2.dist-info/RECORD,, +idna-3.2.dist-info/WHEEL,sha256=OqRkF0eY5GHssMorFjlbTIq072vpHpF60fIQA6lS9xA,92 +idna-3.2.dist-info/top_level.txt,sha256=jSag9sEDqvSPftxOQy-ABfGV_RSy7oFh4zZJpODV8k0,5 +idna/__init__.py,sha256=KJQN1eQBr8iIK5SKrJ47lXvxG0BJ7Lm38W4zT0v_8lk,849 +idna/__pycache__/__init__.cpython-38.pyc,, +idna/__pycache__/codec.cpython-38.pyc,, +idna/__pycache__/compat.cpython-38.pyc,, +idna/__pycache__/core.cpython-38.pyc,, +idna/__pycache__/idnadata.cpython-38.pyc,, +idna/__pycache__/intranges.cpython-38.pyc,, +idna/__pycache__/package_data.cpython-38.pyc,, +idna/__pycache__/uts46data.cpython-38.pyc,, +idna/codec.py,sha256=QsPFD3Je8gN17rfs14e7zTGRWlnL7bNf2ZqcHTRVYHs,3453 +idna/compat.py,sha256=5A9xR04puRHCsyjBNewZlVSiarth7K1bZqyEOeob1fA,360 +idna/core.py,sha256=icq2P13S6JMjoXgKhhd6ihhby7QsnZlNfniH6fLyf6U,12826 +idna/idnadata.py,sha256=cl4x9RLdw1ZMtEEbvKwAsX-Id3AdIjO5U3HaoKM6VGs,42350 +idna/intranges.py,sha256=EqgXwyATAn-CTACInqH9tYsYAitGB2VcQ50RZt_Cpjs,1933 +idna/package_data.py,sha256=_028B4fvadRIaXMwMYjhuQPP3AxTIt1IRE7X6RDR4Mk,21 +idna/py.typed,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 +idna/uts46data.py,sha256=DGzwDQv8JijY17I_7ondo3stjFjNnjvVAbA-z0k1XOE,201849 diff --git a/venv/lib/python3.8/site-packages/idna-3.2.dist-info/WHEEL b/venv/lib/python3.8/site-packages/idna-3.2.dist-info/WHEEL new file mode 100644 index 0000000..385faab --- /dev/null +++ b/venv/lib/python3.8/site-packages/idna-3.2.dist-info/WHEEL @@ -0,0 +1,5 @@ +Wheel-Version: 1.0 +Generator: bdist_wheel (0.36.2) +Root-Is-Purelib: true +Tag: py3-none-any + diff --git a/venv/lib/python3.8/site-packages/idna-3.2.dist-info/top_level.txt b/venv/lib/python3.8/site-packages/idna-3.2.dist-info/top_level.txt new file mode 100644 index 0000000..c40472e --- /dev/null +++ b/venv/lib/python3.8/site-packages/idna-3.2.dist-info/top_level.txt @@ -0,0 +1 @@ +idna diff --git a/venv/lib/python3.8/site-packages/idna/__init__.py b/venv/lib/python3.8/site-packages/idna/__init__.py new file mode 100644 index 0000000..a40eeaf --- /dev/null +++ b/venv/lib/python3.8/site-packages/idna/__init__.py @@ -0,0 +1,44 @@ +from .package_data import __version__ +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/venv/lib/python3.8/site-packages/idna/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/idna/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..5de0dce5b82921314e2ced0ae949dfe9bf8f5911 GIT binary patch literal 869 zcmbu7%Z}496o!*t(xypzNqQNvXHkh#jRZ(Y2mu3&*^EGljW?E?<4HY@o#3Ry%!}|2 zypp%9SnvX@@JSFtvp`5V%9nHgB*(w)^C5~xjvY5o@3VJZ$N7rMpChr!3wu|eEx-Xc zcce>P7voOekzLZ2J<^kX(w83bBChAw)2S2~1%IF(fdD1uV0KtYG!tS)Y7! zt+};p0!pvBu0)|IUB@Ome|_=tl>qTZ>p~kJ(>9!*t811EI4gjcg;2Fw-Br#CRr8zL zcr0f-o|{p+=jnm&Y&kP&`z6|qnb{?3 zrZQeN<(N>~9=4-{Nz86rktx9GXW#rnjAB})%1 z;}lrUbjPZumlm4;*VKQV)%d^H*?2SqN?D#$`o+=r&>G^$>9&^TwiM;&sL&#Z&8I!* w`R4NRN0DY%^;UplTT1abDScSpn&C59z%l2~vC*mr7NPrg9(FtKKV08`0t&U=qW}N^ literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/idna/__pycache__/codec.cpython-38.pyc b/venv/lib/python3.8/site-packages/idna/__pycache__/codec.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..d68bf6a4b7d5df53a33ab7f77c4f70198587d8c7 GIT binary patch literal 2830 zcmds3Pj4JG6t_K|KfBr8q}#NmrE1e44qM2E3;!gFQkn|&vPhJIG^iR)*4}i|nc1nw ztI{$nRZXw(8Ioged;s_&zV_5p51i-)-t#owqzOWRxZsta{eJfN+0VcCytmrzCV}$Z z$8X2eHX%<@Iapj!)}WR@fe=K{lw>rd84FqFgigjop1Gk*iD1G>z0k9*ANtVpG{_oZ zBWs3DN~FItC)`~cwmv7q6aEt-eCchqx1F#JNFW-3Gyv%UG7m^o%mFe7$O0fI0BMOf zAZ^(Oth>#_E?^xo57@lLP6BpPEQk|NNVq7Ro21u$Mq%4M*LX4?j)gRykaZiU@rF!| zH>umkjrGCR>q?E)Gx&fEdd#?AO^Q^S;EO^h<2+6$Eg1N=|Mb!0=Rg1W{FmL^L!5cA zIH0USEtfz@5>i1zCeRbk6B;^jMlM|FapA$<8pgc_TN)a#)G8V3A%4DJu+O1hgIe}M zR7}vjjykQu(L1zayL6jArWGwO;6XL3K-Uh+5rf6~K+VBdFD~B7%Slm;m6l>j;`x^D z#JNb5d~<2}`{{Cz{R-2F@{lA+lT$)fn63kS6bq+fOZ(C zoIPw=Z}jVn`Y)WJ@B;UkIdodp0Z^g4)jWy?6nL&$oWdTCBJ?Lat|>L>QS0*k#x+3{ z<#8sX$TXuU8;ePb{Z0 zl%}OsoM3q2g2q#_oTM7UCwT}<+c{yg1|taj*O+EH(Z*ynk}9gB;360(-vdEjg-Me_ zu+X5c%tH;s2arxJoepi$hnJ3CcmMF(0|@swU}bd{#W@t0Q5?s^H(}rc)DoE%P=)%x zX5qTc#Q!rEs`KEQ-T{UwyhF8w;t~psu{zT%WA7~#GnZr3&qz=wmaBmMT@tV(BzWoV zS0va^T1QCm?%^HHlF>Ubu!ehiNdnZ5kN^YBPQqL}OGWS^G1I!Km5j4*RHCIC>^ZN~ zZ{~)X(G^%`1M0p})c=XmFJ&yisKTf8fWK#kR$*Xtz!2(33^f3}hLe^+XtG5G)ohz= zIaWd<)1LNqAlMH+oY)x{j!$3DHyqRbEZLiGGRwwwsH;O*eLKpuAV+}9?pv4bYkLA+@=IWoA5fQ2U{?y#Qa7aP8s#! z$Lim2>LWmVrwkvC)q&&GNzyVK|3Ih@Ko|zO)YA_NNQDaDFon)D{&1WXNh<5Gz}=d2 zpV^cr#nF^y_kZk!mvnypY`DK;4;Xw>Kfs?NLG3$v9#UpN7g&>ZPj{EQ%Zq%G{{frw BPA32W literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/idna/__pycache__/compat.cpython-38.pyc b/venv/lib/python3.8/site-packages/idna/__pycache__/compat.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..4150f4b755424765d43c603e0285363e356a2a1a GIT binary patch literal 636 zcma)3%}yIJ5VkkF8wZ*S#0%_&L#n2WkdRslAtKj zlCPY21y0NaMT(FrbtKP^$DZ$-nah5Ei=o{9*e|a+W6u<9N`%2Fp7t0OFyM+!-z`TQ zK}SVRXVz)rS>e}dv zl4~KKfY0!>0+na??2%8{k{4JYmAWz@mpmk@{3+FvIcnlH&wXQaTifAW+p_v2VR&;b zr5gS^`de35zkObVF7wJXw)EfZB6O!_G&viO6T%@t7P(KT|BsAI@hQ;(Npu_$T@iU# z+Zcx4)L?s*?qRsb_>BI)F^GZ3Nk8%j4h$z36?b39=fx;HJUIBCfst*djnC%3R&^^g zT{hA>X*27LHf239YoHd%*?Yi9{^oH#^{fqW}N^ literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/idna/__pycache__/core.cpython-38.pyc b/venv/lib/python3.8/site-packages/idna/__pycache__/core.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..6bdcabbd5b0173ca374c87aa51ff3c34172501fb GIT binary patch literal 9126 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 literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/idna/__pycache__/package_data.cpython-38.pyc b/venv/lib/python3.8/site-packages/idna/__pycache__/package_data.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..210ed9c6d5f1f0675270db426e965b108f2f5d00 GIT binary patch literal 163 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 HV*mYrqtaTi literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/idna/codec.py b/venv/lib/python3.8/site-packages/idna/codec.py new file mode 100644 index 0000000..080f22a --- /dev/null +++ b/venv/lib/python3.8/site-packages/idna/codec.py @@ -0,0 +1,117 @@ +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'): + # type: (str, str) -> Tuple[bytes, int] + if errors != 'strict': + raise IDNAError('Unsupported error handling \"{}\"'.format(errors)) + + if not data: + return b"", 0 + + return encode(data), len(data) + + def decode(self, data, errors='strict'): + # type: (bytes, str) -> Tuple[str, int] + if errors != 'strict': + raise IDNAError('Unsupported error handling \"{}\"'.format(errors)) + + if not data: + return '', 0 + + return decode(data), len(data) + +class IncrementalEncoder(codecs.BufferedIncrementalEncoder): + def _buffer_encode(self, data, errors, final): # type: ignore + # type: (str, str, bool) -> Tuple[str, int] + if errors != 'strict': + raise IDNAError('Unsupported error handling \"{}\"'.format(errors)) + + if not data: + return "", 0 + + labels = _unicode_dots_re.split(data) + trailing_dot = '' + if labels: + if not labels[-1]: + trailing_dot = '.' + del labels[-1] + elif not final: + # Keep potentially unfinished label until the next call + del labels[-1] + if labels: + trailing_dot = '.' + + result = [] + size = 0 + for label in labels: + result.append(alabel(label)) + if size: + size += 1 + size += len(label) + + # Join with U+002E + result_str = '.'.join(result) + trailing_dot # type: ignore + size += len(trailing_dot) + return result_str, size + +class IncrementalDecoder(codecs.BufferedIncrementalDecoder): + def _buffer_decode(self, data, errors, final): # type: ignore + # type: (str, str, bool) -> Tuple[str, int] + if errors != 'strict': + raise IDNAError('Unsupported error handling \"{}\"'.format(errors)) + + if not data: + return ('', 0) + + labels = _unicode_dots_re.split(data) + trailing_dot = '' + if labels: + if not labels[-1]: + trailing_dot = '.' + del labels[-1] + elif not final: + # Keep potentially unfinished label until the next call + del labels[-1] + if labels: + trailing_dot = '.' + + result = [] + size = 0 + for label in labels: + result.append(ulabel(label)) + if size: + size += 1 + size += len(label) + + result_str = '.'.join(result) + trailing_dot + size += len(trailing_dot) + return (result_str, size) + + +class StreamWriter(Codec, codecs.StreamWriter): + pass + + +class StreamReader(Codec, codecs.StreamReader): + pass + + +def getregentry(): + # type: () -> codecs.CodecInfo + # Compatibility as a search_function for codecs.register() + return codecs.CodecInfo( + name='idna', + encode=Codec().encode, # type: ignore + decode=Codec().decode, # type: ignore + incrementalencoder=IncrementalEncoder, + incrementaldecoder=IncrementalDecoder, + streamwriter=StreamWriter, + streamreader=StreamReader, + ) diff --git a/venv/lib/python3.8/site-packages/idna/compat.py b/venv/lib/python3.8/site-packages/idna/compat.py new file mode 100644 index 0000000..dc896c7 --- /dev/null +++ b/venv/lib/python3.8/site-packages/idna/compat.py @@ -0,0 +1,16 @@ +from .core import * +from .codec import * +from typing import Any, Union + +def ToASCII(label): + # type: (str) -> bytes + return encode(label) + +def ToUnicode(label): + # type: (Union[bytes, bytearray]) -> str + return decode(label) + +def nameprep(s): + # type: (Any) -> None + raise NotImplementedError('IDNA 2008 does not utilise nameprep protocol') + diff --git a/venv/lib/python3.8/site-packages/idna/core.py b/venv/lib/python3.8/site-packages/idna/core.py new file mode 100644 index 0000000..d605129 --- /dev/null +++ b/venv/lib/python3.8/site-packages/idna/core.py @@ -0,0 +1,409 @@ +from . import idnadata +import bisect +import unicodedata +import re +from typing import Union, Optional +from .intranges import intranges_contain + +_virama_combining_class = 9 +_alabel_prefix = b'xn--' +_unicode_dots_re = re.compile('[\u002e\u3002\uff0e\uff61]') + +class IDNAError(UnicodeError): + """ Base exception for all IDNA-encoding related problems """ + pass + + +class IDNABidiError(IDNAError): + """ Exception when bidirectional requirements are not satisfied """ + pass + + +class InvalidCodepoint(IDNAError): + """ Exception when a disallowed or unallocated codepoint is used """ + pass + + +class InvalidCodepointContext(IDNAError): + """ Exception when the codepoint is not valid in the context it is used """ + pass + + +def _combining_class(cp): + # type: (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): + # type: (str, str) -> bool + return intranges_contain(ord(cp), idnadata.scripts[script]) + +def _punycode(s): + # type: (str) -> bytes + return s.encode('punycode') + +def _unot(s): + # type: (int) -> str + return 'U+{:04X}'.format(s) + + +def valid_label_length(label): + # type: (Union[bytes, str]) -> bool + if len(label) > 63: + return False + return True + + +def valid_string_length(label, trailing_dot): + # type: (Union[bytes, str], bool) -> bool + if len(label) > (254 if trailing_dot else 253): + return False + return True + + +def check_bidi(label, check_ltr=False): + # type: (str, bool) -> bool + # Bidi rules should only be applied if string contains RTL characters + bidi_label = False + for (idx, cp) in enumerate(label, 1): + direction = unicodedata.bidirectional(cp) + if direction == '': + # String likely comes from a newer version of Unicode + raise IDNABidiError('Unknown directionality in label {} at position {}'.format(repr(label), idx)) + if direction in ['R', 'AL', 'AN']: + bidi_label = True + if not bidi_label and not check_ltr: + return True + + # Bidi rule 1 + direction = unicodedata.bidirectional(label[0]) + if direction in ['R', 'AL']: + rtl = True + elif direction == 'L': + rtl = False + else: + raise IDNABidiError('First codepoint in label {} must be directionality L, R or AL'.format(repr(label))) + + valid_ending = False + number_type = None # type: Optional[str] + for (idx, cp) in enumerate(label, 1): + direction = unicodedata.bidirectional(cp) + + if rtl: + # Bidi rule 2 + if not direction in ['R', 'AL', 'AN', 'EN', 'ES', 'CS', 'ET', 'ON', 'BN', 'NSM']: + raise IDNABidiError('Invalid direction for codepoint at position {} in a right-to-left label'.format(idx)) + # Bidi rule 3 + if direction in ['R', 'AL', 'EN', 'AN']: + valid_ending = True + elif direction != 'NSM': + valid_ending = False + # Bidi rule 4 + if direction in ['AN', 'EN']: + if not number_type: + number_type = direction + else: + if number_type != direction: + raise IDNABidiError('Can not mix numeral types in a right-to-left label') + else: + # Bidi rule 5 + if not direction in ['L', 'EN', 'ES', 'CS', 'ET', 'ON', 'BN', 'NSM']: + raise IDNABidiError('Invalid direction for codepoint at position {} in a left-to-right label'.format(idx)) + # Bidi rule 6 + if direction in ['L', 'EN']: + valid_ending = True + elif direction != 'NSM': + valid_ending = False + + if not valid_ending: + raise IDNABidiError('Label ends with illegal codepoint directionality') + + return True + + +def check_initial_combiner(label): + # type: (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): + # type: (str) -> bool + if label[2:4] == '--': + raise IDNAError('Label has disallowed hyphens in 3rd and 4th position') + if label[0] == '-' or label[-1] == '-': + raise IDNAError('Label must not start or end with a hyphen') + return True + + +def check_nfc(label): + # type: (str) -> None + if unicodedata.normalize('NFC', label) != label: + raise IDNAError('Label must be in Normalization Form C') + + +def valid_contextj(label, pos): + # type: (str, int) -> bool + cp_value = ord(label[pos]) + + if cp_value == 0x200c: + + if pos > 0: + if _combining_class(ord(label[pos - 1])) == _virama_combining_class: + return True + + ok = False + for i in range(pos-1, -1, -1): + joining_type = idnadata.joining_types.get(ord(label[i])) + if joining_type == ord('T'): + continue + if joining_type in [ord('L'), ord('D')]: + ok = True + break + + if not ok: + return False + + ok = False + for i in range(pos+1, len(label)): + joining_type = idnadata.joining_types.get(ord(label[i])) + if joining_type == ord('T'): + continue + if joining_type in [ord('R'), ord('D')]: + ok = True + break + return ok + + if cp_value == 0x200d: + + if pos > 0: + if _combining_class(ord(label[pos - 1])) == _virama_combining_class: + return True + return False + + else: + + return False + + +def valid_contexto(label, pos, exception=False): + # type: (str, int, bool) -> bool + cp_value = ord(label[pos]) + + if cp_value == 0x00b7: + if 0 < pos < len(label)-1: + if ord(label[pos - 1]) == 0x006c and ord(label[pos + 1]) == 0x006c: + return True + return False + + elif cp_value == 0x0375: + if pos < len(label)-1 and len(label) > 1: + return _is_script(label[pos + 1], 'Greek') + return False + + elif cp_value == 0x05f3 or cp_value == 0x05f4: + if pos > 0: + return _is_script(label[pos - 1], 'Hebrew') + return False + + elif cp_value == 0x30fb: + for cp in label: + if cp == '\u30fb': + continue + if _is_script(cp, 'Hiragana') or _is_script(cp, 'Katakana') or _is_script(cp, 'Han'): + return True + return False + + elif 0x660 <= cp_value <= 0x669: + for cp in label: + if 0x6f0 <= ord(cp) <= 0x06f9: + return False + return True + + elif 0x6f0 <= cp_value <= 0x6f9: + for cp in label: + if 0x660 <= ord(cp) <= 0x0669: + return False + return True + + return False + + +def check_label(label): + # type: (Union[str, bytes, bytearray]) -> None + if isinstance(label, (bytes, bytearray)): + label = label.decode('utf-8') + if len(label) == 0: + raise IDNAError('Empty Label') + + check_nfc(label) + check_hyphen_ok(label) + check_initial_combiner(label) + + for (pos, cp) in enumerate(label): + cp_value = ord(cp) + if intranges_contain(cp_value, idnadata.codepoint_classes['PVALID']): + continue + elif intranges_contain(cp_value, idnadata.codepoint_classes['CONTEXTJ']): + try: + if not valid_contextj(label, pos): + raise InvalidCodepointContext('Joiner {} not allowed at position {} in {}'.format( + _unot(cp_value), pos+1, repr(label))) + except ValueError: + raise IDNAError('Unknown codepoint adjacent to joiner {} at position {} in {}'.format( + _unot(cp_value), pos+1, repr(label))) + elif intranges_contain(cp_value, idnadata.codepoint_classes['CONTEXTO']): + if not valid_contexto(label, pos): + raise InvalidCodepointContext('Codepoint {} not allowed at position {} in {}'.format(_unot(cp_value), pos+1, repr(label))) + else: + raise InvalidCodepoint('Codepoint {} at position {} of {} not allowed'.format(_unot(cp_value), pos+1, repr(label))) + + check_bidi(label) + + +def alabel(label): + # type: (str) -> bytes + try: + label_bytes = label.encode('ascii') + ulabel(label_bytes) + if not valid_label_length(label_bytes): + raise IDNAError('Label too long') + return label_bytes + except UnicodeEncodeError: + pass + + if not label: + raise IDNAError('No Input') + + label = str(label) + check_label(label) + label_bytes = _punycode(label) + label_bytes = _alabel_prefix + label_bytes + + if not valid_label_length(label_bytes): + raise IDNAError('Label too long') + + return label_bytes + + +def ulabel(label): + # type: (Union[str, bytes, bytearray]) -> str + if not isinstance(label, (bytes, bytearray)): + try: + label_bytes = label.encode('ascii') + except UnicodeEncodeError: + check_label(label) + return label + else: + label_bytes = 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_bytes.decode('ascii')[-1] == '-': + raise IDNAError('A-label must not end with a hyphen') + else: + check_label(label_bytes) + return label_bytes.decode('ascii') + + label = label_bytes.decode('punycode') + check_label(label) + return label + + +def uts46_remap(domain, std3_rules=True, transitional=False): + # type: (str, bool, bool) -> str + """Re-map the characters in the string according to UTS46 processing.""" + from .uts46data import uts46data + output = '' + + 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 = 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)): + output += char + elif replacement is not None and (status == 'M' or + (status == '3' and not std3_rules) or + (status == 'D' and transitional)): + output += replacement + elif status != 'I': + raise IndexError() + 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): + # type: (Union[str, bytes, bytearray], bool, bool, bool, bool) -> bytes + if isinstance(s, (bytes, bytearray)): + s = s.decode('ascii') + if uts46: + s = uts46_remap(s, std3_rules, transitional) + trailing_dot = False + result = [] + if strict: + labels = s.split('.') + else: + labels = _unicode_dots_re.split(s) + if not labels or labels == ['']: + raise IDNAError('Empty domain') + if labels[-1] == '': + del labels[-1] + trailing_dot = True + for label in labels: + s = alabel(label) + if s: + result.append(s) + else: + raise IDNAError('Empty label') + if trailing_dot: + result.append(b'') + s = b'.'.join(result) + if not valid_string_length(s, trailing_dot): + raise IDNAError('Domain too long') + return s + + +def decode(s, strict=False, uts46=False, std3_rules=False): + # type: (Union[str, bytes, bytearray], bool, bool, bool) -> str + if isinstance(s, (bytes, bytearray)): + s = s.decode('ascii') + if uts46: + s = uts46_remap(s, std3_rules, False) + trailing_dot = False + result = [] + if not strict: + labels = _unicode_dots_re.split(s) + else: + labels = s.split('.') + if not labels or labels == ['']: + raise IDNAError('Empty domain') + if not labels[-1]: + del labels[-1] + trailing_dot = True + for label in labels: + s = ulabel(label) + if s: + result.append(s) + else: + raise IDNAError('Empty label') + if trailing_dot: + result.append('') + return '.'.join(result) diff --git a/venv/lib/python3.8/site-packages/idna/idnadata.py b/venv/lib/python3.8/site-packages/idna/idnadata.py new file mode 100644 index 0000000..b86a3e0 --- /dev/null +++ b/venv/lib/python3.8/site-packages/idna/idnadata.py @@ -0,0 +1,2050 @@ +# This file is automatically generated by tools/idna-data + +__version__ = '13.0.0' +scripts = { + 'Greek': ( + 0x37000000374, + 0x37500000378, + 0x37a0000037e, + 0x37f00000380, + 0x38400000385, + 0x38600000387, + 0x3880000038b, + 0x38c0000038d, + 0x38e000003a2, + 0x3a3000003e2, + 0x3f000000400, + 0x1d2600001d2b, + 0x1d5d00001d62, + 0x1d6600001d6b, + 0x1dbf00001dc0, + 0x1f0000001f16, + 0x1f1800001f1e, + 0x1f2000001f46, + 0x1f4800001f4e, + 0x1f5000001f58, + 0x1f5900001f5a, + 0x1f5b00001f5c, + 0x1f5d00001f5e, + 0x1f5f00001f7e, + 0x1f8000001fb5, + 0x1fb600001fc5, + 0x1fc600001fd4, + 0x1fd600001fdc, + 0x1fdd00001ff0, + 0x1ff200001ff5, + 0x1ff600001fff, + 0x212600002127, + 0xab650000ab66, + 0x101400001018f, + 0x101a0000101a1, + 0x1d2000001d246, + ), + 'Han': ( + 0x2e8000002e9a, + 0x2e9b00002ef4, + 0x2f0000002fd6, + 0x300500003006, + 0x300700003008, + 0x30210000302a, + 0x30380000303c, + 0x340000004dc0, + 0x4e0000009ffd, + 0xf9000000fa6e, + 0xfa700000fada, + 0x16ff000016ff2, + 0x200000002a6de, + 0x2a7000002b735, + 0x2b7400002b81e, + 0x2b8200002cea2, + 0x2ceb00002ebe1, + 0x2f8000002fa1e, + 0x300000003134b, + ), + 'Hebrew': ( + 0x591000005c8, + 0x5d0000005eb, + 0x5ef000005f5, + 0xfb1d0000fb37, + 0xfb380000fb3d, + 0xfb3e0000fb3f, + 0xfb400000fb42, + 0xfb430000fb45, + 0xfb460000fb50, + ), + 'Hiragana': ( + 0x304100003097, + 0x309d000030a0, + 0x1b0010001b11f, + 0x1b1500001b153, + 0x1f2000001f201, + ), + 'Katakana': ( + 0x30a1000030fb, + 0x30fd00003100, + 0x31f000003200, + 0x32d0000032ff, + 0x330000003358, + 0xff660000ff70, + 0xff710000ff9e, + 0x1b0000001b001, + 0x1b1640001b168, + ), +} +joining_types = { + 0x600: 85, + 0x601: 85, + 0x602: 85, + 0x603: 85, + 0x604: 85, + 0x605: 85, + 0x608: 85, + 0x60b: 85, + 0x620: 68, + 0x621: 85, + 0x622: 82, + 0x623: 82, + 0x624: 82, + 0x625: 82, + 0x626: 68, + 0x627: 82, + 0x628: 68, + 0x629: 82, + 0x62a: 68, + 0x62b: 68, + 0x62c: 68, + 0x62d: 68, + 0x62e: 68, + 0x62f: 82, + 0x630: 82, + 0x631: 82, + 0x632: 82, + 0x633: 68, + 0x634: 68, + 0x635: 68, + 0x636: 68, + 0x637: 68, + 0x638: 68, + 0x639: 68, + 0x63a: 68, + 0x63b: 68, + 0x63c: 68, + 0x63d: 68, + 0x63e: 68, + 0x63f: 68, + 0x640: 67, + 0x641: 68, + 0x642: 68, + 0x643: 68, + 0x644: 68, + 0x645: 68, + 0x646: 68, + 0x647: 68, + 0x648: 82, + 0x649: 68, + 0x64a: 68, + 0x66e: 68, + 0x66f: 68, + 0x671: 82, + 0x672: 82, + 0x673: 82, + 0x674: 85, + 0x675: 82, + 0x676: 82, + 0x677: 82, + 0x678: 68, + 0x679: 68, + 0x67a: 68, + 0x67b: 68, + 0x67c: 68, + 0x67d: 68, + 0x67e: 68, + 0x67f: 68, + 0x680: 68, + 0x681: 68, + 0x682: 68, + 0x683: 68, + 0x684: 68, + 0x685: 68, + 0x686: 68, + 0x687: 68, + 0x688: 82, + 0x689: 82, + 0x68a: 82, + 0x68b: 82, + 0x68c: 82, + 0x68d: 82, + 0x68e: 82, + 0x68f: 82, + 0x690: 82, + 0x691: 82, + 0x692: 82, + 0x693: 82, + 0x694: 82, + 0x695: 82, + 0x696: 82, + 0x697: 82, + 0x698: 82, + 0x699: 82, + 0x69a: 68, + 0x69b: 68, + 0x69c: 68, + 0x69d: 68, + 0x69e: 68, + 0x69f: 68, + 0x6a0: 68, + 0x6a1: 68, + 0x6a2: 68, + 0x6a3: 68, + 0x6a4: 68, + 0x6a5: 68, + 0x6a6: 68, + 0x6a7: 68, + 0x6a8: 68, + 0x6a9: 68, + 0x6aa: 68, + 0x6ab: 68, + 0x6ac: 68, + 0x6ad: 68, + 0x6ae: 68, + 0x6af: 68, + 0x6b0: 68, + 0x6b1: 68, + 0x6b2: 68, + 0x6b3: 68, + 0x6b4: 68, + 0x6b5: 68, + 0x6b6: 68, + 0x6b7: 68, + 0x6b8: 68, + 0x6b9: 68, + 0x6ba: 68, + 0x6bb: 68, + 0x6bc: 68, + 0x6bd: 68, + 0x6be: 68, + 0x6bf: 68, + 0x6c0: 82, + 0x6c1: 68, + 0x6c2: 68, + 0x6c3: 82, + 0x6c4: 82, + 0x6c5: 82, + 0x6c6: 82, + 0x6c7: 82, + 0x6c8: 82, + 0x6c9: 82, + 0x6ca: 82, + 0x6cb: 82, + 0x6cc: 68, + 0x6cd: 82, + 0x6ce: 68, + 0x6cf: 82, + 0x6d0: 68, + 0x6d1: 68, + 0x6d2: 82, + 0x6d3: 82, + 0x6d5: 82, + 0x6dd: 85, + 0x6ee: 82, + 0x6ef: 82, + 0x6fa: 68, + 0x6fb: 68, + 0x6fc: 68, + 0x6ff: 68, + 0x70f: 84, + 0x710: 82, + 0x712: 68, + 0x713: 68, + 0x714: 68, + 0x715: 82, + 0x716: 82, + 0x717: 82, + 0x718: 82, + 0x719: 82, + 0x71a: 68, + 0x71b: 68, + 0x71c: 68, + 0x71d: 68, + 0x71e: 82, + 0x71f: 68, + 0x720: 68, + 0x721: 68, + 0x722: 68, + 0x723: 68, + 0x724: 68, + 0x725: 68, + 0x726: 68, + 0x727: 68, + 0x728: 82, + 0x729: 68, + 0x72a: 82, + 0x72b: 68, + 0x72c: 82, + 0x72d: 68, + 0x72e: 68, + 0x72f: 82, + 0x74d: 82, + 0x74e: 68, + 0x74f: 68, + 0x750: 68, + 0x751: 68, + 0x752: 68, + 0x753: 68, + 0x754: 68, + 0x755: 68, + 0x756: 68, + 0x757: 68, + 0x758: 68, + 0x759: 82, + 0x75a: 82, + 0x75b: 82, + 0x75c: 68, + 0x75d: 68, + 0x75e: 68, + 0x75f: 68, + 0x760: 68, + 0x761: 68, + 0x762: 68, + 0x763: 68, + 0x764: 68, + 0x765: 68, + 0x766: 68, + 0x767: 68, + 0x768: 68, + 0x769: 68, + 0x76a: 68, + 0x76b: 82, + 0x76c: 82, + 0x76d: 68, + 0x76e: 68, + 0x76f: 68, + 0x770: 68, + 0x771: 82, + 0x772: 68, + 0x773: 82, + 0x774: 82, + 0x775: 68, + 0x776: 68, + 0x777: 68, + 0x778: 82, + 0x779: 82, + 0x77a: 68, + 0x77b: 68, + 0x77c: 68, + 0x77d: 68, + 0x77e: 68, + 0x77f: 68, + 0x7ca: 68, + 0x7cb: 68, + 0x7cc: 68, + 0x7cd: 68, + 0x7ce: 68, + 0x7cf: 68, + 0x7d0: 68, + 0x7d1: 68, + 0x7d2: 68, + 0x7d3: 68, + 0x7d4: 68, + 0x7d5: 68, + 0x7d6: 68, + 0x7d7: 68, + 0x7d8: 68, + 0x7d9: 68, + 0x7da: 68, + 0x7db: 68, + 0x7dc: 68, + 0x7dd: 68, + 0x7de: 68, + 0x7df: 68, + 0x7e0: 68, + 0x7e1: 68, + 0x7e2: 68, + 0x7e3: 68, + 0x7e4: 68, + 0x7e5: 68, + 0x7e6: 68, + 0x7e7: 68, + 0x7e8: 68, + 0x7e9: 68, + 0x7ea: 68, + 0x7fa: 67, + 0x840: 82, + 0x841: 68, + 0x842: 68, + 0x843: 68, + 0x844: 68, + 0x845: 68, + 0x846: 82, + 0x847: 82, + 0x848: 68, + 0x849: 82, + 0x84a: 68, + 0x84b: 68, + 0x84c: 68, + 0x84d: 68, + 0x84e: 68, + 0x84f: 68, + 0x850: 68, + 0x851: 68, + 0x852: 68, + 0x853: 68, + 0x854: 82, + 0x855: 68, + 0x856: 82, + 0x857: 82, + 0x858: 82, + 0x860: 68, + 0x861: 85, + 0x862: 68, + 0x863: 68, + 0x864: 68, + 0x865: 68, + 0x866: 85, + 0x867: 82, + 0x868: 68, + 0x869: 82, + 0x86a: 82, + 0x8a0: 68, + 0x8a1: 68, + 0x8a2: 68, + 0x8a3: 68, + 0x8a4: 68, + 0x8a5: 68, + 0x8a6: 68, + 0x8a7: 68, + 0x8a8: 68, + 0x8a9: 68, + 0x8aa: 82, + 0x8ab: 82, + 0x8ac: 82, + 0x8ad: 85, + 0x8ae: 82, + 0x8af: 68, + 0x8b0: 68, + 0x8b1: 82, + 0x8b2: 82, + 0x8b3: 68, + 0x8b4: 68, + 0x8b6: 68, + 0x8b7: 68, + 0x8b8: 68, + 0x8b9: 82, + 0x8ba: 68, + 0x8bb: 68, + 0x8bc: 68, + 0x8bd: 68, + 0x8be: 68, + 0x8bf: 68, + 0x8c0: 68, + 0x8c1: 68, + 0x8c2: 68, + 0x8c3: 68, + 0x8c4: 68, + 0x8c5: 68, + 0x8c6: 68, + 0x8c7: 68, + 0x8e2: 85, + 0x1806: 85, + 0x1807: 68, + 0x180a: 67, + 0x180e: 85, + 0x1820: 68, + 0x1821: 68, + 0x1822: 68, + 0x1823: 68, + 0x1824: 68, + 0x1825: 68, + 0x1826: 68, + 0x1827: 68, + 0x1828: 68, + 0x1829: 68, + 0x182a: 68, + 0x182b: 68, + 0x182c: 68, + 0x182d: 68, + 0x182e: 68, + 0x182f: 68, + 0x1830: 68, + 0x1831: 68, + 0x1832: 68, + 0x1833: 68, + 0x1834: 68, + 0x1835: 68, + 0x1836: 68, + 0x1837: 68, + 0x1838: 68, + 0x1839: 68, + 0x183a: 68, + 0x183b: 68, + 0x183c: 68, + 0x183d: 68, + 0x183e: 68, + 0x183f: 68, + 0x1840: 68, + 0x1841: 68, + 0x1842: 68, + 0x1843: 68, + 0x1844: 68, + 0x1845: 68, + 0x1846: 68, + 0x1847: 68, + 0x1848: 68, + 0x1849: 68, + 0x184a: 68, + 0x184b: 68, + 0x184c: 68, + 0x184d: 68, + 0x184e: 68, + 0x184f: 68, + 0x1850: 68, + 0x1851: 68, + 0x1852: 68, + 0x1853: 68, + 0x1854: 68, + 0x1855: 68, + 0x1856: 68, + 0x1857: 68, + 0x1858: 68, + 0x1859: 68, + 0x185a: 68, + 0x185b: 68, + 0x185c: 68, + 0x185d: 68, + 0x185e: 68, + 0x185f: 68, + 0x1860: 68, + 0x1861: 68, + 0x1862: 68, + 0x1863: 68, + 0x1864: 68, + 0x1865: 68, + 0x1866: 68, + 0x1867: 68, + 0x1868: 68, + 0x1869: 68, + 0x186a: 68, + 0x186b: 68, + 0x186c: 68, + 0x186d: 68, + 0x186e: 68, + 0x186f: 68, + 0x1870: 68, + 0x1871: 68, + 0x1872: 68, + 0x1873: 68, + 0x1874: 68, + 0x1875: 68, + 0x1876: 68, + 0x1877: 68, + 0x1878: 68, + 0x1880: 85, + 0x1881: 85, + 0x1882: 85, + 0x1883: 85, + 0x1884: 85, + 0x1885: 84, + 0x1886: 84, + 0x1887: 68, + 0x1888: 68, + 0x1889: 68, + 0x188a: 68, + 0x188b: 68, + 0x188c: 68, + 0x188d: 68, + 0x188e: 68, + 0x188f: 68, + 0x1890: 68, + 0x1891: 68, + 0x1892: 68, + 0x1893: 68, + 0x1894: 68, + 0x1895: 68, + 0x1896: 68, + 0x1897: 68, + 0x1898: 68, + 0x1899: 68, + 0x189a: 68, + 0x189b: 68, + 0x189c: 68, + 0x189d: 68, + 0x189e: 68, + 0x189f: 68, + 0x18a0: 68, + 0x18a1: 68, + 0x18a2: 68, + 0x18a3: 68, + 0x18a4: 68, + 0x18a5: 68, + 0x18a6: 68, + 0x18a7: 68, + 0x18a8: 68, + 0x18aa: 68, + 0x200c: 85, + 0x200d: 67, + 0x202f: 85, + 0x2066: 85, + 0x2067: 85, + 0x2068: 85, + 0x2069: 85, + 0xa840: 68, + 0xa841: 68, + 0xa842: 68, + 0xa843: 68, + 0xa844: 68, + 0xa845: 68, + 0xa846: 68, + 0xa847: 68, + 0xa848: 68, + 0xa849: 68, + 0xa84a: 68, + 0xa84b: 68, + 0xa84c: 68, + 0xa84d: 68, + 0xa84e: 68, + 0xa84f: 68, + 0xa850: 68, + 0xa851: 68, + 0xa852: 68, + 0xa853: 68, + 0xa854: 68, + 0xa855: 68, + 0xa856: 68, + 0xa857: 68, + 0xa858: 68, + 0xa859: 68, + 0xa85a: 68, + 0xa85b: 68, + 0xa85c: 68, + 0xa85d: 68, + 0xa85e: 68, + 0xa85f: 68, + 0xa860: 68, + 0xa861: 68, + 0xa862: 68, + 0xa863: 68, + 0xa864: 68, + 0xa865: 68, + 0xa866: 68, + 0xa867: 68, + 0xa868: 68, + 0xa869: 68, + 0xa86a: 68, + 0xa86b: 68, + 0xa86c: 68, + 0xa86d: 68, + 0xa86e: 68, + 0xa86f: 68, + 0xa870: 68, + 0xa871: 68, + 0xa872: 76, + 0xa873: 85, + 0x10ac0: 68, + 0x10ac1: 68, + 0x10ac2: 68, + 0x10ac3: 68, + 0x10ac4: 68, + 0x10ac5: 82, + 0x10ac6: 85, + 0x10ac7: 82, + 0x10ac8: 85, + 0x10ac9: 82, + 0x10aca: 82, + 0x10acb: 85, + 0x10acc: 85, + 0x10acd: 76, + 0x10ace: 82, + 0x10acf: 82, + 0x10ad0: 82, + 0x10ad1: 82, + 0x10ad2: 82, + 0x10ad3: 68, + 0x10ad4: 68, + 0x10ad5: 68, + 0x10ad6: 68, + 0x10ad7: 76, + 0x10ad8: 68, + 0x10ad9: 68, + 0x10ada: 68, + 0x10adb: 68, + 0x10adc: 68, + 0x10add: 82, + 0x10ade: 68, + 0x10adf: 68, + 0x10ae0: 68, + 0x10ae1: 82, + 0x10ae2: 85, + 0x10ae3: 85, + 0x10ae4: 82, + 0x10aeb: 68, + 0x10aec: 68, + 0x10aed: 68, + 0x10aee: 68, + 0x10aef: 82, + 0x10b80: 68, + 0x10b81: 82, + 0x10b82: 68, + 0x10b83: 82, + 0x10b84: 82, + 0x10b85: 82, + 0x10b86: 68, + 0x10b87: 68, + 0x10b88: 68, + 0x10b89: 82, + 0x10b8a: 68, + 0x10b8b: 68, + 0x10b8c: 82, + 0x10b8d: 68, + 0x10b8e: 82, + 0x10b8f: 82, + 0x10b90: 68, + 0x10b91: 82, + 0x10ba9: 82, + 0x10baa: 82, + 0x10bab: 82, + 0x10bac: 82, + 0x10bad: 68, + 0x10bae: 68, + 0x10baf: 85, + 0x10d00: 76, + 0x10d01: 68, + 0x10d02: 68, + 0x10d03: 68, + 0x10d04: 68, + 0x10d05: 68, + 0x10d06: 68, + 0x10d07: 68, + 0x10d08: 68, + 0x10d09: 68, + 0x10d0a: 68, + 0x10d0b: 68, + 0x10d0c: 68, + 0x10d0d: 68, + 0x10d0e: 68, + 0x10d0f: 68, + 0x10d10: 68, + 0x10d11: 68, + 0x10d12: 68, + 0x10d13: 68, + 0x10d14: 68, + 0x10d15: 68, + 0x10d16: 68, + 0x10d17: 68, + 0x10d18: 68, + 0x10d19: 68, + 0x10d1a: 68, + 0x10d1b: 68, + 0x10d1c: 68, + 0x10d1d: 68, + 0x10d1e: 68, + 0x10d1f: 68, + 0x10d20: 68, + 0x10d21: 68, + 0x10d22: 82, + 0x10d23: 68, + 0x10f30: 68, + 0x10f31: 68, + 0x10f32: 68, + 0x10f33: 82, + 0x10f34: 68, + 0x10f35: 68, + 0x10f36: 68, + 0x10f37: 68, + 0x10f38: 68, + 0x10f39: 68, + 0x10f3a: 68, + 0x10f3b: 68, + 0x10f3c: 68, + 0x10f3d: 68, + 0x10f3e: 68, + 0x10f3f: 68, + 0x10f40: 68, + 0x10f41: 68, + 0x10f42: 68, + 0x10f43: 68, + 0x10f44: 68, + 0x10f45: 85, + 0x10f51: 68, + 0x10f52: 68, + 0x10f53: 68, + 0x10f54: 82, + 0x10fb0: 68, + 0x10fb1: 85, + 0x10fb2: 68, + 0x10fb3: 68, + 0x10fb4: 82, + 0x10fb5: 82, + 0x10fb6: 82, + 0x10fb7: 85, + 0x10fb8: 68, + 0x10fb9: 82, + 0x10fba: 82, + 0x10fbb: 68, + 0x10fbc: 68, + 0x10fbd: 82, + 0x10fbe: 68, + 0x10fbf: 68, + 0x10fc0: 85, + 0x10fc1: 68, + 0x10fc2: 82, + 0x10fc3: 82, + 0x10fc4: 68, + 0x10fc5: 85, + 0x10fc6: 85, + 0x10fc7: 85, + 0x10fc8: 85, + 0x10fc9: 82, + 0x10fca: 68, + 0x10fcb: 76, + 0x110bd: 85, + 0x110cd: 85, + 0x1e900: 68, + 0x1e901: 68, + 0x1e902: 68, + 0x1e903: 68, + 0x1e904: 68, + 0x1e905: 68, + 0x1e906: 68, + 0x1e907: 68, + 0x1e908: 68, + 0x1e909: 68, + 0x1e90a: 68, + 0x1e90b: 68, + 0x1e90c: 68, + 0x1e90d: 68, + 0x1e90e: 68, + 0x1e90f: 68, + 0x1e910: 68, + 0x1e911: 68, + 0x1e912: 68, + 0x1e913: 68, + 0x1e914: 68, + 0x1e915: 68, + 0x1e916: 68, + 0x1e917: 68, + 0x1e918: 68, + 0x1e919: 68, + 0x1e91a: 68, + 0x1e91b: 68, + 0x1e91c: 68, + 0x1e91d: 68, + 0x1e91e: 68, + 0x1e91f: 68, + 0x1e920: 68, + 0x1e921: 68, + 0x1e922: 68, + 0x1e923: 68, + 0x1e924: 68, + 0x1e925: 68, + 0x1e926: 68, + 0x1e927: 68, + 0x1e928: 68, + 0x1e929: 68, + 0x1e92a: 68, + 0x1e92b: 68, + 0x1e92c: 68, + 0x1e92d: 68, + 0x1e92e: 68, + 0x1e92f: 68, + 0x1e930: 68, + 0x1e931: 68, + 0x1e932: 68, + 0x1e933: 68, + 0x1e934: 68, + 0x1e935: 68, + 0x1e936: 68, + 0x1e937: 68, + 0x1e938: 68, + 0x1e939: 68, + 0x1e93a: 68, + 0x1e93b: 68, + 0x1e93c: 68, + 0x1e93d: 68, + 0x1e93e: 68, + 0x1e93f: 68, + 0x1e940: 68, + 0x1e941: 68, + 0x1e942: 68, + 0x1e943: 68, + 0x1e94b: 84, +} +codepoint_classes = { + 'PVALID': ( + 0x2d0000002e, + 0x300000003a, + 0x610000007b, + 0xdf000000f7, + 0xf800000100, + 0x10100000102, + 0x10300000104, + 0x10500000106, + 0x10700000108, + 0x1090000010a, + 0x10b0000010c, + 0x10d0000010e, + 0x10f00000110, + 0x11100000112, + 0x11300000114, + 0x11500000116, + 0x11700000118, + 0x1190000011a, + 0x11b0000011c, + 0x11d0000011e, + 0x11f00000120, + 0x12100000122, + 0x12300000124, + 0x12500000126, + 0x12700000128, + 0x1290000012a, + 0x12b0000012c, + 0x12d0000012e, + 0x12f00000130, + 0x13100000132, + 0x13500000136, + 0x13700000139, + 0x13a0000013b, + 0x13c0000013d, + 0x13e0000013f, + 0x14200000143, + 0x14400000145, + 0x14600000147, + 0x14800000149, + 0x14b0000014c, + 0x14d0000014e, + 0x14f00000150, + 0x15100000152, + 0x15300000154, + 0x15500000156, + 0x15700000158, + 0x1590000015a, + 0x15b0000015c, + 0x15d0000015e, + 0x15f00000160, + 0x16100000162, + 0x16300000164, + 0x16500000166, + 0x16700000168, + 0x1690000016a, + 0x16b0000016c, + 0x16d0000016e, + 0x16f00000170, + 0x17100000172, + 0x17300000174, + 0x17500000176, + 0x17700000178, + 0x17a0000017b, + 0x17c0000017d, + 0x17e0000017f, + 0x18000000181, + 0x18300000184, + 0x18500000186, + 0x18800000189, + 0x18c0000018e, + 0x19200000193, + 0x19500000196, + 0x1990000019c, + 0x19e0000019f, + 0x1a1000001a2, + 0x1a3000001a4, + 0x1a5000001a6, + 0x1a8000001a9, + 0x1aa000001ac, + 0x1ad000001ae, + 0x1b0000001b1, + 0x1b4000001b5, + 0x1b6000001b7, + 0x1b9000001bc, + 0x1bd000001c4, + 0x1ce000001cf, + 0x1d0000001d1, + 0x1d2000001d3, + 0x1d4000001d5, + 0x1d6000001d7, + 0x1d8000001d9, + 0x1da000001db, + 0x1dc000001de, + 0x1df000001e0, + 0x1e1000001e2, + 0x1e3000001e4, + 0x1e5000001e6, + 0x1e7000001e8, + 0x1e9000001ea, + 0x1eb000001ec, + 0x1ed000001ee, + 0x1ef000001f1, + 0x1f5000001f6, + 0x1f9000001fa, + 0x1fb000001fc, + 0x1fd000001fe, + 0x1ff00000200, + 0x20100000202, + 0x20300000204, + 0x20500000206, + 0x20700000208, + 0x2090000020a, + 0x20b0000020c, + 0x20d0000020e, + 0x20f00000210, + 0x21100000212, + 0x21300000214, + 0x21500000216, + 0x21700000218, + 0x2190000021a, + 0x21b0000021c, + 0x21d0000021e, + 0x21f00000220, + 0x22100000222, + 0x22300000224, + 0x22500000226, + 0x22700000228, + 0x2290000022a, + 0x22b0000022c, + 0x22d0000022e, + 0x22f00000230, + 0x23100000232, + 0x2330000023a, + 0x23c0000023d, + 0x23f00000241, + 0x24200000243, + 0x24700000248, + 0x2490000024a, + 0x24b0000024c, + 0x24d0000024e, + 0x24f000002b0, + 0x2b9000002c2, + 0x2c6000002d2, + 0x2ec000002ed, + 0x2ee000002ef, + 0x30000000340, + 0x34200000343, + 0x3460000034f, + 0x35000000370, + 0x37100000372, + 0x37300000374, + 0x37700000378, + 0x37b0000037e, + 0x39000000391, + 0x3ac000003cf, + 0x3d7000003d8, + 0x3d9000003da, + 0x3db000003dc, + 0x3dd000003de, + 0x3df000003e0, + 0x3e1000003e2, + 0x3e3000003e4, + 0x3e5000003e6, + 0x3e7000003e8, + 0x3e9000003ea, + 0x3eb000003ec, + 0x3ed000003ee, + 0x3ef000003f0, + 0x3f3000003f4, + 0x3f8000003f9, + 0x3fb000003fd, + 0x43000000460, + 0x46100000462, + 0x46300000464, + 0x46500000466, + 0x46700000468, + 0x4690000046a, + 0x46b0000046c, + 0x46d0000046e, + 0x46f00000470, + 0x47100000472, + 0x47300000474, + 0x47500000476, + 0x47700000478, + 0x4790000047a, + 0x47b0000047c, + 0x47d0000047e, + 0x47f00000480, + 0x48100000482, + 0x48300000488, + 0x48b0000048c, + 0x48d0000048e, + 0x48f00000490, + 0x49100000492, + 0x49300000494, + 0x49500000496, + 0x49700000498, + 0x4990000049a, + 0x49b0000049c, + 0x49d0000049e, + 0x49f000004a0, + 0x4a1000004a2, + 0x4a3000004a4, + 0x4a5000004a6, + 0x4a7000004a8, + 0x4a9000004aa, + 0x4ab000004ac, + 0x4ad000004ae, + 0x4af000004b0, + 0x4b1000004b2, + 0x4b3000004b4, + 0x4b5000004b6, + 0x4b7000004b8, + 0x4b9000004ba, + 0x4bb000004bc, + 0x4bd000004be, + 0x4bf000004c0, + 0x4c2000004c3, + 0x4c4000004c5, + 0x4c6000004c7, + 0x4c8000004c9, + 0x4ca000004cb, + 0x4cc000004cd, + 0x4ce000004d0, + 0x4d1000004d2, + 0x4d3000004d4, + 0x4d5000004d6, + 0x4d7000004d8, + 0x4d9000004da, + 0x4db000004dc, + 0x4dd000004de, + 0x4df000004e0, + 0x4e1000004e2, + 0x4e3000004e4, + 0x4e5000004e6, + 0x4e7000004e8, + 0x4e9000004ea, + 0x4eb000004ec, + 0x4ed000004ee, + 0x4ef000004f0, + 0x4f1000004f2, + 0x4f3000004f4, + 0x4f5000004f6, + 0x4f7000004f8, + 0x4f9000004fa, + 0x4fb000004fc, + 0x4fd000004fe, + 0x4ff00000500, + 0x50100000502, + 0x50300000504, + 0x50500000506, + 0x50700000508, + 0x5090000050a, + 0x50b0000050c, + 0x50d0000050e, + 0x50f00000510, + 0x51100000512, + 0x51300000514, + 0x51500000516, + 0x51700000518, + 0x5190000051a, + 0x51b0000051c, + 0x51d0000051e, + 0x51f00000520, + 0x52100000522, + 0x52300000524, + 0x52500000526, + 0x52700000528, + 0x5290000052a, + 0x52b0000052c, + 0x52d0000052e, + 0x52f00000530, + 0x5590000055a, + 0x56000000587, + 0x58800000589, + 0x591000005be, + 0x5bf000005c0, + 0x5c1000005c3, + 0x5c4000005c6, + 0x5c7000005c8, + 0x5d0000005eb, + 0x5ef000005f3, + 0x6100000061b, + 0x62000000640, + 0x64100000660, + 0x66e00000675, + 0x679000006d4, + 0x6d5000006dd, + 0x6df000006e9, + 0x6ea000006f0, + 0x6fa00000700, + 0x7100000074b, + 0x74d000007b2, + 0x7c0000007f6, + 0x7fd000007fe, + 0x8000000082e, + 0x8400000085c, + 0x8600000086b, + 0x8a0000008b5, + 0x8b6000008c8, + 0x8d3000008e2, + 0x8e300000958, + 0x96000000964, + 0x96600000970, + 0x97100000984, + 0x9850000098d, + 0x98f00000991, + 0x993000009a9, + 0x9aa000009b1, + 0x9b2000009b3, + 0x9b6000009ba, + 0x9bc000009c5, + 0x9c7000009c9, + 0x9cb000009cf, + 0x9d7000009d8, + 0x9e0000009e4, + 0x9e6000009f2, + 0x9fc000009fd, + 0x9fe000009ff, + 0xa0100000a04, + 0xa0500000a0b, + 0xa0f00000a11, + 0xa1300000a29, + 0xa2a00000a31, + 0xa3200000a33, + 0xa3500000a36, + 0xa3800000a3a, + 0xa3c00000a3d, + 0xa3e00000a43, + 0xa4700000a49, + 0xa4b00000a4e, + 0xa5100000a52, + 0xa5c00000a5d, + 0xa6600000a76, + 0xa8100000a84, + 0xa8500000a8e, + 0xa8f00000a92, + 0xa9300000aa9, + 0xaaa00000ab1, + 0xab200000ab4, + 0xab500000aba, + 0xabc00000ac6, + 0xac700000aca, + 0xacb00000ace, + 0xad000000ad1, + 0xae000000ae4, + 0xae600000af0, + 0xaf900000b00, + 0xb0100000b04, + 0xb0500000b0d, + 0xb0f00000b11, + 0xb1300000b29, + 0xb2a00000b31, + 0xb3200000b34, + 0xb3500000b3a, + 0xb3c00000b45, + 0xb4700000b49, + 0xb4b00000b4e, + 0xb5500000b58, + 0xb5f00000b64, + 0xb6600000b70, + 0xb7100000b72, + 0xb8200000b84, + 0xb8500000b8b, + 0xb8e00000b91, + 0xb9200000b96, + 0xb9900000b9b, + 0xb9c00000b9d, + 0xb9e00000ba0, + 0xba300000ba5, + 0xba800000bab, + 0xbae00000bba, + 0xbbe00000bc3, + 0xbc600000bc9, + 0xbca00000bce, + 0xbd000000bd1, + 0xbd700000bd8, + 0xbe600000bf0, + 0xc0000000c0d, + 0xc0e00000c11, + 0xc1200000c29, + 0xc2a00000c3a, + 0xc3d00000c45, + 0xc4600000c49, + 0xc4a00000c4e, + 0xc5500000c57, + 0xc5800000c5b, + 0xc6000000c64, + 0xc6600000c70, + 0xc8000000c84, + 0xc8500000c8d, + 0xc8e00000c91, + 0xc9200000ca9, + 0xcaa00000cb4, + 0xcb500000cba, + 0xcbc00000cc5, + 0xcc600000cc9, + 0xcca00000cce, + 0xcd500000cd7, + 0xcde00000cdf, + 0xce000000ce4, + 0xce600000cf0, + 0xcf100000cf3, + 0xd0000000d0d, + 0xd0e00000d11, + 0xd1200000d45, + 0xd4600000d49, + 0xd4a00000d4f, + 0xd5400000d58, + 0xd5f00000d64, + 0xd6600000d70, + 0xd7a00000d80, + 0xd8100000d84, + 0xd8500000d97, + 0xd9a00000db2, + 0xdb300000dbc, + 0xdbd00000dbe, + 0xdc000000dc7, + 0xdca00000dcb, + 0xdcf00000dd5, + 0xdd600000dd7, + 0xdd800000de0, + 0xde600000df0, + 0xdf200000df4, + 0xe0100000e33, + 0xe3400000e3b, + 0xe4000000e4f, + 0xe5000000e5a, + 0xe8100000e83, + 0xe8400000e85, + 0xe8600000e8b, + 0xe8c00000ea4, + 0xea500000ea6, + 0xea700000eb3, + 0xeb400000ebe, + 0xec000000ec5, + 0xec600000ec7, + 0xec800000ece, + 0xed000000eda, + 0xede00000ee0, + 0xf0000000f01, + 0xf0b00000f0c, + 0xf1800000f1a, + 0xf2000000f2a, + 0xf3500000f36, + 0xf3700000f38, + 0xf3900000f3a, + 0xf3e00000f43, + 0xf4400000f48, + 0xf4900000f4d, + 0xf4e00000f52, + 0xf5300000f57, + 0xf5800000f5c, + 0xf5d00000f69, + 0xf6a00000f6d, + 0xf7100000f73, + 0xf7400000f75, + 0xf7a00000f81, + 0xf8200000f85, + 0xf8600000f93, + 0xf9400000f98, + 0xf9900000f9d, + 0xf9e00000fa2, + 0xfa300000fa7, + 0xfa800000fac, + 0xfad00000fb9, + 0xfba00000fbd, + 0xfc600000fc7, + 0x10000000104a, + 0x10500000109e, + 0x10d0000010fb, + 0x10fd00001100, + 0x120000001249, + 0x124a0000124e, + 0x125000001257, + 0x125800001259, + 0x125a0000125e, + 0x126000001289, + 0x128a0000128e, + 0x1290000012b1, + 0x12b2000012b6, + 0x12b8000012bf, + 0x12c0000012c1, + 0x12c2000012c6, + 0x12c8000012d7, + 0x12d800001311, + 0x131200001316, + 0x13180000135b, + 0x135d00001360, + 0x138000001390, + 0x13a0000013f6, + 0x14010000166d, + 0x166f00001680, + 0x16810000169b, + 0x16a0000016eb, + 0x16f1000016f9, + 0x17000000170d, + 0x170e00001715, + 0x172000001735, + 0x174000001754, + 0x17600000176d, + 0x176e00001771, + 0x177200001774, + 0x1780000017b4, + 0x17b6000017d4, + 0x17d7000017d8, + 0x17dc000017de, + 0x17e0000017ea, + 0x18100000181a, + 0x182000001879, + 0x1880000018ab, + 0x18b0000018f6, + 0x19000000191f, + 0x19200000192c, + 0x19300000193c, + 0x19460000196e, + 0x197000001975, + 0x1980000019ac, + 0x19b0000019ca, + 0x19d0000019da, + 0x1a0000001a1c, + 0x1a2000001a5f, + 0x1a6000001a7d, + 0x1a7f00001a8a, + 0x1a9000001a9a, + 0x1aa700001aa8, + 0x1ab000001abe, + 0x1abf00001ac1, + 0x1b0000001b4c, + 0x1b5000001b5a, + 0x1b6b00001b74, + 0x1b8000001bf4, + 0x1c0000001c38, + 0x1c4000001c4a, + 0x1c4d00001c7e, + 0x1cd000001cd3, + 0x1cd400001cfb, + 0x1d0000001d2c, + 0x1d2f00001d30, + 0x1d3b00001d3c, + 0x1d4e00001d4f, + 0x1d6b00001d78, + 0x1d7900001d9b, + 0x1dc000001dfa, + 0x1dfb00001e00, + 0x1e0100001e02, + 0x1e0300001e04, + 0x1e0500001e06, + 0x1e0700001e08, + 0x1e0900001e0a, + 0x1e0b00001e0c, + 0x1e0d00001e0e, + 0x1e0f00001e10, + 0x1e1100001e12, + 0x1e1300001e14, + 0x1e1500001e16, + 0x1e1700001e18, + 0x1e1900001e1a, + 0x1e1b00001e1c, + 0x1e1d00001e1e, + 0x1e1f00001e20, + 0x1e2100001e22, + 0x1e2300001e24, + 0x1e2500001e26, + 0x1e2700001e28, + 0x1e2900001e2a, + 0x1e2b00001e2c, + 0x1e2d00001e2e, + 0x1e2f00001e30, + 0x1e3100001e32, + 0x1e3300001e34, + 0x1e3500001e36, + 0x1e3700001e38, + 0x1e3900001e3a, + 0x1e3b00001e3c, + 0x1e3d00001e3e, + 0x1e3f00001e40, + 0x1e4100001e42, + 0x1e4300001e44, + 0x1e4500001e46, + 0x1e4700001e48, + 0x1e4900001e4a, + 0x1e4b00001e4c, + 0x1e4d00001e4e, + 0x1e4f00001e50, + 0x1e5100001e52, + 0x1e5300001e54, + 0x1e5500001e56, + 0x1e5700001e58, + 0x1e5900001e5a, + 0x1e5b00001e5c, + 0x1e5d00001e5e, + 0x1e5f00001e60, + 0x1e6100001e62, + 0x1e6300001e64, + 0x1e6500001e66, + 0x1e6700001e68, + 0x1e6900001e6a, + 0x1e6b00001e6c, + 0x1e6d00001e6e, + 0x1e6f00001e70, + 0x1e7100001e72, + 0x1e7300001e74, + 0x1e7500001e76, + 0x1e7700001e78, + 0x1e7900001e7a, + 0x1e7b00001e7c, + 0x1e7d00001e7e, + 0x1e7f00001e80, + 0x1e8100001e82, + 0x1e8300001e84, + 0x1e8500001e86, + 0x1e8700001e88, + 0x1e8900001e8a, + 0x1e8b00001e8c, + 0x1e8d00001e8e, + 0x1e8f00001e90, + 0x1e9100001e92, + 0x1e9300001e94, + 0x1e9500001e9a, + 0x1e9c00001e9e, + 0x1e9f00001ea0, + 0x1ea100001ea2, + 0x1ea300001ea4, + 0x1ea500001ea6, + 0x1ea700001ea8, + 0x1ea900001eaa, + 0x1eab00001eac, + 0x1ead00001eae, + 0x1eaf00001eb0, + 0x1eb100001eb2, + 0x1eb300001eb4, + 0x1eb500001eb6, + 0x1eb700001eb8, + 0x1eb900001eba, + 0x1ebb00001ebc, + 0x1ebd00001ebe, + 0x1ebf00001ec0, + 0x1ec100001ec2, + 0x1ec300001ec4, + 0x1ec500001ec6, + 0x1ec700001ec8, + 0x1ec900001eca, + 0x1ecb00001ecc, + 0x1ecd00001ece, + 0x1ecf00001ed0, + 0x1ed100001ed2, + 0x1ed300001ed4, + 0x1ed500001ed6, + 0x1ed700001ed8, + 0x1ed900001eda, + 0x1edb00001edc, + 0x1edd00001ede, + 0x1edf00001ee0, + 0x1ee100001ee2, + 0x1ee300001ee4, + 0x1ee500001ee6, + 0x1ee700001ee8, + 0x1ee900001eea, + 0x1eeb00001eec, + 0x1eed00001eee, + 0x1eef00001ef0, + 0x1ef100001ef2, + 0x1ef300001ef4, + 0x1ef500001ef6, + 0x1ef700001ef8, + 0x1ef900001efa, + 0x1efb00001efc, + 0x1efd00001efe, + 0x1eff00001f08, + 0x1f1000001f16, + 0x1f2000001f28, + 0x1f3000001f38, + 0x1f4000001f46, + 0x1f5000001f58, + 0x1f6000001f68, + 0x1f7000001f71, + 0x1f7200001f73, + 0x1f7400001f75, + 0x1f7600001f77, + 0x1f7800001f79, + 0x1f7a00001f7b, + 0x1f7c00001f7d, + 0x1fb000001fb2, + 0x1fb600001fb7, + 0x1fc600001fc7, + 0x1fd000001fd3, + 0x1fd600001fd8, + 0x1fe000001fe3, + 0x1fe400001fe8, + 0x1ff600001ff7, + 0x214e0000214f, + 0x218400002185, + 0x2c3000002c5f, + 0x2c6100002c62, + 0x2c6500002c67, + 0x2c6800002c69, + 0x2c6a00002c6b, + 0x2c6c00002c6d, + 0x2c7100002c72, + 0x2c7300002c75, + 0x2c7600002c7c, + 0x2c8100002c82, + 0x2c8300002c84, + 0x2c8500002c86, + 0x2c8700002c88, + 0x2c8900002c8a, + 0x2c8b00002c8c, + 0x2c8d00002c8e, + 0x2c8f00002c90, + 0x2c9100002c92, + 0x2c9300002c94, + 0x2c9500002c96, + 0x2c9700002c98, + 0x2c9900002c9a, + 0x2c9b00002c9c, + 0x2c9d00002c9e, + 0x2c9f00002ca0, + 0x2ca100002ca2, + 0x2ca300002ca4, + 0x2ca500002ca6, + 0x2ca700002ca8, + 0x2ca900002caa, + 0x2cab00002cac, + 0x2cad00002cae, + 0x2caf00002cb0, + 0x2cb100002cb2, + 0x2cb300002cb4, + 0x2cb500002cb6, + 0x2cb700002cb8, + 0x2cb900002cba, + 0x2cbb00002cbc, + 0x2cbd00002cbe, + 0x2cbf00002cc0, + 0x2cc100002cc2, + 0x2cc300002cc4, + 0x2cc500002cc6, + 0x2cc700002cc8, + 0x2cc900002cca, + 0x2ccb00002ccc, + 0x2ccd00002cce, + 0x2ccf00002cd0, + 0x2cd100002cd2, + 0x2cd300002cd4, + 0x2cd500002cd6, + 0x2cd700002cd8, + 0x2cd900002cda, + 0x2cdb00002cdc, + 0x2cdd00002cde, + 0x2cdf00002ce0, + 0x2ce100002ce2, + 0x2ce300002ce5, + 0x2cec00002ced, + 0x2cee00002cf2, + 0x2cf300002cf4, + 0x2d0000002d26, + 0x2d2700002d28, + 0x2d2d00002d2e, + 0x2d3000002d68, + 0x2d7f00002d97, + 0x2da000002da7, + 0x2da800002daf, + 0x2db000002db7, + 0x2db800002dbf, + 0x2dc000002dc7, + 0x2dc800002dcf, + 0x2dd000002dd7, + 0x2dd800002ddf, + 0x2de000002e00, + 0x2e2f00002e30, + 0x300500003008, + 0x302a0000302e, + 0x303c0000303d, + 0x304100003097, + 0x30990000309b, + 0x309d0000309f, + 0x30a1000030fb, + 0x30fc000030ff, + 0x310500003130, + 0x31a0000031c0, + 0x31f000003200, + 0x340000004dc0, + 0x4e0000009ffd, + 0xa0000000a48d, + 0xa4d00000a4fe, + 0xa5000000a60d, + 0xa6100000a62c, + 0xa6410000a642, + 0xa6430000a644, + 0xa6450000a646, + 0xa6470000a648, + 0xa6490000a64a, + 0xa64b0000a64c, + 0xa64d0000a64e, + 0xa64f0000a650, + 0xa6510000a652, + 0xa6530000a654, + 0xa6550000a656, + 0xa6570000a658, + 0xa6590000a65a, + 0xa65b0000a65c, + 0xa65d0000a65e, + 0xa65f0000a660, + 0xa6610000a662, + 0xa6630000a664, + 0xa6650000a666, + 0xa6670000a668, + 0xa6690000a66a, + 0xa66b0000a66c, + 0xa66d0000a670, + 0xa6740000a67e, + 0xa67f0000a680, + 0xa6810000a682, + 0xa6830000a684, + 0xa6850000a686, + 0xa6870000a688, + 0xa6890000a68a, + 0xa68b0000a68c, + 0xa68d0000a68e, + 0xa68f0000a690, + 0xa6910000a692, + 0xa6930000a694, + 0xa6950000a696, + 0xa6970000a698, + 0xa6990000a69a, + 0xa69b0000a69c, + 0xa69e0000a6e6, + 0xa6f00000a6f2, + 0xa7170000a720, + 0xa7230000a724, + 0xa7250000a726, + 0xa7270000a728, + 0xa7290000a72a, + 0xa72b0000a72c, + 0xa72d0000a72e, + 0xa72f0000a732, + 0xa7330000a734, + 0xa7350000a736, + 0xa7370000a738, + 0xa7390000a73a, + 0xa73b0000a73c, + 0xa73d0000a73e, + 0xa73f0000a740, + 0xa7410000a742, + 0xa7430000a744, + 0xa7450000a746, + 0xa7470000a748, + 0xa7490000a74a, + 0xa74b0000a74c, + 0xa74d0000a74e, + 0xa74f0000a750, + 0xa7510000a752, + 0xa7530000a754, + 0xa7550000a756, + 0xa7570000a758, + 0xa7590000a75a, + 0xa75b0000a75c, + 0xa75d0000a75e, + 0xa75f0000a760, + 0xa7610000a762, + 0xa7630000a764, + 0xa7650000a766, + 0xa7670000a768, + 0xa7690000a76a, + 0xa76b0000a76c, + 0xa76d0000a76e, + 0xa76f0000a770, + 0xa7710000a779, + 0xa77a0000a77b, + 0xa77c0000a77d, + 0xa77f0000a780, + 0xa7810000a782, + 0xa7830000a784, + 0xa7850000a786, + 0xa7870000a789, + 0xa78c0000a78d, + 0xa78e0000a790, + 0xa7910000a792, + 0xa7930000a796, + 0xa7970000a798, + 0xa7990000a79a, + 0xa79b0000a79c, + 0xa79d0000a79e, + 0xa79f0000a7a0, + 0xa7a10000a7a2, + 0xa7a30000a7a4, + 0xa7a50000a7a6, + 0xa7a70000a7a8, + 0xa7a90000a7aa, + 0xa7af0000a7b0, + 0xa7b50000a7b6, + 0xa7b70000a7b8, + 0xa7b90000a7ba, + 0xa7bb0000a7bc, + 0xa7bd0000a7be, + 0xa7bf0000a7c0, + 0xa7c30000a7c4, + 0xa7c80000a7c9, + 0xa7ca0000a7cb, + 0xa7f60000a7f8, + 0xa7fa0000a828, + 0xa82c0000a82d, + 0xa8400000a874, + 0xa8800000a8c6, + 0xa8d00000a8da, + 0xa8e00000a8f8, + 0xa8fb0000a8fc, + 0xa8fd0000a92e, + 0xa9300000a954, + 0xa9800000a9c1, + 0xa9cf0000a9da, + 0xa9e00000a9ff, + 0xaa000000aa37, + 0xaa400000aa4e, + 0xaa500000aa5a, + 0xaa600000aa77, + 0xaa7a0000aac3, + 0xaadb0000aade, + 0xaae00000aaf0, + 0xaaf20000aaf7, + 0xab010000ab07, + 0xab090000ab0f, + 0xab110000ab17, + 0xab200000ab27, + 0xab280000ab2f, + 0xab300000ab5b, + 0xab600000ab6a, + 0xabc00000abeb, + 0xabec0000abee, + 0xabf00000abfa, + 0xac000000d7a4, + 0xfa0e0000fa10, + 0xfa110000fa12, + 0xfa130000fa15, + 0xfa1f0000fa20, + 0xfa210000fa22, + 0xfa230000fa25, + 0xfa270000fa2a, + 0xfb1e0000fb1f, + 0xfe200000fe30, + 0xfe730000fe74, + 0x100000001000c, + 0x1000d00010027, + 0x100280001003b, + 0x1003c0001003e, + 0x1003f0001004e, + 0x100500001005e, + 0x10080000100fb, + 0x101fd000101fe, + 0x102800001029d, + 0x102a0000102d1, + 0x102e0000102e1, + 0x1030000010320, + 0x1032d00010341, + 0x103420001034a, + 0x103500001037b, + 0x103800001039e, + 0x103a0000103c4, + 0x103c8000103d0, + 0x104280001049e, + 0x104a0000104aa, + 0x104d8000104fc, + 0x1050000010528, + 0x1053000010564, + 0x1060000010737, + 0x1074000010756, + 0x1076000010768, + 0x1080000010806, + 0x1080800010809, + 0x1080a00010836, + 0x1083700010839, + 0x1083c0001083d, + 0x1083f00010856, + 0x1086000010877, + 0x108800001089f, + 0x108e0000108f3, + 0x108f4000108f6, + 0x1090000010916, + 0x109200001093a, + 0x10980000109b8, + 0x109be000109c0, + 0x10a0000010a04, + 0x10a0500010a07, + 0x10a0c00010a14, + 0x10a1500010a18, + 0x10a1900010a36, + 0x10a3800010a3b, + 0x10a3f00010a40, + 0x10a6000010a7d, + 0x10a8000010a9d, + 0x10ac000010ac8, + 0x10ac900010ae7, + 0x10b0000010b36, + 0x10b4000010b56, + 0x10b6000010b73, + 0x10b8000010b92, + 0x10c0000010c49, + 0x10cc000010cf3, + 0x10d0000010d28, + 0x10d3000010d3a, + 0x10e8000010eaa, + 0x10eab00010ead, + 0x10eb000010eb2, + 0x10f0000010f1d, + 0x10f2700010f28, + 0x10f3000010f51, + 0x10fb000010fc5, + 0x10fe000010ff7, + 0x1100000011047, + 0x1106600011070, + 0x1107f000110bb, + 0x110d0000110e9, + 0x110f0000110fa, + 0x1110000011135, + 0x1113600011140, + 0x1114400011148, + 0x1115000011174, + 0x1117600011177, + 0x11180000111c5, + 0x111c9000111cd, + 0x111ce000111db, + 0x111dc000111dd, + 0x1120000011212, + 0x1121300011238, + 0x1123e0001123f, + 0x1128000011287, + 0x1128800011289, + 0x1128a0001128e, + 0x1128f0001129e, + 0x1129f000112a9, + 0x112b0000112eb, + 0x112f0000112fa, + 0x1130000011304, + 0x113050001130d, + 0x1130f00011311, + 0x1131300011329, + 0x1132a00011331, + 0x1133200011334, + 0x113350001133a, + 0x1133b00011345, + 0x1134700011349, + 0x1134b0001134e, + 0x1135000011351, + 0x1135700011358, + 0x1135d00011364, + 0x113660001136d, + 0x1137000011375, + 0x114000001144b, + 0x114500001145a, + 0x1145e00011462, + 0x11480000114c6, + 0x114c7000114c8, + 0x114d0000114da, + 0x11580000115b6, + 0x115b8000115c1, + 0x115d8000115de, + 0x1160000011641, + 0x1164400011645, + 0x116500001165a, + 0x11680000116b9, + 0x116c0000116ca, + 0x117000001171b, + 0x1171d0001172c, + 0x117300001173a, + 0x118000001183b, + 0x118c0000118ea, + 0x118ff00011907, + 0x119090001190a, + 0x1190c00011914, + 0x1191500011917, + 0x1191800011936, + 0x1193700011939, + 0x1193b00011944, + 0x119500001195a, + 0x119a0000119a8, + 0x119aa000119d8, + 0x119da000119e2, + 0x119e3000119e5, + 0x11a0000011a3f, + 0x11a4700011a48, + 0x11a5000011a9a, + 0x11a9d00011a9e, + 0x11ac000011af9, + 0x11c0000011c09, + 0x11c0a00011c37, + 0x11c3800011c41, + 0x11c5000011c5a, + 0x11c7200011c90, + 0x11c9200011ca8, + 0x11ca900011cb7, + 0x11d0000011d07, + 0x11d0800011d0a, + 0x11d0b00011d37, + 0x11d3a00011d3b, + 0x11d3c00011d3e, + 0x11d3f00011d48, + 0x11d5000011d5a, + 0x11d6000011d66, + 0x11d6700011d69, + 0x11d6a00011d8f, + 0x11d9000011d92, + 0x11d9300011d99, + 0x11da000011daa, + 0x11ee000011ef7, + 0x11fb000011fb1, + 0x120000001239a, + 0x1248000012544, + 0x130000001342f, + 0x1440000014647, + 0x1680000016a39, + 0x16a4000016a5f, + 0x16a6000016a6a, + 0x16ad000016aee, + 0x16af000016af5, + 0x16b0000016b37, + 0x16b4000016b44, + 0x16b5000016b5a, + 0x16b6300016b78, + 0x16b7d00016b90, + 0x16e6000016e80, + 0x16f0000016f4b, + 0x16f4f00016f88, + 0x16f8f00016fa0, + 0x16fe000016fe2, + 0x16fe300016fe5, + 0x16ff000016ff2, + 0x17000000187f8, + 0x1880000018cd6, + 0x18d0000018d09, + 0x1b0000001b11f, + 0x1b1500001b153, + 0x1b1640001b168, + 0x1b1700001b2fc, + 0x1bc000001bc6b, + 0x1bc700001bc7d, + 0x1bc800001bc89, + 0x1bc900001bc9a, + 0x1bc9d0001bc9f, + 0x1da000001da37, + 0x1da3b0001da6d, + 0x1da750001da76, + 0x1da840001da85, + 0x1da9b0001daa0, + 0x1daa10001dab0, + 0x1e0000001e007, + 0x1e0080001e019, + 0x1e01b0001e022, + 0x1e0230001e025, + 0x1e0260001e02b, + 0x1e1000001e12d, + 0x1e1300001e13e, + 0x1e1400001e14a, + 0x1e14e0001e14f, + 0x1e2c00001e2fa, + 0x1e8000001e8c5, + 0x1e8d00001e8d7, + 0x1e9220001e94c, + 0x1e9500001e95a, + 0x1fbf00001fbfa, + 0x200000002a6de, + 0x2a7000002b735, + 0x2b7400002b81e, + 0x2b8200002cea2, + 0x2ceb00002ebe1, + 0x300000003134b, + ), + 'CONTEXTJ': ( + 0x200c0000200e, + ), + 'CONTEXTO': ( + 0xb7000000b8, + 0x37500000376, + 0x5f3000005f5, + 0x6600000066a, + 0x6f0000006fa, + 0x30fb000030fc, + ), +} diff --git a/venv/lib/python3.8/site-packages/idna/intranges.py b/venv/lib/python3.8/site-packages/idna/intranges.py new file mode 100644 index 0000000..ee364a9 --- /dev/null +++ b/venv/lib/python3.8/site-packages/idna/intranges.py @@ -0,0 +1,58 @@ +""" +Given a list of integers, made up of (hopefully) a small number of long runs +of consecutive integers, compute a representation of the form +((start1, end1), (start2, end2) ...). Then answer the question "was x present +in the original list?" in time O(log(# runs)). +""" + +import bisect +from typing import List, Tuple + +def intranges_from_list(list_): + # type: (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. + + Ranges are encoded as single integers (start << 32 | end), not as tuples. + """ + + sorted_list = sorted(list_) + ranges = [] + last_write = -1 + for i in range(len(sorted_list)): + if i+1 < len(sorted_list): + if sorted_list[i] == sorted_list[i+1]-1: + continue + current_range = sorted_list[last_write+1:i+1] + ranges.append(_encode_range(current_range[0], current_range[-1] + 1)) + last_write = i + + return tuple(ranges) + +def _encode_range(start, end): + # type: (int, int) -> int + return (start << 32) | end + +def _decode_range(r): + # type: (int) -> Tuple[int, int] + return (r >> 32), (r & ((1 << 32) - 1)) + + +def intranges_contain(int_, ranges): + # type: (int, 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_) + # we could be immediately ahead of a tuple (start, end) + # with start < int_ <= end + if pos > 0: + left, right = _decode_range(ranges[pos-1]) + if left <= int_ < right: + return True + # or we could be immediately behind a tuple (int_, end) + if pos < len(ranges): + left, _ = _decode_range(ranges[pos]) + if left == int_: + return True + return False diff --git a/venv/lib/python3.8/site-packages/idna/package_data.py b/venv/lib/python3.8/site-packages/idna/package_data.py new file mode 100644 index 0000000..e096d1d --- /dev/null +++ b/venv/lib/python3.8/site-packages/idna/package_data.py @@ -0,0 +1,2 @@ +__version__ = '3.2' + diff --git a/venv/lib/python3.8/site-packages/idna/py.typed b/venv/lib/python3.8/site-packages/idna/py.typed new file mode 100644 index 0000000..e69de29 diff --git a/venv/lib/python3.8/site-packages/idna/uts46data.py b/venv/lib/python3.8/site-packages/idna/uts46data.py new file mode 100644 index 0000000..f382ce3 --- /dev/null +++ b/venv/lib/python3.8/site-packages/idna/uts46data.py @@ -0,0 +1,8438 @@ +# This file is automatically generated by tools/idna-data + +from typing import List, Tuple, Union + +"""IDNA Mapping Table from UTS46.""" + + +__version__ = '13.0.0' +def _seg_0(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0x0, '3'), + (0x1, '3'), + (0x2, '3'), + (0x3, '3'), + (0x4, '3'), + (0x5, '3'), + (0x6, '3'), + (0x7, '3'), + (0x8, '3'), + (0x9, '3'), + (0xA, '3'), + (0xB, '3'), + (0xC, '3'), + (0xD, '3'), + (0xE, '3'), + (0xF, '3'), + (0x10, '3'), + (0x11, '3'), + (0x12, '3'), + (0x13, '3'), + (0x14, '3'), + (0x15, '3'), + (0x16, '3'), + (0x17, '3'), + (0x18, '3'), + (0x19, '3'), + (0x1A, '3'), + (0x1B, '3'), + (0x1C, '3'), + (0x1D, '3'), + (0x1E, '3'), + (0x1F, '3'), + (0x20, '3'), + (0x21, '3'), + (0x22, '3'), + (0x23, '3'), + (0x24, '3'), + (0x25, '3'), + (0x26, '3'), + (0x27, '3'), + (0x28, '3'), + (0x29, '3'), + (0x2A, '3'), + (0x2B, '3'), + (0x2C, '3'), + (0x2D, 'V'), + (0x2E, 'V'), + (0x2F, '3'), + (0x30, 'V'), + (0x31, 'V'), + (0x32, 'V'), + (0x33, 'V'), + (0x34, 'V'), + (0x35, 'V'), + (0x36, 'V'), + (0x37, 'V'), + (0x38, 'V'), + (0x39, 'V'), + (0x3A, '3'), + (0x3B, '3'), + (0x3C, '3'), + (0x3D, '3'), + (0x3E, '3'), + (0x3F, '3'), + (0x40, '3'), + (0x41, 'M', 'a'), + (0x42, 'M', 'b'), + (0x43, 'M', 'c'), + (0x44, 'M', 'd'), + (0x45, 'M', 'e'), + (0x46, 'M', 'f'), + (0x47, 'M', 'g'), + (0x48, 'M', 'h'), + (0x49, 'M', 'i'), + (0x4A, 'M', 'j'), + (0x4B, 'M', 'k'), + (0x4C, 'M', 'l'), + (0x4D, 'M', 'm'), + (0x4E, 'M', 'n'), + (0x4F, 'M', 'o'), + (0x50, 'M', 'p'), + (0x51, 'M', 'q'), + (0x52, 'M', 'r'), + (0x53, 'M', 's'), + (0x54, 'M', 't'), + (0x55, 'M', 'u'), + (0x56, 'M', 'v'), + (0x57, 'M', 'w'), + (0x58, 'M', 'x'), + (0x59, 'M', 'y'), + (0x5A, 'M', 'z'), + (0x5B, '3'), + (0x5C, '3'), + (0x5D, '3'), + (0x5E, '3'), + (0x5F, '3'), + (0x60, '3'), + (0x61, 'V'), + (0x62, 'V'), + (0x63, 'V'), + ] + +def _seg_1(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0x64, 'V'), + (0x65, 'V'), + (0x66, 'V'), + (0x67, 'V'), + (0x68, 'V'), + (0x69, 'V'), + (0x6A, 'V'), + (0x6B, 'V'), + (0x6C, 'V'), + (0x6D, 'V'), + (0x6E, 'V'), + (0x6F, 'V'), + (0x70, 'V'), + (0x71, 'V'), + (0x72, 'V'), + (0x73, 'V'), + (0x74, 'V'), + (0x75, 'V'), + (0x76, 'V'), + (0x77, 'V'), + (0x78, 'V'), + (0x79, 'V'), + (0x7A, 'V'), + (0x7B, '3'), + (0x7C, '3'), + (0x7D, '3'), + (0x7E, '3'), + (0x7F, '3'), + (0x80, 'X'), + (0x81, 'X'), + (0x82, 'X'), + (0x83, 'X'), + (0x84, 'X'), + (0x85, 'X'), + (0x86, 'X'), + (0x87, 'X'), + (0x88, 'X'), + (0x89, 'X'), + (0x8A, 'X'), + (0x8B, 'X'), + (0x8C, 'X'), + (0x8D, 'X'), + (0x8E, 'X'), + (0x8F, 'X'), + (0x90, 'X'), + (0x91, 'X'), + (0x92, 'X'), + (0x93, 'X'), + (0x94, 'X'), + (0x95, 'X'), + (0x96, 'X'), + (0x97, 'X'), + (0x98, 'X'), + (0x99, 'X'), + (0x9A, 'X'), + (0x9B, 'X'), + (0x9C, 'X'), + (0x9D, 'X'), + (0x9E, 'X'), + (0x9F, 'X'), + (0xA0, '3', ' '), + (0xA1, 'V'), + (0xA2, 'V'), + (0xA3, 'V'), + (0xA4, 'V'), + (0xA5, 'V'), + (0xA6, 'V'), + (0xA7, 'V'), + (0xA8, '3', ' ̈'), + (0xA9, 'V'), + (0xAA, 'M', 'a'), + (0xAB, 'V'), + (0xAC, 'V'), + (0xAD, 'I'), + (0xAE, 'V'), + (0xAF, '3', ' ̄'), + (0xB0, 'V'), + (0xB1, 'V'), + (0xB2, 'M', '2'), + (0xB3, 'M', '3'), + (0xB4, '3', ' ́'), + (0xB5, 'M', 'μ'), + (0xB6, 'V'), + (0xB7, 'V'), + (0xB8, '3', ' ̧'), + (0xB9, 'M', '1'), + (0xBA, 'M', 'o'), + (0xBB, 'V'), + (0xBC, 'M', '1⁄4'), + (0xBD, 'M', '1⁄2'), + (0xBE, 'M', '3⁄4'), + (0xBF, 'V'), + (0xC0, 'M', 'à'), + (0xC1, 'M', 'á'), + (0xC2, 'M', 'â'), + (0xC3, 'M', 'ã'), + (0xC4, 'M', 'ä'), + (0xC5, 'M', 'å'), + (0xC6, 'M', 'æ'), + (0xC7, 'M', 'ç'), + ] + +def _seg_2(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0xC8, 'M', 'è'), + (0xC9, 'M', 'é'), + (0xCA, 'M', 'ê'), + (0xCB, 'M', 'ë'), + (0xCC, 'M', 'ì'), + (0xCD, 'M', 'í'), + (0xCE, 'M', 'î'), + (0xCF, 'M', 'ï'), + (0xD0, 'M', 'ð'), + (0xD1, 'M', 'ñ'), + (0xD2, 'M', 'ò'), + (0xD3, 'M', 'ó'), + (0xD4, 'M', 'ô'), + (0xD5, 'M', 'õ'), + (0xD6, 'M', 'ö'), + (0xD7, 'V'), + (0xD8, 'M', 'ø'), + (0xD9, 'M', 'ù'), + (0xDA, 'M', 'ú'), + (0xDB, 'M', 'û'), + (0xDC, 'M', 'ü'), + (0xDD, 'M', 'ý'), + (0xDE, 'M', 'þ'), + (0xDF, 'D', 'ss'), + (0xE0, 'V'), + (0xE1, 'V'), + (0xE2, 'V'), + (0xE3, 'V'), + (0xE4, 'V'), + (0xE5, 'V'), + (0xE6, 'V'), + (0xE7, 'V'), + (0xE8, 'V'), + (0xE9, 'V'), + (0xEA, 'V'), + (0xEB, 'V'), + (0xEC, 'V'), + (0xED, 'V'), + (0xEE, 'V'), + (0xEF, 'V'), + (0xF0, 'V'), + (0xF1, 'V'), + (0xF2, 'V'), + (0xF3, 'V'), + (0xF4, 'V'), + (0xF5, 'V'), + (0xF6, 'V'), + (0xF7, 'V'), + (0xF8, 'V'), + (0xF9, 'V'), + (0xFA, 'V'), + (0xFB, 'V'), + (0xFC, 'V'), + (0xFD, 'V'), + (0xFE, 'V'), + (0xFF, 'V'), + (0x100, 'M', 'ā'), + (0x101, 'V'), + (0x102, 'M', 'ă'), + (0x103, 'V'), + (0x104, 'M', 'ą'), + (0x105, 'V'), + (0x106, 'M', 'ć'), + (0x107, 'V'), + (0x108, 'M', 'ĉ'), + (0x109, 'V'), + (0x10A, 'M', 'ċ'), + (0x10B, 'V'), + (0x10C, 'M', 'č'), + (0x10D, 'V'), + (0x10E, 'M', 'ď'), + (0x10F, 'V'), + (0x110, 'M', 'đ'), + (0x111, 'V'), + (0x112, 'M', 'ē'), + (0x113, 'V'), + (0x114, 'M', 'ĕ'), + (0x115, 'V'), + (0x116, 'M', 'ė'), + (0x117, 'V'), + (0x118, 'M', 'ę'), + (0x119, 'V'), + (0x11A, 'M', 'ě'), + (0x11B, 'V'), + (0x11C, 'M', 'ĝ'), + (0x11D, 'V'), + (0x11E, 'M', 'ğ'), + (0x11F, 'V'), + (0x120, 'M', 'ġ'), + (0x121, 'V'), + (0x122, 'M', 'ģ'), + (0x123, 'V'), + (0x124, 'M', 'ĥ'), + (0x125, 'V'), + (0x126, 'M', 'ħ'), + (0x127, 'V'), + (0x128, 'M', 'ĩ'), + (0x129, 'V'), + (0x12A, 'M', 'ī'), + (0x12B, 'V'), + ] + +def _seg_3(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0x12C, 'M', 'ĭ'), + (0x12D, 'V'), + (0x12E, 'M', 'į'), + (0x12F, 'V'), + (0x130, 'M', 'i̇'), + (0x131, 'V'), + (0x132, 'M', 'ij'), + (0x134, 'M', 'ĵ'), + (0x135, 'V'), + (0x136, 'M', 'ķ'), + (0x137, 'V'), + (0x139, 'M', 'ĺ'), + (0x13A, 'V'), + (0x13B, 'M', 'ļ'), + (0x13C, 'V'), + (0x13D, 'M', 'ľ'), + (0x13E, 'V'), + (0x13F, 'M', 'l·'), + (0x141, 'M', 'ł'), + (0x142, 'V'), + (0x143, 'M', 'ń'), + (0x144, 'V'), + (0x145, 'M', 'ņ'), + (0x146, 'V'), + (0x147, 'M', 'ň'), + (0x148, 'V'), + (0x149, 'M', 'ʼn'), + (0x14A, 'M', 'ŋ'), + (0x14B, 'V'), + (0x14C, 'M', 'ō'), + (0x14D, 'V'), + (0x14E, 'M', 'ŏ'), + (0x14F, 'V'), + (0x150, 'M', 'ő'), + (0x151, 'V'), + (0x152, 'M', 'œ'), + (0x153, 'V'), + (0x154, 'M', 'ŕ'), + (0x155, 'V'), + (0x156, 'M', 'ŗ'), + (0x157, 'V'), + (0x158, 'M', 'ř'), + (0x159, 'V'), + (0x15A, 'M', 'ś'), + (0x15B, 'V'), + (0x15C, 'M', 'ŝ'), + (0x15D, 'V'), + (0x15E, 'M', 'ş'), + (0x15F, 'V'), + (0x160, 'M', 'š'), + (0x161, 'V'), + (0x162, 'M', 'ţ'), + (0x163, 'V'), + (0x164, 'M', 'ť'), + (0x165, 'V'), + (0x166, 'M', 'ŧ'), + (0x167, 'V'), + (0x168, 'M', 'ũ'), + (0x169, 'V'), + (0x16A, 'M', 'ū'), + (0x16B, 'V'), + (0x16C, 'M', 'ŭ'), + (0x16D, 'V'), + (0x16E, 'M', 'ů'), + (0x16F, 'V'), + (0x170, 'M', 'ű'), + (0x171, 'V'), + (0x172, 'M', 'ų'), + (0x173, 'V'), + (0x174, 'M', 'ŵ'), + (0x175, 'V'), + (0x176, 'M', 'ŷ'), + (0x177, 'V'), + (0x178, 'M', 'ÿ'), + (0x179, 'M', 'ź'), + (0x17A, 'V'), + (0x17B, 'M', 'ż'), + (0x17C, 'V'), + (0x17D, 'M', 'ž'), + (0x17E, 'V'), + (0x17F, 'M', 's'), + (0x180, 'V'), + (0x181, 'M', 'ɓ'), + (0x182, 'M', 'ƃ'), + (0x183, 'V'), + (0x184, 'M', 'ƅ'), + (0x185, 'V'), + (0x186, 'M', 'ɔ'), + (0x187, 'M', 'ƈ'), + (0x188, 'V'), + (0x189, 'M', 'ɖ'), + (0x18A, 'M', 'ɗ'), + (0x18B, 'M', 'ƌ'), + (0x18C, 'V'), + (0x18E, 'M', 'ǝ'), + (0x18F, 'M', 'ə'), + (0x190, 'M', 'ɛ'), + (0x191, 'M', 'ƒ'), + (0x192, 'V'), + (0x193, 'M', 'ɠ'), + ] + +def _seg_4(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0x194, 'M', 'ɣ'), + (0x195, 'V'), + (0x196, 'M', 'ɩ'), + (0x197, 'M', 'ɨ'), + (0x198, 'M', 'ƙ'), + (0x199, 'V'), + (0x19C, 'M', 'ɯ'), + (0x19D, 'M', 'ɲ'), + (0x19E, 'V'), + (0x19F, 'M', 'ɵ'), + (0x1A0, 'M', 'ơ'), + (0x1A1, 'V'), + (0x1A2, 'M', 'ƣ'), + (0x1A3, 'V'), + (0x1A4, 'M', 'ƥ'), + (0x1A5, 'V'), + (0x1A6, 'M', 'ʀ'), + (0x1A7, 'M', 'ƨ'), + (0x1A8, 'V'), + (0x1A9, 'M', 'ʃ'), + (0x1AA, 'V'), + (0x1AC, 'M', 'ƭ'), + (0x1AD, 'V'), + (0x1AE, 'M', 'ʈ'), + (0x1AF, 'M', 'ư'), + (0x1B0, 'V'), + (0x1B1, 'M', 'ʊ'), + (0x1B2, 'M', 'ʋ'), + (0x1B3, 'M', 'ƴ'), + (0x1B4, 'V'), + (0x1B5, 'M', 'ƶ'), + (0x1B6, 'V'), + (0x1B7, 'M', 'ʒ'), + (0x1B8, 'M', 'ƹ'), + (0x1B9, 'V'), + (0x1BC, 'M', 'ƽ'), + (0x1BD, 'V'), + (0x1C4, 'M', 'dž'), + (0x1C7, 'M', 'lj'), + (0x1CA, 'M', 'nj'), + (0x1CD, 'M', 'ǎ'), + (0x1CE, 'V'), + (0x1CF, 'M', 'ǐ'), + (0x1D0, 'V'), + (0x1D1, 'M', 'ǒ'), + (0x1D2, 'V'), + (0x1D3, 'M', 'ǔ'), + (0x1D4, 'V'), + (0x1D5, 'M', 'ǖ'), + (0x1D6, 'V'), + (0x1D7, 'M', 'ǘ'), + (0x1D8, 'V'), + (0x1D9, 'M', 'ǚ'), + (0x1DA, 'V'), + (0x1DB, 'M', 'ǜ'), + (0x1DC, 'V'), + (0x1DE, 'M', 'ǟ'), + (0x1DF, 'V'), + (0x1E0, 'M', 'ǡ'), + (0x1E1, 'V'), + (0x1E2, 'M', 'ǣ'), + (0x1E3, 'V'), + (0x1E4, 'M', 'ǥ'), + (0x1E5, 'V'), + (0x1E6, 'M', 'ǧ'), + (0x1E7, 'V'), + (0x1E8, 'M', 'ǩ'), + (0x1E9, 'V'), + (0x1EA, 'M', 'ǫ'), + (0x1EB, 'V'), + (0x1EC, 'M', 'ǭ'), + (0x1ED, 'V'), + (0x1EE, 'M', 'ǯ'), + (0x1EF, 'V'), + (0x1F1, 'M', 'dz'), + (0x1F4, 'M', 'ǵ'), + (0x1F5, 'V'), + (0x1F6, 'M', 'ƕ'), + (0x1F7, 'M', 'ƿ'), + (0x1F8, 'M', 'ǹ'), + (0x1F9, 'V'), + (0x1FA, 'M', 'ǻ'), + (0x1FB, 'V'), + (0x1FC, 'M', 'ǽ'), + (0x1FD, 'V'), + (0x1FE, 'M', 'ǿ'), + (0x1FF, 'V'), + (0x200, 'M', 'ȁ'), + (0x201, 'V'), + (0x202, 'M', 'ȃ'), + (0x203, 'V'), + (0x204, 'M', 'ȅ'), + (0x205, 'V'), + (0x206, 'M', 'ȇ'), + (0x207, 'V'), + (0x208, 'M', 'ȉ'), + (0x209, 'V'), + (0x20A, 'M', 'ȋ'), + (0x20B, 'V'), + (0x20C, 'M', 'ȍ'), + ] + +def _seg_5(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0x20D, 'V'), + (0x20E, 'M', 'ȏ'), + (0x20F, 'V'), + (0x210, 'M', 'ȑ'), + (0x211, 'V'), + (0x212, 'M', 'ȓ'), + (0x213, 'V'), + (0x214, 'M', 'ȕ'), + (0x215, 'V'), + (0x216, 'M', 'ȗ'), + (0x217, 'V'), + (0x218, 'M', 'ș'), + (0x219, 'V'), + (0x21A, 'M', 'ț'), + (0x21B, 'V'), + (0x21C, 'M', 'ȝ'), + (0x21D, 'V'), + (0x21E, 'M', 'ȟ'), + (0x21F, 'V'), + (0x220, 'M', 'ƞ'), + (0x221, 'V'), + (0x222, 'M', 'ȣ'), + (0x223, 'V'), + (0x224, 'M', 'ȥ'), + (0x225, 'V'), + (0x226, 'M', 'ȧ'), + (0x227, 'V'), + (0x228, 'M', 'ȩ'), + (0x229, 'V'), + (0x22A, 'M', 'ȫ'), + (0x22B, 'V'), + (0x22C, 'M', 'ȭ'), + (0x22D, 'V'), + (0x22E, 'M', 'ȯ'), + (0x22F, 'V'), + (0x230, 'M', 'ȱ'), + (0x231, 'V'), + (0x232, 'M', 'ȳ'), + (0x233, 'V'), + (0x23A, 'M', 'ⱥ'), + (0x23B, 'M', 'ȼ'), + (0x23C, 'V'), + (0x23D, 'M', 'ƚ'), + (0x23E, 'M', 'ⱦ'), + (0x23F, 'V'), + (0x241, 'M', 'ɂ'), + (0x242, 'V'), + (0x243, 'M', 'ƀ'), + (0x244, 'M', 'ʉ'), + (0x245, 'M', 'ʌ'), + (0x246, 'M', 'ɇ'), + (0x247, 'V'), + (0x248, 'M', 'ɉ'), + (0x249, 'V'), + (0x24A, 'M', 'ɋ'), + (0x24B, 'V'), + (0x24C, 'M', 'ɍ'), + (0x24D, 'V'), + (0x24E, 'M', 'ɏ'), + (0x24F, 'V'), + (0x2B0, 'M', 'h'), + (0x2B1, 'M', 'ɦ'), + (0x2B2, 'M', 'j'), + (0x2B3, 'M', 'r'), + (0x2B4, 'M', 'ɹ'), + (0x2B5, 'M', 'ɻ'), + (0x2B6, 'M', 'ʁ'), + (0x2B7, 'M', 'w'), + (0x2B8, 'M', 'y'), + (0x2B9, 'V'), + (0x2D8, '3', ' ̆'), + (0x2D9, '3', ' ̇'), + (0x2DA, '3', ' ̊'), + (0x2DB, '3', ' ̨'), + (0x2DC, '3', ' ̃'), + (0x2DD, '3', ' ̋'), + (0x2DE, 'V'), + (0x2E0, 'M', 'ɣ'), + (0x2E1, 'M', 'l'), + (0x2E2, 'M', 's'), + (0x2E3, 'M', 'x'), + (0x2E4, 'M', 'ʕ'), + (0x2E5, 'V'), + (0x340, 'M', '̀'), + (0x341, 'M', '́'), + (0x342, 'V'), + (0x343, 'M', '̓'), + (0x344, 'M', '̈́'), + (0x345, 'M', 'ι'), + (0x346, 'V'), + (0x34F, 'I'), + (0x350, 'V'), + (0x370, 'M', 'ͱ'), + (0x371, 'V'), + (0x372, 'M', 'ͳ'), + (0x373, 'V'), + (0x374, 'M', 'ʹ'), + (0x375, 'V'), + (0x376, 'M', 'ͷ'), + (0x377, 'V'), + ] + +def _seg_6(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0x378, 'X'), + (0x37A, '3', ' ι'), + (0x37B, 'V'), + (0x37E, '3', ';'), + (0x37F, 'M', 'ϳ'), + (0x380, 'X'), + (0x384, '3', ' ́'), + (0x385, '3', ' ̈́'), + (0x386, 'M', 'ά'), + (0x387, 'M', '·'), + (0x388, 'M', 'έ'), + (0x389, 'M', 'ή'), + (0x38A, 'M', 'ί'), + (0x38B, 'X'), + (0x38C, 'M', 'ό'), + (0x38D, 'X'), + (0x38E, 'M', 'ύ'), + (0x38F, 'M', 'ώ'), + (0x390, 'V'), + (0x391, 'M', 'α'), + (0x392, 'M', 'β'), + (0x393, 'M', 'γ'), + (0x394, 'M', 'δ'), + (0x395, 'M', 'ε'), + (0x396, 'M', 'ζ'), + (0x397, 'M', 'η'), + (0x398, 'M', 'θ'), + (0x399, 'M', 'ι'), + (0x39A, 'M', 'κ'), + (0x39B, 'M', 'λ'), + (0x39C, 'M', 'μ'), + (0x39D, 'M', 'ν'), + (0x39E, 'M', 'ξ'), + (0x39F, 'M', 'ο'), + (0x3A0, 'M', 'π'), + (0x3A1, 'M', 'ρ'), + (0x3A2, 'X'), + (0x3A3, 'M', 'σ'), + (0x3A4, 'M', 'τ'), + (0x3A5, 'M', 'υ'), + (0x3A6, 'M', 'φ'), + (0x3A7, 'M', 'χ'), + (0x3A8, 'M', 'ψ'), + (0x3A9, 'M', 'ω'), + (0x3AA, 'M', 'ϊ'), + (0x3AB, 'M', 'ϋ'), + (0x3AC, 'V'), + (0x3C2, 'D', 'σ'), + (0x3C3, 'V'), + (0x3CF, 'M', 'ϗ'), + (0x3D0, 'M', 'β'), + (0x3D1, 'M', 'θ'), + (0x3D2, 'M', 'υ'), + (0x3D3, 'M', 'ύ'), + (0x3D4, 'M', 'ϋ'), + (0x3D5, 'M', 'φ'), + (0x3D6, 'M', 'π'), + (0x3D7, 'V'), + (0x3D8, 'M', 'ϙ'), + (0x3D9, 'V'), + (0x3DA, 'M', 'ϛ'), + (0x3DB, 'V'), + (0x3DC, 'M', 'ϝ'), + (0x3DD, 'V'), + (0x3DE, 'M', 'ϟ'), + (0x3DF, 'V'), + (0x3E0, 'M', 'ϡ'), + (0x3E1, 'V'), + (0x3E2, 'M', 'ϣ'), + (0x3E3, 'V'), + (0x3E4, 'M', 'ϥ'), + (0x3E5, 'V'), + (0x3E6, 'M', 'ϧ'), + (0x3E7, 'V'), + (0x3E8, 'M', 'ϩ'), + (0x3E9, 'V'), + (0x3EA, 'M', 'ϫ'), + (0x3EB, 'V'), + (0x3EC, 'M', 'ϭ'), + (0x3ED, 'V'), + (0x3EE, 'M', 'ϯ'), + (0x3EF, 'V'), + (0x3F0, 'M', 'κ'), + (0x3F1, 'M', 'ρ'), + (0x3F2, 'M', 'σ'), + (0x3F3, 'V'), + (0x3F4, 'M', 'θ'), + (0x3F5, 'M', 'ε'), + (0x3F6, 'V'), + (0x3F7, 'M', 'ϸ'), + (0x3F8, 'V'), + (0x3F9, 'M', 'σ'), + (0x3FA, 'M', 'ϻ'), + (0x3FB, 'V'), + (0x3FD, 'M', 'ͻ'), + (0x3FE, 'M', 'ͼ'), + (0x3FF, 'M', 'ͽ'), + (0x400, 'M', 'ѐ'), + (0x401, 'M', 'ё'), + (0x402, 'M', 'ђ'), + ] + +def _seg_7(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0x403, 'M', 'ѓ'), + (0x404, 'M', 'є'), + (0x405, 'M', 'ѕ'), + (0x406, 'M', 'і'), + (0x407, 'M', 'ї'), + (0x408, 'M', 'ј'), + (0x409, 'M', 'љ'), + (0x40A, 'M', 'њ'), + (0x40B, 'M', 'ћ'), + (0x40C, 'M', 'ќ'), + (0x40D, 'M', 'ѝ'), + (0x40E, 'M', 'ў'), + (0x40F, 'M', 'џ'), + (0x410, 'M', 'а'), + (0x411, 'M', 'б'), + (0x412, 'M', 'в'), + (0x413, 'M', 'г'), + (0x414, 'M', 'д'), + (0x415, 'M', 'е'), + (0x416, 'M', 'ж'), + (0x417, 'M', 'з'), + (0x418, 'M', 'и'), + (0x419, 'M', 'й'), + (0x41A, 'M', 'к'), + (0x41B, 'M', 'л'), + (0x41C, 'M', 'м'), + (0x41D, 'M', 'н'), + (0x41E, 'M', 'о'), + (0x41F, 'M', 'п'), + (0x420, 'M', 'р'), + (0x421, 'M', 'с'), + (0x422, 'M', 'т'), + (0x423, 'M', 'у'), + (0x424, 'M', 'ф'), + (0x425, 'M', 'х'), + (0x426, 'M', 'ц'), + (0x427, 'M', 'ч'), + (0x428, 'M', 'ш'), + (0x429, 'M', 'щ'), + (0x42A, 'M', 'ъ'), + (0x42B, 'M', 'ы'), + (0x42C, 'M', 'ь'), + (0x42D, 'M', 'э'), + (0x42E, 'M', 'ю'), + (0x42F, 'M', 'я'), + (0x430, 'V'), + (0x460, 'M', 'ѡ'), + (0x461, 'V'), + (0x462, 'M', 'ѣ'), + (0x463, 'V'), + (0x464, 'M', 'ѥ'), + (0x465, 'V'), + (0x466, 'M', 'ѧ'), + (0x467, 'V'), + (0x468, 'M', 'ѩ'), + (0x469, 'V'), + (0x46A, 'M', 'ѫ'), + (0x46B, 'V'), + (0x46C, 'M', 'ѭ'), + (0x46D, 'V'), + (0x46E, 'M', 'ѯ'), + (0x46F, 'V'), + (0x470, 'M', 'ѱ'), + (0x471, 'V'), + (0x472, 'M', 'ѳ'), + (0x473, 'V'), + (0x474, 'M', 'ѵ'), + (0x475, 'V'), + (0x476, 'M', 'ѷ'), + (0x477, 'V'), + (0x478, 'M', 'ѹ'), + (0x479, 'V'), + (0x47A, 'M', 'ѻ'), + (0x47B, 'V'), + (0x47C, 'M', 'ѽ'), + (0x47D, 'V'), + (0x47E, 'M', 'ѿ'), + (0x47F, 'V'), + (0x480, 'M', 'ҁ'), + (0x481, 'V'), + (0x48A, 'M', 'ҋ'), + (0x48B, 'V'), + (0x48C, 'M', 'ҍ'), + (0x48D, 'V'), + (0x48E, 'M', 'ҏ'), + (0x48F, 'V'), + (0x490, 'M', 'ґ'), + (0x491, 'V'), + (0x492, 'M', 'ғ'), + (0x493, 'V'), + (0x494, 'M', 'ҕ'), + (0x495, 'V'), + (0x496, 'M', 'җ'), + (0x497, 'V'), + (0x498, 'M', 'ҙ'), + (0x499, 'V'), + (0x49A, 'M', 'қ'), + (0x49B, 'V'), + (0x49C, 'M', 'ҝ'), + (0x49D, 'V'), + ] + +def _seg_8(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0x49E, 'M', 'ҟ'), + (0x49F, 'V'), + (0x4A0, 'M', 'ҡ'), + (0x4A1, 'V'), + (0x4A2, 'M', 'ң'), + (0x4A3, 'V'), + (0x4A4, 'M', 'ҥ'), + (0x4A5, 'V'), + (0x4A6, 'M', 'ҧ'), + (0x4A7, 'V'), + (0x4A8, 'M', 'ҩ'), + (0x4A9, 'V'), + (0x4AA, 'M', 'ҫ'), + (0x4AB, 'V'), + (0x4AC, 'M', 'ҭ'), + (0x4AD, 'V'), + (0x4AE, 'M', 'ү'), + (0x4AF, 'V'), + (0x4B0, 'M', 'ұ'), + (0x4B1, 'V'), + (0x4B2, 'M', 'ҳ'), + (0x4B3, 'V'), + (0x4B4, 'M', 'ҵ'), + (0x4B5, 'V'), + (0x4B6, 'M', 'ҷ'), + (0x4B7, 'V'), + (0x4B8, 'M', 'ҹ'), + (0x4B9, 'V'), + (0x4BA, 'M', 'һ'), + (0x4BB, 'V'), + (0x4BC, 'M', 'ҽ'), + (0x4BD, 'V'), + (0x4BE, 'M', 'ҿ'), + (0x4BF, 'V'), + (0x4C0, 'X'), + (0x4C1, 'M', 'ӂ'), + (0x4C2, 'V'), + (0x4C3, 'M', 'ӄ'), + (0x4C4, 'V'), + (0x4C5, 'M', 'ӆ'), + (0x4C6, 'V'), + (0x4C7, 'M', 'ӈ'), + (0x4C8, 'V'), + (0x4C9, 'M', 'ӊ'), + (0x4CA, 'V'), + (0x4CB, 'M', 'ӌ'), + (0x4CC, 'V'), + (0x4CD, 'M', 'ӎ'), + (0x4CE, 'V'), + (0x4D0, 'M', 'ӑ'), + (0x4D1, 'V'), + (0x4D2, 'M', 'ӓ'), + (0x4D3, 'V'), + (0x4D4, 'M', 'ӕ'), + (0x4D5, 'V'), + (0x4D6, 'M', 'ӗ'), + (0x4D7, 'V'), + (0x4D8, 'M', 'ә'), + (0x4D9, 'V'), + (0x4DA, 'M', 'ӛ'), + (0x4DB, 'V'), + (0x4DC, 'M', 'ӝ'), + (0x4DD, 'V'), + (0x4DE, 'M', 'ӟ'), + (0x4DF, 'V'), + (0x4E0, 'M', 'ӡ'), + (0x4E1, 'V'), + (0x4E2, 'M', 'ӣ'), + (0x4E3, 'V'), + (0x4E4, 'M', 'ӥ'), + (0x4E5, 'V'), + (0x4E6, 'M', 'ӧ'), + (0x4E7, 'V'), + (0x4E8, 'M', 'ө'), + (0x4E9, 'V'), + (0x4EA, 'M', 'ӫ'), + (0x4EB, 'V'), + (0x4EC, 'M', 'ӭ'), + (0x4ED, 'V'), + (0x4EE, 'M', 'ӯ'), + (0x4EF, 'V'), + (0x4F0, 'M', 'ӱ'), + (0x4F1, 'V'), + (0x4F2, 'M', 'ӳ'), + (0x4F3, 'V'), + (0x4F4, 'M', 'ӵ'), + (0x4F5, 'V'), + (0x4F6, 'M', 'ӷ'), + (0x4F7, 'V'), + (0x4F8, 'M', 'ӹ'), + (0x4F9, 'V'), + (0x4FA, 'M', 'ӻ'), + (0x4FB, 'V'), + (0x4FC, 'M', 'ӽ'), + (0x4FD, 'V'), + (0x4FE, 'M', 'ӿ'), + (0x4FF, 'V'), + (0x500, 'M', 'ԁ'), + (0x501, 'V'), + (0x502, 'M', 'ԃ'), + ] + +def _seg_9(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0x503, 'V'), + (0x504, 'M', 'ԅ'), + (0x505, 'V'), + (0x506, 'M', 'ԇ'), + (0x507, 'V'), + (0x508, 'M', 'ԉ'), + (0x509, 'V'), + (0x50A, 'M', 'ԋ'), + (0x50B, 'V'), + (0x50C, 'M', 'ԍ'), + (0x50D, 'V'), + (0x50E, 'M', 'ԏ'), + (0x50F, 'V'), + (0x510, 'M', 'ԑ'), + (0x511, 'V'), + (0x512, 'M', 'ԓ'), + (0x513, 'V'), + (0x514, 'M', 'ԕ'), + (0x515, 'V'), + (0x516, 'M', 'ԗ'), + (0x517, 'V'), + (0x518, 'M', 'ԙ'), + (0x519, 'V'), + (0x51A, 'M', 'ԛ'), + (0x51B, 'V'), + (0x51C, 'M', 'ԝ'), + (0x51D, 'V'), + (0x51E, 'M', 'ԟ'), + (0x51F, 'V'), + (0x520, 'M', 'ԡ'), + (0x521, 'V'), + (0x522, 'M', 'ԣ'), + (0x523, 'V'), + (0x524, 'M', 'ԥ'), + (0x525, 'V'), + (0x526, 'M', 'ԧ'), + (0x527, 'V'), + (0x528, 'M', 'ԩ'), + (0x529, 'V'), + (0x52A, 'M', 'ԫ'), + (0x52B, 'V'), + (0x52C, 'M', 'ԭ'), + (0x52D, 'V'), + (0x52E, 'M', 'ԯ'), + (0x52F, 'V'), + (0x530, 'X'), + (0x531, 'M', 'ա'), + (0x532, 'M', 'բ'), + (0x533, 'M', 'գ'), + (0x534, 'M', 'դ'), + (0x535, 'M', 'ե'), + (0x536, 'M', 'զ'), + (0x537, 'M', 'է'), + (0x538, 'M', 'ը'), + (0x539, 'M', 'թ'), + (0x53A, 'M', 'ժ'), + (0x53B, 'M', 'ի'), + (0x53C, 'M', 'լ'), + (0x53D, 'M', 'խ'), + (0x53E, 'M', 'ծ'), + (0x53F, 'M', 'կ'), + (0x540, 'M', 'հ'), + (0x541, 'M', 'ձ'), + (0x542, 'M', 'ղ'), + (0x543, 'M', 'ճ'), + (0x544, 'M', 'մ'), + (0x545, 'M', 'յ'), + (0x546, 'M', 'ն'), + (0x547, 'M', 'շ'), + (0x548, 'M', 'ո'), + (0x549, 'M', 'չ'), + (0x54A, 'M', 'պ'), + (0x54B, 'M', 'ջ'), + (0x54C, 'M', 'ռ'), + (0x54D, 'M', 'ս'), + (0x54E, 'M', 'վ'), + (0x54F, 'M', 'տ'), + (0x550, 'M', 'ր'), + (0x551, 'M', 'ց'), + (0x552, 'M', 'ւ'), + (0x553, 'M', 'փ'), + (0x554, 'M', 'ք'), + (0x555, 'M', 'օ'), + (0x556, 'M', 'ֆ'), + (0x557, 'X'), + (0x559, 'V'), + (0x587, 'M', 'եւ'), + (0x588, 'V'), + (0x58B, 'X'), + (0x58D, 'V'), + (0x590, 'X'), + (0x591, 'V'), + (0x5C8, 'X'), + (0x5D0, 'V'), + (0x5EB, 'X'), + (0x5EF, 'V'), + (0x5F5, 'X'), + (0x606, 'V'), + (0x61C, 'X'), + (0x61E, 'V'), + ] + +def _seg_10(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0x675, 'M', 'اٴ'), + (0x676, 'M', 'وٴ'), + (0x677, 'M', 'ۇٴ'), + (0x678, 'M', 'يٴ'), + (0x679, 'V'), + (0x6DD, 'X'), + (0x6DE, 'V'), + (0x70E, 'X'), + (0x710, 'V'), + (0x74B, 'X'), + (0x74D, 'V'), + (0x7B2, 'X'), + (0x7C0, 'V'), + (0x7FB, 'X'), + (0x7FD, 'V'), + (0x82E, 'X'), + (0x830, 'V'), + (0x83F, 'X'), + (0x840, 'V'), + (0x85C, 'X'), + (0x85E, 'V'), + (0x85F, 'X'), + (0x860, 'V'), + (0x86B, 'X'), + (0x8A0, 'V'), + (0x8B5, 'X'), + (0x8B6, 'V'), + (0x8C8, 'X'), + (0x8D3, 'V'), + (0x8E2, 'X'), + (0x8E3, 'V'), + (0x958, 'M', 'क़'), + (0x959, 'M', 'ख़'), + (0x95A, 'M', 'ग़'), + (0x95B, 'M', 'ज़'), + (0x95C, 'M', 'ड़'), + (0x95D, 'M', 'ढ़'), + (0x95E, 'M', 'फ़'), + (0x95F, 'M', 'य़'), + (0x960, 'V'), + (0x984, 'X'), + (0x985, 'V'), + (0x98D, 'X'), + (0x98F, 'V'), + (0x991, 'X'), + (0x993, 'V'), + (0x9A9, 'X'), + (0x9AA, 'V'), + (0x9B1, 'X'), + (0x9B2, 'V'), + (0x9B3, 'X'), + (0x9B6, 'V'), + (0x9BA, 'X'), + (0x9BC, 'V'), + (0x9C5, 'X'), + (0x9C7, 'V'), + (0x9C9, 'X'), + (0x9CB, 'V'), + (0x9CF, 'X'), + (0x9D7, 'V'), + (0x9D8, 'X'), + (0x9DC, 'M', 'ড়'), + (0x9DD, 'M', 'ঢ়'), + (0x9DE, 'X'), + (0x9DF, 'M', 'য়'), + (0x9E0, 'V'), + (0x9E4, 'X'), + (0x9E6, 'V'), + (0x9FF, 'X'), + (0xA01, 'V'), + (0xA04, 'X'), + (0xA05, 'V'), + (0xA0B, 'X'), + (0xA0F, 'V'), + (0xA11, 'X'), + (0xA13, 'V'), + (0xA29, 'X'), + (0xA2A, 'V'), + (0xA31, 'X'), + (0xA32, 'V'), + (0xA33, 'M', 'ਲ਼'), + (0xA34, 'X'), + (0xA35, 'V'), + (0xA36, 'M', 'ਸ਼'), + (0xA37, 'X'), + (0xA38, 'V'), + (0xA3A, 'X'), + (0xA3C, 'V'), + (0xA3D, 'X'), + (0xA3E, 'V'), + (0xA43, 'X'), + (0xA47, 'V'), + (0xA49, 'X'), + (0xA4B, 'V'), + (0xA4E, 'X'), + (0xA51, 'V'), + (0xA52, 'X'), + (0xA59, 'M', 'ਖ਼'), + (0xA5A, 'M', 'ਗ਼'), + (0xA5B, 'M', 'ਜ਼'), + ] + +def _seg_11(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0xA5C, 'V'), + (0xA5D, 'X'), + (0xA5E, 'M', 'ਫ਼'), + (0xA5F, 'X'), + (0xA66, 'V'), + (0xA77, 'X'), + (0xA81, 'V'), + (0xA84, 'X'), + (0xA85, 'V'), + (0xA8E, 'X'), + (0xA8F, 'V'), + (0xA92, 'X'), + (0xA93, 'V'), + (0xAA9, 'X'), + (0xAAA, 'V'), + (0xAB1, 'X'), + (0xAB2, 'V'), + (0xAB4, 'X'), + (0xAB5, 'V'), + (0xABA, 'X'), + (0xABC, 'V'), + (0xAC6, 'X'), + (0xAC7, 'V'), + (0xACA, 'X'), + (0xACB, 'V'), + (0xACE, 'X'), + (0xAD0, 'V'), + (0xAD1, 'X'), + (0xAE0, 'V'), + (0xAE4, 'X'), + (0xAE6, 'V'), + (0xAF2, 'X'), + (0xAF9, 'V'), + (0xB00, 'X'), + (0xB01, 'V'), + (0xB04, 'X'), + (0xB05, 'V'), + (0xB0D, 'X'), + (0xB0F, 'V'), + (0xB11, 'X'), + (0xB13, 'V'), + (0xB29, 'X'), + (0xB2A, 'V'), + (0xB31, 'X'), + (0xB32, 'V'), + (0xB34, 'X'), + (0xB35, 'V'), + (0xB3A, 'X'), + (0xB3C, 'V'), + (0xB45, 'X'), + (0xB47, 'V'), + (0xB49, 'X'), + (0xB4B, 'V'), + (0xB4E, 'X'), + (0xB55, 'V'), + (0xB58, 'X'), + (0xB5C, 'M', 'ଡ଼'), + (0xB5D, 'M', 'ଢ଼'), + (0xB5E, 'X'), + (0xB5F, 'V'), + (0xB64, 'X'), + (0xB66, 'V'), + (0xB78, 'X'), + (0xB82, 'V'), + (0xB84, 'X'), + (0xB85, 'V'), + (0xB8B, 'X'), + (0xB8E, 'V'), + (0xB91, 'X'), + (0xB92, 'V'), + (0xB96, 'X'), + (0xB99, 'V'), + (0xB9B, 'X'), + (0xB9C, 'V'), + (0xB9D, 'X'), + (0xB9E, 'V'), + (0xBA0, 'X'), + (0xBA3, 'V'), + (0xBA5, 'X'), + (0xBA8, 'V'), + (0xBAB, 'X'), + (0xBAE, 'V'), + (0xBBA, 'X'), + (0xBBE, 'V'), + (0xBC3, 'X'), + (0xBC6, 'V'), + (0xBC9, 'X'), + (0xBCA, 'V'), + (0xBCE, 'X'), + (0xBD0, 'V'), + (0xBD1, 'X'), + (0xBD7, 'V'), + (0xBD8, 'X'), + (0xBE6, 'V'), + (0xBFB, 'X'), + (0xC00, 'V'), + (0xC0D, 'X'), + (0xC0E, 'V'), + (0xC11, 'X'), + (0xC12, 'V'), + ] + +def _seg_12(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0xC29, 'X'), + (0xC2A, 'V'), + (0xC3A, 'X'), + (0xC3D, 'V'), + (0xC45, 'X'), + (0xC46, 'V'), + (0xC49, 'X'), + (0xC4A, 'V'), + (0xC4E, 'X'), + (0xC55, 'V'), + (0xC57, 'X'), + (0xC58, 'V'), + (0xC5B, 'X'), + (0xC60, 'V'), + (0xC64, 'X'), + (0xC66, 'V'), + (0xC70, 'X'), + (0xC77, 'V'), + (0xC8D, 'X'), + (0xC8E, 'V'), + (0xC91, 'X'), + (0xC92, 'V'), + (0xCA9, 'X'), + (0xCAA, 'V'), + (0xCB4, 'X'), + (0xCB5, 'V'), + (0xCBA, 'X'), + (0xCBC, 'V'), + (0xCC5, 'X'), + (0xCC6, 'V'), + (0xCC9, 'X'), + (0xCCA, 'V'), + (0xCCE, 'X'), + (0xCD5, 'V'), + (0xCD7, 'X'), + (0xCDE, 'V'), + (0xCDF, 'X'), + (0xCE0, 'V'), + (0xCE4, 'X'), + (0xCE6, 'V'), + (0xCF0, 'X'), + (0xCF1, 'V'), + (0xCF3, 'X'), + (0xD00, 'V'), + (0xD0D, 'X'), + (0xD0E, 'V'), + (0xD11, 'X'), + (0xD12, 'V'), + (0xD45, 'X'), + (0xD46, 'V'), + (0xD49, 'X'), + (0xD4A, 'V'), + (0xD50, 'X'), + (0xD54, 'V'), + (0xD64, 'X'), + (0xD66, 'V'), + (0xD80, 'X'), + (0xD81, 'V'), + (0xD84, 'X'), + (0xD85, 'V'), + (0xD97, 'X'), + (0xD9A, 'V'), + (0xDB2, 'X'), + (0xDB3, 'V'), + (0xDBC, 'X'), + (0xDBD, 'V'), + (0xDBE, 'X'), + (0xDC0, 'V'), + (0xDC7, 'X'), + (0xDCA, 'V'), + (0xDCB, 'X'), + (0xDCF, 'V'), + (0xDD5, 'X'), + (0xDD6, 'V'), + (0xDD7, 'X'), + (0xDD8, 'V'), + (0xDE0, 'X'), + (0xDE6, 'V'), + (0xDF0, 'X'), + (0xDF2, 'V'), + (0xDF5, 'X'), + (0xE01, 'V'), + (0xE33, 'M', 'ํา'), + (0xE34, 'V'), + (0xE3B, 'X'), + (0xE3F, 'V'), + (0xE5C, 'X'), + (0xE81, 'V'), + (0xE83, 'X'), + (0xE84, 'V'), + (0xE85, 'X'), + (0xE86, 'V'), + (0xE8B, 'X'), + (0xE8C, 'V'), + (0xEA4, 'X'), + (0xEA5, 'V'), + (0xEA6, 'X'), + (0xEA7, 'V'), + (0xEB3, 'M', 'ໍາ'), + (0xEB4, 'V'), + ] + +def _seg_13(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0xEBE, 'X'), + (0xEC0, 'V'), + (0xEC5, 'X'), + (0xEC6, 'V'), + (0xEC7, 'X'), + (0xEC8, 'V'), + (0xECE, 'X'), + (0xED0, 'V'), + (0xEDA, 'X'), + (0xEDC, 'M', 'ຫນ'), + (0xEDD, 'M', 'ຫມ'), + (0xEDE, 'V'), + (0xEE0, 'X'), + (0xF00, 'V'), + (0xF0C, 'M', '་'), + (0xF0D, 'V'), + (0xF43, 'M', 'གྷ'), + (0xF44, 'V'), + (0xF48, 'X'), + (0xF49, 'V'), + (0xF4D, 'M', 'ཌྷ'), + (0xF4E, 'V'), + (0xF52, 'M', 'དྷ'), + (0xF53, 'V'), + (0xF57, 'M', 'བྷ'), + (0xF58, 'V'), + (0xF5C, 'M', 'ཛྷ'), + (0xF5D, 'V'), + (0xF69, 'M', 'ཀྵ'), + (0xF6A, 'V'), + (0xF6D, 'X'), + (0xF71, 'V'), + (0xF73, 'M', 'ཱི'), + (0xF74, 'V'), + (0xF75, 'M', 'ཱུ'), + (0xF76, 'M', 'ྲྀ'), + (0xF77, 'M', 'ྲཱྀ'), + (0xF78, 'M', 'ླྀ'), + (0xF79, 'M', 'ླཱྀ'), + (0xF7A, 'V'), + (0xF81, 'M', 'ཱྀ'), + (0xF82, 'V'), + (0xF93, 'M', 'ྒྷ'), + (0xF94, 'V'), + (0xF98, 'X'), + (0xF99, 'V'), + (0xF9D, 'M', 'ྜྷ'), + (0xF9E, 'V'), + (0xFA2, 'M', 'ྡྷ'), + (0xFA3, 'V'), + (0xFA7, 'M', 'ྦྷ'), + (0xFA8, 'V'), + (0xFAC, 'M', 'ྫྷ'), + (0xFAD, 'V'), + (0xFB9, 'M', 'ྐྵ'), + (0xFBA, 'V'), + (0xFBD, 'X'), + (0xFBE, 'V'), + (0xFCD, 'X'), + (0xFCE, 'V'), + (0xFDB, 'X'), + (0x1000, 'V'), + (0x10A0, 'X'), + (0x10C7, 'M', 'ⴧ'), + (0x10C8, 'X'), + (0x10CD, 'M', 'ⴭ'), + (0x10CE, 'X'), + (0x10D0, 'V'), + (0x10FC, 'M', 'ნ'), + (0x10FD, 'V'), + (0x115F, 'X'), + (0x1161, 'V'), + (0x1249, 'X'), + (0x124A, 'V'), + (0x124E, 'X'), + (0x1250, 'V'), + (0x1257, 'X'), + (0x1258, 'V'), + (0x1259, 'X'), + (0x125A, 'V'), + (0x125E, 'X'), + (0x1260, 'V'), + (0x1289, 'X'), + (0x128A, 'V'), + (0x128E, 'X'), + (0x1290, 'V'), + (0x12B1, 'X'), + (0x12B2, 'V'), + (0x12B6, 'X'), + (0x12B8, 'V'), + (0x12BF, 'X'), + (0x12C0, 'V'), + (0x12C1, 'X'), + (0x12C2, 'V'), + (0x12C6, 'X'), + (0x12C8, 'V'), + (0x12D7, 'X'), + (0x12D8, 'V'), + (0x1311, 'X'), + (0x1312, 'V'), + ] + +def _seg_14(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0x1316, 'X'), + (0x1318, 'V'), + (0x135B, 'X'), + (0x135D, 'V'), + (0x137D, 'X'), + (0x1380, 'V'), + (0x139A, 'X'), + (0x13A0, 'V'), + (0x13F6, 'X'), + (0x13F8, 'M', 'Ᏸ'), + (0x13F9, 'M', 'Ᏹ'), + (0x13FA, 'M', 'Ᏺ'), + (0x13FB, 'M', 'Ᏻ'), + (0x13FC, 'M', 'Ᏼ'), + (0x13FD, 'M', 'Ᏽ'), + (0x13FE, 'X'), + (0x1400, 'V'), + (0x1680, 'X'), + (0x1681, 'V'), + (0x169D, 'X'), + (0x16A0, 'V'), + (0x16F9, 'X'), + (0x1700, 'V'), + (0x170D, 'X'), + (0x170E, 'V'), + (0x1715, 'X'), + (0x1720, 'V'), + (0x1737, 'X'), + (0x1740, 'V'), + (0x1754, 'X'), + (0x1760, 'V'), + (0x176D, 'X'), + (0x176E, 'V'), + (0x1771, 'X'), + (0x1772, 'V'), + (0x1774, 'X'), + (0x1780, 'V'), + (0x17B4, 'X'), + (0x17B6, 'V'), + (0x17DE, 'X'), + (0x17E0, 'V'), + (0x17EA, 'X'), + (0x17F0, 'V'), + (0x17FA, 'X'), + (0x1800, 'V'), + (0x1806, 'X'), + (0x1807, 'V'), + (0x180B, 'I'), + (0x180E, 'X'), + (0x1810, 'V'), + (0x181A, 'X'), + (0x1820, 'V'), + (0x1879, 'X'), + (0x1880, 'V'), + (0x18AB, 'X'), + (0x18B0, 'V'), + (0x18F6, 'X'), + (0x1900, 'V'), + (0x191F, 'X'), + (0x1920, 'V'), + (0x192C, 'X'), + (0x1930, 'V'), + (0x193C, 'X'), + (0x1940, 'V'), + (0x1941, 'X'), + (0x1944, 'V'), + (0x196E, 'X'), + (0x1970, 'V'), + (0x1975, 'X'), + (0x1980, 'V'), + (0x19AC, 'X'), + (0x19B0, 'V'), + (0x19CA, 'X'), + (0x19D0, 'V'), + (0x19DB, 'X'), + (0x19DE, 'V'), + (0x1A1C, 'X'), + (0x1A1E, 'V'), + (0x1A5F, 'X'), + (0x1A60, 'V'), + (0x1A7D, 'X'), + (0x1A7F, 'V'), + (0x1A8A, 'X'), + (0x1A90, 'V'), + (0x1A9A, 'X'), + (0x1AA0, 'V'), + (0x1AAE, 'X'), + (0x1AB0, 'V'), + (0x1AC1, 'X'), + (0x1B00, 'V'), + (0x1B4C, 'X'), + (0x1B50, 'V'), + (0x1B7D, 'X'), + (0x1B80, 'V'), + (0x1BF4, 'X'), + (0x1BFC, 'V'), + (0x1C38, 'X'), + (0x1C3B, 'V'), + (0x1C4A, 'X'), + (0x1C4D, 'V'), + ] + +def _seg_15(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0x1C80, 'M', 'в'), + (0x1C81, 'M', 'д'), + (0x1C82, 'M', 'о'), + (0x1C83, 'M', 'с'), + (0x1C84, 'M', 'т'), + (0x1C86, 'M', 'ъ'), + (0x1C87, 'M', 'ѣ'), + (0x1C88, 'M', 'ꙋ'), + (0x1C89, 'X'), + (0x1C90, 'M', 'ა'), + (0x1C91, 'M', 'ბ'), + (0x1C92, 'M', 'გ'), + (0x1C93, 'M', 'დ'), + (0x1C94, 'M', 'ე'), + (0x1C95, 'M', 'ვ'), + (0x1C96, 'M', 'ზ'), + (0x1C97, 'M', 'თ'), + (0x1C98, 'M', 'ი'), + (0x1C99, 'M', 'კ'), + (0x1C9A, 'M', 'ლ'), + (0x1C9B, 'M', 'მ'), + (0x1C9C, 'M', 'ნ'), + (0x1C9D, 'M', 'ო'), + (0x1C9E, 'M', 'პ'), + (0x1C9F, 'M', 'ჟ'), + (0x1CA0, 'M', 'რ'), + (0x1CA1, 'M', 'ს'), + (0x1CA2, 'M', 'ტ'), + (0x1CA3, 'M', 'უ'), + (0x1CA4, 'M', 'ფ'), + (0x1CA5, 'M', 'ქ'), + (0x1CA6, 'M', 'ღ'), + (0x1CA7, 'M', 'ყ'), + (0x1CA8, 'M', 'შ'), + (0x1CA9, 'M', 'ჩ'), + (0x1CAA, 'M', 'ც'), + (0x1CAB, 'M', 'ძ'), + (0x1CAC, 'M', 'წ'), + (0x1CAD, 'M', 'ჭ'), + (0x1CAE, 'M', 'ხ'), + (0x1CAF, 'M', 'ჯ'), + (0x1CB0, 'M', 'ჰ'), + (0x1CB1, 'M', 'ჱ'), + (0x1CB2, 'M', 'ჲ'), + (0x1CB3, 'M', 'ჳ'), + (0x1CB4, 'M', 'ჴ'), + (0x1CB5, 'M', 'ჵ'), + (0x1CB6, 'M', 'ჶ'), + (0x1CB7, 'M', 'ჷ'), + (0x1CB8, 'M', 'ჸ'), + (0x1CB9, 'M', 'ჹ'), + (0x1CBA, 'M', 'ჺ'), + (0x1CBB, 'X'), + (0x1CBD, 'M', 'ჽ'), + (0x1CBE, 'M', 'ჾ'), + (0x1CBF, 'M', 'ჿ'), + (0x1CC0, 'V'), + (0x1CC8, 'X'), + (0x1CD0, 'V'), + (0x1CFB, 'X'), + (0x1D00, 'V'), + (0x1D2C, 'M', 'a'), + (0x1D2D, 'M', 'æ'), + (0x1D2E, 'M', 'b'), + (0x1D2F, 'V'), + (0x1D30, 'M', 'd'), + (0x1D31, 'M', 'e'), + (0x1D32, 'M', 'ǝ'), + (0x1D33, 'M', 'g'), + (0x1D34, 'M', 'h'), + (0x1D35, 'M', 'i'), + (0x1D36, 'M', 'j'), + (0x1D37, 'M', 'k'), + (0x1D38, 'M', 'l'), + (0x1D39, 'M', 'm'), + (0x1D3A, 'M', 'n'), + (0x1D3B, 'V'), + (0x1D3C, 'M', 'o'), + (0x1D3D, 'M', 'ȣ'), + (0x1D3E, 'M', 'p'), + (0x1D3F, 'M', 'r'), + (0x1D40, 'M', 't'), + (0x1D41, 'M', 'u'), + (0x1D42, 'M', 'w'), + (0x1D43, 'M', 'a'), + (0x1D44, 'M', 'ɐ'), + (0x1D45, 'M', 'ɑ'), + (0x1D46, 'M', 'ᴂ'), + (0x1D47, 'M', 'b'), + (0x1D48, 'M', 'd'), + (0x1D49, 'M', 'e'), + (0x1D4A, 'M', 'ə'), + (0x1D4B, 'M', 'ɛ'), + (0x1D4C, 'M', 'ɜ'), + (0x1D4D, 'M', 'g'), + (0x1D4E, 'V'), + (0x1D4F, 'M', 'k'), + (0x1D50, 'M', 'm'), + (0x1D51, 'M', 'ŋ'), + (0x1D52, 'M', 'o'), + ] + +def _seg_16(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0x1D53, 'M', 'ɔ'), + (0x1D54, 'M', 'ᴖ'), + (0x1D55, 'M', 'ᴗ'), + (0x1D56, 'M', 'p'), + (0x1D57, 'M', 't'), + (0x1D58, 'M', 'u'), + (0x1D59, 'M', 'ᴝ'), + (0x1D5A, 'M', 'ɯ'), + (0x1D5B, 'M', 'v'), + (0x1D5C, 'M', 'ᴥ'), + (0x1D5D, 'M', 'β'), + (0x1D5E, 'M', 'γ'), + (0x1D5F, 'M', 'δ'), + (0x1D60, 'M', 'φ'), + (0x1D61, 'M', 'χ'), + (0x1D62, 'M', 'i'), + (0x1D63, 'M', 'r'), + (0x1D64, 'M', 'u'), + (0x1D65, 'M', 'v'), + (0x1D66, 'M', 'β'), + (0x1D67, 'M', 'γ'), + (0x1D68, 'M', 'ρ'), + (0x1D69, 'M', 'φ'), + (0x1D6A, 'M', 'χ'), + (0x1D6B, 'V'), + (0x1D78, 'M', 'н'), + (0x1D79, 'V'), + (0x1D9B, 'M', 'ɒ'), + (0x1D9C, 'M', 'c'), + (0x1D9D, 'M', 'ɕ'), + (0x1D9E, 'M', 'ð'), + (0x1D9F, 'M', 'ɜ'), + (0x1DA0, 'M', 'f'), + (0x1DA1, 'M', 'ɟ'), + (0x1DA2, 'M', 'ɡ'), + (0x1DA3, 'M', 'ɥ'), + (0x1DA4, 'M', 'ɨ'), + (0x1DA5, 'M', 'ɩ'), + (0x1DA6, 'M', 'ɪ'), + (0x1DA7, 'M', 'ᵻ'), + (0x1DA8, 'M', 'ʝ'), + (0x1DA9, 'M', 'ɭ'), + (0x1DAA, 'M', 'ᶅ'), + (0x1DAB, 'M', 'ʟ'), + (0x1DAC, 'M', 'ɱ'), + (0x1DAD, 'M', 'ɰ'), + (0x1DAE, 'M', 'ɲ'), + (0x1DAF, 'M', 'ɳ'), + (0x1DB0, 'M', 'ɴ'), + (0x1DB1, 'M', 'ɵ'), + (0x1DB2, 'M', 'ɸ'), + (0x1DB3, 'M', 'ʂ'), + (0x1DB4, 'M', 'ʃ'), + (0x1DB5, 'M', 'ƫ'), + (0x1DB6, 'M', 'ʉ'), + (0x1DB7, 'M', 'ʊ'), + (0x1DB8, 'M', 'ᴜ'), + (0x1DB9, 'M', 'ʋ'), + (0x1DBA, 'M', 'ʌ'), + (0x1DBB, 'M', 'z'), + (0x1DBC, 'M', 'ʐ'), + (0x1DBD, 'M', 'ʑ'), + (0x1DBE, 'M', 'ʒ'), + (0x1DBF, 'M', 'θ'), + (0x1DC0, 'V'), + (0x1DFA, 'X'), + (0x1DFB, 'V'), + (0x1E00, 'M', 'ḁ'), + (0x1E01, 'V'), + (0x1E02, 'M', 'ḃ'), + (0x1E03, 'V'), + (0x1E04, 'M', 'ḅ'), + (0x1E05, 'V'), + (0x1E06, 'M', 'ḇ'), + (0x1E07, 'V'), + (0x1E08, 'M', 'ḉ'), + (0x1E09, 'V'), + (0x1E0A, 'M', 'ḋ'), + (0x1E0B, 'V'), + (0x1E0C, 'M', 'ḍ'), + (0x1E0D, 'V'), + (0x1E0E, 'M', 'ḏ'), + (0x1E0F, 'V'), + (0x1E10, 'M', 'ḑ'), + (0x1E11, 'V'), + (0x1E12, 'M', 'ḓ'), + (0x1E13, 'V'), + (0x1E14, 'M', 'ḕ'), + (0x1E15, 'V'), + (0x1E16, 'M', 'ḗ'), + (0x1E17, 'V'), + (0x1E18, 'M', 'ḙ'), + (0x1E19, 'V'), + (0x1E1A, 'M', 'ḛ'), + (0x1E1B, 'V'), + (0x1E1C, 'M', 'ḝ'), + (0x1E1D, 'V'), + (0x1E1E, 'M', 'ḟ'), + (0x1E1F, 'V'), + (0x1E20, 'M', 'ḡ'), + ] + +def _seg_17(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0x1E21, 'V'), + (0x1E22, 'M', 'ḣ'), + (0x1E23, 'V'), + (0x1E24, 'M', 'ḥ'), + (0x1E25, 'V'), + (0x1E26, 'M', 'ḧ'), + (0x1E27, 'V'), + (0x1E28, 'M', 'ḩ'), + (0x1E29, 'V'), + (0x1E2A, 'M', 'ḫ'), + (0x1E2B, 'V'), + (0x1E2C, 'M', 'ḭ'), + (0x1E2D, 'V'), + (0x1E2E, 'M', 'ḯ'), + (0x1E2F, 'V'), + (0x1E30, 'M', 'ḱ'), + (0x1E31, 'V'), + (0x1E32, 'M', 'ḳ'), + (0x1E33, 'V'), + (0x1E34, 'M', 'ḵ'), + (0x1E35, 'V'), + (0x1E36, 'M', 'ḷ'), + (0x1E37, 'V'), + (0x1E38, 'M', 'ḹ'), + (0x1E39, 'V'), + (0x1E3A, 'M', 'ḻ'), + (0x1E3B, 'V'), + (0x1E3C, 'M', 'ḽ'), + (0x1E3D, 'V'), + (0x1E3E, 'M', 'ḿ'), + (0x1E3F, 'V'), + (0x1E40, 'M', 'ṁ'), + (0x1E41, 'V'), + (0x1E42, 'M', 'ṃ'), + (0x1E43, 'V'), + (0x1E44, 'M', 'ṅ'), + (0x1E45, 'V'), + (0x1E46, 'M', 'ṇ'), + (0x1E47, 'V'), + (0x1E48, 'M', 'ṉ'), + (0x1E49, 'V'), + (0x1E4A, 'M', 'ṋ'), + (0x1E4B, 'V'), + (0x1E4C, 'M', 'ṍ'), + (0x1E4D, 'V'), + (0x1E4E, 'M', 'ṏ'), + (0x1E4F, 'V'), + (0x1E50, 'M', 'ṑ'), + (0x1E51, 'V'), + (0x1E52, 'M', 'ṓ'), + (0x1E53, 'V'), + (0x1E54, 'M', 'ṕ'), + (0x1E55, 'V'), + (0x1E56, 'M', 'ṗ'), + (0x1E57, 'V'), + (0x1E58, 'M', 'ṙ'), + (0x1E59, 'V'), + (0x1E5A, 'M', 'ṛ'), + (0x1E5B, 'V'), + (0x1E5C, 'M', 'ṝ'), + (0x1E5D, 'V'), + (0x1E5E, 'M', 'ṟ'), + (0x1E5F, 'V'), + (0x1E60, 'M', 'ṡ'), + (0x1E61, 'V'), + (0x1E62, 'M', 'ṣ'), + (0x1E63, 'V'), + (0x1E64, 'M', 'ṥ'), + (0x1E65, 'V'), + (0x1E66, 'M', 'ṧ'), + (0x1E67, 'V'), + (0x1E68, 'M', 'ṩ'), + (0x1E69, 'V'), + (0x1E6A, 'M', 'ṫ'), + (0x1E6B, 'V'), + (0x1E6C, 'M', 'ṭ'), + (0x1E6D, 'V'), + (0x1E6E, 'M', 'ṯ'), + (0x1E6F, 'V'), + (0x1E70, 'M', 'ṱ'), + (0x1E71, 'V'), + (0x1E72, 'M', 'ṳ'), + (0x1E73, 'V'), + (0x1E74, 'M', 'ṵ'), + (0x1E75, 'V'), + (0x1E76, 'M', 'ṷ'), + (0x1E77, 'V'), + (0x1E78, 'M', 'ṹ'), + (0x1E79, 'V'), + (0x1E7A, 'M', 'ṻ'), + (0x1E7B, 'V'), + (0x1E7C, 'M', 'ṽ'), + (0x1E7D, 'V'), + (0x1E7E, 'M', 'ṿ'), + (0x1E7F, 'V'), + (0x1E80, 'M', 'ẁ'), + (0x1E81, 'V'), + (0x1E82, 'M', 'ẃ'), + (0x1E83, 'V'), + (0x1E84, 'M', 'ẅ'), + ] + +def _seg_18(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0x1E85, 'V'), + (0x1E86, 'M', 'ẇ'), + (0x1E87, 'V'), + (0x1E88, 'M', 'ẉ'), + (0x1E89, 'V'), + (0x1E8A, 'M', 'ẋ'), + (0x1E8B, 'V'), + (0x1E8C, 'M', 'ẍ'), + (0x1E8D, 'V'), + (0x1E8E, 'M', 'ẏ'), + (0x1E8F, 'V'), + (0x1E90, 'M', 'ẑ'), + (0x1E91, 'V'), + (0x1E92, 'M', 'ẓ'), + (0x1E93, 'V'), + (0x1E94, 'M', 'ẕ'), + (0x1E95, 'V'), + (0x1E9A, 'M', 'aʾ'), + (0x1E9B, 'M', 'ṡ'), + (0x1E9C, 'V'), + (0x1E9E, 'M', 'ss'), + (0x1E9F, 'V'), + (0x1EA0, 'M', 'ạ'), + (0x1EA1, 'V'), + (0x1EA2, 'M', 'ả'), + (0x1EA3, 'V'), + (0x1EA4, 'M', 'ấ'), + (0x1EA5, 'V'), + (0x1EA6, 'M', 'ầ'), + (0x1EA7, 'V'), + (0x1EA8, 'M', 'ẩ'), + (0x1EA9, 'V'), + (0x1EAA, 'M', 'ẫ'), + (0x1EAB, 'V'), + (0x1EAC, 'M', 'ậ'), + (0x1EAD, 'V'), + (0x1EAE, 'M', 'ắ'), + (0x1EAF, 'V'), + (0x1EB0, 'M', 'ằ'), + (0x1EB1, 'V'), + (0x1EB2, 'M', 'ẳ'), + (0x1EB3, 'V'), + (0x1EB4, 'M', 'ẵ'), + (0x1EB5, 'V'), + (0x1EB6, 'M', 'ặ'), + (0x1EB7, 'V'), + (0x1EB8, 'M', 'ẹ'), + (0x1EB9, 'V'), + (0x1EBA, 'M', 'ẻ'), + (0x1EBB, 'V'), + (0x1EBC, 'M', 'ẽ'), + (0x1EBD, 'V'), + (0x1EBE, 'M', 'ế'), + (0x1EBF, 'V'), + (0x1EC0, 'M', 'ề'), + (0x1EC1, 'V'), + (0x1EC2, 'M', 'ể'), + (0x1EC3, 'V'), + (0x1EC4, 'M', 'ễ'), + (0x1EC5, 'V'), + (0x1EC6, 'M', 'ệ'), + (0x1EC7, 'V'), + (0x1EC8, 'M', 'ỉ'), + (0x1EC9, 'V'), + (0x1ECA, 'M', 'ị'), + (0x1ECB, 'V'), + (0x1ECC, 'M', 'ọ'), + (0x1ECD, 'V'), + (0x1ECE, 'M', 'ỏ'), + (0x1ECF, 'V'), + (0x1ED0, 'M', 'ố'), + (0x1ED1, 'V'), + (0x1ED2, 'M', 'ồ'), + (0x1ED3, 'V'), + (0x1ED4, 'M', 'ổ'), + (0x1ED5, 'V'), + (0x1ED6, 'M', 'ỗ'), + (0x1ED7, 'V'), + (0x1ED8, 'M', 'ộ'), + (0x1ED9, 'V'), + (0x1EDA, 'M', 'ớ'), + (0x1EDB, 'V'), + (0x1EDC, 'M', 'ờ'), + (0x1EDD, 'V'), + (0x1EDE, 'M', 'ở'), + (0x1EDF, 'V'), + (0x1EE0, 'M', 'ỡ'), + (0x1EE1, 'V'), + (0x1EE2, 'M', 'ợ'), + (0x1EE3, 'V'), + (0x1EE4, 'M', 'ụ'), + (0x1EE5, 'V'), + (0x1EE6, 'M', 'ủ'), + (0x1EE7, 'V'), + (0x1EE8, 'M', 'ứ'), + (0x1EE9, 'V'), + (0x1EEA, 'M', 'ừ'), + (0x1EEB, 'V'), + (0x1EEC, 'M', 'ử'), + (0x1EED, 'V'), + ] + +def _seg_19(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0x1EEE, 'M', 'ữ'), + (0x1EEF, 'V'), + (0x1EF0, 'M', 'ự'), + (0x1EF1, 'V'), + (0x1EF2, 'M', 'ỳ'), + (0x1EF3, 'V'), + (0x1EF4, 'M', 'ỵ'), + (0x1EF5, 'V'), + (0x1EF6, 'M', 'ỷ'), + (0x1EF7, 'V'), + (0x1EF8, 'M', 'ỹ'), + (0x1EF9, 'V'), + (0x1EFA, 'M', 'ỻ'), + (0x1EFB, 'V'), + (0x1EFC, 'M', 'ỽ'), + (0x1EFD, 'V'), + (0x1EFE, 'M', 'ỿ'), + (0x1EFF, 'V'), + (0x1F08, 'M', 'ἀ'), + (0x1F09, 'M', 'ἁ'), + (0x1F0A, 'M', 'ἂ'), + (0x1F0B, 'M', 'ἃ'), + (0x1F0C, 'M', 'ἄ'), + (0x1F0D, 'M', 'ἅ'), + (0x1F0E, 'M', 'ἆ'), + (0x1F0F, 'M', 'ἇ'), + (0x1F10, 'V'), + (0x1F16, 'X'), + (0x1F18, 'M', 'ἐ'), + (0x1F19, 'M', 'ἑ'), + (0x1F1A, 'M', 'ἒ'), + (0x1F1B, 'M', 'ἓ'), + (0x1F1C, 'M', 'ἔ'), + (0x1F1D, 'M', 'ἕ'), + (0x1F1E, 'X'), + (0x1F20, 'V'), + (0x1F28, 'M', 'ἠ'), + (0x1F29, 'M', 'ἡ'), + (0x1F2A, 'M', 'ἢ'), + (0x1F2B, 'M', 'ἣ'), + (0x1F2C, 'M', 'ἤ'), + (0x1F2D, 'M', 'ἥ'), + (0x1F2E, 'M', 'ἦ'), + (0x1F2F, 'M', 'ἧ'), + (0x1F30, 'V'), + (0x1F38, 'M', 'ἰ'), + (0x1F39, 'M', 'ἱ'), + (0x1F3A, 'M', 'ἲ'), + (0x1F3B, 'M', 'ἳ'), + (0x1F3C, 'M', 'ἴ'), + (0x1F3D, 'M', 'ἵ'), + (0x1F3E, 'M', 'ἶ'), + (0x1F3F, 'M', 'ἷ'), + (0x1F40, 'V'), + (0x1F46, 'X'), + (0x1F48, 'M', 'ὀ'), + (0x1F49, 'M', 'ὁ'), + (0x1F4A, 'M', 'ὂ'), + (0x1F4B, 'M', 'ὃ'), + (0x1F4C, 'M', 'ὄ'), + (0x1F4D, 'M', 'ὅ'), + (0x1F4E, 'X'), + (0x1F50, 'V'), + (0x1F58, 'X'), + (0x1F59, 'M', 'ὑ'), + (0x1F5A, 'X'), + (0x1F5B, 'M', 'ὓ'), + (0x1F5C, 'X'), + (0x1F5D, 'M', 'ὕ'), + (0x1F5E, 'X'), + (0x1F5F, 'M', 'ὗ'), + (0x1F60, 'V'), + (0x1F68, 'M', 'ὠ'), + (0x1F69, 'M', 'ὡ'), + (0x1F6A, 'M', 'ὢ'), + (0x1F6B, 'M', 'ὣ'), + (0x1F6C, 'M', 'ὤ'), + (0x1F6D, 'M', 'ὥ'), + (0x1F6E, 'M', 'ὦ'), + (0x1F6F, 'M', 'ὧ'), + (0x1F70, 'V'), + (0x1F71, 'M', 'ά'), + (0x1F72, 'V'), + (0x1F73, 'M', 'έ'), + (0x1F74, 'V'), + (0x1F75, 'M', 'ή'), + (0x1F76, 'V'), + (0x1F77, 'M', 'ί'), + (0x1F78, 'V'), + (0x1F79, 'M', 'ό'), + (0x1F7A, 'V'), + (0x1F7B, 'M', 'ύ'), + (0x1F7C, 'V'), + (0x1F7D, 'M', 'ώ'), + (0x1F7E, 'X'), + (0x1F80, 'M', 'ἀι'), + (0x1F81, 'M', 'ἁι'), + (0x1F82, 'M', 'ἂι'), + (0x1F83, 'M', 'ἃι'), + (0x1F84, 'M', 'ἄι'), + ] + +def _seg_20(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0x1F85, 'M', 'ἅι'), + (0x1F86, 'M', 'ἆι'), + (0x1F87, 'M', 'ἇι'), + (0x1F88, 'M', 'ἀι'), + (0x1F89, 'M', 'ἁι'), + (0x1F8A, 'M', 'ἂι'), + (0x1F8B, 'M', 'ἃι'), + (0x1F8C, 'M', 'ἄι'), + (0x1F8D, 'M', 'ἅι'), + (0x1F8E, 'M', 'ἆι'), + (0x1F8F, 'M', 'ἇι'), + (0x1F90, 'M', 'ἠι'), + (0x1F91, 'M', 'ἡι'), + (0x1F92, 'M', 'ἢι'), + (0x1F93, 'M', 'ἣι'), + (0x1F94, 'M', 'ἤι'), + (0x1F95, 'M', 'ἥι'), + (0x1F96, 'M', 'ἦι'), + (0x1F97, 'M', 'ἧι'), + (0x1F98, 'M', 'ἠι'), + (0x1F99, 'M', 'ἡι'), + (0x1F9A, 'M', 'ἢι'), + (0x1F9B, 'M', 'ἣι'), + (0x1F9C, 'M', 'ἤι'), + (0x1F9D, 'M', 'ἥι'), + (0x1F9E, 'M', 'ἦι'), + (0x1F9F, 'M', 'ἧι'), + (0x1FA0, 'M', 'ὠι'), + (0x1FA1, 'M', 'ὡι'), + (0x1FA2, 'M', 'ὢι'), + (0x1FA3, 'M', 'ὣι'), + (0x1FA4, 'M', 'ὤι'), + (0x1FA5, 'M', 'ὥι'), + (0x1FA6, 'M', 'ὦι'), + (0x1FA7, 'M', 'ὧι'), + (0x1FA8, 'M', 'ὠι'), + (0x1FA9, 'M', 'ὡι'), + (0x1FAA, 'M', 'ὢι'), + (0x1FAB, 'M', 'ὣι'), + (0x1FAC, 'M', 'ὤι'), + (0x1FAD, 'M', 'ὥι'), + (0x1FAE, 'M', 'ὦι'), + (0x1FAF, 'M', 'ὧι'), + (0x1FB0, 'V'), + (0x1FB2, 'M', 'ὰι'), + (0x1FB3, 'M', 'αι'), + (0x1FB4, 'M', 'άι'), + (0x1FB5, 'X'), + (0x1FB6, 'V'), + (0x1FB7, 'M', 'ᾶι'), + (0x1FB8, 'M', 'ᾰ'), + (0x1FB9, 'M', 'ᾱ'), + (0x1FBA, 'M', 'ὰ'), + (0x1FBB, 'M', 'ά'), + (0x1FBC, 'M', 'αι'), + (0x1FBD, '3', ' ̓'), + (0x1FBE, 'M', 'ι'), + (0x1FBF, '3', ' ̓'), + (0x1FC0, '3', ' ͂'), + (0x1FC1, '3', ' ̈͂'), + (0x1FC2, 'M', 'ὴι'), + (0x1FC3, 'M', 'ηι'), + (0x1FC4, 'M', 'ήι'), + (0x1FC5, 'X'), + (0x1FC6, 'V'), + (0x1FC7, 'M', 'ῆι'), + (0x1FC8, 'M', 'ὲ'), + (0x1FC9, 'M', 'έ'), + (0x1FCA, 'M', 'ὴ'), + (0x1FCB, 'M', 'ή'), + (0x1FCC, 'M', 'ηι'), + (0x1FCD, '3', ' ̓̀'), + (0x1FCE, '3', ' ̓́'), + (0x1FCF, '3', ' ̓͂'), + (0x1FD0, 'V'), + (0x1FD3, 'M', 'ΐ'), + (0x1FD4, 'X'), + (0x1FD6, 'V'), + (0x1FD8, 'M', 'ῐ'), + (0x1FD9, 'M', 'ῑ'), + (0x1FDA, 'M', 'ὶ'), + (0x1FDB, 'M', 'ί'), + (0x1FDC, 'X'), + (0x1FDD, '3', ' ̔̀'), + (0x1FDE, '3', ' ̔́'), + (0x1FDF, '3', ' ̔͂'), + (0x1FE0, 'V'), + (0x1FE3, 'M', 'ΰ'), + (0x1FE4, 'V'), + (0x1FE8, 'M', 'ῠ'), + (0x1FE9, 'M', 'ῡ'), + (0x1FEA, 'M', 'ὺ'), + (0x1FEB, 'M', 'ύ'), + (0x1FEC, 'M', 'ῥ'), + (0x1FED, '3', ' ̈̀'), + (0x1FEE, '3', ' ̈́'), + (0x1FEF, '3', '`'), + (0x1FF0, 'X'), + (0x1FF2, 'M', 'ὼι'), + (0x1FF3, 'M', 'ωι'), + ] + +def _seg_21(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0x1FF4, 'M', 'ώι'), + (0x1FF5, 'X'), + (0x1FF6, 'V'), + (0x1FF7, 'M', 'ῶι'), + (0x1FF8, 'M', 'ὸ'), + (0x1FF9, 'M', 'ό'), + (0x1FFA, 'M', 'ὼ'), + (0x1FFB, 'M', 'ώ'), + (0x1FFC, 'M', 'ωι'), + (0x1FFD, '3', ' ́'), + (0x1FFE, '3', ' ̔'), + (0x1FFF, 'X'), + (0x2000, '3', ' '), + (0x200B, 'I'), + (0x200C, 'D', ''), + (0x200E, 'X'), + (0x2010, 'V'), + (0x2011, 'M', '‐'), + (0x2012, 'V'), + (0x2017, '3', ' ̳'), + (0x2018, 'V'), + (0x2024, 'X'), + (0x2027, 'V'), + (0x2028, 'X'), + (0x202F, '3', ' '), + (0x2030, 'V'), + (0x2033, 'M', '′′'), + (0x2034, 'M', '′′′'), + (0x2035, 'V'), + (0x2036, 'M', '‵‵'), + (0x2037, 'M', '‵‵‵'), + (0x2038, 'V'), + (0x203C, '3', '!!'), + (0x203D, 'V'), + (0x203E, '3', ' ̅'), + (0x203F, 'V'), + (0x2047, '3', '??'), + (0x2048, '3', '?!'), + (0x2049, '3', '!?'), + (0x204A, 'V'), + (0x2057, 'M', '′′′′'), + (0x2058, 'V'), + (0x205F, '3', ' '), + (0x2060, 'I'), + (0x2061, 'X'), + (0x2064, 'I'), + (0x2065, 'X'), + (0x2070, 'M', '0'), + (0x2071, 'M', 'i'), + (0x2072, 'X'), + (0x2074, 'M', '4'), + (0x2075, 'M', '5'), + (0x2076, 'M', '6'), + (0x2077, 'M', '7'), + (0x2078, 'M', '8'), + (0x2079, 'M', '9'), + (0x207A, '3', '+'), + (0x207B, 'M', '−'), + (0x207C, '3', '='), + (0x207D, '3', '('), + (0x207E, '3', ')'), + (0x207F, 'M', 'n'), + (0x2080, 'M', '0'), + (0x2081, 'M', '1'), + (0x2082, 'M', '2'), + (0x2083, 'M', '3'), + (0x2084, 'M', '4'), + (0x2085, 'M', '5'), + (0x2086, 'M', '6'), + (0x2087, 'M', '7'), + (0x2088, 'M', '8'), + (0x2089, 'M', '9'), + (0x208A, '3', '+'), + (0x208B, 'M', '−'), + (0x208C, '3', '='), + (0x208D, '3', '('), + (0x208E, '3', ')'), + (0x208F, 'X'), + (0x2090, 'M', 'a'), + (0x2091, 'M', 'e'), + (0x2092, 'M', 'o'), + (0x2093, 'M', 'x'), + (0x2094, 'M', 'ə'), + (0x2095, 'M', 'h'), + (0x2096, 'M', 'k'), + (0x2097, 'M', 'l'), + (0x2098, 'M', 'm'), + (0x2099, 'M', 'n'), + (0x209A, 'M', 'p'), + (0x209B, 'M', 's'), + (0x209C, 'M', 't'), + (0x209D, 'X'), + (0x20A0, 'V'), + (0x20A8, 'M', 'rs'), + (0x20A9, 'V'), + (0x20C0, 'X'), + (0x20D0, 'V'), + (0x20F1, 'X'), + (0x2100, '3', 'a/c'), + (0x2101, '3', 'a/s'), + ] + +def _seg_22(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0x2102, 'M', 'c'), + (0x2103, 'M', '°c'), + (0x2104, 'V'), + (0x2105, '3', 'c/o'), + (0x2106, '3', 'c/u'), + (0x2107, 'M', 'ɛ'), + (0x2108, 'V'), + (0x2109, 'M', '°f'), + (0x210A, 'M', 'g'), + (0x210B, 'M', 'h'), + (0x210F, 'M', 'ħ'), + (0x2110, 'M', 'i'), + (0x2112, 'M', 'l'), + (0x2114, 'V'), + (0x2115, 'M', 'n'), + (0x2116, 'M', 'no'), + (0x2117, 'V'), + (0x2119, 'M', 'p'), + (0x211A, 'M', 'q'), + (0x211B, 'M', 'r'), + (0x211E, 'V'), + (0x2120, 'M', 'sm'), + (0x2121, 'M', 'tel'), + (0x2122, 'M', 'tm'), + (0x2123, 'V'), + (0x2124, 'M', 'z'), + (0x2125, 'V'), + (0x2126, 'M', 'ω'), + (0x2127, 'V'), + (0x2128, 'M', 'z'), + (0x2129, 'V'), + (0x212A, 'M', 'k'), + (0x212B, 'M', 'å'), + (0x212C, 'M', 'b'), + (0x212D, 'M', 'c'), + (0x212E, 'V'), + (0x212F, 'M', 'e'), + (0x2131, 'M', 'f'), + (0x2132, 'X'), + (0x2133, 'M', 'm'), + (0x2134, 'M', 'o'), + (0x2135, 'M', 'א'), + (0x2136, 'M', 'ב'), + (0x2137, 'M', 'ג'), + (0x2138, 'M', 'ד'), + (0x2139, 'M', 'i'), + (0x213A, 'V'), + (0x213B, 'M', 'fax'), + (0x213C, 'M', 'π'), + (0x213D, 'M', 'γ'), + (0x213F, 'M', 'π'), + (0x2140, 'M', '∑'), + (0x2141, 'V'), + (0x2145, 'M', 'd'), + (0x2147, 'M', 'e'), + (0x2148, 'M', 'i'), + (0x2149, 'M', 'j'), + (0x214A, 'V'), + (0x2150, 'M', '1⁄7'), + (0x2151, 'M', '1⁄9'), + (0x2152, 'M', '1⁄10'), + (0x2153, 'M', '1⁄3'), + (0x2154, 'M', '2⁄3'), + (0x2155, 'M', '1⁄5'), + (0x2156, 'M', '2⁄5'), + (0x2157, 'M', '3⁄5'), + (0x2158, 'M', '4⁄5'), + (0x2159, 'M', '1⁄6'), + (0x215A, 'M', '5⁄6'), + (0x215B, 'M', '1⁄8'), + (0x215C, 'M', '3⁄8'), + (0x215D, 'M', '5⁄8'), + (0x215E, 'M', '7⁄8'), + (0x215F, 'M', '1⁄'), + (0x2160, 'M', 'i'), + (0x2161, 'M', 'ii'), + (0x2162, 'M', 'iii'), + (0x2163, 'M', 'iv'), + (0x2164, 'M', 'v'), + (0x2165, 'M', 'vi'), + (0x2166, 'M', 'vii'), + (0x2167, 'M', 'viii'), + (0x2168, 'M', 'ix'), + (0x2169, 'M', 'x'), + (0x216A, 'M', 'xi'), + (0x216B, 'M', 'xii'), + (0x216C, 'M', 'l'), + (0x216D, 'M', 'c'), + (0x216E, 'M', 'd'), + (0x216F, 'M', 'm'), + (0x2170, 'M', 'i'), + (0x2171, 'M', 'ii'), + (0x2172, 'M', 'iii'), + (0x2173, 'M', 'iv'), + (0x2174, 'M', 'v'), + (0x2175, 'M', 'vi'), + (0x2176, 'M', 'vii'), + (0x2177, 'M', 'viii'), + (0x2178, 'M', 'ix'), + (0x2179, 'M', 'x'), + ] + +def _seg_23(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0x217A, 'M', 'xi'), + (0x217B, 'M', 'xii'), + (0x217C, 'M', 'l'), + (0x217D, 'M', 'c'), + (0x217E, 'M', 'd'), + (0x217F, 'M', 'm'), + (0x2180, 'V'), + (0x2183, 'X'), + (0x2184, 'V'), + (0x2189, 'M', '0⁄3'), + (0x218A, 'V'), + (0x218C, 'X'), + (0x2190, 'V'), + (0x222C, 'M', '∫∫'), + (0x222D, 'M', '∫∫∫'), + (0x222E, 'V'), + (0x222F, 'M', '∮∮'), + (0x2230, 'M', '∮∮∮'), + (0x2231, 'V'), + (0x2260, '3'), + (0x2261, 'V'), + (0x226E, '3'), + (0x2270, 'V'), + (0x2329, 'M', '〈'), + (0x232A, 'M', '〉'), + (0x232B, 'V'), + (0x2427, 'X'), + (0x2440, 'V'), + (0x244B, 'X'), + (0x2460, 'M', '1'), + (0x2461, 'M', '2'), + (0x2462, 'M', '3'), + (0x2463, 'M', '4'), + (0x2464, 'M', '5'), + (0x2465, 'M', '6'), + (0x2466, 'M', '7'), + (0x2467, 'M', '8'), + (0x2468, 'M', '9'), + (0x2469, 'M', '10'), + (0x246A, 'M', '11'), + (0x246B, 'M', '12'), + (0x246C, 'M', '13'), + (0x246D, 'M', '14'), + (0x246E, 'M', '15'), + (0x246F, 'M', '16'), + (0x2470, 'M', '17'), + (0x2471, 'M', '18'), + (0x2472, 'M', '19'), + (0x2473, 'M', '20'), + (0x2474, '3', '(1)'), + (0x2475, '3', '(2)'), + (0x2476, '3', '(3)'), + (0x2477, '3', '(4)'), + (0x2478, '3', '(5)'), + (0x2479, '3', '(6)'), + (0x247A, '3', '(7)'), + (0x247B, '3', '(8)'), + (0x247C, '3', '(9)'), + (0x247D, '3', '(10)'), + (0x247E, '3', '(11)'), + (0x247F, '3', '(12)'), + (0x2480, '3', '(13)'), + (0x2481, '3', '(14)'), + (0x2482, '3', '(15)'), + (0x2483, '3', '(16)'), + (0x2484, '3', '(17)'), + (0x2485, '3', '(18)'), + (0x2486, '3', '(19)'), + (0x2487, '3', '(20)'), + (0x2488, 'X'), + (0x249C, '3', '(a)'), + (0x249D, '3', '(b)'), + (0x249E, '3', '(c)'), + (0x249F, '3', '(d)'), + (0x24A0, '3', '(e)'), + (0x24A1, '3', '(f)'), + (0x24A2, '3', '(g)'), + (0x24A3, '3', '(h)'), + (0x24A4, '3', '(i)'), + (0x24A5, '3', '(j)'), + (0x24A6, '3', '(k)'), + (0x24A7, '3', '(l)'), + (0x24A8, '3', '(m)'), + (0x24A9, '3', '(n)'), + (0x24AA, '3', '(o)'), + (0x24AB, '3', '(p)'), + (0x24AC, '3', '(q)'), + (0x24AD, '3', '(r)'), + (0x24AE, '3', '(s)'), + (0x24AF, '3', '(t)'), + (0x24B0, '3', '(u)'), + (0x24B1, '3', '(v)'), + (0x24B2, '3', '(w)'), + (0x24B3, '3', '(x)'), + (0x24B4, '3', '(y)'), + (0x24B5, '3', '(z)'), + (0x24B6, 'M', 'a'), + (0x24B7, 'M', 'b'), + (0x24B8, 'M', 'c'), + (0x24B9, 'M', 'd'), + ] + +def _seg_24(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0x24BA, 'M', 'e'), + (0x24BB, 'M', 'f'), + (0x24BC, 'M', 'g'), + (0x24BD, 'M', 'h'), + (0x24BE, 'M', 'i'), + (0x24BF, 'M', 'j'), + (0x24C0, 'M', 'k'), + (0x24C1, 'M', 'l'), + (0x24C2, 'M', 'm'), + (0x24C3, 'M', 'n'), + (0x24C4, 'M', 'o'), + (0x24C5, 'M', 'p'), + (0x24C6, 'M', 'q'), + (0x24C7, 'M', 'r'), + (0x24C8, 'M', 's'), + (0x24C9, 'M', 't'), + (0x24CA, 'M', 'u'), + (0x24CB, 'M', 'v'), + (0x24CC, 'M', 'w'), + (0x24CD, 'M', 'x'), + (0x24CE, 'M', 'y'), + (0x24CF, 'M', 'z'), + (0x24D0, 'M', 'a'), + (0x24D1, 'M', 'b'), + (0x24D2, 'M', 'c'), + (0x24D3, 'M', 'd'), + (0x24D4, 'M', 'e'), + (0x24D5, 'M', 'f'), + (0x24D6, 'M', 'g'), + (0x24D7, 'M', 'h'), + (0x24D8, 'M', 'i'), + (0x24D9, 'M', 'j'), + (0x24DA, 'M', 'k'), + (0x24DB, 'M', 'l'), + (0x24DC, 'M', 'm'), + (0x24DD, 'M', 'n'), + (0x24DE, 'M', 'o'), + (0x24DF, 'M', 'p'), + (0x24E0, 'M', 'q'), + (0x24E1, 'M', 'r'), + (0x24E2, 'M', 's'), + (0x24E3, 'M', 't'), + (0x24E4, 'M', 'u'), + (0x24E5, 'M', 'v'), + (0x24E6, 'M', 'w'), + (0x24E7, 'M', 'x'), + (0x24E8, 'M', 'y'), + (0x24E9, 'M', 'z'), + (0x24EA, 'M', '0'), + (0x24EB, 'V'), + (0x2A0C, 'M', '∫∫∫∫'), + (0x2A0D, 'V'), + (0x2A74, '3', '::='), + (0x2A75, '3', '=='), + (0x2A76, '3', '==='), + (0x2A77, 'V'), + (0x2ADC, 'M', '⫝̸'), + (0x2ADD, 'V'), + (0x2B74, 'X'), + (0x2B76, 'V'), + (0x2B96, 'X'), + (0x2B97, 'V'), + (0x2C00, 'M', 'ⰰ'), + (0x2C01, 'M', 'ⰱ'), + (0x2C02, 'M', 'ⰲ'), + (0x2C03, 'M', 'ⰳ'), + (0x2C04, 'M', 'ⰴ'), + (0x2C05, 'M', 'ⰵ'), + (0x2C06, 'M', 'ⰶ'), + (0x2C07, 'M', 'ⰷ'), + (0x2C08, 'M', 'ⰸ'), + (0x2C09, 'M', 'ⰹ'), + (0x2C0A, 'M', 'ⰺ'), + (0x2C0B, 'M', 'ⰻ'), + (0x2C0C, 'M', 'ⰼ'), + (0x2C0D, 'M', 'ⰽ'), + (0x2C0E, 'M', 'ⰾ'), + (0x2C0F, 'M', 'ⰿ'), + (0x2C10, 'M', 'ⱀ'), + (0x2C11, 'M', 'ⱁ'), + (0x2C12, 'M', 'ⱂ'), + (0x2C13, 'M', 'ⱃ'), + (0x2C14, 'M', 'ⱄ'), + (0x2C15, 'M', 'ⱅ'), + (0x2C16, 'M', 'ⱆ'), + (0x2C17, 'M', 'ⱇ'), + (0x2C18, 'M', 'ⱈ'), + (0x2C19, 'M', 'ⱉ'), + (0x2C1A, 'M', 'ⱊ'), + (0x2C1B, 'M', 'ⱋ'), + (0x2C1C, 'M', 'ⱌ'), + (0x2C1D, 'M', 'ⱍ'), + (0x2C1E, 'M', 'ⱎ'), + (0x2C1F, 'M', 'ⱏ'), + (0x2C20, 'M', 'ⱐ'), + (0x2C21, 'M', 'ⱑ'), + (0x2C22, 'M', 'ⱒ'), + (0x2C23, 'M', 'ⱓ'), + (0x2C24, 'M', 'ⱔ'), + (0x2C25, 'M', 'ⱕ'), + ] + +def _seg_25(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0x2C26, 'M', 'ⱖ'), + (0x2C27, 'M', 'ⱗ'), + (0x2C28, 'M', 'ⱘ'), + (0x2C29, 'M', 'ⱙ'), + (0x2C2A, 'M', 'ⱚ'), + (0x2C2B, 'M', 'ⱛ'), + (0x2C2C, 'M', 'ⱜ'), + (0x2C2D, 'M', 'ⱝ'), + (0x2C2E, 'M', 'ⱞ'), + (0x2C2F, 'X'), + (0x2C30, 'V'), + (0x2C5F, 'X'), + (0x2C60, 'M', 'ⱡ'), + (0x2C61, 'V'), + (0x2C62, 'M', 'ɫ'), + (0x2C63, 'M', 'ᵽ'), + (0x2C64, 'M', 'ɽ'), + (0x2C65, 'V'), + (0x2C67, 'M', 'ⱨ'), + (0x2C68, 'V'), + (0x2C69, 'M', 'ⱪ'), + (0x2C6A, 'V'), + (0x2C6B, 'M', 'ⱬ'), + (0x2C6C, 'V'), + (0x2C6D, 'M', 'ɑ'), + (0x2C6E, 'M', 'ɱ'), + (0x2C6F, 'M', 'ɐ'), + (0x2C70, 'M', 'ɒ'), + (0x2C71, 'V'), + (0x2C72, 'M', 'ⱳ'), + (0x2C73, 'V'), + (0x2C75, 'M', 'ⱶ'), + (0x2C76, 'V'), + (0x2C7C, 'M', 'j'), + (0x2C7D, 'M', 'v'), + (0x2C7E, 'M', 'ȿ'), + (0x2C7F, 'M', 'ɀ'), + (0x2C80, 'M', 'ⲁ'), + (0x2C81, 'V'), + (0x2C82, 'M', 'ⲃ'), + (0x2C83, 'V'), + (0x2C84, 'M', 'ⲅ'), + (0x2C85, 'V'), + (0x2C86, 'M', 'ⲇ'), + (0x2C87, 'V'), + (0x2C88, 'M', 'ⲉ'), + (0x2C89, 'V'), + (0x2C8A, 'M', 'ⲋ'), + (0x2C8B, 'V'), + (0x2C8C, 'M', 'ⲍ'), + (0x2C8D, 'V'), + (0x2C8E, 'M', 'ⲏ'), + (0x2C8F, 'V'), + (0x2C90, 'M', 'ⲑ'), + (0x2C91, 'V'), + (0x2C92, 'M', 'ⲓ'), + (0x2C93, 'V'), + (0x2C94, 'M', 'ⲕ'), + (0x2C95, 'V'), + (0x2C96, 'M', 'ⲗ'), + (0x2C97, 'V'), + (0x2C98, 'M', 'ⲙ'), + (0x2C99, 'V'), + (0x2C9A, 'M', 'ⲛ'), + (0x2C9B, 'V'), + (0x2C9C, 'M', 'ⲝ'), + (0x2C9D, 'V'), + (0x2C9E, 'M', 'ⲟ'), + (0x2C9F, 'V'), + (0x2CA0, 'M', 'ⲡ'), + (0x2CA1, 'V'), + (0x2CA2, 'M', 'ⲣ'), + (0x2CA3, 'V'), + (0x2CA4, 'M', 'ⲥ'), + (0x2CA5, 'V'), + (0x2CA6, 'M', 'ⲧ'), + (0x2CA7, 'V'), + (0x2CA8, 'M', 'ⲩ'), + (0x2CA9, 'V'), + (0x2CAA, 'M', 'ⲫ'), + (0x2CAB, 'V'), + (0x2CAC, 'M', 'ⲭ'), + (0x2CAD, 'V'), + (0x2CAE, 'M', 'ⲯ'), + (0x2CAF, 'V'), + (0x2CB0, 'M', 'ⲱ'), + (0x2CB1, 'V'), + (0x2CB2, 'M', 'ⲳ'), + (0x2CB3, 'V'), + (0x2CB4, 'M', 'ⲵ'), + (0x2CB5, 'V'), + (0x2CB6, 'M', 'ⲷ'), + (0x2CB7, 'V'), + (0x2CB8, 'M', 'ⲹ'), + (0x2CB9, 'V'), + (0x2CBA, 'M', 'ⲻ'), + (0x2CBB, 'V'), + (0x2CBC, 'M', 'ⲽ'), + (0x2CBD, 'V'), + (0x2CBE, 'M', 'ⲿ'), + ] + +def _seg_26(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0x2CBF, 'V'), + (0x2CC0, 'M', 'ⳁ'), + (0x2CC1, 'V'), + (0x2CC2, 'M', 'ⳃ'), + (0x2CC3, 'V'), + (0x2CC4, 'M', 'ⳅ'), + (0x2CC5, 'V'), + (0x2CC6, 'M', 'ⳇ'), + (0x2CC7, 'V'), + (0x2CC8, 'M', 'ⳉ'), + (0x2CC9, 'V'), + (0x2CCA, 'M', 'ⳋ'), + (0x2CCB, 'V'), + (0x2CCC, 'M', 'ⳍ'), + (0x2CCD, 'V'), + (0x2CCE, 'M', 'ⳏ'), + (0x2CCF, 'V'), + (0x2CD0, 'M', 'ⳑ'), + (0x2CD1, 'V'), + (0x2CD2, 'M', 'ⳓ'), + (0x2CD3, 'V'), + (0x2CD4, 'M', 'ⳕ'), + (0x2CD5, 'V'), + (0x2CD6, 'M', 'ⳗ'), + (0x2CD7, 'V'), + (0x2CD8, 'M', 'ⳙ'), + (0x2CD9, 'V'), + (0x2CDA, 'M', 'ⳛ'), + (0x2CDB, 'V'), + (0x2CDC, 'M', 'ⳝ'), + (0x2CDD, 'V'), + (0x2CDE, 'M', 'ⳟ'), + (0x2CDF, 'V'), + (0x2CE0, 'M', 'ⳡ'), + (0x2CE1, 'V'), + (0x2CE2, 'M', 'ⳣ'), + (0x2CE3, 'V'), + (0x2CEB, 'M', 'ⳬ'), + (0x2CEC, 'V'), + (0x2CED, 'M', 'ⳮ'), + (0x2CEE, 'V'), + (0x2CF2, 'M', 'ⳳ'), + (0x2CF3, 'V'), + (0x2CF4, 'X'), + (0x2CF9, 'V'), + (0x2D26, 'X'), + (0x2D27, 'V'), + (0x2D28, 'X'), + (0x2D2D, 'V'), + (0x2D2E, 'X'), + (0x2D30, 'V'), + (0x2D68, 'X'), + (0x2D6F, 'M', 'ⵡ'), + (0x2D70, 'V'), + (0x2D71, 'X'), + (0x2D7F, 'V'), + (0x2D97, 'X'), + (0x2DA0, 'V'), + (0x2DA7, 'X'), + (0x2DA8, 'V'), + (0x2DAF, 'X'), + (0x2DB0, 'V'), + (0x2DB7, 'X'), + (0x2DB8, 'V'), + (0x2DBF, 'X'), + (0x2DC0, 'V'), + (0x2DC7, 'X'), + (0x2DC8, 'V'), + (0x2DCF, 'X'), + (0x2DD0, 'V'), + (0x2DD7, 'X'), + (0x2DD8, 'V'), + (0x2DDF, 'X'), + (0x2DE0, 'V'), + (0x2E53, 'X'), + (0x2E80, 'V'), + (0x2E9A, 'X'), + (0x2E9B, 'V'), + (0x2E9F, 'M', '母'), + (0x2EA0, 'V'), + (0x2EF3, 'M', '龟'), + (0x2EF4, 'X'), + (0x2F00, 'M', '一'), + (0x2F01, 'M', '丨'), + (0x2F02, 'M', '丶'), + (0x2F03, 'M', '丿'), + (0x2F04, 'M', '乙'), + (0x2F05, 'M', '亅'), + (0x2F06, 'M', '二'), + (0x2F07, 'M', '亠'), + (0x2F08, 'M', '人'), + (0x2F09, 'M', '儿'), + (0x2F0A, 'M', '入'), + (0x2F0B, 'M', '八'), + (0x2F0C, 'M', '冂'), + (0x2F0D, 'M', '冖'), + (0x2F0E, 'M', '冫'), + (0x2F0F, 'M', '几'), + (0x2F10, 'M', '凵'), + (0x2F11, 'M', '刀'), + ] + +def _seg_27(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0x2F12, 'M', '力'), + (0x2F13, 'M', '勹'), + (0x2F14, 'M', '匕'), + (0x2F15, 'M', '匚'), + (0x2F16, 'M', '匸'), + (0x2F17, 'M', '十'), + (0x2F18, 'M', '卜'), + (0x2F19, 'M', '卩'), + (0x2F1A, 'M', '厂'), + (0x2F1B, 'M', '厶'), + (0x2F1C, 'M', '又'), + (0x2F1D, 'M', '口'), + (0x2F1E, 'M', '囗'), + (0x2F1F, 'M', '土'), + (0x2F20, 'M', '士'), + (0x2F21, 'M', '夂'), + (0x2F22, 'M', '夊'), + (0x2F23, 'M', '夕'), + (0x2F24, 'M', '大'), + (0x2F25, 'M', '女'), + (0x2F26, 'M', '子'), + (0x2F27, 'M', '宀'), + (0x2F28, 'M', '寸'), + (0x2F29, 'M', '小'), + (0x2F2A, 'M', '尢'), + (0x2F2B, 'M', '尸'), + (0x2F2C, 'M', '屮'), + (0x2F2D, 'M', '山'), + (0x2F2E, 'M', '巛'), + (0x2F2F, 'M', '工'), + (0x2F30, 'M', '己'), + (0x2F31, 'M', '巾'), + (0x2F32, 'M', '干'), + (0x2F33, 'M', '幺'), + (0x2F34, 'M', '广'), + (0x2F35, 'M', '廴'), + (0x2F36, 'M', '廾'), + (0x2F37, 'M', '弋'), + (0x2F38, 'M', '弓'), + (0x2F39, 'M', '彐'), + (0x2F3A, 'M', '彡'), + (0x2F3B, 'M', '彳'), + (0x2F3C, 'M', '心'), + (0x2F3D, 'M', '戈'), + (0x2F3E, 'M', '戶'), + (0x2F3F, 'M', '手'), + (0x2F40, 'M', '支'), + (0x2F41, 'M', '攴'), + (0x2F42, 'M', '文'), + (0x2F43, 'M', '斗'), + (0x2F44, 'M', '斤'), + (0x2F45, 'M', '方'), + (0x2F46, 'M', '无'), + (0x2F47, 'M', '日'), + (0x2F48, 'M', '曰'), + (0x2F49, 'M', '月'), + (0x2F4A, 'M', '木'), + (0x2F4B, 'M', '欠'), + (0x2F4C, 'M', '止'), + (0x2F4D, 'M', '歹'), + (0x2F4E, 'M', '殳'), + (0x2F4F, 'M', '毋'), + (0x2F50, 'M', '比'), + (0x2F51, 'M', '毛'), + (0x2F52, 'M', '氏'), + (0x2F53, 'M', '气'), + (0x2F54, 'M', '水'), + (0x2F55, 'M', '火'), + (0x2F56, 'M', '爪'), + (0x2F57, 'M', '父'), + (0x2F58, 'M', '爻'), + (0x2F59, 'M', '爿'), + (0x2F5A, 'M', '片'), + (0x2F5B, 'M', '牙'), + (0x2F5C, 'M', '牛'), + (0x2F5D, 'M', '犬'), + (0x2F5E, 'M', '玄'), + (0x2F5F, 'M', '玉'), + (0x2F60, 'M', '瓜'), + (0x2F61, 'M', '瓦'), + (0x2F62, 'M', '甘'), + (0x2F63, 'M', '生'), + (0x2F64, 'M', '用'), + (0x2F65, 'M', '田'), + (0x2F66, 'M', '疋'), + (0x2F67, 'M', '疒'), + (0x2F68, 'M', '癶'), + (0x2F69, 'M', '白'), + (0x2F6A, 'M', '皮'), + (0x2F6B, 'M', '皿'), + (0x2F6C, 'M', '目'), + (0x2F6D, 'M', '矛'), + (0x2F6E, 'M', '矢'), + (0x2F6F, 'M', '石'), + (0x2F70, 'M', '示'), + (0x2F71, 'M', '禸'), + (0x2F72, 'M', '禾'), + (0x2F73, 'M', '穴'), + (0x2F74, 'M', '立'), + (0x2F75, 'M', '竹'), + ] + +def _seg_28(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0x2F76, 'M', '米'), + (0x2F77, 'M', '糸'), + (0x2F78, 'M', '缶'), + (0x2F79, 'M', '网'), + (0x2F7A, 'M', '羊'), + (0x2F7B, 'M', '羽'), + (0x2F7C, 'M', '老'), + (0x2F7D, 'M', '而'), + (0x2F7E, 'M', '耒'), + (0x2F7F, 'M', '耳'), + (0x2F80, 'M', '聿'), + (0x2F81, 'M', '肉'), + (0x2F82, 'M', '臣'), + (0x2F83, 'M', '自'), + (0x2F84, 'M', '至'), + (0x2F85, 'M', '臼'), + (0x2F86, 'M', '舌'), + (0x2F87, 'M', '舛'), + (0x2F88, 'M', '舟'), + (0x2F89, 'M', '艮'), + (0x2F8A, 'M', '色'), + (0x2F8B, 'M', '艸'), + (0x2F8C, 'M', '虍'), + (0x2F8D, 'M', '虫'), + (0x2F8E, 'M', '血'), + (0x2F8F, 'M', '行'), + (0x2F90, 'M', '衣'), + (0x2F91, 'M', '襾'), + (0x2F92, 'M', '見'), + (0x2F93, 'M', '角'), + (0x2F94, 'M', '言'), + (0x2F95, 'M', '谷'), + (0x2F96, 'M', '豆'), + (0x2F97, 'M', '豕'), + (0x2F98, 'M', '豸'), + (0x2F99, 'M', '貝'), + (0x2F9A, 'M', '赤'), + (0x2F9B, 'M', '走'), + (0x2F9C, 'M', '足'), + (0x2F9D, 'M', '身'), + (0x2F9E, 'M', '車'), + (0x2F9F, 'M', '辛'), + (0x2FA0, 'M', '辰'), + (0x2FA1, 'M', '辵'), + (0x2FA2, 'M', '邑'), + (0x2FA3, 'M', '酉'), + (0x2FA4, 'M', '釆'), + (0x2FA5, 'M', '里'), + (0x2FA6, 'M', '金'), + (0x2FA7, 'M', '長'), + (0x2FA8, 'M', '門'), + (0x2FA9, 'M', '阜'), + (0x2FAA, 'M', '隶'), + (0x2FAB, 'M', '隹'), + (0x2FAC, 'M', '雨'), + (0x2FAD, 'M', '靑'), + (0x2FAE, 'M', '非'), + (0x2FAF, 'M', '面'), + (0x2FB0, 'M', '革'), + (0x2FB1, 'M', '韋'), + (0x2FB2, 'M', '韭'), + (0x2FB3, 'M', '音'), + (0x2FB4, 'M', '頁'), + (0x2FB5, 'M', '風'), + (0x2FB6, 'M', '飛'), + (0x2FB7, 'M', '食'), + (0x2FB8, 'M', '首'), + (0x2FB9, 'M', '香'), + (0x2FBA, 'M', '馬'), + (0x2FBB, 'M', '骨'), + (0x2FBC, 'M', '高'), + (0x2FBD, 'M', '髟'), + (0x2FBE, 'M', '鬥'), + (0x2FBF, 'M', '鬯'), + (0x2FC0, 'M', '鬲'), + (0x2FC1, 'M', '鬼'), + (0x2FC2, 'M', '魚'), + (0x2FC3, 'M', '鳥'), + (0x2FC4, 'M', '鹵'), + (0x2FC5, 'M', '鹿'), + (0x2FC6, 'M', '麥'), + (0x2FC7, 'M', '麻'), + (0x2FC8, 'M', '黃'), + (0x2FC9, 'M', '黍'), + (0x2FCA, 'M', '黑'), + (0x2FCB, 'M', '黹'), + (0x2FCC, 'M', '黽'), + (0x2FCD, 'M', '鼎'), + (0x2FCE, 'M', '鼓'), + (0x2FCF, 'M', '鼠'), + (0x2FD0, 'M', '鼻'), + (0x2FD1, 'M', '齊'), + (0x2FD2, 'M', '齒'), + (0x2FD3, 'M', '龍'), + (0x2FD4, 'M', '龜'), + (0x2FD5, 'M', '龠'), + (0x2FD6, 'X'), + (0x3000, '3', ' '), + (0x3001, 'V'), + (0x3002, 'M', '.'), + ] + +def _seg_29(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0x3003, 'V'), + (0x3036, 'M', '〒'), + (0x3037, 'V'), + (0x3038, 'M', '十'), + (0x3039, 'M', '卄'), + (0x303A, 'M', '卅'), + (0x303B, 'V'), + (0x3040, 'X'), + (0x3041, 'V'), + (0x3097, 'X'), + (0x3099, 'V'), + (0x309B, '3', ' ゙'), + (0x309C, '3', ' ゚'), + (0x309D, 'V'), + (0x309F, 'M', 'より'), + (0x30A0, 'V'), + (0x30FF, 'M', 'コト'), + (0x3100, 'X'), + (0x3105, 'V'), + (0x3130, 'X'), + (0x3131, 'M', 'ᄀ'), + (0x3132, 'M', 'ᄁ'), + (0x3133, 'M', 'ᆪ'), + (0x3134, 'M', 'ᄂ'), + (0x3135, 'M', 'ᆬ'), + (0x3136, 'M', 'ᆭ'), + (0x3137, 'M', 'ᄃ'), + (0x3138, 'M', 'ᄄ'), + (0x3139, 'M', 'ᄅ'), + (0x313A, 'M', 'ᆰ'), + (0x313B, 'M', 'ᆱ'), + (0x313C, 'M', 'ᆲ'), + (0x313D, 'M', 'ᆳ'), + (0x313E, 'M', 'ᆴ'), + (0x313F, 'M', 'ᆵ'), + (0x3140, 'M', 'ᄚ'), + (0x3141, 'M', 'ᄆ'), + (0x3142, 'M', 'ᄇ'), + (0x3143, 'M', 'ᄈ'), + (0x3144, 'M', 'ᄡ'), + (0x3145, 'M', 'ᄉ'), + (0x3146, 'M', 'ᄊ'), + (0x3147, 'M', 'ᄋ'), + (0x3148, 'M', 'ᄌ'), + (0x3149, 'M', 'ᄍ'), + (0x314A, 'M', 'ᄎ'), + (0x314B, 'M', 'ᄏ'), + (0x314C, 'M', 'ᄐ'), + (0x314D, 'M', 'ᄑ'), + (0x314E, 'M', 'ᄒ'), + (0x314F, 'M', 'ᅡ'), + (0x3150, 'M', 'ᅢ'), + (0x3151, 'M', 'ᅣ'), + (0x3152, 'M', 'ᅤ'), + (0x3153, 'M', 'ᅥ'), + (0x3154, 'M', 'ᅦ'), + (0x3155, 'M', 'ᅧ'), + (0x3156, 'M', 'ᅨ'), + (0x3157, 'M', 'ᅩ'), + (0x3158, 'M', 'ᅪ'), + (0x3159, 'M', 'ᅫ'), + (0x315A, 'M', 'ᅬ'), + (0x315B, 'M', 'ᅭ'), + (0x315C, 'M', 'ᅮ'), + (0x315D, 'M', 'ᅯ'), + (0x315E, 'M', 'ᅰ'), + (0x315F, 'M', 'ᅱ'), + (0x3160, 'M', 'ᅲ'), + (0x3161, 'M', 'ᅳ'), + (0x3162, 'M', 'ᅴ'), + (0x3163, 'M', 'ᅵ'), + (0x3164, 'X'), + (0x3165, 'M', 'ᄔ'), + (0x3166, 'M', 'ᄕ'), + (0x3167, 'M', 'ᇇ'), + (0x3168, 'M', 'ᇈ'), + (0x3169, 'M', 'ᇌ'), + (0x316A, 'M', 'ᇎ'), + (0x316B, 'M', 'ᇓ'), + (0x316C, 'M', 'ᇗ'), + (0x316D, 'M', 'ᇙ'), + (0x316E, 'M', 'ᄜ'), + (0x316F, 'M', 'ᇝ'), + (0x3170, 'M', 'ᇟ'), + (0x3171, 'M', 'ᄝ'), + (0x3172, 'M', 'ᄞ'), + (0x3173, 'M', 'ᄠ'), + (0x3174, 'M', 'ᄢ'), + (0x3175, 'M', 'ᄣ'), + (0x3176, 'M', 'ᄧ'), + (0x3177, 'M', 'ᄩ'), + (0x3178, 'M', 'ᄫ'), + (0x3179, 'M', 'ᄬ'), + (0x317A, 'M', 'ᄭ'), + (0x317B, 'M', 'ᄮ'), + (0x317C, 'M', 'ᄯ'), + (0x317D, 'M', 'ᄲ'), + (0x317E, 'M', 'ᄶ'), + (0x317F, 'M', 'ᅀ'), + (0x3180, 'M', 'ᅇ'), + ] + +def _seg_30(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0x3181, 'M', 'ᅌ'), + (0x3182, 'M', 'ᇱ'), + (0x3183, 'M', 'ᇲ'), + (0x3184, 'M', 'ᅗ'), + (0x3185, 'M', 'ᅘ'), + (0x3186, 'M', 'ᅙ'), + (0x3187, 'M', 'ᆄ'), + (0x3188, 'M', 'ᆅ'), + (0x3189, 'M', 'ᆈ'), + (0x318A, 'M', 'ᆑ'), + (0x318B, 'M', 'ᆒ'), + (0x318C, 'M', 'ᆔ'), + (0x318D, 'M', 'ᆞ'), + (0x318E, 'M', 'ᆡ'), + (0x318F, 'X'), + (0x3190, 'V'), + (0x3192, 'M', '一'), + (0x3193, 'M', '二'), + (0x3194, 'M', '三'), + (0x3195, 'M', '四'), + (0x3196, 'M', '上'), + (0x3197, 'M', '中'), + (0x3198, 'M', '下'), + (0x3199, 'M', '甲'), + (0x319A, 'M', '乙'), + (0x319B, 'M', '丙'), + (0x319C, 'M', '丁'), + (0x319D, 'M', '天'), + (0x319E, 'M', '地'), + (0x319F, 'M', '人'), + (0x31A0, 'V'), + (0x31E4, 'X'), + (0x31F0, 'V'), + (0x3200, '3', '(ᄀ)'), + (0x3201, '3', '(ᄂ)'), + (0x3202, '3', '(ᄃ)'), + (0x3203, '3', '(ᄅ)'), + (0x3204, '3', '(ᄆ)'), + (0x3205, '3', '(ᄇ)'), + (0x3206, '3', '(ᄉ)'), + (0x3207, '3', '(ᄋ)'), + (0x3208, '3', '(ᄌ)'), + (0x3209, '3', '(ᄎ)'), + (0x320A, '3', '(ᄏ)'), + (0x320B, '3', '(ᄐ)'), + (0x320C, '3', '(ᄑ)'), + (0x320D, '3', '(ᄒ)'), + (0x320E, '3', '(가)'), + (0x320F, '3', '(나)'), + (0x3210, '3', '(다)'), + (0x3211, '3', '(라)'), + (0x3212, '3', '(마)'), + (0x3213, '3', '(바)'), + (0x3214, '3', '(사)'), + (0x3215, '3', '(아)'), + (0x3216, '3', '(자)'), + (0x3217, '3', '(차)'), + (0x3218, '3', '(카)'), + (0x3219, '3', '(타)'), + (0x321A, '3', '(파)'), + (0x321B, '3', '(하)'), + (0x321C, '3', '(주)'), + (0x321D, '3', '(오전)'), + (0x321E, '3', '(오후)'), + (0x321F, 'X'), + (0x3220, '3', '(一)'), + (0x3221, '3', '(二)'), + (0x3222, '3', '(三)'), + (0x3223, '3', '(四)'), + (0x3224, '3', '(五)'), + (0x3225, '3', '(六)'), + (0x3226, '3', '(七)'), + (0x3227, '3', '(八)'), + (0x3228, '3', '(九)'), + (0x3229, '3', '(十)'), + (0x322A, '3', '(月)'), + (0x322B, '3', '(火)'), + (0x322C, '3', '(水)'), + (0x322D, '3', '(木)'), + (0x322E, '3', '(金)'), + (0x322F, '3', '(土)'), + (0x3230, '3', '(日)'), + (0x3231, '3', '(株)'), + (0x3232, '3', '(有)'), + (0x3233, '3', '(社)'), + (0x3234, '3', '(名)'), + (0x3235, '3', '(特)'), + (0x3236, '3', '(財)'), + (0x3237, '3', '(祝)'), + (0x3238, '3', '(労)'), + (0x3239, '3', '(代)'), + (0x323A, '3', '(呼)'), + (0x323B, '3', '(学)'), + (0x323C, '3', '(監)'), + (0x323D, '3', '(企)'), + (0x323E, '3', '(資)'), + (0x323F, '3', '(協)'), + (0x3240, '3', '(祭)'), + (0x3241, '3', '(休)'), + (0x3242, '3', '(自)'), + ] + +def _seg_31(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0x3243, '3', '(至)'), + (0x3244, 'M', '問'), + (0x3245, 'M', '幼'), + (0x3246, 'M', '文'), + (0x3247, 'M', '箏'), + (0x3248, 'V'), + (0x3250, 'M', 'pte'), + (0x3251, 'M', '21'), + (0x3252, 'M', '22'), + (0x3253, 'M', '23'), + (0x3254, 'M', '24'), + (0x3255, 'M', '25'), + (0x3256, 'M', '26'), + (0x3257, 'M', '27'), + (0x3258, 'M', '28'), + (0x3259, 'M', '29'), + (0x325A, 'M', '30'), + (0x325B, 'M', '31'), + (0x325C, 'M', '32'), + (0x325D, 'M', '33'), + (0x325E, 'M', '34'), + (0x325F, 'M', '35'), + (0x3260, 'M', 'ᄀ'), + (0x3261, 'M', 'ᄂ'), + (0x3262, 'M', 'ᄃ'), + (0x3263, 'M', 'ᄅ'), + (0x3264, 'M', 'ᄆ'), + (0x3265, 'M', 'ᄇ'), + (0x3266, 'M', 'ᄉ'), + (0x3267, 'M', 'ᄋ'), + (0x3268, 'M', 'ᄌ'), + (0x3269, 'M', 'ᄎ'), + (0x326A, 'M', 'ᄏ'), + (0x326B, 'M', 'ᄐ'), + (0x326C, 'M', 'ᄑ'), + (0x326D, 'M', 'ᄒ'), + (0x326E, 'M', '가'), + (0x326F, 'M', '나'), + (0x3270, 'M', '다'), + (0x3271, 'M', '라'), + (0x3272, 'M', '마'), + (0x3273, 'M', '바'), + (0x3274, 'M', '사'), + (0x3275, 'M', '아'), + (0x3276, 'M', '자'), + (0x3277, 'M', '차'), + (0x3278, 'M', '카'), + (0x3279, 'M', '타'), + (0x327A, 'M', '파'), + (0x327B, 'M', '하'), + (0x327C, 'M', '참고'), + (0x327D, 'M', '주의'), + (0x327E, 'M', '우'), + (0x327F, 'V'), + (0x3280, 'M', '一'), + (0x3281, 'M', '二'), + (0x3282, 'M', '三'), + (0x3283, 'M', '四'), + (0x3284, 'M', '五'), + (0x3285, 'M', '六'), + (0x3286, 'M', '七'), + (0x3287, 'M', '八'), + (0x3288, 'M', '九'), + (0x3289, 'M', '十'), + (0x328A, 'M', '月'), + (0x328B, 'M', '火'), + (0x328C, 'M', '水'), + (0x328D, 'M', '木'), + (0x328E, 'M', '金'), + (0x328F, 'M', '土'), + (0x3290, 'M', '日'), + (0x3291, 'M', '株'), + (0x3292, 'M', '有'), + (0x3293, 'M', '社'), + (0x3294, 'M', '名'), + (0x3295, 'M', '特'), + (0x3296, 'M', '財'), + (0x3297, 'M', '祝'), + (0x3298, 'M', '労'), + (0x3299, 'M', '秘'), + (0x329A, 'M', '男'), + (0x329B, 'M', '女'), + (0x329C, 'M', '適'), + (0x329D, 'M', '優'), + (0x329E, 'M', '印'), + (0x329F, 'M', '注'), + (0x32A0, 'M', '項'), + (0x32A1, 'M', '休'), + (0x32A2, 'M', '写'), + (0x32A3, 'M', '正'), + (0x32A4, 'M', '上'), + (0x32A5, 'M', '中'), + (0x32A6, 'M', '下'), + (0x32A7, 'M', '左'), + (0x32A8, 'M', '右'), + (0x32A9, 'M', '医'), + (0x32AA, 'M', '宗'), + (0x32AB, 'M', '学'), + (0x32AC, 'M', '監'), + (0x32AD, 'M', '企'), + ] + +def _seg_32(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0x32AE, 'M', '資'), + (0x32AF, 'M', '協'), + (0x32B0, 'M', '夜'), + (0x32B1, 'M', '36'), + (0x32B2, 'M', '37'), + (0x32B3, 'M', '38'), + (0x32B4, 'M', '39'), + (0x32B5, 'M', '40'), + (0x32B6, 'M', '41'), + (0x32B7, 'M', '42'), + (0x32B8, 'M', '43'), + (0x32B9, 'M', '44'), + (0x32BA, 'M', '45'), + (0x32BB, 'M', '46'), + (0x32BC, 'M', '47'), + (0x32BD, 'M', '48'), + (0x32BE, 'M', '49'), + (0x32BF, 'M', '50'), + (0x32C0, 'M', '1月'), + (0x32C1, 'M', '2月'), + (0x32C2, 'M', '3月'), + (0x32C3, 'M', '4月'), + (0x32C4, 'M', '5月'), + (0x32C5, 'M', '6月'), + (0x32C6, 'M', '7月'), + (0x32C7, 'M', '8月'), + (0x32C8, 'M', '9月'), + (0x32C9, 'M', '10月'), + (0x32CA, 'M', '11月'), + (0x32CB, 'M', '12月'), + (0x32CC, 'M', 'hg'), + (0x32CD, 'M', 'erg'), + (0x32CE, 'M', 'ev'), + (0x32CF, 'M', 'ltd'), + (0x32D0, 'M', 'ア'), + (0x32D1, 'M', 'イ'), + (0x32D2, 'M', 'ウ'), + (0x32D3, 'M', 'エ'), + (0x32D4, 'M', 'オ'), + (0x32D5, 'M', 'カ'), + (0x32D6, 'M', 'キ'), + (0x32D7, 'M', 'ク'), + (0x32D8, 'M', 'ケ'), + (0x32D9, 'M', 'コ'), + (0x32DA, 'M', 'サ'), + (0x32DB, 'M', 'シ'), + (0x32DC, 'M', 'ス'), + (0x32DD, 'M', 'セ'), + (0x32DE, 'M', 'ソ'), + (0x32DF, 'M', 'タ'), + (0x32E0, 'M', 'チ'), + (0x32E1, 'M', 'ツ'), + (0x32E2, 'M', 'テ'), + (0x32E3, 'M', 'ト'), + (0x32E4, 'M', 'ナ'), + (0x32E5, 'M', 'ニ'), + (0x32E6, 'M', 'ヌ'), + (0x32E7, 'M', 'ネ'), + (0x32E8, 'M', 'ノ'), + (0x32E9, 'M', 'ハ'), + (0x32EA, 'M', 'ヒ'), + (0x32EB, 'M', 'フ'), + (0x32EC, 'M', 'ヘ'), + (0x32ED, 'M', 'ホ'), + (0x32EE, 'M', 'マ'), + (0x32EF, 'M', 'ミ'), + (0x32F0, 'M', 'ム'), + (0x32F1, 'M', 'メ'), + (0x32F2, 'M', 'モ'), + (0x32F3, 'M', 'ヤ'), + (0x32F4, 'M', 'ユ'), + (0x32F5, 'M', 'ヨ'), + (0x32F6, 'M', 'ラ'), + (0x32F7, 'M', 'リ'), + (0x32F8, 'M', 'ル'), + (0x32F9, 'M', 'レ'), + (0x32FA, 'M', 'ロ'), + (0x32FB, 'M', 'ワ'), + (0x32FC, 'M', 'ヰ'), + (0x32FD, 'M', 'ヱ'), + (0x32FE, 'M', 'ヲ'), + (0x32FF, 'M', '令和'), + (0x3300, 'M', 'アパート'), + (0x3301, 'M', 'アルファ'), + (0x3302, 'M', 'アンペア'), + (0x3303, 'M', 'アール'), + (0x3304, 'M', 'イニング'), + (0x3305, 'M', 'インチ'), + (0x3306, 'M', 'ウォン'), + (0x3307, 'M', 'エスクード'), + (0x3308, 'M', 'エーカー'), + (0x3309, 'M', 'オンス'), + (0x330A, 'M', 'オーム'), + (0x330B, 'M', 'カイリ'), + (0x330C, 'M', 'カラット'), + (0x330D, 'M', 'カロリー'), + (0x330E, 'M', 'ガロン'), + (0x330F, 'M', 'ガンマ'), + (0x3310, 'M', 'ギガ'), + (0x3311, 'M', 'ギニー'), + ] + +def _seg_33(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0x3312, 'M', 'キュリー'), + (0x3313, 'M', 'ギルダー'), + (0x3314, 'M', 'キロ'), + (0x3315, 'M', 'キログラム'), + (0x3316, 'M', 'キロメートル'), + (0x3317, 'M', 'キロワット'), + (0x3318, 'M', 'グラム'), + (0x3319, 'M', 'グラムトン'), + (0x331A, 'M', 'クルゼイロ'), + (0x331B, 'M', 'クローネ'), + (0x331C, 'M', 'ケース'), + (0x331D, 'M', 'コルナ'), + (0x331E, 'M', 'コーポ'), + (0x331F, 'M', 'サイクル'), + (0x3320, 'M', 'サンチーム'), + (0x3321, 'M', 'シリング'), + (0x3322, 'M', 'センチ'), + (0x3323, 'M', 'セント'), + (0x3324, 'M', 'ダース'), + (0x3325, 'M', 'デシ'), + (0x3326, 'M', 'ドル'), + (0x3327, 'M', 'トン'), + (0x3328, 'M', 'ナノ'), + (0x3329, 'M', 'ノット'), + (0x332A, 'M', 'ハイツ'), + (0x332B, 'M', 'パーセント'), + (0x332C, 'M', 'パーツ'), + (0x332D, 'M', 'バーレル'), + (0x332E, 'M', 'ピアストル'), + (0x332F, 'M', 'ピクル'), + (0x3330, 'M', 'ピコ'), + (0x3331, 'M', 'ビル'), + (0x3332, 'M', 'ファラッド'), + (0x3333, 'M', 'フィート'), + (0x3334, 'M', 'ブッシェル'), + (0x3335, 'M', 'フラン'), + (0x3336, 'M', 'ヘクタール'), + (0x3337, 'M', 'ペソ'), + (0x3338, 'M', 'ペニヒ'), + (0x3339, 'M', 'ヘルツ'), + (0x333A, 'M', 'ペンス'), + (0x333B, 'M', 'ページ'), + (0x333C, 'M', 'ベータ'), + (0x333D, 'M', 'ポイント'), + (0x333E, 'M', 'ボルト'), + (0x333F, 'M', 'ホン'), + (0x3340, 'M', 'ポンド'), + (0x3341, 'M', 'ホール'), + (0x3342, 'M', 'ホーン'), + (0x3343, 'M', 'マイクロ'), + (0x3344, 'M', 'マイル'), + (0x3345, 'M', 'マッハ'), + (0x3346, 'M', 'マルク'), + (0x3347, 'M', 'マンション'), + (0x3348, 'M', 'ミクロン'), + (0x3349, 'M', 'ミリ'), + (0x334A, 'M', 'ミリバール'), + (0x334B, 'M', 'メガ'), + (0x334C, 'M', 'メガトン'), + (0x334D, 'M', 'メートル'), + (0x334E, 'M', 'ヤード'), + (0x334F, 'M', 'ヤール'), + (0x3350, 'M', 'ユアン'), + (0x3351, 'M', 'リットル'), + (0x3352, 'M', 'リラ'), + (0x3353, 'M', 'ルピー'), + (0x3354, 'M', 'ルーブル'), + (0x3355, 'M', 'レム'), + (0x3356, 'M', 'レントゲン'), + (0x3357, 'M', 'ワット'), + (0x3358, 'M', '0点'), + (0x3359, 'M', '1点'), + (0x335A, 'M', '2点'), + (0x335B, 'M', '3点'), + (0x335C, 'M', '4点'), + (0x335D, 'M', '5点'), + (0x335E, 'M', '6点'), + (0x335F, 'M', '7点'), + (0x3360, 'M', '8点'), + (0x3361, 'M', '9点'), + (0x3362, 'M', '10点'), + (0x3363, 'M', '11点'), + (0x3364, 'M', '12点'), + (0x3365, 'M', '13点'), + (0x3366, 'M', '14点'), + (0x3367, 'M', '15点'), + (0x3368, 'M', '16点'), + (0x3369, 'M', '17点'), + (0x336A, 'M', '18点'), + (0x336B, 'M', '19点'), + (0x336C, 'M', '20点'), + (0x336D, 'M', '21点'), + (0x336E, 'M', '22点'), + (0x336F, 'M', '23点'), + (0x3370, 'M', '24点'), + (0x3371, 'M', 'hpa'), + (0x3372, 'M', 'da'), + (0x3373, 'M', 'au'), + (0x3374, 'M', 'bar'), + (0x3375, 'M', 'ov'), + ] + +def _seg_34(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0x3376, 'M', 'pc'), + (0x3377, 'M', 'dm'), + (0x3378, 'M', 'dm2'), + (0x3379, 'M', 'dm3'), + (0x337A, 'M', 'iu'), + (0x337B, 'M', '平成'), + (0x337C, 'M', '昭和'), + (0x337D, 'M', '大正'), + (0x337E, 'M', '明治'), + (0x337F, 'M', '株式会社'), + (0x3380, 'M', 'pa'), + (0x3381, 'M', 'na'), + (0x3382, 'M', 'μa'), + (0x3383, 'M', 'ma'), + (0x3384, 'M', 'ka'), + (0x3385, 'M', 'kb'), + (0x3386, 'M', 'mb'), + (0x3387, 'M', 'gb'), + (0x3388, 'M', 'cal'), + (0x3389, 'M', 'kcal'), + (0x338A, 'M', 'pf'), + (0x338B, 'M', 'nf'), + (0x338C, 'M', 'μf'), + (0x338D, 'M', 'μg'), + (0x338E, 'M', 'mg'), + (0x338F, 'M', 'kg'), + (0x3390, 'M', 'hz'), + (0x3391, 'M', 'khz'), + (0x3392, 'M', 'mhz'), + (0x3393, 'M', 'ghz'), + (0x3394, 'M', 'thz'), + (0x3395, 'M', 'μl'), + (0x3396, 'M', 'ml'), + (0x3397, 'M', 'dl'), + (0x3398, 'M', 'kl'), + (0x3399, 'M', 'fm'), + (0x339A, 'M', 'nm'), + (0x339B, 'M', 'μm'), + (0x339C, 'M', 'mm'), + (0x339D, 'M', 'cm'), + (0x339E, 'M', 'km'), + (0x339F, 'M', 'mm2'), + (0x33A0, 'M', 'cm2'), + (0x33A1, 'M', 'm2'), + (0x33A2, 'M', 'km2'), + (0x33A3, 'M', 'mm3'), + (0x33A4, 'M', 'cm3'), + (0x33A5, 'M', 'm3'), + (0x33A6, 'M', 'km3'), + (0x33A7, 'M', 'm∕s'), + (0x33A8, 'M', 'm∕s2'), + (0x33A9, 'M', 'pa'), + (0x33AA, 'M', 'kpa'), + (0x33AB, 'M', 'mpa'), + (0x33AC, 'M', 'gpa'), + (0x33AD, 'M', 'rad'), + (0x33AE, 'M', 'rad∕s'), + (0x33AF, 'M', 'rad∕s2'), + (0x33B0, 'M', 'ps'), + (0x33B1, 'M', 'ns'), + (0x33B2, 'M', 'μs'), + (0x33B3, 'M', 'ms'), + (0x33B4, 'M', 'pv'), + (0x33B5, 'M', 'nv'), + (0x33B6, 'M', 'μv'), + (0x33B7, 'M', 'mv'), + (0x33B8, 'M', 'kv'), + (0x33B9, 'M', 'mv'), + (0x33BA, 'M', 'pw'), + (0x33BB, 'M', 'nw'), + (0x33BC, 'M', 'μw'), + (0x33BD, 'M', 'mw'), + (0x33BE, 'M', 'kw'), + (0x33BF, 'M', 'mw'), + (0x33C0, 'M', 'kω'), + (0x33C1, 'M', 'mω'), + (0x33C2, 'X'), + (0x33C3, 'M', 'bq'), + (0x33C4, 'M', 'cc'), + (0x33C5, 'M', 'cd'), + (0x33C6, 'M', 'c∕kg'), + (0x33C7, 'X'), + (0x33C8, 'M', 'db'), + (0x33C9, 'M', 'gy'), + (0x33CA, 'M', 'ha'), + (0x33CB, 'M', 'hp'), + (0x33CC, 'M', 'in'), + (0x33CD, 'M', 'kk'), + (0x33CE, 'M', 'km'), + (0x33CF, 'M', 'kt'), + (0x33D0, 'M', 'lm'), + (0x33D1, 'M', 'ln'), + (0x33D2, 'M', 'log'), + (0x33D3, 'M', 'lx'), + (0x33D4, 'M', 'mb'), + (0x33D5, 'M', 'mil'), + (0x33D6, 'M', 'mol'), + (0x33D7, 'M', 'ph'), + (0x33D8, 'X'), + (0x33D9, 'M', 'ppm'), + ] + +def _seg_35(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0x33DA, 'M', 'pr'), + (0x33DB, 'M', 'sr'), + (0x33DC, 'M', 'sv'), + (0x33DD, 'M', 'wb'), + (0x33DE, 'M', 'v∕m'), + (0x33DF, 'M', 'a∕m'), + (0x33E0, 'M', '1日'), + (0x33E1, 'M', '2日'), + (0x33E2, 'M', '3日'), + (0x33E3, 'M', '4日'), + (0x33E4, 'M', '5日'), + (0x33E5, 'M', '6日'), + (0x33E6, 'M', '7日'), + (0x33E7, 'M', '8日'), + (0x33E8, 'M', '9日'), + (0x33E9, 'M', '10日'), + (0x33EA, 'M', '11日'), + (0x33EB, 'M', '12日'), + (0x33EC, 'M', '13日'), + (0x33ED, 'M', '14日'), + (0x33EE, 'M', '15日'), + (0x33EF, 'M', '16日'), + (0x33F0, 'M', '17日'), + (0x33F1, 'M', '18日'), + (0x33F2, 'M', '19日'), + (0x33F3, 'M', '20日'), + (0x33F4, 'M', '21日'), + (0x33F5, 'M', '22日'), + (0x33F6, 'M', '23日'), + (0x33F7, 'M', '24日'), + (0x33F8, 'M', '25日'), + (0x33F9, 'M', '26日'), + (0x33FA, 'M', '27日'), + (0x33FB, 'M', '28日'), + (0x33FC, 'M', '29日'), + (0x33FD, 'M', '30日'), + (0x33FE, 'M', '31日'), + (0x33FF, 'M', 'gal'), + (0x3400, 'V'), + (0x9FFD, 'X'), + (0xA000, 'V'), + (0xA48D, 'X'), + (0xA490, 'V'), + (0xA4C7, 'X'), + (0xA4D0, 'V'), + (0xA62C, 'X'), + (0xA640, 'M', 'ꙁ'), + (0xA641, 'V'), + (0xA642, 'M', 'ꙃ'), + (0xA643, 'V'), + (0xA644, 'M', 'ꙅ'), + (0xA645, 'V'), + (0xA646, 'M', 'ꙇ'), + (0xA647, 'V'), + (0xA648, 'M', 'ꙉ'), + (0xA649, 'V'), + (0xA64A, 'M', 'ꙋ'), + (0xA64B, 'V'), + (0xA64C, 'M', 'ꙍ'), + (0xA64D, 'V'), + (0xA64E, 'M', 'ꙏ'), + (0xA64F, 'V'), + (0xA650, 'M', 'ꙑ'), + (0xA651, 'V'), + (0xA652, 'M', 'ꙓ'), + (0xA653, 'V'), + (0xA654, 'M', 'ꙕ'), + (0xA655, 'V'), + (0xA656, 'M', 'ꙗ'), + (0xA657, 'V'), + (0xA658, 'M', 'ꙙ'), + (0xA659, 'V'), + (0xA65A, 'M', 'ꙛ'), + (0xA65B, 'V'), + (0xA65C, 'M', 'ꙝ'), + (0xA65D, 'V'), + (0xA65E, 'M', 'ꙟ'), + (0xA65F, 'V'), + (0xA660, 'M', 'ꙡ'), + (0xA661, 'V'), + (0xA662, 'M', 'ꙣ'), + (0xA663, 'V'), + (0xA664, 'M', 'ꙥ'), + (0xA665, 'V'), + (0xA666, 'M', 'ꙧ'), + (0xA667, 'V'), + (0xA668, 'M', 'ꙩ'), + (0xA669, 'V'), + (0xA66A, 'M', 'ꙫ'), + (0xA66B, 'V'), + (0xA66C, 'M', 'ꙭ'), + (0xA66D, 'V'), + (0xA680, 'M', 'ꚁ'), + (0xA681, 'V'), + (0xA682, 'M', 'ꚃ'), + (0xA683, 'V'), + (0xA684, 'M', 'ꚅ'), + (0xA685, 'V'), + (0xA686, 'M', 'ꚇ'), + (0xA687, 'V'), + ] + +def _seg_36(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0xA688, 'M', 'ꚉ'), + (0xA689, 'V'), + (0xA68A, 'M', 'ꚋ'), + (0xA68B, 'V'), + (0xA68C, 'M', 'ꚍ'), + (0xA68D, 'V'), + (0xA68E, 'M', 'ꚏ'), + (0xA68F, 'V'), + (0xA690, 'M', 'ꚑ'), + (0xA691, 'V'), + (0xA692, 'M', 'ꚓ'), + (0xA693, 'V'), + (0xA694, 'M', 'ꚕ'), + (0xA695, 'V'), + (0xA696, 'M', 'ꚗ'), + (0xA697, 'V'), + (0xA698, 'M', 'ꚙ'), + (0xA699, 'V'), + (0xA69A, 'M', 'ꚛ'), + (0xA69B, 'V'), + (0xA69C, 'M', 'ъ'), + (0xA69D, 'M', 'ь'), + (0xA69E, 'V'), + (0xA6F8, 'X'), + (0xA700, 'V'), + (0xA722, 'M', 'ꜣ'), + (0xA723, 'V'), + (0xA724, 'M', 'ꜥ'), + (0xA725, 'V'), + (0xA726, 'M', 'ꜧ'), + (0xA727, 'V'), + (0xA728, 'M', 'ꜩ'), + (0xA729, 'V'), + (0xA72A, 'M', 'ꜫ'), + (0xA72B, 'V'), + (0xA72C, 'M', 'ꜭ'), + (0xA72D, 'V'), + (0xA72E, 'M', 'ꜯ'), + (0xA72F, 'V'), + (0xA732, 'M', 'ꜳ'), + (0xA733, 'V'), + (0xA734, 'M', 'ꜵ'), + (0xA735, 'V'), + (0xA736, 'M', 'ꜷ'), + (0xA737, 'V'), + (0xA738, 'M', 'ꜹ'), + (0xA739, 'V'), + (0xA73A, 'M', 'ꜻ'), + (0xA73B, 'V'), + (0xA73C, 'M', 'ꜽ'), + (0xA73D, 'V'), + (0xA73E, 'M', 'ꜿ'), + (0xA73F, 'V'), + (0xA740, 'M', 'ꝁ'), + (0xA741, 'V'), + (0xA742, 'M', 'ꝃ'), + (0xA743, 'V'), + (0xA744, 'M', 'ꝅ'), + (0xA745, 'V'), + (0xA746, 'M', 'ꝇ'), + (0xA747, 'V'), + (0xA748, 'M', 'ꝉ'), + (0xA749, 'V'), + (0xA74A, 'M', 'ꝋ'), + (0xA74B, 'V'), + (0xA74C, 'M', 'ꝍ'), + (0xA74D, 'V'), + (0xA74E, 'M', 'ꝏ'), + (0xA74F, 'V'), + (0xA750, 'M', 'ꝑ'), + (0xA751, 'V'), + (0xA752, 'M', 'ꝓ'), + (0xA753, 'V'), + (0xA754, 'M', 'ꝕ'), + (0xA755, 'V'), + (0xA756, 'M', 'ꝗ'), + (0xA757, 'V'), + (0xA758, 'M', 'ꝙ'), + (0xA759, 'V'), + (0xA75A, 'M', 'ꝛ'), + (0xA75B, 'V'), + (0xA75C, 'M', 'ꝝ'), + (0xA75D, 'V'), + (0xA75E, 'M', 'ꝟ'), + (0xA75F, 'V'), + (0xA760, 'M', 'ꝡ'), + (0xA761, 'V'), + (0xA762, 'M', 'ꝣ'), + (0xA763, 'V'), + (0xA764, 'M', 'ꝥ'), + (0xA765, 'V'), + (0xA766, 'M', 'ꝧ'), + (0xA767, 'V'), + (0xA768, 'M', 'ꝩ'), + (0xA769, 'V'), + (0xA76A, 'M', 'ꝫ'), + (0xA76B, 'V'), + (0xA76C, 'M', 'ꝭ'), + (0xA76D, 'V'), + (0xA76E, 'M', 'ꝯ'), + ] + +def _seg_37(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0xA76F, 'V'), + (0xA770, 'M', 'ꝯ'), + (0xA771, 'V'), + (0xA779, 'M', 'ꝺ'), + (0xA77A, 'V'), + (0xA77B, 'M', 'ꝼ'), + (0xA77C, 'V'), + (0xA77D, 'M', 'ᵹ'), + (0xA77E, 'M', 'ꝿ'), + (0xA77F, 'V'), + (0xA780, 'M', 'ꞁ'), + (0xA781, 'V'), + (0xA782, 'M', 'ꞃ'), + (0xA783, 'V'), + (0xA784, 'M', 'ꞅ'), + (0xA785, 'V'), + (0xA786, 'M', 'ꞇ'), + (0xA787, 'V'), + (0xA78B, 'M', 'ꞌ'), + (0xA78C, 'V'), + (0xA78D, 'M', 'ɥ'), + (0xA78E, 'V'), + (0xA790, 'M', 'ꞑ'), + (0xA791, 'V'), + (0xA792, 'M', 'ꞓ'), + (0xA793, 'V'), + (0xA796, 'M', 'ꞗ'), + (0xA797, 'V'), + (0xA798, 'M', 'ꞙ'), + (0xA799, 'V'), + (0xA79A, 'M', 'ꞛ'), + (0xA79B, 'V'), + (0xA79C, 'M', 'ꞝ'), + (0xA79D, 'V'), + (0xA79E, 'M', 'ꞟ'), + (0xA79F, 'V'), + (0xA7A0, 'M', 'ꞡ'), + (0xA7A1, 'V'), + (0xA7A2, 'M', 'ꞣ'), + (0xA7A3, 'V'), + (0xA7A4, 'M', 'ꞥ'), + (0xA7A5, 'V'), + (0xA7A6, 'M', 'ꞧ'), + (0xA7A7, 'V'), + (0xA7A8, 'M', 'ꞩ'), + (0xA7A9, 'V'), + (0xA7AA, 'M', 'ɦ'), + (0xA7AB, 'M', 'ɜ'), + (0xA7AC, 'M', 'ɡ'), + (0xA7AD, 'M', 'ɬ'), + (0xA7AE, 'M', 'ɪ'), + (0xA7AF, 'V'), + (0xA7B0, 'M', 'ʞ'), + (0xA7B1, 'M', 'ʇ'), + (0xA7B2, 'M', 'ʝ'), + (0xA7B3, 'M', 'ꭓ'), + (0xA7B4, 'M', 'ꞵ'), + (0xA7B5, 'V'), + (0xA7B6, 'M', 'ꞷ'), + (0xA7B7, 'V'), + (0xA7B8, 'M', 'ꞹ'), + (0xA7B9, 'V'), + (0xA7BA, 'M', 'ꞻ'), + (0xA7BB, 'V'), + (0xA7BC, 'M', 'ꞽ'), + (0xA7BD, 'V'), + (0xA7BE, 'M', 'ꞿ'), + (0xA7BF, 'V'), + (0xA7C0, 'X'), + (0xA7C2, 'M', 'ꟃ'), + (0xA7C3, 'V'), + (0xA7C4, 'M', 'ꞔ'), + (0xA7C5, 'M', 'ʂ'), + (0xA7C6, 'M', 'ᶎ'), + (0xA7C7, 'M', 'ꟈ'), + (0xA7C8, 'V'), + (0xA7C9, 'M', 'ꟊ'), + (0xA7CA, 'V'), + (0xA7CB, 'X'), + (0xA7F5, 'M', 'ꟶ'), + (0xA7F6, 'V'), + (0xA7F8, 'M', 'ħ'), + (0xA7F9, 'M', 'œ'), + (0xA7FA, 'V'), + (0xA82D, 'X'), + (0xA830, 'V'), + (0xA83A, 'X'), + (0xA840, 'V'), + (0xA878, 'X'), + (0xA880, 'V'), + (0xA8C6, 'X'), + (0xA8CE, 'V'), + (0xA8DA, 'X'), + (0xA8E0, 'V'), + (0xA954, 'X'), + (0xA95F, 'V'), + (0xA97D, 'X'), + (0xA980, 'V'), + (0xA9CE, 'X'), + (0xA9CF, 'V'), + ] + +def _seg_38(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0xA9DA, 'X'), + (0xA9DE, 'V'), + (0xA9FF, 'X'), + (0xAA00, 'V'), + (0xAA37, 'X'), + (0xAA40, 'V'), + (0xAA4E, 'X'), + (0xAA50, 'V'), + (0xAA5A, 'X'), + (0xAA5C, 'V'), + (0xAAC3, 'X'), + (0xAADB, 'V'), + (0xAAF7, 'X'), + (0xAB01, 'V'), + (0xAB07, 'X'), + (0xAB09, 'V'), + (0xAB0F, 'X'), + (0xAB11, 'V'), + (0xAB17, 'X'), + (0xAB20, 'V'), + (0xAB27, 'X'), + (0xAB28, 'V'), + (0xAB2F, 'X'), + (0xAB30, 'V'), + (0xAB5C, 'M', 'ꜧ'), + (0xAB5D, 'M', 'ꬷ'), + (0xAB5E, 'M', 'ɫ'), + (0xAB5F, 'M', 'ꭒ'), + (0xAB60, 'V'), + (0xAB69, 'M', 'ʍ'), + (0xAB6A, 'V'), + (0xAB6C, 'X'), + (0xAB70, 'M', 'Ꭰ'), + (0xAB71, 'M', 'Ꭱ'), + (0xAB72, 'M', 'Ꭲ'), + (0xAB73, 'M', 'Ꭳ'), + (0xAB74, 'M', 'Ꭴ'), + (0xAB75, 'M', 'Ꭵ'), + (0xAB76, 'M', 'Ꭶ'), + (0xAB77, 'M', 'Ꭷ'), + (0xAB78, 'M', 'Ꭸ'), + (0xAB79, 'M', 'Ꭹ'), + (0xAB7A, 'M', 'Ꭺ'), + (0xAB7B, 'M', 'Ꭻ'), + (0xAB7C, 'M', 'Ꭼ'), + (0xAB7D, 'M', 'Ꭽ'), + (0xAB7E, 'M', 'Ꭾ'), + (0xAB7F, 'M', 'Ꭿ'), + (0xAB80, 'M', 'Ꮀ'), + (0xAB81, 'M', 'Ꮁ'), + (0xAB82, 'M', 'Ꮂ'), + (0xAB83, 'M', 'Ꮃ'), + (0xAB84, 'M', 'Ꮄ'), + (0xAB85, 'M', 'Ꮅ'), + (0xAB86, 'M', 'Ꮆ'), + (0xAB87, 'M', 'Ꮇ'), + (0xAB88, 'M', 'Ꮈ'), + (0xAB89, 'M', 'Ꮉ'), + (0xAB8A, 'M', 'Ꮊ'), + (0xAB8B, 'M', 'Ꮋ'), + (0xAB8C, 'M', 'Ꮌ'), + (0xAB8D, 'M', 'Ꮍ'), + (0xAB8E, 'M', 'Ꮎ'), + (0xAB8F, 'M', 'Ꮏ'), + (0xAB90, 'M', 'Ꮐ'), + (0xAB91, 'M', 'Ꮑ'), + (0xAB92, 'M', 'Ꮒ'), + (0xAB93, 'M', 'Ꮓ'), + (0xAB94, 'M', 'Ꮔ'), + (0xAB95, 'M', 'Ꮕ'), + (0xAB96, 'M', 'Ꮖ'), + (0xAB97, 'M', 'Ꮗ'), + (0xAB98, 'M', 'Ꮘ'), + (0xAB99, 'M', 'Ꮙ'), + (0xAB9A, 'M', 'Ꮚ'), + (0xAB9B, 'M', 'Ꮛ'), + (0xAB9C, 'M', 'Ꮜ'), + (0xAB9D, 'M', 'Ꮝ'), + (0xAB9E, 'M', 'Ꮞ'), + (0xAB9F, 'M', 'Ꮟ'), + (0xABA0, 'M', 'Ꮠ'), + (0xABA1, 'M', 'Ꮡ'), + (0xABA2, 'M', 'Ꮢ'), + (0xABA3, 'M', 'Ꮣ'), + (0xABA4, 'M', 'Ꮤ'), + (0xABA5, 'M', 'Ꮥ'), + (0xABA6, 'M', 'Ꮦ'), + (0xABA7, 'M', 'Ꮧ'), + (0xABA8, 'M', 'Ꮨ'), + (0xABA9, 'M', 'Ꮩ'), + (0xABAA, 'M', 'Ꮪ'), + (0xABAB, 'M', 'Ꮫ'), + (0xABAC, 'M', 'Ꮬ'), + (0xABAD, 'M', 'Ꮭ'), + (0xABAE, 'M', 'Ꮮ'), + (0xABAF, 'M', 'Ꮯ'), + (0xABB0, 'M', 'Ꮰ'), + (0xABB1, 'M', 'Ꮱ'), + (0xABB2, 'M', 'Ꮲ'), + (0xABB3, 'M', 'Ꮳ'), + ] + +def _seg_39(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0xABB4, 'M', 'Ꮴ'), + (0xABB5, 'M', 'Ꮵ'), + (0xABB6, 'M', 'Ꮶ'), + (0xABB7, 'M', 'Ꮷ'), + (0xABB8, 'M', 'Ꮸ'), + (0xABB9, 'M', 'Ꮹ'), + (0xABBA, 'M', 'Ꮺ'), + (0xABBB, 'M', 'Ꮻ'), + (0xABBC, 'M', 'Ꮼ'), + (0xABBD, 'M', 'Ꮽ'), + (0xABBE, 'M', 'Ꮾ'), + (0xABBF, 'M', 'Ꮿ'), + (0xABC0, 'V'), + (0xABEE, 'X'), + (0xABF0, 'V'), + (0xABFA, 'X'), + (0xAC00, 'V'), + (0xD7A4, 'X'), + (0xD7B0, 'V'), + (0xD7C7, 'X'), + (0xD7CB, 'V'), + (0xD7FC, 'X'), + (0xF900, 'M', '豈'), + (0xF901, 'M', '更'), + (0xF902, 'M', '車'), + (0xF903, 'M', '賈'), + (0xF904, 'M', '滑'), + (0xF905, 'M', '串'), + (0xF906, 'M', '句'), + (0xF907, 'M', '龜'), + (0xF909, 'M', '契'), + (0xF90A, 'M', '金'), + (0xF90B, 'M', '喇'), + (0xF90C, 'M', '奈'), + (0xF90D, 'M', '懶'), + (0xF90E, 'M', '癩'), + (0xF90F, 'M', '羅'), + (0xF910, 'M', '蘿'), + (0xF911, 'M', '螺'), + (0xF912, 'M', '裸'), + (0xF913, 'M', '邏'), + (0xF914, 'M', '樂'), + (0xF915, 'M', '洛'), + (0xF916, 'M', '烙'), + (0xF917, 'M', '珞'), + (0xF918, 'M', '落'), + (0xF919, 'M', '酪'), + (0xF91A, 'M', '駱'), + (0xF91B, 'M', '亂'), + (0xF91C, 'M', '卵'), + (0xF91D, 'M', '欄'), + (0xF91E, 'M', '爛'), + (0xF91F, 'M', '蘭'), + (0xF920, 'M', '鸞'), + (0xF921, 'M', '嵐'), + (0xF922, 'M', '濫'), + (0xF923, 'M', '藍'), + (0xF924, 'M', '襤'), + (0xF925, 'M', '拉'), + (0xF926, 'M', '臘'), + (0xF927, 'M', '蠟'), + (0xF928, 'M', '廊'), + (0xF929, 'M', '朗'), + (0xF92A, 'M', '浪'), + (0xF92B, 'M', '狼'), + (0xF92C, 'M', '郎'), + (0xF92D, 'M', '來'), + (0xF92E, 'M', '冷'), + (0xF92F, 'M', '勞'), + (0xF930, 'M', '擄'), + (0xF931, 'M', '櫓'), + (0xF932, 'M', '爐'), + (0xF933, 'M', '盧'), + (0xF934, 'M', '老'), + (0xF935, 'M', '蘆'), + (0xF936, 'M', '虜'), + (0xF937, 'M', '路'), + (0xF938, 'M', '露'), + (0xF939, 'M', '魯'), + (0xF93A, 'M', '鷺'), + (0xF93B, 'M', '碌'), + (0xF93C, 'M', '祿'), + (0xF93D, 'M', '綠'), + (0xF93E, 'M', '菉'), + (0xF93F, 'M', '錄'), + (0xF940, 'M', '鹿'), + (0xF941, 'M', '論'), + (0xF942, 'M', '壟'), + (0xF943, 'M', '弄'), + (0xF944, 'M', '籠'), + (0xF945, 'M', '聾'), + (0xF946, 'M', '牢'), + (0xF947, 'M', '磊'), + (0xF948, 'M', '賂'), + (0xF949, 'M', '雷'), + (0xF94A, 'M', '壘'), + (0xF94B, 'M', '屢'), + (0xF94C, 'M', '樓'), + (0xF94D, 'M', '淚'), + (0xF94E, 'M', '漏'), + ] + +def _seg_40(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0xF94F, 'M', '累'), + (0xF950, 'M', '縷'), + (0xF951, 'M', '陋'), + (0xF952, 'M', '勒'), + (0xF953, 'M', '肋'), + (0xF954, 'M', '凜'), + (0xF955, 'M', '凌'), + (0xF956, 'M', '稜'), + (0xF957, 'M', '綾'), + (0xF958, 'M', '菱'), + (0xF959, 'M', '陵'), + (0xF95A, 'M', '讀'), + (0xF95B, 'M', '拏'), + (0xF95C, 'M', '樂'), + (0xF95D, 'M', '諾'), + (0xF95E, 'M', '丹'), + (0xF95F, 'M', '寧'), + (0xF960, 'M', '怒'), + (0xF961, 'M', '率'), + (0xF962, 'M', '異'), + (0xF963, 'M', '北'), + (0xF964, 'M', '磻'), + (0xF965, 'M', '便'), + (0xF966, 'M', '復'), + (0xF967, 'M', '不'), + (0xF968, 'M', '泌'), + (0xF969, 'M', '數'), + (0xF96A, 'M', '索'), + (0xF96B, 'M', '參'), + (0xF96C, 'M', '塞'), + (0xF96D, 'M', '省'), + (0xF96E, 'M', '葉'), + (0xF96F, 'M', '說'), + (0xF970, 'M', '殺'), + (0xF971, 'M', '辰'), + (0xF972, 'M', '沈'), + (0xF973, 'M', '拾'), + (0xF974, 'M', '若'), + (0xF975, 'M', '掠'), + (0xF976, 'M', '略'), + (0xF977, 'M', '亮'), + (0xF978, 'M', '兩'), + (0xF979, 'M', '凉'), + (0xF97A, 'M', '梁'), + (0xF97B, 'M', '糧'), + (0xF97C, 'M', '良'), + (0xF97D, 'M', '諒'), + (0xF97E, 'M', '量'), + (0xF97F, 'M', '勵'), + (0xF980, 'M', '呂'), + (0xF981, 'M', '女'), + (0xF982, 'M', '廬'), + (0xF983, 'M', '旅'), + (0xF984, 'M', '濾'), + (0xF985, 'M', '礪'), + (0xF986, 'M', '閭'), + (0xF987, 'M', '驪'), + (0xF988, 'M', '麗'), + (0xF989, 'M', '黎'), + (0xF98A, 'M', '力'), + (0xF98B, 'M', '曆'), + (0xF98C, 'M', '歷'), + (0xF98D, 'M', '轢'), + (0xF98E, 'M', '年'), + (0xF98F, 'M', '憐'), + (0xF990, 'M', '戀'), + (0xF991, 'M', '撚'), + (0xF992, 'M', '漣'), + (0xF993, 'M', '煉'), + (0xF994, 'M', '璉'), + (0xF995, 'M', '秊'), + (0xF996, 'M', '練'), + (0xF997, 'M', '聯'), + (0xF998, 'M', '輦'), + (0xF999, 'M', '蓮'), + (0xF99A, 'M', '連'), + (0xF99B, 'M', '鍊'), + (0xF99C, 'M', '列'), + (0xF99D, 'M', '劣'), + (0xF99E, 'M', '咽'), + (0xF99F, 'M', '烈'), + (0xF9A0, 'M', '裂'), + (0xF9A1, 'M', '說'), + (0xF9A2, 'M', '廉'), + (0xF9A3, 'M', '念'), + (0xF9A4, 'M', '捻'), + (0xF9A5, 'M', '殮'), + (0xF9A6, 'M', '簾'), + (0xF9A7, 'M', '獵'), + (0xF9A8, 'M', '令'), + (0xF9A9, 'M', '囹'), + (0xF9AA, 'M', '寧'), + (0xF9AB, 'M', '嶺'), + (0xF9AC, 'M', '怜'), + (0xF9AD, 'M', '玲'), + (0xF9AE, 'M', '瑩'), + (0xF9AF, 'M', '羚'), + (0xF9B0, 'M', '聆'), + (0xF9B1, 'M', '鈴'), + (0xF9B2, 'M', '零'), + ] + +def _seg_41(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0xF9B3, 'M', '靈'), + (0xF9B4, 'M', '領'), + (0xF9B5, 'M', '例'), + (0xF9B6, 'M', '禮'), + (0xF9B7, 'M', '醴'), + (0xF9B8, 'M', '隸'), + (0xF9B9, 'M', '惡'), + (0xF9BA, 'M', '了'), + (0xF9BB, 'M', '僚'), + (0xF9BC, 'M', '寮'), + (0xF9BD, 'M', '尿'), + (0xF9BE, 'M', '料'), + (0xF9BF, 'M', '樂'), + (0xF9C0, 'M', '燎'), + (0xF9C1, 'M', '療'), + (0xF9C2, 'M', '蓼'), + (0xF9C3, 'M', '遼'), + (0xF9C4, 'M', '龍'), + (0xF9C5, 'M', '暈'), + (0xF9C6, 'M', '阮'), + (0xF9C7, 'M', '劉'), + (0xF9C8, 'M', '杻'), + (0xF9C9, 'M', '柳'), + (0xF9CA, 'M', '流'), + (0xF9CB, 'M', '溜'), + (0xF9CC, 'M', '琉'), + (0xF9CD, 'M', '留'), + (0xF9CE, 'M', '硫'), + (0xF9CF, 'M', '紐'), + (0xF9D0, 'M', '類'), + (0xF9D1, 'M', '六'), + (0xF9D2, 'M', '戮'), + (0xF9D3, 'M', '陸'), + (0xF9D4, 'M', '倫'), + (0xF9D5, 'M', '崙'), + (0xF9D6, 'M', '淪'), + (0xF9D7, 'M', '輪'), + (0xF9D8, 'M', '律'), + (0xF9D9, 'M', '慄'), + (0xF9DA, 'M', '栗'), + (0xF9DB, 'M', '率'), + (0xF9DC, 'M', '隆'), + (0xF9DD, 'M', '利'), + (0xF9DE, 'M', '吏'), + (0xF9DF, 'M', '履'), + (0xF9E0, 'M', '易'), + (0xF9E1, 'M', '李'), + (0xF9E2, 'M', '梨'), + (0xF9E3, 'M', '泥'), + (0xF9E4, 'M', '理'), + (0xF9E5, 'M', '痢'), + (0xF9E6, 'M', '罹'), + (0xF9E7, 'M', '裏'), + (0xF9E8, 'M', '裡'), + (0xF9E9, 'M', '里'), + (0xF9EA, 'M', '離'), + (0xF9EB, 'M', '匿'), + (0xF9EC, 'M', '溺'), + (0xF9ED, 'M', '吝'), + (0xF9EE, 'M', '燐'), + (0xF9EF, 'M', '璘'), + (0xF9F0, 'M', '藺'), + (0xF9F1, 'M', '隣'), + (0xF9F2, 'M', '鱗'), + (0xF9F3, 'M', '麟'), + (0xF9F4, 'M', '林'), + (0xF9F5, 'M', '淋'), + (0xF9F6, 'M', '臨'), + (0xF9F7, 'M', '立'), + (0xF9F8, 'M', '笠'), + (0xF9F9, 'M', '粒'), + (0xF9FA, 'M', '狀'), + (0xF9FB, 'M', '炙'), + (0xF9FC, 'M', '識'), + (0xF9FD, 'M', '什'), + (0xF9FE, 'M', '茶'), + (0xF9FF, 'M', '刺'), + (0xFA00, 'M', '切'), + (0xFA01, 'M', '度'), + (0xFA02, 'M', '拓'), + (0xFA03, 'M', '糖'), + (0xFA04, 'M', '宅'), + (0xFA05, 'M', '洞'), + (0xFA06, 'M', '暴'), + (0xFA07, 'M', '輻'), + (0xFA08, 'M', '行'), + (0xFA09, 'M', '降'), + (0xFA0A, 'M', '見'), + (0xFA0B, 'M', '廓'), + (0xFA0C, 'M', '兀'), + (0xFA0D, 'M', '嗀'), + (0xFA0E, 'V'), + (0xFA10, 'M', '塚'), + (0xFA11, 'V'), + (0xFA12, 'M', '晴'), + (0xFA13, 'V'), + (0xFA15, 'M', '凞'), + (0xFA16, 'M', '猪'), + (0xFA17, 'M', '益'), + (0xFA18, 'M', '礼'), + ] + +def _seg_42(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0xFA19, 'M', '神'), + (0xFA1A, 'M', '祥'), + (0xFA1B, 'M', '福'), + (0xFA1C, 'M', '靖'), + (0xFA1D, 'M', '精'), + (0xFA1E, 'M', '羽'), + (0xFA1F, 'V'), + (0xFA20, 'M', '蘒'), + (0xFA21, 'V'), + (0xFA22, 'M', '諸'), + (0xFA23, 'V'), + (0xFA25, 'M', '逸'), + (0xFA26, 'M', '都'), + (0xFA27, 'V'), + (0xFA2A, 'M', '飯'), + (0xFA2B, 'M', '飼'), + (0xFA2C, 'M', '館'), + (0xFA2D, 'M', '鶴'), + (0xFA2E, 'M', '郞'), + (0xFA2F, 'M', '隷'), + (0xFA30, 'M', '侮'), + (0xFA31, 'M', '僧'), + (0xFA32, 'M', '免'), + (0xFA33, 'M', '勉'), + (0xFA34, 'M', '勤'), + (0xFA35, 'M', '卑'), + (0xFA36, 'M', '喝'), + (0xFA37, 'M', '嘆'), + (0xFA38, 'M', '器'), + (0xFA39, 'M', '塀'), + (0xFA3A, 'M', '墨'), + (0xFA3B, 'M', '層'), + (0xFA3C, 'M', '屮'), + (0xFA3D, 'M', '悔'), + (0xFA3E, 'M', '慨'), + (0xFA3F, 'M', '憎'), + (0xFA40, 'M', '懲'), + (0xFA41, 'M', '敏'), + (0xFA42, 'M', '既'), + (0xFA43, 'M', '暑'), + (0xFA44, 'M', '梅'), + (0xFA45, 'M', '海'), + (0xFA46, 'M', '渚'), + (0xFA47, 'M', '漢'), + (0xFA48, 'M', '煮'), + (0xFA49, 'M', '爫'), + (0xFA4A, 'M', '琢'), + (0xFA4B, 'M', '碑'), + (0xFA4C, 'M', '社'), + (0xFA4D, 'M', '祉'), + (0xFA4E, 'M', '祈'), + (0xFA4F, 'M', '祐'), + (0xFA50, 'M', '祖'), + (0xFA51, 'M', '祝'), + (0xFA52, 'M', '禍'), + (0xFA53, 'M', '禎'), + (0xFA54, 'M', '穀'), + (0xFA55, 'M', '突'), + (0xFA56, 'M', '節'), + (0xFA57, 'M', '練'), + (0xFA58, 'M', '縉'), + (0xFA59, 'M', '繁'), + (0xFA5A, 'M', '署'), + (0xFA5B, 'M', '者'), + (0xFA5C, 'M', '臭'), + (0xFA5D, 'M', '艹'), + (0xFA5F, 'M', '著'), + (0xFA60, 'M', '褐'), + (0xFA61, 'M', '視'), + (0xFA62, 'M', '謁'), + (0xFA63, 'M', '謹'), + (0xFA64, 'M', '賓'), + (0xFA65, 'M', '贈'), + (0xFA66, 'M', '辶'), + (0xFA67, 'M', '逸'), + (0xFA68, 'M', '難'), + (0xFA69, 'M', '響'), + (0xFA6A, 'M', '頻'), + (0xFA6B, 'M', '恵'), + (0xFA6C, 'M', '𤋮'), + (0xFA6D, 'M', '舘'), + (0xFA6E, 'X'), + (0xFA70, 'M', '並'), + (0xFA71, 'M', '况'), + (0xFA72, 'M', '全'), + (0xFA73, 'M', '侀'), + (0xFA74, 'M', '充'), + (0xFA75, 'M', '冀'), + (0xFA76, 'M', '勇'), + (0xFA77, 'M', '勺'), + (0xFA78, 'M', '喝'), + (0xFA79, 'M', '啕'), + (0xFA7A, 'M', '喙'), + (0xFA7B, 'M', '嗢'), + (0xFA7C, 'M', '塚'), + (0xFA7D, 'M', '墳'), + (0xFA7E, 'M', '奄'), + (0xFA7F, 'M', '奔'), + (0xFA80, 'M', '婢'), + (0xFA81, 'M', '嬨'), + ] + +def _seg_43(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0xFA82, 'M', '廒'), + (0xFA83, 'M', '廙'), + (0xFA84, 'M', '彩'), + (0xFA85, 'M', '徭'), + (0xFA86, 'M', '惘'), + (0xFA87, 'M', '慎'), + (0xFA88, 'M', '愈'), + (0xFA89, 'M', '憎'), + (0xFA8A, 'M', '慠'), + (0xFA8B, 'M', '懲'), + (0xFA8C, 'M', '戴'), + (0xFA8D, 'M', '揄'), + (0xFA8E, 'M', '搜'), + (0xFA8F, 'M', '摒'), + (0xFA90, 'M', '敖'), + (0xFA91, 'M', '晴'), + (0xFA92, 'M', '朗'), + (0xFA93, 'M', '望'), + (0xFA94, 'M', '杖'), + (0xFA95, 'M', '歹'), + (0xFA96, 'M', '殺'), + (0xFA97, 'M', '流'), + (0xFA98, 'M', '滛'), + (0xFA99, 'M', '滋'), + (0xFA9A, 'M', '漢'), + (0xFA9B, 'M', '瀞'), + (0xFA9C, 'M', '煮'), + (0xFA9D, 'M', '瞧'), + (0xFA9E, 'M', '爵'), + (0xFA9F, 'M', '犯'), + (0xFAA0, 'M', '猪'), + (0xFAA1, 'M', '瑱'), + (0xFAA2, 'M', '甆'), + (0xFAA3, 'M', '画'), + (0xFAA4, 'M', '瘝'), + (0xFAA5, 'M', '瘟'), + (0xFAA6, 'M', '益'), + (0xFAA7, 'M', '盛'), + (0xFAA8, 'M', '直'), + (0xFAA9, 'M', '睊'), + (0xFAAA, 'M', '着'), + (0xFAAB, 'M', '磌'), + (0xFAAC, 'M', '窱'), + (0xFAAD, 'M', '節'), + (0xFAAE, 'M', '类'), + (0xFAAF, 'M', '絛'), + (0xFAB0, 'M', '練'), + (0xFAB1, 'M', '缾'), + (0xFAB2, 'M', '者'), + (0xFAB3, 'M', '荒'), + (0xFAB4, 'M', '華'), + (0xFAB5, 'M', '蝹'), + (0xFAB6, 'M', '襁'), + (0xFAB7, 'M', '覆'), + (0xFAB8, 'M', '視'), + (0xFAB9, 'M', '調'), + (0xFABA, 'M', '諸'), + (0xFABB, 'M', '請'), + (0xFABC, 'M', '謁'), + (0xFABD, 'M', '諾'), + (0xFABE, 'M', '諭'), + (0xFABF, 'M', '謹'), + (0xFAC0, 'M', '變'), + (0xFAC1, 'M', '贈'), + (0xFAC2, 'M', '輸'), + (0xFAC3, 'M', '遲'), + (0xFAC4, 'M', '醙'), + (0xFAC5, 'M', '鉶'), + (0xFAC6, 'M', '陼'), + (0xFAC7, 'M', '難'), + (0xFAC8, 'M', '靖'), + (0xFAC9, 'M', '韛'), + (0xFACA, 'M', '響'), + (0xFACB, 'M', '頋'), + (0xFACC, 'M', '頻'), + (0xFACD, 'M', '鬒'), + (0xFACE, 'M', '龜'), + (0xFACF, 'M', '𢡊'), + (0xFAD0, 'M', '𢡄'), + (0xFAD1, 'M', '𣏕'), + (0xFAD2, 'M', '㮝'), + (0xFAD3, 'M', '䀘'), + (0xFAD4, 'M', '䀹'), + (0xFAD5, 'M', '𥉉'), + (0xFAD6, 'M', '𥳐'), + (0xFAD7, 'M', '𧻓'), + (0xFAD8, 'M', '齃'), + (0xFAD9, 'M', '龎'), + (0xFADA, 'X'), + (0xFB00, 'M', 'ff'), + (0xFB01, 'M', 'fi'), + (0xFB02, 'M', 'fl'), + (0xFB03, 'M', 'ffi'), + (0xFB04, 'M', 'ffl'), + (0xFB05, 'M', 'st'), + (0xFB07, 'X'), + (0xFB13, 'M', 'մն'), + (0xFB14, 'M', 'մե'), + (0xFB15, 'M', 'մի'), + (0xFB16, 'M', 'վն'), + ] + +def _seg_44(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0xFB17, 'M', 'մխ'), + (0xFB18, 'X'), + (0xFB1D, 'M', 'יִ'), + (0xFB1E, 'V'), + (0xFB1F, 'M', 'ײַ'), + (0xFB20, 'M', 'ע'), + (0xFB21, 'M', 'א'), + (0xFB22, 'M', 'ד'), + (0xFB23, 'M', 'ה'), + (0xFB24, 'M', 'כ'), + (0xFB25, 'M', 'ל'), + (0xFB26, 'M', 'ם'), + (0xFB27, 'M', 'ר'), + (0xFB28, 'M', 'ת'), + (0xFB29, '3', '+'), + (0xFB2A, 'M', 'שׁ'), + (0xFB2B, 'M', 'שׂ'), + (0xFB2C, 'M', 'שּׁ'), + (0xFB2D, 'M', 'שּׂ'), + (0xFB2E, 'M', 'אַ'), + (0xFB2F, 'M', 'אָ'), + (0xFB30, 'M', 'אּ'), + (0xFB31, 'M', 'בּ'), + (0xFB32, 'M', 'גּ'), + (0xFB33, 'M', 'דּ'), + (0xFB34, 'M', 'הּ'), + (0xFB35, 'M', 'וּ'), + (0xFB36, 'M', 'זּ'), + (0xFB37, 'X'), + (0xFB38, 'M', 'טּ'), + (0xFB39, 'M', 'יּ'), + (0xFB3A, 'M', 'ךּ'), + (0xFB3B, 'M', 'כּ'), + (0xFB3C, 'M', 'לּ'), + (0xFB3D, 'X'), + (0xFB3E, 'M', 'מּ'), + (0xFB3F, 'X'), + (0xFB40, 'M', 'נּ'), + (0xFB41, 'M', 'סּ'), + (0xFB42, 'X'), + (0xFB43, 'M', 'ףּ'), + (0xFB44, 'M', 'פּ'), + (0xFB45, 'X'), + (0xFB46, 'M', 'צּ'), + (0xFB47, 'M', 'קּ'), + (0xFB48, 'M', 'רּ'), + (0xFB49, 'M', 'שּ'), + (0xFB4A, 'M', 'תּ'), + (0xFB4B, 'M', 'וֹ'), + (0xFB4C, 'M', 'בֿ'), + (0xFB4D, 'M', 'כֿ'), + (0xFB4E, 'M', 'פֿ'), + (0xFB4F, 'M', 'אל'), + (0xFB50, 'M', 'ٱ'), + (0xFB52, 'M', 'ٻ'), + (0xFB56, 'M', 'پ'), + (0xFB5A, 'M', 'ڀ'), + (0xFB5E, 'M', 'ٺ'), + (0xFB62, 'M', 'ٿ'), + (0xFB66, 'M', 'ٹ'), + (0xFB6A, 'M', 'ڤ'), + (0xFB6E, 'M', 'ڦ'), + (0xFB72, 'M', 'ڄ'), + (0xFB76, 'M', 'ڃ'), + (0xFB7A, 'M', 'چ'), + (0xFB7E, 'M', 'ڇ'), + (0xFB82, 'M', 'ڍ'), + (0xFB84, 'M', 'ڌ'), + (0xFB86, 'M', 'ڎ'), + (0xFB88, 'M', 'ڈ'), + (0xFB8A, 'M', 'ژ'), + (0xFB8C, 'M', 'ڑ'), + (0xFB8E, 'M', 'ک'), + (0xFB92, 'M', 'گ'), + (0xFB96, 'M', 'ڳ'), + (0xFB9A, 'M', 'ڱ'), + (0xFB9E, 'M', 'ں'), + (0xFBA0, 'M', 'ڻ'), + (0xFBA4, 'M', 'ۀ'), + (0xFBA6, 'M', 'ہ'), + (0xFBAA, 'M', 'ھ'), + (0xFBAE, 'M', 'ے'), + (0xFBB0, 'M', 'ۓ'), + (0xFBB2, 'V'), + (0xFBC2, 'X'), + (0xFBD3, 'M', 'ڭ'), + (0xFBD7, 'M', 'ۇ'), + (0xFBD9, 'M', 'ۆ'), + (0xFBDB, 'M', 'ۈ'), + (0xFBDD, 'M', 'ۇٴ'), + (0xFBDE, 'M', 'ۋ'), + (0xFBE0, 'M', 'ۅ'), + (0xFBE2, 'M', 'ۉ'), + (0xFBE4, 'M', 'ې'), + (0xFBE8, 'M', 'ى'), + (0xFBEA, 'M', 'ئا'), + (0xFBEC, 'M', 'ئە'), + (0xFBEE, 'M', 'ئو'), + (0xFBF0, 'M', 'ئۇ'), + (0xFBF2, 'M', 'ئۆ'), + ] + +def _seg_45(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0xFBF4, 'M', 'ئۈ'), + (0xFBF6, 'M', 'ئې'), + (0xFBF9, 'M', 'ئى'), + (0xFBFC, 'M', 'ی'), + (0xFC00, 'M', 'ئج'), + (0xFC01, 'M', 'ئح'), + (0xFC02, 'M', 'ئم'), + (0xFC03, 'M', 'ئى'), + (0xFC04, 'M', 'ئي'), + (0xFC05, 'M', 'بج'), + (0xFC06, 'M', 'بح'), + (0xFC07, 'M', 'بخ'), + (0xFC08, 'M', 'بم'), + (0xFC09, 'M', 'بى'), + (0xFC0A, 'M', 'بي'), + (0xFC0B, 'M', 'تج'), + (0xFC0C, 'M', 'تح'), + (0xFC0D, 'M', 'تخ'), + (0xFC0E, 'M', 'تم'), + (0xFC0F, 'M', 'تى'), + (0xFC10, 'M', 'تي'), + (0xFC11, 'M', 'ثج'), + (0xFC12, 'M', 'ثم'), + (0xFC13, 'M', 'ثى'), + (0xFC14, 'M', 'ثي'), + (0xFC15, 'M', 'جح'), + (0xFC16, 'M', 'جم'), + (0xFC17, 'M', 'حج'), + (0xFC18, 'M', 'حم'), + (0xFC19, 'M', 'خج'), + (0xFC1A, 'M', 'خح'), + (0xFC1B, 'M', 'خم'), + (0xFC1C, 'M', 'سج'), + (0xFC1D, 'M', 'سح'), + (0xFC1E, 'M', 'سخ'), + (0xFC1F, 'M', 'سم'), + (0xFC20, 'M', 'صح'), + (0xFC21, 'M', 'صم'), + (0xFC22, 'M', 'ضج'), + (0xFC23, 'M', 'ضح'), + (0xFC24, 'M', 'ضخ'), + (0xFC25, 'M', 'ضم'), + (0xFC26, 'M', 'طح'), + (0xFC27, 'M', 'طم'), + (0xFC28, 'M', 'ظم'), + (0xFC29, 'M', 'عج'), + (0xFC2A, 'M', 'عم'), + (0xFC2B, 'M', 'غج'), + (0xFC2C, 'M', 'غم'), + (0xFC2D, 'M', 'فج'), + (0xFC2E, 'M', 'فح'), + (0xFC2F, 'M', 'فخ'), + (0xFC30, 'M', 'فم'), + (0xFC31, 'M', 'فى'), + (0xFC32, 'M', 'في'), + (0xFC33, 'M', 'قح'), + (0xFC34, 'M', 'قم'), + (0xFC35, 'M', 'قى'), + (0xFC36, 'M', 'قي'), + (0xFC37, 'M', 'كا'), + (0xFC38, 'M', 'كج'), + (0xFC39, 'M', 'كح'), + (0xFC3A, 'M', 'كخ'), + (0xFC3B, 'M', 'كل'), + (0xFC3C, 'M', 'كم'), + (0xFC3D, 'M', 'كى'), + (0xFC3E, 'M', 'كي'), + (0xFC3F, 'M', 'لج'), + (0xFC40, 'M', 'لح'), + (0xFC41, 'M', 'لخ'), + (0xFC42, 'M', 'لم'), + (0xFC43, 'M', 'لى'), + (0xFC44, 'M', 'لي'), + (0xFC45, 'M', 'مج'), + (0xFC46, 'M', 'مح'), + (0xFC47, 'M', 'مخ'), + (0xFC48, 'M', 'مم'), + (0xFC49, 'M', 'مى'), + (0xFC4A, 'M', 'مي'), + (0xFC4B, 'M', 'نج'), + (0xFC4C, 'M', 'نح'), + (0xFC4D, 'M', 'نخ'), + (0xFC4E, 'M', 'نم'), + (0xFC4F, 'M', 'نى'), + (0xFC50, 'M', 'ني'), + (0xFC51, 'M', 'هج'), + (0xFC52, 'M', 'هم'), + (0xFC53, 'M', 'هى'), + (0xFC54, 'M', 'هي'), + (0xFC55, 'M', 'يج'), + (0xFC56, 'M', 'يح'), + (0xFC57, 'M', 'يخ'), + (0xFC58, 'M', 'يم'), + (0xFC59, 'M', 'يى'), + (0xFC5A, 'M', 'يي'), + (0xFC5B, 'M', 'ذٰ'), + (0xFC5C, 'M', 'رٰ'), + (0xFC5D, 'M', 'ىٰ'), + (0xFC5E, '3', ' ٌّ'), + (0xFC5F, '3', ' ٍّ'), + ] + +def _seg_46(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0xFC60, '3', ' َّ'), + (0xFC61, '3', ' ُّ'), + (0xFC62, '3', ' ِّ'), + (0xFC63, '3', ' ّٰ'), + (0xFC64, 'M', 'ئر'), + (0xFC65, 'M', 'ئز'), + (0xFC66, 'M', 'ئم'), + (0xFC67, 'M', 'ئن'), + (0xFC68, 'M', 'ئى'), + (0xFC69, 'M', 'ئي'), + (0xFC6A, 'M', 'بر'), + (0xFC6B, 'M', 'بز'), + (0xFC6C, 'M', 'بم'), + (0xFC6D, 'M', 'بن'), + (0xFC6E, 'M', 'بى'), + (0xFC6F, 'M', 'بي'), + (0xFC70, 'M', 'تر'), + (0xFC71, 'M', 'تز'), + (0xFC72, 'M', 'تم'), + (0xFC73, 'M', 'تن'), + (0xFC74, 'M', 'تى'), + (0xFC75, 'M', 'تي'), + (0xFC76, 'M', 'ثر'), + (0xFC77, 'M', 'ثز'), + (0xFC78, 'M', 'ثم'), + (0xFC79, 'M', 'ثن'), + (0xFC7A, 'M', 'ثى'), + (0xFC7B, 'M', 'ثي'), + (0xFC7C, 'M', 'فى'), + (0xFC7D, 'M', 'في'), + (0xFC7E, 'M', 'قى'), + (0xFC7F, 'M', 'قي'), + (0xFC80, 'M', 'كا'), + (0xFC81, 'M', 'كل'), + (0xFC82, 'M', 'كم'), + (0xFC83, 'M', 'كى'), + (0xFC84, 'M', 'كي'), + (0xFC85, 'M', 'لم'), + (0xFC86, 'M', 'لى'), + (0xFC87, 'M', 'لي'), + (0xFC88, 'M', 'ما'), + (0xFC89, 'M', 'مم'), + (0xFC8A, 'M', 'نر'), + (0xFC8B, 'M', 'نز'), + (0xFC8C, 'M', 'نم'), + (0xFC8D, 'M', 'نن'), + (0xFC8E, 'M', 'نى'), + (0xFC8F, 'M', 'ني'), + (0xFC90, 'M', 'ىٰ'), + (0xFC91, 'M', 'ير'), + (0xFC92, 'M', 'يز'), + (0xFC93, 'M', 'يم'), + (0xFC94, 'M', 'ين'), + (0xFC95, 'M', 'يى'), + (0xFC96, 'M', 'يي'), + (0xFC97, 'M', 'ئج'), + (0xFC98, 'M', 'ئح'), + (0xFC99, 'M', 'ئخ'), + (0xFC9A, 'M', 'ئم'), + (0xFC9B, 'M', 'ئه'), + (0xFC9C, 'M', 'بج'), + (0xFC9D, 'M', 'بح'), + (0xFC9E, 'M', 'بخ'), + (0xFC9F, 'M', 'بم'), + (0xFCA0, 'M', 'به'), + (0xFCA1, 'M', 'تج'), + (0xFCA2, 'M', 'تح'), + (0xFCA3, 'M', 'تخ'), + (0xFCA4, 'M', 'تم'), + (0xFCA5, 'M', 'ته'), + (0xFCA6, 'M', 'ثم'), + (0xFCA7, 'M', 'جح'), + (0xFCA8, 'M', 'جم'), + (0xFCA9, 'M', 'حج'), + (0xFCAA, 'M', 'حم'), + (0xFCAB, 'M', 'خج'), + (0xFCAC, 'M', 'خم'), + (0xFCAD, 'M', 'سج'), + (0xFCAE, 'M', 'سح'), + (0xFCAF, 'M', 'سخ'), + (0xFCB0, 'M', 'سم'), + (0xFCB1, 'M', 'صح'), + (0xFCB2, 'M', 'صخ'), + (0xFCB3, 'M', 'صم'), + (0xFCB4, 'M', 'ضج'), + (0xFCB5, 'M', 'ضح'), + (0xFCB6, 'M', 'ضخ'), + (0xFCB7, 'M', 'ضم'), + (0xFCB8, 'M', 'طح'), + (0xFCB9, 'M', 'ظم'), + (0xFCBA, 'M', 'عج'), + (0xFCBB, 'M', 'عم'), + (0xFCBC, 'M', 'غج'), + (0xFCBD, 'M', 'غم'), + (0xFCBE, 'M', 'فج'), + (0xFCBF, 'M', 'فح'), + (0xFCC0, 'M', 'فخ'), + (0xFCC1, 'M', 'فم'), + (0xFCC2, 'M', 'قح'), + (0xFCC3, 'M', 'قم'), + ] + +def _seg_47(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0xFCC4, 'M', 'كج'), + (0xFCC5, 'M', 'كح'), + (0xFCC6, 'M', 'كخ'), + (0xFCC7, 'M', 'كل'), + (0xFCC8, 'M', 'كم'), + (0xFCC9, 'M', 'لج'), + (0xFCCA, 'M', 'لح'), + (0xFCCB, 'M', 'لخ'), + (0xFCCC, 'M', 'لم'), + (0xFCCD, 'M', 'له'), + (0xFCCE, 'M', 'مج'), + (0xFCCF, 'M', 'مح'), + (0xFCD0, 'M', 'مخ'), + (0xFCD1, 'M', 'مم'), + (0xFCD2, 'M', 'نج'), + (0xFCD3, 'M', 'نح'), + (0xFCD4, 'M', 'نخ'), + (0xFCD5, 'M', 'نم'), + (0xFCD6, 'M', 'نه'), + (0xFCD7, 'M', 'هج'), + (0xFCD8, 'M', 'هم'), + (0xFCD9, 'M', 'هٰ'), + (0xFCDA, 'M', 'يج'), + (0xFCDB, 'M', 'يح'), + (0xFCDC, 'M', 'يخ'), + (0xFCDD, 'M', 'يم'), + (0xFCDE, 'M', 'يه'), + (0xFCDF, 'M', 'ئم'), + (0xFCE0, 'M', 'ئه'), + (0xFCE1, 'M', 'بم'), + (0xFCE2, 'M', 'به'), + (0xFCE3, 'M', 'تم'), + (0xFCE4, 'M', 'ته'), + (0xFCE5, 'M', 'ثم'), + (0xFCE6, 'M', 'ثه'), + (0xFCE7, 'M', 'سم'), + (0xFCE8, 'M', 'سه'), + (0xFCE9, 'M', 'شم'), + (0xFCEA, 'M', 'شه'), + (0xFCEB, 'M', 'كل'), + (0xFCEC, 'M', 'كم'), + (0xFCED, 'M', 'لم'), + (0xFCEE, 'M', 'نم'), + (0xFCEF, 'M', 'نه'), + (0xFCF0, 'M', 'يم'), + (0xFCF1, 'M', 'يه'), + (0xFCF2, 'M', 'ـَّ'), + (0xFCF3, 'M', 'ـُّ'), + (0xFCF4, 'M', 'ـِّ'), + (0xFCF5, 'M', 'طى'), + (0xFCF6, 'M', 'طي'), + (0xFCF7, 'M', 'عى'), + (0xFCF8, 'M', 'عي'), + (0xFCF9, 'M', 'غى'), + (0xFCFA, 'M', 'غي'), + (0xFCFB, 'M', 'سى'), + (0xFCFC, 'M', 'سي'), + (0xFCFD, 'M', 'شى'), + (0xFCFE, 'M', 'شي'), + (0xFCFF, 'M', 'حى'), + (0xFD00, 'M', 'حي'), + (0xFD01, 'M', 'جى'), + (0xFD02, 'M', 'جي'), + (0xFD03, 'M', 'خى'), + (0xFD04, 'M', 'خي'), + (0xFD05, 'M', 'صى'), + (0xFD06, 'M', 'صي'), + (0xFD07, 'M', 'ضى'), + (0xFD08, 'M', 'ضي'), + (0xFD09, 'M', 'شج'), + (0xFD0A, 'M', 'شح'), + (0xFD0B, 'M', 'شخ'), + (0xFD0C, 'M', 'شم'), + (0xFD0D, 'M', 'شر'), + (0xFD0E, 'M', 'سر'), + (0xFD0F, 'M', 'صر'), + (0xFD10, 'M', 'ضر'), + (0xFD11, 'M', 'طى'), + (0xFD12, 'M', 'طي'), + (0xFD13, 'M', 'عى'), + (0xFD14, 'M', 'عي'), + (0xFD15, 'M', 'غى'), + (0xFD16, 'M', 'غي'), + (0xFD17, 'M', 'سى'), + (0xFD18, 'M', 'سي'), + (0xFD19, 'M', 'شى'), + (0xFD1A, 'M', 'شي'), + (0xFD1B, 'M', 'حى'), + (0xFD1C, 'M', 'حي'), + (0xFD1D, 'M', 'جى'), + (0xFD1E, 'M', 'جي'), + (0xFD1F, 'M', 'خى'), + (0xFD20, 'M', 'خي'), + (0xFD21, 'M', 'صى'), + (0xFD22, 'M', 'صي'), + (0xFD23, 'M', 'ضى'), + (0xFD24, 'M', 'ضي'), + (0xFD25, 'M', 'شج'), + (0xFD26, 'M', 'شح'), + (0xFD27, 'M', 'شخ'), + ] + +def _seg_48(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0xFD28, 'M', 'شم'), + (0xFD29, 'M', 'شر'), + (0xFD2A, 'M', 'سر'), + (0xFD2B, 'M', 'صر'), + (0xFD2C, 'M', 'ضر'), + (0xFD2D, 'M', 'شج'), + (0xFD2E, 'M', 'شح'), + (0xFD2F, 'M', 'شخ'), + (0xFD30, 'M', 'شم'), + (0xFD31, 'M', 'سه'), + (0xFD32, 'M', 'شه'), + (0xFD33, 'M', 'طم'), + (0xFD34, 'M', 'سج'), + (0xFD35, 'M', 'سح'), + (0xFD36, 'M', 'سخ'), + (0xFD37, 'M', 'شج'), + (0xFD38, 'M', 'شح'), + (0xFD39, 'M', 'شخ'), + (0xFD3A, 'M', 'طم'), + (0xFD3B, 'M', 'ظم'), + (0xFD3C, 'M', 'اً'), + (0xFD3E, 'V'), + (0xFD40, 'X'), + (0xFD50, 'M', 'تجم'), + (0xFD51, 'M', 'تحج'), + (0xFD53, 'M', 'تحم'), + (0xFD54, 'M', 'تخم'), + (0xFD55, 'M', 'تمج'), + (0xFD56, 'M', 'تمح'), + (0xFD57, 'M', 'تمخ'), + (0xFD58, 'M', 'جمح'), + (0xFD5A, 'M', 'حمي'), + (0xFD5B, 'M', 'حمى'), + (0xFD5C, 'M', 'سحج'), + (0xFD5D, 'M', 'سجح'), + (0xFD5E, 'M', 'سجى'), + (0xFD5F, 'M', 'سمح'), + (0xFD61, 'M', 'سمج'), + (0xFD62, 'M', 'سمم'), + (0xFD64, 'M', 'صحح'), + (0xFD66, 'M', 'صمم'), + (0xFD67, 'M', 'شحم'), + (0xFD69, 'M', 'شجي'), + (0xFD6A, 'M', 'شمخ'), + (0xFD6C, 'M', 'شمم'), + (0xFD6E, 'M', 'ضحى'), + (0xFD6F, 'M', 'ضخم'), + (0xFD71, 'M', 'طمح'), + (0xFD73, 'M', 'طمم'), + (0xFD74, 'M', 'طمي'), + (0xFD75, 'M', 'عجم'), + (0xFD76, 'M', 'عمم'), + (0xFD78, 'M', 'عمى'), + (0xFD79, 'M', 'غمم'), + (0xFD7A, 'M', 'غمي'), + (0xFD7B, 'M', 'غمى'), + (0xFD7C, 'M', 'فخم'), + (0xFD7E, 'M', 'قمح'), + (0xFD7F, 'M', 'قمم'), + (0xFD80, 'M', 'لحم'), + (0xFD81, 'M', 'لحي'), + (0xFD82, 'M', 'لحى'), + (0xFD83, 'M', 'لجج'), + (0xFD85, 'M', 'لخم'), + (0xFD87, 'M', 'لمح'), + (0xFD89, 'M', 'محج'), + (0xFD8A, 'M', 'محم'), + (0xFD8B, 'M', 'محي'), + (0xFD8C, 'M', 'مجح'), + (0xFD8D, 'M', 'مجم'), + (0xFD8E, 'M', 'مخج'), + (0xFD8F, 'M', 'مخم'), + (0xFD90, 'X'), + (0xFD92, 'M', 'مجخ'), + (0xFD93, 'M', 'همج'), + (0xFD94, 'M', 'همم'), + (0xFD95, 'M', 'نحم'), + (0xFD96, 'M', 'نحى'), + (0xFD97, 'M', 'نجم'), + (0xFD99, 'M', 'نجى'), + (0xFD9A, 'M', 'نمي'), + (0xFD9B, 'M', 'نمى'), + (0xFD9C, 'M', 'يمم'), + (0xFD9E, 'M', 'بخي'), + (0xFD9F, 'M', 'تجي'), + (0xFDA0, 'M', 'تجى'), + (0xFDA1, 'M', 'تخي'), + (0xFDA2, 'M', 'تخى'), + (0xFDA3, 'M', 'تمي'), + (0xFDA4, 'M', 'تمى'), + (0xFDA5, 'M', 'جمي'), + (0xFDA6, 'M', 'جحى'), + (0xFDA7, 'M', 'جمى'), + (0xFDA8, 'M', 'سخى'), + (0xFDA9, 'M', 'صحي'), + (0xFDAA, 'M', 'شحي'), + (0xFDAB, 'M', 'ضحي'), + (0xFDAC, 'M', 'لجي'), + (0xFDAD, 'M', 'لمي'), + (0xFDAE, 'M', 'يحي'), + ] + +def _seg_49(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0xFDAF, 'M', 'يجي'), + (0xFDB0, 'M', 'يمي'), + (0xFDB1, 'M', 'ممي'), + (0xFDB2, 'M', 'قمي'), + (0xFDB3, 'M', 'نحي'), + (0xFDB4, 'M', 'قمح'), + (0xFDB5, 'M', 'لحم'), + (0xFDB6, 'M', 'عمي'), + (0xFDB7, 'M', 'كمي'), + (0xFDB8, 'M', 'نجح'), + (0xFDB9, 'M', 'مخي'), + (0xFDBA, 'M', 'لجم'), + (0xFDBB, 'M', 'كمم'), + (0xFDBC, 'M', 'لجم'), + (0xFDBD, 'M', 'نجح'), + (0xFDBE, 'M', 'جحي'), + (0xFDBF, 'M', 'حجي'), + (0xFDC0, 'M', 'مجي'), + (0xFDC1, 'M', 'فمي'), + (0xFDC2, 'M', 'بحي'), + (0xFDC3, 'M', 'كمم'), + (0xFDC4, 'M', 'عجم'), + (0xFDC5, 'M', 'صمم'), + (0xFDC6, 'M', 'سخي'), + (0xFDC7, 'M', 'نجي'), + (0xFDC8, 'X'), + (0xFDF0, 'M', 'صلے'), + (0xFDF1, 'M', 'قلے'), + (0xFDF2, 'M', 'الله'), + (0xFDF3, 'M', 'اكبر'), + (0xFDF4, 'M', 'محمد'), + (0xFDF5, 'M', 'صلعم'), + (0xFDF6, 'M', 'رسول'), + (0xFDF7, 'M', 'عليه'), + (0xFDF8, 'M', 'وسلم'), + (0xFDF9, 'M', 'صلى'), + (0xFDFA, '3', 'صلى الله عليه وسلم'), + (0xFDFB, '3', 'جل جلاله'), + (0xFDFC, 'M', 'ریال'), + (0xFDFD, 'V'), + (0xFDFE, 'X'), + (0xFE00, 'I'), + (0xFE10, '3', ','), + (0xFE11, 'M', '、'), + (0xFE12, 'X'), + (0xFE13, '3', ':'), + (0xFE14, '3', ';'), + (0xFE15, '3', '!'), + (0xFE16, '3', '?'), + (0xFE17, 'M', '〖'), + (0xFE18, 'M', '〗'), + (0xFE19, 'X'), + (0xFE20, 'V'), + (0xFE30, 'X'), + (0xFE31, 'M', '—'), + (0xFE32, 'M', '–'), + (0xFE33, '3', '_'), + (0xFE35, '3', '('), + (0xFE36, '3', ')'), + (0xFE37, '3', '{'), + (0xFE38, '3', '}'), + (0xFE39, 'M', '〔'), + (0xFE3A, 'M', '〕'), + (0xFE3B, 'M', '【'), + (0xFE3C, 'M', '】'), + (0xFE3D, 'M', '《'), + (0xFE3E, 'M', '》'), + (0xFE3F, 'M', '〈'), + (0xFE40, 'M', '〉'), + (0xFE41, 'M', '「'), + (0xFE42, 'M', '」'), + (0xFE43, 'M', '『'), + (0xFE44, 'M', '』'), + (0xFE45, 'V'), + (0xFE47, '3', '['), + (0xFE48, '3', ']'), + (0xFE49, '3', ' ̅'), + (0xFE4D, '3', '_'), + (0xFE50, '3', ','), + (0xFE51, 'M', '、'), + (0xFE52, 'X'), + (0xFE54, '3', ';'), + (0xFE55, '3', ':'), + (0xFE56, '3', '?'), + (0xFE57, '3', '!'), + (0xFE58, 'M', '—'), + (0xFE59, '3', '('), + (0xFE5A, '3', ')'), + (0xFE5B, '3', '{'), + (0xFE5C, '3', '}'), + (0xFE5D, 'M', '〔'), + (0xFE5E, 'M', '〕'), + (0xFE5F, '3', '#'), + (0xFE60, '3', '&'), + (0xFE61, '3', '*'), + (0xFE62, '3', '+'), + (0xFE63, 'M', '-'), + (0xFE64, '3', '<'), + (0xFE65, '3', '>'), + (0xFE66, '3', '='), + ] + +def _seg_50(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0xFE67, 'X'), + (0xFE68, '3', '\\'), + (0xFE69, '3', '$'), + (0xFE6A, '3', '%'), + (0xFE6B, '3', '@'), + (0xFE6C, 'X'), + (0xFE70, '3', ' ً'), + (0xFE71, 'M', 'ـً'), + (0xFE72, '3', ' ٌ'), + (0xFE73, 'V'), + (0xFE74, '3', ' ٍ'), + (0xFE75, 'X'), + (0xFE76, '3', ' َ'), + (0xFE77, 'M', 'ـَ'), + (0xFE78, '3', ' ُ'), + (0xFE79, 'M', 'ـُ'), + (0xFE7A, '3', ' ِ'), + (0xFE7B, 'M', 'ـِ'), + (0xFE7C, '3', ' ّ'), + (0xFE7D, 'M', 'ـّ'), + (0xFE7E, '3', ' ْ'), + (0xFE7F, 'M', 'ـْ'), + (0xFE80, 'M', 'ء'), + (0xFE81, 'M', 'آ'), + (0xFE83, 'M', 'أ'), + (0xFE85, 'M', 'ؤ'), + (0xFE87, 'M', 'إ'), + (0xFE89, 'M', 'ئ'), + (0xFE8D, 'M', 'ا'), + (0xFE8F, 'M', 'ب'), + (0xFE93, 'M', 'ة'), + (0xFE95, 'M', 'ت'), + (0xFE99, 'M', 'ث'), + (0xFE9D, 'M', 'ج'), + (0xFEA1, 'M', 'ح'), + (0xFEA5, 'M', 'خ'), + (0xFEA9, 'M', 'د'), + (0xFEAB, 'M', 'ذ'), + (0xFEAD, 'M', 'ر'), + (0xFEAF, 'M', 'ز'), + (0xFEB1, 'M', 'س'), + (0xFEB5, 'M', 'ش'), + (0xFEB9, 'M', 'ص'), + (0xFEBD, 'M', 'ض'), + (0xFEC1, 'M', 'ط'), + (0xFEC5, 'M', 'ظ'), + (0xFEC9, 'M', 'ع'), + (0xFECD, 'M', 'غ'), + (0xFED1, 'M', 'ف'), + (0xFED5, 'M', 'ق'), + (0xFED9, 'M', 'ك'), + (0xFEDD, 'M', 'ل'), + (0xFEE1, 'M', 'م'), + (0xFEE5, 'M', 'ن'), + (0xFEE9, 'M', 'ه'), + (0xFEED, 'M', 'و'), + (0xFEEF, 'M', 'ى'), + (0xFEF1, 'M', 'ي'), + (0xFEF5, 'M', 'لآ'), + (0xFEF7, 'M', 'لأ'), + (0xFEF9, 'M', 'لإ'), + (0xFEFB, 'M', 'لا'), + (0xFEFD, 'X'), + (0xFEFF, 'I'), + (0xFF00, 'X'), + (0xFF01, '3', '!'), + (0xFF02, '3', '"'), + (0xFF03, '3', '#'), + (0xFF04, '3', '$'), + (0xFF05, '3', '%'), + (0xFF06, '3', '&'), + (0xFF07, '3', '\''), + (0xFF08, '3', '('), + (0xFF09, '3', ')'), + (0xFF0A, '3', '*'), + (0xFF0B, '3', '+'), + (0xFF0C, '3', ','), + (0xFF0D, 'M', '-'), + (0xFF0E, 'M', '.'), + (0xFF0F, '3', '/'), + (0xFF10, 'M', '0'), + (0xFF11, 'M', '1'), + (0xFF12, 'M', '2'), + (0xFF13, 'M', '3'), + (0xFF14, 'M', '4'), + (0xFF15, 'M', '5'), + (0xFF16, 'M', '6'), + (0xFF17, 'M', '7'), + (0xFF18, 'M', '8'), + (0xFF19, 'M', '9'), + (0xFF1A, '3', ':'), + (0xFF1B, '3', ';'), + (0xFF1C, '3', '<'), + (0xFF1D, '3', '='), + (0xFF1E, '3', '>'), + (0xFF1F, '3', '?'), + (0xFF20, '3', '@'), + (0xFF21, 'M', 'a'), + (0xFF22, 'M', 'b'), + (0xFF23, 'M', 'c'), + ] + +def _seg_51(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0xFF24, 'M', 'd'), + (0xFF25, 'M', 'e'), + (0xFF26, 'M', 'f'), + (0xFF27, 'M', 'g'), + (0xFF28, 'M', 'h'), + (0xFF29, 'M', 'i'), + (0xFF2A, 'M', 'j'), + (0xFF2B, 'M', 'k'), + (0xFF2C, 'M', 'l'), + (0xFF2D, 'M', 'm'), + (0xFF2E, 'M', 'n'), + (0xFF2F, 'M', 'o'), + (0xFF30, 'M', 'p'), + (0xFF31, 'M', 'q'), + (0xFF32, 'M', 'r'), + (0xFF33, 'M', 's'), + (0xFF34, 'M', 't'), + (0xFF35, 'M', 'u'), + (0xFF36, 'M', 'v'), + (0xFF37, 'M', 'w'), + (0xFF38, 'M', 'x'), + (0xFF39, 'M', 'y'), + (0xFF3A, 'M', 'z'), + (0xFF3B, '3', '['), + (0xFF3C, '3', '\\'), + (0xFF3D, '3', ']'), + (0xFF3E, '3', '^'), + (0xFF3F, '3', '_'), + (0xFF40, '3', '`'), + (0xFF41, 'M', 'a'), + (0xFF42, 'M', 'b'), + (0xFF43, 'M', 'c'), + (0xFF44, 'M', 'd'), + (0xFF45, 'M', 'e'), + (0xFF46, 'M', 'f'), + (0xFF47, 'M', 'g'), + (0xFF48, 'M', 'h'), + (0xFF49, 'M', 'i'), + (0xFF4A, 'M', 'j'), + (0xFF4B, 'M', 'k'), + (0xFF4C, 'M', 'l'), + (0xFF4D, 'M', 'm'), + (0xFF4E, 'M', 'n'), + (0xFF4F, 'M', 'o'), + (0xFF50, 'M', 'p'), + (0xFF51, 'M', 'q'), + (0xFF52, 'M', 'r'), + (0xFF53, 'M', 's'), + (0xFF54, 'M', 't'), + (0xFF55, 'M', 'u'), + (0xFF56, 'M', 'v'), + (0xFF57, 'M', 'w'), + (0xFF58, 'M', 'x'), + (0xFF59, 'M', 'y'), + (0xFF5A, 'M', 'z'), + (0xFF5B, '3', '{'), + (0xFF5C, '3', '|'), + (0xFF5D, '3', '}'), + (0xFF5E, '3', '~'), + (0xFF5F, 'M', '⦅'), + (0xFF60, 'M', '⦆'), + (0xFF61, 'M', '.'), + (0xFF62, 'M', '「'), + (0xFF63, 'M', '」'), + (0xFF64, 'M', '、'), + (0xFF65, 'M', '・'), + (0xFF66, 'M', 'ヲ'), + (0xFF67, 'M', 'ァ'), + (0xFF68, 'M', 'ィ'), + (0xFF69, 'M', 'ゥ'), + (0xFF6A, 'M', 'ェ'), + (0xFF6B, 'M', 'ォ'), + (0xFF6C, 'M', 'ャ'), + (0xFF6D, 'M', 'ュ'), + (0xFF6E, 'M', 'ョ'), + (0xFF6F, 'M', 'ッ'), + (0xFF70, 'M', 'ー'), + (0xFF71, 'M', 'ア'), + (0xFF72, 'M', 'イ'), + (0xFF73, 'M', 'ウ'), + (0xFF74, 'M', 'エ'), + (0xFF75, 'M', 'オ'), + (0xFF76, 'M', 'カ'), + (0xFF77, 'M', 'キ'), + (0xFF78, 'M', 'ク'), + (0xFF79, 'M', 'ケ'), + (0xFF7A, 'M', 'コ'), + (0xFF7B, 'M', 'サ'), + (0xFF7C, 'M', 'シ'), + (0xFF7D, 'M', 'ス'), + (0xFF7E, 'M', 'セ'), + (0xFF7F, 'M', 'ソ'), + (0xFF80, 'M', 'タ'), + (0xFF81, 'M', 'チ'), + (0xFF82, 'M', 'ツ'), + (0xFF83, 'M', 'テ'), + (0xFF84, 'M', 'ト'), + (0xFF85, 'M', 'ナ'), + (0xFF86, 'M', 'ニ'), + (0xFF87, 'M', 'ヌ'), + ] + +def _seg_52(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0xFF88, 'M', 'ネ'), + (0xFF89, 'M', 'ノ'), + (0xFF8A, 'M', 'ハ'), + (0xFF8B, 'M', 'ヒ'), + (0xFF8C, 'M', 'フ'), + (0xFF8D, 'M', 'ヘ'), + (0xFF8E, 'M', 'ホ'), + (0xFF8F, 'M', 'マ'), + (0xFF90, 'M', 'ミ'), + (0xFF91, 'M', 'ム'), + (0xFF92, 'M', 'メ'), + (0xFF93, 'M', 'モ'), + (0xFF94, 'M', 'ヤ'), + (0xFF95, 'M', 'ユ'), + (0xFF96, 'M', 'ヨ'), + (0xFF97, 'M', 'ラ'), + (0xFF98, 'M', 'リ'), + (0xFF99, 'M', 'ル'), + (0xFF9A, 'M', 'レ'), + (0xFF9B, 'M', 'ロ'), + (0xFF9C, 'M', 'ワ'), + (0xFF9D, 'M', 'ン'), + (0xFF9E, 'M', '゙'), + (0xFF9F, 'M', '゚'), + (0xFFA0, 'X'), + (0xFFA1, 'M', 'ᄀ'), + (0xFFA2, 'M', 'ᄁ'), + (0xFFA3, 'M', 'ᆪ'), + (0xFFA4, 'M', 'ᄂ'), + (0xFFA5, 'M', 'ᆬ'), + (0xFFA6, 'M', 'ᆭ'), + (0xFFA7, 'M', 'ᄃ'), + (0xFFA8, 'M', 'ᄄ'), + (0xFFA9, 'M', 'ᄅ'), + (0xFFAA, 'M', 'ᆰ'), + (0xFFAB, 'M', 'ᆱ'), + (0xFFAC, 'M', 'ᆲ'), + (0xFFAD, 'M', 'ᆳ'), + (0xFFAE, 'M', 'ᆴ'), + (0xFFAF, 'M', 'ᆵ'), + (0xFFB0, 'M', 'ᄚ'), + (0xFFB1, 'M', 'ᄆ'), + (0xFFB2, 'M', 'ᄇ'), + (0xFFB3, 'M', 'ᄈ'), + (0xFFB4, 'M', 'ᄡ'), + (0xFFB5, 'M', 'ᄉ'), + (0xFFB6, 'M', 'ᄊ'), + (0xFFB7, 'M', 'ᄋ'), + (0xFFB8, 'M', 'ᄌ'), + (0xFFB9, 'M', 'ᄍ'), + (0xFFBA, 'M', 'ᄎ'), + (0xFFBB, 'M', 'ᄏ'), + (0xFFBC, 'M', 'ᄐ'), + (0xFFBD, 'M', 'ᄑ'), + (0xFFBE, 'M', 'ᄒ'), + (0xFFBF, 'X'), + (0xFFC2, 'M', 'ᅡ'), + (0xFFC3, 'M', 'ᅢ'), + (0xFFC4, 'M', 'ᅣ'), + (0xFFC5, 'M', 'ᅤ'), + (0xFFC6, 'M', 'ᅥ'), + (0xFFC7, 'M', 'ᅦ'), + (0xFFC8, 'X'), + (0xFFCA, 'M', 'ᅧ'), + (0xFFCB, 'M', 'ᅨ'), + (0xFFCC, 'M', 'ᅩ'), + (0xFFCD, 'M', 'ᅪ'), + (0xFFCE, 'M', 'ᅫ'), + (0xFFCF, 'M', 'ᅬ'), + (0xFFD0, 'X'), + (0xFFD2, 'M', 'ᅭ'), + (0xFFD3, 'M', 'ᅮ'), + (0xFFD4, 'M', 'ᅯ'), + (0xFFD5, 'M', 'ᅰ'), + (0xFFD6, 'M', 'ᅱ'), + (0xFFD7, 'M', 'ᅲ'), + (0xFFD8, 'X'), + (0xFFDA, 'M', 'ᅳ'), + (0xFFDB, 'M', 'ᅴ'), + (0xFFDC, 'M', 'ᅵ'), + (0xFFDD, 'X'), + (0xFFE0, 'M', '¢'), + (0xFFE1, 'M', '£'), + (0xFFE2, 'M', '¬'), + (0xFFE3, '3', ' ̄'), + (0xFFE4, 'M', '¦'), + (0xFFE5, 'M', '¥'), + (0xFFE6, 'M', '₩'), + (0xFFE7, 'X'), + (0xFFE8, 'M', '│'), + (0xFFE9, 'M', '←'), + (0xFFEA, 'M', '↑'), + (0xFFEB, 'M', '→'), + (0xFFEC, 'M', '↓'), + (0xFFED, 'M', '■'), + (0xFFEE, 'M', '○'), + (0xFFEF, 'X'), + (0x10000, 'V'), + (0x1000C, 'X'), + (0x1000D, 'V'), + ] + +def _seg_53(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0x10027, 'X'), + (0x10028, 'V'), + (0x1003B, 'X'), + (0x1003C, 'V'), + (0x1003E, 'X'), + (0x1003F, 'V'), + (0x1004E, 'X'), + (0x10050, 'V'), + (0x1005E, 'X'), + (0x10080, 'V'), + (0x100FB, 'X'), + (0x10100, 'V'), + (0x10103, 'X'), + (0x10107, 'V'), + (0x10134, 'X'), + (0x10137, 'V'), + (0x1018F, 'X'), + (0x10190, 'V'), + (0x1019D, 'X'), + (0x101A0, 'V'), + (0x101A1, 'X'), + (0x101D0, 'V'), + (0x101FE, 'X'), + (0x10280, 'V'), + (0x1029D, 'X'), + (0x102A0, 'V'), + (0x102D1, 'X'), + (0x102E0, 'V'), + (0x102FC, 'X'), + (0x10300, 'V'), + (0x10324, 'X'), + (0x1032D, 'V'), + (0x1034B, 'X'), + (0x10350, 'V'), + (0x1037B, 'X'), + (0x10380, 'V'), + (0x1039E, 'X'), + (0x1039F, 'V'), + (0x103C4, 'X'), + (0x103C8, 'V'), + (0x103D6, 'X'), + (0x10400, 'M', '𐐨'), + (0x10401, 'M', '𐐩'), + (0x10402, 'M', '𐐪'), + (0x10403, 'M', '𐐫'), + (0x10404, 'M', '𐐬'), + (0x10405, 'M', '𐐭'), + (0x10406, 'M', '𐐮'), + (0x10407, 'M', '𐐯'), + (0x10408, 'M', '𐐰'), + (0x10409, 'M', '𐐱'), + (0x1040A, 'M', '𐐲'), + (0x1040B, 'M', '𐐳'), + (0x1040C, 'M', '𐐴'), + (0x1040D, 'M', '𐐵'), + (0x1040E, 'M', '𐐶'), + (0x1040F, 'M', '𐐷'), + (0x10410, 'M', '𐐸'), + (0x10411, 'M', '𐐹'), + (0x10412, 'M', '𐐺'), + (0x10413, 'M', '𐐻'), + (0x10414, 'M', '𐐼'), + (0x10415, 'M', '𐐽'), + (0x10416, 'M', '𐐾'), + (0x10417, 'M', '𐐿'), + (0x10418, 'M', '𐑀'), + (0x10419, 'M', '𐑁'), + (0x1041A, 'M', '𐑂'), + (0x1041B, 'M', '𐑃'), + (0x1041C, 'M', '𐑄'), + (0x1041D, 'M', '𐑅'), + (0x1041E, 'M', '𐑆'), + (0x1041F, 'M', '𐑇'), + (0x10420, 'M', '𐑈'), + (0x10421, 'M', '𐑉'), + (0x10422, 'M', '𐑊'), + (0x10423, 'M', '𐑋'), + (0x10424, 'M', '𐑌'), + (0x10425, 'M', '𐑍'), + (0x10426, 'M', '𐑎'), + (0x10427, 'M', '𐑏'), + (0x10428, 'V'), + (0x1049E, 'X'), + (0x104A0, 'V'), + (0x104AA, 'X'), + (0x104B0, 'M', '𐓘'), + (0x104B1, 'M', '𐓙'), + (0x104B2, 'M', '𐓚'), + (0x104B3, 'M', '𐓛'), + (0x104B4, 'M', '𐓜'), + (0x104B5, 'M', '𐓝'), + (0x104B6, 'M', '𐓞'), + (0x104B7, 'M', '𐓟'), + (0x104B8, 'M', '𐓠'), + (0x104B9, 'M', '𐓡'), + (0x104BA, 'M', '𐓢'), + (0x104BB, 'M', '𐓣'), + (0x104BC, 'M', '𐓤'), + (0x104BD, 'M', '𐓥'), + (0x104BE, 'M', '𐓦'), + ] + +def _seg_54(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0x104BF, 'M', '𐓧'), + (0x104C0, 'M', '𐓨'), + (0x104C1, 'M', '𐓩'), + (0x104C2, 'M', '𐓪'), + (0x104C3, 'M', '𐓫'), + (0x104C4, 'M', '𐓬'), + (0x104C5, 'M', '𐓭'), + (0x104C6, 'M', '𐓮'), + (0x104C7, 'M', '𐓯'), + (0x104C8, 'M', '𐓰'), + (0x104C9, 'M', '𐓱'), + (0x104CA, 'M', '𐓲'), + (0x104CB, 'M', '𐓳'), + (0x104CC, 'M', '𐓴'), + (0x104CD, 'M', '𐓵'), + (0x104CE, 'M', '𐓶'), + (0x104CF, 'M', '𐓷'), + (0x104D0, 'M', '𐓸'), + (0x104D1, 'M', '𐓹'), + (0x104D2, 'M', '𐓺'), + (0x104D3, 'M', '𐓻'), + (0x104D4, 'X'), + (0x104D8, 'V'), + (0x104FC, 'X'), + (0x10500, 'V'), + (0x10528, 'X'), + (0x10530, 'V'), + (0x10564, 'X'), + (0x1056F, 'V'), + (0x10570, 'X'), + (0x10600, 'V'), + (0x10737, 'X'), + (0x10740, 'V'), + (0x10756, 'X'), + (0x10760, 'V'), + (0x10768, 'X'), + (0x10800, 'V'), + (0x10806, 'X'), + (0x10808, 'V'), + (0x10809, 'X'), + (0x1080A, 'V'), + (0x10836, 'X'), + (0x10837, 'V'), + (0x10839, 'X'), + (0x1083C, 'V'), + (0x1083D, 'X'), + (0x1083F, 'V'), + (0x10856, 'X'), + (0x10857, 'V'), + (0x1089F, 'X'), + (0x108A7, 'V'), + (0x108B0, 'X'), + (0x108E0, 'V'), + (0x108F3, 'X'), + (0x108F4, 'V'), + (0x108F6, 'X'), + (0x108FB, 'V'), + (0x1091C, 'X'), + (0x1091F, 'V'), + (0x1093A, 'X'), + (0x1093F, 'V'), + (0x10940, 'X'), + (0x10980, 'V'), + (0x109B8, 'X'), + (0x109BC, 'V'), + (0x109D0, 'X'), + (0x109D2, 'V'), + (0x10A04, 'X'), + (0x10A05, 'V'), + (0x10A07, 'X'), + (0x10A0C, 'V'), + (0x10A14, 'X'), + (0x10A15, 'V'), + (0x10A18, 'X'), + (0x10A19, 'V'), + (0x10A36, 'X'), + (0x10A38, 'V'), + (0x10A3B, 'X'), + (0x10A3F, 'V'), + (0x10A49, 'X'), + (0x10A50, 'V'), + (0x10A59, 'X'), + (0x10A60, 'V'), + (0x10AA0, 'X'), + (0x10AC0, 'V'), + (0x10AE7, 'X'), + (0x10AEB, 'V'), + (0x10AF7, 'X'), + (0x10B00, 'V'), + (0x10B36, 'X'), + (0x10B39, 'V'), + (0x10B56, 'X'), + (0x10B58, 'V'), + (0x10B73, 'X'), + (0x10B78, 'V'), + (0x10B92, 'X'), + (0x10B99, 'V'), + (0x10B9D, 'X'), + (0x10BA9, 'V'), + (0x10BB0, 'X'), + ] + +def _seg_55(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0x10C00, 'V'), + (0x10C49, 'X'), + (0x10C80, 'M', '𐳀'), + (0x10C81, 'M', '𐳁'), + (0x10C82, 'M', '𐳂'), + (0x10C83, 'M', '𐳃'), + (0x10C84, 'M', '𐳄'), + (0x10C85, 'M', '𐳅'), + (0x10C86, 'M', '𐳆'), + (0x10C87, 'M', '𐳇'), + (0x10C88, 'M', '𐳈'), + (0x10C89, 'M', '𐳉'), + (0x10C8A, 'M', '𐳊'), + (0x10C8B, 'M', '𐳋'), + (0x10C8C, 'M', '𐳌'), + (0x10C8D, 'M', '𐳍'), + (0x10C8E, 'M', '𐳎'), + (0x10C8F, 'M', '𐳏'), + (0x10C90, 'M', '𐳐'), + (0x10C91, 'M', '𐳑'), + (0x10C92, 'M', '𐳒'), + (0x10C93, 'M', '𐳓'), + (0x10C94, 'M', '𐳔'), + (0x10C95, 'M', '𐳕'), + (0x10C96, 'M', '𐳖'), + (0x10C97, 'M', '𐳗'), + (0x10C98, 'M', '𐳘'), + (0x10C99, 'M', '𐳙'), + (0x10C9A, 'M', '𐳚'), + (0x10C9B, 'M', '𐳛'), + (0x10C9C, 'M', '𐳜'), + (0x10C9D, 'M', '𐳝'), + (0x10C9E, 'M', '𐳞'), + (0x10C9F, 'M', '𐳟'), + (0x10CA0, 'M', '𐳠'), + (0x10CA1, 'M', '𐳡'), + (0x10CA2, 'M', '𐳢'), + (0x10CA3, 'M', '𐳣'), + (0x10CA4, 'M', '𐳤'), + (0x10CA5, 'M', '𐳥'), + (0x10CA6, 'M', '𐳦'), + (0x10CA7, 'M', '𐳧'), + (0x10CA8, 'M', '𐳨'), + (0x10CA9, 'M', '𐳩'), + (0x10CAA, 'M', '𐳪'), + (0x10CAB, 'M', '𐳫'), + (0x10CAC, 'M', '𐳬'), + (0x10CAD, 'M', '𐳭'), + (0x10CAE, 'M', '𐳮'), + (0x10CAF, 'M', '𐳯'), + (0x10CB0, 'M', '𐳰'), + (0x10CB1, 'M', '𐳱'), + (0x10CB2, 'M', '𐳲'), + (0x10CB3, 'X'), + (0x10CC0, 'V'), + (0x10CF3, 'X'), + (0x10CFA, 'V'), + (0x10D28, 'X'), + (0x10D30, 'V'), + (0x10D3A, 'X'), + (0x10E60, 'V'), + (0x10E7F, 'X'), + (0x10E80, 'V'), + (0x10EAA, 'X'), + (0x10EAB, 'V'), + (0x10EAE, 'X'), + (0x10EB0, 'V'), + (0x10EB2, 'X'), + (0x10F00, 'V'), + (0x10F28, 'X'), + (0x10F30, 'V'), + (0x10F5A, 'X'), + (0x10FB0, 'V'), + (0x10FCC, 'X'), + (0x10FE0, 'V'), + (0x10FF7, 'X'), + (0x11000, 'V'), + (0x1104E, 'X'), + (0x11052, 'V'), + (0x11070, 'X'), + (0x1107F, 'V'), + (0x110BD, 'X'), + (0x110BE, 'V'), + (0x110C2, 'X'), + (0x110D0, 'V'), + (0x110E9, 'X'), + (0x110F0, 'V'), + (0x110FA, 'X'), + (0x11100, 'V'), + (0x11135, 'X'), + (0x11136, 'V'), + (0x11148, 'X'), + (0x11150, 'V'), + (0x11177, 'X'), + (0x11180, 'V'), + (0x111E0, 'X'), + (0x111E1, 'V'), + (0x111F5, 'X'), + (0x11200, 'V'), + (0x11212, 'X'), + ] + +def _seg_56(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0x11213, 'V'), + (0x1123F, 'X'), + (0x11280, 'V'), + (0x11287, 'X'), + (0x11288, 'V'), + (0x11289, 'X'), + (0x1128A, 'V'), + (0x1128E, 'X'), + (0x1128F, 'V'), + (0x1129E, 'X'), + (0x1129F, 'V'), + (0x112AA, 'X'), + (0x112B0, 'V'), + (0x112EB, 'X'), + (0x112F0, 'V'), + (0x112FA, 'X'), + (0x11300, 'V'), + (0x11304, 'X'), + (0x11305, 'V'), + (0x1130D, 'X'), + (0x1130F, 'V'), + (0x11311, 'X'), + (0x11313, 'V'), + (0x11329, 'X'), + (0x1132A, 'V'), + (0x11331, 'X'), + (0x11332, 'V'), + (0x11334, 'X'), + (0x11335, 'V'), + (0x1133A, 'X'), + (0x1133B, 'V'), + (0x11345, 'X'), + (0x11347, 'V'), + (0x11349, 'X'), + (0x1134B, 'V'), + (0x1134E, 'X'), + (0x11350, 'V'), + (0x11351, 'X'), + (0x11357, 'V'), + (0x11358, 'X'), + (0x1135D, 'V'), + (0x11364, 'X'), + (0x11366, 'V'), + (0x1136D, 'X'), + (0x11370, 'V'), + (0x11375, 'X'), + (0x11400, 'V'), + (0x1145C, 'X'), + (0x1145D, 'V'), + (0x11462, 'X'), + (0x11480, 'V'), + (0x114C8, 'X'), + (0x114D0, 'V'), + (0x114DA, 'X'), + (0x11580, 'V'), + (0x115B6, 'X'), + (0x115B8, 'V'), + (0x115DE, 'X'), + (0x11600, 'V'), + (0x11645, 'X'), + (0x11650, 'V'), + (0x1165A, 'X'), + (0x11660, 'V'), + (0x1166D, 'X'), + (0x11680, 'V'), + (0x116B9, 'X'), + (0x116C0, 'V'), + (0x116CA, 'X'), + (0x11700, 'V'), + (0x1171B, 'X'), + (0x1171D, 'V'), + (0x1172C, 'X'), + (0x11730, 'V'), + (0x11740, 'X'), + (0x11800, 'V'), + (0x1183C, 'X'), + (0x118A0, 'M', '𑣀'), + (0x118A1, 'M', '𑣁'), + (0x118A2, 'M', '𑣂'), + (0x118A3, 'M', '𑣃'), + (0x118A4, 'M', '𑣄'), + (0x118A5, 'M', '𑣅'), + (0x118A6, 'M', '𑣆'), + (0x118A7, 'M', '𑣇'), + (0x118A8, 'M', '𑣈'), + (0x118A9, 'M', '𑣉'), + (0x118AA, 'M', '𑣊'), + (0x118AB, 'M', '𑣋'), + (0x118AC, 'M', '𑣌'), + (0x118AD, 'M', '𑣍'), + (0x118AE, 'M', '𑣎'), + (0x118AF, 'M', '𑣏'), + (0x118B0, 'M', '𑣐'), + (0x118B1, 'M', '𑣑'), + (0x118B2, 'M', '𑣒'), + (0x118B3, 'M', '𑣓'), + (0x118B4, 'M', '𑣔'), + (0x118B5, 'M', '𑣕'), + (0x118B6, 'M', '𑣖'), + (0x118B7, 'M', '𑣗'), + ] + +def _seg_57(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0x118B8, 'M', '𑣘'), + (0x118B9, 'M', '𑣙'), + (0x118BA, 'M', '𑣚'), + (0x118BB, 'M', '𑣛'), + (0x118BC, 'M', '𑣜'), + (0x118BD, 'M', '𑣝'), + (0x118BE, 'M', '𑣞'), + (0x118BF, 'M', '𑣟'), + (0x118C0, 'V'), + (0x118F3, 'X'), + (0x118FF, 'V'), + (0x11907, 'X'), + (0x11909, 'V'), + (0x1190A, 'X'), + (0x1190C, 'V'), + (0x11914, 'X'), + (0x11915, 'V'), + (0x11917, 'X'), + (0x11918, 'V'), + (0x11936, 'X'), + (0x11937, 'V'), + (0x11939, 'X'), + (0x1193B, 'V'), + (0x11947, 'X'), + (0x11950, 'V'), + (0x1195A, 'X'), + (0x119A0, 'V'), + (0x119A8, 'X'), + (0x119AA, 'V'), + (0x119D8, 'X'), + (0x119DA, 'V'), + (0x119E5, 'X'), + (0x11A00, 'V'), + (0x11A48, 'X'), + (0x11A50, 'V'), + (0x11AA3, 'X'), + (0x11AC0, 'V'), + (0x11AF9, 'X'), + (0x11C00, 'V'), + (0x11C09, 'X'), + (0x11C0A, 'V'), + (0x11C37, 'X'), + (0x11C38, 'V'), + (0x11C46, 'X'), + (0x11C50, 'V'), + (0x11C6D, 'X'), + (0x11C70, 'V'), + (0x11C90, 'X'), + (0x11C92, 'V'), + (0x11CA8, 'X'), + (0x11CA9, 'V'), + (0x11CB7, 'X'), + (0x11D00, 'V'), + (0x11D07, 'X'), + (0x11D08, 'V'), + (0x11D0A, 'X'), + (0x11D0B, 'V'), + (0x11D37, 'X'), + (0x11D3A, 'V'), + (0x11D3B, 'X'), + (0x11D3C, 'V'), + (0x11D3E, 'X'), + (0x11D3F, 'V'), + (0x11D48, 'X'), + (0x11D50, 'V'), + (0x11D5A, 'X'), + (0x11D60, 'V'), + (0x11D66, 'X'), + (0x11D67, 'V'), + (0x11D69, 'X'), + (0x11D6A, 'V'), + (0x11D8F, 'X'), + (0x11D90, 'V'), + (0x11D92, 'X'), + (0x11D93, 'V'), + (0x11D99, 'X'), + (0x11DA0, 'V'), + (0x11DAA, 'X'), + (0x11EE0, 'V'), + (0x11EF9, 'X'), + (0x11FB0, 'V'), + (0x11FB1, 'X'), + (0x11FC0, 'V'), + (0x11FF2, 'X'), + (0x11FFF, 'V'), + (0x1239A, 'X'), + (0x12400, 'V'), + (0x1246F, 'X'), + (0x12470, 'V'), + (0x12475, 'X'), + (0x12480, 'V'), + (0x12544, 'X'), + (0x13000, 'V'), + (0x1342F, 'X'), + (0x14400, 'V'), + (0x14647, 'X'), + (0x16800, 'V'), + (0x16A39, 'X'), + (0x16A40, 'V'), + (0x16A5F, 'X'), + ] + +def _seg_58(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0x16A60, 'V'), + (0x16A6A, 'X'), + (0x16A6E, 'V'), + (0x16A70, 'X'), + (0x16AD0, 'V'), + (0x16AEE, 'X'), + (0x16AF0, 'V'), + (0x16AF6, 'X'), + (0x16B00, 'V'), + (0x16B46, 'X'), + (0x16B50, 'V'), + (0x16B5A, 'X'), + (0x16B5B, 'V'), + (0x16B62, 'X'), + (0x16B63, 'V'), + (0x16B78, 'X'), + (0x16B7D, 'V'), + (0x16B90, 'X'), + (0x16E40, 'M', '𖹠'), + (0x16E41, 'M', '𖹡'), + (0x16E42, 'M', '𖹢'), + (0x16E43, 'M', '𖹣'), + (0x16E44, 'M', '𖹤'), + (0x16E45, 'M', '𖹥'), + (0x16E46, 'M', '𖹦'), + (0x16E47, 'M', '𖹧'), + (0x16E48, 'M', '𖹨'), + (0x16E49, 'M', '𖹩'), + (0x16E4A, 'M', '𖹪'), + (0x16E4B, 'M', '𖹫'), + (0x16E4C, 'M', '𖹬'), + (0x16E4D, 'M', '𖹭'), + (0x16E4E, 'M', '𖹮'), + (0x16E4F, 'M', '𖹯'), + (0x16E50, 'M', '𖹰'), + (0x16E51, 'M', '𖹱'), + (0x16E52, 'M', '𖹲'), + (0x16E53, 'M', '𖹳'), + (0x16E54, 'M', '𖹴'), + (0x16E55, 'M', '𖹵'), + (0x16E56, 'M', '𖹶'), + (0x16E57, 'M', '𖹷'), + (0x16E58, 'M', '𖹸'), + (0x16E59, 'M', '𖹹'), + (0x16E5A, 'M', '𖹺'), + (0x16E5B, 'M', '𖹻'), + (0x16E5C, 'M', '𖹼'), + (0x16E5D, 'M', '𖹽'), + (0x16E5E, 'M', '𖹾'), + (0x16E5F, 'M', '𖹿'), + (0x16E60, 'V'), + (0x16E9B, 'X'), + (0x16F00, 'V'), + (0x16F4B, 'X'), + (0x16F4F, 'V'), + (0x16F88, 'X'), + (0x16F8F, 'V'), + (0x16FA0, 'X'), + (0x16FE0, 'V'), + (0x16FE5, 'X'), + (0x16FF0, 'V'), + (0x16FF2, 'X'), + (0x17000, 'V'), + (0x187F8, 'X'), + (0x18800, 'V'), + (0x18CD6, 'X'), + (0x18D00, 'V'), + (0x18D09, 'X'), + (0x1B000, 'V'), + (0x1B11F, 'X'), + (0x1B150, 'V'), + (0x1B153, 'X'), + (0x1B164, 'V'), + (0x1B168, 'X'), + (0x1B170, 'V'), + (0x1B2FC, 'X'), + (0x1BC00, 'V'), + (0x1BC6B, 'X'), + (0x1BC70, 'V'), + (0x1BC7D, 'X'), + (0x1BC80, 'V'), + (0x1BC89, 'X'), + (0x1BC90, 'V'), + (0x1BC9A, 'X'), + (0x1BC9C, 'V'), + (0x1BCA0, 'I'), + (0x1BCA4, 'X'), + (0x1D000, 'V'), + (0x1D0F6, 'X'), + (0x1D100, 'V'), + (0x1D127, 'X'), + (0x1D129, 'V'), + (0x1D15E, 'M', '𝅗𝅥'), + (0x1D15F, 'M', '𝅘𝅥'), + (0x1D160, 'M', '𝅘𝅥𝅮'), + (0x1D161, 'M', '𝅘𝅥𝅯'), + (0x1D162, 'M', '𝅘𝅥𝅰'), + (0x1D163, 'M', '𝅘𝅥𝅱'), + (0x1D164, 'M', '𝅘𝅥𝅲'), + (0x1D165, 'V'), + ] + +def _seg_59(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0x1D173, 'X'), + (0x1D17B, 'V'), + (0x1D1BB, 'M', '𝆹𝅥'), + (0x1D1BC, 'M', '𝆺𝅥'), + (0x1D1BD, 'M', '𝆹𝅥𝅮'), + (0x1D1BE, 'M', '𝆺𝅥𝅮'), + (0x1D1BF, 'M', '𝆹𝅥𝅯'), + (0x1D1C0, 'M', '𝆺𝅥𝅯'), + (0x1D1C1, 'V'), + (0x1D1E9, 'X'), + (0x1D200, 'V'), + (0x1D246, 'X'), + (0x1D2E0, 'V'), + (0x1D2F4, 'X'), + (0x1D300, 'V'), + (0x1D357, 'X'), + (0x1D360, 'V'), + (0x1D379, 'X'), + (0x1D400, 'M', 'a'), + (0x1D401, 'M', 'b'), + (0x1D402, 'M', 'c'), + (0x1D403, 'M', 'd'), + (0x1D404, 'M', 'e'), + (0x1D405, 'M', 'f'), + (0x1D406, 'M', 'g'), + (0x1D407, 'M', 'h'), + (0x1D408, 'M', 'i'), + (0x1D409, 'M', 'j'), + (0x1D40A, 'M', 'k'), + (0x1D40B, 'M', 'l'), + (0x1D40C, 'M', 'm'), + (0x1D40D, 'M', 'n'), + (0x1D40E, 'M', 'o'), + (0x1D40F, 'M', 'p'), + (0x1D410, 'M', 'q'), + (0x1D411, 'M', 'r'), + (0x1D412, 'M', 's'), + (0x1D413, 'M', 't'), + (0x1D414, 'M', 'u'), + (0x1D415, 'M', 'v'), + (0x1D416, 'M', 'w'), + (0x1D417, 'M', 'x'), + (0x1D418, 'M', 'y'), + (0x1D419, 'M', 'z'), + (0x1D41A, 'M', 'a'), + (0x1D41B, 'M', 'b'), + (0x1D41C, 'M', 'c'), + (0x1D41D, 'M', 'd'), + (0x1D41E, 'M', 'e'), + (0x1D41F, 'M', 'f'), + (0x1D420, 'M', 'g'), + (0x1D421, 'M', 'h'), + (0x1D422, 'M', 'i'), + (0x1D423, 'M', 'j'), + (0x1D424, 'M', 'k'), + (0x1D425, 'M', 'l'), + (0x1D426, 'M', 'm'), + (0x1D427, 'M', 'n'), + (0x1D428, 'M', 'o'), + (0x1D429, 'M', 'p'), + (0x1D42A, 'M', 'q'), + (0x1D42B, 'M', 'r'), + (0x1D42C, 'M', 's'), + (0x1D42D, 'M', 't'), + (0x1D42E, 'M', 'u'), + (0x1D42F, 'M', 'v'), + (0x1D430, 'M', 'w'), + (0x1D431, 'M', 'x'), + (0x1D432, 'M', 'y'), + (0x1D433, 'M', 'z'), + (0x1D434, 'M', 'a'), + (0x1D435, 'M', 'b'), + (0x1D436, 'M', 'c'), + (0x1D437, 'M', 'd'), + (0x1D438, 'M', 'e'), + (0x1D439, 'M', 'f'), + (0x1D43A, 'M', 'g'), + (0x1D43B, 'M', 'h'), + (0x1D43C, 'M', 'i'), + (0x1D43D, 'M', 'j'), + (0x1D43E, 'M', 'k'), + (0x1D43F, 'M', 'l'), + (0x1D440, 'M', 'm'), + (0x1D441, 'M', 'n'), + (0x1D442, 'M', 'o'), + (0x1D443, 'M', 'p'), + (0x1D444, 'M', 'q'), + (0x1D445, 'M', 'r'), + (0x1D446, 'M', 's'), + (0x1D447, 'M', 't'), + (0x1D448, 'M', 'u'), + (0x1D449, 'M', 'v'), + (0x1D44A, 'M', 'w'), + (0x1D44B, 'M', 'x'), + (0x1D44C, 'M', 'y'), + (0x1D44D, 'M', 'z'), + (0x1D44E, 'M', 'a'), + (0x1D44F, 'M', 'b'), + (0x1D450, 'M', 'c'), + (0x1D451, 'M', 'd'), + ] + +def _seg_60(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0x1D452, 'M', 'e'), + (0x1D453, 'M', 'f'), + (0x1D454, 'M', 'g'), + (0x1D455, 'X'), + (0x1D456, 'M', 'i'), + (0x1D457, 'M', 'j'), + (0x1D458, 'M', 'k'), + (0x1D459, 'M', 'l'), + (0x1D45A, 'M', 'm'), + (0x1D45B, 'M', 'n'), + (0x1D45C, 'M', 'o'), + (0x1D45D, 'M', 'p'), + (0x1D45E, 'M', 'q'), + (0x1D45F, 'M', 'r'), + (0x1D460, 'M', 's'), + (0x1D461, 'M', 't'), + (0x1D462, 'M', 'u'), + (0x1D463, 'M', 'v'), + (0x1D464, 'M', 'w'), + (0x1D465, 'M', 'x'), + (0x1D466, 'M', 'y'), + (0x1D467, 'M', 'z'), + (0x1D468, 'M', 'a'), + (0x1D469, 'M', 'b'), + (0x1D46A, 'M', 'c'), + (0x1D46B, 'M', 'd'), + (0x1D46C, 'M', 'e'), + (0x1D46D, 'M', 'f'), + (0x1D46E, 'M', 'g'), + (0x1D46F, 'M', 'h'), + (0x1D470, 'M', 'i'), + (0x1D471, 'M', 'j'), + (0x1D472, 'M', 'k'), + (0x1D473, 'M', 'l'), + (0x1D474, 'M', 'm'), + (0x1D475, 'M', 'n'), + (0x1D476, 'M', 'o'), + (0x1D477, 'M', 'p'), + (0x1D478, 'M', 'q'), + (0x1D479, 'M', 'r'), + (0x1D47A, 'M', 's'), + (0x1D47B, 'M', 't'), + (0x1D47C, 'M', 'u'), + (0x1D47D, 'M', 'v'), + (0x1D47E, 'M', 'w'), + (0x1D47F, 'M', 'x'), + (0x1D480, 'M', 'y'), + (0x1D481, 'M', 'z'), + (0x1D482, 'M', 'a'), + (0x1D483, 'M', 'b'), + (0x1D484, 'M', 'c'), + (0x1D485, 'M', 'd'), + (0x1D486, 'M', 'e'), + (0x1D487, 'M', 'f'), + (0x1D488, 'M', 'g'), + (0x1D489, 'M', 'h'), + (0x1D48A, 'M', 'i'), + (0x1D48B, 'M', 'j'), + (0x1D48C, 'M', 'k'), + (0x1D48D, 'M', 'l'), + (0x1D48E, 'M', 'm'), + (0x1D48F, 'M', 'n'), + (0x1D490, 'M', 'o'), + (0x1D491, 'M', 'p'), + (0x1D492, 'M', 'q'), + (0x1D493, 'M', 'r'), + (0x1D494, 'M', 's'), + (0x1D495, 'M', 't'), + (0x1D496, 'M', 'u'), + (0x1D497, 'M', 'v'), + (0x1D498, 'M', 'w'), + (0x1D499, 'M', 'x'), + (0x1D49A, 'M', 'y'), + (0x1D49B, 'M', 'z'), + (0x1D49C, 'M', 'a'), + (0x1D49D, 'X'), + (0x1D49E, 'M', 'c'), + (0x1D49F, 'M', 'd'), + (0x1D4A0, 'X'), + (0x1D4A2, 'M', 'g'), + (0x1D4A3, 'X'), + (0x1D4A5, 'M', 'j'), + (0x1D4A6, 'M', 'k'), + (0x1D4A7, 'X'), + (0x1D4A9, 'M', 'n'), + (0x1D4AA, 'M', 'o'), + (0x1D4AB, 'M', 'p'), + (0x1D4AC, 'M', 'q'), + (0x1D4AD, 'X'), + (0x1D4AE, 'M', 's'), + (0x1D4AF, 'M', 't'), + (0x1D4B0, 'M', 'u'), + (0x1D4B1, 'M', 'v'), + (0x1D4B2, 'M', 'w'), + (0x1D4B3, 'M', 'x'), + (0x1D4B4, 'M', 'y'), + (0x1D4B5, 'M', 'z'), + (0x1D4B6, 'M', 'a'), + (0x1D4B7, 'M', 'b'), + (0x1D4B8, 'M', 'c'), + ] + +def _seg_61(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0x1D4B9, 'M', 'd'), + (0x1D4BA, 'X'), + (0x1D4BB, 'M', 'f'), + (0x1D4BC, 'X'), + (0x1D4BD, 'M', 'h'), + (0x1D4BE, 'M', 'i'), + (0x1D4BF, 'M', 'j'), + (0x1D4C0, 'M', 'k'), + (0x1D4C1, 'M', 'l'), + (0x1D4C2, 'M', 'm'), + (0x1D4C3, 'M', 'n'), + (0x1D4C4, 'X'), + (0x1D4C5, 'M', 'p'), + (0x1D4C6, 'M', 'q'), + (0x1D4C7, 'M', 'r'), + (0x1D4C8, 'M', 's'), + (0x1D4C9, 'M', 't'), + (0x1D4CA, 'M', 'u'), + (0x1D4CB, 'M', 'v'), + (0x1D4CC, 'M', 'w'), + (0x1D4CD, 'M', 'x'), + (0x1D4CE, 'M', 'y'), + (0x1D4CF, 'M', 'z'), + (0x1D4D0, 'M', 'a'), + (0x1D4D1, 'M', 'b'), + (0x1D4D2, 'M', 'c'), + (0x1D4D3, 'M', 'd'), + (0x1D4D4, 'M', 'e'), + (0x1D4D5, 'M', 'f'), + (0x1D4D6, 'M', 'g'), + (0x1D4D7, 'M', 'h'), + (0x1D4D8, 'M', 'i'), + (0x1D4D9, 'M', 'j'), + (0x1D4DA, 'M', 'k'), + (0x1D4DB, 'M', 'l'), + (0x1D4DC, 'M', 'm'), + (0x1D4DD, 'M', 'n'), + (0x1D4DE, 'M', 'o'), + (0x1D4DF, 'M', 'p'), + (0x1D4E0, 'M', 'q'), + (0x1D4E1, 'M', 'r'), + (0x1D4E2, 'M', 's'), + (0x1D4E3, 'M', 't'), + (0x1D4E4, 'M', 'u'), + (0x1D4E5, 'M', 'v'), + (0x1D4E6, 'M', 'w'), + (0x1D4E7, 'M', 'x'), + (0x1D4E8, 'M', 'y'), + (0x1D4E9, 'M', 'z'), + (0x1D4EA, 'M', 'a'), + (0x1D4EB, 'M', 'b'), + (0x1D4EC, 'M', 'c'), + (0x1D4ED, 'M', 'd'), + (0x1D4EE, 'M', 'e'), + (0x1D4EF, 'M', 'f'), + (0x1D4F0, 'M', 'g'), + (0x1D4F1, 'M', 'h'), + (0x1D4F2, 'M', 'i'), + (0x1D4F3, 'M', 'j'), + (0x1D4F4, 'M', 'k'), + (0x1D4F5, 'M', 'l'), + (0x1D4F6, 'M', 'm'), + (0x1D4F7, 'M', 'n'), + (0x1D4F8, 'M', 'o'), + (0x1D4F9, 'M', 'p'), + (0x1D4FA, 'M', 'q'), + (0x1D4FB, 'M', 'r'), + (0x1D4FC, 'M', 's'), + (0x1D4FD, 'M', 't'), + (0x1D4FE, 'M', 'u'), + (0x1D4FF, 'M', 'v'), + (0x1D500, 'M', 'w'), + (0x1D501, 'M', 'x'), + (0x1D502, 'M', 'y'), + (0x1D503, 'M', 'z'), + (0x1D504, 'M', 'a'), + (0x1D505, 'M', 'b'), + (0x1D506, 'X'), + (0x1D507, 'M', 'd'), + (0x1D508, 'M', 'e'), + (0x1D509, 'M', 'f'), + (0x1D50A, 'M', 'g'), + (0x1D50B, 'X'), + (0x1D50D, 'M', 'j'), + (0x1D50E, 'M', 'k'), + (0x1D50F, 'M', 'l'), + (0x1D510, 'M', 'm'), + (0x1D511, 'M', 'n'), + (0x1D512, 'M', 'o'), + (0x1D513, 'M', 'p'), + (0x1D514, 'M', 'q'), + (0x1D515, 'X'), + (0x1D516, 'M', 's'), + (0x1D517, 'M', 't'), + (0x1D518, 'M', 'u'), + (0x1D519, 'M', 'v'), + (0x1D51A, 'M', 'w'), + (0x1D51B, 'M', 'x'), + (0x1D51C, 'M', 'y'), + (0x1D51D, 'X'), + ] + +def _seg_62(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0x1D51E, 'M', 'a'), + (0x1D51F, 'M', 'b'), + (0x1D520, 'M', 'c'), + (0x1D521, 'M', 'd'), + (0x1D522, 'M', 'e'), + (0x1D523, 'M', 'f'), + (0x1D524, 'M', 'g'), + (0x1D525, 'M', 'h'), + (0x1D526, 'M', 'i'), + (0x1D527, 'M', 'j'), + (0x1D528, 'M', 'k'), + (0x1D529, 'M', 'l'), + (0x1D52A, 'M', 'm'), + (0x1D52B, 'M', 'n'), + (0x1D52C, 'M', 'o'), + (0x1D52D, 'M', 'p'), + (0x1D52E, 'M', 'q'), + (0x1D52F, 'M', 'r'), + (0x1D530, 'M', 's'), + (0x1D531, 'M', 't'), + (0x1D532, 'M', 'u'), + (0x1D533, 'M', 'v'), + (0x1D534, 'M', 'w'), + (0x1D535, 'M', 'x'), + (0x1D536, 'M', 'y'), + (0x1D537, 'M', 'z'), + (0x1D538, 'M', 'a'), + (0x1D539, 'M', 'b'), + (0x1D53A, 'X'), + (0x1D53B, 'M', 'd'), + (0x1D53C, 'M', 'e'), + (0x1D53D, 'M', 'f'), + (0x1D53E, 'M', 'g'), + (0x1D53F, 'X'), + (0x1D540, 'M', 'i'), + (0x1D541, 'M', 'j'), + (0x1D542, 'M', 'k'), + (0x1D543, 'M', 'l'), + (0x1D544, 'M', 'm'), + (0x1D545, 'X'), + (0x1D546, 'M', 'o'), + (0x1D547, 'X'), + (0x1D54A, 'M', 's'), + (0x1D54B, 'M', 't'), + (0x1D54C, 'M', 'u'), + (0x1D54D, 'M', 'v'), + (0x1D54E, 'M', 'w'), + (0x1D54F, 'M', 'x'), + (0x1D550, 'M', 'y'), + (0x1D551, 'X'), + (0x1D552, 'M', 'a'), + (0x1D553, 'M', 'b'), + (0x1D554, 'M', 'c'), + (0x1D555, 'M', 'd'), + (0x1D556, 'M', 'e'), + (0x1D557, 'M', 'f'), + (0x1D558, 'M', 'g'), + (0x1D559, 'M', 'h'), + (0x1D55A, 'M', 'i'), + (0x1D55B, 'M', 'j'), + (0x1D55C, 'M', 'k'), + (0x1D55D, 'M', 'l'), + (0x1D55E, 'M', 'm'), + (0x1D55F, 'M', 'n'), + (0x1D560, 'M', 'o'), + (0x1D561, 'M', 'p'), + (0x1D562, 'M', 'q'), + (0x1D563, 'M', 'r'), + (0x1D564, 'M', 's'), + (0x1D565, 'M', 't'), + (0x1D566, 'M', 'u'), + (0x1D567, 'M', 'v'), + (0x1D568, 'M', 'w'), + (0x1D569, 'M', 'x'), + (0x1D56A, 'M', 'y'), + (0x1D56B, 'M', 'z'), + (0x1D56C, 'M', 'a'), + (0x1D56D, 'M', 'b'), + (0x1D56E, 'M', 'c'), + (0x1D56F, 'M', 'd'), + (0x1D570, 'M', 'e'), + (0x1D571, 'M', 'f'), + (0x1D572, 'M', 'g'), + (0x1D573, 'M', 'h'), + (0x1D574, 'M', 'i'), + (0x1D575, 'M', 'j'), + (0x1D576, 'M', 'k'), + (0x1D577, 'M', 'l'), + (0x1D578, 'M', 'm'), + (0x1D579, 'M', 'n'), + (0x1D57A, 'M', 'o'), + (0x1D57B, 'M', 'p'), + (0x1D57C, 'M', 'q'), + (0x1D57D, 'M', 'r'), + (0x1D57E, 'M', 's'), + (0x1D57F, 'M', 't'), + (0x1D580, 'M', 'u'), + (0x1D581, 'M', 'v'), + (0x1D582, 'M', 'w'), + (0x1D583, 'M', 'x'), + ] + +def _seg_63(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0x1D584, 'M', 'y'), + (0x1D585, 'M', 'z'), + (0x1D586, 'M', 'a'), + (0x1D587, 'M', 'b'), + (0x1D588, 'M', 'c'), + (0x1D589, 'M', 'd'), + (0x1D58A, 'M', 'e'), + (0x1D58B, 'M', 'f'), + (0x1D58C, 'M', 'g'), + (0x1D58D, 'M', 'h'), + (0x1D58E, 'M', 'i'), + (0x1D58F, 'M', 'j'), + (0x1D590, 'M', 'k'), + (0x1D591, 'M', 'l'), + (0x1D592, 'M', 'm'), + (0x1D593, 'M', 'n'), + (0x1D594, 'M', 'o'), + (0x1D595, 'M', 'p'), + (0x1D596, 'M', 'q'), + (0x1D597, 'M', 'r'), + (0x1D598, 'M', 's'), + (0x1D599, 'M', 't'), + (0x1D59A, 'M', 'u'), + (0x1D59B, 'M', 'v'), + (0x1D59C, 'M', 'w'), + (0x1D59D, 'M', 'x'), + (0x1D59E, 'M', 'y'), + (0x1D59F, 'M', 'z'), + (0x1D5A0, 'M', 'a'), + (0x1D5A1, 'M', 'b'), + (0x1D5A2, 'M', 'c'), + (0x1D5A3, 'M', 'd'), + (0x1D5A4, 'M', 'e'), + (0x1D5A5, 'M', 'f'), + (0x1D5A6, 'M', 'g'), + (0x1D5A7, 'M', 'h'), + (0x1D5A8, 'M', 'i'), + (0x1D5A9, 'M', 'j'), + (0x1D5AA, 'M', 'k'), + (0x1D5AB, 'M', 'l'), + (0x1D5AC, 'M', 'm'), + (0x1D5AD, 'M', 'n'), + (0x1D5AE, 'M', 'o'), + (0x1D5AF, 'M', 'p'), + (0x1D5B0, 'M', 'q'), + (0x1D5B1, 'M', 'r'), + (0x1D5B2, 'M', 's'), + (0x1D5B3, 'M', 't'), + (0x1D5B4, 'M', 'u'), + (0x1D5B5, 'M', 'v'), + (0x1D5B6, 'M', 'w'), + (0x1D5B7, 'M', 'x'), + (0x1D5B8, 'M', 'y'), + (0x1D5B9, 'M', 'z'), + (0x1D5BA, 'M', 'a'), + (0x1D5BB, 'M', 'b'), + (0x1D5BC, 'M', 'c'), + (0x1D5BD, 'M', 'd'), + (0x1D5BE, 'M', 'e'), + (0x1D5BF, 'M', 'f'), + (0x1D5C0, 'M', 'g'), + (0x1D5C1, 'M', 'h'), + (0x1D5C2, 'M', 'i'), + (0x1D5C3, 'M', 'j'), + (0x1D5C4, 'M', 'k'), + (0x1D5C5, 'M', 'l'), + (0x1D5C6, 'M', 'm'), + (0x1D5C7, 'M', 'n'), + (0x1D5C8, 'M', 'o'), + (0x1D5C9, 'M', 'p'), + (0x1D5CA, 'M', 'q'), + (0x1D5CB, 'M', 'r'), + (0x1D5CC, 'M', 's'), + (0x1D5CD, 'M', 't'), + (0x1D5CE, 'M', 'u'), + (0x1D5CF, 'M', 'v'), + (0x1D5D0, 'M', 'w'), + (0x1D5D1, 'M', 'x'), + (0x1D5D2, 'M', 'y'), + (0x1D5D3, 'M', 'z'), + (0x1D5D4, 'M', 'a'), + (0x1D5D5, 'M', 'b'), + (0x1D5D6, 'M', 'c'), + (0x1D5D7, 'M', 'd'), + (0x1D5D8, 'M', 'e'), + (0x1D5D9, 'M', 'f'), + (0x1D5DA, 'M', 'g'), + (0x1D5DB, 'M', 'h'), + (0x1D5DC, 'M', 'i'), + (0x1D5DD, 'M', 'j'), + (0x1D5DE, 'M', 'k'), + (0x1D5DF, 'M', 'l'), + (0x1D5E0, 'M', 'm'), + (0x1D5E1, 'M', 'n'), + (0x1D5E2, 'M', 'o'), + (0x1D5E3, 'M', 'p'), + (0x1D5E4, 'M', 'q'), + (0x1D5E5, 'M', 'r'), + (0x1D5E6, 'M', 's'), + (0x1D5E7, 'M', 't'), + ] + +def _seg_64(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0x1D5E8, 'M', 'u'), + (0x1D5E9, 'M', 'v'), + (0x1D5EA, 'M', 'w'), + (0x1D5EB, 'M', 'x'), + (0x1D5EC, 'M', 'y'), + (0x1D5ED, 'M', 'z'), + (0x1D5EE, 'M', 'a'), + (0x1D5EF, 'M', 'b'), + (0x1D5F0, 'M', 'c'), + (0x1D5F1, 'M', 'd'), + (0x1D5F2, 'M', 'e'), + (0x1D5F3, 'M', 'f'), + (0x1D5F4, 'M', 'g'), + (0x1D5F5, 'M', 'h'), + (0x1D5F6, 'M', 'i'), + (0x1D5F7, 'M', 'j'), + (0x1D5F8, 'M', 'k'), + (0x1D5F9, 'M', 'l'), + (0x1D5FA, 'M', 'm'), + (0x1D5FB, 'M', 'n'), + (0x1D5FC, 'M', 'o'), + (0x1D5FD, 'M', 'p'), + (0x1D5FE, 'M', 'q'), + (0x1D5FF, 'M', 'r'), + (0x1D600, 'M', 's'), + (0x1D601, 'M', 't'), + (0x1D602, 'M', 'u'), + (0x1D603, 'M', 'v'), + (0x1D604, 'M', 'w'), + (0x1D605, 'M', 'x'), + (0x1D606, 'M', 'y'), + (0x1D607, 'M', 'z'), + (0x1D608, 'M', 'a'), + (0x1D609, 'M', 'b'), + (0x1D60A, 'M', 'c'), + (0x1D60B, 'M', 'd'), + (0x1D60C, 'M', 'e'), + (0x1D60D, 'M', 'f'), + (0x1D60E, 'M', 'g'), + (0x1D60F, 'M', 'h'), + (0x1D610, 'M', 'i'), + (0x1D611, 'M', 'j'), + (0x1D612, 'M', 'k'), + (0x1D613, 'M', 'l'), + (0x1D614, 'M', 'm'), + (0x1D615, 'M', 'n'), + (0x1D616, 'M', 'o'), + (0x1D617, 'M', 'p'), + (0x1D618, 'M', 'q'), + (0x1D619, 'M', 'r'), + (0x1D61A, 'M', 's'), + (0x1D61B, 'M', 't'), + (0x1D61C, 'M', 'u'), + (0x1D61D, 'M', 'v'), + (0x1D61E, 'M', 'w'), + (0x1D61F, 'M', 'x'), + (0x1D620, 'M', 'y'), + (0x1D621, 'M', 'z'), + (0x1D622, 'M', 'a'), + (0x1D623, 'M', 'b'), + (0x1D624, 'M', 'c'), + (0x1D625, 'M', 'd'), + (0x1D626, 'M', 'e'), + (0x1D627, 'M', 'f'), + (0x1D628, 'M', 'g'), + (0x1D629, 'M', 'h'), + (0x1D62A, 'M', 'i'), + (0x1D62B, 'M', 'j'), + (0x1D62C, 'M', 'k'), + (0x1D62D, 'M', 'l'), + (0x1D62E, 'M', 'm'), + (0x1D62F, 'M', 'n'), + (0x1D630, 'M', 'o'), + (0x1D631, 'M', 'p'), + (0x1D632, 'M', 'q'), + (0x1D633, 'M', 'r'), + (0x1D634, 'M', 's'), + (0x1D635, 'M', 't'), + (0x1D636, 'M', 'u'), + (0x1D637, 'M', 'v'), + (0x1D638, 'M', 'w'), + (0x1D639, 'M', 'x'), + (0x1D63A, 'M', 'y'), + (0x1D63B, 'M', 'z'), + (0x1D63C, 'M', 'a'), + (0x1D63D, 'M', 'b'), + (0x1D63E, 'M', 'c'), + (0x1D63F, 'M', 'd'), + (0x1D640, 'M', 'e'), + (0x1D641, 'M', 'f'), + (0x1D642, 'M', 'g'), + (0x1D643, 'M', 'h'), + (0x1D644, 'M', 'i'), + (0x1D645, 'M', 'j'), + (0x1D646, 'M', 'k'), + (0x1D647, 'M', 'l'), + (0x1D648, 'M', 'm'), + (0x1D649, 'M', 'n'), + (0x1D64A, 'M', 'o'), + (0x1D64B, 'M', 'p'), + ] + +def _seg_65(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0x1D64C, 'M', 'q'), + (0x1D64D, 'M', 'r'), + (0x1D64E, 'M', 's'), + (0x1D64F, 'M', 't'), + (0x1D650, 'M', 'u'), + (0x1D651, 'M', 'v'), + (0x1D652, 'M', 'w'), + (0x1D653, 'M', 'x'), + (0x1D654, 'M', 'y'), + (0x1D655, 'M', 'z'), + (0x1D656, 'M', 'a'), + (0x1D657, 'M', 'b'), + (0x1D658, 'M', 'c'), + (0x1D659, 'M', 'd'), + (0x1D65A, 'M', 'e'), + (0x1D65B, 'M', 'f'), + (0x1D65C, 'M', 'g'), + (0x1D65D, 'M', 'h'), + (0x1D65E, 'M', 'i'), + (0x1D65F, 'M', 'j'), + (0x1D660, 'M', 'k'), + (0x1D661, 'M', 'l'), + (0x1D662, 'M', 'm'), + (0x1D663, 'M', 'n'), + (0x1D664, 'M', 'o'), + (0x1D665, 'M', 'p'), + (0x1D666, 'M', 'q'), + (0x1D667, 'M', 'r'), + (0x1D668, 'M', 's'), + (0x1D669, 'M', 't'), + (0x1D66A, 'M', 'u'), + (0x1D66B, 'M', 'v'), + (0x1D66C, 'M', 'w'), + (0x1D66D, 'M', 'x'), + (0x1D66E, 'M', 'y'), + (0x1D66F, 'M', 'z'), + (0x1D670, 'M', 'a'), + (0x1D671, 'M', 'b'), + (0x1D672, 'M', 'c'), + (0x1D673, 'M', 'd'), + (0x1D674, 'M', 'e'), + (0x1D675, 'M', 'f'), + (0x1D676, 'M', 'g'), + (0x1D677, 'M', 'h'), + (0x1D678, 'M', 'i'), + (0x1D679, 'M', 'j'), + (0x1D67A, 'M', 'k'), + (0x1D67B, 'M', 'l'), + (0x1D67C, 'M', 'm'), + (0x1D67D, 'M', 'n'), + (0x1D67E, 'M', 'o'), + (0x1D67F, 'M', 'p'), + (0x1D680, 'M', 'q'), + (0x1D681, 'M', 'r'), + (0x1D682, 'M', 's'), + (0x1D683, 'M', 't'), + (0x1D684, 'M', 'u'), + (0x1D685, 'M', 'v'), + (0x1D686, 'M', 'w'), + (0x1D687, 'M', 'x'), + (0x1D688, 'M', 'y'), + (0x1D689, 'M', 'z'), + (0x1D68A, 'M', 'a'), + (0x1D68B, 'M', 'b'), + (0x1D68C, 'M', 'c'), + (0x1D68D, 'M', 'd'), + (0x1D68E, 'M', 'e'), + (0x1D68F, 'M', 'f'), + (0x1D690, 'M', 'g'), + (0x1D691, 'M', 'h'), + (0x1D692, 'M', 'i'), + (0x1D693, 'M', 'j'), + (0x1D694, 'M', 'k'), + (0x1D695, 'M', 'l'), + (0x1D696, 'M', 'm'), + (0x1D697, 'M', 'n'), + (0x1D698, 'M', 'o'), + (0x1D699, 'M', 'p'), + (0x1D69A, 'M', 'q'), + (0x1D69B, 'M', 'r'), + (0x1D69C, 'M', 's'), + (0x1D69D, 'M', 't'), + (0x1D69E, 'M', 'u'), + (0x1D69F, 'M', 'v'), + (0x1D6A0, 'M', 'w'), + (0x1D6A1, 'M', 'x'), + (0x1D6A2, 'M', 'y'), + (0x1D6A3, 'M', 'z'), + (0x1D6A4, 'M', 'ı'), + (0x1D6A5, 'M', 'ȷ'), + (0x1D6A6, 'X'), + (0x1D6A8, 'M', 'α'), + (0x1D6A9, 'M', 'β'), + (0x1D6AA, 'M', 'γ'), + (0x1D6AB, 'M', 'δ'), + (0x1D6AC, 'M', 'ε'), + (0x1D6AD, 'M', 'ζ'), + (0x1D6AE, 'M', 'η'), + (0x1D6AF, 'M', 'θ'), + (0x1D6B0, 'M', 'ι'), + ] + +def _seg_66(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0x1D6B1, 'M', 'κ'), + (0x1D6B2, 'M', 'λ'), + (0x1D6B3, 'M', 'μ'), + (0x1D6B4, 'M', 'ν'), + (0x1D6B5, 'M', 'ξ'), + (0x1D6B6, 'M', 'ο'), + (0x1D6B7, 'M', 'π'), + (0x1D6B8, 'M', 'ρ'), + (0x1D6B9, 'M', 'θ'), + (0x1D6BA, 'M', 'σ'), + (0x1D6BB, 'M', 'τ'), + (0x1D6BC, 'M', 'υ'), + (0x1D6BD, 'M', 'φ'), + (0x1D6BE, 'M', 'χ'), + (0x1D6BF, 'M', 'ψ'), + (0x1D6C0, 'M', 'ω'), + (0x1D6C1, 'M', '∇'), + (0x1D6C2, 'M', 'α'), + (0x1D6C3, 'M', 'β'), + (0x1D6C4, 'M', 'γ'), + (0x1D6C5, 'M', 'δ'), + (0x1D6C6, 'M', 'ε'), + (0x1D6C7, 'M', 'ζ'), + (0x1D6C8, 'M', 'η'), + (0x1D6C9, 'M', 'θ'), + (0x1D6CA, 'M', 'ι'), + (0x1D6CB, 'M', 'κ'), + (0x1D6CC, 'M', 'λ'), + (0x1D6CD, 'M', 'μ'), + (0x1D6CE, 'M', 'ν'), + (0x1D6CF, 'M', 'ξ'), + (0x1D6D0, 'M', 'ο'), + (0x1D6D1, 'M', 'π'), + (0x1D6D2, 'M', 'ρ'), + (0x1D6D3, 'M', 'σ'), + (0x1D6D5, 'M', 'τ'), + (0x1D6D6, 'M', 'υ'), + (0x1D6D7, 'M', 'φ'), + (0x1D6D8, 'M', 'χ'), + (0x1D6D9, 'M', 'ψ'), + (0x1D6DA, 'M', 'ω'), + (0x1D6DB, 'M', '∂'), + (0x1D6DC, 'M', 'ε'), + (0x1D6DD, 'M', 'θ'), + (0x1D6DE, 'M', 'κ'), + (0x1D6DF, 'M', 'φ'), + (0x1D6E0, 'M', 'ρ'), + (0x1D6E1, 'M', 'π'), + (0x1D6E2, 'M', 'α'), + (0x1D6E3, 'M', 'β'), + (0x1D6E4, 'M', 'γ'), + (0x1D6E5, 'M', 'δ'), + (0x1D6E6, 'M', 'ε'), + (0x1D6E7, 'M', 'ζ'), + (0x1D6E8, 'M', 'η'), + (0x1D6E9, 'M', 'θ'), + (0x1D6EA, 'M', 'ι'), + (0x1D6EB, 'M', 'κ'), + (0x1D6EC, 'M', 'λ'), + (0x1D6ED, 'M', 'μ'), + (0x1D6EE, 'M', 'ν'), + (0x1D6EF, 'M', 'ξ'), + (0x1D6F0, 'M', 'ο'), + (0x1D6F1, 'M', 'π'), + (0x1D6F2, 'M', 'ρ'), + (0x1D6F3, 'M', 'θ'), + (0x1D6F4, 'M', 'σ'), + (0x1D6F5, 'M', 'τ'), + (0x1D6F6, 'M', 'υ'), + (0x1D6F7, 'M', 'φ'), + (0x1D6F8, 'M', 'χ'), + (0x1D6F9, 'M', 'ψ'), + (0x1D6FA, 'M', 'ω'), + (0x1D6FB, 'M', '∇'), + (0x1D6FC, 'M', 'α'), + (0x1D6FD, 'M', 'β'), + (0x1D6FE, 'M', 'γ'), + (0x1D6FF, 'M', 'δ'), + (0x1D700, 'M', 'ε'), + (0x1D701, 'M', 'ζ'), + (0x1D702, 'M', 'η'), + (0x1D703, 'M', 'θ'), + (0x1D704, 'M', 'ι'), + (0x1D705, 'M', 'κ'), + (0x1D706, 'M', 'λ'), + (0x1D707, 'M', 'μ'), + (0x1D708, 'M', 'ν'), + (0x1D709, 'M', 'ξ'), + (0x1D70A, 'M', 'ο'), + (0x1D70B, 'M', 'π'), + (0x1D70C, 'M', 'ρ'), + (0x1D70D, 'M', 'σ'), + (0x1D70F, 'M', 'τ'), + (0x1D710, 'M', 'υ'), + (0x1D711, 'M', 'φ'), + (0x1D712, 'M', 'χ'), + (0x1D713, 'M', 'ψ'), + (0x1D714, 'M', 'ω'), + (0x1D715, 'M', '∂'), + (0x1D716, 'M', 'ε'), + ] + +def _seg_67(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0x1D717, 'M', 'θ'), + (0x1D718, 'M', 'κ'), + (0x1D719, 'M', 'φ'), + (0x1D71A, 'M', 'ρ'), + (0x1D71B, 'M', 'π'), + (0x1D71C, 'M', 'α'), + (0x1D71D, 'M', 'β'), + (0x1D71E, 'M', 'γ'), + (0x1D71F, 'M', 'δ'), + (0x1D720, 'M', 'ε'), + (0x1D721, 'M', 'ζ'), + (0x1D722, 'M', 'η'), + (0x1D723, 'M', 'θ'), + (0x1D724, 'M', 'ι'), + (0x1D725, 'M', 'κ'), + (0x1D726, 'M', 'λ'), + (0x1D727, 'M', 'μ'), + (0x1D728, 'M', 'ν'), + (0x1D729, 'M', 'ξ'), + (0x1D72A, 'M', 'ο'), + (0x1D72B, 'M', 'π'), + (0x1D72C, 'M', 'ρ'), + (0x1D72D, 'M', 'θ'), + (0x1D72E, 'M', 'σ'), + (0x1D72F, 'M', 'τ'), + (0x1D730, 'M', 'υ'), + (0x1D731, 'M', 'φ'), + (0x1D732, 'M', 'χ'), + (0x1D733, 'M', 'ψ'), + (0x1D734, 'M', 'ω'), + (0x1D735, 'M', '∇'), + (0x1D736, 'M', 'α'), + (0x1D737, 'M', 'β'), + (0x1D738, 'M', 'γ'), + (0x1D739, 'M', 'δ'), + (0x1D73A, 'M', 'ε'), + (0x1D73B, 'M', 'ζ'), + (0x1D73C, 'M', 'η'), + (0x1D73D, 'M', 'θ'), + (0x1D73E, 'M', 'ι'), + (0x1D73F, 'M', 'κ'), + (0x1D740, 'M', 'λ'), + (0x1D741, 'M', 'μ'), + (0x1D742, 'M', 'ν'), + (0x1D743, 'M', 'ξ'), + (0x1D744, 'M', 'ο'), + (0x1D745, 'M', 'π'), + (0x1D746, 'M', 'ρ'), + (0x1D747, 'M', 'σ'), + (0x1D749, 'M', 'τ'), + (0x1D74A, 'M', 'υ'), + (0x1D74B, 'M', 'φ'), + (0x1D74C, 'M', 'χ'), + (0x1D74D, 'M', 'ψ'), + (0x1D74E, 'M', 'ω'), + (0x1D74F, 'M', '∂'), + (0x1D750, 'M', 'ε'), + (0x1D751, 'M', 'θ'), + (0x1D752, 'M', 'κ'), + (0x1D753, 'M', 'φ'), + (0x1D754, 'M', 'ρ'), + (0x1D755, 'M', 'π'), + (0x1D756, 'M', 'α'), + (0x1D757, 'M', 'β'), + (0x1D758, 'M', 'γ'), + (0x1D759, 'M', 'δ'), + (0x1D75A, 'M', 'ε'), + (0x1D75B, 'M', 'ζ'), + (0x1D75C, 'M', 'η'), + (0x1D75D, 'M', 'θ'), + (0x1D75E, 'M', 'ι'), + (0x1D75F, 'M', 'κ'), + (0x1D760, 'M', 'λ'), + (0x1D761, 'M', 'μ'), + (0x1D762, 'M', 'ν'), + (0x1D763, 'M', 'ξ'), + (0x1D764, 'M', 'ο'), + (0x1D765, 'M', 'π'), + (0x1D766, 'M', 'ρ'), + (0x1D767, 'M', 'θ'), + (0x1D768, 'M', 'σ'), + (0x1D769, 'M', 'τ'), + (0x1D76A, 'M', 'υ'), + (0x1D76B, 'M', 'φ'), + (0x1D76C, 'M', 'χ'), + (0x1D76D, 'M', 'ψ'), + (0x1D76E, 'M', 'ω'), + (0x1D76F, 'M', '∇'), + (0x1D770, 'M', 'α'), + (0x1D771, 'M', 'β'), + (0x1D772, 'M', 'γ'), + (0x1D773, 'M', 'δ'), + (0x1D774, 'M', 'ε'), + (0x1D775, 'M', 'ζ'), + (0x1D776, 'M', 'η'), + (0x1D777, 'M', 'θ'), + (0x1D778, 'M', 'ι'), + (0x1D779, 'M', 'κ'), + (0x1D77A, 'M', 'λ'), + (0x1D77B, 'M', 'μ'), + ] + +def _seg_68(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0x1D77C, 'M', 'ν'), + (0x1D77D, 'M', 'ξ'), + (0x1D77E, 'M', 'ο'), + (0x1D77F, 'M', 'π'), + (0x1D780, 'M', 'ρ'), + (0x1D781, 'M', 'σ'), + (0x1D783, 'M', 'τ'), + (0x1D784, 'M', 'υ'), + (0x1D785, 'M', 'φ'), + (0x1D786, 'M', 'χ'), + (0x1D787, 'M', 'ψ'), + (0x1D788, 'M', 'ω'), + (0x1D789, 'M', '∂'), + (0x1D78A, 'M', 'ε'), + (0x1D78B, 'M', 'θ'), + (0x1D78C, 'M', 'κ'), + (0x1D78D, 'M', 'φ'), + (0x1D78E, 'M', 'ρ'), + (0x1D78F, 'M', 'π'), + (0x1D790, 'M', 'α'), + (0x1D791, 'M', 'β'), + (0x1D792, 'M', 'γ'), + (0x1D793, 'M', 'δ'), + (0x1D794, 'M', 'ε'), + (0x1D795, 'M', 'ζ'), + (0x1D796, 'M', 'η'), + (0x1D797, 'M', 'θ'), + (0x1D798, 'M', 'ι'), + (0x1D799, 'M', 'κ'), + (0x1D79A, 'M', 'λ'), + (0x1D79B, 'M', 'μ'), + (0x1D79C, 'M', 'ν'), + (0x1D79D, 'M', 'ξ'), + (0x1D79E, 'M', 'ο'), + (0x1D79F, 'M', 'π'), + (0x1D7A0, 'M', 'ρ'), + (0x1D7A1, 'M', 'θ'), + (0x1D7A2, 'M', 'σ'), + (0x1D7A3, 'M', 'τ'), + (0x1D7A4, 'M', 'υ'), + (0x1D7A5, 'M', 'φ'), + (0x1D7A6, 'M', 'χ'), + (0x1D7A7, 'M', 'ψ'), + (0x1D7A8, 'M', 'ω'), + (0x1D7A9, 'M', '∇'), + (0x1D7AA, 'M', 'α'), + (0x1D7AB, 'M', 'β'), + (0x1D7AC, 'M', 'γ'), + (0x1D7AD, 'M', 'δ'), + (0x1D7AE, 'M', 'ε'), + (0x1D7AF, 'M', 'ζ'), + (0x1D7B0, 'M', 'η'), + (0x1D7B1, 'M', 'θ'), + (0x1D7B2, 'M', 'ι'), + (0x1D7B3, 'M', 'κ'), + (0x1D7B4, 'M', 'λ'), + (0x1D7B5, 'M', 'μ'), + (0x1D7B6, 'M', 'ν'), + (0x1D7B7, 'M', 'ξ'), + (0x1D7B8, 'M', 'ο'), + (0x1D7B9, 'M', 'π'), + (0x1D7BA, 'M', 'ρ'), + (0x1D7BB, 'M', 'σ'), + (0x1D7BD, 'M', 'τ'), + (0x1D7BE, 'M', 'υ'), + (0x1D7BF, 'M', 'φ'), + (0x1D7C0, 'M', 'χ'), + (0x1D7C1, 'M', 'ψ'), + (0x1D7C2, 'M', 'ω'), + (0x1D7C3, 'M', '∂'), + (0x1D7C4, 'M', 'ε'), + (0x1D7C5, 'M', 'θ'), + (0x1D7C6, 'M', 'κ'), + (0x1D7C7, 'M', 'φ'), + (0x1D7C8, 'M', 'ρ'), + (0x1D7C9, 'M', 'π'), + (0x1D7CA, 'M', 'ϝ'), + (0x1D7CC, 'X'), + (0x1D7CE, 'M', '0'), + (0x1D7CF, 'M', '1'), + (0x1D7D0, 'M', '2'), + (0x1D7D1, 'M', '3'), + (0x1D7D2, 'M', '4'), + (0x1D7D3, 'M', '5'), + (0x1D7D4, 'M', '6'), + (0x1D7D5, 'M', '7'), + (0x1D7D6, 'M', '8'), + (0x1D7D7, 'M', '9'), + (0x1D7D8, 'M', '0'), + (0x1D7D9, 'M', '1'), + (0x1D7DA, 'M', '2'), + (0x1D7DB, 'M', '3'), + (0x1D7DC, 'M', '4'), + (0x1D7DD, 'M', '5'), + (0x1D7DE, 'M', '6'), + (0x1D7DF, 'M', '7'), + (0x1D7E0, 'M', '8'), + (0x1D7E1, 'M', '9'), + (0x1D7E2, 'M', '0'), + (0x1D7E3, 'M', '1'), + ] + +def _seg_69(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0x1D7E4, 'M', '2'), + (0x1D7E5, 'M', '3'), + (0x1D7E6, 'M', '4'), + (0x1D7E7, 'M', '5'), + (0x1D7E8, 'M', '6'), + (0x1D7E9, 'M', '7'), + (0x1D7EA, 'M', '8'), + (0x1D7EB, 'M', '9'), + (0x1D7EC, 'M', '0'), + (0x1D7ED, 'M', '1'), + (0x1D7EE, 'M', '2'), + (0x1D7EF, 'M', '3'), + (0x1D7F0, 'M', '4'), + (0x1D7F1, 'M', '5'), + (0x1D7F2, 'M', '6'), + (0x1D7F3, 'M', '7'), + (0x1D7F4, 'M', '8'), + (0x1D7F5, 'M', '9'), + (0x1D7F6, 'M', '0'), + (0x1D7F7, 'M', '1'), + (0x1D7F8, 'M', '2'), + (0x1D7F9, 'M', '3'), + (0x1D7FA, 'M', '4'), + (0x1D7FB, 'M', '5'), + (0x1D7FC, 'M', '6'), + (0x1D7FD, 'M', '7'), + (0x1D7FE, 'M', '8'), + (0x1D7FF, 'M', '9'), + (0x1D800, 'V'), + (0x1DA8C, 'X'), + (0x1DA9B, 'V'), + (0x1DAA0, 'X'), + (0x1DAA1, 'V'), + (0x1DAB0, 'X'), + (0x1E000, 'V'), + (0x1E007, 'X'), + (0x1E008, 'V'), + (0x1E019, 'X'), + (0x1E01B, 'V'), + (0x1E022, 'X'), + (0x1E023, 'V'), + (0x1E025, 'X'), + (0x1E026, 'V'), + (0x1E02B, 'X'), + (0x1E100, 'V'), + (0x1E12D, 'X'), + (0x1E130, 'V'), + (0x1E13E, 'X'), + (0x1E140, 'V'), + (0x1E14A, 'X'), + (0x1E14E, 'V'), + (0x1E150, 'X'), + (0x1E2C0, 'V'), + (0x1E2FA, 'X'), + (0x1E2FF, 'V'), + (0x1E300, 'X'), + (0x1E800, 'V'), + (0x1E8C5, 'X'), + (0x1E8C7, 'V'), + (0x1E8D7, 'X'), + (0x1E900, 'M', '𞤢'), + (0x1E901, 'M', '𞤣'), + (0x1E902, 'M', '𞤤'), + (0x1E903, 'M', '𞤥'), + (0x1E904, 'M', '𞤦'), + (0x1E905, 'M', '𞤧'), + (0x1E906, 'M', '𞤨'), + (0x1E907, 'M', '𞤩'), + (0x1E908, 'M', '𞤪'), + (0x1E909, 'M', '𞤫'), + (0x1E90A, 'M', '𞤬'), + (0x1E90B, 'M', '𞤭'), + (0x1E90C, 'M', '𞤮'), + (0x1E90D, 'M', '𞤯'), + (0x1E90E, 'M', '𞤰'), + (0x1E90F, 'M', '𞤱'), + (0x1E910, 'M', '𞤲'), + (0x1E911, 'M', '𞤳'), + (0x1E912, 'M', '𞤴'), + (0x1E913, 'M', '𞤵'), + (0x1E914, 'M', '𞤶'), + (0x1E915, 'M', '𞤷'), + (0x1E916, 'M', '𞤸'), + (0x1E917, 'M', '𞤹'), + (0x1E918, 'M', '𞤺'), + (0x1E919, 'M', '𞤻'), + (0x1E91A, 'M', '𞤼'), + (0x1E91B, 'M', '𞤽'), + (0x1E91C, 'M', '𞤾'), + (0x1E91D, 'M', '𞤿'), + (0x1E91E, 'M', '𞥀'), + (0x1E91F, 'M', '𞥁'), + (0x1E920, 'M', '𞥂'), + (0x1E921, 'M', '𞥃'), + (0x1E922, 'V'), + (0x1E94C, 'X'), + (0x1E950, 'V'), + (0x1E95A, 'X'), + (0x1E95E, 'V'), + (0x1E960, 'X'), + ] + +def _seg_70(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0x1EC71, 'V'), + (0x1ECB5, 'X'), + (0x1ED01, 'V'), + (0x1ED3E, 'X'), + (0x1EE00, 'M', 'ا'), + (0x1EE01, 'M', 'ب'), + (0x1EE02, 'M', 'ج'), + (0x1EE03, 'M', 'د'), + (0x1EE04, 'X'), + (0x1EE05, 'M', 'و'), + (0x1EE06, 'M', 'ز'), + (0x1EE07, 'M', 'ح'), + (0x1EE08, 'M', 'ط'), + (0x1EE09, 'M', 'ي'), + (0x1EE0A, 'M', 'ك'), + (0x1EE0B, 'M', 'ل'), + (0x1EE0C, 'M', 'م'), + (0x1EE0D, 'M', 'ن'), + (0x1EE0E, 'M', 'س'), + (0x1EE0F, 'M', 'ع'), + (0x1EE10, 'M', 'ف'), + (0x1EE11, 'M', 'ص'), + (0x1EE12, 'M', 'ق'), + (0x1EE13, 'M', 'ر'), + (0x1EE14, 'M', 'ش'), + (0x1EE15, 'M', 'ت'), + (0x1EE16, 'M', 'ث'), + (0x1EE17, 'M', 'خ'), + (0x1EE18, 'M', 'ذ'), + (0x1EE19, 'M', 'ض'), + (0x1EE1A, 'M', 'ظ'), + (0x1EE1B, 'M', 'غ'), + (0x1EE1C, 'M', 'ٮ'), + (0x1EE1D, 'M', 'ں'), + (0x1EE1E, 'M', 'ڡ'), + (0x1EE1F, 'M', 'ٯ'), + (0x1EE20, 'X'), + (0x1EE21, 'M', 'ب'), + (0x1EE22, 'M', 'ج'), + (0x1EE23, 'X'), + (0x1EE24, 'M', 'ه'), + (0x1EE25, 'X'), + (0x1EE27, 'M', 'ح'), + (0x1EE28, 'X'), + (0x1EE29, 'M', 'ي'), + (0x1EE2A, 'M', 'ك'), + (0x1EE2B, 'M', 'ل'), + (0x1EE2C, 'M', 'م'), + (0x1EE2D, 'M', 'ن'), + (0x1EE2E, 'M', 'س'), + (0x1EE2F, 'M', 'ع'), + (0x1EE30, 'M', 'ف'), + (0x1EE31, 'M', 'ص'), + (0x1EE32, 'M', 'ق'), + (0x1EE33, 'X'), + (0x1EE34, 'M', 'ش'), + (0x1EE35, 'M', 'ت'), + (0x1EE36, 'M', 'ث'), + (0x1EE37, 'M', 'خ'), + (0x1EE38, 'X'), + (0x1EE39, 'M', 'ض'), + (0x1EE3A, 'X'), + (0x1EE3B, 'M', 'غ'), + (0x1EE3C, 'X'), + (0x1EE42, 'M', 'ج'), + (0x1EE43, 'X'), + (0x1EE47, 'M', 'ح'), + (0x1EE48, 'X'), + (0x1EE49, 'M', 'ي'), + (0x1EE4A, 'X'), + (0x1EE4B, 'M', 'ل'), + (0x1EE4C, 'X'), + (0x1EE4D, 'M', 'ن'), + (0x1EE4E, 'M', 'س'), + (0x1EE4F, 'M', 'ع'), + (0x1EE50, 'X'), + (0x1EE51, 'M', 'ص'), + (0x1EE52, 'M', 'ق'), + (0x1EE53, 'X'), + (0x1EE54, 'M', 'ش'), + (0x1EE55, 'X'), + (0x1EE57, 'M', 'خ'), + (0x1EE58, 'X'), + (0x1EE59, 'M', 'ض'), + (0x1EE5A, 'X'), + (0x1EE5B, 'M', 'غ'), + (0x1EE5C, 'X'), + (0x1EE5D, 'M', 'ں'), + (0x1EE5E, 'X'), + (0x1EE5F, 'M', 'ٯ'), + (0x1EE60, 'X'), + (0x1EE61, 'M', 'ب'), + (0x1EE62, 'M', 'ج'), + (0x1EE63, 'X'), + (0x1EE64, 'M', 'ه'), + (0x1EE65, 'X'), + (0x1EE67, 'M', 'ح'), + (0x1EE68, 'M', 'ط'), + (0x1EE69, 'M', 'ي'), + (0x1EE6A, 'M', 'ك'), + ] + +def _seg_71(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0x1EE6B, 'X'), + (0x1EE6C, 'M', 'م'), + (0x1EE6D, 'M', 'ن'), + (0x1EE6E, 'M', 'س'), + (0x1EE6F, 'M', 'ع'), + (0x1EE70, 'M', 'ف'), + (0x1EE71, 'M', 'ص'), + (0x1EE72, 'M', 'ق'), + (0x1EE73, 'X'), + (0x1EE74, 'M', 'ش'), + (0x1EE75, 'M', 'ت'), + (0x1EE76, 'M', 'ث'), + (0x1EE77, 'M', 'خ'), + (0x1EE78, 'X'), + (0x1EE79, 'M', 'ض'), + (0x1EE7A, 'M', 'ظ'), + (0x1EE7B, 'M', 'غ'), + (0x1EE7C, 'M', 'ٮ'), + (0x1EE7D, 'X'), + (0x1EE7E, 'M', 'ڡ'), + (0x1EE7F, 'X'), + (0x1EE80, 'M', 'ا'), + (0x1EE81, 'M', 'ب'), + (0x1EE82, 'M', 'ج'), + (0x1EE83, 'M', 'د'), + (0x1EE84, 'M', 'ه'), + (0x1EE85, 'M', 'و'), + (0x1EE86, 'M', 'ز'), + (0x1EE87, 'M', 'ح'), + (0x1EE88, 'M', 'ط'), + (0x1EE89, 'M', 'ي'), + (0x1EE8A, 'X'), + (0x1EE8B, 'M', 'ل'), + (0x1EE8C, 'M', 'م'), + (0x1EE8D, 'M', 'ن'), + (0x1EE8E, 'M', 'س'), + (0x1EE8F, 'M', 'ع'), + (0x1EE90, 'M', 'ف'), + (0x1EE91, 'M', 'ص'), + (0x1EE92, 'M', 'ق'), + (0x1EE93, 'M', 'ر'), + (0x1EE94, 'M', 'ش'), + (0x1EE95, 'M', 'ت'), + (0x1EE96, 'M', 'ث'), + (0x1EE97, 'M', 'خ'), + (0x1EE98, 'M', 'ذ'), + (0x1EE99, 'M', 'ض'), + (0x1EE9A, 'M', 'ظ'), + (0x1EE9B, 'M', 'غ'), + (0x1EE9C, 'X'), + (0x1EEA1, 'M', 'ب'), + (0x1EEA2, 'M', 'ج'), + (0x1EEA3, 'M', 'د'), + (0x1EEA4, 'X'), + (0x1EEA5, 'M', 'و'), + (0x1EEA6, 'M', 'ز'), + (0x1EEA7, 'M', 'ح'), + (0x1EEA8, 'M', 'ط'), + (0x1EEA9, 'M', 'ي'), + (0x1EEAA, 'X'), + (0x1EEAB, 'M', 'ل'), + (0x1EEAC, 'M', 'م'), + (0x1EEAD, 'M', 'ن'), + (0x1EEAE, 'M', 'س'), + (0x1EEAF, 'M', 'ع'), + (0x1EEB0, 'M', 'ف'), + (0x1EEB1, 'M', 'ص'), + (0x1EEB2, 'M', 'ق'), + (0x1EEB3, 'M', 'ر'), + (0x1EEB4, 'M', 'ش'), + (0x1EEB5, 'M', 'ت'), + (0x1EEB6, 'M', 'ث'), + (0x1EEB7, 'M', 'خ'), + (0x1EEB8, 'M', 'ذ'), + (0x1EEB9, 'M', 'ض'), + (0x1EEBA, 'M', 'ظ'), + (0x1EEBB, 'M', 'غ'), + (0x1EEBC, 'X'), + (0x1EEF0, 'V'), + (0x1EEF2, 'X'), + (0x1F000, 'V'), + (0x1F02C, 'X'), + (0x1F030, 'V'), + (0x1F094, 'X'), + (0x1F0A0, 'V'), + (0x1F0AF, 'X'), + (0x1F0B1, 'V'), + (0x1F0C0, 'X'), + (0x1F0C1, 'V'), + (0x1F0D0, 'X'), + (0x1F0D1, 'V'), + (0x1F0F6, 'X'), + (0x1F101, '3', '0,'), + (0x1F102, '3', '1,'), + (0x1F103, '3', '2,'), + (0x1F104, '3', '3,'), + (0x1F105, '3', '4,'), + (0x1F106, '3', '5,'), + (0x1F107, '3', '6,'), + (0x1F108, '3', '7,'), + ] + +def _seg_72(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0x1F109, '3', '8,'), + (0x1F10A, '3', '9,'), + (0x1F10B, 'V'), + (0x1F110, '3', '(a)'), + (0x1F111, '3', '(b)'), + (0x1F112, '3', '(c)'), + (0x1F113, '3', '(d)'), + (0x1F114, '3', '(e)'), + (0x1F115, '3', '(f)'), + (0x1F116, '3', '(g)'), + (0x1F117, '3', '(h)'), + (0x1F118, '3', '(i)'), + (0x1F119, '3', '(j)'), + (0x1F11A, '3', '(k)'), + (0x1F11B, '3', '(l)'), + (0x1F11C, '3', '(m)'), + (0x1F11D, '3', '(n)'), + (0x1F11E, '3', '(o)'), + (0x1F11F, '3', '(p)'), + (0x1F120, '3', '(q)'), + (0x1F121, '3', '(r)'), + (0x1F122, '3', '(s)'), + (0x1F123, '3', '(t)'), + (0x1F124, '3', '(u)'), + (0x1F125, '3', '(v)'), + (0x1F126, '3', '(w)'), + (0x1F127, '3', '(x)'), + (0x1F128, '3', '(y)'), + (0x1F129, '3', '(z)'), + (0x1F12A, 'M', '〔s〕'), + (0x1F12B, 'M', 'c'), + (0x1F12C, 'M', 'r'), + (0x1F12D, 'M', 'cd'), + (0x1F12E, 'M', 'wz'), + (0x1F12F, 'V'), + (0x1F130, 'M', 'a'), + (0x1F131, 'M', 'b'), + (0x1F132, 'M', 'c'), + (0x1F133, 'M', 'd'), + (0x1F134, 'M', 'e'), + (0x1F135, 'M', 'f'), + (0x1F136, 'M', 'g'), + (0x1F137, 'M', 'h'), + (0x1F138, 'M', 'i'), + (0x1F139, 'M', 'j'), + (0x1F13A, 'M', 'k'), + (0x1F13B, 'M', 'l'), + (0x1F13C, 'M', 'm'), + (0x1F13D, 'M', 'n'), + (0x1F13E, 'M', 'o'), + (0x1F13F, 'M', 'p'), + (0x1F140, 'M', 'q'), + (0x1F141, 'M', 'r'), + (0x1F142, 'M', 's'), + (0x1F143, 'M', 't'), + (0x1F144, 'M', 'u'), + (0x1F145, 'M', 'v'), + (0x1F146, 'M', 'w'), + (0x1F147, 'M', 'x'), + (0x1F148, 'M', 'y'), + (0x1F149, 'M', 'z'), + (0x1F14A, 'M', 'hv'), + (0x1F14B, 'M', 'mv'), + (0x1F14C, 'M', 'sd'), + (0x1F14D, 'M', 'ss'), + (0x1F14E, 'M', 'ppv'), + (0x1F14F, 'M', 'wc'), + (0x1F150, 'V'), + (0x1F16A, 'M', 'mc'), + (0x1F16B, 'M', 'md'), + (0x1F16C, 'M', 'mr'), + (0x1F16D, 'V'), + (0x1F190, 'M', 'dj'), + (0x1F191, 'V'), + (0x1F1AE, 'X'), + (0x1F1E6, 'V'), + (0x1F200, 'M', 'ほか'), + (0x1F201, 'M', 'ココ'), + (0x1F202, 'M', 'サ'), + (0x1F203, 'X'), + (0x1F210, 'M', '手'), + (0x1F211, 'M', '字'), + (0x1F212, 'M', '双'), + (0x1F213, 'M', 'デ'), + (0x1F214, 'M', '二'), + (0x1F215, 'M', '多'), + (0x1F216, 'M', '解'), + (0x1F217, 'M', '天'), + (0x1F218, 'M', '交'), + (0x1F219, 'M', '映'), + (0x1F21A, 'M', '無'), + (0x1F21B, 'M', '料'), + (0x1F21C, 'M', '前'), + (0x1F21D, 'M', '後'), + (0x1F21E, 'M', '再'), + (0x1F21F, 'M', '新'), + (0x1F220, 'M', '初'), + (0x1F221, 'M', '終'), + (0x1F222, 'M', '生'), + (0x1F223, 'M', '販'), + ] + +def _seg_73(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0x1F224, 'M', '声'), + (0x1F225, 'M', '吹'), + (0x1F226, 'M', '演'), + (0x1F227, 'M', '投'), + (0x1F228, 'M', '捕'), + (0x1F229, 'M', '一'), + (0x1F22A, 'M', '三'), + (0x1F22B, 'M', '遊'), + (0x1F22C, 'M', '左'), + (0x1F22D, 'M', '中'), + (0x1F22E, 'M', '右'), + (0x1F22F, 'M', '指'), + (0x1F230, 'M', '走'), + (0x1F231, 'M', '打'), + (0x1F232, 'M', '禁'), + (0x1F233, 'M', '空'), + (0x1F234, 'M', '合'), + (0x1F235, 'M', '満'), + (0x1F236, 'M', '有'), + (0x1F237, 'M', '月'), + (0x1F238, 'M', '申'), + (0x1F239, 'M', '割'), + (0x1F23A, 'M', '営'), + (0x1F23B, 'M', '配'), + (0x1F23C, 'X'), + (0x1F240, 'M', '〔本〕'), + (0x1F241, 'M', '〔三〕'), + (0x1F242, 'M', '〔二〕'), + (0x1F243, 'M', '〔安〕'), + (0x1F244, 'M', '〔点〕'), + (0x1F245, 'M', '〔打〕'), + (0x1F246, 'M', '〔盗〕'), + (0x1F247, 'M', '〔勝〕'), + (0x1F248, 'M', '〔敗〕'), + (0x1F249, 'X'), + (0x1F250, 'M', '得'), + (0x1F251, 'M', '可'), + (0x1F252, 'X'), + (0x1F260, 'V'), + (0x1F266, 'X'), + (0x1F300, 'V'), + (0x1F6D8, 'X'), + (0x1F6E0, 'V'), + (0x1F6ED, 'X'), + (0x1F6F0, 'V'), + (0x1F6FD, 'X'), + (0x1F700, 'V'), + (0x1F774, 'X'), + (0x1F780, 'V'), + (0x1F7D9, 'X'), + (0x1F7E0, 'V'), + (0x1F7EC, 'X'), + (0x1F800, 'V'), + (0x1F80C, 'X'), + (0x1F810, 'V'), + (0x1F848, 'X'), + (0x1F850, 'V'), + (0x1F85A, 'X'), + (0x1F860, 'V'), + (0x1F888, 'X'), + (0x1F890, 'V'), + (0x1F8AE, 'X'), + (0x1F8B0, 'V'), + (0x1F8B2, 'X'), + (0x1F900, 'V'), + (0x1F979, 'X'), + (0x1F97A, 'V'), + (0x1F9CC, 'X'), + (0x1F9CD, 'V'), + (0x1FA54, 'X'), + (0x1FA60, 'V'), + (0x1FA6E, 'X'), + (0x1FA70, 'V'), + (0x1FA75, 'X'), + (0x1FA78, 'V'), + (0x1FA7B, 'X'), + (0x1FA80, 'V'), + (0x1FA87, 'X'), + (0x1FA90, 'V'), + (0x1FAA9, 'X'), + (0x1FAB0, 'V'), + (0x1FAB7, 'X'), + (0x1FAC0, 'V'), + (0x1FAC3, 'X'), + (0x1FAD0, 'V'), + (0x1FAD7, 'X'), + (0x1FB00, 'V'), + (0x1FB93, 'X'), + (0x1FB94, 'V'), + (0x1FBCB, 'X'), + (0x1FBF0, 'M', '0'), + (0x1FBF1, 'M', '1'), + (0x1FBF2, 'M', '2'), + (0x1FBF3, 'M', '3'), + (0x1FBF4, 'M', '4'), + (0x1FBF5, 'M', '5'), + (0x1FBF6, 'M', '6'), + (0x1FBF7, 'M', '7'), + (0x1FBF8, 'M', '8'), + (0x1FBF9, 'M', '9'), + ] + +def _seg_74(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0x1FBFA, 'X'), + (0x20000, 'V'), + (0x2A6DE, 'X'), + (0x2A700, 'V'), + (0x2B735, 'X'), + (0x2B740, 'V'), + (0x2B81E, 'X'), + (0x2B820, 'V'), + (0x2CEA2, 'X'), + (0x2CEB0, 'V'), + (0x2EBE1, 'X'), + (0x2F800, 'M', '丽'), + (0x2F801, 'M', '丸'), + (0x2F802, 'M', '乁'), + (0x2F803, 'M', '𠄢'), + (0x2F804, 'M', '你'), + (0x2F805, 'M', '侮'), + (0x2F806, 'M', '侻'), + (0x2F807, 'M', '倂'), + (0x2F808, 'M', '偺'), + (0x2F809, 'M', '備'), + (0x2F80A, 'M', '僧'), + (0x2F80B, 'M', '像'), + (0x2F80C, 'M', '㒞'), + (0x2F80D, 'M', '𠘺'), + (0x2F80E, 'M', '免'), + (0x2F80F, 'M', '兔'), + (0x2F810, 'M', '兤'), + (0x2F811, 'M', '具'), + (0x2F812, 'M', '𠔜'), + (0x2F813, 'M', '㒹'), + (0x2F814, 'M', '內'), + (0x2F815, 'M', '再'), + (0x2F816, 'M', '𠕋'), + (0x2F817, 'M', '冗'), + (0x2F818, 'M', '冤'), + (0x2F819, 'M', '仌'), + (0x2F81A, 'M', '冬'), + (0x2F81B, 'M', '况'), + (0x2F81C, 'M', '𩇟'), + (0x2F81D, 'M', '凵'), + (0x2F81E, 'M', '刃'), + (0x2F81F, 'M', '㓟'), + (0x2F820, 'M', '刻'), + (0x2F821, 'M', '剆'), + (0x2F822, 'M', '割'), + (0x2F823, 'M', '剷'), + (0x2F824, 'M', '㔕'), + (0x2F825, 'M', '勇'), + (0x2F826, 'M', '勉'), + (0x2F827, 'M', '勤'), + (0x2F828, 'M', '勺'), + (0x2F829, 'M', '包'), + (0x2F82A, 'M', '匆'), + (0x2F82B, 'M', '北'), + (0x2F82C, 'M', '卉'), + (0x2F82D, 'M', '卑'), + (0x2F82E, 'M', '博'), + (0x2F82F, 'M', '即'), + (0x2F830, 'M', '卽'), + (0x2F831, 'M', '卿'), + (0x2F834, 'M', '𠨬'), + (0x2F835, 'M', '灰'), + (0x2F836, 'M', '及'), + (0x2F837, 'M', '叟'), + (0x2F838, 'M', '𠭣'), + (0x2F839, 'M', '叫'), + (0x2F83A, 'M', '叱'), + (0x2F83B, 'M', '吆'), + (0x2F83C, 'M', '咞'), + (0x2F83D, 'M', '吸'), + (0x2F83E, 'M', '呈'), + (0x2F83F, 'M', '周'), + (0x2F840, 'M', '咢'), + (0x2F841, 'M', '哶'), + (0x2F842, 'M', '唐'), + (0x2F843, 'M', '啓'), + (0x2F844, 'M', '啣'), + (0x2F845, 'M', '善'), + (0x2F847, 'M', '喙'), + (0x2F848, 'M', '喫'), + (0x2F849, 'M', '喳'), + (0x2F84A, 'M', '嗂'), + (0x2F84B, 'M', '圖'), + (0x2F84C, 'M', '嘆'), + (0x2F84D, 'M', '圗'), + (0x2F84E, 'M', '噑'), + (0x2F84F, 'M', '噴'), + (0x2F850, 'M', '切'), + (0x2F851, 'M', '壮'), + (0x2F852, 'M', '城'), + (0x2F853, 'M', '埴'), + (0x2F854, 'M', '堍'), + (0x2F855, 'M', '型'), + (0x2F856, 'M', '堲'), + (0x2F857, 'M', '報'), + (0x2F858, 'M', '墬'), + (0x2F859, 'M', '𡓤'), + (0x2F85A, 'M', '売'), + (0x2F85B, 'M', '壷'), + ] + +def _seg_75(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0x2F85C, 'M', '夆'), + (0x2F85D, 'M', '多'), + (0x2F85E, 'M', '夢'), + (0x2F85F, 'M', '奢'), + (0x2F860, 'M', '𡚨'), + (0x2F861, 'M', '𡛪'), + (0x2F862, 'M', '姬'), + (0x2F863, 'M', '娛'), + (0x2F864, 'M', '娧'), + (0x2F865, 'M', '姘'), + (0x2F866, 'M', '婦'), + (0x2F867, 'M', '㛮'), + (0x2F868, 'X'), + (0x2F869, 'M', '嬈'), + (0x2F86A, 'M', '嬾'), + (0x2F86C, 'M', '𡧈'), + (0x2F86D, 'M', '寃'), + (0x2F86E, 'M', '寘'), + (0x2F86F, 'M', '寧'), + (0x2F870, 'M', '寳'), + (0x2F871, 'M', '𡬘'), + (0x2F872, 'M', '寿'), + (0x2F873, 'M', '将'), + (0x2F874, 'X'), + (0x2F875, 'M', '尢'), + (0x2F876, 'M', '㞁'), + (0x2F877, 'M', '屠'), + (0x2F878, 'M', '屮'), + (0x2F879, 'M', '峀'), + (0x2F87A, 'M', '岍'), + (0x2F87B, 'M', '𡷤'), + (0x2F87C, 'M', '嵃'), + (0x2F87D, 'M', '𡷦'), + (0x2F87E, 'M', '嵮'), + (0x2F87F, 'M', '嵫'), + (0x2F880, 'M', '嵼'), + (0x2F881, 'M', '巡'), + (0x2F882, 'M', '巢'), + (0x2F883, 'M', '㠯'), + (0x2F884, 'M', '巽'), + (0x2F885, 'M', '帨'), + (0x2F886, 'M', '帽'), + (0x2F887, 'M', '幩'), + (0x2F888, 'M', '㡢'), + (0x2F889, 'M', '𢆃'), + (0x2F88A, 'M', '㡼'), + (0x2F88B, 'M', '庰'), + (0x2F88C, 'M', '庳'), + (0x2F88D, 'M', '庶'), + (0x2F88E, 'M', '廊'), + (0x2F88F, 'M', '𪎒'), + (0x2F890, 'M', '廾'), + (0x2F891, 'M', '𢌱'), + (0x2F893, 'M', '舁'), + (0x2F894, 'M', '弢'), + (0x2F896, 'M', '㣇'), + (0x2F897, 'M', '𣊸'), + (0x2F898, 'M', '𦇚'), + (0x2F899, 'M', '形'), + (0x2F89A, 'M', '彫'), + (0x2F89B, 'M', '㣣'), + (0x2F89C, 'M', '徚'), + (0x2F89D, 'M', '忍'), + (0x2F89E, 'M', '志'), + (0x2F89F, 'M', '忹'), + (0x2F8A0, 'M', '悁'), + (0x2F8A1, 'M', '㤺'), + (0x2F8A2, 'M', '㤜'), + (0x2F8A3, 'M', '悔'), + (0x2F8A4, 'M', '𢛔'), + (0x2F8A5, 'M', '惇'), + (0x2F8A6, 'M', '慈'), + (0x2F8A7, 'M', '慌'), + (0x2F8A8, 'M', '慎'), + (0x2F8A9, 'M', '慌'), + (0x2F8AA, 'M', '慺'), + (0x2F8AB, 'M', '憎'), + (0x2F8AC, 'M', '憲'), + (0x2F8AD, 'M', '憤'), + (0x2F8AE, 'M', '憯'), + (0x2F8AF, 'M', '懞'), + (0x2F8B0, 'M', '懲'), + (0x2F8B1, 'M', '懶'), + (0x2F8B2, 'M', '成'), + (0x2F8B3, 'M', '戛'), + (0x2F8B4, 'M', '扝'), + (0x2F8B5, 'M', '抱'), + (0x2F8B6, 'M', '拔'), + (0x2F8B7, 'M', '捐'), + (0x2F8B8, 'M', '𢬌'), + (0x2F8B9, 'M', '挽'), + (0x2F8BA, 'M', '拼'), + (0x2F8BB, 'M', '捨'), + (0x2F8BC, 'M', '掃'), + (0x2F8BD, 'M', '揤'), + (0x2F8BE, 'M', '𢯱'), + (0x2F8BF, 'M', '搢'), + (0x2F8C0, 'M', '揅'), + (0x2F8C1, 'M', '掩'), + (0x2F8C2, 'M', '㨮'), + ] + +def _seg_76(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0x2F8C3, 'M', '摩'), + (0x2F8C4, 'M', '摾'), + (0x2F8C5, 'M', '撝'), + (0x2F8C6, 'M', '摷'), + (0x2F8C7, 'M', '㩬'), + (0x2F8C8, 'M', '敏'), + (0x2F8C9, 'M', '敬'), + (0x2F8CA, 'M', '𣀊'), + (0x2F8CB, 'M', '旣'), + (0x2F8CC, 'M', '書'), + (0x2F8CD, 'M', '晉'), + (0x2F8CE, 'M', '㬙'), + (0x2F8CF, 'M', '暑'), + (0x2F8D0, 'M', '㬈'), + (0x2F8D1, 'M', '㫤'), + (0x2F8D2, 'M', '冒'), + (0x2F8D3, 'M', '冕'), + (0x2F8D4, 'M', '最'), + (0x2F8D5, 'M', '暜'), + (0x2F8D6, 'M', '肭'), + (0x2F8D7, 'M', '䏙'), + (0x2F8D8, 'M', '朗'), + (0x2F8D9, 'M', '望'), + (0x2F8DA, 'M', '朡'), + (0x2F8DB, 'M', '杞'), + (0x2F8DC, 'M', '杓'), + (0x2F8DD, 'M', '𣏃'), + (0x2F8DE, 'M', '㭉'), + (0x2F8DF, 'M', '柺'), + (0x2F8E0, 'M', '枅'), + (0x2F8E1, 'M', '桒'), + (0x2F8E2, 'M', '梅'), + (0x2F8E3, 'M', '𣑭'), + (0x2F8E4, 'M', '梎'), + (0x2F8E5, 'M', '栟'), + (0x2F8E6, 'M', '椔'), + (0x2F8E7, 'M', '㮝'), + (0x2F8E8, 'M', '楂'), + (0x2F8E9, 'M', '榣'), + (0x2F8EA, 'M', '槪'), + (0x2F8EB, 'M', '檨'), + (0x2F8EC, 'M', '𣚣'), + (0x2F8ED, 'M', '櫛'), + (0x2F8EE, 'M', '㰘'), + (0x2F8EF, 'M', '次'), + (0x2F8F0, 'M', '𣢧'), + (0x2F8F1, 'M', '歔'), + (0x2F8F2, 'M', '㱎'), + (0x2F8F3, 'M', '歲'), + (0x2F8F4, 'M', '殟'), + (0x2F8F5, 'M', '殺'), + (0x2F8F6, 'M', '殻'), + (0x2F8F7, 'M', '𣪍'), + (0x2F8F8, 'M', '𡴋'), + (0x2F8F9, 'M', '𣫺'), + (0x2F8FA, 'M', '汎'), + (0x2F8FB, 'M', '𣲼'), + (0x2F8FC, 'M', '沿'), + (0x2F8FD, 'M', '泍'), + (0x2F8FE, 'M', '汧'), + (0x2F8FF, 'M', '洖'), + (0x2F900, 'M', '派'), + (0x2F901, 'M', '海'), + (0x2F902, 'M', '流'), + (0x2F903, 'M', '浩'), + (0x2F904, 'M', '浸'), + (0x2F905, 'M', '涅'), + (0x2F906, 'M', '𣴞'), + (0x2F907, 'M', '洴'), + (0x2F908, 'M', '港'), + (0x2F909, 'M', '湮'), + (0x2F90A, 'M', '㴳'), + (0x2F90B, 'M', '滋'), + (0x2F90C, 'M', '滇'), + (0x2F90D, 'M', '𣻑'), + (0x2F90E, 'M', '淹'), + (0x2F90F, 'M', '潮'), + (0x2F910, 'M', '𣽞'), + (0x2F911, 'M', '𣾎'), + (0x2F912, 'M', '濆'), + (0x2F913, 'M', '瀹'), + (0x2F914, 'M', '瀞'), + (0x2F915, 'M', '瀛'), + (0x2F916, 'M', '㶖'), + (0x2F917, 'M', '灊'), + (0x2F918, 'M', '災'), + (0x2F919, 'M', '灷'), + (0x2F91A, 'M', '炭'), + (0x2F91B, 'M', '𠔥'), + (0x2F91C, 'M', '煅'), + (0x2F91D, 'M', '𤉣'), + (0x2F91E, 'M', '熜'), + (0x2F91F, 'X'), + (0x2F920, 'M', '爨'), + (0x2F921, 'M', '爵'), + (0x2F922, 'M', '牐'), + (0x2F923, 'M', '𤘈'), + (0x2F924, 'M', '犀'), + (0x2F925, 'M', '犕'), + (0x2F926, 'M', '𤜵'), + ] + +def _seg_77(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0x2F927, 'M', '𤠔'), + (0x2F928, 'M', '獺'), + (0x2F929, 'M', '王'), + (0x2F92A, 'M', '㺬'), + (0x2F92B, 'M', '玥'), + (0x2F92C, 'M', '㺸'), + (0x2F92E, 'M', '瑇'), + (0x2F92F, 'M', '瑜'), + (0x2F930, 'M', '瑱'), + (0x2F931, 'M', '璅'), + (0x2F932, 'M', '瓊'), + (0x2F933, 'M', '㼛'), + (0x2F934, 'M', '甤'), + (0x2F935, 'M', '𤰶'), + (0x2F936, 'M', '甾'), + (0x2F937, 'M', '𤲒'), + (0x2F938, 'M', '異'), + (0x2F939, 'M', '𢆟'), + (0x2F93A, 'M', '瘐'), + (0x2F93B, 'M', '𤾡'), + (0x2F93C, 'M', '𤾸'), + (0x2F93D, 'M', '𥁄'), + (0x2F93E, 'M', '㿼'), + (0x2F93F, 'M', '䀈'), + (0x2F940, 'M', '直'), + (0x2F941, 'M', '𥃳'), + (0x2F942, 'M', '𥃲'), + (0x2F943, 'M', '𥄙'), + (0x2F944, 'M', '𥄳'), + (0x2F945, 'M', '眞'), + (0x2F946, 'M', '真'), + (0x2F948, 'M', '睊'), + (0x2F949, 'M', '䀹'), + (0x2F94A, 'M', '瞋'), + (0x2F94B, 'M', '䁆'), + (0x2F94C, 'M', '䂖'), + (0x2F94D, 'M', '𥐝'), + (0x2F94E, 'M', '硎'), + (0x2F94F, 'M', '碌'), + (0x2F950, 'M', '磌'), + (0x2F951, 'M', '䃣'), + (0x2F952, 'M', '𥘦'), + (0x2F953, 'M', '祖'), + (0x2F954, 'M', '𥚚'), + (0x2F955, 'M', '𥛅'), + (0x2F956, 'M', '福'), + (0x2F957, 'M', '秫'), + (0x2F958, 'M', '䄯'), + (0x2F959, 'M', '穀'), + (0x2F95A, 'M', '穊'), + (0x2F95B, 'M', '穏'), + (0x2F95C, 'M', '𥥼'), + (0x2F95D, 'M', '𥪧'), + (0x2F95F, 'X'), + (0x2F960, 'M', '䈂'), + (0x2F961, 'M', '𥮫'), + (0x2F962, 'M', '篆'), + (0x2F963, 'M', '築'), + (0x2F964, 'M', '䈧'), + (0x2F965, 'M', '𥲀'), + (0x2F966, 'M', '糒'), + (0x2F967, 'M', '䊠'), + (0x2F968, 'M', '糨'), + (0x2F969, 'M', '糣'), + (0x2F96A, 'M', '紀'), + (0x2F96B, 'M', '𥾆'), + (0x2F96C, 'M', '絣'), + (0x2F96D, 'M', '䌁'), + (0x2F96E, 'M', '緇'), + (0x2F96F, 'M', '縂'), + (0x2F970, 'M', '繅'), + (0x2F971, 'M', '䌴'), + (0x2F972, 'M', '𦈨'), + (0x2F973, 'M', '𦉇'), + (0x2F974, 'M', '䍙'), + (0x2F975, 'M', '𦋙'), + (0x2F976, 'M', '罺'), + (0x2F977, 'M', '𦌾'), + (0x2F978, 'M', '羕'), + (0x2F979, 'M', '翺'), + (0x2F97A, 'M', '者'), + (0x2F97B, 'M', '𦓚'), + (0x2F97C, 'M', '𦔣'), + (0x2F97D, 'M', '聠'), + (0x2F97E, 'M', '𦖨'), + (0x2F97F, 'M', '聰'), + (0x2F980, 'M', '𣍟'), + (0x2F981, 'M', '䏕'), + (0x2F982, 'M', '育'), + (0x2F983, 'M', '脃'), + (0x2F984, 'M', '䐋'), + (0x2F985, 'M', '脾'), + (0x2F986, 'M', '媵'), + (0x2F987, 'M', '𦞧'), + (0x2F988, 'M', '𦞵'), + (0x2F989, 'M', '𣎓'), + (0x2F98A, 'M', '𣎜'), + (0x2F98B, 'M', '舁'), + (0x2F98C, 'M', '舄'), + (0x2F98D, 'M', '辞'), + ] + +def _seg_78(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0x2F98E, 'M', '䑫'), + (0x2F98F, 'M', '芑'), + (0x2F990, 'M', '芋'), + (0x2F991, 'M', '芝'), + (0x2F992, 'M', '劳'), + (0x2F993, 'M', '花'), + (0x2F994, 'M', '芳'), + (0x2F995, 'M', '芽'), + (0x2F996, 'M', '苦'), + (0x2F997, 'M', '𦬼'), + (0x2F998, 'M', '若'), + (0x2F999, 'M', '茝'), + (0x2F99A, 'M', '荣'), + (0x2F99B, 'M', '莭'), + (0x2F99C, 'M', '茣'), + (0x2F99D, 'M', '莽'), + (0x2F99E, 'M', '菧'), + (0x2F99F, 'M', '著'), + (0x2F9A0, 'M', '荓'), + (0x2F9A1, 'M', '菊'), + (0x2F9A2, 'M', '菌'), + (0x2F9A3, 'M', '菜'), + (0x2F9A4, 'M', '𦰶'), + (0x2F9A5, 'M', '𦵫'), + (0x2F9A6, 'M', '𦳕'), + (0x2F9A7, 'M', '䔫'), + (0x2F9A8, 'M', '蓱'), + (0x2F9A9, 'M', '蓳'), + (0x2F9AA, 'M', '蔖'), + (0x2F9AB, 'M', '𧏊'), + (0x2F9AC, 'M', '蕤'), + (0x2F9AD, 'M', '𦼬'), + (0x2F9AE, 'M', '䕝'), + (0x2F9AF, 'M', '䕡'), + (0x2F9B0, 'M', '𦾱'), + (0x2F9B1, 'M', '𧃒'), + (0x2F9B2, 'M', '䕫'), + (0x2F9B3, 'M', '虐'), + (0x2F9B4, 'M', '虜'), + (0x2F9B5, 'M', '虧'), + (0x2F9B6, 'M', '虩'), + (0x2F9B7, 'M', '蚩'), + (0x2F9B8, 'M', '蚈'), + (0x2F9B9, 'M', '蜎'), + (0x2F9BA, 'M', '蛢'), + (0x2F9BB, 'M', '蝹'), + (0x2F9BC, 'M', '蜨'), + (0x2F9BD, 'M', '蝫'), + (0x2F9BE, 'M', '螆'), + (0x2F9BF, 'X'), + (0x2F9C0, 'M', '蟡'), + (0x2F9C1, 'M', '蠁'), + (0x2F9C2, 'M', '䗹'), + (0x2F9C3, 'M', '衠'), + (0x2F9C4, 'M', '衣'), + (0x2F9C5, 'M', '𧙧'), + (0x2F9C6, 'M', '裗'), + (0x2F9C7, 'M', '裞'), + (0x2F9C8, 'M', '䘵'), + (0x2F9C9, 'M', '裺'), + (0x2F9CA, 'M', '㒻'), + (0x2F9CB, 'M', '𧢮'), + (0x2F9CC, 'M', '𧥦'), + (0x2F9CD, 'M', '䚾'), + (0x2F9CE, 'M', '䛇'), + (0x2F9CF, 'M', '誠'), + (0x2F9D0, 'M', '諭'), + (0x2F9D1, 'M', '變'), + (0x2F9D2, 'M', '豕'), + (0x2F9D3, 'M', '𧲨'), + (0x2F9D4, 'M', '貫'), + (0x2F9D5, 'M', '賁'), + (0x2F9D6, 'M', '贛'), + (0x2F9D7, 'M', '起'), + (0x2F9D8, 'M', '𧼯'), + (0x2F9D9, 'M', '𠠄'), + (0x2F9DA, 'M', '跋'), + (0x2F9DB, 'M', '趼'), + (0x2F9DC, 'M', '跰'), + (0x2F9DD, 'M', '𠣞'), + (0x2F9DE, 'M', '軔'), + (0x2F9DF, 'M', '輸'), + (0x2F9E0, 'M', '𨗒'), + (0x2F9E1, 'M', '𨗭'), + (0x2F9E2, 'M', '邔'), + (0x2F9E3, 'M', '郱'), + (0x2F9E4, 'M', '鄑'), + (0x2F9E5, 'M', '𨜮'), + (0x2F9E6, 'M', '鄛'), + (0x2F9E7, 'M', '鈸'), + (0x2F9E8, 'M', '鋗'), + (0x2F9E9, 'M', '鋘'), + (0x2F9EA, 'M', '鉼'), + (0x2F9EB, 'M', '鏹'), + (0x2F9EC, 'M', '鐕'), + (0x2F9ED, 'M', '𨯺'), + (0x2F9EE, 'M', '開'), + (0x2F9EF, 'M', '䦕'), + (0x2F9F0, 'M', '閷'), + (0x2F9F1, 'M', '𨵷'), + ] + +def _seg_79(): + # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] + return [ + (0x2F9F2, 'M', '䧦'), + (0x2F9F3, 'M', '雃'), + (0x2F9F4, 'M', '嶲'), + (0x2F9F5, 'M', '霣'), + (0x2F9F6, 'M', '𩅅'), + (0x2F9F7, 'M', '𩈚'), + (0x2F9F8, 'M', '䩮'), + (0x2F9F9, 'M', '䩶'), + (0x2F9FA, 'M', '韠'), + (0x2F9FB, 'M', '𩐊'), + (0x2F9FC, 'M', '䪲'), + (0x2F9FD, 'M', '𩒖'), + (0x2F9FE, 'M', '頋'), + (0x2FA00, 'M', '頩'), + (0x2FA01, 'M', '𩖶'), + (0x2FA02, 'M', '飢'), + (0x2FA03, 'M', '䬳'), + (0x2FA04, 'M', '餩'), + (0x2FA05, 'M', '馧'), + (0x2FA06, 'M', '駂'), + (0x2FA07, 'M', '駾'), + (0x2FA08, 'M', '䯎'), + (0x2FA09, 'M', '𩬰'), + (0x2FA0A, 'M', '鬒'), + (0x2FA0B, 'M', '鱀'), + (0x2FA0C, 'M', '鳽'), + (0x2FA0D, 'M', '䳎'), + (0x2FA0E, 'M', '䳭'), + (0x2FA0F, 'M', '鵧'), + (0x2FA10, 'M', '𪃎'), + (0x2FA11, 'M', '䳸'), + (0x2FA12, 'M', '𪄅'), + (0x2FA13, 'M', '𪈎'), + (0x2FA14, 'M', '𪊑'), + (0x2FA15, 'M', '麻'), + (0x2FA16, 'M', '䵖'), + (0x2FA17, 'M', '黹'), + (0x2FA18, 'M', '黾'), + (0x2FA19, 'M', '鼅'), + (0x2FA1A, 'M', '鼏'), + (0x2FA1B, 'M', '鼖'), + (0x2FA1C, 'M', '鼻'), + (0x2FA1D, 'M', '𪘀'), + (0x2FA1E, 'X'), + (0x30000, 'V'), + (0x3134B, 'X'), + (0xE0100, 'I'), + (0xE01F0, 'X'), + ] + +uts46data = tuple( + _seg_0() + + _seg_1() + + _seg_2() + + _seg_3() + + _seg_4() + + _seg_5() + + _seg_6() + + _seg_7() + + _seg_8() + + _seg_9() + + _seg_10() + + _seg_11() + + _seg_12() + + _seg_13() + + _seg_14() + + _seg_15() + + _seg_16() + + _seg_17() + + _seg_18() + + _seg_19() + + _seg_20() + + _seg_21() + + _seg_22() + + _seg_23() + + _seg_24() + + _seg_25() + + _seg_26() + + _seg_27() + + _seg_28() + + _seg_29() + + _seg_30() + + _seg_31() + + _seg_32() + + _seg_33() + + _seg_34() + + _seg_35() + + _seg_36() + + _seg_37() + + _seg_38() + + _seg_39() + + _seg_40() + + _seg_41() + + _seg_42() + + _seg_43() + + _seg_44() + + _seg_45() + + _seg_46() + + _seg_47() + + _seg_48() + + _seg_49() + + _seg_50() + + _seg_51() + + _seg_52() + + _seg_53() + + _seg_54() + + _seg_55() + + _seg_56() + + _seg_57() + + _seg_58() + + _seg_59() + + _seg_60() + + _seg_61() + + _seg_62() + + _seg_63() + + _seg_64() + + _seg_65() + + _seg_66() + + _seg_67() + + _seg_68() + + _seg_69() + + _seg_70() + + _seg_71() + + _seg_72() + + _seg_73() + + _seg_74() + + _seg_75() + + _seg_76() + + _seg_77() + + _seg_78() + + _seg_79() +) # type: Tuple[Union[Tuple[int, str], Tuple[int, str, str]], ...] diff --git a/venv/lib/python3.8/site-packages/pip-20.0.2.dist-info/INSTALLER b/venv/lib/python3.8/site-packages/pip-20.0.2.dist-info/INSTALLER new file mode 100644 index 0000000..a1b589e --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip-20.0.2.dist-info/INSTALLER @@ -0,0 +1 @@ +pip diff --git a/venv/lib/python3.8/site-packages/pip-20.0.2.dist-info/LICENSE.txt b/venv/lib/python3.8/site-packages/pip-20.0.2.dist-info/LICENSE.txt new file mode 100644 index 0000000..737fec5 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip-20.0.2.dist-info/LICENSE.txt @@ -0,0 +1,20 @@ +Copyright (c) 2008-2019 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/venv/lib/python3.8/site-packages/pip-20.0.2.dist-info/METADATA b/venv/lib/python3.8/site-packages/pip-20.0.2.dist-info/METADATA new file mode 100644 index 0000000..5183c4e --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip-20.0.2.dist-info/METADATA @@ -0,0 +1,84 @@ +Metadata-Version: 2.1 +Name: pip +Version: 20.0.2 +Summary: The PyPA recommended tool for installing Python packages. +Home-page: https://pip.pypa.io/ +Author: The pip developers +Author-email: pypa-dev@groups.google.com +License: MIT +Project-URL: Documentation, https://pip.pypa.io +Project-URL: Source, https://github.com/pypa/pip +Keywords: distutils easy_install egg setuptools wheel virtualenv +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 :: 2 +Classifier: Programming Language :: Python :: 2.7 +Classifier: Programming Language :: Python :: 3 +Classifier: Programming Language :: Python :: 3.5 +Classifier: Programming Language :: Python :: 3.6 +Classifier: Programming Language :: Python :: 3.7 +Classifier: Programming Language :: Python :: 3.8 +Classifier: Programming Language :: Python :: Implementation :: CPython +Classifier: Programming Language :: Python :: Implementation :: PyPy +Requires-Python: >=2.7,!=3.0.*,!=3.1.*,!=3.2.*,!=3.3.*,!=3.4.* + +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`_ + +Updates are released regularly, with a new version every 3 months. More details can be found in our documentation: + +* `Release notes`_ +* `Release process`_ + +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`_ +* `Dev documentation`_ +* `Dev mailing list`_ +* `Dev IRC`_ + +Code of Conduct +--------------- + +Everyone interacting in the pip project's codebases, issue trackers, chat +rooms, and mailing lists is expected to follow the `PyPA 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 +.. _Dev documentation: https://pip.pypa.io/en/latest/development +.. _Issue tracking: https://github.com/pypa/pip/issues +.. _Discourse channel: https://discuss.python.org/c/packaging +.. _Dev mailing list: https://groups.google.com/forum/#!forum/pypa-dev +.. _User IRC: https://webchat.freenode.net/?channels=%23pypa +.. _Dev IRC: https://webchat.freenode.net/?channels=%23pypa-dev +.. _PyPA Code of Conduct: https://www.pypa.io/en/latest/code-of-conduct/ + + diff --git a/venv/lib/python3.8/site-packages/pip-20.0.2.dist-info/RECORD b/venv/lib/python3.8/site-packages/pip-20.0.2.dist-info/RECORD new file mode 100644 index 0000000..5f243ff --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip-20.0.2.dist-info/RECORD @@ -0,0 +1,246 @@ +../../../bin/pip,sha256=35bf9qD6lfp3oyaI2BON-lgqjbmrBkt8mkSbPIt_khk,261 +../../../bin/pip3,sha256=35bf9qD6lfp3oyaI2BON-lgqjbmrBkt8mkSbPIt_khk,261 +../../../bin/pip3.8,sha256=35bf9qD6lfp3oyaI2BON-lgqjbmrBkt8mkSbPIt_khk,261 +pip-20.0.2.dist-info/INSTALLER,sha256=zuuue4knoyJ-UwPPXg8fezS7VCrXJQrAP7zeNuwvFQg,4 +pip-20.0.2.dist-info/LICENSE.txt,sha256=W6Ifuwlk-TatfRU2LR7W1JMcyMj5_y1NkRkOEJvnRDE,1090 +pip-20.0.2.dist-info/METADATA,sha256=MSgjT2JTt8usp4Hopp5AGEmc-7sKR2Jd7HTMJqCoRhw,3352 +pip-20.0.2.dist-info/RECORD,, +pip-20.0.2.dist-info/WHEEL,sha256=kGT74LWyRUZrL4VgLh6_g12IeVl_9u9ZVhadrgXZUEY,110 +pip-20.0.2.dist-info/entry_points.txt,sha256=HtfDOwpUlr9s73jqLQ6wF9V0_0qvUXJwCBz7Vwx0Ue0,125 +pip-20.0.2.dist-info/top_level.txt,sha256=zuuue4knoyJ-UwPPXg8fezS7VCrXJQrAP7zeNuwvFQg,4 +pip/__init__.py,sha256=U1AM82iShMaw90K6Yq0Q2-AZ1EsOcqQLQRB-rxwFtII,455 +pip/__main__.py,sha256=NM95x7KuQr-lwPoTjAC0d_QzLJsJjpmAoxZg0mP8s98,632 +pip/__pycache__/__init__.cpython-38.pyc,, +pip/__pycache__/__main__.cpython-38.pyc,, +pip/_internal/__init__.py,sha256=j5fiII6yCeZjpW7_7wAVRMM4DwE-gyARGVU4yAADDeE,517 +pip/_internal/__pycache__/__init__.cpython-38.pyc,, +pip/_internal/__pycache__/build_env.cpython-38.pyc,, +pip/_internal/__pycache__/cache.cpython-38.pyc,, +pip/_internal/__pycache__/configuration.cpython-38.pyc,, +pip/_internal/__pycache__/exceptions.cpython-38.pyc,, +pip/_internal/__pycache__/legacy_resolve.cpython-38.pyc,, +pip/_internal/__pycache__/locations.cpython-38.pyc,, +pip/_internal/__pycache__/main.cpython-38.pyc,, +pip/_internal/__pycache__/pep425tags.cpython-38.pyc,, +pip/_internal/__pycache__/pyproject.cpython-38.pyc,, +pip/_internal/__pycache__/self_outdated_check.cpython-38.pyc,, +pip/_internal/__pycache__/wheel_builder.cpython-38.pyc,, +pip/_internal/build_env.py,sha256=--aNgzIdYrCOclHMwoAdpclCpfdFE_jooRuCy5gczwg,7532 +pip/_internal/cache.py,sha256=16GrnDRLBQNlfKWIuIF6Sa-EFS78kez_w1WEjT3ykTI,11605 +pip/_internal/cli/__init__.py,sha256=FkHBgpxxb-_gd6r1FjnNhfMOzAUYyXoXKJ6abijfcFU,132 +pip/_internal/cli/__pycache__/__init__.cpython-38.pyc,, +pip/_internal/cli/__pycache__/autocompletion.cpython-38.pyc,, +pip/_internal/cli/__pycache__/base_command.cpython-38.pyc,, +pip/_internal/cli/__pycache__/cmdoptions.cpython-38.pyc,, +pip/_internal/cli/__pycache__/command_context.cpython-38.pyc,, +pip/_internal/cli/__pycache__/main.cpython-38.pyc,, +pip/_internal/cli/__pycache__/main_parser.cpython-38.pyc,, +pip/_internal/cli/__pycache__/parser.cpython-38.pyc,, +pip/_internal/cli/__pycache__/req_command.cpython-38.pyc,, +pip/_internal/cli/__pycache__/status_codes.cpython-38.pyc,, +pip/_internal/cli/autocompletion.py,sha256=ekGNtcDI0p7rFVc-7s4T9Tbss4Jgb7vsB649XJIblRg,6547 +pip/_internal/cli/base_command.py,sha256=v6yl5XNRqye8BT9ep8wvpMu6lylP_Hu6D95r_HqbpbQ,7948 +pip/_internal/cli/cmdoptions.py,sha256=f1TVHuu_fR3lLlMo6b367H_GsWFv26tLI9cAS-kZfE0,28114 +pip/_internal/cli/command_context.py,sha256=ygMVoTy2jpNilKT-6416gFSQpaBtrKRBbVbi2fy__EU,975 +pip/_internal/cli/main.py,sha256=8iq3bHe5lxJTB2EvKOqZ38NS0MmoS79_S1kgj4QuH8A,2610 +pip/_internal/cli/main_parser.py,sha256=W9OWeryh7ZkqELohaFh0Ko9sB98ZkSeDmnYbOZ1imBc,2819 +pip/_internal/cli/parser.py,sha256=O9djTuYQuSfObiY-NU6p4MJCfWsRUnDpE2YGA_fwols,9487 +pip/_internal/cli/req_command.py,sha256=pAUAglpTn0mUA6lRs7KN71yOm1KDabD0ySVTQTqWTSA,12463 +pip/_internal/cli/status_codes.py,sha256=F6uDG6Gj7RNKQJUDnd87QKqI16Us-t-B0wPF_4QMpWc,156 +pip/_internal/commands/__init__.py,sha256=uTSj58QlrSKeXqCUSdL-eAf_APzx5BHy1ABxb0j5ZNE,3714 +pip/_internal/commands/__pycache__/__init__.cpython-38.pyc,, +pip/_internal/commands/__pycache__/check.cpython-38.pyc,, +pip/_internal/commands/__pycache__/completion.cpython-38.pyc,, +pip/_internal/commands/__pycache__/configuration.cpython-38.pyc,, +pip/_internal/commands/__pycache__/debug.cpython-38.pyc,, +pip/_internal/commands/__pycache__/download.cpython-38.pyc,, +pip/_internal/commands/__pycache__/freeze.cpython-38.pyc,, +pip/_internal/commands/__pycache__/hash.cpython-38.pyc,, +pip/_internal/commands/__pycache__/help.cpython-38.pyc,, +pip/_internal/commands/__pycache__/install.cpython-38.pyc,, +pip/_internal/commands/__pycache__/list.cpython-38.pyc,, +pip/_internal/commands/__pycache__/search.cpython-38.pyc,, +pip/_internal/commands/__pycache__/show.cpython-38.pyc,, +pip/_internal/commands/__pycache__/uninstall.cpython-38.pyc,, +pip/_internal/commands/__pycache__/wheel.cpython-38.pyc,, +pip/_internal/commands/check.py,sha256=mgLNYT3bd6Kmynwh4zzcBmVlFZ-urMo40jTgk6U405E,1505 +pip/_internal/commands/completion.py,sha256=UFQvq0Q4_B96z1bvnQyMOq82aPSu05RejbLmqeTZjC0,2975 +pip/_internal/commands/configuration.py,sha256=6riioZjMhsNSEct7dE-X8SobGodk3WERKJvuyjBje4Q,7226 +pip/_internal/commands/debug.py,sha256=a8llax2hRkxgK-tvwdJgaCaZCYPIx0fDvrlMDoYr8bQ,4209 +pip/_internal/commands/download.py,sha256=zX_0-IeFb4C8dxSmGHxk-6H5kehtyTSsdWpjNpAhSww,5007 +pip/_internal/commands/freeze.py,sha256=QS-4ib8jbKJ2wrDaDbTuyaB3Y_iJ5CQC2gAVHuAv9QU,3481 +pip/_internal/commands/hash.py,sha256=47teimfAPhpkaVbSDaafck51BT3XXYuL83lAqc5lOcE,1735 +pip/_internal/commands/help.py,sha256=Nhecq--ydFn80Gm1Zvbf9943EcRJfO0TnXUhsF0RO7s,1181 +pip/_internal/commands/install.py,sha256=T4P3J1rw7CQrZX4OUamtcoWMkTrJBfUe6gWpTfZW1bQ,27286 +pip/_internal/commands/list.py,sha256=2l0JiqHxjxDHNTCb2HZOjwwdo4duS1R0MsqZb6HSMKk,10660 +pip/_internal/commands/search.py,sha256=7Il8nKZ9mM7qF5jlnBoPvSIFY9f-0-5IbYoX3miTuZY,5148 +pip/_internal/commands/show.py,sha256=Vzsj2oX0JBl94MPyF3LV8YoMcigl8B2UsMM8zp0pH2s,6792 +pip/_internal/commands/uninstall.py,sha256=8mldFbrQecSoWDZRqxBgJkrlvx6Y9Iy7cs-2BIgtXt4,2983 +pip/_internal/commands/wheel.py,sha256=TMU5ZhjLo7BIZQApGPsYfoCsbGTnvP-N9jkgPJXhj1Y,7170 +pip/_internal/configuration.py,sha256=MgKrLFBJBkF3t2VJM4tvlnEspfSuS4scp_LhHWh53nY,14222 +pip/_internal/distributions/__init__.py,sha256=ECBUW5Gtu9TjJwyFLvim-i6kUMYVuikNh9I5asL6tbA,959 +pip/_internal/distributions/__pycache__/__init__.cpython-38.pyc,, +pip/_internal/distributions/__pycache__/base.cpython-38.pyc,, +pip/_internal/distributions/__pycache__/installed.cpython-38.pyc,, +pip/_internal/distributions/__pycache__/sdist.cpython-38.pyc,, +pip/_internal/distributions/__pycache__/wheel.cpython-38.pyc,, +pip/_internal/distributions/base.py,sha256=ruprpM_L2T2HNi3KLUHlbHimZ1sWVw-3Q0Lb8O7TDAI,1425 +pip/_internal/distributions/installed.py,sha256=YqlkBKr6TVP1MAYS6SG8ojud21wVOYLMZ8jMLJe9MSU,760 +pip/_internal/distributions/sdist.py,sha256=D4XTMlCwgPlK69l62GLYkNSVTVe99fR5iAcVt2EbGok,4086 +pip/_internal/distributions/wheel.py,sha256=95uD-TfaYoq3KiKBdzk9YMN4RRqJ28LNoSTS2K46gek,1294 +pip/_internal/exceptions.py,sha256=6YRuwXAK6F1iyUWKIkCIpWWN2khkAn1sZOgrFA9S8Ro,10247 +pip/_internal/index/__init__.py,sha256=vpt-JeTZefh8a-FC22ZeBSXFVbuBcXSGiILhQZJaNpQ,30 +pip/_internal/index/__pycache__/__init__.cpython-38.pyc,, +pip/_internal/index/__pycache__/collector.cpython-38.pyc,, +pip/_internal/index/__pycache__/package_finder.cpython-38.pyc,, +pip/_internal/index/collector.py,sha256=YS7Ix4oylU7ZbPTPFugh-244GSRqMvdHsGUG6nmz2gE,17892 +pip/_internal/index/package_finder.py,sha256=2Rg75AOpLj8BN1jyL8EI-Iw-Hv6ibJkrYVARCht3bX8,37542 +pip/_internal/legacy_resolve.py,sha256=L7R72I7CjVgJlPTggmA1j4b-H8NmxNu_dKVhrpGXGps,16277 +pip/_internal/locations.py,sha256=VifFEqhc7FWFV8QGoEM3CpECRY8Doq7kTytytxsEgx0,6734 +pip/_internal/main.py,sha256=IVBnUQ-FG7DK6617uEXRB5_QJqspAsBFmTmTesYkbdQ,437 +pip/_internal/models/__init__.py,sha256=3DHUd_qxpPozfzouoqa9g9ts1Czr5qaHfFxbnxriepM,63 +pip/_internal/models/__pycache__/__init__.cpython-38.pyc,, +pip/_internal/models/__pycache__/candidate.cpython-38.pyc,, +pip/_internal/models/__pycache__/format_control.cpython-38.pyc,, +pip/_internal/models/__pycache__/index.cpython-38.pyc,, +pip/_internal/models/__pycache__/link.cpython-38.pyc,, +pip/_internal/models/__pycache__/scheme.cpython-38.pyc,, +pip/_internal/models/__pycache__/search_scope.cpython-38.pyc,, +pip/_internal/models/__pycache__/selection_prefs.cpython-38.pyc,, +pip/_internal/models/__pycache__/target_python.cpython-38.pyc,, +pip/_internal/models/__pycache__/wheel.cpython-38.pyc,, +pip/_internal/models/candidate.py,sha256=Y58Bcm6oXUj0iS-yhmerlGo5CQJI2p0Ww9h6hR9zQDw,1150 +pip/_internal/models/format_control.py,sha256=ICzVjjGwfZYdX-eLLKHjMHLutEJlAGpfj09OG_eMqac,2673 +pip/_internal/models/index.py,sha256=K59A8-hVhBM20Xkahr4dTwP7OjkJyEqXH11UwHFVgqM,1060 +pip/_internal/models/link.py,sha256=y0H2ZOk0P6d1lfGUL2Pl09xFgZcRt5HwN2LElMifOpI,6827 +pip/_internal/models/scheme.py,sha256=vvhBrrno7eVDXcdKHiZWwxhPHf4VG5uSCEkC0QDR2RU,679 +pip/_internal/models/search_scope.py,sha256=2LXbU4wV8LwqdtXQXNXFYKv-IxiDI_QwSz9ZgbwtAfk,3898 +pip/_internal/models/selection_prefs.py,sha256=rPeif2KKjhTPXeMoQYffjqh10oWpXhdkxRDaPT1HO8k,1908 +pip/_internal/models/target_python.py,sha256=c-cFi6zCuo5HYbXNS3rVVpKRaHVh5yQlYEjEW23SidQ,3799 +pip/_internal/models/wheel.py,sha256=6KLuLKH5b0C5goWQXGSISRaq2UZtkHUEAU1y1Zsrwms,2766 +pip/_internal/network/__init__.py,sha256=jf6Tt5nV_7zkARBrKojIXItgejvoegVJVKUbhAa5Ioc,50 +pip/_internal/network/__pycache__/__init__.cpython-38.pyc,, +pip/_internal/network/__pycache__/auth.cpython-38.pyc,, +pip/_internal/network/__pycache__/cache.cpython-38.pyc,, +pip/_internal/network/__pycache__/download.cpython-38.pyc,, +pip/_internal/network/__pycache__/session.cpython-38.pyc,, +pip/_internal/network/__pycache__/utils.cpython-38.pyc,, +pip/_internal/network/__pycache__/xmlrpc.cpython-38.pyc,, +pip/_internal/network/auth.py,sha256=K3G1ukKb3PiH8w_UnpXTz8qQsTULO-qdbfOE9zTo1fE,11119 +pip/_internal/network/cache.py,sha256=51CExcRkXWrgMZ7WsrZ6cmijKfViD5tVgKbBvJHO1IE,2394 +pip/_internal/network/download.py,sha256=3D9vdJmVwmCUMxzC-TaVI_GvVOpQna3BLEYNPCSx3Fc,6260 +pip/_internal/network/session.py,sha256=u1IXQfv21R1xv86ulyiB58-be4sYm90eFB0Wp8fVMYw,14702 +pip/_internal/network/utils.py,sha256=iiixo1OeaQ3niUWiBjg59PN6f1w7vvTww1vFriTD_IU,1959 +pip/_internal/network/xmlrpc.py,sha256=AL115M3vFJ8xiHVJneb8Hi0ZFeRvdPhblC89w25OG5s,1597 +pip/_internal/operations/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 +pip/_internal/operations/__pycache__/__init__.cpython-38.pyc,, +pip/_internal/operations/__pycache__/check.cpython-38.pyc,, +pip/_internal/operations/__pycache__/freeze.cpython-38.pyc,, +pip/_internal/operations/__pycache__/prepare.cpython-38.pyc,, +pip/_internal/operations/build/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 +pip/_internal/operations/build/__pycache__/__init__.cpython-38.pyc,, +pip/_internal/operations/build/__pycache__/metadata.cpython-38.pyc,, +pip/_internal/operations/build/__pycache__/metadata_legacy.cpython-38.pyc,, +pip/_internal/operations/build/__pycache__/wheel.cpython-38.pyc,, +pip/_internal/operations/build/__pycache__/wheel_legacy.cpython-38.pyc,, +pip/_internal/operations/build/metadata.py,sha256=yHMi5gHYXcXyHcvUPWHdO-UyOo3McFWljn_nHfM1O9c,1307 +pip/_internal/operations/build/metadata_legacy.py,sha256=4n6N7BTysqVmEpITzT2UVClyt0Peij_Im8Qm965IWB4,3957 +pip/_internal/operations/build/wheel.py,sha256=ntltdNP6D2Tpr4V0agssu6rE0F9LaBpJkYT6zSdhEbw,1469 +pip/_internal/operations/build/wheel_legacy.py,sha256=DYSxQKutwSZnmNvWkwsl2HzE2XQBxV0i0wTphjtUe90,3349 +pip/_internal/operations/check.py,sha256=a6uHG0daoWpmSPCdL7iYJaGQYZ-CRvPvTnCv2PnIIs0,5353 +pip/_internal/operations/freeze.py,sha256=td4BeRnW10EXFTZrx6VgygO3CrjqD5B9f0BGzjQm-Ew,10180 +pip/_internal/operations/install/__init__.py,sha256=mX7hyD2GNBO2mFGokDQ30r_GXv7Y_PLdtxcUv144e-s,51 +pip/_internal/operations/install/__pycache__/__init__.cpython-38.pyc,, +pip/_internal/operations/install/__pycache__/editable_legacy.cpython-38.pyc,, +pip/_internal/operations/install/__pycache__/legacy.cpython-38.pyc,, +pip/_internal/operations/install/__pycache__/wheel.cpython-38.pyc,, +pip/_internal/operations/install/editable_legacy.py,sha256=rJ_xs2qtDUjpY2-n6eYlVyZiNoKbOtZXZrYrcnIELt4,1488 +pip/_internal/operations/install/legacy.py,sha256=eBV8gHbO9sBlBc-4nuR3Sd2nikHgEcnC9khfeLiypio,4566 +pip/_internal/operations/install/wheel.py,sha256=xdCjH6uIUyg39Pf8tUaMFUN4a7eozJAFMb_wKcgQlsY,23012 +pip/_internal/operations/prepare.py,sha256=ro2teBlbBpkRJhBKraP9CoJgVLpueSk62ziWhRToXww,20942 +pip/_internal/pep425tags.py,sha256=SlIQokevkoKnXhoK3PZvXiDoj8hFKoJ7thDifDtga3k,5490 +pip/_internal/pyproject.py,sha256=VJKsrXORGiGoDPVKCQhuu4tWlQSTOhoiRlVLRNu4rx4,7400 +pip/_internal/req/__init__.py,sha256=UVaYPlHZVGRBQQPjvGC_6jJDQtewXm0ws-8Lxhg_TiY,2671 +pip/_internal/req/__pycache__/__init__.cpython-38.pyc,, +pip/_internal/req/__pycache__/constructors.cpython-38.pyc,, +pip/_internal/req/__pycache__/req_file.cpython-38.pyc,, +pip/_internal/req/__pycache__/req_install.cpython-38.pyc,, +pip/_internal/req/__pycache__/req_set.cpython-38.pyc,, +pip/_internal/req/__pycache__/req_tracker.cpython-38.pyc,, +pip/_internal/req/__pycache__/req_uninstall.cpython-38.pyc,, +pip/_internal/req/constructors.py,sha256=w5-kWWVCqlSqcIBitw86yq7XGMPpKrHDfQZSE2mJ_xc,14388 +pip/_internal/req/req_file.py,sha256=ECqRUicCw5Y08R1YynZAAp8dSKQhDXoc1Q-mY3a9b6I,18485 +pip/_internal/req/req_install.py,sha256=wjsIr4lDpbVSLqANKJI9mXwRVHaRxcnj8q30UiHoLRA,30442 +pip/_internal/req/req_set.py,sha256=GsrKmupRKhNMhjkofVfCEHEHfgEvYBxClaQH5xLBQHg,8066 +pip/_internal/req/req_tracker.py,sha256=27fvVG8Y2MJS1KpU2rBMnQyUEMHG4lkHT_bzbzQK-c0,4723 +pip/_internal/req/req_uninstall.py,sha256=DWnOsuyYGju6-sylyoCm7GtUNevn9qMAVhjAGLcdXUE,23609 +pip/_internal/self_outdated_check.py,sha256=3KO1pTJUuYaiV9X0t87I9PimkGL82HbhLWbocqKZpBU,8009 +pip/_internal/utils/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 +pip/_internal/utils/__pycache__/__init__.cpython-38.pyc,, +pip/_internal/utils/__pycache__/appdirs.cpython-38.pyc,, +pip/_internal/utils/__pycache__/compat.cpython-38.pyc,, +pip/_internal/utils/__pycache__/deprecation.cpython-38.pyc,, +pip/_internal/utils/__pycache__/distutils_args.cpython-38.pyc,, +pip/_internal/utils/__pycache__/encoding.cpython-38.pyc,, +pip/_internal/utils/__pycache__/entrypoints.cpython-38.pyc,, +pip/_internal/utils/__pycache__/filesystem.cpython-38.pyc,, +pip/_internal/utils/__pycache__/filetypes.cpython-38.pyc,, +pip/_internal/utils/__pycache__/glibc.cpython-38.pyc,, +pip/_internal/utils/__pycache__/hashes.cpython-38.pyc,, +pip/_internal/utils/__pycache__/inject_securetransport.cpython-38.pyc,, +pip/_internal/utils/__pycache__/logging.cpython-38.pyc,, +pip/_internal/utils/__pycache__/marker_files.cpython-38.pyc,, +pip/_internal/utils/__pycache__/misc.cpython-38.pyc,, +pip/_internal/utils/__pycache__/models.cpython-38.pyc,, +pip/_internal/utils/__pycache__/packaging.cpython-38.pyc,, +pip/_internal/utils/__pycache__/pkg_resources.cpython-38.pyc,, +pip/_internal/utils/__pycache__/setuptools_build.cpython-38.pyc,, +pip/_internal/utils/__pycache__/subprocess.cpython-38.pyc,, +pip/_internal/utils/__pycache__/temp_dir.cpython-38.pyc,, +pip/_internal/utils/__pycache__/typing.cpython-38.pyc,, +pip/_internal/utils/__pycache__/ui.cpython-38.pyc,, +pip/_internal/utils/__pycache__/unpacking.cpython-38.pyc,, +pip/_internal/utils/__pycache__/urls.cpython-38.pyc,, +pip/_internal/utils/__pycache__/virtualenv.cpython-38.pyc,, +pip/_internal/utils/__pycache__/wheel.cpython-38.pyc,, +pip/_internal/utils/appdirs.py,sha256=PVo_7-IQWHa9qNuNbWSFiF2QGqeLbSAR4eLcYYhQ9ek,1307 +pip/_internal/utils/compat.py,sha256=D7FKGLBdQwWH-dHIGaoWMawDZWBYApvtJVL1kFPJ930,8869 +pip/_internal/utils/deprecation.py,sha256=pBnNogoA4UGTxa_JDnPXBRRYpKMbExAhXpBwAwklOBs,3318 +pip/_internal/utils/distutils_args.py,sha256=a56mblNxk9BGifbpEETG61mmBrqhjtjRkJ4HYn-oOEE,1350 +pip/_internal/utils/encoding.py,sha256=hxZz0t3Whw3d4MHQEiofxalTlfKwxFdLc8fpeGfhKo8,1320 +pip/_internal/utils/entrypoints.py,sha256=vHcNpnksCv6mllihU6hfifdsKPEjwcaJ1aLIXEaynaU,1152 +pip/_internal/utils/filesystem.py,sha256=PXa3vMcz4mbEKtkD0joFI8pBwddLQxhfPFOkVH5xjfE,5255 +pip/_internal/utils/filetypes.py,sha256=R2FwzoeX7b-rZALOXx5cuO8VPPMhUQ4ne7wm3n3IcWA,571 +pip/_internal/utils/glibc.py,sha256=LOeNGgawCKS-4ke9fii78fwXD73dtNav3uxz1Bf-Ab8,3297 +pip/_internal/utils/hashes.py,sha256=my-wSnAWEDvl_8rQaOQcVIWjwh1-f_QiEvGy9TPf53U,3942 +pip/_internal/utils/inject_securetransport.py,sha256=M17ZlFVY66ApgeASVjKKLKNz0LAfk-SyU0HZ4ZB6MmI,810 +pip/_internal/utils/logging.py,sha256=aJL7NldPhS5KGFof6Qt3o3MG5cjm5TOoo7bGRu9_wsg,13033 +pip/_internal/utils/marker_files.py,sha256=CO5djQlrPIozJpJybViH_insoAaBGY1aqEt6-cC-iW0,741 +pip/_internal/utils/misc.py,sha256=uIb58Hiu_g2HRORo2aMcgnW_7R5d-5wUAuoW0fA2ZME,26085 +pip/_internal/utils/models.py,sha256=IA0hw_T4awQzui0kqfIEASm5yLtgZAB08ag59Nip5G8,1148 +pip/_internal/utils/packaging.py,sha256=VtiwcAAL7LBi7tGL2je7LeW4bE11KMHGCsJ1NZY5XtM,3035 +pip/_internal/utils/pkg_resources.py,sha256=ZX-k7V5q_aNWyDse92nN7orN1aCpRLsaxzpkBZ1XKzU,1254 +pip/_internal/utils/setuptools_build.py,sha256=DouaVolV9olDDFIIN9IszaL-FHdNaZt10ufOZFH9ZAU,5070 +pip/_internal/utils/subprocess.py,sha256=Ph3x5eHQBxFotyGhpZN8asSMBud-BBkmgaNfARG-di8,9922 +pip/_internal/utils/temp_dir.py,sha256=87Ib8aNic_hoSDEmUYJHTQIn5-prL2AYL5u_yZ3s4sI,7768 +pip/_internal/utils/typing.py,sha256=xkYwOeHlf4zsHXBDC4310HtEqwhQcYXFPq2h35Tcrl0,1401 +pip/_internal/utils/ui.py,sha256=0FNxXlGtbpPtTviv2oXS9t8bQG_NBdfUgP4GbubhS9U,13911 +pip/_internal/utils/unpacking.py,sha256=M944JTSiapBOSKLWu7lbawpVHSE7flfzZTEr3TAG7v8,9438 +pip/_internal/utils/urls.py,sha256=aNV9wq5ClUmrz6sG-al7hEWJ4ToitOy7l82CmFGFNW8,1481 +pip/_internal/utils/virtualenv.py,sha256=Q3S1WPlI7JWpGOT2jUVJ8l2chm_k7VPJ9cHA_cUluEU,3396 +pip/_internal/utils/wheel.py,sha256=grTRwZtMQwApwbbSPmRVLtac6FKy6SVKeCXNkWyyePA,7302 +pip/_internal/vcs/__init__.py,sha256=viJxJRqRE_mVScum85bgQIXAd6o0ozFt18VpC-qIJrM,617 +pip/_internal/vcs/__pycache__/__init__.cpython-38.pyc,, +pip/_internal/vcs/__pycache__/bazaar.cpython-38.pyc,, +pip/_internal/vcs/__pycache__/git.cpython-38.pyc,, +pip/_internal/vcs/__pycache__/mercurial.cpython-38.pyc,, +pip/_internal/vcs/__pycache__/subversion.cpython-38.pyc,, +pip/_internal/vcs/__pycache__/versioncontrol.cpython-38.pyc,, +pip/_internal/vcs/bazaar.py,sha256=84q1-kj1_nJ9AMzMu8RmMp-riRZu81M7K9kowcYgi3U,3957 +pip/_internal/vcs/git.py,sha256=CdLz3DTsZsLMLPZpEuUwiS40npvDaVB1CNRzoXgcuJQ,14352 +pip/_internal/vcs/mercurial.py,sha256=2mg7BdYI_Fe00fF6omaNccFQLPHBsDBG5CAEzvqn5sA,5110 +pip/_internal/vcs/subversion.py,sha256=Fpwy71AmuqXnoKi6h1SrXRtPjEMn8fieuM1O4j01IBg,12292 +pip/_internal/vcs/versioncontrol.py,sha256=nqoaM1_rzx24WnHtihXA8RcPpnUae0sV2sR_LS_5HFA,22600 +pip/_internal/wheel_builder.py,sha256=gr9jE14W5ZuYblpldo-tpRuyG0e0AVmHLttImuAvXlE,9441 +pip/_vendor/__init__.py,sha256=RcHf8jwLPL0ZEaa6uMhTSfyCrA_TpWgDWAW5br9xD7Y,4975 +pip/_vendor/__pycache__/__init__.cpython-38.pyc,, diff --git a/venv/lib/python3.8/site-packages/pip-20.0.2.dist-info/WHEEL b/venv/lib/python3.8/site-packages/pip-20.0.2.dist-info/WHEEL new file mode 100644 index 0000000..ef99c6c --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip-20.0.2.dist-info/WHEEL @@ -0,0 +1,6 @@ +Wheel-Version: 1.0 +Generator: bdist_wheel (0.34.2) +Root-Is-Purelib: true +Tag: py2-none-any +Tag: py3-none-any + diff --git a/venv/lib/python3.8/site-packages/pip-20.0.2.dist-info/entry_points.txt b/venv/lib/python3.8/site-packages/pip-20.0.2.dist-info/entry_points.txt new file mode 100644 index 0000000..d48bd8a --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip-20.0.2.dist-info/entry_points.txt @@ -0,0 +1,5 @@ +[console_scripts] +pip = pip._internal.cli.main:main +pip3 = pip._internal.cli.main:main +pip3.8 = pip._internal.cli.main:main + diff --git a/venv/lib/python3.8/site-packages/pip-20.0.2.dist-info/top_level.txt b/venv/lib/python3.8/site-packages/pip-20.0.2.dist-info/top_level.txt new file mode 100644 index 0000000..a1b589e --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip-20.0.2.dist-info/top_level.txt @@ -0,0 +1 @@ +pip diff --git a/venv/lib/python3.8/site-packages/pip/__init__.py b/venv/lib/python3.8/site-packages/pip/__init__.py new file mode 100644 index 0000000..827a4e2 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/__init__.py @@ -0,0 +1,18 @@ +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import List, Optional + + +__version__ = "20.0.2" + + +def main(args=None): + # type: (Optional[List[str]]) -> 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. + """ + from pip._internal.utils.entrypoints import _wrapper + + return _wrapper(args) diff --git a/venv/lib/python3.8/site-packages/pip/__main__.py b/venv/lib/python3.8/site-packages/pip/__main__.py new file mode 100644 index 0000000..e83b9e0 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/__main__.py @@ -0,0 +1,19 @@ +from __future__ import absolute_import + +import os +import sys + +# If we are running from a wheel, add the wheel to sys.path +# This allows the usage python pip-*.whl/pip install pip-*.whl +if __package__ == '': + # __file__ is pip-*.whl/pip/__main__.py + # first dirname call strips of '/__main__.py', second strips off '/pip' + # Resulting path is the name of the wheel itself + # Add that to sys.path so we can import pip + path = os.path.dirname(os.path.dirname(__file__)) + sys.path.insert(0, path) + +from pip._internal.cli.main import main as _main # isort:skip # noqa + +if __name__ == '__main__': + sys.exit(_main()) diff --git a/venv/lib/python3.8/site-packages/pip/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..1cfdc5295dcca8432e1af8fc758774ffde03da8e GIT binary patch literal 629 zcmZuv&2H2%5Vn(S8kSZ0zjS*v53X7W;0d^$LEwnv z8a24Y7zu0$;Ghngune21j4H zcuc^aK`P^1UP>ceI3{a*k60nd(m8D(=J`UpWp|QQZIkO>vm7{cX>BKLzPs~aFIy8C z-wcc(p)13*76uyMhRlrqRhe}Ts57CQ>2(XI){Oie7!WgyOYjYu1kQd1i_WGUGS_B1d=_t)~KST|a%0IJ>AfR|NFdn72NH>Pt{}bYRE!D#K xp%3vN;D3Vg1jBVoKMP~w#VB1ft%Y3)*L+s;sA+jui^slu>!oi75xx;d;cxb8qICcO literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/__pycache__/__main__.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/__pycache__/__main__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..6c70a4ee8997c5d01002feef1f6dfd34f1a6fa18 GIT binary patch literal 422 zcmYjMyH3L}6t$hW4Sj(S;tv=)G-W`*fDjWS3u4J)h5Dv->pXBAwVnBqX5^Q=GVu#c z_(mXcCEwTaImdn(j|arZ&GkjPV}yL-@ISa89{j1-K1m{}COJ(g#hz)Fu&xG40HF*v z%sc{H^F!}9_gmW1ghSwWktD!d)-gkUln;_2B`}iQvoZ({V;H`Z7M0mEnfAWCADL2j zoW9njZY&6uSEaE}4!2>Rs=`G=U=?CIaRVW;#x@3oF#aRNv9fkSy|3L+h$>xd(xr!7 zSfzI5`cj!9%>flMr4i_ int + """This is preserved for old console scripts that may still be referencing + it. + + For additional details, see https://github.com/pypa/pip/issues/7498. + """ + from pip._internal.utils.entrypoints import _wrapper + + return _wrapper(args) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..21fa558c4b42712b6c6454863b1ddf22cef0a3fe GIT binary patch literal 678 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 tzJ literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/__pycache__/exceptions.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/__pycache__/exceptions.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..f26ec825f3f6858facbeaba23f2f5a2dd6de6ca4 GIT binary patch literal 12482 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 z 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 literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/__pycache__/main.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/__pycache__/main.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..b20e095d3e4b3e2e5db15feab03088dc915213e1 GIT binary patch literal 615 zcmZuv&2H2%5Vn)-535!}h!Yol;Sh;UE>&9)LP)FfBOoB4hwf$N#?y_3lNgWFRZuy> zb8zPYc$r)|@d}(6Z&B3)BhRP#EYEy1wvTsrXN>G%|DOEG8T%E;b&H8SA;*kBF~tq5 z`I2)6+zH~5iRyS6*U2*BOpR5dM&I~yq~iB1o&2U8mh$1&>yx)9tHtx9#mm*Z>j1%> zgA!-06RlCAY#VG12rQkp9)+)@7q#pKdToq21>xWf95khF)-yq-eKy+$PpO1dN?-OT z6nLo(-WLcUD(@{m%=5MORd*zaw&OQ;3I9*41UOt2Fr{AT}}qyLG2!(4OHPl(GY=j+9TfZ|)SDD=$q^mO<1b3U7&uWI;y zzWq~AtZ3RlX)*noSUkW#`v$<*+M3UNJ!FyI))~!>&}bXQXtqs^W>|`>wiT7z<;ZT^ zQKemps_kkt*Pe@N?OJiB6wXKWcAaUwE+o!a;e}|Sy%1e&UyK&piv>*?e3sfvpfOID z`N|nM!}ruUY#? z{+hqyU&8FizVS?JTt43Xl*e3nk~?1PI|qr_cMbx%=j?p4<7{ny=sZlK)RVz(5C-zd zdG7VH<{MZ*YcO@e+s%@&FS#2;X(D8+QC0>h)P>IIP{>`06ROrpkK|qwk5)Yr8FYrL zg&>w(q=Eywu@`Z*G>!R+i!4ZDH6M8$Hw``6O+=JI`r_|C-}&5q_~?^|zjdE})@nU& zecCXT`6S4svVWgS9P&a{dfrb%4)Xb(LW4gH*&VN3Yrfxbuf6ckArKu#R~vmaFXR6Z z|7;DwXQ!HEQqSRkU;mSSSv%3s7_4Ztl=emk1u5_{31VeLUaE{t3P`SvuHXi7H~Ctl z=+eHucT+~`%``}F^yAd)>~sId!5-(~jiBHA^3KuL0qxzy5m*KHxS8@4-XLQ((<8Mq z&C->L8z+7u-z7y!4b2d%fHSwDn@|iJ_-9W6q;|@3?Tigr&cvgfo$6=W3-hnqKpz+b zQyRH`!T^mE*3}24KWklv2-RQP(#%V_d7}SXJ7EJWwsNh9F}Dgk%!njaZ2Xr<|3G>ccVn*#;TT^s|W%HZva!8#>7`}%EYN5^~_#QVQ;k* zb15<7qcDj3hnu%P*t$IsO(~q@pOdF`dy%h=A^6|n)4mE)6ZlQ!Kx$0&g;e

pPB!LGJt zvqiSd?9w6=A7bynY)k1<*!BS?Q&weUSF91eXG~nBqJVTTE02bax>I^Z%1Tk}p zZL=kQ20qFfhIT_2?_(*N01Z>zqOEEsVUUb!aN+Gjt+7cqiTXByEdperw{O4V_P88d zU{Wtzpv>w3nvQ6~&t_E}@kI8Rxib|#imBqxcQKK;HFA{go8p>8T=`V?khz#4kBcIR z0`UxmalF?>Z1`GH4&D$uK>%01Li6`%&Qy7n5^rn2RA@hH79*NAj${^qrq|fIE`EVo zrzmrT!$ylxGo1DT|IXi>S4ZU@2z8bt5Gz>xYQBbuK zmjMu%bu_h*M?98je@QIJ7;me)I&JK!uC)u=tawl8HnU)CnEIE%bx6(eNBfih@((O} z+5j(yL5WPeUlD6V(+^58Erpjpu&`Us@yfvNR&Jo~mVvQxLBc#j5Tcx7t*1NEIDxD7 z^+6@Ch%`4(O<6+SF6Xvy{LP?*kCzK9DtCc3hu8vF2Bihc(ilg{?mdH@pK{q3vEw;Z zGM%LBWc`#{KldH#O%BSm!@bU)GxD92rMwe#1MCNJ)xr10XeaxkSuGHEQ2@MXeBds4 zqiqIpZ;ZK4V&ont-jTC$`}T$dAse?hH?9}wi761RB<4-$Iq1fs4}vgscDdtaSwA8L zld-l=(ihH0A3ttRD=^NLyCa>C3ZeWE)!Z5HIY&v~Iq+iXeC36KKaoGaJ9Hgu^0-^5 zblvG^yx>%H8z(!;B#$NxXEdOI`yuJGf%w1cFcqi{@t#q_+YNq52cZAIg28Yox25z> ziicBuHtW&fcY_S=Ve;fN)ZCQj;sG*7d<1~x{T0nWo*?X^Mid!WRJbC!mBkMw+KZs_ zCa9hW%Em^u$ZTbg1)*udCdz<#RhfkMl!ym(lmx44kh!Cm?c0@Mo~rQV^ggJw-vDS! zrf#Ah*m|`XthkJ9C*%zfVY?R!z;_d|Z48cs%y)?_slU|YXht-;XCdJSf;8tD2f_9eS! M+tsSZir;tt0sa(|KL7v# literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/__pycache__/pyproject.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/__pycache__/pyproject.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..c3a0d36a0d37c5ac1981e10700b506a5b9cef792 GIT binary patch literal 3732 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 literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/__pycache__/wheel_builder.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/__pycache__/wheel_builder.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..62f3651ccaf542c1f4b4bff7753516478141cf4d GIT binary patch literal 6699 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 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'] + # Note: prefer distutils' sysconfig to get the + # library paths so PyPy is correctly supported. + purelib = get_python_lib(plat_specific=False, prefix=path) + platlib = get_python_lib(plat_specific=True, prefix=path) + if purelib == platlib: + self.lib_dirs = [purelib] + else: + self.lib_dirs = [purelib, platlib] + + +class BuildEnvironment(object): + """Creates and manages an isolated environment to install build deps + """ + + def __init__(self): + # type: () -> None + self._temp_dir = TempDirectory(kind="build-env") + + self._prefixes = OrderedDict(( + (name, _Prefix(os.path.join(self._temp_dir.path, name))) + for name in ('normal', 'overlay') + )) + + self._bin_dirs = [] # type: List[str] + self._lib_dirs = [] # type: List[str] + for prefix in reversed(list(self._prefixes.values())): + self._bin_dirs.append(prefix.bin_dir) + self._lib_dirs.extend(prefix.lib_dirs) + + # Customize site to: + # - ensure .pth files are honored + # - prevent access to system site packages + system_sites = { + os.path.normcase(site) for site in ( + get_python_lib(plat_specific=False), + get_python_lib(plat_specific=True), + ) + } + self._site_dir = os.path.join(self._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( + ''' + import os, site, sys + + # First, drop system-sites related paths. + original_sys_path = sys.path[:] + known_paths = set() + for path in {system_sites!r}: + site.addsitedir(path, known_paths=known_paths) + system_paths = set( + os.path.normcase(path) + for path in sys.path[len(original_sys_path):] + ) + original_sys_path = [ + path for path in original_sys_path + if os.path.normcase(path) not in system_paths + ] + sys.path = original_sys_path + + # Second, add lib directories. + # ensuring .pth file are processed. + 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)) + + def __enter__(self): + self._save_env = { + name: os.environ.get(name, None) + for name in ('PATH', 'PYTHONNOUSERSITE', 'PYTHONPATH') + } + + path = self._bin_dirs[:] + 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), + }) + + def __exit__(self, exc_type, exc_val, exc_tb): + 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 cleanup(self): + # type: () -> None + self._temp_dir.cleanup() + + def check_requirements(self, reqs): + # type: (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 + """ + 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]))) + return conflicting, missing + + def install_requirements( + self, + finder, # type: PackageFinder + requirements, # type: Iterable[str] + prefix_as_string, # type: str + message # type: Optional[str] + ): + # type: (...) -> None + prefix = self._prefixes[prefix_as_string] + assert not prefix.setup + prefix.setup = True + if not requirements: + return + args = [ + sys.executable, os.path.dirname(pip_location), 'install', + '--ignore-installed', '--no-user', '--prefix', prefix.path, + '--no-warn-script-location', + ] # type: List[str] + if logger.getEffectiveLevel() <= logging.DEBUG: + 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:'})))) + + index_urls = finder.index_urls + if index_urls: + args.extend(['-i', index_urls[0]]) + for extra_index in index_urls[1:]: + args.extend(['--extra-index-url', extra_index]) + else: + args.append('--no-index') + for link in finder.find_links: + args.extend(['--find-links', link]) + + for host in finder.trusted_hosts: + args.extend(['--trusted-host', host]) + if finder.allow_all_prereleases: + args.append('--pre') + args.append('--') + args.extend(requirements) + with open_spinner(message) as spinner: + call_subprocess(args, spinner=spinner) + + +class NoOpBuildEnvironment(BuildEnvironment): + """A no-op drop-in replacement for BuildEnvironment + """ + + def __init__(self): + pass + + def __enter__(self): + pass + + def __exit__(self, exc_type, exc_val, exc_tb): + pass + + def cleanup(self): + pass + + def install_requirements(self, finder, requirements, prefix, message): + raise NotImplementedError() diff --git a/venv/lib/python3.8/site-packages/pip/_internal/cache.py b/venv/lib/python3.8/site-packages/pip/_internal/cache.py new file mode 100644 index 0000000..abecd78 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/cache.py @@ -0,0 +1,329 @@ +"""Cache Management +""" + +# The following comment should be removed at some point in the future. +# mypy: strict-optional=False + +import hashlib +import json +import logging +import os + +from pip._vendor.packaging.tags import interpreter_name, interpreter_version +from pip._vendor.packaging.utils import canonicalize_name + +from pip._internal.exceptions import InvalidWheelFilename +from pip._internal.models.link import Link +from pip._internal.models.wheel import Wheel +from pip._internal.utils.temp_dir import TempDirectory +from pip._internal.utils.typing import MYPY_CHECK_RUNNING +from pip._internal.utils.urls import path_to_url + +if MYPY_CHECK_RUNNING: + from typing import Optional, Set, List, Any, Dict + + from pip._vendor.packaging.tags import Tag + + from pip._internal.models.format_control import FormatControl + +logger = logging.getLogger(__name__) + + +def _hash_dict(d): + # type: (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() + + +class Cache(object): + """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) + """ + + def __init__(self, cache_dir, format_control, allowed_formats): + # type: (str, FormatControl, Set[str]) -> None + super(Cache, self).__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_legacy(self, link): + # type: (Link) -> List[str] + """Get parts of part that must be os.path.joined with cache_dir + + Legacy cache key (pip < 20) for compatibility with older caches. + """ + + # 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 + # and we don't care about those. + key_parts = [link.url_without_fragment] + if link.hash_name is not None and link.hash is not None: + key_parts.append("=".join([link.hash_name, link.hash])) + key_url = "#".join(key_parts) + + # Encode our key url with sha224, we'll use this because it has similar + # security properties to sha256, but with a shorter total output (and + # thus less secure). However the differences don't make a lot of + # difference for our use case here. + hashed = hashlib.sha224(key_url.encode()).hexdigest() + + # We want to nest the directories some to prevent having a ton of top + # level directories where we might run out of sub directories on some + # FS. + parts = [hashed[:2], hashed[2:4], hashed[4:6], hashed[6:]] + + return parts + + def _get_cache_path_parts(self, link): + # type: (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 + # and we don't care about those. + key_parts = {"url": link.url_without_fragment} + if link.hash_name is not None and link.hash is not None: + key_parts[link.hash_name] = link.hash + if link.subdirectory_fragment: + key_parts["subdirectory"] = link.subdirectory_fragment + + # Include interpreter name, major and minor version in cache key + # to cope with ill-behaved sdists that build a different wheel + # depending on the python version their setup.py is being run on, + # and don't encode the difference in compatibility tags. + # https://github.com/pypa/pip/issues/7296 + key_parts["interpreter_name"] = interpreter_name() + key_parts["interpreter_version"] = interpreter_version() + + # Encode our key url with sha224, we'll use this because it has similar + # security properties to sha256, but with a shorter total output (and + # thus less secure). However the differences don't make a lot of + # difference for our use case here. + hashed = _hash_dict(key_parts) + + # We want to nest the directories some to prevent having a ton of top + # level directories where we might run out of sub directories on some + # FS. + parts = [hashed[:2], hashed[2:4], hashed[4:6], hashed[6:]] + + return parts + + def _get_candidates(self, link, canonical_package_name): + # type: (Link, Optional[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): + for candidate in os.listdir(path): + candidates.append((candidate, path)) + # TODO remove legacy path lookup in pip>=21 + legacy_path = self.get_path_for_link_legacy(link) + if os.path.isdir(legacy_path): + for candidate in os.listdir(legacy_path): + candidates.append((candidate, legacy_path)) + return candidates + + def get_path_for_link_legacy(self, link): + # type: (Link) -> str + raise NotImplementedError() + + def get_path_for_link(self, link): + # type: (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 + """Returns a link to a cached item if it exists, otherwise returns the + passed link. + """ + raise NotImplementedError() + + def cleanup(self): + # type: () -> None + pass + + +class SimpleWheelCache(Cache): + """A cache of wheels for future installs. + """ + + def __init__(self, cache_dir, format_control): + # type: (str, FormatControl) -> None + super(SimpleWheelCache, self).__init__( + cache_dir, format_control, {"binary"} + ) + + def get_path_for_link_legacy(self, link): + # type: (Link) -> str + parts = self._get_cache_path_parts_legacy(link) + return os.path.join(self.cache_dir, "wheels", *parts) + + def get_path_for_link(self, link): + # type: (Link) -> str + """Return a directory to store cached wheels for link + + Because there are M wheels for any one sdist, we provide a directory + to cache them in, and then consult that directory when looking up + cache hits. + + We only insert things into the cache if they have plausible version + numbers, so that we don't contaminate the cache with things that were + not unique. E.g. ./package might have dozens of installs done for it + and build a version of 0.0...and if we built and cached a wheel, we'd + end up using the same wheel even if the source has been edited. + + :param link: The link of the sdist for which this will cache wheels. + """ + parts = self._get_cache_path_parts(link) + + # Store wheels within the root cache_dir + return os.path.join(self.cache_dir, "wheels", *parts) + + def get( + self, + link, # type: Link + package_name, # type: Optional[str] + supported_tags, # type: List[Tag] + ): + # type: (...) -> 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 + ): + try: + wheel = Wheel(wheel_name) + except InvalidWheelFilename: + continue + if canonicalize_name(wheel.name) != canonical_package_name: + logger.debug( + "Ignoring cached wheel {} for {} as it " + "does not match the expected distribution name {}.".format( + wheel_name, link, package_name + ) + ) + continue + if not wheel.supported(supported_tags): + # Built for a different python/arch/etc + continue + candidates.append( + ( + wheel.support_index_min(supported_tags), + wheel_name, + wheel_dir, + ) + ) + + if not candidates: + return link + + _, wheel_name, wheel_dir = min(candidates) + return Link(path_to_url(os.path.join(wheel_dir, wheel_name))) + + +class EphemWheelCache(SimpleWheelCache): + """A SimpleWheelCache that creates it's own temporary cache directory + """ + + def __init__(self, format_control): + # type: (FormatControl) -> None + self._temp_dir = TempDirectory(kind="ephem-wheel-cache") + + super(EphemWheelCache, self).__init__( + self._temp_dir.path, format_control + ) + + def cleanup(self): + # type: () -> None + self._temp_dir.cleanup() + + +class WheelCache(Cache): + """Wraps EphemWheelCache and SimpleWheelCache into a single Cache + + This Cache allows for gracefully degradation, using the ephem wheel 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(WheelCache, self).__init__( + cache_dir, format_control, {'binary'} + ) + self._wheel_cache = SimpleWheelCache(cache_dir, format_control) + self._ephem_cache = EphemWheelCache(format_control) + + def get_path_for_link_legacy(self, link): + # type: (Link) -> str + return self._wheel_cache.get_path_for_link_legacy(link) + + def get_path_for_link(self, link): + # type: (Link) -> str + return self._wheel_cache.get_path_for_link(link) + + def get_ephem_path_for_link(self, link): + # type: (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 + retval = self._wheel_cache.get( + link=link, + package_name=package_name, + supported_tags=supported_tags, + ) + if retval is not link: + return retval + + return self._ephem_cache.get( + link=link, + package_name=package_name, + supported_tags=supported_tags, + ) + + def cleanup(self): + # type: () -> None + self._wheel_cache.cleanup() + self._ephem_cache.cleanup() diff --git a/venv/lib/python3.8/site-packages/pip/_internal/cli/__init__.py b/venv/lib/python3.8/site-packages/pip/_internal/cli/__init__.py new file mode 100644 index 0000000..e589bb9 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/cli/__init__.py @@ -0,0 +1,4 @@ +"""Subpackage containing all of pip's command line interface related code +""" + +# This file intentionally does not import submodules diff --git a/venv/lib/python3.8/site-packages/pip/_internal/cli/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/cli/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..dbdc1daa5d96942fdce96c8bff94cf747232b66e GIT binary patch literal 236 zcmYjMu?oU45KUba!GFji;!v}QI!JMIb15z^;Y_YIn5MB!kvjV`{*tSo;O6Aj$%FTf zcMsm<_M_2|(JU8ZxYK@h;(sC%8$vxG((J%=l(K2>woRL(2X%%Vxhh=%}9zzSuJkR(lza^~CTU|p2Dv6yrpyb0_Jt!zTP literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/cli/__pycache__/autocompletion.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/cli/__pycache__/autocompletion.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..8fcaf4102cd2e6c67031269d86223d6cdcf7dfdd GIT binary patch literal 4953 zcmb7IZEqXL5#HT99?26$Nt7Z>isM{f8@91jplK7hiW|QOi4jE>EIThmo#Tmjk|-W| z)ZR(5gd@;GX=@iP;G#u==9BcLX#PUcAJLD&er$mP`3wFK_nAFXFSY};6n1ZKc6N4W zcAl9z-5DOX8Gdj7vt<0YL{vyJufU zeCq-GjCI7PEXf_Po=B`Dk9Ed6>p@~Km$K{Z?nKW@t<-2)awoNVxbv;wZSABvU$lx3 zg?s~}d`rl`C56MHZys^ZKq<7W=$GrKCMrqa!W+p-3s_n1*~v(1AAtUlZ&gmtkc_4| zXfl)zZH{eL!1+$El$JKflZnmeS_an7<82b{+&R*5vNxQX*kc%!sWn0SKwb@P-Y@yX zUobjPW=XR1by)WS{|#T`ei^fc)FevJ{0#$TGa?~k{HrjGd&Z-Wmu80*{MKbhm9zrQ#O8U@DtY1XLRvZEz45{AK+dnzaqRo*84C&dd1{>42)h^$#n$H? zr?1g?UmGF+3a{zwL%x%Y_>+e(YD=8cmN4iPN1V=gaz7f+Q~N(#=p=H_S&o{W#952v zDXcotnnQ?mfI%nTUhMm^P}a(h1&~D%BG?F$<15W zSH9r@PoHp&D2gd_BM7?yxEXImyQ;X|>0|g2zjzzCwZo|4g>KXd_ZqZ%@T2gULt83WS;;9uO`2!ilpb9;U3oxQhqX>Jbj1)&0wVXhH2=gx+@+3udQ=R*V# z3UHS{pmUk%EGF3g>982g&TF0G%NPvU&*(-WhL(<#3_ZdJ4_fN%| z$TZYC=&ou=BoijdB8u-o;bK2pv4wC3x5Un)CtJC`UEdypieL} zIKd&i4+}rz3}4~G5b$LZ?>3W-{$Uhv$qSHy$$Vp5$^cGAMwiD&`4Df%N3qWyg)W+m zp)Z<(us%wOF4|`U15~-b-^>I;n?RXeFWJa8I=kC#+HG((dfhj)$-cOFQBGoT#u79` z_o271V4%0RY5UE-e`ULJHI!k&rAw{$55b$yI>G0Vb9{nF+<9upW7|LJ*#o$UPB-7xB`Yll@sE`owgvX@-Plk2gXqC8Jm>k`hgGQ&;wx`7%e zKn|#Z=84sCfA@76ZFgh&J?t&%PSx<5jM{GVIQ4HL=v60_)!2=sAEO+hr~EOo4xPk1 zm@X3-tC16`+wt0{9%zMn4oBV&eeDG&^@u7SmnKSt4P{b&0<0VdQe{A{7Vg68YUD}f za-?#stZa8x#M2GE)gV+RhOsKIglvgRv+zaUDWjPfaChF3&I2rdxz ztjA`~;x=X=M>w>~9Od9gBMFm+#l>S2Qs`+J=eZCCUZ7Z`w!*fqZoN$VR*T*uGR*ryf@(N$$R8^EgLAg+4dLB3szIziRex%3jy;kBL29WOaCJk0T8Exixk zHUg;^Iy;_hQuPXnCz-Zhe@e*zBSR!qm}I` zgJfHFE5I0V*cs>$q)65r63spVN_92kWPTCAmvXje<9dfO3`_TGq$7qAh$U zQ3-%t^ctp>N%mI;Y`>I6N*y?L%sdX9syM$6B;D)E%fBSK6a!5m9`FC)yJF9&ls;Hl zE$CROqn&&k668CyzX5b-Q8(WX5|~md!|Uu-bMgxDT&3<7b&JH!qbJkHJjh#UF`b(g zXEYc~0B(iP0Fd^#1*3v;8gmT_bAum!xe$zAL5u%^j=oC{MT#_zq%Iz0??wtBp=M-< z01P;CM}9w}5IDt9w?qvQHC4!wz|> z-CKtIQqzm6g<|5%G_UXLV@W7amY=j2X!e-oiPYi_;a8?snpU_z$0Azh#ZQt41jmOr$33|R`|d;G<2(-z$dPNtpaI-E zvo6t8abT%ERq8v6EqiaO%|eSd=^SQIXP}}+2{OvHf4Af@^GEt1sUkQZ=l@ujmqWCDdg>(M}3qSN8 literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/cli/__pycache__/base_command.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/cli/__pycache__/base_command.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..ca77a4a7ef69886a50a8c81efe37eb0ed3550cb5 GIT binary patch literal 5847 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 literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/cli/__pycache__/cmdoptions.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/cli/__pycache__/cmdoptions.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..e8882ec9aab95baf08b068414128f820b62976d0 GIT binary patch literal 20328 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 literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/cli/__pycache__/main_parser.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/cli/__pycache__/main_parser.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..8803ae91e51d0083fd35814461df84f4fe1b1de5 GIT binary patch literal 2159 zcmZWrTW{P%6!wh0w%6I+TpH4g09l2!T8Sj6LM;*@qDos@Q9?!AhZ-u&^-NqR<4b2| znnO!)MgY=xkI)xj#g%^27?=ZjUM%^Na z0;9WZrszdIGxk`&7(|0&HkviM&*qBxXdYQ~o;R>omn{@$qBF%}vbNO~fQmrCQ9Wj747LEaCC-6ztU7Y~5~hUg@w|?N{e@{G4(D`zzlV zc$I}lYG}gz8+heJ|c^>bY z>O&qk2L>+mP3S^`(Djtop+#(oKsvv6#+Jm}R%88y#;8FP`^Z9;bPlZs#U1HRJn8QE z4LZVO471$^A0enx2WA7}W{7yie`(2?N$<$IVI88g*4QT9Nx!j=V6}MAAgEh#aCOtX zwlMYKRE~HlPM60N6H;?ogqwHo1R=D83&C;?xe3>&DcuOao7U~|E#+pcdXlhVM|DOb z$*7u52#KFUq2ks_bpao3#gtPf1td|g_CQ%Ff?OOo8wMTd_o0jTL1d7Q$4lSiF&bk6 ziD>YSwT+jopYbyXj)M;T<&`VfM7S)VXr34W5cvMkR(SPeeg@)IZ~D4%UT#;vTl_p2 z|GvH^i+T+XxH2m1B;BQCW$!7aY$YFM&pzG%WKYknK?ne>OxRk=^0gCXUaj|4u+9Jk zuz0<3MZc^mFLwVsxb!wGR@YgTCQNL=;5bO3U^vTl6z^)GPp;0BTqI8zZFd$m0F#n9 z;hEsRp7*9u<@%CP^F^{tr}>RDUX5zi&uB?`!lvq+u0mUYsm0O9;5x;slS^6% zsb&ZjDbEe>hK}mCc#e1Xlsknsu%py#3BC-`CXcPSpw&KzbI`>_5SEJ(Mvm_PxPE|q z?Arqr*sdL5_g~-X;Wvt|kERo0nDHkJG%E}PP-7h-C_WzBPh77 z@H7*oJ@GYT8kEXfRsN5~9y%KIqb8Uqem&L_{#Uj~%Lc{%P6c#ioWoxy=m2fz3va5pj zZZT-k)KIqA7s?fqR3oW6dmQSia3z$-@{$T#D~GPhzgR|`X*^tZ+{s%caRV@Gj literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/cli/__pycache__/parser.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/cli/__pycache__/parser.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..d8b08e2b3a95cf8f9e21bd06f817d1ac88553e3f GIT binary patch literal 8977 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 G_WlR_fE*bB literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/cli/__pycache__/req_command.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/cli/__pycache__/req_command.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..4fe7f8e4f32a30f9db3cd40a096264cab1b36396 GIT binary patch literal 8289 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 literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/cli/autocompletion.py b/venv/lib/python3.8/site-packages/pip/_internal/cli/autocompletion.py new file mode 100644 index 0000000..329de60 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/cli/autocompletion.py @@ -0,0 +1,164 @@ +"""Logic that powers autocompletion installed by ``pip completion``. +""" + +import optparse +import os +import sys +from itertools import chain + +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.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import Any, Iterable, List, Optional + + +def autocomplete(): + # type: () -> 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: + return + cwords = os.environ['COMP_WORDS'].split()[1:] + cword = int(os.environ['COMP_CWORD']) + try: + current = cwords[cword - 1] + except IndexError: + current = '' + + parser = create_main_parser() + subcommands = list(commands_dict) + options = [] + + # subcommand + subcommand_name = None # type: Optional[str] + for word in cwords: + if word in subcommands: + subcommand_name = word + break + # subcommand options + if subcommand_name is not None: + # special case: 'help' subcommand has no options + if subcommand_name == 'help': + sys.exit(1) + # special case: list locally installed dists for show and uninstall + should_list_installed = ( + subcommand_name in ['show', 'uninstall'] and + not current.startswith('-') + ) + if should_list_installed: + installed = [] + lc = current.lower() + for dist in get_installed_distributions(local_only=True): + if dist.key.startswith(lc) and dist.key not in cwords[1:]: + installed.append(dist.key) + # if there are no dists installed, fall back to option completion + if installed: + for dist in installed: + print(dist) + sys.exit(1) + + subcommand = create_command(subcommand_name) + + for opt in subcommand.parser.option_list_all: + if opt.help != optparse.SUPPRESS_HELP: + for opt_str in opt._long_opts + opt._short_opts: + options.append((opt_str, opt.nargs)) + + # filter out previously specified options from available options + prev_opts = [x.split('=')[0] for x in cwords[1:cword - 1]] + options = [(x, v) for (x, v) in options if x not in prev_opts] + # filter options by current input + options = [(k, v) for k, v in options if k.startswith(current)] + # get completion type given cwords and available subcommand options + completion_type = get_path_completion_type( + cwords, cword, subcommand.parser.option_list_all, + ) + # get completion files and directories if ``completion_type`` is + # ````, ``

`` or ```` + if completion_type: + paths = auto_complete_paths(current, completion_type) + options = [(path, 0) for path in paths] + for option in options: + opt_label = option[0] + # append '=' to options which require args + if option[1] and option[0][:2] == "--": + opt_label += '=' + print(opt_label) + else: + # show main parser options only when necessary + + opts = [i.option_list for i in parser.option_groups] + opts.append(parser.option_list) + flattened_opts = chain.from_iterable(opts) + if current.startswith('-'): + for opt in flattened_opts: + if opt.help != optparse.SUPPRESS_HELP: + subcommands += opt._long_opts + opt._short_opts + else: + # get completion type given cwords and all available options + completion_type = get_path_completion_type(cwords, cword, + flattened_opts) + if completion_type: + subcommands = list(auto_complete_paths(current, + completion_type)) + + print(' '.join([x for x in subcommands if x.startswith(current)])) + sys.exit(1) + + +def get_path_completion_type(cwords, cword, opts): + # type: (List[str], int, Iterable[Any]) -> Optional[str] + """Get the type of path completion (``file``, ``dir``, ``path`` or None) + + :param cwords: same as the environmental variable ``COMP_WORDS`` + :param cword: same as the environmental variable ``COMP_CWORD`` + :param opts: The available options to check + :return: path completion type (``file``, ``dir``, ``path`` or None) + """ + if cword < 2 or not cwords[cword - 2].startswith('-'): + return None + for opt in opts: + if opt.help == optparse.SUPPRESS_HELP: + continue + for o in str(opt).split('/'): + if cwords[cword - 2].split('=')[0] == o: + if not opt.metavar or any( + x in ('path', 'file', 'dir') + for x in opt.metavar.split('/')): + return opt.metavar + return None + + +def auto_complete_paths(current, completion_type): + # type: (str, 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 + :return: A generator of regular files and/or directories + """ + directory, filename = os.path.split(current) + current_path = os.path.abspath(directory) + # Don't complete paths if they can't be accessed + if not os.access(current_path, os.R_OK): + return + filename = os.path.normcase(filename) + # list all files that start with ``filename`` + file_list = (x for x in os.listdir(current_path) + if os.path.normcase(x).startswith(filename)) + for f in file_list: + opt = os.path.join(current_path, f) + comp_file = os.path.normcase(os.path.join(directory, f)) + # complete regular files when there is not ```` after option + # complete directories when there is ````, ```` or + # ````after option + if completion_type != 'dir' and os.path.isfile(opt): + yield comp_file + elif os.path.isdir(opt): + yield os.path.join(comp_file, '') diff --git a/venv/lib/python3.8/site-packages/pip/_internal/cli/base_command.py b/venv/lib/python3.8/site-packages/pip/_internal/cli/base_command.py new file mode 100644 index 0000000..628faa3 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/cli/base_command.py @@ -0,0 +1,226 @@ +"""Base Command class, and related routines""" + +from __future__ import absolute_import, print_function + +import logging +import logging.config +import optparse +import os +import platform +import sys +import traceback + +from pip._internal.cli import cmdoptions +from pip._internal.cli.command_context import CommandContextMixIn +from pip._internal.cli.parser import ( + ConfigOptionParser, + UpdatingDefaultsHelpFormatter, +) +from pip._internal.cli.status_codes import ( + ERROR, + PREVIOUS_BUILD_DIR_ERROR, + SUCCESS, + UNKNOWN_ERROR, + VIRTUALENV_NOT_FOUND, +) +from pip._internal.exceptions import ( + BadCommand, + CommandError, + InstallationError, + 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 +from pip._internal.utils.temp_dir import global_tempdir_manager +from pip._internal.utils.typing import MYPY_CHECK_RUNNING +from pip._internal.utils.virtualenv import running_under_virtualenv + +if MYPY_CHECK_RUNNING: + from typing import List, Tuple, Any + from optparse import Values + +__all__ = ['Command'] + +logger = logging.getLogger(__name__) + + +class Command(CommandContextMixIn): + usage = None # type: str + ignore_require_venv = False # type: bool + + def __init__(self, name, summary, isolated=False): + # type: (str, str, bool) -> None + super(Command, self).__init__() + parser_kw = { + 'usage': self.usage, + 'prog': '%s %s' % (get_prog(), name), + 'formatter': UpdatingDefaultsHelpFormatter(), + 'add_help_option': False, + 'name': name, + 'description': self.__doc__, + 'isolated': isolated, + } + + self.name = name + self.summary = summary + self.parser = ConfigOptionParser(**parser_kw) + + # Commands should add options to this option group + optgroup_name = '%s Options' % self.name.capitalize() + self.cmd_opts = optparse.OptionGroup(self.parser, optgroup_name) + + # Add the general options + gen_opts = cmdoptions.make_option_group( + cmdoptions.general_group, + self.parser, + ) + self.parser.add_option_group(gen_opts) + + def handle_pip_version_check(self, options): + # type: (Values) -> None + """ + This is a no-op so that commands by default do not do the pip version + check. + """ + # Make sure we do the pip version check if the index_group options + # are present. + assert not hasattr(options, 'no_index') + + def run(self, options, args): + # type: (Values, List[Any]) -> Any + raise NotImplementedError + + def parse_args(self, args): + # type: (List[str]) -> Tuple[Any, Any] + # factored out for testability + return self.parser.parse_args(args) + + def main(self, args): + # type: (List[str]) -> int + try: + with self.main_context(): + return self._main(args) + finally: + logging.shutdown() + + def _main(self, args): + # type: (List[str]) -> int + # Intentionally set as early as possible so globally-managed temporary + # directories are available to the rest of the code. + self.enter_context(global_tempdir_manager()) + + options, args = self.parse_args(args) + + # Set verbosity so that it can be used elsewhere. + self.verbosity = options.verbose - options.quiet + + level_number = setup_logging( + verbosity=self.verbosity, + no_color=options.no_color, + user_log_file=options.log, + ) + + if ( + sys.version_info[:2] == (2, 7) and + not options.no_python_version_warning + ): + message = ( + "A future version of pip will drop support for Python 2.7. " + "More details about Python 2 support in pip, can be found at " + "https://pip.pypa.io/en/latest/development/release-process/#python-2-support" # noqa + ) + if platform.python_implementation() == "CPython": + message = ( + "Python 2.7 reached the end of its life on January " + "1st, 2020. Please upgrade your Python as Python 2.7 " + "is no longer maintained. " + ) + message + deprecated(message, replacement=None, gone_in=None) + + if options.skip_requirements_regex: + deprecated( + "--skip-requirements-regex is unsupported and will be removed", + replacement=( + "manage requirements/constraints files explicitly, " + "possibly generating them from metadata" + ), + gone_in="20.1", + issue=7297, + ) + + # 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. + + if options.no_input: + os.environ['PIP_NO_INPUT'] = '1' + + if options.exists_action: + os.environ['PIP_EXISTS_ACTION'] = ' '.join(options.exists_action) + + if options.require_venv and not self.ignore_require_venv: + # If a venv is required check if it can really be found + if not running_under_virtualenv(): + logger.critical( + 'Could not find an activated virtualenv (required).' + ) + sys.exit(VIRTUALENV_NOT_FOUND) + + if options.cache_dir: + options.cache_dir = normalize_path(options.cache_dir) + if not check_path_owner(options.cache_dir): + logger.warning( + "The directory '%s' or its parent directory is not owned " + "or is not writable by the current user. The cache " + "has been disabled. Check the permissions and owner of " + "that directory. If executing pip with sudo, you may want " + "sudo's -H flag.", + options.cache_dir, + ) + options.cache_dir = None + + try: + status = self.run(options, args) + # FIXME: all commands should return an exit status + # and when it is done, isinstance is not needed anymore + if 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) 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 + finally: + self.handle_pip_version_check(options) + + return SUCCESS diff --git a/venv/lib/python3.8/site-packages/pip/_internal/cli/cmdoptions.py b/venv/lib/python3.8/site-packages/pip/_internal/cli/cmdoptions.py new file mode 100644 index 0000000..447f319 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/cli/cmdoptions.py @@ -0,0 +1,957 @@ +""" +shared options and groups + +The principle here is to define options once, but *not* instantiate them +globally. One reason being that options with action='append' can carry state +between parses. pip parses general options twice internally, and shouldn't +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 + +from __future__ import absolute_import + +import logging +import os +import textwrap +import warnings +from distutils.util import strtobool +from functools import partial +from optparse import SUPPRESS_HELP, Option, OptionGroup +from textwrap import dedent + +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 +from pip._internal.models.index import PyPI +from pip._internal.models.target_python import TargetPython +from pip._internal.utils.hashes import STRONG_HASHES +from pip._internal.utils.typing import MYPY_CHECK_RUNNING +from pip._internal.utils.ui import BAR_TYPES + +if MYPY_CHECK_RUNNING: + from typing import Any, Callable, Dict, Optional, Tuple + from optparse import OptionParser, Values + from pip._internal.cli.parser import ConfigOptionParser + +logger = logging.getLogger(__name__) + + +def raise_option_error(parser, option, msg): + # type: (OptionParser, Option, str) -> None + """ + Raise an option parsing error using parser.error(). + + Args: + parser: an OptionParser instance. + option: an Option instance. + msg: the error text. + """ + msg = '{} error: {}'.format(option, msg) + msg = textwrap.fill(' '.join(msg.split())) + parser.error(msg) + + +def make_option_group(group, parser): + # type: (Dict[str, Any], ConfigOptionParser) -> OptionGroup + """ + Return an OptionGroup object + group -- assumed to be dict with 'name' and 'options' keys + parser -- an optparse Parser + """ + option_group = OptionGroup(parser, group['name']) + for option in group['options']: + option_group.add_option(option()) + 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 + """Function for determining if custom platform options are allowed. + + :param options: The OptionParser options. + :param check_target: Whether or not to check if --target is being used. + """ + dist_restriction_set = any([ + options.python_version, + options.platform, + options.abi, + options.implementation, + ]) + + binary_only = FormatControl(set(), {':all:'}) + sdist_dependencies_allowed = ( + options.format_control != binary_only and + not options.ignore_dependencies + ) + + # Installations or downloads using dist restrictions must not combine + # source distributions and dist-specific wheels, as they are not + # guaranteed to be locally compatible. + if dist_restriction_set and sdist_dependencies_allowed: + raise CommandError( + "When restricting platform and interpreter constraints using " + "--python-version, --platform, --abi, or --implementation, " + "either --no-deps must be set, or --only-binary=:all: must be " + "set and --no-binary must not be set (or must be set to " + ":none:)." + ) + + if check_target: + if dist_restriction_set and not options.target_dir: + raise CommandError( + "Can not use any platform or abi specific options unless " + "installing via '--target'" + ) + + +def _path_option_check(option, opt, value): + # type: (Option, str, str) -> str + return os.path.expanduser(value) + + +class PipOption(Option): + TYPES = Option.TYPES + ("path",) + TYPE_CHECKER = Option.TYPE_CHECKER.copy() + TYPE_CHECKER["path"] = _path_option_check + + +########### +# options # +########### + +help_ = partial( + Option, + '-h', '--help', + dest='help', + action='help', + help='Show help.', +) # type: Callable[..., Option] + +isolated_mode = partial( + Option, + "--isolated", + dest="isolated_mode", + action="store_true", + default=False, + help=( + "Run pip in an isolated mode, ignoring environment variables and user " + "configuration." + ), +) # type: Callable[..., Option] + +require_virtualenv = 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] + +verbose = partial( + Option, + '-v', '--verbose', + dest='verbose', + 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( + Option, + '--no-color', + dest='no_color', + action='store_true', + default=False, + help="Suppress colored output", +) # type: Callable[..., Option] + +version = partial( + Option, + '-V', '--version', + dest='version', + action='store_true', + help='Show version and exit.', +) # type: Callable[..., Option] + +quiet = partial( + Option, + '-q', '--quiet', + dest='quiet', + action='count', + default=0, + help=( + 'Give less output. Option is additive, and can be used up to 3' + ' times (corresponding to WARNING, ERROR, and CRITICAL logging' + ' levels).' + ), +) # type: Callable[..., Option] + +progress_bar = partial( + Option, + '--progress-bar', + dest='progress_bar', + type='choice', + choices=list(BAR_TYPES.keys()), + default='on', + help=( + 'Specify type of progress to be displayed [' + + '|'.join(BAR_TYPES.keys()) + '] (default: %default)' + ), +) # type: Callable[..., Option] + +log = partial( + PipOption, + "--log", "--log-file", "--local-log", + dest="log", + metavar="path", + type="path", + help="Path to a verbose appending log." +) # type: Callable[..., Option] + +no_input = partial( + Option, + # Don't ask for input + '--no-input', + dest='no_input', + action='store_true', + default=False, + help=SUPPRESS_HELP +) # type: Callable[..., Option] + +proxy = partial( + Option, + '--proxy', + dest='proxy', + type='str', + default='', + help="Specify a proxy in the form [user:passwd@]proxy.server:port." +) # type: Callable[..., Option] + +retries = partial( + Option, + '--retries', + dest='retries', + type='int', + default=5, + help="Maximum number of retries each connection should attempt " + "(default %default times).", +) # type: Callable[..., Option] + +timeout = partial( + Option, + '--timeout', '--default-timeout', + metavar='sec', + dest='timeout', + type='float', + default=15, + help='Set the socket timeout (default %default seconds).', +) # type: Callable[..., Option] + +skip_requirements_regex = partial( + Option, + # A regex to be used to skip requirements + '--skip-requirements-regex', + dest='skip_requirements_regex', + type='str', + default='', + help=SUPPRESS_HELP, +) # type: Callable[..., Option] + + +def exists_action(): + # type: () -> Option + return Option( + # Option when path already exist + '--exists-action', + dest='exists_action', + type='choice', + choices=['s', 'i', 'w', 'b', 'a'], + default=[], + action='append', + metavar='action', + help="Default action when a path already exists: " + "(s)witch, (i)gnore, (w)ipe, (b)ackup, (a)bort.", + ) + + +cert = partial( + PipOption, + '--cert', + dest='cert', + type='path', + metavar='path', + help="Path to alternate CA bundle.", +) # type: Callable[..., Option] + +client_cert = partial( + PipOption, + '--client-cert', + dest='client_cert', + type='path', + default=None, + 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( + Option, + '-i', '--index-url', '--pypi-url', + dest='index_url', + metavar='URL', + default=PyPI.simple_url, + help="Base URL of the Python Package Index (default %default). " + "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 + return Option( + '--extra-index-url', + dest='extra_index_urls', + metavar='URL', + action='append', + default=[], + help="Extra URLs of package indexes to use in addition to " + "--index-url. Should follow the same rules as " + "--index-url.", + ) + + +no_index = 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 + return Option( + '-f', '--find-links', + dest='find_links', + action='append', + default=[], + metavar='url', + help="If a url or path to an html file, then parse for links to " + "archives. If a local path or file:// url that's a directory, " + "then look for archives in the directory listing.", + ) + + +def trusted_host(): + # type: () -> Option + return Option( + "--trusted-host", + dest="trusted_hosts", + action="append", + metavar="HOSTNAME", + default=[], + help="Mark this host or host:port pair as trusted, even though it " + "does not have valid or any HTTPS.", + ) + + +def constraints(): + # type: () -> Option + return Option( + '-c', '--constraint', + dest='constraints', + action='append', + default=[], + metavar='file', + help='Constrain versions using the given constraints file. ' + 'This option can be used multiple times.' + ) + + +def requirements(): + # type: () -> Option + return Option( + '-r', '--requirement', + dest='requirements', + action='append', + default=[], + metavar='file', + help='Install from the given requirements file. ' + 'This option can be used multiple times.' + ) + + +def editable(): + # type: () -> Option + return Option( + '-e', '--editable', + dest='editables', + action='append', + default=[], + metavar='path/url', + help=('Install a project in editable mode (i.e. setuptools ' + '"develop mode") from a local project path or a VCS url.'), + ) + + +def _handle_src(option, opt_str, value, parser): + # type: (Option, str, str, OptionParser) -> None + value = os.path.abspath(value) + setattr(parser.values, option.dest, value) + + +src = partial( + PipOption, + '--src', '--source', '--source-dir', '--source-directory', + dest='src_dir', + type='path', + metavar='dir', + default=get_src_prefix(), + action='callback', + callback=_handle_src, + help='Directory to check out editable projects into. ' + 'The default in a virtualenv is "/src". ' + 'The default for global installs is "/src".' +) # type: Callable[..., Option] + + +def _get_format_control(values, option): + # type: (Values, 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 + existing = _get_format_control(parser.values, option) + FormatControl.handle_mutual_excludes( + value, existing.no_binary, existing.only_binary, + ) + + +def _handle_only_binary(option, opt_str, value, parser): + # type: (Option, str, str, OptionParser) -> None + existing = _get_format_control(parser.values, option) + FormatControl.handle_mutual_excludes( + value, existing.only_binary, existing.no_binary, + ) + + +def no_binary(): + # type: () -> Option + format_control = FormatControl(set(), set()) + return Option( + "--no-binary", dest="format_control", action="callback", + callback=_handle_no_binary, type="str", + default=format_control, + help="Do not use binary packages. Can be supplied multiple times, and " + "each time adds to the existing value. Accepts either :all: to " + "disable all binary packages, :none: to empty the set, or one or " + "more package names with commas between them (no colons). Note " + "that some packages are tricky to compile and may fail to " + "install when this option is used on them.", + ) + + +def only_binary(): + # type: () -> Option + format_control = FormatControl(set(), set()) + return Option( + "--only-binary", dest="format_control", action="callback", + callback=_handle_only_binary, type="str", + default=format_control, + help="Do not use source packages. Can be supplied multiple times, and " + "each time adds to the existing value. Accepts either :all: to " + "disable all source packages, :none: to empty the set, or one or " + "more package names with commas between them. Packages without " + "binary distributions will fail to install when this option is " + "used on them.", + ) + + +platform = partial( + Option, + '--platform', + dest='platform', + metavar='platform', + default=None, + help=("Only use wheels compatible with . " + "Defaults to the platform of the running system."), +) # 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]] + """ + Convert a version string like "3", "37", or "3.7.3" into a tuple of ints. + + :return: A 2-tuple (version_info, error_msg), where `error_msg` is + non-None if and only if there was a parsing error. + """ + if not value: + # The empty string is the same as not providing a value. + return (None, None) + + parts = value.split('.') + if len(parts) > 3: + return ((), 'at most three version parts are allowed') + + if len(parts) == 1: + # Then we are in the case of "3" or "37". + value = parts[0] + if len(value) > 1: + parts = [value[0], value[1:]] + + try: + version_info = tuple(int(part) for part in parts) + except ValueError: + return ((), 'each version part must be an integer') + + return (version_info, None) + + +def _handle_python_version(option, opt_str, value, parser): + # type: (Option, str, str, OptionParser) -> None + """ + Handle a provided --python-version value. + """ + version_info, error_msg = _convert_python_version(value) + if error_msg is not None: + msg = ( + 'invalid --python-version value: {!r}: {}'.format( + value, error_msg, + ) + ) + raise_option_error(parser, option=option, msg=msg) + + parser.values.python_version = version_info + + +python_version = partial( + Option, + '--python-version', + dest='python_version', + metavar='python_version', + action='callback', + callback=_handle_python_version, type='str', + default=None, + help=dedent("""\ + The Python interpreter version to use for wheel and "Requires-Python" + compatibility checks. Defaults to a version derived from the running + interpreter. The version can be specified using up to three dot-separated + integers (e.g. "3" for 3.0.0, "3.7" for 3.7.0, or "3.7.3"). A major-minor + version can also be given as a string without dots (e.g. "37" for 3.7.0). + """), +) # type: Callable[..., Option] + + +implementation = partial( + Option, + '--implementation', + dest='implementation', + metavar='implementation', + default=None, + help=("Only use wheels compatible with Python " + "implementation , e.g. 'pp', 'jy', 'cp', " + " or 'ip'. If not specified, then the current " + "interpreter implementation is used. Use 'py' to force " + "implementation-agnostic wheels."), +) # type: Callable[..., Option] + + +abi = partial( + Option, + '--abi', + dest='abi', + metavar='abi', + default=None, + help=("Only use wheels compatible with Python " + "abi , e.g. 'pypy_41'. If not specified, then the " + "current interpreter abi tag is used. Generally " + "you will need to specify --implementation, " + "--platform, and --python-version when using " + "this option."), +) # type: Callable[..., Option] + + +def add_target_python_options(cmd_opts): + # type: (OptionGroup) -> None + cmd_opts.add_option(platform()) + cmd_opts.add_option(python_version()) + cmd_opts.add_option(implementation()) + cmd_opts.add_option(abi()) + + +def make_target_python(options): + # type: (Values) -> TargetPython + target_python = TargetPython( + platform=options.platform, + py_version_info=options.python_version, + abi=options.abi, + implementation=options.implementation, + ) + + return target_python + + +def prefer_binary(): + # type: () -> Option + return Option( + "--prefer-binary", + dest="prefer_binary", + action="store_true", + default=False, + help="Prefer older binary packages over newer source packages." + ) + + +cache_dir = partial( + PipOption, + "--cache-dir", + dest="cache_dir", + default=USER_CACHE_DIR, + metavar="dir", + type='path', + help="Store the cache data in ." +) # type: Callable[..., Option] + + +def _handle_no_cache_dir(option, opt, value, parser): + # type: (Option, str, str, OptionParser) -> None + """ + Process a value provided for the --no-cache-dir option. + + This is an optparse.Option callback for the --no-cache-dir option. + """ + # The value argument will be None if --no-cache-dir is passed via the + # command-line, since the option doesn't accept arguments. However, + # the value can be non-None if the option is triggered e.g. by an + # environment variable, like PIP_NO_CACHE_DIR=true. + if value is not None: + # Then parse the string value to get argument error-checking. + try: + strtobool(value) + except ValueError as exc: + raise_option_error(parser, option=option, msg=str(exc)) + + # Originally, setting PIP_NO_CACHE_DIR to a value that strtobool() + # converted to 0 (like "false" or "no") caused cache_dir to be disabled + # rather than enabled (logic would say the latter). Thus, we disable + # the cache directory not just on values that parse to True, but (for + # backwards compatibility reasons) also on values that parse to False. + # In other words, always set it to False if the option is provided in + # some (valid) form. + parser.values.cache_dir = False + + +no_cache = 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( + Option, + '--no-deps', '--no-dependencies', + dest='ignore_dependencies', + action='store_true', + default=False, + help="Don't install package dependencies.", +) # type: Callable[..., Option] + + +def _handle_build_dir(option, opt, value, parser): + # type: (Option, str, str, OptionParser) -> None + if value: + value = os.path.abspath(value) + setattr(parser.values, option.dest, value) + + +build_dir = partial( + PipOption, + '-b', '--build', '--build-dir', '--build-directory', + dest='build_dir', + type='path', + metavar='dir', + action='callback', + callback=_handle_build_dir, + help='Directory to unpack packages into and build in. Note that ' + 'an initial build still takes place in a temporary directory. ' + 'The location of temporary directories can be controlled by setting ' + 'the TMPDIR environment variable (TEMP on Windows) appropriately. ' + 'When passed, build directories are not cleaned in case of failures.' +) # type: Callable[..., Option] + +ignore_requires_python = 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( + Option, + '--no-build-isolation', + dest='build_isolation', + action='store_false', + default=True, + 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] + + +def _handle_no_use_pep517(option, opt, value, parser): + # type: (Option, str, str, OptionParser) -> None + """ + Process a value provided for the --no-use-pep517 option. + + This is an optparse.Option callback for the no_use_pep517 option. + """ + # Since --no-use-pep517 doesn't accept arguments, the value argument + # will be None if --no-use-pep517 is passed via the command-line. + # However, the value can be non-None if the option is triggered e.g. + # by an environment variable, for example "PIP_NO_USE_PEP517=true". + if value is not None: + msg = """A value was passed for --no-use-pep517, + probably using either the PIP_NO_USE_PEP517 environment variable + or the "no-use-pep517" config file option. Use an appropriate value + of the PIP_USE_PEP517 environment variable or the "use-pep517" + config file option instead. + """ + 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( + Option, + '--use-pep517', + dest='use_pep517', + action='store_true', + default=None, + help='Use PEP 517 for building source distributions ' + '(use --no-use-pep517 to force legacy behaviour).' +) # type: Any + +no_use_pep517 = partial( + Option, + '--no-use-pep517', + dest='use_pep517', + action='callback', + callback=_handle_no_use_pep517, + default=None, + help=SUPPRESS_HELP +) # type: Any + +install_options = 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] + +global_options = partial( + Option, + '--global-option', + dest='global_options', + action='append', + metavar='options', + help="Extra global options to be supplied to the setup.py " + "call before the install command.", +) # type: Callable[..., Option] + +no_clean = partial( + Option, + '--no-clean', + action='store_true', + default=False, + help="Don't clean up build directories." +) # type: Callable[..., Option] + +pre = 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( + Option, + "--disable-pip-version-check", + dest="disable_pip_version_check", + action="store_true", + default=True, + 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] + + +# Deprecated, Remove later +always_unzip = partial( + Option, + '-Z', '--always-unzip', + dest='always_unzip', + action='store_true', + help=SUPPRESS_HELP, +) # type: Callable[..., Option] + + +def _handle_merge_hash(option, opt_str, value, parser): + # type: (Option, str, str, 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: + parser.values.hashes = {} + try: + algo, digest = value.split(':', 1) + except ValueError: + parser.error('Arguments to %s must be a hash name ' + 'followed by a value, like --hash=sha256:abcde...' % + opt_str) + if algo not in STRONG_HASHES: + parser.error('Allowed hash algorithms for %s are %s.' % + (opt_str, ', '.join(STRONG_HASHES))) + parser.values.hashes.setdefault(algo, []).append(digest) + + +hash = partial( + Option, + '--hash', + # Hash values eventually end up in InstallRequirement.hashes due to + # __dict__ copying in process_line(). + dest='hashes', + action='callback', + callback=_handle_merge_hash, + type='string', + help="Verify that the package's archive matches this " + 'hash before installing. Example: --hash=sha256:abcdef...', +) # type: Callable[..., Option] + + +require_hashes = partial( + Option, + '--require-hashes', + dest='require_hashes', + action='store_true', + default=False, + 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( + PipOption, + '--path', + dest='path', + type='path', + 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 + if options.path and (options.user or options.local): + raise CommandError( + "Cannot combine '--path' with '--user' or '--local'" + ) + + +no_python_version_warning = 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] + + +########## +# groups # +########## + +general_group = { + 'name': 'General Options', + 'options': [ + help_, + isolated_mode, + require_virtualenv, + verbose, + version, + quiet, + log, + no_input, + proxy, + retries, + timeout, + skip_requirements_regex, + exists_action, + trusted_host, + cert, + client_cert, + cache_dir, + no_cache, + disable_pip_version_check, + no_color, + no_python_version_warning, + ] +} # type: Dict[str, Any] + +index_group = { + 'name': 'Package Index Options', + 'options': [ + index_url, + extra_index_url, + no_index, + find_links, + ] +} # type: Dict[str, Any] diff --git a/venv/lib/python3.8/site-packages/pip/_internal/cli/command_context.py b/venv/lib/python3.8/site-packages/pip/_internal/cli/command_context.py new file mode 100644 index 0000000..d1a64a7 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/cli/command_context.py @@ -0,0 +1,36 @@ +from contextlib import contextmanager + +from pip._vendor.contextlib2 import ExitStack + +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import Iterator, ContextManager, TypeVar + + _T = TypeVar('_T', covariant=True) + + +class CommandContextMixIn(object): + def __init__(self): + # type: () -> None + super(CommandContextMixIn, self).__init__() + self._in_main_context = False + self._main_context = ExitStack() + + @contextmanager + def main_context(self): + # type: () -> Iterator[None] + assert not self._in_main_context + + self._in_main_context = True + try: + with self._main_context: + yield + finally: + self._in_main_context = False + + def enter_context(self, context_provider): + # type: (ContextManager[_T]) -> _T + assert self._in_main_context + + return self._main_context.enter_context(context_provider) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/cli/main.py b/venv/lib/python3.8/site-packages/pip/_internal/cli/main.py new file mode 100644 index 0000000..5e97a51 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/cli/main.py @@ -0,0 +1,75 @@ +"""Primary application entrypoint. +""" +from __future__ import absolute_import + +import locale +import logging +import os +import sys + +from pip._internal.cli.autocompletion import autocomplete +from pip._internal.cli.main_parser import parse_command +from pip._internal.commands import create_command +from pip._internal.exceptions import PipError +from pip._internal.utils import deprecation +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import List, Optional + +logger = logging.getLogger(__name__) + + +# Do not import and use main() directly! Using it directly is actively +# discouraged by pip's maintainers. The name, location and behavior of +# this function is subject to change, so calling it directly is not +# portable across different pip versions. + +# In addition, running pip in-process is unsupported and unsafe. This is +# elaborated in detail at +# https://pip.pypa.io/en/stable/user_guide/#using-pip-from-your-program. +# That document also provides suggestions that should work for nearly +# all users that are considering importing and using main() directly. + +# However, we know that certain users will still want to invoke pip +# in-process. If you understand and accept the implications of using pip +# in an unsupported manner, the best approach is to use runpy to avoid +# depending on the exact location of this entry point. + +# The following example shows how to use runpy to invoke pip in that +# case: +# +# sys.argv = ["pip", your, args, here] +# runpy.run_module("pip", run_name="__main__") +# +# Note that this will exit the process after running, unlike a direct +# call to main. As it is not safe to do any processing after calling +# main, this should not be an issue in practice. + +def main(args=None): + # type: (Optional[List[str]]) -> int + if args is None: + args = sys.argv[1:] + + # Configure our deprecation warnings to be sent through loggers + deprecation.install_warning_logger() + + autocomplete() + + try: + cmd_name, cmd_args = parse_command(args) + except PipError as exc: + sys.stderr.write("ERROR: %s" % exc) + sys.stderr.write(os.linesep) + sys.exit(1) + + # Needed for locale.getpreferredencoding(False) to work + # in pip._internal.utils.encoding.auto_decode + try: + locale.setlocale(locale.LC_ALL, '') + except locale.Error as e: + # setlocale can apparently crash if locale are uninitialized + logger.debug("Ignoring error %s when setting locale", e) + command = create_command(cmd_name, isolated=("--isolated" in cmd_args)) + + return command.main(cmd_args) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/cli/main_parser.py b/venv/lib/python3.8/site-packages/pip/_internal/cli/main_parser.py new file mode 100644 index 0000000..a89821d --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/cli/main_parser.py @@ -0,0 +1,99 @@ +"""A single place for constructing and exposing the main parser +""" + +import os +import sys + +from pip._internal.cli import cmdoptions +from pip._internal.cli.parser import ( + ConfigOptionParser, + UpdatingDefaultsHelpFormatter, +) +from pip._internal.commands import commands_dict, get_similar_commands +from pip._internal.exceptions import CommandError +from pip._internal.utils.misc import get_pip_version, get_prog +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import Tuple, List + + +__all__ = ["create_main_parser", "parse_command"] + + +def create_main_parser(): + # type: () -> ConfigOptionParser + """Creates and returns the main parser for pip's CLI + """ + + parser_kw = { + 'usage': '\n%prog [options]', + 'add_help_option': False, + 'formatter': UpdatingDefaultsHelpFormatter(), + 'name': 'global', + 'prog': get_prog(), + } + + parser = ConfigOptionParser(**parser_kw) + parser.disable_interspersed_args() + + parser.version = get_pip_version() + + # add the general options + gen_opts = cmdoptions.make_option_group(cmdoptions.general_group, parser) + parser.add_option_group(gen_opts) + + # so the help formatter knows + parser.main = True # type: ignore + + # create command listing for description + description = [''] + [ + '%-27s %s' % (name, command_info.summary) + for name, command_info in commands_dict.items() + ] + parser.description = '\n'.join(description) + + return parser + + +def parse_command(args): + # type: (List[str]) -> Tuple[str, List[str]] + parser = create_main_parser() + + # Note: parser calls disable_interspersed_args(), so the result of this + # call is to split the initial args into the general options before the + # subcommand and everything else. + # For example: + # args: ['--timeout=5', 'install', '--user', 'INITools'] + # general_options: ['--timeout==5'] + # args_else: ['install', '--user', 'INITools'] + general_options, args_else = parser.parse_args(args) + + # --version + if general_options.version: + sys.stdout.write(parser.version) # type: ignore + sys.stdout.write(os.linesep) + sys.exit() + + # pip || pip help -> print_help() + if not args_else or (args_else[0] == 'help' and len(args_else) == 1): + parser.print_help() + sys.exit() + + # the subcommand name + cmd_name = args_else[0] + + if cmd_name not in commands_dict: + guess = get_similar_commands(cmd_name) + + msg = ['unknown command "%s"' % cmd_name] + if guess: + msg.append('maybe you meant "%s"' % guess) + + raise CommandError(' - '.join(msg)) + + # all the args without the subcommand + cmd_args = args[:] + cmd_args.remove(cmd_name) + + return cmd_name, cmd_args diff --git a/venv/lib/python3.8/site-packages/pip/_internal/cli/parser.py b/venv/lib/python3.8/site-packages/pip/_internal/cli/parser.py new file mode 100644 index 0000000..c99456b --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/cli/parser.py @@ -0,0 +1,265 @@ +"""Base option parser setup""" + +# The following comment should be removed at some point in the future. +# mypy: disallow-untyped-defs=False + +from __future__ import absolute_import + +import logging +import optparse +import sys +import textwrap +from distutils.util import strtobool + +from pip._vendor.six import string_types + +from pip._internal.cli.status_codes import UNKNOWN_ERROR +from pip._internal.configuration import Configuration, ConfigurationError +from pip._internal.utils.compat import get_terminal_size + +logger = logging.getLogger(__name__) + + +class PrettyHelpFormatter(optparse.IndentedHelpFormatter): + """A prettier/less verbose help formatter for optparse.""" + + def __init__(self, *args, **kwargs): + # help position must be aligned with __init__.parseopts.description + kwargs['max_help_position'] = 30 + kwargs['indent_increment'] = 1 + kwargs['width'] = get_terminal_size()[0] - 2 + optparse.IndentedHelpFormatter.__init__(self, *args, **kwargs) + + def format_option_strings(self, option): + return self._format_option_strings(option, ' <%s>', ', ') + + def _format_option_strings(self, option, mvarfmt=' <%s>', optsep=', '): + """ + Return a comma-separated list of option strings and metavars. + + :param option: tuple of (short opt, long opt), e.g: ('-f', '--format') + :param mvarfmt: metavar format string - evaluated as mvarfmt % metavar + :param optsep: separator + """ + opts = [] + + if option._short_opts: + opts.append(option._short_opts[0]) + if option._long_opts: + opts.append(option._long_opts[0]) + if len(opts) > 1: + opts.insert(1, optsep) + + if option.takes_value(): + metavar = option.metavar or option.dest.lower() + opts.append(mvarfmt % metavar.lower()) + + return ''.join(opts) + + def format_heading(self, heading): + if heading == 'Options': + return '' + return heading + ':\n' + + def format_usage(self, usage): + """ + Ensure there is only one newline between usage and the first heading + if there is no description. + """ + msg = '\nUsage: %s\n' % self.indent_lines(textwrap.dedent(usage), " ") + return msg + + def format_description(self, description): + # leave full control over description to us + if description: + if hasattr(self.parser, 'main'): + label = 'Commands' + else: + label = 'Description' + # some doc strings have initial newlines, some don't + description = description.lstrip('\n') + # some doc strings have final newlines and spaces, some don't + description = description.rstrip() + # dedent, then reindent + description = self.indent_lines(textwrap.dedent(description), " ") + description = '%s:\n%s\n' % (label, description) + return description + else: + return '' + + def format_epilog(self, epilog): + # leave full control over epilog to us + if epilog: + return epilog + else: + return '' + + def indent_lines(self, text, indent): + new_lines = [indent + line for line in text.split('\n')] + return "\n".join(new_lines) + + +class UpdatingDefaultsHelpFormatter(PrettyHelpFormatter): + """Custom help formatter for use in ConfigOptionParser. + + This is updates the defaults before expanding them, allowing + them to show up correctly in the help listing. + """ + + def expand_default(self, option): + if self.parser is not None: + self.parser._update_defaults(self.parser.defaults) + return optparse.IndentedHelpFormatter.expand_default(self, option) + + +class CustomOptionParser(optparse.OptionParser): + + def insert_option_group(self, idx, *args, **kwargs): + """Insert an OptionGroup at a given position.""" + group = self.add_option_group(*args, **kwargs) + + self.option_groups.pop() + self.option_groups.insert(idx, group) + + return group + + @property + def option_list_all(self): + """Get a list of all options, including those in option groups.""" + res = self.option_list[:] + for i in self.option_groups: + res.extend(i.option_list) + + return res + + +class ConfigOptionParser(CustomOptionParser): + """Custom option parser which updates its defaults by checking the + configuration files and environmental variables""" + + def __init__(self, *args, **kwargs): + self.name = kwargs.pop('name') + + isolated = kwargs.pop("isolated", False) + self.config = Configuration(isolated) + + assert self.name + optparse.OptionParser.__init__(self, *args, **kwargs) + + def check_default(self, option, key, val): + try: + return option.check_value(key, val) + except optparse.OptionValueError as exc: + print("An error occurred during configuration: %s" % exc) + sys.exit(3) + + def _get_ordered_configuration_items(self): + # Configuration gives keys in an unordered manner. Order them. + override_order = ["global", self.name, ":env:"] + + # Pool the options into different groups + section_items = {name: [] for name in override_order} + for section_key, val in self.config.items(): + # ignore empty values + if not val: + logger.debug( + "Ignoring configuration key '%s' as it's value is empty.", + section_key + ) + continue + + section, key = section_key.split(".", 1) + if section in override_order: + section_items[section].append((key, val)) + + # Yield each group in their override order + for section in override_order: + for key, val in section_items[section]: + yield key, val + + def _update_defaults(self, defaults): + """Updates the given defaults with values from the config files and + the environ. Does a little special handling for certain types of + options (lists).""" + + # Accumulate complex default state. + self.values = optparse.Values(self.defaults) + late_eval = set() + # Then set the options with those values + for key, val in self._get_ordered_configuration_items(): + # '--' because configuration supports only long names + option = self.get_option('--' + key) + + # Ignore options not present in this parser. E.g. non-globals put + # in [global] by users that want them to apply to all applicable + # commands. + if option is None: + continue + + if option.action in ('store_true', 'store_false', 'count'): + try: + val = strtobool(val) + except ValueError: + error_msg = invalid_config_error_message( + option.action, key, val + ) + self.error(error_msg) + + elif option.action == 'append': + val = val.split() + val = [self.check_default(option, key, v) for v in val] + elif option.action == 'callback': + late_eval.add(option.dest) + opt_str = option.get_opt_string() + val = option.convert_value(opt_str, val) + # From take_action + args = option.callback_args or () + kwargs = option.callback_kwargs or {} + option.callback(option, opt_str, val, self, *args, **kwargs) + else: + val = self.check_default(option, key, val) + + defaults[option.dest] = val + + for key in late_eval: + defaults[key] = getattr(self.values, key) + self.values = None + return defaults + + def get_default_values(self): + """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: + # Old, pre-Optik 1.5 behaviour. + return optparse.Values(self.defaults) + + # Load the configuration, or error out in case of an error + try: + self.config.load() + except ConfigurationError as err: + self.exit(UNKNOWN_ERROR, str(err)) + + defaults = self._update_defaults(self.defaults.copy()) # ours + for option in self._get_all_options(): + default = defaults.get(option.dest) + if isinstance(default, string_types): + opt_str = option.get_opt_string() + defaults[option.dest] = option.check_value(opt_str, default) + return optparse.Values(defaults) + + def error(self, msg): + self.print_usage(sys.stderr) + self.exit(UNKNOWN_ERROR, "%s\n" % msg) + + +def invalid_config_error_message(action, key, val): + """Returns a better error message when invalid configuration option + is provided.""" + if action in ('store_true', 'store_false'): + return ("{0} is not a valid value for {1} option, " + "please specify a boolean value like yes/no, " + "true/false or 1/0 instead.").format(val, key) + + return ("{0} is not a valid value for {1} option, " + "please specify a numerical value like 1/0 " + "instead.").format(val, key) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/cli/req_command.py b/venv/lib/python3.8/site-packages/pip/_internal/cli/req_command.py new file mode 100644 index 0000000..9383b3b --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/cli/req_command.py @@ -0,0 +1,333 @@ +"""Contains the Command base classes that depend on PipSession. + +The classes in this module are in a separate module so the commands not +needing download / PackageFinder capability don't unnecessarily import the +PackageFinder machinery and all its vendored dependencies, etc. +""" + +import logging +import os +from functools import partial + +from pip._internal.cli.base_command import Command +from pip._internal.cli.command_context import CommandContextMixIn +from pip._internal.exceptions import CommandError +from pip._internal.index.package_finder import PackageFinder +from pip._internal.legacy_resolve import Resolver +from pip._internal.models.selection_prefs import SelectionPreferences +from pip._internal.network.download import Downloader +from pip._internal.network.session import PipSession +from pip._internal.operations.prepare import RequirementPreparer +from pip._internal.req.constructors import ( + install_req_from_editable, + install_req_from_line, + install_req_from_req_string, +) +from pip._internal.req.req_file import parse_requirements +from pip._internal.self_outdated_check import ( + make_link_collector, + pip_self_version_check, +) +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from optparse import Values + from typing import List, Optional, Tuple + from pip._internal.cache import WheelCache + from pip._internal.models.target_python import TargetPython + from pip._internal.req.req_set import RequirementSet + from pip._internal.req.req_tracker import RequirementTracker + from pip._internal.utils.temp_dir import TempDirectory + +logger = logging.getLogger(__name__) + + +class SessionCommandMixin(CommandContextMixIn): + + """ + A class mixin for command classes needing _build_session(). + """ + def __init__(self): + # type: () -> None + super(SessionCommandMixin, self).__init__() + self._session = None # Optional[PipSession] + + @classmethod + def _get_index_urls(cls, options): + # type: (Values) -> Optional[List[str]] + """Return a list of index urls from user-provided options.""" + index_urls = [] + if not getattr(options, "no_index", False): + url = getattr(options, "index_url", None) + if url: + index_urls.append(url) + urls = getattr(options, "extra_index_urls", None) + if urls: + index_urls.extend(urls) + # Return None rather than an empty list + return index_urls or None + + def get_default_session(self, options): + # type: (Values) -> PipSession + """Get a default-managed session.""" + if self._session is None: + self._session = self.enter_context(self._build_session(options)) + # there's no type annotation on requests.Session, so it's + # automatically ContextManager[Any] and self._session becomes Any, + # then https://github.com/python/mypy/issues/7696 kicks in + 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) + session = PipSession( + cache=( + os.path.join(options.cache_dir, "http") + if options.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), + ) + + # Handle custom ca-bundles from the user + if options.cert: + session.verify = options.cert + + # Handle SSL client certificate + if options.client_cert: + session.cert = options.client_cert + + # Handle timeouts + if options.timeout or timeout: + session.timeout = ( + timeout if timeout is not None else options.timeout + ) + + # Handle configured proxies + if options.proxy: + session.proxies = { + "http": options.proxy, + "https": options.proxy, + } + + # Determine if we can prompt the user for authentication or not + session.auth.prompting = not options.no_input + + return session + + +class IndexGroupCommand(Command, SessionCommandMixin): + + """ + Abstract base class for commands with the index_group options. + + This also corresponds to the commands that permit the pip version check. + """ + + def handle_pip_version_check(self, options): + # type: (Values) -> None + """ + Do the pip version check if not disabled. + + This overrides the default behavior of not doing the check. + """ + # Make sure the index_group options are present. + assert hasattr(options, 'no_index') + + if options.disable_pip_version_check or options.no_index: + return + + # Otherwise, check if we're using the latest version of pip available. + session = self._build_session( + options, + retries=0, + timeout=min(5, options.timeout) + ) + with session: + pip_self_version_check(session, options) + + +class RequirementCommand(IndexGroupCommand): + + @staticmethod + def make_requirement_preparer( + 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 + wheel_download_dir=None, # type: str + ): + # type: (...) -> RequirementPreparer + """ + Create a RequirementPreparer instance for the given parameters. + """ + downloader = Downloader(session, progress_bar=options.progress_bar) + + temp_build_dir_path = temp_build_dir.path + assert temp_build_dir_path is not None + + return RequirementPreparer( + build_dir=temp_build_dir_path, + src_dir=options.src_dir, + download_dir=download_dir, + wheel_download_dir=wheel_download_dir, + build_isolation=options.build_isolation, + req_tracker=req_tracker, + downloader=downloader, + finder=finder, + require_hashes=options.require_hashes, + use_user_site=use_user_site, + ) + + @staticmethod + def make_resolver( + 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: (...) -> Resolver + """ + Create a Resolver instance for the given parameters. + """ + make_install_req = partial( + install_req_from_req_string, + isolated=options.isolated_mode, + wheel_cache=wheel_cache, + use_pep517=use_pep517, + ) + return Resolver( + preparer=preparer, + finder=finder, + make_install_req=make_install_req, + use_user_site=use_user_site, + ignore_dependencies=options.ignore_dependencies, + ignore_installed=ignore_installed, + ignore_requires_python=ignore_requires_python, + force_reinstall=force_reinstall, + upgrade_strategy=upgrade_strategy, + py_version_info=py_version_info, + ) + + def populate_requirement_set( + self, + requirement_set, # type: RequirementSet + args, # type: List[str] + options, # type: Values + finder, # type: PackageFinder + session, # type: PipSession + wheel_cache, # type: Optional[WheelCache] + ): + # type: (...) -> None + """ + Marshal cmd line args into a requirement set. + """ + for filename in options.constraints: + for req_to_add in parse_requirements( + filename, + constraint=True, finder=finder, options=options, + session=session, wheel_cache=wheel_cache): + req_to_add.is_direct = True + requirement_set.add_requirement(req_to_add) + + for req in args: + req_to_add = install_req_from_line( + req, None, isolated=options.isolated_mode, + use_pep517=options.use_pep517, + wheel_cache=wheel_cache + ) + req_to_add.is_direct = True + requirement_set.add_requirement(req_to_add) + + for req in options.editables: + req_to_add = install_req_from_editable( + req, + isolated=options.isolated_mode, + use_pep517=options.use_pep517, + wheel_cache=wheel_cache + ) + req_to_add.is_direct = True + requirement_set.add_requirement(req_to_add) + + # NOTE: options.require_hashes may be set if --require-hashes is True + for filename in options.requirements: + for req_to_add in parse_requirements( + filename, + finder=finder, options=options, session=session, + wheel_cache=wheel_cache, + use_pep517=options.use_pep517): + req_to_add.is_direct = True + requirement_set.add_requirement(req_to_add) + + # If any requirement has hash options, enable hash checking. + requirements = ( + requirement_set.unnamed_requirements + + list(requirement_set.requirements.values()) + ) + if any(req.has_hash_options for req in requirements): + options.require_hashes = True + + if not (args or options.editables or options.requirements): + opts = {'name': self.name} + if options.find_links: + raise CommandError( + 'You must give at least one requirement to %(name)s ' + '(maybe you meant "pip %(name)s %(links)s"?)' % + dict(opts, links=' '.join(options.find_links))) + else: + raise CommandError( + 'You must give at least one requirement to %(name)s ' + '(see "pip help %(name)s")' % opts) + + @staticmethod + def trace_basic_info(finder): + # type: (PackageFinder) -> None + """ + Trace basic information about the provided objects. + """ + # Display where finder is looking for packages + search_scope = finder.search_scope + locations = search_scope.get_formatted_locations() + if locations: + logger.info(locations) + + 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 + """ + Create a package finder appropriate to this requirement command. + + :param ignore_requires_python: Whether to ignore incompatible + "Requires-Python" values in links. Defaults to False. + """ + link_collector = make_link_collector(session, options=options) + selection_prefs = SelectionPreferences( + allow_yanked=True, + format_control=options.format_control, + allow_all_prereleases=options.pre, + prefer_binary=options.prefer_binary, + ignore_requires_python=ignore_requires_python, + ) + + return PackageFinder.create( + link_collector=link_collector, + selection_prefs=selection_prefs, + target_python=target_python, + ) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/cli/status_codes.py b/venv/lib/python3.8/site-packages/pip/_internal/cli/status_codes.py new file mode 100644 index 0000000..275360a --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/cli/status_codes.py @@ -0,0 +1,8 @@ +from __future__ import absolute_import + +SUCCESS = 0 +ERROR = 1 +UNKNOWN_ERROR = 2 +VIRTUALENV_NOT_FOUND = 3 +PREVIOUS_BUILD_DIR_ERROR = 4 +NO_MATCHES_FOUND = 23 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/commands/__init__.py b/venv/lib/python3.8/site-packages/pip/_internal/commands/__init__.py new file mode 100644 index 0000000..2a311f8 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/commands/__init__.py @@ -0,0 +1,114 @@ +""" +Package containing all pip commands +""" + +# The following comment should be removed at some point in the future. +# mypy: disallow-untyped-defs=False + +from __future__ import absolute_import + +import importlib +from collections import OrderedDict, namedtuple + +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import Any + from pip._internal.cli.base_command import Command + + +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.', + )), + ('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] + + +def create_command(name, **kwargs): + # type: (str, **Any) -> Command + """ + Create an instance of the Command class with the given name. + """ + module_path, class_name, summary = commands_dict[name] + module = importlib.import_module(module_path) + command_class = getattr(module, class_name) + command = command_class(name=name, summary=summary, **kwargs) + + return command + + +def get_similar_commands(name): + """Command name auto-correct.""" + from difflib import get_close_matches + + name = name.lower() + + close_commands = get_close_matches(name, commands_dict.keys()) + + if close_commands: + return close_commands[0] + else: + return False diff --git a/venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..f39a689af66049211b159506d1c083a9868865dd GIT binary patch literal 2852 zcmc&$OK;mo5GE<=VZCf8ZWHIxFiq@4X)HI7=G8P!BFBx9#xZK7MT7zb%~?r=m!z^w zMvx#~>YjV;rH2IQrN5>BV6Q#(FZ57!c1apaYn@Ah%l&p{XJ)^d-POxlt*qg5`__u{ zLtWGUkYM^bj^H7_{GP69ptUv7!JxWtv<+SMb2Qh^;n$?5pKs^=Lc5^G^R(!f+9h2h zCANd|0-f{A?Xr>;X~nO$t0*f#3FZ!rc8%nrOlnYpD%1{g9Ruo!=3xOA6*`9KI4r>j z3Vn#^1e}Crg-#(l4QJr2LLVVI2Ns-H=wn0|;3BLjw2J5wT!w~1R}g&yS7A+|CZcut z6s{?B9nlTA37;u+3(;-319ug=hv;*-4__$s0MVE55FSa?tsm&^Iy{Efk6L>kHsA?< z7a+H*H8w{p zbx}z>TR|rrS$+sHC3fG5dRHx%I-J|m=2eTw7z`VVq8IQ8BOHB%AvSFkPSg}8^>{QoJ;RL@iptm6W-d-jaD)T2#CzdjrX?v9m0fHzOIIX7OGzYN7+B6; zcx3QRk#~E<-5;Hq5vG!gYD+3*=5K#XnAaH|5vtX5-pI=LvD~~pN-Q9K5&#KYk6?Ke za8Go+?&#tyXG$D1oE!#XsWlBV=c~`1KyEJ@x(>B)H(6a8?qN5volZtyoH)$w%}jG5 z7PVcamRVm;ptUpH*^-Go%rX)+=n+C^5~ZY~`khqDtX+H@dlW1s!n$CgZwYC0FddkyMvmRH8%@IXXX+?o352N}Gv# z=4S1Y)g!b|Saxh#F~_o(q@Znij;TZ^laL-DdvSLrJxVI78&WCru=<}eMGu{rDj#Y> z7f(+~5XLc^AQU1&*k*Q5D7$jfbhNzb;^lVul(3h__ZhzY9yXCS)|R#Ja}#5do0yUQ z))*V_^hrL-jq~H&fiWqJ3mw!Mo1p(>8^5)mo4I z{yG-YS{%spp1_(a>oqU#zP>ZOIgqmT!`ov$3wqtgF)y<1W`8K^t|G`zg>5v<)gP05 zT`%Kr$zV5d?7ckYaKOa3C6#YsqyCy`zCO`)%*I>eoi@?N`dEu{Z_Rfa<_Yu0nqvd> zWo=iJ*D{!xqx|SpD=k~eu;s*2xaNk85jScwSs8eTE+U0UK*))WM>w8+d~>^z7e(+o z9b}x{L^YA8;ear9N%qZsGUSb%B0Q1Slj+&|6?;i@T~1h%9=PXw)L|J9yo(ZE#YQu# zM#-ofrd~4GUBrz=QM7FcUE3CA+wR0s%!q9>17++oHlpH&l;Rq2qjM(7Vv;R!>is<* zM;_(PXxPUM#bnuwLJA5J{QK&sUUSbu64F($qO>b_j9Rryk_vBXb+SsBT4L#bQc@2j osr*-L%pxvJU%od5s; literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/check.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/check.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..dade849d3ff3cab9a5e0b1f6f2f29c1049850861 GIT binary patch literal 1312 zcmZ7$%Z?jGuzTJfkEI2Xg`j|j!yX*5V}zoF1BzB!BreF82o6J{(RjLTPj+7J?#as5 z%*pux4*7s^@ zXJqQW1Dj+%rP{r&%QCIl)X*PgYo6UCO`6@LE1pQM^jDeSsp6-yWGU)0$t$VSqTmcn z1h*oGH+8F;R%K}T^ccWg0muh{IEg7EvB79;G9$K_$*k8TwwVnf^XVfaHPKuZ`XOY4s#h+wfe7Ak)V*%?($AyogS4+Ua3KE z(W-D;w|Au+o<;8loiFBfxDfRXuiiUC9T_g`wqnuL5;&LwYpLB=Tu7*`fcYiUiMAv! zmfAfOTwAGFNj*LpsCd$(pi!+7Xw5=ux6CE7dYskOvdA-qOaPZJd8U#oExGW}lYi{+ zR(n7XS9*-pAqH(iS^gm66L|jj)l8MmtjU|pwnF!uUEZ!aFD~Hyd0kw?X+36@p zU~CTa?IlCpNuvEEDQngi9OxiPHf>s9vcS1X!s-kNyOpqp0)rTmIzjhP<^VbakVtso z(=rFyG|+BQuU1&eFCoq7m}Zm}d9+9+PY(GCT+aVLsv9m~tzcuKp&CQ0ho= zypR#JFdGIyk5*j$1fIDNpQ2$0!vF>YJc%AVBrpZ-eScSkr#Mm){|-GPpl4QK_~yT{ C{bb?* literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/completion.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/completion.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..49e0c1c46103581022e09b143e0a6e3fe2532617 GIT binary patch literal 3013 zcmai0-*4Q;5#C+?xYOwr$4;XfZdz;=88`;zscMQeC@iC{q84rwOOR|Nxx^r7?%s(q zkEC~(R(v@<$v~c3pzi@HKjvTB*FF{f588)xhIi7PEGZ$uxeXdY6}J$!~Y`zRa>f^Q0J-nKWsUb8TW}U?x#%X#)KND`hTP z@jH}|7N1@bSdC`3I>Fh@*JnLky1D(y&hFOE$DeO>_-dyfMxSo)ezdo-vidbnPDWq6 z_xNaqe|b*zbgSvRUc8CA8>_Sa59{pQ--+%$dbk~-!pB<=w>H-K>N@|;-8CVfujN&i z@qo`6}p$=I@xCZ z@p*W!LN_rP5C8fjh#p>!Xw*;j{wez;0z3x~=UPIrvajaI#yb#DOpYwgF{S}uS-D!J zCK>Nsa`<6v_R&^u;xyMhOnDf-X4?dOLeHAz0l;{k)iXSh*Qc&t0Fx`gr5%C18 z&-~>~2l`jgk)%fjfl5cA%CVmN4e3+i2=`^P=Lt{vFGbeV716&Mqv&O?a-sqcdm>F?39h*#R5V zG5b5EWK0g6BWLU!xPl6X4x)3S@i!mlPznVYq%Dvx&Pm&138Zg;^x9NP4!jdzyg7DW zF)Zb9sOt|#ei$NXBNjffi`o=Q0!?#mln2gOuP(x)pKlEzinBvNSIGK+s2jM}kL%K5 zy;|40LTY1O#Af7$A;bghkCYE4NAFx|3zvaA7&utoR}EZ#_13sfA(jvuPgf8Hg-F_F z6s37;qR2Lrp@@poXxoZK-GcyFzl@cZ%Dx2&A(g=eAdUvAs7g4Bt7X==Zmb5{vZsgY zI@tV<+Jz`evRLaV`i}f}Yt0PHHOS(y%F8%;Dn)p>FJ%^{)!^BOFMfN7b8Fy+kt&a~ zwJAF^cBbF5ZuvsJ38p`UM}Ghfp*NV%T*?Te)BAtE|0CnZ=+@?$N$4R5yQk+*PT7vu z5qo?#;n4~jLr&-`a^xVXUJ}E`&N2On9MdCrOb>u=Pkr^7aZfy0=c7abZG>wY$0Vi8 zt9jFRMbF(im(5dLx z;z9ac!j~RD{^v4(*aVX8pySBs!!F1*LQ7ba-k>e&(l*f5{T^;_ znfbK+{pjsW5e%A`m3cgrkd>_{8Wy6;u-}fNXH}d{XBtr?iUh=OrGp$Rk&@4<6yCsy z=XJKIF6?fXrn#5^N1|xX)tfM@FvN8wcpo|%OG1;n%w_FcwKP~n5Bimn(6K^1s-5@R0o@1VuPE{xrf-*?%C#@ b2?Tdhp=NU%Fm19nZ8O(n3v7}7$A9<#PDc}! literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/configuration.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/configuration.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..639e7ce42da38fe9bc92bf02c99ade1571b36b34 GIT binary patch literal 6575 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 WQr$7R?9edKF_Q>4=S<|hr2h*<$+6S` literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/debug.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/debug.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..1850a39a1c9b49bac7ec3ffa67125c7357a70a89 GIT binary patch literal 4089 zcmZu!TW=f372erh?k*`(k|j&FW4GD32@Gi(kc+erZP9-~J?5q8V;=fT=Cx0G=?^GSxZfF4vJ`uXo$HyiXU_S~h4)&m zhK1*6KYb;+zie6mrpf8Y#pGSQ)ql`%i?htiS;QEP?aYpB(>sx4dN*=SUyEw!oy^Pq z$TzfZ7UcD)ZpO8&kuO9GX6$9nycM;~*v}U8rD(~FgKRlJ7o9WXdbX0UMyqDr$j;|$ z(HgVFn*1lev5>9j7orRK#pq&wDY|56n%N8a<>)eKoaq(uy(1QVpSSqpV=H=*FY#sc zAwS1g(7(i2`FZqLKeYH7Uw>@zb+K^hL_gs6w$;AyE$(c!nO;hEsxliY5vTc}lxhoW zwTHVx3JeAcDv^Dm;=zI1Eej&pzPGV)YkQkcrUe&; zinFqh*^(hk2k`?TD{vzYzyAE=&*P1cZf*Q3zH@JD>la%ewjJ%fR~%^fc3LSN{KkAZ z$w2IVnq)&!b!`%Q{?ORNyMeb_N29DM<7{e=tuZ^YkBl90Q+sRVJ(|27KAM2P2YLEJ zYBw!*x>*AAE@Wpx>?&mU6G ziGu!x31_%IlyS%=_Sl}XBWvQIx6!-Yp47&!>~Lr5jNKzPsd0DeD0l1}vT^Omo_MM@ z^~N5l7wYtRZQqiE`99ls<$!w=e+;i5vp?FGz!~cHC%y`x?zeEp*|fe`nFPc|)yKgh zBTo1KF!tp?c(CV;8L$6^o&L&q%+lEUmI9N!h-TCZUz@p+LFi}=J~n`vb}|vFq+ikM zqsh0VjJqF<-syBYjo*Ec%1VWgupMVC&$_iN&ce)a!&e|ZqEE6?xzn#Av^?Xi1fK^D?N!5GFa1(GdDV}aL^QjM;M&3LyAY}y2oYHaAE{nPV;QgnPQYCJ z8ul{Yb&M8g>uedl{ls?c|9P(b5$MlAs)hx+zJs^Q&?xKBny@i~$dLsDU-`W~u>mRy zDE8FhFfs=ijHwsLta_6>+ZK0ujeC9P&(>E~k8z&|kApGWBv`s*xB86Nw*jK5%jNd&CI-)3*wU;c$*QB)R;j{jAi8NU#pV69s1%H4g0RSRz+u&_O!yh;DPmCiTE$xt zj{1P|7t4^J{mI(*B;vu}?fdTbER-2#BFfpFH*_r%4@CAgi!Pf%6|3Du#U<=2Q!e6u zR_-L(Dc^0}$PkSY+Xgp3r;m}&JZ4*gHM-hO;+?T=t6NBR;+M6*P z*{_Ff4}cL$*HR_&N;?VXx>gOcRB2C&93p6UuS|<}O?%z4=%syxYZ4Z;`{F>-U84&# ze#Zi*1$=;LW)lAxB+`VO#j~<~OrpPl#zK@?X6rT}V`7f|#B*k2c@w*5!ZMK)Jm{(3 zKqIV(aSL?;Lrq|#9&n0_%}q)M^TauNxe?;oOmXYv zAT)U*B-K$CLS*ik?a{jF!tj-WEc@Y&xp&>Xdj3>?F|xHAsx=s?wKe+Y?rvIz^J*i+ zuq?8JFc(RoLO^K-t3EuV6K+jUAS~8Si6(av;0An-qOvK8F(|L)sOc(Efrctrg$>3Om5P*jl0=prF~I6NM%`Q2Mi>6he?Xk$EfYd z4{6~QYCfWdD&VKSryV&g6qc&j&>-#uSkBuVIExD#m6Ir4(}tYsP9Oe+M^a*tki# grurcoAc~ov-Lz-Oo3}vYdEl+#1ht?QTn$$L58c;CJOBUy literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/download.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/download.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..b3f4c8e7910cfeb5449f3b3ba1d51179e8009cf3 GIT binary patch literal 3921 zcmbVPOOM>f5pF()uX*fC(n_`zFa`u`0MBd^Se6lN76v3Z2p|ZG*NF`Z2EiqJXSm`^ z-Q;d&!8xq}BL_vv#pm6lulYHB%_)B%K$M4F)#R*ZB*%x4V6&^bSzT3K^>y)g{k}us zy7$rT;N=z}e?wyV(t-E{9{vq95s8$9q>85~*jE$PQ{`LpG>IL|mxn`!Wr z`enc-wDgNvIn6WVeny{FF{3HX%KLem23Z8$!4h|$mcZG@uh{Fke#wIHDP==VI5guG zqka@KG01Y321$HM{URu*qIbe#&?&FVqCzqK&uLmbfc3&MXR{EMU%s@K;2%JT5>JT; zxLE-gtDgQfIaDGo(w|#iC+bATbK)6a6PBzy6`*`;FH|`xU+|A1=Wp12B^beE|-HONA#9cDlxH%NHy z@~XgX z%@gX<>^Nq5hH-$y2lR3!8a2iS?=Bqby0<~{#C_66*H`ZDk`k}IwC6r)T|Sad9bL{J zj~kh9OB%5iVU0!qkD%S-kY8>9Y|WngzZcz2R<;X6_eZCa9@y z6>6|Tt*ub&E7ZmcwYfrVtx#81sH+R=NRO0A#mvR5Ew3GIM`mQbuoMDzU#~T^8+td& z&e1#IlXoxFxsLDin~`1X7pnABLup7w1oGW^bgGV`Q)4uWC@)Vpns=N92zMjMx6|#n zSPkfi-Xeu0Vre+{*4q#fXOIQEFt|4!>O#j=gqhMZI1ZRFBYGHANh$OxO$vq^KfEP6 zkffBc9#F#a{WyzD-xn63un&RHg%d=w2O2U&I?)XQngK{*EiQUXDa3_+P{m0kH8iu_ zk7&WgV3OnqL4v{%(}fKK2VgRriEf@Hvjx#F7(JwHL28_ZLIa+#;Da!sK_&+6V*WJX zQwob?J~PU>e*orfqF}jx42Ozzscsc+fi|ujGMDOZ z$OEWR-k-3%DnwVpLQ5D$z&K@ME6(6mw%;{_!;a87O%8<)=NA|1(-U?TJ?Jz7(7oR( z!uG+u0F3azC9m%9lxeX806MBNL?IfDPNtM5qqv$p`*`-@36AZ+E|rvJL9!Dzryt*0 zgvYp;u`9619eDVs&=6%)HPnIfqqnLnDv`IM!VT2F49fv7-2c@(1LgGkBG}r4YP<-Q zaB=+MT77uB@Z5)o{{$i|QfkE~69TPLs^?m*$i&fW<*0LpW1Z4y`j{~1CXUaw(yEm+ zMJALDz@ycAq`uJR9hm79UqajMk-1U!&dAHZ&dsuqoZ7%-eWAVlW^R>(Gcvb9-db(f z2wj~T>YWQiCgpk!(rXi>qC9yhzcA+xB=1J;AP=~kk@-TOcR|8d-H{O2J-<@h*o&<5 ztC1Z!&q-|`U3);zP~%?RWB(|(qi)?h!_)^o|EzGMw$HC$5QTg}?vme<&&Zccz1qe~ z=+Wm;iWQpjn1f#GPyE{~c5z&N}ROnA3iav!BVo*YL(ndZ6Gy4d9FS?K_ zi)x46LymEXQO6i=k?3P0z{7kFl@36K1(^ns4C8w+-pE)hX8ti$4WJMN++qGoaaT?Y z6=ve*@5944p@D5CUpaGhAo+{>Oy4K$LtsM%rDs7(L3wrjGogWMlHW9UVTN#albDwf z%*EaxQ5sgU28874`)`IFtFm!(@bNw9EWSE@XTJ(V@ZMpSB(tR|z`f0fH^h28ff^6W zOhB$6NoXW&8pUOB0Ch)$YS+Rk4W9yZajX~t-{KJQirJuv^ck~I(JibfTO9S<-D0S% zxY}+(TRZrzyMKz`-@wMi29tvs(1`0rUQ_^6bfrM$v=lca$0%8f1`Rg(F|ha% zG(<5pLv_?1JdSE1HsSprqccz)MMu>7&QMj=Sd28|uXMYeDQW2c({L6X{ojU((%}2= zEKOG&%~Ecvr&~V|Y(ooAMGRj!6&>GC^QcO&-}C)vRgknJrVri>f!(P%6zdX#nFrd7 zehcp*O%mT<3jANdD8uNNXD?zl#}ESxd%D@XBe}!txaMJ1;;)L&Fyn-o$((HYp zybU-H#+T>8I80(0&)&_q_~X|o+8fnZ!nMzG&$+&w%*Jh$bHN-Pa8DT@-Jp{V}pq?OYpcC4%Wyz;9kR+m5 ayUkARVRG_o(DWd9EVZXB?kfs}l=eNYCVasF literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/freeze.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/freeze.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..32d80c7e1bbe78d1fb6e28925053007892b455e2 GIT binary patch literal 2929 zcmZWr-EZ8+5$88~)SW(U*>w_!K_=BSSKp+tJ3S8d)bBPc^bZy)!e~B*y33c=HFa zK^yDsMsgrZR!bUZc~x@x0C@fvb4uCWB%MND4bE8;lCbO`u8wA+HLI*@eL-bi$+Bc3@<}En&ko?Pt$mFDYDSf$x;Pg?QahlUYieRcXI`P%CORa>{fWb~+ zCQL|zG!Zm})o39ynLVa~0Dpq8`^EcAu(4M1t39h!$0(TPD!V$C#Sqc@(p zml98b10@KMRmlipLN>`3*(N*B0CxRa*T{9n-36}QanCJjpF0=Y#fv}QAU8qlSLD{Y zE4>SSS0k@H0~q&fyh>gJ>FrD2;M^y#qwK;!=t7Kw2aOT(W)uPnE<=U)r~4rbu^m!k*T0YEm$Ae1S#P9MGT^5XHP^GOJ)EndMYW#&&BFDkK<{Vs5l9q0E>vInAB>9Vb|Fmj4N+yv&#A;Fyl%wbmAO1t~g&QR~HVR%9}c zTMsH_4A6lPL!^)bU~mhS23RQKDv|TnIxMrI_3qvOXZ*K6fBJdrR0&6q?O^HPvY!^u zcv)9tv$X_e)7DBjR8r&U_*=al#Bs_JA>#O3?fD<~WnS$=g$?ThJwr*TDr%V3vq$fr zynBqYeXvkcUL-Rxc|$CIT4(`A`QJ3MIU-@DMnf1$%-cc$8zacW8^d57l0 z1lp3iw9fQX8#uOjdjX|Mx>%Z|cRpC?it<6W25ks!1Z^GK2DD9RTMKJ}bGM29%s+LS zU(0J#ZQ*>Q-_yRjcIwLOhr8!D7A`SvsDk%MexdzNTUh5i7n-hp*_AKz!PsxtR;m@> z1(RD}rDI$|7PJFIdPmv_1V9O*I_7jnpR`^E$8ZA2MZ2cr7pHjqLi9m}zlv+={`e+$ zkTT&c<>;$+ptNF=agP4tuOQQ@D*`L=H;|*yw+l<9M^JKl4E7j<3YMjkucIEC%Wq33lzd@1P zpL+aF9IbbUYn*o12>uQ*`Mc0XqrMIt9V_r#P%$b0Es9mQhqFyy7k>pp;7HTg^`Y(o z_I$%P4Bfi&B0jAjosj`ryGFBh6@#$Oc!0TFBsqm#_G8>y&5$0(@gu04y~K@UQl`MR zYXP@~c8!&@816GP$%V=#ejhCx^;w!y#^QLz?lDL?nybnOmQR8AMo+gK%dm{$TZ%v4 zLKCL7tf7v_+(7-0p=);_pC_03JW&8pV2HL}lCZ3c{_S7zCkJp<0gtOv!0}$%zHwCv z!^*_urPv_)qSvo#mQV=c1clq-q>EP<|65nJYMH@u@JGN^2UUemOz;)gyojs!Vdwpi T5WfPQG&DS82;uEtW8M5e)96Vr literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/hash.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/hash.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..2fa485be1cd4e82d6282e546a99cf2211c94bc8d GIT binary patch literal 1990 zcmZuxTW=IM6t+Fry(KB2h*A|z5vjUTchd)Y5uy}CDYUABnxq#^g{;ZgyE|cSu|1@$ zHZKhlPqcp_dE}S$Klrsz{R_O%WA6qQ39sxqwvWB%eBXEcbFbG%(7ya)Bl*Wi=wCBg zZZ1r2L6?8Rz!1YZDsYUku}My1V!ux8*smMA@O5&p@MGWlxOq^7acFHXZx!vhU3B7( zo%?yW=*7KaC0@aZJ147r?G(rF-9s#3;Zwvy?jJkxIo4wBrzk$p$PVgv{)0GBAM4d* zPgZ%OIL(T>5^4+9f;&}FBqamWySu&pV7pIr@4MT-JlOtz_b$DEd*{CH?d)zp*t%yY zcXwdFBY47SI%&#BQg;tU1~*oXsvDJ>e_C$NVj@2SgQFNT1o>mgoj~4B>^(yx%v|O@ z4P&4AEP$wkXUIiy2$6@nb3c)jMTpbq?Fbso;GcMuL=)JHsu5Uul_q&qC+VYP3_Bv7 zWRLlMXZALnkOpR z%elQNE2T>ETn_DQdTFB;)j0aSs#R8%@?mtt9K9J0hr`_zFQH&S=s;hEE`NYQA%$n? znCz1oo{_&m8Z)%-?7Ivz!W`u>SNY6i{z;&`Q@jr3J`b!PIz7mlV88BJ=xS;h!)IrNNHAPic%e>1)~6q)a`^>3vLilD@b_8 z)7`JKQu}oxBp3QT;L3$E2f&SvMb*@ON4t{eBkd+)EH!y__yX$|rD>i>N$Csp@|#Un z)SGoy51P^t&)MK`!g)T(n(@I`Pp%!By-kQnaZx7uW;)lo+%&Wg>nGwIMDihYc?kxD z&tV@EMDUwm_=>#r!|8=32@cOvObw@J&Eyn9zXM&~gkeVHIfm z?Z_uUkW>sP5a!tt=4BEl7Tu#JQCf|tQDxr~7tLz05UY6q%v-y4q9(#1F&{1)KSwlW z9}IZ`283O_f?eX{5G()*g|DWo%di;lmJvXi6dVN5rnIP7lN-BB=|Pj^i=BW{R;94) z%~Lp^jZ07{U6dew%*)4?8nI#G=q)Hud7e|c6y*o7D@>?XdxlGCa)$r|7eeiJ?RrXJ z?W`G^j8H92x4=+Pb_^erzdt!53ZFnRp5h}%0Y%3cNLo1pVouzdYY05J{44q#{e-sB zZwOYsQ&W6o`q4I5jVL2^R$nX|L;1{KB?J6W6S3F#wOiF3ipX%1XM5Ty`Jo6P2JJUB zOBC0w3IAh$7`VC$JC;iwEFLo`J2EqBoG!{n7`?yC30_3iNN|H!!%9$J zdi$nEW$&-}@%w#cN}8Tf)KW*Gf0M cF_+#=QxI0aT@r$FL%^kr*YFx?J8M_|2Re%i`v3p{ literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/help.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/help.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..4bbc049f6ba883385893181efc4f6b397bb89009 GIT binary patch literal 1186 zcmZuw&2Aev5GI%Vr?u<=iJ>|`Q7i)Zpo67L(B=@N0ory z$HMAT=hSy7U?2NRy!O;r=&8e%6sSRmn9*<~&V2LD=+ouki;3r&i5)$l8g*KseBn^!QlHF;a=u*k_Fu7!AF#ZJcR0z-TOgQ%_ie=vbd~o(o2Y>7qw3Fb$PR#BjjoII zr<_2MtvKdl&{I(JI~b0E6X0h>q_^@VSpgr*aSv#oqE+}aQb#^&{i{U3z{s68 z2+^--fqp@K*psVBw|&rucX$$lZPQI^ckLM42Y)0?r)o-yv$pBkZZw!^G(zq7NVu5lx4;AHfWZIow`!> zjoLDjK07wgmWPtvo{RLh?ouh3YS&Sco}|+~J88;hMoZNStyneNR@D)}(2gcO0%MaO z6&D|dQEInbHe^jB6xV^f`0wgc*|1^S2yK%_Lq6)pGfk{-M0H`Kx@pT=8S67$n9sAv zx#UzaDQr-5!Wc`WDQvU>^C!|@K$U;Kowu@?1KyKPH7vgp{N(0Ri0Y*5it87*&u`p! z^H06Zx4q0Al386$Yj0*gYcp6d1HKl6EDWGmtY?scn9Do-ty7Tw$0$x8Ejxo z2Z)r~gi=}at`gvnDZTDk<-o%&qLkM;I6-GvA?%Z~P_-6Ri|ek0&-X&T*H5AN(9w=L zaxmb^D81H~!2df)~c7SdCa?Qglw-N*DF)#{;{0j+BIFtYY literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/install.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/install.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..8f75a42e17e545f70208a8ce269ba24b2e957c9e GIT binary patch literal 16661 zcmbVzYit}>mR?nLb@hYIHzkpJmMF~;@?y$h2Mmmu4hUa?rXZ)`cP?z z(@8g1A1)1Z+Hyzgqoq+!r`)mncxjx|X?LPNS(@Z@#+|C~EA8WS*4Yl8hDxKo= znEO=ybm=sw$K5mad@0ZA3HRyxGo@!ZJ?WmU7fOYCu~e*|E1j!9TY8qur`)g9pDR7b z>3#0=_4B3koZj!gP=B%XBBu|y7wQ*F7wa#TUeYz^{6k&-W313LR_Nu@%iLndeWiY> zbgBMo>DBt>(&hSBOJC*kgYMVrS4vkneaO99pDWFA`Y<3~D_!IC5zKhLG!Mv$?d#5K zJ9_DLaa0_;ua$1RrU_ddzpsho&c1tz($~eTIDzsv#7S`qzi*0yI4#cH*Gq4Sym%TV z3*s4Z7Qb%`V@b;we@@hq*Td1uve$ImzEiH%TTSUNplo>Q_Tu8r`K6`u>+^3eQbB8D zwJaU4*_KtuL&12p(r7kn)rwo|IORsA?w~OH&YI)6bCv2E=c;wlZ27fjgE~yqD;rMP zugF!$FSoY*wPu4#Z#s9{HR;ryhCkP=*DDQ?H^Sun&6{uE3{y+D=jMP!J`v`k%6Tc9 zG916r@cfGFRtUH%+P5g3yR~N9yV|a~;#y5|@h5sXCTgDF_G_+J_J9}Tc>sy(M!BY- zl&j6gid(Dt9)=#-h0v1YhZAw5)!JRBfhD*@lQ}?>KsrXf?8{1Z!;z@U3a2HVYQ=X1 za#O8}^qg`Z2h86CR^z_o`Q=Sn^DE0P)yupYW}SxDmYfUs(FoDljws)Cq=&hNXIir9 zJ5{V;tyNx;&3d`s6txxX11&`v|C_ajXl{C8j(|JmX4`MIePA+t%c-}pF6i8pTPT=# z>)pk7%X6>K&%IH;d3#~u#=>ia@ZFm9+ZESo+$}en+goe4T~X#- zd8H|19I=RM_w>;EX2orTNX#&CrLh&JZ}^U+S%&7D*orXyHq!*40;%gwS+8K{8@_B( z!9=vPyLJJk`>)m-6}ffAb(@=xz)lOAFwxkwY&ROU#%j6U5RNSOk+14R-q9a8o|cHd z-WU=;&{lMz3*&yes|PwxLt^0ZM~=P2()!gW(Au1I?~2Hy{mtuZ6^YKNADWK z2#gJj!Q2Y1Wk#0vvyH89IjtAIazQ2mBsA%qgp;(jpkA5_Eg=@b1BoX8>PRTuW9+_0(`T__Sh}fa@#(xs*gvUp@sisFJMb;8swP{S!R?> z-s^-g@24TllEMN9v_wjz@tYDEk;QNN2b!ssGT6YOa3rF@h~ZRjfRM5_{-Sc5R=Be2 zcs3osm$O_~uot%$Z`fzRzU-#I=13c-(D?v|z;1gWPkR@yu)UU3#gWB{E=HZdIk#lv zV6WqB+HL9f%HN~~?bU!u@ZqgFdm1z);Mc(yY{j4Lima}IU7;BdfZeyTF-_ZRw}``g zz>fJRVMepCXLsR;iPc=kn>}l9uGOk*H2mF~a2QghVLKIX%igSP**@U$Ot$O_nl@d> z2Ggj?W`meHRWCd7K#ovTtw1KL)wJzX0K96y7fFcs?Mu6G= `@Lwv3%sO-Ui)HE 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 JihHrq`Y&!*gaQBn literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/show.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/show.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..23703d2a712fecc8d905bdd2b67b81571f3fa8e3 GIT binary patch literal 6325 zcmb_g&2!t<5eGmJ1V2R4vTVzC;vjJxn;DZ%TQ^Bv)vYU8u^UJBNKTqEaao8Dq9}nM zdI0SR1D@ngl$oYYXL{(N2P&ufAIV?P6OQevm;M3n!Ts%mq@Y;IOw*EshlhP%`}Xbr zcK5wMHI-BFd+W^$_TCvq`3HR@e>y&XhR6Fe3ZV$qRoZGzRjIDIT2143s+Ph#wSIQ?;pfu~y`7)17XYY9&>1wBa#lW?!ux ze@78nk$bF&oRi;8)n-Lr6do(J6QU%FV*0UKJ1MkPrF`t4;7%#4(X_qhb=|)2)LZRd zSNhAK<(3>r+_RfckH%M48q17Zz@=uA;Ha2HV+xA=Cj%BZ5 zajV;Ltgf`$UFo3J^KI94gw?YfTXxg&syQBee*>MEQ>*2no3*mEP-%4AJ-20de5-A@ zTx-Lzg(Iza{wfa(Ugei%UFgYf)B32}qlLW(*8FJx>sGZ|z28t1Tc@3yc&71q*HQS2 zuZGI5wyA|`sQn&V6DpgjOFJ>%OlsfPNE;xF>~f%0)`Lu?vfgqX zFG|O+oabZ5bzkra%YKfU6&dslj`UZvk5 z5j&#tXv1;bN~_=8etYNYBWk+>4tz&;Z1)O|kQCIr;z2p8y&ZWRJidg-n?<3hGpeC# zil&bK|28tgY(lfDB$0m zN{fmtigH@c;T2^@+AL4gS9-he$ek!N9`hn~=i(eSr)0nLIw~FwRa9Ng;n6jdBnzw6 zpBb922GdE|VnjJh`a(N{zU1olc31RWsu$|@?Y`}fS~B&z=r%x3_dOUbbf?)N<(AHN zzlHZhr}L0cR$d}rrbZgma9p=ukC|jn&!SZlyR53D0UqJHsp^KV=~^Mr^h4HKLVE_! zdFp&$Q>Z0;sW}t@Zp6bJHH*wPQ%65)y_A%^tQNhV;zW%8S6a%I`HvM!6 zt=QG51#Qp``D@=8X2`yWW|-Pn*`gWg2JtwP#)Uj$QTalB@VC#DJy<@TES?-NA8YL? z!~8z47wXiytBTxT(u1_f4-7mRzpw{{*__(dzEI^k^e&3RzKXhm`ZU!CrkG-`P3Ahw z$Xn#KvkA&{fCO8 z38wyz=R(;yjJ|ds7)qhne9?lJ$d2yuvAQ z25W0l52uH7VctJ2&OrM4-)g57n)3^78!cG*?7R{h=ywZ9VC-T}@d7C655Uj%Cn66V zcro}FJCb*7V6?P^M_p-ItXCG6w?vV{!Ng`v!Wu6JR-~m@JTW+_( z-te*o9865c_))cPPdsAm0!Aj~SvF4tG_{&e$C0)Vr+IPWKVx50^*`}1lD8z!l4QiQ zE>@jpvqE5VktY(c(*``!PV6`j*%+(}5TU@C!N$lco3Nk!f5<7ODj%@a71(9fgC{d6JInT}Nd+>=0*!`ZNW34etdM z%-QV6+5pxaYJ1972B&|BLjsy|N>W%OzlS19A(SFFHj&){YRd1U!y+EfKw;o-D#6^n zI5fHBm90+Khg0r%#5L=J_f)%V9pa9>FL5~G4)OxJe5SAk6B3!ey2<##zUI(i5<0EQ zg9$cyYt}&BLs%hHfS5W|Vqn=aXp@_xZI-p?<{=UB;hh}MQ;ZL9^YHPNHAzddTu>(& zMdnE3#Mh3JWwVSP2WPnY?Pu6@$fJ=*fcKj?yra%IaokX*F$Z2$fcM>mnzBcF5;G`& z03L9D#Yq6ntzSFDcZty=3WO8*8>;b4$3M9B|6&;`#iAooNBKuxxka1w9KVc6d*s{` zjQtqh*waNPj~2^qVwfTXMK#G+KMSsY7gmo{g^51K*1}#=Atl;_Qk_pu%hAXsylU3T0LP2(4pnO9`iUl%oBTmLk~_SRepm z%cbCoKr}MPASx-^i}GWYt*`AYN5;y{g}W<@&v8dk#oQrbjJe}@VF>fuN2EBGLs@&O zUXBB46@fGo4u8z7>K?`FZ!q12)#p~7nDhZ!ktuGfL!i}WDnyi#kU!#kt?Na44}K@o zH@mHlB-k9Oex&xG_&Njo;ghkyD-Vd5ICn|#@I;rlFr6fgr0~)uW|$30Rwdt~;_&io zAWcLNneW}ae`E2+{Tl)06mfoc;Gh0y2_0}Je?csoaBLh!elnPos`7*V=LIsIj-k^dMGq%56%j1LY zG@NL55sv#d!VG$kgQKXhVSDxQUZNR-!0}hzZFP_(7m_sC9me(~0ZOE=<02$VH(aDu zQ3~Cn99v~P4r#S5eeY2V24mR0p3?!#uG1-(9Tc@Z=SmF6UX*FKAPwYWKc(3- zBdm_H6mNkUB-iGcw=Q`(6dkc@}qEIrFnw7L7ywu5OdP-MkG&4Jg2ru{pevkg93iiz|mFPx2Gy`2pb3f zOZVB=1*uA<5}3;f;VHC@{jCz@KZrdp)5z+B{A!FpOd&5FOx+p-5z{^-TJ8oT5)*z! zgi=h1p^3>gp6yPIQB3)WD1|$t{D?_}F+pJ^zE<#<^d?9QJHhmbE-Gs~+(b$o%)U2< z%p~t0P}9`ykvjqoVvq0h`DyT*Vy(0V~K9`uJQd$@bZG) zp?rX2k;GNzfvYR0qpZ{EBP&9-Ch2BFHmP6?6{z95W$I9xCh00nS}1DMql=w7Ukw2P z)fNLulsf?MD9v6(N*cv3`M@u~3fdp=cqBtb2d)4`7!?RN68|}M4(I?BdZueL=urZW zP#O29HwC1U<|}JUOXX8^F|^+I`?%<-OATbW8eDY|q*CAj*GB%Q8iQku;d$h(Rk{`u zUCG`iI-8)ND_#C#f+})p*JCdfo#P(ko5O0uZB^HBBUc|?AxgRhI;s;Kg5USh4Hu<+ z=f;<4(cIzbc%dp>L4yw_%EGbS;R`!i#>BD5%TtX&lXstx@I=g!IUnDVT_+#Pmu&@H TvYBduP#RAOWiC}ZZ+`e64lFUo literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/uninstall.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/uninstall.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..b8ec3db86806e01b644776c0eb5406727388230b GIT binary patch literal 2694 zcmZuzUvC@75#PQ4q)5w>+8{yNbd%JH378a+7Hv@&L6Ep8inc}&#{qIha5~*C$(8P( zcK5`Hpk895c~UrZD&d$!xpWn>#@o?BD@ci~S zchZ0E5b|%FY(G9sK7dc3!@vorIVosNDbh~v6mINV+ReSfk9|vfc~FFLXlXx>ieB8a zbddLpop{I6VLm8^@zByyeyiAxcPaTJ;XU4eN_b!RB7EY-xB1Q^G8+5`&L$(;?xx4O z${QmRS=5y>z}m~wvMObk=5i^LGA#r!!;h+>NJ|dn!6Tuytjdn_SNWwZaoe9tZPGkX z4Xph^sY(HJzfP4Fi4tdxRH6{2(ZKzwT#F(Z7Ce{^jG&nmdrz8T(tccKi!=zYFI3Y%*DkGWN2} zSh4%tu(5X94H+b7^I+b4@a@8`D!ZNP#IvDJoLOjD3)Lrna6s#QgqY6w9h|Dpg?%k5$txgmaM#i{Qz~RktAI3WKlqalq6-Mfth`yeRC0ZImRklqN~q zC@XjZ-oUvjw-nkM*cPGM13;fp1_iLzXR2!Ik=uG&Ec`3_L3yaQ>~Na zTk_q5LsQg;P>tiJL{terUd)Ba$FiB7{qEw|3tT${3jp(FnjdECHl`0Z6$@3QUI9aY z0iXUQ4215}fI7sXoAsExS5SjseAHk>p1;dIwBP;rx zUb>Q8dMoDv`Qn{RA0X?m=m|8eE9Wv;1t+fBUj-}Act}5?_sQ8ltotB+?=m#ODg(|5OQPbo8$~z5saD@fpJ?lRw))G8> z2TmG*{E&yI9*@AHXceh%R?)Lt&j}@G-`IlaJ%oN8Nw_>xfbz&`!>+vBP_OTY9E^|=RzGUOKyTCj zHHiP$_W}U6XXpJF&I`|XXz(KN2Eg-31o9qT{^SR+R!upIu!zwjDB^yCacXj;2T5|) zq?$@Bd7dO&KD+^|3LUYn;x-T(a}rUn?|Fj*%Y8W7 z!$YTyfjbg*J0Q@$4mqDB&^CFcChOY-kT9{gr_EmbhLyOk`$?9|$#DvQMY;x{JXG`Z z9|}PRHZu56t$p?TGB+2vg+;vg{bks0G4t~Iz@GptHMH6cdahn$?9qf@1qwQ<2G>MrJL9NKWI%7mjD0& literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/wheel.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/wheel.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..2e545230d887701facc25f4adcc1945301a77bd0 GIT binary patch literal 5246 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 literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/commands/check.py b/venv/lib/python3.8/site-packages/pip/_internal/commands/check.py new file mode 100644 index 0000000..9689446 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/commands/check.py @@ -0,0 +1,45 @@ +# The following comment should be removed at some point in the future. +# mypy: disallow-untyped-defs=False + +import logging + +from pip._internal.cli.base_command import Command +from pip._internal.operations.check import ( + check_package_set, + create_package_set_from_installed, +) +from pip._internal.utils.misc import write_output + +logger = logging.getLogger(__name__) + + +class CheckCommand(Command): + """Verify installed packages have compatible dependencies.""" + + usage = """ + %prog [options]""" + + def run(self, options, args): + package_set, parsing_probs = create_package_set_from_installed() + missing, conflicting = check_package_set(package_set) + + for project_name in missing: + version = package_set[project_name].version + for dependency in missing[project_name]: + write_output( + "%s %s requires %s, which is not installed.", + project_name, version, dependency[0], + ) + + for project_name in conflicting: + version = package_set[project_name].version + 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, + ) + + if missing or conflicting or parsing_probs: + return 1 + else: + write_output("No broken requirements found.") diff --git a/venv/lib/python3.8/site-packages/pip/_internal/commands/completion.py b/venv/lib/python3.8/site-packages/pip/_internal/commands/completion.py new file mode 100644 index 0000000..c532806 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/commands/completion.py @@ -0,0 +1,96 @@ +# The following comment should be removed at some point in the future. +# mypy: disallow-untyped-defs=False + +from __future__ import absolute_import + +import sys +import textwrap + +from pip._internal.cli.base_command import Command +from pip._internal.utils.misc import get_prog + +BASE_COMPLETION = """ +# pip %(shell)s completion start%(script)s# pip %(shell)s completion end +""" + +COMPLETION_SCRIPTS = { + 'bash': """ + _pip_completion() + { + COMPREPLY=( $( COMP_WORDS="${COMP_WORDS[*]}" \\ + COMP_CWORD=$COMP_CWORD \\ + PIP_AUTO_COMPLETE=1 $1 2>/dev/null ) ) + } + complete -o default -F _pip_completion %(prog)s + """, + '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)s + """, + 'fish': """ + function __fish_complete_pip + set -lx COMP_WORDS (commandline -o) "" + set -lx COMP_CWORD ( \\ + math (contains -i -- (commandline -t) $COMP_WORDS)-1 \\ + ) + set -lx PIP_AUTO_COMPLETE 1 + string split \\ -- (eval $COMP_WORDS[1]) + end + complete -fa "(__fish_complete_pip)" -c %(prog)s + """, +} + + +class CompletionCommand(Command): + """A helper command to be used for command completion.""" + + ignore_require_venv = True + + def __init__(self, *args, **kw): + super(CompletionCommand, self).__init__(*args, **kw) + + cmd_opts = self.cmd_opts + + cmd_opts.add_option( + '--bash', '-b', + action='store_const', + const='bash', + dest='shell', + help='Emit completion code for bash') + cmd_opts.add_option( + '--zsh', '-z', + action='store_const', + const='zsh', + dest='shell', + help='Emit completion code for zsh') + cmd_opts.add_option( + '--fish', '-f', + action='store_const', + const='fish', + dest='shell', + help='Emit completion code for fish') + + self.parser.insert_option_group(0, cmd_opts) + + def run(self, options, args): + """Prints the completion code of the given shell""" + shells = COMPLETION_SCRIPTS.keys() + shell_options = ['--' + shell for shell in sorted(shells)] + if options.shell in shells: + script = textwrap.dedent( + COMPLETION_SCRIPTS.get(options.shell, '') % { + 'prog': get_prog(), + } + ) + print(BASE_COMPLETION % {'script': script, 'shell': options.shell}) + else: + sys.stderr.write( + 'ERROR: You must pass %s\n' % ' or '.join(shell_options) + ) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/commands/configuration.py b/venv/lib/python3.8/site-packages/pip/_internal/commands/configuration.py new file mode 100644 index 0000000..efcf5bb --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/commands/configuration.py @@ -0,0 +1,233 @@ +# The following comment should be removed at some point in the future. +# mypy: disallow-untyped-defs=False + +import logging +import os +import subprocess + +from pip._internal.cli.base_command import Command +from pip._internal.cli.status_codes import ERROR, SUCCESS +from pip._internal.configuration import ( + Configuration, + get_configuration_files, + kinds, +) +from pip._internal.exceptions import PipError +from pip._internal.utils.misc import get_prog, write_output + +logger = logging.getLogger(__name__) + + +class ConfigurationCommand(Command): + """Manage local and global configuration. + + Subcommands: + + 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 + + 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 + default. + """ + + ignore_require_venv = True + usage = """ + %prog [] list + %prog [] [--editor ] edit + + %prog [] get name + %prog [] set name value + %prog [] unset name + """ + + def __init__(self, *args, **kwargs): + super(ConfigurationCommand, self).__init__(*args, **kwargs) + + self.configuration = None + + self.cmd_opts.add_option( + '--editor', + dest='editor', + action='store', + default=None, + help=( + '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', + default=False, + help='Use the system-wide configuration file only' + ) + + self.cmd_opts.add_option( + '--user', + dest='user_file', + action='store_true', + default=False, + help='Use the user configuration file only' + ) + + self.cmd_opts.add_option( + '--site', + dest='site_file', + action='store_true', + default=False, + help='Use the current environment configuration file only' + ) + + self.parser.insert_option_group(0, self.cmd_opts) + + def run(self, options, args): + handlers = { + "list": self.list_values, + "edit": self.open_in_editor, + "get": self.get_name, + "set": self.set_name_value, + "unset": self.unset_name + } + + # Determine action + if not args or args[0] not in handlers: + logger.error("Need an action ({}) to perform.".format( + ", ".join(sorted(handlers))) + ) + return ERROR + + action = args[0] + + # Determine which configuration files are to be loaded + # Depends on whether the command is modifying. + try: + load_only = self._determine_file( + options, need_value=(action in ["get", "set", "unset", "edit"]) + ) + except PipError as e: + logger.error(e.args[0]) + return ERROR + + # Load a new configuration + self.configuration = Configuration( + isolated=options.isolated_mode, load_only=load_only + ) + self.configuration.load() + + # Error handling happens here, not in the action-handlers. + try: + handlers[action](options, args[1:]) + except PipError as e: + logger.error(e.args[0]) + return ERROR + + return SUCCESS + + def _determine_file(self, options, need_value): + 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: + return None + # Default to user, unless there's a site file. + elif any( + os.path.exists(site_config_file) + for site_config_file in get_configuration_files()[kinds.SITE] + ): + return kinds.SITE + else: + return kinds.USER + elif len(file_options) == 1: + return file_options[0] + + raise PipError( + "Need exactly one file to operate upon " + "(--user, --site, --global) to perform." + ) + + def list_values(self, options, args): + 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): + 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): + 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): + key = self._get_n_args(args, "unset [name]", n=1) + self.configuration.unset_value(key) + + self._save_configuration() + + def open_in_editor(self, options, args): + editor = self._determine_editor(options) + + fname = self.configuration.get_file_to_edit() + if fname is None: + raise PipError("Could not determine appropriate file.") + + try: + subprocess.check_call([editor, fname]) + except subprocess.CalledProcessError as e: + raise PipError( + "Editor Subprocess exited with exit code {}" + .format(e.returncode) + ) + + def _get_n_args(self, args, example, n): + """Helper to make sure the command got the right number of arguments + """ + if len(args) != n: + msg = ( + 'Got unexpected number of arguments, expected {}. ' + '(example: "{} config {}")' + ).format(n, get_prog(), example) + raise PipError(msg) + + if n == 1: + return args[0] + else: + return args + + def _save_configuration(self): + # We successfully ran a modifying command. Need to save the + # configuration. + try: + self.configuration.save() + except Exception: + logger.error( + "Unable to save configuration. Please report this as a bug.", + exc_info=1 + ) + raise PipError("Internal Error.") + + def _determine_editor(self, options): + if options.editor is not None: + return options.editor + elif "VISUAL" in os.environ: + return os.environ["VISUAL"] + elif "EDITOR" in os.environ: + return os.environ["EDITOR"] + else: + raise PipError("Could not determine editor to use.") diff --git a/venv/lib/python3.8/site-packages/pip/_internal/commands/debug.py b/venv/lib/python3.8/site-packages/pip/_internal/commands/debug.py new file mode 100644 index 0000000..fe93b3a --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/commands/debug.py @@ -0,0 +1,142 @@ +# The following comment should be removed at some point in the future. +# mypy: disallow-untyped-defs=False + +from __future__ import absolute_import + +import locale +import logging +import os +import sys + +from pip._vendor.certifi import where + +from pip._internal.cli import cmdoptions +from pip._internal.cli.base_command import Command +from pip._internal.cli.cmdoptions import make_target_python +from pip._internal.cli.status_codes import SUCCESS +from pip._internal.utils.logging import indent_log +from pip._internal.utils.misc import get_pip_version +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import Any, List, Optional + from optparse import Values + +logger = logging.getLogger(__name__) + + +def show_value(name, value): + # type: (str, Optional[str]) -> None + logger.info('{}: {}'.format(name, value)) + + +def show_sys_implementation(): + # type: () -> None + logger.info('sys.implementation:') + if hasattr(sys, 'implementation'): + implementation = sys.implementation # type: ignore + implementation_name = implementation.name + else: + implementation_name = '' + + with indent_log(): + show_value('name', implementation_name) + + +def show_tags(options): + # type: (Values) -> None + tag_limit = 10 + + target_python = make_target_python(options) + tags = target_python.get_tags() + + # Display the target options that were explicitly provided. + formatted_target = target_python.format_given() + suffix = '' + if formatted_target: + suffix = ' (target: {})'.format(formatted_target) + + msg = 'Compatible tags: {}{}'.format(len(tags), suffix) + logger.info(msg) + + if options.verbose < 1 and len(tags) > tag_limit: + tags_limited = True + tags = tags[:tag_limit] + else: + tags_limited = False + + with indent_log(): + for tag in tags: + logger.info(str(tag)) + + if tags_limited: + msg = ( + '...\n' + '[First {tag_limit} tags shown. Pass --verbose to show all.]' + ).format(tag_limit=tag_limit) + logger.info(msg) + + +def ca_bundle_info(config): + levels = set() + for key, value in config.items(): + levels.add(key.split('.')[0]) + + if not levels: + return "Not specified" + + 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' + + levels.remove('global') + return ", ".join(levels) + + +class DebugCommand(Command): + """ + Display debug information. + """ + + usage = """ + %prog """ + ignore_require_venv = True + + def __init__(self, *args, **kw): + super(DebugCommand, self).__init__(*args, **kw) + + cmd_opts = self.cmd_opts + cmdoptions.add_target_python_options(cmd_opts) + self.parser.insert_option_group(0, cmd_opts) + self.parser.config.load() + + def run(self, options, args): + # type: (Values, List[Any]) -> 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( + 'locale.getpreferredencoding', locale.getpreferredencoding(), + ) + 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("pip._vendor.certifi.where()", where()) + + show_tags(options) + + return SUCCESS diff --git a/venv/lib/python3.8/site-packages/pip/_internal/commands/download.py b/venv/lib/python3.8/site-packages/pip/_internal/commands/download.py new file mode 100644 index 0000000..24da3eb --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/commands/download.py @@ -0,0 +1,147 @@ +# The following comment should be removed at some point in the future. +# mypy: disallow-untyped-defs=False + +from __future__ import absolute_import + +import logging +import os + +from pip._internal.cli import cmdoptions +from pip._internal.cli.cmdoptions import make_target_python +from pip._internal.cli.req_command import RequirementCommand +from pip._internal.req import RequirementSet +from pip._internal.req.req_tracker import get_requirement_tracker +from pip._internal.utils.misc import ensure_dir, normalize_path, write_output +from pip._internal.utils.temp_dir import TempDirectory + +logger = logging.getLogger(__name__) + + +class DownloadCommand(RequirementCommand): + """ + Download packages from: + + - PyPI (and other indexes) using requirement specifiers. + - VCS project urls. + - Local project directories. + - Local or remote source archives. + + pip also supports downloading from "requirements files", which provide + an easy way to specify a whole environment to be downloaded. + """ + + usage = """ + %prog [options] [package-index-options] ... + %prog [options] -r [package-index-options] ... + %prog [options] ... + %prog [options] ... + %prog [options] ...""" + + def __init__(self, *args, **kw): + super(DownloadCommand, self).__init__(*args, **kw) + + cmd_opts = self.cmd_opts + + cmd_opts.add_option(cmdoptions.constraints()) + cmd_opts.add_option(cmdoptions.requirements()) + cmd_opts.add_option(cmdoptions.build_dir()) + cmd_opts.add_option(cmdoptions.no_deps()) + cmd_opts.add_option(cmdoptions.global_options()) + cmd_opts.add_option(cmdoptions.no_binary()) + cmd_opts.add_option(cmdoptions.only_binary()) + cmd_opts.add_option(cmdoptions.prefer_binary()) + cmd_opts.add_option(cmdoptions.src()) + cmd_opts.add_option(cmdoptions.pre()) + cmd_opts.add_option(cmdoptions.no_clean()) + cmd_opts.add_option(cmdoptions.require_hashes()) + cmd_opts.add_option(cmdoptions.progress_bar()) + cmd_opts.add_option(cmdoptions.no_build_isolation()) + cmd_opts.add_option(cmdoptions.use_pep517()) + cmd_opts.add_option(cmdoptions.no_use_pep517()) + + cmd_opts.add_option( + '-d', '--dest', '--destination-dir', '--destination-directory', + dest='download_dir', + metavar='dir', + default=os.curdir, + help=("Download packages into ."), + ) + + cmdoptions.add_target_python_options(cmd_opts) + + 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, cmd_opts) + + def run(self, options, args): + options.ignore_installed = True + # editable doesn't really make sense for `pip download`, but the bowels + # of the RequirementSet code require that property. + options.editables = [] + + cmdoptions.check_dist_restriction(options) + + options.download_dir = normalize_path(options.download_dir) + + ensure_dir(options.download_dir) + + session = self.get_default_session(options) + + target_python = make_target_python(options) + finder = self._build_package_finder( + options=options, + session=session, + target_python=target_python, + ) + build_delete = (not (options.no_clean or options.build_dir)) + + with get_requirement_tracker() as req_tracker, TempDirectory( + options.build_dir, delete=build_delete, kind="download" + ) as directory: + + requirement_set = RequirementSet() + self.populate_requirement_set( + requirement_set, + args, + options, + finder, + session, + None + ) + + preparer = self.make_requirement_preparer( + temp_build_dir=directory, + options=options, + req_tracker=req_tracker, + session=session, + finder=finder, + download_dir=options.download_dir, + use_user_site=False, + ) + + resolver = self.make_resolver( + preparer=preparer, + finder=finder, + options=options, + py_version_info=options.python_version, + ) + + self.trace_basic_info(finder) + + resolver.resolve(requirement_set) + + downloaded = ' '.join([ + req.name for req in requirement_set.successfully_downloaded + ]) + if downloaded: + write_output('Successfully downloaded %s', downloaded) + + # Clean up + if not options.no_clean: + requirement_set.cleanup_files() + + return requirement_set diff --git a/venv/lib/python3.8/site-packages/pip/_internal/commands/freeze.py b/venv/lib/python3.8/site-packages/pip/_internal/commands/freeze.py new file mode 100644 index 0000000..e96c083 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/commands/freeze.py @@ -0,0 +1,103 @@ +# The following comment should be removed at some point in the future. +# mypy: disallow-untyped-defs=False + +from __future__ import absolute_import + +import sys + +from pip._internal.cache import WheelCache +from pip._internal.cli import cmdoptions +from pip._internal.cli.base_command import Command +from pip._internal.models.format_control import FormatControl +from pip._internal.operations.freeze import freeze +from pip._internal.utils.compat import stdlib_pkgs + +DEV_PKGS = {'pip', 'setuptools', 'distribute', 'wheel', 'pkg-resources'} + + +class FreezeCommand(Command): + """ + Output installed packages in requirements format. + + packages are listed in a case-insensitive sorted order. + """ + + usage = """ + %prog [options]""" + log_streams = ("ext://sys.stderr", "ext://sys.stderr") + + def __init__(self, *args, **kw): + super(FreezeCommand, self).__init__(*args, **kw) + + 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.") + self.cmd_opts.add_option( + '-f', '--find-links', + dest='find_links', + action='append', + default=[], + metavar='URL', + help='URL for finding packages, which will be added to the ' + 'output.') + self.cmd_opts.add_option( + '-l', '--local', + dest='local', + action='store_true', + default=False, + 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', + default=False, + 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:' + ' %s' % ', '.join(DEV_PKGS)) + self.cmd_opts.add_option( + '--exclude-editable', + dest='exclude_editable', + action='store_true', + help='Exclude editable package from output.') + + self.parser.insert_option_group(0, self.cmd_opts) + + def run(self, options, args): + format_control = FormatControl(set(), set()) + wheel_cache = WheelCache(options.cache_dir, format_control) + skip = set(stdlib_pkgs) + if not options.freeze_all: + skip.update(DEV_PKGS) + + cmdoptions.check_list_path_option(options) + + freeze_kwargs = dict( + requirement=options.requirements, + find_links=options.find_links, + local_only=options.local, + user_only=options.user, + paths=options.path, + skip_regex=options.skip_requirements_regex, + isolated=options.isolated_mode, + wheel_cache=wheel_cache, + skip=skip, + exclude_editable=options.exclude_editable, + ) + + try: + for line in freeze(**freeze_kwargs): + sys.stdout.write(line + '\n') + finally: + wheel_cache.cleanup() diff --git a/venv/lib/python3.8/site-packages/pip/_internal/commands/hash.py b/venv/lib/python3.8/site-packages/pip/_internal/commands/hash.py new file mode 100644 index 0000000..1dc7fb0 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/commands/hash.py @@ -0,0 +1,58 @@ +# The following comment should be removed at some point in the future. +# mypy: disallow-untyped-defs=False + +from __future__ import absolute_import + +import hashlib +import logging +import sys + +from pip._internal.cli.base_command import Command +from pip._internal.cli.status_codes import ERROR +from pip._internal.utils.hashes import FAVORITE_HASH, STRONG_HASHES +from pip._internal.utils.misc import read_chunks, write_output + +logger = logging.getLogger(__name__) + + +class HashCommand(Command): + """ + Compute a hash of a local package archive. + + These can be used with --hash in a requirements file to do repeatable + installs. + """ + + usage = '%prog [options] ...' + ignore_require_venv = True + + def __init__(self, *args, **kw): + super(HashCommand, self).__init__(*args, **kw) + self.cmd_opts.add_option( + '-a', '--algorithm', + dest='algorithm', + choices=STRONG_HASHES, + action='store', + default=FAVORITE_HASH, + help='The hash algorithm to use: one of %s' % + ', '.join(STRONG_HASHES)) + self.parser.insert_option_group(0, self.cmd_opts) + + def run(self, options, args): + 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)) + + +def _hash_of_file(path, algorithm): + """Return the hash digest of a file.""" + with open(path, 'rb') as archive: + hash = hashlib.new(algorithm) + for chunk in read_chunks(archive): + hash.update(chunk) + return hash.hexdigest() diff --git a/venv/lib/python3.8/site-packages/pip/_internal/commands/help.py b/venv/lib/python3.8/site-packages/pip/_internal/commands/help.py new file mode 100644 index 0000000..75af999 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/commands/help.py @@ -0,0 +1,41 @@ +# The following comment should be removed at some point in the future. +# mypy: disallow-untyped-defs=False + +from __future__ import absolute_import + +from pip._internal.cli.base_command import Command +from pip._internal.cli.status_codes import SUCCESS +from pip._internal.exceptions import CommandError + + +class HelpCommand(Command): + """Show help for commands""" + + usage = """ + %prog """ + ignore_require_venv = True + + def run(self, options, args): + from pip._internal.commands import ( + commands_dict, create_command, get_similar_commands, + ) + + try: + # 'pip help' with no args is handled by pip.__init__.parseopt() + cmd_name = args[0] # the command we need help for + except IndexError: + return SUCCESS + + if cmd_name not in commands_dict: + guess = get_similar_commands(cmd_name) + + msg = ['unknown command "%s"' % cmd_name] + if guess: + msg.append('maybe you meant "%s"' % guess) + + raise CommandError(' - '.join(msg)) + + command = create_command(cmd_name) + command.parser.print_help() + + return SUCCESS diff --git a/venv/lib/python3.8/site-packages/pip/_internal/commands/install.py b/venv/lib/python3.8/site-packages/pip/_internal/commands/install.py new file mode 100644 index 0000000..cb2fb28 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/commands/install.py @@ -0,0 +1,727 @@ +# The following comment should be removed at some point in the future. +# It's included for now because without it InstallCommand.run() has a +# couple errors where we have to know req.name is str rather than +# Optional[str] for the InstallRequirement req. +# mypy: strict-optional=False +# mypy: disallow-untyped-defs=False + +from __future__ import absolute_import + +import errno +import logging +import operator +import os +import shutil +import site +from optparse import SUPPRESS_HELP + +from pip._vendor import pkg_resources +from pip._vendor.packaging.utils import canonicalize_name + +from pip._internal.cache import WheelCache +from pip._internal.cli import cmdoptions +from pip._internal.cli.cmdoptions import make_target_python +from pip._internal.cli.req_command import RequirementCommand +from pip._internal.cli.status_codes import ERROR, SUCCESS +from pip._internal.exceptions import ( + CommandError, + InstallationError, + PreviousBuildDirError, +) +from pip._internal.locations import distutils_scheme +from pip._internal.operations.check import check_install_conflicts +from pip._internal.req import RequirementSet, install_given_reqs +from pip._internal.req.req_tracker import get_requirement_tracker +from pip._internal.utils.deprecation import deprecated +from pip._internal.utils.distutils_args import parse_distutils_args +from pip._internal.utils.filesystem import test_writable_dir +from pip._internal.utils.misc import ( + ensure_dir, + get_installed_version, + protect_pip_from_modification_on_windows, + write_output, +) +from pip._internal.utils.temp_dir import TempDirectory +from pip._internal.utils.typing import MYPY_CHECK_RUNNING +from pip._internal.utils.virtualenv import virtualenv_no_global +from pip._internal.wheel_builder import build, should_build_for_install_command + +if MYPY_CHECK_RUNNING: + from optparse import Values + from typing import Any, Iterable, List, Optional + + from pip._internal.models.format_control import FormatControl + from pip._internal.req.req_install import InstallRequirement + from pip._internal.wheel_builder import BinaryAllowedPredicate + +from pip._internal.locations import running_under_virtualenv + +logger = logging.getLogger(__name__) + + +def get_check_binary_allowed(format_control): + # type: (FormatControl) -> BinaryAllowedPredicate + def check_binary_allowed(req): + # type: (InstallRequirement) -> bool + if req.use_pep517: + return True + canonical_name = canonicalize_name(req.name) + allowed_formats = format_control.get_allowed_formats(canonical_name) + return "binary" in allowed_formats + + return check_binary_allowed + + +class InstallCommand(RequirementCommand): + """ + Install packages from: + + - PyPI (and other indexes) using requirement specifiers. + - VCS project urls. + - Local project directories. + - Local or remote source archives. + + pip also supports installing from "requirements files", which provide + an easy way to specify a whole environment to be installed. + """ + + usage = """ + %prog [options] [package-index-options] ... + %prog [options] -r [package-index-options] ... + %prog [options] [-e] ... + %prog [options] [-e] ... + %prog [options] ...""" + + def __init__(self, *args, **kw): + super(InstallCommand, self).__init__(*args, **kw) + + cmd_opts = self.cmd_opts + + cmd_opts.add_option(cmdoptions.requirements()) + cmd_opts.add_option(cmdoptions.constraints()) + cmd_opts.add_option(cmdoptions.no_deps()) + cmd_opts.add_option(cmdoptions.pre()) + + cmd_opts.add_option(cmdoptions.editable()) + cmd_opts.add_option( + '-t', '--target', + dest='target_dir', + metavar='dir', + default=None, + help='Install packages into . ' + 'By default this will not replace existing files/folders in ' + '. Use --upgrade to replace existing packages in ' + 'with new versions.' + ) + cmdoptions.add_target_python_options(cmd_opts) + + 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.) On Debian systems, this is the " + "default when running outside of a virtual environment " + "and not as root.") + + cmd_opts.add_option( + '--no-user', + dest='use_system_location', + action='store_true', + help=SUPPRESS_HELP) + cmd_opts.add_option( + '--root', + dest='root_path', + metavar='dir', + default=None, + help="Install everything relative to this alternate root " + "directory.") + cmd_opts.add_option( + '--prefix', + dest='prefix_path', + metavar='dir', + default=None, + help="Installation prefix where lib, bin and other top-level " + "folders are placed") + + cmd_opts.add_option( + '--system', + dest='use_system_location', + action='store_true', + help="Install using the system scheme (overrides --user on " + "Debian systems)") + + cmd_opts.add_option(cmdoptions.build_dir()) + + cmd_opts.add_option(cmdoptions.src()) + + 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.' + ) + + 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).' + ) + + cmd_opts.add_option( + '--force-reinstall', + dest='force_reinstall', + action='store_true', + help='Reinstall all packages even if they are already ' + 'up-to-date.') + + 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!' + ) + + cmd_opts.add_option(cmdoptions.ignore_requires_python()) + cmd_opts.add_option(cmdoptions.no_build_isolation()) + cmd_opts.add_option(cmdoptions.use_pep517()) + cmd_opts.add_option(cmdoptions.no_use_pep517()) + + cmd_opts.add_option(cmdoptions.install_options()) + cmd_opts.add_option(cmdoptions.global_options()) + + cmd_opts.add_option( + "--compile", + action="store_true", + dest="compile", + default=True, + help="Compile Python source files to bytecode", + ) + + cmd_opts.add_option( + "--no-compile", + action="store_false", + dest="compile", + help="Do not compile Python source files to bytecode", + ) + + cmd_opts.add_option( + "--no-warn-script-location", + action="store_false", + dest="warn_script_location", + default=True, + help="Do not warn when installing scripts outside PATH", + ) + cmd_opts.add_option( + "--no-warn-conflicts", + action="store_false", + dest="warn_about_conflicts", + default=True, + help="Do not warn about broken dependencies", + ) + + cmd_opts.add_option(cmdoptions.no_binary()) + cmd_opts.add_option(cmdoptions.only_binary()) + cmd_opts.add_option(cmdoptions.prefer_binary()) + cmd_opts.add_option(cmdoptions.no_clean()) + cmd_opts.add_option(cmdoptions.require_hashes()) + cmd_opts.add_option(cmdoptions.progress_bar()) + + 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, cmd_opts) + + def run(self, options, args): + # type: (Values, List[Any]) -> int + cmdoptions.check_install_build_global(options) + upgrade_strategy = "to-satisfy-only" + if options.upgrade: + upgrade_strategy = options.upgrade_strategy + + cmdoptions.check_dist_restriction(options, check_target=True) + + if options.python_version: + python_versions = [options.python_version] + else: + python_versions = None + + # compute install location defaults + if (not options.use_user_site and not options.prefix_path and not + options.target_dir and not options.use_system_location): + if not running_under_virtualenv() and os.geteuid() != 0: + options.use_user_site = True + + if options.use_system_location: + options.use_user_site = False + + options.src_dir = os.path.abspath(options.src_dir) + install_options = options.install_options or [] + + options.use_user_site = decide_user_install( + options.use_user_site, + prefix_path=options.prefix_path, + target_dir=options.target_dir, + root_path=options.root_path, + isolated_mode=options.isolated_mode, + ) + + target_temp_dir = None # type: Optional[TempDirectory] + target_temp_dir_path = None # type: Optional[str] + 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)): + raise CommandError( + "Target path exists but is not a directory, will not " + "continue." + ) + + # Create a target directory for using with the target option + target_temp_dir = TempDirectory(kind="target") + target_temp_dir_path = target_temp_dir.path + + global_options = options.global_options or [] + + session = self.get_default_session(options) + + target_python = make_target_python(options) + finder = self._build_package_finder( + options=options, + session=session, + target_python=target_python, + ignore_requires_python=options.ignore_requires_python, + ) + build_delete = (not (options.no_clean or options.build_dir)) + wheel_cache = WheelCache(options.cache_dir, options.format_control) + + with get_requirement_tracker() as req_tracker, TempDirectory( + options.build_dir, delete=build_delete, kind="install" + ) as directory: + requirement_set = RequirementSet( + check_supported_wheels=not options.target_dir, + ) + + try: + self.populate_requirement_set( + requirement_set, args, options, finder, session, + wheel_cache + ) + + warn_deprecated_install_options( + requirement_set, options.install_options + ) + + preparer = self.make_requirement_preparer( + temp_build_dir=directory, + options=options, + req_tracker=req_tracker, + session=session, + finder=finder, + use_user_site=options.use_user_site, + ) + resolver = self.make_resolver( + preparer=preparer, + finder=finder, + options=options, + wheel_cache=wheel_cache, + use_user_site=options.use_user_site, + ignore_installed=options.ignore_installed, + ignore_requires_python=options.ignore_requires_python, + force_reinstall=options.force_reinstall, + upgrade_strategy=upgrade_strategy, + use_pep517=options.use_pep517, + ) + + self.trace_basic_info(finder) + + resolver.resolve(requirement_set) + + try: + pip_req = requirement_set.get_requirement("pip") + except KeyError: + modifying_pip = None + else: + # 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 + ) + + reqs_to_build = [ + r for r in requirement_set.requirements.values() + if should_build_for_install_command( + r, check_binary_allowed + ) + ] + + _, build_failures = build( + reqs_to_build, + wheel_cache=wheel_cache, + build_options=[], + global_options=[], + ) + + # If we're using PEP 517, we cannot do a direct install + # so we fail here. + # We don't care about failures building legacy + # requirements, as we'll fall through to a direct + # install for those. + pep517_build_failures = [ + r for r in build_failures if r.use_pep517 + ] + if pep517_build_failures: + raise InstallationError( + "Could not build wheels for {} which use" + " PEP 517 and cannot be installed directly".format( + ", ".join(r.name for r in pep517_build_failures))) + + to_install = resolver.get_installation_order( + requirement_set + ) + + # Consistency Checking of the package set we're installing. + should_warn_about_conflicts = ( + not options.ignore_dependencies and + options.warn_about_conflicts + ) + if should_warn_about_conflicts: + self._warn_about_conflicts(to_install) + + # Don't warn about script install locations if + # --target has been specified + warn_script_location = options.warn_script_location + if options.target_dir: + warn_script_location = False + + installed = install_given_reqs( + to_install, + install_options, + global_options, + root=options.root_path, + home=target_temp_dir_path, + prefix=options.prefix_path, + pycompile=options.compile, + warn_script_location=warn_script_location, + use_user_site=options.use_user_site, + ) + + lib_locations = get_lib_location_guesses( + user=options.use_user_site, + home=target_temp_dir_path, + root=options.root_path, + prefix=options.prefix_path, + isolated=options.isolated_mode, + ) + working_set = pkg_resources.WorkingSet(lib_locations) + + installed.sort(key=operator.attrgetter('name')) + items = [] + for result in installed: + item = result.name + try: + installed_version = get_installed_version( + result.name, working_set=working_set + ) + if installed_version: + item += '-' + installed_version + except Exception: + pass + items.append(item) + installed_desc = ' '.join(items) + if installed_desc: + write_output( + 'Successfully installed %s', installed_desc, + ) + except EnvironmentError as error: + show_traceback = (self.verbosity >= 1) + + message = create_env_error_message( + error, show_traceback, options.use_user_site, + ) + logger.error(message, exc_info=show_traceback) + + return ERROR + except PreviousBuildDirError: + options.no_clean = True + raise + finally: + # Clean up + if not options.no_clean: + requirement_set.cleanup_files() + wheel_cache.cleanup() + + if options.target_dir: + self._handle_target_dir( + options.target_dir, target_temp_dir, options.upgrade + ) + + return SUCCESS + + def _handle_target_dir(self, target_dir, target_temp_dir, upgrade): + ensure_dir(target_dir) + + # Checking both purelib and platlib directories for installed + # packages to be moved to target directory + lib_dir_list = [] + + with target_temp_dir: + # Checking both purelib and platlib directories for installed + # packages to be moved to target directory + scheme = distutils_scheme('', home=target_temp_dir.path) + purelib_dir = scheme['purelib'] + platlib_dir = scheme['platlib'] + data_dir = scheme['data'] + + if os.path.exists(purelib_dir): + lib_dir_list.append(purelib_dir) + if os.path.exists(platlib_dir) and platlib_dir != purelib_dir: + lib_dir_list.append(platlib_dir) + if os.path.exists(data_dir): + lib_dir_list.append(data_dir) + + for lib_dir in lib_dir_list: + for item in os.listdir(lib_dir): + if lib_dir == data_dir: + ddir = os.path.join(data_dir, item) + if any(s.startswith(ddir) for s in lib_dir_list[:-1]): + continue + target_item_dir = os.path.join(target_dir, item) + 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 + ) + 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 + ) + continue + if os.path.isdir(target_item_dir): + shutil.rmtree(target_item_dir) + else: + os.remove(target_item_dir) + + shutil.move( + os.path.join(lib_dir, item), + target_item_dir + ) + + def _warn_about_conflicts(self, to_install): + try: + package_set, _dep_info = check_install_conflicts(to_install) + except Exception: + logger.error("Error checking for conflicts.", exc_info=True) + return + missing, conflicting = _dep_info + + # NOTE: There is some duplication here from pip check + for project_name in missing: + version = package_set[project_name][0] + for dependency in missing[project_name]: + logger.critical( + "%s %s requires %s, which is not installed.", + project_name, version, dependency[1], + ) + + for project_name in conflicting: + version = package_set[project_name][0] + for dep_name, dep_version, req in conflicting[project_name]: + logger.critical( + "%s %s has requirement %s, but you'll have %s %s which is " + "incompatible.", + project_name, version, req, dep_name, dep_version, + ) + + +def get_lib_location_guesses(*args, **kwargs): + scheme = distutils_scheme('', *args, **kwargs) + return [scheme['purelib'], scheme['platlib']] + + +def site_packages_writable(**kwargs): + return all( + test_writable_dir(d) for d in set(get_lib_location_guesses(**kwargs)) + ) + + +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 + """Determine whether to do a user install based on the input options. + + If use_user_site is False, no additional checks are done. + If use_user_site is True, it is checked for compatibility with other + options. + If use_user_site is None, the default behaviour depends on the environment, + which is provided by the other arguments. + """ + # In some cases (config from tox), use_user_site can be set to an integer + # rather than a bool, which 'use_user_site is False' wouldn't catch. + if (use_user_site is not None) and (not use_user_site): + logger.debug("Non-user install by explicit request") + return False + + if use_user_site: + if prefix_path: + raise CommandError( + "Can not combine '--user' and '--prefix' as they imply " + "different installation locations" + ) + if virtualenv_no_global(): + raise InstallationError( + "Can not perform a '--user' install. User site-packages " + "are not visible in this virtualenv." + ) + logger.debug("User install by explicit request") + return True + + # If we are here, user installs have not been explicitly requested/avoided + assert use_user_site is None + + # user install incompatible with --prefix/--target + if prefix_path or target_dir: + logger.debug("Non-user install due to --prefix or --target option") + return False + + # If user installs are not enabled, choose a non-user install + if not site.ENABLE_USER_SITE: + logger.debug("Non-user install because user site-packages disabled") + return False + + # If we have permission for a non-user install, do that, + # otherwise do a user install. + if site_packages_writable(root=root_path, isolated=isolated_mode): + 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 warn_deprecated_install_options(requirement_set, options): + # type: (RequirementSet, 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] + + requirements = ( + requirement_set.unnamed_requirements + + list(requirement_set.requirements.values()) + ) + + offenders = [] + + for requirement in requirements: + install_options = requirement.options.get("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 + + deprecated( + reason=( + "Location-changing options found in --install-option: {}. " + "This configuration may cause unexpected behavior and is " + "unsupported.".format( + "; ".join(offenders) + ) + ), + replacement=( + "using pip-level options like --user, --prefix, --root, and " + "--target" + ), + gone_in="20.2", + issue=7309, + ) + + +def create_env_error_message(error, show_traceback, using_user_site): + """Format an error message for an EnvironmentError + + It may occur anytime during the execution of the install command. + """ + parts = [] + + # Mention the error if we are not going to show a traceback + parts.append("Could not install packages due to an EnvironmentError") + if not show_traceback: + parts.append(": ") + parts.append(str(error)) + else: + parts.append(".") + + # Spilt the error indication from a helper message (if any) + parts[-1] += "\n" + + # Suggest useful actions to the user: + # (1) using user site-packages or (2) verifying the permissions + if error.errno == errno.EACCES: + user_option_part = "Consider using the `--user` option" + permissions_part = "Check the permissions" + + if not using_user_site: + parts.extend([ + user_option_part, " or ", + permissions_part.lower(), + ]) + else: + parts.append(permissions_part) + parts.append(".\n") + + return "".join(parts).strip() + "\n" diff --git a/venv/lib/python3.8/site-packages/pip/_internal/commands/list.py b/venv/lib/python3.8/site-packages/pip/_internal/commands/list.py new file mode 100644 index 0000000..d006206 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/commands/list.py @@ -0,0 +1,315 @@ +# The following comment should be removed at some point in the future. +# mypy: disallow-untyped-defs=False + +from __future__ import absolute_import + +import json +import logging + +from pip._vendor import six +from pip._vendor.six.moves import zip_longest + +from pip._internal.cli import cmdoptions +from pip._internal.cli.req_command import IndexGroupCommand +from pip._internal.exceptions import CommandError +from pip._internal.index.package_finder import PackageFinder +from pip._internal.models.selection_prefs import SelectionPreferences +from pip._internal.self_outdated_check import make_link_collector +from pip._internal.utils.misc import ( + dist_is_editable, + get_installed_distributions, + write_output, +) +from pip._internal.utils.packaging import get_installer + +from pip._vendor.packaging.version import parse + +logger = logging.getLogger(__name__) + + +class ListCommand(IndexGroupCommand): + """ + List installed packages, including editables. + + Packages are listed in a case-insensitive sorted order. + """ + + usage = """ + %prog [options]""" + + def __init__(self, *args, **kw): + super(ListCommand, self).__init__(*args, **kw) + + cmd_opts = self.cmd_opts + + cmd_opts.add_option( + '-o', '--outdated', + action='store_true', + default=False, + help='List outdated packages') + cmd_opts.add_option( + '-u', '--uptodate', + action='store_true', + default=False, + help='List uptodate packages') + cmd_opts.add_option( + '-e', '--editable', + action='store_true', + default=False, + help='List editable projects.') + cmd_opts.add_option( + '-l', '--local', + action='store_true', + default=False, + 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', + default=False, + help='Only output packages installed in user-site.') + cmd_opts.add_option(cmdoptions.list_path()) + cmd_opts.add_option( + '--pre', + action='store_true', + default=False, + help=("Include pre-release and development versions. By default, " + "pip only finds stable versions."), + ) + + cmd_opts.add_option( + '--format', + action='store', + dest='list_format', + default="columns", + choices=('columns', 'freeze', 'json'), + help="Select the output format among: columns (default), freeze, " + "or json", + ) + + cmd_opts.add_option( + '--not-required', + action='store_true', + dest='not_required', + help="List packages that are not dependencies of " + "installed packages.", + ) + + cmd_opts.add_option( + '--exclude-editable', + action='store_false', + dest='include_editable', + help='Exclude editable package from output.', + ) + cmd_opts.add_option( + '--include-editable', + action='store_true', + dest='include_editable', + help='Include editable package from output.', + default=True, + ) + 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, cmd_opts) + + def _build_package_finder(self, options, session): + """ + Create a package finder appropriate to this list command. + """ + link_collector = make_link_collector(session, options=options) + + # Pass allow_yanked=False to ignore yanked versions. + selection_prefs = SelectionPreferences( + allow_yanked=False, + allow_all_prereleases=options.pre, + ) + + return PackageFinder.create( + link_collector=link_collector, + selection_prefs=selection_prefs, + ) + + def run(self, options, args): + if options.outdated and options.uptodate: + raise CommandError( + "Options --outdated and --uptodate cannot be combined.") + + cmdoptions.check_list_path_option(options) + + packages = get_installed_distributions( + local_only=options.local, + user_only=options.user, + editables_only=options.editable, + include_editables=options.include_editable, + paths=options.path, + ) + + # get_not_required must be called firstly in order to find and + # filter out all dependencies correctly. Otherwise a package + # can't be identified as requirement because some parent packages + # could be filtered out before. + if options.not_required: + packages = self.get_not_required(packages, options) + + if options.outdated: + packages = self.get_outdated(packages, options) + elif options.uptodate: + packages = self.get_uptodate(packages, options) + + self.output_package_listing(packages, options) + + def get_outdated(self, packages, options): + return [ + dist for dist in self.iter_packages_latest_infos(packages, options) + if parse(str(dist.latest_version)) > parse(str(dist.parsed_version)) + ] + + def get_uptodate(self, packages, options): + return [ + dist for dist in self.iter_packages_latest_infos(packages, options) + if parse(str(dist.latest_version)) == parse(str(dist.parsed_version)) + ] + + def get_not_required(self, packages, options): + dep_keys = set() + for dist in packages: + dep_keys.update(requirement.key for requirement in dist.requires()) + return {pkg for pkg in packages if pkg.key not in dep_keys} + + def iter_packages_latest_infos(self, packages, options): + with self._build_session(options) as session: + finder = self._build_package_finder(options, session) + + for dist in packages: + typ = 'unknown' + all_candidates = finder.find_all_candidates(dist.key) + if not options.pre: + # Remove prereleases + all_candidates = [candidate for candidate in all_candidates + if not candidate.version.is_prerelease] + + evaluator = finder.make_candidate_evaluator( + project_name=dist.project_name, + ) + best_candidate = evaluator.sort_best_candidate(all_candidates) + if best_candidate is None: + continue + + remote_version = best_candidate.version + if best_candidate.link.is_wheel: + typ = 'wheel' + else: + typ = 'sdist' + # This is dirty but makes the rest of the code much cleaner + dist.latest_version = remote_version + dist.latest_filetype = typ + yield dist + + def output_package_listing(self, packages, options): + packages = sorted( + packages, + key=lambda dist: dist.project_name.lower(), + ) + 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': + for dist in packages: + if options.verbose >= 1: + write_output("%s==%s (%s)", dist.project_name, + dist.version, dist.location) + else: + write_output("%s==%s", dist.project_name, dist.version) + elif options.list_format == 'json': + write_output(format_for_json(packages, options)) + + def output_package_listing_columns(self, data, header): + # insert the header first: we need to know the size of column names + if len(data) > 0: + data.insert(0, header) + + pkg_strings, sizes = tabulate(data) + + # Create and add a separator. + if len(data) > 0: + pkg_strings.insert(1, " ".join(map(lambda x: '-' * x, sizes))) + + for val in pkg_strings: + write_output(val) + + +def tabulate(vals): + # From pfmoore on GitHub: + # https://github.com/pypa/pip/issues/3651#issuecomment-216932564 + assert len(vals) > 0 + + sizes = [0] * max(len(x) for x in vals) + for row in vals: + sizes = [max(s, len(str(c))) for s, c in zip_longest(sizes, row)] + + result = [] + for row in vals: + display = " ".join([str(c).ljust(s) if c is not None else '' + for s, c in zip_longest(sizes, row)]) + result.append(display) + + return result, sizes + + +def format_for_columns(pkgs, options): + """ + Convert the package data into something usable + by output_package_listing_columns. + """ + 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"] + + data = [] + if options.verbose >= 1 or any(dist_is_editable(x) for x in pkgs): + header.append("Location") + if options.verbose >= 1: + header.append("Installer") + + 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] + + if running_outdated: + row.append(proj.latest_version) + row.append(proj.latest_filetype) + + if options.verbose >= 1 or dist_is_editable(proj): + row.append(proj.location) + if options.verbose >= 1: + row.append(get_installer(proj)) + + data.append(row) + + return data, header + + +def format_for_json(packages, options): + data = [] + for dist in packages: + info = { + 'name': dist.project_name, + 'version': six.text_type(dist.version), + } + if options.verbose >= 1: + info['location'] = dist.location + info['installer'] = get_installer(dist) + if options.outdated: + info['latest_version'] = six.text_type(dist.latest_version) + info['latest_filetype'] = dist.latest_filetype + data.append(info) + return json.dumps(data) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/commands/search.py b/venv/lib/python3.8/site-packages/pip/_internal/commands/search.py new file mode 100644 index 0000000..2e880ee --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/commands/search.py @@ -0,0 +1,145 @@ +# The following comment should be removed at some point in the future. +# mypy: disallow-untyped-defs=False + +from __future__ import absolute_import + +import logging +import sys +import textwrap +from collections import OrderedDict + +from pip._vendor import pkg_resources +from pip._vendor.packaging.version import parse as parse_version +# NOTE: XMLRPC Client is not annotated in typeshed as on 2017-07-17, which is +# why we ignore the type on this import +from pip._vendor.six.moves import xmlrpc_client # type: ignore + +from pip._internal.cli.base_command import Command +from pip._internal.cli.req_command import SessionCommandMixin +from pip._internal.cli.status_codes import NO_MATCHES_FOUND, SUCCESS +from pip._internal.exceptions import CommandError +from pip._internal.models.index import PyPI +from pip._internal.network.xmlrpc import PipXmlrpcTransport +from pip._internal.utils.compat import get_terminal_size +from pip._internal.utils.logging import indent_log +from pip._internal.utils.misc import write_output + +logger = logging.getLogger(__name__) + + +class SearchCommand(Command, SessionCommandMixin): + """Search for PyPI packages whose name or summary contains .""" + + usage = """ + %prog [options] """ + ignore_require_venv = True + + def __init__(self, *args, **kw): + super(SearchCommand, self).__init__(*args, **kw) + self.cmd_opts.add_option( + '-i', '--index', + dest='index', + metavar='URL', + default=PyPI.pypi_url, + help='Base URL of Python Package Index (default %default)') + + self.parser.insert_option_group(0, self.cmd_opts) + + def run(self, options, args): + if not args: + raise CommandError('Missing required argument (search query).') + query = args + pypi_hits = self.search(query, options) + hits = transform_hits(pypi_hits) + + terminal_width = None + if sys.stdout.isatty(): + terminal_width = get_terminal_size()[0] + + print_results(hits, terminal_width=terminal_width) + if pypi_hits: + return SUCCESS + return NO_MATCHES_FOUND + + def search(self, query, options): + index_url = options.index + + session = self.get_default_session(options) + + transport = PipXmlrpcTransport(index_url, session) + pypi = xmlrpc_client.ServerProxy(index_url, transport) + hits = pypi.search({'name': query, 'summary': query}, 'or') + return hits + + +def transform_hits(hits): + """ + 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() + for hit in hits: + name = hit['name'] + summary = hit['summary'] + version = hit['version'] + + if name not in packages.keys(): + packages[name] = { + 'name': name, + 'summary': summary, + 'versions': [version], + } + else: + 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 + + return list(packages.values()) + + +def print_results(hits, name_column_width=None, terminal_width=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 + + installed_packages = [p.project_name for p in pkg_resources.working_set] + for hit in hits: + 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 = textwrap.wrap(summary, target_width) + summary = ('\n' + ' ' * (name_column_width + 3)).join(summary) + + line = '%-*s - %s' % (name_column_width, + '%s (%s)' % (name, latest), summary) + try: + write_output(line) + if name in installed_packages: + dist = pkg_resources.get_distribution(name) + 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) + except UnicodeEncodeError: + pass + + +def highest_version(versions): + return max(versions, key=parse_version) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/commands/show.py b/venv/lib/python3.8/site-packages/pip/_internal/commands/show.py new file mode 100644 index 0000000..a46b08e --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/commands/show.py @@ -0,0 +1,180 @@ +# The following comment should be removed at some point in the future. +# mypy: disallow-untyped-defs=False + +from __future__ import absolute_import + +import logging +import os +from email.parser import FeedParser + +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.utils.misc import write_output + +logger = logging.getLogger(__name__) + + +class ShowCommand(Command): + """ + Show information about one or more installed packages. + + The output is in RFC-compliant mail header format. + """ + + usage = """ + %prog [options] ...""" + ignore_require_venv = True + + def __init__(self, *args, **kw): + super(ShowCommand, self).__init__(*args, **kw) + self.cmd_opts.add_option( + '-f', '--files', + dest='files', + action='store_true', + default=False, + 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): + if not args: + 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): + return ERROR + return SUCCESS + + +def search_packages_info(query): + """ + 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 + + 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): + 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 = None + 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 = [l.split(',')[0] for l 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') + 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): + """ + Print the informations from installed distributions found. + """ + results_printed = False + for i, dist in enumerate(distributions): + results_printed = True + 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', []))) + + if verbose: + write_output("Metadata-Version: %s", + dist.get('metadata-version', '')) + write_output("Installer: %s", dist.get('installer', '')) + write_output("Classifiers:") + for classifier in dist.get('classifiers', []): + write_output(" %s", classifier) + write_output("Entry-points:") + for entry in dist.get('entry_points', []): + write_output(" %s", entry.strip()) + 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") + return results_printed diff --git a/venv/lib/python3.8/site-packages/pip/_internal/commands/uninstall.py b/venv/lib/python3.8/site-packages/pip/_internal/commands/uninstall.py new file mode 100644 index 0000000..1bde414 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/commands/uninstall.py @@ -0,0 +1,82 @@ +# The following comment should be removed at some point in the future. +# mypy: disallow-untyped-defs=False + +from __future__ import absolute_import + +from pip._vendor.packaging.utils import canonicalize_name + +from pip._internal.cli.base_command import Command +from pip._internal.cli.req_command import SessionCommandMixin +from pip._internal.exceptions import InstallationError +from pip._internal.req import parse_requirements +from pip._internal.req.constructors import install_req_from_line +from pip._internal.utils.misc import protect_pip_from_modification_on_windows + + +class UninstallCommand(Command, SessionCommandMixin): + """ + Uninstall packages. + + pip is able to uninstall most installed packages. Known exceptions are: + + - Pure distutils packages installed with ``python setup.py install``, which + leave behind no metadata to determine what files were installed. + - Script wrappers installed by ``python setup.py develop``. + """ + + usage = """ + %prog [options] ... + %prog [options] -r ...""" + + def __init__(self, *args, **kw): + super(UninstallCommand, self).__init__(*args, **kw) + self.cmd_opts.add_option( + '-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.', + ) + self.cmd_opts.add_option( + '-y', '--yes', + dest='yes', + action='store_true', + help="Don't ask for confirmation of uninstall deletions.") + + self.parser.insert_option_group(0, self.cmd_opts) + + def run(self, options, args): + session = self.get_default_session(options) + + reqs_to_uninstall = {} + for name in args: + req = install_req_from_line( + name, isolated=options.isolated_mode, + ) + if req.name: + reqs_to_uninstall[canonicalize_name(req.name)] = req + for filename in options.requirements: + for req in parse_requirements( + filename, + options=options, + session=session): + if req.name: + reqs_to_uninstall[canonicalize_name(req.name)] = req + if not reqs_to_uninstall: + raise InstallationError( + 'You must give at least one requirement to %(name)s (see ' + '"pip help %(name)s")' % dict(name=self.name) + ) + + 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, + ) + if uninstall_pathset: + uninstall_pathset.commit() diff --git a/venv/lib/python3.8/site-packages/pip/_internal/commands/wheel.py b/venv/lib/python3.8/site-packages/pip/_internal/commands/wheel.py new file mode 100644 index 0000000..eb44bce --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/commands/wheel.py @@ -0,0 +1,197 @@ +# -*- coding: utf-8 -*- + +# The following comment should be removed at some point in the future. +# mypy: disallow-untyped-defs=False + +from __future__ import absolute_import + +import logging +import os +import shutil + +from pip._internal.cache import WheelCache +from pip._internal.cli import cmdoptions +from pip._internal.cli.req_command import RequirementCommand +from pip._internal.exceptions import CommandError, PreviousBuildDirError +from pip._internal.req import RequirementSet +from pip._internal.req.req_tracker import get_requirement_tracker +from pip._internal.utils.misc import ensure_dir, normalize_path +from pip._internal.utils.temp_dir import TempDirectory +from pip._internal.utils.typing import MYPY_CHECK_RUNNING +from pip._internal.wheel_builder import build, should_build_for_wheel_command + +if MYPY_CHECK_RUNNING: + from optparse import Values + from typing import Any, List + + +logger = logging.getLogger(__name__) + + +class WheelCommand(RequirementCommand): + """ + Build Wheel archives for your requirements and dependencies. + + Wheel is a built-package format, and offers the advantage of not + 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. + + """ + + usage = """ + %prog [options] ... + %prog [options] -r ... + %prog [options] [-e] ... + %prog [options] [-e] ... + %prog [options] ...""" + + def __init__(self, *args, **kw): + super(WheelCommand, self).__init__(*args, **kw) + + cmd_opts = self.cmd_opts + + cmd_opts.add_option( + '-w', '--wheel-dir', + dest='wheel_dir', + metavar='dir', + default=os.curdir, + help=("Build wheels into , where the default is the " + "current working directory."), + ) + cmd_opts.add_option(cmdoptions.no_binary()) + cmd_opts.add_option(cmdoptions.only_binary()) + cmd_opts.add_option(cmdoptions.prefer_binary()) + cmd_opts.add_option( + '--build-option', + dest='build_options', + metavar='options', + action='append', + help="Extra arguments to be supplied to 'setup.py bdist_wheel'.", + ) + cmd_opts.add_option(cmdoptions.no_build_isolation()) + cmd_opts.add_option(cmdoptions.use_pep517()) + cmd_opts.add_option(cmdoptions.no_use_pep517()) + cmd_opts.add_option(cmdoptions.constraints()) + cmd_opts.add_option(cmdoptions.editable()) + cmd_opts.add_option(cmdoptions.requirements()) + cmd_opts.add_option(cmdoptions.src()) + cmd_opts.add_option(cmdoptions.ignore_requires_python()) + cmd_opts.add_option(cmdoptions.no_deps()) + cmd_opts.add_option(cmdoptions.build_dir()) + cmd_opts.add_option(cmdoptions.progress_bar()) + + cmd_opts.add_option( + '--global-option', + dest='global_options', + action='append', + metavar='options', + help="Extra global options to be supplied to the setup.py " + "call before the 'bdist_wheel' command.") + + cmd_opts.add_option( + '--pre', + action='store_true', + default=False, + help=("Include pre-release and development versions. By default, " + "pip only finds stable versions."), + ) + + cmd_opts.add_option(cmdoptions.no_clean()) + cmd_opts.add_option(cmdoptions.require_hashes()) + + 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, cmd_opts) + + def run(self, options, args): + # type: (Values, List[Any]) -> None + cmdoptions.check_install_build_global(options) + + session = self.get_default_session(options) + + finder = self._build_package_finder(options, session) + build_delete = (not (options.no_clean or options.build_dir)) + wheel_cache = WheelCache(options.cache_dir, options.format_control) + + options.wheel_dir = normalize_path(options.wheel_dir) + ensure_dir(options.wheel_dir) + + with get_requirement_tracker() as req_tracker, TempDirectory( + options.build_dir, delete=build_delete, kind="wheel" + ) as directory: + + requirement_set = RequirementSet() + + try: + self.populate_requirement_set( + requirement_set, args, options, finder, session, + wheel_cache + ) + + preparer = self.make_requirement_preparer( + temp_build_dir=directory, + options=options, + req_tracker=req_tracker, + session=session, + finder=finder, + wheel_download_dir=options.wheel_dir, + use_user_site=False, + ) + + resolver = self.make_resolver( + preparer=preparer, + finder=finder, + options=options, + wheel_cache=wheel_cache, + ignore_requires_python=options.ignore_requires_python, + use_pep517=options.use_pep517, + ) + + self.trace_basic_info(finder) + + resolver.resolve(requirement_set) + + reqs_to_build = [ + r for r in requirement_set.requirements.values() + if should_build_for_wheel_command(r) + ] + + # build wheels + build_successes, build_failures = build( + reqs_to_build, + wheel_cache=wheel_cache, + build_options=options.build_options or [], + global_options=options.global_options or [], + ) + for req in build_successes: + assert req.link and req.link.is_wheel + assert req.local_file_path + # copy from cache to target directory + try: + shutil.copy(req.local_file_path, options.wheel_dir) + except OSError as e: + logger.warning( + "Building wheel for %s failed: %s", + req.name, e, + ) + build_failures.append(req) + if len(build_failures) != 0: + raise CommandError( + "Failed to build one or more wheels" + ) + except PreviousBuildDirError: + options.no_clean = True + raise + finally: + if not options.no_clean: + requirement_set.cleanup_files() + wheel_cache.cleanup() diff --git a/venv/lib/python3.8/site-packages/pip/_internal/configuration.py b/venv/lib/python3.8/site-packages/pip/_internal/configuration.py new file mode 100644 index 0000000..f09a1ae --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/configuration.py @@ -0,0 +1,422 @@ +"""Configuration management setup + +Some terminology: +- name + As written in config files. +- value + Value associated with a name +- key + Name combined with it's section (section.name) +- variant + A single word describing where the configuration key-value pair came from +""" + +# The following comment should be removed at some point in the future. +# mypy: strict-optional=False + +import locale +import logging +import os +import sys + +from pip._vendor.six.moves import configparser + +from pip._internal.exceptions import ( + ConfigurationError, + ConfigurationFileCouldNotBeLoaded, +) +from pip._internal.utils import appdirs +from pip._internal.utils.compat import WINDOWS, expanduser +from pip._internal.utils.misc import ensure_dir, enum +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import ( + Any, Dict, Iterable, List, NewType, Optional, Tuple + ) + + RawConfigParser = configparser.RawConfigParser # Shorthand + Kind = NewType("Kind", str) + +logger = logging.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('--'): + name = name[2:] # only prefer long opts + return name + + +def _disassemble_key(name): + # type: (str) -> List[str] + if "." not in name: + error_message = ( + "Key does not contain dot separated section and key. " + "Perhaps you wanted to use 'global.{}' instead?" + ).format(name) + raise ConfigurationError(error_message) + return name.split(".", 1) + + +# 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 + ENV_VAR="env-var", # from Environment Variables +) + + +CONFIG_BASENAME = 'pip.ini' if WINDOWS else 'pip.conf' + + +def get_configuration_files(): + # type: () -> Dict[Kind, List[str]] + global_config_files = [ + 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( + expanduser('~'), + 'pip' if WINDOWS else '.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], + kinds.USER: [legacy_config_file, new_config_file], + } + + +class Configuration(object): + """Handles management of configuration. + + Provides an interface to accessing and managing configuration files. + + This class converts provides an API that takes "section.key-name" style + keys and stores the value associated with it as "key-name" under the + section "section". + + This allows for a clean interface wherein the both the section and the + key-name are preserved in an easy to manage form in the configuration files + and the data stored is also nice. + """ + + def __init__(self, isolated, load_only=None): + # type: (bool, Kind) -> None + super(Configuration, self).__init__() + + _valid_load_only = [kinds.USER, kinds.GLOBAL, kinds.SITE, None] + if load_only not in _valid_load_only: + raise ConfigurationError( + "Got invalid value for load_only - should be one of {}".format( + ", ".join(map(repr, _valid_load_only[:-1])) + ) + ) + self.isolated = isolated # type: bool + self.load_only = load_only # type: Optional[Kind] + + # The order here determines the override order. + self._override_order = [ + kinds.GLOBAL, kinds.USER, kinds.SITE, kinds.ENV, kinds.ENV_VAR + ] + + self._ignore_env_names = ["version", "help"] + + # Because we keep track of where we got the data from + self._parsers = { + variant: [] for variant in self._override_order + } # type: Dict[Kind, List[Tuple[str, RawConfigParser]]] + self._config = { + variant: {} for variant in self._override_order + } # type: Dict[Kind, Dict[str, Any]] + self._modified_parsers = [] # type: List[Tuple[str, RawConfigParser]] + + def load(self): + # type: () -> 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" + + try: + return self._get_parser_to_modify()[0] + except IndexError: + return None + + def items(self): + # type: () -> 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. + """ + try: + return self._dictionary[key] + except KeyError: + raise ConfigurationError("No such key - {}".format(key)) + + def set_value(self, key, value): + # type: (str, Any) -> None + """Modify a value in the configuration. + """ + self._ensure_have_load_only() + + fname, parser = self._get_parser_to_modify() + + if parser is not None: + section, name = _disassemble_key(key) + + # Modify the parser and the configuration + if not parser.has_section(section): + parser.add_section(section) + parser.set(section, name, value) + + self._config[self.load_only][key] = value + self._mark_as_modified(fname, parser) + + def unset_value(self, key): + # type: (str) -> None + """Unset a value in the configuration. + """ + self._ensure_have_load_only() + + if key not in self._config[self.load_only]: + raise ConfigurationError("No such key - {}".format(key)) + + fname, parser = self._get_parser_to_modify() + + if parser is not None: + section, name = _disassemble_key(key) + + # Remove the key in the parser + modified_something = False + if parser.has_section(section): + # Returns whether the option was removed or not + modified_something = parser.remove_option(section, name) + + if modified_something: + # name removed from parser, section may now be empty + section_iter = iter(parser.items(section)) + try: + val = next(section_iter) + except StopIteration: + val = None + + if val is None: + parser.remove_section(section) + + self._mark_as_modified(fname, parser) + else: + raise ConfigurationError( + "Fatal Internal error [id=1]. Please report as a bug." + ) + + del self._config[self.load_only][key] + + def save(self): + # type: () -> None + """Save the current in-memory state. + """ + self._ensure_have_load_only() + + for fname, parser in self._modified_parsers: + logger.info("Writing to %s", fname) + + # Ensure directory exists. + ensure_dir(os.path.dirname(fname)) + + with open(fname, "w") as f: + parser.write(f) + + # + # Private routines + # + + def _ensure_have_load_only(self): + # type: () -> 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. + """ + # NOTE: Dictionaries are not populated if not loaded. So, conditionals + # are not needed here. + retval = {} + + for variant in self._override_order: + retval.update(self._config[variant]) + + return retval + + def _load_config_files(self): + # type: () -> None + """Loads configuration from configuration files + """ + config_files = dict(self._iter_config_files()) + if config_files[kinds.ENV][0:1] == [os.devnull]: + logger.debug( + "Skipping loading configuration files due to " + "environment's PIP_CONFIG_FILE being os.devnull" + ) + return + + for variant, files in config_files.items(): + for fname in files: + # 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 + ) + continue + + parser = self._load_file(variant, fname) + + # 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) + parser = self._construct_parser(fname) + + for section in parser.sections(): + items = parser.items(section) + self._config[variant].update(self._normalized_keys(section, items)) + + return parser + + def _construct_parser(self, fname): + # type: (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): + try: + parser.read(fname) + except UnicodeDecodeError: + # See https://github.com/pypa/pip/issues/4963 + raise ConfigurationFileCouldNotBeLoaded( + reason="contains invalid {} characters".format( + locale.getpreferredencoding(False) + ), + fname=fname, + ) + except configparser.Error as error: + # See https://github.com/pypa/pip/issues/4893 + raise ConfigurationFileCouldNotBeLoaded(error=error) + return parser + + def _load_environment_vars(self): + # type: () -> 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] + """Normalizes items to construct a dictionary with normalized keys. + + This routine is where the names become keys and are made the same + regardless of source - configuration files or environment. + """ + normalized = {} + for name, val in items: + key = section + "." + _normalize_name(name) + normalized[key] = val + return normalized + + def _get_environ_vars(self): + # type: () -> Iterable[Tuple[str, str]] + """Returns a generator with all environmental vars with prefix PIP_""" + for key, val in os.environ.items(): + should_be_yielded = ( + key.startswith("PIP_") and + key[4:].lower() not in self._ignore_env_names + ) + if should_be_yielded: + yield key[4:].lower(), val + + # XXX: This is patched in the tests. + def _iter_config_files(self): + # type: () -> Iterable[Tuple[Kind, List[str]]] + """Yields variant and configuration files associated with it. + + This should be treated like items of a dictionary. + """ + # SMELL: Move the conditions out of this function + + # environment variables have the lowest priority + config_file = os.environ.get('PIP_CONFIG_FILE', None) + if config_file is not None: + yield kinds.ENV, [config_file] + else: + yield kinds.ENV, [] + + config_files = get_configuration_files() + + # at the base we have any global configuration + yield kinds.GLOBAL, config_files[kinds.GLOBAL] + + # per-user configuration next + should_load_user_config = not self.isolated and not ( + config_file and os.path.exists(config_file) + ) + if should_load_user_config: + # The legacy config file is overridden by the new config file + yield kinds.USER, config_files[kinds.USER] + + # finally virtualenv configuration first trumping others + yield kinds.SITE, config_files[kinds.SITE] + + def _get_parser_to_modify(self): + # type: () -> Tuple[str, RawConfigParser] + # Determine which parser to modify + parsers = self._parsers[self.load_only] + if not parsers: + # This should not happen if everything works correctly. + raise ConfigurationError( + "Fatal Internal error [id=2]. Please report as a bug." + ) + + # Use the highest priority parser. + return parsers[-1] + + # XXX: This is patched in the tests. + def _mark_as_modified(self, fname, parser): + # type: (str, RawConfigParser) -> None + file_parser_tuple = (fname, parser) + if file_parser_tuple not in self._modified_parsers: + self._modified_parsers.append(file_parser_tuple) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/distributions/__init__.py b/venv/lib/python3.8/site-packages/pip/_internal/distributions/__init__.py new file mode 100644 index 0000000..d5c1afc --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/distributions/__init__.py @@ -0,0 +1,24 @@ +from pip._internal.distributions.sdist import SourceDistribution +from pip._internal.distributions.wheel import WheelDistribution +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from pip._internal.distributions.base import AbstractDistribution + from pip._internal.req.req_install import InstallRequirement + + +def make_distribution_for_install_requirement(install_req): + # type: (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. + if install_req.editable: + return SourceDistribution(install_req) + + # If it's a wheel, it's a WheelDistribution + if install_req.is_wheel: + return WheelDistribution(install_req) + + # Otherwise, a SourceDistribution + return SourceDistribution(install_req) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/distributions/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/distributions/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..77fd3f51b25936701d01570a32456a5cb4664ef9 GIT binary patch literal 812 zcmaJ<&2G~`5Z?7)oTNo+)l&tMk>KD%> z;AMCU-osZ;yaFd?Tmnv!7;9GZ^X-2AX7_A+yGOvDJ$;;hvkCc*N!u()j==RBSTd4P zNphM{im@fF+)nH!wxyH1iAxE0)e-a@>E)fI)AU^F=iQ_Wv6pqekffLS6B2fRz=YFTWCn z7xeQaHhCGBq8wC3na(bGHfZ(?L^WR?te#wBFJ_`JTotK|v(_|q%%C9*V^O)P!#us@ ztleku;{a%8g`DeQA+c_rhv!k>Mps)<8-@M)A<#vC=%V&(FXlSO|TKc%zKg<_dCHZrF85*T- KQTQweSNj+A`sgzN literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/distributions/__pycache__/base.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/distributions/__pycache__/base.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..3faa360227670e897bc12d9642b83ef7ddca4cc1 GIT binary patch literal 1928 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 F_zx$QxXl0n literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/distributions/base.py b/venv/lib/python3.8/site-packages/pip/_internal/distributions/base.py new file mode 100644 index 0000000..b836b98 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/distributions/base.py @@ -0,0 +1,45 @@ +import abc + +from pip._vendor.six import add_metaclass + +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import Optional + + from pip._vendor.pkg_resources import Distribution + from pip._internal.req import InstallRequirement + from pip._internal.index.package_finder import PackageFinder + + +@add_metaclass(abc.ABCMeta) +class AbstractDistribution(object): + """A base class for handling installable artifacts. + + The requirements for anything installable are as follows: + + - we must be able to determine the requirement name + (or we can't correctly handle the non-upgrade case). + + - for packages with setup requirements, we must also be able + to determine their requirements without installing additional + packages (for the same reason as run-time dependencies) + + - we must be able to create a Distribution object exposing the + above metadata. + """ + + def __init__(self, req): + # type: (InstallRequirement) -> None + super(AbstractDistribution, self).__init__() + self.req = req + + @abc.abstractmethod + def get_pkg_resources_distribution(self): + # type: () -> Optional[Distribution] + raise NotImplementedError() + + @abc.abstractmethod + def prepare_distribution_metadata(self, finder, build_isolation): + # type: (PackageFinder, bool) -> None + raise NotImplementedError() diff --git a/venv/lib/python3.8/site-packages/pip/_internal/distributions/installed.py b/venv/lib/python3.8/site-packages/pip/_internal/distributions/installed.py new file mode 100644 index 0000000..0d15bf4 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/distributions/installed.py @@ -0,0 +1,24 @@ +from pip._internal.distributions.base import AbstractDistribution +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import Optional + + from pip._vendor.pkg_resources import Distribution + from pip._internal.index.package_finder import PackageFinder + + +class InstalledDistribution(AbstractDistribution): + """Represents an installed package. + + This does not need any preparation as the required information has already + been computed. + """ + + def get_pkg_resources_distribution(self): + # type: () -> Optional[Distribution] + return self.req.satisfied_by + + def prepare_distribution_metadata(self, finder, build_isolation): + # type: (PackageFinder, bool) -> None + pass diff --git a/venv/lib/python3.8/site-packages/pip/_internal/distributions/sdist.py b/venv/lib/python3.8/site-packages/pip/_internal/distributions/sdist.py new file mode 100644 index 0000000..be3d7d9 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/distributions/sdist.py @@ -0,0 +1,104 @@ +import logging + +from pip._internal.build_env import BuildEnvironment +from pip._internal.distributions.base import AbstractDistribution +from pip._internal.exceptions import InstallationError +from pip._internal.utils.subprocess import runner_with_spinner_message +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import Set, Tuple + + from pip._vendor.pkg_resources import Distribution + from pip._internal.index.package_finder import PackageFinder + + +logger = logging.getLogger(__name__) + + +class SourceDistribution(AbstractDistribution): + """Represents a source distribution. + + The preparation step for these needs metadata for the packages to be + generated, either using PEP 517 or using the legacy `setup.py egg_info`. + """ + + def get_pkg_resources_distribution(self): + # type: () -> Distribution + return self.req.get_dist() + + def prepare_distribution_metadata(self, finder, build_isolation): + # type: (PackageFinder, 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}." + ) + error_message = format_string.format( + requirement=self.req, + conflicting_with=conflicting_with, + description=', '.join( + '{} is incompatible with {}'.format(installed, wanted) + for installed, wanted in sorted(conflicting) + ) + ) + raise InstallationError(error_message) + + # Isolate in a BuildEnvironment and install the build-time + # requirements. + pyproject_requires = self.req.pyproject_requires + assert pyproject_requires is not None + + self.req.build_env = BuildEnvironment() + self.req.build_env.install_requirements( + finder, pyproject_requires, 'overlay', + "Installing 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) + if missing: + logger.warning( + "Missing build requirements in pyproject.toml for %s.", + self.req, + ) + logger.warning( + "The project does not specify a build backend, and " + "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. + 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() + + conflicting, missing = self.req.build_env.check_requirements(reqs) + if conflicting: + _raise_conflicts("the backend dependencies", conflicting) + self.req.build_env.install_requirements( + finder, missing, 'normal', + "Installing backend dependencies" + ) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/distributions/wheel.py b/venv/lib/python3.8/site-packages/pip/_internal/distributions/wheel.py new file mode 100644 index 0000000..bf3482b --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/distributions/wheel.py @@ -0,0 +1,36 @@ +from zipfile import ZipFile + +from pip._internal.distributions.base import AbstractDistribution +from pip._internal.utils.typing import MYPY_CHECK_RUNNING +from pip._internal.utils.wheel import pkg_resources_distribution_for_wheel + +if MYPY_CHECK_RUNNING: + from pip._vendor.pkg_resources import Distribution + from pip._internal.index.package_finder import PackageFinder + + +class WheelDistribution(AbstractDistribution): + """Represents a wheel distribution. + + This does not need any preparation as wheels can be directly unpacked. + """ + + def get_pkg_resources_distribution(self): + # type: () -> Distribution + """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 + pass diff --git a/venv/lib/python3.8/site-packages/pip/_internal/exceptions.py b/venv/lib/python3.8/site-packages/pip/_internal/exceptions.py new file mode 100644 index 0000000..dddec78 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/exceptions.py @@ -0,0 +1,308 @@ +"""Exceptions used throughout package""" + +# The following comment should be removed at some point in the future. +# mypy: disallow-untyped-defs=False + +from __future__ import absolute_import + +from itertools import chain, groupby, repeat + +from pip._vendor.six import iteritems + +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import Optional + from pip._vendor.pkg_resources import Distribution + from pip._internal.req.req_install import InstallRequirement + + +class PipError(Exception): + """Base pip exception""" + + +class ConfigurationError(PipError): + """General exception in configuration""" + + +class InstallationError(PipError): + """General exception during installation""" + + +class UninstallationError(PipError): + """General exception during uninstallation""" + + +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"). + """ + + def __init__(self, dist, metadata_name): + # type: (Distribution, str) -> None + """ + :param dist: A Distribution object. + :param metadata_name: The name of the metadata being accessed + (can be "METADATA" or "PKG-INFO"). + """ + self.dist = dist + self.metadata_name = metadata_name + + def __str__(self): + # type: () -> 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, + ) + ) + + +class DistributionNotFound(InstallationError): + """Raised when a distribution cannot be found to satisfy a requirement""" + + +class RequirementsFileParseError(InstallationError): + """Raised when a general error occurs parsing a requirements file line.""" + + +class BestVersionAlreadyInstalled(PipError): + """Raised when the most up-to-date version of a package is already + installed.""" + + +class BadCommand(PipError): + """Raised when virtualenv or a command is not found""" + + +class CommandError(PipError): + """Raised when there is an error in command-line arguments""" + + +class PreviousBuildDirError(PipError): + """Raised when there's a previous conflicting build directory""" + + +class InvalidWheelFilename(InstallationError): + """Invalid wheel filename.""" + + +class UnsupportedWheel(InstallationError): + """Unsupported wheel.""" + + +class HashErrors(InstallationError): + """Multiple HashError instances rolled into one for reporting""" + + def __init__(self): + self.errors = [] + + def append(self, error): + self.errors.append(error) + + def __str__(self): + 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) + + def __nonzero__(self): + return bool(self.errors) + + def __bool__(self): + return self.__nonzero__() + + +class HashError(InstallationError): + """ + A failure to verify a package against known-good hashes + + :cvar order: An int sorting hash exception classes by difficulty of + recovery (lower being harder), so the user doesn't bother fretting + about unpinned packages when he has deeper issues, like VCS + dependencies, to deal with. Also keeps error reports in a + deterministic order. + :cvar head: A section heading for display above potentially many + exceptions of this kind + :ivar req: The InstallRequirement that triggered this error. This is + pasted on after the exception is instantiated, because it's not + typically available earlier. + + """ + req = None # type: Optional[InstallRequirement] + head = '' + + def body(self): + """Return a summary of me for display under the heading. + + This default implementation simply prints a description of the + triggering requirement. + + :param req: The InstallRequirement that provoked this error, with + populate_link() having already been called + + """ + return ' %s' % self._requirement_name() + + def __str__(self): + return '%s\n%s' % (self.head, self.body()) + + def _requirement_name(self): + """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' + + +class VcsHashUnsupported(HashError): + """A hash was provided for a version-control-system-based requirement, but + 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:") + + +class DirectoryUrlHashUnsupported(HashError): + """A hash was provided for a version-control-system-based requirement, but + 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:") + + +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): + """ + :param gotten_hash: The hash of the (possibly malicious) archive we + just downloaded + """ + self.gotten_hash = gotten_hash + + def body(self): + # Dodge circular import. + from pip._internal.utils.hashes import FAVORITE_HASH + + package = None + if self.req: + # 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 ' %s --hash=%s:%s' % (package or 'unknown package', + FAVORITE_HASH, + self.gotten_hash) + + +class HashUnpinned(HashError): + """A requirement had a hash specified but was not pinned to a specific + version.""" + + order = 3 + head = ('In --require-hashes mode, all requirements must have their ' + 'versions pinned with ==. These do not:') + + +class HashMismatch(HashError): + """ + Distribution file hash values don't match. + + :ivar package_name: The name of the package that triggered the hash + mismatch. Feel free to write to this after the exception is raise to + 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): + """ + :param allowed: A dict of algorithm names pointing to lists of allowed + hex digests + :param gots: A dict of algorithm names pointing to hashes we + actually got from the files under suspicion + """ + self.allowed = allowed + self.gots = gots + + def body(self): + return ' %s:\n%s' % (self._requirement_name(), + self._hash_comparison()) + + def _hash_comparison(self): + """ + Return a comparison of actual and expected hash values. + + Example:: + + Expected sha256 abcdeabcdeabcdeabcdeabcdeabcdeabcdeabcdeabcde + or 123451234512345123451234512345123451234512345 + Got bcdefbcdefbcdefbcdefbcdefbcdefbcdefbcdefbcdef + + """ + def hash_then_or(hash_name): + # 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')) + + lines = [] + for hash_name, expecteds in iteritems(self.allowed): + prefix = hash_then_or(hash_name) + lines.extend((' Expected %s %s' % (next(prefix), e)) + for e in expecteds) + lines.append(' Got %s\n' % + self.gots[hash_name].hexdigest()) + return '\n'.join(lines) + + +class UnsupportedPythonVersion(InstallationError): + """Unsupported python version according to Requires-Python package + metadata.""" + + +class ConfigurationFileCouldNotBeLoaded(ConfigurationError): + """When there are errors while loading a configuration file + """ + + def __init__(self, reason="could not be loaded", fname=None, error=None): + super(ConfigurationFileCouldNotBeLoaded, self).__init__(error) + self.reason = reason + self.fname = fname + self.error = error + + def __str__(self): + if self.fname is not None: + message_part = " in {}.".format(self.fname) + else: + assert self.error is not None + message_part = ".\n{}\n".format(self.error.message) + return "Configuration file {}{}".format(self.reason, message_part) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/index/__init__.py b/venv/lib/python3.8/site-packages/pip/_internal/index/__init__.py new file mode 100644 index 0000000..7a17b7b --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/index/__init__.py @@ -0,0 +1,2 @@ +"""Index interaction code +""" diff --git a/venv/lib/python3.8/site-packages/pip/_internal/index/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/index/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..6adc64dc26d78238bda86117cf6b144d4cde3d3e GIT binary patch literal 190 zcmWIL<>g`k0&_FfL^&Y+7{oyaj6jY95EpX*i4=w?h7`tN22G|aanHPz)Cz^nypq(S z#N?99{5*x^{FGEKKTXD4?D6p_`N{F|D;bKIfV#lMF9-dS+yecA%mUrgyn@8!?9>$9 z@{H8f9No;)^g@eDlX8%pemvN~yu=*+Opy8d@j!vhlK6PNg34PQHo5sJr8%i~AUAym GVg>*P%`uh$ literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/index/__pycache__/collector.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/index/__pycache__/collector.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..9bc9977a1bbbaa63369a5e29f6ba019edf6b505a GIT binary patch literal 14156 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�-{FdlG7OqrLLINYsyt+KC##y5RB| zO))6(h&gGE5viZ+O$C1JA0gopuSQ2!Zy>V5=F$kE=EMAN)3fHy0hMqA}s#pDGjl%p4}-oS0*W(uY?@c`?Jt2fe#REzgE z<#apu_SWi{H4cS++To;>_($}KJQU!iX`8k+35A`saBaDkWu|{Wa|$X#n;``zXZfw; z8!<^DK836mnf{8v&hO`lRIS)+7Ptg7;3g6x@*%BtGRlMmOBBdODRS^Xu0v&`VZZ?oc zZfNqW(AxPfrAj*`qgMJ+@r_O*R`|z4m&f**GMj;pwvKU}MW*^CK&C>aJ?>B|BjJ#7{ zmQipRbSgV90i=)LQZi7erO0~joU zn7}oxR$XU74gsS(&gAs!GsP8PxbucO z!ig;%aB~re?qw0%#G_C{2CQnedpR@5GOXU@mRaQ?vg&OxM}mHE@PM(1lc_$7&5`Ab z(x-YTCbE}uX$~f&Zpgsr&}a~e-i;f0Ujr&UPE){0lwmrc=^StkgyLmuu6J;@(}k)s zE?W$N980WqFq-iWM&1!Gy3!C#9q)gUtC&Xtt|BVCxaA1vtoSe0~_ucU&o9yU#X_HPpxcSss{tUL{j1x6vZfz(Psa+;UkBS^uJG}8S0-m23+!~`^4&?1 zaJ=kf>UcV@(MxVMZCW#l^^}jg#Og$8l-`IyM|GJE0~Tc#Z5BjB1pm|sI`=&^TJG@b zt1JpE7-}au*!;v67=s2SnE(mWHOsP+!UC3y#fq6Jmvq=6@C~h2Qrg@x(+H|r)5!qA zog@dqOML}b+imaousl8vv66Vuuo#h8pW61$96ShO6+5@v+?V5q)F{9o3kV15*yfXx zy;EPopV*&F;cg$E@@u25XHH?;ZYKg$;340_5{8U8#dzR_n3r%93L8*>gs3)Uv-h(2 z_;i*r_jc58VW@LM#-Cgzdvo|kpP*PWzRs`tuJNw9 zXyL?z^^OZai~X)QlC>PYF5a8zlikm)1O1Ui%8pJTnfg)RR_FS;HK*+&dCE!h#P&#? zu%-E(zNx+;{gGZV$wEF|;1x#RjkF5+HQKs;r(a;AhTuHD`a_KR!Fwk1Zp?$4AI7Ei zk-*Me2WtLHdX32p--l~J$|kjJ2d6|gaCKii&ef=Y-7?ZX8Oh07yl1?Jw*@B)y|;yv zXByWUhy}NBvIA{}Y7#6$tOzL9TT-3wD&mU$v|`bIZ#vx_jmpB<{Rk7I%6^S{&uGjX zC=P5@1Bp6igBba=bUy5{G0r}C_za02IY-gEjSS+xt4910JpjTW;vZP=!!u)N-iCL5 z0Iw)}_9pE5d+Gjt8XD#2&Ovw_NED7!h-DV^77^$qhE0ksXfC(qqNKEh!xfRHG36`U3isNd{fpo%WINO|VK-l#6zV#q242v zNUFq3h3X}k>C$S|d{~b1AOqvv~`>Kuk5=Xfol<|UqQ$uW2M#~ z(ZF@=>k}wIm_x&Y?H}}%hC|o^Vg)%B1=k>HrNDVIRD`_(Y|CxkW}_FTK12YP&>;$u z&4UO49{p^uZTg|Ic0qbLhA9qE%6UjN-c-oXm4AdqQeHV+V40dJ5m@5frzw17Ti6NH@)@ z6F5NuU{WD)gCc(2padH+l8g;0c<*~c*Ngg`N&~UD96U%>jJnF^8EmIzf`(#?hHO&~ zq}A+}ZN#RjfFOYFFbo*E$&|Dqa%u=0J#r{gA4m~j2A7|%K=X^al^j<|#hrA>KD-`? zJDs%PTN>*^jy^zglF>-c`{67a4*bbZEg+5K=pfhXJG|QDjj)CM`lpO729Unq?jh<8 z7(Nt@paYWZQ~~MUfej#R8>~c6C4%-Ao^GF%5B`Od@~w**wQcmuRa>&j>9b$1nB2blgjDDWaf}&g(c%Akx z#ZJG3QA$B+y%4*+#!9Rub8VzwLVP~8HrgLqF9sus*he?8Mnu)?5P7g==^ zdtBHS5hvq&!xk%5>`gA?Opy9RPh{OqobJ(6)JxQe%bLZfkZ13o>kPm79W)QsD`!nmyV`5p~?reSIdVK-l z9=$?jpw^K^#U-lmvDl{Ve~G&MU{zS(Ehmv2gBYa{VQS5!VB)YD7_P7fwuKl_7AEz{ zBqGZw#HMpt>!`+317~j4UvPfnscO>%h{@q1N?ZhmAEdEIfA*PWh)&?K_U^_T>6_j( zWxEF0Z)$3O?yDxn6H8$mQL#EXn!T`%7w%PlIW}aS|NmE}{tE9kHngV0Z>uV#+%q+_0FyBqsE&RqES%=9K^`7kExMK z?llM!ne3Gw*+F}>4?-X&6a{^7{jTBX-ME3r6c>Rh^lA1zw`v2lx-Q#W>01t_&_kd* zi8etp+_FE`90@9-n71c8hUWl=DVezbUkFY*8l8vQ#e!y9-Ohr?(9~WQ`&it8BH8sO z4m#uHau`<9?cW7lCplDCr(`0{s!B$3MT?x=JG_RJRzq>$U2M0FW@)Ti$&RgZ3oXgZ z^vTH9`3vbyb%Y5^dZT^=&8rh>2pv8r=fI<+2%B?W&hBXixQJHr{~hFTUs61qomQ7PqfoJHyNhrNzP77YadYFt{DdBa<$^w!6c9*d1}F a+x&y+Lr*Dl-mYuB@lTsbH2vh|ThzMPlqTz#}r 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 F|1Yo8;2;11 literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/index/collector.py b/venv/lib/python3.8/site-packages/pip/_internal/index/collector.py new file mode 100644 index 0000000..8330793 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/index/collector.py @@ -0,0 +1,544 @@ +""" +The main purpose of this module is to expose LinkCollector.collect_links(). +""" + +import cgi +import itertools +import logging +import mimetypes +import os +from collections import OrderedDict + +from pip._vendor import html5lib, requests +from pip._vendor.distlib.compat import unescape +from pip._vendor.requests.exceptions import HTTPError, RetryError, SSLError +from pip._vendor.six.moves.urllib import parse as urllib_parse +from pip._vendor.six.moves.urllib import request as urllib_request + +from pip._internal.models.link import Link +from pip._internal.utils.filetypes import ARCHIVE_EXTENSIONS +from pip._internal.utils.misc import redact_auth_from_url +from pip._internal.utils.typing import MYPY_CHECK_RUNNING +from pip._internal.utils.urls import path_to_url, url_to_path +from pip._internal.vcs import is_url, vcs + +if MYPY_CHECK_RUNNING: + from typing import ( + Callable, Iterable, List, MutableMapping, Optional, Sequence, Tuple, + Union, + ) + import xml.etree.ElementTree + + from pip._vendor.requests import Response + + from pip._internal.models.search_scope import SearchScope + from pip._internal.network.session import PipSession + + HTMLElement = xml.etree.ElementTree.Element + ResponseHeaders = MutableMapping[str, str] + + +logger = logging.getLogger(__name__) + + +def _match_vcs_scheme(url): + # type: (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 '+:': + return scheme + return None + + +def _is_url_like_archive(url): + # type: (str) -> bool + """Return whether the URL looks like an archive. + """ + filename = Link(url).filename + for bad_ext in ARCHIVE_EXTENSIONS: + if filename.endswith(bad_ext): + return True + return False + + +class _NotHTML(Exception): + def __init__(self, content_type, request_desc): + # type: (str, str) -> None + super(_NotHTML, self).__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. + + Raises `_NotHTML` if the content type is not text/html. + """ + content_type = response.headers.get("Content-Type", "") + if not content_type.lower().startswith("text/html"): + raise _NotHTML(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. + + Raises `_NotHTTP` if the URL is not available for a HEAD request, or + `_NotHTML` if the content type is not text/html. + """ + scheme, netloc, path, query, fragment = urllib_parse.urlsplit(url) + if scheme not in {'http', 'https'}: + raise _NotHTTP() + + resp = session.head(url, allow_redirects=True) + resp.raise_for_status() + + _ensure_html_header(resp) + + +def _get_html_response(url, session): + # type: (str, PipSession) -> Response + """Access an HTML page 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. + 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. + """ + if _is_url_like_archive(url): + _ensure_html_response(url, session=session) + + logger.debug('Getting page %s', redact_auth_from_url(url)) + + resp = session.get( + url, + headers={ + "Accept": "text/html", + # We don't want to blindly returned cached data for + # /simple/, because authors generally expecting that + # twine upload && pip install will function, but if + # they've done a pip install in the last ~10 minutes + # it won't. Thus by setting this to zero we will not + # blindly use any cached data, however the benefit of + # using max-age=0 instead of no-cache, is that we will + # still support conditional requests, so we will still + # minimize traffic sent in cases where the page hasn't + # changed at all, we will just always incur the round + # trip for the conditional GET now instead of only + # once per 10 minutes. + # For more information, please see pypa/pip#5670. + "Cache-Control": "max-age=0", + }, + ) + resp.raise_for_status() + + # 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) + + return resp + + +def _get_encoding_from_headers(headers): + # type: (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'] + return None + + +def _determine_base_url(document, page_url): + # type: (HTMLElement, str) -> str + """Determine the HTML document's base URL. + + This looks for a ```` 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_link(url): + # type: (str) -> str + """Makes sure a link is fully encoded. That is, if a ' ' shows up in + the link, it will be rewritten to %20 (while not over-quoting + % or other characters).""" + # Split the URL into parts according to the general structure + # `scheme://netloc/path;parameters?query#fragment`. Note that the + # `netloc` can be empty and the URI will then refer to a local + # filesystem path. + result = urllib_parse.urlparse(url) + # In both cases below we unquote prior to quoting to make sure + # nothing is double quoted. + if result.netloc == "": + # 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. + path = urllib_request.pathname2url( + urllib_request.url2pathname(result.path)) + else: + # In addition to the `/` character we protect `@` so that + # revision strings in VCS URLs are properly parsed. + path = urllib_parse.quote(urllib_parse.unquote(result.path), safe="/@") + 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 = unescape(pyrequire) if pyrequire else None + + yanked_reason = anchor.get('data-yanked') + if yanked_reason: + # This is a unicode string in Python 2 (and 3). + yanked_reason = unescape(yanked_reason) + + link = Link( + url, + comes_from=page_url, + requires_python=pyrequire, + yanked_reason=yanked_reason, + ) + + return link + + +def parse_links(page): + # type: (HTMLPage) -> Iterable[Link] + """ + Parse an HTML document, and yield its anchor elements as Link objects. + """ + document = html5lib.parse( + page.content, + transport_encoding=page.encoding, + namespaceHTMLElements=False, + ) + + 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, + ) + if link is None: + continue + yield link + + +class HTMLPage(object): + """Represents one page, along with its URL""" + + def __init__( + self, + content, # type: bytes + encoding, # type: Optional[str] + url, # type: str + ): + # type: (...) -> None + """ + :param encoding: the encoding to decode the given content. + :param url: the URL from which the HTML was downloaded. + """ + self.content = content + self.encoding = encoding + self.url = url + + def __str__(self): + # type: () -> 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 + if meth is None: + meth = logger.debug + meth("Could not fetch URL %s: %s - skipping", link, reason) + + +def _make_html_page(response): + # type: (Response) -> HTMLPage + encoding = _get_encoding_from_headers(response.headers) + return HTMLPage(response.content, encoding=encoding, url=response.url) + + +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] + + # Check for VCS schemes that do not support lookup as web pages. + vcs_scheme = _match_vcs_scheme(url) + if vcs_scheme: + logger.debug('Cannot look at %s URL %s', 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))): + # 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) + + try: + resp = _get_html_response(url, session=session) + except _NotHTTP: + logger.debug( + 'Skipping page %s because it looks like an archive, and cannot ' + 'be checked by HEAD.', link, + ) + except _NotHTML as exc: + logger.debug( + 'Skipping page %s because the %s request got Content-Type: %s', + link, exc.request_desc, exc.content_type, + ) + except HTTPError as exc: + _handle_get_page_fail(link, exc) + except RetryError as exc: + _handle_get_page_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) + except requests.ConnectionError as exc: + _handle_get_page_fail(link, "connection error: %s" % exc) + except requests.Timeout: + _handle_get_page_fail(link, "timed out") + else: + return _make_html_page(resp) + return None + + +def _remove_duplicate_links(links): + # type: (Iterable[Link]) -> List[Link] + """ + Return a list of links, with duplicates removed and ordering preserved. + """ + # We preserve the ordering when removing duplicates because we can. + return list(OrderedDict.fromkeys(links)) + + +def group_locations(locations, expand_dir=False): + # type: (Sequence[str], bool) -> Tuple[List[str], List[str]] + """ + Divide a list of locations into two groups: "files" (archives) and "urls." + + :return: A pair of lists (files, urls). + """ + files = [] + urls = [] + + # puts the url for the given file path into the appropriate list + def sort_path(path): + # type: (str) -> None + url = path_to_url(path) + if mimetypes.guess_type(url, strict=False)[0] == 'text/html': + urls.append(url) + else: + files.append(url) + + for url in locations: + + is_local_path = os.path.exists(url) + is_file_url = url.startswith('file:') + + if is_local_path or is_file_url: + if is_local_path: + path = url + else: + path = url_to_path(url) + if os.path.isdir(path): + if expand_dir: + path = os.path.realpath(path) + for item in os.listdir(path): + sort_path(os.path.join(path, item)) + elif is_file_url: + urls.append(url) + else: + logger.warning( + "Path '{0}' is ignored: " + "it is a directory.".format(path), + ) + elif os.path.isfile(path): + sort_path(path) + else: + logger.warning( + "Url '%s' is ignored: it is neither a file " + "nor a directory.", url, + ) + elif is_url(url): + # Only add url with clear scheme + urls.append(url) + else: + logger.warning( + "Url '%s' is ignored. It is either a non-existing " + "path or lacks a specific scheme.", url, + ) + + return files, urls + + +class CollectedLinks(object): + + """ + Encapsulates the return value of a call to LinkCollector.collect_links(). + + The return value includes both URLs to project pages containing package + links, as well as individual package Link objects collected from other + sources. + + This info is stored separately as: + + (1) links from the configured file locations, + (2) links from the configured find_links, and + (3) urls to HTML project pages, as described by the PEP 503 simple + repository API. + """ + + def __init__( + self, + files, # type: List[Link] + find_links, # type: List[Link] + project_urls, # type: List[Link] + ): + # type: (...) -> None + """ + :param files: Links from file locations. + :param find_links: Links from find_links. + :param project_urls: URLs to HTML project pages, as described by + the PEP 503 simple repository API. + """ + self.files = files + self.find_links = find_links + self.project_urls = project_urls + + +class LinkCollector(object): + + """ + Responsible for collecting Link objects from all configured locations, + making network requests as needed. + + The class's main method is its collect_links() method. + """ + + def __init__( + self, + session, # type: PipSession + search_scope, # type: SearchScope + ): + # type: (...) -> None + self.search_scope = search_scope + self.session = session + + @property + def find_links(self): + # type: () -> List[str] + return self.search_scope.find_links + + def fetch_page(self, location): + # type: (Link) -> Optional[HTMLPage] + """ + Fetch an HTML page containing package links. + """ + return _get_html_page(location, session=self.session) + + def collect_links(self, project_name): + # type: (str) -> CollectedLinks + """Find all available links for the given project name. + + :return: All the Link objects (unfiltered), as a CollectedLinks object. + """ + search_scope = self.search_scope + index_locations = search_scope.get_index_urls_locations(project_name) + index_file_loc, index_url_loc = group_locations(index_locations) + fl_file_loc, fl_url_loc = group_locations( + self.find_links, expand_dir=True, + ) + + file_links = [ + Link(url) for url in itertools.chain(index_file_loc, fl_file_loc) + ] + + # We trust every directly linked archive in find_links + find_link_links = [Link(url, '-f') for url in self.find_links] + + # We trust every url that the user has given us whether it was given + # via --index-url or --find-links. + # We want to filter out anything that does not have a secure origin. + url_locations = [ + link for link in itertools.chain( + (Link(url) for url in index_url_loc), + (Link(url) for url in fl_url_loc), + ) + if self.session.is_secure_origin(link) + ] + + url_locations = _remove_duplicate_links(url_locations) + lines = [ + '{} location(s) to search for versions of {}:'.format( + len(url_locations), project_name, + ), + ] + for link in url_locations: + lines.append('* {}'.format(link)) + logger.debug('\n'.join(lines)) + + return CollectedLinks( + files=file_links, + find_links=find_link_links, + project_urls=url_locations, + ) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/index/package_finder.py b/venv/lib/python3.8/site-packages/pip/_internal/index/package_finder.py new file mode 100644 index 0000000..a74d78d --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/index/package_finder.py @@ -0,0 +1,1013 @@ +"""Routines related to PyPI, indexes""" + +# The following comment should be removed at some point in the future. +# mypy: strict-optional=False + +from __future__ import absolute_import + +import logging +import re + +from pip._vendor.packaging import specifiers +from pip._vendor.packaging.utils import canonicalize_name +from pip._vendor.packaging.version import parse as parse_version + +from pip._internal.exceptions import ( + BestVersionAlreadyInstalled, + DistributionNotFound, + InvalidWheelFilename, + UnsupportedWheel, +) +from pip._internal.index.collector import parse_links +from pip._internal.models.candidate import InstallationCandidate +from pip._internal.models.format_control import FormatControl +from pip._internal.models.link import Link +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.utils.filetypes import WHEEL_EXTENSION +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.typing import MYPY_CHECK_RUNNING +from pip._internal.utils.unpacking import SUPPORTED_EXTENSIONS +from pip._internal.utils.urls import url_to_path + +if MYPY_CHECK_RUNNING: + from typing import ( + FrozenSet, Iterable, List, Optional, Set, Text, Tuple, Union, + ) + + from pip._vendor.packaging.tags import Tag + from pip._vendor.packaging.version import _BaseVersion + + from pip._internal.index.collector import LinkCollector + from pip._internal.models.search_scope import SearchScope + from pip._internal.req import InstallRequirement + from pip._internal.utils.hashes import Hashes + + BuildTag = Union[Tuple[()], Tuple[int, str]] + CandidateSortingKey = ( + Tuple[int, int, int, _BaseVersion, BuildTag, Optional[int]] + ) + + +__all__ = ['FormatControl', 'BestCandidateResult', 'PackageFinder'] + + +logger = logging.getLogger(__name__) + + +def _check_link_requires_python( + link, # type: Link + version_info, # type: Tuple[int, int, int] + ignore_requires_python=False, # type: bool +): + # type: (...) -> bool + """ + Return whether the given Python version is compatible with a link's + "Requires-Python" value. + + :param version_info: A 3-tuple of ints representing the Python + major-minor-micro version to check. + :param ignore_requires_python: Whether to ignore the "Requires-Python" + value if the given Python version isn't compatible. + """ + try: + is_compatible = check_requires_python( + link.requires_python, version_info=version_info, + ) + except specifiers.InvalidSpecifier: + logger.debug( + "Ignoring invalid Requires-Python (%r) for link: %s", + link.requires_python, link, + ) + else: + if not is_compatible: + 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, + ) + return False + + logger.debug( + 'Ignoring failed Requires-Python check (%s not in: %r) ' + 'for link: %s', + version, link.requires_python, link, + ) + + return True + + +class LinkEvaluator(object): + + """ + Responsible for evaluating links for a particular project. + """ + + _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 + # that decision to be made explicit in the calling code, which helps + # 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 + """ + :param project_name: The user supplied package name. + :param canonical_name: The canonical package name. + :param formats: The formats allowed for this package. Should be a set + with 'binary' or 'source' or both in it. + :param target_python: The target Python interpreter to use when + evaluating link compatibility. This is used, for example, to + check wheel compatibility, as well as when checking the Python + version, e.g. the Python version embedded in a link filename + (or egg fragment) and against an HTML link's optional PEP 503 + "data-requires-python" attribute. + :param allow_yanked: Whether files marked as yanked (in the sense + of PEP 592) are permitted to be candidates for install. + :param ignore_requires_python: Whether to ignore incompatible + PEP 503 "data-requires-python" values in HTML links. Defaults + to False. + """ + if ignore_requires_python is None: + ignore_requires_python = False + + self._allow_yanked = allow_yanked + self._canonical_name = canonical_name + self._ignore_requires_python = ignore_requires_python + self._formats = formats + self._target_python = target_python + + self.project_name = project_name + + def evaluate_link(self, link): + # type: (Link) -> Tuple[bool, Optional[Text]] + """ + 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. + """ + version = None + if link.is_yanked and not self._allow_yanked: + reason = link.yanked_reason or '' + # Mark this as a unicode string to prevent "UnicodeEncodeError: + # 'ascii' codec can't encode character" in Python 2 when + # the reason contains non-ascii characters. + return (False, u'yanked for reason: {}'.format(reason)) + + if link.egg_fragment: + egg_info = link.egg_fragment + ext = link.ext + else: + egg_info, ext = link.splitext() + if not ext: + return (False, 'not a file') + if ext not in SUPPORTED_EXTENSIONS: + return (False, 'unsupported archive format: %s' % ext) + if "binary" not in self._formats and ext == WHEEL_EXTENSION: + reason = 'No binaries permitted for %s' % self.project_name + return (False, reason) + if "macosx10" in link.path and ext == '.zip': + return (False, 'macosx10 one') + if ext == WHEEL_EXTENSION: + try: + wheel = Wheel(link.filename) + except InvalidWheelFilename: + return (False, 'invalid wheel filename') + if canonicalize_name(wheel.name) != self._canonical_name: + reason = 'wrong project name (not %s)' % self.project_name + return (False, 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() + reason = ( + "none of the wheel's tags match: {}".format( + ', '.join(file_tags) + ) + ) + return (False, 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: + return (False, 'No sources permitted for %s' % self.project_name) + + if not version: + version = _extract_version_from_fragment( + egg_info, self._canonical_name, + ) + if not version: + return ( + False, 'Missing project version for %s' % self.project_name, + ) + + match = self._py_version_re.search(version) + if match: + version = version[:match.start()] + py_version = match.group(1) + if py_version != self._target_python.py_version: + return (False, 'Python version is incorrect') + + supports_python = _check_link_requires_python( + 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) + + logger.debug('Found link %s, version: %s', link, version) + + return (True, version) + + +def filter_unallowed_hashes( + candidates, # type: List[InstallationCandidate] + hashes, # type: Hashes + project_name, # type: str +): + # type: (...) -> List[InstallationCandidate] + """ + Filter out candidates whose hashes aren't allowed, and return a new + list of candidates. + + If at least one candidate has an allowed hash, then all candidates with + either an allowed hash or no hash specified are returned. Otherwise, + the given candidates are returned. + + Including the candidates with no hash specified when there is a match + allows a warning to be logged if there is a more preferred candidate + with no hash specified. Returning all candidates in the case of no + matches lets pip report the hash of the candidate that would otherwise + have been installed (e.g. permitting the user to more easily update + their requirements file with the desired hash). + """ + if not hashes: + logger.debug( + 'Given no hashes to check %s links for project %r: ' + 'discarding no candidates', + len(candidates), + project_name, + ) + # Make sure we're not returning back the given value. + return list(candidates) + + matches_or_no_digest = [] + # Collect the non-matches for logging purposes. + non_matches = [] + match_count = 0 + for candidate in candidates: + link = candidate.link + if not link.has_hash: + pass + elif link.is_hash_allowed(hashes=hashes): + match_count += 1 + else: + non_matches.append(candidate) + continue + + matches_or_no_digest.append(candidate) + + if match_count: + filtered = matches_or_no_digest + else: + # Make sure we're not returning back the given value. + filtered = list(candidates) + + if len(filtered) == len(candidates): + discard_message = 'discarding no candidates' + else: + discard_message = 'discarding {} non-matches:\n {}'.format( + len(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', + len(candidates), + project_name, + hashes.digest_count, + match_count, + len(matches_or_no_digest) - match_count, + discard_message + ) + + return filtered + + +class CandidatePreferences(object): + + """ + Encapsulates some of the preferences for filtering and sorting + InstallationCandidate objects. + """ + + def __init__( + self, + prefer_binary=False, # type: bool + allow_all_prereleases=False, # type: bool + ): + # type: (...) -> None + """ + :param allow_all_prereleases: Whether to allow all pre-releases. + """ + self.allow_all_prereleases = allow_all_prereleases + self.prefer_binary = prefer_binary + + +class BestCandidateResult(object): + """A collection of candidates, returned by `PackageFinder.find_best_candidate`. + + This class is only intended to be instantiated by CandidateEvaluator's + `compute_best_candidate()` method. + """ + + def __init__( + self, + candidates, # type: List[InstallationCandidate] + applicable_candidates, # type: List[InstallationCandidate] + best_candidate, # type: Optional[InstallationCandidate] + ): + # type: (...) -> None + """ + :param candidates: A sequence of all available candidates found. + :param applicable_candidates: The applicable candidates. + :param best_candidate: The most preferred candidate found, or None + if no applicable candidates were found. + """ + assert set(applicable_candidates) <= set(candidates) + + if best_candidate is None: + assert not applicable_candidates + else: + assert best_candidate in applicable_candidates + + self._applicable_candidates = applicable_candidates + self._candidates = candidates + + self.best_candidate = best_candidate + + def iter_all(self): + # type: () -> Iterable[InstallationCandidate] + """Iterate through all candidates. + """ + return iter(self._candidates) + + def iter_applicable(self): + # type: () -> Iterable[InstallationCandidate] + """Iterate through the applicable candidates. + """ + return iter(self._applicable_candidates) + + +class CandidateEvaluator(object): + + """ + Responsible for filtering and sorting candidates for installation based + on what tags are valid. + """ + + @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 + """Create a CandidateEvaluator object. + + :param target_python: The target Python interpreter to use when + checking compatibility. If None (the default), a TargetPython + object will be constructed from the running Python. + :param specifier: An optional object implementing `filter` + (e.g. `packaging.specifiers.SpecifierSet`) to filter applicable + versions. + :param hashes: An optional collection of allowed hashes. + """ + if target_python is None: + target_python = TargetPython() + if specifier is None: + specifier = specifiers.SpecifierSet() + + supported_tags = target_python.get_tags() + + return cls( + project_name=project_name, + supported_tags=supported_tags, + specifier=specifier, + prefer_binary=prefer_binary, + allow_all_prereleases=allow_all_prereleases, + hashes=hashes, + ) + + 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 + """ + :param supported_tags: The PEP 425 tags supported by the target + Python in order of preference (most preferred first). + """ + self._allow_all_prereleases = allow_all_prereleases + self._hashes = hashes + self._prefer_binary = prefer_binary + self._project_name = project_name + self._specifier = specifier + self._supported_tags = supported_tags + + def get_applicable_candidates( + self, + candidates, # type: List[InstallationCandidate] + ): + # type: (...) -> List[InstallationCandidate] + """ + Return the applicable candidates from a list of candidates. + """ + # Using None infers from the specifier instead. + allow_prereleases = self._allow_all_prereleases or None + specifier = self._specifier + versions = { + 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 + # pkg_resources._vendor.packaging.version.Version as different + # types. This way we'll use a str as a common data interchange + # format. If we stop using the pkg_resources provided specifier + # and start using our own, we can drop the cast to str(). + (str(c.version) for c in candidates), + prereleases=allow_prereleases, + ) + } + + # Again, converting version to str to deal with debundling. + applicable_candidates = [ + c for c in candidates if str(c.version) in versions + ] + + filtered_applicable_candidates = filter_unallowed_hashes( + candidates=applicable_candidates, + hashes=self._hashes, + project_name=self._project_name, + ) + + return sorted(filtered_applicable_candidates, key=self._sort_key) + + def _sort_key(self, candidate): + # type: (InstallationCandidate) -> CandidateSortingKey + """ + Function to pass as the `key` argument to a call to sorted() to sort + InstallationCandidates by preference. + + Returns a tuple such that tuples sorting as greater using Python's + default comparison operator are more preferred. + + The preference is as follows: + + First and foremost, candidates with allowed (matching) hashes are + always preferred over candidates without matching hashes. This is + because e.g. if the only candidate with an allowed hash is yanked, + we still want to use that candidate. + + Second, excepting hash considerations, candidates that have been + yanked (in the sense of PEP 592) are always less preferred than + candidates that haven't been yanked. Then: + + If not finding wheels, they are sorted by version only. + If finding wheels, then the sort order is by version, then: + 1. existing installs + 2. wheels ordered via Wheel.support_index_min(self._supported_tags) + 3. source archives + If prefer_binary was set, then all wheels are sorted above sources. + + Note: it was considered to embed this logic into the Link + comparison operators, but then different sdist links + with the same version, would have to be considered equal + """ + valid_tags = self._supported_tags + support_num = len(valid_tags) + build_tag = () # type: BuildTag + binary_preference = 0 + link = candidate.link + if link.is_wheel: + # can raise InvalidWheelFilename + wheel = Wheel(link.filename) + if not wheel.supported(valid_tags): + raise UnsupportedWheel( + "%s is not a supported wheel for this platform. It " + "can't be sorted." % wheel.filename + ) + if self._prefer_binary: + binary_preference = 1 + pri = -(wheel.support_index_min(valid_tags)) + if wheel.build_tag is not None: + match = re.match(r'^(\d+)(.*)$', wheel.build_tag) + build_tag_groups = match.groups() + build_tag = (int(build_tag_groups[0]), build_tag_groups[1]) + else: # sdist + pri = -(support_num) + 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, + build_tag, pri, + ) + + def sort_best_candidate( + self, + candidates, # type: List[InstallationCandidate] + ): + # type: (...) -> Optional[InstallationCandidate] + """ + Return the best candidate per the instance's sort order, or None if + no candidate is acceptable. + """ + if not candidates: + return None + + best_candidate = max(candidates, key=self._sort_key) + + # Log a warning per PEP 592 if necessary before returning. + link = best_candidate.link + if link.is_yanked: + reason = link.yanked_reason or '' + msg = ( + # Mark this as a unicode string to prevent + # "UnicodeEncodeError: 'ascii' codec can't encode character" + # in Python 2 when the reason contains non-ascii characters. + u'The candidate selected for download or install is a ' + 'yanked version: {candidate}\n' + 'Reason for being yanked: {reason}' + ).format(candidate=best_candidate, reason=reason) + logger.warning(msg) + + return best_candidate + + def compute_best_candidate( + self, + candidates, # type: List[InstallationCandidate] + ): + # type: (...) -> BestCandidateResult + """ + Compute and return a `BestCandidateResult` instance. + """ + applicable_candidates = self.get_applicable_candidates(candidates) + + best_candidate = self.sort_best_candidate(applicable_candidates) + + return BestCandidateResult( + candidates, + applicable_candidates=applicable_candidates, + best_candidate=best_candidate, + ) + + +class PackageFinder(object): + """This finds packages. + + This is meant to match easy_install's technique for looking for + packages, by reading pages and looking for appropriate links. + """ + + 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 + """ + This constructor is primarily meant to be used by the create() class + method and from tests. + + :param format_control: A FormatControl object, used to control + the selection of source packages / binary packages when consulting + the index and links. + :param candidate_prefs: Options to use when creating a + CandidateEvaluator object. + """ + if candidate_prefs is None: + candidate_prefs = CandidatePreferences() + + format_control = format_control or FormatControl(set(), set()) + + self._allow_yanked = allow_yanked + self._candidate_prefs = candidate_prefs + self._ignore_requires_python = ignore_requires_python + self._link_collector = link_collector + self._target_python = target_python + + self.format_control = format_control + + # These are boring links that have already been logged somehow. + self._logged_links = set() # type: Set[Link] + + # Don't include an allow_yanked default value to make sure each call + # site considers whether yanked releases are allowed. This also causes + # that decision to be made explicit in the calling code, which helps + # people when reading the code. + @classmethod + def create( + cls, + link_collector, # type: LinkCollector + selection_prefs, # type: SelectionPreferences + target_python=None, # type: Optional[TargetPython] + ): + # type: (...) -> PackageFinder + """Create a PackageFinder. + + :param selection_prefs: The candidate selection preferences, as a + SelectionPreferences object. + :param target_python: The target Python interpreter to use when + checking compatibility. If None (the default), a TargetPython + object will be constructed from the running Python. + """ + if target_python is None: + target_python = TargetPython() + + candidate_prefs = CandidatePreferences( + prefer_binary=selection_prefs.prefer_binary, + allow_all_prereleases=selection_prefs.allow_all_prereleases, + ) + + return cls( + candidate_prefs=candidate_prefs, + link_collector=link_collector, + target_python=target_python, + allow_yanked=selection_prefs.allow_yanked, + format_control=selection_prefs.format_control, + ignore_requires_python=selection_prefs.ignore_requires_python, + ) + + @property + def search_scope(self): + # type: () -> SearchScope + return self._link_collector.search_scope + + @search_scope.setter + def search_scope(self, search_scope): + # type: (SearchScope) -> None + self._link_collector.search_scope = search_scope + + @property + def find_links(self): + # type: () -> List[str] + return self._link_collector.find_links + + @property + def index_urls(self): + # type: () -> List[str] + return self.search_scope.index_urls + + @property + def trusted_hosts(self): + # type: () -> 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 + return self._candidate_prefs.allow_all_prereleases + + def set_allow_all_prereleases(self): + # type: () -> None + self._candidate_prefs.allow_all_prereleases = True + + def make_link_evaluator(self, project_name): + # type: (str) -> LinkEvaluator + canonical_name = canonicalize_name(project_name) + formats = self.format_control.get_allowed_formats(canonical_name) + + return LinkEvaluator( + project_name=project_name, + canonical_name=canonical_name, + formats=formats, + target_python=self._target_python, + allow_yanked=self._allow_yanked, + ignore_requires_python=self._ignore_requires_python, + ) + + def _sort_links(self, links): + # type: (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] + for link in links: + if link not in seen: + seen.add(link) + if link.egg_fragment: + eggs.append(link) + else: + no_eggs.append(link) + return no_eggs + eggs + + def _log_skipped_link(self, link, reason): + # type: (Link, Text) -> None + if link not in self._logged_links: + # Mark this as a unicode string to prevent "UnicodeEncodeError: + # 'ascii' codec can't encode character" in Python 2 when + # the reason contains non-ascii characters. + # Also, put the link at the end so the reason is more visible + # and because the link string is usually very long. + logger.debug(u'Skipping link: %s: %s', reason, link) + self._logged_links.add(link) + + def get_install_candidate(self, link_evaluator, link): + # type: (LinkEvaluator, 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) + return None + + return InstallationCandidate( + name=link_evaluator.project_name, + link=link, + # Convert the Text result to str since InstallationCandidate + # accepts str. + version=str(result), + ) + + def evaluate_links(self, link_evaluator, links): + # type: (LinkEvaluator, Iterable[Link]) -> List[InstallationCandidate] + """ + Convert links that are candidates to InstallationCandidate objects. + """ + candidates = [] + for link in self._sort_links(links): + candidate = self.get_install_candidate(link_evaluator, link) + if candidate is not None: + candidates.append(candidate) + + return candidates + + def process_project_url(self, project_url, link_evaluator): + # type: (Link, LinkEvaluator) -> List[InstallationCandidate] + logger.debug( + 'Fetching project page and analyzing links: %s', project_url, + ) + html_page = self._link_collector.fetch_page(project_url) + if html_page is None: + return [] + + page_links = list(parse_links(html_page)) + + with indent_log(): + package_links = self.evaluate_links( + link_evaluator, + links=page_links, + ) + + return package_links + + def find_all_candidates(self, project_name): + # type: (str) -> List[InstallationCandidate] + """Find all available InstallationCandidate for project_name + + This checks index_urls and find_links. + All versions found are returned as an InstallationCandidate list. + + See LinkEvaluator.evaluate_link() for details on which files + are accepted. + """ + collected_links = self._link_collector.collect_links(project_name) + + link_evaluator = self.make_link_evaluator(project_name) + + find_links_versions = self.evaluate_links( + link_evaluator, + links=collected_links.find_links, + ) + + page_versions = [] + for project_url in collected_links.project_urls: + package_links = self.process_project_url( + project_url, link_evaluator=link_evaluator, + ) + page_versions.extend(package_links) + + file_versions = self.evaluate_links( + link_evaluator, + links=collected_links.files, + ) + if file_versions: + file_versions.sort(reverse=True) + logger.debug( + 'Local files found: %s', + ', '.join([ + url_to_path(candidate.link.url) + for candidate in file_versions + ]) + ) + + # This is an intentional priority ordering + return file_versions + find_links_versions + page_versions + + 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. + """ + candidate_prefs = self._candidate_prefs + return CandidateEvaluator.create( + project_name=project_name, + target_python=self._target_python, + prefer_binary=candidate_prefs.prefer_binary, + allow_all_prereleases=candidate_prefs.allow_all_prereleases, + specifier=specifier, + hashes=hashes, + ) + + def find_best_candidate( + self, + project_name, # type: str + specifier=None, # type: Optional[specifiers.BaseSpecifier] + hashes=None, # type: Optional[Hashes] + ): + # type: (...) -> BestCandidateResult + """Find matches for the given project and specifier. + + :param specifier: An optional object implementing `filter` + (e.g. `packaging.specifiers.SpecifierSet`) to filter applicable + versions. + + :return: A `BestCandidateResult` instance. + """ + candidates = self.find_all_candidates(project_name) + candidate_evaluator = self.make_candidate_evaluator( + project_name=project_name, + specifier=specifier, + hashes=hashes, + ) + return candidate_evaluator.compute_best_candidate(candidates) + + def find_requirement(self, req, upgrade): + # type: (InstallRequirement, bool) -> Optional[Link] + """Try to find a Link matching req + + Expects req, an InstallRequirement and upgrade, a boolean + Returns a Link if found, + Raises DistributionNotFound or BestVersionAlreadyInstalled otherwise + """ + hashes = req.hashes(trust_internet=False) + best_candidate_result = self.find_best_candidate( + req.name, specifier=req.specifier, hashes=hashes, + ) + best_candidate = best_candidate_result.best_candidate + + installed_version = None # type: Optional[_BaseVersion] + if req.satisfied_by is not None: + installed_version = parse_version(req.satisfied_by.version) + + def _format_versions(cand_iter): + # type: (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" + + 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)', + req, + _format_versions(best_candidate_result.iter_all()), + ) + + raise DistributionNotFound( + 'No matching distribution found for %s' % req + ) + + best_installed = False + if installed_version and ( + best_candidate is None or + best_candidate.version <= installed_version): + best_installed = True + + if not upgrade and installed_version is not None: + if best_installed: + logger.debug( + 'Existing installed version (%s) is most up-to-date and ' + 'satisfies requirement', + installed_version, + ) + else: + logger.debug( + 'Existing installed version (%s) satisfies requirement ' + '(most up-to-date version is %s)', + installed_version, + best_candidate.version, + ) + return None + + if best_installed: + # We have an existing version, and its the best version + logger.debug( + 'Installed version (%s) is most up-to-date (past versions: ' + '%s)', + installed_version, + _format_versions(best_candidate_result.iter_applicable()), + ) + raise BestVersionAlreadyInstalled + + logger.debug( + 'Using version %s (newest of versions: %s)', + best_candidate.version, + _format_versions(best_candidate_result.iter_applicable()), + ) + return best_candidate.link + + +def _find_name_version_sep(fragment, canonical_name): + # type: (str, str) -> int + """Find the separator's index based on the package's canonical name. + + :param fragment: A + filename "fragment" (stem) or + egg fragment. + :param canonical_name: The package's canonical name. + + This function is needed since the canonicalized name does not necessarily + have the same length as the egg info's name part. An example:: + + >>> fragment = 'foo__bar-1.0' + >>> canonical_name = 'foo-bar' + >>> _find_name_version_sep(fragment, canonical_name) + 8 + """ + # Project name and version must be separated by one single dash. Find all + # occurrences of dashes; if the string in front of it matches the canonical + # name, this is the one separating the name and version parts. + for i, c in enumerate(fragment): + if c != "-": + continue + if canonicalize_name(fragment[:i]) == canonical_name: + return i + raise ValueError("{} does not match {}".format(fragment, canonical_name)) + + +def _extract_version_from_fragment(fragment, canonical_name): + # type: (str, str) -> Optional[str] + """Parse the version string from a + filename + "fragment" (stem) or egg fragment. + + :param fragment: The string to parse. E.g. foo-2.1 + :param canonical_name: The canonicalized name of the package this + belongs to. + """ + try: + version_start = _find_name_version_sep(fragment, canonical_name) + 1 + except ValueError: + return None + version = fragment[version_start:] + if not version: + return None + return version diff --git a/venv/lib/python3.8/site-packages/pip/_internal/legacy_resolve.py b/venv/lib/python3.8/site-packages/pip/_internal/legacy_resolve.py new file mode 100644 index 0000000..ca26912 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/legacy_resolve.py @@ -0,0 +1,430 @@ +"""Dependency Resolution + +The dependency resolution in pip is performed as follows: + +for top-level requirements: + a. only one spec allowed per project, regardless of conflicts or not. + otherwise a "double requirement" exception is raised + b. they override sub-dependency requirements. +for sub-dependencies + a. "first found, wins" (where the order is breadth first) +""" + +# The following comment should be removed at some point in the future. +# mypy: strict-optional=False +# mypy: disallow-untyped-defs=False + +import logging +import sys +from collections import defaultdict +from itertools import chain + +from pip._vendor.packaging import specifiers + +from pip._internal.exceptions import ( + BestVersionAlreadyInstalled, + DistributionNotFound, + HashError, + HashErrors, + UnsupportedPythonVersion, +) +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.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import Callable, DefaultDict, List, Optional, Set, Tuple + from pip._vendor import pkg_resources + + from pip._internal.distributions import AbstractDistribution + from pip._internal.index.package_finder import PackageFinder + from pip._internal.operations.prepare import RequirementPreparer + from pip._internal.req.req_install import InstallRequirement + from pip._internal.req.req_set import RequirementSet + + InstallRequirementProvider = Callable[ + [str, InstallRequirement], InstallRequirement + ] + DiscoveredDependencies = DefaultDict[str, List[InstallRequirement]] + +logger = logging.getLogger(__name__) + + +def _check_dist_requires_python( + dist, # type: pkg_resources.Distribution + version_info, # type: Tuple[int, int, int] + ignore_requires_python=False, # type: bool +): + # type: (...) -> None + """ + Check whether the given Python version is compatible with a distribution's + "Requires-Python" value. + + :param version_info: A 3-tuple of ints representing the Python + major-minor-micro version to check. + :param ignore_requires_python: Whether to ignore the "Requires-Python" + value if the given Python version isn't compatible. + + :raises UnsupportedPythonVersion: When the given Python version isn't + compatible. + """ + requires_python = get_requires_python(dist) + try: + is_compatible = check_requires_python( + 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, + ) + return + + if is_compatible: + return + + 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, version, requires_python, + ) + return + + raise UnsupportedPythonVersion( + 'Package {!r} requires a different Python: {} not in {!r}'.format( + dist.project_name, version, requires_python, + )) + + +class Resolver(object): + """Resolves which packages need to be installed/uninstalled to perform \ + the requested operation without breaking the requirements of any package. + """ + + _allowed_strategies = {"eager", "only-if-needed", "to-satisfy-only"} + + def __init__( + self, + preparer, # type: RequirementPreparer + finder, # type: PackageFinder + 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 + super(Resolver, self).__init__() + assert upgrade_strategy in self._allowed_strategies + + if py_version_info is None: + py_version_info = sys.version_info[:3] + else: + py_version_info = normalize_version_info(py_version_info) + + self._py_version_info = py_version_info + + self.preparer = preparer + self.finder = finder + + self.upgrade_strategy = upgrade_strategy + self.force_reinstall = force_reinstall + self.ignore_dependencies = ignore_dependencies + self.ignore_installed = ignore_installed + self.ignore_requires_python = ignore_requires_python + self.use_user_site = use_user_site + self._make_install_req = make_install_req + + self._discovered_dependencies = \ + defaultdict(list) # type: DiscoveredDependencies + + def resolve(self, requirement_set): + # type: (RequirementSet) -> None + """Resolve what operations need to be done + + As a side-effect of this method, the packages (and their dependencies) + are downloaded, unpacked and prepared for installation. This + preparation is done by ``pip.operations.prepare``. + + Once PyPI has static dependency metadata available, it would be + possible to move the preparation to become a step separated from + dependency resolution. + """ + # If any top-level requirement has a hash specified, enter + # hash-checking mode, which requires hashes from all. + root_reqs = ( + requirement_set.unnamed_requirements + + list(requirement_set.requirements.values()) + ) + + # Actually prepare the files, and collect any exceptions. Most hash + # exceptions cannot be checked ahead of time, because + # req.populate_link() needs to be called before we can make decisions + # based on link type. + discovered_reqs = [] # type: List[InstallRequirement] + hash_errors = HashErrors() + for req in chain(root_reqs, discovered_reqs): + try: + discovered_reqs.extend(self._resolve_one(requirement_set, req)) + except HashError as exc: + exc.req = req + hash_errors.append(exc) + + if hash_errors: + raise hash_errors + + def _is_upgrade_allowed(self, req): + # type: (InstallRequirement) -> bool + if self.upgrade_strategy == "to-satisfy-only": + return False + elif self.upgrade_strategy == "eager": + return True + else: + assert self.upgrade_strategy == "only-if-needed" + return req.is_direct + + def _set_req_to_reinstall(self, req): + # type: (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): + req.should_reinstall = True + req.satisfied_by = None + + def _check_skip_installed(self, req_to_install): + # type: (InstallRequirement) -> Optional[str] + """Check if req_to_install should be skipped. + + This will check if the req is installed, and whether we should upgrade + or reinstall it, taking into account all the relevant user options. + + After calling this req_to_install will only have satisfied_by set to + None if the req_to_install is to be upgraded/reinstalled etc. Any + other value will be a dist recording the current thing installed that + satisfies the requirement. + + Note that for vcs urls and the like we can't assess skipping in this + routine - we simply identify that we need to pull the thing down, + then later on it is pulled down and introspected to assess upgrade/ + reinstalls etc. + + :return: A text reason for why it was skipped, or None. + """ + if self.ignore_installed: + return None + + req_to_install.check_if_exists(self.use_user_site) + if not req_to_install.satisfied_by: + return None + + if self.force_reinstall: + self._set_req_to_reinstall(req_to_install) + return None + + if not self._is_upgrade_allowed(req_to_install): + if self.upgrade_strategy == "only-if-needed": + return 'already satisfied, skipping upgrade' + return 'already satisfied' + + # Check for the possibility of an upgrade. For link-based + # requirements we have to pull the tree down and inspect to assess + # the version #, so it's handled way down. + if not req_to_install.link: + try: + self.finder.find_requirement(req_to_install, upgrade=True) + except BestVersionAlreadyInstalled: + # Then the best version is installed. + return 'already up-to-date' + except DistributionNotFound: + # No distribution found, so we squash the error. It will + # be raised later when we re-try later to do the install. + # Why don't we just raise here? + pass + + self._set_req_to_reinstall(req_to_install) + return None + + def _get_abstract_dist_for(self, req): + # type: (InstallRequirement) -> AbstractDistribution + """Takes a InstallRequirement and returns a single AbstractDist \ + representing a prepared variant of the same. + """ + if req.editable: + return self.preparer.prepare_editable_requirement(req) + + # satisfied_by is only evaluated by calling _check_skip_installed, + # so it must be None here. + assert req.satisfied_by is None + skip_reason = self._check_skip_installed(req) + + if req.satisfied_by: + return self.preparer.prepare_installed_requirement( + req, skip_reason + ) + + upgrade_allowed = self._is_upgrade_allowed(req) + + # We eagerly populate the link, since that's our "legacy" behavior. + require_hashes = self.preparer.require_hashes + req.populate_link(self.finder, upgrade_allowed, require_hashes) + abstract_dist = self.preparer.prepare_linked_requirement(req) + + # NOTE + # The following portion is for determining if a certain package is + # going to be re-installed/upgraded or not and reporting to the user. + # This should probably get cleaned up in a future refactor. + + # req.req is only avail after unpack for URL + # pkgs repeat check_if_exists to uninstall-on-upgrade + # (#14) + if not self.ignore_installed: + req.check_if_exists(self.use_user_site) + + if req.satisfied_by: + should_modify = ( + self.upgrade_strategy != "to-satisfy-only" or + self.force_reinstall or + self.ignore_installed or + req.link.scheme == 'file' + ) + if should_modify: + self._set_req_to_reinstall(req) + else: + logger.info( + 'Requirement already satisfied (use --upgrade to upgrade):' + ' %s', req, + ) + + return abstract_dist + + def _resolve_one( + self, + requirement_set, # type: RequirementSet + req_to_install, # type: InstallRequirement + ): + # type: (...) -> List[InstallRequirement] + """Prepare a single requirements file. + + :return: A list of additional InstallRequirements to also install. + """ + # Tell user what we are doing for this requirement: + # obtain (editable), skipping, processing (local url), collecting + # (remote url or package name) + if req_to_install.constraint or req_to_install.prepared: + return [] + + req_to_install.prepared = True + + # register tmp src for cleanup in case something goes wrong + requirement_set.reqs_to_cleanup.append(req_to_install) + + abstract_dist = self._get_abstract_dist_for(req_to_install) + + # Parse and return dependencies + dist = abstract_dist.get_pkg_resources_distribution() + # This will raise UnsupportedPythonVersion if the given Python + # version isn't compatible with the distribution's Requires-Python. + _check_dist_requires_python( + dist, version_info=self._py_version_info, + ignore_requires_python=self.ignore_requires_python, + ) + + more_reqs = [] # type: List[InstallRequirement] + + def add_req(subreq, extras_requested): + 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( + sub_install_req, + parent_req_name=parent_req_name, + extras_requested=extras_requested, + ) + if parent_req_name and add_to_parent: + self._discovered_dependencies[parent_req_name].append( + add_to_parent + ) + more_reqs.extend(to_scan_again) + + with indent_log(): + # We add req_to_install before its dependencies, so that we + # can refer to it when adding dependencies. + if not requirement_set.has_requirement(req_to_install.name): + # 'unnamed' requirements will get added here + # 'unnamed' requirements can only come from being directly + # provided by the user. + assert req_to_install.is_direct + requirement_set.add_requirement( + req_to_install, parent_req_name=None, + ) + + if not self.ignore_dependencies: + if req_to_install.extras: + logger.debug( + "Installing extra requirements: %r", + ','.join(req_to_install.extras), + ) + missing_requested = sorted( + set(req_to_install.extras) - set(dist.extras) + ) + for missing in missing_requested: + logger.warning( + '%s does not provide the extra \'%s\'', + dist, missing + ) + + available_requested = sorted( + set(dist.extras) & set(req_to_install.extras) + ) + for subreq in dist.requires(available_requested): + add_req(subreq, extras_requested=available_requested) + + if not req_to_install.editable and not req_to_install.satisfied_by: + # XXX: --no-install leads this to report 'Successfully + # downloaded' for only non-editable reqs, even though we took + # action on them. + requirement_set.successfully_downloaded.append(req_to_install) + + return more_reqs + + def get_installation_order(self, req_set): + # type: (RequirementSet) -> List[InstallRequirement] + """Create the installation order. + + The installation order is topological - requirements are installed + before the requiring thing. We break cycles at an arbitrary point, + and make no other guarantees. + """ + # The current implementation, which we may change at any point + # 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] + + def schedule(req): + if req.satisfied_by or req in ordered_reqs: + return + if req.constraint: + return + ordered_reqs.add(req) + for dep in self._discovered_dependencies[req.name]: + schedule(dep) + order.append(req) + + for install_req in req_set.requirements.values(): + schedule(install_req) + return order diff --git a/venv/lib/python3.8/site-packages/pip/_internal/locations.py b/venv/lib/python3.8/site-packages/pip/_internal/locations.py new file mode 100644 index 0000000..0c11553 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/locations.py @@ -0,0 +1,194 @@ +"""Locations where we look for configs, install stuff, etc""" + +# The following comment should be removed at some point in the future. +# mypy: strict-optional=False + +from __future__ import absolute_import + +import os +import os.path +import platform +import site +import sys +import sysconfig +from distutils import sysconfig as distutils_sysconfig +from distutils.command.install import SCHEME_KEYS # type: ignore +from distutils.command.install import install as distutils_install_command + +from pip._internal.models.scheme import Scheme +from pip._internal.utils import appdirs +from pip._internal.utils.compat import WINDOWS +from pip._internal.utils.typing import MYPY_CHECK_RUNNING, cast +from pip._internal.utils.virtualenv import running_under_virtualenv + +if MYPY_CHECK_RUNNING: + from typing import Dict, List, Optional, Union + + from distutils.cmd import Command as DistutilsCommand + + +# Application Directories +USER_CACHE_DIR = appdirs.user_cache_dir("pip") + + +def get_major_minor_version(): + # type: () -> str + """ + Return the major-minor version of the current Python as a string, e.g. + "3.7" or "3.10". + """ + return '{}.{}'.format(*sys.version_info) + + +def get_src_prefix(): + # type: () -> str + if running_under_virtualenv(): + src_prefix = os.path.join(sys.prefix, 'src') + else: + # FIXME: keep src in cwd for now (it is not a temporary folder) + try: + src_prefix = os.path.join(os.getcwd(), 'src') + except OSError: + # In case the current working directory has been renamed or deleted + sys.exit( + "The folder you are executing pip from can no longer be found." + ) + + # under macOS + virtualenv sys.prefix is not properly resolved + # it is something like /path/to/python/bin/.. + return os.path.abspath(src_prefix) + + +# FIXME doesn't account for venv linked to global site-packages + +site_packages = sysconfig.get_path("purelib") # type: Optional[str] + +# This is because of a bug in PyPy's sysconfig module, see +# https://bitbucket.org/pypy/pypy/issues/2506/sysconfig-returns-incorrect-paths +# for more information. +if platform.python_implementation().lower() == "pypy": + site_packages = distutils_sysconfig.get_python_lib() +try: + # Use getusersitepackages if this is present, as it ensures that the + # value is initialised properly. + user_site = site.getusersitepackages() +except AttributeError: + user_site = site.USER_SITE + +if WINDOWS: + bin_py = os.path.join(sys.prefix, 'Scripts') + bin_user = os.path.join(user_site, 'Scripts') + # buildout uses 'bin' on Windows too? + if not os.path.exists(bin_py): + bin_py = os.path.join(sys.prefix, 'bin') + bin_user = os.path.join(user_site, 'bin') +else: + bin_py = os.path.join(sys.prefix, 'bin') + bin_user = os.path.join(user_site, 'bin') + + # 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/': + bin_py = '/usr/local/bin' + + +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] + """ + Return a distutils install scheme + """ + from distutils.dist import Distribution + + dist_args = {'name': dist_name} # type: Dict[str, Union[str, List[str]]] + if isolated: + dist_args["script_args"] = ["--no-user-cfg"] + + d = Distribution(dist_args) + d.parse_config_files() + obj = None # type: Optional[DistutilsCommand] + obj = d.get_command_obj('install', create=True) + assert obj is not None + i = cast(distutils_install_command, obj) + # NOTE: setting user or home has the side-effect of creating the home dir + # or user base for installations during finalize_options() + # ideally, we'd prefer a scheme class that has no side-effects. + assert not (user and prefix), "user={} prefix={}".format(user, prefix) + assert not (home and prefix), "home={} prefix={}".format(home, prefix) + i.user = user or i.user + if user or home: + i.prefix = "" + i.prefix = prefix or i.prefix + i.home = home or i.home + i.root = root or i.root + i.finalize_options() + + scheme = {} + for key in SCHEME_KEYS: + scheme[key] = getattr(i, 'install_' + key) + + # install_lib specified in setup.cfg should install *everything* + # into there (i.e. it takes precedence over both purelib and + # platlib). Note, i.install_lib is *always* set after + # finalize_options(); we only want to override here if the user + # has explicitly requested it hence going back to the config + if 'install_lib' in d.get_option_dict('install'): + scheme.update(dict(purelib=i.install_lib, platlib=i.install_lib)) + + if running_under_virtualenv(): + scheme['headers'] = os.path.join( + sys.prefix, + 'include', + 'site', + 'python{}'.format(get_major_minor_version()), + dist_name, + ) + + 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:], + ) + + 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 + """ + Get the "scheme" corresponding to the input parameters. The distutils + documentation provides the context for the available schemes: + https://docs.python.org/3/install/index.html#alternate-installation + + :param dist_name: the name of the package to retrieve the scheme for, used + in the headers scheme path + :param user: indicates to use the "user" scheme + :param home: indicates to use the "home" scheme and provides the base + directory for the same + :param root: root under which other directories are re-based + :param isolated: equivalent to --no-user-cfg, i.e. do not consider + ~/.pydistutils.cfg (posix) or ~/pydistutils.cfg (non-posix) for + scheme paths + :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 + ) + return Scheme( + platlib=scheme["platlib"], + purelib=scheme["purelib"], + headers=scheme["headers"], + scripts=scheme["scripts"], + data=scheme["data"], + ) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/main.py b/venv/lib/python3.8/site-packages/pip/_internal/main.py new file mode 100644 index 0000000..3208d5b --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/main.py @@ -0,0 +1,16 @@ +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import Optional, List + + +def main(args=None): + # type: (Optional[List[str]]) -> int + """This is preserved for old console scripts that may still be referencing + it. + + For additional details, see https://github.com/pypa/pip/issues/7498. + """ + from pip._internal.utils.entrypoints import _wrapper + + return _wrapper(args) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/models/__init__.py b/venv/lib/python3.8/site-packages/pip/_internal/models/__init__.py new file mode 100644 index 0000000..7855226 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/models/__init__.py @@ -0,0 +1,2 @@ +"""A package that contains models that represent entities. +""" diff --git a/venv/lib/python3.8/site-packages/pip/_internal/models/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/models/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..40066fb255660d0150d4a0d42784ee278f79d084 GIT binary patch literal 224 zcmYjLF%E)25IkrkB>v$V3ktZ#D1}k^fQ_-Sxm>snT!iD~ju8BjU!wI1c2+LZILXXr zW|P^yESDicY&R=$!1WX_htov!l fxY7<+Vd^#hu9`JlQjLqMsCM{B3v1J;VU;LV(`$w1e=Hs9viF{(?#e39MWckFS2ufNZwuVyRz=rMZG<(YBAbXa{I+orSx_& z-Fg1Y?8g_l*N2==nM&w>Igv`+{*hQ&Ju_cGUNpM}K)jH4Xy|q57WMwyyRh~bvK7k_ z#UsmsegHNAv!?+h{RcGzJr}zD>$hs{rB~Kwz5Mc`dG&pAjOo=w)`akzrEnkVV7`PK z%-2VN7ovOy>VxxhFtcr=d5kjnYWDx9-?BLJd2hLhbdw`JlgrD$O70{R1)0~ zE#GcD%z&qxb8X(VY11)%>Pa_42& literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/models/__pycache__/format_control.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/models/__pycache__/format_control.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..9de7f7a7a23ceb0617d807cae04e17212cffcb98 GIT binary patch literal 2416 zcmaJ@TW=dh6rS0e*N&4mX=qDZ=pqWjP}_hiilTxlg*F9*si^u;OE7GACh;bFv1iv! ze|5v|KPsFrmMFNs{h=Wwl^$NhFc>^FyrGFb5Dc29_? z84foFU+>)7R%>k*Cb^J^MLSNph_ZHhVHT85Y4vvsmq94Z8C!(fOdUZCmpT;PaOmjb zj2Bx|;Xqw_+SL5m2};A5Y{C(nWDAjyRWOh&IERM;&UtCbd9VsQ&3i)X+mypO#dR1H z1IDgmp6N4;(eh~%l)zgCs7UB2lm_g>fCE~GmyZmP%Mg%DYETZGJu(rDT?h9+k5mEy zg~YU}xs9%myod>>IFfAAO@w#TM7Iu1=^y_hr_cHxvED5_8x`B}!8 za*e7m#!iHpYA2mG6_Qf)C1W4r#7rZFVIf!+wf=cKRHf)lzABTC&Hf9-nC!#!11gtt z%8gz62Xb`Z;N}6HpajR}mLq>38~f$~q44PO*W%UzKxb@n^nF`V+`dHqG`<0#U{^(6 zQyD(EHa5Q_zkWHf#uj(B3^|(W81UQ~Te}o1#(rg7YNPv*Q+fwn?QT>$hqO7m-E1al zv#buU?KPXKK&Eu6!N!wfFbt*0ye~XoZVY3Q8`v|(Hc1`fHbkvaElr$ zTIShynD?a0o5IfeQJ5EY5D8xvrq6j{hY1(YrOLsg!ow`^B}e$|XMQvkg#!f}B9|A` zvYCkO!crkT9j}W$z-1&@Jj{oF#KiL;8gh|+hF#gm7>HS;1~pz=_`3R6qsvF-r)UGc zMn^YhE8uLUGZmq3rTQv*wvK@#x;!^sPL>X3Amn>EyBa63a#(`~_7SxcF|rK)cQT{T)i(c!%hX1#aD{{OG+vP9qt z?W62vgRP}#gQ5ruv_Oz02>P*TArz60<;s#m(oSr6 zOMp!M56+ms#I;lZLYMYP+o%ha08j7k#N*w2{MzZX5v(__U!>1ngnk%jb3qKfhb<4l zFvM_yMmQlD9U(@TbAy<}oogp?xyxMEVBU93 zGEBo&Dzv#UEm>HLYLYW9L!QcLJH5( zHCd25gwY%@b(Fhk%<&x_df>rcG#Pk+eT#|3tvP{6n;~f3InkcXM|HuqTTkmedY~I} zTyr7JUD~HKFLOnycE+O60hl5`qn14FgD2}ESK2GNDymF(D1>Og67Yu_==QR*32NU| zw`jMY7o18}2_THJYLw<>jMb=)>%8uc%Noe$ zta~}&yy)iR^NWM&t4ouMpG97UcqD?8xHU45aJP2|WHv^kjb38&wmy1}K2XCJaAIa=q$o v$TPKkn(pcJ^jP~}ptM07v)L)lY}$Xfr0Nix0Uv=0ob7#r2_nBeXZigDX3s02 literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/models/__pycache__/link.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/models/__pycache__/link.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..5c49d785a16e04025296a8465f5f58a9371257c0 GIT binary patch literal 6659 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 wewsMZ$DRTAvX9BVY2n>0g5RgI7Sku6f{s6@~ literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/models/__pycache__/scheme.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/models/__pycache__/scheme.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..3e412e7b82cf6a3ec17f4f499349736a299c6d07 GIT binary patch literal 862 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 F{{TAePXPb` literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/models/candidate.py b/venv/lib/python3.8/site-packages/pip/_internal/models/candidate.py new file mode 100644 index 0000000..1dc1a57 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/models/candidate.py @@ -0,0 +1,36 @@ +from pip._vendor.packaging.version import parse as parse_version + +from pip._internal.utils.models import KeyBasedCompareMixin +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from pip._vendor.packaging.version import _BaseVersion + from pip._internal.models.link import Link + + +class InstallationCandidate(KeyBasedCompareMixin): + """Represents a potential "candidate" for installation. + """ + + def __init__(self, name, version, link): + # type: (str, str, Link) -> None + self.name = name + self.version = parse_version(version) # type: _BaseVersion + self.link = link + + super(InstallationCandidate, self).__init__( + key=(self.name, self.version, self.link), + defining_class=InstallationCandidate + ) + + def __repr__(self): + # type: () -> str + return "".format( + self.name, self.version, self.link, + ) + + def __str__(self): + # type: () -> str + return '{!r} candidate (version {} at {})'.format( + self.name, self.version, self.link, + ) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/models/format_control.py b/venv/lib/python3.8/site-packages/pip/_internal/models/format_control.py new file mode 100644 index 0000000..2e13727 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/models/format_control.py @@ -0,0 +1,84 @@ +# The following comment should be removed at some point in the future. +# mypy: strict-optional=False + +from pip._vendor.packaging.utils import canonicalize_name + +from pip._internal.exceptions import CommandError +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import Optional, Set, FrozenSet + + +class FormatControl(object): + """Helper for managing formats from which a package can be installed. + """ + + def __init__(self, no_binary=None, only_binary=None): + # type: (Optional[Set[str]], Optional[Set[str]]) -> None + if no_binary is None: + no_binary = set() + if only_binary is None: + only_binary = set() + + self.no_binary = no_binary + self.only_binary = only_binary + + def __eq__(self, other): + # type: (object) -> bool + return self.__dict__ == other.__dict__ + + def __ne__(self, other): + # type: (object) -> bool + return not self.__eq__(other) + + def __repr__(self): + # type: () -> str + return "{}({}, {})".format( + self.__class__.__name__, + self.no_binary, + self.only_binary + ) + + @staticmethod + def handle_mutual_excludes(value, target, other): + # type: (str, Optional[Set[str]], Optional[Set[str]]) -> None + if value.startswith('-'): + raise CommandError( + "--no-binary / --only-binary option requires 1 argument." + ) + new = value.split(',') + while ':all:' in new: + other.clear() + target.clear() + 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: + return + for name in new: + 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] + result = {"binary", "source"} + if canonical_name in self.only_binary: + 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') + return frozenset(result) + + def disallow_binaries(self): + # type: () -> None + self.handle_mutual_excludes( + ':all:', self.no_binary, self.only_binary, + ) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/models/index.py b/venv/lib/python3.8/site-packages/pip/_internal/models/index.py new file mode 100644 index 0000000..ead1efb --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/models/index.py @@ -0,0 +1,31 @@ +from pip._vendor.six.moves.urllib import parse as urllib_parse + + +class PackageIndex(object): + """Represents a Package Index and provides easier access to endpoints + """ + + def __init__(self, url, file_storage_domain): + # type: (str, str) -> None + super(PackageIndex, self).__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') + + # 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 + return urllib_parse.urljoin(self.url, path) + + +PyPI = PackageIndex( + 'https://pypi.org/', file_storage_domain='files.pythonhosted.org' +) +TestPyPI = PackageIndex( + 'https://test.pypi.org/', file_storage_domain='test-files.pythonhosted.org' +) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/models/link.py b/venv/lib/python3.8/site-packages/pip/_internal/models/link.py new file mode 100644 index 0000000..34fbcbf --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/models/link.py @@ -0,0 +1,227 @@ +import os +import posixpath +import re + +from pip._vendor.six.moves.urllib import parse as urllib_parse + +from pip._internal.utils.filetypes import WHEEL_EXTENSION +from pip._internal.utils.misc import ( + redact_auth_from_url, + split_auth_from_netloc, + splitext, +) +from pip._internal.utils.models import KeyBasedCompareMixin +from pip._internal.utils.typing import MYPY_CHECK_RUNNING +from pip._internal.utils.urls import path_to_url, url_to_path + +if MYPY_CHECK_RUNNING: + from typing import Optional, Text, Tuple, Union + from pip._internal.index.collector import HTMLPage + from pip._internal.utils.hashes import Hashes + + +class Link(KeyBasedCompareMixin): + """Represents a parsed link from a Package Index's simple URL + """ + + 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[Text] + ): + # type: (...) -> None + """ + :param url: url of the resource pointed to (href of the link) + :param comes_from: instance of HTMLPage 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 + a data-requires-python attribute in the HTML link tag, as + described in PEP 503. + :param yanked_reason: the reason the file has been yanked, if the + file has been yanked, or None if the file hasn't been yanked. + This is the value of the "data-yanked" attribute, if present, in + 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. + """ + + # url can be a UNC windows share + if url.startswith('\\\\'): + url = path_to_url(url) + + self._parsed_url = urllib_parse.urlsplit(url) + # Store the url as a private attribute to prevent accidentally + # trying to set a new value. + self._url = url + + self.comes_from = comes_from + self.requires_python = requires_python if requires_python else None + self.yanked_reason = yanked_reason + + super(Link, self).__init__(key=url, defining_class=Link) + + def __str__(self): + # type: () -> str + if self.requires_python: + rp = ' (requires-python:%s)' % self.requires_python + else: + rp = '' + if self.comes_from: + return '%s (from %s)%s' % (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 '' % self + + @property + def url(self): + # type: () -> str + return self._url + + @property + def filename(self): + # type: () -> str + path = self.path.rstrip('/') + name = posixpath.basename(path) + if not name: + # Make sure we don't leak auth information if the netloc + # includes a username and password. + netloc, user_pass = split_auth_from_netloc(self.netloc) + return netloc + + name = urllib_parse.unquote(name) + assert name, ('URL %r produced no filename' % self._url) + return name + + @property + def file_path(self): + # type: () -> str + return url_to_path(self.url) + + @property + def scheme(self): + # type: () -> str + return self._parsed_url.scheme + + @property + def netloc(self): + # type: () -> str + """ + This can contain auth information. + """ + return self._parsed_url.netloc + + @property + def path(self): + # type: () -> str + return urllib_parse.unquote(self._parsed_url.path) + + def splitext(self): + # type: () -> Tuple[str, str] + return splitext(posixpath.basename(self.path.rstrip('/'))) + + @property + def ext(self): + # type: () -> str + return self.splitext()[1] + + @property + def url_without_fragment(self): + # type: () -> str + scheme, netloc, path, query, fragment = self._parsed_url + return urllib_parse.urlunsplit((scheme, netloc, path, query, None)) + + _egg_fragment_re = re.compile(r'[#&]egg=([^&]*)') + + @property + def egg_fragment(self): + # type: () -> 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=([^&]*)') + + @property + def subdirectory_fragment(self): + # type: () -> 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]+)' + ) + + @property + def hash(self): + # type: () -> Optional[str] + match = self._hash_re.search(self._url) + if match: + return match.group(2) + return None + + @property + def hash_name(self): + # type: () -> Optional[str] + match = self._hash_re.search(self._url) + if match: + return match.group(1) + return None + + @property + def show_url(self): + # type: () -> 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_existing_dir(self): + # type: () -> bool + return self.is_file and os.path.isdir(self.file_path) + + @property + def is_wheel(self): + # type: () -> bool + return self.ext == WHEEL_EXTENSION + + @property + def is_vcs(self): + # type: () -> bool + from pip._internal.vcs import vcs + + return self.scheme in vcs.all_schemes + + @property + def is_yanked(self): + # type: () -> bool + return self.yanked_reason is not None + + @property + def has_hash(self): + # type: () -> bool + return self.hash_name is not None + + def is_hash_allowed(self, hashes): + # type: (Optional[Hashes]) -> bool + """ + Return True if the link has a hash and it is allowed. + """ + if hashes is None or not self.has_hash: + 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 hashes.is_hash_allowed(self.hash_name, hex_digest=self.hash) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/models/scheme.py b/venv/lib/python3.8/site-packages/pip/_internal/models/scheme.py new file mode 100644 index 0000000..af07b40 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/models/scheme.py @@ -0,0 +1,25 @@ +""" +For types associated with installation schemes. + +For a general overview of available schemes and their context, see +https://docs.python.org/3/install/index.html#alternate-installation. +""" + + +class Scheme(object): + """A Scheme holds paths which are used as the base directories for + artifacts associated with a Python package. + """ + def __init__( + self, + platlib, # type: str + purelib, # type: str + headers, # type: str + scripts, # type: str + data, # type: str + ): + self.platlib = platlib + self.purelib = purelib + self.headers = headers + self.scripts = scripts + self.data = data diff --git a/venv/lib/python3.8/site-packages/pip/_internal/models/search_scope.py b/venv/lib/python3.8/site-packages/pip/_internal/models/search_scope.py new file mode 100644 index 0000000..138d1b6 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/models/search_scope.py @@ -0,0 +1,114 @@ +import itertools +import logging +import os +import posixpath + +from pip._vendor.packaging.utils import canonicalize_name +from pip._vendor.six.moves.urllib import parse as urllib_parse + +from pip._internal.models.index import PyPI +from pip._internal.utils.compat import has_tls +from pip._internal.utils.misc import normalize_path, redact_auth_from_url +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import List + + +logger = logging.getLogger(__name__) + + +class SearchScope(object): + + """ + Encapsulates the locations that pip is configured to search. + """ + + @classmethod + def create( + cls, + find_links, # type: List[str] + index_urls, # type: List[str] + ): + # type: (...) -> SearchScope + """ + Create a SearchScope object after normalizing the `find_links`. + """ + # Build find_links. If an argument starts with ~, it may be + # a local file relative to a home directory. So try normalizing + # 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] + for link in find_links: + if link.startswith('~'): + new_link = normalize_path(link) + if os.path.exists(new_link): + link = new_link + built_find_links.append(link) + + # If we don't have TLS enabled, then WARN if anyplace we're looking + # relies on TLS. + if not has_tls(): + for link in itertools.chain(index_urls, built_find_links): + parsed = urllib_parse.urlparse(link) + if parsed.scheme == 'https': + logger.warning( + '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, + ) + + def __init__( + self, + find_links, # type: List[str] + index_urls, # type: List[str] + ): + # type: (...) -> None + self.find_links = find_links + self.index_urls = index_urls + + def get_formatted_locations(self): + # type: () -> str + lines = [] + if self.index_urls and self.index_urls != [PyPI.simple_url]: + lines.append( + 'Looking in indexes: {}'.format(', '.join( + redact_auth_from_url(url) for url in self.index_urls)) + ) + if self.find_links: + lines.append( + 'Looking in links: {}'.format(', '.join( + redact_auth_from_url(url) for url in self.find_links)) + ) + return '\n'.join(lines) + + def get_index_urls_locations(self, project_name): + # type: (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 + loc = posixpath.join( + 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 + '/' + return loc + + return [mkurl_pypi_url(url) for url in self.index_urls] diff --git a/venv/lib/python3.8/site-packages/pip/_internal/models/selection_prefs.py b/venv/lib/python3.8/site-packages/pip/_internal/models/selection_prefs.py new file mode 100644 index 0000000..f58fdce --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/models/selection_prefs.py @@ -0,0 +1,47 @@ +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import Optional + from pip._internal.models.format_control import FormatControl + + +class SelectionPreferences(object): + + """ + Encapsulates the candidate selection preferences for downloading + and installing files. + """ + + # Don't include an allow_yanked default value to make sure each call + # site considers whether yanked releases are allowed. This also causes + # that decision to be made explicit in the calling code, which helps + # 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 + """Create a SelectionPreferences object. + + :param allow_yanked: Whether files marked as yanked (in the sense + of PEP 592) are permitted to be candidates for install. + :param format_control: A FormatControl object or None. Used to control + the selection of source packages / binary packages when consulting + the index and links. + :param prefer_binary: Whether to prefer an old, but valid, binary + dist over a new source dist. + :param ignore_requires_python: Whether to ignore incompatible + "Requires-Python" values in links. Defaults to False. + """ + if ignore_requires_python is None: + ignore_requires_python = False + + self.allow_yanked = allow_yanked + self.allow_all_prereleases = allow_all_prereleases + self.format_control = format_control + self.prefer_binary = prefer_binary + self.ignore_requires_python = ignore_requires_python diff --git a/venv/lib/python3.8/site-packages/pip/_internal/models/target_python.py b/venv/lib/python3.8/site-packages/pip/_internal/models/target_python.py new file mode 100644 index 0000000..97ae85a --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/models/target_python.py @@ -0,0 +1,107 @@ +import sys + +from pip._internal.pep425tags import get_supported, version_info_to_nodot +from pip._internal.utils.misc import normalize_version_info +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import List, Optional, Tuple + + from pip._vendor.packaging.tags import Tag + + +class TargetPython(object): + + """ + Encapsulates the properties of a Python interpreter one is targeting + for a package install, download, etc. + """ + + def __init__( + self, + platform=None, # type: Optional[str] + py_version_info=None, # type: Optional[Tuple[int, ...]] + abi=None, # type: Optional[str] + implementation=None, # type: Optional[str] + ): + # type: (...) -> None + """ + :param platform: A string or None. If None, searches for packages + that are supported by the current system. Otherwise, will find + packages that can be built on the platform passed in. These + packages will only be downloaded for distribution: they will + not be built locally. + :param py_version_info: An optional tuple of ints representing the + Python version information to use (e.g. `sys.version_info[:3]`). + This can have length 1, 2, or 3 when provided. + :param abi: A string or None. This is passed to pep425tags.py's + get_supported() function as is. + :param implementation: A string or None. This is passed to + pep425tags.py's get_supported() function as is. + """ + # Store the given py_version_info for when we call get_supported(). + self._given_py_version_info = py_version_info + + if py_version_info is None: + py_version_info = sys.version_info[:3] + else: + py_version_info = normalize_version_info(py_version_info) + + py_version = '.'.join(map(str, py_version_info[:2])) + + self.abi = abi + self.implementation = implementation + self.platform = platform + self.py_version = py_version + 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]] + + def format_given(self): + # type: () -> str + """ + Format the given, non-None attributes for display. + """ + display_version = None + if self._given_py_version_info is not None: + display_version = '.'.join( + str(part) for part in self._given_py_version_info + ) + + key_values = [ + ('platform', self.platform), + ('version_info', display_version), + ('abi', self.abi), + ('implementation', self.implementation), + ] + return ' '.join( + '{}={!r}'.format(key, value) for key, value in key_values + if value is not None + ) + + def get_tags(self): + # type: () -> List[Tag] + """ + Return the supported PEP 425 tags to check wheel candidates against. + + The tags are returned in order of preference (most preferred first). + """ + if self._valid_tags is None: + # Pass versions=None if no py_version_info was given since + # versions=None uses special default logic. + py_version_info = self._given_py_version_info + if py_version_info is None: + version = None + else: + version = version_info_to_nodot(py_version_info) + + tags = get_supported( + version=version, + platform=self.platform, + abi=self.abi, + impl=self.implementation, + ) + self._valid_tags = tags + + return self._valid_tags diff --git a/venv/lib/python3.8/site-packages/pip/_internal/models/wheel.py b/venv/lib/python3.8/site-packages/pip/_internal/models/wheel.py new file mode 100644 index 0000000..f1e3f44 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/models/wheel.py @@ -0,0 +1,78 @@ +"""Represents a wheel file and provides access to the various parts of the +name that have meaning. +""" +import re + +from pip._vendor.packaging.tags import Tag + +from pip._internal.exceptions import InvalidWheelFilename +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import List + + +class Wheel(object): + """A wheel file""" + + wheel_file_re = re.compile( + r"""^(?P(?P.+?)-(?P.*?)) + ((-(?P\d[^-]*?))?-(?P.+?)-(?P.+?)-(?P.+?) + \.whl|\.dist-info)$""", + re.VERBOSE + ) + + def __init__(self, filename): + # type: (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( + "%s is not a valid wheel filename." % filename + ) + self.filename = filename + 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('.') + + # 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 + } + + def get_formatted_file_tags(self): + # type: () -> 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 + """Return the lowest index that one of the wheel's file_tag combinations + achieves in the given list of supported tags. + + For example, if there are 8 supported tags and one of the file tags + is first in the list, then return 0. + + :param tags: the PEP 425 tags to check the wheel against, in order + with most preferred first. + + :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 supported(self, tags): + # type: (List[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. + """ + return not self.file_tags.isdisjoint(tags) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/network/__init__.py b/venv/lib/python3.8/site-packages/pip/_internal/network/__init__.py new file mode 100644 index 0000000..b51bde9 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/network/__init__.py @@ -0,0 +1,2 @@ +"""Contains purely network-related utilities. +""" diff --git a/venv/lib/python3.8/site-packages/pip/_internal/network/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/network/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..c9932b2669d353eca66eedb4165109569f6849bb GIT binary patch literal 212 zcmWIL<>g`k0&_FfL?a;m7{oyaj6jY95EpX*i4=w?h7`tN22G|aZRh;FlElosVugaz zqSTy9g}l^~^8BJ~T_7j1BsE2$v?Mbpvm`UMSdYt3lkpaNe0)lNa(w(sh9V}QNnqla zlYU8Vfqp?|fo^GDL1J=tYKm@oMrvw~Zf0qEp+%)hIY>@FJ~OW*wJ0w!M;~g3emqbp bvm`!Vub}c4hfQvNN@-529mu7hftUdRcgs4V literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/network/__pycache__/auth.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/network/__pycache__/auth.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..c0f0bc50d517d104d0c048d033f4a24ef6216063 GIT binary patch literal 6978 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 literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/network/__pycache__/download.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/network/__pycache__/download.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..833736f6f0c03abadce2a787c1232a7589821f68 GIT binary patch literal 4370 zcmbVPO>^7E8D1wNt(2iNz*!t?bxAJORi&1I~bT)QIPP# zES8qVkUm5?wtt}0gEZ|WxAfXm5B(K;?J4~UnQ7DKU67K$aw#}?_ubuh7rW2<$-7fi zHHPQipIr>qB4hue&XbRW&WCu53l?J$Yq7|Rcw)6I)AANKt=+Os>$DuSc2Y^*mTQr$ zlT=f$0)a!U1}|v`8vLLwsqFxwUNg>Ez|~eCs^c@xxby ze`K{@jb@_RuUP9sG#AaIeJwf_EueipdMP@M_F{A06vnXzdDwoA- z?OOu6*|4-H#pgXyr~>@_)!WU@wdQ7U_4?iB&0yn3YYn5$`u_S2v{P{rY{@(g+F^TJ zU|b<}pFqU|_Sy1FewoV3uj--by~tVx+m?cEgnB{#9T z-z^8}q=etsOrF6ZzWenRm3FUmxS)J5v}ZP3z4kEz0T+F?Z3T8b5{a{gVd{|Kvv|4Ve z+Tmox2bCjkv8---cG&}8KVoWXXL{F>DsqNyc4@TgOVe8(*u@{B3dZLLcH~0pPp0S4 zteP1xHG9B^)qz`lGpKGbH8ss|Rl!E5%bUkv>>zZf?9Gk1$P>-ffSBmZL2 zpB|eS4PPui-i$x|Gh@(+oraGZ^9CR70^=laONvAK6nRuoz8jWECAr7;87lI~^gl6K7kwo`cfXwzfoD#Sg_T@lYhX zN&+~Vc5XC3zAar^N!pT=APrBRrd^x_hOX;l_YNL}QrA_k!XzkdQrmR0n)z5{PB~@H zJ6@sP(r=9cmIPs#>A9dQMK_dm%`%)cFkHL`!d#EnEswk0q8t5=4>?@PK19kovWCvUk*_P; zxDWX5r2*ZU_Ycf**F#zSzZbsjhgoEHkwW!kW^jwdR@h6F$q59XA8(m)#0VOW3tyyN zwO@iIe~fcC9BsEdF^r4O5|m(S8-{8wjbL|b3`}$ax}F_<=@>0t2^0dJcCk;G7H03~ zur9yxg8hDvlN6>zaHp-B<=CDje~z)|Fem>ocJw6}1Sd9x9g#H|w1KL$bF74zLkFjSJGSyvMK33k&#GymIqvKuV<6~(` z#Fc)2O(>|sN7f3H6X1=(k|}rK>Y0Cib93DvN9xP|R+zx0JN^TNe_!QBjU-HdezFIY zm*tAGI_1Qu)LMV6kCi9%@hzpgetm@OiqQmX)JiSPV@|$Jgdmj@AbKK=Q$b>dp6Q?{ zC<3Hukx>ejZ<5pskyVgJ#l#?akp{?Oe!eHoylwa-vFXMJ`f}8nhGUlXoTewKFa)01m5{Fcaz9C@_q%0VitsP zLV_>27XP=q2t=-7tW6V7J`{~U#9J(Y2!>Lbm1Q!DNIRlCJK7uPzBXYveu$^l#*Zk! z3=p{j2D@f~1>a!-rvm6}tBG)mqOq*}O5MK&act}qBH5CkpmQ?(tTlK6N|;y$!CxU( zkmItdi?q?78=q=*EYYO11_4E^AkeiSNb{(N931F+5PaSXlX6Dhq7R-RX*kMb@;b<0 z@S1oH#Hjznh%ICGdBh?I$iaeuoU3c&GYa`s@nmD^F?OV^C$S^c(t3vjuCs#L5}O(Evy~axdV&B;60YT zM|CbLyPCXiv7v3T{-SaYD-qPa<09Z$M;QB(-DB^d>K)pT?axpJXZ$mUI*+4PhkthO3;W4!V=bWy@hPtXEWAxoe7URxrK zx5LC(lb$U73CS3xHEGd=15;DTJLtk24SXgVncBz_&mc&ag#D5r_&XL9r0lX7HeSVC zs#EL*s#p+h>i>BL-g0FVQSVc%lT9MGi5T0vN8E|RP7H7z6W`!9TJtP#Lefa%EnN-Z z;O!ug6u9JTMBXPt@l{Wv&|eLZAEI2A@SJ;MWOe+1Z58eylET!5`mB){|2Y^O=# zcvP0JRqkj*pZTc%$7NtKR(Ni%#LXN5zpZ09ZA+{zbPWqv}Wn)HRbJBDL2X)nt%D}`SA_M0hruUPrwLoncBNl zq>n*U>zB4f1znjADcu+&)o%V^2c>ywcBH-+Xlm%-@+$|D7(RR^`P`5~{>>BVoM YLOj*YW`x&l&+{(ho$(gES7xXF2LOms%>V!Z literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/network/__pycache__/session.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/network/__pycache__/session.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..b8482c87ca1eef50f34132001ab3d04b669d80d5 GIT binary patch literal 8851 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 HhphhvF9cbD literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/network/__pycache__/utils.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/network/__pycache__/utils.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..6f66cdff79c226c6c0ddbc242644531f4d83ef52 GIT binary patch literal 706 zcmYjO%Wl&^6rCA6iLuhO$^xXa@rH$^#$kb=i;7nWB~%#HCO|A9%k>P68^1C$Zj>nO z*zymsLj2Nf*}yNb;!c`Kz0$q%xpRE(YqYatBd|vg??pcw2>sUJrWpX9f{P;v6j7X_ z3ao(+P&vQC*Oi(D`ltM;4myD>cWdne)P$oB{SF=VZQWIU1ukBQdVm~PJkkHN(d z!qQoxOLU1>m|{x4kr(Kb{e`T^dxX)f{Q>2ki6oiY+{ci?NVC5iEBpg%mUupUz2V*; zqnvz%fuMDBd3c;$vD}Fq&Sn)8QaIa&51f)0R|#c~oG^z*GIHWcl~09dJ76!N^%iAu zL0K3Vxn#NYT~ir6nyb2yoJE;xJ(H3r=apoA&I_(g$Wqr(7T+vI*=xyABul1h>+fHP zw_x0VPr5QIyJb>#s=SQiDWjeFgt4@fR2Q?u#e=zi>xKzb=6RHMb0+5npLQ#mq{1r~ zYIj>Cyl(rJ-sEiv$RwnW$sO{?-f!ZT(ZnVunD4=h?^^0E=z1Y6g%;e~ZpF)B&Qx%H zBCcs-DRzg0;pqRpqk%`Kzk_elUm$jL$y3pMK#J@&_7s2Lodd zrak~6NJ0b^PC*k2|8C)wZsJn(v4WLe;&r-L_+^lUlt{XaWW1tD?`tA_5j-U#klwWa zvzrWr^O%gn`MvA1P)%0kC*wnvR=TN`8RlhE$Wm4&HF;gdf5O#de?)Dl>G1eDn2-MhdU%QK;~xHhPBGhMebBZaBC7 znJR!`-Z5lDu-2NdvkCBQ1HMs0uGe5ko@H7Vr#8wfA+I@XvB72yj?t2DVyCUZ+2!?lV;~q>|9NxEOzqQ*~NpKkFRiT7vLGGsrIObKDIs`%J7L930=WqT$G2`1;W=P=ez@o<4k@*`aEt!&*wvK=z7Ua}l zcm~P!fKY$_0E;@OivXhBDQo@KZ3C>1U)dsT!=<+(l(eiPoh*YkoQ5m<1c+zEMAP^@ zR=-fPh$xxAW_ruM@Y-lPm~OTH3Yz05@`QW>cP^qIqa*SIshlIQAZh;oy#KHU3M#X6 zc+<#vXymm)4h~1IWk7IhgNaOqRNDI5D4CY?cfL71JQzx)YBjvChgXxlki#=+OkSOV zWAuXR!D|(=W@E@2@(*pH`siRyt&M$Ar8y+6LPDYlQcHh1XiYsL#%%vSFrjlV@pxeYx4tTc60YTF6nX2HmX_yfv7ll_+3af78VL zq!u^ob&SB)HQKs>SG^1l^)7l{d7X9Tv=-aw3pShI2BYg}Lbstb94HQu#QDc}Lh3`g zY*PkapE!RrHh<$eWwSX5J}Zy#=VQB6X(^#yV$RE2%nH=|oL|h+VzUx(F6xZ)t~}NI z2o>x7jzE+OD-jh9UsMuO#$vzojkeTB;IRQR2nn-2XoE4ol$EGe$8++^9nV1VWhi|(asSnVJWGRHwfw%*t<8 literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/network/auth.py b/venv/lib/python3.8/site-packages/pip/_internal/network/auth.py new file mode 100644 index 0000000..1e1da54 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/network/auth.py @@ -0,0 +1,298 @@ +"""Network Authentication Helpers + +Contains interface (MultiDomainBasicAuth) and associated glue code for +providing credentials in the context of network requests. +""" + +# The following comment should be removed at some point in the future. +# mypy: disallow-untyped-defs=False + +import logging + +from pip._vendor.requests.auth import AuthBase, HTTPBasicAuth +from pip._vendor.requests.utils import get_netrc_auth +from pip._vendor.six.moves.urllib import parse as urllib_parse + +from pip._internal.utils.misc import ( + ask, + ask_input, + ask_password, + remove_auth_from_url, + split_auth_netloc_from_url, +) +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from optparse import Values + from typing import Dict, Optional, Tuple + + from pip._internal.vcs.versioncontrol import AuthInfo + + Credentials = Tuple[str, str, str] + +logger = logging.getLogger(__name__) + +try: + import keyring # noqa +except ImportError: + keyring = None +except Exception as exc: + logger.warning( + "Keyring is skipped due to an exception: %s", str(exc), + ) + keyring = None + + +def get_keyring_auth(url, username): + """Return the tuple auth for a given url from keyring.""" + if not url or not keyring: + return None + + try: + try: + get_credential = keyring.get_credential + except AttributeError: + pass + else: + logger.debug("Getting credentials from keyring for %s", url) + cred = get_credential(url, username) + if cred is not None: + return cred.username, cred.password + return None + + if username: + logger.debug("Getting password from keyring for %s", url) + password = keyring.get_password(url, username) + if password: + return username, password + + except Exception as exc: + logger.warning( + "Keyring is skipped due to an exception: %s", str(exc), + ) + + +class MultiDomainBasicAuth(AuthBase): + + def __init__(self, prompting=True, index_urls=None): + # type: (bool, Optional[Values]) -> None + self.prompting = prompting + self.index_urls = index_urls + self.passwords = {} # type: 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] + + def _get_index_url(self, url): + """Return the original index URL matching the requested URL. + + Cached or dynamically generated credentials may work against + the original index URL rather than just the netloc. + + The provided url should have had its username and password + removed already. If the original index url had credentials then + they will be included in the return value. + + Returns None if no matching index was found, or if --no-index + was specified by the user. + """ + 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 + + def _get_new_credentials(self, original_url, allow_netrc=True, + allow_keyring=True): + """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( + original_url, + ) + + # Start with the credentials embedded in the url + username, password = url_user_password + if username is not None and password is not None: + logger.debug("Found credentials in url for %s", netloc) + return url_user_password + + # Find a matching index url for this request + index_url = self._get_index_url(url) + if index_url: + # Split the credentials from the url. + index_info = split_auth_netloc_from_url(index_url) + if index_info: + index_url, _, index_url_user_password = index_info + logger.debug("Found index url %s", index_url) + + # If an index URL was found, try its embedded credentials + if index_url and index_url_user_password[0] is not None: + username, password = index_url_user_password + if username is not None and password is not None: + logger.debug("Found credentials in index url for %s", netloc) + return index_url_user_password + + # Get creds from netrc if we still don't have them + if allow_netrc: + netrc_auth = get_netrc_auth(original_url) + if netrc_auth: + logger.debug("Found credentials in netrc for %s", netloc) + return netrc_auth + + # 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 + kr_auth = ( + get_keyring_auth(index_url, username) or + get_keyring_auth(netloc, username) + ) + 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): + """Return the credentials to use for the provided URL. + + If allowed, netrc and keyring may be used to obtain the + correct credentials. + + Returns (url_without_credentials, username, password). Note + that even if the original URL contains credentials, this + function may return a different username and password. + """ + 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)) + + 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 username is not None or password is not None: + # Convert the username and password if they're None, so that + # this netloc will show up as "cached" in the conditional above. + # Further, HTTPBasicAuth doesn't accept None, so it makes sense to + # cache the value that is going to be used. + username = username or "" + password = password or "" + + # Store any acquired credentials. + self.passwords[netloc] = (username, password) + + assert ( + # Credentials were found + (username is not None and password is not None) or + # Credentials were not found + (username is None and password is None) + ), "Could not load credentials from url: {}".format(original_url) + + return url, username, password + + def __call__(self, req): + # Get credentials for this request + url, username, password = self._get_url_and_credentials(req.url) + + # Set the url of the request to the url without any credentials + req.url = url + + if username is not None and password is not None: + # Send the basic auth with this request + req = HTTPBasicAuth(username, password)(req) + + # Attach a hook to handle 401 responses + req.register_hook("response", self.handle_401) + + return req + + # Factored out to allow for easy patching in tests + def _prompt_for_password(self, netloc): + username = ask_input("User for %s: " % netloc) + if not username: + return None, None + auth = get_keyring_auth(netloc, username) + if auth: + 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): + if not keyring: + return False + return ask("Save credentials to keyring [y/N]: ", ["y", "n"]) == "y" + + def handle_401(self, resp, **kwargs): + # We only care about 401 responses, anything else we want to just + # pass through the actual response + if resp.status_code != 401: + return resp + + # We are not able to prompt the user so simply return the response + if not self.prompting: + return resp + + parsed = urllib_parse.urlparse(resp.url) + + # Prompt the user for a new username and password + username, password, save = self._prompt_for_password(parsed.netloc) + + # Store the new username and password to use for future requests + self._credentials_to_save = None + if username is not None and password is not None: + self.passwords[parsed.netloc] = (username, password) + + # Prompt to save the password to keyring + if save and self._should_save_password_to_keyring(): + self._credentials_to_save = (parsed.netloc, username, password) + + # Consume content and release the original connection to allow our new + # request to reuse the same one. + resp.content + resp.raw.release_conn() + + # Add our new username and password to the request + req = HTTPBasicAuth(username or "", password or "")(resp.request) + req.register_hook("response", self.warn_on_401) + + # On successful request, save the credentials that were used to + # keyring. (Note that if the user responded "no" above, this member + # is not set and nothing will be saved.) + if self._credentials_to_save: + req.register_hook("response", self.save_credentials) + + # Send our new request + new_resp = resp.connection.send(req, **kwargs) + new_resp.history.append(resp) + + return new_resp + + def warn_on_401(self, resp, **kwargs): + """Response callback to warn about incorrect credentials.""" + if resp.status_code == 401: + logger.warning( + '401 Error, Credentials not correct for %s', resp.request.url, + ) + + def save_credentials(self, resp, **kwargs): + """Response callback to save credentials on success.""" + assert keyring is not None, "should never reach here without keyring" + if not keyring: + return + + 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) + except Exception: + logger.exception('Failed to save credentials') diff --git a/venv/lib/python3.8/site-packages/pip/_internal/network/cache.py b/venv/lib/python3.8/site-packages/pip/_internal/network/cache.py new file mode 100644 index 0000000..c9386e1 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/network/cache.py @@ -0,0 +1,81 @@ +"""HTTP cache implementation. +""" + +# The following comment should be removed at some point in the future. +# mypy: disallow-untyped-defs=False + +import os +from contextlib import contextmanager + +from pip._vendor.cachecontrol.cache import BaseCache +from pip._vendor.cachecontrol.caches import FileCache +from pip._vendor.requests.models import Response + +from pip._internal.utils.filesystem import adjacent_tmp_file, replace +from pip._internal.utils.misc import ensure_dir +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import Optional + + +def is_from_cache(response): + # type: (Response) -> bool + return getattr(response, "from_cache", False) + + +@contextmanager +def suppressed_cache_errors(): + """If we can't access the cache then we can just skip caching and process + requests as if caching wasn't enabled. + """ + try: + yield + except (OSError, IOError): + pass + + +class SafeFileCache(BaseCache): + """ + A file based cache which is safe to use even when the target directory may + not be accessible or writable. + """ + + def __init__(self, directory): + # type: (str) -> None + assert directory is not None, "Cache directory must not be None." + super(SafeFileCache, self).__init__() + self.directory = directory + + def _get_cache_path(self, name): + # type: (str) -> str + # From cachecontrol.caches.file_cache.FileCache._fn, brought into our + # class for backwards-compatibility and to avoid using a non-public + # method. + hashed = FileCache.encode(name) + parts = list(hashed[:5]) + [hashed] + return os.path.join(self.directory, *parts) + + def get(self, key): + # type: (str) -> Optional[bytes] + path = self._get_cache_path(key) + with suppressed_cache_errors(): + with open(path, 'rb') as f: + return f.read() + + def set(self, key, value): + # type: (str, bytes) -> None + path = self._get_cache_path(key) + with suppressed_cache_errors(): + ensure_dir(os.path.dirname(path)) + + with adjacent_tmp_file(path) as f: + f.write(value) + + replace(f.name, path) + + def delete(self, key): + # type: (str) -> None + path = self._get_cache_path(key) + with suppressed_cache_errors(): + os.remove(path) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/network/download.py b/venv/lib/python3.8/site-packages/pip/_internal/network/download.py new file mode 100644 index 0000000..c90c4bf --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/network/download.py @@ -0,0 +1,200 @@ +"""Download files with progress indicators. +""" +import cgi +import logging +import mimetypes +import os + +from pip._vendor import requests +from pip._vendor.requests.models import CONTENT_CHUNK_SIZE + +from pip._internal.models.index import PyPI +from pip._internal.network.cache import is_from_cache +from pip._internal.network.utils import response_chunks +from pip._internal.utils.misc import ( + format_size, + redact_auth_from_url, + splitext, +) +from pip._internal.utils.typing import MYPY_CHECK_RUNNING +from pip._internal.utils.ui import DownloadProgressProvider + +if MYPY_CHECK_RUNNING: + from typing import Iterable, Optional + + from pip._vendor.requests.models import Response + + from pip._internal.models.link import Link + from pip._internal.network.session import PipSession + +logger = logging.getLogger(__name__) + + +def _get_http_response_size(resp): + # type: (Response) -> Optional[int] + try: + 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] + total_length = _get_http_response_size(resp) + + if link.netloc == PyPI.file_storage_domain: + url = link.show_url + else: + url = link.url_without_fragment + + logged_url = redact_auth_from_url(url) + + if total_length: + logged_url = '{} ({})'.format(logged_url, format_size(total_length)) + + if is_from_cache(resp): + logger.info("Using cached %s", logged_url) + else: + logger.info("Downloading %s", logged_url) + + if logger.getEffectiveLevel() > logging.INFO: + show_progress = False + elif is_from_cache(resp): + show_progress = False + elif not total_length: + show_progress = True + elif total_length > (40 * 1000): + show_progress = True + else: + show_progress = False + + chunks = response_chunks(resp, CONTENT_CHUNK_SIZE) + + if not show_progress: + return chunks + + return DownloadProgressProvider( + progress_bar, max=total_length + )(chunks) + + +def sanitize_content_filename(filename): + # type: (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 + """ + 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') + if filename: + # We need to sanitize the filename to prevent directory traversal + # in case the filename contains ".." path parts. + filename = sanitize_content_filename(filename) + return filename or default_filename + + +def _get_http_response_filename(resp, link): + # type: (Response, 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') + if content_disposition: + filename = parse_content_disposition(content_disposition, filename) + ext = splitext(filename)[1] # type: Optional[str] + if not ext: + ext = mimetypes.guess_extension( + resp.headers.get('content-type', '') + ) + if ext: + filename += ext + if not ext and link.url != resp.url: + ext = os.path.splitext(resp.url)[1] + if ext: + filename += ext + return filename + + +def _http_get_download(session, link): + # type: (PipSession, Link) -> Response + target_url = link.url.split('#', 1)[0] + resp = session.get( + target_url, + # We use Accept-Encoding: identity here because requests + # defaults to accepting compressed responses. This breaks in + # a variety of ways depending on how the server is configured. + # - Some servers will notice that the file isn't a compressible + # file and will leave the file alone and with an empty + # Content-Encoding + # - Some servers will notice that the file is already + # compressed and will leave the file alone and will add a + # Content-Encoding: gzip header + # - Some servers won't notice anything at all and will take + # a file that's already been compressed and compress it again + # and set the Content-Encoding: gzip header + # By setting this to request only the identity encoding We're + # hoping to eliminate the third case. Hopefully there does not + # exist a server which when given a file will notice it is + # already compressed and that 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"}, + stream=True, + ) + resp.raise_for_status() + return resp + + +class Download(object): + def __init__( + self, + response, # type: Response + filename, # type: str + chunks, # type: Iterable[bytes] + ): + # type: (...) -> None + self.response = response + self.filename = filename + self.chunks = chunks + + +class Downloader(object): + def __init__( + self, + session, # type: PipSession + progress_bar, # type: str + ): + # type: (...) -> None + self._session = session + self._progress_bar = progress_bar + + def __call__(self, link): + # type: (Link) -> Download + try: + resp = _http_get_download(self._session, link) + except requests.HTTPError as e: + logger.critical( + "HTTP error %s while getting %s", e.response.status_code, link + ) + raise + + return Download( + resp, + _get_http_response_filename(resp, link), + _prepare_download(resp, link, self._progress_bar), + ) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/network/session.py b/venv/lib/python3.8/site-packages/pip/_internal/network/session.py new file mode 100644 index 0000000..f5eb15e --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/network/session.py @@ -0,0 +1,405 @@ +"""PipSession and supporting code, containing all pip-specific +network request configuration and behavior. +""" + +# The following comment should be removed at some point in the future. +# mypy: disallow-untyped-defs=False + +import email.utils +import json +import logging +import mimetypes +import os +import platform +import sys +import warnings + +from pip._vendor import requests, six, urllib3 +from pip._vendor.cachecontrol import CacheControlAdapter +from pip._vendor.requests.adapters import BaseAdapter, HTTPAdapter +from pip._vendor.requests.models import Response +from pip._vendor.requests.structures import CaseInsensitiveDict +from pip._vendor.six.moves.urllib import parse as urllib_parse +from pip._vendor.urllib3.exceptions import InsecureRequestWarning + +from pip import __version__ +from pip._internal.network.auth import MultiDomainBasicAuth +from pip._internal.network.cache import SafeFileCache +# Import ssl from compat so the initial import occurs in only one place. +from pip._internal.utils.compat import has_tls, ipaddress +from pip._internal.utils.glibc import libc_ver +from pip._internal.utils.misc import ( + build_url_from_netloc, + get_installed_version, + parse_netloc, +) +from pip._internal.utils.typing import MYPY_CHECK_RUNNING +from pip._internal.utils.urls import url_to_path + +if MYPY_CHECK_RUNNING: + from typing import ( + Iterator, List, Optional, Tuple, Union, + ) + + from pip._internal.models.link import Link + + SecureOrigin = Tuple[str, str, Optional[Union[int, str]]] + + +logger = logging.getLogger(__name__) + + +# Ignore warning raised when using --trusted-host. +warnings.filterwarnings("ignore", category=InsecureRequestWarning) + + +SECURE_ORIGINS = [ + # protocol, hostname, port + # Taken from Chrome's list of secure origins (See: http://bit.ly/1qrySKC) + ("https", "*", "*"), + ("*", "localhost", "*"), + ("*", "127.0.0.0/8", "*"), + ("*", "::1/128", "*"), + ("file", "*", None), + # ssh is always secure. + ("ssh", "*", "*"), +] # type: List[SecureOrigin] + + +# These are environment variables present when running under various +# CI systems. For each variable, some CI systems that use the variable +# are indicated. The collection was chosen so that for each of a number +# of popular systems, at least one of the environment variables is used. +# This list is used to provide some indication of and lower bound for +# CI traffic to PyPI. Thus, it is okay if the list is not comprehensive. +# For more background, see: https://github.com/pypa/pip/issues/5499 +CI_ENVIRONMENT_VARIABLES = ( + # Azure Pipelines + 'BUILD_BUILDID', + # Jenkins + 'BUILD_ID', + # AppVeyor, CircleCI, Codeship, Gitlab CI, Shippable, Travis CI + 'CI', + # Explicit environment variable. + 'PIP_IS_CI', +) + + +def looks_like_ci(): + # type: () -> bool + """ + Return whether it looks like pip is running under CI. + """ + # We don't use the method of checking for a tty (e.g. using isatty()) + # because some CI systems mimic a tty (e.g. Travis CI). Thus that + # method doesn't provide definitive information in either direction. + return any(name in os.environ for name in CI_ENVIRONMENT_VARIABLES) + + +def user_agent(): + """ + Return a string representing the user agent. + """ + data = { + "installer": {"name": "pip", "version": __version__}, + "python": platform.python_version(), + "implementation": { + "name": platform.python_implementation(), + }, + } + + if data["implementation"]["name"] == 'CPython': + data["implementation"]["version"] = platform.python_version() + elif data["implementation"]["name"] == 'PyPy': + if sys.pypy_version_info.releaselevel == 'final': + pypy_version_info = sys.pypy_version_info[:3] + else: + pypy_version_info = sys.pypy_version_info + data["implementation"]["version"] = ".".join( + [str(x) for x in pypy_version_info] + ) + elif data["implementation"]["name"] == 'Jython': + # Complete Guess + data["implementation"]["version"] = platform.python_version() + elif data["implementation"]["name"] == 'IronPython': + # Complete Guess + data["implementation"]["version"] = platform.python_version() + + if sys.platform.startswith("linux"): + from pip._vendor import distro + distro_infos = dict(filter( + lambda x: x[1], + zip(["name", "version", "id"], distro.linux_distribution()), + )) + libc = dict(filter( + lambda x: x[1], + zip(["lib", "version"], libc_ver()), + )) + if libc: + distro_infos["libc"] = libc + if distro_infos: + data["distro"] = distro_infos + + if sys.platform.startswith("darwin") and platform.mac_ver()[0]: + data["distro"] = {"name": "macOS", "version": platform.mac_ver()[0]} + + if platform.system(): + data.setdefault("system", {})["name"] = platform.system() + + if platform.release(): + data.setdefault("system", {})["release"] = platform.release() + + if platform.machine(): + data["cpu"] = platform.machine() + + if has_tls(): + import _ssl as ssl + data["openssl_version"] = ssl.OPENSSL_VERSION + + setuptools_version = get_installed_version("setuptools") + if setuptools_version is not None: + data["setuptools_version"] = setuptools_version + + # 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 + # value to make it easier to know that the check has been run. + data["ci"] = True if looks_like_ci() else None + + user_data = os.environ.get("PIP_USER_AGENT_USER_DATA") + if user_data is not None: + data["user_data"] = user_data + + return "{data[installer][name]}/{data[installer][version]} {json}".format( + data=data, + json=json.dumps(data, separators=(",", ":"), sort_keys=True), + ) + + +class LocalFSAdapter(BaseAdapter): + + def send(self, request, stream=None, timeout=None, verify=None, cert=None, + proxies=None): + pathname = url_to_path(request.url) + + resp = Response() + resp.status_code = 200 + resp.url = request.url + + try: + stats = os.stat(pathname) + except OSError as exc: + resp.status_code = 404 + resp.raw = exc + 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.raw = open(pathname, "rb") + resp.close = resp.raw.close + + return resp + + def close(self): + pass + + +class InsecureHTTPAdapter(HTTPAdapter): + + def cert_verify(self, conn, url, verify, cert): + super(InsecureHTTPAdapter, self).cert_verify( + conn=conn, url=url, verify=False, cert=cert + ) + + +class PipSession(requests.Session): + + timeout = None # type: Optional[int] + + def __init__(self, *args, **kwargs): + """ + :param trusted_hosts: Domains not to emit warnings for when not using + HTTPS. + """ + retries = kwargs.pop("retries", 0) + cache = kwargs.pop("cache", None) + trusted_hosts = kwargs.pop("trusted_hosts", []) # type: List[str] + index_urls = kwargs.pop("index_urls", None) + + super(PipSession, self).__init__(*args, **kwargs) + + # 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]]] + + # Attach our User Agent to the request + self.headers["User-Agent"] = user_agent() + + # Attach our Authentication handler to the session + self.auth = MultiDomainBasicAuth(index_urls=index_urls) + + # Create our urllib3.Retry instance which will allow us to customize + # how we handle retries. + retries = urllib3.Retry( + # 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 + # retry it. + # 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, + ) + + # We want to _only_ cache responses on securely fetched origins. We do + # this because we can't validate the response of an insecurely fetched + # origin, and we don't want someone to be able to poison the cache and + # require manual eviction from the cache to fix it. + if cache: + secure_adapter = CacheControlAdapter( + cache=SafeFileCache(cache), + max_retries=retries, + ) + else: + secure_adapter = HTTPAdapter(max_retries=retries) + + # Our Insecure HTTPAdapter disables HTTPS validation. It does not + # support caching (see above) so we'll use it for all http:// URLs as + # well as any https:// host that we've marked as ignoring TLS errors + # for. + insecure_adapter = InsecureHTTPAdapter(max_retries=retries) + # Save this for later use in add_insecure_host(). + self._insecure_adapter = insecure_adapter + + self.mount("https://", secure_adapter) + self.mount("http://", insecure_adapter) + + # Enable file:// urls + self.mount("file://", LocalFSAdapter()) + + for host in trusted_hosts: + self.add_trusted_host(host, suppress_logging=True) + + def add_trusted_host(self, host, source=None, suppress_logging=False): + # type: (str, Optional[str], bool) -> None + """ + :param host: It is okay to provide a host that has previously been + added. + :param source: An optional source string, for logging where the host + string came from. + """ + if not suppress_logging: + msg = 'adding trusted host: {!r}'.format(host) + if source is not None: + msg += ' (from {})'.format(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) + + self.mount(build_url_from_netloc(host) + '/', self._insecure_adapter) + if not host_port[1]: + # Mount wildcard ports for the same host. + self.mount( + build_url_from_netloc(host) + ':', + self._insecure_adapter + ) + + def iter_secure_origins(self): + # type: () -> Iterator[SecureOrigin] + for secure_origin in SECURE_ORIGINS: + yield secure_origin + for host, port in self.pip_trusted_origins: + yield ('*', host, '*' if port is None else port) + + def is_secure_origin(self, location): + # type: (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, + ) + + # 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] + + # Determine if our origin is a secure origin by looking through our + # hardcoded list of secure origins, as well as any additional ones + # configured on this PackageFinder instance. + for secure_origin in self.iter_secure_origins(): + secure_protocol, secure_host, secure_port = secure_origin + if origin_protocol != secure_protocol and secure_protocol != "*": + continue + + try: + addr = ipaddress.ip_address( + None + if origin_host is None + else six.ensure_text(origin_host) + ) + network = ipaddress.ip_network( + six.ensure_text(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 != "*" + ): + continue + else: + # We have a valid address and network, so see if the address + # is contained within the network. + if addr not in network: + continue + + # Check to see if the port matches. + if ( + origin_port != secure_port and + secure_port != "*" and + secure_port is not None + ): + continue + + # If we've gotten here, then this origin matches the current + # secure origin and we should return True + return True + + # If we've gotten to this point, then the origin isn't secure and we + # will not accept it as a valid location to search. We will however + # log a warning that we are ignoring it. + logger.warning( + "The repository located at %s is not a trusted or secure host and " + "is being ignored. If this repository is available via HTTPS we " + "recommend you use HTTPS instead, otherwise you may silence " + "this warning and allow it anyway with '--trusted-host %s'.", + origin_host, + origin_host, + ) + + return False + + def request(self, method, url, *args, **kwargs): + # Allow setting a default timeout on a session + kwargs.setdefault("timeout", self.timeout) + + # Dispatch the actual request + return super(PipSession, self).request(method, url, *args, **kwargs) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/network/utils.py b/venv/lib/python3.8/site-packages/pip/_internal/network/utils.py new file mode 100644 index 0000000..a19050b --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/network/utils.py @@ -0,0 +1,48 @@ +from pip._vendor.requests.models import CONTENT_CHUNK_SIZE, Response + +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import Iterator + + +def response_chunks(response, chunk_size=CONTENT_CHUNK_SIZE): + # type: (Response, int) -> Iterator[bytes] + """Given a requests Response, provide the data chunks. + """ + try: + # Special case for urllib3. + for chunk in response.raw.stream( + chunk_size, + # We use decode_content=False here because we don't + # want urllib3 to mess with the raw bytes we get + # from the server. If we decompress inside of + # urllib3 then we cannot verify the checksum + # because the checksum will be of the compressed + # file. This breakage will only occur if the + # server adds a Content-Encoding header, which + # depends on how the server was configured: + # - Some servers will notice that the file isn't a + # compressible file and will leave the file alone + # and with an empty Content-Encoding + # - Some servers will notice that the file is + # already compressed and will leave the file + # alone and will add a Content-Encoding: gzip + # header + # - Some servers won't notice anything at all and + # will take a file that's already been compressed + # and compress it again and set the + # Content-Encoding: gzip header + # + # By setting this not to decode automatically we + # hope to eliminate problems with the second case. + decode_content=False, + ): + yield chunk + except AttributeError: + # Standard file-like object. + while True: + chunk = response.raw.read(chunk_size) + if not chunk: + break + yield chunk diff --git a/venv/lib/python3.8/site-packages/pip/_internal/network/xmlrpc.py b/venv/lib/python3.8/site-packages/pip/_internal/network/xmlrpc.py new file mode 100644 index 0000000..121edd9 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/network/xmlrpc.py @@ -0,0 +1,44 @@ +"""xmlrpclib.Transport implementation +""" + +# The following comment should be removed at some point in the future. +# mypy: disallow-untyped-defs=False + +import logging + +from pip._vendor import requests +# NOTE: XMLRPC Client is not annotated in typeshed as on 2017-07-17, which is +# why we ignore the type on this import +from pip._vendor.six.moves import xmlrpc_client # type: ignore +from pip._vendor.six.moves.urllib import parse as urllib_parse + +logger = logging.getLogger(__name__) + + +class PipXmlrpcTransport(xmlrpc_client.Transport): + """Provide a `xmlrpclib.Transport` implementation via a `PipSession` + object. + """ + + def __init__(self, index_url, session, use_datetime=False): + xmlrpc_client.Transport.__init__(self, 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): + 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) + response.raise_for_status() + self.verbose = verbose + return self.parse_response(response.raw) + except requests.HTTPError as exc: + logger.critical( + "HTTP error %s while getting %s", + exc.response.status_code, url, + ) + raise diff --git a/venv/lib/python3.8/site-packages/pip/_internal/operations/__init__.py b/venv/lib/python3.8/site-packages/pip/_internal/operations/__init__.py new file mode 100644 index 0000000..e69de29 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/operations/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/operations/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..ce5d08889af886690492df2b27752693b6e4f4c9 GIT binary patch literal 160 zcmWIL<>g`k0&_FfL=gQLL?8o3AjbiSi&=m~3PUi1CZpd^EiC(_dfLb z)Rd#)`QfeW!MF38_IFxLJ|-4-F{G<&TBvzisD~`pJsrPB%o4*hblNjxGpTtsHLt~1 zQupd=ZpC)e@EU4fkDa9HHPzgXTgj9+rE6S2n&#);=-v#U690gvMm(F$d2>q2iO(nV z-h8s)EhLNHVsgQ|kSuvi$+EYctavLpy~r|a4DP#XJ6^wYB(33$IkU| zK3u@>_rt~T0)F2Q*;B2(eDMA+gE$I$)Ky@HFIUC*qRUgP_w7dR#i+l99LC zdg-J=!oz$xh&fiXogmH9r~@Sj+$R<`7oPCFVI+9M)BJHDB)>02CctPXL7)3!By$mM z59ytLHxqu8$~=f;Uz{F;@Wmd_k6AoCb4r3e_u2Eu&;8Ax-{1VyfAaa(*2Arz(eA@a z*TfCl_0srhx?kFxct@}u^U}N*b@I~w#ei-Q#HI0+=Vk2~eNt&Y!tKiG$JKY=<9QIp zvaG-0LPEH-$9I$+vd8gbVba9-6hr<2q|hR*&%_*oFEswbMp%yk!4b=~F1UZx?`gmK zYGmYkVeGO)ePkXiv&dHu)^&B82d zZwSh@5&J^>NDHk|?d#f?+H;)v5(DR1mt0&w_;@o*asOPpfg9uNl%FSjAl)dorERFX|Q}(05!FAsi3{2NFCRP=2zLpXT_i~uJL!zeT$vjq)+i z-R95)OsZ&h^PM1fb0ikvTPZny2f@M((hva6hax5TZ)aJ|gS3M8RtF{Ga8v=WA7AV;wqNq)S27fr=!Z-`oRr_qe<|rZKyz!ch=4vdWNjk90)Er zZYDXUHlxq?+pW@ok*e@8=+%q#LMsVGA2DL{7ePD(JWC@8LlsG7Lk@T+>PEzdVUf8~ zSz0m^IS-*M7wx84Ax-a*rg{=d3g5B`*=~%CNQ>4n+Eq-o#xg$2f-Gky1gjkbp|9+M zdqEqoF7mFCX8*?&KgI>*hag(r)@=iU!)#{h7PEDRz;O&4q2%C?0*V=qKBLbeyk@YT zV}cHzaUFS!5)GM2-U6X;`HGDw-Rgk1e#nq&0Z5wt9&4mp{kK{dp%=1Oc4)k=Ql)vo zA0U0H>r!F^V)Gq-S`+u(o(Kjz?n^=_q3{&GZqP+4p`?jqs;U_&=tVDhdL}elygep)wTkly%7h=b{O0#AoNcR?Vw$m z`?#ncJ58SA@AynxS5Ro1Do>TmzKoJ#OgV3SSfxZi>z1?rI2oSafxOT*ODE5cr4_hJ z-7n{qf&A?gJpcxMo*>^;fpg*iTr!4)q>`Xn4s#60U`VG-bN*xgTl@sOXObx;(i+Al zhI|B~(j-%8Y5`k^glv<~9D%b`#0+d+QVO=8W??_tWHW<~+V*Y@L0+=Ec z7~)4Df5NE1g!DomNy&vOw9OR1t#7q&ly%<^vyShVb?QIH88MEb9}S-r6r1Hmv^e>j6RzX6YadiBq$QsOl?PfLl{9Pd)I?VX$8sEy_(H3d(&9L9MCcb9ZiR#Abj zaHzaA;n@@Smi9)Hg~OQNq4X)&Kuna97HiQkh*Ce+(pPJk>(guo#iPZh4ST^^w-@Y% F{{m)M#6SQ5 literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/operations/__pycache__/freeze.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/operations/__pycache__/freeze.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..fe2605c54f7f9f23344f449d51e70618d9c0c2f6 GIT binary patch literal 5803 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 literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/operations/build/__pycache__/metadata.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/operations/build/__pycache__/metadata.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..7553793e8dd92b6998abfd5347d4c54e77a47341 GIT binary patch literal 1208 zcmZux&2HQ_5GE}XH^Z6vW~djNn*#*n(Klabdp(5y_QLxk z0O5Q1%qdJ9rHErrN}S?uB`JY5D1(Zo6nl)8y(&z@Zr>~WRg^{;iAbLS7M2^;ARTmA zzx=2grbEE+^``jv2B%v*;v0XUbeof3(P(h_;JL6F&ukVKLJ6H&S*y6L3z^5SYaN@q z)wzhdG*-)L>rs;o{(&gb(FnUe-72tR7t+p{X=Eoy$##tK;7@Wz7UUFP1q<{x!N?L$f5%sJfv*!DFf7$>Ai1 z(38O+hH)%xtCflEOspsdwe?ke#ZJ;`Uv5=37h3JF6i!CO(KD&I+b+s_3RKKll_}tt zU+zw{Xfo|%xtIx2u5TUnweKiLo6OF%C(iAdcG~DVhuW}Z(Oleg=7Oz!F{n73`dYB= zK1XWf=xHt0D0CZ3K&W%qpJw@)fRMJ0d~H0s;N| zYz#KzMmGDcYW#hCzjL}T+v3f)^9L6m8#Ada(2p?_DnU zz=zp|355g`MBaroBq5FP5K~Ov?Na?2V51$^XN=c5W3CTfUjUbS2!Q(vyeDh#33PsG zk~-?;8cuqIQ_d3Fqt%!77<{e7O6{Iaam`Mg)a|)d-$@#& z*Ym2rn>5o_uT}LM$(6L-Ygc_QnMr4Rvy_OoEMb2$xth-P=F<7ze6`+67Se0IYp_m_ z7sX3s+FRmRc>5{oUFS1=7QV}zJtUp0!?!;WI^>}a{l3VA40W7mev+2~L+|6Znam?YKi`%>l-CR-v?11SO?S&9gU>(uJh=Pr{kwk&Hb2?ecyHqY z%vz5l)nUedA1-6O4-33Zn83o^p9gWm?`Mx=nP;iUbj0w2CyxtX2VOLd`U)B}#Z&SP z`3KnnV{rSaH)7o3?o%?dN;0xbD!U~s?ISvJvSm&7=rN3VW6VajCdXE3k71>B)Mwh} z-m!z@Bl;E9Zs{C>N%n17l+IqGw0P?orDSqK>F_Hz$Qa>o5AVMdXWS1nzYBP*ARd04 z`CB#K2%U&@E)Ta}_qRhOxDUqJiUB+x>u@^}TiuoqPeehV$%Fj{ybs}3cc7_%xN1Q$ zRC{cVY0<4_Kow97=K%tohif?-#@dcE;}(Z{H_uGtVI<>1t6}S-YN9Kih>l}eu8duT zde<}(@dT^^!@V5$)uRrT;2Y#Qk=Nk!-R7!Ji`617Rt8xSM*D)V9PA2_ti*%p_?VB76J`R2>aY ztYy0N{jeMC0L)X$b=Q&{*rwLImv27@CvpbiL><(Bpy`tl1^d&IjOjh{<=?-sz9Azv zvNYSXV7vs(u}ik^%3CEnhW;3A|LB%>N_K?uYa{z>*uUoYvz{l3rA?e#)h%A00(ifRp&H9uRyJSgBtx3nv#6E zh&my|;ZAhS{z~A^j01-{bfaU*S&*uXDd(XF-p9Ikj1BY*o>ODXJlB7kuw z1*@?S!en0}#f%4tW??FnaivJ}$HLeseu_N0mWHc?_t_W_Oe+dA9z*Tb}s)NwfIxQpdFN6AJ5K#yOVK!Z)E$Y#>-KGn)&E{yE-lW4jKUe2-roy0v zM5s*lDs)P6Of=mCpBdBYYs;6XbKo<@E1X_O{;>^-n?YkI$_JS~<)X2aD2y8>8om&0 zQ00q8T;QV6yFtEl8cW{b~ zEZ2}Z2N2aEkpFG;ZFPCbTKnR#R>V8ipz| zVnQ%i&SU}k8f=tZY;NNbO{74@qZ*D5u2il$dtTEeSWvg1A&%E*U-KF^wP}mZ!fR7T zy%%<)4GfTf1c|7Mrzi^#!qKs zvr3zo56w)4P*5BORlaVW(g`BrNiAW#SmjW{32qu3Qf-_l`4${!Y^=~OI@bJ2xhR4O zd>@0XLMD(@|gm(LZ?E_+`3eBT8dVvnwysi z>B9oAi@ssz&kI1AT1R#FL>AlGp-`eB9H m8Ec#-EN?B%`5+PN7;>t_Zd)Gp7`X7{58Qf=wOPyZ-u?mOAAh_6 literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/operations/build/__pycache__/wheel.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/operations/build/__pycache__/wheel.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..96716bae2e1cbd340f36c143f81d17ca288adf76 GIT binary patch literal 1306 zcmZuxO>Y}T7@pa0Z=8@;6;c}nBSfTH!fREc6d{D5CM6Zc4MA0#J+Rt%Ce9}N)tOn0 z&E^6exKvy@+DCo_e`Kzl_zN5;?~F|vB*vPt-+8~D=b0Hl+1v~fjC=3zroX!g{h^Jk z!v^CMnBp5)D55w=@#-7L7;G!I3Oly3-m`P3aAOxE=JI{8o!l$@*e`-OFn%}h6k!~K zA1yXmcZuUo>QVnE6mL=dHR=U_LJu_RVYS1XvSd7&X7V%U@~yIpbrXcsYFd)qy#L zDSm~ewJ1LCh^|CG;MV5vNW8G9)uI#pI$C0&03hf0Vb`X1>ntsdq(hyB+k*E;eBriu z;kE7(|8fJP7N7a80~OsD)`j;J-9=xaL-Y(iMdjNLlEHb%f5u3EOcxJoK)oZ=;~A2j zvv9Ei`QFk3Vf^`v`%RWpQk9H6EQJIzhwOQiaaOQWl160Zgve7y4)zWRFeb+)yyn#y zM2o_Zz&K>G;iVvTDo=^5$n=!4oMb0NG-Dlh(&YKfWXgy%0+kk4&Y} z{J}6S%Sx{MtSX&Uoa~A8C^5)XXYac)Gt`t-3FT;k zm2*~QWzSbmnHEg>$LaW-m6YpCr#4sFD>;O6B`a#Gymjr+R84f=Z;0Q7gunI&vZx1j zR`;8-)|F`A1og9K^8AC@dsFQjBv~mLhpRuRYQ~MGVqjVgOmtMw)b%UCliECwE$AR_ z!-Be9>{uRlUV4^;E!?#%9K3XF*age_`-ZcHyEwpn2V#4#DPKzm67y}a)tdkzx`Yrl zGRsBuO1YJ!xBf3k&ftYlxc;kA-r8`$;QFv<8ZTdpe>sVe--H s6obU*mLy!iYy;FNcxAbzQ-Y6*iZ(g>7=tA={s0G77brV;8`jYN2XPsERsaA1 literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/operations/build/__pycache__/wheel_legacy.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/operations/build/__pycache__/wheel_legacy.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..dfa07cd8704b0f24a62c5e83381f4367e111fa2a GIT binary patch literal 2567 zcma)8TW{P%6rS;YolVlFNlLlNjategvJnW{Dnb=%l3pMrkW$(%0^@il8#lfzGvlV& zc%NGFM8#i7#1n7)o_Xb|e*q|PX1v)(rAT&|-N@k{Z=5(CQ?YNoO@wCiJ8=2qn^}C&p zWz9|#BkHs7K;KEnvx&|`HrbiXPIOLy937mbQ-`>7inzpkj5^b#L40`5kTKGP=Pbdu zP;2}t>;4ktxCnQ*DNVzOb$QE_W2@`e!{wV_-CSPTkdtwg zrXepkd#s2l=knB6!Lmq%agk+FPHH18r#`#)`Mq%I#>&#C;l}N?wVP|#VYz0}qj|`C zNuE;%uB}yAO?vA+kra89O6yDdP{fAX-SD#DX~Vq)H~$s}fhzO}4-A42aAh3gfmvZ5 zR3J2~tN+^$|C7>q1AT|r8 zzppQdthdlhdh=!8i{c$h<~3I4ld}8$<-HGf)whK($pvLl&;_VBi&Sy>!e*JIWT8e@ zO1n|K*Y54fnL3&gd>G|rDrR6UJ`DqMJnS15_VENfeeB^A273kMvC75K<-p4bBmyQw zkN{Np`y-&(l`V|QtgJ_>+_o?etja#b&{@VUBy0sMVghJ3iKU=bp+jTvpEkm|?;dy+ zt`M=$fTo7dl?`YlmIq>+2E9mZtD>rR9W($*PXx_+1&i2TpfeJXghA~Jw%6{zx2p3p z{7`HS4HfG4&$2-fGa3m>g1iW}l9ckczxEVExc$!mG|UPHNZXF`03fM-wEb(~DUUMB zgSX@DqTqmS_`fyAKy#|mDYm9_CNkc+Xp5FllehvoYd)P9J zzYW9q%Q68TFl(y0X&~d7WhuZgr5G!C99?Srim)}G{0c7s6<~r2pg`~wYv2$l{1%=? z16Sb6eT08{Jn$5!5EH;+VAP)yR^Xf9uycu{ zfP~RKbO(KizCau3XGGjv=q?i8K|=v>;0wR=rjMbK&)(u{YBbcctCv?*f+>%V?20vwY%*cV-|wQLqZ zt=U;M%&B1nz}6U3=M8h!pdoD&x>(|wHdR0&v>}HwvX;_vYChIm zKhjlBUu>7D<2_PW{RY_c%P^pE0}p?HI<6000zGmhdFI=yZ<=@tsC6X8#vhK$E`n|A zG@FEnbPL|r3+u4Y0mZjR6yGjIlJfTPzYq$YI;rx_m#U8bJm}*{C%Qh`UVWLm*n`A$ znQCG=`!alnbg;*=s*XCQnaKMn fD@d8rD~biVl6%-Qn&!0KghX0++VD+p#(VQ0Y8KMp literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/operations/build/metadata.py b/venv/lib/python3.8/site-packages/pip/_internal/operations/build/metadata.py new file mode 100644 index 0000000..b13fbde --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/operations/build/metadata.py @@ -0,0 +1,40 @@ +"""Metadata generation logic for source distributions. +""" + +import logging +import os + +from pip._internal.utils.subprocess import runner_with_spinner_message +from pip._internal.utils.temp_dir import TempDirectory +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from pip._internal.build_env import BuildEnvironment + from pip._vendor.pep517.wrappers import Pep517HookCaller + +logger = logging.getLogger(__name__) + + +def generate_metadata(build_env, backend): + # type: (BuildEnvironment, Pep517HookCaller) -> str + """Generate metadata using mechanisms described in PEP 517. + + Returns the generated metadata directory. + """ + metadata_tmpdir = TempDirectory( + kind="modern-metadata", globally_managed=True + ) + + metadata_dir = metadata_tmpdir.path + + with build_env: + # Note that Pep517HookCaller 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") + with backend.subprocess_runner(runner): + distinfo_dir = backend.prepare_metadata_for_build_wheel( + metadata_dir + ) + + return os.path.join(metadata_dir, distinfo_dir) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/operations/build/metadata_legacy.py b/venv/lib/python3.8/site-packages/pip/_internal/operations/build/metadata_legacy.py new file mode 100644 index 0000000..b6813f8 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/operations/build/metadata_legacy.py @@ -0,0 +1,122 @@ +"""Metadata generation logic for legacy source distributions. +""" + +import logging +import os + +from pip._internal.exceptions import InstallationError +from pip._internal.utils.misc import ensure_dir +from pip._internal.utils.setuptools_build import make_setuptools_egg_info_args +from pip._internal.utils.subprocess import call_subprocess +from pip._internal.utils.typing import MYPY_CHECK_RUNNING +from pip._internal.vcs import vcs + +if MYPY_CHECK_RUNNING: + from typing import List, Optional + + from pip._internal.build_env import BuildEnvironment + +logger = logging.getLogger(__name__) + + +def _find_egg_info(source_directory, is_editable): + # type: (str, bool) -> str + """Find an .egg-info in `source_directory`, based on `is_editable`. + """ + + def looks_like_virtual_env(path): + # type: (str) -> bool + return ( + os.path.lexists(os.path.join(path, 'bin', 'python')) or + os.path.exists(os.path.join(path, 'Scripts', 'Python.exe')) + ) + + def locate_editable_egg_info(base): + # type: (str) -> List[str] + candidates = [] # type: List[str] + for root, dirs, files in os.walk(base): + for dir_ in vcs.dirnames: + if dir_ in dirs: + dirs.remove(dir_) + # Iterate over a copy of ``dirs``, since mutating + # a list while iterating over it can cause trouble. + # (See https://github.com/pypa/pip/pull/462.) + for dir_ in list(dirs): + if looks_like_virtual_env(os.path.join(root, dir_)): + dirs.remove(dir_) + # Also don't search through tests + elif dir_ == 'test' or dir_ == 'tests': + dirs.remove(dir_) + candidates.extend(os.path.join(root, dir_) for dir_ in dirs) + return [f for f in candidates if f.endswith('.egg-info')] + + def depth_of_directory(dir_): + # type: (str) -> int + return ( + dir_.count(os.path.sep) + + (os.path.altsep and dir_.count(os.path.altsep) or 0) + ) + + base = source_directory + if is_editable: + filenames = locate_editable_egg_info(base) + else: + base = os.path.join(base, 'pip-egg-info') + filenames = os.listdir(base) + + if not filenames: + raise InstallationError( + "Files/directories not found in {}".format(base) + ) + + # If we have more than one match, we pick the toplevel one. This + # can easily be the case if there is a dist folder which contains + # an extracted tarball for testing purposes. + if len(filenames) > 1: + filenames.sort(key=depth_of_directory) + + return os.path.join(base, filenames[0]) + + +def generate_metadata( + build_env, # type: BuildEnvironment + setup_py_path, # type: str + source_dir, # type: str + editable, # type: bool + isolated, # type: bool + details, # type: str +): + # type: (...) -> 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, + ) + + egg_info_dir = None # type: Optional[str] + # For non-editable installs, don't put the .egg-info files at the root, + # to avoid confusion due to the source code being considered an installed + # egg. + if not editable: + egg_info_dir = os.path.join(source_dir, 'pip-egg-info') + # setuptools complains if the target directory does not exist. + ensure_dir(egg_info_dir) + + args = make_setuptools_egg_info_args( + setup_py_path, + egg_info_dir=egg_info_dir, + no_user_config=isolated, + ) + + with build_env: + call_subprocess( + args, + cwd=source_dir, + command_desc='python setup.py egg_info', + ) + + # Return the .egg-info directory. + return _find_egg_info(source_dir, editable) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/operations/build/wheel.py b/venv/lib/python3.8/site-packages/pip/_internal/operations/build/wheel.py new file mode 100644 index 0000000..1266ce0 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/operations/build/wheel.py @@ -0,0 +1,46 @@ +import logging +import os + +from pip._internal.utils.subprocess import runner_with_spinner_message +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import List, Optional + from pip._vendor.pep517.wrappers import Pep517HookCaller + +logger = logging.getLogger(__name__) + + +def build_wheel_pep517( + name, # type: str + backend, # type: Pep517HookCaller + metadata_directory, # type: str + build_options, # type: List[str] + tempd, # type: str +): + # type: (...) -> 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 + if build_options: + # PEP 517 does not support --build-options + logger.error('Cannot build wheel for %s using PEP 517 when ' + '--build-option is present' % (name,)) + return None + try: + logger.debug('Destination directory: %s', tempd) + + runner = runner_with_spinner_message( + 'Building wheel for {} (PEP 517)'.format(name) + ) + with backend.subprocess_runner(runner): + wheel_name = backend.build_wheel( + tempd, + metadata_directory=metadata_directory, + ) + except Exception: + logger.error('Failed building wheel for %s', name) + return None + return os.path.join(tempd, wheel_name) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/operations/build/wheel_legacy.py b/venv/lib/python3.8/site-packages/pip/_internal/operations/build/wheel_legacy.py new file mode 100644 index 0000000..3ebd9fe --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/operations/build/wheel_legacy.py @@ -0,0 +1,115 @@ +import logging +import os.path + +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.typing import MYPY_CHECK_RUNNING +from pip._internal.utils.ui import open_spinner + +if MYPY_CHECK_RUNNING: + from typing import List, Optional, Text + +logger = logging.getLogger(__name__) + + +def format_command_result( + command_args, # type: List[str] + command_output, # type: Text +): + # type: (...) -> str + """Format command information for logging.""" + command_desc = format_command_args(command_args) + text = 'Command arguments: {}\n'.format(command_desc) + + if not command_output: + text += 'Command output: None' + elif logger.getEffectiveLevel() > logging.DEBUG: + text += 'Command output: [use --verbose to show]' + else: + if not command_output.endswith('\n'): + command_output += '\n' + text += 'Command output:\n{}{}'.format(command_output, LOG_DIVIDER) + + 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: Text +): + # type: (...) -> 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 += 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' + ).format(name, names) + msg += format_command_result(command_args, command_output) + logger.warning(msg) + + return os.path.join(temp_dir, names[0]) + + +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] + """Build one unpacked package using the "legacy" build process. + + Returns path to wheel if successfully built. Otherwise, returns None. + """ + wheel_args = make_setuptools_bdist_wheel_args( + setup_py_path, + global_options=global_options, + build_options=build_options, + destination_dir=tempd, + ) + + spin_message = 'Building wheel for %s (setup.py)' % (name,) + with open_spinner(spin_message) as spinner: + logger.debug('Destination directory: %s', tempd) + + try: + output = call_subprocess( + wheel_args, + cwd=source_dir, + spinner=spinner, + ) + except Exception: + spinner.finish("error") + logger.error('Failed building wheel for %s', name) + return None + + names = os.listdir(tempd) + wheel_path = get_legacy_build_wheel_path( + names=names, + temp_dir=tempd, + name=name, + command_args=wheel_args, + command_output=output, + ) + return wheel_path diff --git a/venv/lib/python3.8/site-packages/pip/_internal/operations/check.py b/venv/lib/python3.8/site-packages/pip/_internal/operations/check.py new file mode 100644 index 0000000..b85a123 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/operations/check.py @@ -0,0 +1,163 @@ +"""Validation of dependencies of packages +""" + +# The following comment should be removed at some point in the future. +# mypy: strict-optional=False +# mypy: disallow-untyped-defs=False + +import logging +from collections import namedtuple + +from pip._vendor.packaging.utils import canonicalize_name +from pip._vendor.pkg_resources import RequirementParseError + +from pip._internal.distributions import ( + make_distribution_for_install_requirement, +) +from pip._internal.utils.misc import get_installed_distributions +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +logger = logging.getLogger(__name__) + +if MYPY_CHECK_RUNNING: + from pip._internal.req.req_install import InstallRequirement + from typing import ( + Any, Callable, Dict, Optional, Set, Tuple, List + ) + + # Shorthands + PackageSet = Dict[str, 'PackageDetails'] + Missing = Tuple[str, Any] + Conflicting = Tuple[str, str, Any] + + MissingDict = Dict[str, List[Missing]] + ConflictingDict = Dict[str, List[Conflicting]] + CheckResult = Tuple[MissingDict, ConflictingDict] + +PackageDetails = namedtuple('PackageDetails', ['version', 'requires']) + + +def create_package_set_from_installed(**kwargs): + # type: (**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": ()} + + package_set = {} + problems = False + for dist in get_installed_distributions(**kwargs): + name = canonicalize_name(dist.project_name) + try: + package_set[name] = PackageDetails(dist.version, dist.requires()) + except RequirementParseError as e: + # Don't crash on 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 + """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. + """ + if should_ignore is None: + def should_ignore(name): + return False + + missing = {} + conflicting = {} + + for package_name in package_set: + # Info about dependencies of package_name + missing_deps = set() # type: Set[Missing] + conflicting_deps = set() # type: Set[Conflicting] + + if should_ignore(package_name): + continue + + for req in package_set[package_name].requires: + name = canonicalize_name(req.project_name) # type: str + + # Check if it's missing + if name not in package_set: + missed = True + if req.marker is not None: + missed = req.marker.evaluate() + if missed: + missing_deps.add((name, req)) + continue + + # Check if there's a conflict + version = package_set[name].version # type: str + if not req.specifier.contains(version, prereleases=True): + conflicting_deps.add((name, version, req)) + + if missing_deps: + missing[package_name] = sorted(missing_deps, key=str) + if conflicting_deps: + conflicting[package_name] = sorted(conflicting_deps, key=str) + + return missing, conflicting + + +def check_install_conflicts(to_install): + # type: (List[InstallRequirement]) -> Tuple[PackageSet, CheckResult] + """For checking if the dependency graph would be consistent after \ + installing given requirements + """ + # Start from the current state + package_set, _ = create_package_set_from_installed() + # Install packages + would_be_installed = _simulate_installation_of(to_install, package_set) + + # Only warn about directly-dependent packages; create a whitelist of them + whitelist = _create_whitelist(would_be_installed, package_set) + + return ( + 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[str] + """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() + + name = canonicalize_name(dist.key) + package_set[name] = PackageDetails(dist.version, dist.requires()) + + installed.add(name) + + return installed + + +def _create_whitelist(would_be_installed, package_set): + # type: (Set[str], PackageSet) -> Set[str] + 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: + if canonicalize_name(req.name) in packages_affected: + packages_affected.add(package_name) + break + + return packages_affected diff --git a/venv/lib/python3.8/site-packages/pip/_internal/operations/freeze.py b/venv/lib/python3.8/site-packages/pip/_internal/operations/freeze.py new file mode 100644 index 0000000..36a5c33 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/operations/freeze.py @@ -0,0 +1,265 @@ +# The following comment should be removed at some point in the future. +# mypy: strict-optional=False +# mypy: disallow-untyped-defs=False + +from __future__ import absolute_import + +import collections +import logging +import os +import re + +from pip._vendor import six +from pip._vendor.packaging.utils import canonicalize_name +from pip._vendor.pkg_resources import RequirementParseError + +from pip._internal.exceptions import BadCommand, InstallationError +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.misc import ( + dist_is_editable, + get_installed_distributions, +) +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import ( + Iterator, Optional, List, Container, Set, Dict, Tuple, Iterable, Union + ) + from pip._internal.cache import WheelCache + from pip._vendor.pkg_resources import ( + Distribution, Requirement + ) + + RequirementInfo = Tuple[Optional[Union[str, Requirement]], bool, List[str]] + + +logger = logging.getLogger(__name__) + + +def freeze( + requirement=None, # type: Optional[List[str]] + find_links=None, # type: Optional[List[str]] + local_only=None, # type: Optional[bool] + user_only=None, # type: Optional[bool] + paths=None, # type: Optional[List[str]] + skip_regex=None, # type: Optional[str] + isolated=False, # type: bool + wheel_cache=None, # type: Optional[WheelCache] + exclude_editable=False, # type: bool + skip=() # type: Container[str] +): + # type: (...) -> Iterator[str] + find_links = find_links or [] + skip_match = None + + if skip_regex: + skip_match = re.compile(skip_regex).search + + for link in find_links: + yield '-f %s' % 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 + if exclude_editable and req.editable: + continue + installations[req.canonical_name] = req + + if requirement: + # the options that don't get turned into an InstallRequirement + # 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] + # 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]] + 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 + (skip_match and skip_match(line)) or + line.startswith(( + '-r', '--requirement', + '-Z', '--always-unzip', + '-f', '--find-links', + '-i', '--index-url', + '--pre', + '--trusted-host', + '--process-dependency-links', + '--extra-index-url'))): + 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'): + line = line[2:].strip() + else: + line = line[len('--editable'):].strip().lstrip('=') + line_req = install_req_from_editable( + line, + isolated=isolated, + wheel_cache=wheel_cache, + ) + else: + line_req = install_req_from_line( + COMMENT_RE.sub('', line).strip(), + isolated=isolated, + wheel_cache=wheel_cache, + ) + + if not line_req.name: + logger.info( + "Skipping line in requirement file [%s] because " + "it's not clear what it would install: %s", + 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) + if line_req_canonical_name not in installations: + # either it's not installed, or it is installed + # but has been processed already + if not req_files[line_req.name]: + logger.warning( + "Requirement file [%s] contains %s, but " + "package %r is not installed", + req_file_path, + 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() + del installations[line_req_canonical_name] + req_files[line_req.name].append(req_file_path) + + # Warn about requirements that were included multiple times (in a + # single requirements file or in different requirements files). + for name, files in six.iteritems(req_files): + if len(files) > 1: + 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()): + if installation.canonical_name not in skip: + yield str(installation).rstrip() + + +def get_requirement_info(dist): + # type: (Distribution) -> RequirementInfo + """ + Compute and return values (req, editable, comments) for use in + FrozenRequirement.from_dist(). + """ + if not dist_is_editable(dist): + return (None, False, []) + + location = os.path.normcase(os.path.abspath(dist.location)) + + from pip._internal.vcs import vcs, RemoteNotFoundError + vcs_backend = vcs.get_backend_for_dir(location) + + if vcs_backend is None: + req = dist.as_requirement() + logger.debug( + 'No VCS found for editable requirement "%s" in: %r', req, + location, + ) + comments = [ + '# Editable install with no version control ({})'.format(req) + ] + return (location, True, comments) + + try: + req = vcs_backend.get_src_requirement(location, dist.project_name) + except RemoteNotFoundError: + req = dist.as_requirement() + comments = [ + '# Editable {} install with no remote ({})'.format( + type(vcs_backend).__name__, req, + ) + ] + return (location, True, comments) + + except BadCommand: + logger.warning( + 'cannot determine version of editable source in %s ' + '(%s command not found in path)', + location, + vcs_backend.name, + ) + return (None, True, []) + + except InstallationError as exc: + logger.warning( + "Error when trying to get requirement for VCS system %s, " + "falling back to uneditable format", exc + ) + else: + if req is not None: + return (req, True, []) + + logger.warning( + 'Could not determine repository location of %s', location + ) + comments = ['## !! Could not determine repository location'] + + return (None, False, comments) + + +class FrozenRequirement(object): + def __init__(self, name, req, editable, comments=()): + # type: (str, Union[str, Requirement], bool, Iterable[str]) -> None + self.name = name + self.canonical_name = canonicalize_name(name) + self.req = req + self.editable = editable + self.comments = comments + + @classmethod + def from_dist(cls, dist): + # type: (Distribution) -> FrozenRequirement + req, editable, comments = get_requirement_info(dist) + if req is None: + req = dist.as_requirement() + + return cls(dist.project_name, req, editable, comments=comments) + + def __str__(self): + req = self.req + if self.editable: + req = '-e %s' % req + return '\n'.join(list(self.comments) + [str(req)]) + '\n' diff --git a/venv/lib/python3.8/site-packages/pip/_internal/operations/install/__init__.py b/venv/lib/python3.8/site-packages/pip/_internal/operations/install/__init__.py new file mode 100644 index 0000000..24d6a5d --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/operations/install/__init__.py @@ -0,0 +1,2 @@ +"""For modules related to installing packages. +""" diff --git a/venv/lib/python3.8/site-packages/pip/_internal/operations/install/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/operations/install/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..50867c4d9ff1446d3aaa1be477379d32af4f633d GIT binary patch literal 224 zcmYjLu?oU46imA)h5kbp2f;Rjq7EWXZn}tzO9;)Q2Gb-aDWZSmFLm`3+?-6*!GpWU zagXV2*n(spIQAL~ru*eMd=;cG@Sa#YeRfvh!Lh}Ra^&NT#f*;5N&;)UniHC5h|1i htC%F(fMs52<;d?5p&=EX($ZYJ{^Hwc8CyRC(HkdeKGFaH literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/operations/install/__pycache__/editable_legacy.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/operations/install/__pycache__/editable_legacy.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..a2037313b46a60f5872b02c6d7a2631db937bac7 GIT binary patch literal 1302 zcmZux&5zSY6d!-YahzncEGr?PYOSgqB6X7sv^`XSSRsnKr0oJ~aSyXz&#W_I>@hRr zU9vJKxFY@qIQGBkd9FS6Pbde}H%|5gX~&vh=6(6S`Mu{n9S$P|>-+C+q9*&9hea>xIf(Y;9{6>6 zRP>X6F-Qi*Fd4Q!Azv#-$q0O$_v`f12PfGeJrcb^$z|d`M&thRogJE|*&?Qd>2#md zn3YPWoTr+JGOnb^s8Zj?Y(gjTo}#+0CevVi1S%ebuwRv)&Nw_&R%02;jqZkx^r*FoBC zg2ri3({0?wYkcCq?Y@e%_Zq$X+CfeDZUcP$CTe=bdkg-*qg&`Vw2S^YcOpJ8*g5|5 z;gYd9jjJ?!p5~UrGd>GJfVxLQ=@{-_+cFiLC^##%rRP%A`8YZi# vLyT=hF_xEXu)TWQm2+^-hJ-)Dq}QC@c0f{_0KOZ#1E+ml-`R8rUgZ4`mIZ!x literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/operations/install/__pycache__/legacy.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/operations/install/__pycache__/legacy.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..7cd5d87ef2984daa4daab122580b082a4ccf70a1 GIT binary patch literal 3048 zcmZuzOK&5`5$+xihr{i(o& zuON8ddhn|Ew>ComP=lLK0S50v<9`7{&=3(!j0g|0{u)CAzJ;g|n?n<;IWsE8*3i=Z zVpNLlp{@H?RE{gditd-9YFr!Ebl;BZabwuf{c_ZdTf>&_SE6>@8FnzD9rh>CTaC8j z?ywv8hP`-uxUFSs(N4TO+|~VhbSK^$?twg>@6)>rJUk!`(tL)7_lWTb^;^>i4{6}} zmrj^);YE=r!ZdL*mim^M zW{motphS(rgwRB|Q5vWbP56XSmxK&PcVq9Ix>~hJ(}=q(3tW!{9On1gBuOZ9FG4YP zc^2wH3|4soh3WdoG|t`+VJ(reOJH<<{@E`+bKm>fkKg;yJ^AGL_=Dr0_6yQ{7;+)) zk22+#7fJgOeLSIwuT)r%{4tGHuk*pu`xBT1l`+`tmz9UBX9vCwXe#Xd8;p=Zxp9Sa zbcW{;>HsZ_9W*n5i#J?j#l^XOR+yEANeaY#j<5eZtBB&6H816rGm8`##;huA&{WQi z9Ou<9P+rW-xtUwQtK=nOJ+IDcqDo5h8gS|hSYcKdjVpBh8b-irUU%VJ&(&;;*v}1& zeuaL3eu+-duW$79n(e&0!2Iu`Gv6X*=--h2Bf$6(B9$DuUD3;{SNOU!Yvhgj_5#g! z7HHPIP3!N`2tY_`&+J(%Z@!Oy^ZKl%W`#wAMf5dVF^97R=<` z`8_>*AJ*zYB(@gD0_*iMm~$2gBk@wcbp<>vSIV~t$jr9E<89KtGOqWu&o7f6#HR~( z^>)Czn>(tk>Te&*Mi8Z^UgV}4SzI>P@Le-3fM&{67MSOd2Gh<;;Bd(wh$o_7VNF03 zYXOnXCEp!|5ly_9N>injv>=^E;S*UIQ;$G8K=Md)oWgv4!l?_5xjYn9Hj;EX^3!A# z2C|%8`e~ejw(0#7NTo0dobM*GGfJ8Bbk;Xy!H)@$3o_k3(RMq^4(C+o^klt#*>nR#L?iy`+; zIWs^(AG3S#`7>r+^+8{KcqHQNC=0X0Ns@W~IVFb|V@jjLa1uQJ;pO)))Z7u&4M7>? z_EDNqrt23!TJ7~wq>CGrE?I+p%xFS%q52dS;1&>Mbg^kn4_5Mnx1-eeBL2?cru4Kt zph0jLCZlxv?CH!QA^8!QgMqt@EjUt{723tBg_AbF-WfKbvkmM zzA+m(KLK%t6c7Y-2+tQ_Grg(7S&BL$bt0-~W9K|cFBC)TR$kJOZFCQ&=9_N}-V8t8 zhsc={(C+axkyY5`$n$jxm8Bp}D8xranNR3+YqLRz3SC^~fW#LPSNg9=Gg6hhv`(Kw zKw-25J!dwAiXAATAR^7PG)$NZpsZ_W-R#oUc(OyD!XZWpE2&uvHY)anG*w11Q?bgY zlQ1GKO@1ryta0V?bi#anGA$z|E&2q^;nISmE1*mk2|b+zvc2-a18rT9(OI16V%2!!i>r!Ve z#7>{I5|3nURfMz)>=h*oaY?8wZ$K<-kPHyiQL1ZEIiVNs(qns5x^ywrm5l4Ku$Mp+ za};@5=`5|*SBCQ60YPmG*It;0rUlEW;TATq3GLf2aQeOYo{ zlKQSIODg)1l^S}oK>!jH5k`EVs4iOaKGdMWrUvN=K3HFZ;LfoO`u=TFYvmf2ySGWi zA@`Rs_}*>PH!e>a)XR*xcdO{+bakm)CdS>{gf<{i=_dDX6}g0)SiscfNLpe!P*-JE zRivia-|;n0356Y7p|P$c4!*4!06l;Po2aj#Ox?6(8S?+(GWTrPRf*)f?15TD1!)N= ljVetvs_eI6tw}`RQD+l(fS5Y8HGtEN*D!HcaSD~fe*xM}kIMi6 literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/operations/install/__pycache__/wheel.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/operations/install/__pycache__/wheel.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..60e606a292dff8c695147fa641ea8cbfe4d9fbd3 GIT binary patch literal 14582 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 IlgJ_e-&l4p(EtDd literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/operations/install/editable_legacy.py b/venv/lib/python3.8/site-packages/pip/_internal/operations/install/editable_legacy.py new file mode 100644 index 0000000..a668a61 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/operations/install/editable_legacy.py @@ -0,0 +1,52 @@ +"""Legacy editable installation process, i.e. `setup.py develop`. +""" +import logging + +from pip._internal.utils.logging import indent_log +from pip._internal.utils.setuptools_build import make_setuptools_develop_args +from pip._internal.utils.subprocess import call_subprocess +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import List, Optional, Sequence + + from pip._internal.build_env import BuildEnvironment + + +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 + """Install a package in editable mode. Most arguments are pass-through + to setuptools. + """ + 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, + use_user_site=use_user_site, + ) + + with indent_log(): + with build_env: + call_subprocess( + args, + cwd=unpacked_source_directory, + ) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/operations/install/legacy.py b/venv/lib/python3.8/site-packages/pip/_internal/operations/install/legacy.py new file mode 100644 index 0000000..2d4adc4 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/operations/install/legacy.py @@ -0,0 +1,129 @@ +"""Legacy installation process, i.e. `setup.py install`. +""" + +import logging +import os +from distutils.util import change_root + +from pip._internal.utils.deprecation import deprecated +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 +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import List, Optional, Sequence + + from pip._internal.models.scheme import Scheme + from pip._internal.req.req_install import InstallRequirement + + +logger = logging.getLogger(__name__) + + +def install( + install_req, # type: InstallRequirement + 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 +): + # type: (...) -> None + # 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) + \ + install_req.options.get('global_options', []) + install_options = list(install_options) + \ + install_req.options.get('install_options', []) + + header_dir = scheme.headers + + with TempDirectory(kind="record") as temp_dir: + record_filename = os.path.join(temp_dir.path, 'install-record.txt') + install_args = make_setuptools_install_args( + install_req.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=install_req.isolated, + pycompile=pycompile, + ) + + runner = runner_with_spinner_message( + "Running setup.py install for {}".format(install_req.name) + ) + with indent_log(), install_req.build_env: + runner( + cmd=install_args, + cwd=install_req.unpacked_source_directory, + ) + + if not os.path.exists(record_filename): + logger.debug('Record file %s not found', record_filename) + return + install_req.install_succeeded = True + + # 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: + deprecated( + reason=( + "{} did not indicate that it installed an " + ".egg-info directory. Only setup.py projects " + "generating .egg-info directories are supported." + ).format(install_req), + replacement=( + "for maintainers: updating the setup.py of {0}. " + "For users: contact the maintainers of {0} to let " + "them know to update their setup.py.".format( + install_req.name + ) + ), + gone_in="20.2", + issue=6998, + ) + # FIXME: put the record somewhere + return + 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') diff --git a/venv/lib/python3.8/site-packages/pip/_internal/operations/install/wheel.py b/venv/lib/python3.8/site-packages/pip/_internal/operations/install/wheel.py new file mode 100644 index 0000000..aac975c --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/operations/install/wheel.py @@ -0,0 +1,615 @@ +"""Support for installing and building the "wheel" binary package format. +""" + +# The following comment should be removed at some point in the future. +# mypy: strict-optional=False + +from __future__ import absolute_import + +import collections +import compileall +import csv +import logging +import os.path +import re +import shutil +import stat +import sys +import warnings +from base64 import urlsafe_b64encode +from zipfile import ZipFile + +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.six import StringIO + +from pip._internal.exceptions import InstallationError +from pip._internal.locations import get_major_minor_version +from pip._internal.utils.misc import captured_stdout, ensure_dir, hash_file +from pip._internal.utils.temp_dir import TempDirectory +from pip._internal.utils.typing import MYPY_CHECK_RUNNING +from pip._internal.utils.unpacking import unpack_file +from pip._internal.utils.wheel import parse_wheel + +if MYPY_CHECK_RUNNING: + from email.message import Message + from typing import ( + Dict, List, Optional, Sequence, Tuple, IO, Text, Any, + Iterable, Callable, Set, + ) + + from pip._internal.models.scheme import Scheme + + InstalledCSVRow = Tuple[str, ...] + + +logger = logging.getLogger(__name__) + + +def normpath(src, p): + # type: (str, str) -> str + return os.path.relpath(src, p).replace(os.path.sep, '/') + + +def rehash(path, blocksize=1 << 20): + # type: (str, int) -> 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('=') + # unicode/str python2 issues + return (digest, str(length)) # type: ignore + + +def open_for_csv(name, mode): + # type: (str, Text) -> IO[Any] + if sys.version_info[0] < 3: + nl = {} # type: Dict[str, Any] + bin = 'b' + else: + nl = {'newline': ''} # type: Dict[str, Any] + bin = '' + return open(name, mode + bin, **nl) + + +def fix_script(path): + # type: (str) -> Optional[bool] + """Replace #!python with #!/path/to/python + Return True if file was changed. + """ + # XXX RECORD hashes will need to be updated + if os.path.isfile(path): + with open(path, 'rb') as script: + firstline = script.readline() + if not firstline.startswith(b'#!python'): + return False + exename = sys.executable.encode(sys.getfilesystemencoding()) + firstline = b'#!' + exename + os.linesep.encode("ascii") + rest = script.read() + with open(path, 'wb') as script: + script.write(firstline) + script.write(rest) + return True + return None + + +def wheel_root_is_purelib(metadata): + # type: (Message) -> bool + return metadata.get("Root-Is-Purelib", "").lower() == "true" + + +def get_entrypoints(filename): + # type: (str) -> Tuple[Dict[str, str], Dict[str, str]] + if not os.path.exists(filename): + return {}, {} + + # This is done because you can pass a string to entry_points wrappers which + # means that they may or may not be valid INI files. The attempt here is to + # strip leading and trailing whitespace in order to make them valid INI + # files. + with open(filename) as fp: + data = StringIO() + for line in fp: + data.write(line.strip()) + data.write("\n") + data.seek(0) + + # get the entry points and then the script names + entry_points = pkg_resources.EntryPoint.parse_map(data) + console = entry_points.get('console_scripts', {}) + gui = entry_points.get('gui_scripts', {}) + + 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] + """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. + """ + if not scripts: + return None + + # Group scripts by the path they were installed in + grouped_by_dir = collections.defaultdict(set) # type: Dict[str, Set[str]] + for destfile in scripts: + parent_dir = os.path.dirname(destfile) + script_name = os.path.basename(destfile) + grouped_by_dir[parent_dir].add(script_name) + + # 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) + ] + # 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]] + 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] + if len(sorted_scripts) == 1: + start_text = "script {} is".format(sorted_scripts[0]) + else: + start_text = "scripts {} are".format( + ", ".join(sorted_scripts[:-1]) + " and " + sorted_scripts[-1] + ) + + msg_lines.append( + "The {} installed in '{}' which is not on PATH." + .format(start_text, parent_dir) + ) + + last_line_fmt = ( + "Consider adding {} to PATH or, if you prefer " + "to suppress this warning, use --no-warn-script-location." + ) + if len(msg_lines) == 1: + msg_lines.append(last_line_fmt.format("this directory")) + else: + msg_lines.append(last_line_fmt.format("these directories")) + + # Add a note if any directory starts with ~ + warn_for_tilde = any( + i[0] == "~" for i in os.environ.get("PATH", "").split(os.pathsep) if i + ) + if warn_for_tilde: + tilde_warning_msg = ( + "NOTE: The current PATH contains path(s) starting with `~`, " + "which may not be expanded by all applications." + ) + msg_lines.append(tilde_warning_msg) + + # Returns the formatted multiline message + return "\n".join(msg_lines) + + +def sorted_outrows(outrows): + # type: (Iterable[InstalledCSVRow]) -> List[InstalledCSVRow] + """Return the given rows of a RECORD file in sorted order. + + Each row is a 3-tuple (path, hash, size) and corresponds to a record of + a RECORD file (see PEP 376 and PEP 427 for details). For the rows + passed to this function, the size can be an integer as an int or string, + or the empty string. + """ + # Normally, there should only be one row per path, in which case the + # second and third elements don't come into play when sorting. + # However, in cases in the wild where a path might happen to occur twice, + # we don't want the sort operation to trigger an error (but still want + # determinism). Since the third element can be an int or string, we + # coerce each element to a string to avoid a TypeError in this case. + # For additional background, see-- + # https://github.com/pypa/pip/issues/5868 + return sorted(outrows, key=lambda row: tuple(str(x) for x in row)) + + +def get_csv_rows_for_installed( + old_csv_rows, # type: Iterable[List[str]] + installed, # type: Dict[str, str] + changed, # type: Set[str] + generated, # type: List[str] + lib_dir, # type: str +): + # type: (...) -> List[InstalledCSVRow] + """ + :param installed: A map from archive RECORD path to installation RECORD + path. + """ + installed_rows = [] # type: List[InstalledCSVRow] + for row in old_csv_rows: + if len(row) > 3: + logger.warning( + 'RECORD line has more than three elements: {}'.format(row) + ) + # Make a copy because we are mutating the row. + row = list(row) + old_path = row[0] + new_path = installed.pop(old_path, old_path) + row[0] = new_path + if new_path in changed: + digest, length = rehash(new_path) + row[1] = digest + row[2] = length + installed_rows.append(tuple(row)) + for f in generated: + digest, length = rehash(f) + installed_rows.append((normpath(f, lib_dir), digest, str(length))) + for f in installed: + installed_rows.append((installed[f], '', '')) + return installed_rows + + +class MissingCallableSuffix(Exception): + pass + + +def _raise_for_invalid_entrypoint(specification): + # type: (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] + _raise_for_invalid_entrypoint(specification) + return super(PipScriptMaker, self).make(specification, options) + + +def install_unpacked_wheel( + name, # type: str + wheeldir, # type: str + wheel_zip, # type: ZipFile + scheme, # type: Scheme + req_description, # type: str + pycompile=True, # type: bool + warn_script_location=True # type: bool +): + # type: (...) -> None + """Install a wheel. + + :param name: Name of the project to install + :param wheeldir: Base directory of the unpacked wheel + :param wheel_zip: open ZipFile for wheel being installed + :param scheme: Distutils scheme dictating the install directories + :param req_description: String used in place of the requirement, for + logging + :param pycompile: Whether to byte-compile installed Python files + :param warn_script_location: Whether to check that scripts are installed + into a directory on PATH + :raises UnsupportedWheel: + * when the directory holds an unpacked wheel with incompatible + Wheel-Version + * when the .dist-info dir does not match the wheel + """ + # TODO: Investigate and break this up. + # TODO: Look into moving this into a dedicated class for representing an + # installation. + + source = wheeldir.rstrip(os.path.sep) + os.path.sep + + info_dir, metadata = parse_wheel(wheel_zip, name) + + if wheel_root_is_purelib(metadata): + lib_dir = scheme.purelib + else: + lib_dir = scheme.platlib + + subdirs = os.listdir(source) + data_dirs = [s for s in subdirs if s.endswith('.data')] + + # Record details of the files moved + # 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[str, str] + changed = set() + generated = [] # type: List[str] + + # Compile all of the pyc files that we're going to be installing + if pycompile: + with captured_stdout() as stdout: + with warnings.catch_warnings(): + warnings.filterwarnings('ignore') + compileall.compile_dir(source, force=True, quiet=True) + logger.debug(stdout.getvalue()) + + def record_installed(srcfile, destfile, modified=False): + # type: (str, str, bool) -> None + """Map archive RECORD paths to installation RECORD paths.""" + oldpath = normpath(srcfile, wheeldir) + newpath = normpath(destfile, lib_dir) + installed[oldpath] = newpath + if modified: + changed.add(destfile) + + def clobber( + source, # type: str + dest, # type: str + is_base, # type: bool + fixer=None, # type: Optional[Callable[[str], Any]] + filter=None # type: Optional[Callable[[str], bool]] + ): + # type: (...) -> None + ensure_dir(dest) # common for the 'include' path + + for dir, subdirs, files in os.walk(source): + basedir = dir[len(source):].lstrip(os.path.sep) + destdir = os.path.join(dest, basedir) + if is_base and basedir == '': + subdirs[:] = [s for s in subdirs if not s.endswith('.data')] + for f in files: + # Skip unwanted files + if filter and filter(f): + continue + srcfile = os.path.join(dir, f) + destfile = os.path.join(dest, basedir, f) + # directory creation is lazy and after the file filtering above + # to ensure we don't install empty dirs; empty dirs can't be + # uninstalled. + ensure_dir(destdir) + + # copyfile (called below) truncates the destination if it + # exists and then writes the new contents. This is fine in most + # cases, but can cause a segfault if pip has loaded a shared + # object (e.g. from pyopenssl through its vendored urllib3) + # Since the shared object is mmap'd an attempt to call a + # symbol in it will then cause a segfault. Unlinking the file + # allows writing of new contents while allowing the process to + # continue to use the old copy. + if os.path.exists(destfile): + os.unlink(destfile) + + # We use copyfile (not move, copy, or copy2) to be extra sure + # that we are not moving directories over (copyfile fails for + # directories) as well as to ensure that we are not copying + # over any metadata because we want more control over what + # metadata we actually copy over. + shutil.copyfile(srcfile, destfile) + + # Copy over the metadata for the file, currently this only + # includes the atime and mtime. + st = os.stat(srcfile) + if hasattr(os, "utime"): + os.utime(destfile, (st.st_atime, st.st_mtime)) + + # If our file is executable, then make our destination file + # executable. + if os.access(srcfile, os.X_OK): + st = os.stat(srcfile) + permissions = ( + st.st_mode | stat.S_IXUSR | stat.S_IXGRP | stat.S_IXOTH + ) + os.chmod(destfile, permissions) + + changed = False + if fixer: + changed = fixer(destfile) + record_installed(srcfile, destfile, changed) + + clobber(source, lib_dir, True) + + dest_info_dir = os.path.join(lib_dir, info_dir) + + # Get the defined entry points + ep_file = os.path.join(dest_info_dir, 'entry_points.txt') + console, gui = get_entrypoints(ep_file) + + def is_entrypoint_wrapper(name): + # type: (str) -> bool + # EP, EP.exe and EP-script.py are scripts generated for + # entry point EP by setuptools + if name.lower().endswith('.exe'): + matchname = name[:-4] + 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) + + for datadir in data_dirs: + fixer = None + filter = None + for subdir in os.listdir(os.path.join(wheeldir, datadir)): + fixer = None + if subdir == 'scripts': + fixer = fix_script + filter = is_entrypoint_wrapper + source = os.path.join(wheeldir, datadir, subdir) + dest = getattr(scheme, subdir) + clobber(source, dest, False, fixer=fixer, filter=filter) + + maker = PipScriptMaker(None, scheme.scripts) + + # Ensure old scripts are overwritten. + # See https://github.com/pypa/pip/issues/1800 + maker.clobber = True + + # 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 = {''} + + # This is required because otherwise distlib creates scripts that are not + # executable. + # See https://bitbucket.org/pypa/distlib/issue/32/ + maker.set_mode = True + + scripts_to_generate = [] + + # Special case pip and setuptools to generate versioned wrappers + # + # The issue is that some projects (specifically, pip and setuptools) use + # code in setup.py to create "versioned" entry points - pip2.7 on Python + # 2.7, pip3.3 on Python 3.3, etc. But these entry points are baked into + # the wheel metadata at build time, and so if the wheel is installed with + # a *different* version of Python the entry points will be wrong. The + # correct fix for this is to enhance the metadata to be able to describe + # such versioned entry points, but that won't happen till Metadata 2.0 is + # available. + # In the meantime, projects using versioned entry points will either have + # incorrect versioned entry points, or they will not be able to distribute + # "universal" wheels (i.e., they will need a wheel per Python version). + # + # Because setuptools and pip are bundled with _ensurepip and virtualenv, + # we need to use universal wheels. So, as a stopgap until Metadata 2.0, we + # override the versioned entry points in the wheel and generate the + # correct ones. This code is purely a short-term measure until Metadata 2.0 + # is available. + # + # To add the level of hack in this section of code, in order to support + # ensurepip this code will look for an ``ENSUREPIP_OPTIONS`` environment + # variable which will control which version scripts get installed. + # + # ENSUREPIP_OPTIONS=altinstall + # - Only pipX.Y and easy_install-X.Y will be generated and installed + # ENSUREPIP_OPTIONS=install + # - pipX.Y, pipX, easy_install-X.Y will be generated and installed. Note + # that this option is technically if ENSUREPIP_OPTIONS is set and is + # not altinstall + # DEFAULT + # - The default behavior is to install pip, pipX, pipX.Y, easy_install + # and easy_install-X.Y. + pip_script = console.pop('pip', None) + if pip_script: + if "ENSUREPIP_OPTIONS" not in os.environ: + scripts_to_generate.append('pip = ' + pip_script) + + if os.environ.get("ENSUREPIP_OPTIONS", "") != "altinstall": + scripts_to_generate.append( + 'pip%s = %s' % (sys.version_info[0], pip_script) + ) + + scripts_to_generate.append( + 'pip%s = %s' % (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)] + for k in pip_ep: + del console[k] + 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-%s = %s' % ( + 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) + ] + for k in easy_install_ep: + del console[k] + + # Generate the console and GUI entry points specified in the wheel + scripts_to_generate.extend( + '%s = %s' % kv for kv in console.items() + ) + + gui_scripts_to_generate = [ + '%s = %s' % kv for kv in gui.items() + ] + + generated_console_scripts = [] # type: List[str] + + try: + 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}) + ) + except MissingCallableSuffix as e: + entry = e.args[0] + raise InstallationError( + "Invalid script entry point: {} for req: {} - A callable " + "suffix is required. Cf https://packaging.python.org/" + "specifications/entry-points/#use-for-scripts for more " + "information.".format(entry, req_description) + ) + + if warn_script_location: + msg = message_about_scripts_not_on_PATH(generated_console_scripts) + if msg is not None: + logger.warning(msg) + + # Record pip as the installer + installer = os.path.join(dest_info_dir, 'INSTALLER') + temp_installer = os.path.join(dest_info_dir, 'INSTALLER.pip') + with open(temp_installer, 'wb') as installer_file: + installer_file.write(b'pip\n') + shutil.move(temp_installer, installer) + generated.append(installer) + + # Record details of all files installed + record = os.path.join(dest_info_dir, 'RECORD') + temp_record = os.path.join(dest_info_dir, 'RECORD.pip') + with open_for_csv(record, 'r') as record_in: + with open_for_csv(temp_record, 'w+') as record_out: + reader = csv.reader(record_in) + outrows = get_csv_rows_for_installed( + reader, installed=installed, changed=changed, + generated=generated, lib_dir=lib_dir, + ) + writer = csv.writer(record_out) + # Sort to simplify testing. + for row in sorted_outrows(outrows): + writer.writerow(row) + shutil.move(temp_record, record) + + +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 + _temp_dir_for_testing=None, # type: Optional[str] +): + # type: (...) -> None + with TempDirectory( + path=_temp_dir_for_testing, kind="unpacked-wheel" + ) as unpacked_dir, ZipFile(wheel_path, allowZip64=True) as z: + unpack_file(wheel_path, unpacked_dir.path) + install_unpacked_wheel( + name=name, + wheeldir=unpacked_dir.path, + wheel_zip=z, + scheme=scheme, + req_description=req_description, + pycompile=pycompile, + warn_script_location=warn_script_location, + ) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/operations/prepare.py b/venv/lib/python3.8/site-packages/pip/_internal/operations/prepare.py new file mode 100644 index 0000000..0b61f20 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/operations/prepare.py @@ -0,0 +1,591 @@ +"""Prepares a distribution for installation +""" + +# The following comment should be removed at some point in the future. +# mypy: strict-optional=False + +import logging +import mimetypes +import os +import shutil +import sys + +from pip._vendor import requests +from pip._vendor.six import PY2 + +from pip._internal.distributions import ( + make_distribution_for_install_requirement, +) +from pip._internal.distributions.installed import InstalledDistribution +from pip._internal.exceptions import ( + DirectoryUrlHashUnsupported, + HashMismatch, + HashUnpinned, + InstallationError, + PreviousBuildDirError, + VcsHashUnsupported, +) +from pip._internal.utils.filesystem import copy2_fixed +from pip._internal.utils.hashes import MissingHashes +from pip._internal.utils.logging import indent_log +from pip._internal.utils.marker_files import write_delete_marker_file +from pip._internal.utils.misc import ( + ask_path_exists, + backup_dir, + display_path, + hide_url, + path_to_display, + rmtree, +) +from pip._internal.utils.temp_dir import TempDirectory +from pip._internal.utils.typing import MYPY_CHECK_RUNNING +from pip._internal.utils.unpacking import unpack_file +from pip._internal.vcs import vcs + +if MYPY_CHECK_RUNNING: + from typing import ( + Callable, List, Optional, Tuple, + ) + + from mypy_extensions import TypedDict + + from pip._internal.distributions import AbstractDistribution + from pip._internal.index.package_finder import PackageFinder + from pip._internal.models.link import Link + from pip._internal.network.download import Downloader + from pip._internal.req.req_install import InstallRequirement + from pip._internal.req.req_tracker import RequirementTracker + from pip._internal.utils.hashes import Hashes + + if PY2: + CopytreeKwargs = TypedDict( + 'CopytreeKwargs', + { + 'ignore': Callable[[str, List[str]], List[str]], + 'symlinks': bool, + }, + total=False, + ) + else: + CopytreeKwargs = TypedDict( + 'CopytreeKwargs', + { + 'copy_function': Callable[[str, str], None], + 'ignore': Callable[[str, List[str]], List[str]], + 'ignore_dangling_symlinks': bool, + 'symlinks': bool, + }, + total=False, + ) + +logger = logging.getLogger(__name__) + + +def _get_prepared_distribution( + req, # type: InstallRequirement + req_tracker, # type: RequirementTracker + finder, # type: PackageFinder + build_isolation # type: bool +): + # type: (...) -> AbstractDistribution + """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 + + +def unpack_vcs_link(link, location): + # type: (Link, str) -> 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)) + + +def _copy_file(filename, location, link): + # type: (str, str, Link) -> None + copy = True + download_location = os.path.join(location, link.filename) + if os.path.exists(download_location): + response = ask_path_exists( + 'The file {} exists. (i)gnore, (w)ipe, (b)ackup, (a)abort'.format( + display_path(download_location) + ), + ('i', 'w', 'b', 'a'), + ) + if response == 'i': + copy = False + elif response == 'w': + logger.warning('Deleting %s', display_path(download_location)) + os.remove(download_location) + elif response == 'b': + dest_file = backup_dir(download_location) + logger.warning( + 'Backing up %s to %s', + display_path(download_location), + display_path(dest_file), + ) + shutil.move(download_location, dest_file) + elif response == 'a': + sys.exit(-1) + if copy: + shutil.copy(filename, download_location) + logger.info('Saved %s', display_path(download_location)) + + +def unpack_http_url( + link, # type: Link + location, # type: str + downloader, # type: Downloader + download_dir=None, # type: Optional[str] + hashes=None, # type: Optional[Hashes] +): + # type: (...) -> str + 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 + ) + + if already_downloaded_path: + from_path = already_downloaded_path + content_type = mimetypes.guess_type(from_path)[0] + else: + # let's download to a tmp dir + from_path, content_type = _download_http_url( + link, downloader, temp_dir.path, hashes + ) + + # unpack the archive to the build dir location. even when only + # downloading archives, they have to be unpacked to parse dependencies + unpack_file(from_path, location, content_type) + + return from_path + + +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), + path_to_display(src), + path_to_display(dest), + ) + + +def _copy_source_tree(source, target): + # type: (str, str) -> None + def ignore(d, names): + # type: (str, List[str]) -> List[str] + # 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 + return ['.tox', '.nox'] if d == source else [] + + kwargs = dict(ignore=ignore, symlinks=True) # type: CopytreeKwargs + + if not PY2: + # Python 2 does not support copy_function, so we only ignore + # errors on special file copy in Python 3. + kwargs['copy_function'] = _copy2_ignoring_special_files + + shutil.copytree(source, target, **kwargs) + + +def unpack_file_url( + link, # type: Link + location, # type: str + download_dir=None, # type: Optional[str] + hashes=None # type: Optional[Hashes] +): + # type: (...) -> Optional[str] + """Unpack link into location. + """ + link_path = link.file_path + # If it's a url to a local directory + if link.is_existing_dir(): + if os.path.isdir(location): + rmtree(location) + _copy_source_tree(link_path, location) + return None + + # 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 + ) + + if already_downloaded_path: + from_path = already_downloaded_path + else: + from_path = link_path + + # If --require-hashes is off, `hashes` is either empty, the + # link's embedded hash, or MissingHashes; it is required to + # match. If --require-hashes is on, we are satisfied by any + # hash in `hashes` matching: a URL-based or an option-based + # one; no internet-sourced hash will be in `hashes`. + if hashes: + hashes.check_against_path(from_path) + + content_type = mimetypes.guess_type(from_path)[0] + + # unpack the archive to the build dir location. even when only downloading + # archives, they have to be unpacked to parse dependencies + unpack_file(from_path, location, content_type) + + return from_path + + +def unpack_url( + link, # type: Link + location, # type: str + downloader, # type: Downloader + download_dir=None, # type: Optional[str] + hashes=None, # type: Optional[Hashes] +): + # type: (...) -> Optional[str] + """Unpack link into location, downloading if required. + + :param hashes: A Hashes object, one of whose embedded hashes must match, + or HashMismatch will be raised. If the Hashes is empty, no matches are + required, and unhashable types of requirements (like VCS ones, which + would ordinarily raise HashUnsupported) are allowed. + """ + # non-editable vcs urls + if link.is_vcs: + unpack_vcs_link(link, location) + return None + + # file urls + elif link.is_file: + return unpack_file_url(link, location, download_dir, hashes=hashes) + + # http urls + else: + return unpack_http_url( + link, + location, + downloader, + download_dir, + hashes=hashes, + ) + + +def _download_http_url( + link, # type: Link + downloader, # type: Downloader + temp_dir, # type: str + hashes, # type: Optional[Hashes] +): + # type: (...) -> Tuple[str, str] + """Download link url into temp_dir using provided session""" + download = downloader(link) + + file_path = os.path.join(temp_dir, download.filename) + with open(file_path, 'wb') as content_file: + for chunk in download.chunks: + content_file.write(chunk) + + if hashes: + hashes.check_against_path(file_path) + + return file_path, download.response.headers.get('content-type', '') + + +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 + """ + download_path = os.path.join(download_dir, link.filename) + + if not os.path.exists(download_path): + return None + + # If already downloaded, does its hash match? + 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 + ) + os.unlink(download_path) + return None + return download_path + + +class RequirementPreparer(object): + """Prepares a Requirement + """ + + def __init__( + self, + build_dir, # type: str + download_dir, # type: Optional[str] + src_dir, # type: str + wheel_download_dir, # type: Optional[str] + build_isolation, # type: bool + req_tracker, # type: RequirementTracker + downloader, # type: Downloader + finder, # type: PackageFinder + require_hashes, # type: bool + use_user_site, # type: bool + ): + # type: (...) -> None + super(RequirementPreparer, self).__init__() + + self.src_dir = src_dir + self.build_dir = build_dir + self.req_tracker = req_tracker + self.downloader = downloader + self.finder = finder + + # Where still-packed archives should be written to. If None, they are + # not saved, and are deleted immediately after unpacking. + self.download_dir = download_dir + + # Where still-packed .whl files should be written to. If None, they are + # written to the download_dir parameter. Separate to download_dir to + # permit only keeping wheel archives for pip wheel. + self.wheel_download_dir = wheel_download_dir + + # NOTE + # download_dir and wheel_download_dir overlap semantically and may + # be combined if we're willing to have non-wheel archives present in + # the wheelhouse output by 'pip wheel'. + + # Is build isolation allowed? + self.build_isolation = build_isolation + + # Should hash-checking be required? + self.require_hashes = require_hashes + + # Should install in user site-packages? + self.use_user_site = use_user_site + + @property + def _download_should_save(self): + # type: () -> bool + if not self.download_dir: + return False + + if os.path.exists(self.download_dir): + return True + + logger.critical('Could not find download directory') + raise InstallationError( + "Could not find or access download directory '{}'" + .format(self.download_dir)) + + def prepare_linked_requirement( + self, + req, # type: InstallRequirement + ): + # type: (...) -> AbstractDistribution + """Prepare a requirement that would be obtained from req.link + """ + assert req.link + link = req.link + + # TODO: Breakup into smaller functions + if link.scheme == 'file': + path = link.file_path + logger.info('Processing %s', display_path(path)) + else: + logger.info('Collecting %s', req.req or req) + + with indent_log(): + # @@ if filesystem packages are not marked + # editable in a req, a non deterministic error + # occurs when the script attempts to unpack the + # build directory + # Since source_dir is only set for editable requirements. + assert req.source_dir is None + req.ensure_has_source_dir(self.build_dir) + # If a checkout exists, it's unwise to keep going. version + # inconsistencies are logged later, but do not fail the + # 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')): + raise PreviousBuildDirError( + "pip can't proceed with requirements '{}' due to a" + " pre-existing build directory ({}). This is " + "likely due to a previous installation that failed" + ". pip is being responsible and not assuming it " + "can delete this. Please delete it and try again." + .format(req, req.source_dir) + ) + + # Now that we have the real link, we can tell what kind of + # requirements we have and raise some more informative errors + # than otherwise. (For example, we can raise VcsHashUnsupported + # for a VCS URL rather than HashMissing.) + if self.require_hashes: + # We could check these first 2 conditions inside + # unpack_url and save repetition of conditions, but then + # we would report less-useful error messages for + # unhashable requirements, complaining that there's no + # hash provided. + if link.is_vcs: + raise VcsHashUnsupported() + elif link.is_existing_dir(): + raise DirectoryUrlHashUnsupported() + if not req.original_link and not req.is_pinned: + # Unpinned packages are asking for trouble when a new + # version is uploaded. This isn't a security check, but + # it saves users a surprising hash mismatch in the + # future. + # + # file:/// URLs aren't pinnable, so don't complain + # about them not being pinned. + raise HashUnpinned() + + hashes = req.hashes(trust_internet=not self.require_hashes) + if self.require_hashes and not hashes: + # Known-good hashes are missing for this requirement, so + # shim it with a facade object that will provoke hash + # computation and then raise a HashMissing exception + # showing the user what the hash should be. + hashes = MissingHashes() + + download_dir = self.download_dir + if link.is_wheel and self.wheel_download_dir: + # when doing 'pip wheel` we download wheels to a + # dedicated dir. + download_dir = self.wheel_download_dir + + try: + local_path = unpack_url( + link, req.source_dir, self.downloader, download_dir, + hashes=hashes, + ) + except requests.HTTPError as exc: + logger.critical( + 'Could not install requirement %s because of error %s', + req, + exc, + ) + raise InstallationError( + 'Could not install requirement {} because of HTTP ' + 'error {} for URL {}'.format(req, exc, link) + ) + + # For use in later processing, preserve the file path on the + # requirement. + if local_path: + req.local_file_path = local_path + + if link.is_wheel: + if download_dir: + # When downloading, we only unpack wheels to get + # metadata. + autodelete_unpacked = True + else: + # When installing a wheel, we use the unpacked + # wheel. + autodelete_unpacked = False + else: + # We always delete unpacked sdists after pip runs. + autodelete_unpacked = True + if autodelete_unpacked: + write_delete_marker_file(req.source_dir) + + abstract_dist = _get_prepared_distribution( + req, self.req_tracker, self.finder, self.build_isolation, + ) + + if download_dir: + if link.is_existing_dir(): + logger.info('Link is a directory, ignoring download_dir') + elif local_path and not os.path.exists( + os.path.join(download_dir, link.filename) + ): + _copy_file(local_path, download_dir, link) + + if self._download_should_save: + # Make a .zip of the source_dir we already created. + if link.is_vcs: + req.archive(self.download_dir) + return abstract_dist + + def prepare_editable_requirement( + self, + req, # type: InstallRequirement + ): + # type: (...) -> AbstractDistribution + """Prepare an editable requirement + """ + assert req.editable, "cannot prepare a non-editable req as editable" + + 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) + ) + req.ensure_has_source_dir(self.src_dir) + req.update_editable(not self._download_should_save) + + abstract_dist = _get_prepared_distribution( + req, self.req_tracker, self.finder, self.build_isolation, + ) + + if self._download_should_save: + req.archive(self.download_dir) + req.check_if_exists(self.use_user_site) + + return abstract_dist + + def prepare_installed_requirement( + self, + req, # type: InstallRequirement + skip_reason # type: str + ): + # type: (...) -> AbstractDistribution + """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 + ) + 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.' + ) + abstract_dist = InstalledDistribution(req) + + return abstract_dist diff --git a/venv/lib/python3.8/site-packages/pip/_internal/pep425tags.py b/venv/lib/python3.8/site-packages/pip/_internal/pep425tags.py new file mode 100644 index 0000000..a2386ee --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/pep425tags.py @@ -0,0 +1,167 @@ +"""Generate and work with PEP 425 Compatibility Tags.""" +from __future__ import absolute_import + +import logging +import re + +from pip._vendor.packaging.tags import ( + Tag, + compatible_tags, + cpython_tags, + generic_tags, + interpreter_name, + interpreter_version, + mac_platforms, +) + +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import List, Optional, Tuple + + from pip._vendor.packaging.tags import PythonVersion + +logger = logging.getLogger(__name__) + +_osx_arch_pat = re.compile(r'(.+)_(\d+)_(\d+)_(.+)') + + +def version_info_to_nodot(version_info): + # type: (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] + match = _osx_arch_pat.match(arch) + if match: + name, major, minor, actual_arch = match.groups() + mac_version = (int(major), int(minor)) + arches = [ + # Since we have always only checked that the platform starts + # with "macosx", for backwards-compatibility we extract the + # actual prefix provided by the user in case they provided + # something like "macosxcustom_". It may be good to remove + # this as undocumented or deprecate it in the future. + '{}_{}'.format(name, arch[len('macosx_'):]) + for arch in mac_platforms(mac_version, actual_arch) + ] + else: + # arch pattern didn't match (?!) + arches = [arch] + return arches + + +def _custom_manylinux_platforms(arch): + # type: (str) -> List[str] + arches = [arch] + arch_prefix, arch_sep, arch_suffix = arch.partition('_') + if arch_prefix == 'manylinux2014': + # manylinux1/manylinux2010 wheels run on most manylinux2014 systems + # with the exception of wheels depending on ncurses. PEP 599 states + # manylinux1/manylinux2010 wheels should be considered + # manylinux2014 wheels: + # https://www.python.org/dev/peps/pep-0599/#backwards-compatibility-with-manylinux2010-wheels + if arch_suffix in {'i686', 'x86_64'}: + arches.append('manylinux2010' + arch_sep + arch_suffix) + arches.append('manylinux1' + arch_sep + arch_suffix) + elif arch_prefix == 'manylinux2010': + # manylinux1 wheels run on most manylinux2010 systems with the + # exception of wheels depending on ncurses. PEP 571 states + # manylinux1 wheels should be considered manylinux2010 wheels: + # https://www.python.org/dev/peps/pep-0571/#backwards-compatibility-with-manylinux1-wheels + arches.append('manylinux1' + arch_sep + arch_suffix) + return arches + + +def _get_custom_platforms(arch): + # type: (str) -> List[str] + arch_prefix, arch_sep, arch_suffix = arch.partition('_') + if arch.startswith('macosx'): + arches = _mac_platforms(arch) + elif arch_prefix in ['manylinux2014', 'manylinux2010']: + arches = _custom_manylinux_platforms(arch) + else: + arches = [arch] + return arches + + +def _get_python_version(version): + # type: (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 + if implementation is None: + implementation = interpreter_name() + if version is None: + version = interpreter_version() + return "{}{}".format(implementation, version) + + +def get_supported( + version=None, # type: Optional[str] + platform=None, # type: Optional[str] + impl=None, # type: Optional[str] + abi=None # type: Optional[str] +): + # type: (...) -> List[Tag] + """Return a list of supported tags for each version specified in + `versions`. + + :param version: a string version, of the form "33" or "32", + or None. The version will be assumed to support our ABI. + :param platform: specify the exact platform you want valid + tags for, or None. If None, use the local system platform. + :param impl: specify the exact implementation you want valid + tags for, or None. If None, use the local interpreter impl. + :param abi: specify the exact abi you want valid + tags for, or None. If None, use the local interpreter abi. + """ + supported = [] # type: List[Tag] + + python_version = None # type: Optional[PythonVersion] + if version is not None: + python_version = _get_python_version(version) + + interpreter = _get_custom_interpreter(impl, version) + + abis = None # type: Optional[List[str]] + if abi is not None: + abis = [abi] + + platforms = None # type: Optional[List[str]] + if platform is not None: + platforms = _get_custom_platforms(platform) + + is_cpython = (impl or interpreter_name()) == "cp" + if is_cpython: + supported.extend( + cpython_tags( + python_version=python_version, + abis=abis, + platforms=platforms, + ) + ) + else: + supported.extend( + generic_tags( + interpreter=interpreter, + abis=abis, + platforms=platforms, + ) + ) + supported.extend( + compatible_tags( + python_version=python_version, + interpreter=interpreter, + platforms=platforms, + ) + ) + + return supported diff --git a/venv/lib/python3.8/site-packages/pip/_internal/pyproject.py b/venv/lib/python3.8/site-packages/pip/_internal/pyproject.py new file mode 100644 index 0000000..6b4faf7 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/pyproject.py @@ -0,0 +1,196 @@ +from __future__ import absolute_import + +import io +import os +import sys +from collections import namedtuple + +from pip._vendor import six, toml +from pip._vendor.packaging.requirements import InvalidRequirement, Requirement + +from pip._internal.exceptions import InstallationError +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import Any, Optional, List + + +def _is_list_of_str(obj): + # type: (Any) -> bool + return ( + isinstance(obj, list) and + all(isinstance(item, six.string_types) for item in obj) + ) + + +def make_pyproject_path(unpacked_source_directory): + # type: (str) -> str + path = os.path.join(unpacked_source_directory, 'pyproject.toml') + + # Python2 __file__ should not be unicode + if six.PY2 and isinstance(path, six.text_type): + path = path.encode(sys.getfilesystemencoding()) + + return 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] + """Load the pyproject.toml file. + + Parameters: + use_pep517 - Has the user requested PEP 517 processing? None + means the user hasn't explicitly specified. + pyproject_toml - Location of the project's pyproject.toml file + setup_py - Location of the project's setup.py file + req_name - The name of the requirement we're processing (for + error reporting) + + Returns: + None if we should use the legacy code path, otherwise a tuple + ( + requirements from pyproject.toml, + name of PEP 517 backend, + requirements we should check are installed after setting + up the build environment + directory paths to import the backend from (backend-path), + relative to the project root. + ) + """ + has_pyproject = os.path.isfile(pyproject_toml) + has_setup = os.path.isfile(setup_py) + + if has_pyproject: + with io.open(pyproject_toml, encoding="utf-8") as f: + pp_toml = toml.load(f) + build_system = pp_toml.get("build-system") + else: + build_system = None + + # The following cases must use PEP 517 + # We check for use_pep517 being non-None and falsey because that means + # the user explicitly requested --no-use-pep517. The value 0 as + # opposed to False can occur when the value is provided via an + # environment variable or config file option (due to the quirk of + # strtobool() returning an integer in pip's configuration code). + if has_pyproject and not has_setup: + if use_pep517 is not None and not use_pep517: + raise InstallationError( + "Disabling PEP 517 processing is invalid: " + "project does not have a setup.py" + ) + use_pep517 = True + elif build_system and "build-backend" in build_system: + if use_pep517 is not None and not use_pep517: + raise InstallationError( + "Disabling PEP 517 processing is invalid: " + "project specifies a build backend of {} " + "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. + elif use_pep517 is None: + use_pep517 = has_pyproject + + # At this point, we know whether we're going to use PEP 517. + assert use_pep517 is not None + + # If we're using the legacy code path, there is nothing further + # for us to do here. + if not use_pep517: + return None + + if build_system is None: + # Either the user has a pyproject.toml with no build-system + # section, or the user has no pyproject.toml, but has opted in + # explicitly via --use-pep517. + # In the absence of any explicit backend specification, we + # assume the setuptools backend that most closely emulates the + # traditional direct setup.py execution, and require wheel and + # a version of setuptools that supports that backend. + + build_system = { + "requires": ["setuptools>=40.8.0", "wheel"], + "build-backend": "setuptools.build_meta:__legacy__", + } + + # If we're using PEP 517, we have build system information (either + # from pyproject.toml, or defaulted by the code above). + # Note that at this point, we do not know if the user has actually + # specified a backend, though. + assert build_system is not None + + # 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" + )) + ) + + # 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( + package=req_name, + reason="'build-system.requires' 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) + ), + ) + ) + + backend = build_system.get("build-backend") + backend_path = build_system.get("backend-path", []) + check = [] # type: 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 + # 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 + # adopted PEP 518 early for the ability to specify requirements to + # execute setup.py, but never considered needing to mention the build + # 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"] + + return BuildSystemDetails(requires, backend, check, backend_path) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/req/__init__.py b/venv/lib/python3.8/site-packages/pip/_internal/req/__init__.py new file mode 100644 index 0000000..d2d027a --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/req/__init__.py @@ -0,0 +1,92 @@ +# The following comment should be removed at some point in the future. +# mypy: strict-optional=False + +from __future__ import absolute_import + +import logging + +from pip._internal.utils.logging import indent_log +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +from .req_file import parse_requirements +from .req_install import InstallRequirement +from .req_set import RequirementSet + +if MYPY_CHECK_RUNNING: + from typing import Any, List, Sequence + +__all__ = [ + "RequirementSet", "InstallRequirement", + "parse_requirements", "install_given_reqs", +] + +logger = logging.getLogger(__name__) + + +class InstallationResult(object): + def __init__(self, name): + # type: (str) -> None + self.name = name + + def __repr__(self): + # type: () -> str + return "InstallationResult(name={!r})".format(self.name) + + +def install_given_reqs( + to_install, # type: List[InstallRequirement] + install_options, # type: List[str] + global_options=(), # type: Sequence[str] + *args, # type: Any + **kwargs # type: Any +): + # type: (...) -> List[InstallationResult] + """ + Install everything in the given list. + + (to be called after having downloaded and unpacked the packages) + """ + + if to_install: + logger.info( + 'Installing collected packages: %s', + ', '.join([req.name for req in to_install]), + ) + + installed = [] + + with indent_log(): + for requirement in to_install: + if requirement.should_reinstall: + logger.info('Attempting uninstall: %s', requirement.name) + with indent_log(): + uninstalled_pathset = requirement.uninstall( + auto_confirm=True + ) + try: + requirement.install( + install_options, + global_options, + *args, + **kwargs + ) + except Exception: + should_rollback = ( + requirement.should_reinstall and + not requirement.install_succeeded + ) + # if install did not succeed, rollback previous uninstall + if should_rollback: + uninstalled_pathset.rollback() + raise + else: + should_commit = ( + requirement.should_reinstall and + requirement.install_succeeded + ) + if should_commit: + uninstalled_pathset.commit() + + installed.append(InstallationResult(requirement.name)) + + return installed diff --git a/venv/lib/python3.8/site-packages/pip/_internal/req/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/req/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..69f65990bceefe360e4815e3ff00dd4a924a1a96 GIT binary patch literal 2194 zcmaJCO>Y}TbY^zFUT^%7IBlu=AzVaJEm5Zj3J8^`Ra=!pF_2KTS*coWJY##){cvVy z8)BRb?G+GLgivy8FPu2>3-}FlW-aYFl zfc=4o!^?!jW!ULY065_^BoTEfMVy7qW$-mZBQjkxr!4ne*W)}p#wj~Z?xns?`c$Ki9l%4-ADT@Y-yDHivrd*lY;b>4VH zctae0Xt>9ClP~bvBkI1!*(zx-J_QR&o9c$Yo+e?Ygcn4kM5->(oFL{RR$iD4;MDwd z?ejJ7>POeFe&Vg%?sji>Z#<<_;pWJfsqm!O%mOJQkV#SCW}GTN3|F3$fm%OwTotNq zXyZz}t<76Os=ctdp%dak{y>^`pHOYaek9sV zo2dx8ZC{2(fKSM`MvvspWhk^5uOjS!RGth?`+}Sk{85E$k-2; zz?UTtj)C&L&S+cP#o;8rog2l*CugxdWN)Y7>tPm(g}4DbH@pf6r@LfAHs~G&(^+?X z`c+Nm(3cOtJ|lP9;E~l&WaO*dr#6-Ipd)u|3Yu_46QvkQ&wCwC|8L@yuiGx65WeGi z+VQ+7;aP}y)$=wpKb+pkMSSe&i!WkOB|a-_08YS8vA=9;n>i)7tA{=p3-dJx`!m?- zp8zIAwiMZ=SPZ*tS_%_#jXZ>?>@i9PWT&KzhvfTTDezt+_a5(96Klhi{amU9cnSG( zo+j{E8y2^C`CGbEzC$jOFUShHOUB26UWP(peKs+EW)t%}X!$!NzF-n%-*@CMl;96F zCqDwLRLPD#vE}1QdDq#4n{UV(iBH^}a{PuIJC#XA{towZct0uaR#gq?CA6H9%?r<8 zpI~9zud_ZoN>cSlO7h zRm>9RcL1@!=j_l4-5@`(O>=ctcXhafx@4UT+JI(xxfq>G=uIz)M#~pb6&8mD%{zW8 zcx7gEE`62?{4&s5^|lDHqps9o0<48wtt+6>}; zqRovYh$VWV=hI=5g&Z1VrXg=2T{+OG%d-nzx&Bp8zYpjW9y>i~iF z&%D9%JGRdZ_KcbAZ`-Ofi(31vWCD+ESk&BSCgAK8gAs%ipnV+2Mn6-Tgs~y9cyt+a z0a?>0VWM^pCTb^BL6~-Cm(%Q=_%9B%JpyTo1p`qRn_fQ%#q|FMqf-Pq{~OX}q(E5m zewUYG>XpHI9!f+i5;lY&C_ND1? gTt>UnHvm+b&8oDD8=y>qCq8-nW?^ELA9U+VTlK>z>% literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/req/__pycache__/constructors.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/req/__pycache__/constructors.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..26d4e01f745a6a438b0695d36cff2cb292757b29 GIT binary patch literal 10363 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 literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/req/__pycache__/req_file.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/req/__pycache__/req_file.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..547438d184287a8e568ddde121e5219ec1bc3019 GIT binary patch literal 12702 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 literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/req/__pycache__/req_install.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/req/__pycache__/req_install.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..814b966833a2fb6da1844f7dc46af26f7c25c9c3 GIT binary patch literal 21338 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 E7gDc^B>(^b literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/req/constructors.py b/venv/lib/python3.8/site-packages/pip/_internal/req/constructors.py new file mode 100644 index 0000000..1f3cd8a --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/req/constructors.py @@ -0,0 +1,436 @@ +"""Backing implementation for InstallRequirement's various constructors + +The idea here is that these formed a major chunk of InstallRequirement's size +so, moving them and support code dedicated to them outside of that class +helps creates for better understandability for the rest of the code. + +These are meant to be used elsewhere within pip to create instances of +InstallRequirement. +""" + +# The following comment should be removed at some point in the future. +# mypy: strict-optional=False + +import logging +import os +import re + +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_install import InstallRequirement +from pip._internal.utils.filetypes import ARCHIVE_EXTENSIONS +from pip._internal.utils.misc import is_installable_dir, splitext +from pip._internal.utils.typing import MYPY_CHECK_RUNNING +from pip._internal.utils.urls import path_to_url +from pip._internal.vcs import is_url, vcs + +if MYPY_CHECK_RUNNING: + from typing import ( + Any, Dict, Optional, Set, Tuple, Union, + ) + from pip._internal.cache import WheelCache + + +__all__ = [ + "install_req_from_editable", "install_req_from_line", + "parse_editable" +] + +logger = logging.getLogger(__name__) +operators = Specifier._operators.keys() + + +def is_archive_file(name): + # type: (str) -> bool + """Return True if `name` is a considered as an archive file.""" + ext = splitext(name)[1].lower() + if ext in ARCHIVE_EXTENSIONS: + return True + return False + + +def _strip_extras(path): + # type: (str) -> Tuple[str, Optional[str]] + m = re.match(r'^(.+)(\[[^\]]+\])$', path) + extras = None + if m: + path_no_extras = m.group(1) + extras = m.group(2) + else: + path_no_extras = path + + return path_no_extras, extras + + +def convert_extras(extras): + # type: (Optional[str]) -> Set[str] + if not extras: + return set() + return Requirement("placeholder" + extras.lower()).extras + + +def parse_editable(editable_req): + # type: (str) -> Tuple[Optional[str], str, Optional[Set[str]]] + """Parses an editable requirement into: + - a requirement name + - an URL + - extras + - editable options + Accepted requirements: + svn+http://blahblah@rev#egg=Foobar[baz]&subdirectory=version_subdir + .[some_extra] + """ + + url = editable_req + + # If a file path is specified with extras, strip off the extras. + url_no_extras, extras = _strip_extras(url) + + if os.path.isdir(url_no_extras): + if not os.path.exists(os.path.join(url_no_extras, 'setup.py')): + msg = ( + 'File "setup.py" 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 setup.py 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:'): + package_name = Link(url_no_extras).egg_fragment + if extras: + return ( + package_name, + url_no_extras, + Requirement("placeholder" + extras.lower()).extras, + ) + else: + return package_name, url_no_extras, None + + for version_control in vcs: + if url.lower().startswith('%s:' % version_control): + url = '%s+%s' % (version_control, url) + break + + if '+' not in url: + raise InstallationError( + '{} is not a valid editable requirement. ' + 'It should either be a path to a local project or a VCS URL ' + '(beginning with svn+, git+, hg+, or bzr+).'.format(editable_req) + ) + + vc_type = url.split('+', 1)[0].lower() + + if not vcs.get_backend(vc_type): + error_message = 'For --editable=%s only ' % editable_req + \ + ', '.join([backend.name + '+URL' for backend in vcs.backends]) + \ + ' is currently supported' + raise InstallationError(error_message) + + package_name = Link(url).egg_fragment + if not package_name: + raise InstallationError( + "Could not detect requirement name for '%s', please specify one " + "with #egg=your_package_name" % editable_req + ) + return package_name, url, None + + +def deduce_helpful_msg(req): + # type: (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 = " It does exist." + # Try to parse and check if it is a requirements file. + try: + with open(req, 'r') as fp: + # parse first line only + next(parse_requirements(fp.read())) + msg += " The argument you provided " + \ + "(%s) appears to be a" % (req) + \ + " requirements file. If that is the" + \ + " case, use the '-r' flag to install" + \ + " the packages specified within it." + except RequirementParseError: + logger.debug("Cannot parse '%s' as requirements \ + file" % (req), exc_info=True) + else: + msg += " File '%s' does not exist." % (req) + return msg + + +class RequirementParts(object): + def __init__( + self, + requirement, # type: Optional[Requirement] + link, # type: Optional[Link] + markers, # type: Optional[Marker] + extras, # type: Set[str] + ): + self.requirement = requirement + self.link = link + self.markers = markers + self.extras = extras + + +def parse_req_from_editable(editable_req): + # type: (str) -> RequirementParts + name, url, extras_override = parse_editable(editable_req) + + if name is not None: + try: + req = Requirement(name) + except InvalidRequirement: + raise InstallationError("Invalid requirement: '%s'" % name) + else: + req = None + + link = Link(url) + + return RequirementParts(req, link, None, extras_override) + + +# ---- The actual constructors follow ---- + + +def install_req_from_editable( + editable_req, # type: str + comes_from=None, # type: Optional[str] + use_pep517=None, # type: Optional[bool] + isolated=False, # type: bool + options=None, # type: Optional[Dict[str, Any]] + wheel_cache=None, # type: Optional[WheelCache] + constraint=False # type: bool +): + # type: (...) -> InstallRequirement + + parts = parse_req_from_editable(editable_req) + + source_dir = parts.link.file_path if parts.link.scheme == 'file' else None + + return InstallRequirement( + parts.requirement, comes_from, source_dir=source_dir, + editable=True, + link=parts.link, + constraint=constraint, + use_pep517=use_pep517, + isolated=isolated, + options=options if options else {}, + wheel_cache=wheel_cache, + extras=parts.extras, + ) + + +def _looks_like_path(name): + # type: (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 + appearance. + + Returns true if any of the following conditions is true: + * a path separator is found (either os.path.sep or os.path.altsep); + * a dot is found (which represents the current directory). + """ + if os.path.sep in name: + return True + if os.path.altsep is not None and os.path.altsep in name: + return True + if name.startswith("."): + return True + return False + + +def _get_url_from_path(path, name): + # type: (str, str) -> 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. + + 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 + an @, it will treat it as a PEP 440 URL requirement and return the path. + """ + if _looks_like_path(name) and os.path.isdir(path): + if is_installable_dir(path): + return path_to_url(path) + raise InstallationError( + "Directory %r is not installable. Neither 'setup.py' " + "nor 'pyproject.toml' found." % name + ) + if not is_archive_file(path): + return None + if os.path.isfile(path): + return path_to_url(path) + 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 + ) + return path_to_url(path) + + +def parse_req_from_line(name, line_source): + # type: (str, Optional[str]) -> RequirementParts + if is_url(name): + marker_sep = '; ' + else: + marker_sep = ';' + if marker_sep in name: + name, markers_as_string = name.split(marker_sep, 1) + markers_as_string = markers_as_string.strip() + if not markers_as_string: + markers = None + else: + markers = Marker(markers_as_string) + else: + markers = None + name = name.strip() + req_as_string = None + path = os.path.normpath(os.path.abspath(name)) + link = None + extras_as_string = None + + if is_url(name): + link = Link(name) + else: + p, extras_as_string = _strip_extras(path) + url = _get_url_from_path(p, name) + if url is not None: + link = Link(url) + + # 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)))) + # wheel file + if link.is_wheel: + wheel = Wheel(link.filename) # can raise InvalidWheelFilename + req_as_string = "%s==%s" % (wheel.name, wheel.version) + else: + # set the req to the egg fragment. when it's not there, this + # will become an 'unnamed' requirement + req_as_string = link.egg_fragment + + # a requirement specifier + else: + req_as_string = name + + extras = convert_extras(extras_as_string) + + def with_source(text): + # type: (str) -> str + if not line_source: + return text + return '{} (from {})'.format(text, line_source) + + if req_as_string is not None: + try: + req = 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)): + add_msg = "= is not a valid operator. Did you mean == ?" + else: + add_msg = '' + msg = with_source( + 'Invalid requirement: {!r}'.format(req_as_string) + ) + if add_msg: + msg += '\nHint: {}'.format(add_msg) + raise InstallationError(msg) + else: + req = None + + return RequirementParts(req, link, markers, extras) + + +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]] + wheel_cache=None, # type: Optional[WheelCache] + constraint=False, # type: bool + line_source=None, # type: Optional[str] +): + # type: (...) -> InstallRequirement + """Creates an InstallRequirement from a name, which might be a + requirement, directory containing 'setup.py', filename, or URL. + + :param line_source: An optional string describing where the line is from, + for logging purposes in case of an error. + """ + 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, + options=options if options else {}, + wheel_cache=wheel_cache, + constraint=constraint, + extras=parts.extras, + ) + + +def install_req_from_req_string( + req_string, # type: str + comes_from=None, # type: Optional[InstallRequirement] + isolated=False, # type: bool + wheel_cache=None, # type: Optional[WheelCache] + use_pep517=None # type: Optional[bool] +): + # type: (...) -> InstallRequirement + try: + req = Requirement(req_string) + except InvalidRequirement: + raise InstallationError("Invalid requirement: '%s'" % req_string) + + domains_not_allowed = [ + 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): + # Explicitly disallow pypi packages that depend on external urls + raise InstallationError( + "Packages installed from PyPI cannot depend on packages " + "which are not also hosted on PyPI.\n" + "%s depends on %s " % (comes_from.name, req) + ) + + return InstallRequirement( + req, comes_from, isolated=isolated, wheel_cache=wheel_cache, + use_pep517=use_pep517 + ) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/req/req_file.py b/venv/lib/python3.8/site-packages/pip/_internal/req/req_file.py new file mode 100644 index 0000000..8c78104 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/req/req_file.py @@ -0,0 +1,546 @@ +""" +Requirements file parsing +""" + +# The following comment should be removed at some point in the future. +# mypy: strict-optional=False + +from __future__ import absolute_import + +import optparse +import os +import re +import shlex +import sys + +from pip._vendor.six.moves import filterfalse +from pip._vendor.six.moves.urllib import parse as urllib_parse + +from pip._internal.cli import cmdoptions +from pip._internal.exceptions import ( + InstallationError, + RequirementsFileParseError, +) +from pip._internal.models.search_scope import SearchScope +from pip._internal.req.constructors import ( + install_req_from_editable, + install_req_from_line, +) +from pip._internal.utils.encoding import auto_decode +from pip._internal.utils.typing import MYPY_CHECK_RUNNING +from pip._internal.utils.urls import get_url_scheme + +if MYPY_CHECK_RUNNING: + from optparse import Values + from typing import ( + Any, Callable, Iterator, List, NoReturn, Optional, Text, Tuple, + ) + + from pip._internal.req import InstallRequirement + from pip._internal.cache import WheelCache + from pip._internal.index.package_finder import PackageFinder + from pip._internal.network.session import PipSession + + ReqFileLines = Iterator[Tuple[int, Text]] + + LineParser = Callable[[Text], Tuple[str, Values]] + + +__all__ = ['parse_requirements'] + +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\$\{(?P[A-Z0-9_]+)\})') + +SUPPORTED_OPTIONS = [ + cmdoptions.index_url, + cmdoptions.extra_index_url, + cmdoptions.no_index, + cmdoptions.constraints, + cmdoptions.requirements, + cmdoptions.editable, + cmdoptions.find_links, + cmdoptions.no_binary, + cmdoptions.only_binary, + cmdoptions.require_hashes, + cmdoptions.pre, + cmdoptions.trusted_host, + cmdoptions.always_unzip, # Deprecated +] # type: List[Callable[..., optparse.Option]] + +# options to be passed to requirements +SUPPORTED_OPTIONS_REQ = [ + cmdoptions.install_options, + cmdoptions.global_options, + cmdoptions.hash, +] # type: List[Callable[..., optparse.Option]] + +# the 'dest' string values +SUPPORTED_OPTIONS_REQ_DEST = [str(o().dest) for o in SUPPORTED_OPTIONS_REQ] + + +class ParsedLine(object): + def __init__( + self, + filename, # type: str + lineno, # type: int + comes_from, # type: str + args, # type: str + opts, # type: Values + constraint, # type: bool + ): + # type: (...) -> None + self.filename = filename + self.lineno = lineno + self.comes_from = comes_from + self.args = args + self.opts = opts + self.constraint = constraint + + +def parse_requirements( + filename, # type: str + session, # type: PipSession + finder=None, # type: Optional[PackageFinder] + comes_from=None, # type: Optional[str] + options=None, # type: Optional[optparse.Values] + constraint=False, # type: bool + wheel_cache=None, # type: Optional[WheelCache] + use_pep517=None # type: Optional[bool] +): + # type: (...) -> Iterator[InstallRequirement] + """Parse a requirements file and yield InstallRequirement instances. + + :param filename: Path or url of requirements file. + :param session: PipSession instance. + :param finder: Instance of pip.index.PackageFinder. + :param comes_from: Origin description of requirements. + :param options: cli options. + :param constraint: If true, parsing a constraint file rather than + requirements file. + :param wheel_cache: Instance of pip.wheel.WheelCache + :param use_pep517: Value of the --use-pep517 option. + """ + skip_requirements_regex = ( + options.skip_requirements_regex if options else None + ) + line_parser = get_line_parser(finder) + parser = RequirementsFileParser( + session, line_parser, comes_from, skip_requirements_regex + ) + + for parsed_line in parser.parse(filename, constraint): + req = handle_line( + parsed_line, finder, options, session, wheel_cache, use_pep517 + ) + if req is not None: + yield req + + +def preprocess(content, skip_requirements_regex): + # type: (Text, Optional[str]) -> ReqFileLines + """Split, filter, and join lines, and return a line iterator + + :param content: the content of the requirements file + :param options: cli options + """ + lines_enum = enumerate(content.splitlines(), start=1) # type: ReqFileLines + lines_enum = join_lines(lines_enum) + lines_enum = ignore_comments(lines_enum) + if skip_requirements_regex: + lines_enum = skip_regex(lines_enum, skip_requirements_regex) + lines_enum = expand_env_variables(lines_enum) + return lines_enum + + +def handle_line( + line, # type: ParsedLine + finder=None, # type: Optional[PackageFinder] + options=None, # type: Optional[optparse.Values] + session=None, # type: Optional[PipSession] + wheel_cache=None, # type: Optional[WheelCache] + use_pep517=None, # type: Optional[bool] +): + # type: (...) -> Optional[InstallRequirement] + """Handle a single parsed requirements line; This can result in + creating/yielding requirements, or updating the finder. + + For lines that contain requirements, the only options that have an effect + are from SUPPORTED_OPTIONS_REQ, and they are scoped to the + requirement. Other options from SUPPORTED_OPTIONS may be present, but are + ignored. + + For lines that do not contain requirements, the only options that have an + effect are from SUPPORTED_OPTIONS. Options from SUPPORTED_OPTIONS_REQ may + be present, but are ignored. These lines may contain multiple options + (although our docs imply only one is supported), and all our parsed and + affect the finder. + """ + + # preserve for the nested code path + line_comes_from = '%s %s (line %s)' % ( + '-c' if line.constraint else '-r', line.filename, line.lineno, + ) + + # return a line requirement + if line.args: + isolated = options.isolated_mode if options else False + if 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 = 'line {} of {}'.format(line.lineno, line.filename) + return install_req_from_line( + line.args, + comes_from=line_comes_from, + use_pep517=use_pep517, + isolated=isolated, + options=req_options, + wheel_cache=wheel_cache, + constraint=line.constraint, + line_source=line_source, + ) + + # return an editable requirement + elif line.opts.editables: + isolated = options.isolated_mode if options else False + return install_req_from_editable( + line.opts.editables[0], comes_from=line_comes_from, + use_pep517=use_pep517, + constraint=line.constraint, isolated=isolated, + wheel_cache=wheel_cache + ) + + # percolate hash-checking option upward + elif line.opts.require_hashes: + options.require_hashes = line.opts.require_hashes + + # set finder options + elif finder: + find_links = finder.find_links + index_urls = finder.index_urls + if line.opts.index_url: + index_urls = [line.opts.index_url] + if line.opts.no_index is True: + index_urls = [] + if line.opts.extra_index_urls: + index_urls.extend(line.opts.extra_index_urls) + if line.opts.find_links: + # FIXME: it would be nice to keep track of the source + # of the find_links: support a find-links local path + # relative to a requirements file. + value = line.opts.find_links[0] + req_dir = os.path.dirname(os.path.abspath(line.filename)) + relative_to_reqs_file = os.path.join(req_dir, value) + if os.path.exists(relative_to_reqs_file): + value = relative_to_reqs_file + find_links.append(value) + + search_scope = SearchScope( + find_links=find_links, + index_urls=index_urls, + ) + finder.search_scope = search_scope + + if line.opts.pre: + finder.set_allow_all_prereleases() + + if session: + for host in line.opts.trusted_hosts or []: + source = 'line {} of {}'.format(line.lineno, line.filename) + session.add_trusted_host(host, source=source) + + return None + + +class RequirementsFileParser(object): + def __init__( + self, + session, # type: PipSession + line_parser, # type: LineParser + comes_from, # type: str + skip_requirements_regex, # type: Optional[str] + ): + # type: (...) -> None + self._session = session + self._line_parser = line_parser + self._comes_from = comes_from + self._skip_requirements_regex = skip_requirements_regex + + def parse(self, filename, constraint): + # type: (str, bool) -> Iterator[ParsedLine] + """Parse a given file, yielding parsed lines. + """ + for line in self._parse_and_recurse(filename, constraint): + yield line + + def _parse_and_recurse(self, filename, constraint): + # type: (str, bool) -> Iterator[ParsedLine] + for line in self._parse_file(filename, constraint): + if ( + not line.args and + not line.opts.editables and + (line.opts.requirements or line.opts.constraints) + ): + # parse a nested requirements file + if line.opts.requirements: + req_path = line.opts.requirements[0] + nested_constraint = False + else: + req_path = line.opts.constraints[0] + nested_constraint = True + + # original file is over http + if SCHEME_RE.search(filename): + # do a url join so relative paths work + req_path = urllib_parse.urljoin(filename, req_path) + # original file and nested file are paths + 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, + ) + + for inner_line in self._parse_and_recurse( + req_path, nested_constraint, + ): + yield inner_line + else: + yield line + + def _parse_file(self, filename, constraint): + # type: (str, bool) -> Iterator[ParsedLine] + _, content = get_file_content( + filename, self._session, comes_from=self._comes_from + ) + + lines_enum = preprocess(content, self._skip_requirements_regex) + + for line_number, line in lines_enum: + try: + args_str, opts = self._line_parser(line) + except OptionParsingError as e: + # add offending line + msg = 'Invalid requirement: %s\n%s' % (line, e.msg) + raise RequirementsFileParseError(msg) + + yield ParsedLine( + filename, + line_number, + self._comes_from, + args_str, + opts, + constraint, + ) + + +def get_line_parser(finder): + # type: (Optional[PackageFinder]) -> LineParser + def parse_line(line): + # type: (Text) -> Tuple[str, Values] + # Build new parser for each line since it accumulates appendable + # options. + parser = build_parser() + defaults = parser.get_default_values() + defaults.index_url = None + if finder: + defaults.format_control = finder.format_control + + args_str, options_str = break_args_options(line) + # Prior to 2.7.3, shlex cannot deal with unicode entries + if sys.version_info < (2, 7, 3): + # https://github.com/python/mypy/issues/1174 + options_str = options_str.encode('utf8') # type: ignore + + # https://github.com/python/mypy/issues/1174 + opts, _ = parser.parse_args( + shlex.split(options_str), defaults) # type: ignore + + return args_str, opts + + return parse_line + + +def break_args_options(line): + # type: (Text) -> Tuple[str, Text] + """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(' ') + args = [] + options = tokens[:] + for token in tokens: + if token.startswith('-') or token.startswith('--'): + break + else: + args.append(token) + options.pop(0) + return ' '.join(args), ' '.join(options) # type: ignore + + +class OptionParsingError(Exception): + def __init__(self, msg): + # type: (str) -> None + self.msg = msg + + +def build_parser(): + # type: () -> optparse.OptionParser + """ + Return a parser for parsing requirement lines + """ + parser = optparse.OptionParser(add_help_option=False) + + option_factories = SUPPORTED_OPTIONS + SUPPORTED_OPTIONS_REQ + for option_factory in option_factories: + option = option_factory() + parser.add_option(option) + + # 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 + raise OptionParsingError(msg) + # NOTE: mypy disallows assigning to a method + # https://github.com/python/mypy/issues/2427 + parser.exit = parser_exit # type: ignore + + return parser + + +def join_lines(lines_enum): + # type: (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[Text] + for line_number, line in lines_enum: + if not line.endswith('\\') or COMMENT_RE.match(line): + if COMMENT_RE.match(line): + # this ensures comments are always matched later + line = ' ' + line + if new_line: + new_line.append(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('\\')) + + # last line contains \ + if new_line: + yield primary_line_number, ''.join(new_line) + + # TODO: handle space after '\'. + + +def ignore_comments(lines_enum): + # type: (ReqFileLines) -> ReqFileLines + """ + Strips comments and filter empty lines. + """ + for line_number, line in lines_enum: + line = COMMENT_RE.sub('', line) + line = line.strip() + if line: + yield line_number, line + + +def skip_regex(lines_enum, pattern): + # type: (ReqFileLines, str) -> ReqFileLines + """ + Skip lines that match the provided pattern + + Note: the regex pattern is only built once + """ + matcher = re.compile(pattern) + lines_enum = filterfalse(lambda e: matcher.search(e[1]), lines_enum) + return lines_enum + + +def expand_env_variables(lines_enum): + # type: (ReqFileLines) -> ReqFileLines + """Replace all environment variables that can be retrieved via `os.getenv`. + + The only allowed format for environment variables defined in the + requirement file is `${MY_VARIABLE_1}` to ensure two things: + + 1. Strings that contain a `$` aren't accidentally (partially) expanded. + 2. Ensure consistency across platforms for requirement files. + + These points are the result of a discussion on the `github pull + request #3514 `_. + + Valid characters in variable names follow the `POSIX standard + `_ and are limited + to uppercase letter, digits and the `_` (underscore). + """ + for line_number, line in lines_enum: + for env_var, var_name in ENV_VAR_RE.findall(line): + value = os.getenv(var_name) + if not value: + continue + + line = line.replace(env_var, value) + + yield line_number, line + + +def get_file_content(url, session, comes_from=None): + # type: (str, PipSession, Optional[str]) -> Tuple[str, Text] + """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. + + :param url: File path or url. + :param session: PipSession instance. + :param comes_from: Origin description of requirements. + """ + scheme = get_url_scheme(url) + + if scheme in ['http', 'https']: + # FIXME: catch some errors + resp = session.get(url) + resp.raise_for_status() + return resp.url, resp.text + + elif scheme == 'file': + if comes_from and comes_from.startswith('http'): + raise InstallationError( + 'Requirements file %s references URL %s, which is local' + % (comes_from, url)) + + path = url.split(':', 1)[1] + path = path.replace('\\', '/') + match = _url_slash_drive_re.match(path) + if match: + path = match.group(1) + ':' + path.split('|', 1)[1] + path = urllib_parse.unquote(path) + if path.startswith('/'): + path = '/' + path.lstrip('/') + url = path + + try: + with open(url, 'rb') as f: + content = auto_decode(f.read()) + except IOError as exc: + raise InstallationError( + 'Could not open requirements file: %s' % str(exc) + ) + return url, content + + +_url_slash_drive_re = re.compile(r'/*([a-z])\|', re.I) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/req/req_install.py b/venv/lib/python3.8/site-packages/pip/_internal/req/req_install.py new file mode 100644 index 0000000..22ac24b --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/req/req_install.py @@ -0,0 +1,830 @@ +# The following comment should be removed at some point in the future. +# mypy: strict-optional=False + +from __future__ import absolute_import + +import logging +import os +import shutil +import sys +import zipfile + +from pip._vendor import pkg_resources, six +from pip._vendor.packaging.requirements import Requirement +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._internal import pep425tags +from pip._internal.build_env import NoOpBuildEnvironment +from pip._internal.exceptions import InstallationError +from pip._internal.locations import get_scheme +from pip._internal.models.link import Link +from pip._internal.operations.build.metadata import generate_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 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.hashes import Hashes +from pip._internal.utils.logging import indent_log +from pip._internal.utils.marker_files import ( + PIP_DELETE_MARKER_FILENAME, + has_delete_marker_file, + write_delete_marker_file, +) +from pip._internal.utils.misc import ( + ask_path_exists, + backup_dir, + display_path, + dist_in_site_packages, + dist_in_usersite, + get_installed_version, + hide_url, + redact_auth_from_url, + rmtree, +) +from pip._internal.utils.packaging import get_metadata +from pip._internal.utils.temp_dir import TempDirectory +from pip._internal.utils.typing import MYPY_CHECK_RUNNING +from pip._internal.utils.virtualenv import running_under_virtualenv +from pip._internal.vcs import vcs + +if MYPY_CHECK_RUNNING: + from typing import ( + Any, Dict, Iterable, List, Optional, Sequence, Union, + ) + from pip._internal.build_env import BuildEnvironment + from pip._internal.cache import WheelCache + from pip._internal.index.package_finder import PackageFinder + from pip._vendor.pkg_resources import Distribution + from pip._vendor.packaging.specifiers import SpecifierSet + from pip._vendor.packaging.markers import Marker + + +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) + + # Determine the correct Distribution object type. + if dist_dir.endswith(".egg-info"): + dist_cls = pkg_resources.Distribution + else: + assert dist_dir.endswith(".dist-info") + dist_cls = pkg_resources.DistInfoDistribution + + # Build a PathMetadata object, from path to metadata. :wink: + base_dir, dist_dir_name = os.path.split(dist_dir) + dist_name = os.path.splitext(dist_dir_name)[0] + metadata = pkg_resources.PathMetadata(base_dir, dist_dir) + + return dist_cls( + base_dir, + project_name=dist_name, + metadata=metadata, + ) + + +class InstallRequirement(object): + """ + Represents something that may be installed later on, may have information + about where to fetch the relevant requirement and also contains logic for + installing the said requirement. + """ + + def __init__( + self, + req, # type: Optional[Requirement] + comes_from, # type: Optional[Union[str, InstallRequirement]] + source_dir=None, # type: Optional[str] + editable=False, # type: bool + link=None, # type: Optional[Link] + markers=None, # type: Optional[Marker] + use_pep517=None, # type: Optional[bool] + isolated=False, # type: bool + options=None, # type: Optional[Dict[str, Any]] + wheel_cache=None, # type: Optional[WheelCache] + constraint=False, # type: bool + extras=() # type: Iterable[str] + ): + # type: (...) -> None + assert req is None or isinstance(req, Requirement), req + self.req = req + self.comes_from = comes_from + self.constraint = constraint + if source_dir is None: + self.source_dir = None # type: Optional[str] + else: + self.source_dir = os.path.normpath(os.path.abspath(source_dir)) + self.editable = editable + + self._wheel_cache = wheel_cache + if link is None and req and req.url: + # PEP 508 URL requirement + link = Link(req.url) + self.link = self.original_link = link + # Path to any downloaded or already-existing package. + self.local_file_path = None # type: Optional[str] + 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 + } + 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] + # 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] + # Set to True after successful installation + self.install_succeeded = None # type: Optional[bool] + self.options = options if options else {} + # Set to True after successful preparation of this requirement + self.prepared = False + self.is_direct = False + + self.isolated = isolated + self.build_env = NoOpBuildEnvironment() # type: BuildEnvironment + + # 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] + + # The static build requirements (from pyproject.toml) + self.pyproject_requires = None # type: Optional[List[str]] + + # Build requirements that we will check are available + self.requirements_to_check = [] # type: List[str] + + # The PEP 517 backend we should use to build the project + self.pep517_backend = None # type: Optional[Pep517HookCaller] + + # Are we using PEP 517 for this requirement? + # After pyproject.toml has been loaded, the only valid values are True + # and False. Before loading, None is valid (meaning "use the default"). + # Setting an explicit value before loading pyproject.toml is supported, + # but after loading this flag should be treated as read only. + self.use_pep517 = use_pep517 + + def __str__(self): + # type: () -> str + if self.req: + s = str(self.req) + if self.link: + s += ' from %s' % redact_auth_from_url(self.link.url) + elif self.link: + s = redact_auth_from_url(self.link.url) + else: + s = '' + if self.satisfied_by is not None: + s += ' in %s' % display_path(self.satisfied_by.location) + if self.comes_from: + if isinstance(self.comes_from, six.string_types): + comes_from = self.comes_from # type: Optional[str] + else: + comes_from = self.comes_from.from_path() + if comes_from: + s += ' (from %s)' % comes_from + return s + + def __repr__(self): + # type: () -> str + return '<%s object: %s editable=%r>' % ( + self.__class__.__name__, str(self), self.editable) + + def format_debug(self): + # type: () -> 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( + name=self.__class__.__name__, + state=", ".join(state), + ) + + def populate_link(self, finder, upgrade, require_hashes): + # type: (PackageFinder, bool, bool) -> None + """Ensure that if a link can be found for this, that it is found. + + Note that self.link may still be None - if Upgrade is False and the + requirement is already installed. + + If require_hashes is True, don't use the wheel cache, because cached + wheels, always built locally, have different hashes than the files + downloaded from the index server and thus throw false hash mismatches. + Furthermore, cached wheels at present have undeterministic contents due + to file modification times. + """ + if self.link is None: + self.link = finder.find_requirement(self, upgrade) + if self._wheel_cache is not None and not require_hashes: + old_link = self.link + supported_tags = pep425tags.get_supported() + self.link = self._wheel_cache.get( + link=self.link, + package_name=self.name, + supported_tags=supported_tags, + ) + if old_link != self.link: + logger.debug('Using cached wheel link: %s', self.link) + + # Things that are valid for all kinds of requirements? + @property + def name(self): + # type: () -> Optional[str] + if self.req is None: + return None + return six.ensure_str(pkg_resources.safe_name(self.req.name)) + + @property + def specifier(self): + # type: () -> SpecifierSet + return self.req.specifier + + @property + def is_pinned(self): + # type: () -> 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 {'==', '==='}) + + @property + def installed_version(self): + # type: () -> Optional[str] + return get_installed_version(self.name) + + def match_markers(self, extras_requested=None): + # type: (Optional[Iterable[str]]) -> bool + if not extras_requested: + # Provide an extra to safely evaluate the markers + # without matching any extra + extras_requested = ('',) + if self.markers is not None: + return any( + self.markers.evaluate({'extra': extra}) + for extra in extras_requested) + else: + return True + + @property + def has_hash_options(self): + # type: () -> bool + """Return whether any known-good hashes are specified as options. + + These activate --require-hashes mode; hashes specified as part of a + URL do not. + + """ + return bool(self.options.get('hashes', {})) + + def hashes(self, trust_internet=True): + # type: (bool) -> Hashes + """Return a hash-comparer that considers my option- and URL-based + hashes to be known-good. + + Hashes in URLs--ones embedded in the requirements file, not ones + downloaded from an index server--are almost peers with ones from + flags. They satisfy --require-hashes (whether it was implicitly or + explicitly activated) but do not activate it. md5 and sha224 are not + allowed in flags, which should nudge people toward good algos. We + always OR all hashes together, even ones from URLs. + + :param trust_internet: Whether to trust URL-based (#md5=...) hashes + downloaded from the internet, as by populate_link() + + """ + good_hashes = self.options.get('hashes', {}).copy() + link = self.link if trust_internet else self.original_link + 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" + """ + if self.req is None: + return None + s = str(self.req) + if self.comes_from: + if isinstance(self.comes_from, six.string_types): + comes_from = self.comes_from + else: + comes_from = self.comes_from.from_path() + if comes_from: + s += '->' + comes_from + return s + + def ensure_build_location(self, build_dir): + # type: (str) -> str + assert build_dir is not None + if self._temp_build_dir is not None: + assert self._temp_build_dir.path + return self._temp_build_dir.path + if self.req is None: + # Some systems have /tmp as a symlink which confuses custom + # builds (such as numpy). Thus, we ensure that the real path + # is returned. + self._temp_build_dir = TempDirectory(kind="req-build") + + return self._temp_build_dir.path + if self.editable: + name = self.name.lower() + else: + name = self.name + # 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) + os.makedirs(build_dir) + write_delete_marker_file(build_dir) + return os.path.join(build_dir, name) + + def _set_requirement(self): + # type: () -> None + """Set requirement after generating metadata. + """ + assert self.req is None + assert self.metadata is not None + assert self.source_dir is not None + + # Construct a Requirement object from the generated metadata + if isinstance(parse_version(self.metadata["Version"]), Version): + op = "==" + else: + op = "===" + + self.req = Requirement( + "".join([ + self.metadata["Name"], + op, + self.metadata["Version"], + ]) + ) + + def warn_on_mismatching_name(self): + # type: () -> None + metadata_name = canonicalize_name(self.metadata["Name"]) + if canonicalize_name(self.req.name) == metadata_name: + # Everything is fine. + return + + # 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 + ) + self.req = Requirement(metadata_name) + + def remove_temporary_source(self): + # type: () -> None + """Remove the source files from this requirement, if they are marked + for deletion""" + if self.source_dir and has_delete_marker_file(self.source_dir): + logger.debug('Removing source in %s', self.source_dir) + rmtree(self.source_dir) + self.source_dir = None + if self._temp_build_dir: + self._temp_build_dir.cleanup() + self._temp_build_dir = None + self.build_env.cleanup() + + def check_if_exists(self, use_user_site): + # type: (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 + # get_distribution() will resolve the entire list of requirements + # anyway, and we've already determined that we need the requirement + # in question, so strip the marker so that we don't try to + # evaluate it. + no_marker = Requirement(str(self.req)) + no_marker.marker = None + try: + self.satisfied_by = pkg_resources.get_distribution(str(no_marker)) + except pkg_resources.DistributionNotFound: + return + except pkg_resources.VersionConflict: + existing_dist = pkg_resources.get_distribution( + self.req.name + ) + if use_user_site: + if dist_in_usersite(existing_dist): + self.should_reinstall = True + elif (running_under_virtualenv() and + dist_in_site_packages(existing_dist)): + raise InstallationError( + "Will not install to the user site because it will " + "lack sys.path precedence to %s in %s" % + (existing_dist.project_name, existing_dist.location) + ) + else: + self.should_reinstall = True + else: + if self.editable and self.satisfied_by: + self.should_reinstall = True + # when installing editables, nothing pre-existing should ever + # satisfy + self.satisfied_by = None + + # Things valid for wheels + @property + def is_wheel(self): + # type: () -> bool + if not self.link: + return False + return self.link.is_wheel + + # Things valid for sdists + @property + def unpacked_source_directory(self): + # type: () -> str + return os.path.join( + self.source_dir, + self.link and self.link.subdirectory_fragment or '') + + @property + def setup_py_path(self): + # type: () -> str + assert self.source_dir, "No source dir for %s" % self + setup_py = os.path.join(self.unpacked_source_directory, 'setup.py') + + # Python2 __file__ should not be unicode + if six.PY2 and isinstance(setup_py, six.text_type): + setup_py = setup_py.encode(sys.getfilesystemencoding()) + + return setup_py + + @property + def pyproject_toml_path(self): + # type: () -> str + assert self.source_dir, "No source dir for %s" % self + return make_pyproject_path(self.unpacked_source_directory) + + def load_pyproject_toml(self): + # type: () -> None + """Load the pyproject.toml file. + + After calling this routine, all of the attributes related to PEP 517 + processing for this requirement have been set. In particular, the + use_pep517 attribute can be used to determine whether we should + 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) + ) + + if pyproject_toml_data is None: + self.use_pep517 = False + return + + self.use_pep517 = True + 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, + ) + + def _generate_metadata(self): + # type: () -> str + """Invokes metadata generator functions, with the required arguments. + """ + if not self.use_pep517: + assert self.unpacked_source_directory + + return generate_metadata_legacy( + build_env=self.build_env, + setup_py_path=self.setup_py_path, + source_dir=self.unpacked_source_directory, + editable=self.editable, + isolated=self.isolated, + details=self.name or "from {}".format(self.link) + ) + + 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 + """Ensure that project metadata is available. + + Under PEP 517, 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() + + # Act on the newly generated metadata, based on the name and version. + if not self.name: + self._set_requirement() + else: + self.warn_on_mismatching_name() + + self.assert_source_matches_version() + + @property + def metadata(self): + # type: () -> Any + if not hasattr(self, '_metadata'): + self._metadata = get_metadata(self.get_dist()) + + return self._metadata + + def get_dist(self): + # type: () -> Distribution + return _get_dist(self.metadata_directory) + + def assert_source_matches_version(self): + # type: () -> None + assert self.source_dir + version = self.metadata['version'] + if self.req.specifier and version not in self.req.specifier: + logger.warning( + 'Requested %s, but installing version %s', + self, + version, + ) + else: + logger.debug( + 'Source in %s has version %s, which satisfies requirement %s', + display_path(self.source_dir), + version, + self, + ) + + # For both source distributions and editables + def ensure_has_source_dir(self, parent_dir): + # type: (str) -> None + """Ensure that a source_dir is set. + + This will create a temporary build dir if the name of the requirement + isn't known yet. + + :param parent_dir: The ideal pip parent_dir for the source_dir. + Generally src_dir for editables and build_dir for sdists. + :return: self.source_dir + """ + if self.source_dir is None: + self.source_dir = self.ensure_build_location(parent_dir) + + # For editable installations + def update_editable(self, obtain=True): + # type: (bool) -> None + if not self.link: + logger.debug( + "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': + # Static paths don't get updated + return + assert '+' in self.link.url, "bad url: %r" % self.link.url + vc_type, url = self.link.url.split('+', 1) + vcs_backend = vcs.get_backend(vc_type) + if vcs_backend: + if not self.link.is_vcs: + reason = ( + "This form of VCS requirement is being deprecated: {}." + ).format( + self.link.url + ) + replacement = None + if self.link.url.startswith("git+git@"): + replacement = ( + "git+https://git@example.com/..., " + "git+ssh://git@example.com/..., " + "or the insecure git+git://git@example.com/..." + ) + deprecated(reason, replacement, gone_in="21.0", issue=7554) + hidden_url = hide_url(self.link.url) + if obtain: + vcs_backend.obtain(self.source_dir, url=hidden_url) + else: + vcs_backend.export(self.source_dir, url=hidden_url) + else: + assert 0, ( + 'Unexpected version control type (in %s): %s' + % (self.link, vc_type)) + + # Top-level Actions + def uninstall(self, auto_confirm=False, verbose=False): + # type: (bool, bool) -> Optional[UninstallPathSet] + """ + Uninstall the distribution currently satisfying this requirement. + + Prompts before removing or modifying files unless + ``auto_confirm`` is True. + + Refuses to delete or modify files outside of ``sys.prefix`` - + thus uninstallation within a virtual environment can only + modify that virtual environment, even if the virtualenv is + linked to global site-packages. + + """ + assert self.req + try: + dist = pkg_resources.get_distribution(self.req.name) + except pkg_resources.DistributionNotFound: + logger.warning("Skipping %s as it is not installed.", self.name) + return None + else: + 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), ( + "name %r doesn't start with prefix %r" % (name, prefix) + ) + 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 + + def archive(self, build_dir): + # type: (str) -> None + """Saves archive to provided build_dir. + + Used for saving downloaded VCS requirements as part of `pip download`. + """ + assert self.source_dir + + create_archive = True + archive_name = '%s-%s.zip' % (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 %s exists. (i)gnore, (w)ipe, (b)ackup, (a)bort ' % + 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)) + os.remove(archive_path) + elif response == 'b': + dest_file = backup_dir(archive_path) + logger.warning( + 'Backing up %s to %s', + display_path(archive_path), + display_path(dest_file), + ) + shutil.move(archive_path, dest_file) + elif response == 'a': + sys.exit(-1) + + if not create_archive: + return + + zip_output = zipfile.ZipFile( + archive_path, 'w', zipfile.ZIP_DEFLATED, allowZip64=True, + ) + with zip_output: + dir = os.path.normcase( + os.path.abspath(self.unpacked_source_directory) + ) + for dirpath, dirnames, filenames in os.walk(dir): + if 'pip-egg-info' in dirnames: + dirnames.remove('pip-egg-info') + for dirname in dirnames: + dir_arcname = self._get_archive_name( + dirname, parentdir=dirpath, rootdir=dir, + ) + zipdir = zipfile.ZipInfo(dir_arcname + '/') + zipdir.external_attr = 0x1ED << 16 # 0o755 + zip_output.writestr(zipdir, '') + for filename in filenames: + if filename == PIP_DELETE_MARKER_FILENAME: + continue + file_arcname = self._get_archive_name( + 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)) + + 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 + scheme = get_scheme( + self.name, + user=use_user_site, + home=home, + root=root, + isolated=self.isolated, + prefix=prefix, + ) + + global_options = global_options if global_options is not None else [] + if self.editable: + install_editable_legacy( + install_options, + global_options, + prefix=prefix, + home=home, + use_user_site=use_user_site, + name=self.name, + setup_py_path=self.setup_py_path, + isolated=self.isolated, + build_env=self.build_env, + unpacked_source_directory=self.unpacked_source_directory, + ) + self.install_succeeded = True + return + + if 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, + ) + self.install_succeeded = True + return + + install_legacy( + self, + install_options=install_options, + global_options=global_options, + root=root, + home=home, + prefix=prefix, + use_user_site=use_user_site, + pycompile=pycompile, + scheme=scheme, + ) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/req/req_set.py b/venv/lib/python3.8/site-packages/pip/_internal/req/req_set.py new file mode 100644 index 0000000..087ac59 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/req/req_set.py @@ -0,0 +1,209 @@ +# The following comment should be removed at some point in the future. +# mypy: strict-optional=False + +from __future__ import absolute_import + +import logging +from collections import OrderedDict + +from pip._vendor.packaging.utils import canonicalize_name + +from pip._internal import pep425tags +from pip._internal.exceptions import InstallationError +from pip._internal.models.wheel import Wheel +from pip._internal.utils.logging import indent_log +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import Dict, Iterable, List, Optional, Tuple + from pip._internal.req.req_install import InstallRequirement + + +logger = logging.getLogger(__name__) + + +class RequirementSet(object): + + def __init__(self, check_supported_wheels=True): + # type: (bool) -> None + """Create a RequirementSet. + """ + + self.requirements = OrderedDict() # type: Dict[str, InstallRequirement] # noqa: E501 + self.check_supported_wheels = check_supported_wheels + + self.unnamed_requirements = [] # type: List[InstallRequirement] + self.successfully_downloaded = [] # type: List[InstallRequirement] + self.reqs_to_cleanup = [] # type: List[InstallRequirement] + + def __str__(self): + # type: () -> str + requirements = sorted( + (req for req in self.requirements.values() if not req.comes_from), + key=lambda req: canonicalize_name(req.name), + ) + return ' '.join(str(req.req) for req in requirements) + + def __repr__(self): + # type: () -> str + requirements = sorted( + self.requirements.values(), + key=lambda req: canonicalize_name(req.name), + ) + + 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), + ) + + def add_unnamed_requirement(self, install_req): + # type: (InstallRequirement) -> None + assert not install_req.name + self.unnamed_requirements.append(install_req) + + def add_named_requirement(self, install_req): + # type: (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]] # noqa: E501 + """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 = pep425tags.get_supported() + if (self.check_supported_wheels and not wheel.supported(tags)): + raise InstallationError( + "%s is not a supported wheel on this platform." % + wheel.filename + ) + + # This next bit is really a sanity check. + assert install_req.is_direct == (parent_req_name is None), ( + "a direct req shouldn't have a parent and also, " + "a non direct req should 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) + 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.specifier != install_req.req.specifier + ) + if has_conflicting_requirement: + raise InstallationError( + "Double requirement given: %s (already in %s, name=%r)" + % (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: + self.reqs_to_cleanup.append(install_req) + raise InstallationError( + "Could not satisfy constraints for '%s': " + "installation from path or url cannot be " + "constrained to a version" % install_req.name, + ) + # If we're now installing a constraint, mark the existing + # object for real installation. + existing_req.constraint = False + 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 + project_name = canonicalize_name(name) + + return ( + project_name in self.requirements and + not self.requirements[project_name].constraint + ) + + def get_requirement(self, name): + # type: (str) -> InstallRequirement + project_name = canonicalize_name(name) + + if project_name in self.requirements: + return self.requirements[project_name] + + raise KeyError("No project with the name %r" % name) + + def cleanup_files(self): + # type: () -> None + """Clean up files, remove builds.""" + logger.debug('Cleaning up...') + with indent_log(): + for req in self.reqs_to_cleanup: + req.remove_temporary_source() diff --git a/venv/lib/python3.8/site-packages/pip/_internal/req/req_tracker.py b/venv/lib/python3.8/site-packages/pip/_internal/req/req_tracker.py new file mode 100644 index 0000000..84e0c04 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/req/req_tracker.py @@ -0,0 +1,150 @@ +# The following comment should be removed at some point in the future. +# mypy: strict-optional=False + +from __future__ import absolute_import + +import contextlib +import errno +import hashlib +import logging +import os + +from pip._vendor import contextlib2 + +from pip._internal.utils.temp_dir import TempDirectory +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from types import TracebackType + from typing import Dict, Iterator, Optional, Set, Type, Union + from pip._internal.req.req_install import InstallRequirement + from pip._internal.models.link import Link + +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 contextlib2.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(object): + + 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. + """ + + # 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 IOError as e: + # if the error is anything other than "file does not exist", raise. + if e.errno != errno.ENOENT: + raise + else: + message = '%s is already being built: %s' % (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') 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. + """ + + # 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/venv/lib/python3.8/site-packages/pip/_internal/req/req_uninstall.py b/venv/lib/python3.8/site-packages/pip/_internal/req/req_uninstall.py new file mode 100644 index 0000000..5971b13 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/req/req_uninstall.py @@ -0,0 +1,644 @@ +from __future__ import absolute_import + +import csv +import functools +import logging +import os +import sys +import sysconfig + +from pip._vendor import pkg_resources + +from pip._internal.exceptions import UninstallationError +from pip._internal.locations import bin_py, bin_user +from pip._internal.utils.compat import WINDOWS, cache_from_source, uses_pycache +from pip._internal.utils.logging import indent_log +from pip._internal.utils.misc import ( + FakeFile, + ask, + dist_in_usersite, + dist_is_local, + egg_link_path, + is_local, + normalize_path, + renames, + rmtree, +) +from pip._internal.utils.temp_dir import AdjacentTempDirectory, TempDirectory +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import ( + Any, Callable, Dict, Iterable, Iterator, List, Optional, Set, Tuple, + ) + from pip._vendor.pkg_resources import Distribution + +logger = logging.getLogger(__name__) + + +def _script_names(dist, script_name, is_gui): + # type: (Distribution, str, bool) -> List[str] + """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 = bin_user + else: + bin_dir = bin_py + 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 + + +def _unique(fn): + # type: (Callable[..., Iterator[Any]]) -> Callable[..., Iterator[Any]] + @functools.wraps(fn) + def unique(*args, **kw): + # type: (Any, Any) -> Iterator[Any] + seen = set() # type: Set[Any] + 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] + """ + Yield all the uninstallation paths for dist based on RECORD-without-.py[co] + + Yield paths to all the files in RECORD. For each .py file in RECORD, add + the .pyc and .pyo in the same directory. + + UninstallPathSet.add() takes care of the __pycache__ .py[co]. + """ + r = csv.reader(FakeFile(dist.get_metadata_lines('RECORD'))) + for row in r: + path = os.path.join(dist.location, row[0]) + yield path + if path.endswith('.py'): + dn, fn = os.path.split(path) + base = fn[:-3] + path = os.path.join(dn, base + '.pyc') + yield path + path = os.path.join(dn, base + '.pyo') + yield path + + +def compact(paths): + # type: (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] + for path in sorted(paths, key=len): + should_skip = any( + path.startswith(shortpath.rstrip("*")) and + path[len(shortpath.rstrip("*").rstrip(sep))] == sep + for shortpath in short_paths + ) + if not should_skip: + short_paths.add(path) + return short_paths + + +def compress_for_rename(paths): + # type: (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 + included every file on disk. + """ + case_map = dict((os.path.normcase(p), p) for p in paths) + remaining = set(case_map) + unchecked = sorted(set(os.path.split(p)[0] + for p in case_map.values()), key=len) + wildcards = set() # type: Set[str] + + def norm_join(*a): + # type: (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): + # This directory has already been handled. + continue + + all_files = set() # type: Set[str] + all_subdirs = set() # type: Set[str] + 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) + # 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. + if not (all_files - remaining): + remaining.difference_update(all_files) + wildcards.add(root + os.sep) + + return set(map(case_map.__getitem__, remaining)) | wildcards + + +def compress_for_output_listing(paths): + # type: (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 + are not added and the top-level directory of the package has a '*' added + at the end - to signify that all it's contents are removed. + + The second set contains files that would have been skipped in the above + folders. + """ + + will_remove = set(paths) + will_skip = set() + + # Determine folders and files + folders = set() + files = set() + for path in will_remove: + if path.endswith(".pyc"): + continue + if path.endswith("__init__.py") or ".dist-info" in path: + folders.add(os.path.dirname(path)) + files.add(path) + + # probably this one https://github.com/python/mypy/issues/390 + _normcased_files = set(map(os.path.normcase, files)) # type: ignore + + folders = compact(folders) + + # This walks the tree using os.walk to not miss extra folders + # that might get added. + for folder in folders: + for dirpath, _, dirfiles in os.walk(folder): + for fname in dirfiles: + if fname.endswith(".pyc"): + continue + + file_ = os.path.join(dirpath, fname) + 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 + } + + return will_remove, will_skip + + +class StashedUninstallPathSet(object): + """A set of file rename operations to stash files while + tentatively uninstalling them.""" + def __init__(self): + # type: () -> None + # Mapping from source file root to [Adjacent]TempDirectory + # for files under that directory. + self._save_dirs = {} # type: Dict[str, TempDirectory] + # (old path, new path) tuples for each move that may need + # to be undone. + self._moves = [] # type: List[Tuple[str, str]] + + def _get_directory_stash(self, path): + # type: (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 + 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 + """Stashes a file. + + If no root has been provided, one will be created for the directory + in the user's temp directory.""" + path = os.path.normcase(path) + head, old_head = os.path.dirname(path), None + save_dir = None + + while head != old_head: + try: + save_dir = self._save_dirs[head] + break + except KeyError: + pass + head, old_head = os.path.dirname(head), head + else: + # Did not find any suitable root + head = os.path.dirname(path) + save_dir = TempDirectory(kind='uninstall') + self._save_dirs[head] = save_dir + + relpath = os.path.relpath(path, head) + if relpath and relpath != os.path.curdir: + return os.path.join(save_dir.path, relpath) + return save_dir.path + + def stash(self, path): + # type: (str) -> str + """Stashes the directory or file and returns its new location. + Handle symlinks as files to avoid modifying the symlink targets. + """ + path_is_dir = os.path.isdir(path) and not os.path.islink(path) + if path_is_dir: + new_path = self._get_directory_stash(path) + else: + new_path = self._get_file_stash(path) + + self._moves.append((path, 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. + # We just created new_path ourselves, so it will + # be removable. + os.rmdir(new_path) + renames(path, new_path) + return new_path + + def commit(self): + # type: () -> 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 + """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) + if os.path.isfile(new_path) or os.path.islink(new_path): + os.unlink(new_path) + elif os.path.isdir(new_path): + rmtree(new_path) + renames(path, new_path) + except OSError as ex: + logger.error("Failed to restore %s", new_path) + logger.debug("Exception: %s", ex) + + self.commit() + + @property + def can_rollback(self): + # type: () -> bool + return bool(self._moves) + + +class UninstallPathSet(object): + """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 + self._moved_paths = StashedUninstallPathSet() + + def _permitted(self, path): + # type: (str) -> bool + """ + Return True if the given path is one we are permitted to + remove/modify, False otherwise. + + """ + return is_local(path) + + def add(self, path): + # type: (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)) + + if not os.path.exists(path): + return + if self._permitted(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' and uses_pycache: + self.add(cache_from_source(path)) + + def add_pth(self, pth_file, entry): + # type: (str, str) -> None + pth_file = normalize_path(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) + 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 + ``auto_confirm`` is True).""" + + if not self.paths: + logger.info( + "Can't uninstall '%s'. No files were found to uninstall.", + self.dist.project_name, + ) + return + + dist_name_version = ( + self.dist.project_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 path in sorted(compact(for_rename)): + moved.stash(path) + logger.debug('Removing file or directory %s', path) + + for pth in self.pth.values(): + pth.remove() + + 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 _display(msg, paths): + # type: (str, Iterable[str]) -> None + if not paths: + return + + logger.info(msg) + with indent_log(): + for path in sorted(compact(paths)): + logger.info(path) + + if not verbose: + 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_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) + if verbose: + _display('Will actually move:', compress_for_rename(self.paths)) + + return ask('Proceed (y/n)? ', ('y', 'n')) == 'y' + + def rollback(self): + # type: () -> 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, + ) + return + logger.info('Rolling back uninstall of %s', self.dist.project_name) + self._moved_paths.rollback() + for pth in self.pth.values(): + pth.rollback() + + def commit(self): + # type: () -> 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): + logger.info( + "Not uninstalling %s at %s, outside environment %s", + dist.key, + dist_path, + sys.prefix, + ) + return cls(dist) + + if dist_path 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, + ) + 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) + + # 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) + # 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: + namespaces = [] + 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) + paths_to_remove.add(path) + paths_to_remove.add(path + '.py') + paths_to_remove.add(path + '.pyc') + paths_to_remove.add(path + '.pyo') + + elif distutils_egg_info: + 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, + ) + ) + + elif dist.location.endswith('.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) + + elif egg_info_exists and dist.egg_info.endswith('.dist-info'): + for path in uninstallation_paths(dist): + paths_to_remove.add(path) + + elif develop_egg_link: + # develop egg + with open(develop_egg_link, 'r') as fh: + link_pointer = os.path.normcase(fh.readline().strip()) + assert (link_pointer == dist.location), ( + 'Egg-link %s does not match installed location of %s ' + '(at %s)' % (link_pointer, dist.project_name, 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) + + else: + logger.debug( + 'Not sure how to uninstall: %s - Check: %s', + dist, dist.location, + ) + + # 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 = bin_user + else: + bin_dir = bin_py + 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(s) + + return paths_to_remove + + +class UninstallPthEntries(object): + def __init__(self, pth_file): + # type: (str) -> None + if not os.path.isfile(pth_file): + raise UninstallationError( + "Cannot remove entries from nonexistent file %s" % pth_file + ) + self.file = pth_file + self.entries = set() # type: Set[str] + self._saved_lines = None # type: Optional[List[bytes]] + + def add(self, entry): + # type: (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 + # paths outside of site-packages, but all the others use forward + # slashes. + # os.path.splitdrive is used instead of os.path.isabs because isabs + # treats non-absolute paths with drive letter markings like c:foo\bar + # as absolute paths. It also does not recognize UNC paths if they don't + # have more than "\\sever\share". Valid examples: "\\server\share\" or + # "\\server\share\folder". Python 2.7.8+ support UNC in splitdrive. + if WINDOWS and not os.path.splitdrive(entry)[0]: + entry = entry.replace('\\', '/') + self.entries.add(entry) + + def remove(self): + # type: () -> None + logger.debug('Removing pth entries from %s:', self.file) + 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' + else: + 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) + lines.remove((entry + endline).encode("utf-8")) + except ValueError: + pass + with open(self.file, 'wb') as fh: + fh.writelines(lines) + + def rollback(self): + # type: () -> bool + if self._saved_lines is None: + 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: + fh.writelines(self._saved_lines) + return True diff --git a/venv/lib/python3.8/site-packages/pip/_internal/self_outdated_check.py b/venv/lib/python3.8/site-packages/pip/_internal/self_outdated_check.py new file mode 100644 index 0000000..8fc3c59 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/self_outdated_check.py @@ -0,0 +1,242 @@ +# The following comment should be removed at some point in the future. +# mypy: disallow-untyped-defs=False + +from __future__ import absolute_import + +import datetime +import hashlib +import json +import logging +import os.path +import sys + +from pip._vendor import pkg_resources +from pip._vendor.packaging import version as packaging_version +from pip._vendor.six import ensure_binary + +from pip._internal.index.collector import LinkCollector +from pip._internal.index.package_finder import PackageFinder +from pip._internal.models.search_scope import SearchScope +from pip._internal.models.selection_prefs import SelectionPreferences +from pip._internal.utils.filesystem import ( + adjacent_tmp_file, + check_path_owner, + replace, +) +from pip._internal.utils.misc import ( + ensure_dir, + get_installed_version, + redact_auth_from_url, +) +from pip._internal.utils.packaging import get_installer +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + import optparse + from optparse import Values + from typing import Any, Dict, Text, Union + + from pip._internal.network.session import PipSession + + +SELFCHECK_DATE_FMT = "%Y-%m-%dT%H:%M:%SZ" + + +logger = logging.getLogger(__name__) + + +def make_link_collector( + session, # type: PipSession + options, # type: Values + suppress_no_index=False, # type: bool +): + # type: (...) -> LinkCollector + """ + :param session: The Session to use to make requests. + :param suppress_no_index: Whether to ignore the --no-index option + when constructing the SearchScope object. + """ + 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), + ) + index_urls = [] + + # Make sure find_links is a list before passing to create(). + find_links = options.find_links or [] + + search_scope = SearchScope.create( + find_links=find_links, index_urls=index_urls, + ) + + link_collector = LinkCollector(session=session, search_scope=search_scope) + + return link_collector + + +def _get_statefile_name(key): + # type: (Union[str, Text]) -> str + key_bytes = ensure_binary(key) + name = hashlib.sha224(key_bytes).hexdigest() + return name + + +class SelfCheckState(object): + def __init__(self, cache_dir): + # type: (str) -> None + self.state = {} # type: Dict[str, Any] + self.statefile_path = None + + # Try to load the existing state + if cache_dir: + self.statefile_path = os.path.join( + cache_dir, "selfcheck", _get_statefile_name(self.key) + ) + try: + with open(self.statefile_path) as statefile: + self.state = json.load(statefile) + except (IOError, ValueError, KeyError): + # Explicitly suppressing exceptions, since we don't want to + # error out if the cache file is invalid. + pass + + @property + def key(self): + return sys.prefix + + def save(self, pypi_version, current_time): + # type: (str, datetime.datetime) -> None + # If we do not have a path to cache in, don't bother saving. + 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)): + 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)) + + 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), + "pypi_version": pypi_version, + } + + text = json.dumps(state, sort_keys=True, separators=(",", ":")) + + with adjacent_tmp_file(self.statefile_path) as f: + f.write(ensure_binary(text)) + + 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) + except OSError: + # Best effort. + pass + + +def was_installed_by_pip(pkg): + # type: (str) -> bool + """Checks whether pkg was installed by pip + + This is used not to display the upgrade message when pip is in fact + installed by system package manager, such as dnf on Fedora. + """ + try: + dist = pkg_resources.get_distribution(pkg) + return "pip" == get_installer(dist) + except pkg_resources.DistributionNotFound: + return False + + +def pip_self_version_check(session, options): + # type: (PipSession, optparse.Values) -> None + """Check for an update for pip. + + Limit the frequency of checks to once per week. State is stored either in + the active virtualenv or in the user's USER_CACHE_DIR keyed off the prefix + of the pip script path. + """ + installed_version = get_installed_version("pip") + if not installed_version: + return + + pip_version = packaging_version.parse(installed_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 = make_link_collector( + 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 = packaging_version.parse(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 = "{} -m pip".format(sys.executable) + 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 + ) + except Exception: + logger.debug( + "There was an error checking the latest version of pip", + exc_info=True, + ) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/__init__.py b/venv/lib/python3.8/site-packages/pip/_internal/utils/__init__.py new file mode 100644 index 0000000..e69de29 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..d9c4fbc2feca77530450b6bbb7ae636b30a9d976 GIT binary patch literal 155 zcmWIL<>g`k0&_FfL=gQLL?8o3AjbiSi&=m~3PUi1CZpdyIxC{<0c4@9Lh@z2(Tp}Es`FJCV){lMN^?@oI`XW=p`*N-dBd) z2nw8AuKo|n(SK>LJ@qHFr_8LRBJr&hIGP7Jk8g(iVlYTOT#p`pBkxC^_ZJDDuK|HC{iqFJxgMR{B#vxIp%fhTC|OVJjqgHdC71(JFlQSlr;dlbi6k8I>MQ>dYocN z%}wdhWU7*5c=QW;3C3x@z0+7ZN6&MRs*!oVI^-8x*QT6zo}ISN@>*JZn95RdjTyV{ z99K})cm}=7bEkphWxjESY4U6#%ehwL^lt>(8?kmM&uo=9P771i6}Tzt;!WMi9{m3D zkC)>3>CeZ%i9cUVr@u~rL2dZVSeG$!v0222xQ}t$JtWS1#V)%xUik=hFg?M0JLp(8 zZc)L=ZxgWz)9y7^gUDpI&;s$^WKhaNUwc4<^Y7z{E9waXdDN7(%r3M#S}wHCk4!Uv z{ln_}CD|r|P=!+Flg63cPB#9>^$HU7a))yBk$8S5pJtsv3S7kFXs#>RM`l~WC63}1 zj>|RG;6o2hZ48wxup21HBoEgWROPvuQwi5T?4TY7M5ux_*(Hw9xrck33dtw`FBRzH zoo(zv7h6duDKZSvbTcHC^EK{mNRq#3-xtL{K-*9EWrHZNXp1;ph|9}C(K4PaM zb}|~au@I`tglJPC&KrEsS_mK@;4YGO7bj{g)}I2P@6$Trd!2eaXyb0s#%@JV6X*f7 yy^TP#)Qwr!a3ILL_@AZS4F=6boBX)`#Qa3>$lgX0CVfBg`}hl4KS-i9O5;!X%}j3q literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/compat.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/compat.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..e81e1c602da88e4713111f50f87656c4c3071594 GIT binary patch literal 6120 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 BLdF09 literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/deprecation.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/deprecation.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..9f81e460ff524d53018e60920c1971deff501286 GIT binary patch literal 2826 zcmaJ@-HzMF73Po>#no!>y5d%{oMXNTJ0wYKZ!!WW~yN=ODF&yW|LJM|QGm_}# zpJ#?EYpuQM`nEtH!M^N+^d)%PtGqxjf&%GxNUc_mi<01Qe$SlqoipE=uXc7i4xZnB z@(c0ruH*cR8k>)g#;5qq-%&_sRfZ!xc(bkm*DPI_T<0psE5;sZx+$<8ZBcGT{vH@YM}aamrH+p_zL zjjqTYdEu2adQV=K7v(N`u1fDqr+4Le*xBQ0F3Uu5I}?`2X_2T@W!7+;=SiGR@#iWN z2biIRS@5~g8M+M@2YG3^RE1V!VdFeA{myr=(&@44qBt;lQd$*3V6N>DeXT-hqfpt7 zq9dgZRzwk+mp^~{=xMb7+5P=LM32834j&F5^xVqZ%NAAmML~i^a=dfz{-ekD_xGMW z{9<^Uk7=9DhoSK)J_8>(${8_0?Mem{-RkP2xVU$&q6P)j zyHWJK6iGAk4@Z;8y7+#7VAEny#Kp}rE5!Iv$(!?;QpwG@oId~E;^R4u4Wc-+N<-;E zY2(BUHW2C;3mrn-&q!4lMab&*I6(dEX`@2lK0Y%-vGk>LxTQa^2q65ww$9R7vZcH9 zmj1GJieSlZS+-=>J$3ax>%B%Gy8&e*P6JbnkK-Et2DW*-Ut*NqqL|y5sy_(%?SM5|8Bc`ef z5h`k$Yxs5&Cy1+5RRO|GWqIXOPvuh!eYK2p@bwOmfNwUm_&EXeYZML(@w&`)*6$C2 z*YP^6>%QHquVeN*(bGa_jrOllvCcClfu(e%_cxC@)&uGxq5sSmo^4qtfPsH_S zDk+pE<~R!{kjIPISmKjOnT?xM9ot2})8TkDs3p&C*L7+?Q7A%0zOUFTj%KM@sTIYs3;{ zk40>-5OJ1k!{b`kFAX1;T7%Bln*gjS(1z;R1FGekE22A~yS9QhZv@jZSLYBtq$bbG z^Z?6&54po?V!~RQ30L#vs!g}FT#Ok+DM5BlRg9TbZ~)M=)+ z&kP{(d&b9<0M8x|6=DNJ-v=m`&Y$1^lY7EW=-g8Z!C8Kd6!M0B?J(!LThke%938-> zR9NIjxBpS)9f_n0t-_sv0%n~E8!q0uGgX;-QRusWp^b=hd=@yNb9`fc>Sg~KL7GTgrxubhu>EIvpmi;8CG3fMfBMn zqM_9rG~^Ref`EgDPO9w<^sDwNII32ST(xCzEL1jDMqk0=A6wTsx8W{^4J8iedIxkH zP^S68{g1!Z!9Q&Ml!dM)QbslfhQr>qsvSi#A2;`kNoh-sJBB8!^)3~p?C3_FcaM-V za^0ufgrNM{Uy(s$tA{z7T&aJ9qWV#)uCEt;yC|?u6Wv$AszJWcbcfJA>TZA2++T->6-oB2|FS%H37A&5^-~$i@ z5gefyI~dEk5-G9jsO4OZv{-j^jHu2w0MjBPt~iz0bWFf?Vvq_kNtM*d60t~~ER#E= z5m-)@s>7K1Zx65``yo?aV%lJn6pSOTr|uy~IvW&ZsYJG4O;v@Hk9p&4w0x!XGT|>()yBb~3c{Qea< z_;oOAbM>iw7dH_z6}A<3fl+tHs9Q4XieUz+V45^AZWgjMm?1T$3(qP{6VBwHq4Zvc lzaUmiyUjQyc|@Pc3gZtzSlCi5MZ*nE0sgo2KU&jN{{e_PFZTcd literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/encoding.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/encoding.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..22e7645e34605a056412369141a3c1f8db0cbb46 GIT binary patch literal 1247 zcmZuv&u<$=6rR~%Uay@tP16cWkyb)Taly74qYzbqs@e`9QnzZ7L$`^n&Cb}~X1u$d znN{k@IRO{`0FKD!#=kUIPC0Xe3%pq;mJiHo-}k=vX5ahf?HsMGc?i~*JD-MIHbQ@D zvbtO#PvI56f+2`thJpp+02kZ{i~`NT1T>g6wgVd@YV!_olR4v3P#U{|J1z%hh@-b2 zu?7ZUh1dmFiBsSjDHV8&xCP!OBMF!Cg`%Yd@i2li&kXyLAQH zP_Ks7#`D)NU-#SJb=yDmUmf*&-}k<)nabLag;e%oo-wMdL;7A`*ts0kcP|_bk9RK0 z3#^~grOW6d+uB})THDJkxQvSX&@)O&oDAPQ`TFEoJlc9wKR$1qd{&FF)^oiqKo~4) z!z+FVBT)yPe12?P;!9(SW_XI{m|IgMjVb;S6a2IBA)1*}V~!1k(E)k~xtT?P6HH8< zh3`9;=F}t>u{9^onZY~Ko;gz!YAwB4X^x1ctC7-t(QUPE2kM&Aot23@$JuYvn^op$ zt_NDa_@zCf(U~9mrxQtqFC>R^`h%21=-G?szD)fn<(x*6O?*NnIKCWFpC*fuc%Bby zFJ$aAggUUDrBTReV@PGj>43tw=U%+v-phqX-1Q+nx7{A%ZVJNNvrpl9;bI@ zfaTh~(xwQ0qU=yaalBWnDhp&CC{M_cOK~2{kun)gltU;eqRJK-i>0b`d+iq;xEB3a zUF8TG@@S--Ay4y6C}*KjZT_D~Wr~SV8;~M&5avwYsIOVdBB2bGd76%udlOa`ixc_> z;va$9f1WnwIBRBcR?m|RCPGR5d_*a$$NBKx?&OPeoon{vL{grFteMN0iRMkMMmABE zFqdh6aT;AxY=S{{6?^!haUVaxAK-Ot;q`y{#}KdGQ;t4&B=}vR%HWjW)6N6v(^&Rt z6nz?UlELrgdcw-NCMFQBFE7`(SGh3W{?Xyyt}0)9k9Smc>Gq#>SJ{4dxvjOmOtiLF zw*lMl@`^5AiqdfwGs@R>Kdrx*+KPEtX!vTJlAO_Rv@GF+adGh&Rl~xY<~3Wy{1L`=H>Ws%%1`+8r*t#p>DS3( z_B-Mv>qXk(ADoF0y|1m5b6EruzH~8Df>vw!=ex z;7Zc&Uk*X+1i>6_0WNB31TWyZs8|~W*cxOAtq21a^D;=Yh1y#U zSI@35mk_#8I2M~F=vGDPlz^))Hr9kC#70OD$OYq6lsf)nhJ&^t4tR);Yc$f?5iA?{ zNfRQH6?_TEzy}CzU1OR=w}U9PK#(KWuoZEnr|k~8k7-|9s)^W176k^80UT;G#&_QC zBu5y~qH36tK@UaTGjE8;7#5ihB)Rkg+2j9#YeZlJSb1-qAJCm*l^6gTq1+Po0*u`s zYB?%XkLkAl{~`g3anLag5Euih)_YV1tP#an_j@S&H_u*>k)Di23UDiklQcW~o#1fW z5iPPnsJwLXAJhV_DfzubgVana+<&tY|=4NM&?JF~3rRq3A&fXkv8XNm*`X zY}(tRvbuDgVZImjM zM~9?vT|c`yh(?fMhD~xlO|!r9nLoq+B3&=u@>A^f?_s3kU$ml9vY<<1pw{30@8l4w xh@Hct`3dcw9tL=gCH{mOf*%q&YTl-$v!~kfR*8@3Dhb4EmYt<%S)RT#`5S)ij2r*} literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/filesystem.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/filesystem.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..3bbdfc1603592aa2e2af88df008982205354d20f GIT binary patch literal 4035 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 literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/filetypes.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/filetypes.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..71366cd6913187ec306c8d6ab72968d9c74a5980 GIT binary patch literal 556 zcmY*VO-sW-6x?i+Cat!Dh=M0C9&%^`A}T0iEzuS=N?X775~91Ui<>m23AOu={7bod z@-KMNmsqsE-J|B^uR8nU;x8b*2q4F{nW*%wXj;#46DG8X{F%=^?W!S5LTL$uwdcJRFST zz)$!nw5lI437JZ^d~ttu@3q=a>&)w3yKcul1y$>(kzi7_CQrh|(y$UgwjSgbD9M8~ zHK`ZMtIUNT6mllQrBb*;20r+bM`mf}4T}dq=*OJ@f*mUG>v#n~#fw-~@`i&A==#?;7MYn) literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/glibc.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/glibc.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..b431e01f27a02ffd8a97de3db84ae34ac0c6c7bb GIT binary patch literal 1708 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 literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/inject_securetransport.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/inject_securetransport.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..c209d4807737756a867658cf984598ecea0da7d7 GIT binary patch literal 932 zcmZuwOK;Oa5Z<+&)-`=ZAQh=dXfH?@HBNa5I3QF&IaDeRs#_ktSR3!QakANUch?O; z^aMWyj{GHGIq?@bF?Ld^s#s}9GufGMzM0QCT3ZVcoM%t((FZOXmV zRGLC*yG@iN`J{HEAUGWIML^6@m4cB0Crn9Bs3DwcF{_2+$rCsuYrf69RkK96%PMmi63zwsfaIo!tUC_$4h9V{`UDCk=p*`y zMjms=Exp@Rw4uTit;x~_#&y+JU1gU~9H<;!tHeM2pS7NV6Sm@NiBUbxr3PJ5zR^bQ z5LX+f5z$_X7_L;VnVHHj1hpqhParg+y0O>j+S6L;YP0{Y7sEQz_q~H;uOFxJ(c9O( zgX&I^7g2i7B~v;owGjE>ag-@(bw1GWJ)&y4pUfd{&9|QB(yDZk8ajFjlA6q4NUwtb zH}2X=(FNR2DGQo`79G%ri%wpio;{yEnbvRJ8is30MYpuMFx>_Cwb7ztR&D^piLUPHH9PE)3`G}Ru&&5sS!E2ajk{1@|o%*%S&rk=}N I@m>G+KWIV$FaQ7m literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/logging.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/logging.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..04c80d0f07c62949d9e39b3c66be95294b7dbaa8 GIT binary patch literal 9159 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 G#Qz6C{+*xz literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/models.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/models.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..7644515642878d5455abe649aca8a838ecb077d0 GIT binary patch literal 1924 zcmb_cO>fgc5Z$$%)J>E08zfMXB?M9qZ7v8nR8>U}2q7Y*suId&<$AV_Q^$69H~atC|y1|GGP>&P-^caQ69*XFb?BWua|&~bma%4 zuvS3hWV7&PAG`j9gJf-vf3koRD%jVo?SKO%v?VCR0@^aTu!wd6DzJpsg(}q0EmpVP}q((Me|0ZvFSo8>SW!_vc>I^wMS;rrZ5E^@B4B+ZP=vqwTPN zdj5Lw;)3>?B8-hxu^%=2cr3bEoWf2z$XtPYp%J1+ROyr%FZ0W-y9C-9`v#o+MvdmT zvC<_nY{K^2MYqYKZ{vfY$AiL zd06}pE#&zOEgm2PZw?j&aBnT*Sz6GYcsd6Q0{Ej$QHthi^8_cDx>%?%c`dzSFmb40 zb?qVV+E=$}2Ae7n#0B4&|OSodl*YG+q1W z*frGz#;e@1W>ub1;9HO>NH0xEwrxbE0;UA>$vvhqsXJ-DAI3~!^v@11}5K_fXmT~ Sa<^O1-lN)?7hR|1+P?q{=8{MN literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/packaging.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/packaging.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..cfcb4ef4b798f542207f2ce2c78bd724a5cf0a77 GIT binary patch literal 2608 zcmaJ@%Wm676y=bVMA4MxR~$P@(`kSN5fI636SRd<6fqnpH4-a^?EnpnfMUdvM4PY7 zjN;mmfwu0lAJC<|>@W0FrpvDS3*EGLhLRvVKq+vZmzQ_$J?BubDivFU>&q|h`hU)7 z+Fx=qeHk!$3^)4&nm`Lsq{YZZNRIVLcXjBE$cRnXRBL8bh>LDfjSEpJwp=SNyJa;m zMs_^o&Zu!Ia^i|xQDZBbjjL`IX{1Vj1%KseE}nPi;{|s??c32}yyPya@l13rUUrwk zRv%s`D;LOJ4V<9zi{{=4W`ip9H-oug9{O9sLa+$^M}fYt)t3H-__Z1mRsStZqdq5I z7-uQvO<1#^5)$nClo1NEN_N!sC}C-zwh620!e$w1hnpWGCX9Dj2XSN6zT{ z%ix_U-Kki*iEMot(HpSV23SrmiFKI+h4mj{5TG-}0r4Ci>gPJWH_(R00FbRlrW~E= z$)|EP0L0VBfqn*j7>;+Ad0|)#3|<;&ht@f|&_PekGku^31z=E*mj{~U%Fl?~=bB{8 zaAp90kOm{?LId6uPk+i`PV-uS!2k6z%0L7r1eS0Iong2IMfc*7Ufi#>CfJey#lUvl z>JmO}F@hSy@=ZB9gtfDEu<>N$VB^%BoxFHZUhmsMI8C z$ThPAQYs4VC}jjNY06B9$~ZVL@na&a@l?!6YmiE*yb5!9vnt(TXdb}LZbPFLP2?c! zUtM>QjbN-VAXB#hIz_`q%Jvd?WGwPl;JF6_37m5P&;Silpr8VU*N@8d4hIOp4zy5W zXDRq;dF8;37xi+wy@><1W@WVMtR(A6a6c%*iD0Z*%Ymu0kBGgSP-fRxik zh!qxO$oYpzil`TaZBCb9?MjlwqAb%Dc0B{ToLxnkAj`0HDie7rLGr6INzmso0j2=M zfHw^osT4iY-mIvE=@%MZg2X|uYY3R|Zb^MpjixAXH}?-VUcA`aqqo2bME)^!VqqFR zUKA#TiGrj=Rs-Tn3sWv$JxxVErmz}CgnkEh`8jkO%_0kK`k8#mZDD&}rw=MjJdetg zh>`>-08=<5_QR+#f|NX=m;se)fVL$;N)-XzYf~#=I?^kpxVgrzD1))EHOLQbqCVJ6 zAzfVAR=U@SL)OlDapUsS`8GevByq|zqT*;GC6L0uE+};#cAWnQpbo6LtCymj{!cqX8>%TvsPYzKIUK2>wp3K7xuI}+RCIQ*eK|DB#-y;yE`7PtaJ#BN8fxI{9zOFJ1(jN z_Q(_X^*#_m1dT~TeM*sMF-t7pGQ1VrNyBeYA{**4oY`?RY5A?h@tvgYw<&o>L_;*+ z5z&;LOUv(y)&cRHKS3+;Xwf~7WGr|brBcJPBU3$9lIvW-YW?}q{t@5a-P!(u|8zJS z?Twy!R$)Jl!n|u`KK#Bb|q+uR0hkp1`knfk@(0L3}2tZwV%>cf_}aEgCR` zZ=wZrQ#hgxb4zqY7iLHF#0t!9u`1SJ?ub74eW&Q5_2)7VM34uw?Y)xSSJ|6LNaf}y zLGCIU2<;|IG50u%rFM^1mbif{KtYtHfjS>_To@s`S`Os#--cgfhURomIDmdYuIT8B z7HwW?^;ltR86Ou;xpPI-DqQ(%XP76G;Ut=DP18vbo=LIw_C(5fE1Hg9e|!GmEuIZ| zlmdil5D%w$6zk#SY|NF^*;Iv64<_e@!$Bm8U0x1 z*U{et8B+*^G1{knc9+iTC{(3uC}760jSUJ|7>L1pz~BSDq|01*Ore&OSP_&V1Xxtl> z(NWWsFGRlv#bpvcuKDwi%*g9v6QerLiw@^WCZ;j+JB#H(8}R51_#2suObu#}jVVEY zt$MDbpG{8{n`XCsss`q%8sz7bC><*-p`y85G+?2cNLpq)dvz+q+*rTO>B4!uK;t`1 PkLj=;?Xe!S>0Rq@*Ak$N literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/setuptools_build.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/setuptools_build.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..b50b823d835124d7b461efcacb78baac1262c60a GIT binary patch literal 2927 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 literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/temp_dir.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/temp_dir.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..00114e619f9632393fc4cd33b0ac0ed18c61232d GIT binary patch literal 6711 zcmcgw&2!tv6~`Arkdi1_{&s8!apj5G+H#sWiJQ7<)^bc?k>F+JTFG-&1so-D<56_*foI_eLECDfNxy^HtR@F3m~G8gUN2#q^h_0V_FS*z-D z+FwnRxGk6$HChQ5%lK9alBQr!MZ<6Ub;j|fwDdF*cZ452#EZ=vf-{Dv*&Fw7-S@73 zvUK%V-tEtpm#;5hs}`iW(A<>PViXAJTo;V{BH_}x*%DFG^kZ3E*=(`TeJ%}eMNX}- zMr$$REI^}8h%Bro?PeIz?E061hZ1i3n7)ldXj|I1XL_2@yPBc(bYJh3L+x`-*Y0ZX zYF)hFQ%}FvZfp0jns>Ap`f}CawBT~a6Bsg#xYt+DkcE^~lLwPH++F)Z;|J00{n6#kOHZioq8Gt%99mv%izrSn(oi18ns05&BlS30 z_2be4)2%rjdCca^RCkE4W_U0i`qqvsbr(?qV~ zR`~?1_MSW%Au^+eDZe`0U6S+Mu zqHU&bp))r&lhLJ_A9e_oZP1G@dL|eT6^6RodRGti9rA0V^V@4oxNzXLsNUu*9G$wm z7W;K~Eg>6Z>W+=?3Si^>K)aBw`R!P^E40 zPlPvq1jU=UQwN2kTc%?|c+{+q2{@-}6c9&E(T|Lo z?QVcKlW;^GW%73GTy;#=qN00R9=5L@sxfBV%z!^SUf=ZR-6$jDOjp|A>-W{OjcGF(v)$6)Dq`Nx26DD z#=RWc)j}SkNDjY%4yvo1$!IFx%yXd-!Mfym%FV#4L-HhkWw=wKeyv!sW^~Iyx?(w;LGhX&5eQ)06uV)^E&VH4aKluV>CC~QAXa%t z;`%|rKmoZST+-(Q_gSxM@$-KFHyr? z##dTB9Dt%d`O~$j{1^A+k;IkGzeffGOdEfY;;O|HyNfo@LgGt0BQ99%|Yf;Q(vGFjZ z7llV@$4MRAI#~$WYP+7NuNjvpfR0<2{}8tLGwv)eaBO`B-ZG!Np@8> zJ%a~DjUd(y1C*(4SUWmDEeiCsMPx{JG&?`P%^JyL1d;s%$skx#^rzq~Tx{R+{K>_& zvRt(@I`}z;%&cN##Z!@HoIohv&kgzesCa=pB_L>)tylJ_*$1b!yv%7M_HlJ8^KDX( z|A2})Du^+q)8fbmx!BA+|6Qt}WSD&cH{%VkG^6%xv_0@R2G6hT%?T%Sl$uC?Rw8Ij0-O1F>R!?CmYHKxt~CztC?U-)wVXJ_B~@!RiQdiTBe zFaKnD-~F@+u%v|OuD%VY-Jy&|7a+r~wq-LIvSYF#FCH!>Ykt{`CY!F z@)4SFcoBsz#f)?_#n^5z5OLncrpBd4%|r}jWF6>03@3$3eCnQ~6Nc3U!f$P2=g?H4 z4?zuC+ZrADAW0?N1~T&A)uDTQM=8xq{Y$BV%4LE3%{r52%$l+kK^>7KaVk#*Nn;hH zpyYX^4CPQ{g$DdpPJOzxu!sXm98WIXz9X%TBx=&(WPq*~*+J@&EMYSkMj^~DohEyt zP8@b+i*nkl=S!oi(|-`KTohV)7Ac0M+21?H38WikGkZ7iK8yFx*;l}JT;5m~LPrl1 zxUb?)|B52ZLJ%Q=%Lhi!=)ncIEkY@9x7xE*J#99u9ivz10GZo%w?J9RU9I_+rHSIh zGLLnwXX{#Lwrg)V!r3SR%@4j(XQUx&zO?UY_q9hS?`5Nvsei8kr2pyBNhQB5CN?IK z1x<})K?PCSo<5M5cBab zsG#IP7AduZ>&s%2srGN&`*|D^KiKjRQms&WV1doxc#GIi0z2I>YB>DhT16)RQF~`hBX>(aef!VP~kC z&cLOetZv{;S{-Wfv-J5*DkvGs0?N>UgZLqxE7@`3hr}W&?F%QdSMC2M4gB;;Yzs~r TlV;hpOxSi}=BWCw%&h(wa*B}E literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/typing.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/typing.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..6ad94fe2e5608470190565bb909d60971469d883 GIT binary patch literal 1437 zcmZWpO^@3)5S7;6%|bwW=&|U5m$X>GlF+0`i$xK%U3Al+s1c-_L-yjO#j!<1B2|9a z70_ex3a0x>4wU=%^Qlnx`$lw>}#1FGQ6U;4Wk&;p<5WXQ>`8)xq_ zY;Ek6SP~axT_7c75H6ywo_Q)JrMRTfVqqnHiPC>|4d_fJZ4Q-^$sZWijlV z4}=FUm5uGWsUQum0OoEKz;M(<#AFsjXb`GS6W+wO;#k>053gA-r5!4SZB=xf>d;`Q ze#MIHZ3bcof3XJ-%*8rNmkfY5>xO_~;4@@ASixH)26b69z_t-+Qp1KCUQ4VU$)*)8 z!Lo@s+Rkl2?icBx%vj9B@hA^sI_l6(It!g`U+za$wEJu-4v3^7WI)Up*}@|HYk?o#ne}BYkN2D!P66JI8y0*W*Xlem31bSS*xn7K`1dAFHxE+3!!m@3`#0P5`z${ci85 SXIzgz#W4MRI+^C5O#cU963LDL literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/ui.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/ui.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..8f846c63cd0590d8daac41acba29bc282e8df276 GIT binary patch literal 11802 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 UXLyQJlHm-JiSbI5cGJcG0TG~irT_o{ literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/virtualenv.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/virtualenv.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..012f6d674cb7141355725c08c715960f7a4d0fc3 GIT binary patch literal 3280 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 literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/appdirs.py b/venv/lib/python3.8/site-packages/pip/_internal/utils/appdirs.py new file mode 100644 index 0000000..93d17b5 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/utils/appdirs.py @@ -0,0 +1,44 @@ +""" +This code wraps the vendored appdirs module to so the return values are +compatible for the current pip code base. + +The intention is to rewrite current usages gradually, keeping the tests pass, +and eventually drop this after all usages are changed. +""" + +from __future__ import absolute_import + +import os + +from pip._vendor import appdirs as _appdirs + +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import List + + +def user_cache_dir(appname): + # type: (str) -> str + return _appdirs.user_cache_dir(appname, appauthor=False) + + +def user_config_dir(appname, roaming=True): + # type: (str, bool) -> str + return _appdirs.user_config_dir(appname, appauthor=False, roaming=roaming) + + +def user_data_dir(appname, roaming=False): + # type: (str, bool) -> str + return _appdirs.user_data_dir(appname, appauthor=False, roaming=roaming) + + +# for the discussion regarding site_config_dir locations +# see +def site_config_dirs(appname): + # type: (str) -> List[str] + 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] diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/compat.py b/venv/lib/python3.8/site-packages/pip/_internal/utils/compat.py new file mode 100644 index 0000000..6efa52a --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/utils/compat.py @@ -0,0 +1,269 @@ +"""Stuff that differs in different Python versions and platform +distributions.""" + +# The following comment should be removed at some point in the future. +# mypy: disallow-untyped-defs=False + +from __future__ import absolute_import, division + +import codecs +import locale +import logging +import os +import shutil +import sys + +from pip._vendor.six import PY2, text_type + +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import Optional, Text, Tuple, Union + +try: + import ipaddress +except ImportError: + try: + from pip._vendor import ipaddress # type: ignore + except ImportError: + import ipaddr as ipaddress # type: ignore + ipaddress.ip_address = ipaddress.IPAddress # type: ignore + ipaddress.ip_network = ipaddress.IPNetwork # type: ignore + + +__all__ = [ + "ipaddress", "uses_pycache", "console_to_str", + "get_path_uid", "stdlib_pkgs", "WINDOWS", "samefile", "get_terminal_size", +] + + +logger = logging.getLogger(__name__) + +if PY2: + import imp + + try: + cache_from_source = imp.cache_from_source # type: ignore + except AttributeError: + # does not use __pycache__ + cache_from_source = None + + uses_pycache = cache_from_source is not None +else: + uses_pycache = True + from importlib.util import cache_from_source + + +if PY2: + # In Python 2.7, backslashreplace exists + # but does not support use for decoding. + # We implement our own replace handler for this + # situation, so that we can consistently use + # backslash replacement for all versions. + def backslashreplace_decode_fn(err): + raw_bytes = (err.object[i] for i in range(err.start, err.end)) + # Python 2 gave us characters - convert to numeric bytes + raw_bytes = (ord(b) for b in raw_bytes) + return u"".join(u"\\x%x" % c for c in raw_bytes), err.end + codecs.register_error( + "backslashreplace_decode", + backslashreplace_decode_fn, + ) + backslashreplace_decode = "backslashreplace_decode" +else: + backslashreplace_decode = "backslashreplace" + + +def has_tls(): + # type: () -> bool + try: + import _ssl # noqa: F401 # ignore unused + return True + except ImportError: + pass + + from pip._vendor.urllib3.util import IS_PYOPENSSL + return IS_PYOPENSSL + + +def str_to_display(data, desc=None): + # type: (Union[bytes, Text], Optional[str]) -> Text + """ + For display or logging purposes, convert a bytes object (or text) to + text (e.g. unicode in Python 2) safe for output. + + :param desc: An optional phrase describing the input data, for use in + the log message if a warning is logged. Defaults to "Bytes object". + + This function should never error out and so can take a best effort + approach. It is okay to be lossy if needed since the return value is + just for display. + + We assume the data is in the locale preferred encoding. If it won't + decode properly, we warn the user but decode as best we can. + + We also ensure that the output can be safely written to standard output + without encoding errors. + """ + if isinstance(data, text_type): + return data + + # Otherwise, data is a bytes object (str in Python 2). + # First, get the encoding we assume. This is the preferred + # encoding for the locale, unless that is not found, or + # it is ASCII, in which case assume UTF-8 + encoding = locale.getpreferredencoding() + if (not encoding) or codecs.lookup(encoding).name == "ascii": + encoding = "utf-8" + + # Now try to decode the data - if we fail, warn the user and + # decode with replacement. + try: + decoded_data = data.decode(encoding) + except UnicodeDecodeError: + if desc is None: + desc = 'Bytes object' + msg_format = '{} does not appear to be encoded as %s'.format(desc) + logger.warning(msg_format, encoding) + decoded_data = data.decode(encoding, errors=backslashreplace_decode) + + # Make sure we can print the output, by encoding it to the output + # encoding with replacement of unencodable characters, and then + # decoding again. + # We use stderr's encoding because it's less likely to be + # redirected and if we don't find an encoding we skip this + # step (on the assumption that output is wrapped by something + # that won't fail). + # The double getattr is to deal with the possibility that we're + # being called in a situation where sys.__stderr__ doesn't exist, + # or doesn't have an encoding attribute. Neither of these cases + # should occur in normal pip use, but there's no harm in checking + # in case people use pip in (unsupported) unusual situations. + output_encoding = getattr(getattr(sys, "__stderr__", None), + "encoding", None) + + if output_encoding: + output_encoded = decoded_data.encode( + output_encoding, + errors="backslashreplace" + ) + decoded_data = output_encoded.decode(output_encoding) + + return decoded_data + + +def console_to_str(data): + # type: (bytes) -> Text + """Return a string, safe for output, of subprocess output. + """ + return str_to_display(data, desc='Subprocess output') + + +def get_path_uid(path): + # type: (str) -> int + """ + Return path's uid. + + Does not follow symlinks: + https://github.com/pypa/pip/pull/935#discussion_r5307003 + + Placed this function in compat due to differences on AIX and + Jython, that should eventually go away. + + :raises OSError: When path is a symlink or can't be read. + """ + if hasattr(os, 'O_NOFOLLOW'): + fd = os.open(path, os.O_RDONLY | os.O_NOFOLLOW) + file_uid = os.fstat(fd).st_uid + os.close(fd) + else: # AIX and Jython + # WARNING: time of check vulnerability, but best we can do w/o NOFOLLOW + if not os.path.islink(path): + # older versions of Jython don't have `os.fstat` + file_uid = os.stat(path).st_uid + else: + # raise OSError for parity with os.O_NOFOLLOW above + raise OSError( + "%s is a symlink; Will not return uid for symlinks" % path + ) + return file_uid + + +def expanduser(path): + # type: (str) -> str + """ + Expand ~ and ~user constructions. + + Includes a workaround for https://bugs.python.org/issue14768 + """ + expanded = os.path.expanduser(path) + if path.startswith('~/') and expanded.startswith('//'): + expanded = expanded[1:] + return expanded + + +# packages in the stdlib that may have installation metadata, but should not be +# considered 'installed'. this theoretically could be determined based on +# dist.location (py27:`sysconfig.get_paths()['stdlib']`, +# py26:sysconfig.get_config_vars('LIBDEST')), but fear platform variation may +# make this ineffective, so hard-coding +stdlib_pkgs = {"python", "wsgiref", "argparse"} + + +# windows detection, covers cpython and ironpython +WINDOWS = (sys.platform.startswith("win") or + (sys.platform == 'cli' and os.name == 'nt')) + + +def samefile(file1, file2): + # type: (str, str) -> bool + """Provide an alternative for os.path.samefile on Windows/Python2""" + if hasattr(os.path, 'samefile'): + return os.path.samefile(file1, file2) + else: + path1 = os.path.normcase(os.path.abspath(file1)) + path2 = os.path.normcase(os.path.abspath(file2)) + return path1 == path2 + + +if hasattr(shutil, 'get_terminal_size'): + def get_terminal_size(): + # type: () -> Tuple[int, int] + """ + Returns a tuple (x, y) representing the width(x) and the height(y) + in characters of the terminal window. + """ + return tuple(shutil.get_terminal_size()) # type: ignore +else: + def get_terminal_size(): + # type: () -> Tuple[int, int] + """ + Returns a tuple (x, y) representing the width(x) and the height(y) + in characters of the terminal window. + """ + def ioctl_GWINSZ(fd): + try: + import fcntl + import termios + import struct + cr = struct.unpack_from( + 'hh', + fcntl.ioctl(fd, termios.TIOCGWINSZ, '12345678') + ) + except Exception: + return None + if cr == (0, 0): + return None + return cr + cr = ioctl_GWINSZ(0) or ioctl_GWINSZ(1) or ioctl_GWINSZ(2) + if not cr: + if sys.platform != "win32": + try: + fd = os.open(os.ctermid(), os.O_RDONLY) + cr = ioctl_GWINSZ(fd) + os.close(fd) + except Exception: + pass + if not cr: + cr = (os.environ.get('LINES', 25), os.environ.get('COLUMNS', 80)) + return int(cr[1]), int(cr[0]) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/deprecation.py b/venv/lib/python3.8/site-packages/pip/_internal/utils/deprecation.py new file mode 100644 index 0000000..2f20cfd --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/utils/deprecation.py @@ -0,0 +1,104 @@ +""" +A module that implements tooling to enable easy warnings about deprecations. +""" + +# The following comment should be removed at some point in the future. +# mypy: disallow-untyped-defs=False + +from __future__ import absolute_import + +import logging +import warnings + +from pip._vendor.packaging.version import parse + +from pip import __version__ as current_version +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import Any, Optional + + +DEPRECATION_MSG_PREFIX = "DEPRECATION: " + + +class PipDeprecationWarning(Warning): + pass + + +_original_showwarning = None # type: Any + + +# Warnings <-> Logging Integration +def _showwarning(message, category, filename, lineno, file=None, line=None): + if file is not None: + if _original_showwarning is not None: + _original_showwarning( + message, category, filename, lineno, file, line, + ) + elif issubclass(category, PipDeprecationWarning): + # We use a specially named logger which will handle all of the + # deprecation messages for pip. + logger = logging.getLogger("pip._internal.deprecations") + logger.warning(message) + else: + _original_showwarning( + message, category, filename, lineno, file, line, + ) + + +def install_warning_logger(): + # type: () -> None + # Enable our Deprecation Warnings + warnings.simplefilter("default", PipDeprecationWarning, append=True) + + global _original_showwarning + + if _original_showwarning is None: + _original_showwarning = warnings.showwarning + warnings.showwarning = _showwarning + + +def deprecated(reason, replacement, gone_in, issue=None): + # type: (str, Optional[str], Optional[str], Optional[int]) -> None + """Helper to deprecate existing functionality. + + reason: + Textual reason shown to the user about why this functionality has + been deprecated. + 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 + this. + 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 {}."), + (issue, ( + "You can find discussion regarding this at " + "https://github.com/pypa/pip/issues/{}." + )), + ] + message = " ".join( + template.format(val) for val, template in sentences if val 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 PipDeprecationWarning(message) + + warnings.warn(message, category=PipDeprecationWarning, stacklevel=2) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/distutils_args.py b/venv/lib/python3.8/site-packages/pip/_internal/utils/distutils_args.py new file mode 100644 index 0000000..e38e402 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/utils/distutils_args.py @@ -0,0 +1,48 @@ +from distutils.errors import DistutilsArgError +from distutils.fancy_getopt import FancyGetopt + +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + 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/venv/lib/python3.8/site-packages/pip/_internal/utils/encoding.py b/venv/lib/python3.8/site-packages/pip/_internal/utils/encoding.py new file mode 100644 index 0000000..ab4d4b9 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/utils/encoding.py @@ -0,0 +1,42 @@ +# The following comment should be removed at some point in the future. +# mypy: strict-optional=False + +import codecs +import locale +import re +import sys + +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import List, Tuple, Text + +BOMS = [ + (codecs.BOM_UTF8, 'utf-8'), + (codecs.BOM_UTF16, 'utf-16'), + (codecs.BOM_UTF16_BE, 'utf-16-be'), + (codecs.BOM_UTF16_LE, 'utf-16-le'), + (codecs.BOM_UTF32, 'utf-32'), + (codecs.BOM_UTF32_BE, 'utf-32-be'), + (codecs.BOM_UTF32_LE, 'utf-32-le'), +] # type: List[Tuple[bytes, Text]] + +ENCODING_RE = re.compile(br'coding[:=]\s*([-\w.]+)') + + +def auto_decode(data): + # type: (bytes) -> Text + """Check a bytes string for a BOM to correctly detect the encoding + + Fallback to locale.getpreferredencoding(False) like open() on Python3""" + for bom, encoding in BOMS: + if data.startswith(bom): + return data[len(bom):].decode(encoding) + # Lets check the first two lines as in PEP263 + for line in data.split(b'\n')[:2]: + if line[0:1] == b'#' and ENCODING_RE.search(line): + encoding = ENCODING_RE.search(line).groups()[0].decode('ascii') + return data.decode(encoding) + return data.decode( + locale.getpreferredencoding(False) or sys.getdefaultencoding(), + ) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/entrypoints.py b/venv/lib/python3.8/site-packages/pip/_internal/utils/entrypoints.py new file mode 100644 index 0000000..befd01c --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/utils/entrypoints.py @@ -0,0 +1,31 @@ +import sys + +from pip._internal.cli.main import main +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import Optional, List + + +def _wrapper(args=None): + # type: (Optional[List[str]]) -> int + """Central wrapper for all old entrypoints. + + Historically pip has had several entrypoints defined. Because of issues + arising from PATH, sys.path, multiple Pythons, their interactions, and most + of them having a pip installed, users suffer every time an entrypoint gets + moved. + + To alleviate this pain, and provide a mechanism for warning users and + directing them to an appropriate place for help, we now define all of + our old entrypoints as wrappers for the current one. + """ + sys.stderr.write( + "WARNING: pip is being invoked by an old script wrapper. This will " + "fail in a future version of pip.\n" + "Please see https://github.com/pypa/pip/issues/5599 for advice on " + "fixing the underlying issue.\n" + "To avoid this problem you can invoke Python with '-m pip' instead of " + "running pip directly.\n" + ) + return main(args) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/filesystem.py b/venv/lib/python3.8/site-packages/pip/_internal/utils/filesystem.py new file mode 100644 index 0000000..6f1537e --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/utils/filesystem.py @@ -0,0 +1,171 @@ +import errno +import os +import os.path +import random +import shutil +import stat +import sys +from contextlib import contextmanager +from tempfile import NamedTemporaryFile + +# NOTE: retrying is not annotated in typeshed as on 2017-07-17, which is +# why we ignore the type on this import. +from pip._vendor.retrying import retry # type: ignore +from pip._vendor.six import PY2 + +from pip._internal.utils.compat import get_path_uid +from pip._internal.utils.typing import MYPY_CHECK_RUNNING, cast + +if MYPY_CHECK_RUNNING: + from typing import BinaryIO, Iterator + + class NamedTemporaryFileResult(BinaryIO): + @property + def file(self): + # type: () -> BinaryIO + pass + + +def check_path_owner(path): + # type: (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"): + return True + + assert os.path.isabs(path) + + previous = None + while path != previous: + if os.path.lexists(path): + # Check if path is writable by current user. + if os.geteuid() == 0: + # Special handling for root user in order to handle properly + # cases where users use sudo without -H flag. + try: + path_uid = get_path_uid(path) + except OSError: + return False + return path_uid == 0 + else: + return os.access(path, os.W_OK) + else: + previous, path = path, os.path.dirname(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, IOError): + 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("`%s` is a socket" % f) + + raise + + +def is_socket(path): + # type: (str) -> bool + return stat.S_ISSOCK(os.lstat(path).st_mode) + + +@contextmanager +def adjacent_tmp_file(path): + # type: (str) -> Iterator[NamedTemporaryFileResult] + """Given a path to a file, open a temp file next to it securely and ensure + it is written to disk after the context reaches its end. + """ + with NamedTemporaryFile( + delete=False, + dir=os.path.dirname(path), + prefix=os.path.basename(path), + suffix='.tmp', + ) as f: + result = cast('NamedTemporaryFileResult', f) + try: + yield result + finally: + result.file.flush() + os.fsync(result.file.fileno()) + + +_replace_retry = retry(stop_max_delay=1000, wait_fixed=250) + +if PY2: + @_replace_retry + def replace(src, dest): + # type: (str, str) -> None + try: + os.rename(src, dest) + except OSError: + os.remove(dest) + os.rename(src, dest) + +else: + 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 + """Check if a directory is writable. + + Uses os.access() on POSIX, tries creating files on Windows. + """ + # If the directory doesn't exist, find the closest parent that does. + while not os.path.isdir(path): + parent = os.path.dirname(path) + if parent == path: + break # Should never get here, but infinite loops are bad + path = parent + + if os.name == 'posix': + return os.access(path, os.W_OK) + + return _test_writable_dir_win(path) + + +def _test_writable_dir_win(path): + # type: (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_' + alphabet = 'abcdefghijklmnopqrstuvwxyz0123456789' + for i in range(10): + name = basename + ''.join(random.choice(alphabet) for _ in range(6)) + file = os.path.join(path, name) + try: + fd = os.open(file, os.O_RDWR | os.O_CREAT | os.O_EXCL) + except OSError as e: + if e.errno == errno.EEXIST: + continue + if e.errno == errno.EPERM: + # This could be because there's a directory with the same name. + # But it's highly unlikely there's a directory called that, + # so we'll assume it's because the parent dir is not writable. + return False + raise + else: + os.close(fd) + os.unlink(file) + return True + + # This should never be reached + raise EnvironmentError( + 'Unexpected condition testing for writable directory' + ) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/filetypes.py b/venv/lib/python3.8/site-packages/pip/_internal/utils/filetypes.py new file mode 100644 index 0000000..daa0ca7 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/utils/filetypes.py @@ -0,0 +1,16 @@ +"""Filetype information. +""" +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import Tuple + +WHEEL_EXTENSION = '.whl' +BZ2_EXTENSIONS = ('.tar.bz2', '.tbz') # type: Tuple[str, ...] +XZ_EXTENSIONS = ('.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, ...] +ARCHIVE_EXTENSIONS = ( + ZIP_EXTENSIONS + BZ2_EXTENSIONS + TAR_EXTENSIONS + XZ_EXTENSIONS +) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/glibc.py b/venv/lib/python3.8/site-packages/pip/_internal/utils/glibc.py new file mode 100644 index 0000000..3610424 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/utils/glibc.py @@ -0,0 +1,98 @@ +# The following comment should be removed at some point in the future. +# mypy: strict-optional=False + +from __future__ import absolute_import + +import os +import sys + +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import Optional, Tuple + + +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 + if sys.platform == "win32": + return None + try: + # os.confstr("CS_GNU_LIBC_VERSION") returns a string like "glibc 2.17": + _, version = os.confstr("CS_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] + "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. + process_namespace = ctypes.CDLL(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() + # py2 / py3 compatibility: + if not isinstance(version_str, str): + version_str = version_str.decode("ascii") + + return version_str + + +# platform.libc_ver regularly returns completely nonsensical glibc +# versions. E.g. on my computer, platform says: +# +# ~$ python2.7 -c 'import platform; print(platform.libc_ver())' +# ('glibc', '2.7') +# ~$ python3.5 -c 'import platform; print(platform.libc_ver())' +# ('glibc', '2.9') +# +# But the truth is: +# +# ~$ ldd --version +# ldd (Debian GLIBC 2.22-11) 2.22 +# +# This is unfortunate, because it means that the linehaul data on libc +# 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] + """Try to determine the glibc version + + Returns a tuple of strings (lib, version) which default to empty strings + in case the lookup fails. + """ + glibc_version = glibc_version_string() + if glibc_version is None: + return ("", "") + else: + return ("glibc", glibc_version) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/hashes.py b/venv/lib/python3.8/site-packages/pip/_internal/utils/hashes.py new file mode 100644 index 0000000..4c41551 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/utils/hashes.py @@ -0,0 +1,131 @@ +from __future__ import absolute_import + +import hashlib + +from pip._vendor.six import iteritems, iterkeys, itervalues + +from pip._internal.exceptions import ( + HashMismatch, + HashMissing, + InstallationError, +) +from pip._internal.utils.misc import read_chunks +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import ( + Dict, List, BinaryIO, NoReturn, Iterator + ) + from pip._vendor.six import PY3 + if PY3: + from hashlib import _Hash + else: + from hashlib import _hash as _Hash + + +# The recommended hash algo of the moment. Change this whenever the state of +# the art changes; it won't hurt backward compatibility. +FAVORITE_HASH = 'sha256' + + +# Names of hashlib algorithms allowed by the --hash option and ``pip hash`` +# Currently, those are the ones at least as collision-resistant as sha256. +STRONG_HASHES = ['sha256', 'sha384', 'sha512'] + + +class Hashes(object): + """A wrapper that builds multiple hashes at once and checks them against + known-good values + + """ + def __init__(self, hashes=None): + # type: (Dict[str, List[str]]) -> None + """ + :param hashes: A dict of algorithm names pointing to lists of allowed + hex digests + """ + self._allowed = {} if hashes is None else hashes + + @property + def digest_count(self): + # type: () -> 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 + """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 + """Check good hashes against ones built from iterable of chunks of + data. + + Raise HashMismatch if none match. + + """ + gots = {} + for hash_name in iterkeys(self._allowed): + try: + gots[hash_name] = hashlib.new(hash_name) + except (ValueError, TypeError): + raise InstallationError('Unknown hash name: %s' % hash_name) + + for chunk in chunks: + for hash in itervalues(gots): + hash.update(chunk) + + for hash_name, got in iteritems(gots): + if got.hexdigest() in self._allowed[hash_name]: + return + self._raise(gots) + + def _raise(self, gots): + # type: (Dict[str, _Hash]) -> NoReturn + raise HashMismatch(self._allowed, gots) + + def check_against_file(self, file): + # type: (BinaryIO) -> None + """Check good hashes against a file-like object + + Raise HashMismatch if none match. + + """ + return self.check_against_chunks(read_chunks(file)) + + def check_against_path(self, path): + # type: (str) -> None + with open(path, 'rb') as file: + return self.check_against_file(file) + + def __nonzero__(self): + # type: () -> bool + """Return whether I know any known-good hashes.""" + return bool(self._allowed) + + def __bool__(self): + # type: () -> bool + return self.__nonzero__() + + +class MissingHashes(Hashes): + """A workalike for Hashes used when we're missing a hash for a requirement + + It computes the actual hash of the requirement and raises a HashMissing + exception showing it to the user. + + """ + def __init__(self): + # type: () -> 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(MissingHashes, self).__init__(hashes={FAVORITE_HASH: []}) + + def _raise(self, gots): + # type: (Dict[str, _Hash]) -> NoReturn + raise HashMissing(gots[FAVORITE_HASH].hexdigest()) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/inject_securetransport.py b/venv/lib/python3.8/site-packages/pip/_internal/utils/inject_securetransport.py new file mode 100644 index 0000000..5b93b1d --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/utils/inject_securetransport.py @@ -0,0 +1,36 @@ +"""A helper module that injects SecureTransport, on import. + +The import should be done as early as possible, to ensure all requests and +sessions (or whatever) are created after injecting SecureTransport. + +Note that we only do the injection on macOS, when the linked OpenSSL is too +old to handle TLSv1.2. +""" + +import sys + + +def inject_securetransport(): + # type: () -> None + # Only relevant on macOS + if sys.platform != "darwin": + return + + try: + import ssl + except ImportError: + return + + # Checks for OpenSSL 1.0.1 + if ssl.OPENSSL_VERSION_NUMBER >= 0x1000100f: + return + + try: + from pip._vendor.urllib3.contrib import securetransport + except (ImportError, OSError): + return + + securetransport.inject_into_urllib3() + + +inject_securetransport() diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/logging.py b/venv/lib/python3.8/site-packages/pip/_internal/utils/logging.py new file mode 100644 index 0000000..7767111 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/utils/logging.py @@ -0,0 +1,398 @@ +# The following comment should be removed at some point in the future. +# mypy: disallow-untyped-defs=False + +from __future__ import absolute_import + +import contextlib +import errno +import logging +import logging.handlers +import os +import sys +from logging import Filter, getLogger + +from pip._vendor.six import PY2 + +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: + # Use "import as" and set colorama in the else clause to avoid mypy + # errors and get the following correct revealed type for colorama: + # `Union[_importlib_modulespec.ModuleType, None]` + # Otherwise, we get an error like the following in the except block: + # > Incompatible types in assignment (expression has type "None", + # variable has type Module) + # TODO: eliminate the need to use "import as" once mypy addresses some + # of its issues with conditional imports. Here is an umbrella issue: + # https://github.com/python/mypy/issues/1297 + from pip._vendor import colorama as _colorama +# Lots of different errors can come from this, including SystemError and +# ImportError. +except Exception: + colorama = None +else: + # Import Fore explicitly rather than accessing below as colorama.Fore + # to avoid the following error running mypy: + # > Module has no attribute "Fore" + # TODO: eliminate the need to import Fore once mypy addresses some of its + # issues with conditional imports. This particular case could be an + # instance of the following issue (but also see the umbrella issue above): + # https://github.com/python/mypy/issues/3500 + from pip._vendor.colorama import Fore + + colorama = _colorama + + +_log_state = threading.local() +_log_state.indentation = 0 +subprocess_logger = getLogger('pip.subprocessor') + + +class BrokenStdoutLoggingError(Exception): + """ + Raised if BrokenPipeError occurs for the stdout stream while logging. + """ + pass + + +# BrokenPipeError does not exist in Python 2 and, in addition, manifests +# differently in Windows and non-Windows. +if WINDOWS: + # In Windows, a broken pipe can show up as EINVAL rather than EPIPE: + # https://bugs.python.org/issue19612 + # https://bugs.python.org/issue30418 + if PY2: + def _is_broken_pipe_error(exc_class, exc): + """See the docstring for non-Windows Python 3 below.""" + return (exc_class is IOError and + exc.errno in (errno.EINVAL, errno.EPIPE)) + else: + # In Windows, a broken pipe IOError became OSError in Python 3. + def _is_broken_pipe_error(exc_class, exc): + """See the docstring for non-Windows Python 3 below.""" + return ((exc_class is BrokenPipeError) or # noqa: F821 + (exc_class is OSError and + exc.errno in (errno.EINVAL, errno.EPIPE))) +elif PY2: + def _is_broken_pipe_error(exc_class, exc): + """See the docstring for non-Windows Python 3 below.""" + return (exc_class is IOError and exc.errno == errno.EPIPE) +else: + # Then we are in the non-Windows Python 3 case. + def _is_broken_pipe_error(exc_class, exc): + """ + Return whether an exception is a broken pipe error. + + Args: + exc_class: an exception class. + exc: an exception instance. + """ + return (exc_class is BrokenPipeError) # noqa: F821 + + +@contextlib.contextmanager +def indent_log(num=2): + """ + A context manager which will cause the log output to be indented for any + log messages emitted inside it. + """ + _log_state.indentation += num + try: + yield + finally: + _log_state.indentation -= num + + +def get_indentation(): + return getattr(_log_state, 'indentation', 0) + + +class IndentingFormatter(logging.Formatter): + + def __init__(self, *args, **kwargs): + """ + A logging.Formatter that obeys the indent_log() context manager. + + :param add_timestamp: A bool indicating output lines should be prefixed + with their record's timestamp. + """ + self.add_timestamp = kwargs.pop("add_timestamp", False) + super(IndentingFormatter, self).__init__(*args, **kwargs) + + def get_message_start(self, formatted, levelno): + """ + Return the start of the formatted log message (not counting the + prefix to add to each line). + """ + if levelno < logging.WARNING: + return '' + if formatted.startswith(DEPRECATION_MSG_PREFIX): + # Then the message already has a prefix. We don't want it to + # look like "WARNING: DEPRECATION: ...." + return '' + if levelno < logging.ERROR: + return 'WARNING: ' + + return 'ERROR: ' + + def format(self, record): + """ + Calls the standard formatter, but will indent all of the log message + lines by our current indentation level. + """ + formatted = super(IndentingFormatter, self).format(record) + message_start = self.get_message_start(formatted, record.levelno) + formatted = message_start + formatted + + prefix = '' + if self.add_timestamp: + # TODO: Use Formatter.default_time_format after dropping PY2. + t = self.formatTime(record, "%Y-%m-%dT%H:%M:%S") + prefix = '%s,%03d ' % (t, record.msecs) + prefix += " " * get_indentation() + formatted = "".join([ + prefix + line + for line in formatted.splitlines(True) + ]) + return formatted + + +def _color_wrap(*colors): + def wrapped(inp): + 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(Fore.RED)), + (logging.WARNING, _color_wrap(Fore.YELLOW)), + ] + else: + COLORS = [] + + def __init__(self, stream=None, no_color=None): + logging.StreamHandler.__init__(self, stream) + self._no_color = no_color + + if WINDOWS and colorama: + self.stream = colorama.AnsiToWin32(self.stream) + + def _using_stdout(self): + """ + Return whether the handler is using sys.stdout. + """ + if WINDOWS and colorama: + # Then self.stream is an AnsiToWin32 object. + return self.stream.wrapped is sys.stdout + + return self.stream is sys.stdout + + def should_color(self): + # 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 + ) + + # 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 + + # If anything else we should not color it + return False + + def format(self, record): + msg = logging.StreamHandler.format(self, 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): + 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 + # exception so we can handle it in main() instead of logging the + # broken pipe error and continuing. + if (exc_class and self._using_stdout() and + _is_broken_pipe_error(exc_class, exc)): + raise BrokenStdoutLoggingError() + + return super(ColorizedStreamHandler, self).handleError(record) + + +class BetterRotatingFileHandler(logging.handlers.RotatingFileHandler): + + def _open(self): + ensure_dir(os.path.dirname(self.baseFilename)) + return logging.handlers.RotatingFileHandler._open(self) + + +class MaxLevelFilter(Filter): + + def __init__(self, level): + self.level = level + + def filter(self, record): + return record.levelno < self.level + + +class ExcludeLoggerFilter(Filter): + + """ + A logging Filter that excludes records from a logger (or its children). + """ + + def filter(self, record): + # The base Filter class allows only records from a logger (or its + # children). + return not super(ExcludeLoggerFilter, self).filter(record) + + +def setup_logging(verbosity, no_color, user_log_file): + """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" + elif verbosity == -1: + level = "WARNING" + elif verbosity == -2: + level = "ERROR" + elif verbosity <= -3: + level = "CRITICAL" + else: + level = "INFO" + + level_number = getattr(logging, level) + + # The "root" logger should match the "console" level *unless* we also need + # to log to a user log file. + include_user_log = user_log_file is not None + if include_user_log: + additional_log_file = user_log_file + root_level = "DEBUG" + else: + additional_log_file = "/dev/null" + root_level = level + + # Disable any logging besides WARNING unless we have DEBUG level logging + # enabled for vendored libraries. + vendored_log_level = "WARNING" if level in ["INFO", "ERROR"] else "DEBUG" + + # Shorthands for clarity + log_streams = { + "stdout": "ext://sys.stdout", + "stderr": "ext://sys.stderr", + } + handler_classes = { + "stream": "pip._internal.utils.logging.ColorizedStreamHandler", + "file": "pip._internal.utils.logging.BetterRotatingFileHandler", + } + handlers = ["console", "console_errors", "console_subprocess"] + ( + ["user_log"] if include_user_log else [] + ) + + logging.config.dictConfig({ + "version": 1, + "disable_existing_loggers": False, + "filters": { + "exclude_warnings": { + "()": "pip._internal.utils.logging.MaxLevelFilter", + "level": logging.WARNING, + }, + "restrict_to_subprocess": { + "()": "logging.Filter", + "name": subprocess_logger.name, + }, + "exclude_subprocess": { + "()": "pip._internal.utils.logging.ExcludeLoggerFilter", + "name": subprocess_logger.name, + }, + }, + "formatters": { + "indent": { + "()": IndentingFormatter, + "format": "%(message)s", + }, + "indent_with_timestamp": { + "()": IndentingFormatter, + "format": "%(message)s", + "add_timestamp": True, + }, + }, + "handlers": { + "console": { + "level": level, + "class": handler_classes["stream"], + "no_color": no_color, + "stream": log_streams["stdout"], + "filters": ["exclude_subprocess", "exclude_warnings"], + "formatter": "indent", + }, + "console_errors": { + "level": "WARNING", + "class": handler_classes["stream"], + "no_color": no_color, + "stream": log_streams["stderr"], + "filters": ["exclude_subprocess"], + "formatter": "indent", + }, + # A handler responsible for logging to the console messages + # from the "subprocessor" logger. + "console_subprocess": { + "level": level, + "class": handler_classes["stream"], + "no_color": no_color, + "stream": log_streams["stderr"], + "filters": ["restrict_to_subprocess"], + "formatter": "indent", + }, + "user_log": { + "level": "DEBUG", + "class": handler_classes["file"], + "filename": additional_log_file, + "delay": True, + "formatter": "indent_with_timestamp", + }, + }, + "root": { + "level": root_level, + "handlers": handlers, + }, + "loggers": { + "pip._vendor": { + "level": vendored_log_level + } + }, + }) + + return level_number diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/marker_files.py b/venv/lib/python3.8/site-packages/pip/_internal/utils/marker_files.py new file mode 100644 index 0000000..42ea814 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/utils/marker_files.py @@ -0,0 +1,25 @@ +import os.path + +DELETE_MARKER_MESSAGE = '''\ +This file is placed here by pip to indicate the source was put +here by pip. + +Once this package is successfully installed this source code will be +deleted (unless you remove this file). +''' +PIP_DELETE_MARKER_FILENAME = 'pip-delete-this-directory.txt' + + +def has_delete_marker_file(directory): + # type: (str) -> bool + return os.path.exists(os.path.join(directory, PIP_DELETE_MARKER_FILENAME)) + + +def write_delete_marker_file(directory): + # type: (str) -> None + """ + Write the pip delete marker file into this directory. + """ + filepath = os.path.join(directory, PIP_DELETE_MARKER_FILENAME) + with open(filepath, 'w') as marker_fp: + marker_fp.write(DELETE_MARKER_MESSAGE) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/misc.py b/venv/lib/python3.8/site-packages/pip/_internal/utils/misc.py new file mode 100644 index 0000000..554af0b --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/utils/misc.py @@ -0,0 +1,904 @@ +# The following comment should be removed at some point in the future. +# mypy: strict-optional=False +# mypy: disallow-untyped-defs=False + +from __future__ import absolute_import + +import contextlib +import errno +import getpass +import hashlib +import io +import logging +import os +import posixpath +import shutil +import stat +import sys +from collections import deque + +from pip._vendor import pkg_resources +# NOTE: retrying is not annotated in typeshed as on 2017-07-17, which is +# why we ignore the type on this import. +from pip._vendor.retrying import retry # type: ignore +from pip._vendor.six import PY2, text_type +from pip._vendor.six.moves import input +from pip._vendor.six.moves.urllib import parse as urllib_parse +from pip._vendor.six.moves.urllib.parse import unquote as urllib_unquote + +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, + expanduser, + stdlib_pkgs, + str_to_display, +) +from pip._internal.utils.typing import MYPY_CHECK_RUNNING, cast +from pip._internal.utils.virtualenv import ( + running_under_virtualenv, + virtualenv_no_global, +) + +if PY2: + from io import BytesIO as StringIO +else: + from io import StringIO + +if MYPY_CHECK_RUNNING: + from typing import ( + Any, AnyStr, Container, Iterable, List, Optional, Text, + Tuple, Union, + ) + from pip._vendor.pkg_resources import Distribution + + VersionInfo = Tuple[int, int, int] + + +__all__ = ['rmtree', 'display_path', 'backup_dir', + 'ask', 'splitext', + 'format_size', 'is_installable_dir', + 'normalize_path', + 'renames', 'get_prog', + 'captured_stdout', 'ensure_dir', + 'get_installed_version', 'remove_auth_from_url'] + + +logger = logging.getLogger(__name__) + + +def get_pip_version(): + # type: () -> str + pip_pkg_dir = os.path.join(os.path.dirname(__file__), "..", "..") + pip_pkg_dir = os.path.abspath(pip_pkg_dir) + + return ( + 'pip {} from {} (python {})'.format( + __version__, pip_pkg_dir, get_major_minor_version(), + ) + ) + + +def normalize_version_info(py_version_info): + # type: (Tuple[int, ...]) -> Tuple[int, int, int] + """ + Convert a tuple of ints representing a Python version to one of length + three. + + :param py_version_info: a tuple of ints representing a Python version, + or None to specify no version. The tuple can have any length. + + :return: a tuple of length three if `py_version_info` is non-None. + Otherwise, return `py_version_info` unchanged (i.e. None). + """ + if len(py_version_info) < 3: + py_version_info += (3 - len(py_version_info)) * (0,) + elif len(py_version_info) > 3: + py_version_info = py_version_info[:3] + + return cast('VersionInfo', py_version_info) + + +def ensure_dir(path): + # type: (AnyStr) -> None + """os.path.makedirs without EEXIST.""" + try: + os.makedirs(path) + except OSError as e: + # Windows can raise spurious ENOTEMPTY errors. See #6426. + if e.errno != errno.EEXIST and e.errno != errno.ENOTEMPTY: + raise + + +def get_prog(): + # type: () -> str + try: + prog = os.path.basename(sys.argv[0]) + if prog in ('__main__.py', '-c'): + return "%s -m pip" % sys.executable + else: + return prog + except (AttributeError, TypeError, IndexError): + pass + return 'pip' + + +# Retry every half second for up to 3 seconds +@retry(stop_max_delay=3000, wait_fixed=500) +def rmtree(dir, ignore_errors=False): + # type: (str, bool) -> None + shutil.rmtree(dir, ignore_errors=ignore_errors, + onerror=rmtree_errorhandler) + + +def rmtree_errorhandler(func, path, exc_info): + """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.""" + try: + has_attr_readonly = not (os.stat(path).st_mode & stat.S_IWRITE) + except (IOError, OSError): + # it's equivalent to os.path.exists + return + + if has_attr_readonly: + # convert to read/write + os.chmod(path, stat.S_IWRITE) + # use the original function to repeat the operation + func(path) + return + else: + raise + + +def path_to_display(path): + # type: (Optional[Union[str, Text]]) -> Optional[Text] + """ + Convert a bytes (or text) path to text (unicode in Python 2) for display + and logging purposes. + + This function should never error out. Also, this function is mainly needed + for Python 2 since in Python 3 str paths are already text. + """ + if path is None: + return None + if isinstance(path, text_type): + return path + # Otherwise, path is a bytes object (str in Python 2). + try: + display_path = path.decode(sys.getfilesystemencoding(), 'strict') + except UnicodeDecodeError: + # Include the full bytes to make troubleshooting easier, even though + # it may not be very human readable. + if PY2: + # Convert the bytes to a readable str representation using + # repr(), and then convert the str to unicode. + # Also, we add the prefix "b" to the repr() return value both + # to make the Python 2 output look like the Python 3 output, and + # to signal to the user that this is a bytes representation. + display_path = str_to_display('b{!r}'.format(path)) + else: + # Silence the "F821 undefined name 'ascii'" flake8 error since + # in Python 3 ascii() is a built-in. + display_path = ascii(path) # noqa: F821 + + return display_path + + +def display_path(path): + # type: (Union[str, Text]) -> str + """Gives the display value for a given path, making it relative to cwd + if possible.""" + path = os.path.normcase(os.path.abspath(path)) + if sys.version_info[0] == 2: + path = path.decode(sys.getfilesystemencoding(), 'replace') + path = path.encode(sys.getdefaultencoding(), 'replace') + if path.startswith(os.getcwd() + os.path.sep): + path = '.' + path[len(os.getcwd()):] + return path + + +def backup_dir(dir, ext='.bak'): + # type: (str, str) -> str + """Figure out the name of a directory to back up the given dir to + (adding .bak, .bak2, etc)""" + n = 1 + extension = ext + while os.path.exists(dir + extension): + n += 1 + extension = ext + str(n) + return dir + extension + + +def ask_path_exists(message, options): + # type: (str, 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 + """Raise an error if no input is allowed.""" + if os.environ.get('PIP_NO_INPUT'): + raise Exception( + 'No input was expected ($PIP_NO_INPUT set); question: %s' % + message + ) + + +def ask(message, options): + # type: (str, Iterable[str]) -> str + """Ask the message interactively, with the given possible responses""" + while 1: + _check_no_input(message) + response = input(message) + response = response.strip().lower() + if response not in options: + print( + 'Your response (%r) was not one of the expected responses: ' + '%s' % (response, ', '.join(options)) + ) + else: + return response + + +def ask_input(message): + # type: (str) -> str + """Ask for input interactively.""" + _check_no_input(message) + return input(message) + + +def ask_password(message): + # type: (str) -> str + """Ask for a password interactively.""" + _check_no_input(message) + return getpass.getpass(message) + + +def format_size(bytes): + # type: (float) -> str + if bytes > 1000 * 1000: + return '%.1f MB' % (bytes / 1000.0 / 1000) + elif bytes > 10 * 1000: + return '%i kB' % (bytes / 1000) + elif bytes > 1000: + return '%.1f kB' % (bytes / 1000.0) + else: + return '%i bytes' % bytes + + +def is_installable_dir(path): + # type: (str) -> bool + """Is path is a directory containing setup.py or pyproject.toml? + """ + if not os.path.isdir(path): + return False + setup_py = os.path.join(path, 'setup.py') + if os.path.isfile(setup_py): + return True + pyproject_toml = os.path.join(path, 'pyproject.toml') + if os.path.isfile(pyproject_toml): + return True + return False + + +def read_chunks(file, size=io.DEFAULT_BUFFER_SIZE): + """Yield pieces of data from a file-like object until EOF.""" + while True: + chunk = file.read(size) + if not chunk: + break + yield chunk + + +def normalize_path(path, resolve_symlinks=True): + # type: (str, bool) -> str + """ + Convert a path to its canonical, case-normalized, absolute version. + + """ + path = expanduser(path) + if resolve_symlinks: + path = os.path.realpath(path) + else: + path = os.path.abspath(path) + return os.path.normcase(path) + + +def splitext(path): + # type: (str) -> Tuple[str, str] + """Like os.path.splitext, but take off .tar too""" + base, ext = posixpath.splitext(path) + if base.lower().endswith('.tar'): + ext = base[-4:] + ext + base = base[:-4] + return base, ext + + +def renames(old, new): + # type: (str, str) -> None + """Like os.renames(), but handles renaming across devices.""" + # Implementation borrowed from os.renames(). + head, tail = os.path.split(new) + if head and tail and not os.path.exists(head): + os.makedirs(head) + + shutil.move(old, new) + + head, tail = os.path.split(old) + if head and tail: + try: + os.removedirs(head) + except OSError: + pass + + +def is_local(path): + # type: (str) -> bool + """ + Return True if this is a path pip is allowed to modify. + + If we're in a virtualenv, sys.prefix points to the virtualenv's + prefix; only sys.prefix is considered local. + + If we're not in a virtualenv, in general we can modify anything. + However, if the OS vendor has configured distutils to install + somewhere other than sys.prefix (which could be a subdirectory of + sys.prefix, e.g. /usr/local), we consider sys.prefix itself nonlocal + and the domain of the OS vendor. (In other words, everything _other + than_ sys.prefix is considered local.) + + Caution: this function assumes the head of path has been normalized + with normalize_path. + """ + + path = normalize_path(path) + prefix = normalize_path(sys.prefix) + + if running_under_virtualenv(): + return path.startswith(normalize_path(sys.prefix)) + else: + from pip._internal.locations import distutils_scheme + if path.startswith(prefix): + for local_path in distutils_scheme("").values(): + if path.startswith(normalize_path(local_path)): + return True + return False + else: + return True + + +def dist_is_local(dist): + # type: (Distribution) -> bool + """ + Return True if given Distribution object is installed somewhere pip + is allowed to modify. + + """ + 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. + + If ``local_only`` is True (default), only return installations + local to the current virtualenv, if in a virtualenv. + + ``skip`` argument is an iterable of lower-case project names to + ignore; defaults to stdlib_pkgs + + If ``include_editables`` is False, don't report editables. + + If ``editables_only`` is True , only report editables. + + If ``user_only`` is True , only report installations in the user + site directory. + + If ``paths`` is set, only report the distributions present at the + specified list of locations. + """ + if paths: + working_set = pkg_resources.WorkingSet(paths) + else: + working_set = pkg_resources.working_set + + if local_only: + local_test = dist_is_local + else: + def local_test(d): + return True + + if include_editables: + def editable_test(d): + return True + else: + def editable_test(d): + return not dist_is_editable(d) + + if editables_only: + def editables_only_test(d): + return dist_is_editable(d) + else: + def editables_only_test(d): + return True + + if user_only: + user_test = dist_in_usersite + else: + def user_test(d): + return True + + return [d for d in working_set + if local_test(d) and + d.key not in skip and + editable_test(d) and + editables_only_test(d) and + user_test(d) + ] + + +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: (str, str) -> None + logger.info(msg, *args) + + +class FakeFile(object): + """Wrap a list of lines in an object with readline() to make + ConfigParser happy.""" + def __init__(self, lines): + self._gen = (l for l in lines) + + def readline(self): + try: + try: + return next(self._gen) + except NameError: + return self._gen.next() + except StopIteration: + return '' + + def __iter__(self): + return self._gen + + +class StreamWrapper(StringIO): + + @classmethod + def from_stream(cls, orig_stream): + cls.orig_stream = orig_stream + return cls() + + # compileall.compile_dir() needs stdout.encoding to print to stdout + @property + def encoding(self): + return self.orig_stream.encoding + + +@contextlib.contextmanager +def captured_output(stream_name): + """Return a context manager used by captured_stdout/stdin/stderr + that temporarily replaces the sys stream *stream_name* with a StringIO. + + Taken from Lib/support/__init__.py in the CPython repo. + """ + orig_stdout = getattr(sys, stream_name) + setattr(sys, stream_name, StreamWrapper.from_stream(orig_stdout)) + try: + yield getattr(sys, stream_name) + finally: + setattr(sys, stream_name, orig_stdout) + + +def captured_stdout(): + """Capture the output of sys.stdout: + + with captured_stdout() as stdout: + print('hello') + self.assertEqual(stdout.getvalue(), 'hello\n') + + Taken from Lib/support/__init__.py in the CPython repo. + """ + return captured_output('stdout') + + +def captured_stderr(): + """ + See captured_stdout(). + """ + return captured_output('stderr') + + +class cached_property(object): + """A property that is only computed once per instance and then replaces + itself with an ordinary attribute. Deleting the attribute resets the + property. + + Source: https://github.com/bottlepy/bottle/blob/0.11.5/bottle.py#L175 + """ + + def __init__(self, func): + self.__doc__ = getattr(func, '__doc__') + self.func = func + + def __get__(self, obj, cls): + if obj is None: + # We're being accessed from the class itself, not from an object + return self + value = obj.__dict__[self.func.__name__] = self.func(obj) + return value + + +def get_installed_version(dist_name, working_set=None): + """Get the installed version of dist_name avoiding pkg_resources cache""" + # Create a requirement that we'll look for inside of setuptools. + req = pkg_resources.Requirement.parse(dist_name) + + if working_set is None: + # We want to avoid having this cached, so we need to construct a new + # working set each time. + working_set = pkg_resources.WorkingSet() + + # Get the installed distribution from our working set + dist = working_set.find(req) + + # Check to see if we got an installed distribution or not, if we did + # we want to return it's version. + return dist.version if dist else None + + +def consume(iterator): + """Consume an iterable at C speed.""" + deque(iterator, maxlen=0) + + +# Simulates an enum +def enum(*sequential, **named): + 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 + """ + Build a netloc from a host-port pair + """ + if port is None: + return host + if ':' in host: + # Only wrap host with square brackets when it is IPv6 + host = '[{}]'.format(host) + return '{}:{}'.format(host, port) + + +def build_url_from_netloc(netloc, scheme='https'): + # type: (str, str) -> str + """ + Build a full URL from a netloc. + """ + if netloc.count(':') >= 2 and '@' not in netloc and '[' not in netloc: + # It must be a bare IPv6 address, so wrap it with brackets. + netloc = '[{}]'.format(netloc) + return '{}://{}'.format(scheme, netloc) + + +def parse_netloc(netloc): + # type: (str) -> Tuple[str, Optional[int]] + """ + Return the host-port pair from a netloc. + """ + url = build_url_from_netloc(netloc) + parsed = urllib_parse.urlparse(url) + return parsed.hostname, parsed.port + + +def split_auth_from_netloc(netloc): + """ + Parse out and remove the auth information from a netloc. + + Returns: (netloc, (username, password)). + """ + if '@' not in netloc: + return netloc, (None, None) + + # Split from the right because that's how urllib.parse.urlsplit() + # 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) + 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 + # using the password attribute of the return value) + user_pass = auth.split(':', 1) + else: + user_pass = auth, None + + user_pass = tuple( + None if x is None else urllib_unquote(x) for x in user_pass + ) + + return netloc, user_pass + + +def redact_netloc(netloc): + # type: (str) -> str + """ + Replace the sensitive data in a netloc with "****", if it exists. + + For example: + - "user:pass@example.com" returns "user:****@example.com" + - "accesstoken@example.com" returns "****@example.com" + """ + netloc, (user, password) = split_auth_from_netloc(netloc) + if user is None: + return netloc + if password is None: + user = '****' + password = '' + else: + user = urllib_parse.quote(user) + password = ':****' + return '{user}{password}@{netloc}'.format(user=user, + password=password, + netloc=netloc) + + +def _transform_url(url, transform_netloc): + """Transform and replace netloc in a url. + + transform_netloc is a function taking the netloc and returning a + tuple. The first element of this tuple is the new netloc. The + entire tuple is returned. + + Returns a tuple containing the transformed url as item 0 and the + original tuple returned by transform_netloc as item 1. + """ + purl = urllib_parse.urlsplit(url) + netloc_tuple = transform_netloc(purl.netloc) + # stripped url + url_pieces = ( + purl.scheme, netloc_tuple[0], purl.path, purl.query, purl.fragment + ) + surl = urllib_parse.urlunsplit(url_pieces) + return surl, netloc_tuple + + +def _get_netloc(netloc): + return split_auth_from_netloc(netloc) + + +def _redact_netloc(netloc): + return (redact_netloc(netloc),) + + +def split_auth_netloc_from_url(url): + # type: (str) -> Tuple[str, str, Tuple[str, str]] + """ + Parse a url into separate netloc, auth, and url with no auth. + + Returns: (url_without_auth, netloc, (username, password)) + """ + url_without_auth, (netloc, auth) = _transform_url(url, _get_netloc) + return url_without_auth, netloc, auth + + +def remove_auth_from_url(url): + # type: (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 + """Replace the password in a given url with ****.""" + return _transform_url(url, _redact_netloc)[0] + + +class HiddenText(object): + def __init__( + self, + secret, # type: str + redacted, # type: str + ): + # type: (...) -> None + self.secret = secret + self.redacted = redacted + + def __repr__(self): + # type: (...) -> str + return ''.format(str(self)) + + def __str__(self): + # type: (...) -> str + return self.redacted + + # This is useful for testing. + def __eq__(self, other): + # type: (Any) -> bool + if type(self) != type(other): + return False + + # The string being used for redaction doesn't also have to match, + # just the raw, original string. + return (self.secret == other.secret) + + # We need to provide an explicit __ne__ implementation for Python 2. + # TODO: remove this when we drop PY2 support. + def __ne__(self, other): + # type: (Any) -> bool + return not self == other + + +def hide_value(value): + # type: (str) -> HiddenText + return HiddenText(value, redacted='****') + + +def hide_url(url): + # type: (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 + """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]) + ] + + # See https://github.com/pypa/pip/issues/1299 for more discussion + should_show_use_python_msg = ( + modifying_pip and + WINDOWS and + os.path.basename(sys.argv[0]) in pip_names + ) + + if should_show_use_python_msg: + new_command = [ + sys.executable, "-m", "pip" + ] + sys.argv[1:] + raise CommandError( + 'To modify pip, please run the following command:\n{}' + .format(" ".join(new_command)) + ) + + +def is_console_interactive(): + # type: () -> 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] + """Return (hash, length) for path using hashlib.sha256() + """ + + h = hashlib.sha256() + length = 0 + with open(path, 'rb') as f: + for block in read_chunks(f, size=blocksize): + length += len(block) + h.update(block) + return h, length + + +def is_wheel_installed(): + """ + Return whether the wheel package is installed. + """ + try: + import wheel # noqa: F401 + except ImportError: + return False + + return True diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/models.py b/venv/lib/python3.8/site-packages/pip/_internal/utils/models.py new file mode 100644 index 0000000..29e1441 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/utils/models.py @@ -0,0 +1,42 @@ +"""Utilities for defining models +""" +# The following comment should be removed at some point in the future. +# mypy: disallow-untyped-defs=False + +import operator + + +class KeyBasedCompareMixin(object): + """Provides comparison capabilities that is based on a key + """ + + def __init__(self, key, defining_class): + self._compare_key = key + self._defining_class = defining_class + + def __hash__(self): + return hash(self._compare_key) + + def __lt__(self, other): + return self._compare(other, operator.__lt__) + + def __le__(self, other): + return self._compare(other, operator.__le__) + + def __gt__(self, other): + return self._compare(other, operator.__gt__) + + def __ge__(self, other): + return self._compare(other, operator.__ge__) + + def __eq__(self, other): + return self._compare(other, operator.__eq__) + + def __ne__(self, other): + return self._compare(other, operator.__ne__) + + def _compare(self, other, method): + if not isinstance(other, self._defining_class): + return NotImplemented + + return method(self._compare_key, other._compare_key) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/packaging.py b/venv/lib/python3.8/site-packages/pip/_internal/utils/packaging.py new file mode 100644 index 0000000..68aa86e --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/utils/packaging.py @@ -0,0 +1,94 @@ +from __future__ import absolute_import + +import logging +from email.parser import FeedParser + +from pip._vendor import pkg_resources +from pip._vendor.packaging import specifiers, version + +from pip._internal.exceptions import NoneMetadataError +from pip._internal.utils.misc import display_path +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import Optional, Tuple + from email.message import Message + from pip._vendor.pkg_resources import Distribution + + +logger = logging.getLogger(__name__) + + +def check_requires_python(requires_python, version_info): + # type: (Optional[str], Tuple[int, ...]) -> bool + """ + Check if the given Python version matches a "Requires-Python" specifier. + + :param version_info: A 3-tuple of ints representing a Python + major-minor-micro version to check (e.g. `sys.version_info[:3]`). + + :return: `True` if the given Python version satisfies the requirement. + Otherwise, return `False`. + + :raises InvalidSpecifier: If `requires_python` has an invalid format. + """ + if requires_python is None: + # The package provides no information + return True + requires_python_specifier = specifiers.SpecifierSet(requires_python) + + python_version = version.parse('.'.join(map(str, 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 = '' + + 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 get_requires_python(dist): + # type: (pkg_resources.Distribution) -> Optional[str] + """ + 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 '' diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/pkg_resources.py b/venv/lib/python3.8/site-packages/pip/_internal/utils/pkg_resources.py new file mode 100644 index 0000000..0bc129a --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/utils/pkg_resources.py @@ -0,0 +1,44 @@ +from pip._vendor.pkg_resources import yield_lines +from pip._vendor.six import ensure_str + +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import Dict, Iterable, List + + +class DictMetadata(object): + """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 ensure_str(self._metadata[name]) + except UnicodeDecodeError as e: + # Mirrors handling done in pkg_resources.NullProvider. + e.reason += " in {} file".format(name) + 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/venv/lib/python3.8/site-packages/pip/_internal/utils/setuptools_build.py b/venv/lib/python3.8/site-packages/pip/_internal/utils/setuptools_build.py new file mode 100644 index 0000000..4147a65 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/utils/setuptools_build.py @@ -0,0 +1,181 @@ +import sys + +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + 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 sys, setuptools, tokenize; sys.argv[0] = {0!r}; __file__={0!r};" + "f=getattr(tokenize, 'open', open)(__file__);" + "code=f.read().replace('\\r\\n', '\\n');" + "f.close();" + "exec(compile(code, __file__, 'exec'))" +) + + +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] + """ + Get setuptools command arguments with shim wrapped setup file invocation. + + :param setup_py_path: The path to setup.py to be wrapped. + :param global_options: Additional global options. + :param no_user_config: If True, disables personal user configuration. + :param unbuffered_output: If True, adds the unbuffered switch to the + argument list. + """ + args = [sys.executable] + if unbuffered_output: + args += ["-u"] + args += ["-c", _SETUPTOOLS_SHIM.format(setup_py_path)] + if global_options: + args += global_options + if no_user_config: + args += ["--no-user-cfg"] + return 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] + # 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 + # virtualenv. + args = make_setuptools_shim_args( + setup_py_path, + global_options=global_options, + unbuffered_output=True + ) + args += ["bdist_wheel", "-d", destination_dir] + args += build_options + return args + + +def make_setuptools_clean_args( + setup_py_path, # type: str + global_options, # type: Sequence[str] +): + # type: (...) -> List[str] + args = make_setuptools_shim_args( + setup_py_path, + global_options=global_options, + unbuffered_output=True + ) + args += ["clean", "--all"] + return 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] + assert not (use_user_site and prefix) + + args = make_setuptools_shim_args( + setup_py_path, + global_options=global_options, + no_user_config=no_user_config, + ) + + args += ["develop", "--no-deps"] + + args += install_options + + if prefix: + args += ["--prefix", prefix] + if home is not None: + args += ["--home", home] + + if use_user_site: + args += ["--user", "--prefix="] + + return 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] + args = make_setuptools_shim_args(setup_py_path) + if no_user_config: + args += ["--no-user-cfg"] + + args += ["egg_info"] + + if egg_info_dir: + 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/venv/lib/python3.8/site-packages/pip/_internal/utils/subprocess.py b/venv/lib/python3.8/site-packages/pip/_internal/utils/subprocess.py new file mode 100644 index 0000000..ea0176d --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/utils/subprocess.py @@ -0,0 +1,278 @@ +# The following comment should be removed at some point in the future. +# mypy: strict-optional=False + +from __future__ import absolute_import + +import logging +import os +import subprocess + +from pip._vendor.six.moves import shlex_quote + +from pip._internal.exceptions import InstallationError +from pip._internal.utils.compat import console_to_str, str_to_display +from pip._internal.utils.logging import subprocess_logger +from pip._internal.utils.misc import HiddenText, path_to_display +from pip._internal.utils.typing import MYPY_CHECK_RUNNING +from pip._internal.utils.ui import open_spinner + +if MYPY_CHECK_RUNNING: + from typing import ( + Any, Callable, Iterable, List, Mapping, Optional, Text, Union, + ) + from pip._internal.utils.ui import SpinnerInterface + + CommandArgs = List[Union[str, HiddenText]] + + +LOG_DIVIDER = '----------------------------------------' + + +def make_command(*args): + # type: (Union[str, HiddenText, CommandArgs]) -> CommandArgs + """ + Create a CommandArgs object. + """ + command_args = [] # type: CommandArgs + for arg in args: + # Check for list instead of CommandArgs since CommandArgs is + # only known during type-checking. + if isinstance(arg, list): + command_args.extend(arg) + else: + # Otherwise, arg is str or HiddenText. + command_args.append(arg) + + return command_args + + +def format_command_args(args): + # type: (Union[List[str], CommandArgs]) -> str + """ + Format command arguments for display. + """ + # For HiddenText arguments, display the redacted form by calling str(). + # Also, we don't apply str() to arguments that aren't HiddenText since + # this can trigger a UnicodeDecodeError in Python 2 if the argument + # has type unicode and includes a non-ascii character. (The type + # checker doesn't ensure the annotations are correct in all cases.) + return ' '.join( + shlex_quote(str(arg)) if isinstance(arg, HiddenText) + else shlex_quote(arg) for arg in args + ) + + +def reveal_command_args(args): + # type: (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[Text] + exit_status, # type: int +): + # type: (...) -> Text + """ + 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) + # Convert `command` and `cwd` to text (unicode in Python 2) so we can use + # them as arguments in the unicode format string below. This avoids + # "UnicodeDecodeError: 'ascii' codec can't decode byte ..." in Python 2 + # if either contains a non-ascii character. + command_display = str_to_display(command, desc='command bytes') + cwd_display = path_to_display(cwd) + + # 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. + u'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_display, + cwd_display=cwd_display, + 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] +): + # type: (...) -> Text + """ + Args: + show_stdout: if true, use INFO to log the subprocess's stderr and + stdout streams. Otherwise, use DEBUG. Defaults to False. + extra_ok_returncodes: an iterable of integer return codes that are + acceptable, in addition to 0. Defaults to None, which means []. + unset_environ: an iterable of environment variable names to unset + prior to calling subprocess.Popen(). + log_failed_cmd: if false, failed commands are not logged, only raised. + """ + if extra_ok_returncodes is None: + extra_ok_returncodes = [] + if unset_environ is None: + unset_environ = [] + # Most places in pip use show_stdout=False. What this means is-- + # + # - We connect the child's output (combined stderr and stdout) to a + # single pipe, which we read. + # - We log this output to stderr at DEBUG level as it is received. + # - If DEBUG logging isn't enabled (e.g. if --verbose logging wasn't + # requested), then we show a spinner so the user can still see the + # subprocess is in progress. + # - If the subprocess exits with an error, we log the output to stderr + # at ERROR level if it hasn't already been displayed to the console + # (e.g. if --verbose logging wasn't enabled). This way we don't log + # the output to the console twice. + # + # If show_stdout=True, then the above is still done, but with DEBUG + # replaced by INFO. + if show_stdout: + # Then log the subprocess output at INFO level. + log_subprocess = subprocess_logger.info + used_level = logging.INFO + else: + # Then log the subprocess output using DEBUG. 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 + + # Whether the subprocess will be visible in the console. + showing_subprocess = subprocess_logger.getEffectiveLevel() <= used_level + + # Only use the spinner if we're not showing the subprocess output + # 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: + env.update(extra_environ) + for name in unset_environ: + env.pop(name, None) + try: + proc = subprocess.Popen( + # Convert HiddenText objects to the underlying str. + reveal_command_args(cmd), + stderr=subprocess.STDOUT, stdin=subprocess.PIPE, + stdout=subprocess.PIPE, cwd=cwd, env=env, + ) + proc.stdin.close() + except Exception as exc: + if log_failed_cmd: + subprocess_logger.critical( + "Error %s while executing command %s", exc, command_desc, + ) + raise + all_output = [] + while True: + # The "line" value is a unicode string in Python 2. + line = console_to_str(proc.stdout.readline()) + if not line: + break + line = line.rstrip() + all_output.append(line + '\n') + + # Show the line immediately. + log_subprocess(line) + # Update the spinner. + if use_spinner: + spinner.spin() + try: + proc.wait() + finally: + if proc.stdout: + proc.stdout.close() + proc_had_error = ( + proc.returncode and proc.returncode not in extra_ok_returncodes + ) + if use_spinner: + if proc_had_error: + spinner.finish("error") + else: + 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, + ) + subprocess_logger.error(msg) + exc_msg = ( + 'Command errored out with exit status {}: {} ' + 'Check the logs for full command output.' + ).format(proc.returncode, command_desc) + raise InstallationError(exc_msg) + elif on_returncode == 'warn': + subprocess_logger.warning( + 'Command "%s" had error code %s in %s', + command_desc, proc.returncode, cwd, + ) + elif on_returncode == 'ignore': + pass + else: + raise ValueError('Invalid value: on_returncode=%s' % + repr(on_returncode)) + return ''.join(all_output) + + +def runner_with_spinner_message(message): + # type: (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. + """ + + def runner( + cmd, # type: List[str] + cwd=None, # type: Optional[str] + extra_environ=None # type: Optional[Mapping[str, Any]] + ): + # type: (...) -> None + with open_spinner(message) as spinner: + call_subprocess( + cmd, + cwd=cwd, + extra_environ=extra_environ, + spinner=spinner, + ) + + return runner diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/temp_dir.py b/venv/lib/python3.8/site-packages/pip/_internal/utils/temp_dir.py new file mode 100644 index 0000000..65e41bc --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/utils/temp_dir.py @@ -0,0 +1,250 @@ +from __future__ import absolute_import + +import errno +import itertools +import logging +import os.path +import tempfile +from contextlib import contextmanager + +from pip._vendor.contextlib2 import ExitStack + +from pip._internal.utils.misc import rmtree +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import Any, Dict, Iterator, Optional, TypeVar + + _T = TypeVar('_T', bound='TempDirectory') + + +logger = logging.getLogger(__name__) + + +_tempdir_manager = None # type: Optional[ExitStack] + + +@contextmanager +def global_tempdir_manager(): + # type: () -> Iterator[None] + global _tempdir_manager + with ExitStack() as stack: + old_tempdir_manager, _tempdir_manager = _tempdir_manager, stack + try: + yield + finally: + _tempdir_manager = old_tempdir_manager + + +class TempDirectoryTypeRegistry(object): + """Manages temp directory behavior + """ + + def __init__(self): + # type: () -> None + self._should_delete = {} # type: Dict[str, bool] + + def set_delete(self, kind, value): + # type: (str, 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 + """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] + + +@contextmanager +def tempdir_registry(): + # type: () -> Iterator[TempDirectoryTypeRegistry] + """Provides a scoped global tempdir registry that can be used to dictate + whether directories should be deleted. + """ + global _tempdir_registry + old_tempdir_registry = _tempdir_registry + _tempdir_registry = TempDirectoryTypeRegistry() + try: + yield _tempdir_registry + finally: + _tempdir_registry = old_tempdir_registry + + +class TempDirectory(object): + """Helper class that owns and cleans up a temporary directory. + + This class can be used as a context manager or as an OO representation of a + temporary directory. + + Attributes: + path + Location to the created temporary directory + delete + Whether the directory should be deleted when exiting + (when used as a contextmanager) + + Methods: + cleanup() + Deletes the temporary directory + + When used as a context manager, if the delete attribute is True, on + exiting the context the temporary directory is deleted. + """ + + def __init__( + self, + path=None, # type: Optional[str] + delete=None, # type: Optional[bool] + kind="temp", # type: str + globally_managed=False, # type: bool + ): + super(TempDirectory, self).__init__() + + # If we were given an explicit directory, resolve delete option now. + # Otherwise we wait until cleanup and see what tempdir_registry says. + if path is not None and delete is None: + delete = False + + if path is None: + path = self._create(kind) + + self._path = path + self._deleted = False + self.delete = delete + self.kind = kind + + if globally_managed: + assert _tempdir_manager is not None + _tempdir_manager.enter_context(self) + + @property + def path(self): + # type: () -> str + assert not self._deleted, ( + "Attempted to access deleted path: {}".format(self._path) + ) + return self._path + + def __repr__(self): + # type: () -> str + return "<{} {!r}>".format(self.__class__.__name__, self.path) + + def __enter__(self): + # type: (_T) -> _T + return self + + def __exit__(self, exc, value, tb): + # type: (Any, Any, Any) -> None + if self.delete is not None: + delete = self.delete + elif _tempdir_registry: + delete = _tempdir_registry.get_delete(self.kind) + else: + delete = True + + if delete: + self.cleanup() + + def _create(self, kind): + # type: (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 + # scripts, so we canonicalize the path by traversing potential + # symlinks here. + path = os.path.realpath( + tempfile.mkdtemp(prefix="pip-{}-".format(kind)) + ) + logger.debug("Created temporary directory: {}".format(path)) + return path + + def cleanup(self): + # type: () -> None + """Remove the temporary directory created and reset state + """ + self._deleted = True + if os.path.exists(self._path): + rmtree(self._path) + + +class AdjacentTempDirectory(TempDirectory): + """Helper class that creates a temporary directory adjacent to a real one. + + Attributes: + original + The original directory to create a temp directory for. + path + After calling create() or entering, contains the full + path to the temporary directory. + delete + Whether the directory should be deleted when exiting + (when used as a contextmanager) + + """ + # The characters that may be used to name the temp directory + # We always prepend a ~ and then rotate through these until + # a usable name is found. + # pkg_resources raises a different error for .dist-info folder + # with leading '-' and invalid metadata + LEADING_CHARS = "-~.=%0123456789" + + def __init__(self, original, delete=None): + # type: (str, Optional[bool]) -> None + self.original = original.rstrip('/\\') + super(AdjacentTempDirectory, self).__init__(delete=delete) + + @classmethod + def _generate_names(cls, name): + # type: (str) -> Iterator[str] + """Generates a series of temporary names. + + The algorithm replaces the leading characters in the name + with ones that are valid filesystem characters, but are not + valid package names (for both Python and pip definitions of + package). + """ + for i in range(1, len(name)): + for candidate in itertools.combinations_with_replacement( + cls.LEADING_CHARS, i - 1): + new_name = '~' + ''.join(candidate) + name[i:] + if new_name != name: + yield new_name + + # If we make it this far, we will have to make a longer name + for i in range(len(cls.LEADING_CHARS)): + for candidate in itertools.combinations_with_replacement( + cls.LEADING_CHARS, i): + new_name = '~' + ''.join(candidate) + name + if new_name != name: + yield new_name + + def _create(self, kind): + # type: (str) -> str + root, name = os.path.split(self.original) + for candidate in self._generate_names(name): + path = os.path.join(root, candidate) + try: + os.mkdir(path) + except OSError as ex: + # Continue if the name exists already + if ex.errno != errno.EEXIST: + raise + else: + path = os.path.realpath(path) + break + else: + # Final fallback on the default behavior. + path = os.path.realpath( + tempfile.mkdtemp(prefix="pip-{}-".format(kind)) + ) + + logger.debug("Created temporary directory: {}".format(path)) + return path diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/typing.py b/venv/lib/python3.8/site-packages/pip/_internal/utils/typing.py new file mode 100644 index 0000000..8505a29 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/utils/typing.py @@ -0,0 +1,38 @@ +"""For neatly implementing static typing in pip. + +`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 pip, all static-typing related imports should be guarded as follows: + + from pip._internal.utils.typing import MYPY_CHECK_RUNNING + + if MYPY_CHECK_RUNNING: + from typing import ... + +Ref: https://github.com/python/mypy/issues/3216 +""" + +MYPY_CHECK_RUNNING = False + + +if MYPY_CHECK_RUNNING: + from typing import cast +else: + # typing's cast() is needed at runtime, but we don't want to import typing. + # Thus, we use a dummy no-op version, which we tell mypy to ignore. + def cast(type_, value): # type: ignore + return value diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/ui.py b/venv/lib/python3.8/site-packages/pip/_internal/utils/ui.py new file mode 100644 index 0000000..87782aa --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/utils/ui.py @@ -0,0 +1,428 @@ +# The following comment should be removed at some point in the future. +# mypy: strict-optional=False +# mypy: disallow-untyped-defs=False + +from __future__ import absolute_import, division + +import contextlib +import itertools +import logging +import sys +import time +from signal import SIGINT, default_int_handler, signal + +from pip._vendor import six +from pip._vendor.progress import HIDE_CURSOR, SHOW_CURSOR +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 +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import Any, Iterator, IO + +try: + from pip._vendor import colorama +# Lots of different errors can come from this, including SystemError and +# ImportError. +except Exception: + colorama = None + +logger = logging.getLogger(__name__) + + +def _select_progress_class(preferred, fallback): + 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", six.text_type()), + getattr(preferred, "fill", six.text_type()), + ] + 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: + six.text_type().join(characters).encode(encoding) + except UnicodeEncodeError: + return fallback + else: + return preferred + + +_BaseBar = _select_progress_class(IncrementalBar, Bar) # type: Any + + +class InterruptibleMixin(object): + """ + 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): + """ + Save the original SIGINT handler for later. + """ + super(InterruptibleMixin, self).__init__(*args, **kwargs) + + 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): + """ + Restore the original SIGINT handler after finishing. + + This should happen regardless of whether the progress display finishes + normally, or gets interrupted. + """ + super(InterruptibleMixin, self).finish() + signal(SIGINT, self.original_handler) + + def handle_sigint(self, signum, frame): + """ + 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): + pass + + +class BlueEmojiBar(IncrementalBar): + + suffix = "%(percent)d%%" + bar_prefix = " " + bar_suffix = " " + phases = (u"\U0001F539", u"\U0001F537", u"\U0001F535") # type: Any + + +class DownloadProgressMixin(object): + + def __init__(self, *args, **kwargs): + super(DownloadProgressMixin, self).__init__(*args, **kwargs) + self.message = (" " * (get_indentation() + 2)) + self.message + + @property + def downloaded(self): + return format_size(self.index) + + @property + def download_speed(self): + # Avoid zero division errors... + if self.avg == 0.0: + return "..." + return format_size(1 / self.avg) + "/s" + + @property + def pretty_eta(self): + if self.eta: + return "eta %s" % self.eta_td + return "" + + def iter(self, it): + for x in it: + yield x + self.next(len(x)) + self.finish() + + +class WindowsMixin(object): + + def __init__(self, *args, **kwargs): + # 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: + self.hide_cursor = False + + super(WindowsMixin, self).__init__(*args, **kwargs) + + # 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) + # 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" + +# NOTE: The "type: ignore" comments on the following classes are there to +# work around https://github.com/python/typing/issues/241 + + +class DefaultDownloadProgressBar(BaseDownloadProgressBar, + _BaseBar): + pass + + +class DownloadSilentBar(BaseDownloadProgressBar, SilentBar): # type: ignore + pass + + +class DownloadBar(BaseDownloadProgressBar, # type: ignore + Bar): + pass + + +class DownloadFillingCirclesBar(BaseDownloadProgressBar, # type: ignore + FillingCirclesBar): + pass + + +class DownloadBlueEmojiProgressBar(BaseDownloadProgressBar, # type: ignore + BlueEmojiBar): + pass + + +class DownloadProgressSpinner(WindowsMixin, InterruptibleMixin, + DownloadProgressMixin, Spinner): + + file = sys.stdout + suffix = "%(downloaded)s %(download_speed)s" + + def next_phase(self): + if not hasattr(self, "_phaser"): + self._phaser = itertools.cycle(self.phases) + return next(self._phaser) + + def update(self): + message = self.message % self + phase = self.next_phase() + suffix = self.suffix % self + line = ''.join([ + message, + " " if message else "", + phase, + " " if suffix else "", + suffix, + ]) + + self.writeln(line) + + +BAR_TYPES = { + "off": (DownloadSilentBar, DownloadSilentBar), + "on": (DefaultDownloadProgressBar, DownloadProgressSpinner), + "ascii": (DownloadBar, DownloadProgressSpinner), + "pretty": (DownloadFillingCirclesBar, DownloadProgressSpinner), + "emoji": (DownloadBlueEmojiProgressBar, DownloadProgressSpinner) +} + + +def DownloadProgressProvider(progress_bar, max=None): + if max is None or max == 0: + return BAR_TYPES[progress_bar][1]().iter + else: + return BAR_TYPES[progress_bar][0](max=max).iter + + +################################################################ +# Generic "something is happening" spinners +# +# We don't even try using progress.spinner.Spinner here because it's actually +# simpler to reimplement from scratch than to coerce their code into doing +# what we need. +################################################################ + +@contextlib.contextmanager +def hidden_cursor(file): + # type: (IO[Any]) -> Iterator[None] + # The Windows terminal does not support the hide/show cursor ANSI codes, + # even via colorama. So don't even try. + if WINDOWS: + yield + # We don't want to clutter the output with control characters if we're + # writing to a file, or if the user is running with --quiet. + # See https://github.com/pypa/pip/issues/3418 + elif not file.isatty() or logger.getEffectiveLevel() > logging.INFO: + yield + else: + file.write(HIDE_CURSOR) + try: + yield + finally: + file.write(SHOW_CURSOR) + + +class RateLimiter(object): + def __init__(self, min_update_interval_seconds): + # type: (float) -> None + self._min_update_interval_seconds = min_update_interval_seconds + self._last_update = 0 # type: float + + def ready(self): + # type: () -> bool + now = time.time() + delta = now - self._last_update + return delta >= self._min_update_interval_seconds + + def reset(self): + # type: () -> None + self._last_update = time.time() + + +class SpinnerInterface(object): + def spin(self): + # type: () -> None + raise NotImplementedError() + + def finish(self, final_status): + # type: (str) -> None + raise NotImplementedError() + + +class InteractiveSpinner(SpinnerInterface): + def __init__(self, message, file=None, spin_chars="-\\|/", + # Empirically, 8 updates/second looks nice + min_update_interval_seconds=0.125): + self._message = message + if file is None: + file = sys.stdout + self._file = file + self._rate_limiter = RateLimiter(min_update_interval_seconds) + self._finished = False + + self._spin_cycle = itertools.cycle(spin_chars) + + self._file.write(" " * get_indentation() + self._message + " ... ") + self._width = 0 + + def _write(self, status): + 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 + backup = "\b" * self._width + self._file.write(backup + " " * self._width + backup) + # Now we have a blank slate to add our status + self._file.write(status) + self._width = len(status) + self._file.flush() + self._rate_limiter.reset() + + def spin(self): + # type: () -> 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 + if self._finished: + return + self._write(final_status) + self._file.write("\n") + self._file.flush() + self._finished = True + + +# Used for dumb terminals, non-interactive installs (no tty), etc. +# We still print updates occasionally (once every 60 seconds by default) to +# 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 + self._message = message + self._finished = False + self._rate_limiter = RateLimiter(min_update_interval_seconds) + self._update("started") + + def _update(self, status): + assert not self._finished + self._rate_limiter.reset() + logger.info("%s: %s", self._message, status) + + def spin(self): + # type: () -> None + if self._finished: + return + if not self._rate_limiter.ready(): + return + self._update("still running...") + + def finish(self, final_status): + # type: (str) -> None + if self._finished: + return + self._update("finished with status '%s'" % (final_status,)) + self._finished = True + + +@contextlib.contextmanager +def open_spinner(message): + # type: (str) -> Iterator[SpinnerInterface] + # 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 + else: + spinner = NonInteractiveSpinner(message) + try: + with hidden_cursor(sys.stdout): + yield spinner + except KeyboardInterrupt: + spinner.finish("canceled") + raise + except Exception: + spinner.finish("error") + raise + else: + spinner.finish("done") diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/unpacking.py b/venv/lib/python3.8/site-packages/pip/_internal/utils/unpacking.py new file mode 100644 index 0000000..7252dc2 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/utils/unpacking.py @@ -0,0 +1,272 @@ +"""Utilities related archives. +""" + +# The following comment should be removed at some point in the future. +# mypy: strict-optional=False +# mypy: disallow-untyped-defs=False + +from __future__ import absolute_import + +import logging +import os +import shutil +import stat +import tarfile +import zipfile + +from pip._internal.exceptions import InstallationError +from pip._internal.utils.filetypes import ( + BZ2_EXTENSIONS, + TAR_EXTENSIONS, + XZ_EXTENSIONS, + ZIP_EXTENSIONS, +) +from pip._internal.utils.misc import ensure_dir +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import Iterable, List, Optional, Text, Union + + +logger = logging.getLogger(__name__) + + +SUPPORTED_EXTENSIONS = ZIP_EXTENSIONS + TAR_EXTENSIONS + +try: + import bz2 # noqa + SUPPORTED_EXTENSIONS += BZ2_EXTENSIONS +except ImportError: + logger.debug('bz2 module is not available') + +try: + # Only for Python 3.3+ + import lzma # noqa + SUPPORTED_EXTENSIONS += XZ_EXTENSIONS +except ImportError: + logger.debug('lzma module is not available') + + +def current_umask(): + """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: (Union[str, Text]) -> List[Union[str, Text]] + path = path.lstrip('/').lstrip('\\') + if ( + '/' in path and ( + ('\\' in path and path.find('/') < path.find('\\')) or + '\\' not in path + ) + ): + return path.split('/', 1) + elif '\\' in path: + return path.split('\\', 1) + else: + return [path, ''] + + +def has_leading_dir(paths): + # type: (Iterable[Union[str, Text]]) -> 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 + for path in paths: + prefix, rest = split_leading_dir(path) + if not prefix: + return False + elif common_prefix is None: + common_prefix = prefix + elif prefix != common_prefix: + return False + return True + + +def is_within_directory(directory, target): + # type: ((Union[str, Text]), (Union[str, Text])) -> bool + """ + Return true if the absolute path of target is within the directory + """ + abs_directory = os.path.abspath(directory) + abs_target = os.path.abspath(target) + + prefix = os.path.commonprefix([abs_directory, abs_target]) + return prefix == abs_directory + + +def unzip_file(filename, location, flatten=True): + # type: (str, str, bool) -> 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 + not preserved), except that regular file members with any execute + permissions (user, group, or world) have "chmod +x" applied after being + written. Note that for windows, any execute changes using os.chmod are + no-ops per the python docs. + """ + ensure_dir(location) + zipfp = open(filename, 'rb') + try: + zip = zipfile.ZipFile(zipfp, allowZip64=True) + leading = has_leading_dir(zip.namelist()) and flatten + for info in zip.infolist(): + name = info.filename + fn = name + if leading: + fn = split_leading_dir(name)[1] + fn = os.path.join(location, fn) + dir = os.path.dirname(fn) + if not is_within_directory(location, fn): + message = ( + 'The zip file ({}) has a file ({}) trying to install ' + 'outside target directory ({})' + ) + raise InstallationError(message.format(filename, fn, location)) + if fn.endswith('/') or fn.endswith('\\'): + # A directory + ensure_dir(fn) + else: + ensure_dir(dir) + # Don't use read() to avoid allocating an arbitrarily large + # chunk of memory for the file's content + fp = zip.open(name) + try: + with open(fn, 'wb') as destfp: + shutil.copyfileobj(fp, destfp) + finally: + fp.close() + mode = info.external_attr >> 16 + # if mode and regular file and any execute permissions for + # user/group/world? + if mode and stat.S_ISREG(mode) and mode & 0o111: + # make dest file have execute for user/group/world + # (chmod +x) no-op on windows per python docs + os.chmod(fn, (0o777 - current_umask() | 0o111)) + finally: + zipfp.close() + + +def untar_file(filename, location): + # type: (str, 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 + are not preserved), except that regular file members with any execute + permissions (user, group, or world) have "chmod +x" applied after being + written. Note that for windows, any execute changes using os.chmod are + no-ops per the python docs. + """ + ensure_dir(location) + if filename.lower().endswith('.gz') or filename.lower().endswith('.tgz'): + mode = 'r:gz' + elif filename.lower().endswith(BZ2_EXTENSIONS): + mode = 'r:bz2' + elif filename.lower().endswith(XZ_EXTENSIONS): + mode = 'r:xz' + elif filename.lower().endswith('.tar'): + mode = 'r' + else: + logger.warning( + 'Cannot determine compression type for file %s', filename, + ) + mode = 'r:*' + tar = tarfile.open(filename, mode) + try: + leading = has_leading_dir([ + member.name for member in tar.getmembers() + ]) + for member in tar.getmembers(): + fn = member.name + if leading: + # https://github.com/python/mypy/issues/1174 + fn = split_leading_dir(fn)[1] # type: ignore + path = os.path.join(location, fn) + if not is_within_directory(location, path): + message = ( + 'The tar file ({}) has a file ({}) trying to install ' + 'outside target directory ({})' + ) + raise InstallationError( + message.format(filename, path, location) + ) + if member.isdir(): + ensure_dir(path) + elif member.issym(): + try: + # https://github.com/python/typeshed/issues/2673 + tar._extract_member(member, path) # type: ignore + except Exception as exc: + # Some corrupt tar files seem to produce this + # (specifically bad symlinks) + logger.warning( + 'In the tar file %s the member %s is invalid: %s', + filename, member.name, exc, + ) + continue + else: + try: + fp = tar.extractfile(member) + except (KeyError, AttributeError) as exc: + # Some corrupt tar files seem to produce this + # (specifically bad symlinks) + logger.warning( + 'In the tar file %s the member %s is invalid: %s', + filename, member.name, exc, + ) + continue + ensure_dir(os.path.dirname(path)) + with open(path, 'wb') as destfp: + shutil.copyfileobj(fp, destfp) + fp.close() + # Update the timestamp (useful for cython compiled files) + # https://github.com/python/typeshed/issues/2673 + tar.utime(member, path) # type: ignore + # member have any execute permissions for user/group/world? + if member.mode & 0o111: + # make dest file have execute for user/group/world + # no-op on windows per python docs + os.chmod(path, (0o777 - current_umask() | 0o111)) + finally: + tar.close() + + +def unpack_file( + filename, # type: str + location, # type: str + content_type=None, # type: Optional[str] +): + # type: (...) -> None + filename = os.path.realpath(filename) + if ( + content_type == 'application/zip' or + filename.lower().endswith(ZIP_EXTENSIONS) or + zipfile.is_zipfile(filename) + ): + unzip_file( + filename, + location, + flatten=not filename.endswith('.whl') + ) + elif ( + content_type == 'application/x-gzip' or + tarfile.is_tarfile(filename) or + filename.lower().endswith( + TAR_EXTENSIONS + BZ2_EXTENSIONS + XZ_EXTENSIONS + ) + ): + untar_file(filename, location) + else: + # FIXME: handle? + # FIXME: magic signatures? + logger.critical( + 'Cannot unpack file %s (downloaded from %s, content-type: %s); ' + 'cannot detect archive format', + filename, location, content_type, + ) + raise InstallationError( + 'Cannot determine archive format of {}'.format(location) + ) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/urls.py b/venv/lib/python3.8/site-packages/pip/_internal/utils/urls.py new file mode 100644 index 0000000..9ad40fe --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/utils/urls.py @@ -0,0 +1,54 @@ +import os +import sys + +from pip._vendor.six.moves.urllib import parse as urllib_parse +from pip._vendor.six.moves.urllib import request as urllib_request + +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import Optional, Text, Union + + +def get_url_scheme(url): + # type: (Union[str, Text]) -> Optional[Text] + if ':' not in url: + return None + return url.split(':', 1)[0].lower() + + +def path_to_url(path): + # type: (Union[str, Text]) -> str + """ + Convert a path to a file: URL. The path will be made absolute and have + quoted path parts. + """ + path = os.path.normpath(os.path.abspath(path)) + url = urllib_parse.urljoin('file:', urllib_request.pathname2url(path)) + return url + + +def url_to_path(url): + # type: (str) -> str + """ + Convert a file: URL to a path. + """ + assert url.startswith('file:'), ( + "You can only turn file: urls into filenames (not %r)" % url) + + _, netloc, path, _, _ = urllib_parse.urlsplit(url) + + if not netloc or netloc == 'localhost': + # According to RFC 8089, same as empty authority. + netloc = '' + elif sys.platform == 'win32': + # If we have a UNC path, prepend UNC share notation. + netloc = '\\\\' + netloc + else: + raise ValueError( + 'non-local file URIs are not supported on this platform: %r' + % url + ) + + path = urllib_request.url2pathname(netloc + path) + return path diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/virtualenv.py b/venv/lib/python3.8/site-packages/pip/_internal/utils/virtualenv.py new file mode 100644 index 0000000..d81e6ac --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/utils/virtualenv.py @@ -0,0 +1,115 @@ +from __future__ import absolute_import + +import logging +import os +import re +import site +import sys + +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from typing import List, Optional + +logger = logging.getLogger(__name__) +_INCLUDE_SYSTEM_SITE_PACKAGES_REGEX = re.compile( + r"include-system-site-packages\s*=\s*(?Ptrue|false)" +) + + +def _running_under_venv(): + # type: () -> bool + """Checks if sys.base_prefix and sys.prefix match. + + This handles PEP 405 compliant virtual environments. + """ + return sys.prefix != getattr(sys, "base_prefix", sys.prefix) + + +def _running_under_regular_virtualenv(): + # type: () -> bool + """Checks if sys.real_prefix is set. + + This handles virtual environments created with pypa's virtualenv. + """ + # pypa/virtualenv case + 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 _get_pyvenv_cfg_lines(): + # type: () -> 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. + """ + pyvenv_cfg_file = os.path.join(sys.prefix, 'pyvenv.cfg') + try: + with open(pyvenv_cfg_file) as f: + return f.read().splitlines() # avoids trailing newlines + except IOError: + return None + + +def _no_global_under_venv(): + # type: () -> bool + """Check `{sys.prefix}/pyvenv.cfg` for system site-packages inclusion + + PEP 405 specifies that when system site-packages are not supposed to be + visible from a virtual environment, `pyvenv.cfg` must contain the following + line: + + include-system-site-packages = false + + Additionally, log a warning if accessing the file fails. + """ + cfg_lines = _get_pyvenv_cfg_lines() + if cfg_lines is None: + # We're not in a "sane" venv, so assume there is no system + # site-packages access (since that's PEP 405's default state). + logger.warning( + "Could not access 'pyvenv.cfg' despite a virtual environment " + "being active. Assuming global site-packages is not accessible " + "in this environment." + ) + return True + + for line in cfg_lines: + match = _INCLUDE_SYSTEM_SITE_PACKAGES_REGEX.match(line) + if match is not None and match.group('value') == 'false': + return True + return False + + +def _no_global_under_regular_virtualenv(): + # type: () -> bool + """Check if "no-global-site-packages.txt" exists beside site.py + + This mirrors logic in pypa/virtualenv for determining whether system + site-packages are visible in the virtual environment. + """ + site_mod_dir = os.path.dirname(os.path.abspath(site.__file__)) + no_global_site_packages_file = os.path.join( + site_mod_dir, 'no-global-site-packages.txt', + ) + return os.path.exists(no_global_site_packages_file) + + +def virtualenv_no_global(): + # type: () -> bool + """Returns a boolean, whether running in venv with no system site-packages. + """ + + if _running_under_regular_virtualenv(): + return _no_global_under_regular_virtualenv() + + if _running_under_venv(): + return _no_global_under_venv() + + return False diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/wheel.py b/venv/lib/python3.8/site-packages/pip/_internal/utils/wheel.py new file mode 100644 index 0000000..837e0af --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/utils/wheel.py @@ -0,0 +1,225 @@ +"""Support functions for working with wheel files. +""" + +from __future__ import absolute_import + +import logging +from email.parser import Parser +from zipfile import ZipFile + +from pip._vendor.packaging.utils import canonicalize_name +from pip._vendor.pkg_resources import DistInfoDistribution +from pip._vendor.six import PY2, ensure_str + +from pip._internal.exceptions import UnsupportedWheel +from pip._internal.utils.pkg_resources import DictMetadata +from pip._internal.utils.typing import MYPY_CHECK_RUNNING + +if MYPY_CHECK_RUNNING: + from email.message import Message + from typing import Dict, Tuple + + from pip._vendor.pkg_resources import Distribution + +if PY2: + from zipfile import BadZipfile as BadZipFile +else: + from zipfile import BadZipFile + + +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(WheelMetadata, self).__init__(metadata) + self._wheel_name = wheel_name + + def get_metadata(self, name): + # type: (str) -> str + try: + return super(WheelMetadata, self).get_metadata(name) + except UnicodeDecodeError as e: + # Augment the default error with the origin of the file. + raise UnsupportedWheel( + "Error decoding metadata for {}: {}".format( + 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("{}/".format(info_dir)) + ] + + metadata_text = {} # type: Dict[str, bytes] + for path in metadata_files: + # If a flag is set, namelist entries may be unicode in Python 2. + # We coerce them to native str type to match the types used in the rest + # of the code. This cannot fail because unicode can always be encoded + # with UTF-8. + full_path = ensure_str(path) + _, metadata_name = full_path.split("/", 1) + + try: + metadata_text[metadata_name] = read_wheel_metadata_file( + wheel_zip, full_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] + """Extract information from the provided wheel, ensuring it meets basic + standards. + + Returns the name of the .dist-info directory and the parsed WHEEL metadata. + """ + try: + info_dir = wheel_dist_info_dir(wheel_zip, name) + metadata = wheel_metadata(wheel_zip, info_dir) + version = wheel_version(metadata) + except UnsupportedWheel as e: + raise UnsupportedWheel( + "{} has an invalid wheel, {}".format(name, str(e)) + ) + + check_compatibility(version, name) + + return info_dir, metadata + + +def wheel_dist_info_dir(source, name): + # type: (ZipFile, str) -> str + """Returns the name of the contained .dist-info directory. + + Raises AssertionError or UnsupportedWheel if not found, >1 found, or + it doesn't match the provided name. + """ + # Zip file path separators must be / + subdirs = list(set(p.split("/")[0] for p in source.namelist())) + + info_dirs = [s for s in subdirs if s.endswith('.dist-info')] + + if not info_dirs: + raise UnsupportedWheel(".dist-info directory not found") + + if len(info_dirs) > 1: + raise UnsupportedWheel( + "multiple .dist-info directories found: {}".format( + ", ".join(info_dirs) + ) + ) + + info_dir = info_dirs[0] + + info_dir_name = canonicalize_name(info_dir) + canonical_name = canonicalize_name(name) + if not info_dir_name.startswith(canonical_name): + raise UnsupportedWheel( + ".dist-info directory {!r} does not start with {!r}".format( + info_dir, canonical_name + ) + ) + + # Zip file paths can be unicode or str depending on the zip entry flags, + # so normalize it. + return ensure_str(info_dir) + + +def read_wheel_metadata_file(source, path): + # type: (ZipFile, str) -> bytes + try: + return source.read(path) + # BadZipFile for general corruption, KeyError for missing entry, + # and RuntimeError for password-protected files + except (BadZipFile, KeyError, RuntimeError) as e: + raise UnsupportedWheel( + "could not read {!r} file: {!r}".format(path, e) + ) + + +def wheel_metadata(source, dist_info_dir): + # type: (ZipFile, str) -> Message + """Return the WHEEL metadata of an extracted wheel, if possible. + Otherwise, raise UnsupportedWheel. + """ + path = "{}/WHEEL".format(dist_info_dir) + # Zip file path separators must be / + wheel_contents = read_wheel_metadata_file(source, path) + + try: + wheel_text = ensure_str(wheel_contents) + except UnicodeDecodeError as e: + raise UnsupportedWheel("error decoding {!r}: {!r}".format(path, e)) + + # FeedParser (used by Parser) does not raise any exceptions. The returned + # message may have .defects populated, but for backwards-compatibility we + # currently ignore them. + return Parser().parsestr(wheel_text) + + +def wheel_version(wheel_data): + # type: (Message) -> Tuple[int, ...] + """Given WHEEL metadata, return the parsed Wheel-Version. + Otherwise, raise UnsupportedWheel. + """ + version_text = wheel_data["Wheel-Version"] + if version_text is None: + raise UnsupportedWheel("WHEEL is missing Wheel-Version") + + version = version_text.strip() + + try: + return tuple(map(int, version.split('.'))) + except ValueError: + raise UnsupportedWheel("invalid Wheel-Version: {!r}".format(version)) + + +def check_compatibility(version, name): + # type: (Tuple[int, ...], 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 + ahead of what it's compatible with (e.g 2.0 > 1.1); and warn when + installing a version only minor version ahead (e.g 1.2 > 1.1). + + version: a 2-tuple representing a Wheel-Version (Major, Minor) + name: name of wheel or package to raise exception about + + :raises UnsupportedWheel: when an incompatible Wheel-Version is given + """ + if version[0] > VERSION_COMPATIBLE[0]: + raise UnsupportedWheel( + "%s's Wheel-Version (%s) is not compatible with this version " + "of pip" % (name, '.'.join(map(str, version))) + ) + elif version > VERSION_COMPATIBLE: + logger.warning( + 'Installing from a newer Wheel-Version (%s)', + '.'.join(map(str, version)), + ) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/vcs/__init__.py b/venv/lib/python3.8/site-packages/pip/_internal/vcs/__init__.py new file mode 100644 index 0000000..2a4eb13 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/vcs/__init__.py @@ -0,0 +1,15 @@ +# Expose a limited set of classes and functions so callers outside of +# the vcs package don't need to import deeper than `pip._internal.vcs`. +# (The test directory and imports protected by MYPY_CHECK_RUNNING may +# still need to import from a vcs sub-package.) +# Import all vcs modules to register each VCS in the VcsSupport object. +import pip._internal.vcs.bazaar +import pip._internal.vcs.git +import pip._internal.vcs.mercurial +import pip._internal.vcs.subversion # noqa: F401 +from pip._internal.vcs.versioncontrol import ( # noqa: F401 + RemoteNotFoundError, + is_url, + make_vcs_requirement_url, + vcs, +) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/vcs/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/vcs/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..ee80bcaedc7b46fb9fd4f630d41e657a49e464cc GIT binary patch literal 448 zcmZXQy-ve06os9pP1A}_2&obbEDRl*EC?8?iUr0FAeJnan^?uFf6^PfRe2*`$!jNG zfr;xD^^3kri&PDYL4>bf$t3>54rDRu`tujAjO7bspN-Si6MzAqh=w|leyrG<({0&M z;2S4^E3WO4#28M7eq4(>qe5E_n#l~qY{@uUwoC^{p6#&pC(^E+}yms`7vhaXjh`kWF&JO*8Yo-Dk}$f%Yl|kZ zMBDCMm_05Y^i>t&tKc*_P=}AqLvG z`LJ6vff@~klnXf1L`jkjGMyx*wj*?^wKPo_IM24=C2$+LOk5#sC*T{N@s-H8ji1UL zWx~gM^nT7vJxO|bs#KCZcfP;1p^M?hFdMFo2E(-XSn##Iz7Y9ZHrjde!T!5@w6=lI zY9Zk$8*rSBEvwS?;l8|x@BI`_h3Fi%*-Dj2u$a(gZeUu`agIA)oqqNQOg*yA>>(S~(Cqi` zfY8n(b_5$8Gr6L@2|I+PCeD#RagW*8?ty#YO`J!84k0J(IPs2Z$IhY8UGDwE1)hCK z9*iG0I@9N)rv&7V?u$+(Pe+PjsWM&4{Z3jfz+xR;S{^Qx&IT!gu#=ZPOPriVhNRQ( zK_7FfU+yJJ^KyhR5gE5s#;+oSc$z7#WPr<(@CgCJFL5sgRzI3-QdXKZgP6s;a zTvyi>Y4y62OE~^}ckKzl)4)Zianyu)xw9jr@iW9TNy1rWNOB_CMb`~0ZTMsr`3_C5 zp{vv}J0r3wx=lVdbxJ!mFE{6Is58)lbo8 z5SrPqI`)iQ5E53nAPN0VxacU)CHaedA6?fwukygE z{Jfm+(gunIRo4M!!qJeYT6_*#SR`7;O550*r%WmwO+tURWM#TjWy)rBt@>eZ_zzKvoX=}FR})U*!Yc8F>QwG*_X~-mQa0S z9*qIH4QD%KA~K10;7(jJ)gPU29w4N7M=rqUaUbJ5FrIhhO?)Wf1}L8>9$a=T=mG+r z{F?^&4w>sPL~jP;PJ&nTlN(R2a58wfDSw4;-+S)LpW!V(K-YE0D?I`#fwbK2RJr$N zXFQLLg)Db6@q$tVaxx(iS{&w?&a;6~NPt>qLwSql13Pb4l1wEOvnbHb!mFfo0t^%U zy!AeBqQmUhO$! z339m;OI*X?|5<|jmq};ArU?*k2jxBadvL#aiD!o7+n4}kUR@{xXGV40`CBxrTU3jW zu}wA6Ij+xq7|eYcdgJ9YvR9mEQX@%DHn0#U^l%3G-0@qt^SyLmb>Ow5LfEvmTUC>) z!^^?Xb*D%Xh3;9IX5tdyj6X;VabDCVn2xGflrb4k#FJ5)OE6b4$QxgtiupsX?h4gE zbR_DZMv@dIALT?hlY~yGR^%pqxyCb8D}^w1vbo)4Y6^Z>2xW^F(*#a+)+>bWmt0ar zv#Cw~hA0Y*@+KWLXDg*C7lBmXr|vWAC={92w3zCNJWrBSm$d-z5FeFplxEdi=qMxD zU(l?%tl>rTQ9JUZz-8?S;}%-zGP|dHjjp*p(j$p$N(yeKMoA1gPhQ6;zKYsxJ=sOE zSITvjJzX!#U7^Q52be602B2&F84U)f_Yp>%`qphJVdjbK= z77kZl$E5d%BoU?e*MEs%XwhjpXZNF+T%Y<q>m)S&BQ)Xk+&P*dca|;csP2$d zW}7;k{!cci%P(k>%I;~MEX59rB9zUqlE_J{HPNlgbv`5~SA@|f5_RM@kx`oVw*cS} Lz2G&xg}?p}&mW+f literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/vcs/__pycache__/git.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/vcs/__pycache__/git.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..d32b9608f5b1b2b7e9c438e15c6a55318b03eb30 GIT binary patch literal 9559 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 QF+Kdb*7R?*-)O=A0+tw;mH+?% literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/vcs/__pycache__/mercurial.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/vcs/__pycache__/mercurial.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..d412bb0a7f4b69c924d0da4f0994397943c37877 GIT binary patch literal 4888 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 D+VPJq literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/vcs/__pycache__/versioncontrol.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/vcs/__pycache__/versioncontrol.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..1898c9586766b8218df5512bbd79e9fbb94f5057 GIT binary patch literal 19216 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 K+w*q{x&I4X2Bgja literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/vcs/bazaar.py b/venv/lib/python3.8/site-packages/pip/_internal/vcs/bazaar.py new file mode 100644 index 0000000..347c06f --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/vcs/bazaar.py @@ -0,0 +1,120 @@ +# The following comment should be removed at some point in the future. +# mypy: disallow-untyped-defs=False + +from __future__ import absolute_import + +import logging +import os + +from pip._vendor.six.moves.urllib import parse as urllib_parse + +from pip._internal.utils.misc import display_path, rmtree +from pip._internal.utils.subprocess import make_command +from pip._internal.utils.typing import MYPY_CHECK_RUNNING +from pip._internal.utils.urls import path_to_url +from pip._internal.vcs.versioncontrol import VersionControl, vcs + +if MYPY_CHECK_RUNNING: + from typing import Optional, Tuple + from pip._internal.utils.misc import HiddenText + from pip._internal.vcs.versioncontrol import AuthInfo, RevOptions + + +logger = logging.getLogger(__name__) + + +class Bazaar(VersionControl): + name = 'bzr' + dirname = '.bzr' + repo_name = 'branch' + schemes = ( + 'bzr', 'bzr+http', 'bzr+https', 'bzr+ssh', 'bzr+sftp', 'bzr+ftp', + 'bzr+lp', + ) + + def __init__(self, *args, **kwargs): + super(Bazaar, self).__init__(*args, **kwargs) + # This is only needed for python <2.7.5 + # Register lp but do not expose as a scheme to support bzr+lp. + if getattr(urllib_parse, 'uses_fragment', None): + urllib_parse.uses_fragment.extend(['lp']) + + @staticmethod + def get_base_rev_args(rev): + return ['-r', rev] + + def export(self, location, url): + # type: (str, HiddenText) -> None + """ + Export the Bazaar repository at the url to the destination location + """ + # Remove the location to make sure Bazaar can export it correctly + if os.path.exists(location): + rmtree(location) + + url, rev_options = self.get_url_rev_options(url) + self.run_command( + make_command('export', location, url, rev_options.to_args()), + show_stdout=False, + ) + + def fetch_new(self, dest, url, rev_options): + # type: (str, HiddenText, RevOptions) -> None + rev_display = rev_options.to_display() + logger.info( + 'Checking out %s%s to %s', + url, + rev_display, + display_path(dest), + ) + cmd_args = ( + make_command('branch', '-q', 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 update(self, dest, url, rev_options): + # type: (str, HiddenText, RevOptions) -> None + cmd_args = make_command('pull', '-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 + url, rev, user_pass = super(Bazaar, cls).get_url_rev_and_auth(url) + if url.startswith('ssh://'): + url = 'bzr+' + url + return url, rev, user_pass + + @classmethod + def get_remote_url(cls, location): + urls = cls.run_command(['info'], show_stdout=False, cwd=location) + for line in urls.splitlines(): + line = line.strip() + for x in ('checkout of branch: ', + 'parent branch: '): + if line.startswith(x): + repo = line.split(x)[1] + if cls._is_local_repository(repo): + return path_to_url(repo) + return repo + return None + + @classmethod + def get_revision(cls, location): + revision = cls.run_command( + ['revno'], show_stdout=False, cwd=location, + ) + return revision.splitlines()[-1] + + @classmethod + def is_commit_id_equal(cls, dest, name): + """Always assume the versions don't match""" + return False + + +vcs.register(Bazaar) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/vcs/git.py b/venv/lib/python3.8/site-packages/pip/_internal/vcs/git.py new file mode 100644 index 0000000..d706064 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/vcs/git.py @@ -0,0 +1,395 @@ +# The following comment should be removed at some point in the future. +# mypy: disallow-untyped-defs=False + +from __future__ import absolute_import + +import logging +import os.path +import re + +from pip._vendor.packaging.version import parse as parse_version +from pip._vendor.six.moves.urllib import parse as urllib_parse +from pip._vendor.six.moves.urllib import request as urllib_request + +from pip._internal.exceptions import BadCommand +from pip._internal.utils.misc import display_path, hide_url +from pip._internal.utils.subprocess import make_command +from pip._internal.utils.temp_dir import TempDirectory +from pip._internal.utils.typing import MYPY_CHECK_RUNNING +from pip._internal.vcs.versioncontrol import ( + RemoteNotFoundError, + VersionControl, + find_path_to_setup_from_repo_root, + vcs, +) + +if MYPY_CHECK_RUNNING: + from typing import Optional, Tuple + from pip._internal.utils.misc import HiddenText + from pip._internal.vcs.versioncontrol import AuthInfo, RevOptions + + +urlsplit = urllib_parse.urlsplit +urlunsplit = urllib_parse.urlunsplit + + +logger = logging.getLogger(__name__) + + +HASH_REGEX = re.compile('^[a-fA-F0-9]{40}$') + + +def looks_like_hash(sha): + return bool(HASH_REGEX.match(sha)) + + +class Git(VersionControl): + name = 'git' + dirname = '.git' + repo_name = 'clone' + schemes = ( + 'git', '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' + + @staticmethod + def get_base_rev_args(rev): + return [rev] + + def is_immutable_rev_checkout(self, url, dest): + # type: (str, str) -> bool + _, rev_options = self.get_url_rev_options(hide_url(url)) + if not rev_options.rev: + return False + if not self.is_commit_id_equal(dest, rev_options.rev): + # the current commit is different from rev, + # which means rev was something else than a commit hash + return False + # 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] + ) + return not is_tag_or_branch + + def get_git_version(self): + VERSION_PFX = 'git version ' + version = self.run_command(['version'], show_stdout=False) + 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) + + @classmethod + def get_current_branch(cls, location): + """ + Return the current branch, or None if HEAD isn't at a branch + (e.g. detached HEAD). + """ + # git-symbolic-ref exits with empty stdout if "HEAD" is a detached + # 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'] + output = cls.run_command( + args, extra_ok_returncodes=(1, ), show_stdout=False, cwd=location, + ) + ref = output.strip() + + if ref.startswith('refs/heads/'): + return ref[len('refs/heads/'):] + + return None + + def export(self, location, url): + # type: (str, HiddenText) -> None + """Export the Git repository at the url to the destination location""" + if not location.endswith('/'): + location = location + '/' + + with TempDirectory(kind="export") as temp_dir: + self.unpack(temp_dir.path, url=url) + self.run_command( + ['checkout-index', '-a', '-f', '--prefix', location], + show_stdout=False, cwd=temp_dir.path + ) + + @classmethod + def get_revision_sha(cls, dest, rev): + """ + 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. + + Args: + dest: the repository directory. + rev: the revision name. + """ + # Pass rev to pre-filter the list. + output = cls.run_command(['show-ref', rev], cwd=dest, + show_stdout=False, on_returncode='ignore') + refs = {} + # NOTE: We do not use splitlines here since that would split on other + # unicode separators, which can be maliciously used to install a + # different revision. + for line in output.strip().split("\n"): + line = line.rstrip("\r") + if not line: + continue + try: + sha, ref = line.split(" ", maxsplit=2) + except ValueError: + # Include the offending line to simplify troubleshooting if + # this error ever occurs. + raise ValueError('unexpected show-ref line: {!r}'.format(line)) + + refs[ref] = sha + + branch_ref = 'refs/remotes/origin/{}'.format(rev) + tag_ref = 'refs/tags/{}'.format(rev) + + sha = refs.get(branch_ref) + if sha is not None: + return (sha, True) + + sha = refs.get(tag_ref) + + return (sha, False) + + @classmethod + def resolve_revision(cls, dest, url, rev_options): + # type: (str, HiddenText, RevOptions) -> RevOptions + """ + Resolve a revision to a new RevOptions object with the SHA1 of the + branch, tag, or ref if found. + + Args: + rev_options: a RevOptions object. + """ + rev = rev_options.arg_rev + # The arg_rev property's implementation for Git ensures that the + # rev return value is always non-None. + assert rev is not None + + sha, is_branch = cls.get_revision_sha(dest, rev) + + if sha is not None: + rev_options = rev_options.make_new(sha) + rev_options.branch_name = rev if is_branch else None + + return rev_options + + # Do not show a warning for the common case of something that has + # the form of a Git commit hash. + if not looks_like_hash(rev): + logger.warning( + "Did not find branch or tag '%s', assuming revision or ref.", + rev, + ) + + if not rev.startswith('refs/'): + return rev_options + + # If it looks like a ref, we have to fetch it explicitly. + cls.run_command( + 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') + rev_options = rev_options.make_new(sha) + + return rev_options + + @classmethod + def is_commit_id_equal(cls, dest, name): + """ + Return whether the current commit hash equals the given name. + + Args: + dest: the repository directory. + name: a string name. + """ + if not name: + # Then avoid an unnecessary subprocess call. + return False + + return cls.get_revision(dest) == name + + def fetch_new(self, dest, url, rev_options): + # type: (str, HiddenText, RevOptions) -> 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)) + + 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) + 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(), + ) + 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 = 'origin/{}'.format(branch_name) + cmd_args = [ + 'checkout', '-b', branch_name, '--track', track_branch, + ] + self.run_command(cmd_args, cwd=dest) + + #: repo may contain submodules + self.update_submodules(dest) + + def switch(self, dest, url, rev_options): + # type: (str, HiddenText, RevOptions) -> None + self.run_command( + make_command('config', 'remote.origin.url', url), + cwd=dest, + ) + 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 + # First fetch changes from the default remote + if self.get_git_version() >= parse_version('1.9.0'): + # fetch tags in addition to everything else + self.run_command(['fetch', '-q', '--tags'], cwd=dest) + else: + 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()) + self.run_command(cmd_args, cwd=dest) + #: update submodules + self.update_submodules(dest) + + @classmethod + def get_remote_url(cls, location): + """ + Return URL of the first remote encountered. + + Raises RemoteNotFoundError if the repository does not have a remote + url configured. + """ + # 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, ), show_stdout=False, cwd=location, + ) + remotes = stdout.splitlines() + try: + found_remote = remotes[0] + except IndexError: + raise RemoteNotFoundError + + for remote in remotes: + if remote.startswith('remote.origin.url '): + found_remote = remote + break + url = found_remote.split(' ')[1] + return url.strip() + + @classmethod + def get_revision(cls, location, rev=None): + if rev is None: + rev = 'HEAD' + current_rev = cls.run_command( + ['rev-parse', rev], show_stdout=False, cwd=location, + ) + return current_rev.strip() + + @classmethod + def get_subdirectory(cls, location): + """ + Return the path to setup.py, relative to the repo root. + Return None if setup.py is in the repo root. + """ + # find the repo root + git_dir = cls.run_command( + ['rev-parse', '--git-dir'], + show_stdout=False, 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) + + @classmethod + def get_url_rev_and_auth(cls, url): + # type: (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 + work with a ssh:// scheme (e.g. GitHub). But we need a scheme for + parsing. Hence we remove it again afterwards and return it as a stub. + """ + # 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('/') + ) + url = urlunsplit((scheme, netloc, newpath, query, fragment)) + 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://') + url, rev, user_pass = super(Git, cls).get_url_rev_and_auth(url) + url = url.replace('ssh://', '') + else: + url, rev, user_pass = super(Git, cls).get_url_rev_and_auth(url) + + return url, rev, user_pass + + @classmethod + def update_submodules(cls, location): + if not os.path.exists(os.path.join(location, '.gitmodules')): + return + cls.run_command( + ['submodule', 'update', '--init', '--recursive', '-q'], + cwd=location, + ) + + @classmethod + def controls_location(cls, location): + if super(Git, cls).controls_location(location): + return True + try: + r = cls.run_command(['rev-parse'], + cwd=location, + show_stdout=False, + on_returncode='ignore', + log_failed_cmd=False) + return not r + except BadCommand: + logger.debug("could not determine if %s is under git control " + "because git is not available", location) + return False + + +vcs.register(Git) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/vcs/mercurial.py b/venv/lib/python3.8/site-packages/pip/_internal/vcs/mercurial.py new file mode 100644 index 0000000..d9b58cf --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/vcs/mercurial.py @@ -0,0 +1,155 @@ +# The following comment should be removed at some point in the future. +# mypy: disallow-untyped-defs=False + +from __future__ import absolute_import + +import logging +import os + +from pip._vendor.six.moves import configparser + +from pip._internal.exceptions import BadCommand, InstallationError +from pip._internal.utils.misc import display_path +from pip._internal.utils.subprocess import make_command +from pip._internal.utils.temp_dir import TempDirectory +from pip._internal.utils.typing import MYPY_CHECK_RUNNING +from pip._internal.utils.urls import path_to_url +from pip._internal.vcs.versioncontrol import ( + VersionControl, + find_path_to_setup_from_repo_root, + vcs, +) + +if MYPY_CHECK_RUNNING: + from pip._internal.utils.misc import HiddenText + from pip._internal.vcs.versioncontrol import RevOptions + + +logger = logging.getLogger(__name__) + + +class Mercurial(VersionControl): + name = 'hg' + dirname = '.hg' + repo_name = 'clone' + schemes = ( + 'hg', 'hg+file', 'hg+http', 'hg+https', 'hg+ssh', 'hg+static-http', + ) + + @staticmethod + def get_base_rev_args(rev): + return [rev] + + def export(self, location, url): + # type: (str, HiddenText) -> None + """Export the Hg repository at the url to the destination location""" + with TempDirectory(kind="export") as temp_dir: + self.unpack(temp_dir.path, url=url) + + self.run_command( + ['archive', location], show_stdout=False, cwd=temp_dir.path + ) + + def fetch_new(self, dest, url, rev_options): + # type: (str, HiddenText, RevOptions) -> None + rev_display = rev_options.to_display() + logger.info( + 'Cloning hg %s%s to %s', + url, + rev_display, + display_path(dest), + ) + self.run_command(make_command('clone', '--noupdate', '-q', url, dest)) + self.run_command( + make_command('update', '-q', 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') + config = configparser.RawConfigParser() + try: + config.read(repo_config) + 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, + ) + else: + 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()) + self.run_command(cmd_args, cwd=dest) + + @classmethod + def get_remote_url(cls, location): + url = cls.run_command( + ['showconfig', 'paths.default'], + show_stdout=False, cwd=location).strip() + if cls._is_local_repository(url): + url = path_to_url(url) + return url.strip() + + @classmethod + def get_revision(cls, location): + """ + Return the repository-local changeset revision number, as an integer. + """ + current_revision = cls.run_command( + ['parents', '--template={rev}'], + show_stdout=False, cwd=location).strip() + return current_revision + + @classmethod + def get_requirement_revision(cls, location): + """ + Return the changeset identification hash, as a 40-character + hexadecimal string + """ + current_rev_hash = cls.run_command( + ['parents', '--template={node}'], + show_stdout=False, cwd=location).strip() + return current_rev_hash + + @classmethod + def is_commit_id_equal(cls, dest, name): + """Always assume the versions don't match""" + return False + + @classmethod + def get_subdirectory(cls, location): + """ + Return the path to setup.py, relative to the repo root. + Return None if setup.py is in the repo root. + """ + # find the repo root + repo_root = cls.run_command( + ['root'], show_stdout=False, 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) + + @classmethod + def controls_location(cls, location): + if super(Mercurial, cls).controls_location(location): + return True + try: + cls.run_command( + ['identify'], + cwd=location, + show_stdout=False, + on_returncode='raise', + log_failed_cmd=False) + return True + except (BadCommand, InstallationError): + return False + + +vcs.register(Mercurial) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/vcs/subversion.py b/venv/lib/python3.8/site-packages/pip/_internal/vcs/subversion.py new file mode 100644 index 0000000..6c76d1a --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/vcs/subversion.py @@ -0,0 +1,333 @@ +# The following comment should be removed at some point in the future. +# mypy: disallow-untyped-defs=False + +from __future__ import absolute_import + +import logging +import os +import re + +from pip._internal.utils.logging import indent_log +from pip._internal.utils.misc import ( + display_path, + is_console_interactive, + rmtree, + split_auth_from_netloc, +) +from pip._internal.utils.subprocess import make_command +from pip._internal.utils.typing import MYPY_CHECK_RUNNING +from pip._internal.vcs.versioncontrol import VersionControl, vcs + +_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'(.*)') + + +if MYPY_CHECK_RUNNING: + from typing import Optional, Tuple + from pip._internal.utils.subprocess import CommandArgs + from pip._internal.utils.misc import HiddenText + from pip._internal.vcs.versioncontrol import AuthInfo, RevOptions + + +logger = logging.getLogger(__name__) + + +class Subversion(VersionControl): + name = 'svn' + dirname = '.svn' + repo_name = 'checkout' + schemes = ('svn', 'svn+ssh', 'svn+http', 'svn+https', 'svn+svn') + + @classmethod + def should_add_vcs_url_prefix(cls, remote_url): + return True + + @staticmethod + def get_base_rev_args(rev): + return ['-r', rev] + + @classmethod + def get_revision(cls, location): + """ + Return the maximum revision for all files under a given location + """ + # Note: taken from setuptools.command.egg_info + revision = 0 + + for base, dirs, files in os.walk(location): + if cls.dirname not in dirs: + dirs[:] = [] + continue # no sense walking uncontrolled subdirs + dirs.remove(cls.dirname) + entries_fn = os.path.join(base, cls.dirname, 'entries') + if not os.path.exists(entries_fn): + # FIXME: should we warn? + continue + + dirurl, localrev = cls._get_svn_url_rev(base) + + if base == location: + 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 + revision = max(revision, localrev) + return revision + + @classmethod + def get_netloc_and_auth(cls, netloc, scheme): + """ + 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': + # The --username and --password options can't be used for + # svn+ssh URLs, so keep the auth information in the URL. + return super(Subversion, cls).get_netloc_and_auth(netloc, scheme) + + 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 + url, rev, user_pass = super(Subversion, cls).get_url_rev_and_auth(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 + if username: + extra_args += ['--username', username] + if password: + extra_args += ['--password', password] + + return extra_args + + @classmethod + def get_remote_url(cls, location): + # 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 + orig_location = location + while not os.path.exists(os.path.join(location, 'setup.py')): + 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 + logger.warning( + "Could not find setup.py for directory %s (tried all " + "parent directories)", + orig_location, + ) + return None + + return cls._get_svn_url_rev(location)[0] + + @classmethod + def _get_svn_url_rev(cls, location): + from pip._internal.exceptions import InstallationError + + 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 = '' + + if (data.startswith('8') or + data.startswith('9') or + data.startswith('10')): + data = list(map(str.splitlines, data.split('\n\x0c\n'))) + del data[0][0] # get rid of the '8' + url = data[0][3] + revs = [int(d[9]) for d in data if len(d) > 9 and d[9]] + [0] + elif data.startswith('= 1.7 + # Note that using get_remote_call_options is not necessary here + # because `svn info` is being run against a local directory. + # We don't need to worry about making sure interactive mode + # is being used to prompt for passwords, because passwords + # are only potentially needed for remote server requests. + xml = cls.run_command( + ['info', '--xml', location], + show_stdout=False, + ) + url = _svn_info_xml_url_re.search(xml).group(1) + revs = [ + int(m.group(1)) for m in _svn_info_xml_rev_re.finditer(xml) + ] + except InstallationError: + url, revs = None, [] + + if revs: + rev = max(revs) + else: + rev = 0 + + return url, rev + + @classmethod + def is_commit_id_equal(cls, dest, name): + """Always assume the versions don't match""" + return False + + def __init__(self, use_interactive=None): + # type: (bool) -> None + if use_interactive is None: + use_interactive = is_console_interactive() + self.use_interactive = use_interactive + + # This member is used to cache the fetched version of the current + # ``svn`` client. + # Special value definitions: + # None: Not evaluated yet. + # Empty tuple: Could not parse version. + self._vcs_version = None # type: Optional[Tuple[int, ...]] + + super(Subversion, self).__init__() + + def call_vcs_version(self): + # type: () -> Tuple[int, ...] + """Query the version of the currently installed Subversion client. + + :return: A tuple containing the parts of the version information or + ``()`` if the version returned from ``svn`` could not be parsed. + :raises: BadCommand: If ``svn`` is not installed. + """ + # Example versions: + # svn, version 1.10.3 (r1842928) + # compiled Feb 25 2019, 14:20:39 on x86_64-apple-darwin17.0.0 + # svn, version 1.7.14 (r1542130) + # compiled Mar 28 2018, 08:49:13 on x86_64-pc-linux-gnu + version_prefix = 'svn, version ' + version = self.run_command(['--version'], show_stdout=False) + if not version.startswith(version_prefix): + return () + + version = version[len(version_prefix):].split()[0] + version_list = version.split('.') + try: + parsed_version = tuple(map(int, version_list)) + except ValueError: + return () + + return parsed_version + + def get_vcs_version(self): + # type: () -> Tuple[int, ...] + """Return the version of the currently installed Subversion client. + + If the version of the Subversion client has already been queried, + a cached value will be used. + + :return: A tuple containing the parts of the version information or + ``()`` if the version returned from ``svn`` could not be parsed. + :raises: BadCommand: If ``svn`` is not installed. + """ + if self._vcs_version is not None: + # Use cached version, if available. + # If parsing the version failed previously (empty tuple), + # do not attempt to parse it again. + return self._vcs_version + + vcs_version = self.call_vcs_version() + self._vcs_version = vcs_version + return vcs_version + + def get_remote_call_options(self): + # type: () -> CommandArgs + """Return options to be used on calls to Subversion that contact the server. + + These options are applicable for the following ``svn`` subcommands used + in this class. + + - checkout + - export + - switch + - update + + :return: A list of command line arguments to pass to ``svn``. + """ + 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'] + + svn_version = self.get_vcs_version() + # By default, Subversion >= 1.8 runs in non-interactive mode if + # stdin is not a TTY. Since that is how pip invokes SVN, in + # call_subprocess(), pip must pass --force-interactive to ensure + # the user can be prompted for a password, if required. + # SVN added the --force-interactive option in SVN 1.8. Since + # e.g. RHEL/CentOS 7, which is supported until 2024, ships with + # 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 [] + + def export(self, location, url): + # type: (str, HiddenText) -> None + """Export the svn repository at the url to the destination location""" + url, rev_options = self.get_url_rev_options(url) + + logger.info('Exporting svn repository %s to %s', url, location) + with indent_log(): + if os.path.exists(location): + # Subversion doesn't like to check out over an existing + # directory --force fixes this, but was only added in svn 1.5 + rmtree(location) + cmd_args = make_command( + 'export', self.get_remote_call_options(), + rev_options.to_args(), url, location, + ) + self.run_command(cmd_args, show_stdout=False) + + def fetch_new(self, dest, url, rev_options): + # type: (str, HiddenText, RevOptions) -> None + rev_display = rev_options.to_display() + logger.info( + 'Checking out %s%s to %s', + url, + rev_display, + display_path(dest), + ) + cmd_args = make_command( + 'checkout', '-q', 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 + cmd_args = make_command( + '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 + cmd_args = make_command( + 'update', self.get_remote_call_options(), rev_options.to_args(), + dest, + ) + self.run_command(cmd_args) + + +vcs.register(Subversion) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/vcs/versioncontrol.py b/venv/lib/python3.8/site-packages/pip/_internal/vcs/versioncontrol.py new file mode 100644 index 0000000..7cfd568 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/vcs/versioncontrol.py @@ -0,0 +1,700 @@ +"""Handles all VCS (version control) support""" + +from __future__ import absolute_import + +import errno +import logging +import os +import shutil +import sys + +from pip._vendor import pkg_resources +from pip._vendor.six.moves.urllib import parse as urllib_parse + +from pip._internal.exceptions import BadCommand +from pip._internal.utils.compat import samefile +from pip._internal.utils.misc import ( + ask_path_exists, + backup_dir, + display_path, + hide_url, + hide_value, + rmtree, +) +from pip._internal.utils.subprocess import call_subprocess, make_command +from pip._internal.utils.typing import MYPY_CHECK_RUNNING +from pip._internal.utils.urls import get_url_scheme + +if MYPY_CHECK_RUNNING: + from typing import ( + Any, Dict, Iterable, Iterator, List, Mapping, Optional, Text, Tuple, + Type, Union + ) + from pip._internal.utils.ui import SpinnerInterface + from pip._internal.utils.misc import HiddenText + from pip._internal.utils.subprocess import CommandArgs + + AuthInfo = Tuple[Optional[str], Optional[str]] + + +__all__ = ['vcs'] + + +logger = logging.getLogger(__name__) + + +def is_url(name): + # type: (Union[str, Text]) -> 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 + + +def make_vcs_requirement_url(repo_url, rev, project_name, subdir=None): + # type: (str, str, str, Optional[str]) -> str + """ + Return the URL for a VCS requirement. + + Args: + repo_url: the remote VCS url, with any needed VCS prefix (e.g. "git+"). + project_name: the (unescaped) project name. + """ + egg_project_name = pkg_resources.to_filename(project_name) + req = '{}@{}#egg={}'.format(repo_url, rev, egg_project_name) + if subdir: + req += '&subdirectory={}'.format(subdir) + + return req + + +def find_path_to_setup_from_repo_root(location, repo_root): + # type: (str, 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 setup.py + orig_location = location + while not os.path.exists(os.path.join(location, 'setup.py')): + 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 + logger.warning( + "Could not find setup.py for directory %s (tried all " + "parent directories)", + orig_location, + ) + return None + + if samefile(repo_root, location): + return None + + return os.path.relpath(location, repo_root) + + +class RemoteNotFoundError(Exception): + pass + + +class RevOptions(object): + + """ + Encapsulates a VCS-specific revision to install, along with any VCS + install options. + + Instances of this class should be treated as if immutable. + """ + + def __init__( + self, + vc_class, # type: Type[VersionControl] + rev=None, # type: Optional[str] + extra_args=None, # type: Optional[CommandArgs] + ): + # type: (...) -> None + """ + Args: + vc_class: a VersionControl subclass. + rev: the name of the revision to install. + extra_args: a list of extra options. + """ + if extra_args is None: + extra_args = [] + + self.extra_args = extra_args + self.rev = rev + self.vc_class = vc_class + self.branch_name = None # type: Optional[str] + + def __repr__(self): + # type: () -> str + return ''.format(self.vc_class.name, self.rev) + + @property + def arg_rev(self): + # type: () -> Optional[str] + if self.rev is None: + return self.vc_class.default_arg_rev + + return self.rev + + def to_args(self): + # type: () -> CommandArgs + """ + Return the VCS-specific command arguments. + """ + args = [] # type: CommandArgs + rev = self.arg_rev + if rev is not None: + args += self.vc_class.get_base_rev_args(rev) + args += self.extra_args + + return args + + def to_display(self): + # type: () -> str + if not self.rev: + return '' + + return ' (to revision {})'.format(self.rev) + + def make_new(self, rev): + # type: (str) -> RevOptions + """ + Make a copy of the current instance, but with a new rev. + + Args: + rev: the name of the revision for the new object. + """ + return self.vc_class.make_rev_options(rev, extra_args=self.extra_args) + + +class VcsSupport(object): + _registry = {} # type: Dict[str, VersionControl] + schemes = ['ssh', 'git', 'hg', 'bzr', 'sftp', 'svn'] + + def __init__(self): + # type: () -> None + # Register more schemes with urlparse for various version control + # systems + urllib_parse.uses_netloc.extend(self.schemes) + # Python >= 2.7.4, 3.3 doesn't have uses_fragment + if getattr(urllib_parse, 'uses_fragment', None): + urllib_parse.uses_fragment.extend(self.schemes) + super(VcsSupport, self).__init__() + + def __iter__(self): + # type: () -> Iterator[str] + return self._registry.__iter__() + + @property + def backends(self): + # type: () -> List[VersionControl] + return list(self._registry.values()) + + @property + def dirnames(self): + # type: () -> List[str] + return [backend.dirname for backend in self.backends] + + @property + def all_schemes(self): + # type: () -> List[str] + schemes = [] # type: 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__) + return + if cls.name not in self._registry: + self._registry[cls.name] = cls() + logger.debug('Registered VCS backend: %s', cls.name) + + def unregister(self, name): + # type: (str) -> None + if name in self._registry: + del self._registry[name] + + def get_backend_for_dir(self, location): + # type: (str) -> Optional[VersionControl] + """ + Return a VersionControl object if a repository of that type is found + at the given directory. + """ + for vcs_backend in self._registry.values(): + if vcs_backend.controls_location(location): + logger.debug('Determine that %s uses VCS: %s', + location, vcs_backend.name) + return vcs_backend + return None + + def get_backend_for_scheme(self, scheme): + # type: (str) -> Optional[VersionControl] + """ + Return a VersionControl object or None. + """ + for vcs_backend in self._registry.values(): + if scheme in vcs_backend.schemes: + return vcs_backend + return None + + def get_backend(self, name): + # type: (str) -> Optional[VersionControl] + """ + Return a VersionControl object or None. + """ + name = name.lower() + return self._registry.get(name) + + +vcs = VcsSupport() + + +class VersionControl(object): + name = '' + dirname = '' + repo_name = '' + # List of supported schemes for this Version Control + schemes = () # type: Tuple[str, ...] + # Iterable of environment variable names to pass to call_subprocess(). + unset_environ = () # type: Tuple[str, ...] + default_arg_rev = None # type: Optional[str] + + @classmethod + def should_add_vcs_url_prefix(cls, remote_url): + # type: (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('{}:'.format(cls.name)) + + @classmethod + def get_subdirectory(cls, location): + # type: (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 None + + @classmethod + def get_requirement_revision(cls, repo_dir): + # type: (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) -> Optional[str] + """ + Return the requirement string to use to redownload the files + currently at the given repository directory. + + Args: + project_name: the (unescaped) project name. + + The return value has a form similar to the following: + + {repository_url}@{revision}#egg={project_name} + """ + repo_url = cls.get_remote_url(repo_dir) + if repo_url is None: + return None + + if cls.should_add_vcs_url_prefix(repo_url): + repo_url = '{}+{}'.format(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) + + return req + + @staticmethod + def get_base_rev_args(rev): + # type: (str) -> List[str] + """ + Return the base revision arguments for a vcs command. + + Args: + rev: the name of a revision to install. Cannot be None. + """ + raise NotImplementedError + + def is_immutable_rev_checkout(self, url, dest): + # type: (str, str) -> bool + """ + Return true if the commit hash checked out at dest matches + the revision in url. + + Always return False, if the VCS does not support immutable commit + hashes. + + This method does not check if there are local uncommitted changes + in dest after checkout, as pip currently has no use case for that. + """ + return False + + @classmethod + def make_rev_options(cls, rev=None, extra_args=None): + # type: (Optional[str], Optional[CommandArgs]) -> RevOptions + """ + Return a RevOptions object. + + Args: + rev: the name of a revision to install. + extra_args: a list of extra options. + """ + return RevOptions(cls, rev, extra_args=extra_args) + + @classmethod + def _is_local_repository(cls, repo): + # type: (str) -> bool + """ + 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) + + def export(self, location, url): + # type: (str, HiddenText) -> None + """ + Export the repository at the url to the destination location + i.e. only download the files, without vcs informations + + :param url: the repository URL starting with a vcs prefix. + """ + raise NotImplementedError + + @classmethod + def get_netloc_and_auth(cls, netloc, scheme): + # type: (str, 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. + + Args: + netloc: the original repository URL netloc. + scheme: the repository URL's scheme without the vcs prefix. + + This is mainly for the Subversion class to override, so that auth + information can be provided via the --username and --password options + instead of through the URL. For other subclasses like Git without + such an option, auth information must stay in the URL. + + Returns: (netloc, (username, password)). + """ + return netloc, (None, None) + + @classmethod + def get_url_rev_and_auth(cls, url): + # type: (str) -> Tuple[str, Optional[str], AuthInfo] + """ + Parse the repository URL to use, and return the URL, revision, + and auth info to use. + + Returns: (url, rev, (username, password)). + """ + scheme, netloc, path, query, frag = urllib_parse.urlsplit(url) + if '+' not in scheme: + raise ValueError( + "Sorry, {!r} is a malformed VCS url. " + "The format is +://, " + "e.g. svn+http://myrepo/svn/MyApp#egg=MyApp".format(url) + ) + # Remove the vcs prefix. + 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) + 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 + """ + Return the RevOptions "extra arguments" to use in obtain(). + """ + return [] + + def get_url_rev_options(self, url): + # type: (HiddenText) -> Tuple[HiddenText, RevOptions] + """ + Return the URL and RevOptions object to use in obtain() and in + some cases export(), 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] + if secret_password is not None: + password = hide_value(secret_password) + extra_args = self.make_rev_args(username, password) + rev_options = self.make_rev_options(rev, extra_args=extra_args) + + return hide_url(secret_url), rev_options + + @staticmethod + def normalize_url(url): + # type: (str) -> str + """ + Normalize a URL for comparison by unquoting it and removing any + trailing slash. + """ + return urllib_parse.unquote(url).rstrip('/') + + @classmethod + def compare_urls(cls, url1, url2): + # type: (str, str) -> bool + """ + Compare two repo URLs for identity, ignoring incidental differences. + """ + return (cls.normalize_url(url1) == cls.normalize_url(url2)) + + def fetch_new(self, dest, url, rev_options): + # type: (str, HiddenText, RevOptions) -> None + """ + Fetch a revision from a repository, in the case that this is the + first fetch from the repository. + + Args: + dest: the directory to fetch the repository to. + rev_options: a RevOptions object. + """ + raise NotImplementedError + + def switch(self, dest, url, rev_options): + # type: (str, HiddenText, RevOptions) -> None + """ + Switch the repo at ``dest`` to point to ``URL``. + + Args: + rev_options: a RevOptions object. + """ + raise NotImplementedError + + def update(self, dest, url, rev_options): + # type: (str, HiddenText, RevOptions) -> None + """ + Update an already-existing repo to the given ``rev_options``. + + Args: + rev_options: a RevOptions object. + """ + raise NotImplementedError + + @classmethod + def is_commit_id_equal(cls, dest, name): + # type: (str, Optional[str]) -> bool + """ + Return whether the id of the current commit equals the given name. + + Args: + dest: the repository directory. + name: a string name. + """ + raise NotImplementedError + + def obtain(self, dest, url): + # type: (str, HiddenText) -> 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. + """ + url, rev_options = self.get_url_rev_options(url) + + if not os.path.exists(dest): + self.fetch_new(dest, url, rev_options) + return + + rev_display = rev_options.to_display() + if self.is_repository_directory(dest): + 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)', + 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', + display_path(dest), + self.repo_name, + rev_display, + ) + self.update(dest, url, rev_options) + else: + logger.info('Skipping because already up-to-date.') + return + + logger.warning( + '%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')) + else: + logger.warning( + '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')) + + logger.warning( + 'The plan is to install the %s repository %s', + self.name, + url, + ) + response = ask_path_exists('What to do? %s' % prompt[0], prompt[1]) + + if response == 'a': + sys.exit(-1) + + if response == 'w': + logger.warning('Deleting %s', display_path(dest)) + rmtree(dest) + self.fetch_new(dest, url, rev_options) + return + + if response == 'b': + dest_dir = backup_dir(dest) + logger.warning( + 'Backing up %s to %s', display_path(dest), dest_dir, + ) + shutil.move(dest, dest_dir) + self.fetch_new(dest, url, rev_options) + return + + # Do nothing if the response is "i". + if response == 's': + logger.info( + 'Switching %s %s to %s%s', + self.repo_name, + display_path(dest), + url, + rev_display, + ) + self.switch(dest, url, rev_options) + + def unpack(self, location, url): + # type: (str, HiddenText) -> 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. + """ + if os.path.exists(location): + rmtree(location) + self.obtain(location, url=url) + + @classmethod + def get_remote_url(cls, location): + # type: (str) -> str + """ + Return the url used at location + + Raises RemoteNotFoundError if the repository does not have a remote + url configured. + """ + raise NotImplementedError + + @classmethod + def get_revision(cls, location): + # type: (str) -> str + """ + Return the current commit id of the files at the given location. + """ + raise NotImplementedError + + @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 + ): + # type: (...) -> Text + """ + 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) + 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) + except OSError as e: + # errno.ENOENT = no such file or directory + # In other words, the VCS executable isn't available + if e.errno == errno.ENOENT: + raise BadCommand( + 'Cannot find command %r - do you have ' + '%r installed and in your ' + 'PATH?' % (cls.name, cls.name)) + else: + raise # re-raise exception if a different error occurred + + @classmethod + def is_repository_directory(cls, path): + # type: (str) -> bool + """ + Return whether a directory path is a repository directory. + """ + 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 controls_location(cls, location): + # type: (str) -> bool + """ + Check if a location is controlled by the vcs. + It is meant to be overridden to implement smarter detection + mechanisms for specific vcs. + + This can do more than is_repository_directory() alone. For example, + the Git override checks that Git is actually available. + """ + return cls.is_repository_directory(location) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/wheel_builder.py b/venv/lib/python3.8/site-packages/pip/_internal/wheel_builder.py new file mode 100644 index 0000000..7c7820d --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_internal/wheel_builder.py @@ -0,0 +1,305 @@ +"""Orchestrator for building wheels from InstallRequirements. +""" + +# The following comment should be removed at some point in the future. +# mypy: strict-optional=False + +import logging +import os.path +import re +import shutil + +from pip._internal.models.link import Link +from pip._internal.operations.build.wheel import build_wheel_pep517 +from pip._internal.operations.build.wheel_legacy import build_wheel_legacy +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.setuptools_build import make_setuptools_clean_args +from pip._internal.utils.subprocess import call_subprocess +from pip._internal.utils.temp_dir import TempDirectory +from pip._internal.utils.typing import MYPY_CHECK_RUNNING +from pip._internal.utils.urls import path_to_url +from pip._internal.vcs import vcs + +if MYPY_CHECK_RUNNING: + from typing import ( + Any, Callable, Iterable, List, Optional, Pattern, Tuple, + ) + + from pip._internal.cache import WheelCache + from pip._internal.req.req_install import InstallRequirement + + BinaryAllowedPredicate = Callable[[InstallRequirement], bool] + BuildResult = Tuple[List[InstallRequirement], List[InstallRequirement]] + +logger = logging.getLogger(__name__) + + +def _contains_egg_info( + s, _egg_info_re=re.compile(r'([a-z0-9_.]+)-([a-z0-9_.!+-]+)', re.I)): + # type: (str, Pattern[str]) -> bool + """Determine whether the string looks like an egg_info. + + :param s: The string to parse. E.g. foo-2.1 + """ + return bool(_egg_info_re.search(s)) + + +def _should_build( + req, # type: InstallRequirement + need_wheel, # type: bool + check_binary_allowed, # type: BinaryAllowedPredicate +): + # type: (...) -> bool + """Return whether an InstallRequirement should be built into a wheel.""" + if req.constraint: + # never build requirements that are merely constraints + return False + if req.is_wheel: + if need_wheel: + logger.info( + 'Skipping %s, due to already being wheel.', req.name, + ) + return False + + if need_wheel: + # i.e. pip wheel, not pip install + return True + + # From this point, this concerns the pip install command only + # (need_wheel=False). + + if not req.use_pep517 and not is_wheel_installed(): + # we don't build legacy requirements if wheel is not installed + return False + + if req.editable or not req.source_dir: + return False + + if not check_binary_allowed(req): + logger.info( + "Skipping wheel build for %s, due to binaries " + "being disabled for it.", req.name, + ) + return False + + 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 + ) + + +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 + ) + + +def _should_cache( + req, # type: InstallRequirement +): + # type: (...) -> Optional[bool] + """ + Return whether a built InstallRequirement can be stored in the persistent + wheel cache, assuming the wheel cache is available, and _should_build() + has determined a wheel needs to be built. + """ + if not should_build_for_install_command( + req, check_binary_allowed=_always_true + ): + # never cache if pip install would not have built + # (editable mode, etc) + return False + + if req.link and req.link.is_vcs: + # VCS checkout. Do not cache + # unless it points to an immutable commit hash. + assert not req.editable + assert req.source_dir + vcs_backend = vcs.get_backend_for_scheme(req.link.scheme) + assert vcs_backend + if vcs_backend.is_immutable_rev_checkout(req.link.url, req.source_dir): + return True + return False + + base, ext = req.link.splitext() + if _contains_egg_info(base): + return True + + # Otherwise, do not cache. + return False + + +def _get_cache_dir( + req, # type: InstallRequirement + wheel_cache, # type: WheelCache +): + # type: (...) -> str + """Return the persistent or temporary cache directory where the built + wheel need to be stored. + """ + cache_available = bool(wheel_cache.cache_dir) + if cache_available and _should_cache(req): + cache_dir = wheel_cache.get_path_for_link(req.link) + else: + cache_dir = wheel_cache.get_ephem_path_for_link(req.link) + return cache_dir + + +def _always_true(_): + # type: (Any) -> bool + return True + + +def _build_one( + req, # type: InstallRequirement + output_dir, # type: str + build_options, # type: List[str] + global_options, # type: List[str] +): + # type: (...) -> Optional[str] + """Build one wheel. + + :return: The filename of the built wheel, or None if the build failed. + """ + try: + ensure_dir(output_dir) + except OSError as e: + logger.warning( + "Building wheel for %s failed: %s", + req.name, e, + ) + return None + + # Install build deps into temporary directory (PEP 518) + with req.build_env: + return _build_one_inside_env( + req, output_dir, build_options, global_options + ) + + +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] + with TempDirectory(kind="wheel") as temp_dir: + if req.use_pep517: + wheel_path = build_wheel_pep517( + name=req.name, + backend=req.pep517_backend, + metadata_directory=req.metadata_directory, + build_options=build_options, + tempd=temp_dir.path, + ) + else: + wheel_path = build_wheel_legacy( + name=req.name, + setup_py_path=req.setup_py_path, + source_dir=req.unpacked_source_directory, + global_options=global_options, + build_options=build_options, + tempd=temp_dir.path, + ) + + if wheel_path is not None: + wheel_name = os.path.basename(wheel_path) + dest_path = os.path.join(output_dir, wheel_name) + 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) + return dest_path + except Exception as e: + logger.warning( + "Building wheel for %s failed: %s", + req.name, e, + ) + # Ignore return, we can't do anything else useful. + if not req.use_pep517: + _clean_one_legacy(req, global_options) + return None + + +def _clean_one_legacy(req, global_options): + # type: (InstallRequirement, 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) + try: + call_subprocess(clean_args, cwd=req.source_dir) + return True + except Exception: + logger.error('Failed cleaning build dir for %s', req.name) + return False + + +def build( + requirements, # type: Iterable[InstallRequirement] + wheel_cache, # type: WheelCache + build_options, # type: List[str] + global_options, # type: List[str] +): + # type: (...) -> BuildResult + """Build wheels. + + :return: The list of InstallRequirement that succeeded to build and + the list of InstallRequirement that failed to build. + """ + if not requirements: + return [], [] + + # Build the wheels. + logger.info( + 'Building wheels for collected packages: %s', + ', '.join(req.name for req in requirements), + ) + + with indent_log(): + build_successes, build_failures = [], [] + for req in requirements: + cache_dir = _get_cache_dir(req, wheel_cache) + wheel_file = _build_one( + req, cache_dir, build_options, global_options + ) + if wheel_file: + # Update the link for this. + req.link = Link(path_to_url(wheel_file)) + req.local_file_path = req.link.file_path + assert req.link.is_wheel + build_successes.append(req) + else: + build_failures.append(req) + + # notify success/failure + if build_successes: + logger.info( + 'Successfully built %s', + ' '.join([req.name for req in build_successes]), + ) + if build_failures: + logger.info( + 'Failed to build %s', + ' '.join([req.name for req in build_failures]), + ) + # Return a list of requirements that failed to build + return build_successes, build_failures diff --git a/venv/lib/python3.8/site-packages/pip/_vendor/__init__.py b/venv/lib/python3.8/site-packages/pip/_vendor/__init__.py new file mode 100644 index 0000000..e02eaef --- /dev/null +++ b/venv/lib/python3.8/site-packages/pip/_vendor/__init__.py @@ -0,0 +1,119 @@ +""" +pip._vendor is for vendoring dependencies of pip to prevent needing pip to +depend on something external. + +Files inside of pip._vendor should be considered immutable and should only be +updated to versions from upstream. +""" +from __future__ import absolute_import + +import glob +import os.path +import sys + +# Downstream redistributors which have debundled our dependencies should also +# patch this value to be true. This will trigger the additional patching +# to cause things like "six" to be available as pip. +DEBUNDLED = True + +# By default, look in this directory for a bunch of .whl files which we will +# add to the beginning of sys.path before attempting to import anything. This +# is done to support downstream re-distributors like Debian and Fedora who +# wish to create their own Wheels for our dependencies to aid in debundling. +prefix = getattr(sys, "base_prefix", sys.prefix) +if prefix.startswith('/usr/lib/pypy'): + prefix = '/usr' +WHEEL_DIR = os.path.abspath(os.path.join(prefix, 'share', 'python-wheels')) + + +# Define a small helper function to alias our vendored modules to the real ones +# if the vendored ones do not exist. This idea of this was taken from +# https://github.com/kennethreitz/requests/pull/2567. +def vendored(modulename): + vendored_name = "{0}.{1}".format(__name__, modulename) + + try: + __import__(modulename, globals(), locals(), level=0) + except ImportError: + # We can just silently allow import failures to pass here. If we + # got to this point it means that ``import pip._vendor.whatever`` + # failed and so did ``import whatever``. Since we're importing this + # upfront in an attempt to alias imports, not erroring here will + # just mean we get a regular import error whenever pip *actually* + # tries to import one of these modules to use it, which actually + # gives us a better error message than we would have otherwise + # gotten. + pass + else: + sys.modules[vendored_name] = sys.modules[modulename] + base, head = vendored_name.rsplit(".", 1) + setattr(sys.modules[base], head, sys.modules[modulename]) + + +# If we're operating in a debundled setup, then we want to go ahead and trigger +# the aliasing of our vendored libraries as well as looking for wheels to add +# to our sys.path. This will cause all of this code to be a no-op typically +# however downstream redistributors can enable it in a consistent way across +# all platforms. +if DEBUNDLED: + # Actually look inside of WHEEL_DIR to find .whl files and add them to the + # front of our sys.path. + sys.path[:] = glob.glob(os.path.join(WHEEL_DIR, "*.whl")) + sys.path + + # Actually alias all of our vendored dependencies. + vendored("appdirs") + vendored("cachecontrol") + vendored("colorama") + vendored("contextlib2") + vendored("distlib") + vendored("distro") + vendored("html5lib") + vendored("six") + vendored("six.moves") + vendored("six.moves.urllib") + vendored("six.moves.urllib.parse") + vendored("packaging") + vendored("packaging.version") + vendored("packaging.specifiers") + vendored("pep517") + vendored("pkg_resources") + vendored("progress") + vendored("retrying") + vendored("requests") + vendored("requests.exceptions") + vendored("requests.packages") + vendored("requests.packages.urllib3") + vendored("requests.packages.urllib3._collections") + vendored("requests.packages.urllib3.connection") + vendored("requests.packages.urllib3.connectionpool") + vendored("requests.packages.urllib3.contrib") + vendored("requests.packages.urllib3.contrib.ntlmpool") + vendored("requests.packages.urllib3.contrib.pyopenssl") + vendored("requests.packages.urllib3.exceptions") + vendored("requests.packages.urllib3.fields") + vendored("requests.packages.urllib3.filepost") + vendored("requests.packages.urllib3.packages") + try: + vendored("requests.packages.urllib3.packages.ordered_dict") + vendored("requests.packages.urllib3.packages.six") + except ImportError: + # Debian already unbundles these from requests. + pass + vendored("requests.packages.urllib3.packages.ssl_match_hostname") + vendored("requests.packages.urllib3.packages.ssl_match_hostname." + "_implementation") + vendored("requests.packages.urllib3.poolmanager") + vendored("requests.packages.urllib3.request") + vendored("requests.packages.urllib3.response") + vendored("requests.packages.urllib3.util") + vendored("requests.packages.urllib3.util.connection") + vendored("requests.packages.urllib3.util.request") + vendored("requests.packages.urllib3.util.response") + vendored("requests.packages.urllib3.util.retry") + vendored("requests.packages.urllib3.util.ssl_") + vendored("requests.packages.urllib3.util.timeout") + vendored("requests.packages.urllib3.util.url") + vendored("toml") + vendored("toml.encoder") + vendored("toml.decoder") + vendored("urllib3") diff --git a/venv/lib/python3.8/site-packages/pip/_vendor/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_vendor/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..996d06e61b94db4f77f92ecda8d37e6f50db2212 GIT binary patch literal 3037 zcmbW3TXWPl6o7qOd)L{`rG${smYO?(#>*{`(v&i7!a#@Np)CX5>5Ru&DOo4BWh6Oa zP4X1_*cpC8^4R~-U!v(-pZE(r^~hGXnRc>auxIs2M@PrfIY-hyYqeYrp1XH0hUA2% z{Vf}ZpE@)iz>oc4Xd2Qw8q$#w>xt1ZbXhlJvtyRDI<=B^$3|Ai!F6n-8n)LPyJn|> z8+$IY_jURRInb)DkL)$evV|L{jvD*szTO!{E*g2Gb;hvs)}Rluxo0Y!QPkWw_I0o} za!QjWGLiY4v8drO)Y{c`$x+2I#c{<6#ZMGZC{8M#RGd;gr8uoPqj*~JQ^n5|KUX}X z_=TdUcvkV8;(5gjiWe0xDPC5*qByH~Rq>kQmy*RKtb9&Me97lpI%R2ie8YXK(?4}h zzQ1Ux@k08jtu(JI-cY=$cuVoN;=JM=#k-0NieD+-Q~X+SQSlqa`-P5_31yrplUGosmpa-Yj2s4kYdZ6ra;$;+r4);=wkyNY1Zl&#!)MF&U zyeGTxD~@Rz#=h%5jAF17r7S{N85?|=^++BgZv}f@QYui4yeLU>9#LPhB2dUn+LkPCPYz#DB4d8=k@g+|MiU>D(43)uEh|bSm^${Qs4?3 z;+lk9)Po=m6C4D>4U{*a?ySXRC5)M{W73rzd0aYbnNmW9$@)w<2|+o;PuP@Yam0ng zFb_GWvzBnHK51CAs^r0_{Eo1spM}-KA^Jn3Ct-H)7ur0@+K@7Hd76dY4U8)1&PDm! z%Z2{!E!o#rDcOcurV$SUKkJM7fo%`$uyH6fy=fTwv_9Ifjd6Wkr>8(x)UNtly;wM5 zmZ69;(d>rZ9)`r?l*FRmB{8945{eNif&_)g-xLmtn5+p~Rwxnm9#7(VDKQx&NdpQ$ zA)A;LHJo3p>Nv{EfS! zm2IpA6f=_3F8IBkQL+Y2s8P&mA8g9n%N#S#iW3JlAHVA2jLYp%Obmq8hhXY6{}ZVt z+$t^|+2se|vKV(Os~3*e1AnHKT5;t=v@$~C;_OgOPQkrbk5%zg9z)84xogMkW_<$3 z8e?%WWG#pM=pAhmLKY)doExSQA{bzm!yLG-%Zjy5qEs}V zKU!XX5-dIbu{_;r6D*cD$)RFOex<%x-9z`~oyXolVL45suESfi>`~p-Eq&UqpSH~l YW+|0DANd+EuBne3wj5u5;|NRt0I8|6M*si- literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pkg_resources-0.0.0.dist-info/AUTHORS.txt b/venv/lib/python3.8/site-packages/pkg_resources-0.0.0.dist-info/AUTHORS.txt new file mode 100644 index 0000000..72c87d7 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pkg_resources-0.0.0.dist-info/AUTHORS.txt @@ -0,0 +1,562 @@ +A_Rog +Aakanksha Agrawal <11389424+rasponic@users.noreply.github.com> +Abhinav Sagar <40603139+abhinavsagar@users.noreply.github.com> +ABHYUDAY PRATAP SINGH +abs51295 +AceGentile +Adam Chainz +Adam Tse +Adam Tse +Adam Wentz +admin +Adrien Morison +ahayrapetyan +Ahilya +AinsworthK +Akash Srivastava +Alan Yee +Albert Tugushev +Albert-Guan +albertg +Aleks Bunin +Alethea Flowers +Alex Gaynor +Alex Grönholm +Alex Loosley +Alex Morega +Alex Stachowiak +Alexander Shtyrov +Alexandre Conrad +Alexey Popravka +Alexey Popravka +Alli +Ami Fischman +Ananya Maiti +Anatoly Techtonik +Anders Kaseorg +Andreas Lutro +Andrei Geacar +Andrew Gaul +Andrey Bulgakov +Andrés Delfino <34587441+andresdelfino@users.noreply.github.com> +Andrés Delfino +Andy Freeland +Andy Freeland +Andy Kluger +Ani Hayrapetyan +Aniruddha Basak +Anish Tambe +Anrs Hu +Anthony Sottile +Antoine Musso +Anton Ovchinnikov +Anton Patrushev +Antonio Alvarado Hernandez +Antony Lee +Antti Kaihola +Anubhav Patel +Anuj Godase +AQNOUCH Mohammed +AraHaan +Arindam Choudhury +Armin Ronacher +Artem +Ashley Manton +Ashwin Ramaswami +atse +Atsushi Odagiri +Avner Cohen +Baptiste Mispelon +Barney Gale +barneygale +Bartek Ogryczak +Bastian Venthur +Ben Darnell +Ben Hoyt +Ben Rosser +Bence Nagy +Benjamin Peterson +Benjamin VanEvery +Benoit Pierre +Berker Peksag +Bernardo B. Marques +Bernhard M. Wiedemann +Bertil Hatt +Bogdan Opanchuk +BorisZZZ +Brad Erickson +Bradley Ayers +Brandon L. Reiss +Brandt Bucher +Brett Randall +Brian Cristante <33549821+brcrista@users.noreply.github.com> +Brian Cristante +Brian Rosner +BrownTruck +Bruno Oliveira +Bruno Renié +Bstrdsmkr +Buck Golemon +burrows +Bussonnier Matthias +c22 +Caleb Martinez +Calvin Smith +Carl Meyer +Carlos Liam +Carol Willing +Carter Thayer +Cass +Chandrasekhar Atina +Chih-Hsuan Yen +Chih-Hsuan Yen +Chris Brinker +Chris Hunt +Chris Jerdonek +Chris McDonough +Chris Wolfe +Christian Heimes +Christian Oudard +Christopher Hunt +Christopher Snyder +Clark Boylan +Clay McClure +Cody +Cody Soyland +Colin Watson +Connor Osborn +Cooper Lees +Cooper Ry Lees +Cory Benfield +Cory Wright +Craig Kerstiens +Cristian Sorinel +Curtis Doty +cytolentino +Damian Quiroga +Dan Black +Dan Savilonis +Dan Sully +daniel +Daniel Collins +Daniel Hahler +Daniel Holth +Daniel Jost +Daniel Shaulov +Daniele Esposti +Daniele Procida +Danny Hermes +Dav Clark +Dave Abrahams +Dave Jones +David Aguilar +David Black +David Bordeynik +David Bordeynik +David Caro +David Evans +David Linke +David Pursehouse +David Tucker +David Wales +Davidovich +derwolfe +Desetude +Diego Caraballo +DiegoCaraballo +Dmitry Gladkov +Domen Kožar +Donald Stufft +Dongweiming +Douglas Thor +DrFeathers +Dustin Ingram +Dwayne Bailey +Ed Morley <501702+edmorley@users.noreply.github.com> +Ed Morley +Eitan Adler +ekristina +elainechan +Eli Schwartz +Eli Schwartz +Emil Burzo +Emil Styrke +Endoh Takanao +enoch +Erdinc Mutlu +Eric Gillingham +Eric Hanchrow +Eric Hopper +Erik M. Bray +Erik Rose +Ernest W Durbin III +Ernest W. Durbin III +Erwin Janssen +Eugene Vereshchagin +everdimension +Felix Yan +fiber-space +Filip Kokosiński +Florian Briand +Florian Rathgeber +Francesco +Francesco Montesano +Frost Ming +Gabriel Curio +Gabriel de Perthuis +Garry Polley +gdanielson +Geoffrey Lehée +Geoffrey Sneddon +George Song +Georgi Valkov +Giftlin Rajaiah +gizmoguy1 +gkdoc <40815324+gkdoc@users.noreply.github.com> +Gopinath M <31352222+mgopi1990@users.noreply.github.com> +GOTO Hayato <3532528+gh640@users.noreply.github.com> +gpiks +Guilherme Espada +Guy Rozendorn +gzpan123 +Hanjun Kim +Hari Charan +Harsh Vardhan +Herbert Pfennig +Hsiaoming Yang +Hugo +Hugo Lopes Tavares +Hugo van Kemenade +hugovk +Hynek Schlawack +Ian Bicking +Ian Cordasco +Ian Lee +Ian Stapleton Cordasco +Ian Wienand +Ian Wienand +Igor Kuzmitshov +Igor Sobreira +Ilya Baryshev +INADA Naoki +Ionel Cristian Mărieș +Ionel Maries Cristian +Ivan Pozdeev +Jacob Kim +jakirkham +Jakub Stasiak +Jakub Vysoky +Jakub Wilk +James Cleveland +James Cleveland +James Firth +James Polley +Jan Pokorný +Jannis Leidel +jarondl +Jason R. Coombs +Jay Graves +Jean-Christophe Fillion-Robin +Jeff Barber +Jeff Dairiki +Jelmer Vernooij +jenix21 +Jeremy Stanley +Jeremy Zafran +Jiashuo Li +Jim Garrison +Jivan Amara +John Paton +John-Scott Atlakson +johnthagen +johnthagen +Jon Banafato +Jon Dufresne +Jon Parise +Jonas Nockert +Jonathan Herbert +Joost Molenaar +Jorge Niedbalski +Joseph Long +Josh Bronson +Josh Hansen +Josh Schneier +Juanjo Bazán +Julian Berman +Julian Gethmann +Julien Demoor +jwg4 +Jyrki Pulliainen +Kai Chen +Kamal Bin Mustafa +kaustav haldar +keanemind +Keith Maxwell +Kelsey Hightower +Kenneth Belitzky +Kenneth Reitz +Kenneth Reitz +Kevin Burke +Kevin Carter +Kevin Frommelt +Kevin R Patterson +Kexuan Sun +Kit Randel +kpinc +Krishna Oza +Kumar McMillan +Kyle Persohn +lakshmanaram +Laszlo Kiss-Kollar +Laurent Bristiel +Laurie Opperman +Leon Sasson +Lev Givon +Lincoln de Sousa +Lipis +Loren Carvalho +Lucas Cimon +Ludovic Gasc +Luke Macken +Luo Jiebin +luojiebin +luz.paz +László Kiss Kollár +László Kiss Kollár +Marc Abramowitz +Marc Tamlyn +Marcus Smith +Mariatta +Mark Kohler +Mark Williams +Mark Williams +Markus Hametner +Masaki +Masklinn +Matej Stuchlik +Mathew Jennings +Mathieu Bridon +Matt Good +Matt Maker +Matt Robenolt +matthew +Matthew Einhorn +Matthew Gilliard +Matthew Iversen +Matthew Trumbell +Matthew Willson +Matthias Bussonnier +mattip +Maxim Kurnikov +Maxime Rouyrre +mayeut +mbaluna <44498973+mbaluna@users.noreply.github.com> +mdebi <17590103+mdebi@users.noreply.github.com> +memoselyk +Michael +Michael Aquilina +Michael E. Karpeles +Michael Klich +Michael Williamson +michaelpacer +Mickaël Schoentgen +Miguel Araujo Perez +Mihir Singh +Mike +Mike Hendricks +Min RK +MinRK +Miro Hrončok +Monica Baluna +montefra +Monty Taylor +Nate Coraor +Nathaniel J. Smith +Nehal J Wani +Neil Botelho +Nick Coghlan +Nick Stenning +Nick Timkovich +Nicolas Bock +Nikhil Benesch +Nitesh Sharma +Nowell Strite +NtaleGrey +nvdv +Ofekmeister +ofrinevo +Oliver Jeeves +Oliver Tonnhofer +Olivier Girardot +Olivier Grisel +Ollie Rutherfurd +OMOTO Kenji +Omry Yadan +Oren Held +Oscar Benjamin +Oz N Tiram +Pachwenko <32424503+Pachwenko@users.noreply.github.com> +Patrick Dubroy +Patrick Jenkins +Patrick Lawson +patricktokeeffe +Patrik Kopkan +Paul Kehrer +Paul Moore +Paul Nasrat +Paul Oswald +Paul van der Linden +Paulus Schoutsen +Pavithra Eswaramoorthy <33131404+QueenCoffee@users.noreply.github.com> +Pawel Jasinski +Pekka Klärck +Peter Lisák +Peter Waller +petr-tik +Phaneendra Chiruvella +Phil Freo +Phil Pennock +Phil Whelan +Philip Jägenstedt +Philip Molloy +Philippe Ombredanne +Pi Delport +Pierre-Yves Rofes +pip +Prabakaran Kumaresshan +Prabhjyotsing Surjit Singh Sodhi +Prabhu Marappan +Pradyun Gedam +Pratik Mallya +Preet Thakkar +Preston Holmes +Przemek Wrzos +Pulkit Goyal <7895pulkit@gmail.com> +Qiangning Hong +Quentin Pradet +R. David Murray +Rafael Caricio +Ralf Schmitt +Razzi Abuissa +rdb +Remi Rampin +Remi Rampin +Rene Dudfield +Riccardo Magliocchetti +Richard Jones +RobberPhex +Robert Collins +Robert McGibbon +Robert T. McGibbon +robin elisha robinson +Roey Berman +Rohan Jain +Rohan Jain +Rohan Jain +Roman Bogorodskiy +Romuald Brunet +Ronny Pfannschmidt +Rory McCann +Ross Brattain +Roy Wellington Ⅳ +Roy Wellington Ⅳ +Ryan Wooden +ryneeverett +Sachi King +Salvatore Rinchiera +Savio Jomton +schlamar +Scott Kitterman +Sean +seanj +Sebastian Jordan +Sebastian Schaetz +Segev Finer +SeongSoo Cho +Sergey Vasilyev +Seth Woodworth +Shlomi Fish +Shovan Maity +Simeon Visser +Simon Cross +Simon Pichugin +sinoroc +Sorin Sbarnea +Stavros Korokithakis +Stefan Scherfke +Stephan Erb +stepshal +Steve (Gadget) Barnes +Steve Barnes +Steve Dower +Steve Kowalik +Steven Myint +stonebig +Stéphane Bidoul (ACSONE) +Stéphane Bidoul +Stéphane Klein +Sumana Harihareswara +Sviatoslav Sydorenko +Sviatoslav Sydorenko +Swat009 +Takayuki SHIMIZUKAWA +tbeswick +Thijs Triemstra +Thomas Fenzl +Thomas Grainger +Thomas Guettler +Thomas Johansson +Thomas Kluyver +Thomas Smith +Tim D. Smith +Tim Gates +Tim Harder +Tim Heap +tim smith +tinruufu +Tom Forbes +Tom Freudenheim +Tom V +Tomas Orsava +Tomer Chachamu +Tony Beswick +Tony Zhaocheng Tan +TonyBeswick +toonarmycaptain +Toshio Kuratomi +Travis Swicegood +Tzu-ping Chung +Valentin Haenel +Victor Stinner +victorvpaulo +Viktor Szépe +Ville Skyttä +Vinay Sajip +Vincent Philippon +Vinicyus Macedo <7549205+vinicyusmacedo@users.noreply.github.com> +Vitaly Babiy +Vladimir Rutsky +W. Trevor King +Wil Tan +Wilfred Hughes +William ML Leslie +William T Olson +Wilson Mo +wim glenn +Wolfgang Maier +Xavier Fernandez +Xavier Fernandez +xoviat +xtreak +YAMAMOTO Takashi +Yen Chi Hsuan +Yeray Diaz Diaz +Yoval P +Yu Jian +Yuan Jing Vincent Yan +Zearin +Zearin +Zhiping Deng +Zvezdan Petkovic +Łukasz Langa +Семён Марьясин diff --git a/venv/lib/python3.8/site-packages/pkg_resources-0.0.0.dist-info/INSTALLER b/venv/lib/python3.8/site-packages/pkg_resources-0.0.0.dist-info/INSTALLER new file mode 100644 index 0000000..a1b589e --- /dev/null +++ b/venv/lib/python3.8/site-packages/pkg_resources-0.0.0.dist-info/INSTALLER @@ -0,0 +1 @@ +pip diff --git a/venv/lib/python3.8/site-packages/pkg_resources-0.0.0.dist-info/LICENSE.txt b/venv/lib/python3.8/site-packages/pkg_resources-0.0.0.dist-info/LICENSE.txt new file mode 100644 index 0000000..737fec5 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pkg_resources-0.0.0.dist-info/LICENSE.txt @@ -0,0 +1,20 @@ +Copyright (c) 2008-2019 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/venv/lib/python3.8/site-packages/pkg_resources-0.0.0.dist-info/METADATA b/venv/lib/python3.8/site-packages/pkg_resources-0.0.0.dist-info/METADATA new file mode 100644 index 0000000..cf6c930 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pkg_resources-0.0.0.dist-info/METADATA @@ -0,0 +1,13 @@ +Metadata-Version: 2.1 +Name: pkg_resources +Version: 0.0.0 +Summary: UNKNOWN +Home-page: UNKNOWN +Author: UNKNOWN +Author-email: UNKNOWN +License: UNKNOWN +Platform: UNKNOWN + +UNKNOWN + + diff --git a/venv/lib/python3.8/site-packages/pkg_resources-0.0.0.dist-info/RECORD b/venv/lib/python3.8/site-packages/pkg_resources-0.0.0.dist-info/RECORD new file mode 100644 index 0000000..2bbae1d --- /dev/null +++ b/venv/lib/python3.8/site-packages/pkg_resources-0.0.0.dist-info/RECORD @@ -0,0 +1,38 @@ +pkg_resources-0.0.0.dist-info/AUTHORS.txt,sha256=RtqU9KfonVGhI48DAA4-yTOBUhBtQTjFhaDzHoyh7uU,21518 +pkg_resources-0.0.0.dist-info/INSTALLER,sha256=zuuue4knoyJ-UwPPXg8fezS7VCrXJQrAP7zeNuwvFQg,4 +pkg_resources-0.0.0.dist-info/LICENSE.txt,sha256=W6Ifuwlk-TatfRU2LR7W1JMcyMj5_y1NkRkOEJvnRDE,1090 +pkg_resources-0.0.0.dist-info/METADATA,sha256=V9_WPOtD1FnuKrTGv6Ique7kAOn2lasvT8W0_iMCCCk,177 +pkg_resources-0.0.0.dist-info/RECORD,, +pkg_resources-0.0.0.dist-info/WHEEL,sha256=kGT74LWyRUZrL4VgLh6_g12IeVl_9u9ZVhadrgXZUEY,110 +pkg_resources/__init__.py,sha256=0IssxXPnaDKpYZRra8Ime0JG4hwosQljItGD0bnIkGk,108349 +pkg_resources/__pycache__/__init__.cpython-38.pyc,, +pkg_resources/__pycache__/py31compat.cpython-38.pyc,, +pkg_resources/_vendor/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 +pkg_resources/_vendor/__pycache__/__init__.cpython-38.pyc,, +pkg_resources/_vendor/__pycache__/appdirs.cpython-38.pyc,, +pkg_resources/_vendor/__pycache__/pyparsing.cpython-38.pyc,, +pkg_resources/_vendor/__pycache__/six.cpython-38.pyc,, +pkg_resources/_vendor/appdirs.py,sha256=MievUEuv3l_mQISH5SF0shDk_BNhHHzYiAPrT3ITN4I,24701 +pkg_resources/_vendor/packaging/__about__.py,sha256=zkcCPTN_6TcLW0Nrlg0176-R1QQ_WVPTm8sz1R4-HjM,720 +pkg_resources/_vendor/packaging/__init__.py,sha256=_vNac5TrzwsrzbOFIbF-5cHqc_Y2aPT2D7zrIR06BOo,513 +pkg_resources/_vendor/packaging/__pycache__/__about__.cpython-38.pyc,, +pkg_resources/_vendor/packaging/__pycache__/__init__.cpython-38.pyc,, +pkg_resources/_vendor/packaging/__pycache__/_compat.cpython-38.pyc,, +pkg_resources/_vendor/packaging/__pycache__/_structures.cpython-38.pyc,, +pkg_resources/_vendor/packaging/__pycache__/markers.cpython-38.pyc,, +pkg_resources/_vendor/packaging/__pycache__/requirements.cpython-38.pyc,, +pkg_resources/_vendor/packaging/__pycache__/specifiers.cpython-38.pyc,, +pkg_resources/_vendor/packaging/__pycache__/utils.cpython-38.pyc,, +pkg_resources/_vendor/packaging/__pycache__/version.cpython-38.pyc,, +pkg_resources/_vendor/packaging/_compat.py,sha256=Vi_A0rAQeHbU-a9X0tt1yQm9RqkgQbDSxzRw8WlU9kA,860 +pkg_resources/_vendor/packaging/_structures.py,sha256=RImECJ4c_wTlaTYYwZYLHEiebDMaAJmK1oPARhw1T5o,1416 +pkg_resources/_vendor/packaging/markers.py,sha256=uEcBBtGvzqltgnArqb9c4RrcInXezDLos14zbBHhWJo,8248 +pkg_resources/_vendor/packaging/requirements.py,sha256=SikL2UynbsT0qtY9ltqngndha_sfo0w6XGFhAhoSoaQ,4355 +pkg_resources/_vendor/packaging/specifiers.py,sha256=SAMRerzO3fK2IkFZCaZkuwZaL_EGqHNOz4pni4vhnN0,28025 +pkg_resources/_vendor/packaging/utils.py,sha256=3m6WvPm6NNxE8rkTGmn0r75B_GZSGg7ikafxHsBN1WA,421 +pkg_resources/_vendor/packaging/version.py,sha256=OwGnxYfr2ghNzYx59qWIBkrK3SnB6n-Zfd1XaLpnnM0,11556 +pkg_resources/_vendor/pyparsing.py,sha256=tmrp-lu-qO1i75ZzIN5A12nKRRD1Cm4Vpk-5LR9rims,232055 +pkg_resources/_vendor/six.py,sha256=A6hdJZVjI3t_geebZ9BzUvwRrIXo0lfwzQlM2LcKyas,30098 +pkg_resources/extern/__init__.py,sha256=cHiEfHuLmm6rs5Ve_ztBfMI7Lr31vss-D4wkqF5xzlI,2498 +pkg_resources/extern/__pycache__/__init__.cpython-38.pyc,, +pkg_resources/py31compat.py,sha256=-WQ0e4c3RG_acdhwC3gLiXhP_lg4G5q7XYkZkQg0gxU,558 diff --git a/venv/lib/python3.8/site-packages/pkg_resources-0.0.0.dist-info/WHEEL b/venv/lib/python3.8/site-packages/pkg_resources-0.0.0.dist-info/WHEEL new file mode 100644 index 0000000..ef99c6c --- /dev/null +++ b/venv/lib/python3.8/site-packages/pkg_resources-0.0.0.dist-info/WHEEL @@ -0,0 +1,6 @@ +Wheel-Version: 1.0 +Generator: bdist_wheel (0.34.2) +Root-Is-Purelib: true +Tag: py2-none-any +Tag: py3-none-any + diff --git a/venv/lib/python3.8/site-packages/pkg_resources/__init__.py b/venv/lib/python3.8/site-packages/pkg_resources/__init__.py new file mode 100644 index 0000000..2f5aa64 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pkg_resources/__init__.py @@ -0,0 +1,3296 @@ +# coding: utf-8 +""" +Package resource API +-------------------- + +A resource is a logical file contained within a package, or a logical +subdirectory thereof. The package resource API expects resource names +to have their path parts separated with ``/``, *not* whatever the local +path separator is. Do not use os.path operations to manipulate resource +names being passed into the API. + +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 + +import sys +import os +import io +import time +import re +import types +import zipfile +import zipimport +import warnings +import stat +import functools +import pkgutil +import operator +import platform +import collections +import plistlib +import email.parser +import errno +import tempfile +import textwrap +import itertools +import inspect +import ntpath +import posixpath +from pkgutil import get_importer + +try: + import _imp +except ImportError: + # Python 3.2 compatibility + import imp as _imp + +try: + FileExistsError +except NameError: + FileExistsError = OSError + +from pkg_resources.extern import six +from pkg_resources.extern.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 + WRITE_SUPPORT = False + +from os import open as os_open +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 pkg_resources.extern import appdirs +from pkg_resources.extern import packaging +__import__('pkg_resources.extern.packaging.version') +__import__('pkg_resources.extern.packaging.specifiers') +__import__('pkg_resources.extern.packaging.requirements') +__import__('pkg_resources.extern.packaging.markers') + + +__metaclass__ = type + + +if (3, 0) < 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 +working_set = None +add_activation_listener = None +resources_stream = None +cleanup_resources = None +resource_dir = None +resource_stream = None +set_extraction_path = None +resource_isdir = None +resource_string = None +iter_entry_points = None +resource_listdir = None +resource_filename = None +resource_exists = None +_distribution_finders = None +_namespace_handlers = None +_namespace_packages = None + + +class PEP440Warning(RuntimeWarning): + """ + Used when there is an issue with a version or specifier not complying with + PEP 440. + """ + + +def parse_version(v): + try: + return packaging.version.Version(v) + except packaging.version.InvalidVersion: + return packaging.version.LegacyVersion(v) + + +_state_vars = {} + + +def _declare_state(vartype, **kw): + globals().update(kw) + _state_vars.update(dict.fromkeys(kw, vartype)) + + +def __getstate__(): + state = {} + g = globals() + for k, v in _state_vars.items(): + state[k] = g['_sget_' + v](g[k]) + return state + + +def __setstate__(state): + g = globals() + for k, v in state.items(): + g['_sset_' + _state_vars[k]](k, g[k], v) + return state + + +def _sget_dict(val): + return val.copy() + + +def _sset_dict(key, ob, state): + ob.clear() + ob.update(state) + + +def _sget_object(val): + return val.__getstate__() + + +def _sset_object(key, ob, state): + ob.__setstate__(state) + + +_sget_none = _sset_none = lambda *args: None + + +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 + 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 + current version of the OS. + + If this condition occurs for any other platform with a version in its + platform strings, this function should be extended accordingly. + """ + plat = get_build_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)) + except ValueError: + # not Mac OS X + 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', + 'iter_entry_points', + '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', + 'get_default_cache', + + # Primary implementation classes + 'Environment', 'WorkingSet', 'ResourceManager', + 'Distribution', 'Requirement', 'EntryPoint', + + # Exceptions + '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', + + # filesystem utilities + 'ensure_directory', 'normalize_path', + + # Distribution "precedence" constants + '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', + + # Warnings + 'PkgResourcesDeprecationWarning', + + # Deprecated/backward compatibility only + 'run_main', 'AvailableDistributions', +] + + +class ResolutionError(Exception): + """Abstract base for dependency resolution errors""" + + def __repr__(self): + return self.__class__.__name__ + repr(self.args) + + +class VersionConflict(ResolutionError): + """ + An already-installed version conflicts with the requested version. + + Should be initialized with the installed Distribution and the requested + Requirement. + """ + + _template = "{self.dist} is installed but {self.req} is required" + + @property + def dist(self): + return self.args[0] + + @property + def req(self): + return self.args[1] + + def report(self): + return self._template.format(**locals()) + + def with_context(self, required_by): + """ + If required_by is non-empty, return a version of self that is a + ContextualVersionConflict. + """ + if not required_by: + return self + args = self.args + (required_by,) + return ContextualVersionConflict(*args) + + +class ContextualVersionConflict(VersionConflict): + """ + A VersionConflict that accepts a third parameter, the set of the + requirements that required the installed Distribution. + """ + + _template = VersionConflict._template + ' by {self.required_by}' + + @property + def required_by(self): + return self.args[2] + + +class DistributionNotFound(ResolutionError): + """A requested distribution was not found""" + + _template = ("The '{self.req}' distribution was not found " + "and is required by {self.requirers_str}") + + @property + def req(self): + return self.args[0] + + @property + def requirers(self): + return self.args[1] + + @property + def requirers_str(self): + if not self.requirers: + return 'the application' + return ', '.join(self.requirers) + + def report(self): + return self._template.format(**locals()) + + def __str__(self): + return self.report() + + +class UnknownExtra(ResolutionError): + """Distribution doesn't have an "extra feature" of the given name""" + + +_provider_factories = {} + +PY_MAJOR = '{}.{}'.format(*sys.version_info) +EGG_DIST = 3 +BINARY_DIST = 2 +SOURCE_DIST = 1 +CHECKOUT_DIST = 0 +DEVELOP_DIST = -1 + + +def register_loader_type(loader_type, provider_factory): + """Register `provider_factory` to make providers for `loader_type` + + `loader_type` is the type or class of a PEP 302 ``module.__loader__``, + and `provider_factory` is a function that, passed a *module* object, + returns an ``IResourceProvider`` for that module. + """ + _provider_factories[loader_type] = provider_factory + + +def get_provider(moduleOrReq): + """Return an IResourceProvider for the named module or requirement""" + if isinstance(moduleOrReq, Requirement): + return working_set.find(moduleOrReq) or require(str(moduleOrReq))[0] + try: + module = sys.modules[moduleOrReq] + except KeyError: + __import__(moduleOrReq) + module = sys.modules[moduleOrReq] + loader = getattr(module, '__loader__', None) + return _find_adapter(_provider_factories, loader)(module) + + +def _macosx_vers(_cache=[]): + if not _cache: + version = platform.mac_ver()[0] + # fallback for MacPorts + if version == '': + plist = '/System/Library/CoreServices/SystemVersion.plist' + if os.path.exists(plist): + if hasattr(plistlib, 'readPlist'): + plist_content = plistlib.readPlist(plist) + if 'ProductVersion' in plist_content: + version = plist_content['ProductVersion'] + + _cache.append(version.split('.')) + return _cache[0] + + +def _macosx_arch(machine): + return {'PowerPC': 'ppc', 'Power_Macintosh': 'ppc'}.get(machine, machine) + + +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. + """ + from sysconfig import get_platform + + plat = get_platform() + if sys.platform == "darwin" and not plat.startswith('macosx-'): + try: + version = _macosx_vers() + machine = os.uname()[4].replace(" ", "_") + return "macosx-%d.%d-%s" % ( + int(version[0]), int(version[1]), + _macosx_arch(machine), + ) + except ValueError: + # if someone is running a non-Mac darwin system, this will fall + # through to the default implementation + pass + return plat + + +macosVersionString = re.compile(r"macosx-(\d+)\.(\d+)-(.*)") +darwinVersionString = re.compile(r"darwin-(\d+)\.(\d+)\.(\d+)-(.*)") +# XXX backward compat +get_platform = get_build_platform + + +def compatible_platforms(provided, required): + """Can code for the `provided` platform run on the `required` platform? + + Returns true if either platform is ``None``, or the platforms are equal. + + XXX Needs compatibility checks for Linux and other unixy OSes. + """ + if provided is None or required is None or provided == required: + # easy case + return True + + # Mac OS X special cases + reqMac = macosVersionString.match(required) + if reqMac: + provMac = macosVersionString.match(provided) + + # is this a Mac package? + 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. + 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": + return True + # egg isn't macosx 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): + return False + + # is the required OS major update >= the provided one? + if int(provMac.group(2)) > int(reqMac.group(2)): + return False + + return True + + # XXX Linux and other platforms' special cases should go here + return False + + +def run_script(dist_spec, script_name): + """Locate distribution `dist_spec` and run its `script_name` script""" + ns = sys._getframe(1).f_globals + name = ns['__name__'] + ns.clear() + ns['__name__'] = name + require(dist_spec)[0].run_script(script_name, ns) + + +# backward compatibility +run_main = run_script + + +def get_distribution(dist): + """Return a current distribution object for a Requirement or string""" + if isinstance(dist, six.string_types): + dist = Requirement.parse(dist) + if isinstance(dist, Requirement): + dist = get_provider(dist) + if not isinstance(dist, Distribution): + raise TypeError("Expected string, Requirement, or Distribution", dist) + return dist + + +def load_entry_point(dist, group, name): + """Return `name` entry point of `group` for `dist` or raise ImportError""" + return get_distribution(dist).load_entry_point(group, name) + + +def get_entry_map(dist, group=None): + """Return the entry point map for `group`, or the full entry map""" + return get_distribution(dist).get_entry_map(group) + + +def get_entry_info(dist, group, name): + """Return the EntryPoint object for `group`+`name`, or ``None``""" + return get_distribution(dist).get_entry_info(group, name) + + +class IMetadataProvider: + def has_metadata(name): + """Does the package's distribution contain the named metadata?""" + + def get_metadata(name): + """The named metadata resource as a string""" + + 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.""" + + def metadata_isdir(name): + """Is the named metadata a directory? (like ``os.path.isdir()``)""" + + def metadata_listdir(name): + """List of metadata names in the directory (like ``os.listdir()``)""" + + def run_script(script_name, namespace): + """Execute the named script in the supplied namespace dictionary""" + + +class IResourceProvider(IMetadataProvider): + """An object that provides access to package resources""" + + def get_resource_filename(manager, resource_name): + """Return a true filesystem path for `resource_name` + + `manager` must be an ``IResourceManager``""" + + def get_resource_stream(manager, resource_name): + """Return a readable file-like object for `resource_name` + + `manager` must be an ``IResourceManager``""" + + def get_resource_string(manager, resource_name): + """Return a string containing the contents of `resource_name` + + `manager` must be an ``IResourceManager``""" + + def has_resource(resource_name): + """Does the package contain the named resource?""" + + def resource_isdir(resource_name): + """Is the named resource a directory? (like ``os.path.isdir()``)""" + + def resource_listdir(resource_name): + """List of resource names in the directory (like ``os.listdir()``)""" + + +class WorkingSet: + """A collection of active distributions on sys.path (or a similar list)""" + + def __init__(self, entries=None): + """Create working set from list of path entries (default=sys.path)""" + self.entries = [] + self.entry_keys = {} + self.by_key = {} + self.callbacks = [] + + if entries is None: + entries = sys.path + + for entry in entries: + self.add_entry(entry) + + @classmethod + def _build_master(cls): + """ + Prepare the master working set. + """ + ws = cls() + try: + from __main__ import __requires__ + except ImportError: + # The main program does not list any requirements + return ws + + # ensure the requirements are met + try: + ws.require(__requires__) + except VersionConflict: + return cls._build_from_requirements(__requires__) + + return ws + + @classmethod + def _build_from_requirements(cls, req_spec): + """ + Build a working set from a requirement spec. Rewrites sys.path. + """ + # try it without defaults already on sys.path + # by starting with an empty path + ws = cls([]) + reqs = parse_requirements(req_spec) + dists = ws.resolve(reqs, Environment()) + for dist in dists: + ws.add(dist) + + # add any missing entries from sys.path + for entry in sys.path: + if entry not in ws.entries: + ws.add_entry(entry) + + # then copy back to sys.path + sys.path[:] = ws.entries + return ws + + def add_entry(self, entry): + """Add a path item to ``.entries``, finding any distributions on it + + ``find_distributions(entry, True)`` is used to find distributions + corresponding to the path entry, and they are added. `entry` is + always appended to ``.entries``, even if it is already present. + (This is because ``sys.path`` can contain the same value more than + once, and the ``.entries`` of the ``sys.path`` WorkingSet should always + equal ``sys.path``.) + """ + self.entry_keys.setdefault(entry, []) + self.entries.append(entry) + for dist in find_distributions(entry, True): + self.add(dist, entry, False) + + def __contains__(self, dist): + """True if `dist` is the active distribution for its project""" + return self.by_key.get(dist.key) == dist + + def find(self, req): + """Find a distribution matching requirement `req` + + If there is an active distribution for the requested project, this + returns it as long as it meets the version requirement specified by + `req`. But, if there is an active distribution for the project and it + does *not* meet the `req` requirement, ``VersionConflict`` is raised. + If there is no active distribution for the requested project, ``None`` + is returned. + """ + dist = self.by_key.get(req.key) + if dist is not None and dist not in req: + # XXX add more info + raise VersionConflict(dist, req) + return dist + + def iter_entry_points(self, group, name=None): + """Yield entry point objects from `group` matching `name` + + If `name` is None, yields all entry points in `group` from all + distributions in the working set, otherwise only ones matching + both `group` and `name` are yielded (in distribution order). + """ + return ( + entry + for dist in self + for entry in dist.get_entry_map(group).values() + if name is None or name == entry.name + ) + + def run_script(self, requires, script_name): + """Locate distribution for `requires` and run `script_name` script""" + ns = sys._getframe(1).f_globals + name = ns['__name__'] + ns.clear() + ns['__name__'] = name + self.require(requires)[0].run_script(script_name, ns) + + def __iter__(self): + """Yield distributions for non-duplicate projects in the working set + + The yield order is the order in which the items' path entries were + added to the working set. + """ + seen = {} + for item in self.entries: + if item not in self.entry_keys: + # workaround a cache issue + continue + + for key in self.entry_keys[item]: + if key not in seen: + seen[key] = 1 + yield self.by_key[key] + + def add(self, dist, entry=None, insert=True, replace=False): + """Add `dist` to working set, associated with `entry` + + If `entry` is unspecified, it defaults to the ``.location`` of `dist`. + On exit from this routine, `entry` is added to the end of the working + set's ``.entries`` (if it wasn't already present). + + `dist` is only added to the working set if it's for a project that + doesn't already have a distribution in the set, unless `replace=True`. + If it's added, any callbacks registered with the ``subscribe()`` method + will be called. + """ + if insert: + dist.insert_on(self.entries, entry, replace=replace) + + if entry is None: + entry = dist.location + keys = self.entry_keys.setdefault(entry, []) + keys2 = self.entry_keys.setdefault(dist.location, []) + if not replace and dist.key in self.by_key: + # ignore hidden distros + return + + self.by_key[dist.key] = dist + 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): + """List all distributions needed to (recursively) meet `requirements` + + `requirements` must be a sequence of ``Requirement`` objects. `env`, + if supplied, should be an ``Environment`` instance. If + not supplied, it defaults to all distributions available within any + entry or distribution in the working set. `installer`, if supplied, + will be invoked with each requirement that cannot be met by an + already-installed distribution; it should return a ``Distribution`` or + ``None``. + + Unless `replace_conflicting=True`, raises a VersionConflict exception + if + any requirements are found on the path that have the correct name but + the wrong version. Otherwise, if an `installer` is supplied it will be + invoked to obtain the correct version of the requirement and activate + it. + + `extras` is a list of the extras to be used with these requirements. + This is important because extra requirements may look like `my_req; + extra = "my_extra"`, which would otherwise be interpreted as a purely + optional requirement. Instead, we want to be able to assert that these + requirements are truly required. + """ + + # set up the stack + requirements = list(requirements)[::-1] + # set of processed requirements + processed = {} + # key -> dist + best = {} + to_activate = [] + + req_extras = _ReqExtras() + + # Mapping of requirement to set of distributions that required it; + # useful for reporting info about conflicts. + required_by = collections.defaultdict(set) + + while requirements: + # process dependencies breadth-first + req = requirements.pop(0) + if req in processed: + # Ignore cyclic or redundant dependencies + continue + + 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) + + # push the new requirements onto the stack + new_requirements = dist.requires(req.extras)[::-1] + requirements.extend(new_requirements) + + # Register the new requirements needed by req + for new_requirement in new_requirements: + required_by[new_requirement].add(req.project_name) + req_extras[new_requirement] = req.extras + + processed[req] = True + + # return list of distros to activate + return to_activate + + def find_plugins( + self, plugin_env, full_env=None, installer=None, fallback=True): + """Find all activatable distributions in `plugin_env` + + Example usage:: + + distributions, errors = working_set.find_plugins( + Environment(plugin_dirlist) + ) + # add plugins+libs to sys.path + map(working_set.add, distributions) + # display errors + print('Could not load', errors) + + The `plugin_env` should be an ``Environment`` instance that contains + only distributions that are in the project's "plugin directory" or + directories. The `full_env`, if supplied, should be an ``Environment`` + contains all currently-available distributions. If `full_env` is not + supplied, one is created automatically from the ``WorkingSet`` this + method is called on, which will typically mean that every directory on + ``sys.path`` will be scanned for distributions. + + `installer` is a standard installer callback as used by the + ``resolve()`` method. The `fallback` flag indicates whether we should + attempt to resolve older versions of a plugin if the newest version + cannot be resolved. + + This method returns a 2-tuple: (`distributions`, `error_info`), where + `distributions` is a list of the distributions found in `plugin_env` + that were loadable, along with any other distributions that are needed + to resolve their dependencies. `error_info` is a dictionary mapping + unloadable plugin distributions to an exception instance describing the + error that occurred. Usually this will be a ``DistributionNotFound`` or + ``VersionConflict`` instance. + """ + + plugin_projects = list(plugin_env) + # scan project names in alphabetic order + plugin_projects.sort() + + error_info = {} + distributions = {} + + if full_env is None: + env = Environment(self.entries) + env += plugin_env + else: + env = full_env + plugin_env + + shadow_set = self.__class__([]) + # put all our entries in shadow_set + list(map(shadow_set.add, self)) + + for project_name in plugin_projects: + + for dist in plugin_env[project_name]: + + req = [dist.as_requirement()] + + try: + resolvees = shadow_set.resolve(req, env, installer) + + except ResolutionError as v: + # save error info + error_info[dist] = v + if fallback: + # try the next older version of project + continue + else: + # give up on this project, keep going + break + + else: + list(map(shadow_set.add, resolvees)) + distributions.update(dict.fromkeys(resolvees)) + + # success, no need to try any more versions of this project + break + + distributions = list(distributions) + distributions.sort() + + return distributions, error_info + + def require(self, *requirements): + """Ensure that distributions matching `requirements` are activated + + `requirements` must be a string or a (possibly-nested) sequence + thereof, specifying the distributions and versions required. The + return value is a sequence of the distributions that needed to be + activated to fulfill the requirements; all relevant distributions are + included, even if they were already activated in this working set. + """ + needed = self.resolve(parse_requirements(requirements)) + + for dist in needed: + self.add(dist) + + return needed + + def subscribe(self, callback, existing=True): + """Invoke `callback` for all distributions + + If `existing=True` (default), + call on all existing ones, as well. + """ + if callback in self.callbacks: + return + self.callbacks.append(callback) + if not existing: + return + for dist in self: + callback(dist) + + def _added_new(self, dist): + for callback in self.callbacks: + callback(dist) + + def __getstate__(self): + return ( + self.entries[:], self.entry_keys.copy(), self.by_key.copy(), + self.callbacks[:] + ) + + def __setstate__(self, e_k_b_c): + entries, keys, by_key, callbacks = e_k_b_c + self.entries = entries[:] + self.entry_keys = keys.copy() + self.by_key = by_key.copy() + self.callbacks = callbacks[:] + + +class _ReqExtras(dict): + """ + Map each requirement to the extras that demanded it. + """ + + def markers_pass(self, req, extras=None): + """ + Evaluate markers for req against each extra that + demanded it. + + Return False if the req has a marker and fails + evaluation. Otherwise, return True. + """ + extra_evals = ( + req.marker.evaluate({'extra': extra}) + for extra in self.get(req, ()) + (extras or (None,)) + ) + return not req.marker or any(extra_evals) + + +class Environment: + """Searchable snapshot of distributions on a search path""" + + def __init__( + 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. + `search_path` should be a sequence of ``sys.path`` items. If not + supplied, ``sys.path`` is used. + + `platform` is an optional string specifying the name of the platform + that platform-specific distributions must be compatible with. If + unspecified, it defaults to the current platform. `python` is an + optional string naming the desired version of Python (e.g. ``'3.6'``); + it defaults to the current version. + + You may explicitly set `platform` (and/or `python`) to ``None`` if you + wish to map *all* distributions, not just those compatible with the + running platform or Python version. + """ + self._distmap = {} + self.platform = platform + self.python = python + self.scan(search_path) + + def can_add(self, dist): + """Is distribution `dist` acceptable for this environment? + + The distribution must match the platform and python version + requirements specified when this environment was created, or False + is returned. + """ + py_compat = ( + self.python is None + or dist.py_version is None + or dist.py_version == self.python + ) + return py_compat and compatible_platforms(dist.platform, self.platform) + + def remove(self, dist): + """Remove `dist` from the environment""" + self._distmap[dist.key].remove(dist) + + def scan(self, search_path=None): + """Scan `search_path` for distributions usable in this environment + + Any distributions found are added to the environment. + `search_path` should be a sequence of ``sys.path`` items. If not + supplied, ``sys.path`` is used. Only distributions conforming to + the platform/python version defined at initialization are added. + """ + if search_path is None: + search_path = sys.path + + for item in search_path: + for dist in find_distributions(item): + self.add(dist) + + def __getitem__(self, project_name): + """Return a newest-to-oldest list of distributions for `project_name` + + Uses case-insensitive `project_name` comparison, assuming all the + project's distributions use their project's name converted to all + lowercase as their key. + + """ + distribution_key = project_name.lower() + return self._distmap.get(distribution_key, []) + + def add(self, dist): + """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): + """Find distribution best matching `req` and usable on `working_set` + + This calls the ``find(req)`` method of the `working_set` to see if a + suitable distribution is already active. (This may raise + ``VersionConflict`` if an unsuitable version of the project is already + active in the specified `working_set`.) If a suitable distribution + isn't active, this method returns the newest distribution in the + environment that meets the ``Requirement`` in `req`. If no suitable + distribution is found, and `installer` is supplied, then the result of + calling the environment's ``obtain(req, installer)`` method will be + returned. + """ + try: + dist = working_set.find(req) + except VersionConflict: + if not replace_conflicting: + raise + dist = None + if dist is not None: + return dist + for dist in self[req.key]: + if dist in req: + return dist + # try to download/install + return self.obtain(req, installer) + + def obtain(self, requirement, installer=None): + """Obtain a distribution matching `requirement` (e.g. via download) + + Obtain a distro that matches requirement (e.g. via download). In the + base ``Environment`` class, this routine just returns + ``installer(requirement)``, unless `installer` is None, in which case + None is returned instead. This method is a hook that allows subclasses + to attempt other ways of obtaining a distribution before falling back + to the `installer` argument.""" + if installer is not None: + return installer(requirement) + + def __iter__(self): + """Yield the unique project names of the available distributions""" + for key in self._distmap.keys(): + if self[key]: + yield key + + def __iadd__(self, other): + """In-place addition of a distribution or environment""" + if isinstance(other, Distribution): + self.add(other) + elif isinstance(other, Environment): + for project in other: + for dist in other[project]: + self.add(dist) + else: + raise TypeError("Can't add %r to environment" % (other,)) + return self + + def __add__(self, other): + """Add an environment or distribution to an environment""" + new = self.__class__([], platform=None, python=None) + for env in self, other: + new += env + return new + + +# XXX backward compatibility +AvailableDistributions = Environment + + +class ExtractionError(RuntimeError): + """An error occurred extracting a resource + + The following attributes are available from instances of this exception: + + manager + The resource manager that raised this exception + + cache_path + The base directory for resource extraction + + original_error + The exception instance that caused extraction to fail + """ + + +class ResourceManager: + """Manage resource extraction and packages""" + extraction_path = None + + def __init__(self): + self.cached_files = {} + + def resource_exists(self, package_or_requirement, resource_name): + """Does the named resource exist?""" + return get_provider(package_or_requirement).has_resource(resource_name) + + 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 + ) + + def resource_filename(self, package_or_requirement, resource_name): + """Return a true filesystem path for specified resource""" + return get_provider(package_or_requirement).get_resource_filename( + self, resource_name + ) + + def resource_stream(self, package_or_requirement, resource_name): + """Return a readable file-like object for specified resource""" + return get_provider(package_or_requirement).get_resource_stream( + self, resource_name + ) + + def resource_string(self, package_or_requirement, resource_name): + """Return specified resource as a string""" + return get_provider(package_or_requirement).get_resource_string( + self, resource_name + ) + + 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 + ) + + def extraction_error(self): + """Give an error message for problems extracting file(s)""" + + old_exc = sys.exc_info()[1] + cache_path = self.extraction_path or get_default_cache() + + tmpl = textwrap.dedent(""" + Can't extract file(s) to egg cache + + The following error occurred while trying to extract file(s) + to the Python egg cache: + + {old_exc} + + The Python egg cache directory is currently set to: + + {cache_path} + + 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() + err = ExtractionError(tmpl.format(**locals())) + err.manager = self + err.cache_path = cache_path + err.original_error = old_exc + raise err + + def get_cache_path(self, archive_name, names=()): + """Return absolute location in cache for `archive_name` and `names` + + The parent directory of the resulting path will be created if it does + not already exist. `archive_name` should be the base filename of the + enclosing egg (which may not be the name of the enclosing zipfile!), + including its ".egg" extension. `names`, if provided, should be a + sequence of path name parts "under" the egg's extraction location. + + This method should only be called by resource providers that need to + obtain an extraction location, and only for names they intend to + extract, as it tracks the generated names for possible cleanup later. + """ + extract_path = self.extraction_path or get_default_cache() + target_path = os.path.join(extract_path, archive_name + '-tmp', *names) + try: + _bypass_ensure_directory(target_path) + except Exception: + self.extraction_error() + + self._warn_unsafe_extraction_path(extract_path) + + self.cached_files[target_path] = 1 + return target_path + + @staticmethod + def _warn_unsafe_extraction_path(path): + """ + If the default extraction path is overridden and set to an insecure + location, such as /tmp, it opens up an opportunity for an attacker to + replace an extracted file with an unauthorized payload. Warn the user + if a known insecure location is used. + + See Distribute #375 for more details. + """ + if os.name == 'nt' and not path.startswith(os.environ['windir']): + # On Windows, permissions are generally restrictive by default + # and temp directories are not writable by other users, so + # bypass the warning. + return + 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 " + "location (set with .set_extraction_path or the " + "PYTHON_EGG_CACHE environment variable)." % path + ) + warnings.warn(msg, UserWarning) + + def postprocess(self, tempname, filename): + """Perform any platform-specific postprocessing of `tempname` + + This is where Mac header rewrites should be done; other platforms don't + have anything special they should do. + + Resource providers should call this method ONLY after successfully + extracting a compressed resource. They must NOT call it on resources + that are already in the filesystem. + + `tempname` is the current (temporary) name of the file, and `filename` + is the name it will be renamed to by the caller after this routine + returns. + """ + + if os.name == 'posix': + # Make the resource executable + mode = ((os.stat(tempname).st_mode) | 0o555) & 0o7777 + os.chmod(tempname, mode) + + def set_extraction_path(self, path): + """Set the base path where resources will be extracted to, if needed. + + If you do not call this routine before any extractions take place, the + path defaults to the return value of ``get_default_cache()``. (Which + is based on the ``PYTHON_EGG_CACHE`` environment variable, with various + platform-specific fallbacks. See that routine's documentation for more + details.) + + Resources are extracted to subdirectories of this path based upon + information given by the ``IResourceProvider``. You may set this to a + temporary directory, but then you must call ``cleanup_resources()`` to + delete the extracted files when done. There is no guarantee that + ``cleanup_resources()`` will be able to remove all extracted files. + + (Note: you may not change the extraction path for a given resource + manager once resources have been extracted, unless you first call + ``cleanup_resources()``.) + """ + if self.cached_files: + raise ValueError( + "Can't change extraction path, files already extracted" + ) + + self.extraction_path = path + + def cleanup_resources(self, force=False): + """ + Delete all extracted resource files and directories, returning a list + of the file and directory names that could not be successfully removed. + This function does not have any concurrency protection, so it should + generally only be called when the extraction path is a temporary + directory exclusive to a single process. This method is not + automatically called; you must call it explicitly or register it as an + ``atexit`` function if you wish to ensure cleanup of a temporary + directory used for extractions. + """ + # XXX + + +def get_default_cache(): + """ + Return the ``PYTHON_EGG_CACHE`` environment variable + 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') + ) + + +def safe_name(name): + """Convert an arbitrary string to a standard distribution name + + Any runs of non-alphanumeric/. characters are replaced with a single '-'. + """ + return re.sub('[^A-Za-z0-9.]+', '-', name) + + +def safe_version(version): + """ + Convert an arbitrary string to a standard version string + """ + try: + # normalize the version + return str(packaging.version.Version(version)) + except packaging.version.InvalidVersion: + version = version.replace(' ', '.') + return re.sub('[^A-Za-z0-9.]+', '-', version) + + +def safe_extra(extra): + """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. + """ + return re.sub('[^A-Za-z0-9.-]+', '_', extra).lower() + + +def to_filename(name): + """Convert a project or version name to its filename-escaped form + + Any '-' characters are currently replaced with '_'. + """ + return name.replace('-', '_') + + +def invalid_marker(text): + """ + Validate text as a PEP 508 environment marker; return an exception + if invalid or False otherwise. + """ + try: + evaluate_marker(text) + except SyntaxError as e: + e.filename = None + e.lineno = None + return e + return False + + +def evaluate_marker(text, extra=None): + """ + Evaluate a PEP 508 environment marker. + Return a boolean indicating the marker result in this environment. + Raise SyntaxError if marker is invalid. + + This implementation uses the 'pyparsing' module. + """ + try: + marker = packaging.markers.Marker(text) + return marker.evaluate() + except packaging.markers.InvalidMarker as e: + raise SyntaxError(e) + + +class NullProvider: + """Try to implement resources and metadata for arbitrary PEP 302 loaders""" + + egg_name = None + egg_info = None + loader = None + + def __init__(self, module): + self.loader = getattr(module, '__loader__', None) + self.module_path = os.path.dirname(getattr(module, '__file__', '')) + + def get_resource_filename(self, manager, resource_name): + return self._fn(self.module_path, resource_name) + + def get_resource_stream(self, manager, resource_name): + return io.BytesIO(self.get_resource_string(manager, resource_name)) + + def get_resource_string(self, manager, resource_name): + return self._get(self._fn(self.module_path, resource_name)) + + def has_resource(self, resource_name): + return self._has(self._fn(self.module_path, resource_name)) + + def _get_metadata_path(self, name): + return self._fn(self.egg_info, name) + + def has_metadata(self, name): + if not self.egg_info: + return self.egg_info + + path = self._get_metadata_path(name) + return self._has(path) + + def get_metadata(self, name): + if not self.egg_info: + 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: + # Include the path in the error message to simplify + # troubleshooting, and without changing the exception type. + exc.reason += ' in {} file at path: {}'.format(name, path) + raise + + def get_metadata_lines(self, name): + return yield_lines(self.get_metadata(name)) + + def resource_isdir(self, resource_name): + return self._isdir(self._fn(self.module_path, resource_name)) + + def metadata_isdir(self, name): + return self.egg_info and self._isdir(self._fn(self.egg_info, name)) + + def resource_listdir(self, resource_name): + return self._listdir(self._fn(self.module_path, resource_name)) + + def metadata_listdir(self, name): + if self.egg_info: + return self._listdir(self._fn(self.egg_info, name)) + return [] + + def run_script(self, script_name, namespace): + 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_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() + 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 + ) + script_code = compile(script_text, script_filename, 'exec') + exec(script_code, namespace, namespace) + + def _has(self, path): + raise NotImplementedError( + "Can't perform this operation for unregistered loader type" + ) + + def _isdir(self, path): + raise NotImplementedError( + "Can't perform this operation for unregistered loader type" + ) + + def _listdir(self, path): + raise NotImplementedError( + "Can't perform this operation for unregistered loader type" + ) + + def _fn(self, base, resource_name): + self._validate_resource_path(resource_name) + if resource_name: + return os.path.join(base, *resource_name.split('/')) + return base + + @staticmethod + 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 + + >>> warned = getfixture('recwarn') + >>> warnings.simplefilter('always') + >>> vrp = NullProvider._validate_resource_path + >>> vrp('foo/bar.txt') + >>> bool(warned) + False + >>> vrp('../foo/bar.txt') + >>> bool(warned) + True + >>> warned.clear() + >>> vrp('/foo/bar.txt') + >>> bool(warned) + True + >>> vrp('foo/../../bar.txt') + >>> bool(warned) + True + >>> warned.clear() + >>> vrp('foo/f../bar.txt') + >>> bool(warned) + False + + Windows path separators are straight-up disallowed. + >>> vrp(r'\\foo/bar.txt') + Traceback (most recent call last): + ... + ValueError: Use of .. or absolute path in a resource path \ +is not allowed. + + >>> vrp(r'C:\\foo/bar.txt') + Traceback (most recent call last): + ... + ValueError: Use of .. or absolute path in a resource path \ +is not allowed. + + Blank values are allowed + + >>> vrp('') + >>> bool(warned) + False + + Non-string values are not. + + >>> vrp(None) + Traceback (most recent call last): + ... + AttributeError: ... + """ + invalid = ( + os.path.pardir in path.split(posixpath.sep) or + posixpath.isabs(path) or + ntpath.isabs(path) + ) + if not invalid: + return + + msg = "Use of .. or absolute path in a resource path is not allowed." + + # Aggressively disallow Windows absolute paths + if ntpath.isabs(path) and not posixpath.isabs(path): + raise ValueError(msg) + + # for compatibility, warn; in future + # raise ValueError(msg) + warnings.warn( + msg[:-1] + " and will raise exceptions in a future release.", + DeprecationWarning, + stacklevel=4, + ) + + def _get(self, path): + if hasattr(self.loader, 'get_data'): + return self.loader.get_data(path) + raise NotImplementedError( + "Can't perform this operation for loaders without 'get_data()'" + ) + + +register_loader_type(object, NullProvider) + + +class EggProvider(NullProvider): + """Provider based on a virtual filesystem""" + + def __init__(self, module): + NullProvider.__init__(self, 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) + + +class DefaultProvider(EggProvider): + """Provides access to package resources in the filesystem""" + + def _has(self, path): + return os.path.exists(path) + + def _isdir(self, path): + return os.path.isdir(path) + + def _listdir(self, path): + return os.listdir(path) + + def get_resource_stream(self, manager, resource_name): + return open(self._fn(self.module_path, resource_name), 'rb') + + def _get(self, path): + with open(path, 'rb') as stream: + return stream.read() + + @classmethod + def _register(cls): + loader_names = 'SourceFileLoader', 'SourcelessFileLoader', + for name in loader_names: + loader_cls = getattr(importlib_machinery, name, type(None)) + register_loader_type(loader_cls, cls) + + +DefaultProvider._register() + + +class EmptyProvider(NullProvider): + """Provider that returns nothing for all requests""" + + module_path = None + + _isdir = _has = lambda self, path: False + + def _get(self, path): + return '' + + def _listdir(self, path): + return [] + + def __init__(self): + pass + + +empty_provider = EmptyProvider() + + +class ZipManifests(dict): + """ + zip manifest builder + """ + + @classmethod + def build(cls, path): + """ + Build a dictionary similar to the zipimport directory + caches, except instead of tuples, store ZipInfo objects. + + Use a platform-specific path separator (os.sep) for the path keys + for compatibility with pypy on Windows. + """ + with zipfile.ZipFile(path) as zfile: + items = ( + ( + name.replace('/', os.sep), + zfile.getinfo(name), + ) + for name in zfile.namelist() + ) + return dict(items) + + load = build + + +class MemoizedZipManifests(ZipManifests): + """ + Memoized zipfile manifests. + """ + manifest_mod = collections.namedtuple('manifest_mod', 'manifest mtime') + + def load(self, path): + """ + Load a manifest at path or return a suitable manifest already loaded. + """ + path = os.path.normpath(path) + mtime = os.stat(path).st_mtime + + if path not in self or self[path].mtime != mtime: + manifest = self.build(path) + self[path] = self.manifest_mod(manifest, mtime) + + return self[path].manifest + + +class ZipProvider(EggProvider): + """Resource support for zips and eggs""" + + eagers = None + _zip_manifests = MemoizedZipManifests() + + def __init__(self, module): + EggProvider.__init__(self, module) + self.zip_pre = self.loader.archive + os.sep + + def _zipinfo_name(self, fspath): + # Convert a virtual filename (full path to file) into a zipfile subpath + # usable with the zipimport directory cache for our target archive + fspath = fspath.rstrip(os.sep) + 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) + ) + + 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) + ) + + @property + def zipinfo(self): + return self._zip_manifests.load(self.loader.archive) + + def get_resource_filename(self, manager, resource_name): + if not self.egg_name: + raise NotImplementedError( + "resource_filename() only supported for .egg, not .zip" + ) + # no need to lock for extraction, since we use temp names + zip_path = self._resource_to_zip(resource_name) + eagers = self._get_eager_resources() + if '/'.join(self._parts(zip_path)) in eagers: + for name in eagers: + self._extract_resource(manager, self._eager_to_zip(name)) + return self._extract_resource(manager, zip_path) + + @staticmethod + def _get_date_and_size(zip_stat): + size = zip_stat.file_size + # ymdhms+wday, yday, dst + date_time = zip_stat.date_time + (0, 0, -1) + # 1980 offset already done + timestamp = time.mktime(date_time) + return timestamp, size + + def _extract_resource(self, manager, zip_path): + + if zip_path in self._index(): + for name in self._index()[zip_path]: + 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) + ) + + if self._is_current(real_path, zip_path): + return real_path + + outf, tmpnam = _mkstemp( + ".$extract", + dir=os.path.dirname(real_path), + ) + os.write(outf, self.loader.get_data(zip_path)) + os.close(outf) + utime(tmpnam, (timestamp, timestamp)) + manager.postprocess(tmpnam, real_path) + + try: + rename(tmpnam, real_path) + + except os.error: + if os.path.isfile(real_path): + if self._is_current(real_path, zip_path): + # the file became current since it was checked above, + # so proceed. + return real_path + # Windows, del old file and retry + elif os.name == 'nt': + unlink(real_path) + rename(tmpnam, real_path) + return real_path + raise + + except os.error: + # report a user-friendly error + manager.extraction_error() + + return real_path + + def _is_current(self, file_path, zip_path): + """ + Return True if the file_path is current for this zip_path + """ + timestamp, size = self._get_date_and_size(self.zipinfo[zip_path]) + if not os.path.isfile(file_path): + return False + stat = os.stat(file_path) + if stat.st_size != size or stat.st_mtime != timestamp: + return False + # check that the contents match + zip_contents = self.loader.get_data(zip_path) + with open(file_path, 'rb') as f: + file_contents = f.read() + return zip_contents == file_contents + + def _get_eager_resources(self): + if self.eagers is None: + eagers = [] + for name in ('native_libs.txt', 'eager_resources.txt'): + if self.has_metadata(name): + eagers.extend(self.get_metadata_lines(name)) + self.eagers = eagers + return self.eagers + + def _index(self): + try: + return self._dirindex + except AttributeError: + ind = {} + for path in self.zipinfo: + parts = path.split(os.sep) + while parts: + parent = os.sep.join(parts[:-1]) + if parent in ind: + ind[parent].append(parts[-1]) + break + else: + ind[parent] = [parts.pop()] + self._dirindex = ind + return ind + + def _has(self, fspath): + zip_path = self._zipinfo_name(fspath) + return zip_path in self.zipinfo or zip_path in self._index() + + def _isdir(self, fspath): + return self._zipinfo_name(fspath) in self._index() + + def _listdir(self, fspath): + return list(self._index().get(self._zipinfo_name(fspath), ())) + + def _eager_to_zip(self, resource_name): + return self._zipinfo_name(self._fn(self.egg_root, resource_name)) + + def _resource_to_zip(self, resource_name): + return self._zipinfo_name(self._fn(self.module_path, resource_name)) + + +register_loader_type(zipimport.zipimporter, ZipProvider) + + +class FileMetadata(EmptyProvider): + """Metadata handler for standalone PKG-INFO files + + Usage:: + + metadata = FileMetadata("/path/to/PKG-INFO") + + This provider rejects all data and metadata requests except for PKG-INFO, + which is treated as existing, and will be the contents of the file at + the provided location. + """ + + def __init__(self, path): + self.path = path + + def _get_metadata_path(self, name): + return self.path + + def has_metadata(self, name): + return name == 'PKG-INFO' and os.path.isfile(self.path) + + def get_metadata(self, name): + if name != 'PKG-INFO': + raise KeyError("No metadata except PKG-INFO is available") + + with io.open(self.path, encoding='utf-8', errors="replace") as f: + metadata = f.read() + self._warn_on_replacement(metadata) + return metadata + + def _warn_on_replacement(self, metadata): + # Python 2.7 compat for: replacement_char = '�' + replacement_char = b'\xef\xbf\xbd'.decode('utf-8') + if replacement_char in metadata: + tmpl = "{self.path} could not be properly decoded in UTF-8" + msg = tmpl.format(**locals()) + warnings.warn(msg) + + def get_metadata_lines(self, name): + return yield_lines(self.get_metadata(name)) + + +class PathMetadata(DefaultProvider): + """Metadata provider for egg directories + + Usage:: + + # Development eggs: + + egg_info = "/path/to/PackageName.egg-info" + base_dir = os.path.dirname(egg_info) + metadata = PathMetadata(base_dir, egg_info) + dist_name = os.path.splitext(os.path.basename(egg_info))[0] + dist = Distribution(basedir, project_name=dist_name, metadata=metadata) + + # Unpacked egg directories: + + egg_path = "/path/to/PackageName-ver-pyver-etc.egg" + metadata = PathMetadata(egg_path, os.path.join(egg_path,'EGG-INFO')) + dist = Distribution.from_filename(egg_path, metadata=metadata) + """ + + def __init__(self, path, egg_info): + self.module_path = path + self.egg_info = egg_info + + +class EggMetadata(ZipProvider): + """Metadata provider for .egg files""" + + def __init__(self, importer): + """Create a metadata provider from a zipimporter""" + + self.zip_pre = importer.archive + os.sep + self.loader = importer + if importer.prefix: + self.module_path = os.path.join(importer.archive, importer.prefix) + else: + self.module_path = importer.archive + self._setup_prefix() + + +_declare_state('dict', _distribution_finders={}) + + +def register_finder(importer_type, distribution_finder): + """Register `distribution_finder` to find distributions in sys.path items + + `importer_type` is the type or class of a PEP 302 "Importer" (sys.path item + handler), and `distribution_finder` is a callable that, passed a path + item and the importer instance, yields ``Distribution`` instances found on + that path item. See ``pkg_resources.find_on_path`` for an example.""" + _distribution_finders[importer_type] = distribution_finder + + +def find_distributions(path_item, only=False): + """Yield distributions accessible via `path_item`""" + importer = get_importer(path_item) + finder = _find_adapter(_distribution_finders, importer) + return finder(importer, path_item, only) + + +def find_eggs_in_zip(importer, path_item, only=False): + """ + Find eggs in zip files; possibly multiple nested eggs. + """ + if importer.archive.endswith('.whl'): + # wheels are not supported with this finder + # they don't have PKG-INFO metadata, and won't ever contain eggs + return + metadata = EggMetadata(importer) + if metadata.has_metadata('PKG-INFO'): + yield Distribution.from_filename(path_item, metadata=metadata) + if only: + # don't yield nested distros + return + for subitem in metadata.resource_listdir(''): + if _is_egg_path(subitem): + subpath = os.path.join(path_item, subitem) + dists = find_eggs_in_zip(zipimport.zipimporter(subpath), subpath) + for dist in dists: + yield dist + elif subitem.lower().endswith('.dist-info'): + subpath = os.path.join(path_item, subitem) + submeta = EggMetadata(zipimport.zipimporter(subpath)) + submeta.egg_info = subpath + yield Distribution.from_location(path_item, subitem, submeta) + + +register_finder(zipimport.zipimporter, find_eggs_in_zip) + + +def find_nothing(importer, path_item, only=False): + return () + + +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') + ) + ) + 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) + ) + + # scan for .egg and .egg-info in directory + path_item_entries = _by_version_descending(filtered) + for entry in path_item_entries: + fullpath = os.path.join(path_item, entry) + factory = dist_factory(path_item, entry, only) + for dist in factory(fullpath): + yield dist + + +def dist_factory(path_item, entry, only): + """ + Return a dist_factory for a path_item and entry + """ + lower = entry.lower() + is_meta = any(map(lower.endswith, ('.egg-info', '.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() + ) + + +class NoDists: + """ + >>> bool(NoDists()) + False + + >>> list(NoDists()('anything')) + [] + """ + def __bool__(self): + return False + if six.PY2: + __nonzero__ = __bool__ + + def __call__(self, fullpath): + return iter(()) + + +def safe_listdir(path): + """ + Attempt to list contents of path, but suppress some exceptions. + """ + try: + return os.listdir(path) + except (PermissionError, NotADirectoryError): + pass + 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: + raise + return () + + +def distributions_from_metadata(path): + root = os.path.dirname(path) + if os.path.isdir(path): + if len(os.listdir(path)) == 0: + # empty metadata dir; skip + return + metadata = PathMetadata(root, path) + else: + metadata = FileMetadata(path) + entry = os.path.basename(path) + yield Distribution.from_location( + root, entry, metadata, precedence=DEVELOP_DIST, + ) + + +def non_empty_lines(path): + """ + Yield non-empty lines from file at path + """ + with open(path) as f: + for line in f: + line = line.strip() + if line: + yield line + + +def resolve_egg_link(path): + """ + Given a path to an .egg-link, resolve distributions + present in the referenced path. + """ + referenced_paths = non_empty_lines(path) + resolved_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(importlib_machinery, 'FileFinder'): + register_finder(importlib_machinery.FileFinder, find_on_path) + +_declare_state('dict', _namespace_handlers={}) +_declare_state('dict', _namespace_packages={}) + + +def register_namespace_handler(importer_type, namespace_handler): + """Register `namespace_handler` to declare namespace packages + + `importer_type` is the type or class of a PEP 302 "Importer" (sys.path item + handler), and `namespace_handler` is a callable like this:: + + def namespace_handler(importer, path_entry, moduleName, module): + # return a path_entry to use for child packages + + Namespace handlers are only called if the importer object has already + agreed that it can handle the relevant path item, and they should only + return a subpath if the module __path__ does not already contain an + equivalent subpath. For an example namespace handler, see + ``pkg_resources.file_ns_handler``. + """ + _namespace_handlers[importer_type] = namespace_handler + + +def _handle_ns(packageName, path_item): + """Ensure that named package includes a subpath of path_item (if needed)""" + + importer = get_importer(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) + + if loader is None: + return None + module = sys.modules.get(packageName) + if module is None: + module = sys.modules[packageName] = types.ModuleType(packageName) + module.__path__ = [] + _set_parent_ns(packageName) + elif not hasattr(module, '__path__'): + raise TypeError("Not a package:", packageName) + handler = _find_adapter(_namespace_handlers, importer) + subpath = handler(importer, path_item, packageName, module) + if subpath is not None: + path = module.__path__ + path.append(subpath) + loader.load_module(packageName) + _rebuild_mod_path(path, packageName, module) + return subpath + + +def _rebuild_mod_path(orig_path, package_name, module): + """ + Rebuild module.__path__ ensuring that all entries are ordered + corresponding to their sys.path order + """ + sys_path = [_normalize_cached(p) for p in sys.path] + + def safe_sys_path_index(entry): + """ + Workaround for #520 and #513. + """ + try: + return sys_path.index(entry) + except ValueError: + return float('inf') + + def position_in_sys_path(path): + """ + Return the ordinal of the path based on its position in sys.path + """ + path_parts = path.split(os.sep) + module_parts = package_name.count('.') + 1 + parts = path_parts[:-module_parts] + return safe_sys_path_index(_normalize_cached(os.sep.join(parts))) + + new_path = sorted(orig_path, key=position_in_sys_path) + new_path = [_normalize_cached(p) for p in new_path] + + if isinstance(module.__path__, list): + module.__path__[:] = new_path + else: + module.__path__ = new_path + + +def declare_namespace(packageName): + """Declare that package 'packageName' is a namespace package""" + + _imp.acquire_lock() + try: + if packageName in _namespace_packages: + return + + path = sys.path + parent, _, _ = packageName.rpartition('.') + + if parent: + declare_namespace(parent) + if parent not in _namespace_packages: + __import__(parent) + try: + path = sys.modules[parent].__path__ + except AttributeError: + raise TypeError("Not a package:", parent) + + # Track what packages are namespaces, so when new path items are added, + # they can be updated + _namespace_packages.setdefault(parent or None, []).append(packageName) + _namespace_packages.setdefault(packageName, []) + + for path_item in path: + # Ensure all the parent's path items are reflected in the child, + # if they apply + _handle_ns(packageName, path_item) + + finally: + _imp.release_lock() + + +def fixup_namespace_packages(path_item, parent=None): + """Ensure that previously-declared namespace packages include path_item""" + _imp.acquire_lock() + try: + for package in _namespace_packages.get(parent, ()): + subpath = _handle_ns(package, path_item) + if subpath: + fixup_namespace_packages(subpath, package) + finally: + _imp.release_lock() + + +def file_ns_handler(importer, path_item, packageName, module): + """Compute an ns-package subpath for a filesystem or zipfile importer""" + + subpath = os.path.join(path_item, packageName.split('.')[-1]) + normalized = _normalize_cached(subpath) + for item in module.__path__: + if _normalize_cached(item) == normalized: + break + else: + # Only return the path if it's not already there + return subpath + + +register_namespace_handler(pkgutil.ImpImporter, file_ns_handler) +register_namespace_handler(zipimport.zipimporter, file_ns_handler) + +if hasattr(importlib_machinery, 'FileFinder'): + register_namespace_handler(importlib_machinery.FileFinder, file_ns_handler) + + +def null_ns_handler(importer, path_item, packageName, module): + return None + + +register_namespace_handler(object, null_ns_handler) + + +def normalize_path(filename): + """Normalize a file/dir name for comparison purposes""" + return os.path.normcase(os.path.realpath(os.path.normpath(_cygwin_patch(filename)))) + + +def _cygwin_patch(filename): # pragma: nocover + """ + Contrary to POSIX 2008, on Cygwin, getcwd (3) contains + symlink components. Using + os.path.abspath() works around this limitation. A fix in os.getcwd() + would probably better, in Cygwin even more so, except + that this seems to be by design... + """ + return os.path.abspath(filename) if sys.platform == 'cygwin' else filename + + +def _normalize_cached(filename, _cache={}): + try: + return _cache[filename] + except KeyError: + _cache[filename] = result = normalize_path(filename) + return result + + +def _is_egg_path(path): + """ + Determine if given path appears to be an egg. + """ + return path.lower().endswith('.egg') + + +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')) + ) + + +def _set_parent_ns(packageName): + parts = packageName.split('.') + name = parts.pop() + if parts: + parent = '.'.join(parts) + 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""" + (?P[^-]+) ( + -(?P[^-]+) ( + -py(?P[^-]+) ( + -(?P.+) + )? + )? + )? + """, + re.VERBOSE | re.IGNORECASE, +).match + + +class EntryPoint: + """Object representing an advertised importable object""" + + def __init__(self, name, module_name, attrs=(), extras=(), dist=None): + if not MODULE(module_name): + raise ValueError("Invalid module name", module_name) + self.name = name + self.module_name = module_name + self.attrs = tuple(attrs) + self.extras = tuple(extras) + self.dist = dist + + def __str__(self): + s = "%s = %s" % (self.name, self.module_name) + if self.attrs: + s += ':' + '.'.join(self.attrs) + if self.extras: + s += ' [%s]' % ','.join(self.extras) + return s + + def __repr__(self): + return "EntryPoint.parse(%r)" % str(self) + + def load(self, require=True, *args, **kwargs): + """ + Require packages for this EntryPoint, then resolve it. + """ + if not require or args or kwargs: + warnings.warn( + "Parameters to load are deprecated. Call .resolve and " + ".require separately.", + PkgResourcesDeprecationWarning, + stacklevel=2, + ) + if require: + self.require(*args, **kwargs) + return self.resolve() + + def resolve(self): + """ + Resolve the entry point from its module and attrs. + """ + module = __import__(self.module_name, fromlist=['__name__'], level=0) + try: + return functools.reduce(getattr, self.attrs, module) + except AttributeError as exc: + raise ImportError(str(exc)) + + def require(self, env=None, installer=None): + if self.extras and not self.dist: + raise UnknownExtra("Can't require() without a distribution", self) + + # Get the requirements for this entry point with all its extras and + # then resolve them. We have to pass `extras` along when resolving so + # that the working set knows what extras we want. Otherwise, for + # dist-info distributions, the working set will assume that the + # requirements for that extra are purely optional and skip over them. + reqs = self.dist.requires(self.extras) + items = working_set.resolve(reqs, env, installer, extras=self.extras) + list(map(working_set.add, items)) + + pattern = re.compile( + r'\s*' + r'(?P.+?)\s*' + r'=\s*' + r'(?P[\w.]+)\s*' + r'(:\s*(?P[\w.]+))?\s*' + r'(?P\[.*\])?\s*$' + ) + + @classmethod + def parse(cls, src, dist=None): + """Parse a single entry point from string `src` + + Entry point syntax follows the form:: + + name = some.module:some.attr [extra1, extra2] + + The entry name and module name are required, but the ``:attrs`` and + ``[extras]`` parts are optional + """ + m = cls.pattern.match(src) + if not m: + msg = "EntryPoint must be in 'name=module:attrs [extras]' format" + raise ValueError(msg, src) + res = m.groupdict() + extras = cls._parse_extras(res['extras']) + attrs = res['attr'].split('.') if res['attr'] else () + return cls(res['name'], res['module'], attrs, extras, dist) + + @classmethod + def _parse_extras(cls, extras_spec): + if not extras_spec: + return () + req = Requirement.parse('x' + extras_spec) + if req.specs: + raise ValueError() + return req.extras + + @classmethod + def parse_group(cls, group, lines, dist=None): + """Parse an entry point group""" + if not MODULE(group): + raise ValueError("Invalid group name", group) + this = {} + for line in yield_lines(lines): + ep = cls.parse(line, dist) + if ep.name in this: + raise ValueError("Duplicate entry point", group, ep.name) + this[ep.name] = ep + return this + + @classmethod + def parse_map(cls, data, dist=None): + """Parse a map of entry point groups""" + if isinstance(data, dict): + data = data.items() + else: + data = split_sections(data) + maps = {} + for group, lines in data: + if group is None: + if not lines: + continue + raise ValueError("Entry points must be listed in groups") + group = group.strip() + if group in maps: + raise ValueError("Duplicate group name", group) + maps[group] = cls.parse_group(group, lines, dist) + 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(':') + return safe_version(value.strip()) or None + + +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.project_name = safe_name(project_name or 'Unknown') + if version is not None: + self._version = safe_version(version) + self.py_version = py_version + self.platform = platform + self.location = location + self.precedence = precedence + self._provider = metadata or empty_provider + + @classmethod + def from_location(cls, location, basename, metadata=None, **kw): + project_name, version, py_version, platform = [None] * 4 + basename, ext = os.path.splitext(basename) + if ext.lower() in _distributionImpl: + cls = _distributionImpl[ext.lower()] + + match = EGG_NAME(basename) + if match: + project_name, version, py_version, platform = match.group( + 'name', 'ver', 'pyver', 'plat' + ) + return cls( + location, metadata, project_name=project_name, version=version, + py_version=py_version, platform=platform, **kw + )._reload_version() + + def _reload_version(self): + return self + + @property + def hashcmp(self): + return ( + self.parsed_version, + self.precedence, + self.key, + _remove_md5_fragment(self.location), + self.py_version or '', + self.platform or '', + ) + + def __hash__(self): + return hash(self.hashcmp) + + def __lt__(self, other): + return self.hashcmp < other.hashcmp + + def __le__(self, other): + return self.hashcmp <= other.hashcmp + + def __gt__(self, other): + return self.hashcmp > other.hashcmp + + def __ge__(self, other): + return self.hashcmp >= other.hashcmp + + def __eq__(self, other): + if not isinstance(other, self.__class__): + # It's not a Distribution, so they are not equal + return False + return self.hashcmp == other.hashcmp + + def __ne__(self, other): + return not self == other + + # These properties have to be lazy so that we don't have to load any + # metadata until/unless it's actually needed. (i.e., some distributions + # may not know their name or version without loading PKG-INFO) + + @property + def key(self): + try: + return self._key + except AttributeError: + self._key = key = self.project_name.lower() + return key + + @property + def parsed_version(self): + if not hasattr(self, "_parsed_version"): + self._parsed_version = parse_version(self.version) + + 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 + + # 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 + + 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', ' ') + + warnings.warn(tmpl.format(**vars(self)), PEP440Warning) + + @property + def version(self): + try: + return self._version + except AttributeError: + 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) + + return version + + @property + def _dep_map(self): + """ + A map of extra to its list of (direct) requirements + for this distribution, including the null extra. + """ + try: + return self.__dep_map + except AttributeError: + self.__dep_map = self._filter_extras(self._build_dep_map()) + return self.__dep_map + + @staticmethod + def _filter_extras(dm): + """ + Given a mapping of extras to dependencies, strip off + environment markers and filter out any dependencies + not matching the markers. + """ + for extra in list(filter(None, dm)): + new_extra = extra + reqs = dm.pop(extra) + new_extra, _, marker = extra.partition(':') + fails_marker = marker and ( + invalid_marker(marker) + or not evaluate_marker(marker) + ) + if fails_marker: + reqs = [] + new_extra = safe_extra(new_extra) or None + + dm.setdefault(new_extra, []).extend(reqs) + return dm + + def _build_dep_map(self): + dm = {} + for name in 'requires.txt', 'depends.txt': + for extra, reqs in split_sections(self._get_metadata(name)): + dm.setdefault(extra, []).extend(parse_requirements(reqs)) + return dm + + def requires(self, extras=()): + """List of Requirements needed for this distro if `extras` are used""" + dm = self._dep_map + deps = [] + deps.extend(dm.get(None, ())) + for ext in extras: + try: + deps.extend(dm[safe_extra(ext)]) + except KeyError: + raise UnknownExtra( + "%s has no such extra feature %r" % (self, ext) + ) + return deps + + def _get_metadata_path_for_display(self, name): + """ + Return the path to the given metadata file, if available. + """ + try: + # We need to access _get_metadata_path() on the provider object + # directly rather than through this class's __getattr__() + # since _get_metadata_path() is marked private. + path = self._provider._get_metadata_path(name) + + # Handle exceptions e.g. in case the distribution's metadata + # provider doesn't support _get_metadata_path(). + except Exception: + return '[could not detect]' + + return path + + def _get_metadata(self, name): + if self.has_metadata(name): + for line in self.get_metadata_lines(name): + yield line + + def _get_version(self): + lines = self._get_metadata(self.PKG_INFO) + version = _version_from_file(lines) + + return version + + def activate(self, path=None, replace=False): + """Ensure distribution is importable on `path` (default=sys.path)""" + if path is None: + path = sys.path + self.insert_on(path, replace=replace) + if path is sys.path: + fixup_namespace_packages(self.location) + for pkg in self._get_metadata('namespace_packages.txt'): + if pkg in sys.modules: + declare_namespace(pkg) + + 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 + ) + + if self.platform: + filename += '-' + self.platform + return filename + + def __repr__(self): + if self.location: + return "%s (%s)" % (self, self.location) + else: + return str(self) + + def __str__(self): + try: + version = getattr(self, 'version', None) + except ValueError: + version = None + version = version or "[unknown version]" + return "%s %s" % (self.project_name, version) + + def __getattr__(self, attr): + """Delegate all unrecognized public attributes to .metadata provider""" + if attr.startswith('_'): + raise AttributeError(attr) + return getattr(self._provider, attr) + + def __dir__(self): + return list( + set(super(Distribution, self).__dir__()) + | 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 + ) + + def as_requirement(self): + """Return a ``Requirement`` that matches this distribution exactly""" + if isinstance(self.parsed_version, packaging.version.Version): + spec = "%s==%s" % (self.project_name, self.parsed_version) + else: + spec = "%s===%s" % (self.project_name, self.parsed_version) + + return Requirement.parse(spec) + + def load_entry_point(self, group, name): + """Return the `name` entry point of `group` or raise ImportError""" + ep = self.get_entry_info(group, name) + if ep is None: + raise ImportError("Entry point %r not found" % ((group, name),)) + return ep.load() + + def get_entry_map(self, group=None): + """Return the entry point map for `group`, or the full entry map""" + try: + ep_map = self._ep_map + except AttributeError: + ep_map = self._ep_map = EntryPoint.parse_map( + self._get_metadata('entry_points.txt'), self + ) + if group is not None: + return ep_map.get(group, {}) + return ep_map + + def get_entry_info(self, group, name): + """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): + """Ensure self.location is on path + + If replace=False (default): + - If location is already in path anywhere, do nothing. + - Else: + - If it's an egg and its parent directory is on path, + insert just ahead of the parent. + - Else: add to the end of path. + If replace=True: + - If location is already on path anywhere (not eggs) + or higher priority than its parent (eggs) + do nothing. + - Else: + - If it's an egg and its parent directory is on path, + insert just ahead of the parent, + removing any lower-priority entries. + - Else: add it to the front of path. + """ + + loc = loc or self.location + if not loc: + return + + nloc = _normalize_cached(loc) + bdir = os.path.dirname(nloc) + npath = [(p and _normalize_cached(p) or p) for p in path] + + for p, item in enumerate(npath): + if item == nloc: + if replace: + break + else: + # don't modify path (even removing duplicates) if + # found and not replace + return + elif item == bdir and self.precedence == EGG_DIST: + # if it's an .egg, give it precedence over its directory + # UNLESS it's already been added to sys.path and replace=False + if (not replace) and nloc in npath[p:]: + return + if path is sys.path: + self.check_version_conflict() + path.insert(p, loc) + npath.insert(p, nloc) + break + else: + if path is sys.path: + self.check_version_conflict() + if replace: + path.insert(0, loc) + else: + path.append(loc) + return + + # p is the spot where we found or inserted loc; now remove duplicates + while True: + try: + np = npath.index(nloc, p + 1) + except ValueError: + break + else: + del npath[np], path[np] + # ha! + p = np + + return + + def check_version_conflict(self): + if self.key == 'setuptools': + # ignore the inevitable setuptools self-conflicts :( + return + + 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): + 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)): + continue + issue_warning( + "Module %s was already imported from %s, but %s is being added" + " to sys.path" % (modname, fn, self.location), + ) + + def has_version(self): + try: + self.version + except ValueError: + issue_warning("Unbuilt egg for " + repr(self)) + return False + return True + + def clone(self, **kw): + """Copy this distribution, substituting in any changed keyword args""" + names = 'project_name version py_version platform location precedence' + for attr in names.split(): + kw.setdefault(attr, getattr(self, attr, None)) + kw.setdefault('metadata', self._provider) + return self.__class__(**kw) + + @property + def extras(self): + return [dep for dep in self._dep_map if dep] + + +class EggInfoDistribution(Distribution): + def _reload_version(self): + """ + Packages installed by distutils (e.g. numpy or scipy), + which uses an old safe_version, and so + their version numbers can get mangled when + converted to filenames (e.g., 1.11.0.dev0+2329eae to + 1.11.0.dev0_2329eae). These distributions will not be + parsed properly + downstream by Distribution and safe_version, so + take an extra step and try to get the version number from + the metadata file itself instead of the filename. + """ + md_version = self._get_version() + if md_version: + self._version = md_version + return self + + +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*([,\)])") + + @property + def _parsed_pkg_info(self): + """Parse and cache metadata""" + try: + return self._pkg_info + except AttributeError: + metadata = self.get_metadata(self.PKG_INFO) + self._pkg_info = email.parser.Parser().parsestr(metadata) + return self._pkg_info + + @property + def _dep_map(self): + try: + return self.__dep_map + except AttributeError: + self.__dep_map = self._compute_dependencies() + return self.__dep_map + + def _compute_dependencies(self): + """Recompute this distribution's dependencies.""" + dm = self.__dep_map = {None: []} + + reqs = [] + # Including any condition expressions + for req in self._parsed_pkg_info.get_all('Requires-Dist') or []: + reqs.extend(parse_requirements(req)) + + def reqs_for_extra(extra): + for req in reqs: + if not req.marker or req.marker.evaluate({'extra': extra}): + yield req + + common = frozenset(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) + + return dm + + +_distributionImpl = { + '.egg': Distribution, + '.egg-info': EggInfoDistribution, + '.dist-info': DistInfoDistribution, +} + + +def issue_warning(*args, **kw): + level = 1 + g = globals() + try: + # find the first stack frame that is *not* code in + # the pkg_resources module, to use for the warning + while sys._getframe(level).f_globals is g: + level += 1 + except ValueError: + pass + 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` + + `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)) + + 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 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)) + 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.extras = tuple(map(safe_extra, self.extras)) + self.hashCmp = ( + self.key, + self.url, + self.specifier, + frozenset(self.extras), + str(self.marker) if self.marker else None, + ) + self.__hash = hash(self.hashCmp) + + def __eq__(self, other): + return ( + isinstance(other, Requirement) and + self.hashCmp == other.hashCmp + ) + + def __ne__(self, other): + return not self == other + + def __contains__(self, item): + if isinstance(item, Distribution): + if item.key != self.key: + return False + + item = item.version + + # Allow prereleases always in order to match the previous behavior of + # this method. In the future this should be smarter and follow PEP 440 + # more accurately. + return self.specifier.contains(item, prereleases=True) + + def __hash__(self): + return self.__hash + + def __repr__(self): + return "Requirement.parse(%r)" % str(self) + + @staticmethod + def parse(s): + req, = parse_requirements(s) + return req + + +def _always_object(classes): + """ + Ensure object appears in the mro even + for old-style classes. + """ + if object not in classes: + return classes + (object,) + return classes + + +def _find_adapter(registry, ob): + """Return an adapter factory for `ob` from `registry`""" + types = _always_object(inspect.getmro(getattr(ob, '__class__', type(ob)))) + for t in types: + if t in registry: + return registry[t] + + +def ensure_directory(path): + """Ensure that the parent directory of `path` exists""" + dirname = os.path.dirname(path) + py31compat.makedirs(dirname, exist_ok=True) + + +def _bypass_ensure_directory(path): + """Sandbox-bypassing version of ensure_directory()""" + if not WRITE_SUPPORT: + raise IOError('"os.mkdir" not supported on this platform.') + dirname, filename = split(path) + if dirname and filename and not isdir(dirname): + _bypass_ensure_directory(dirname) + try: + mkdir(dirname, 0o755) + except FileExistsError: + pass + + +def split_sections(s): + """Split a string or iterable thereof into (section, content) pairs + + Each ``section`` is a stripped version of the section header ("[section]") + and each ``content`` is a list of stripped lines excluding blank lines and + comment-only lines. If there are any such lines before the first section + header, they're returned in a first ``section`` of ``None``. + """ + section = None + content = [] + for line in yield_lines(s): + if line.startswith("["): + if line.endswith("]"): + if section or content: + yield section, content + section = line[1:-1].strip() + content = [] + else: + raise ValueError("Invalid section heading", line) + else: + content.append(line) + + # wrap up last segment + yield section, content + + +def _mkstemp(*args, **kw): + old_open = os.open + try: + # temporarily bypass sandboxing + os.open = os_open + return tempfile.mkstemp(*args, **kw) + finally: + # and then put it back + os.open = old_open + + +# Silence the PEP440Warning by default, so that end users don't get hit by it +# randomly just because they use pkg_resources. We want to append the rule +# because we want earlier uses of filterwarnings to take precedence over this +# one. +warnings.filterwarnings("ignore", category=PEP440Warning, append=True) + + +# from jaraco.functools 1.3 +def _call_aside(f, *args, **kwargs): + f(*args, **kwargs) + return f + + +@_call_aside +def _initialize(g=globals()): + "Set up global resource manager (deliberately not state-saved)" + manager = ResourceManager() + g['_manager'] = manager + g.update( + (name, getattr(manager, name)) + for name in dir(manager) + if not name.startswith('_') + ) + + +@_call_aside +def _initialize_master_working_set(): + """ + Prepare the master working set and make the ``require()`` + API available. + + This function has explicit effects on the global state + of pkg_resources. It is intended to be invoked once at + the initialization of this module. + + Invocation by other packages is unsupported and done + at their own risk. + """ + working_set = WorkingSet._build_master() + _declare_state('object', working_set=working_set) + + require = working_set.require + iter_entry_points = working_set.iter_entry_points + add_activation_listener = working_set.subscribe + run_script = working_set.run_script + # backward compatibility + run_main = run_script + # Activate all distributions already on sys.path with replace=False and + # 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 + ) + add_activation_listener( + lambda dist: dist.activate(replace=True), + existing=False, + ) + working_set.entries = [] + # 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/venv/lib/python3.8/site-packages/pkg_resources/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/pkg_resources/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..ddeb95c2e9e331d282f79bba0be23058dda23d2b GIT binary patch literal 100356 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 >V^A-WFxDTY$&6TM8h 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 literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pkg_resources/__pycache__/py31compat.cpython-38.pyc b/venv/lib/python3.8/site-packages/pkg_resources/__pycache__/py31compat.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..bbe8caa4f7e6503785ab028c3af6cc4c2a8202b0 GIT binary patch literal 600 zcmYjO&2AGh5T3EU$tFrdPly-bu!l4xZQ)W?2$ZTws33)(b}u1{UAo!L?smL^q)Is; z9t4iOlCPZd3LFsQAgYe#Z#?#R=9`(f?RFDbo;-dy*%bi4ym40~8&7%L4-6VKW)T0= z7~|F!vCu-xOwLuT5OhNay7mp@z^GZRe5vb3%<2jxq*$EjFoj$RK!`&V(mNC6%D}7< zH#CkQYHm0SoNkaYLMLsqJf1SGTk&)};pe>V3Bz@#g73J7ABgZC@_hxBNSpKw;YJ`_ z-(Mp=T8o*iZK24C6hfD5=0U&I-lL(ZsyQ{!nAI8j&^&L^qS30YTvH5w8Xrab0N8Bw}t~LIje!SNYeU;n!pui69@S+aiMPlO{ zu~Ggk=^iWE@!(q(;c?U?|3q~LZsN+inpswca`NA{A)I`DK5(s1hHO&g<0QW*Tqie1 n+gkz@cxPYJ9ccTI;o-c{i_9GPIa!}ML|&pLo2?o?_#@O`tEz?) literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pkg_resources/_vendor/__init__.py b/venv/lib/python3.8/site-packages/pkg_resources/_vendor/__init__.py new file mode 100644 index 0000000..e69de29 diff --git a/venv/lib/python3.8/site-packages/pkg_resources/_vendor/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/pkg_resources/_vendor/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..020243cb5a83bd38f45ced7b747476c3c5fdfa2a GIT binary patch literal 157 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 Yp6SB@NBY3UA^cLLCjHWX`lXuw57nVPd;kCd literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pkg_resources/_vendor/__pycache__/pyparsing.cpython-38.pyc b/venv/lib/python3.8/site-packages/pkg_resources/_vendor/__pycache__/pyparsing.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..26a703feff59e4e2b1fefa2b4131c6f87fc0b9d9 GIT binary patch literal 201634 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 z zd=ocuaRY(#H;0?$rCfk0u1L3T#_PIST6a}yn9>!MgF?)+z#JA?xt0v0dfklQ#!)Yt zc{7?DO?$CMy(}pMvTXC;Lr6B#Nkf(2Ci#w&eAXZdW@WQ+ zm`9Cx1u?r||0X2}9rp!qMvUKbzY=jnB9gOFeF@D35|upIB_kNYN3Oz=q;`mq}LEAk)+A@?HJoHWY|jq~>TvfYsD<}0qzC~XWw zuSH&qzGhAF_wR6Jkt?*!lrB{Zc*r4&Ojq71~B7p|(+QH`OMW?RCyfiez%5=@fC9Y-z^N4_-sXdK?D7}u|HJ2NPF_Nvd zQgPeRYD#J;2_k-+q`S=5$N2g|zJ$p>N=PQ?hXJi&tsL)&H5Av3>FPI$#5PlSYDpev^aer|%(YiZ4=AvZr?;TO~%9Z3MlUzi~mr-xm z9~6cVzc$#4uL2gzqVV$`I&Rq&D zp8@3_B7rEgybN9Niy|5I0mQ=Ym5>llbkJ_+AkhYRu2{Sm`1_Xp*64Rc5C>vXY6UCc zj}i$PuOAK}kqmud_wEkbf-UgJkjYzxJq&(1111G?E8cVnS_Ergh0t|>gfM=BC?Z8V zT9C?(ZXC9dV+%sW#M-$236$z$4hSdFb~$FU0cv0T<(kA<)OzqB&ku6S#?=KLb;uei z#$vjpm#)hfXe<092I0`nAV720l_;*BP{9Bz@>+^7e)d60fc}iNa?=8SosRKX<_ATA zNi5(P7iz-;C z&`@urm6YTunDnXjy#ISP#cg4y+xIPVCXm(h!Li&r+x6<*3m)>11%}=V*-Y38` ze}ZZwt<4SjX`U6k(q68Da#RV%pWkLCQsy*&3PJQMb1d>RWYM3+3+IH~uo!_Qa#0xf zrnhNpH`$mc8j&Q0>i^8W-q~6tPaj3$zbT^tycuH0Z2z5%xcuc``lg}Kbf(^Xp>o^ z#}>_bTMXMZZ-Bnh)3!EoBD!&TM1JGMCRz188UJxDo4#=8LY4~;)wv`RF^A4#t-t!+Mt0kqs6Ns$m)9| z==)eVy#>6!G1zm=&}?TU4}s00DUV(C!+i0u5N>DqQ2^-QJjh#(uYXW0?NCwnR&_+u zQNojR^5AGO@VoGCV77KFkzLaj72@1oK0uu(f|`dxS`Ku0#NuU1le*%$KgRM&CLZVO z1YbM`5K}bH*Jm``>#;EKi}};U?W*L2`Qn0bc@Bq=HFq1Q25yomAY0NZR z&n3*onhqrzX5rLF6;zhxVU3JRz#M zs9drDi^$UAAO#`g-^iqEOF&XlK7O9n-xyx}2Zxn#`9o}b9A5acQ?--(pZX%v2vTwyP z76!wh#QK53C`)D&*?t*IP>cT@&7=<}W1tUg3K;JIiYGxIP)VL_EE`*!z_?3I9es!~ zm;Vo*7)1VdC`%ffGUO=WAh`j{uX3TU#-wcU8S!ySTiJM)`B|4(N|=xT95JNfKN%gg zhSNjYOk!;`%Lj2os4u&7Ez6~{)`+w_lupL7+3Zku4RJ>c;DF)85O@LHjQnxyF9Bvh B+hYI# literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pkg_resources/_vendor/appdirs.py b/venv/lib/python3.8/site-packages/pkg_resources/_vendor/appdirs.py new file mode 100644 index 0000000..ae67001 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pkg_resources/_vendor/appdirs.py @@ -0,0 +1,608 @@ +#!/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 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_info__ = (1, 4, 3) +__version__ = '.'.join(map(str, __version_info__)) + + +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' +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 ".". + 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 + + for a discussion of issues. + + Typical user data directories are: + Mac OS X: ~/Library/Application Support/ + Unix: ~/.local/share/ # or in $XDG_DATA_HOME, if defined + Win XP (not roaming): C:\Documents and Settings\\Application Data\\ + Win XP (roaming): C:\Documents and Settings\\Local Settings\Application Data\\ + Win 7 (not roaming): C:\Users\\AppData\Local\\ + Win 7 (roaming): C:\Users\\AppData\Roaming\\ + + For Unix, we follow the XDG spec and support $XDG_DATA_HOME. + That means, by default "~/.local/share/". + """ + 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 ".". + 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/', + if XDG_DATA_DIRS is not set + + Typical site data directories are: + Mac OS X: /Library/Application Support/ + Unix: /usr/local/share/ or /usr/share/ + Win XP: C:\Documents and Settings\All Users\Application Data\\ + Vista: (Fail! "C:\ProgramData" is a hidden *system* directory on Vista.) + Win 7: C:\ProgramData\\ # 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.sep.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 ".". + 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 + + for a discussion of issues. + + Typical user config directories are: + Mac OS X: same as user_data_dir + Unix: ~/.config/ # 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/". + """ + 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 + + +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 ".". + 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/', if XDG_CONFIG_DIRS is not set + + Typical site config directories are: + Mac OS X: same as site_data_dir + Unix: /etc/xdg/ or $XDG_CONFIG_DIRS[i]/ 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 + # only first, if multipath is False + path = os.getenv('XDG_CONFIG_DIRS', '/etc/xdg') + 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.sep.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 ".". + 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/ + Unix: ~/.cache/ (XDG default) + Win XP: C:\Documents and Settings\\Local Settings\Application Data\\\Cache + Vista: C:\Users\\AppData\Local\\\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\\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")) + 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 ".". + 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 + + for a discussion of issues. + + Typical user state directories are: + Mac OS X: same as user_data_dir + Unix: ~/.local/state/ # or in $XDG_STATE_HOME, if defined + Win *: same as user_data_dir + + For Unix, we follow this Debian proposal + to extend the XDG spec and support $XDG_STATE_HOME. + + That means, by default "~/.local/state/". + """ + 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 ".". + 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/ + Unix: ~/.cache//log # or under $XDG_CACHE_HOME if defined + Win XP: C:\Documents and Settings\\Local Settings\Application Data\\\Logs + Vista: C:\Users\\AppData\Local\\\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 + # . + 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 + # . + 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 + # . + 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: + import win32com.shell + _get_win_folder = _get_win_folder_with_pywin32 + except ImportError: + 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 + + +#---- 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/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__about__.py b/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__about__.py new file mode 100644 index 0000000..95d330e --- /dev/null +++ b/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__about__.py @@ -0,0 +1,21 @@ +# 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__", "__summary__", "__uri__", "__version__", "__author__", + "__email__", "__license__", "__copyright__", +] + +__title__ = "packaging" +__summary__ = "Core utilities for Python packages" +__uri__ = "https://github.com/pypa/packaging" + +__version__ = "16.8" + +__author__ = "Donald Stufft and individual contributors" +__email__ = "donald@stufft.io" + +__license__ = "BSD or Apache License, Version 2.0" +__copyright__ = "Copyright 2014-2016 %s" % __author__ diff --git a/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__init__.py b/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__init__.py new file mode 100644 index 0000000..5ee6220 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__init__.py @@ -0,0 +1,14 @@ +# 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__, __copyright__, __email__, __license__, __summary__, __title__, + __uri__, __version__ +) + +__all__ = [ + "__title__", "__summary__", "__uri__", "__version__", "__author__", + "__email__", "__license__", "__copyright__", +] diff --git a/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/__about__.cpython-38.pyc b/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/__about__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..b89fa20133a87a97a39c5297c7f27e68abe31721 GIT binary patch literal 707 zcmYk4OK%e~5XZfbB%4LC)zHc<%(AyjCOfGS0B*o(E<@n)^=u3bNZvfqer z!#P(@d<6~&I{_7s{IkazkNqF}^KjThw!K`Qr{8^qemLj<7Fp-Yc6Dn32)q(iUgA}L z;#WZucnEw5AcPjQp#u?gH&GHoFKIzPX~Q7tz%Ys6BU{)k%M|1F{zOPtYm%Ef)6VY_qM0r!A^Scd%2ZV0; zVkA4RZmD#8t}i}~f$Vu{byr^(QjAvfAcD_7cQMlx^+EnMBw($++_+)~@26BvstVjH;MyX$@RH s)F!s4ueq^xpNZW*dQ)*QC4K8|rp6Xe10Vf0?=b!jTcKyox8~^m0mRVFf&c&j literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..1ea67109d3944fcbcf690457e5db482a839c3f69 GIT binary patch literal 545 zcmYk4O>WyT5QQnp)~}T!K(0_AUN}OF{%ne(2Pm>>yWwWQh_pxG+O}qRK7M#Dl9aJuBwn5p#TR_$?+D3cVwg>MVpE>ljAsdx zsm#pEuKC*LJhufeY{^So@ygb`wheFWhHucfl53gELYA_UwQPoxw{r81ZQCd8%(mI` zO5DxP#GpXi$@#F9QXloK-MCy#UXKCxaqI)?r-UlXr3Mf&9GnMOT7ce7C$EP?Kv@AO zE40Da2EgcEjk7w7Ia(|H>1+x*82VlSM6b_=qw+Krz&AL@(}Mhl&=PV2t;JV_0&%;& zpe*|sqQ_<)7s-4^SRp8jxN{L>or|gDMTh79&y)TSp*X@|_($e1$xZnEwF`FYCOz%q zIEnsV$=%O`QfBw&-NXBbw|mn~_XBt}yXbp0cW_jrbiO0681y)F0D9Dz<7PT7DoUag9>2;p6e;5A-ynp@zCMAqt literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/_compat.cpython-38.pyc b/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/_compat.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..115cd2f9412ffe0a82286272f654e5b6401e23a1 GIT binary patch literal 981 zcmah{OKTKC5bnq9?quC;1cTz^upSilkR6P#O9+C32O$We;2<=e>E2|_ywcs1upyoj zNPdPM^OySSDSyF}RlOl@P8L*6RZaI-Usd(z<>fvBdHw2%{Kg6SjlrTY2;P9&FJKf= zv>+u-X~|Mn@|07|u_8(%9ewX8a-S%^$I|X~6hYL}J@Zb-Q<^SSUERm8>ZtB1NpC6k ziHv)ffKA5SugGm%7p>DGFPqvpAFKQzw|QOpVPo>jiD_G94&tp#Bz6gmNk;MZm0+R^ z+5@#u!MrDDVo;s+>a36;AH-M zNL<+@P2Q}vRU@-Kt=0~AwJz44z1V-bzdkLJW^YFrZR^%#+9u*aSE@D%o|QX!wUdaf zE*t44&CK_NsPv%_kB}d(h0vq%e_Nbf-P!{3G5Ek-2;Uc?tW{f}KM-QSmBsvzxed61 zyulI7y%q5M()H9HLKq0d)U4vK6{qnXNi!2+bK%yQ`N+*09T3Od3=wV_4c=KO5zvP> z8^I$sET?yun|lzA2S|F_y4C<`gZ&$P3I0*FZs%ezrcx^OQLezWuVoG*)uB?9fm^GEi#JR#rlVY21mVGnxv z4hBY;=8>M((t3JJ?-?yaBOeIUnQ=~-!E-~SmFM{(Y31Q_R&Tx1nig}KC**$T`HY!$3r zi>;4-+x1;};%ESpG+bkU3q3^VFb%ZzrU2)W5gBQ5F63TYnDD5EpPw4C7c>Gls7HQa zJ4c+=zjitI>QA2yb_UyRuMr$|sNi8g5)Ka=^qBjsFB+(8cU-^IprI6zBO}n+3Ql5+ zf_5M%EuszR3Zk7ZC)REy(kZhIP*i4@VIhgs&d5+3g83t@Inv`?*ABaJ4v!WE(D;1? zfj|h08kFMpG}y7!Q3inuHe646Yos^dtHVdSus|Ws_hpxh>v$%mo}{z_8VOou;*uzv zk0q+GeSGrrwAW`5rdM31bP(CzSR#;c1*WxF#bFHxjEUI50bM8V;eZ#M zD2mIhRaAo&8e-mBx@BDbDY*lpD-BC=5Bh(kOtA^)&vyLr{iTB1gOd%ZQry5$U z7)3kXxE`v%pgL8f0vRkV&MGQT=0M(*=4NNHihW}O>UPTQZpd*n%SGka_BGpd^=^j|n?<=FrL literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/markers.cpython-38.pyc b/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/markers.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..c0839d1a6d8763def637530b9fa04a339932e1c9 GIT binary patch literal 8919 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 WU(rS;9xaUE_bb|V9ON1;-1FbA$=hK7 literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/utils.cpython-38.pyc b/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/utils.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..d24880bccb4791e34fc337ab8934a94bee83dcfb GIT binary patch literal 466 zcmY*Vy-ve05VoB(jSA&Q@CpnON+T+M7KD(PSh^sVAY`Sn8>~9Ev6B`mMjoUc7lHzac=e;G++q{d;=@AL@VH=&}a=)r*weJLP){Ng0lt1 znpX712Bsa`4wrMP6KF$G)btZ*fBX72YigA#rqWiZqMTBa&Yvjd>B;Hy+4FG1Gc~Q; z7$aLl%f9D#%?;S{)cCTNq~-L=HyY19L~+myegFudb?*QG literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/version.cpython-38.pyc b/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/version.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..db38c68b84ad368670118b271503aa66d5512e43 GIT binary patch literal 10634 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 literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/_compat.py b/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/_compat.py new file mode 100644 index 0000000..210bb80 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/_compat.py @@ -0,0 +1,30 @@ +# 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 + + +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): + """ + 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): + def __new__(cls, name, this_bases, d): + return meta(name, bases, d) + return type.__new__(metaclass, 'temporary_class', (), {}) diff --git a/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/_structures.py b/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/_structures.py new file mode 100644 index 0000000..ccc2786 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/_structures.py @@ -0,0 +1,68 @@ +# 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 Infinity(object): + + def __repr__(self): + return "Infinity" + + def __hash__(self): + return hash(repr(self)) + + def __lt__(self, other): + return False + + def __le__(self, other): + return False + + def __eq__(self, other): + return isinstance(other, self.__class__) + + def __ne__(self, other): + return not isinstance(other, self.__class__) + + def __gt__(self, other): + return True + + def __ge__(self, other): + return True + + def __neg__(self): + return NegativeInfinity + +Infinity = Infinity() + + +class NegativeInfinity(object): + + def __repr__(self): + return "-Infinity" + + def __hash__(self): + return hash(repr(self)) + + def __lt__(self, other): + return True + + def __le__(self, other): + return True + + def __eq__(self, other): + return isinstance(other, self.__class__) + + def __ne__(self, other): + return not isinstance(other, self.__class__) + + def __gt__(self, other): + return False + + def __ge__(self, other): + return False + + def __neg__(self): + return Infinity + +NegativeInfinity = NegativeInfinity() diff --git a/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/markers.py b/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/markers.py new file mode 100644 index 0000000..892e578 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/markers.py @@ -0,0 +1,301 @@ +# 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 pkg_resources.extern.pyparsing import ParseException, ParseResults, stringStart, stringEnd +from pkg_resources.extern.pyparsing import ZeroOrMore, Group, Forward, QuotedString +from pkg_resources.extern.pyparsing import Literal as L # noqa + +from ._compat import string_types +from .specifiers import Specifier, InvalidSpecifier + + +__all__ = [ + "InvalidMarker", "UndefinedComparison", "UndefinedEnvironmentName", + "Marker", "default_environment", +] + + +class InvalidMarker(ValueError): + """ + An invalid marker was found, users should refer to PEP 508. + """ + + +class UndefinedComparison(ValueError): + """ + An invalid operation was attempted on a value that doesn't support it. + """ + + +class UndefinedEnvironmentName(ValueError): + """ + A name was attempted to be used that does not exist inside of the + environment. + """ + + +class Node(object): + + def __init__(self, value): + self.value = value + + def __str__(self): + return str(self.value) + + def __repr__(self): + return "<{0}({1!r})>".format(self.__class__.__name__, str(self)) + + def serialize(self): + raise NotImplementedError + + +class Variable(Node): + + def serialize(self): + return str(self) + + +class Value(Node): + + def serialize(self): + return '"{0}"'.format(self) + + +class Op(Node): + + def serialize(self): + return str(self) + + +VARIABLE = ( + L("implementation_version") | + L("platform_python_implementation") | + L("implementation_name") | + L("python_full_version") | + L("platform_release") | + L("platform_version") | + L("platform_machine") | + L("platform_system") | + L("python_version") | + L("sys_platform") | + L("os_name") | + L("os.name") | # PEP-345 + L("sys.platform") | # PEP-345 + L("platform.version") | # PEP-345 + L("platform.machine") | # PEP-345 + L("platform.python_implementation") | # PEP-345 + L("python_implementation") | # undocumented setuptools legacy + L("extra") +) +ALIASES = { + 'os.name': 'os_name', + 'sys.platform': 'sys_platform', + 'platform.version': 'platform_version', + 'platform.machine': 'platform_machine', + 'platform.python_implementation': 'platform_python_implementation', + 'python_implementation': 'platform_python_implementation' +} +VARIABLE.setParseAction(lambda s, l, t: Variable(ALIASES.get(t[0], t[0]))) + +VERSION_CMP = ( + L("===") | + L("==") | + L(">=") | + L("<=") | + L("!=") | + L("~=") | + L(">") | + L("<") +) + +MARKER_OP = VERSION_CMP | L("not in") | L("in") +MARKER_OP.setParseAction(lambda s, l, t: Op(t[0])) + +MARKER_VALUE = QuotedString("'") | QuotedString('"') +MARKER_VALUE.setParseAction(lambda s, l, t: Value(t[0])) + +BOOLOP = L("and") | L("or") + +MARKER_VAR = VARIABLE | MARKER_VALUE + +MARKER_ITEM = Group(MARKER_VAR + MARKER_OP + MARKER_VAR) +MARKER_ITEM.setParseAction(lambda s, l, t: tuple(t[0])) + +LPAREN = L("(").suppress() +RPAREN = L(")").suppress() + +MARKER_EXPR = Forward() +MARKER_ATOM = MARKER_ITEM | Group(LPAREN + MARKER_EXPR + RPAREN) +MARKER_EXPR << MARKER_ATOM + ZeroOrMore(BOOLOP + MARKER_EXPR) + +MARKER = stringStart + MARKER_EXPR + stringEnd + + +def _coerce_parse_result(results): + if isinstance(results, ParseResults): + return [_coerce_parse_result(i) for i in results] + else: + return results + + +def _format_marker(marker, first=True): + assert isinstance(marker, (list, tuple, string_types)) + + # 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 + # the rest of this function so that we don't get extraneous () on the + # outside. + if (isinstance(marker, list) and len(marker) == 1 and + isinstance(marker[0], (list, tuple))): + return _format_marker(marker[0]) + + if isinstance(marker, list): + inner = (_format_marker(m, first=False) for m in marker) + if first: + return " ".join(inner) + else: + return "(" + " ".join(inner) + ")" + elif isinstance(marker, tuple): + return " ".join([m.serialize() for m in marker]) + else: + return marker + + +_operators = { + "in": lambda lhs, rhs: lhs in rhs, + "not in": lambda lhs, rhs: lhs not in rhs, + "<": operator.lt, + "<=": operator.le, + "==": operator.eq, + "!=": operator.ne, + ">=": operator.ge, + ">": operator.gt, +} + + +def _eval_op(lhs, op, rhs): + try: + spec = Specifier("".join([op.serialize(), rhs])) + except InvalidSpecifier: + pass + else: + return spec.contains(lhs) + + oper = _operators.get(op.serialize()) + if oper is None: + raise UndefinedComparison( + "Undefined {0!r} on {1!r} and {2!r}.".format(op, lhs, rhs) + ) + + return oper(lhs, rhs) + + +_undefined = object() + + +def _get_env(environment, name): + value = environment.get(name, _undefined) + + if value is _undefined: + raise UndefinedEnvironmentName( + "{0!r} does not exist in evaluation environment.".format(name) + ) + + return value + + +def _evaluate_markers(markers, environment): + groups = [[]] + + for marker in markers: + assert isinstance(marker, (list, tuple, string_types)) + + if isinstance(marker, list): + groups[-1].append(_evaluate_markers(marker, environment)) + elif isinstance(marker, tuple): + lhs, op, rhs = marker + + if isinstance(lhs, Variable): + lhs_value = _get_env(environment, lhs.value) + rhs_value = rhs.value + else: + lhs_value = lhs.value + rhs_value = _get_env(environment, rhs.value) + + groups[-1].append(_eval_op(lhs_value, op, rhs_value)) + else: + assert marker in ["and", "or"] + if marker == "or": + groups.append([]) + + return any(all(item) for item in groups) + + +def format_full_version(info): + version = '{0.major}.{0.minor}.{0.micro}'.format(info) + kind = info.releaselevel + if kind != 'final': + version += kind[0] + str(info.serial) + return version + + +def default_environment(): + if hasattr(sys, 'implementation'): + iver = format_full_version(sys.implementation.version) + implementation_name = sys.implementation.name + else: + iver = '0' + implementation_name = '' + + return { + "implementation_name": implementation_name, + "implementation_version": iver, + "os_name": os.name, + "platform_machine": platform.machine(), + "platform_release": platform.release(), + "platform_system": platform.system(), + "platform_version": platform.version(), + "python_full_version": platform.python_version(), + "platform_python_implementation": platform.python_implementation(), + "python_version": platform.python_version()[:3], + "sys_platform": sys.platform, + } + + +class Marker(object): + + def __init__(self, marker): + 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(err_str) + + def __str__(self): + return _format_marker(self._markers) + + def __repr__(self): + return "".format(str(self)) + + def evaluate(self, environment=None): + """Evaluate a marker. + + Return the boolean from evaluating the given marker against the + environment. environment is an optional argument to override all or + part of the determined environment. + + The environment is determined from the current Python process. + """ + current_environment = default_environment() + if environment is not None: + current_environment.update(environment) + + return _evaluate_markers(self._markers, current_environment) diff --git a/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/requirements.py b/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/requirements.py new file mode 100644 index 0000000..0c8c4a3 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/requirements.py @@ -0,0 +1,127 @@ +# 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 string +import re + +from pkg_resources.extern.pyparsing import stringStart, stringEnd, originalTextFor, ParseException +from pkg_resources.extern.pyparsing import ZeroOrMore, Word, Optional, Regex, Combine +from pkg_resources.extern.pyparsing import Literal as L # noqa +from pkg_resources.extern.six.moves.urllib import parse as urlparse + +from .markers import MARKER_EXPR, Marker +from .specifiers import LegacySpecifier, Specifier, SpecifierSet + + +class InvalidRequirement(ValueError): + """ + An invalid requirement was found, users should refer to PEP 508. + """ + + +ALPHANUM = Word(string.ascii_letters + string.digits) + +LBRACKET = L("[").suppress() +RBRACKET = L("]").suppress() +LPAREN = L("(").suppress() +RPAREN = L(")").suppress() +COMMA = L(",").suppress() +SEMICOLON = L(";").suppress() +AT = L("@").suppress() + +PUNCTUATION = Word("-_.") +IDENTIFIER_END = ALPHANUM | (ZeroOrMore(PUNCTUATION) + ALPHANUM) +IDENTIFIER = Combine(ALPHANUM + ZeroOrMore(IDENTIFIER_END)) + +NAME = IDENTIFIER("name") +EXTRA = IDENTIFIER + +URI = Regex(r'[^ ]+')("url") +URL = (AT + URI) + +EXTRAS_LIST = EXTRA + ZeroOrMore(COMMA + EXTRA) +EXTRAS = (LBRACKET + Optional(EXTRAS_LIST) + RBRACKET)("extras") + +VERSION_PEP440 = Regex(Specifier._regex_str, re.VERBOSE | re.IGNORECASE) +VERSION_LEGACY = Regex(LegacySpecifier._regex_str, re.VERBOSE | re.IGNORECASE) + +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.setParseAction(lambda s, l, t: t._raw_spec or '') + +VERSION_SPEC = originalTextFor(_VERSION_SPEC)("specifier") +VERSION_SPEC.setParseAction(lambda s, l, t: t[1]) + +MARKER_EXPR = originalTextFor(MARKER_EXPR())("marker") +MARKER_EXPR.setParseAction( + lambda s, l, t: Marker(s[t._original_start:t._original_end]) +) +MARKER_SEPERATOR = SEMICOLON +MARKER = MARKER_SEPERATOR + MARKER_EXPR + +VERSION_AND_MARKER = VERSION_SPEC + Optional(MARKER) +URL_AND_MARKER = URL + Optional(MARKER) + +NAMED_REQUIREMENT = \ + NAME + Optional(EXTRAS) + (URL_AND_MARKER | VERSION_AND_MARKER) + +REQUIREMENT = stringStart + NAMED_REQUIREMENT + stringEnd + + +class Requirement(object): + """Parse a requirement. + + Parse a given requirement string into its parts, such as name, specifier, + URL, and extras. Raises InvalidRequirement on a badly-formed requirement + string. + """ + + # TODO: Can we test whether something is contained within a requirement? + # If so how do we do that? Do we need to test against the _name_ of + # 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): + try: + req = REQUIREMENT.parseString(requirement_string) + except ParseException as e: + raise InvalidRequirement( + "Invalid requirement, parse error at \"{0!r}\"".format( + requirement_string[e.loc:e.loc + 8])) + + self.name = req.name + if req.url: + parsed_url = urlparse.urlparse(req.url) + if not (parsed_url.scheme and parsed_url.netloc) or ( + not parsed_url.scheme and not parsed_url.netloc): + raise InvalidRequirement("Invalid URL given") + self.url = req.url + else: + self.url = None + self.extras = set(req.extras.asList() if req.extras else []) + self.specifier = SpecifierSet(req.specifier) + self.marker = req.marker if req.marker else None + + def __str__(self): + parts = [self.name] + + if self.extras: + parts.append("[{0}]".format(",".join(sorted(self.extras)))) + + if self.specifier: + parts.append(str(self.specifier)) + + if self.url: + parts.append("@ {0}".format(self.url)) + + if self.marker: + parts.append("; {0}".format(self.marker)) + + return "".join(parts) + + def __repr__(self): + return "".format(str(self)) diff --git a/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/specifiers.py b/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/specifiers.py new file mode 100644 index 0000000..7f5a76c --- /dev/null +++ b/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/specifiers.py @@ -0,0 +1,774 @@ +# 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 + +from ._compat import string_types, with_metaclass +from .version import Version, LegacyVersion, parse + + +class InvalidSpecifier(ValueError): + """ + An invalid specifier was found, users should refer to PEP 440. + """ + + +class BaseSpecifier(with_metaclass(abc.ABCMeta, object)): + + @abc.abstractmethod + def __str__(self): + """ + Returns the str representation of this Specifier like object. This + should be representative of the Specifier itself. + """ + + @abc.abstractmethod + def __hash__(self): + """ + Returns a hash value for this Specifier like object. + """ + + @abc.abstractmethod + def __eq__(self, other): + """ + Returns a boolean representing whether or not the two Specifier like + objects are equal. + """ + + @abc.abstractmethod + def __ne__(self, other): + """ + Returns a boolean representing whether or not the two Specifier like + objects are not equal. + """ + + @abc.abstractproperty + def prereleases(self): + """ + Returns whether or not pre-releases as a whole are allowed by this + specifier. + """ + + @prereleases.setter + def prereleases(self, value): + """ + Sets whether or not pre-releases as a whole are allowed by this + specifier. + """ + + @abc.abstractmethod + def contains(self, item, prereleases=None): + """ + Determines if the given item is contained within this specifier. + """ + + @abc.abstractmethod + def filter(self, iterable, prereleases=None): + """ + Takes an iterable of items and filters them so that only items which + are contained within this specifier are allowed in it. + """ + + +class _IndividualSpecifier(BaseSpecifier): + + _operators = {} + + def __init__(self, spec="", prereleases=None): + match = self._regex.search(spec) + if not match: + raise InvalidSpecifier("Invalid specifier: '{0}'".format(spec)) + + self._spec = ( + match.group("operator").strip(), + match.group("version").strip(), + ) + + # Store whether or not this Specifier should accept prereleases + self._prereleases = prereleases + + def __repr__(self): + pre = ( + ", prereleases={0!r}".format(self.prereleases) + if self._prereleases is not None + else "" + ) + + return "<{0}({1!r}{2})>".format( + self.__class__.__name__, + str(self), + pre, + ) + + def __str__(self): + return "{0}{1}".format(*self._spec) + + def __hash__(self): + return hash(self._spec) + + def __eq__(self, other): + if isinstance(other, string_types): + try: + other = self.__class__(other) + except InvalidSpecifier: + return NotImplemented + elif not isinstance(other, self.__class__): + return NotImplemented + + return self._spec == other._spec + + def __ne__(self, other): + if isinstance(other, string_types): + try: + other = self.__class__(other) + except InvalidSpecifier: + return NotImplemented + elif not isinstance(other, self.__class__): + return NotImplemented + + return self._spec != other._spec + + def _get_operator(self, op): + return getattr(self, "_compare_{0}".format(self._operators[op])) + + def _coerce_version(self, version): + if not isinstance(version, (LegacyVersion, Version)): + version = parse(version) + return version + + @property + def operator(self): + return self._spec[0] + + @property + def version(self): + return self._spec[1] + + @property + def prereleases(self): + return self._prereleases + + @prereleases.setter + def prereleases(self, value): + self._prereleases = value + + def __contains__(self, item): + return self.contains(item) + + def contains(self, item, prereleases=None): + # Determine if prereleases are to be allowed or not. + if prereleases is None: + prereleases = self.prereleases + + # Normalize item to a Version or LegacyVersion, this allows us to have + # a shortcut for ``"2.0" in Specifier(">=2") + item = self._coerce_version(item) + + # Determine if we should be supporting prereleases in this specifier + # or not, if we do not support prereleases than we can short circuit + # logic if this version is a prereleases. + if item.is_prerelease and not prereleases: + return False + + # Actually do the comparison to determine if this item is contained + # within this Specifier or not. + return self._get_operator(self.operator)(item, self.version) + + def filter(self, iterable, prereleases=None): + yielded = False + found_prereleases = [] + + kw = {"prereleases": prereleases if prereleases is not None else True} + + # Attempt to iterate over all the values in the iterable and if any of + # them match, yield them. + for version in iterable: + parsed_version = self._coerce_version(version) + + 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 + # else matches this specifier. + if (parsed_version.is_prerelease and not + (prereleases or self.prereleases)): + found_prereleases.append(version) + # Either this is not a prerelease, or we should have been + # accepting prereleases from the begining. + else: + yielded = True + yield version + + # Now that we've iterated over everything, determine if we've yielded + # any values, and if we have not and we have any prereleases stored up + # then we will go ahead and yield the prereleases. + if not yielded and found_prereleases: + for version in found_prereleases: + yield version + + +class LegacySpecifier(_IndividualSpecifier): + + _regex_str = ( + r""" + (?P(==|!=|<=|>=|<|>)) + \s* + (?P + [^,;\s)]* # Since this is a "legacy" specifier, and the version + # string can be just about anything, we match everything + # except for whitespace, a semi-colon for marker support, + # a closing paren since versions can be enclosed in + # them, and a comma since it's a version separator. + ) + """ + ) + + _regex = re.compile( + r"^\s*" + _regex_str + r"\s*$", re.VERBOSE | re.IGNORECASE) + + _operators = { + "==": "equal", + "!=": "not_equal", + "<=": "less_than_equal", + ">=": "greater_than_equal", + "<": "less_than", + ">": "greater_than", + } + + def _coerce_version(self, version): + if not isinstance(version, LegacyVersion): + version = LegacyVersion(str(version)) + return version + + def _compare_equal(self, prospective, spec): + return prospective == self._coerce_version(spec) + + def _compare_not_equal(self, prospective, spec): + return prospective != self._coerce_version(spec) + + def _compare_less_than_equal(self, prospective, spec): + return prospective <= self._coerce_version(spec) + + def _compare_greater_than_equal(self, prospective, spec): + return prospective >= self._coerce_version(spec) + + def _compare_less_than(self, prospective, spec): + return prospective < self._coerce_version(spec) + + def _compare_greater_than(self, prospective, spec): + return prospective > self._coerce_version(spec) + + +def _require_version_compare(fn): + @functools.wraps(fn) + def wrapped(self, prospective, spec): + if not isinstance(prospective, Version): + return False + return fn(self, prospective, spec) + return wrapped + + +class Specifier(_IndividualSpecifier): + + _regex_str = ( + r""" + (?P(~=|==|!=|<=|>=|<|>|===)) + (?P + (?: + # The identity operators allow for an escape hatch that will + # do an exact string match of the version you wish to install. + # This will not be parsed by PEP 440 and we cannot determine + # any semantic meaning from it. This operator is discouraged + # but included entirely as an escape hatch. + (?<====) # Only match for the identity operator + \s* + [^\s]* # We just match everything, except for whitespace + # since we are only testing for strict identity. + ) + | + (?: + # The (non)equality operators allow for wild card and local + # versions to be specified so we have to define these two + # operators separately to enable that. + (?<===|!=) # Only match for equals and not equals + + \s* + v? + (?:[0-9]+!)? # epoch + [0-9]+(?:\.[0-9]+)* # release + (?: # pre release + [-_\.]? + (a|b|c|rc|alpha|beta|pre|preview) + [-_\.]? + [0-9]* + )? + (?: # post release + (?:-[0-9]+)|(?:[-_\.]?(post|rev|r)[-_\.]?[0-9]*) + )? + + # You cannot use a wild card and a dev or local version + # together so group them with a | and make them optional. + (?: + (?:[-_\.]?dev[-_\.]?[0-9]*)? # dev release + (?:\+[a-z0-9]+(?:[-_\.][a-z0-9]+)*)? # local + | + \.\* # Wild card syntax of .* + )? + ) + | + (?: + # The compatible operator requires at least two digits in the + # release segment. + (?<=~=) # Only match for the compatible operator + + \s* + v? + (?:[0-9]+!)? # epoch + [0-9]+(?:\.[0-9]+)+ # release (We have a + instead of a *) + (?: # pre release + [-_\.]? + (a|b|c|rc|alpha|beta|pre|preview) + [-_\.]? + [0-9]* + )? + (?: # post release + (?:-[0-9]+)|(?:[-_\.]?(post|rev|r)[-_\.]?[0-9]*) + )? + (?:[-_\.]?dev[-_\.]?[0-9]*)? # dev release + ) + | + (?: + # All other operators only allow a sub set of what the + # (non)equality operators do. Specifically they do not allow + # local versions to be specified nor do they allow the prefix + # matching wild cards. + (?=": "greater_than_equal", + "<": "less_than", + ">": "greater_than", + "===": "arbitrary", + } + + @_require_version_compare + def _compare_compatible(self, prospective, spec): + # Compatible releases have an equivalent combination of >= and ==. That + # is that ~=2.2 is equivalent to >=2.2,==2.*. This allows us to + # implement this in terms of the other specifiers instead of + # implementing it ourselves. The only thing we need to do is construct + # 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. + prefix = ".".join( + list( + itertools.takewhile( + lambda x: (not x.startswith("post") and not + x.startswith("dev")), + _version_split(spec), + ) + )[:-1] + ) + + # Add the prefix notation to the end of our string + prefix += ".*" + + return (self._get_operator(">=")(prospective, spec) and + self._get_operator("==")(prospective, prefix)) + + @_require_version_compare + def _compare_equal(self, prospective, spec): + # We need special logic to handle prefix matching + if spec.endswith(".*"): + # In the case of prefix matching we want to ignore local segment. + prospective = Version(prospective.public) + # Split the spec out by dots, and pretend that there is an implicit + # dot in between a release segment and a pre-release segment. + spec = _version_split(spec[:-2]) # Remove the trailing .* + + # Split the prospective version out by dots, and pretend that there + # is an implicit dot in between a release segment and a pre-release + # segment. + prospective = _version_split(str(prospective)) + + # Shorten the prospective version to be the same length as the spec + # so that we can determine if the specifier is a prefix of the + # prospective version or not. + prospective = prospective[:len(spec)] + + # Pad out our two sides with zeros so that they both equal the same + # length. + spec, prospective = _pad_version(spec, prospective) + else: + # Convert our spec string into a Version + spec = Version(spec) + + # If the specifier does not have a local segment, then we want to + # act as if the prospective version also does not have a local + # segment. + if not spec.local: + prospective = Version(prospective.public) + + return prospective == spec + + @_require_version_compare + def _compare_not_equal(self, prospective, spec): + return not self._compare_equal(prospective, spec) + + @_require_version_compare + def _compare_less_than_equal(self, prospective, spec): + return prospective <= Version(spec) + + @_require_version_compare + def _compare_greater_than_equal(self, prospective, spec): + return prospective >= Version(spec) + + @_require_version_compare + def _compare_less_than(self, prospective, spec): + # Convert our spec to a Version instance, since we'll want to work with + # it as a version. + spec = Version(spec) + + # Check to see if the prospective version is less than the spec + # version. If it's not we can short circuit and just return False now + # instead of doing extra unneeded work. + if not prospective < spec: + return False + + # This special case is here so that, unless the specifier itself + # includes is a pre-release version, that we do not accept pre-release + # versions for the version mentioned in the specifier (e.g. <3.1 should + # not match 3.1.dev0, but should match 3.0.dev0). + if not spec.is_prerelease and prospective.is_prerelease: + if Version(prospective.base_version) == Version(spec.base_version): + return False + + # If we've gotten to here, it means that prospective version is both + # less than the spec version *and* it's not a pre-release of the same + # version in the spec. + return True + + @_require_version_compare + def _compare_greater_than(self, prospective, spec): + # Convert our spec to a Version instance, since we'll want to work with + # it as a version. + spec = Version(spec) + + # Check to see if the prospective version is greater than the spec + # version. If it's not we can short circuit and just return False now + # instead of doing extra unneeded work. + if not prospective > spec: + return False + + # This special case is here so that, unless the specifier itself + # includes is a post-release version, that we do not accept + # post-release versions for the version mentioned in the specifier + # (e.g. >3.1 should not match 3.0.post0, but should match 3.2.post0). + if not spec.is_postrelease and prospective.is_postrelease: + if Version(prospective.base_version) == Version(spec.base_version): + return False + + # Ensure that we do not allow a local version of the version mentioned + # in the specifier, which is techincally greater than, to match. + if prospective.local is not None: + if Version(prospective.base_version) == Version(spec.base_version): + return False + + # If we've gotten to here, it means that prospective version is both + # greater than the spec version *and* it's not a pre-release of the + # same version in the spec. + return True + + def _compare_arbitrary(self, prospective, spec): + return str(prospective).lower() == str(spec).lower() + + @property + def prereleases(self): + # If there is an explicit prereleases set for this, then we'll just + # blindly use that. + if self._prereleases is not None: + return self._prereleases + + # Look at all of our specifiers and determine if they are inclusive + # operators, and if they are if they are including an explicit + # prerelease. + operator, version = self._spec + if operator in ["==", ">=", "<=", "~=", "==="]: + # The == specifier can include a trailing .*, if it does we + # want to remove before parsing. + if operator == "==" and version.endswith(".*"): + version = version[:-2] + + # Parse the version, and if it is a pre-release than this + # specifier allows pre-releases. + if parse(version).is_prerelease: + return True + + return False + + @prereleases.setter + def prereleases(self, value): + self._prereleases = value + + +_prefix_regex = re.compile(r"^([0-9]+)((?:a|b|c|rc)[0-9]+)$") + + +def _version_split(version): + result = [] + for item in version.split("."): + match = _prefix_regex.search(item) + if match: + result.extend(match.groups()) + else: + result.append(item) + return result + + +def _pad_version(left, right): + left_split, right_split = [], [] + + # Get the release segment of our versions + left_split.append(list(itertools.takewhile(lambda x: x.isdigit(), left))) + right_split.append(list(itertools.takewhile(lambda x: x.isdigit(), right))) + + # Get the rest of our versions + left_split.append(left[len(left_split[0]):]) + right_split.append(right[len(right_split[0]):]) + + # Insert our padding + left_split.insert( + 1, + ["0"] * max(0, len(right_split[0]) - len(left_split[0])), + ) + right_split.insert( + 1, + ["0"] * max(0, len(left_split[0]) - len(right_split[0])), + ) + + return ( + list(itertools.chain(*left_split)), + list(itertools.chain(*right_split)), + ) + + +class SpecifierSet(BaseSpecifier): + + def __init__(self, specifiers="", prereleases=None): + # Split on , to break each indidivual specifier into it's own item, and + # strip each item to remove leading/trailing whitespace. + specifiers = [s.strip() for s in specifiers.split(",") if s.strip()] + + # Parsed each individual specifier, attempting first to make it a + # Specifier and falling back to a LegacySpecifier. + parsed = set() + for specifier in specifiers: + try: + parsed.add(Specifier(specifier)) + except InvalidSpecifier: + parsed.add(LegacySpecifier(specifier)) + + # Turn our parsed specifiers into a frozen set and save them for later. + self._specs = frozenset(parsed) + + # Store our prereleases value so we can use it later to determine if + # we accept prereleases or not. + self._prereleases = prereleases + + def __repr__(self): + pre = ( + ", prereleases={0!r}".format(self.prereleases) + if self._prereleases is not None + else "" + ) + + return "".format(str(self), pre) + + def __str__(self): + return ",".join(sorted(str(s) for s in self._specs)) + + def __hash__(self): + return hash(self._specs) + + def __and__(self, other): + if isinstance(other, string_types): + other = SpecifierSet(other) + elif not isinstance(other, SpecifierSet): + return NotImplemented + + specifier = SpecifierSet() + specifier._specs = frozenset(self._specs | other._specs) + + if self._prereleases is None and other._prereleases is not None: + specifier._prereleases = other._prereleases + elif self._prereleases is not None and other._prereleases is None: + specifier._prereleases = self._prereleases + elif self._prereleases == other._prereleases: + specifier._prereleases = self._prereleases + else: + raise ValueError( + "Cannot combine SpecifierSets with True and False prerelease " + "overrides." + ) + + return specifier + + def __eq__(self, other): + if isinstance(other, string_types): + other = SpecifierSet(other) + elif isinstance(other, _IndividualSpecifier): + other = SpecifierSet(str(other)) + elif not isinstance(other, SpecifierSet): + return NotImplemented + + return self._specs == other._specs + + def __ne__(self, other): + if isinstance(other, string_types): + other = SpecifierSet(other) + elif isinstance(other, _IndividualSpecifier): + other = SpecifierSet(str(other)) + elif not isinstance(other, SpecifierSet): + return NotImplemented + + return self._specs != other._specs + + def __len__(self): + return len(self._specs) + + def __iter__(self): + return iter(self._specs) + + @property + def prereleases(self): + # If we have been given an explicit prerelease modifier, then we'll + # pass that through here. + if self._prereleases is not None: + return self._prereleases + + # If we don't have any specifiers, and we don't have a forced value, + # then we'll just return None since we don't know if this should have + # pre-releases or not. + if not self._specs: + return None + + # Otherwise we'll see if any of the given specifiers accept + # prereleases, if any of them do we'll return True, otherwise False. + return any(s.prereleases for s in self._specs) + + @prereleases.setter + def prereleases(self, value): + self._prereleases = value + + def __contains__(self, item): + return self.contains(item) + + def contains(self, item, prereleases=None): + # Ensure that our item is a Version or LegacyVersion instance. + if not isinstance(item, (LegacyVersion, Version)): + item = parse(item) + + # 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 + # SpecifierSet thinks for whether or not we should support prereleases. + if prereleases is None: + prereleases = self.prereleases + + # We can determine if we're going to allow pre-releases by looking to + # see if any of the underlying items supports them. If none of them do + # and this item is a pre-release then we do not allow it and we can + # short circuit that here. + # Note: This means that 1.0.dev1 would not be contained in something + # like >=1.0.devabc however it would be in >=1.0.debabc,>0.0.dev0 + if not prereleases and item.is_prerelease: + return False + + # We simply dispatch to the underlying specs here to make sure that the + # given version is contained within all of them. + # Note: This use of all() here means that an empty set of specifiers + # will always return True, this is an explicit design decision. + return all( + s.contains(item, prereleases=prereleases) + for s in self._specs + ) + + def filter(self, iterable, prereleases=None): + # 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 + # SpecifierSet thinks for whether or not we should support prereleases. + if prereleases is None: + prereleases = self.prereleases + + # If we have any specifiers, then we want to wrap our iterable in the + # filter method for each one, this will act as a logical AND amongst + # each specifier. + if self._specs: + for spec in self._specs: + iterable = spec.filter(iterable, prereleases=bool(prereleases)) + return iterable + # If we do not have any specifiers, then we need to have a rough filter + # which will filter out any pre-releases, unless there are no final + # releases, and which will filter out LegacyVersion in general. + else: + filtered = [] + found_prereleases = [] + + for item in iterable: + # Ensure that we some kind of Version class for this item. + if not isinstance(item, (LegacyVersion, Version)): + parsed_version = parse(item) + else: + parsed_version = item + + # Filter out any item which is parsed as a LegacyVersion + if isinstance(parsed_version, LegacyVersion): + continue + + # Store any item which is a pre-release for later unless we've + # already found a final version or we are accepting prereleases + if parsed_version.is_prerelease and not prereleases: + if not filtered: + found_prereleases.append(item) + else: + filtered.append(item) + + # If we've found no items except for pre-releases, then we'll go + # ahead and use the pre-releases + if not filtered and found_prereleases and prereleases is None: + return found_prereleases + + return filtered diff --git a/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/utils.py b/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/utils.py new file mode 100644 index 0000000..942387c --- /dev/null +++ b/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/utils.py @@ -0,0 +1,14 @@ +# 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 + + +_canonicalize_regex = re.compile(r"[-_.]+") + + +def canonicalize_name(name): + # This is taken from PEP 503. + return _canonicalize_regex.sub("-", name).lower() diff --git a/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/version.py b/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/version.py new file mode 100644 index 0000000..83b5ee8 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/version.py @@ -0,0 +1,393 @@ +# 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 + +from ._structures import Infinity + + +__all__ = [ + "parse", "Version", "LegacyVersion", "InvalidVersion", "VERSION_PATTERN" +] + + +_Version = collections.namedtuple( + "_Version", + ["epoch", "release", "dev", "pre", "post", "local"], +) + + +def parse(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 + a valid PEP 440 version or a legacy version. + """ + try: + return Version(version) + except InvalidVersion: + return LegacyVersion(version) + + +class InvalidVersion(ValueError): + """ + An invalid version was found, users should refer to PEP 440. + """ + + +class _BaseVersion(object): + + def __hash__(self): + return hash(self._key) + + def __lt__(self, other): + return self._compare(other, lambda s, o: s < o) + + def __le__(self, other): + return self._compare(other, lambda s, o: s <= o) + + def __eq__(self, other): + return self._compare(other, lambda s, o: s == o) + + def __ge__(self, other): + return self._compare(other, lambda s, o: s >= o) + + def __gt__(self, other): + return self._compare(other, lambda s, o: s > o) + + def __ne__(self, other): + return self._compare(other, lambda s, o: s != o) + + def _compare(self, other, method): + if not isinstance(other, _BaseVersion): + return NotImplemented + + return method(self._key, other._key) + + +class LegacyVersion(_BaseVersion): + + def __init__(self, version): + self._version = str(version) + self._key = _legacy_cmpkey(self._version) + + def __str__(self): + return self._version + + def __repr__(self): + return "".format(repr(str(self))) + + @property + def public(self): + return self._version + + @property + def base_version(self): + return self._version + + @property + def local(self): + return None + + @property + def is_prerelease(self): + return False + + @property + def is_postrelease(self): + return False + + +_legacy_version_component_re = re.compile( + r"(\d+ | [a-z]+ | \.| -)", re.VERBOSE, +) + +_legacy_version_replacement_map = { + "pre": "c", "preview": "c", "-": "final-", "rc": "c", "dev": "@", +} + + +def _parse_version_parts(s): + for part in _legacy_version_component_re.split(s): + part = _legacy_version_replacement_map.get(part, part) + + if not part or part == ".": + continue + + if part[:1] in "0123456789": + # pad for numeric comparison + yield part.zfill(8) + else: + yield "*" + part + + # ensure that alpha/beta/candidate are before final + yield "*final" + + +def _legacy_cmpkey(version): + # 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, + # which uses the defacto standard originally implemented by setuptools, + # as before all PEP 440 versions. + epoch = -1 + + # This scheme is taken from pkg_resources.parse_version setuptools prior to + # it's adoption of the packaging library. + parts = [] + for part in _parse_version_parts(version.lower()): + if part.startswith("*"): + # remove "-" before a prerelease tag + if part < "*final": + while parts and parts[-1] == "*final-": + parts.pop() + + # remove trailing zeros from each series of numeric parts + while parts and parts[-1] == "00000000": + parts.pop() + + parts.append(part) + parts = tuple(parts) + + return epoch, parts + +# Deliberately not anchored to the start and end of the string, to make it +# easier for 3rd party code to reuse +VERSION_PATTERN = r""" + v? + (?: + (?:(?P[0-9]+)!)? # epoch + (?P[0-9]+(?:\.[0-9]+)*) # release segment + (?P

                                          # pre-release
+            [-_\.]?
+            (?P(a|b|c|rc|alpha|beta|pre|preview))
+            [-_\.]?
+            (?P[0-9]+)?
+        )?
+        (?P                                         # post release
+            (?:-(?P[0-9]+))
+            |
+            (?:
+                [-_\.]?
+                (?Ppost|rev|r)
+                [-_\.]?
+                (?P[0-9]+)?
+            )
+        )?
+        (?P                                          # dev release
+            [-_\.]?
+            (?Pdev)
+            [-_\.]?
+            (?P[0-9]+)?
+        )?
+    )
+    (?:\+(?P[a-z0-9]+(?:[-_\.][a-z0-9]+)*))?       # local version
+"""
+
+
+class Version(_BaseVersion):
+
+    _regex = re.compile(
+        r"^\s*" + VERSION_PATTERN + r"\s*$",
+        re.VERBOSE | re.IGNORECASE,
+    )
+
+    def __init__(self, version):
+        # Validate the version and parse it into pieces
+        match = self._regex.search(version)
+        if not match:
+            raise InvalidVersion("Invalid version: '{0}'".format(version))
+
+        # Store the parsed out pieces of the version
+        self._version = _Version(
+            epoch=int(match.group("epoch")) if match.group("epoch") else 0,
+            release=tuple(int(i) for i in match.group("release").split(".")),
+            pre=_parse_letter_version(
+                match.group("pre_l"),
+                match.group("pre_n"),
+            ),
+            post=_parse_letter_version(
+                match.group("post_l"),
+                match.group("post_n1") or match.group("post_n2"),
+            ),
+            dev=_parse_letter_version(
+                match.group("dev_l"),
+                match.group("dev_n"),
+            ),
+            local=_parse_local_version(match.group("local")),
+        )
+
+        # Generate a key which will be used for sorting
+        self._key = _cmpkey(
+            self._version.epoch,
+            self._version.release,
+            self._version.pre,
+            self._version.post,
+            self._version.dev,
+            self._version.local,
+        )
+
+    def __repr__(self):
+        return "".format(repr(str(self)))
+
+    def __str__(self):
+        parts = []
+
+        # Epoch
+        if self._version.epoch != 0:
+            parts.append("{0}!".format(self._version.epoch))
+
+        # Release segment
+        parts.append(".".join(str(x) for x in self._version.release))
+
+        # Pre-release
+        if self._version.pre is not None:
+            parts.append("".join(str(x) for x in self._version.pre))
+
+        # Post-release
+        if self._version.post is not None:
+            parts.append(".post{0}".format(self._version.post[1]))
+
+        # Development release
+        if self._version.dev is not None:
+            parts.append(".dev{0}".format(self._version.dev[1]))
+
+        # Local version segment
+        if self._version.local is not None:
+            parts.append(
+                "+{0}".format(".".join(str(x) for x in self._version.local))
+            )
+
+        return "".join(parts)
+
+    @property
+    def public(self):
+        return str(self).split("+", 1)[0]
+
+    @property
+    def base_version(self):
+        parts = []
+
+        # Epoch
+        if self._version.epoch != 0:
+            parts.append("{0}!".format(self._version.epoch))
+
+        # Release segment
+        parts.append(".".join(str(x) for x in self._version.release))
+
+        return "".join(parts)
+
+    @property
+    def local(self):
+        version_string = str(self)
+        if "+" in version_string:
+            return version_string.split("+", 1)[1]
+
+    @property
+    def is_prerelease(self):
+        return bool(self._version.dev or self._version.pre)
+
+    @property
+    def is_postrelease(self):
+        return bool(self._version.post)
+
+
+def _parse_letter_version(letter, number):
+    if letter:
+        # We consider there to be an implicit 0 in a pre-release if there is
+        # not a numeral associated with it.
+        if number is None:
+            number = 0
+
+        # We normalize any letters to their lower case form
+        letter = letter.lower()
+
+        # We consider some words to be alternate spellings of other words and
+        # in those cases we want to normalize the spellings to our preferred
+        # spelling.
+        if letter == "alpha":
+            letter = "a"
+        elif letter == "beta":
+            letter = "b"
+        elif letter in ["c", "pre", "preview"]:
+            letter = "rc"
+        elif letter in ["rev", "r"]:
+            letter = "post"
+
+        return letter, int(number)
+    if not letter and number:
+        # We assume if we are given a number, but we are not given a letter
+        # then this is using the implicit post release syntax (e.g. 1.0-1)
+        letter = "post"
+
+        return letter, int(number)
+
+
+_local_version_seperators = re.compile(r"[\._-]")
+
+
+def _parse_local_version(local):
+    """
+    Takes a string like abc.1.twelve and turns it into ("abc", 1, "twelve").
+    """
+    if local is not None:
+        return tuple(
+            part.lower() if not part.isdigit() else int(part)
+            for part in _local_version_seperators.split(local)
+        )
+
+
+def _cmpkey(epoch, release, pre, post, dev, local):
+    # 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
+    # leading zeros until we come to something non zero, then take the rest
+    # re-reverse it back into the correct order and make it a tuple and use
+    # that for our sorting key.
+    release = tuple(
+        reversed(list(
+            itertools.dropwhile(
+                lambda x: x == 0,
+                reversed(release),
+            )
+        ))
+    )
+
+    # We need to "trick" the sorting algorithm to put 1.0.dev0 before 1.0a0.
+    # We'll do this by abusing the pre segment, but we _only_ want to do this
+    # 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 = -Infinity
+    # Versions without a pre-release (except as noted above) should sort after
+    # those with one.
+    elif pre is None:
+        pre = Infinity
+
+    # Versions without a post segment should sort before those with one.
+    if post is None:
+        post = -Infinity
+
+    # Versions without a development segment should sort after those with one.
+    if dev is None:
+        dev = Infinity
+
+    if local is None:
+        # Versions without a local segment should sort before those with one.
+        local = -Infinity
+    else:
+        # Versions with a local segment need that segment parsed to implement
+        # the sorting rules in PEP440.
+        # - Alpha numeric segments sort before numeric segments
+        # - Alpha numeric segments sort lexicographically
+        # - Numeric segments sort numerically
+        # - Shorter versions sort before longer versions when the prefixes
+        #   match exactly
+        local = tuple(
+            (i, "") if isinstance(i, int) else (-Infinity, i)
+            for i in local
+        )
+
+    return epoch, release, pre, post, dev, local
diff --git a/venv/lib/python3.8/site-packages/pkg_resources/_vendor/pyparsing.py b/venv/lib/python3.8/site-packages/pkg_resources/_vendor/pyparsing.py
new file mode 100644
index 0000000..cf75e1e
--- /dev/null
+++ b/venv/lib/python3.8/site-packages/pkg_resources/_vendor/pyparsing.py
@@ -0,0 +1,5742 @@
+# module pyparsing.py
+#
+# Copyright (c) 2003-2018  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 
+C{", !"}), built up using L{Word}, L{Literal}, and L{And} elements 
+(L{'+'} operator gives L{And} expressions, strings are auto-converted to
+L{Literal} expressions)::
+
+    from 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 L{ParseResults} object returned from L{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 L{ParserElement} and L{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 L{Literal} and L{CaselessLiteral} classes
+ - construct character word-group expressions using the L{Word} class
+ - see how to create repetitive expressions using L{ZeroOrMore} and L{OneOrMore} classes
+ - use L{'+'}, L{'|'}, L{'^'}, and L{'&'} operators to combine simple expressions into more complex ones
+ - associate names with your parsed results using L{ParserElement.setResultsName}
+ - find some helpful expression short-cuts like L{delimitedList} and L{oneOf}
+ - find more useful common expressions in the L{pyparsing_common} namespace class
+"""
+
+__version__ = "2.2.1"
+__versionTime__ = "18 Sep 2018 00:49 UTC"
+__author__ = "Paul McGuire "
+
+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
+
+try:
+    from _thread import RLock
+except ImportError:
+    from threading import RLock
+
+try:
+    # Python 3
+    from collections.abc import Iterable
+    from collections.abc import MutableMapping
+except ImportError:
+    # Python 2.7
+    from collections import Iterable
+    from collections import MutableMapping
+
+try:
+    from collections import OrderedDict as _OrderedDict
+except ImportError:
+    try:
+        from ordereddict import OrderedDict as _OrderedDict
+    except ImportError:
+        _OrderedDict = None
+
+#~ sys.stderr.write( "testing pyparsing module, version %s, %s\n" % (__version__,__versionTime__ ) )
+
+__all__ = [
+'And', 'CaselessKeyword', 'CaselessLiteral', 'CharsNotIn', 'Combine', 'Dict', 'Each', 'Empty',
+'FollowedBy', 'Forward', 'GoToColumn', 'Group', 'Keyword', 'LineEnd', 'LineStart', 'Literal',
+'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',
+'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',
+]
+
+system_version = tuple(sys.version_info)[:3]
+PY_3 = system_version[0] == 3
+if PY_3:
+    _MAX_INT = sys.maxsize
+    basestring = str
+    unichr = chr
+    _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
+
+class _Constants(object):
+    pass
+
+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)
+
+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 ):
+        return "%s (at char %d), (line:%d, col:%d)" % \
+                ( self.msg, 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
+    """
+    pass
+
+class ParseFatalException(ParseBaseException):
+    """user-throwable exception thrown when inconsistent parse content
+       is found; stops all parsing immediately"""
+    pass
+
+class ParseSyntaxException(ParseFatalException):
+    """just like L{ParseFatalException}, but thrown internally when an
+       L{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 L{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 (C{len(results)})
+       - by list index (C{results[0], results[1]}, etc.)
+       - by attribute (C{results.} - see L{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(toklist.copy(),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 (Python 3.x only)."""
+
+        values = _itervalues
+        """Returns an iterator of all named result values (Python 3.x only)."""
+
+        items = _iteritems
+        """Returns an iterator of all named result key-value tuples (Python 3.x only)."""
+
+    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=C{last}).
+        Supports both C{list} and C{dict} semantics for C{pop()}. If passed no
+        argument or an integer argument, it will use C{list} semantics
+        and pop tokens from the list of parsed tokens. If passed a 
+        non-integer argument (most likely a string), it will use C{dict}
+        semantics and pop the corresponding value from any defined 
+        results names. A second default return value argument is 
+        supported, just as in C{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 C{defaultValue} or C{None} if no
+        C{defaultValue} is specified.
+
+        Similar to C{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 C{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 += 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 ""
+            
+        if name in self.__tokdict:
+            if name not in self.__accumNames:
+                return self.__tokdict[name][-1][0]
+            else:
+                return ParseResults([ v[0] for v in self.__tokdict[name] ])
+        else:
+            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) # ->  ['sldkj', 'lsdkj', 'sldkj']
+            
+            # Use asList() to create an actual list
+            result_list = result.asList()
+            print(type(result_list), result_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)) # ->  (['12', '/', '31', '/', '1999'], {'day': [('1999', 4)], 'year': [('12', 0)], 'month': [('31', 2)]})
+            
+            result_dict = result.asDict()
+            print(type(result_dict), repr(result_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 C{ParseResults} object.
+        """
+        ret = ParseResults( self.__toklist )
+        ret.__tokdict = self.__tokdict.copy()
+        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,
+                                                "" ]
+
+        out += [ nl, indent, "" ]
+        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='', depth=0, full=True):
+        """
+        Diagnostic method for listing out the contents of a C{ParseResults}.
+        Accepts an optional C{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'
+        out.append( indent+_ustr(self.asList()) )
+        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,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,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 C{pprint} module.
+        Accepts additional positional or keyword args as defined for the 
+        C{pprint.pprint} method. (U{http://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()))
+
+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 L{I{ParserElement.parseString}} for more information
+   on parsing strings containing C{}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} for more information
+   on parsing strings containing C{}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:
+                        del tb
+
+                if limit[0] <= maxargs:
+                    limit[0] += 1
+                    continue
+                raise
+
+    # copy func name to wrapper for sensible debug output
+    func_name = ""
+    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,  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
+
+    def __init__( self, savelist=False ):
+        self.parseAction = list()
+        self.failAction = None
+        #~ self.name = ""  # don't define self.name, let subclasses try/except upcall
+        self.strRepr = None
+        self.resultsName = None
+        self.saveAsList = savelist
+        self.skipWhitespace = True
+        self.whiteChars = 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 C{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 C{expr.copy()} is just C{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 hasattr(self,"exception"):
+            self.exception.msg = self.errmsg
+        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 C{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,
+        C{expr("name")} in place of C{expr.setResultsName("name")} - 
+        see L{I{__call__}<__call__>}.
+
+        Example::
+            date_str = (integer.setResultsName("year") + '/' 
+                        + integer.setResultsName("month") + '/' 
+                        + integer.setResultsName("day"))
+
+            # equivalent form:
+            date_str = integer("year") + '/' + integer("month") + '/' + integer("day")
+        """
+        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 C{breakFlag} to True to enable, False to
+           disable.
+        """
+        if breakFlag:
+            _parseMethod = self._parse
+            def breaker(instring, loc, doActions=True, callPreParse=True):
+                import pdb
+                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 C{fn(s,loc,toks)},
+        C{fn(loc,toks)}, C{fn(toks)}, or just C{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 C{L{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.
+
+        Optional keyword arguments:
+         - callDuringTry = (default=C{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 L{I{parseString}} for more information
+        on parsing strings containing C{}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]
+        """
+        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 L{I{setParseAction}}.
+        
+        See examples in L{I{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 
+        L{I{setParseAction}} for function call signatures. Unlike C{setParseAction}, 
+        functions passed to C{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)
+        """
+        msg = kwargs.get("message", "failed user-defined condition")
+        exc_type = ParseFatalException if kwargs.get("fatal", False) else ParseException
+        for fn in fns:
+            def pa(s,l,t):
+                if not bool(_trim_arity(fn)(s,l,t)):
+                    raise exc_type(s,l,msg)
+            self.parseAction.append(pa)
+        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
+           C{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 C{L{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 ):
+        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[0] ):
+                self.debugActions[0]( instring, loc, self )
+            if callPreParse and self.callPreparse:
+                preloc = self.preParse( instring, loc )
+            else:
+                preloc = loc
+            tokensStart = preloc
+            try:
+                try:
+                    loc,tokens = self.parseImpl( instring, preloc, doActions )
+                except IndexError:
+                    raise ParseException( instring, len(instring), self.errmsg, self )
+            except ParseBaseException as err:
+                #~ print ("Exception raised:", err)
+                if self.debugActions[2]:
+                    self.debugActions[2]( 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:
+                        tokens = fn( instring, tokensStart, retTokens )
+                        if tokens is not None:
+                            retTokens = ParseResults( tokens,
+                                                      self.resultsName,
+                                                      asList=self.saveAsList and isinstance(tokens,(ParseResults,list)),
+                                                      modal=self.modalResults )
+                except ParseBaseException as err:
+                    #~ print "Exception raised in user parse action:", err
+                    if (self.debugActions[2] ):
+                        self.debugActions[2]( instring, tokensStart, self, err )
+                    raise
+            else:
+                for fn in self.parseAction:
+                    tokens = fn( instring, tokensStart, retTokens )
+                    if tokens is not None:
+                        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[1] ):
+                self.debugActions[1]( 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=C{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 C{ParserElement.enablePackrat()}.  If
+           your program uses C{psyco} to "compile as you go", you must call
+           C{enablePackrat} before calling C{psyco.full()}.  If you do not do this,
+           Python will crash.  For best results, call C{enablePackrat()} immediately
+           after importing pyparsing.
+           
+           Example::
+               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.
+
+        If you want the grammar to require that the entire input string be
+        successfully parsed, then set C{parseAll} to True (equivalent to ending
+        the grammar with C{L{StringEnd()}}).
+
+        Note: C{parseString} implicitly calls C{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 C{loc} argument to index into the
+        string being parsed, you can ensure you have a consistent view of the input
+        string by:
+         - calling C{parseWithTabs} on your grammar before calling C{parseString}
+           (see L{I{parseWithTabs}})
+         - define your parse action using the full C{(s,loc,toks)} signature, and
+           reference the input string using the parse action's C{s} argument
+         - explictly expand the tabs in your input string before calling
+           C{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, clears out pyparsing internal stack trace
+                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
+        C{maxMatches} argument, to clip scanning after 'n' matches are found.  If
+        C{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 L{I{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, clears out pyparsing internal stack trace
+                raise exc
+
+    def transformString( self, instring ):
+        """
+        Extension to C{L{scanString}}, to modify matching text with modified tokens that may
+        be returned from a parse action.  To use C{transformString}, define a grammar and
+        attach a parse action to it that modifies the returned token list.
+        Invoking C{transformString()} on a target string will then scan for matches,
+        and replace the matched text patterns according to the logic in the parse
+        action.  C{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 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, clears out pyparsing internal stack trace
+                raise exc
+
+    def searchString( self, instring, maxMatches=_MAX_INT ):
+        """
+        Another extension to C{L{scanString}}, simplifying the access to the tokens found
+        to match the given parse expression.  May be called with optional
+        C{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, clears out pyparsing internal stack trace
+                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 C{maxsplit} argument, to limit the number of splits;
+        and the optional C{includeSeparators} argument (default=C{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 C{L{And}}. Adding strings to a ParserElement
+        converts them to L{Literal}s by default.
+        
+        Example::
+            greet = Word(alphas) + "," + Word(alphas) + "!"
+            hello = "Hello, World!"
+            print (hello, "->", greet.parseString(hello))
+        Prints::
+            Hello, World! -> ['Hello', ',', 'World', '!']
+        """
+        if isinstance( other, basestring ):
+            other = ParserElement._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 C{L{ParserElement}}
+        """
+        if isinstance( other, basestring ):
+            other = ParserElement._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 C{L{And}} with error stop
+        """
+        if isinstance( other, basestring ):
+            other = ParserElement._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 C{L{ParserElement}}
+        """
+        if isinstance( other, basestring ):
+            other = ParserElement._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 C{expr * 3} in place of
+        C{expr + expr + expr}.  Expressions may also me multiplied by a 2-integer
+        tuple, similar to C{{min,max}} multipliers in regular expressions.  Tuples
+        may also include C{None} as in:
+         - C{expr*(n,None)} or C{expr*(n,)} is equivalent
+              to C{expr*n + L{ZeroOrMore}(expr)}
+              (read as "at least n instances of C{expr}")
+         - C{expr*(None,n)} is equivalent to C{expr*(0,n)}
+              (read as "0 to n instances of C{expr}")
+         - C{expr*(None,None)} is equivalent to C{L{ZeroOrMore}(expr)}
+         - C{expr*(1,None)} is equivalent to C{L{OneOrMore}(expr)}
+
+        Note that C{expr*(None,n)} does not raise an exception if
+        more than n exprs exist in the input stream; that is,
+        C{expr*(None,n)} does not enforce a maximum number of expr
+        occurrences.  If this behavior is desired, then write
+        C{expr*(None,n) + ~expr}
+        """
+        if isinstance(other,int):
+            minElements, optElements = other,0
+        elif isinstance(other,tuple):
+            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 C{L{MatchFirst}}
+        """
+        if isinstance( other, basestring ):
+            other = ParserElement._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 C{L{ParserElement}}
+        """
+        if isinstance( other, basestring ):
+            other = ParserElement._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 C{L{Or}}
+        """
+        if isinstance( other, basestring ):
+            other = ParserElement._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 C{L{ParserElement}}
+        """
+        if isinstance( other, basestring ):
+            other = ParserElement._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 C{L{Each}}
+        """
+        if isinstance( other, basestring ):
+            other = ParserElement._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 C{L{ParserElement}}
+        """
+        if isinstance( other, basestring ):
+            other = ParserElement._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 C{L{NotAny}}
+        """
+        return NotAny( self )
+
+    def __call__(self, name=None):
+        """
+        Shortcut for C{L{setResultsName}}, with C{listAllMatches=False}.
+        
+        If C{name} is given with a trailing C{'*'} character, then C{listAllMatches} will be
+        passed as C{True}.
+           
+        If C{name} is omitted, same as calling C{L{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 C{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
+        C{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 C{}s to spaces before parsing the input string.
+        Must be called before C{parseString} when the input grammar contains elements that
+        match C{} 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 C{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 L{setDebugActions}. Prior to attempting
+        to match the C{wd} expression, the debugging message C{"Match  at loc (,)"}
+        is shown. Then if the parse succeeds, a C{"Matched"} message is shown, or an C{"Exception raised"}
+        message is shown. Also note the use of L{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 C{Word} expression without calling C{setName} is C{"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=[] ):
+        """
+        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, clears out pyparsing internal stack trace
+                raise exc
+
+    def __eq__(self,other):
+        if isinstance(other, ParserElement):
+            return self is other or vars(self) == vars(other)
+        elif isinstance(other, basestring):
+            return self.matches(other)
+        else:
+            return super(ParserElement,self)==other
+
+    def __ne__(self,other):
+        return not (self == other)
+
+    def __hash__(self):
+        return hash(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=C{True}) - flag to pass to C{L{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):
+        """
+        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=C{True}) - flag to pass to C{L{parseString}} when running tests           
+         - comment - (default=C{'#'}) - expression for indicating embedded comments in the test 
+              string; pass None to disable comment filtering
+         - fullDump - (default=C{True}) - dump results as list followed by results names in nested outline;
+              if False, only dump nested list
+         - printResults - (default=C{True}) prints test output to stdout
+         - failureTests - (default=C{False}) indicates if these tests are expected to fail parsing
+
+        Returns: a (success, results) tuple, where success indicates that all tests succeeded
+        (or failed if C{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)
+        allResults = []
+        comments = []
+        success = True
+        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'.join(comments), t]
+            comments = []
+            try:
+                t = t.replace(r'\n','\n')
+                result = self.parseString(t, parseAll=parseAll)
+                out.append(result.dump(full=fullDump))
+                success = success and not failureTests
+            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
+
+            if printResults:
+                if fullDump:
+                    out.append('')
+                print('\n'.join(out))
+
+            allResults.append((t, result))
+        
+        return success, allResults
+
+        
+class Token(ParserElement):
+    """
+    Abstract C{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 L{CaselessLiteral}.
+    
+    For keyword matching (force word break before and after the matched string),
+    use L{Keyword} or L{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: this routine gets called a *lot*
+    # if this is a single character match string  and the first character matches,
+    # short-circuit as quickly as possible, and avoid calling startswith
+    #~ @profile
+    def parseImpl( self, instring, loc, doActions=True ):
+        if (instring[loc] == self.firstMatchChar and
+            (self.matchLen==1 or instring.startswith(self.match,loc)) ):
+            return loc+self.matchLen, 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 C{L{Literal}}:
+     - C{Literal("if")} will match the leading C{'if'} in C{'ifAndOnlyIf'}.
+     - C{Keyword("if")} will not; it will only match the leading C{'if'} in C{'if x=1'}, or C{'if(y==2)'}
+    Accepts two optional constructor arguments in addition to the keyword string:
+     - C{identChars} is a string of characters that would be valid identifier characters,
+          defaulting to all alphanumerics + "_" and "$"
+     - C{caseless} allows case-insensitive matching, default is C{False}.
+       
+    Example::
+        Keyword("start").parseString("start")  # -> ['start']
+        Keyword("start").parseString("starting")  # -> Exception
+
+    For case-insensitive matching, use L{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 and
+                (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 L{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 L{Keyword}.
+
+    Example::
+        OneOrMore(CaselessKeyword("CMD")).parseString("cmd CMD Cmd10") # -> ['CMD', 'CMD']
+        
+    (Contrast with example for L{CaselessLiteral}.)
+    """
+    def __init__( self, matchString, identChars=None ):
+        super(CaselessKeyword,self).__init__( matchString, identChars, caseless=True )
+
+    def parseImpl( self, instring, loc, doActions=True ):
+        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) ):
+            return loc+self.matchLen, self.match
+        raise ParseException(instring, loc, self.errmsg, self)
+
+class CloseMatch(Token):
+    """
+    A variation on L{Literal} which matches "close" matches, that is, 
+    strings with at most 'n' mismatching characters. C{CloseMatch} takes parameters:
+     - C{match_string} - string to be matched
+     - C{maxMismatches} - (C{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:
+     - C{mismatches} - a list of the positions within the match_string where mismatches were found
+     - C{original} - the original match_string used to compare against the input string
+    
+    If C{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], self.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'] = self.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 C{min} is 1 (a
+    minimum value < 1 is not valid); the default values for C{max} and C{exact}
+    are 0, meaning no maximum or exact length restriction. An optional
+    C{excludeChars} parameter can list characters that might be found in 
+    the input C{bodyChars} string; useful to define a word of all printables
+    except for one or two characters, for instance.
+    
+    L{srange} is useful for defining custom character set strings for defining 
+    C{Word} expressions, using range notation from regular expression character sets.
+    
+    A common mistake is to use C{Word} to match a specific literal string, as in 
+    C{Word("Address")}. Remember that C{Word} uses the string argument to define
+    I{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 L{Literal} or L{Keyword}.
+
+    pyparsing includes helper strings for building Words:
+     - L{alphas}
+     - L{nums}
+     - L{alphanums}
+     - L{hexnums}
+     - L{alphas8bit} (alphabetic characters in ASCII range 128-255 - accented, tilded, umlauted, etc.)
+     - L{punc8bit} (non-alphabetic characters in ASCII range 128-255 - currency, symbols, superscripts, diacriticals, etc.)
+     - L{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:
+            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
+
+    def parseImpl( self, instring, loc, doActions=True ):
+        if self.re:
+            result = self.re.match(instring,loc)
+            if not result:
+                raise ParseException(instring, loc, self.errmsg, self)
+
+            loc = result.end()
+            return loc, result.group()
+
+        if not(instring[ loc ] 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
+        if self.maxSpecified and loc < instrlen and instring[loc] in bodychars:
+            throwException = True
+        if self.asKeyword:
+            if (start>0 and instring[start-1] in bodychars) or (loc4:
+                    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 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 inbuilt Python re module.
+    If the given regex contains named groups (defined using C{(?P...)}), these will be preserved as 
+    named parse results.
+
+    Example::
+        realnum = Regex(r"[+-]?\d+\.\d*")
+        date = Regex(r'(?P\d{4})-(?P\d\d?)-(?P\d\d?)')
+        # ref: http://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?C{0,3})(XC|XL|L?X{0,3})(IX|IV|V?I{0,3})")
+    """
+    compiledREtype = type(re.compile("[A-Z]"))
+    def __init__( self, pattern, flags=0):
+        """The parameters C{pattern} and C{flags} are passed to the C{re.compile()} function as-is. See the Python C{re} 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 isinstance(pattern, Regex.compiledREtype):
+            self.re = pattern
+            self.pattern = \
+            self.reString = str(pattern)
+            self.flags = flags
+            
+        else:
+            raise ValueError("Regex may only be constructed with a string or a compiled RE object")
+
+        self.name = _ustr(self)
+        self.errmsg = "Expected " + self.name
+        self.mayIndexError = False
+        self.mayReturnEmpty = True
+
+    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()
+        d = result.groupdict()
+        ret = ParseResults(result.group())
+        if d:
+            for k in d:
+                ret[k] = d[k]
+        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
+
+
+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=C{None})
+        - escQuote - special quote sequence to escape an embedded quote string (such as SQL's "" to escape an embedded ") (default=C{None})
+        - multiline - boolean indicating whether quotes can span multiple lines (default=C{False})
+        - unquoteResults - boolean indicating whether the matched text should be unquoted (default=C{True})
+        - endQuoteChar - string of one or more characters defining the end of the quote delimited string (default=C{None} => same as quoteChar)
+        - convertWhitespaceEscapes - convert escaped whitespace (C{'\t'}, C{'\n'}, etc.) to actual whitespace (default=C{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
+        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 I{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 C{min} is 1 (a
+    minimum value < 1 is not valid); the default values for C{max} and C{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 C{" \\t\\r\\n"}.  Also takes optional C{min}, C{max}, and C{exact} arguments,
+    as defined for the C{L{Word}} class.
+    """
+    whiteStrs = {
+        " " : "",
+        "\t": "",
+        "\n": "",
+        "\r": "",
+        "\f": "",
+        }
+    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 not(instring[ loc ] 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):
+    """
+    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):
+            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 C{wordChars}
+    (default=C{printables}). To emulate the C{\b} behavior of regular expressions,
+    use C{WordStart(alphanums)}. C{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 C{wordChars}
+    (default=C{printables}). To emulate the C{\b} behavior of regular expressions,
+    use C{WordEnd(alphanums)}. C{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 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:
+            matches.sort(key=lambda x: -x[0])
+            for _,e in matches:
+                try:
+                    return e._parse( instring, loc, doActions )
+                except ParseException as err:
+                    err.__traceback__ = None
+                    if err.loc > maxExcLoc:
+                        maxException = err
+                        maxExcLoc = err.loc
+
+        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 = ParserElement._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 )
+
+
+class MatchFirst(ParseExpression):
+    """
+    Requires that at least one C{ParseExpression} is found.
+    If two expressions match, the first one listed is the one that will match.
+    May be constructed using the C{'|'} 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 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 = ParserElement._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 )
+
+
+class Each(ParseExpression):
+    """
+    Requires all given C{ParseExpression}s to be found, but in any order.
+    Expressions may be separated by whitespace.
+    May be constructed using the C{'&'} 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
+
+    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)]
+            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 C{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(ParserElement._literalStringClass, Token):
+                expr = ParserElement._literalStringClass(expr)
+            else:
+                expr = ParserElement._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=[] ):
+        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.  C{FollowedBy}
+    does I{not} advance the parsing position within the input string, it only
+    verifies that the specified parse expression matches at the current
+    position.  C{FollowedBy} always returns a null token list.
+
+    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 ):
+        self.expr.tryParse( instring, loc )
+        return loc, []
+
+
+class NotAny(ParseElementEnhance):
+    """
+    Lookahead to disallow matching with the given parse expression.  C{NotAny}
+    does I{not} advance the parsing position within the input string, it only
+    verifies that the specified parse expression does I{not} match at the current
+    position.  Also, C{NotAny} does I{not} skip over leading whitespace. C{NotAny}
+    always returns a null token list.  May be constructed using the '~' operator.
+
+    Example::
+        
+    """
+    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 = ParserElement._literalStringClass(ender)
+        self.not_ender = ~ender if ender is not None else None
+
+    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
+        
+class OneOrMore(_MultipleMatch):
+    """
+    Repetition of one or more of the given expression.
+    
+    Parameters:
+     - expr - expression that must match one or more times
+     - stopOn - (default=C{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=C{None}) - expression for a terminating sentinel
+          (only required if the sentinel would ordinarily match the repetition 
+          expression)          
+
+    Example: similar to L{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 ""
+
+_optionalNotMatched = _NullToken()
+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)
+    """
+    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 _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=C{False}) if True, the target expression is also parsed 
+          (the skipped text and target expression are returned as a 2-element list).
+     - ignore - (default=C{None}) used to define grammars (typically quoted strings and 
+          comments) that might contain false matches to the target expression
+     - failOn - (default=C{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.asList = False
+        if isinstance(failOn, basestring):
+            self.failOn = ParserElement._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 C{Forward} variable using the '<<' operator.
+
+    Note: take care when assigning to C{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 C{Forward}::
+        fwdExpr << (a | b | c)
+    Converting to use the '<<=' operator instead will avoid this problem.
+
+    See L{ParseResults.pprint} for an example of a recursive parser created using
+    C{Forward}.
+    """
+    def __init__( self, other=None ):
+        super(Forward,self).__init__( other, savelist=False )
+
+    def __lshift__( self, other ):
+        if isinstance( other, basestring ):
+            other = ParserElement._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=[] ):
+        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
+        return self.__class__.__name__ + ": ..."
+
+        # stubbed out for now - creates awful memory and perf issues
+        self._revertClass = self.__class__
+        self.__class__ = _ForwardNoRecurse
+        try:
+            if self.expr is not None:
+                retString = _ustr(self.expr)
+            else:
+                retString = "None"
+        finally:
+            self.__class__ = self._revertClass
+        return self.__class__.__name__ + ": " + retString
+
+    def copy(self):
+        if self.expr is not None:
+            return super(Forward,self).copy()
+        else:
+            ret = Forward()
+            ret <<= self
+            return ret
+
+class _ForwardNoRecurse(Forward):
+    def __str__( self ):
+        return "..."
+
+class TokenConverter(ParseElementEnhance):
+    """
+    Abstract subclass of C{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 C{'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 C{L{ZeroOrMore}} and C{L{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 L{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 L{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 C{">> entering I{method-name}(line:I{current_source_line}, I{parse_location}, I{matched_tokens})".}
+    When the parse action completes, the decorator will print C{"<<"} 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'], {}))
+        <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( "< ['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 C{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 C{"1:1"}, but not C{"1:2"}.  Because this matches a
+    previous literal, will also match the leading C{"1:1"} in C{"1:10"}.
+    If this is not desired, use C{matchPreviousExpr}.
+    Do I{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 C{"1:1"}, but not C{"1:2"}.  Because this matches by
+    expressions, will I{not} match the leading C{"1:1"} in C{"1:10"};
+    the expressions are evaluated first, and then compared, so
+    C{"1"} is compared with C{"10"}.
+    Do I{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 ):
+    """
+    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 C{L{MatchFirst}} for best performance.
+
+    Parameters:
+     - strs - a string of space-delimited literals, or a collection of string literals
+     - caseless - (default=C{False}) - treat all literals as caseless
+     - useRegex - (default=C{True}) - as an optimization, will generate a Regex
+          object; otherwise, will generate a C{MatchFirst} object (if C{caseless=True}, or
+          if creating a C{Regex} raises an exception)
+
+    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 caseless:
+        isequal = ( lambda a,b: a.upper() == b.upper() )
+        masks = ( lambda a,b: b.upper().startswith(a.upper()) )
+        parseElementClass = CaselessLiteral
+    else:
+        isequal = ( lambda a,b: a == b )
+        masks = ( lambda a,b: b.startswith(a) )
+        parseElementClass = 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()
+
+    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)
+                cur = other
+                break
+        else:
+            i += 1
+
+    if not caseless 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 C{L{Dict}}, C{L{ZeroOrMore}}, and C{L{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 C{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( ZeroOrMore( 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 C{asString} argument is passed as C{False}, then the return value is a 
+    C{L{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 C{L{originalTextFor}} contains expressions with defined
+    results names, you must set C{asString} to C{False} if you want to preserve those
+    results name values.
+
+    Example::
+        src = "this is test  bold text  normal text "
+        for tag in ("b","i"):
+            opener,closer = makeHTMLTags(tag)
+            patt = originalTextFor(opener + SkipTo(closer) + closer)
+            print(patt.searchString(src)[0])
+    prints::
+        [' bold text ']
+        ['text']
+    """
+    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).setParseAction(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 C{} characters, you may want to call
+    C{L{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 C{\-} or C{\]})
+     - an escaped hex character with a leading C{'\x'} (C{\x21}, which is a C{'!'} character) 
+         (C{\0x##} is also supported for backwards compatibility) 
+     - an escaped octal character with a leading C{'\0'} (C{\041}, which is a C{'!'} character)
+     - a range of any of the above, separated by a dash (C{'a-z'}, etc.)
+     - any combination of the above (C{'aeiouy'}, C{'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 C{L{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 C{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 L{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 L{pyparsing_common.upcaseTokens}"""
+
+downcaseTokens = tokenMap(lambda t: _ustr(t).lower())
+"""(Deprecated) Helper parse action to convert tokens to lower case. Deprecated in favor of L{pyparsing_common.downcaseTokens}"""
+    
+def _makeTags(tagStr, xml):
+    """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("<") + tagStr("tag") + \
+                Dict(ZeroOrMore(Group( tagAttrName + Suppress("=") + tagAttrValue ))) + \
+                Optional("/",default=[False]).setResultsName("empty").setParseAction(lambda s,l,t:t[0]=='/') + Suppress(">")
+    else:
+        printablesLessRAbrack = "".join(c for c in printables if c not in ">")
+        tagAttrValue = quotedString.copy().setParseAction( removeQuotes ) | Word(printablesLessRAbrack)
+        openTag = Suppress("<") + tagStr("tag") + \
+                Dict(ZeroOrMore(Group( tagAttrName.setParseAction(downcaseTokens) + \
+                Optional( Suppress("=") + tagAttrValue ) ))) + \
+                Optional("/",default=[False]).setResultsName("empty").setParseAction(lambda s,l,t:t[0]=='/') + Suppress(">")
+    closeTag = Combine(_L("")
+
+    openTag = openTag.setResultsName("start"+"".join(resname.replace(":"," ").title().split())).setName("<%s>" % resname)
+    closeTag = closeTag.setResultsName("end"+"".join(resname.replace(":"," ").title().split())).setName("" % resname)
+    openTag.tag = resname
+    closeTag.tag = resname
+    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 = 'More info at the pyparsing wiki page'
+        # 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  tag (like "href" shown here) are also accessible as named results
+            print(link.link_text, '->', link.href)
+    prints::
+        pyparsing -> http://pyparsing.wikispaces.com
+    """
+    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 L{makeHTMLTags}
+    """
+    return _makeTags( tagStr, True )
+
+def withAttribute(*args,**attrDict):
+    """
+    Helper to create a validating parse action to be used with start tags created
+    with C{L{makeXMLTags}} or C{L{makeHTMLTags}}. Use C{withAttribute} to qualify a starting tag
+    with a required attribute value, to avoid false matches on common tags such as
+    C{} or C{
}. + + Call C{withAttribute} with a series of attribute names and values. Specify the list + of filter attributes names and values as: + - keyword arguments, as in C{(align="right")}, or + - as an explicit dict with C{**} operator, when an attribute name is also a Python + reserved word, as in C{**{"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 C{class} (with or without a namespace), use C{L{withClass}}. + + To verify that the attribute exists, but without specifying a value, pass + C{withAttribute.ANY_VALUE} as the value. + + Example:: + html = ''' +
+ Some text +
1 4 0 1 0
+
1,3 2,3 1,1
+
this has no type
+
+ + ''' + 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 C{L{withAttribute}} when matching on a div class - made + difficult because C{class} is a reserved word in Python. + + Example:: + html = ''' +
+ Some text +
1 4 0 1 0
+
1,3 2,3 1,1
+
this <div> has no class
+
+ + ''' + 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 = _Constants() +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 L{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 C{opAssoc.RIGHT} and C{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 C{setParseAction(*fn)} (L{ParserElement.setParseAction}) + - lpar - expression for matching left-parentheses (default=C{Suppress('(')}) + - rpar - expression for matching right-parentheses (default=C{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]]] + """ + 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 = FollowedBy(lastExpr + opExpr) + Group( lastExpr + OneOrMore( opExpr ) ) + elif arity == 2: + if opExpr is not None: + matchExpr = FollowedBy(lastExpr + opExpr + lastExpr) + Group( lastExpr + OneOrMore( opExpr + lastExpr ) ) + else: + matchExpr = FollowedBy(lastExpr+lastExpr) + Group( lastExpr + OneOrMore(lastExpr) ) + elif arity == 3: + matchExpr = FollowedBy(lastExpr + opExpr1 + lastExpr + opExpr2 + lastExpr) + \ + Group( lastExpr + 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 = FollowedBy(opExpr.expr + thisExpr) + Group( opExpr + thisExpr ) + elif arity == 2: + if opExpr is not None: + matchExpr = FollowedBy(lastExpr + opExpr + thisExpr) + Group( lastExpr + OneOrMore( opExpr + thisExpr ) ) + else: + matchExpr = FollowedBy(lastExpr + thisExpr) + Group( lastExpr + OneOrMore( thisExpr ) ) + elif arity == 3: + matchExpr = FollowedBy(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 C{L{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=C{"("}); can also be a pyparsing expression + - closer - closing character for a nested list (default=C{")"}); can also be a pyparsing expression + - content - expression for items within the nested lists (default=C{None}) + - ignoreExpr - expression for ignoring opening and closing delimiters (default=C{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 C{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 C{L{Or}} or C{L{MatchFirst}}. + The default is L{quotedString}, but if no expressions are to be ignored, + then pass C{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 + the current level; set to False for block of left-most statements + (default=C{True}) + + A valid block must contain at least one C{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']]]]]]] + """ + def checkPeerIndent(s,l,t): + if l >= len(s): return + curCol = col(l,s) + if curCol != indentStack[-1]: + if curCol > indentStack[-1]: + raise ParseFatalException(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 < indentStack[-1] and curCol <= indentStack[-2]): + raise ParseException(s,l,"not an unindent") + indentStack.pop() + + NL = OneOrMore(LineEnd().setWhitespaceChars("\t ").suppress()) + INDENT = (Empty() + Empty().setParseAction(checkSubIndent)).setName('INDENT') + PEER = Empty().setParseAction(checkPeerIndent).setName('') + UNDENT = Empty().setParseAction(checkUnindent).setName('UNINDENT') + if indent: + smExpr = Group( Optional(NL) + + #~ FollowedBy(blockStatementExpr) + + INDENT + (OneOrMore( PEER + Group(blockStatementExpr) + Optional(NL) )) + UNDENT) + else: + smExpr = Group( Optional(NL) + + (OneOrMore( PEER + Group(blockStatementExpr) + Optional(NL) )) ) + 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' + '|'.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 C{/* ... */}" + +htmlComment = Regex(r"").setName("HTML comment") +"Comment of the form C{}" + +restOfLine = Regex(r".*").leaveWhitespace().setName("rest of line") +dblSlashComment = Regex(r"//(?:\\\n|[^\n])*").setName("// comment") +"Comment of the form C{// ... (to end of line)}" + +cppStyleComment = Combine(Regex(r"/\*(?:[^*]|\*(?!/))*") + '*/'| dblSlashComment).setName("C++ style comment") +"Comment of either form C{L{cStyleComment}} or C{L{dblSlashComment}}" + +javaStyleComment = cppStyleComment +"Same as C{L{cppStyleComment}}" + +pythonStyleComment = Regex(r"#.*").setName("Python style comment") +"Comment of the form C{# ... (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 L{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 (L{integers}, L{reals}, L{scientific notation}) + - common L{programming identifiers} + - network addresses (L{MAC}, L{IPv4}, L{IPv6}) + - ISO8601 L{dates} and L{datetime} + - L{UUID} + - L{comma-separated list} + Parse actions: + - C{L{convertToInteger}} + - C{L{convertToFloat}} + - C{L{convertToDate}} + - C{L{convertToDatetime}} + - C{L{stripHTMLTags}} + - C{L{upcaseTokens}} + - C{L{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*').setName("real number").setParseAction(convertToFloat) + """expression that parses a floating point number and returns a float""" + + sci_real = Regex(r'[+-]?\d+([eE][+-]?\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 (C{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=C{"%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=C{"%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\d{4})(?:-(?P\d\d)(?:-(?P\d\d))?)?').setName("ISO8601 date") + "ISO8601 date (C{yyyy-mm-dd})" + + iso8601_datetime = Regex(r'(?P\d{4})-(?P\d\d)-(?P\d\d)[T ](?P\d\d):(?P\d\d)(:(?P\d\d(\.\d*)?)?)?(?PZ|[+-]\d\d:?\d\d)?').setName("ISO8601 datetime") + "ISO8601 datetime (C{yyyy-mm-ddThh:mm:ss.s(Z|+-00:00)}) - trailing seconds, milliseconds, and timezone optional; accepts separating C{'T'} or C{' '}" + + uuid = Regex(r'[0-9a-fA-F]{8}(-[0-9a-fA-F]{4}){3}-[0-9a-fA-F]{12}').setName("UUID") + "UUID (C{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 = 'More info at the
pyparsing wiki page' + td,td_end = makeHTMLTags("TD") + table_text = td + SkipTo(td_end).setParseAction(pyparsing_common.stripHTMLTags)("body") + td_end + + print(table_text.parseString(text).body) # -> '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.""" + + +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/venv/lib/python3.8/site-packages/pkg_resources/_vendor/six.py b/venv/lib/python3.8/site-packages/pkg_resources/_vendor/six.py new file mode 100644 index 0000000..190c023 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pkg_resources/_vendor/six.py @@ -0,0 +1,868 @@ +"""Utilities for writing code that runs on Python 2 and 3""" + +# Copyright (c) 2010-2015 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 +# 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 absolute_import + +import functools +import itertools +import operator +import sys +import types + +__author__ = "Benjamin Peterson " +__version__ = "1.10.0" + + +# Useful for very coarse version differentiation. +PY2 = sys.version_info[0] == 2 +PY3 = sys.version_info[0] == 3 +PY34 = sys.version_info[0:2] >= (3, 4) + +if PY3: + string_types = str, + integer_types = int, + class_types = type, + text_type = str + binary_type = bytes + + MAXSIZE = sys.maxsize +else: + string_types = basestring, + integer_types = (int, long) + class_types = (type, types.ClassType) + text_type = unicode + binary_type = str + + if sys.platform.startswith("java"): + # Jython always uses 32 bits. + MAXSIZE = int((1 << 31) - 1) + else: + # It's possible to have sizeof(long) != sizeof(Py_ssize_t). + class X(object): + + def __len__(self): + return 1 << 31 + try: + len(X()) + except OverflowError: + # 32-bit + MAXSIZE = int((1 << 31) - 1) + else: + # 64-bit + MAXSIZE = int((1 << 63) - 1) + del X + + +def _add_doc(func, doc): + """Add documentation to a function.""" + func.__doc__ = doc + + +def _import_module(name): + """Import module, returning the module after the last dot.""" + __import__(name) + return sys.modules[name] + + +class _LazyDescr(object): + + def __init__(self, name): + self.name = name + + def __get__(self, obj, tp): + result = self._resolve() + setattr(obj, self.name, result) # Invokes __set__. + try: + # This is a bit ugly, but it avoids running this again by + # removing this descriptor. + delattr(obj.__class__, self.name) + except AttributeError: + pass + return result + + +class MovedModule(_LazyDescr): + + def __init__(self, name, old, new=None): + super(MovedModule, self).__init__(name) + if PY3: + if new is None: + new = name + self.mod = new + else: + self.mod = old + + def _resolve(self): + return _import_module(self.mod) + + def __getattr__(self, attr): + _module = self._resolve() + value = getattr(_module, attr) + setattr(self, attr, value) + return value + + +class _LazyModule(types.ModuleType): + + def __init__(self, name): + super(_LazyModule, self).__init__(name) + self.__doc__ = self.__class__.__doc__ + + def __dir__(self): + attrs = ["__doc__", "__name__"] + attrs += [attr.name for attr in self._moved_attributes] + return attrs + + # Subclasses should override this + _moved_attributes = [] + + +class MovedAttribute(_LazyDescr): + + def __init__(self, name, old_mod, new_mod, old_attr=None, new_attr=None): + super(MovedAttribute, self).__init__(name) + if PY3: + if new_mod is None: + new_mod = name + self.mod = new_mod + if new_attr is None: + if old_attr is None: + new_attr = name + else: + new_attr = old_attr + self.attr = new_attr + else: + self.mod = old_mod + if old_attr is None: + old_attr = name + self.attr = old_attr + + def _resolve(self): + module = _import_module(self.mod) + return getattr(module, self.attr) + + +class _SixMetaPathImporter(object): + + """ + A meta path importer to import six.moves and its submodules. + + This class implements a PEP302 finder and loader. It should be compatible + with Python 2.5 and all existing versions of Python3 + """ + + def __init__(self, six_module_name): + self.name = six_module_name + self.known_modules = {} + + def _add_module(self, mod, *fullnames): + for fullname in fullnames: + self.known_modules[self.name + "." + fullname] = mod + + def _get_module(self, fullname): + return self.known_modules[self.name + "." + fullname] + + def find_module(self, fullname, path=None): + if fullname in self.known_modules: + return self + return None + + def __get_module(self, fullname): + try: + return self.known_modules[fullname] + except KeyError: + raise ImportError("This loader does not know module " + fullname) + + def load_module(self, fullname): + try: + # in case of a reload + return sys.modules[fullname] + except KeyError: + pass + mod = self.__get_module(fullname) + if isinstance(mod, MovedModule): + mod = mod._resolve() + else: + mod.__loader__ = self + sys.modules[fullname] = mod + return mod + + def is_package(self, fullname): + """ + Return true, if the named module is a package. + + We need this method to get correct spec objects with + Python 3.4 (see PEP451) + """ + return hasattr(self.__get_module(fullname), "__path__") + + def get_code(self, fullname): + """Return None + + Required, if is_package is implemented""" + self.__get_module(fullname) # eventually raises ImportError + return None + get_source = get_code # same as get_code + +_importer = _SixMetaPathImporter(__name__) + + +class _MovedItems(_LazyModule): + + """Lazy loading of moved objects""" + __path__ = [] # mark as package + + +_moved_attributes = [ + MovedAttribute("cStringIO", "cStringIO", "io", "StringIO"), + MovedAttribute("filter", "itertools", "builtins", "ifilter", "filter"), + MovedAttribute("filterfalse", "itertools", "itertools", "ifilterfalse", "filterfalse"), + MovedAttribute("input", "__builtin__", "builtins", "raw_input", "input"), + MovedAttribute("intern", "__builtin__", "sys"), + MovedAttribute("map", "itertools", "builtins", "imap", "map"), + MovedAttribute("getcwd", "os", "os", "getcwdu", "getcwd"), + MovedAttribute("getcwdb", "os", "os", "getcwd", "getcwdb"), + MovedAttribute("range", "__builtin__", "builtins", "xrange", "range"), + MovedAttribute("reload_module", "__builtin__", "importlib" if PY34 else "imp", "reload"), + MovedAttribute("reduce", "__builtin__", "functools"), + MovedAttribute("shlex_quote", "pipes", "shlex", "quote"), + MovedAttribute("StringIO", "StringIO", "io"), + MovedAttribute("UserDict", "UserDict", "collections"), + MovedAttribute("UserList", "UserList", "collections"), + MovedAttribute("UserString", "UserString", "collections"), + MovedAttribute("xrange", "__builtin__", "builtins", "xrange", "range"), + MovedAttribute("zip", "itertools", "builtins", "izip", "zip"), + MovedAttribute("zip_longest", "itertools", "itertools", "izip_longest", "zip_longest"), + MovedModule("builtins", "__builtin__"), + MovedModule("configparser", "ConfigParser"), + MovedModule("copyreg", "copy_reg"), + MovedModule("dbm_gnu", "gdbm", "dbm.gnu"), + MovedModule("_dummy_thread", "dummy_thread", "_dummy_thread"), + MovedModule("http_cookiejar", "cookielib", "http.cookiejar"), + MovedModule("http_cookies", "Cookie", "http.cookies"), + MovedModule("html_entities", "htmlentitydefs", "html.entities"), + MovedModule("html_parser", "HTMLParser", "html.parser"), + MovedModule("http_client", "httplib", "http.client"), + MovedModule("email_mime_multipart", "email.MIMEMultipart", "email.mime.multipart"), + MovedModule("email_mime_nonmultipart", "email.MIMENonMultipart", "email.mime.nonmultipart"), + MovedModule("email_mime_text", "email.MIMEText", "email.mime.text"), + MovedModule("email_mime_base", "email.MIMEBase", "email.mime.base"), + MovedModule("BaseHTTPServer", "BaseHTTPServer", "http.server"), + MovedModule("CGIHTTPServer", "CGIHTTPServer", "http.server"), + MovedModule("SimpleHTTPServer", "SimpleHTTPServer", "http.server"), + MovedModule("cPickle", "cPickle", "pickle"), + MovedModule("queue", "Queue"), + MovedModule("reprlib", "repr"), + MovedModule("socketserver", "SocketServer"), + MovedModule("_thread", "thread", "_thread"), + MovedModule("tkinter", "Tkinter"), + MovedModule("tkinter_dialog", "Dialog", "tkinter.dialog"), + MovedModule("tkinter_filedialog", "FileDialog", "tkinter.filedialog"), + MovedModule("tkinter_scrolledtext", "ScrolledText", "tkinter.scrolledtext"), + MovedModule("tkinter_simpledialog", "SimpleDialog", "tkinter.simpledialog"), + MovedModule("tkinter_tix", "Tix", "tkinter.tix"), + MovedModule("tkinter_ttk", "ttk", "tkinter.ttk"), + MovedModule("tkinter_constants", "Tkconstants", "tkinter.constants"), + MovedModule("tkinter_dnd", "Tkdnd", "tkinter.dnd"), + MovedModule("tkinter_colorchooser", "tkColorChooser", + "tkinter.colorchooser"), + MovedModule("tkinter_commondialog", "tkCommonDialog", + "tkinter.commondialog"), + MovedModule("tkinter_tkfiledialog", "tkFileDialog", "tkinter.filedialog"), + MovedModule("tkinter_font", "tkFont", "tkinter.font"), + MovedModule("tkinter_messagebox", "tkMessageBox", "tkinter.messagebox"), + MovedModule("tkinter_tksimpledialog", "tkSimpleDialog", + "tkinter.simpledialog"), + MovedModule("urllib_parse", __name__ + ".moves.urllib_parse", "urllib.parse"), + MovedModule("urllib_error", __name__ + ".moves.urllib_error", "urllib.error"), + MovedModule("urllib", __name__ + ".moves.urllib", __name__ + ".moves.urllib"), + MovedModule("urllib_robotparser", "robotparser", "urllib.robotparser"), + MovedModule("xmlrpc_client", "xmlrpclib", "xmlrpc.client"), + MovedModule("xmlrpc_server", "SimpleXMLRPCServer", "xmlrpc.server"), +] +# Add windows specific modules. +if sys.platform == "win32": + _moved_attributes += [ + MovedModule("winreg", "_winreg"), + ] + +for attr in _moved_attributes: + setattr(_MovedItems, attr.name, attr) + if isinstance(attr, MovedModule): + _importer._add_module(attr, "moves." + attr.name) +del attr + +_MovedItems._moved_attributes = _moved_attributes + +moves = _MovedItems(__name__ + ".moves") +_importer._add_module(moves, "moves") + + +class Module_six_moves_urllib_parse(_LazyModule): + + """Lazy loading of moved objects in six.moves.urllib_parse""" + + +_urllib_parse_moved_attributes = [ + MovedAttribute("ParseResult", "urlparse", "urllib.parse"), + MovedAttribute("SplitResult", "urlparse", "urllib.parse"), + MovedAttribute("parse_qs", "urlparse", "urllib.parse"), + MovedAttribute("parse_qsl", "urlparse", "urllib.parse"), + MovedAttribute("urldefrag", "urlparse", "urllib.parse"), + MovedAttribute("urljoin", "urlparse", "urllib.parse"), + MovedAttribute("urlparse", "urlparse", "urllib.parse"), + MovedAttribute("urlsplit", "urlparse", "urllib.parse"), + MovedAttribute("urlunparse", "urlparse", "urllib.parse"), + MovedAttribute("urlunsplit", "urlparse", "urllib.parse"), + MovedAttribute("quote", "urllib", "urllib.parse"), + MovedAttribute("quote_plus", "urllib", "urllib.parse"), + MovedAttribute("unquote", "urllib", "urllib.parse"), + MovedAttribute("unquote_plus", "urllib", "urllib.parse"), + MovedAttribute("urlencode", "urllib", "urllib.parse"), + MovedAttribute("splitquery", "urllib", "urllib.parse"), + MovedAttribute("splittag", "urllib", "urllib.parse"), + MovedAttribute("splituser", "urllib", "urllib.parse"), + MovedAttribute("uses_fragment", "urlparse", "urllib.parse"), + MovedAttribute("uses_netloc", "urlparse", "urllib.parse"), + MovedAttribute("uses_params", "urlparse", "urllib.parse"), + MovedAttribute("uses_query", "urlparse", "urllib.parse"), + MovedAttribute("uses_relative", "urlparse", "urllib.parse"), +] +for attr in _urllib_parse_moved_attributes: + setattr(Module_six_moves_urllib_parse, attr.name, attr) +del attr + +Module_six_moves_urllib_parse._moved_attributes = _urllib_parse_moved_attributes + +_importer._add_module(Module_six_moves_urllib_parse(__name__ + ".moves.urllib_parse"), + "moves.urllib_parse", "moves.urllib.parse") + + +class Module_six_moves_urllib_error(_LazyModule): + + """Lazy loading of moved objects in six.moves.urllib_error""" + + +_urllib_error_moved_attributes = [ + MovedAttribute("URLError", "urllib2", "urllib.error"), + MovedAttribute("HTTPError", "urllib2", "urllib.error"), + MovedAttribute("ContentTooShortError", "urllib", "urllib.error"), +] +for attr in _urllib_error_moved_attributes: + setattr(Module_six_moves_urllib_error, attr.name, attr) +del attr + +Module_six_moves_urllib_error._moved_attributes = _urllib_error_moved_attributes + +_importer._add_module(Module_six_moves_urllib_error(__name__ + ".moves.urllib.error"), + "moves.urllib_error", "moves.urllib.error") + + +class Module_six_moves_urllib_request(_LazyModule): + + """Lazy loading of moved objects in six.moves.urllib_request""" + + +_urllib_request_moved_attributes = [ + MovedAttribute("urlopen", "urllib2", "urllib.request"), + MovedAttribute("install_opener", "urllib2", "urllib.request"), + MovedAttribute("build_opener", "urllib2", "urllib.request"), + MovedAttribute("pathname2url", "urllib", "urllib.request"), + MovedAttribute("url2pathname", "urllib", "urllib.request"), + MovedAttribute("getproxies", "urllib", "urllib.request"), + MovedAttribute("Request", "urllib2", "urllib.request"), + MovedAttribute("OpenerDirector", "urllib2", "urllib.request"), + MovedAttribute("HTTPDefaultErrorHandler", "urllib2", "urllib.request"), + MovedAttribute("HTTPRedirectHandler", "urllib2", "urllib.request"), + MovedAttribute("HTTPCookieProcessor", "urllib2", "urllib.request"), + MovedAttribute("ProxyHandler", "urllib2", "urllib.request"), + MovedAttribute("BaseHandler", "urllib2", "urllib.request"), + MovedAttribute("HTTPPasswordMgr", "urllib2", "urllib.request"), + MovedAttribute("HTTPPasswordMgrWithDefaultRealm", "urllib2", "urllib.request"), + MovedAttribute("AbstractBasicAuthHandler", "urllib2", "urllib.request"), + MovedAttribute("HTTPBasicAuthHandler", "urllib2", "urllib.request"), + MovedAttribute("ProxyBasicAuthHandler", "urllib2", "urllib.request"), + MovedAttribute("AbstractDigestAuthHandler", "urllib2", "urllib.request"), + MovedAttribute("HTTPDigestAuthHandler", "urllib2", "urllib.request"), + MovedAttribute("ProxyDigestAuthHandler", "urllib2", "urllib.request"), + MovedAttribute("HTTPHandler", "urllib2", "urllib.request"), + MovedAttribute("HTTPSHandler", "urllib2", "urllib.request"), + MovedAttribute("FileHandler", "urllib2", "urllib.request"), + MovedAttribute("FTPHandler", "urllib2", "urllib.request"), + MovedAttribute("CacheFTPHandler", "urllib2", "urllib.request"), + MovedAttribute("UnknownHandler", "urllib2", "urllib.request"), + MovedAttribute("HTTPErrorProcessor", "urllib2", "urllib.request"), + MovedAttribute("urlretrieve", "urllib", "urllib.request"), + MovedAttribute("urlcleanup", "urllib", "urllib.request"), + MovedAttribute("URLopener", "urllib", "urllib.request"), + MovedAttribute("FancyURLopener", "urllib", "urllib.request"), + MovedAttribute("proxy_bypass", "urllib", "urllib.request"), +] +for attr in _urllib_request_moved_attributes: + setattr(Module_six_moves_urllib_request, attr.name, attr) +del attr + +Module_six_moves_urllib_request._moved_attributes = _urllib_request_moved_attributes + +_importer._add_module(Module_six_moves_urllib_request(__name__ + ".moves.urllib.request"), + "moves.urllib_request", "moves.urllib.request") + + +class Module_six_moves_urllib_response(_LazyModule): + + """Lazy loading of moved objects in six.moves.urllib_response""" + + +_urllib_response_moved_attributes = [ + MovedAttribute("addbase", "urllib", "urllib.response"), + MovedAttribute("addclosehook", "urllib", "urllib.response"), + MovedAttribute("addinfo", "urllib", "urllib.response"), + MovedAttribute("addinfourl", "urllib", "urllib.response"), +] +for attr in _urllib_response_moved_attributes: + setattr(Module_six_moves_urllib_response, attr.name, attr) +del attr + +Module_six_moves_urllib_response._moved_attributes = _urllib_response_moved_attributes + +_importer._add_module(Module_six_moves_urllib_response(__name__ + ".moves.urllib.response"), + "moves.urllib_response", "moves.urllib.response") + + +class Module_six_moves_urllib_robotparser(_LazyModule): + + """Lazy loading of moved objects in six.moves.urllib_robotparser""" + + +_urllib_robotparser_moved_attributes = [ + MovedAttribute("RobotFileParser", "robotparser", "urllib.robotparser"), +] +for attr in _urllib_robotparser_moved_attributes: + setattr(Module_six_moves_urllib_robotparser, attr.name, attr) +del attr + +Module_six_moves_urllib_robotparser._moved_attributes = _urllib_robotparser_moved_attributes + +_importer._add_module(Module_six_moves_urllib_robotparser(__name__ + ".moves.urllib.robotparser"), + "moves.urllib_robotparser", "moves.urllib.robotparser") + + +class Module_six_moves_urllib(types.ModuleType): + + """Create a six.moves.urllib namespace that resembles the Python 3 namespace""" + __path__ = [] # mark as package + parse = _importer._get_module("moves.urllib_parse") + error = _importer._get_module("moves.urllib_error") + request = _importer._get_module("moves.urllib_request") + response = _importer._get_module("moves.urllib_response") + robotparser = _importer._get_module("moves.urllib_robotparser") + + def __dir__(self): + return ['parse', 'error', 'request', 'response', 'robotparser'] + +_importer._add_module(Module_six_moves_urllib(__name__ + ".moves.urllib"), + "moves.urllib") + + +def add_move(move): + """Add an item to six.moves.""" + setattr(_MovedItems, move.name, move) + + +def remove_move(name): + """Remove item from six.moves.""" + try: + delattr(_MovedItems, name) + except AttributeError: + try: + del moves.__dict__[name] + except KeyError: + raise AttributeError("no such move, %r" % (name,)) + + +if PY3: + _meth_func = "__func__" + _meth_self = "__self__" + + _func_closure = "__closure__" + _func_code = "__code__" + _func_defaults = "__defaults__" + _func_globals = "__globals__" +else: + _meth_func = "im_func" + _meth_self = "im_self" + + _func_closure = "func_closure" + _func_code = "func_code" + _func_defaults = "func_defaults" + _func_globals = "func_globals" + + +try: + advance_iterator = next +except NameError: + def advance_iterator(it): + return it.next() +next = advance_iterator + + +try: + callable = callable +except NameError: + def callable(obj): + return any("__call__" in klass.__dict__ for klass in type(obj).__mro__) + + +if PY3: + def get_unbound_function(unbound): + return unbound + + create_bound_method = types.MethodType + + def create_unbound_method(func, cls): + return func + + Iterator = object +else: + def get_unbound_function(unbound): + return unbound.im_func + + def create_bound_method(func, obj): + return types.MethodType(func, obj, obj.__class__) + + def create_unbound_method(func, cls): + return types.MethodType(func, None, cls) + + class Iterator(object): + + def next(self): + return type(self).__next__(self) + + callable = callable +_add_doc(get_unbound_function, + """Get the function out of a possibly unbound function""") + + +get_method_function = operator.attrgetter(_meth_func) +get_method_self = operator.attrgetter(_meth_self) +get_function_closure = operator.attrgetter(_func_closure) +get_function_code = operator.attrgetter(_func_code) +get_function_defaults = operator.attrgetter(_func_defaults) +get_function_globals = operator.attrgetter(_func_globals) + + +if PY3: + def iterkeys(d, **kw): + return iter(d.keys(**kw)) + + def itervalues(d, **kw): + return iter(d.values(**kw)) + + def iteritems(d, **kw): + return iter(d.items(**kw)) + + def iterlists(d, **kw): + return iter(d.lists(**kw)) + + viewkeys = operator.methodcaller("keys") + + viewvalues = operator.methodcaller("values") + + viewitems = operator.methodcaller("items") +else: + def iterkeys(d, **kw): + return d.iterkeys(**kw) + + def itervalues(d, **kw): + return d.itervalues(**kw) + + def iteritems(d, **kw): + return d.iteritems(**kw) + + def iterlists(d, **kw): + return d.iterlists(**kw) + + viewkeys = operator.methodcaller("viewkeys") + + viewvalues = operator.methodcaller("viewvalues") + + viewitems = operator.methodcaller("viewitems") + +_add_doc(iterkeys, "Return an iterator over the keys of a dictionary.") +_add_doc(itervalues, "Return an iterator over the values of a dictionary.") +_add_doc(iteritems, + "Return an iterator over the (key, value) pairs of a dictionary.") +_add_doc(iterlists, + "Return an iterator over the (key, [values]) pairs of a dictionary.") + + +if PY3: + def b(s): + return s.encode("latin-1") + + def u(s): + return s + unichr = chr + import struct + int2byte = struct.Struct(">B").pack + del struct + byte2int = operator.itemgetter(0) + indexbytes = operator.getitem + iterbytes = iter + import io + StringIO = io.StringIO + BytesIO = io.BytesIO + _assertCountEqual = "assertCountEqual" + if sys.version_info[1] <= 1: + _assertRaisesRegex = "assertRaisesRegexp" + _assertRegex = "assertRegexpMatches" + else: + _assertRaisesRegex = "assertRaisesRegex" + _assertRegex = "assertRegex" +else: + def b(s): + return s + # Workaround for standalone backslash + + def u(s): + return unicode(s.replace(r'\\', r'\\\\'), "unicode_escape") + unichr = unichr + int2byte = chr + + def byte2int(bs): + return ord(bs[0]) + + def indexbytes(buf, i): + return ord(buf[i]) + iterbytes = functools.partial(itertools.imap, ord) + import StringIO + StringIO = BytesIO = StringIO.StringIO + _assertCountEqual = "assertItemsEqual" + _assertRaisesRegex = "assertRaisesRegexp" + _assertRegex = "assertRegexpMatches" +_add_doc(b, """Byte literal""") +_add_doc(u, """Text literal""") + + +def assertCountEqual(self, *args, **kwargs): + return getattr(self, _assertCountEqual)(*args, **kwargs) + + +def assertRaisesRegex(self, *args, **kwargs): + return getattr(self, _assertRaisesRegex)(*args, **kwargs) + + +def assertRegex(self, *args, **kwargs): + return getattr(self, _assertRegex)(*args, **kwargs) + + +if PY3: + exec_ = getattr(moves.builtins, "exec") + + def reraise(tp, value, tb=None): + if value is None: + value = tp() + if value.__traceback__ is not tb: + raise value.with_traceback(tb) + raise value + +else: + def exec_(_code_, _globs_=None, _locs_=None): + """Execute code in a namespace.""" + if _globs_ is None: + frame = sys._getframe(1) + _globs_ = frame.f_globals + if _locs_ is None: + _locs_ = frame.f_locals + del frame + elif _locs_ is None: + _locs_ = _globs_ + exec("""exec _code_ in _globs_, _locs_""") + + exec_("""def reraise(tp, value, tb=None): + raise tp, value, tb +""") + + +if sys.version_info[:2] == (3, 2): + exec_("""def raise_from(value, from_value): + if from_value is None: + raise value + raise value from from_value +""") +elif sys.version_info[:2] > (3, 2): + exec_("""def raise_from(value, from_value): + raise value from from_value +""") +else: + def raise_from(value, from_value): + raise value + + +print_ = getattr(moves.builtins, "print", None) +if print_ is None: + def print_(*args, **kwargs): + """The new-style print function for Python 2.4 and 2.5.""" + fp = kwargs.pop("file", sys.stdout) + if fp is None: + return + + def write(data): + if not isinstance(data, basestring): + data = str(data) + # If the file has an encoding, encode unicode with it. + if (isinstance(fp, file) and + isinstance(data, unicode) and + fp.encoding is not None): + errors = getattr(fp, "errors", None) + if errors is None: + errors = "strict" + data = data.encode(fp.encoding, errors) + fp.write(data) + want_unicode = False + sep = kwargs.pop("sep", None) + if sep is not None: + if isinstance(sep, unicode): + want_unicode = True + elif not isinstance(sep, str): + raise TypeError("sep must be None or a string") + end = kwargs.pop("end", None) + if end is not None: + if isinstance(end, unicode): + want_unicode = True + elif not isinstance(end, str): + raise TypeError("end must be None or a string") + if kwargs: + raise TypeError("invalid keyword arguments to print()") + if not want_unicode: + for arg in args: + if isinstance(arg, unicode): + want_unicode = True + break + if want_unicode: + newline = unicode("\n") + space = unicode(" ") + else: + newline = "\n" + space = " " + if sep is None: + sep = space + if end is None: + end = newline + for i, arg in enumerate(args): + if i: + write(sep) + write(arg) + write(end) +if sys.version_info[:2] < (3, 3): + _print = print_ + + def print_(*args, **kwargs): + fp = kwargs.get("file", sys.stdout) + flush = kwargs.pop("flush", False) + _print(*args, **kwargs) + if flush and fp is not None: + fp.flush() + +_add_doc(reraise, """Reraise an exception.""") + +if sys.version_info[0:2] < (3, 4): + 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 +else: + wraps = functools.wraps + + +def with_metaclass(meta, *bases): + """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): + + def __new__(cls, name, this_bases, d): + return meta(name, bases, d) + return type.__new__(metaclass, 'temporary_class', (), {}) + + +def add_metaclass(metaclass): + """Class decorator for creating a class with a metaclass.""" + def wrapper(cls): + orig_vars = cls.__dict__.copy() + slots = orig_vars.get('__slots__') + if slots is not None: + if isinstance(slots, str): + slots = [slots] + for slots_var in slots: + orig_vars.pop(slots_var) + orig_vars.pop('__dict__', None) + orig_vars.pop('__weakref__', None) + return metaclass(cls.__name__, cls.__bases__, orig_vars) + return wrapper + + +def python_2_unicode_compatible(klass): + """ + A 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 + returning text and apply this decorator to the class. + """ + if PY2: + if '__str__' not in klass.__dict__: + raise ValueError("@python_2_unicode_compatible cannot be applied " + "to %s because it doesn't define __str__()." % + klass.__name__) + klass.__unicode__ = klass.__str__ + klass.__str__ = lambda self: self.__unicode__().encode('utf-8') + return klass + + +# Complete the moves implementation. +# This code is at the end of this module to speed up module loading. +# Turn this module into a package. +__path__ = [] # required for PEP 302 and PEP 451 +__package__ = __name__ # see PEP 366 @ReservedAssignment +if globals().get("__spec__") is not None: + __spec__.submodule_search_locations = [] # PEP 451 @UndefinedVariable +# Remove other six meta path importers, since they cause problems. This can +# happen if six is removed from sys.modules and then reloaded. (Setuptools does +# this for some reason.) +if sys.meta_path: + for i, importer in enumerate(sys.meta_path): + # Here's some real nastiness: Another "instance" of the six module might + # be floating around. Therefore, we can't use isinstance() to check for + # the six meta path importer, since the other six instance will have + # inserted an importer with different class. + if (type(importer).__name__ == "_SixMetaPathImporter" and + importer.name == __name__): + del sys.meta_path[i] + break + del i, importer +# Finally, add the importer to the meta path import hook. +sys.meta_path.append(_importer) diff --git a/venv/lib/python3.8/site-packages/pkg_resources/extern/__init__.py b/venv/lib/python3.8/site-packages/pkg_resources/extern/__init__.py new file mode 100644 index 0000000..c1eb9e9 --- /dev/null +++ b/venv/lib/python3.8/site-packages/pkg_resources/extern/__init__.py @@ -0,0 +1,73 @@ +import sys + + +class VendorImporter: + """ + A PEP 302 meta path importer for finding optionally-vendored + or otherwise naturally-installed packages from root_name. + """ + + def __init__(self, root_name, vendored_names=(), vendor_pkg=None): + self.root_name = root_name + self.vendored_names = set(vendored_names) + self.vendor_pkg = vendor_pkg or root_name.replace('extern', '_vendor') + + @property + def search_path(self): + """ + Search first the vendor package then as a natural package. + """ + yield self.vendor_pkg + '.' + yield '' + + def find_module(self, fullname, path=None): + """ + Return self when fullname starts with root_name and the + target module is one vendored through this importer. + """ + root, base, target = fullname.partition(self.root_name + '.') + if root: + return + if not any(map(target.startswith, self.vendored_names)): + return + return self + + def load_module(self, fullname): + """ + Iterate over the search path to locate and load fullname. + """ + root, base, target = fullname.partition(self.root_name + '.') + for prefix in self.search_path: + try: + extant = prefix + target + __import__(extant) + mod = sys.modules[extant] + sys.modules[fullname] = mod + # mysterious hack: + # Remove the reference to the extant package/module + # on later Python versions to cause relative imports + # in the vendor package to resolve the same modules + # as those going through this importer. + if prefix and sys.version_info > (3, 3): + del sys.modules[extant] + return mod + except ImportError: + pass + else: + raise ImportError( + "The '{target}' package is required; " + "normally this is bundled with this package so if you get " + "this warning, consult the packager of your " + "distribution.".format(**locals()) + ) + + def install(self): + """ + Install this importer into sys.meta_path if not already present. + """ + if self not in sys.meta_path: + sys.meta_path.append(self) + + +names = 'packaging', 'pyparsing', 'six', 'appdirs' +VendorImporter(__name__, names).install() diff --git a/venv/lib/python3.8/site-packages/pkg_resources/extern/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/pkg_resources/extern/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..7e7a5dfd037ec1ea9a00593e5df91630a44d0b00 GIT binary patch literal 2406 zcmZ`)TW=gS6t?HSlS@k<5?V@Sfl9T|Bv8slqM%l7g(^@~wNPMH7){sSWRlsLiS2E= z%j^pq@yG)b@6BWX20z2EJoPUiAvnjgyGaw_(VVfzw{y<-`SZ6+OEH1+$;X$|KU;+S zg^lCIg~m;I)m1Q@aGH}2`I2yly9b236Q@JD*Kq_Du5c#KbMKH)81;~}{g*Iy2I3S&fFY+b$wzvzs zoHfgjM8QjWuV0l?3pqN78I)V>{@wfR!}qVTzR)SFQoYTx=@8Z{CF^Ac&x$QpRyr$- zG|z`?Pwhg2+XY}qskepP&y-+Ast3}J$qJ>RA~-DB-A%WIVm(>*nJi146lq_q+u1K5 zaPL^uSjYD^yy_h=HLXcPG_9Qp)|}d{F4gq8%PDsb9r)vM0^zxvCJ@gctipsz<6ql1 zt@&=oRYIHPndjC6WkM;cJnae-Hyuf}yVdrLr$pY90qia#G>E)JIIQ{m)`sp^8&y`V z4GIiS@U{JIA@a2kuJ3)ccdeIiz%q#xsvO9!P#cY38%dHCnNE`RYG|Ta1D95~6QKc( z>1g%QDTwfT5Kr z!imU^4eVlWX9bfnXTYb>0JJeciUA(d$L`o2dt<+Lp=Wk_juI!AA&kv-U|JRImEk$E>@sdz42|1QD-$P&fz%q~5the*9_dkM7id?X8k=0H6dDN{RM%{5m*K#$g@WI=w+^Up|If-%Is7i z1*F&;WK!_YSW(J8s@{|Uiai+=9JSA~%Ccgrf=rbx>#<=uV8|!iwV%oY6!t3XmW3MR z&GDR$2XVEdCF7aWGJ7&W_N;HVV|fnTYeecbsF@g~!s>RCfY=Q|+!_ifvk2)>Fbnjj zSDJ<90=O$>DNO(h-%qs(Fg3YqN6n!|O_8soIgjQ7t{+rV^s;AGX466gZA*TNdYINJ z_1=a_>MbzDTLEQrXarA8<6zl-!8#5NT<;&}-&2Gn=Gy&NLN~kX; z$=)Ef$_1@3NqE^!61jvvMU^ZoA@xuqA>=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*, !=3.4.*, !=3.5.* +Description-Content-Type: text/markdown +Requires-Dist: urllib3 (<1.27,>=1.21.1) +Requires-Dist: certifi (>=2017.4.17) +Requires-Dist: chardet (<5,>=3.0.2) ; python_version < "3" +Requires-Dist: idna (<3,>=2.5) ; python_version < "3" +Requires-Dist: charset-normalizer (~=2.0.0) ; python_version >= "3" +Requires-Dist: idna (<4,>=2.5) ; python_version >= "3" +Provides-Extra: security +Provides-Extra: socks +Requires-Dist: PySocks (!=1.5.7,>=1.5.6) ; extra == 'socks' +Requires-Dist: win-inet-pton ; (sys_platform == "win32" and python_version == "2.7") and extra == 'socks' +Provides-Extra: use_chardet_on_py3 +Requires-Dist: chardet (<5,>=3.0.2) ; extra == 'use_chardet_on_py3' + +# Requests + +**Requests** is a simple, yet elegant, HTTP library. + +```python +>>> import requests +>>> r = requests.get('https://api.github.com/user', auth=('user', 'pass')) +>>> r.status_code +200 +>>> r.headers['content-type'] +'application/json; charset=utf8' +>>> r.encoding +'utf-8' +>>> r.text +'{"type":"User"...' +>>> r.json() +{'disk_usage': 368627, 'private_gists': 484, ...} +``` + +Requests allows you to send HTTP/1.1 requests extremely easily. There’s no need to manually add query strings to your URLs, or to form-encode your `PUT` & `POST` data — but nowadays, just use the `json` method! + +Requests is one of the most downloaded Python package today, pulling in around `14M downloads / week`— according to GitHub, Requests is currently [depended upon](https://github.com/psf/requests/network/dependents?package_id=UGFja2FnZS01NzA4OTExNg%3D%3D) by `500,000+` repositories. You may certainly put your trust in this code. + +[![Downloads](https://pepy.tech/badge/requests/month)](https://pepy.tech/project/requests/month) +[![Supported Versions](https://img.shields.io/pypi/pyversions/requests.svg)](https://pypi.org/project/requests) +[![Contributors](https://img.shields.io/github/contributors/psf/requests.svg)](https://github.com/psf/requests/graphs/contributors) + +## Installing Requests and Supported Versions + +Requests is available on PyPI: + +```console +$ python -m pip install requests +``` + +Requests officially supports Python 2.7 & 3.6+. + +## Supported Features & Best–Practices + +Requests is ready for the demands of building robust and reliable HTTP–speaking applications, for the needs of today. + +- Keep-Alive & Connection Pooling +- International Domains and URLs +- Sessions with Cookie Persistence +- Browser-style TLS/SSL Verification +- Basic & Digest Authentication +- Familiar `dict`–like Cookies +- Automatic Content Decompression and Decoding +- Multi-part File Uploads +- SOCKS Proxy Support +- Connection Timeouts +- Streaming Downloads +- Automatic honoring of `.netrc` +- Chunked HTTP Requests + +## API Reference and User Guide available on [Read the Docs](https://requests.readthedocs.io) + +[![Read the Docs](https://raw.githubusercontent.com/psf/requests/master/ext/ss.png)](https://requests.readthedocs.io) + +## Cloning the repository + +When cloning the Requests repository, you may need to add the `-c +fetch.fsck.badTimezone=ignore` flag to avoid an error about a bad commit (see +[this issue](https://github.com/psf/requests/issues/2690) for more background): + +```shell +git clone -c fetch.fsck.badTimezone=ignore https://github.com/psf/requests.git +``` + +You can also apply this setting to your global Git config: + +```shell +git config --global fetch.fsck.badTimezone ignore +``` + +--- + +[![Kenneth Reitz](https://raw.githubusercontent.com/psf/requests/master/ext/kr.png)](https://kennethreitz.org) [![Python Software Foundation](https://raw.githubusercontent.com/psf/requests/master/ext/psf.png)](https://www.python.org/psf) + + diff --git a/venv/lib/python3.8/site-packages/requests-2.26.0.dist-info/RECORD b/venv/lib/python3.8/site-packages/requests-2.26.0.dist-info/RECORD new file mode 100644 index 0000000..df77bf0 --- /dev/null +++ b/venv/lib/python3.8/site-packages/requests-2.26.0.dist-info/RECORD @@ -0,0 +1,42 @@ +requests-2.26.0.dist-info/INSTALLER,sha256=zuuue4knoyJ-UwPPXg8fezS7VCrXJQrAP7zeNuwvFQg,4 +requests-2.26.0.dist-info/LICENSE,sha256=CeipvOyAZxBGUsFoaFqwkx54aPnIKEtm9a5u2uXxEws,10142 +requests-2.26.0.dist-info/METADATA,sha256=hWaDQ1HOaMvAc-KaJFZgv1-fov-CKxGSwEIsZGhiBB8,4753 +requests-2.26.0.dist-info/RECORD,, +requests-2.26.0.dist-info/WHEEL,sha256=Z-nyYpwrcSqxfdux5Mbn_DQ525iP7J2DG3JgGvOYyTQ,110 +requests-2.26.0.dist-info/top_level.txt,sha256=fMSVmHfb5rbGOo6xv-O_tUX6j-WyixssE-SnwcDRxNQ,9 +requests/__init__.py,sha256=h2SCZm8MM-UeAS48UuY7Lz97fEqsma6g6oVsKUi0eyw,4907 +requests/__pycache__/__init__.cpython-38.pyc,, +requests/__pycache__/__version__.cpython-38.pyc,, +requests/__pycache__/_internal_utils.cpython-38.pyc,, +requests/__pycache__/adapters.cpython-38.pyc,, +requests/__pycache__/api.cpython-38.pyc,, +requests/__pycache__/auth.cpython-38.pyc,, +requests/__pycache__/certs.cpython-38.pyc,, +requests/__pycache__/compat.cpython-38.pyc,, +requests/__pycache__/cookies.cpython-38.pyc,, +requests/__pycache__/exceptions.cpython-38.pyc,, +requests/__pycache__/help.cpython-38.pyc,, +requests/__pycache__/hooks.cpython-38.pyc,, +requests/__pycache__/models.cpython-38.pyc,, +requests/__pycache__/packages.cpython-38.pyc,, +requests/__pycache__/sessions.cpython-38.pyc,, +requests/__pycache__/status_codes.cpython-38.pyc,, +requests/__pycache__/structures.cpython-38.pyc,, +requests/__pycache__/utils.cpython-38.pyc,, +requests/__version__.py,sha256=PZEyPTSIN_jRIAIB51wV7pw81m3qAw0InSR7OrKZUnE,441 +requests/_internal_utils.py,sha256=Zx3PnEUccyfsB-ie11nZVAW8qClJy0gx1qNME7rgT18,1096 +requests/adapters.py,sha256=WelSM1BCQXdbjEuDsBxqKDADeY8BHmxlrwbNnLN2rr4,21344 +requests/api.py,sha256=hjuoP79IAEmX6Dysrw8t032cLfwLHxbI_wM4gC5G9t0,6402 +requests/auth.py,sha256=OMoJIVKyRLy9THr91y8rxysZuclwPB-K1Xg1zBomUhQ,10207 +requests/certs.py,sha256=dOB5rV2DZ13dEhq9BUa_4hd5kAqg59e_zUZB00faYz8,453 +requests/compat.py,sha256=0fzHbLvfnFi2WR0o7XkrvXlElG0_VgQmmOgiooaXh_Y,1852 +requests/cookies.py,sha256=Y-bKX6TvW3FnYlE6Au0SXtVVWcaNdFvuAwQxw-G0iTI,18430 +requests/exceptions.py,sha256=AiGbnc4Z7wjlpETMcTwmsmYvZVep8Qmsd46_yp0h0mY,3238 +requests/help.py,sha256=ywPNssPohrch_Q_q4_JLJM1z2bP0TirHkA9QnoOF0sY,3968 +requests/hooks.py,sha256=QReGyy0bRcr5rkwCuObNakbYsc7EkiKeBwG4qHekr2Q,757 +requests/models.py,sha256=BtTPURThE_VpZZmUfDguGhZj5qUmqmY9rk9pIU3w3X4,34859 +requests/packages.py,sha256=kr9J9dYZr9Ef4JmwHbCEUgwViwcCyOUPgfXZvIL84Os,932 +requests/sessions.py,sha256=57O4ud9yRL6eLYh-dtFbqC1kO4d_EwZcCgYXEkujlfs,30168 +requests/status_codes.py,sha256=gT79Pbs_cQjBgp-fvrUgg1dn2DQO32bDj4TInjnMPSc,4188 +requests/structures.py,sha256=msAtr9mq1JxHd-JRyiILfdFlpbJwvvFuP3rfUQT_QxE,3005 +requests/utils.py,sha256=Ws5IP5Z7KdFkWNlMkk8L6M3iXaDwBt6CLwgWq8yXSF4,31382 diff --git a/venv/lib/python3.8/site-packages/requests-2.26.0.dist-info/WHEEL b/venv/lib/python3.8/site-packages/requests-2.26.0.dist-info/WHEEL new file mode 100644 index 0000000..01b8fc7 --- /dev/null +++ b/venv/lib/python3.8/site-packages/requests-2.26.0.dist-info/WHEEL @@ -0,0 +1,6 @@ +Wheel-Version: 1.0 +Generator: bdist_wheel (0.36.2) +Root-Is-Purelib: true +Tag: py2-none-any +Tag: py3-none-any + diff --git a/venv/lib/python3.8/site-packages/requests-2.26.0.dist-info/top_level.txt b/venv/lib/python3.8/site-packages/requests-2.26.0.dist-info/top_level.txt new file mode 100644 index 0000000..f229360 --- /dev/null +++ b/venv/lib/python3.8/site-packages/requests-2.26.0.dist-info/top_level.txt @@ -0,0 +1 @@ +requests diff --git a/venv/lib/python3.8/site-packages/requests/__init__.py b/venv/lib/python3.8/site-packages/requests/__init__.py new file mode 100644 index 0000000..0ac7713 --- /dev/null +++ b/venv/lib/python3.8/site-packages/requests/__init__.py @@ -0,0 +1,152 @@ +# -*- coding: utf-8 -*- + +# __ +# /__) _ _ _ _ _/ _ +# / ( (- (/ (/ (- _) / _) +# / + +""" +Requests HTTP Library +~~~~~~~~~~~~~~~~~~~~~ + +Requests is an HTTP library, written in Python, for human beings. +Basic GET usage: + + >>> import requests + >>> r = requests.get('https://www.python.org') + >>> r.status_code + 200 + >>> b'Python is a programming language' in r.content + True + +... or POST: + + >>> payload = dict(key1='value1', key2='value2') + >>> r = requests.post('https://httpbin.org/post', data=payload) + >>> print(r.text) + { + ... + "form": { + "key1": "value1", + "key2": "value2" + }, + ... + } + +The other HTTP methods are supported - see `requests.api`. Full documentation +is at . + +:copyright: (c) 2017 by Kenneth Reitz. +:license: Apache 2.0, see LICENSE for more details. +""" + +import urllib3 +import warnings +from .exceptions import RequestsDependencyWarning + +try: + from charset_normalizer import __version__ as charset_normalizer_version +except ImportError: + charset_normalizer_version = None + +try: + from chardet import __version__ as chardet_version +except ImportError: + chardet_version = None + +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') + + # 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 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, < 5.0.0 + assert (3, 0, 2) <= (major, minor, patch) < (5, 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 < 3.0.0 + assert (2, 0, 0) <= (major, minor, patch) < (3, 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('.'))) + except ValueError: + return + + if cryptography_version < [1, 3, 4]: + 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, charset_normalizer_version) +except (AssertionError, ValueError): + 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 +# 'ssl' library isn't available. +try: + try: + import ssl + except ImportError: + ssl = None + + if not getattr(ssl, "HAS_SNI", False): + from 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 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 +) + +# Set default logging handler to avoid "No handler found" warnings. +import logging +from logging import NullHandler + +logging.getLogger(__name__).addHandler(NullHandler()) + +# FileModeWarnings go off per the default. +warnings.simplefilter('default', FileModeWarning, append=True) diff --git a/venv/lib/python3.8/site-packages/requests/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/requests/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..388e40a9ca05e18ba76caa1f470f680e022920f8 GIT binary patch literal 3850 zcmbVOOLr8x6|P6WTyDP&*ua1=19pSmHs)=>Jk2A+FdXm%MknVK<(6z0U8<@`YD|0D zS;WaQ=gd#Am-!=EWR;U;ZL?yNA25p~_f}OmJ%=oEQhoYLy1J6?)&2BI-wzEr27DiH zp7SnF7{))a(f?uZJ@~88G7M%=gPF__b1>SqJhXY?&@zpD^>@3~)c-L$*5~Cvduxwnc6^+V zu|Zbdw|_F#c^EMiOo&N3X&QX;;K(6Hgz+AQD2{=y%8%`vsYge%xPLO`YBpyci^+zA zDKSl_!P+`F&PMn&dIftp8kEEddP1C}C&gFvE10pA>c>ETik=du>1jbI5ohR`R6h>- z89F1*(z9uMBKTUIqvz84B-GE-^J)D^Fe~QhoT$;7xIizYx}(8GF;C~k0$mVwS{I9S zQ7q9Vafx0M%XC>>rk7K@W5E@1m0lIs=(V&x6-;S-#+KFv9E|1Wen?)n^>!4_lg&ty?Un%34ep0qs_s1Sl;0pv*49Z&d0TwNaR?!+tE6UUE5#y*_URvt* zZOmq#5%izLGTM@!5a1aJyl|@p4$Y$bvfhY72u0(#b=l&MQ?J(v1oQH{*Xy5sj=gpe zc??`+enZbSdHd3x*$-aO;+JOU2{f1U=5n8V{QWc^?+wemSXAyf~4(4g^PQFYp z!dUvDo|ARWKk8KZBl<}Q_?T5@VBf{e3d!|^%%E$an8}=*na}L9j^$p*@=T`R%lq>Q z_Z(+^o0CXybD8B_aL6x%J(QfNR*aeBj4TkvIeFJjVcm=UcXjf(6$FGujh287^|T*_ z4(`4tx4W6_4UpVpum~8dx*x699cQHx#ck*Qh}*FI^`aZSoBdL-2vT;=bOk zJ1c?T;GyCxqCditZOn1-0 zBOddR@vzZ;-NTV~T% zQ`-E!sjZH&Z!)`S$vW5otK+%s7{9Ui?7hNXQ5QP)z6r9B%HqCh8#*+i05dugqy0>Te-j-WV>0(ZY=%RwmMG6PXg6`zVdMVe4M)n^vD;`0zx>|XyNYLSowYymilA?+OUnj%&mEsZsy(VQO6FcBxQu1QNPh!In zO$OFJHh7E{FlwYF1K`TbT_`0Z`P@Cl@h@HI^%aHp9@Z!VSz!@-y0QIdLry~|KVMzc zB3_LBc%c;n{F|ID>}+!$EV#=7+qfFF7P}{G(RKaM*RBi9nM}YzX*7W*1wfp+Tv&X=4193Y7>?##NW9$naOiKP1V2{@d$$;x>UkBWElM&Zt zTs5Sh!WqNWoW)(YW+g*FwO#Iq z-U>9mCaeg)6~@=uHpzTgJk5T8j}KN%8Dzb|D^mntDqP7zEFUj(R}*eVNc5I zzTgo|HTeCj=h*9m6Upd$6n*Q3?N^*ZyP;JwfN!o0Un37AxX~J)*<|FgAMkHsiToN$ zhI5PF+^@j-yaDbEzJPo7sTZ<<%cRWsrq>Gedd-xhn1?5r7r0kpC(AjOM6|ZwZ+)Pvthm)(ZG4vb5R+Q8-&MD`pi)XB0@s z>6MjJm8xZq!>?i%;4NbP+p?^GIc3YV;4(nVVJItbMO0yA2}^4Vh-);xEGEr4&{oa) JGR{42{|8B6B0B&8 literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/requests/__pycache__/__version__.cpython-38.pyc b/venv/lib/python3.8/site-packages/requests/__pycache__/__version__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..24f4c3feb947d61fe3d3607243df708c81989619 GIT binary patch literal 507 zcmZ8e%WB*(6xB@T;c+sww2N#4)h2;J#vTkUZ7C(Cn?NCiJT}@0$M-fCV_U8sZO8x6 zKPY6I?7Ho*%rg0bth?%UUL?6fmvhe55%)?*<8jC+e!g2z|8^L=Y{|nQjcwDmTa0)yW?T4$Tpy}8SE#di)5_xM+B z_>M2r%0|tr+_~DmkK?pEW zMlr1rX>-zqpXxNrktfl#S^KQ(xlt#%RLK9v5KI2!Xzy5FnyPM%+B&AcX zKq(i`qy)5?QMFULB4H?{HwA%ZDZit!H!3-fy()n8P|DQPoQCl8dyHkOZe4}Su(Ivt zV=1${-iQW7(-{@cnQ7a)PXFG$fSVd*V^B|TKu4+sGcu^ T52XfQ;KzRZbuTFOI#1Vsd7ho` literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/requests/__pycache__/_internal_utils.cpython-38.pyc b/venv/lib/python3.8/site-packages/requests/__pycache__/_internal_utils.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..8431975e27d3a75aa1b1f20536ca01a18d1d0d93 GIT binary patch literal 1272 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 TGsUIC{A%&m{L=jGqWkwh#l5~c literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/requests/__pycache__/auth.cpython-38.pyc b/venv/lib/python3.8/site-packages/requests/__pycache__/auth.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..ea2d70c1f665a6eb70610326bcd68ae8d5afdf43 GIT binary patch literal 8291 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 literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/requests/__pycache__/certs.cpython-38.pyc b/venv/lib/python3.8/site-packages/requests/__pycache__/certs.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..6d73935e9ef97c13d2a7609d755e460d6140e494 GIT binary patch literal 573 zcmY*W!DlbPzVx;x2UM944r z6Ml$4F-JZ53!dzm9YG7a=z8>fRj=#g(UBA>9$p>m@0k!k`{LioQ}H$(f0B|BH^O8l zud^n<$uofm=HNEx=QzRqQ9NduFq02rK8+ViN-}^t@Y426Ke#< z5ScuLEkes!Au}28Rd;BZMDcz77)oy<*o4 z#Ylx#m$!O@g_M^S>|6w$*n7~@2Hua;E&z*7v4F}kXn1ESK7g@4uwBPs9l?M%nv#~0 zNOzVUHArDGh?bh5+-ln3&^%eNWcR!Z?)!;f%pthZaq8f))tqeAJ2_5hdc&hh`73?9 zm}lK|;C3^m8f{6btNFA$RLZzgsqS#}$o;nZH>4X(__Sq9;hW%D!iV(xbQPL*)!KF$ tsqcqonUt|!s?*x6U%I&ZySCM^wxZp2v)B7Iy_qB#|0Jc!(`WfC`vc`rv&jGe literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/requests/__pycache__/compat.cpython-38.pyc b/venv/lib/python3.8/site-packages/requests/__pycache__/compat.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..3182fd7fa7babca13740e4403f4d68508ccf035f GIT binary patch literal 1667 zcmZuwTaVjB6!tBS<2cFQFEn)1%TfZnN!e`?NEJdVJoI7PN(BM)VmbC?GrKb$@65Pu zR*2ug-{2qcTjrIgm3ZKpC(hW}63UJ>pU-9H_&dkveBbGW7Ob~l?k7*0mi32GmRA7E z*RbVZwq<1&vM!^{&KznZ`v)uUdlq)iLvdhR=BYd`vVXF2=f_&}kcYjq2J*3=*}GQe zo;#?ykUfxtMZ6XYm*V}r6fZzinT4if! zjjf|~wt+S(K0e)Kn`o15p)IzJw%HEaVY_Iz@-^uP>=wGU;N3@kh#k-m*==;YvbE?Q z+e3Sm9MS>1gYK}q=q|g5?y>vmzHQ-s^bza__+zw>hiHgD!Jp!Tsf!McGg2-e8;$Ue48w=YyjG+zA)T@hH49?f3l30labnhArK= zD7nJAS?0A6R-#g3pVM7NHxJZPAxFD5zEjK|v<0P-#vVbhLVUXdeNKS{g?p4R)nNmeeiBw?n zPdG%OAO)|KAo=OD7eh}6PZLU$356t2lA-{!?w*v&Sg!T<3z1=gvu{YMhN0*{X++mR z&%lZSGpxch&@kW|fT6a;D!{NI){NXTV1{0_4MYGyrj>GjPViYGhPK!-HdkyK|CWJm zWB6P*<2d7K9P4H}OMs2i?Pt}G{#FPs(3-JItm2#tmQZqug?8l}%KsV*Nq8QUe9E;K zgQ|TZ<6?facpsxsLeEfqCV8&C3Vo;~C6gNysxrMHlN-xovWMoWq8(L5xK0l=4LBPF^xBNE)ko0k=AE0H0#9P@|gZsBW?DLR*ZX_DnO0UBfdnB8;W^aZ)>k z>)sOcQ8Gz?v&0uBEdzfaj}$MQG@Cr;<@kEk$MxKfin$J+ z)RX;{8AbULzzZBZvb%QI37WnexskKbecwKC```;;N6wDx+4U3Jq2t>RZR0bZ$lh>j IPXK5C0ZD_+^#A|> literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/requests/__pycache__/cookies.cpython-38.pyc b/venv/lib/python3.8/site-packages/requests/__pycache__/cookies.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..4a0d146b1b7dd43a68625578d8e7a64794a215ea GIT binary patch literal 18786 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 Mj})EZcaqNj3w58MVgLXD literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/requests/__pycache__/help.cpython-38.pyc b/venv/lib/python3.8/site-packages/requests/__pycache__/help.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..c48ddb787fed8c516c36989465a0188bcf961725 GIT binary patch literal 2845 zcmZ`5U2oh(&|ZI@<6J&U(^9@%piNIoE~2GERDcjApj0%8nih(MWSrYg&KI9;)_ZL) zT%@A(6~qJLsSoWV|AYtLk@l6RzVn1o%goxBCaE~z&g_h5XJ%(-#(QgW($nB~@BMS} z{V7fR3yH%&7l@Bxl(w#ER0}n#Qc4#Z?gpR^)=u(qf zX`}Cj6S}tRE3O~!9HRXs|&; zcA#?(I1X^`A8<_S?&%|Kq|?Sj0`c(TKVd&Nm>BRZhy$8*L~u6|-9U6%us#&sJPVS3 zk+MF6aA5#~IHN(m^S0*&@LT8korJPrGp`qBai1wU)Kbd^`PTm{Rcbl|&cRAL4EP|! zgJ}n!?yGa?0Pd2!l^PMu-WTiN43b(sHTpwNuk}N1B?Kn&zy` z=D{UU6KsLw*Q)TrY=!4pQpEEP$yILL~) zv%~1(-7aJ4VstU3o0s#!5@+8HAo%4HR(rb`%Bf?!cnhobJOFLNC9dx2E-(f0^7s0rApu_+u*;jN?I8p7oqC|6M?Hf(Bx9ZNL$FQU=2sRPjK zP0T@?Kt9O&Vv@Sl+BZO}t?1?f?TD$~#GXry5w@HL|ARUscMe)RwLrRoO=Q#%)A&xH zggdfEWMqzvkv(!i*Gz&<#>XbJd;W8lF&+!ddrZ(O>oIZTL*2IxhiyZ?2-cTQoeJEC z=MWP(n|M4*GO>x?*&? zF)x{jAP@U-n(Q(jLNi~3X1=lUg>(iyO_R+_(m^@Ogq(eGf%H3kScrU^$3=H2&4gyL zbjNAdnyox~9o>2Z-EvmemN|!l#>C-oB0$&q+XyiEq*L1u4Rm5|ZGCwaCefG6H#Sz* zR-@Hh*FRalA)RdoO<8b$4i{p=LcNtKw{SK+wm%M0%L^yRM*ik) zuyLe@(WnhW)$kdZ2uTc)&>255d|o=J-i`bDXHt0HqeMt!)# z`~d1o)Tt4E8K88d2>Ea?IVGJaqIoBZq!+;*20uMf#8H@ELZC`z7H10xFomjo#9FJ8 zauH{knQ~&KkC&t>bumq$rmE^_<86v3n=12o3s~ms08{s&{i+8s@!{xwy{UVL@HEgSCICtp?pgOk*YfoL02;>#nE(I) literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/requests/__pycache__/hooks.cpython-38.pyc b/venv/lib/python3.8/site-packages/requests/__pycache__/hooks.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..d89ba531aff87422e67eb1d8ee67eeed713b128b GIT binary patch literal 944 zcmY*Y&ubJh6i(*XPNNkR!HY;dC~Tp#Qc$pzqS!;B(t=wrg)*B?vb$ktccw|Ub<3=m z_Uy%fK#v~%cXIV_@Z!mrbW68yc;95cyu8WxW#;qhDnSrm-o9Xe1BCv#hvfhcy@S-x z0602A91rjj<^d0{&{4o69>YE4Nf)(S7r%)Tr&FPg&W2Sr(&X!%Amnf;H62%cS_)dL z>P&K>sTm4du$rC7QW^b^<;8#3muVo)WsQCR+4* zn}k9fLem?L4#Y$#W(22wRgEd5i_RIb=}l1q0`G*A{sB@y0N^0`3K_J6E-^?A_Y1sK z>`EiZE~I`0AW?&k$s9L$fW8N(Q5XF}%2l-k8)UC+EY8Hlc*euOjgA@Dom$rG(@D*W zk>Km+Lm|rbe52$iud8Y2#@UY7oYgZ+wzw=zQH|?u_fDMvBq)IE;yD+6HZ4tlUA$FR z1uOM-cDtgDZM=JMu-Coa#PukKE_U_K`iHK&+daZ61uQ~0UW9wA)4m6(KLRwkP9$>L ze}D@=u^Xvf1IY1Zpk9I}p4&mkPv=n+H9;RY;Ws>wo0tcq6}8sH^Wb!?37pXvZ+4`v znJI?wVK9H-)XA3BgsB;=CO{4(xJhd%3PGzr<;<|mrg;vU%RJu)&%=Q*wl!p$8Kc^X z4M$>TV{eXKaktzpvdQS2se!hUqb%|6`I#k?7XB5lWLtU8t0K=;3kdI{pIU0|ELOgMx^?}NY&)m@!AAFzFirjgzjW_+ literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/requests/__pycache__/models.cpython-38.pyc b/venv/lib/python3.8/site-packages/requests/__pycache__/models.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..7b3e99740fbe729025eb0b51abca3e394ff8a55f GIT binary patch literal 24428 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 O#7(e^w;kW^b@4BbZ?-M~ literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/requests/__pycache__/sessions.cpython-38.pyc b/venv/lib/python3.8/site-packages/requests/__pycache__/sessions.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..284c09bd4c68ebc89e2a2194f575e5d5fd6b85f4 GIT binary patch literal 19887 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 literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/requests/__pycache__/status_codes.cpython-38.pyc b/venv/lib/python3.8/site-packages/requests/__pycache__/status_codes.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..0f9313a48a4ad6e350b9e00ccc77ea9f904a5852 GIT binary patch literal 4199 zcmaJ^U2q&n5#HVV(djH%k}dzlV6uRXk+CHIh1kX@0qhV+FsZWP!Le(#+Mc`HXm95{ zJEy;rd9kZV3KB>R2>}Oes`xPl#RG2?FTe}`@H~&<$SPbbzL5hGyv?9iqc@gpSf9^kI6Gj?r;CK_8)$^ii6l$LMkT7=4^RL8s_6Jwczm ze(HQdc=RNF>P7c_kv>gNU3JcvMCpnHE1y2=OnoNY>^V;LTtoQt^N}Qx&CmOC;W-g$ zpF}NAMdpWoGilGZ2FOGHf8FkVH3QXRQ{9a&OPI2I@Ik;)O)`B8H6eLnzl;#S3i>T~GxA#gUF>8miT5tVJ`Msa8*~gw0kW zPMoM#ef;L;=KQ$Xl1lqZTxyFlc z?KqLkc#XnL_)9`%a2rvmRS}y`cta)pFkvy8@t;6|L>`I*-QAjzi}UmS(Py9H5tgcU zb`$(?67v-|#Z)r5>p+3-{b?5wbck0NG5cL}CshfqJ(3YCt-q{kWR5T=S|#BP3& z*Mu4Crb3snsn3qh=6kp?)*lZOI7FPXoaENAp|}~Kyx7O_-h`+jW5j!^U?!S!Nl<{q zYKAH7PF79Hk~mh=m{h9CcFIv1&V&e%hC-Q=eSkTVN*y#M#kJV3FpQOWV^>z0neTOH zTrgWUmXsOm)9k8dxJQ6-TY6^oiqK3TjOY*85wsIji58}ulVIbfg^(a>OWPDMU^Cij zXD`?6?vA&@)h0Z(awu#vh`*&kco=PIAtn+jd(7Th_ty&32!?02GzGGP0%mlo%WN7L zK*MG`w8<2rVZn>tHXt^kuq^r-XG?!|&i$2D%Qln!_r56B9qVSjj+;WZwHfNXU_mag zT9TJqu`W|Cv#~^^b=~MK0u@_Z=wYbf*sfj+;{=|M3=%PKXLlW5U9aY47pgkz+}7pw zD$g@#hMEm zg(P}AXNEcyFt-ivR!>4b#!c5V6Wk+F#9aOP*=8zT64*N$=nO&ysMLhA{?3~5w^JaD zoQ4+e_?a+8v^@c0RSAvb5DmP+%?$4#?petF4;Gk{l3dOLv@=Aj)8G_3yqVZQ!qnX; z%q8TZ4KM00NJJfz(7`gSYew%Gasoz4481{=Nc6L=muQ;Xa8L-9Vs0iBj>AAGB^CP5 zz-X;7D=&0f|7%b-#$}4TKq9yo*yd%MM;+(Ea>$--<>}~>!GM`&)4+hWbi{*hIeKPS zL+e)1Ih6B^?iPm`8RTL5j-^n=AzTWROa`f_OPmY1(10}=qo``NII=Eh8dniip=Wk3 z;EZ053B{en%~%IwB@%*A%fmemrrX9WR&Wx5#if=Cy)4z@1G~`3pa4$5`-)GUx=l#7 z+k&CSP-j?U_zlBv8Ggs`dxk$S{E^{L41Z?$3&Wd$_yBGT@ifB>!z{x=hC>X88ICX< zW%w$?%M7nDTx0ke!`B&JWq6I@8w{^Ae3Ri@4A&XnVE8t}cNlIk++_GJ!}l1z&+r3= zA2Qrx_z}a88Ggd>Q-)tK{F32U48Lah8^hlj{=x81hJP{qo8dnUcNqT5@IQvT3~vFD zsP+nsrhwZnHm}Gxx^F95W2!@cR8axNab;9YhuyX!9A_h0t3rwi-e zx^t!AI_utzBDpu+Y%-_bDBW~&&ZWsq74oQX)p^0uWpWmW)e@e?9S#+541Lk5x%?4w zwW2H9xdP2spk;@XdiY#{G%o)`XQsS6?u9$1i9pqi>cmPd47H` zzC6y{;uh%595imKp2q|WcaG2MW^1+;x2DmyL+;bl%MBrt>ELie3y;Y5Y`0g=4(`EB zYt;;&tcw(C z6){zsZ-F>4?8l243IaG71nNbeSI+WVYQdU<6FSz3$V|yTbCa$?E{{yfTCvEM?F2aP zxLa{Y+^Re2RffuUEAFnhik^2@y#d~tsj_+2EcLVUGgYrL{(r3tIW7PI literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/requests/__pycache__/structures.cpython-38.pyc b/venv/lib/python3.8/site-packages/requests/__pycache__/structures.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..62478385409f89a5677d7300db9daaf4434e1587 GIT binary patch literal 4412 zcma)9TW{RP6&{j%p>`$3jUB~K(w0D)t~ZcYsnPV3DnbM~ZJZ`b5jzFCiNU2fBZ(H5 zq-SQOXtC~#4CJl9L4MSa=-=oAU;C855TIzkGhFV)TD7IbA!p~zxqj!&;a4jw4TkI6 z-@X(4y~)@=X)=3NF!>0#x{ragF5?!rW2ZHsY-S7N7M=~nvHZq;IcV7$s}&l#_Y z>bcXcVP5Ah=B}t??((IFtlb!X(U9WlKq##`O3Oj02U4iUU$0(`#{EDC-jvAGM}hXT z^i)Xi%aTXqd#J|RR^I$Vav=r3ABFmRi+;27`sYEGMaf~l`uRWy`>`0$L)tTYIhcHe zTkT^ItZTton_FFnzfNX8x4M%7UA@pSnLU&V8Yzrt_e+2B9o zuj1L{H~B3*m-%aa4bK&B!wt9do4bJ$4-zF373t_iklMjNpvR6EVr3(mE_uBk$7-*) z5l6?uOZT6MPbg==Hon zd8Yy!@gx~71z};Do%MPhZzoo%*_X-mB;tbBV)DKpY0+08DRkJu{$p_lsZx02+YH(X z?&;Lq7Zg4CUv<1kM`lvQ+mq0_zb~XhOofp_Mng}UdvTyNaV&WVy>2Y(^&nW@g==(> zgreQ+t&i;@@pows6^(K;6FFTZw-ih!M25j>1QWtE(Lt0H?w`cPSl01Af!!xUu6uy4 zJcCI_q45@Fm}p>{79wR>cry|F;Df?b6tOVk-iO|T=-+J{He;HvTRUMWGTnL%>K0%e zN1=)4<`b1Bt$EU5clYBzJtERYw4V32_ec&3KNI^nQu;3RXcPU6ppwoo|9vVE%z*Gk zUOf^4(o22aBAbD?4UvQ?hrO-GfRS;a6v*Xd648?&9+;2@*xuS5Z~M61hFwVf4Db|Q z!F(M*90rodLKPkb9FEdc1BrsdOM<@eP65_bMu$-X$e#gXDbl{ohXO%RvZxy=LI$7? zG9G9__#msE4uUw+XNY(|3uFX;8jEKVhLC)StV{}Eo5FJxoB-ammpGb4Ae5=~iN*T@ zG!Y~K0)vE$gD4@z$mM&XjmlD9RBq`0BX0F`44R#@5%aAP3eT}CZ$<2xHDXWfk#%5= z?7vy4w(KFhwD#JLBu077H)iLx!m_rLSCohk@(Sz>^4jrfAP?0glPe(p;n$nGpKWGQ zwlPSuAUqa)~c*DOJ^ZobJ!Dd;KH>cIMlbz+R??*|beg9oj)WyIo7k?FN_|^gh zcS`b*j4LmCr-Nh{w_3w6f=LH9%){G-^@42~<76F6m$oD+dDXZV#?tweJILU?YVc$X zDuz{BYWltsnzGsV-@^~exY-&0bg_C9+PQGh9@5fi_$pqey4}H%cL%O-+k28o}S?9VENC?Voz;CvI(|v9gu5x z-pgI8|D597?4#HTzA)NLTZbaS2_v_+h(DpK!fI@|xj5Qzfb{*&R-A@GthPIo-R&{V zYDS8>w2F9AvdmzM&~G^Wj)WOtU5|T1IOhuTA8p#D-GmoSzO%?{#(eZAPAn1wc==JXz#a#kuwt7O+8f7R-o}pHH3BH`H4KQyOJ0y~g37qi zMBA?Ydw6e=4-A{4G5Ie6uNos4db>HpVTX*WVPJO6asRbAd1vUaB=4l&QB6YJEp46K z@|H#toLkSVq@taNOjkziqWS`Pgg2{rJ4Sa{pre*IB2~6Jk{C+TC|})6^`z?)92FmZ zoBSD;;9pZNt0|f&`H~-TV)){z?>_+HxRN)lhF!6TZ!B_WK|B}jxq3jwx4`p-O%{|| zJ4VR@({F)hp{py@VSY)9j8T1ikqSg~MS+Q9sVZuwaY_~n%&3q%IK^a(q`!Tg3dn6K zGE|4JX4JUmOe+Z6IDA*>M5G?X_w$DD_ftNI>3!MvsV^9>Aa8jZLcl8|ohqlKN+@5a zfzm{JG*HN7n}&C3Sf^oHfy^6u**KIqnR1G=_l-u)t-8+m&vlpF!s#Js<}UITU5bk3 z+(%9GJ9c2151XY0A2!S8)5hx7ze9F+T_o;G-uNs{j|Uljr3~-Ti0_I(o_VqPx%?)X z?{X-(R3hkBl|kFgXp{mApa@%&TgEFBka>Y%m@i!&=_M50_TH zUOhC@*@SWYMhjkv)+ve+8m(_hq`AypC=*7{q!8p$44PT^!*qjbEM70P-nm@V_KC zKqEUeY|=nwu}BXCdy^i-Dqk5#H^fJ28DSIVU(yaEl7R6S+~!P0KG>@j;sDh2vQV9@^rcpMG^!BfKTxxh@|)eMcz>mj|3@cMQOR%9smpM zi#-F9*jvb#qmnpPr?UTWU7UL)pzU1wT<64FMeIJ-*+g=f==b-on58uk0&-wQX7do+q3C z<#2Kazu*UsWhtv@DO));yJ*YaDLS%G6;rZzi>~a`#kA}*#fhM_YkgaBn;hqAPt~^QmT1r=C@x#{OmXocav*uc$lfd9~+5yEvs@PKtmfn7YU#?(QSzNTJOZV&MV-eJ-%uCS zG|p$#MfE!NZ>me`GWJ*1=hWx1|AM-r-oXBvno)0Je_i@}ReeGFJFBj#>nOdU0yV2{ zpkFuDP4yN^-cq4@M-@@>wt83HLdiSoJ@r2JMO9jVSKY=4-tup$@^-8E9`T6tL0kIWR>}qnm6Cno_{~|b)#JKDrjV--eO~u`H#twGh=o% z_@-9A_SJ=ICB$i=US9S~i+&k}!N)c#eH(R3rMo!AjinOmq$|D-100Nm%~GQrR`2?y zAk@{y0?M|u$~r&`Vc06wszEq59HsB9G($hit>~IujM8(fp&vvk+!SS38s>6-!4L8F z_p7*4;K6EXZnaeof+&w0R~qKl{9HM}Q1W5XP_+^I3%)Let1aA=sRpIi>al3&=9^1? z<8DMxabXwW_*t?MgHhA77HOi?&>>*8De`%73e@8|>}VHyYZ%S8b^BT+Kh%RIAfk zH}#m)&P+D^P*QJL6v49lsSEoaH!|D;2*L;yo%& zh4$NV!9-FJrSY(1M=PAeC`zrGvu3|#HFmgG zm|D*3!?wl0cPx_g+gAHT$6j|k_EK7<9y)7In8A6r<0$tb1otk8jxRd(6Yzp8Q_YdNcb6{2wf_0sEk zl~Z{<9W`(~s0!WVA(i8CIJjQuq&rqPxHR-IrN3tGyz@0-$>ABzLAls|^?GwYya$%L z^+vU#n*q*ly@eTS-V1J>U(p&gbJNiMt;--ajrsAe`(cRT4vK?UNu$#ZPG@mQPTmBU zXmIZ%`_*>#WUW~#*G@{NA_!D!+JX&A7wB<+FyvWrTAd*a=q2m zq0mK?eY52^KJTwaTQ7Zn`km7G8`rK)&&-x?T%W!cr9k*m;R`FiUcFhat@zXTQT@8P zFCDZXH=?ZeTeWh3TV=EJpU_u?#4x3HBL72Z|%)AHLMaI|=I~?<6P5J4G&7 zHvG1wU&gJEjvfl@twXJ9Yl4hfS@zY$y+z-zO_Yw-)Z9zWl|zZlJ0vo1vb7pLE$zij zUBa6~I_T9CXfC*jjb%HwYv-MUJ#6P3$IjW#CvJ*c2fs`z6CdRqT*sfA&O6-a?2KKI zzY!ekDYVo>^PFk`4MX$0aS&P$EIl0B9nk7^D|F0W;TX*LwQGL3q8r|O7>b z?{UbyV6nMUQ{J5K8L{N6$$Z|6|D9j-E6V|;_x)8bh)Kj-DC2I(R*#}YTG}Lyr1hZX zSE}<>UyXO0g2?7Glku7CUYHq6=^g05ewrJ;=a{WId@?0w^9oN#uz3%^fb4E%G8j%N zdu&)zxGbW8&4yM7DCvQtw{@&_`=Pala~YCDW=I0B-0%#=K$!&8JB^C(Q9wd5l=Z5& z(o*HnpN!Jg(60xOUfIQRP!2<_Uq$9>o5 z0sN%j$1%CeS_5)~AY%U=^#55iwGd}>QkFv5WXD>ffV(OsE=oRV7x11A-ZPa5yCoL_ zs+b6<#@@HBFuk7Xq#oK!Sv&*cWGM$R^g%cPp_2&*A3C-fwd?~Tubt9j0WCUcaWBN@ zP&hpApv_-5ZFV4Bmk0EBJLv5@R^xrN&pzkO-EuW2?d(U-wm=jQ@Ci6(n;_TqEgh%z zN6LO^+ZLYi+{P1d*ADXxjD(H0owu!Sd;3`yLdbXQjg zW*$1L(Twc5GGMEfU<(h^=qVqvqF!x)nn|7j6CuRo1nMt@ivl!&M*@(oKpg-O2uZ0q zR~6z2s%_tE8h+wqrodJAdViP&lX0-hVz?U@a zD@b+?)YNQ5PBVzo^FdgKzz)I^$0&078c_~viLfDvTpsC9vo+GZKFlVwm){g|uP^W{ zRWIKkb0fPM6~bm%u5nH=E73^BD6vwjN!ZeCNPqfyZ~z?xh{8P@jRohhu^@?ECl6^% zCd@-J7wi!`;}qOHt~eRzf4cdClx|DsP-}}CfN;PY&vu-70Eou0N-6h40FVm;D1O>*8>`K&yK8Pey_SYTchrRNqOBZwV>ft%a3f5(nH*yPjMN0H+sQnz*GD>o zxL)WKz>#jJz^nSdsC2_o18YN_LT6}~h0^>kYaTM$h3=9aeH% z(AZHP-77Z~Y$zS&0Kp8f%J}yISOPuBiuo$!8~7F)P!F*nqkQ0SKgytU0Dk%i3y1k8 zkdoC(Ic(}c&!AAhC|AxxEmr4NLeqB`Nh!=oRM6!rj3=L#K~T)gijHtGgvu(48LYzTp2 z$F)Zs7m&+=C>VANV0hQg0H9@@oD1NFzY)N;VVsZHJMHZNY=zWzTQ||h6Uj<6IHiqf zLHK|kq@d+&eH!}P4ynmcLx-hyS;}2b$uYP|Wq2H>mfZC;iSW9i{%rg3tcK-CalZgt zo7S=~;<{0;clC}T{pQ>f6afS`FBv`f$Ugb;C;0csJ`ISR#ZU-rsi1Ru8#g2&UBV{H z(E#P0pu`lK(k)&hC^j1+uxMENAT!6R{~2Y0IK?n%yY2iZj-&6PtY=tgmvzPC@8HCU z$BqR-H9{yR=P91wf`tZ=X=}h4ick(jV2)vX#n<6JgPoS@I16wQtvPo*0W+-mzOF27n_iZM(3doOQGXQRmRzw3dmV2}>>bZ3st*y`S2#2GI+P z%UvJp;AsY+ykvdBx(17}lYxXtwSViHu}Hi|6Z{WW0%Le2+Ss#EgW>Jfs>?p7ZWU^G z-Ukwf_V((2eGbO}4`r`iZ3!SQ>&hYoncxAL>x46;T7zB>U9N=C+m&W(H31%BSz~U; zJ-S6|fiEpBtpMC>gZfD{!0`0IDCwIA@5^Gju|Tj-sQ<`5q^Tug!*xkQ&!NCDyt~w_ zHli##Nv5TgC?&_)VzqUVg*j3LJtI*LFgdP>Uhza#bu zoT0#M{O(c43`~@1VX&(Aqa2yCi&@drFWYykEL^Y63^INojRzk*sl^qfWk>6uIve25L{h8_Ya zT1RgWouyR6#nuHlO)q6|lwF6N4?0VIL<)D-Qtk23SsyUIg`X91mer*!8}to8 zD{$C@%Fl0j7;xtxp}TD*N>rsmhne=oTO3l55{H8X#z|MzV41iMCXN|?Z@wHX5;0M$ z7)4@7Db9~`Z*FF+0O!>z{8WistlEIuBSl0RcnvVY`Y7-FfF;@bGKjt2if0dPumTjN zk|`cK2Z1tupUxaYLflWhIhKxc?4VT5#m2lY4r5~BlME`l+JZ_c=6KFJ#X%lDd2;oa z(2cElk$|$yO6|t1QBXsS<1cT^^`5!oOVfBfk6$o}4NXJ9qXM-(#dQb)9i~Eeo~G3P zFb&~tf7ymF2(XFVUd{qM%)*t(5j6rAM?mB7A#lurmT6p9fyYrnP&SAdf|VQ#YojdO zwqaXNdN&$?-oW1Gjz%+l!d<~iWpO;=<#I#X*yP?E_x#C)$#G+~PfcxD@25|n7BEy= z_E$@A=!xUNo}Aop2N=%}k-`)Qks~6mKWIBqaGM;)ymoX#kYLbl>&e~w zqP+8zdFQo_PX6dumPV&E{jgJ;M@PzM9=-VI=-*gYQ(_3J(ghqv?p(83)1<;Ezwy!< z1V-O<8j}M@Sf4oCD$d)@)A8%o!T(1&;qoTF*`Ri)PS6ewYy$q^N76d{Et`ktN6>IT5A;w^e=|RfcK%$A z{D0?<9$Mz08Y0$T1v!ij^bx22t0)!P)IZCkXSkuaD{^_O{%bt%qs=XS<2FUgq;YI* zO(;`bU*AMY4|S$cK&>iL`E495z%4{+{J@48d{K;OptQdToCci<%*G?vN?Fji#{r@p zeW~HvR$~MJ8|Jo3@jA?0;74Fc;5OKEg%0I+y6oU#Vp|DaK_JruM71*q0X?_sUAuVR zJ9_xU%kYPb|Ia%bdqd$*L8JyI&q}Qf-;P9WfWhkZ@{Id4yE48pnLq4q5 z*%_$P3Sa~Ds0m0hQV8#x=ui!BRosnPjAIOKMNG0z8LyA~%UXF;73h~>>Nbb^cB~Jn z7EJe88u#zOXxLo#8{^)dcm$=jJ+Tsd*IcEh+b~n_dO@RWO$cEN=M2dwSrN z7cgn#3|^8dWDMc~QwUsk$0`Yl#xFTVs;Ya^r73wmMhA^$P&Q;_9&2>xlo^nz-nTao zi!~VETnc84AAyMfk-cXu6>S4BW_WYc*hJgo2xi)U=Aaf z)7vi*wm#PA+ms2^e%3QCkoEy!wSujG0p~pufnJWTM7WQW>Sl>BzXtD2$AMk9M}fyX z&PnpOvknx_*c~u-icbDS65z-+(j%4`H&q%kV=0yyh?CGM7t0LXhZa-PA|*zq{5}-& zRSu2}Ia%3*k{LJi0+OogA4iIiv}NeQ!T{Ie=&eHph#}Zo4HugY2{~+{R^^?FDOQ3B zX08v6&NrK<_6WVtSA)ep<6uaAY7gYtJ@{)A(j~PMwH#1mva~m!f*QLSo-taJjp*3GaOrvx%NI8j$v7A2N{lGMf$nO zcrcK@h4LO>Ho+&E?>v6NEo?fLew$zssuv8^RlA-_frZ`{7COGcU|>62U%)vsk;qU8 zbEkO!I*u5?#(sb-ieNWmaQXIsx?!>;D86GEDq;ru>A*EcQ3Ax|z;Us-6fxW*k8Y0{ z=_kPv)r1bAQ4mX7=m^|y#27^<{F2^1W}D1ugu>CdXg|19R;ch~E=+uf3V_OS8t@ro5Hu74bVG<~L&Kw;tKIu-k*MC#~x-$B5QJcv%ut zxlghRNqn7CE66{$H(khXM~p(sdn9QJ4R$B=Ih;_Eb}Znk5#p*PN;_xChP=xOLbBUm zO5E+jzlUTxHb+Ax=3Dm8OFqfx%DPuuRhFhUE+rN+MkjW|0GlukB@j*7J5*hEh~Hlb z9IDBwEJcInHpyCvGUlXjNTR2N>cu`X6_D$K%nB=@1JcUU!#nKg@8I|`isv8+#d9

8dej7XeOWgF~_NU8A$s-xBHa)=5eUC#&abV^2FJs$7 zRivmcRn6igL}*>Xck&QED>|_iyeQ11`3N3eId{9~xU%l5G(5D-r-5hXAt=!7pRqcr z6;Pcw22IR+cU%0{smzCB)!ALOc^`q zRyB!J$wL#R7Gvj0?;>PIy-7VtpBZ6v6POR!*5FxV5WpW-SqYeN=HY)e2v&UWg`-DL zoS5_uhzN_rqe)gqvq2zkuyPYYnaQ#C^C#zd(+>%Q8(chg<%z3-pA_1gV<4NWKS{Dii%`U>V-zkyA(?Scx^hT4WV3IkobC(k9&`NnP{M;%M0}~4>Nc^_WdNf z`-e}&_erNDaVw1oZp!&nH$!i(RpmdP0=5{LeUIzFtu5o zKS3xyK{+Qlrkza81gUTa{A`3!+Zo-%jFJ0cJAe85n-ed;{L(8EN7^G0T{T9DK|hC< zf@b4UdL^8ncp31PiCi**`tRZhdOjQXPX7k4{C#fv6xFWHQou;#_?|!Ed0*HrndZ`3wP&NGtdSOV}Xo(*y#Z6KIqtG?FxcVF?UKC~}D*9L&^5R9pm5 zI}x}^t*1JeH70Cg9@BEq@lI+9qJtP1>W^3E%@s*0$hLQ14}nYT@H;WGPUH(phX1Ik zCualz!uy*sq4GaQ-z;Xurok>{3ea3K?Sw&SA&8#FsKAv3Jp@lvxn^3`TH#K_d~-?L zk*&pUh_Z1Fq&qLJG?o!izuQ01&tbaJLj+{_49Mf4h0wfTT4_{SupO|#h};w$dgKeb zoncS7*bZZ>e-{t$8F6w&cf=V_QsSOtZc4BnqSjuvk>3V>f!hvnz#J`Gv?U-4VdOt! zQCM<(dG=X|7l7U{sK8C-1Q>`^LJo&Mg9n4sG893`TrNo6 zB&jHcWTO6o806@cOq2Wh*5bMVg)t?w06C!l4VrvR1`u(c$1h--xP-i&L7Sp@q&mt@NzbSMr?lP}ZWmedwXM24T-F@QT@=<$zjWvq8l zj{F%H3MAeBy+mTrYKid;e3glumk14fit*(3N({tcuEn#z3Cx4ylIq=N2)yHaXOXd> zVn@c2NiP-=1~$h}74ac@F9?n8kmLH zm2-&Df60<9pk>6h6R{BJf6n`#Bsrfr8iz^MvXB4M~)sl{?duhzWmC>Wa)z*ULgo$C|!8vw{WnbFGI*$q%cEQK5!sw*XhjfKmsJ7 zY%PVWsRvm71V6+tQVu_~^e=)xTyRKAr5_-0D+&4@I4T4FfDqtcm{rKG+W|TAa{EJi*YPCL7@65gfJm#cMu(Sl1Cp-4~3`L~!B6 zs7^DPL5N#GP!A}SXze4XPsV=dns0(I^o7ReDJC`%h|C~P zy!!yo0hapoR>YZZt}HBK4iiVxA#rwjmDP%*a|k^kDzX9#GmfXw?BI*zho)XV_1c+t-}|8b6iWLG0X^KHJnu6{ zpJtPcrshnd;6Gv)ZRKTg%$8z0kG6M<=*5jo`)6~Ing|i75@!BRSGDE<-fRc?w!^Oe z12o?QBC;sxPFxKqiE0H1131H~9I&lK{aiR139?gb?na$3jXVx0-UndQxGr+RjNbw+ z;0{yTNuQxz=Wq{O4clc}Vs85n#X|4SBbX3gL~pgZLib;VDAf6-gYmCbFD) zrR*Wck+CwQV9(*usIck#AA>!X72vc|38Rcz z9E0;FmdJ$B0Mh5f5)f>|NP}V3MB0~P+H1WWEQ<`l?GEg|6w0uotp%SG*2v*R4&1pa z7@w!CF9#g3ewx|F%E*=}A<+|cS>-R2bV!+2jyBnIOxgMqob_-#>TIO_?8gZLMd0F& zwbMEcul7#stb~`=;lNr4a)%rT<`V4m7tWh-4c0NDV+O(;x__TZ^YHL+cJJT6Ke_4G zH@Tn(xe=Ut^!SDdNG9v(OD|0(zr#<4HZ_W?Pk!Q)pGa9Esz3H{-gZu3hC%(`a2O9h zJc(ufhdf8FZ)F)toURQ0|3FdSFlt&AU*)(Fky~&aOG(d&Q6F?!Z5$`SsdQj~%_J#p zC$y@yM9H|{NXBXWl?Fr-YF8DGxb| zvtYb5G6))>QN?t^n4FI8JZR`PF3KE^XCY=S{Ryk~A;}@k2SNf>Rbnr{!`U$UcNm(N z9GF9vw2OS{o#KRpEr=xzy<(hH*G-_L^B5y*FAvb>)_dY4T#P5(!#wN2A=bv)ciMhT zkwmQ-AUvk+T`<>AS&e)rmDGjZL*8}T-^cPl8P83N(-59CW9W^dR5A=l$;C{CTk%H? z3tngD1RR@ptId_b1T@FJ)v8}p<06bPM|2biu-K`K`|HB SMk!fayKcffngd&m} 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 being sent. + :param stream: (optional) Whether to stream the request content. + :param timeout: (optional) How long to wait for the server to send + data before giving up, as a float, or a :ref:`(connect timeout, + read timeout) ` tuple. + :type timeout: float or tuple + :param verify: (optional) Either a boolean, in which case it controls whether we verify + the server's TLS certificate, or a string, in which case it must be a path + to a CA bundle to use + :param cert: (optional) Any user-provided SSL certificate to be trusted. + :param proxies: (optional) The proxies dictionary to apply to the request. + """ + raise NotImplementedError + + def close(self): + """Cleans up adapter specific items.""" + raise NotImplementedError + + +class HTTPAdapter(BaseAdapter): + """The built-in HTTP Adapter for urllib3. + + Provides a general-case interface for Requests sessions to contact HTTP and + HTTPS urls by implementing the Transport Adapter interface. This class will + usually be created by the :class:`Session ` class under the + covers. + + :param pool_connections: The number of urllib3 connection pools to cache. + :param pool_maxsize: The maximum number of connections to save in the pool. + :param max_retries: The maximum number of retries each connection + should attempt. Note, this applies only to failed DNS lookups, socket + connections and connection timeouts, never to requests where data has + made it to the server. By default, Requests does not retry failed + connections. If you need granular control over the conditions under + which we retry a request, import urllib3's ``Retry`` class and pass + that instead. + :param pool_block: Whether the connection pool should block for connections. + + Usage:: + + >>> import requests + >>> s = requests.Session() + >>> 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): + if max_retries == DEFAULT_RETRIES: + self.max_retries = Retry(0, read=False) + else: + self.max_retries = Retry.from_int(max_retries) + self.config = {} + self.proxy_manager = {} + + super(HTTPAdapter, self).__init__() + + self._pool_connections = pool_connections + self._pool_maxsize = pool_maxsize + self._pool_block = pool_block + + self.init_poolmanager(pool_connections, pool_maxsize, block=pool_block) + + def __getstate__(self): + return {attr: getattr(self, attr, None) for attr in self.__attrs__} + + def __setstate__(self, state): + # Can't handle by adding 'proxy_manager' to self.__attrs__ because + # self.poolmanager uses a lambda function, which isn't pickleable. + self.proxy_manager = {} + self.config = {} + + for attr, value in state.items(): + setattr(self, attr, value) + + self.init_poolmanager(self._pool_connections, self._pool_maxsize, + block=self._pool_block) + + 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 + exposed for use when subclassing the + :class:`HTTPAdapter `. + + :param connections: The number of urllib3 connection pools to cache. + :param maxsize: The maximum number of connections to save in the pool. + :param block: Block when no free connections are available. + :param pool_kwargs: Extra keyword arguments used to initialize the Pool Manager. + """ + # save these values for pickling + self._pool_connections = connections + self._pool_maxsize = maxsize + self._pool_block = block + + self.poolmanager = PoolManager(num_pools=connections, maxsize=maxsize, + block=block, strict=True, **pool_kwargs) + + def proxy_manager_for(self, proxy, **proxy_kwargs): + """Return urllib3 ProxyManager for the given proxy. + + This method should not be called from user code, and is only + exposed for use when subclassing the + :class:`HTTPAdapter `. + + :param proxy: The proxy to return a urllib3 ProxyManager for. + :param proxy_kwargs: Extra keyword arguments used to configure the Proxy Manager. + :returns: ProxyManager + :rtype: urllib3.ProxyManager + """ + if proxy in self.proxy_manager: + manager = self.proxy_manager[proxy] + elif proxy.lower().startswith('socks'): + username, password = get_auth_from_url(proxy) + manager = self.proxy_manager[proxy] = SOCKSProxyManager( + proxy, + username=username, + password=password, + num_pools=self._pool_connections, + maxsize=self._pool_maxsize, + block=self._pool_block, + **proxy_kwargs + ) + else: + proxy_headers = self.proxy_headers(proxy) + manager = self.proxy_manager[proxy] = proxy_from_url( + proxy, + proxy_headers=proxy_headers, + num_pools=self._pool_connections, + maxsize=self._pool_maxsize, + block=self._pool_block, + **proxy_kwargs) + + return manager + + def cert_verify(self, conn, url, verify, cert): + """Verify a SSL certificate. This method should not be called from user + code, and is only exposed for use when subclassing the + :class:`HTTPAdapter `. + + :param conn: The urllib3 connection object associated with the cert. + :param url: The requested URL. + :param verify: Either a boolean, in which case it controls whether we verify + the server's TLS certificate, or a string, in which case it must be a path + to a CA bundle to use + :param cert: The SSL certificate to verify. + """ + if url.lower().startswith('https') and verify: + + cert_loc = None + + # Allow self-specified cert location. + if verify is not True: + cert_loc = verify + + if not cert_loc: + 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)) + + 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.ca_certs = None + conn.ca_cert_dir = None + + if cert: + if not isinstance(cert, basestring): + conn.cert_file = cert[0] + conn.key_file = cert[1] + else: + 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)) + 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)) + + def build_response(self, req, resp): + """Builds a :class:`Response ` object from a urllib3 + response. This should not be called from user code, and is only exposed + for use when subclassing the + :class:`HTTPAdapter ` + + :param req: The :class:`PreparedRequest ` used to generate the response. + :param resp: The urllib3 response object. + :rtype: requests.Response + """ + response = Response() + + # Fallback to None if there's no status_code, for whatever reason. + response.status_code = getattr(resp, 'status', None) + + # Make headers case-insensitive. + response.headers = CaseInsensitiveDict(getattr(resp, 'headers', {})) + + # Set encoding. + response.encoding = get_encoding_from_headers(response.headers) + response.raw = resp + response.reason = response.raw.reason + + if isinstance(req.url, bytes): + response.url = req.url.decode('utf-8') + else: + response.url = req.url + + # Add new cookies from the server. + extract_cookies_to_jar(response.cookies, req, resp) + + # Give the Response some context. + response.request = req + response.connection = self + + return response + + def get_connection(self, url, proxies=None): + """Returns a urllib3 connection for the given URL. This should not be + called from user code, and is only exposed for use when subclassing the + :class:`HTTPAdapter `. + + :param url: The URL to connect to. + :param proxies: (optional) A Requests-style dictionary of proxies used on this request. + :rtype: urllib3.ConnectionPool + """ + proxy = select_proxy(url, proxies) + + if proxy: + 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.") + proxy_manager = self.proxy_manager_for(proxy) + conn = proxy_manager.connection_from_url(url) + else: + # Only scheme should be lower case + parsed = urlparse(url) + url = parsed.geturl() + conn = self.poolmanager.connection_from_url(url) + + return conn + + def close(self): + """Disposes of any internal state. + + Currently, this closes the PoolManager and any active ProxyManager, + which closes any pooled connections. + """ + self.poolmanager.clear() + for proxy in self.proxy_manager.values(): + proxy.clear() + + def request_url(self, request, proxies): + """Obtain the url to use when making the final request. + + If the message is being sent through a HTTP proxy, the full URL has to + be used. Otherwise, we should only use the path portion of the URL. + + This should not be called from user code, and is only exposed for use + when subclassing the + :class:`HTTPAdapter `. + + :param request: The :class:`PreparedRequest ` being sent. + :param proxies: A dictionary of schemes or schemes and hosts to proxy URLs. + :rtype: str + """ + proxy = select_proxy(request.url, proxies) + scheme = urlparse(request.url).scheme + + 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') + + url = request.path_url + if is_proxied_http_request and not using_socks_proxy: + url = urldefragauth(request.url) + + return url + + def add_headers(self, request, **kwargs): + """Add any headers needed by the connection. As of v2.0 this does + nothing by default, but is left for overriding by users that subclass + the :class:`HTTPAdapter `. + + This should not be called from user code, and is only exposed for use + when subclassing the + :class:`HTTPAdapter `. + + :param request: The :class:`PreparedRequest ` to add headers to. + :param kwargs: The keyword arguments from the call to send(). + """ + pass + + def proxy_headers(self, proxy): + """Returns a dictionary of the headers to add to any request sent + through a proxy. This works with urllib3 magic to ensure that they are + correctly sent to the proxy, rather than in a tunnelled request if + CONNECT is being used. + + This should not be called from user code, and is only exposed for use + when subclassing the + :class:`HTTPAdapter `. + + :param proxy: The url of the proxy being used for this request. + :rtype: dict + """ + headers = {} + username, password = get_auth_from_url(proxy) + + if username: + headers['Proxy-Authorization'] = _basic_auth_str(username, + password) + + return headers + + 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 ` being sent. + :param stream: (optional) Whether to stream the request content. + :param timeout: (optional) How long to wait for the server to send + data before giving up, as a float, or a :ref:`(connect timeout, + read timeout) ` tuple. + :type timeout: float or tuple or urllib3 Timeout object + :param verify: (optional) Either a boolean, in which case it controls whether + we verify the server's TLS certificate, or a string, in which case it + must be a path to a CA bundle to use + :param cert: (optional) Any user-provided SSL certificate to be trusted. + :param proxies: (optional) The proxies dictionary to apply to the request. + :rtype: requests.Response + """ + + try: + conn = self.get_connection(request.url, proxies) + except LocationValueError as e: + raise InvalidURL(e, request=request) + + 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) + + 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) + 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 + ) + + # 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: + raise ConnectionError(err, request=request) + + except MaxRetryError as e: + if isinstance(e.reason, ConnectTimeoutError): + # TODO: Remove this in 3.0.0: see #2811 + if not isinstance(e.reason, NewConnectionError): + raise ConnectTimeout(e, request=request) + + if isinstance(e.reason, ResponseError): + raise RetryError(e, request=request) + + if isinstance(e.reason, _ProxyError): + raise ProxyError(e, request=request) + + if isinstance(e.reason, _SSLError): + # This branch is for urllib3 v1.22 and later. + raise SSLError(e, request=request) + + raise ConnectionError(e, request=request) + + except ClosedPoolError as e: + raise ConnectionError(e, request=request) + + except _ProxyError as e: + raise ProxyError(e) + + except (_SSLError, _HTTPError) as e: + if isinstance(e, _SSLError): + # This branch is for urllib3 versions earlier than v1.22 + raise SSLError(e, request=request) + elif isinstance(e, ReadTimeoutError): + raise ReadTimeout(e, request=request) + else: + raise + + return self.build_response(request, resp) diff --git a/venv/lib/python3.8/site-packages/requests/api.py b/venv/lib/python3.8/site-packages/requests/api.py new file mode 100644 index 0000000..4cba90e --- /dev/null +++ b/venv/lib/python3.8/site-packages/requests/api.py @@ -0,0 +1,159 @@ +# -*- coding: utf-8 -*- + +""" +requests.api +~~~~~~~~~~~~ + +This module implements the Requests API. + +:copyright: (c) 2012 by Kenneth Reitz. +:license: Apache2, see LICENSE for more details. +""" + +from . import sessions + + +def request(method, url, **kwargs): + """Constructs and sends a :class:`Request `. + + :param method: method for the new :class:`Request` object: ``GET``, ``OPTIONS``, ``HEAD``, ``POST``, ``PUT``, ``PATCH``, or ``DELETE``. + :param url: URL for the new :class:`Request` object. + :param params: (optional) Dictionary, list of tuples or bytes to send + in the query string for the :class:`Request`. + :param data: (optional) Dictionary, list of tuples, bytes, or file-like + object 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 headers: (optional) Dictionary of HTTP Headers to send with the :class:`Request`. + :param cookies: (optional) Dict or CookieJar object to send with the :class:`Request`. + :param files: (optional) Dictionary of ``'name': file-like-objects`` (or ``{'name': file-tuple}``) for multipart encoding upload. + ``file-tuple`` can be a 2-tuple ``('filename', fileobj)``, 3-tuple ``('filename', fileobj, 'content_type')`` + or a 4-tuple ``('filename', fileobj, 'content_type', custom_headers)``, where ``'content-type'`` is a string + defining the content type of the given file and ``custom_headers`` a dict-like object containing additional headers + to add for the file. + :param auth: (optional) Auth tuple to enable Basic/Digest/Custom HTTP Auth. + :param timeout: (optional) How many seconds to wait for the server to send data + before giving up, as a float, or a :ref:`(connect timeout, read + timeout) ` tuple. + :type timeout: float or tuple + :param allow_redirects: (optional) Boolean. Enable/disable GET/OPTIONS/POST/PUT/PATCH/DELETE/HEAD redirection. Defaults to ``True``. + :type allow_redirects: bool + :param proxies: (optional) Dictionary mapping protocol to the URL of the proxy. + :param verify: (optional) Either a boolean, in which case it controls whether we verify + the server's TLS certificate, or a string, in which case it must be a path + to a CA bundle to use. Defaults to ``True``. + :param stream: (optional) if ``False``, the response content will be immediately downloaded. + :param cert: (optional) if String, path to ssl client cert file (.pem). If Tuple, ('cert', 'key') pair. + :return: :class:`Response ` object + :rtype: requests.Response + + Usage:: + + >>> import requests + >>> req = requests.request('GET', 'https://httpbin.org/get') + >>> req + + """ + + # By using the 'with' statement we are sure the session is closed, thus we + # avoid leaving sockets open which can trigger a ResourceWarning in some + # cases, and look like a memory leak in others. + with sessions.Session() as session: + return session.request(method=method, url=url, **kwargs) + + +def get(url, params=None, **kwargs): + r"""Sends a GET request. + + :param url: URL for the new :class:`Request` object. + :param params: (optional) Dictionary, list of tuples or bytes to send + in the query string for the :class:`Request`. + :param \*\*kwargs: Optional arguments that ``request`` takes. + :return: :class:`Response ` object + :rtype: requests.Response + """ + + return request('get', url, params=params, **kwargs) + + +def options(url, **kwargs): + r"""Sends an OPTIONS request. + + :param url: URL for the new :class:`Request` object. + :param \*\*kwargs: Optional arguments that ``request`` takes. + :return: :class:`Response ` object + :rtype: requests.Response + """ + + return request('options', url, **kwargs) + + +def head(url, **kwargs): + r"""Sends a HEAD request. + + :param url: URL for the new :class:`Request` object. + :param \*\*kwargs: Optional arguments that ``request`` takes. If + `allow_redirects` is not provided, it will be set to `False` (as + opposed to the default :meth:`request` behavior). + :return: :class:`Response ` object + :rtype: requests.Response + """ + + kwargs.setdefault('allow_redirects', False) + return request('head', url, **kwargs) + + +def post(url, data=None, json=None, **kwargs): + r"""Sends a POST request. + + :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 \*\*kwargs: Optional arguments that ``request`` takes. + :return: :class:`Response ` object + :rtype: requests.Response + """ + + return request('post', url, data=data, json=json, **kwargs) + + +def put(url, data=None, **kwargs): + r"""Sends a PUT request. + + :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 \*\*kwargs: Optional arguments that ``request`` takes. + :return: :class:`Response ` object + :rtype: requests.Response + """ + + return request('put', url, data=data, **kwargs) + + +def patch(url, data=None, **kwargs): + r"""Sends a PATCH request. + + :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 \*\*kwargs: Optional arguments that ``request`` takes. + :return: :class:`Response ` object + :rtype: requests.Response + """ + + return request('patch', url, data=data, **kwargs) + + +def delete(url, **kwargs): + r"""Sends a DELETE request. + + :param url: URL for the new :class:`Request` object. + :param \*\*kwargs: Optional arguments that ``request`` takes. + :return: :class:`Response ` object + :rtype: requests.Response + """ + + return request('delete', url, **kwargs) diff --git a/venv/lib/python3.8/site-packages/requests/auth.py b/venv/lib/python3.8/site-packages/requests/auth.py new file mode 100644 index 0000000..eeface3 --- /dev/null +++ b/venv/lib/python3.8/site-packages/requests/auth.py @@ -0,0 +1,305 @@ +# -*- coding: utf-8 -*- + +""" +requests.auth +~~~~~~~~~~~~~ + +This module contains the authentication handlers for Requests. +""" + +import os +import re +import time +import hashlib +import threading +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 .utils import parse_dict_header + +CONTENT_TYPE_FORM_URLENCODED = 'application/x-www-form-urlencoded' +CONTENT_TYPE_MULTI_PART = 'multipart/form-data' + + +def _basic_auth_str(username, password): + """Returns a Basic Auth string.""" + + # "I want us to put a big-ol' comment on top of it that + # says that this behaviour is dumb but we need to preserve + # it because people are relying on it." + # - Lukasa + # + # These are here solely to maintain backwards compatibility + # for things like ints. This will be removed in 3.0.0. + if not isinstance(username, basestring): + warnings.warn( + "Non-string usernames will no longer be supported in Requests " + "3.0.0. Please convert the object you've passed in ({!r}) to " + "a string or bytes object in the near future to avoid " + "problems.".format(username), + category=DeprecationWarning, + ) + username = str(username) + + if not isinstance(password, basestring): + warnings.warn( + "Non-string passwords will no longer be supported in Requests " + "3.0.0. Please convert the object you've passed in ({!r}) to " + "a string or bytes object in the near future to avoid " + "problems.".format(type(password)), + category=DeprecationWarning, + ) + password = str(password) + # -- End Removal -- + + if isinstance(username, str): + username = username.encode('latin1') + + if isinstance(password, str): + password = password.encode('latin1') + + authstr = 'Basic ' + to_native_string( + b64encode(b':'.join((username, password))).strip() + ) + + return authstr + + +class AuthBase(object): + """Base class that all auth implementations derive from""" + + def __call__(self, r): + raise NotImplementedError('Auth hooks must be callable.') + + +class HTTPBasicAuth(AuthBase): + """Attaches HTTP Basic Authentication to the given Request object.""" + + def __init__(self, username, password): + self.username = username + self.password = password + + def __eq__(self, other): + 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) + return r + + +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) + return r + + +class HTTPDigestAuth(AuthBase): + """Attaches HTTP Digest Authentication to the given Request object.""" + + def __init__(self, username, password): + self.username = username + self.password = password + # Keep state in per-thread local storage + self._thread_local = threading.local() + + def init_per_thread_state(self): + # Ensure state is initialized just once per-thread + if not hasattr(self._thread_local, 'init'): + self._thread_local.init = True + self._thread_local.last_nonce = '' + self._thread_local.nonce_count = 0 + self._thread_local.chal = {} + self._thread_local.pos = None + self._thread_local.num_401_calls = None + + def build_digest_header(self, method, url): + """ + :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') + hash_utf8 = None + + if algorithm is None: + _algorithm = 'MD5' + else: + _algorithm = algorithm.upper() + # lambdas assume digest modules are imported at the top level + if _algorithm == 'MD5' or _algorithm == 'MD5-SESS': + def md5_utf8(x): + if isinstance(x, str): + x = x.encode('utf-8') + return hashlib.md5(x).hexdigest() + hash_utf8 = md5_utf8 + elif _algorithm == 'SHA': + def sha_utf8(x): + if isinstance(x, str): + x = x.encode('utf-8') + return hashlib.sha1(x).hexdigest() + hash_utf8 = sha_utf8 + elif _algorithm == 'SHA-256': + def sha256_utf8(x): + if isinstance(x, str): + x = x.encode('utf-8') + return hashlib.sha256(x).hexdigest() + hash_utf8 = sha256_utf8 + elif _algorithm == 'SHA-512': + def sha512_utf8(x): + if isinstance(x, str): + x = x.encode('utf-8') + return hashlib.sha512(x).hexdigest() + hash_utf8 = sha512_utf8 + + KD = lambda s, d: hash_utf8("%s:%s" % (s, d)) + + if hash_utf8 is None: + return None + + # XXX not implemented yet + entdig = None + p_parsed = urlparse(url) + #: 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 + + A1 = '%s:%s:%s' % (self.username, realm, self.password) + A2 = '%s:%s' % (method, path) + + HA1 = hash_utf8(A1) + HA2 = hash_utf8(A2) + + if nonce == self._thread_local.last_nonce: + 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') + s += os.urandom(8) + + cnonce = (hashlib.sha1(s).hexdigest()[:16]) + if _algorithm == 'MD5-SESS': + HA1 = hash_utf8('%s:%s:%s' % (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, noncebit) + else: + # XXX handle auth-int. + return None + + 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) + if opaque: + base += ', opaque="%s"' % opaque + if algorithm: + base += ', algorithm="%s"' % algorithm + if entdig: + base += ', digest="%s"' % entdig + if qop: + base += ', qop="auth", nc=%s, cnonce="%s"' % (ncvalue, cnonce) + + return 'Digest %s' % (base) + + def handle_redirect(self, r, **kwargs): + """Reset num_401_calls counter on redirects.""" + if r.is_redirect: + self._thread_local.num_401_calls = 1 + + def handle_401(self, r, **kwargs): + """ + Takes the given response and tries digest-auth, if needed. + + :rtype: requests.Response + """ + + # If response is not 4xx, do not auth + # See https://github.com/psf/requests/issues/3772 + if not 400 <= r.status_code < 500: + self._thread_local.num_401_calls = 1 + return r + + if self._thread_local.pos is not None: + # 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', '') + + 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)) + + # Consume content and release the original connection + # to allow our new request to reuse the same one. + r.content + r.close() + prep = r.request.copy() + 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) + _r = r.connection.send(prep, **kwargs) + _r.history.append(r) + _r.request = prep + + return _r + + self._thread_local.num_401_calls = 1 + return r + + def __call__(self, r): + # Initialize per-thread state, if needed + 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) + try: + self._thread_local.pos = r.body.tell() + except AttributeError: + # In the case of HTTPDigestAuth being reused and the body of + # the previous request was a file-like object, pos has the + # 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) + 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) + ]) + + def __ne__(self, other): + return not self == other diff --git a/venv/lib/python3.8/site-packages/requests/certs.py b/venv/lib/python3.8/site-packages/requests/certs.py new file mode 100644 index 0000000..d1a378d --- /dev/null +++ b/venv/lib/python3.8/site-packages/requests/certs.py @@ -0,0 +1,18 @@ +#!/usr/bin/env python +# -*- coding: utf-8 -*- + +""" +requests.certs +~~~~~~~~~~~~~~ + +This module returns the preferred default CA certificate bundle. There is +only one — the one from the certifi package. + +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 certifi import where + +if __name__ == '__main__': + print(where()) diff --git a/venv/lib/python3.8/site-packages/requests/compat.py b/venv/lib/python3.8/site-packages/requests/compat.py new file mode 100644 index 0000000..0b14f50 --- /dev/null +++ b/venv/lib/python3.8/site-packages/requests/compat.py @@ -0,0 +1,75 @@ +# -*- coding: utf-8 -*- + +""" +requests.compat +~~~~~~~~~~~~~~~ + +This module handles import compatibility issues between Python 2 and +Python 3. +""" + +try: + import chardet +except ImportError: + import charset_normalizer as chardet + +import sys + +# ------- +# Pythons +# ------- + +# Syntax sugar. +_ver = sys.version_info + +#: Python 2.x? +is_py2 = (_ver[0] == 2) + +#: Python 3.x? +is_py3 = (_ver[0] == 3) + +try: + import simplejson as json +except ImportError: + import json + +# --------- +# 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) + +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 + + builtin_str = str + str = str + bytes = bytes + basestring = (str, bytes) + numeric_types = (int, float) + integer_types = (int,) diff --git a/venv/lib/python3.8/site-packages/requests/cookies.py b/venv/lib/python3.8/site-packages/requests/cookies.py new file mode 100644 index 0000000..56fccd9 --- /dev/null +++ b/venv/lib/python3.8/site-packages/requests/cookies.py @@ -0,0 +1,549 @@ +# -*- coding: utf-8 -*- + +""" +requests.cookies +~~~~~~~~~~~~~~~~ + +Compatibility code to be able to use `cookielib.CookieJar` with requests. + +requests.utils imports from here, so be careful with imports. +""" + +import copy +import time +import calendar + +from ._internal_utils import to_native_string +from .compat import cookielib, urlparse, urlunparse, Morsel, MutableMapping + +try: + import threading +except ImportError: + import dummy_threading as threading + + +class MockRequest(object): + """Wraps a `requests.Request` to mimic a `urllib2.Request`. + + The code in `cookielib.CookieJar` expects this interface in order to correctly + manage cookie policies, i.e., determine whether a cookie can be set, given the + domains of the request and the cookie. + + The original request object is read-only. The client is responsible for collecting + the new headers via `get_new_headers()` and interpreting them appropriately. You + probably want `get_cookie_header`, defined below. + """ + + def __init__(self, request): + self._r = request + self._new_headers = {} + self.type = urlparse(self._r.url).scheme + + def get_type(self): + return self.type + + def get_host(self): + return urlparse(self._r.url).netloc + + def get_origin_req_host(self): + return self.get_host() + + 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'): + 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') + 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 + ]) + + def is_unverifiable(self): + return True + + def has_header(self, name): + return name in self._r.headers or name in self._new_headers + + def get_header(self, name, default=None): + return self._r.headers.get(name, self._new_headers.get(name, default)) + + 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()") + + def add_unredirected_header(self, name, value): + self._new_headers[name] = value + + def get_new_headers(self): + return self._new_headers + + @property + def unverifiable(self): + return self.is_unverifiable() + + @property + def origin_req_host(self): + return self.get_origin_req_host() + + @property + def host(self): + return self.get_host() + + +class MockResponse(object): + """Wraps a `httplib.HTTPMessage` to mimic a `urllib.addinfourl`. + + ...what? Basically, expose the parsed HTTP headers from the server response + the way `cookielib` expects to see them. + """ + + def __init__(self, headers): + """Make a MockResponse for `cookielib` to read. + + :param headers: a httplib.HTTPMessage or analogous carrying the headers + """ + self._headers = headers + + def info(self): + return self._headers + + def getheaders(self, name): + self._headers.getheaders(name) + + +def extract_cookies_to_jar(jar, request, response): + """Extract the cookies from the response into a CookieJar. + + :param jar: cookielib.CookieJar (not necessarily a RequestsCookieJar) + :param request: our own requests.Request object + :param response: urllib3.HTTPResponse object + """ + if not (hasattr(response, '_original_response') and + response._original_response): + return + # the _original_response field is the wrapped httplib.HTTPResponse object, + req = MockRequest(request) + # pull out the HTTPMessage with the headers and put it in the mock: + res = MockResponse(response._original_response.msg) + jar.extract_cookies(res, req) + + +def get_cookie_header(jar, request): + """ + Produce an appropriate Cookie header string to be sent with `request`, or None. + + :rtype: str + """ + r = MockRequest(request) + jar.add_cookie_header(r) + return r.get_new_headers().get('Cookie') + + +def remove_cookie_by_name(cookiejar, name, domain=None, path=None): + """Unsets a cookie by name, by default over all domains and paths. + + Wraps CookieJar.clear(), is O(n). + """ + clearables = [] + for cookie in cookiejar: + if cookie.name != name: + continue + if domain is not None and domain != cookie.domain: + continue + if path is not None and path != cookie.path: + continue + clearables.append((cookie.domain, cookie.path, cookie.name)) + + for domain, path, name in clearables: + cookiejar.clear(domain, path, name) + + +class CookieConflictError(RuntimeError): + """There are two cookies that meet the criteria specified in the cookie jar. + Use .get and .set and include domain and path args in order to be more specific. + """ + + +class RequestsCookieJar(cookielib.CookieJar, MutableMapping): + """Compatibility class; is a cookielib.CookieJar, but exposes a dict + interface. + + This is the CookieJar we create by default for requests and sessions that + don't specify one, since some clients may expect response.cookies and + session.cookies to support dict operations. + + Requests does not use the dict interface internally; it's just for + compatibility with external client code. All requests code should work + out of the box with externally provided instances of ``CookieJar``, e.g. + ``LWPCookieJar`` and ``FileCookieJar``. + + Unlike a regular CookieJar, this class is pickleable. + + .. warning:: dictionary operations that are normally O(1) may be O(n). + """ + + def get(self, name, default=None, domain=None, path=None): + """Dict-like get() that also supports optional domain and path args in + order to resolve naming collisions from using one cookie jar over + multiple domains. + + .. warning:: operation is O(n), not O(1). + """ + try: + return self._find_no_duplicates(name, domain, path) + except KeyError: + return default + + def set(self, name, value, **kwargs): + """Dict-like set() that also supports optional domain and path args in + order to resolve naming collisions from using one cookie jar over + multiple domains. + """ + # 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')) + return + + if isinstance(value, Morsel): + c = morsel_to_cookie(value) + else: + c = create_cookie(name, value, **kwargs) + self.set_cookie(c) + return c + + def iterkeys(self): + """Dict-like iterkeys() that returns an iterator of names of cookies + from the jar. + + .. seealso:: itervalues() and iteritems(). + """ + for cookie in iter(self): + yield cookie.name + + def keys(self): + """Dict-like keys() that returns a list of names of cookies from the + jar. + + .. seealso:: values() and items(). + """ + return list(self.iterkeys()) + + def itervalues(self): + """Dict-like itervalues() that returns an iterator of values of cookies + from the jar. + + .. seealso:: iterkeys() and iteritems(). + """ + for cookie in iter(self): + yield cookie.value + + def values(self): + """Dict-like values() that returns a list of values of cookies from the + jar. + + .. seealso:: keys() and items(). + """ + return list(self.itervalues()) + + def iteritems(self): + """Dict-like iteritems() that returns an iterator of name-value tuples + from the jar. + + .. seealso:: iterkeys() and itervalues(). + """ + for cookie in iter(self): + yield cookie.name, cookie.value + + def items(self): + """Dict-like items() that returns a list of name-value tuples from the + jar. Allows client-code to call ``dict(RequestsCookieJar)`` and get a + vanilla python dict of key value pairs. + + .. seealso:: keys() and values(). + """ + return list(self.iteritems()) + + def list_domains(self): + """Utility method to list all the domains in the jar.""" + domains = [] + for cookie in iter(self): + if cookie.domain not in domains: + domains.append(cookie.domain) + return domains + + def list_paths(self): + """Utility method to list all the paths in the jar.""" + paths = [] + for cookie in iter(self): + if cookie.path not in paths: + paths.append(cookie.path) + return paths + + def multiple_domains(self): + """Returns True if there are multiple domains in the jar. + Returns False otherwise. + + :rtype: bool + """ + domains = [] + for cookie in iter(self): + if cookie.domain is not None and cookie.domain in domains: + return True + domains.append(cookie.domain) + return False # there is only one domain in jar + + def get_dict(self, domain=None, path=None): + """Takes as an argument an optional domain and path and returns a plain + old Python dict of name-value pairs of cookies that meet the + requirements. + + :rtype: dict + """ + dictionary = {} + for cookie in iter(self): + 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) + except CookieConflictError: + return True + + def __getitem__(self, name): + """Dict-like __getitem__() for compatibility with client code. Throws + exception if there are more than one cookie with name. In that case, + use the more explicit get() method instead. + + .. warning:: operation is O(n), not O(1). + """ + return self._find_no_duplicates(name) + + def __setitem__(self, name, value): + """Dict-like __setitem__ for compatibility with client code. Throws + exception if there is already a cookie of that name in the jar. In that + case, use the more explicit set() method instead. + """ + self.set(name, value) + + def __delitem__(self, name): + """Deletes a cookie given a name. Wraps ``cookielib.CookieJar``'s + ``remove_cookie_by_name()``. + """ + 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) + + def update(self, other): + """Updates this jar with cookies from another CookieJar or dict-like""" + if isinstance(other, cookielib.CookieJar): + for cookie in other: + self.set_cookie(copy.copy(cookie)) + else: + super(RequestsCookieJar, self).update(other) + + def _find(self, name, domain=None, path=None): + """Requests uses this method internally to get cookie values. + + If there are conflicting cookies, _find arbitrarily chooses one. + See _find_no_duplicates if you want an exception thrown if there are + conflicting cookies. + + :param name: a string containing name of cookie + :param domain: (optional) string containing domain of cookie + :param path: (optional) string containing path of cookie + :return: cookie.value + """ + for cookie in iter(self): + if cookie.name == name: + if domain is None or cookie.domain == domain: + if path is None or cookie.path == path: + return cookie.value + + raise KeyError('name=%r, domain=%r, path=%r' % (name, domain, path)) + + def _find_no_duplicates(self, name, domain=None, path=None): + """Both ``__get_item__`` and ``get`` call this function: it's never + used elsewhere in Requests. + + :param name: a string containing name of cookie + :param domain: (optional) string containing domain of cookie + :param path: (optional) string containing path of cookie + :raises KeyError: if cookie is not found + :raises CookieConflictError: if there are multiple cookies + that match name and optionally domain and path + :return: cookie.value + """ + toReturn = None + for cookie in iter(self): + 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: + return toReturn + raise KeyError('name=%r, domain=%r, path=%r' % (name, domain, path)) + + def __getstate__(self): + """Unlike a normal CookieJar, this class is pickleable.""" + state = self.__dict__.copy() + # remove the unpickleable RLock object + 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__: + self._cookies_lock = threading.RLock() + + def copy(self): + """Return a copy of this RequestsCookieJar.""" + new_cj = RequestsCookieJar() + new_cj.set_policy(self.get_policy()) + new_cj.update(self) + return new_cj + + def get_policy(self): + """Return the CookiePolicy instance used.""" + return self._policy + + +def _copy_cookie_jar(jar): + if jar is None: + return None + + if hasattr(jar, 'copy'): + # We're dealing with an instance of RequestsCookieJar + return jar.copy() + # We're dealing with a generic CookieJar instance + new_jar = copy.copy(jar) + new_jar.clear() + for cookie in jar: + new_jar.set_cookie(copy.copy(cookie)) + return new_jar + + +def create_cookie(name, value, **kwargs): + """Make a cookie from underspecified parameters. + + By default, the pair of `name` and `value` will be set for the domain '' + 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, + } + + badargs = set(kwargs) - set(result) + if badargs: + err = 'create_cookie() got unexpected keyword arguments: %s' + raise TypeError(err % 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']) + + return cookielib.Cookie(**result) + + +def morsel_to_cookie(morsel): + """Convert a Morsel object into a Cookie containing the one k/v pair.""" + + expires = None + if morsel['max-age']: + try: + 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) + ) + return create_cookie( + comment=morsel['comment'], + comment_url=bool(morsel['comment']), + discard=False, + domain=morsel['domain'], + expires=expires, + name=morsel.key, + path=morsel['path'], + port=None, + rest={'HttpOnly': morsel['httponly']}, + rfc2109=False, + secure=bool(morsel['secure']), + value=morsel.value, + version=morsel['version'] or 0, + ) + + +def cookiejar_from_dict(cookie_dict, cookiejar=None, overwrite=True): + """Returns a CookieJar from a key/value dictionary. + + :param cookie_dict: Dict of key/values to insert into CookieJar. + :param cookiejar: (optional) A cookiejar to add the cookies to. + :param overwrite: (optional) If False, will not replace cookies + already in the jar with new ones. + :rtype: CookieJar + """ + if cookiejar is None: + cookiejar = RequestsCookieJar() + + if cookie_dict is not None: + names_from_jar = [cookie.name for cookie in cookiejar] + for name in cookie_dict: + if overwrite or (name not in names_from_jar): + cookiejar.set_cookie(create_cookie(name, cookie_dict[name])) + + return cookiejar + + +def merge_cookies(cookiejar, cookies): + """Add cookies to cookiejar and returns a merged CookieJar. + + :param cookiejar: CookieJar object to add the cookies to. + :param cookies: Dictionary or CookieJar object to be added. + :rtype: CookieJar + """ + if not isinstance(cookiejar, cookielib.CookieJar): + raise ValueError('You can only merge into CookieJar') + + if isinstance(cookies, dict): + cookiejar = cookiejar_from_dict( + cookies, cookiejar=cookiejar, overwrite=False) + elif isinstance(cookies, cookielib.CookieJar): + try: + cookiejar.update(cookies) + except AttributeError: + for cookie_in_jar in cookies: + cookiejar.set_cookie(cookie_in_jar) + + return cookiejar diff --git a/venv/lib/python3.8/site-packages/requests/exceptions.py b/venv/lib/python3.8/site-packages/requests/exceptions.py new file mode 100644 index 0000000..c412ec9 --- /dev/null +++ b/venv/lib/python3.8/site-packages/requests/exceptions.py @@ -0,0 +1,127 @@ +# -*- coding: utf-8 -*- + +""" +requests.exceptions +~~~~~~~~~~~~~~~~~~~ + +This module contains the set of Requests' exceptions. +""" +from urllib3.exceptions import HTTPError as BaseHTTPError + + +class RequestException(IOError): + """There was an ambiguous exception that occurred while handling your + request. + """ + + def __init__(self, *args, **kwargs): + """Initialize RequestException with `request` and `response` objects.""" + 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 = self.response.request + super(RequestException, self).__init__(*args, **kwargs) + + +class InvalidJSONError(RequestException): + """A JSON error occurred.""" + + +class HTTPError(RequestException): + """An HTTP error occurred.""" + + +class ConnectionError(RequestException): + """A Connection error occurred.""" + + +class ProxyError(ConnectionError): + """A proxy error occurred.""" + + +class SSLError(ConnectionError): + """An SSL error occurred.""" + + +class Timeout(RequestException): + """The request timed out. + + Catching this error will catch both + :exc:`~requests.exceptions.ConnectTimeout` and + :exc:`~requests.exceptions.ReadTimeout` errors. + """ + + +class ConnectTimeout(ConnectionError, Timeout): + """The request timed out while trying to connect to the remote server. + + Requests that produced this error are safe to retry. + """ + + +class ReadTimeout(Timeout): + """The server did not send any data in the allotted amount of time.""" + + +class URLRequired(RequestException): + """A valid URL is required to make a request.""" + + +class TooManyRedirects(RequestException): + """Too many redirects.""" + + +class MissingSchema(RequestException, ValueError): + """The URL schema (e.g. http or https) is missing.""" + + +class InvalidSchema(RequestException, ValueError): + """See defaults.py for valid schemas.""" + + +class InvalidURL(RequestException, ValueError): + """The URL provided was somehow invalid.""" + + +class InvalidHeader(RequestException, ValueError): + """The header value provided was somehow invalid.""" + + +class InvalidProxyURL(InvalidURL): + """The proxy URL provided is invalid.""" + + +class ChunkedEncodingError(RequestException): + """The server declared chunked encoding but sent an invalid chunk.""" + + +class ContentDecodingError(RequestException, BaseHTTPError): + """Failed to decode response content.""" + + +class StreamConsumedError(RequestException, TypeError): + """The content for this response was already consumed.""" + + +class RetryError(RequestException): + """Custom retries logic failed""" + + +class UnrewindableBodyError(RequestException): + """Requests encountered an error when trying to rewind a body.""" + +# Warnings + + +class RequestsWarning(Warning): + """Base warning for Requests.""" + + +class FileModeWarning(RequestsWarning, DeprecationWarning): + """A file was opened in text mode, but Requests determined its binary length.""" + + +class RequestsDependencyWarning(RequestsWarning): + """An imported dependency doesn't match the expected version range.""" diff --git a/venv/lib/python3.8/site-packages/requests/help.py b/venv/lib/python3.8/site-packages/requests/help.py new file mode 100644 index 0000000..4cd6389 --- /dev/null +++ b/venv/lib/python3.8/site-packages/requests/help.py @@ -0,0 +1,135 @@ +"""Module containing bug report helper(s).""" +from __future__ import print_function + +import json +import platform +import sys +import ssl + +import idna +import urllib3 + +from . import __version__ as requests_version + +try: + import charset_normalizer +except ImportError: + charset_normalizer = None + +try: + import chardet +except ImportError: + chardet = None + +try: + from urllib3.contrib import pyopenssl +except ImportError: + pyopenssl = None + OpenSSL = None + cryptography = None +else: + import OpenSSL + import cryptography + + +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'}. + + This function works best on CPython and PyPy: in particular, it probably + doesn't work for Jython or IronPython. Future investigation should be done + to work out the correct shape of the code for those platforms. + """ + implementation = platform.python_implementation() + + 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': + implementation_version = platform.python_version() # Complete Guess + elif implementation == 'IronPython': + implementation_version = platform.python_version() # Complete Guess + else: + implementation_version = 'Unknown' + + return {'name': implementation, 'version': implementation_version} + + +def info(): + """Generate information for a bug report.""" + try: + platform_info = { + 'system': platform.system(), + 'release': platform.release(), + } + except IOError: + platform_info = { + 'system': 'Unknown', + 'release': 'Unknown', + } + + implementation_info = _implementation() + 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': '', + } + if OpenSSL: + pyopenssl_info = { + 'version': OpenSSL.__version__, + 'openssl_version': '%x' % OpenSSL.SSL.OPENSSL_VERSION_NUMBER, + } + cryptography_info = { + 'version': getattr(cryptography, '__version__', ''), + } + idna_info = { + 'version': getattr(idna, '__version__', ''), + } + + system_ssl = ssl.OPENSSL_VERSION_NUMBER + system_ssl_info = { + 'version': '%x' % system_ssl 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, + '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, + }, + } + + +def main(): + """Pretty-print the bug information as JSON.""" + print(json.dumps(info(), sort_keys=True, indent=2)) + + +if __name__ == '__main__': + main() diff --git a/venv/lib/python3.8/site-packages/requests/hooks.py b/venv/lib/python3.8/site-packages/requests/hooks.py new file mode 100644 index 0000000..7a51f21 --- /dev/null +++ b/venv/lib/python3.8/site-packages/requests/hooks.py @@ -0,0 +1,34 @@ +# -*- coding: utf-8 -*- + +""" +requests.hooks +~~~~~~~~~~~~~~ + +This module provides the capabilities for the Requests hooks system. + +Available hooks: + +``response``: + The response generated from a Request. +""" +HOOKS = ['response'] + + +def default_hooks(): + return {event: [] for event in HOOKS} + +# TODO: response is the only one + + +def dispatch_hook(key, hooks, hook_data, **kwargs): + """Dispatches a hook dictionary on a given piece of data.""" + hooks = hooks or {} + hooks = hooks.get(key) + if hooks: + if hasattr(hooks, '__call__'): + hooks = [hooks] + for hook in hooks: + _hook_data = hook(hook_data, **kwargs) + if _hook_data is not None: + hook_data = _hook_data + return hook_data diff --git a/venv/lib/python3.8/site-packages/requests/models.py b/venv/lib/python3.8/site-packages/requests/models.py new file mode 100644 index 0000000..aa6fb86 --- /dev/null +++ b/venv/lib/python3.8/site-packages/requests/models.py @@ -0,0 +1,966 @@ +# -*- coding: utf-8 -*- + +""" +requests.models +~~~~~~~~~~~~~~~ + +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 + +from urllib3.fields import RequestField +from urllib3.filepost import encode_multipart_formdata +from urllib3.util import parse_url +from 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, InvalidJSONError) +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 .compat import ( + Callable, Mapping, + cookielib, urlunparse, urlsplit, urlencode, str, bytes, + is_py2, chardet, builtin_str, basestring) +from .compat import json as complexjson +from .status_codes import codes + +#: The set of HTTP status codes that indicate an automatically +#: processable redirect. +REDIRECT_STATI = ( + codes.moved, # 301 + codes.found, # 302 + codes.other, # 303 + codes.temporary_redirect, # 307 + codes.permanent_redirect, # 308 +) + +DEFAULT_REDIRECT_LIMIT = 30 +CONTENT_CHUNK_SIZE = 10 * 1024 +ITER_CHUNK_SIZE = 512 + + +class RequestEncodingMixin(object): + @property + def path_url(self): + """Build the path URL to use.""" + + url = [] + + p = urlsplit(self.url) + + path = p.path + if not path: + path = '/' + + url.append(path) + + query = p.query + if query: + url.append('?') + url.append(query) + + return ''.join(url) + + @staticmethod + def _encode_params(data): + """Encode parameters in a piece of data. + + Will successfully encode parameters when passed as a dict or a list of + 2-tuples. Order is retained if data is a list of 2-tuples but arbitrary + if parameters are supplied as a dict. + """ + + if isinstance(data, (str, bytes)): + return data + elif hasattr(data, 'read'): + return data + elif hasattr(data, '__iter__'): + result = [] + for k, vs in to_key_val_list(data): + 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)) + return urlencode(result, doseq=True) + else: + return data + + @staticmethod + def _encode_files(files, data): + """Build the body for a multipart/form-data request. + + Will successfully encode files when passed as a dict or a list of + tuples. Order is retained if data is a list of tuples but arbitrary + if parameters are supplied as a dict. + The tuples may be 2-tuples (filename, fileobj), 3-tuples (filename, fileobj, contentype) + or 4-tuples (filename, fileobj, contentype, custom_headers). + """ + if (not files): + raise ValueError("Files must be provided.") + elif isinstance(data, basestring): + raise ValueError("Data must not be a string.") + + new_fields = [] + fields = to_key_val_list(data or {}) + files = to_key_val_list(files or {}) + + for field, val in fields: + if isinstance(val, basestring) or not hasattr(val, '__iter__'): + val = [val] + for v in val: + if v is not None: + # Don't call str() on bytestrings: in Py3 it all goes wrong. + if not isinstance(v, bytes): + 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)) + + for (k, v) in files: + # support for explicit filename + ft = None + fh = None + if isinstance(v, (tuple, list)): + if len(v) == 2: + fn, fp = v + elif len(v) == 3: + fn, fp, ft = v + else: + fn, fp, ft, fh = v + else: + fn = guess_filename(v) or k + fp = v + + if isinstance(fp, (str, bytes, bytearray)): + fdata = fp + elif hasattr(fp, 'read'): + fdata = fp.read() + elif fp is None: + continue + else: + fdata = fp + + rf = RequestField(name=k, data=fdata, filename=fn, headers=fh) + rf.make_multipart(content_type=ft) + new_fields.append(rf) + + body, content_type = encode_multipart_formdata(new_fields) + + return body, content_type + + +class RequestHooksMixin(object): + 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)) + + if isinstance(hook, Callable): + self.hooks[event].append(hook) + elif hasattr(hook, '__iter__'): + self.hooks[event].extend(h for h in hook if isinstance(h, Callable)) + + def deregister_hook(self, event, hook): + """Deregister a previously registered hook. + Returns True if the hook existed, False if not. + """ + + try: + self.hooks[event].remove(hook) + return True + except ValueError: + return False + + +class Request(RequestHooksMixin): + """A user-created :class:`Request ` object. + + Used to prepare a :class:`PreparedRequest `, which is sent to the server. + + :param method: HTTP method to use. + :param url: URL to send. + :param headers: dictionary of headers to send. + :param files: dictionary of {filename: fileobject} files to multipart upload. + :param data: the body to attach to the request. If a dictionary or + list of tuples ``[(key, value)]`` is provided, form-encoding will + take place. + :param json: json for the body to attach to the request (if files or data is not specified). + :param params: URL parameters to append to the URL. If a dictionary or + list of tuples ``[(key, value)]`` is provided, form-encoding will + take place. + :param auth: Auth handler or (user, pass) tuple. + :param cookies: dictionary or CookieJar of cookies to attach to this request. + :param hooks: dictionary of callback hooks, for internal usage. + + Usage:: + + >>> import requests + >>> req = requests.Request('GET', 'https://httpbin.org/get') + >>> req.prepare() + + """ + + 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 + files = [] if files is None else files + headers = {} if headers is None else headers + params = {} if params is None else params + hooks = {} if hooks is None else hooks + + self.hooks = default_hooks() + for (k, v) in list(hooks.items()): + self.register_hook(event=k, hook=v) + + self.method = method + self.url = url + self.headers = headers + self.files = files + self.data = data + self.json = json + self.params = params + self.auth = auth + self.cookies = cookies + + def __repr__(self): + return '' % (self.method) + + def prepare(self): + """Constructs a :class:`PreparedRequest ` for transmission and returns it.""" + p = PreparedRequest() + p.prepare( + method=self.method, + url=self.url, + headers=self.headers, + files=self.files, + data=self.data, + json=self.json, + params=self.params, + auth=self.auth, + cookies=self.cookies, + hooks=self.hooks, + ) + return p + + +class PreparedRequest(RequestEncodingMixin, RequestHooksMixin): + """The fully mutable :class:`PreparedRequest ` object, + containing the exact bytes that will be sent to the server. + + Instances are generated from a :class:`Request ` object, and + should not be instantiated manually; doing so may produce undesirable + effects. + + Usage:: + + >>> import requests + >>> req = requests.Request('GET', 'https://httpbin.org/get') + >>> r = req.prepare() + >>> r + + + >>> s = requests.Session() + >>> s.send(r) + + """ + + def __init__(self): + #: HTTP verb to send to the server. + self.method = None + #: HTTP URL to send the request to. + self.url = None + #: dictionary of HTTP headers. + self.headers = None + # The `CookieJar` used to create the Cookie header will be stored here + # after prepare_cookies is called + self._cookies = None + #: request body to send to the server. + self.body = None + #: dictionary of callback hooks, for internal usage. + self.hooks = default_hooks() + #: 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): + """Prepares the entire request with the given parameters.""" + + self.prepare_method(method) + self.prepare_url(url, params) + self.prepare_headers(headers) + self.prepare_cookies(cookies) + self.prepare_body(data, files, json) + self.prepare_auth(auth, url) + + # Note that prepare_auth must be last to enable authentication schemes + # such as OAuth to work on a fully prepared request. + + # This MUST go after prepare_auth. Authenticators could add a hook + self.prepare_hooks(hooks) + + def __repr__(self): + return '' % (self.method) + + def copy(self): + p = PreparedRequest() + p.method = self.method + p.url = self.url + p.headers = self.headers.copy() if self.headers is not None else None + p._cookies = _copy_cookie_jar(self._cookies) + p.body = self.body + p.hooks = self.hooks + p._body_position = self._body_position + return p + + def prepare_method(self, method): + """Prepares the given HTTP method.""" + self.method = method + if self.method is not None: + self.method = to_native_string(self.method.upper()) + + @staticmethod + def _get_idna_encoded_host(host): + import idna + + try: + host = idna.encode(host, uts46=True).decode('utf-8') + except idna.IDNAError: + raise UnicodeError + return host + + def prepare_url(self, url, params): + """Prepares the given HTTP URL.""" + #: Accept objects that have string representations. + #: We're unable to blindly call unicode/str functions + #: as this will include the bytestring indicator (b'') + #: on python 3.x. + #: https://github.com/psf/requests/pull/2238 + if isinstance(url, bytes): + url = url.decode('utf8') + else: + url = unicode(url) if is_py2 else str(url) + + # Remove leading whitespaces from url + url = url.lstrip() + + # 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'): + self.url = url + return + + # Support for unicode domain names and paths. + try: + scheme, auth, host, port, path, query, fragment = parse_url(url) + except LocationParseError as e: + 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) + + if not host: + raise InvalidURL("Invalid URL %r: No host supplied" % url) + + # 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 + # behaviour. For strings containing only ASCII characters, we need to also verify + # it doesn't start with a wildcard (*), before allowing the unencoded hostname. + if not unicode_is_ascii(host): + 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.') + + # Carefully reconstruct the network location + netloc = auth or '' + if netloc: + netloc += '@' + netloc += host + if port: + netloc += ':' + str(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') + + if isinstance(params, (str, bytes)): + params = to_native_string(params) + + enc_params = self._encode_params(params) + if enc_params: + if query: + query = '%s&%s' % (query, enc_params) + else: + query = enc_params + + url = requote_uri(urlunparse([scheme, netloc, path, None, query, fragment])) + self.url = url + + def prepare_headers(self, headers): + """Prepares the given HTTP headers.""" + + self.headers = CaseInsensitiveDict() + if headers: + for header in headers.items(): + # Raise exception on invalid header value. + check_header_validity(header) + name, value = header + self.headers[to_native_string(name)] = value + + def prepare_body(self, data, files, json=None): + """Prepares the given HTTP body data.""" + + # Check if file, fo, generator, iterator. + # If not, run through normal process. + + # Nottin' on you. + body = None + content_type = None + + 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' + + 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') + + is_stream = all([ + hasattr(data, '__iter__'), + not isinstance(data, (basestring, list, tuple, Mapping)) + ]) + + if is_stream: + try: + length = super_len(data) + except (TypeError, AttributeError, UnsupportedOperation): + length = None + + body = data + + 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): + # 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.') + + if length: + self.headers['Content-Length'] = builtin_str(length) + else: + self.headers['Transfer-Encoding'] = 'chunked' + else: + # Multi-part file uploads. + if files: + (body, content_type) = self._encode_files(files, data) + else: + if data: + body = self._encode_params(data) + if isinstance(data, basestring) or hasattr(data, 'read'): + content_type = None + else: + 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 + + self.body = body + + def prepare_content_length(self, body): + """Prepare Content-Length header based on request method and body""" + if body is not None: + length = super_len(body) + 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: + # 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' + + def prepare_auth(self, auth, url=''): + """Prepares the given HTTP auth data.""" + + # If no Auth is explicitly provided, extract it from the URL first. + if auth is None: + url_auth = get_auth_from_url(self.url) + auth = url_auth if any(url_auth) else None + + if auth: + if isinstance(auth, tuple) and len(auth) == 2: + # special-case basic HTTP auth + auth = HTTPBasicAuth(*auth) + + # Allow auth to make its changes. + r = auth(self) + + # Update self to reflect the auth changes. + self.__dict__.update(r.__dict__) + + # Recompute Content-Length + self.prepare_content_length(self.body) + + def prepare_cookies(self, cookies): + """Prepares the given HTTP cookie data. + + This function eventually generates a ``Cookie`` header from the + given cookies using cookielib. Due to cookielib's design, the header + will not be regenerated if it already exists, meaning this function + can only be called once for the life of the + :class:`PreparedRequest ` object. Any subsequent calls + to ``prepare_cookies`` will have no actual effect, unless the "Cookie" + header is removed beforehand. + """ + if isinstance(cookies, cookielib.CookieJar): + self._cookies = cookies + else: + self._cookies = cookiejar_from_dict(cookies) + + cookie_header = get_cookie_header(self._cookies, self) + if cookie_header is not None: + self.headers['Cookie'] = cookie_header + + def prepare_hooks(self, hooks): + """Prepares the given hooks.""" + # hooks can be passed as None to the prepare method and to this + # method. To prevent iterating over None, simply use an empty list + # if hooks is False-y + hooks = hooks or [] + for event in hooks: + self.register_hook(event, hooks[event]) + + +class Response(object): + """The :class:`Response ` object, which contains a + server's response to an HTTP request. + """ + + __attrs__ = [ + '_content', 'status_code', 'headers', 'url', 'history', + 'encoding', 'reason', 'cookies', 'elapsed', 'request' + ] + + def __init__(self): + self._content = False + self._content_consumed = False + self._next = None + + #: Integer Code of responded HTTP Status, e.g. 404 or 200. + self.status_code = None + + #: Case-insensitive Dictionary of Response Headers. + #: For example, ``headers['content-encoding']`` will return the + #: value of a ``'Content-Encoding'`` response header. + self.headers = CaseInsensitiveDict() + + #: File-like object representation of response (for advanced usage). + #: Use of ``raw`` requires that ``stream=True`` be set on the request. + #: This requirement does not apply for use internally to Requests. + self.raw = None + + #: Final URL location of Response. + self.url = None + + #: Encoding to decode with when accessing r.text. + self.encoding = None + + #: A list of :class:`Response ` objects from + #: the history of the Request. Any redirect responses will end + #: up here. The list is sorted from the oldest to the most recent request. + self.history = [] + + #: Textual reason of responded HTTP Status, e.g. "Not Found" or "OK". + self.reason = None + + #: A CookieJar of Cookies the server sent back. + self.cookies = cookiejar_from_dict({}) + + #: The amount of time elapsed between sending the request + #: and the arrival of the response (as a timedelta). + #: This property specifically measures the time taken between sending + #: the first byte of the request and finishing parsing the headers. It + #: is therefore unaffected by consuming the response content or the + #: value of the ``stream`` keyword argument. + self.elapsed = datetime.timedelta(0) + + #: The :class:`PreparedRequest ` object to which this + #: is a response. + self.request = None + + def __enter__(self): + return self + + def __exit__(self, *args): + self.close() + + def __getstate__(self): + # Consume everything; accessing the content attribute makes + # sure the content has been fully read. + if not self._content_consumed: + self.content + + return {attr: getattr(self, attr, None) for attr in self.__attrs__} + + def __setstate__(self, state): + for name, value in state.items(): + setattr(self, name, value) + + # pickled objects do not have .raw + setattr(self, '_content_consumed', True) + setattr(self, 'raw', None) + + def __repr__(self): + return '' % (self.status_code) + + def __bool__(self): + """Returns True if :attr:`status_code` is less than 400. + + This attribute checks if the status code of the response is between + 400 and 600 to see if there was a client error or a server error. If + the status code, is between 200 and 400, this will return True. This + is **not** a check to see if the response code is ``200 OK``. + """ + return self.ok + + def __nonzero__(self): + """Returns True if :attr:`status_code` is less than 400. + + This attribute checks if the status code of the response is between + 400 and 600 to see if there was a client error or a server error. If + the status code, is between 200 and 400, this will return True. This + is **not** a check to see if the response code is ``200 OK``. + """ + return self.ok + + def __iter__(self): + """Allows you to use a response as an iterator.""" + return self.iter_content(128) + + @property + def ok(self): + """Returns True if :attr:`status_code` is less than 400, False if not. + + This attribute checks if the status code of the response is between + 400 and 600 to see if there was a client error or a server error. If + the status code is between 200 and 400, this will return True. This + is **not** a check to see if the response code is ``200 OK``. + """ + try: + self.raise_for_status() + except HTTPError: + return False + return True + + @property + def is_redirect(self): + """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) + + @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)) + + @property + def next(self): + """Returns a PreparedRequest for the next request in a redirect chain, if there is one.""" + return self._next + + @property + def apparent_encoding(self): + """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 + request, this avoids reading the content at once into memory for + large responses. The chunk size is the number of bytes it should + read into memory. This is not necessarily the length of each item + returned as decoding can take place. + + chunk_size must be of type int or None. A value of None will + function differently depending on the value of `stream`. + stream=True will read data as it arrives in whatever size the + chunks are received. If stream=False, data is returned as + a single chunk. + + If decode_unicode is True, content will be decoded using the best + available encoding based on the response. + """ + + def generate(): + # Special case for urllib3. + if hasattr(self.raw, 'stream'): + try: + for chunk in self.raw.stream(chunk_size, decode_content=True): + yield chunk + except ProtocolError as e: + raise ChunkedEncodingError(e) + except DecodeError as e: + raise ContentDecodingError(e) + except ReadTimeoutError as e: + raise ConnectionError(e) + else: + # Standard file-like object. + while True: + chunk = self.raw.read(chunk_size) + if not chunk: + break + yield chunk + + self._content_consumed = True + + 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)) + # simulate reading small chunks of the content + reused_chunks = iter_slices(self._content, chunk_size) + + stream_chunks = generate() + + chunks = reused_chunks if self._content_consumed else stream_chunks + + if decode_unicode: + chunks = stream_decode_response_unicode(chunks, self) + + return chunks + + 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. + + .. note:: This method is not reentrant safe. + """ + + pending = None + + for chunk in self.iter_content(chunk_size=chunk_size, decode_unicode=decode_unicode): + + if pending is not None: + chunk = pending + chunk + + if delimiter: + lines = chunk.split(delimiter) + else: + lines = chunk.splitlines() + + if lines and lines[-1] and chunk and lines[-1][-1] == chunk[-1]: + pending = lines.pop() + else: + pending = None + + for line in lines: + yield line + + if pending is not None: + yield pending + + @property + def content(self): + """Content of the response, in bytes.""" + + if self._content is False: + # Read the contents. + if self._content_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_consumed = True + # don't need to release the connection; that's been handled by urllib3 + # since we exhausted the data. + return self._content + + @property + def text(self): + """Content of the response, in unicode. + + If Response.encoding is None, encoding will be guessed using + ``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 + non-HTTP knowledge to make a better guess at the encoding, you should + set ``r.encoding`` appropriately before accessing this property. + """ + + # Try charset from content-type + content = None + encoding = self.encoding + + if not self.content: + return str('') + + # Fallback to auto-detected encoding. + if self.encoding is None: + encoding = self.apparent_encoding + + # Decode unicode from given encoding. + try: + 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. + # + # A TypeError can be raised if encoding is None + # + # So we try blindly encoding. + content = str(self.content, errors='replace') + + return content + + def json(self, **kwargs): + r"""Returns the json-encoded content of a response, if any. + + :param \*\*kwargs: Optional arguments that ``json.loads`` takes. + :raises simplejson.JSONDecodeError: If the response body does not + contain valid json and simplejson is installed. + :raises json.JSONDecodeError: If the response body does not contain + valid json and simplejson is not installed on Python 3. + :raises ValueError: If the response body does not contain valid + json and simplejson is not installed on Python 2. + """ + + 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 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 + ) + 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) + + @property + def links(self): + """Returns the parsed header links of the response, if any.""" + + header = self.headers.get('link') + + # l = MultiDict() + l = {} + + if header: + links = parse_header_links(header) + + for link in links: + key = link.get('rel') or link.get('url') + l[key] = link + + return l + + def raise_for_status(self): + """Raises :class:`HTTPError`, if one occurred.""" + + 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') + except UnicodeDecodeError: + 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) + + elif 500 <= self.status_code < 600: + http_error_msg = u'%s Server Error: %s for url: %s' % (self.status_code, reason, self.url) + + if http_error_msg: + raise HTTPError(http_error_msg, response=self) + + def close(self): + """Releases the connection back to the pool. Once this method has been + called the underlying ``raw`` object must not be accessed again. + + *Note: Should not normally need to be called explicitly.* + """ + if not self._content_consumed: + self.raw.close() + + release_conn = getattr(self.raw, 'release_conn', None) + if release_conn is not None: + release_conn() diff --git a/venv/lib/python3.8/site-packages/requests/packages.py b/venv/lib/python3.8/site-packages/requests/packages.py new file mode 100644 index 0000000..00196bf --- /dev/null +++ b/venv/lib/python3.8/site-packages/requests/packages.py @@ -0,0 +1,26 @@ +import sys + +try: + import chardet +except ImportError: + import charset_normalizer as chardet + import warnings + + warnings.filterwarnings('ignore', 'Trying to detect', module='charset_normalizer') + +# This code exists for backwards compatibility reasons. +# I don't like it either. Just look the other way. :) + +for package in ('urllib3', 'idna'): + locals()[package] = __import__(package) + # This traversal is apparently necessary such that the identities are + # preserved (requests.packages.urllib3.* is urllib3.*) + for mod in list(sys.modules): + if mod == package or mod.startswith(package + '.'): + sys.modules['requests.packages.' + mod] = sys.modules[mod] + +target = chardet.__name__ +for mod in list(sys.modules): + if mod == target or mod.startswith(target + '.'): + sys.modules['requests.packages.' + target.replace(target, 'chardet')] = sys.modules[mod] +# Kinda cool, though, right? diff --git a/venv/lib/python3.8/site-packages/requests/sessions.py b/venv/lib/python3.8/site-packages/requests/sessions.py new file mode 100644 index 0000000..ae4bcc8 --- /dev/null +++ b/venv/lib/python3.8/site-packages/requests/sessions.py @@ -0,0 +1,781 @@ +# -*- coding: utf-8 -*- + +""" +requests.sessions +~~~~~~~~~~~~~~~~~ + +This module provides a Session object to manage and persist settings across +requests (cookies, auth, proxies). +""" +import os +import sys +import time +from datetime import timedelta +from collections import OrderedDict + +from .auth import _basic_auth_str +from .compat import cookielib, is_py3, urljoin, urlparse, Mapping +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 +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 +) + +from .status_codes import codes + +# formerly defined here, reexposed here for backward compatibility +from .models import REDIRECT_STATI + +# 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 +else: + preferred_clock = time.time + + +def merge_setting(request_setting, session_setting, dict_class=OrderedDict): + """Determines appropriate setting for a given request, taking into account + the explicit setting on that request, and the setting in the session. If a + setting is a dictionary, they will be merged together using `dict_class` + """ + + if session_setting is None: + return request_setting + + if request_setting is None: + return session_setting + + # Bypass if not a dictionary (e.g. verify) + if not ( + isinstance(session_setting, Mapping) and + isinstance(request_setting, Mapping) + ): + return request_setting + + merged_setting = dict_class(to_key_val_list(session_setting)) + merged_setting.update(to_key_val_list(request_setting)) + + # Remove keys that are set to None. Extract keys first to avoid altering + # the dictionary during iteration. + none_keys = [k for (k, v) in merged_setting.items() if v is None] + for key in none_keys: + del merged_setting[key] + + return merged_setting + + +def merge_hooks(request_hooks, session_hooks, dict_class=OrderedDict): + """Properly merges both requests and session hooks. + + This is necessary because when request_hooks == {'response': []}, the + merge breaks Session hooks entirely. + """ + if session_hooks is None or session_hooks.get('response') == []: + return request_hooks + + 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): + + 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 + # be called at least once upon the original response and at least twice + # on each subsequent redirect response (if any). + # If a custom mixin is used to handle this logic, it may be advantageous + # to cache the redirect location onto the response object as a private + # attribute. + if resp.is_redirect: + 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') + return None + + def should_strip_auth(self, old_url, new_url): + """Decide whether Authorization header should be removed when redirecting""" + old_parsed = urlparse(old_url) + new_parsed = urlparse(new_url) + if old_parsed.hostname != new_parsed.hostname: + return True + # Special case: allow http -> https redirect when using the standard + # 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)): + 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): + 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): + """Receives a Response. Returns a generator of Responses or Requests.""" + + hist = [] # keep track of history + + url = self.get_redirect_target(resp) + previous_fragment = urlparse(req.url).fragment + while url: + prepared_request = req.copy() + + # Update history and keep track of redirects. + # resp.history must ignore the original request in this loop + hist.append(resp) + resp.history = hist[1:] + + try: + resp.content # Consume socket so it can be released + except (ChunkedEncodingError, ContentDecodingError, RuntimeError): + resp.raw.read(decode_content=False) + + if len(resp.history) >= self.max_redirects: + raise TooManyRedirects('Exceeded {} redirects.'.format(self.max_redirects), response=resp) + + # Release the connection back into the pool. + resp.close() + + # Handle redirection without scheme (see: RFC 1808 Section 4) + if url.startswith('//'): + parsed_rurl = urlparse(resp.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: + parsed = parsed._replace(fragment=previous_fragment) + elif parsed.fragment: + previous_fragment = parsed.fragment + url = parsed.geturl() + + # Facilitate relative 'location' headers, as allowed by RFC 7231. + # (e.g. '/path/to/resource' instead of 'http://domain.tld/path/to/resource') + # Compliant with RFC3986, we percent encode the url. + if not parsed.netloc: + url = urljoin(resp.url, requote_uri(url)) + else: + url = requote_uri(url) + + prepared_request.url = to_native_string(url) + + 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): + # https://github.com/psf/requests/issues/3490 + 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) + + # Extract any cookies sent on the response to the cookiejar + # in the new request. Because we've mutated our copied prepared + # request, use the old one that we haven't yet touched. + extract_cookies_to_jar(prepared_request._cookies, req, resp.raw) + merge_cookies(prepared_request._cookies, self.cookies) + prepared_request.prepare_cookies(prepared_request._cookies) + + # Rebuild auth and proxy information. + proxies = self.rebuild_proxies(prepared_request, proxies) + self.rebuild_auth(prepared_request, resp) + + # 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) + ) + + # Attempt to rewind consumed file-like object. + if rewindable: + rewind_body(prepared_request) + + # Override the original request. + req = prepared_request + + if yield_requests: + yield req + else: + + resp = self.send( + req, + stream=stream, + timeout=timeout, + verify=verify, + cert=cert, + proxies=proxies, + allow_redirects=False, + **adapter_kwargs + ) + + extract_cookies_to_jar(self.cookies, prepared_request, resp.raw) + + # extract redirect url, if any, for the next loop + url = self.get_redirect_target(resp) + yield resp + + def rebuild_auth(self, prepared_request, response): + """When being redirected we may want to strip authentication from the + request to avoid leaking credentials. This method intelligently removes + and reapplies authentication where possible to avoid credential loss. + """ + headers = prepared_request.headers + url = prepared_request.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'] + + # .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 + NO_PROXY, we strip the proxy configuration. Otherwise, we set missing + proxy keys for this URL (in case they were stripped by a previous + redirect). + + This method also replaces the Proxy-Authorization header where + necessary. + + :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') + + 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'] + + 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) + + return new_proxies + + def rebuild_method(self, prepared_request, response): + """When being redirected we may want to change the method of the request + based on certain specs or browser behavior. + """ + 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' + + # Do what the browsers do, despite standards... + # First, turn 302s into GETs. + 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' + + prepared_request.method = method + + +class Session(SessionRedirectMixin): + """A Requests session. + + Provides cookie persistence, connection-pooling, and configuration. + + Basic Usage:: + + >>> import requests + >>> s = requests.Session() + >>> s.get('https://httpbin.org/get') + + + Or as a context manager:: + + >>> with requests.Session() as s: + ... s.get('https://httpbin.org/get') + + """ + + __attrs__ = [ + 'headers', 'cookies', 'auth', 'proxies', 'hooks', 'params', 'verify', + 'cert', 'adapters', 'stream', 'trust_env', + 'max_redirects', + ] + + def __init__(self): + + #: A case-insensitive dictionary of headers to be sent on each + #: :class:`Request ` sent from this + #: :class:`Session `. + self.headers = default_headers() + + #: Default Authentication tuple or object to attach to + #: :class:`Request `. + self.auth = None + + #: Dictionary mapping protocol or protocol and host to the URL of the proxy + #: (e.g. {'http': 'foo.bar:3128', 'http://host.name': 'foo.bar:4012'}) to + #: be used on each :class:`Request `. + self.proxies = {} + + #: Event-handling hooks. + self.hooks = default_hooks() + + #: Dictionary of querystring data to attach to each + #: :class:`Request `. The dictionary values may be lists for + #: representing multivalued query parameters. + self.params = {} + + #: Stream response content default. + self.stream = False + + #: SSL Verification default. + #: Defaults to `True`, requiring requests to verify the TLS certificate at the + #: remote end. + #: If verify is set to `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. + #: Only set this to `False` for testing. + self.verify = True + + #: SSL client certificate default, if String, path to ssl client + #: cert file (.pem). If Tuple, ('cert', 'key') pair. + self.cert = None + + #: Maximum number of redirects allowed. If the request exceeds this + #: limit, a :class:`TooManyRedirects` exception is raised. + #: This defaults to requests.models.DEFAULT_REDIRECT_LIMIT, which is + #: 30. + self.max_redirects = DEFAULT_REDIRECT_LIMIT + + #: Trust environment settings for proxy configuration, default + #: authentication and similar. + self.trust_env = True + + #: A CookieJar containing all currently outstanding cookies set on this + #: session. By default it is a + #: :class:`RequestsCookieJar `, but + #: may be any other ``cookielib.CookieJar`` compatible object. + self.cookies = cookiejar_from_dict({}) + + # Default connection adapters. + self.adapters = OrderedDict() + self.mount('https://', HTTPAdapter()) + self.mount('http://', HTTPAdapter()) + + def __enter__(self): + return self + + def __exit__(self, *args): + self.close() + + def prepare_request(self, request): + """Constructs a :class:`PreparedRequest ` for + transmission and returns it. The :class:`PreparedRequest` has settings + merged from the :class:`Request ` instance and those of the + :class:`Session`. + + :param request: :class:`Request` instance to prepare with this + session's settings. + :rtype: requests.PreparedRequest + """ + cookies = request.cookies or {} + + # Bootstrap CookieJar. + if not isinstance(cookies, cookielib.CookieJar): + cookies = cookiejar_from_dict(cookies) + + # Merge with session cookies + merged_cookies = merge_cookies( + merge_cookies(RequestsCookieJar(), self.cookies), cookies) + + # Set environment's basic authentication if not explicitly set. + auth = request.auth + if self.trust_env and not auth and not self.auth: + auth = get_netrc_auth(request.url) + + p = PreparedRequest() + p.prepare( + method=request.method.upper(), + url=request.url, + files=request.files, + data=request.data, + json=request.json, + 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, + hooks=merge_hooks(request.hooks, self.hooks), + ) + 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): + """Constructs a :class:`Request `, prepares it and sends it. + Returns :class:`Response ` object. + + :param method: method for the new :class:`Request` object. + :param url: URL for the new :class:`Request` object. + :param params: (optional) Dictionary or bytes to be sent in the query + string for the :class:`Request`. + :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 to send in the body of the + :class:`Request`. + :param headers: (optional) Dictionary of HTTP Headers to send with the + :class:`Request`. + :param cookies: (optional) Dict or CookieJar object to send with the + :class:`Request`. + :param files: (optional) Dictionary of ``'filename': file-like-objects`` + for multipart encoding upload. + :param auth: (optional) Auth tuple or callable to enable + Basic/Digest/Custom HTTP Auth. + :param timeout: (optional) How long to wait for the server to send + data before giving up, as a float, or a :ref:`(connect timeout, + read timeout) ` tuple. + :type timeout: float or tuple + :param allow_redirects: (optional) Set to True by default. + :type allow_redirects: bool + :param proxies: (optional) Dictionary mapping protocol or protocol and + hostname to the URL of the proxy. + :param stream: (optional) whether to immediately download the response + content. Defaults to ``False``. + :param verify: (optional) Either a boolean, in which case it controls whether we verify + the server's TLS certificate, or a string, in which case it must be a path + to a CA bundle to use. Defaults to ``True``. When set to + ``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`` + 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. + :rtype: requests.Response + """ + # Create the Request. + req = Request( + method=method.upper(), + url=url, + headers=headers, + files=files, + data=data or {}, + json=json, + params=params or {}, + auth=auth, + cookies=cookies, + hooks=hooks, + ) + prep = self.prepare_request(req) + + proxies = proxies or {} + + settings = self.merge_environment_settings( + prep.url, proxies, stream, verify, cert + ) + + # Send the request. + send_kwargs = { + 'timeout': timeout, + 'allow_redirects': allow_redirects, + } + send_kwargs.update(settings) + resp = self.send(prep, **send_kwargs) + + return resp + + def get(self, url, **kwargs): + r"""Sends a GET request. Returns :class:`Response` object. + + :param url: URL for the new :class:`Request` object. + :param \*\*kwargs: Optional arguments that ``request`` takes. + :rtype: requests.Response + """ + + 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. + + :param url: URL for the new :class:`Request` object. + :param \*\*kwargs: Optional arguments that ``request`` takes. + :rtype: requests.Response + """ + + 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. + + :param url: URL for the new :class:`Request` object. + :param \*\*kwargs: Optional arguments that ``request`` takes. + :rtype: requests.Response + """ + + 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. + + :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 to send in the body of the :class:`Request`. + :param \*\*kwargs: Optional arguments that ``request`` takes. + :rtype: requests.Response + """ + + 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. + + :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 \*\*kwargs: Optional arguments that ``request`` takes. + :rtype: requests.Response + """ + + return self.request('PUT', url, data=data, **kwargs) + + def patch(self, url, data=None, **kwargs): + r"""Sends a PATCH request. Returns :class:`Response` object. + + :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 \*\*kwargs: Optional arguments that ``request`` takes. + :rtype: requests.Response + """ + + return self.request('PATCH', url, data=data, **kwargs) + + def delete(self, url, **kwargs): + r"""Sends a DELETE request. Returns :class:`Response` object. + + :param url: URL for the new :class:`Request` object. + :param \*\*kwargs: Optional arguments that ``request`` takes. + :rtype: requests.Response + """ + + return self.request('DELETE', url, **kwargs) + + def send(self, request, **kwargs): + """Send a given PreparedRequest. + + :rtype: requests.Response + """ + # 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.rebuild_proxies(request, self.proxies)) + + # 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.') + + # Set up variables needed for resolve_redirects and dispatching of hooks + allow_redirects = kwargs.pop('allow_redirects', True) + stream = kwargs.get('stream') + hooks = request.hooks + + # Get the appropriate adapter to use + adapter = self.get_adapter(url=request.url) + + # Start time (approximately) of the request + start = preferred_clock() + + # Send the request + r = adapter.send(request, **kwargs) + + # Total elapsed time of the request (approximately) + elapsed = preferred_clock() - start + r.elapsed = timedelta(seconds=elapsed) + + # Response manipulation hooks + r = dispatch_hook('response', hooks, r, **kwargs) + + # Persist cookies + if r.history: + + # If the hooks create history then we want those cookies too + for resp in r.history: + extract_cookies_to_jar(self.cookies, resp.request, resp.raw) + + extract_cookies_to_jar(self.cookies, request, r.raw) + + # Resolve redirects if allowed. + if allow_redirects: + # Redirect resolving generator. + gen = self.resolve_redirects(r, request, **kwargs) + history = [resp for resp in gen] + else: + history = [] + + # Shuffle things around if there's history. + if history: + # Insert the first (original) request at the start + history.insert(0, r) + # Get the last request made + r = history.pop() + r.history = history + + # 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)) + except StopIteration: + pass + + if not stream: + r.content + + return r + + def merge_environment_settings(self, url, proxies, stream, verify, cert): + """ + Check the environment and merge it with some settings. + + :rtype: dict + """ + # 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 + 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. + if verify is True or verify is None: + verify = (os.environ.get('REQUESTS_CA_BUNDLE') or + os.environ.get('CURL_CA_BUNDLE')) + + # Merge all the kwargs. + proxies = merge_setting(proxies, self.proxies) + stream = merge_setting(stream, self.stream) + verify = merge_setting(verify, self.verify) + cert = merge_setting(cert, self.cert) + + return {'verify': verify, 'proxies': proxies, 'stream': stream, + 'cert': cert} + + def get_adapter(self, url): + """ + Returns the appropriate connection adapter for the given URL. + + :rtype: requests.adapters.BaseAdapter + """ + for (prefix, adapter) in self.adapters.items(): + + if url.lower().startswith(prefix.lower()): + return adapter + + # Nothing matches :-/ + raise InvalidSchema("No connection adapters were found for {!r}".format(url)) + + def close(self): + """Closes all adapters and as such the session""" + for v in self.adapters.values(): + v.close() + + def mount(self, prefix, adapter): + """Registers a connection adapter to a prefix. + + Adapters are sorted in descending order by prefix length. + """ + self.adapters[prefix] = adapter + keys_to_move = [k for k in self.adapters if len(k) < len(prefix)] + + for key in keys_to_move: + self.adapters[key] = self.adapters.pop(key) + + def __getstate__(self): + state = {attr: getattr(self, attr, None) for attr in self.__attrs__} + return state + + def __setstate__(self, state): + for attr, value in state.items(): + setattr(self, attr, value) + + +def session(): + """ + Returns a :class:`Session` for context-management. + + .. deprecated:: 1.0.0 + + This method has been deprecated since version 1.0.0 and is only kept for + backwards compatibility. New code should use :class:`~requests.sessions.Session` + to create a session. This may be removed at a future date. + + :rtype: Session + """ + return Session() diff --git a/venv/lib/python3.8/site-packages/requests/status_codes.py b/venv/lib/python3.8/site-packages/requests/status_codes.py new file mode 100644 index 0000000..d80a7cd --- /dev/null +++ b/venv/lib/python3.8/site-packages/requests/status_codes.py @@ -0,0 +1,123 @@ +# -*- 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 +items. + +Example:: + + >>> import requests + >>> requests.codes['temporary_redirect'] + 307 + >>> requests.codes.teapot + 418 + >>> requests.codes['\o/'] + 200 + +Some codes have multiple names, and both upper- and lower-case versions of +the names are allowed. For example, ``codes.ok``, ``codes.OK``, and +``codes.okay`` all correspond to the HTTP status code 200. +""" + +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',), + + # 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 + + # 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',), + + # 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'), +} + +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(('\\', '/')): + setattr(codes, title.upper(), code) + + def doc(code): + names = ', '.join('``%s``' % 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) + +_init() diff --git a/venv/lib/python3.8/site-packages/requests/structures.py b/venv/lib/python3.8/site-packages/requests/structures.py new file mode 100644 index 0000000..8ee0ba7 --- /dev/null +++ b/venv/lib/python3.8/site-packages/requests/structures.py @@ -0,0 +1,105 @@ +# -*- coding: utf-8 -*- + +""" +requests.structures +~~~~~~~~~~~~~~~~~~~ + +Data structures that power Requests. +""" + +from collections import OrderedDict + +from .compat import Mapping, MutableMapping + + +class CaseInsensitiveDict(MutableMapping): + """A case-insensitive ``dict``-like object. + + Implements all methods and operations of + ``MutableMapping`` as well as dict's ``copy``. Also + provides ``lower_items``. + + All keys are expected to be strings. The structure remembers the + case of the last key to be set, and ``iter(instance)``, + ``keys()``, ``items()``, ``iterkeys()``, and ``iteritems()`` + will contain case-sensitive keys. However, querying and contains + testing is case insensitive:: + + cid = CaseInsensitiveDict() + cid['Accept'] = 'application/json' + cid['aCCEPT'] == 'application/json' # True + list(cid) == ['Accept'] # True + + For example, ``headers['content-encoding']`` will return the + value of a ``'Content-Encoding'`` response header, regardless + of how the header name was originally stored. + + If the constructor, ``.update``, or equality comparison + operations are given keys that have equal ``.lower()``s, the + behavior is undefined. + """ + + def __init__(self, data=None, **kwargs): + self._store = OrderedDict() + if data is None: + data = {} + self.update(data, **kwargs) + + def __setitem__(self, key, value): + # Use the lowercased key for lookups, but store the actual + # key alongside the value. + self._store[key.lower()] = (key, value) + + def __getitem__(self, key): + return self._store[key.lower()][1] + + def __delitem__(self, key): + del self._store[key.lower()] + + def __iter__(self): + return (casedkey for casedkey, mappedvalue in self._store.values()) + + def __len__(self): + return len(self._store) + + def lower_items(self): + """Like iteritems(), but with all lowercase keys.""" + return ( + (lowerkey, keyval[1]) + for (lowerkey, keyval) + in self._store.items() + ) + + def __eq__(self, other): + if isinstance(other, Mapping): + other = CaseInsensitiveDict(other) + else: + return NotImplemented + # Compare insensitively + return dict(self.lower_items()) == dict(other.lower_items()) + + # Copy is required + def copy(self): + return CaseInsensitiveDict(self._store.values()) + + def __repr__(self): + return str(dict(self.items())) + + +class LookupDict(dict): + """Dictionary lookup object.""" + + def __init__(self, name=None): + self.name = name + super(LookupDict, self).__init__() + + def __repr__(self): + return '' % (self.name) + + def __getitem__(self, key): + # We allow fall-through here, so values default to None + + return self.__dict__.get(key, None) + + def get(self, key, default=None): + return self.__dict__.get(key, default) diff --git a/venv/lib/python3.8/site-packages/requests/utils.py b/venv/lib/python3.8/site-packages/requests/utils.py new file mode 100644 index 0000000..dbb02a0 --- /dev/null +++ b/venv/lib/python3.8/site-packages/requests/utils.py @@ -0,0 +1,1013 @@ +# -*- coding: utf-8 -*- + +""" +requests.utils +~~~~~~~~~~~~~~ + +This module provides utility functions that are used within Requests +that are also useful for external consumption. +""" + +import codecs +import contextlib +import io +import os +import re +import socket +import struct +import sys +import tempfile +import warnings +import zipfile +from collections import OrderedDict +from urllib3.util import make_headers + +from .__version__ import __version__ +from . import certs +# to_native_string is unused here, but imported here for backwards compatibility +from ._internal_utils import to_native_string +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) +from .cookies import cookiejar_from_dict +from .structures import CaseInsensitiveDict +from .exceptions import ( + InvalidURL, InvalidHeader, FileModeWarning, UnrewindableBodyError) + +NETRC_FILES = ('.netrc', '_netrc') + +DEFAULT_CA_BUNDLE_PATH = certs.where() + +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': + # 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 + except ImportError: + return False + + try: + 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]) + # ProxyOverride is almost always a string + proxyOverride = winreg.QueryValueEx(internetSettings, + 'ProxyOverride')[0] + except OSError: + return False + if not proxyEnable or not proxyOverride: + return False + + # make a check value list from the registry entry: replace the + # '' string by the localhost entry and the corresponding + # canonical entry. + proxyOverride = proxyOverride.split(';') + # now check if we match one of the registry values. + for test in proxyOverride: + if test == '': + 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 + if re.match(test, host, re.I): + return True + return False + + def proxy_bypass(host): # noqa + """Return True, if the host should be bypassed. + + Checks proxy settings gathered from the environment, if specified, + or the registry. + """ + if getproxies_environment(): + return proxy_bypass_environment(host) + else: + return proxy_bypass_registry(host) + + +def dict_to_sequence(d): + """Returns an internal sequence dictionary update.""" + + if hasattr(d, 'items'): + d = d.items() + + return d + + +def super_len(o): + total_length = None + current_position = 0 + + if hasattr(o, '__len__'): + total_length = len(o) + + elif hasattr(o, 'len'): + total_length = o.len + + elif hasattr(o, 'fileno'): + try: + fileno = o.fileno() + except io.UnsupportedOperation: + 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 hasattr(o, 'tell'): + try: + current_position = o.tell() + except (OSError, IOError): + # 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 + # let requests chunk it instead. + 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 + try: + # seek to end of file + o.seek(0, 2) + total_length = o.tell() + + # seek back to current position to support + # partially read file-like objects + o.seek(current_position or 0) + except (OSError, IOError): + total_length = 0 + + if total_length is None: + total_length = 0 + + return max(0, total_length - current_position) + + +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') + if netrc_file is not None: + netrc_locations = (netrc_file,) + else: + netrc_locations = ('~/{}'.format(f) for f in NETRC_FILES) + + try: + from netrc import netrc, NetrcParseError + + netrc_path = None + + for f in netrc_locations: + try: + loc = os.path.expanduser(f) + except KeyError: + # os.path.expanduser can fail when $HOME is undefined and + # getpwuid fails. See https://bugs.python.org/issue20164 & + # https://github.com/psf/requests/issues/1846 + return + + if os.path.exists(loc): + netrc_path = loc + break + + # Abort early if there isn't one. + if netrc_path is None: + return + + ri = urlparse(url) + + # Strip port numbers from netloc. This weird `if...encode`` dance is + # used for Python 3.2, which doesn't support unicode literals. + splitstr = b':' + if isinstance(url, str): + 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) + return (_netrc[login_i], _netrc[2]) + except (NetrcParseError, IOError): + # 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: + raise + + # App Engine hackiness. + except (ImportError, AttributeError): + pass + + +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] != '>'): + return os.path.basename(name) + + +def extract_zipped_paths(path): + """Replace nonexistent paths that look like they refer to a member of a zip + archive with the location of an extracted copy of the target, or else + just return the provided path unchanged. + """ + if os.path.exists(path): + # this is already a valid path, no need to do anything further + return path + + # find the first valid part of the provided path and treat that as a zip archive + # assume the rest of the path is the name of a member in the archive + 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 zipfile.is_zipfile(archive): + return path + + zip_file = zipfile.ZipFile(archive) + if member not in zip_file.namelist(): + return 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('/')[-1]) + if not os.path.exists(extracted_path): + # 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""" + replacer = os.rename if sys.version_info[0] == 2 else os.replace + tmp_descriptor, tmp_name = tempfile.mkstemp(dir=os.path.dirname(filename)) + try: + with os.fdopen(tmp_descriptor, 'wb') as tmp_handler: + yield tmp_handler + replacer(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 + OrderedDict, e.g., + + :: + + >>> from_key_val_list([('key', 'val')]) + OrderedDict([('key', 'val')]) + >>> from_key_val_list('string') + Traceback (most recent call last): + ... + ValueError: cannot encode objects that are not 2-tuples + >>> from_key_val_list({'key': 'val'}) + OrderedDict([('key', 'val')]) + + :rtype: OrderedDict + """ + if value is None: + return None + + if isinstance(value, (str, bytes, bool, int)): + raise ValueError('cannot encode objects that are not 2-tuples') + + return OrderedDict(value) + + +def to_key_val_list(value): + """Take an object and test to see if it can be represented as a + dictionary. If it can be, return a list of tuples, e.g., + + :: + + >>> to_key_val_list([('key', 'val')]) + [('key', 'val')] + >>> to_key_val_list({'key': 'val'}) + [('key', 'val')] + >>> to_key_val_list('string') + Traceback (most recent call last): + ... + ValueError: cannot encode objects that are not 2-tuples + + :rtype: list + """ + if value is None: + return None + + if isinstance(value, (str, bytes, bool, int)): + raise ValueError('cannot encode objects that are not 2-tuples') + + if isinstance(value, Mapping): + value = value.items() + + return list(value) + + +# From mitsuhiko/werkzeug (used with permission). +def parse_list_header(value): + """Parse lists as described by RFC 2068 Section 2. + + In particular, parse comma-separated lists where the elements of + the list may include quoted-strings. A quoted-string could + contain a comma. A non-quoted string could have quotes in the + middle. Quotes are removed automatically after parsing. + + It basically works like :func:`parse_set_header` just that items + may appear multiple times and case sensitivity is preserved. + + The return value is a standard :class:`list`: + + >>> parse_list_header('token, "quoted value"') + ['token', 'quoted value'] + + To create a header from the :class:`list` again, use the + :func:`dump_header` function. + + :param value: a string with a list header. + :return: :class:`list` + :rtype: list + """ + result = [] + for item in _parse_list_header(value): + if item[:1] == item[-1:] == '"': + item = unquote_header_value(item[1:-1]) + result.append(item) + return result + + +# From mitsuhiko/werkzeug (used with permission). +def parse_dict_header(value): + """Parse lists of key, value pairs as described by RFC 2068 Section 2 and + convert them into a python dict: + + >>> d = parse_dict_header('foo="is a fish", bar="as well"') + >>> type(d) is dict + True + >>> sorted(d.items()) + [('bar', 'as well'), ('foo', 'is a fish')] + + If there is no value for a key it will be `None`: + + >>> parse_dict_header('key_without_value') + {'key_without_value': None} + + To create a header from the :class:`dict` again, use the + :func:`dump_header` function. + + :param value: a string with a dict header. + :return: :class:`dict` + :rtype: dict + """ + result = {} + for item in _parse_list_header(value): + if '=' not in item: + result[item] = None + continue + name, value = item.split('=', 1) + if value[:1] == value[-1:] == '"': + value = unquote_header_value(value[1:-1]) + result[name] = value + return result + + +# From mitsuhiko/werkzeug (used with permission). +def unquote_header_value(value, is_filename=False): + r"""Unquotes a header value. (Reversal of :func:`quote_header_value`). + This does not use the real unquoting but what browsers are actually + using for quoting. + + :param value: the header value to unquote. + :rtype: str + """ + if value and value[0] == value[-1] == '"': + # this is not the real unquoting, but fixing this so that the + # RFC is met will result in bugs with internet explorer and + # probably some other browsers as well. IE for example is + # uploading files with "C:\foo\bar.txt" as filename + value = value[1:-1] + + # if this is a filename and the starting characters look like + # a UNC path, then just return the value without quotes. Using the + # 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('\\"', '"') + return value + + +def dict_from_cookiejar(cj): + """Returns a key/value dictionary from a CookieJar. + + :param cj: CookieJar object to extract cookies from. + :rtype: dict + """ + + cookie_dict = {} + + for cookie in cj: + cookie_dict[cookie.name] = cookie.value + + return cookie_dict + + +def add_dict_to_cookiejar(cj, cookie_dict): + """Returns a CookieJar from a key/value dictionary. + + :param cj: CookieJar to insert cookies into. + :param cookie_dict: Dict of key/values to insert into CookieJar. + :rtype: CookieJar + """ + + return cookiejar_from_dict(cookie_dict, cj) + + +def get_encodings_from_content(content): + """Returns encodings from given content string. + + :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) + + charset_re = re.compile(r']', flags=re.I) + pragma_re = re.compile(r']', flags=re.I) + xml_re = re.compile(r'^<\?xml.*?encoding=["\']*(.+?)["\'>]') + + return (charset_re.findall(content) + + pragma_re.findall(content) + + xml_re.findall(content)) + + +def _parse_content_type_header(header): + """Returns content type and parameters from given header + + :param header: string + :return: tuple containing content type and dictionary of + parameters + """ + + tokens = header.split(';') + content_type, params = tokens[0].strip(), tokens[1:] + params_dict = {} + items_to_strip = "\"' " + + for param in params: + param = param.strip() + if param: + key, value = param, True + 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) + params_dict[key.lower()] = value + return content_type, params_dict + + +def get_encoding_from_headers(headers): + """Returns encodings from given HTTP Header Dict. + + :param headers: dictionary to extract encoding from. + :rtype: str + """ + + 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 'text' in content_type: + return 'ISO-8859-1' + + 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' + + +def stream_decode_response_unicode(iterator, r): + """Stream decodes a iterator.""" + + if r.encoding is None: + for item in iterator: + yield item + return + + 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) + if rv: + yield rv + + +def iter_slices(string, slice_length): + """Iterate over slices of a string.""" + pos = 0 + if slice_length is None or slice_length <= 0: + slice_length = len(string) + while pos < len(string): + yield string[pos:pos + slice_length] + pos += slice_length + + +def get_unicode_from_response(r): + """Returns the requested content back in unicode. + + :param r: Response object to get unicode content from. + + Tried: + + 1. charset from content-type + 2. fall back and replace all unicode characters + + :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) + + tried_encodings = [] + + # Try charset from content-type + encoding = get_encoding_from_headers(r.headers) + + if encoding: + try: + return str(r.content, encoding) + except UnicodeError: + tried_encodings.append(encoding) + + # Fall back: + try: + return str(r.content, encoding, errors='replace') + except TypeError: + return r.content + + +# The unreserved URI characters (RFC 3986) +UNRESERVED_SET = frozenset( + "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz" + "0123456789-._~") + + +def unquote_unreserved(uri): + """Un-escape any percent-escape sequences in a URI that are unreserved + characters. This leaves all reserved, illegal and non-ASCII bytes encoded. + + :rtype: str + """ + 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) + + if c in UNRESERVED_SET: + parts[i] = c + parts[i][2:] + else: + parts[i] = '%' + parts[i] + else: + parts[i] = '%' + parts[i] + return ''.join(parts) + + +def requote_uri(uri): + """Re-quote the given URI. + + This function passes the given URI through an unquote/quote cycle to + ensure that it is fully and consistently quoted. + + :rtype: str + """ + safe_with_percent = "!#$%&'()*+,/:;=?@[]~" + safe_without_percent = "!#$&'()*+,/:;=?@[]~" + try: + # Unquote only the unreserved characters + # Then quote only illegal characters (do not quote reserved, + # unreserved, or '%') + return quote(unquote_unreserved(uri), safe=safe_with_percent) + except InvalidURL: + # We couldn't unquote the given URI, so let's try quoting it, but + # there may be unquoted '%'s in the URI. We need to make sure they're + # properly quoted so they do not cause issues elsewhere. + return quote(uri, safe=safe_without_percent) + + +def address_in_network(ip, net): + """This function allows you to check if an IP belongs to a network subnet + + Example: returns True if ip = 192.168.1.1 and net = 192.168.1.0/24 + returns False if ip = 192.168.1.1 and net = 192.168.100.0/24 + + :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 + return (ipaddr & netmask) == (network & netmask) + + +def dotted_netmask(mask): + """Converts mask from /xx format to xxx.xxx.xxx.xxx + + Example: if mask is 24 function returns 255.255.255.0 + + :rtype: str + """ + bits = 0xffffffff ^ (1 << 32 - mask) - 1 + return socket.inet_ntoa(struct.pack('>I', bits)) + + +def is_ipv4_address(string_ip): + """ + :rtype: bool + """ + try: + socket.inet_aton(string_ip) + except socket.error: + return False + return True + + +def is_valid_cidr(string_network): + """ + Very simple check of the cidr format in no_proxy variable. + + :rtype: bool + """ + if string_network.count('/') == 1: + try: + mask = int(string_network.split('/')[1]) + except ValueError: + return False + + if mask < 1 or mask > 32: + return False + + try: + socket.inet_aton(string_network.split('/')[0]) + except socket.error: + return False + else: + return False + return True + + +@contextlib.contextmanager +def set_environ(env_name, value): + """Set the environment variable 'env_name' to 'value' + + Save previous value, yield, and then restore the previous value stored in + the environment variable 'env_name'. + + If 'value' is None, do nothing""" + value_changed = value is not None + if value_changed: + old_value = os.environ.get(env_name) + os.environ[env_name] = value + try: + yield + finally: + if value_changed: + if old_value is None: + del os.environ[env_name] + else: + os.environ[env_name] = old_value + + +def should_bypass_proxies(url, no_proxy): + """ + Returns whether we should bypass proxies or not. + + :rtype: bool + """ + # 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()) + + # 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') + parsed = urlparse(url) + + if parsed.hostname is None: + # URLs don't always have hostnames, e.g. file:/// urls. + return True + + 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 + ) + + if is_ipv4_address(parsed.hostname): + for proxy_ip in no_proxy: + if is_valid_cidr(proxy_ip): + if address_in_network(parsed.hostname, proxy_ip): + return True + elif parsed.hostname == proxy_ip: + # If no_proxy ip was defined in plain IP notation instead of cidr notation & + # matches the IP of the index + return True + else: + host_with_port = parsed.hostname + if parsed.port: + host_with_port += ':{}'.format(parsed.port) + + for host in no_proxy: + if parsed.hostname.endswith(host) or host_with_port.endswith(host): + # The URL does match something in no_proxy, so we don't want + # to apply the proxies on this URL. + return True + + 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) + except (TypeError, socket.gaierror): + bypass = False + + if bypass: + return True + + return False + + +def get_environ_proxies(url, no_proxy=None): + """ + Return a dict of environment proxies. + + :rtype: dict + """ + if should_bypass_proxies(url, no_proxy=no_proxy): + return {} + else: + return getproxies() + + +def select_proxy(url, proxies): + """Select a proxy for the url, if applicable. + + :param url: The url being for the request + :param proxies: A dictionary of schemes or schemes and hosts to proxy URLs + """ + proxies = proxies or {} + urlparts = urlparse(url) + if urlparts.hostname is None: + return proxies.get(urlparts.scheme, proxies.get('all')) + + proxy_keys = [ + urlparts.scheme + '://' + urlparts.hostname, + urlparts.scheme, + 'all://' + urlparts.hostname, + 'all', + ] + proxy = None + for proxy_key in proxy_keys: + if proxy_key in proxies: + proxy = proxies[proxy_key] + break + + return proxy + + +def default_user_agent(name="python-requests"): + """ + Return a string representing the default user agent. + + :rtype: str + """ + return '%s/%s' % (name, __version__) + + +def default_headers(): + """ + :rtype: requests.structures.CaseInsensitiveDict + """ + return CaseInsensitiveDict({ + 'User-Agent': default_user_agent(), + 'Accept-Encoding': DEFAULT_ACCEPT_ENCODING, + 'Accept': '*/*', + 'Connection': 'keep-alive', + }) + + +def parse_header_links(value): + """Return a list of parsed link headers proxies. + + i.e. Link: ; rel=front; type="image/jpeg",; rel=back;type="image/jpeg" + + :rtype: list + """ + + links = [] + + replace_chars = ' \'"' + + value = value.strip(replace_chars) + if not value: + return links + + for val in re.split(', *<', value): + try: + url, params = val.split(';', 1) + except ValueError: + url, params = val, '' + + link = {'url': url.strip('<> \'"')} + + for param in params.split(';'): + try: + key, value = param.split('=') + except ValueError: + break + + link[key.strip(replace_chars)] = value.strip(replace_chars) + + links.append(link) + + return links + + +# Null bytes; no need to recreate these on each call to guess_json_utf +_null = '\x00'.encode('ascii') # encoding to ASCII for Python 3 +_null2 = _null * 2 +_null3 = _null * 3 + + +def guess_json_utf(data): + """ + :rtype: str + """ + # JSON always starts with two ASCII characters, so detection is as + # easy as counting the nulls and from their location and count + # 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 + if sample[:3] == codecs.BOM_UTF8: + 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 + nullcount = sample.count(_null) + if nullcount == 0: + return 'utf-8' + if nullcount == 2: + 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' + # Did not detect 2 valid UTF-16 ascii-range characters + if nullcount == 3: + if sample[:3] == _null3: + return 'utf-32-be' + if sample[1:] == _null3: + return 'utf-32-le' + # Did not detect a valid UTF-32 ascii-range character + return None + + +def prepend_scheme_if_needed(url, new_scheme): + """Given a URL that may or may not have a scheme, prepend the given scheme. + Does not replace a present scheme with the one provided as an argument. + + :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. + if not netloc: + netloc, path = path, netloc + + return urlunparse((scheme, netloc, path, params, query, fragment)) + + +def get_auth_from_url(url): + """Given a url with authentication components, extract them into a tuple of + username,password. + + :rtype: (str,str) + """ + parsed = urlparse(url) + + try: + auth = (unquote(parsed.username), unquote(parsed.password)) + except (AttributeError, TypeError): + 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. + + :param header: tuple, in the format (name, value). + """ + name, value = header + + if isinstance(value, bytes): + pat = _CLEAN_HEADER_REGEX_BYTE + 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))) + + +def urldefragauth(url): + """ + Given a url remove the fragment and the authentication part. + + :rtype: str + """ + scheme, netloc, path, params, query, fragment = urlparse(url) + + # see func:`prepend_scheme_if_needed` + if not netloc: + netloc, path = path, netloc + + netloc = netloc.rsplit('@', 1)[-1] + + 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): + try: + body_seek(prepared_request._body_position) + except (IOError, 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/venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/AUTHORS.txt b/venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/AUTHORS.txt new file mode 100644 index 0000000..72c87d7 --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/AUTHORS.txt @@ -0,0 +1,562 @@ +A_Rog +Aakanksha Agrawal <11389424+rasponic@users.noreply.github.com> +Abhinav Sagar <40603139+abhinavsagar@users.noreply.github.com> +ABHYUDAY PRATAP SINGH +abs51295 +AceGentile +Adam Chainz +Adam Tse +Adam Tse +Adam Wentz +admin +Adrien Morison +ahayrapetyan +Ahilya +AinsworthK +Akash Srivastava +Alan Yee +Albert Tugushev +Albert-Guan +albertg +Aleks Bunin +Alethea Flowers +Alex Gaynor +Alex Grönholm +Alex Loosley +Alex Morega +Alex Stachowiak +Alexander Shtyrov +Alexandre Conrad +Alexey Popravka +Alexey Popravka +Alli +Ami Fischman +Ananya Maiti +Anatoly Techtonik +Anders Kaseorg +Andreas Lutro +Andrei Geacar +Andrew Gaul +Andrey Bulgakov +Andrés Delfino <34587441+andresdelfino@users.noreply.github.com> +Andrés Delfino +Andy Freeland +Andy Freeland +Andy Kluger +Ani Hayrapetyan +Aniruddha Basak +Anish Tambe +Anrs Hu +Anthony Sottile +Antoine Musso +Anton Ovchinnikov +Anton Patrushev +Antonio Alvarado Hernandez +Antony Lee +Antti Kaihola +Anubhav Patel +Anuj Godase +AQNOUCH Mohammed +AraHaan +Arindam Choudhury +Armin Ronacher +Artem +Ashley Manton +Ashwin Ramaswami +atse +Atsushi Odagiri +Avner Cohen +Baptiste Mispelon +Barney Gale +barneygale +Bartek Ogryczak +Bastian Venthur +Ben Darnell +Ben Hoyt +Ben Rosser +Bence Nagy +Benjamin Peterson +Benjamin VanEvery +Benoit Pierre +Berker Peksag +Bernardo B. Marques +Bernhard M. Wiedemann +Bertil Hatt +Bogdan Opanchuk +BorisZZZ +Brad Erickson +Bradley Ayers +Brandon L. Reiss +Brandt Bucher +Brett Randall +Brian Cristante <33549821+brcrista@users.noreply.github.com> +Brian Cristante +Brian Rosner +BrownTruck +Bruno Oliveira +Bruno Renié +Bstrdsmkr +Buck Golemon +burrows +Bussonnier Matthias +c22 +Caleb Martinez +Calvin Smith +Carl Meyer +Carlos Liam +Carol Willing +Carter Thayer +Cass +Chandrasekhar Atina +Chih-Hsuan Yen +Chih-Hsuan Yen +Chris Brinker +Chris Hunt +Chris Jerdonek +Chris McDonough +Chris Wolfe +Christian Heimes +Christian Oudard +Christopher Hunt +Christopher Snyder +Clark Boylan +Clay McClure +Cody +Cody Soyland +Colin Watson +Connor Osborn +Cooper Lees +Cooper Ry Lees +Cory Benfield +Cory Wright +Craig Kerstiens +Cristian Sorinel +Curtis Doty +cytolentino +Damian Quiroga +Dan Black +Dan Savilonis +Dan Sully +daniel +Daniel Collins +Daniel Hahler +Daniel Holth +Daniel Jost +Daniel Shaulov +Daniele Esposti +Daniele Procida +Danny Hermes +Dav Clark +Dave Abrahams +Dave Jones +David Aguilar +David Black +David Bordeynik +David Bordeynik +David Caro +David Evans +David Linke +David Pursehouse +David Tucker +David Wales +Davidovich +derwolfe +Desetude +Diego Caraballo +DiegoCaraballo +Dmitry Gladkov +Domen Kožar +Donald Stufft +Dongweiming +Douglas Thor +DrFeathers +Dustin Ingram +Dwayne Bailey +Ed Morley <501702+edmorley@users.noreply.github.com> +Ed Morley +Eitan Adler +ekristina +elainechan +Eli Schwartz +Eli Schwartz +Emil Burzo +Emil Styrke +Endoh Takanao +enoch +Erdinc Mutlu +Eric Gillingham +Eric Hanchrow +Eric Hopper +Erik M. Bray +Erik Rose +Ernest W Durbin III +Ernest W. Durbin III +Erwin Janssen +Eugene Vereshchagin +everdimension +Felix Yan +fiber-space +Filip Kokosiński +Florian Briand +Florian Rathgeber +Francesco +Francesco Montesano +Frost Ming +Gabriel Curio +Gabriel de Perthuis +Garry Polley +gdanielson +Geoffrey Lehée +Geoffrey Sneddon +George Song +Georgi Valkov +Giftlin Rajaiah +gizmoguy1 +gkdoc <40815324+gkdoc@users.noreply.github.com> +Gopinath M <31352222+mgopi1990@users.noreply.github.com> +GOTO Hayato <3532528+gh640@users.noreply.github.com> +gpiks +Guilherme Espada +Guy Rozendorn +gzpan123 +Hanjun Kim +Hari Charan +Harsh Vardhan +Herbert Pfennig +Hsiaoming Yang +Hugo +Hugo Lopes Tavares +Hugo van Kemenade +hugovk +Hynek Schlawack +Ian Bicking +Ian Cordasco +Ian Lee +Ian Stapleton Cordasco +Ian Wienand +Ian Wienand +Igor Kuzmitshov +Igor Sobreira +Ilya Baryshev +INADA Naoki +Ionel Cristian Mărieș +Ionel Maries Cristian +Ivan Pozdeev +Jacob Kim +jakirkham +Jakub Stasiak +Jakub Vysoky +Jakub Wilk +James Cleveland +James Cleveland +James Firth +James Polley +Jan Pokorný +Jannis Leidel +jarondl +Jason R. Coombs +Jay Graves +Jean-Christophe Fillion-Robin +Jeff Barber +Jeff Dairiki +Jelmer Vernooij +jenix21 +Jeremy Stanley +Jeremy Zafran +Jiashuo Li +Jim Garrison +Jivan Amara +John Paton +John-Scott Atlakson +johnthagen +johnthagen +Jon Banafato +Jon Dufresne +Jon Parise +Jonas Nockert +Jonathan Herbert +Joost Molenaar +Jorge Niedbalski +Joseph Long +Josh Bronson +Josh Hansen +Josh Schneier +Juanjo Bazán +Julian Berman +Julian Gethmann +Julien Demoor +jwg4 +Jyrki Pulliainen +Kai Chen +Kamal Bin Mustafa +kaustav haldar +keanemind +Keith Maxwell +Kelsey Hightower +Kenneth Belitzky +Kenneth Reitz +Kenneth Reitz +Kevin Burke +Kevin Carter +Kevin Frommelt +Kevin R Patterson +Kexuan Sun +Kit Randel +kpinc +Krishna Oza +Kumar McMillan +Kyle Persohn +lakshmanaram +Laszlo Kiss-Kollar +Laurent Bristiel +Laurie Opperman +Leon Sasson +Lev Givon +Lincoln de Sousa +Lipis +Loren Carvalho +Lucas Cimon +Ludovic Gasc +Luke Macken +Luo Jiebin +luojiebin +luz.paz +László Kiss Kollár +László Kiss Kollár +Marc Abramowitz +Marc Tamlyn +Marcus Smith +Mariatta +Mark Kohler +Mark Williams +Mark Williams +Markus Hametner +Masaki +Masklinn +Matej Stuchlik +Mathew Jennings +Mathieu Bridon +Matt Good +Matt Maker +Matt Robenolt +matthew +Matthew Einhorn +Matthew Gilliard +Matthew Iversen +Matthew Trumbell +Matthew Willson +Matthias Bussonnier +mattip +Maxim Kurnikov +Maxime Rouyrre +mayeut +mbaluna <44498973+mbaluna@users.noreply.github.com> +mdebi <17590103+mdebi@users.noreply.github.com> +memoselyk +Michael +Michael Aquilina +Michael E. Karpeles +Michael Klich +Michael Williamson +michaelpacer +Mickaël Schoentgen +Miguel Araujo Perez +Mihir Singh +Mike +Mike Hendricks +Min RK +MinRK +Miro Hrončok +Monica Baluna +montefra +Monty Taylor +Nate Coraor +Nathaniel J. Smith +Nehal J Wani +Neil Botelho +Nick Coghlan +Nick Stenning +Nick Timkovich +Nicolas Bock +Nikhil Benesch +Nitesh Sharma +Nowell Strite +NtaleGrey +nvdv +Ofekmeister +ofrinevo +Oliver Jeeves +Oliver Tonnhofer +Olivier Girardot +Olivier Grisel +Ollie Rutherfurd +OMOTO Kenji +Omry Yadan +Oren Held +Oscar Benjamin +Oz N Tiram +Pachwenko <32424503+Pachwenko@users.noreply.github.com> +Patrick Dubroy +Patrick Jenkins +Patrick Lawson +patricktokeeffe +Patrik Kopkan +Paul Kehrer +Paul Moore +Paul Nasrat +Paul Oswald +Paul van der Linden +Paulus Schoutsen +Pavithra Eswaramoorthy <33131404+QueenCoffee@users.noreply.github.com> +Pawel Jasinski +Pekka Klärck +Peter Lisák +Peter Waller +petr-tik +Phaneendra Chiruvella +Phil Freo +Phil Pennock +Phil Whelan +Philip Jägenstedt +Philip Molloy +Philippe Ombredanne +Pi Delport +Pierre-Yves Rofes +pip +Prabakaran Kumaresshan +Prabhjyotsing Surjit Singh Sodhi +Prabhu Marappan +Pradyun Gedam +Pratik Mallya +Preet Thakkar +Preston Holmes +Przemek Wrzos +Pulkit Goyal <7895pulkit@gmail.com> +Qiangning Hong +Quentin Pradet +R. David Murray +Rafael Caricio +Ralf Schmitt +Razzi Abuissa +rdb +Remi Rampin +Remi Rampin +Rene Dudfield +Riccardo Magliocchetti +Richard Jones +RobberPhex +Robert Collins +Robert McGibbon +Robert T. McGibbon +robin elisha robinson +Roey Berman +Rohan Jain +Rohan Jain +Rohan Jain +Roman Bogorodskiy +Romuald Brunet +Ronny Pfannschmidt +Rory McCann +Ross Brattain +Roy Wellington Ⅳ +Roy Wellington Ⅳ +Ryan Wooden +ryneeverett +Sachi King +Salvatore Rinchiera +Savio Jomton +schlamar +Scott Kitterman +Sean +seanj +Sebastian Jordan +Sebastian Schaetz +Segev Finer +SeongSoo Cho +Sergey Vasilyev +Seth Woodworth +Shlomi Fish +Shovan Maity +Simeon Visser +Simon Cross +Simon Pichugin +sinoroc +Sorin Sbarnea +Stavros Korokithakis +Stefan Scherfke +Stephan Erb +stepshal +Steve (Gadget) Barnes +Steve Barnes +Steve Dower +Steve Kowalik +Steven Myint +stonebig +Stéphane Bidoul (ACSONE) +Stéphane Bidoul +Stéphane Klein +Sumana Harihareswara +Sviatoslav Sydorenko +Sviatoslav Sydorenko +Swat009 +Takayuki SHIMIZUKAWA +tbeswick +Thijs Triemstra +Thomas Fenzl +Thomas Grainger +Thomas Guettler +Thomas Johansson +Thomas Kluyver +Thomas Smith +Tim D. Smith +Tim Gates +Tim Harder +Tim Heap +tim smith +tinruufu +Tom Forbes +Tom Freudenheim +Tom V +Tomas Orsava +Tomer Chachamu +Tony Beswick +Tony Zhaocheng Tan +TonyBeswick +toonarmycaptain +Toshio Kuratomi +Travis Swicegood +Tzu-ping Chung +Valentin Haenel +Victor Stinner +victorvpaulo +Viktor Szépe +Ville Skyttä +Vinay Sajip +Vincent Philippon +Vinicyus Macedo <7549205+vinicyusmacedo@users.noreply.github.com> +Vitaly Babiy +Vladimir Rutsky +W. Trevor King +Wil Tan +Wilfred Hughes +William ML Leslie +William T Olson +Wilson Mo +wim glenn +Wolfgang Maier +Xavier Fernandez +Xavier Fernandez +xoviat +xtreak +YAMAMOTO Takashi +Yen Chi Hsuan +Yeray Diaz Diaz +Yoval P +Yu Jian +Yuan Jing Vincent Yan +Zearin +Zearin +Zhiping Deng +Zvezdan Petkovic +Łukasz Langa +Семён Марьясин diff --git a/venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/INSTALLER b/venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/INSTALLER new file mode 100644 index 0000000..a1b589e --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/INSTALLER @@ -0,0 +1 @@ +pip diff --git a/venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/LICENSE.txt b/venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/LICENSE.txt new file mode 100644 index 0000000..737fec5 --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/LICENSE.txt @@ -0,0 +1,20 @@ +Copyright (c) 2008-2019 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/venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/METADATA b/venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/METADATA new file mode 100644 index 0000000..4adf953 --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/METADATA @@ -0,0 +1,82 @@ +Metadata-Version: 2.1 +Name: setuptools +Version: 44.0.0 +Summary: Easily download, build, install, upgrade, and uninstall Python packages +Home-page: https://github.com/pypa/setuptools +Author: Python Packaging Authority +Author-email: distutils-sig@python.org +License: UNKNOWN +Project-URL: Documentation, https://setuptools.readthedocs.io/ +Keywords: CPAN PyPI distutils eggs package management +Platform: UNKNOWN +Classifier: Development Status :: 5 - Production/Stable +Classifier: Intended Audience :: Developers +Classifier: License :: OSI Approved :: MIT License +Classifier: Operating System :: OS Independent +Classifier: Programming Language :: Python :: 2 +Classifier: Programming Language :: Python :: 2.7 +Classifier: Programming Language :: Python :: 3 +Classifier: Programming Language :: Python :: 3.5 +Classifier: Programming Language :: Python :: 3.6 +Classifier: Programming Language :: Python :: 3.7 +Classifier: Programming Language :: Python :: 3.8 +Classifier: Topic :: Software Development :: Libraries :: Python Modules +Classifier: Topic :: System :: Archiving :: Packaging +Classifier: Topic :: System :: Systems Administration +Classifier: Topic :: Utilities +Requires-Python: !=3.0.*,!=3.1.*,!=3.2.*,!=3.3.*,!=3.4.*,>=2.7 +Description-Content-Type: text/x-rst; charset=UTF-8 + +.. image:: https://img.shields.io/pypi/v/setuptools.svg + :target: https://pypi.org/project/setuptools + +.. image:: https://img.shields.io/readthedocs/setuptools/latest.svg + :target: https://setuptools.readthedocs.io + +.. image:: https://img.shields.io/travis/pypa/setuptools/master.svg?label=Linux%20CI&logo=travis&logoColor=white + :target: https://travis-ci.org/pypa/setuptools + +.. image:: https://img.shields.io/appveyor/ci/pypa/setuptools/master.svg?label=Windows%20CI&logo=appveyor&logoColor=white + :target: https://ci.appveyor.com/project/pypa/setuptools/branch/master + +.. image:: https://img.shields.io/codecov/c/github/pypa/setuptools/master.svg?logo=codecov&logoColor=white + :target: https://codecov.io/gh/pypa/setuptools + +.. image:: https://tidelift.com/badges/github/pypa/setuptools?style=flat + :target: https://tidelift.com/subscription/pkg/pypi-setuptools?utm_source=pypi-setuptools&utm_medium=readme + +.. image:: https://img.shields.io/pypi/pyversions/setuptools.svg + +See the `Installation Instructions +`_ in the Python Packaging +User's Guide for instructions on installing, upgrading, and uninstalling +Setuptools. + +Questions and comments should be directed to the `distutils-sig +mailing list `_. +Bug reports and especially tested patches may be +submitted directly to the `bug tracker +`_. + +To report a security vulnerability, please use the +`Tidelift security contact `_. +Tidelift will coordinate the fix and disclosure. + + +For Enterprise +============== + +Available as part of the Tidelift Subscription. + +Setuptools and the maintainers of thousands of other packages are working with Tidelift to deliver one enterprise subscription that covers all of the open source you use. + +`Learn more `_. + +Code of Conduct +=============== + +Everyone interacting in the setuptools project's codebases, issue trackers, +chat rooms, and mailing lists is expected to follow the +`PyPA Code of Conduct `_. + + diff --git a/venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/RECORD b/venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/RECORD new file mode 100644 index 0000000..32b8a84 --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/RECORD @@ -0,0 +1,163 @@ +../../../bin/easy_install,sha256=4DRAdRywY6MW0wB-bN1--ZtEd9HSTgvoauVDQ47yHPY,270 +../../../bin/easy_install-3.8,sha256=4DRAdRywY6MW0wB-bN1--ZtEd9HSTgvoauVDQ47yHPY,270 +__pycache__/easy_install.cpython-38.pyc,, +easy_install.py,sha256=MDC9vt5AxDsXX5qcKlBz2TnW6Tpuv_AobnfhCJ9X3PM,126 +setuptools-44.0.0.dist-info/AUTHORS.txt,sha256=RtqU9KfonVGhI48DAA4-yTOBUhBtQTjFhaDzHoyh7uU,21518 +setuptools-44.0.0.dist-info/INSTALLER,sha256=zuuue4knoyJ-UwPPXg8fezS7VCrXJQrAP7zeNuwvFQg,4 +setuptools-44.0.0.dist-info/LICENSE.txt,sha256=W6Ifuwlk-TatfRU2LR7W1JMcyMj5_y1NkRkOEJvnRDE,1090 +setuptools-44.0.0.dist-info/METADATA,sha256=L93fcafgVw4xoJUNG0lehyy0prVj-jU_JFxRh0ZUtos,3523 +setuptools-44.0.0.dist-info/RECORD,, +setuptools-44.0.0.dist-info/WHEEL,sha256=kGT74LWyRUZrL4VgLh6_g12IeVl_9u9ZVhadrgXZUEY,110 +setuptools-44.0.0.dist-info/dependency_links.txt,sha256=HlkCFkoK5TbZ5EMLbLKYhLcY_E31kBWD8TqW2EgmatQ,239 +setuptools-44.0.0.dist-info/entry_points.txt,sha256=ZmIqlp-SBdsBS2cuetmU2NdSOs4DG0kxctUR9UJ8Xk0,3150 +setuptools-44.0.0.dist-info/top_level.txt,sha256=2HUXVVwA4Pff1xgTFr3GsTXXKaPaO6vlG6oNJ_4u4Tg,38 +setuptools-44.0.0.dist-info/zip-safe,sha256=AbpHGcgLb-kRsJGnwFEktk7uzpZOCcBY74-YBdrKVGs,1 +setuptools/__init__.py,sha256=WBpCcn2lvdckotabeae1TTYonPOcgCIF3raD2zRWzBc,7283 +setuptools/__pycache__/__init__.cpython-38.pyc,, +setuptools/__pycache__/_deprecation_warning.cpython-38.pyc,, +setuptools/__pycache__/_imp.cpython-38.pyc,, +setuptools/__pycache__/archive_util.cpython-38.pyc,, +setuptools/__pycache__/build_meta.cpython-38.pyc,, +setuptools/__pycache__/config.cpython-38.pyc,, +setuptools/__pycache__/dep_util.cpython-38.pyc,, +setuptools/__pycache__/depends.cpython-38.pyc,, +setuptools/__pycache__/dist.cpython-38.pyc,, +setuptools/__pycache__/errors.cpython-38.pyc,, +setuptools/__pycache__/extension.cpython-38.pyc,, +setuptools/__pycache__/glob.cpython-38.pyc,, +setuptools/__pycache__/installer.cpython-38.pyc,, +setuptools/__pycache__/launch.cpython-38.pyc,, +setuptools/__pycache__/lib2to3_ex.cpython-38.pyc,, +setuptools/__pycache__/monkey.cpython-38.pyc,, +setuptools/__pycache__/msvc.cpython-38.pyc,, +setuptools/__pycache__/namespaces.cpython-38.pyc,, +setuptools/__pycache__/package_index.cpython-38.pyc,, +setuptools/__pycache__/py27compat.cpython-38.pyc,, +setuptools/__pycache__/py31compat.cpython-38.pyc,, +setuptools/__pycache__/py33compat.cpython-38.pyc,, +setuptools/__pycache__/py34compat.cpython-38.pyc,, +setuptools/__pycache__/sandbox.cpython-38.pyc,, +setuptools/__pycache__/site-patch.cpython-38.pyc,, +setuptools/__pycache__/ssl_support.cpython-38.pyc,, +setuptools/__pycache__/unicode_utils.cpython-38.pyc,, +setuptools/__pycache__/version.cpython-38.pyc,, +setuptools/__pycache__/wheel.cpython-38.pyc,, +setuptools/__pycache__/windows_support.cpython-38.pyc,, +setuptools/_deprecation_warning.py,sha256=jU9-dtfv6cKmtQJOXN8nP1mm7gONw5kKEtiPtbwnZyI,218 +setuptools/_imp.py,sha256=jloslOkxrTKbobgemfP94YII0nhqiJzE1bRmCTZ1a5I,2223 +setuptools/_vendor/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 +setuptools/_vendor/__pycache__/__init__.cpython-38.pyc,, +setuptools/_vendor/__pycache__/ordered_set.cpython-38.pyc,, +setuptools/_vendor/__pycache__/pyparsing.cpython-38.pyc,, +setuptools/_vendor/__pycache__/six.cpython-38.pyc,, +setuptools/_vendor/ordered_set.py,sha256=dbaCcs27dyN9gnMWGF5nA_BrVn6Q-NrjKYJpV9_fgBs,15130 +setuptools/_vendor/packaging/__about__.py,sha256=CpuMSyh1V7adw8QMjWKkY3LtdqRUkRX4MgJ6nF4stM0,744 +setuptools/_vendor/packaging/__init__.py,sha256=6enbp5XgRfjBjsI9-bn00HjHf5TH21PDMOKkJW8xw-w,562 +setuptools/_vendor/packaging/__pycache__/__about__.cpython-38.pyc,, +setuptools/_vendor/packaging/__pycache__/__init__.cpython-38.pyc,, +setuptools/_vendor/packaging/__pycache__/_compat.cpython-38.pyc,, +setuptools/_vendor/packaging/__pycache__/_structures.cpython-38.pyc,, +setuptools/_vendor/packaging/__pycache__/markers.cpython-38.pyc,, +setuptools/_vendor/packaging/__pycache__/requirements.cpython-38.pyc,, +setuptools/_vendor/packaging/__pycache__/specifiers.cpython-38.pyc,, +setuptools/_vendor/packaging/__pycache__/tags.cpython-38.pyc,, +setuptools/_vendor/packaging/__pycache__/utils.cpython-38.pyc,, +setuptools/_vendor/packaging/__pycache__/version.cpython-38.pyc,, +setuptools/_vendor/packaging/_compat.py,sha256=Ugdm-qcneSchW25JrtMIKgUxfEEBcCAz6WrEeXeqz9o,865 +setuptools/_vendor/packaging/_structures.py,sha256=pVd90XcXRGwpZRB_qdFuVEibhCHpX_bL5zYr9-N0mc8,1416 +setuptools/_vendor/packaging/markers.py,sha256=-meFl9Fr9V8rF5Rduzgett5EHK9wBYRUqssAV2pj0lw,8268 +setuptools/_vendor/packaging/requirements.py,sha256=3dwIJekt8RRGCUbgxX8reeAbgmZYjb0wcCRtmH63kxI,4742 +setuptools/_vendor/packaging/specifiers.py,sha256=0ZzQpcUnvrQ6LjR-mQRLzMr8G6hdRv-mY0VSf_amFtI,27778 +setuptools/_vendor/packaging/tags.py,sha256=EPLXhO6GTD7_oiWEO1U0l0PkfR8R_xivpMDHXnsTlts,12933 +setuptools/_vendor/packaging/utils.py,sha256=VaTC0Ei7zO2xl9ARiWmz2YFLFt89PuuhLbAlXMyAGms,1520 +setuptools/_vendor/packaging/version.py,sha256=Npdwnb8OHedj_2L86yiUqscujb7w_i5gmSK1PhOAFzg,11978 +setuptools/_vendor/pyparsing.py,sha256=tmrp-lu-qO1i75ZzIN5A12nKRRD1Cm4Vpk-5LR9rims,232055 +setuptools/_vendor/six.py,sha256=A6hdJZVjI3t_geebZ9BzUvwRrIXo0lfwzQlM2LcKyas,30098 +setuptools/archive_util.py,sha256=kw8Ib_lKjCcnPKNbS7h8HztRVK0d5RacU3r_KRdVnmM,6592 +setuptools/build_meta.py,sha256=-9Nmj9YdbW4zX3TssPJZhsENrTa4fw3k86Jm1cdKMik,9597 +setuptools/cli-32.exe,sha256=dfEuovMNnA2HLa3jRfMPVi5tk4R7alCbpTvuxtCyw0Y,65536 +setuptools/cli-64.exe,sha256=KLABu5pyrnokJCv6skjXZ6GsXeyYHGcqOUT3oHI3Xpo,74752 +setuptools/cli.exe,sha256=dfEuovMNnA2HLa3jRfMPVi5tk4R7alCbpTvuxtCyw0Y,65536 +setuptools/command/__init__.py,sha256=QCAuA9whnq8Bnoc0bBaS6Lw_KAUO0DiHYZQXEMNn5hg,568 +setuptools/command/__pycache__/__init__.cpython-38.pyc,, +setuptools/command/__pycache__/alias.cpython-38.pyc,, +setuptools/command/__pycache__/bdist_egg.cpython-38.pyc,, +setuptools/command/__pycache__/bdist_rpm.cpython-38.pyc,, +setuptools/command/__pycache__/bdist_wininst.cpython-38.pyc,, +setuptools/command/__pycache__/build_clib.cpython-38.pyc,, +setuptools/command/__pycache__/build_ext.cpython-38.pyc,, +setuptools/command/__pycache__/build_py.cpython-38.pyc,, +setuptools/command/__pycache__/develop.cpython-38.pyc,, +setuptools/command/__pycache__/dist_info.cpython-38.pyc,, +setuptools/command/__pycache__/easy_install.cpython-38.pyc,, +setuptools/command/__pycache__/egg_info.cpython-38.pyc,, +setuptools/command/__pycache__/install.cpython-38.pyc,, +setuptools/command/__pycache__/install_egg_info.cpython-38.pyc,, +setuptools/command/__pycache__/install_lib.cpython-38.pyc,, +setuptools/command/__pycache__/install_scripts.cpython-38.pyc,, +setuptools/command/__pycache__/py36compat.cpython-38.pyc,, +setuptools/command/__pycache__/register.cpython-38.pyc,, +setuptools/command/__pycache__/rotate.cpython-38.pyc,, +setuptools/command/__pycache__/saveopts.cpython-38.pyc,, +setuptools/command/__pycache__/sdist.cpython-38.pyc,, +setuptools/command/__pycache__/setopt.cpython-38.pyc,, +setuptools/command/__pycache__/test.cpython-38.pyc,, +setuptools/command/__pycache__/upload.cpython-38.pyc,, +setuptools/command/__pycache__/upload_docs.cpython-38.pyc,, +setuptools/command/alias.py,sha256=KjpE0sz_SDIHv3fpZcIQK-sCkJz-SrC6Gmug6b9Nkc8,2426 +setuptools/command/bdist_egg.py,sha256=nnfV8Ah8IRC_Ifv5Loa9FdxL66MVbyDXwy-foP810zM,18185 +setuptools/command/bdist_rpm.py,sha256=B7l0TnzCGb-0nLlm6rS00jWLkojASwVmdhW2w5Qz_Ak,1508 +setuptools/command/bdist_wininst.py,sha256=_6dz3lpB1tY200LxKPLM7qgwTCceOMgaWFF-jW2-pm0,637 +setuptools/command/build_clib.py,sha256=bQ9aBr-5ZSO-9fGsGsDLz0mnnFteHUZnftVLkhvHDq0,4484 +setuptools/command/build_ext.py,sha256=Ib42YUGksBswm2mL5xmQPF6NeTA6HcqrvAtEgFCv32A,13019 +setuptools/command/build_py.py,sha256=yWyYaaS9F3o9JbIczn064A5g1C5_UiKRDxGaTqYbtLE,9596 +setuptools/command/develop.py,sha256=MQlnGS6uP19erK2JCNOyQYoYyquk3PADrqrrinqqLtA,8184 +setuptools/command/dist_info.py,sha256=5t6kOfrdgALT-P3ogss6PF9k-Leyesueycuk3dUyZnI,960 +setuptools/command/easy_install.py,sha256=0lY8Agxe-7IgMtxgxFuOY1NrDlBzOUlpCKsvayXlTYY,89903 +setuptools/command/egg_info.py,sha256=0e_TXrMfpa8nGTO7GmJcmpPCMWzliZi6zt9aMchlumc,25578 +setuptools/command/install.py,sha256=8doMxeQEDoK4Eco0mO2WlXXzzp9QnsGJQ7Z7yWkZPG8,4705 +setuptools/command/install_egg_info.py,sha256=4zq_Ad3jE-EffParuyDEnvxU6efB-Xhrzdr8aB6Ln_8,3195 +setuptools/command/install_lib.py,sha256=9zdc-H5h6RPxjySRhOwi30E_WfcVva7gpfhZ5ata60w,5023 +setuptools/command/install_scripts.py,sha256=UD0rEZ6861mTYhIdzcsqKnUl8PozocXWl9VBQ1VTWnc,2439 +setuptools/command/launcher manifest.xml,sha256=xlLbjWrB01tKC0-hlVkOKkiSPbzMml2eOPtJ_ucCnbE,628 +setuptools/command/py36compat.py,sha256=SzjZcOxF7zdFUT47Zv2n7AM3H8koDys_0OpS-n9gIfc,4986 +setuptools/command/register.py,sha256=kk3DxXCb5lXTvqnhfwx2g6q7iwbUmgTyXUCaBooBOUk,468 +setuptools/command/rotate.py,sha256=co5C1EkI7P0GGT6Tqz-T2SIj2LBJTZXYELpmao6d4KQ,2164 +setuptools/command/saveopts.py,sha256=za7QCBcQimKKriWcoCcbhxPjUz30gSB74zuTL47xpP4,658 +setuptools/command/sdist.py,sha256=IL1LepD2h8qGKOFJ3rrQVbjNH_Q6ViD40l0QADr4MEU,8088 +setuptools/command/setopt.py,sha256=NTWDyx-gjDF-txf4dO577s7LOzHVoKR0Mq33rFxaRr8,5085 +setuptools/command/test.py,sha256=u2kXngIIdSYqtvwFlHiN6Iye1IB4TU6uadB2uiV1szw,9602 +setuptools/command/upload.py,sha256=XT3YFVfYPAmA5qhGg0euluU98ftxRUW-PzKcODMLxUs,462 +setuptools/command/upload_docs.py,sha256=oXiGplM_cUKLwE4CWWw98RzCufAu8tBhMC97GegFcms,7311 +setuptools/config.py,sha256=6SB2OY3qcooOJmG_rsK_s0pKBsorBlDpfMJUyzjQIGk,20575 +setuptools/dep_util.py,sha256=fgixvC1R7sH3r13ktyf7N0FALoqEXL1cBarmNpSEoWg,935 +setuptools/depends.py,sha256=qt2RWllArRvhnm8lxsyRpcthEZYp4GHQgREl1q0LkFw,5517 +setuptools/dist.py,sha256=xtXaNsOsE32MwwQqErzgXJF7jsTQz9GYFRrwnPFQ0J0,49865 +setuptools/errors.py,sha256=MVOcv381HNSajDgEUWzOQ4J6B5BHCBMSjHfaWcEwA1o,524 +setuptools/extension.py,sha256=uc6nHI-MxwmNCNPbUiBnybSyqhpJqjbhvOQ-emdvt_E,1729 +setuptools/extern/__init__.py,sha256=4q9gtShB1XFP6CisltsyPqtcfTO6ZM9Lu1QBl3l-qmo,2514 +setuptools/extern/__pycache__/__init__.cpython-38.pyc,, +setuptools/glob.py,sha256=o75cHrOxYsvn854thSxE0x9k8JrKDuhP_rRXlVB00Q4,5084 +setuptools/gui-32.exe,sha256=XBr0bHMA6Hpz2s9s9Bzjl-PwXfa9nH4ie0rFn4V2kWA,65536 +setuptools/gui-64.exe,sha256=aYKMhX1IJLn4ULHgWX0sE0yREUt6B3TEHf_jOw6yNyE,75264 +setuptools/gui.exe,sha256=XBr0bHMA6Hpz2s9s9Bzjl-PwXfa9nH4ie0rFn4V2kWA,65536 +setuptools/installer.py,sha256=TCFRonRo01I79zo-ucf3Ymhj8TenPlmhMijN916aaJs,5337 +setuptools/launch.py,sha256=sd7ejwhBocCDx_wG9rIs0OaZ8HtmmFU8ZC6IR_S0Lvg,787 +setuptools/lib2to3_ex.py,sha256=t5e12hbR2pi9V4ezWDTB4JM-AISUnGOkmcnYHek3xjg,2013 +setuptools/monkey.py,sha256=FGc9fffh7gAxMLFmJs2DW_OYWpBjkdbNS2n14UAK4NA,5264 +setuptools/msvc.py,sha256=8baJ6aYgCA4TRdWQQi185qB9dnU8FaP4wgpbmd7VODs,46751 +setuptools/namespaces.py,sha256=F0Nrbv8KCT2OrO7rwa03om4N4GZKAlnce-rr-cgDQa8,3199 +setuptools/package_index.py,sha256=6pb-B1POtHyLycAbkDETk4fO-Qv8_sY-rjTXhUOoh6k,40605 +setuptools/py27compat.py,sha256=tvmer0Tn-wk_JummCkoM22UIjpjL-AQ8uUiOaqTs8sI,1496 +setuptools/py31compat.py,sha256=h2rtZghOfwoGYd8sQ0-auaKiF3TcL3qX0bX3VessqcE,838 +setuptools/py33compat.py,sha256=SMF9Z8wnGicTOkU1uRNwZ_kz5Z_bj29PUBbqdqeeNsc,1330 +setuptools/py34compat.py,sha256=KYOd6ybRxjBW8NJmYD8t_UyyVmysppFXqHpFLdslGXU,245 +setuptools/sandbox.py,sha256=9UbwfEL5QY436oMI1LtFWohhoZ-UzwHvGyZjUH_qhkw,14276 +setuptools/script (dev).tmpl,sha256=RUzQzCQUaXtwdLtYHWYbIQmOaES5Brqq1FvUA_tu-5I,218 +setuptools/script.tmpl,sha256=WGTt5piezO27c-Dbx6l5Q4T3Ff20A5z7872hv3aAhYY,138 +setuptools/site-patch.py,sha256=OumkIHMuoSenRSW1382kKWI1VAwxNE86E5W8iDd34FY,2302 +setuptools/ssl_support.py,sha256=nLjPUBBw7RTTx6O4RJZ5eAMGgjJG8beiDbkFXDZpLuM,8493 +setuptools/unicode_utils.py,sha256=NOiZ_5hD72A6w-4wVj8awHFM3n51Kmw1Ic_vx15XFqw,996 +setuptools/version.py,sha256=og_cuZQb0QI6ukKZFfZWPlr1HgJBPPn2vO2m_bI9ZTE,144 +setuptools/wheel.py,sha256=zct-SEj5_LoHg6XELt2cVRdulsUENenCdS1ekM7TlZA,8455 +setuptools/windows_support.py,sha256=5GrfqSP2-dLGJoZTq2g6dCKkyQxxa2n5IQiXlJCoYEE,714 diff --git a/venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/WHEEL b/venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/WHEEL new file mode 100644 index 0000000..ef99c6c --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/WHEEL @@ -0,0 +1,6 @@ +Wheel-Version: 1.0 +Generator: bdist_wheel (0.34.2) +Root-Is-Purelib: true +Tag: py2-none-any +Tag: py3-none-any + diff --git a/venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/dependency_links.txt b/venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/dependency_links.txt new file mode 100644 index 0000000..e87d021 --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/dependency_links.txt @@ -0,0 +1,2 @@ +https://files.pythonhosted.org/packages/source/c/certifi/certifi-2016.9.26.tar.gz#md5=baa81e951a29958563689d868ef1064d +https://files.pythonhosted.org/packages/source/w/wincertstore/wincertstore-0.2.zip#md5=ae728f2f007185648d0c7a8679b361e2 diff --git a/venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/entry_points.txt b/venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/entry_points.txt new file mode 100644 index 0000000..0fed3f1 --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/entry_points.txt @@ -0,0 +1,68 @@ +[console_scripts] +easy_install = setuptools.command.easy_install:main + +[distutils.commands] +alias = setuptools.command.alias:alias +bdist_egg = setuptools.command.bdist_egg:bdist_egg +bdist_rpm = setuptools.command.bdist_rpm:bdist_rpm +bdist_wininst = setuptools.command.bdist_wininst:bdist_wininst +build_clib = setuptools.command.build_clib:build_clib +build_ext = setuptools.command.build_ext:build_ext +build_py = setuptools.command.build_py:build_py +develop = setuptools.command.develop:develop +dist_info = setuptools.command.dist_info:dist_info +easy_install = setuptools.command.easy_install:easy_install +egg_info = setuptools.command.egg_info:egg_info +install = setuptools.command.install:install +install_egg_info = setuptools.command.install_egg_info:install_egg_info +install_lib = setuptools.command.install_lib:install_lib +install_scripts = setuptools.command.install_scripts:install_scripts +rotate = setuptools.command.rotate:rotate +saveopts = setuptools.command.saveopts:saveopts +sdist = setuptools.command.sdist:sdist +setopt = setuptools.command.setopt:setopt +test = setuptools.command.test:test +upload_docs = setuptools.command.upload_docs:upload_docs + +[distutils.setup_keywords] +convert_2to3_doctests = setuptools.dist:assert_string_list +dependency_links = setuptools.dist:assert_string_list +eager_resources = setuptools.dist:assert_string_list +entry_points = setuptools.dist:check_entry_points +exclude_package_data = setuptools.dist:check_package_data +extras_require = setuptools.dist:check_extras +include_package_data = setuptools.dist:assert_bool +install_requires = setuptools.dist:check_requirements +namespace_packages = setuptools.dist:check_nsp +package_data = setuptools.dist:check_package_data +packages = setuptools.dist:check_packages +python_requires = setuptools.dist:check_specifier +setup_requires = setuptools.dist:check_requirements +test_loader = setuptools.dist:check_importable +test_runner = setuptools.dist:check_importable +test_suite = setuptools.dist:check_test_suite +tests_require = setuptools.dist:check_requirements +use_2to3 = setuptools.dist:assert_bool +use_2to3_exclude_fixers = setuptools.dist:assert_string_list +use_2to3_fixers = setuptools.dist:assert_string_list +zip_safe = setuptools.dist:assert_bool + +[egg_info.writers] +PKG-INFO = setuptools.command.egg_info:write_pkg_info +dependency_links.txt = setuptools.command.egg_info:overwrite_arg +depends.txt = setuptools.command.egg_info:warn_depends_obsolete +eager_resources.txt = setuptools.command.egg_info:overwrite_arg +entry_points.txt = setuptools.command.egg_info:write_entries +namespace_packages.txt = setuptools.command.egg_info:overwrite_arg +requires.txt = setuptools.command.egg_info:write_requirements +top_level.txt = setuptools.command.egg_info:write_toplevel_names + +[setuptools.finalize_distribution_options] +2to3_doctests = setuptools.dist:Distribution._finalize_2to3_doctests +features = setuptools.dist:Distribution._finalize_feature_opts +keywords = setuptools.dist:Distribution._finalize_setup_keywords +parent_finalize = setuptools.dist:_Distribution.finalize_options + +[setuptools.installation] +eggsecutable = setuptools.command.easy_install:bootstrap + diff --git a/venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/top_level.txt b/venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/top_level.txt new file mode 100644 index 0000000..4577c6a --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/top_level.txt @@ -0,0 +1,3 @@ +easy_install +pkg_resources +setuptools diff --git a/venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/zip-safe b/venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/zip-safe new file mode 100644 index 0000000..8b13789 --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/zip-safe @@ -0,0 +1 @@ + diff --git a/venv/lib/python3.8/site-packages/setuptools/__init__.py b/venv/lib/python3.8/site-packages/setuptools/__init__.py new file mode 100644 index 0000000..a71b2bb --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/__init__.py @@ -0,0 +1,228 @@ +"""Extensions to the 'distutils' for large or complex distributions""" + +import os +import sys +import functools +import distutils.core +import distutils.filelist +import re +from distutils.errors import DistutilsOptionError +from distutils.util import convert_path +from fnmatch import fnmatchcase + +from ._deprecation_warning import SetuptoolsDeprecationWarning + +from setuptools.extern.six import PY3, string_types +from setuptools.extern.six.moves import filter, map + +import setuptools.version +from setuptools.extension import Extension +from setuptools.dist import Distribution, Feature +from setuptools.depends import Require +from . import monkey + +__metaclass__ = type + + +__all__ = [ + 'setup', 'Distribution', 'Feature', 'Command', 'Extension', 'Require', + 'SetuptoolsDeprecationWarning', + 'find_packages' +] + +if PY3: + __all__.append('find_namespace_packages') + +__version__ = setuptools.version.__version__ + +bootstrap_install_from = None + +# If we run 2to3 on .py files, should we also convert docstrings? +# Default: yes; assume that we can detect doctests reliably +run_2to3_on_doctests = True +# Standard package names for fixer packages +lib2to3_fixer_packages = ['lib2to3.fixes'] + + +class PackageFinder: + """ + Generate a list of all Python packages found within a directory + """ + + @classmethod + def find(cls, where='.', exclude=(), include=('*',)): + """Return a list all Python packages found within directory 'where' + + 'where' is the root directory which will be searched for packages. It + should be supplied as a "cross-platform" (i.e. URL-style) path; it will + be converted to the appropriate local path syntax. + + 'exclude' is a sequence of package names to exclude; '*' can be used + as a wildcard in the names, such that 'foo.*' will exclude all + subpackages of 'foo' (but not 'foo' itself). + + 'include' is a sequence of package names to include. If it's + specified, only the named packages will be included. If it's not + specified, all found packages will be included. 'include' can contain + shell style wildcard patterns just like 'exclude'. + """ + + return list(cls._find_packages_iter( + convert_path(where), + cls._build_filter('ez_setup', '*__pycache__', *exclude), + cls._build_filter(*include))) + + @classmethod + def _find_packages_iter(cls, where, exclude, include): + """ + All the packages found in 'where' that pass the 'include' filter, but + not the 'exclude' filter. + """ + for root, dirs, files in os.walk(where, followlinks=True): + # Copy dirs to iterate over it, then empty dirs. + all_dirs = dirs[:] + dirs[:] = [] + + for dir in all_dirs: + full_path = os.path.join(root, dir) + rel_path = os.path.relpath(full_path, where) + package = rel_path.replace(os.path.sep, '.') + + # Skip directory trees that are not valid packages + if ('.' in dir or not cls._looks_like_package(full_path)): + continue + + # Should this package be included? + if include(package) and not exclude(package): + yield package + + # Keep searching subdirectories, as there may be more packages + # down there, even if the parent was excluded. + dirs.append(dir) + + @staticmethod + def _looks_like_package(path): + """Does a directory look like a package?""" + return os.path.isfile(os.path.join(path, '__init__.py')) + + @staticmethod + def _build_filter(*patterns): + """ + Given a list of patterns, return a callable that will be true only if + the input matches at least one of the patterns. + """ + return lambda name: any(fnmatchcase(name, pat=pat) for pat in patterns) + + +class PEP420PackageFinder(PackageFinder): + @staticmethod + def _looks_like_package(path): + return True + + +find_packages = PackageFinder.find + +if PY3: + find_namespace_packages = PEP420PackageFinder.find + + +def _install_setup_requires(attrs): + # Note: do not use `setuptools.Distribution` directly, as + # our PEP 517 backend patch `distutils.core.Distribution`. + dist = distutils.core.Distribution(dict( + (k, v) for k, v in attrs.items() + if k in ('dependency_links', 'setup_requires') + )) + # Honor setup.cfg's options. + dist.parse_config_files(ignore_option_errors=True) + if dist.setup_requires: + dist.fetch_build_eggs(dist.setup_requires) + + +def setup(**attrs): + # Make sure we have any requirements needed to interpret 'attrs'. + _install_setup_requires(attrs) + return distutils.core.setup(**attrs) + +setup.__doc__ = distutils.core.setup.__doc__ + + +_Command = monkey.get_unpatched(distutils.core.Command) + + +class Command(_Command): + __doc__ = _Command.__doc__ + + command_consumes_arguments = False + + def __init__(self, dist, **kw): + """ + Construct the command for dist, updating + vars(self) with any keyword parameters. + """ + _Command.__init__(self, dist) + vars(self).update(kw) + + def _ensure_stringlike(self, option, what, default=None): + val = getattr(self, option) + if val is None: + setattr(self, option, default) + return default + elif not isinstance(val, string_types): + raise DistutilsOptionError("'%s' must be a %s (got `%s`)" + % (option, what, val)) + return val + + def ensure_string_list(self, option): + r"""Ensure that 'option' is a list of strings. If 'option' is + currently a string, we split it either on /,\s*/ or /\s+/, so + "foo bar baz", "foo,bar,baz", and "foo, bar baz" all become + ["foo", "bar", "baz"]. + """ + val = getattr(self, option) + if val is None: + return + elif isinstance(val, string_types): + setattr(self, option, re.split(r',\s*|\s+', val)) + else: + if isinstance(val, list): + ok = all(isinstance(v, string_types) for v in val) + else: + ok = False + if not ok: + raise DistutilsOptionError( + "'%s' must be a list of strings (got %r)" + % (option, val)) + + def reinitialize_command(self, command, reinit_subcommands=0, **kw): + cmd = _Command.reinitialize_command(self, command, reinit_subcommands) + vars(cmd).update(kw) + return cmd + + +def _find_all_simple(path): + """ + Find all files under 'path' + """ + results = ( + os.path.join(base, file) + for base, dirs, files in os.walk(path, followlinks=True) + for file in files + ) + return filter(os.path.isfile, results) + + +def findall(dir=os.curdir): + """ + Find all files under 'dir' and return the list of full filenames. + Unless dir is '.', return full filenames with dir prepended. + """ + files = _find_all_simple(dir) + if dir == os.curdir: + make_rel = functools.partial(os.path.relpath, start=dir) + files = map(make_rel, files) + return list(files) + + +# Apply monkey patches +monkey.patch_all() diff --git a/venv/lib/python3.8/site-packages/setuptools/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..4f566699c348f9c001f476f31ddfd46322e47b83 GIT binary patch literal 7768 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 W)`9KN#_C~h**|YSdr{H95ab7TS&euA literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/setuptools/__pycache__/_imp.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/__pycache__/_imp.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..40c92b88c7118ae8cdb6e715a0a3429984259c35 GIT binary patch literal 1890 zcmZuyTW{Mo6xM~7W%-&kO)tYXZCIPSYZ7cJ+F=-qA+7_sXq_ULAr%G)ib%(@Wl1Gz zqzUAgrRZ~iLIUiiPkZb0eg|K-7ypI4bcb@9I9)08ko9<_RfXypM z>K|&V^$=U-IhfOrG`gBu7#IPbmo_*zg3yf+HzmRgN7@KzTw4eM(LG$ zW$^HZS27C&=aDkXkId-rOy30kKSBTflztWT-}Blh`fouWy;bSY(r#q%ncnR2mDD&< zap4AdO!L68)SK%Y^j~a68ZM5^DeRPA9qG~SGi1JRfTs$-2H5Nwc0I#veq*GkI={-V zb+rsx<2O?yHDQM+D#4!5caS2$^QoEY9rz#xN{0`h3>mk>pik@tIKicQ#f!iZ_G7eoSPU>APq zF(wKF&+i5ip$DR}mL>mWQE*gv{=!|`Sa+IjQC*engXm(e;jV7Co^G|;LW`L|iO0Lb zWJwrs@`{V<=KA(Vqv>vLudTIqnwy!g2_|M%Uu-oS>yM{qi?C8-{n_)@)8=C_+uYe| zwl`br?F;i_!#zg@iW3sm3&NP3gUHFnfkPHE)Q4LwP$vk9W5Dit;L~qp#0@s=bb?m` zffaeD&>sLiU0LRXWH||v#bG2*p5Vp(E+OIKOV)YWW1anFM))w{aU8N`7mf-}Rurd_ zXHMSSCmGLFM+P9(G~D^>6wr( z2!fhD6L+EW=`+E;f+s?qej<)@sdA!jD(|#5h38kP8?*`ytw}K>#jF(bAcQF&J|Ch| z*QxYQzn9{k6f#H?@gwxa%>SOqM*uUqfCBrFyQUAI?@PuXi)4Pz{x%FQv4<;tnLS6T zegw?veNe6EK1*A=ucHgH0tHbg{w!rnQl2DA6Ra+C{Ym;!+wxZxdDq3U@4D0mR8-)w zC--tmUdxPzxN-rWUmM3t4p#2_@c^=rN@DaoDda}!9Vxz+;!7#y!DjKHa^b1qW?{}E fZ2mIg`bhq#uS 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 literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/setuptools/__pycache__/build_meta.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/__pycache__/build_meta.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..9535ea6d8c1a180f949dc337dfbc3eb3f0b6f02f GIT binary patch literal 8495 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 literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/setuptools/__pycache__/config.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/__pycache__/config.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..66578d0f229eca7622c6515fb5d7b962b88b14f1 GIT binary patch literal 17896 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 M&oNlWZGIO22m7PykN^Mx literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/setuptools/__pycache__/depends.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/__pycache__/depends.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..9aa026dc6fe40cc91ec7091487ee67c767aa0815 GIT binary patch literal 5216 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 WCQ1SPzOyTfcj`^&N6!28rT+qGkwqE+ literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/setuptools/__pycache__/dist.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/__pycache__/dist.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..98fa40231e56c9b632ef058693eacffba0011074 GIT binary patch literal 42326 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 x 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 YFZLY6Dk%2j*8~5X@V{J+CLc|*zscwFR{#J2 literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/setuptools/__pycache__/extension.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/__pycache__/extension.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..eebaabe50c1f86f7cc92d69ca0c7c63c55a5192f GIT binary patch literal 1961 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 literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/setuptools/__pycache__/launch.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/__pycache__/launch.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..ca908b37cef7a8273d35a2dccbe2d1394ffccd6b GIT binary patch literal 824 zcmYjP%Wl*#6!jyorY#$UXjyr~Vvsr`7Qm)LNNiD6f!IuoA~*JQToNa>ot7D8Rs&1^ zpa1AR%!*0nuyu=05FnocnQiH%B0^UOwdyDMCMkb6*HJZ(!RoD1oL(U_mN8 z#hWjg5_g-t7mL^>Yq}ym>CqbBq_=2AdwP?J zM5MQ56}hcGg0nKHiCx~uJzf(aO@Z{*@;GN8@4JEEU%Cp2FYK6`^Q)8RpBM*jGo~Dy zbFnEulTtIKubR(5Q*+lDUR8_nCU=K{iqDFo=1LdE(TE0TrYcz!!P2}AR$3IIDZz-E zR_bMRYEJc%oN6D*FR~nM`<r~~GwopX@kB2k!MD+ zEtDtcwfzZ2e)L}&=u@Bi7xL6|X0@_xoV;X~Idh+L<~!dx`|IMOPoRA9`GfX9bwd8d z!F+LGunSfG4uX-0Fv_fyW>#cV?Axi6xshx7PFlR%7+ogw=Wd z+>U%0d#nND2Df2sG50wM{n45KWGGdUB_qy)ACuE0f2@kn0y!KE3ZcIC{a`z2GbXE< zpj(KbQ{*qXP)XhkSkX~jD(Uu>8X0??D^tSmqaYW zrZ->hsBEw^NCw-(9N)y*_Q?y*)9qu~J?_iy$&Tb|I8XqB+)0x|^iIrATZ1#*0IXu8 zV-+njrqa>9x4oq`+kWj;Xe!occ*ombC4i!&dY6;r-Qv;~4VV+iVzGb%pHqq@=;;Mi zmvJe_U|fLCm<^ zU>37qQ(!aj*s$3IIV*H^O zOvahs=ZR@f0_V>ZYp*&TIwl~r+f7m~Bd@wiQ!z&ZyHU;M8+)D<#Kw zVaDy(7y$zOR`%bra~JO`!@n**0WIQV5YgQ#6_p50v$51QeyVuR1R5qbap!X7zbW>R zMKEz_I=BH#^uaA&Y{6EEJ|_Un6dKxuZ?ts<&n@S!A%&rUAz+aD0XhosVYEliZG#Qq zWRQ3`rV|^`fUzMy1xz+ySz`<4oTHj}gzdx~o7Lk-h)ihhM@!eq1$m+lf2+1qqC{YQ zhQRfW;sKaqFx54|v*INW%cL4DPd82pEhGPmh&NGNiQ#uJPwp?_R@nqW3{XqJDW8ru z=i$13U_YdLVNGC?7I#ssqd=01k5C|0=d@nsF=Qa_nC3D6j#nn1a6#8&3?)d8OBl@N z*V;m9l9Tup4(Y~hrTks4Oexi>;!L2=N+u!aOi12lhxWcHbMdzr9_Hyz139u{dG^Y} E|El;zVgLXD literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/setuptools/__pycache__/monkey.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/__pycache__/monkey.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..d600c0a7ab67462bc21b4119310493f4444358a8 GIT binary patch literal 4644 zcmaJ_&5zs06(@%jMQODkwl|K`1Pzg|Mop}ZQzuOV!;Nb@sDpUp+K!VDO$n}slBlIf zd1kch6|_LnHPG}@1O<943j3Jf2YCXk74j3iu@xgZiN=NIm_(OHZ2Ps)4HK++Dce4trvP| zovb?WL*FjHsf9Jr+^jxW30J1HM%d_D;VQ3i@1Yg0@hbPxuJanNqut;uyn*%O={zgWLnkwH6)CAFPGpf3Z7{SzMS9GEpXZ-3gV zn=d~v#I6itQH*jP#CecPIZA>e4?aFnJv95hL?l6)%VE-1t!|2RK+bX5qX`|UD zff^ZJMXusBCv_7eBWRE+nPimsL`Ti06{C~IOVyU&i8*icS> z){NbL1>-<@IXM%1XdT)U*xeD?nzOyckj$0J9Te%J;^;Q*Z6gn)b5oTJ%%H3qSfc$) zSv=U`@#P<4^bZtk{31y}Lc@O&-nx_(?KqQ{(J5CptGb>_Xivp?I}s#t4m+KhLzIb7u&EmZ13N! zB1rj5x*>JUmHhz*r7}syNA@+8Lt8MYq#9~j1gRgz8Yd$5=L zj2qn2^v>dq z?Fyh)kkelmq7Y5joH<-0)rvgMO5D*d!H;$ZvU@@taRywrP~-+G%k!A`)T{V#WgmZL zwoMbW-;#y>4OC_IZN>UdWGgr^f`)yFOAs%C?txy7JVR%@*6^1c7S^x0FwtGB_>jB1 zR_-!f4rVF~Ga+#)XXq-0;2zm4xcU8BR97oU_y(f}?TfP7ajsckt-*e+extuOaiX>R zU!%X?-=G!I#=O5CZSX2~I<@PGzfP$b@#=FHR-Gok22K3!rt^dx=}85Zco`K4WNc5W zR1wO-dx`#pG}3fTU%XBPvWV%Vcm@6Oi!-=K41tRPKZj|n5Z$dT>BjAYt?~17E1*y? zKp<)DjM9upxW(of@f?`w>eX^akdZt2=de?kRK6{fqgo?b>zbIh%IFp|FMif9kHdgw;#dPB%^#a23Tc<3Q1`f-EKrzV$uZi@?#3+Nxig7*f`U5 zKv9Rsg3G3(*Oocx)uqqFO@f`-htbp;wws==Vj@;b7y}X)A%m_0{S3)i(dObU-ke@D zpwFcxx|%2Z(HYr>R(No;Pd* zaeo3iwYwJ!X`%~HIx&(@@gc}fSFbFbF{~d8plfr>DIY2}!3$QCyUah+u zj`$ekrC3Nw5nX{%IYllC``kXFV9vJ1HBg$iIV`fIS{wG2!mX1NTZ*$-_bU`h#&6kX z+@|jAM|=1v)XKl0QnZWxTe!p{hIa$ob;LRD+_8Rxw*z;1<)IIUF>eR%JvI(Q?+9K+ zpN(Hom5I&$Bl~v*>eR25{m-p@)3ubhTNjy)IotZu%Gnpzcmt~#uYYIN@BhcDmG7+j z^WrKxWwSB<#R+pG*pp;#1bF5_6~Iz}KvTEOiaZH!rfpHkqN9R)sT{$|uDxG+sZ>I9h~%y81aVy4aW7ZKGmnkbWkSKuZBxeu4`AVIfX6ILjG#C<0FGM;3P< z+s{(2W`AuVTVsc=BHytOEAS(z?}*8tB9Fs`Adhp2(jg%$>( zpnR?!n;S`NM$iLK+c1=qUO=pLg(P}E^h^_lRcbF>jIrzTv{vo}E;68J! R{+eI&Py0XctNtn9{V({X+hPC! literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/setuptools/__pycache__/msvc.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/__pycache__/msvc.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..26145e33a84060399adb70c9b3539ba486e5e05a GIT binary patch literal 39631 zcmd6Q3zQt!S!Q?jyXUEqG~toyTT?xwp6Tfx z-KrT$MNgtcj+5nVLV!RZ%R|a853?N3S(XEYWmz5v&MwPx*xf+bVqd_LU|?C;!*W0* z@qXWbtE#KIdlWg5*qu3b`_`>{Z&m&Gf8GE7|E-q>2J$id9h=xw`N5x##r}{d;lC_S zPU5g$iN|7QtQ0fjrcsZV;`mL}jip2>5ocMlo?J?mQcLMlTFz7T%u=?LUCNbmOZifM zsjt*0p=qqMcU{d%mlt$JT| zcwxuF{c}cXr^9;<)gM?YlnU|K%V?2|Rd+7t)t|>>{C`iZVZ0JEhs_PI#YzvFyUmT} zrq|-7F>|vyijrOC7IQ0pcbj|6?dE;BvIlqEVcw5B-j6%(#o12t0h~R6vwb)#m=EIY zL7eT!*_gQtXS;AVZW`0E@x7JrH)65;GfT^=xmq;~*2?m7Q`v>NrYbyNn^jG#IcFEn z*Q}LFy)gNXcNAuuOUt!-RawP+{@F(Ja>H+e#=*4{`G?p2%lGW|vErc<`2zlWUY+!A zDv$NzRr_MIQ8-dOR@i^#_{4!iWyzd4I^NOxQ>Xojy7%-tc$hf zWnjzYntf4NU$YYs$?mSL};c zb$LALCKsBuhMTTgb3jfvRkP$el162zinasKRp%?SSI_HSQP78qc2&*cA**kK!^Bu= zzG|0O8t8TQV%2mr-bms~`f{zIs`JQYs*Tl}YBpy1RN+7NaT15M14%UoJ{2n&X1tWZ zk;IY0kv8L?IYSMi%G7wq&6dl2zH-^km&;2{bEVFFf4O`KYS9hBU1F-3zJViSAPD<$)}&0I_+0`?#b!t)6?a%FT8N>jhNbkdrETa zk%RWq^1c zOMnf&D;cv5u)zh*2Av(Ko%CyW)ZOaUHFaGxwU*FqQ>U$jdfiU65@!0kv6i%xt>pE% zdcBpLj@crEi6PUGP*XmZ0@BNt1(28^5Cgs)H)rztz z_4-)BZWdOoYQer(Em(G?VOHwRMpe4Z~noNmqsDTwyGD<>G~kJ?2$?v7&&qARbG4YIAxy^$7PwVXoe+=zH<8&sHz3;09*z zclH_u&tk8rMyPYiTDFp3_7-`r0v}f{IS)@mTwSiH>dYQ1kR&sws;j4Jt1}_k&+Iu= zJUr*d+W>uxcxN z-ihQ%92PUN&B=Iw+%SgYgGl@1{2exu@q8SlX-Hi+0pU0c;U4_)0jYDnfJ2DV*R_!=pK z4^&aJ7f*oGv?&v9>Q@&WQ*Z};JP=cF3Ptwr&q0?Ga5{Az-=9+F^L9VDq8TWTb%9WLQUMW|v z%vP6e$olcLn*fElNxm-AdCN^Nf|~K0B&Tx|sM|>wyMfJ%#As4UY?A>B*c2ZDEesmz zgaOLf1WHk?6_HRR3=)G#D20qOsEL8np#z2YMv#5P1{!nX@G;{?x(nUwK=(M%eb~-G zg2k^J0kS97;_r_K$ew@%N>(1a4YHRx7``|umWA)k5_V&v2Hzo~ABI}__krNcK!dWi zT%Em#c=|;Q6aEgIgvyZz3tg%;%0QT@@vKJQ4TRX?qajeKJ*cntGTFyuoC(z!^$sNC zMkyCOw>r$?Kugk0_bAG~9fvi7BsOAz&5j6KjR39kamDKqO)!B19>QavLdJ~Sv4!|z zS{*f^?9`1l1FDI!0F}f}m`E36>L|`r3+aUnx#P#d1?{Yzqne`6##7D@3z_!NQldCA zUu~4@wF~8@kdvkHWUh8aS`(9~Y1isC`zrJW`*IbU!dPQvY58g~An-BaiXlBHa)&YL zX+Qbw6x$UZFB~o&K3qJarytHxM{f$~9h-8}ekC_yUA5ed)^x2>N~)_ID!F}S4kcCo za#=>Llnao*G}Q5Cdbme};f}oactRD?qdLfLjmC24m>x&@Kf_^>{9|c~%n`5&#d5VB z$t(xZ|D(|4`6LeO29j260fV|Nww8c4o466b8Cy(SV&u*VO$+tOexkM(pTqzE@hYvz*ROlbs457P0anPHq<pOfYlb3s+LumhX&g$ zT&&iY3-c>AQ|q(PYqglENVCfqD-biYQI+sGKJF+j%2u4+5M ztaGTR(ES!~gilcUTBA0qJguHcWaVP>?4`Tk_fDUOM^xmRav6ioVQ_cLw zJ*LMA#!i-!oXx-a7XF<5g?Bn5puj;A$KdjLPQQuIK4YPeQx!btbD&LtR1+_$p+sI`?wq1ev?;7wI#GykTV$ru2O|HnMxB}`@%nO6Kp3`_zFglXKwq`7RE(5lB1 zQ_$)sj=Cvr@=B<0L|r$ds*qx{RT*N~N0L^xJ|`y~gGzfttx>bf<^PFxmOMe+*&GI2 z(XSCvmdM6~=Oc?G6Xd}s1RFE9#LUEpjct6!q@$;Wguq$R_k6%lzW7ovg|%H#MvSL= zN*SDn6<=QV1`_=RRor-4(cmxz>k2Vloka3RT)mU|s8DzFwkXf#+2xhLz-0}Gyt5?& zhjyJVNDyu^QWPLs94yk7YB(PWp2vT4wE|8#SJ1r`2mx?COw0<894TC=*;dg*I=+@} z6Lir5gbOgo1lL%-yR+c3+Jz^>+dqpR^)4nIAQsE3GuX8H_>yetm`5OsgAa2HknmUETPFf033pOMyA889|Y{Lk&%Iue&tv!(k zRqrn1RH%jpM0ZZ0Q22j_H#5Mno&$~YJH;H1L#%YV^iGav542MFt&02D~L}#v8EVEx@#n6oz$hm>rtm z+%TX?BuvaUTQI%fq@+q!mc!^WiDf?Pu3`&xs@Zke%uBGF?-TsM1jB=Ol*3e4F);<( z>3Ol%)-FiEWK)7v0q%e8yhD)7lhmCouh+922=2)z+2c^}B^ezzYBV=$De zt1>0|K|z@IyfiWc#9SC+9t$K`XOt#ydurmdd+7Lc%@c+2@CTSW7A_sbEx3F&3)?YK zIKpMfad-%q5lvT{7@()T5$AHOv0Q_)O++mXL~b1#dKq=14Ryz0!Vw0_`V$Vc&^PDs z>xEP2TJR$4La_;s5P%TND_^r(;Xh>oodmZn_3J^?tJL~Udnwrc;aU7#@bYWHa|YYI19!4+^VUngVYY0Ui=SEdts~XC z-uiaP{-GXk@0o26`XWnwx$Ye})BrHlr||jp(7q3zKy)l4AbuhQh^>*~4^?_wVCW^^ zic_c070z(#dbz0^8dZDl3IXtQApnd<01#B^di`Fw-|Mw~ zqy4k6k`>NEs&lo#(~RyuDeMT}Zsr;76ar;TZoEEWjQ9h+h^H(oKIN~4VDdl&Cf#+T z)*~{;U|zQyC!Ei5vB(;Pt!M-@Ji~;ulnn(J3qMJCQowqIx!exiF(4n$-UbLkxeGbl z(2tXjF#!-mdeNO(j?iUvZI>#e|AJJK#1DrKNVrSA*<5VTd@w`nZhD4uM6re5?%Cen zbT0fj0Z7EYQ|b$O_mr}}pOBjicpzq7uM*{DGQ)AecK<3lj5 zadQFR`wtv^j$>?iH10%6BB&Ix{Lr0_j7LP{uOq|dVhnO@0lsTMfCN?!V++YsvG@J> zTG|UH14;XScSTXB5+l~^OG^K?gcM&W^%Yh_wkjNsbm%a|F&F%by$@XLM=m$trw zK1}W3urrLB&jBaIbwS*xxbzYr5HJN8#kW3q8-TrseA4>b* zT!BkOfV*yz&t1xbM9ZpLF-sXb(&EfDmatNIk-6jrq@8$;#l+^~%JLr(smJgXvEg)_ z|M|EPABB07zgzJ;X!s@0MxO#@dZXK8vUp~EONXUFy%+t-JFAV%(ITKWGvWG|T4utD zqk12c3KP+~P3Edh=9q|_t}(a3WRVF0rmisQWrO%;TzH9ZG=U6l5J_=mO@29<(zXcN zBW`!(H!AiqizD(!vOkH#dK|q+trY%(X9<=Hut(sxPlpr0hA|)upIjattPaW2C-cL|Gem&-4PKDIh!-TV5!b{Xfoq$Pzt7wu z^)@4azqwQLqsTvC79_s~`3KE0$!|q|m$_T=+mPR5?v?y@-+}x) z%mb3YANhyPqU3iXf6zQ6`3I0cY#xz(!F8IQ-{ z!e>Cx>UHgevlL*#8SsB`sL}5W(?h{?ZP5;-S~Cj#FnQXsnj3YFW(B_k=K1IBnQDgg zHxJWk=WX;K&N{+9JCw9a#?Wxbli9=naIM+(%By#6nUU^5F#=wpm~dH_ky{* z!8`$fDnYKq$WAY0 zZzk8$P>^;&QOVhPQIO!E$$uy}M|8LVTJ^QkH{&yjwai*}Eob+)ve)D2^VC}2dB`5X z^+70Id9C^YNBUZQt;AwR{UltzhFX2Zl$T?dUdKI#p@9ACp#RsQ2)&NpGSb^q=xwj` zwn6t6>gh|7o<660`b1nI0?m8Y&!Ml+T{?2!6mU+~`9nJ5KZ`g9Z9S4Wc7{7K+ez zQHX}=mJi=h`bNP!O3sGmj8~ldLIl!Duo0S|Ph>z7KaZ0dIF||j9Snd`V;Jl4umqJYAnsBDYfj6Y7SpU_WWXXg^Y{htc( zbprG?0i2y^5m$50n^9c#FjPCaF`n&Mz}BpSIOTm^n*=l39Y1SI^rC~2%MLgEv5q$C1!1>7;i3^;0 ze){}mX=Av8N1E{Or#NiWn6}#kkzUv~)L=D^^+F)_2BL_oEJ)b23rt^GFE3 za#m?T?nB6O`LWc0v0@=;PU6`tWwW||8&MGaypGP3w-kb;^3X|RYiRpk(%3`D#PUhQ zc+0>dVZSkAe#6<-Nn1VimI#fJOVPbo=Dv5#$K{!VHz9g^T?b`uyg2nHaRZvcNAM%a;-)OTl|3F;;!WDY z7r!0VKFl#=v)GWcBQzFWI29QLHb~)+L7>Z&zt9B{4|fGb@KFtbn#Obij-$H#rm=iL zSWCiL4jw#U1|9PP;3q<4n(Av`3nZQfw{h-Y??w_;b}J=6aK7bxxkF*S9csI}hEgpW zWsXXL=&hr=8M8W9S*hC{B;od-pB6q=uVZrX-GnpEMzOwhJo{EM>1+u>J6tmYXfgmE z0%*!Mtq(5`;uki?HOLWaz}9|B85?n5H&QV7Kr+PwO-fbA~zx`dr@k10~ zL=EN2^AOw+@3Zc3kS*6G;#XzxsvT;ur}4T;4y&73vgW%1KG_ENj}YK8{m8>#fdb!% zf;?0=0&-de*iJzHtpak!4lKsiAYF5uVc@bTxe&I9IcjW&Fr^LexF^bK{fm1_D%4st z0ctRu-I%IyT9RZ80tPSLO58**p;Z-p)^pT)tz*(&?5Lp&9Xr*N%1{=YVk5GBw_(i9u#66g294nUHL> zydqoCv%)|-bo0+N;K3-yFV8>=6;I2ctd9mgXOf>rXP@Oz(t$aa%Og-y0w^In@(D^6 z{%?vqn?lqSU{hpV`G7oRTrVKg&9kHgMC9`;j-2o@jGc~oMwIeXsKp>4qXE*>)?N@D z`CQs>2R`>IBbN~b^eq7c>OEc_8;2v8VjwWglpMdiGki|>OjK)H1>toFtySL*IH>!O zl#KI}h?bR6{1gkXF_F1|%m9SzaYBF)2C5b6dytf}oP82y5RxVF7ocVs!8AWazJo&5 zKSHC=b2K@Ph~+dV+ytF_BoWcFgAw%jL1ZAQ0iX{(knchUzz-3qoY7Zz2mN&AEQPa& zXrz*}49d6{p#;>vC?V5BzBwU+_X(Bj&&{5u{$ zMC@Y|1x(O7>CnGT@HFZK-gG?SB(TwilfdQ}PI97nsG=TcvB6@L;9BL2D8S#|lPo=s z%1I=C>3)>nLMiGZsR)6iUXl^D>N99I1qbwN`0eREu)zbww7Ga*D=>e`!K4*9mIrCV zwj4ep3Po4bt}zXWlRj;fb2iy5w7Tn%Xc!yAX$Qmh9-Ddvvt18zcRU2^Kt2Gxn?Q8l zcmlDn2(l{k7F3-@W!AdFK>O7o=z9WgbGyoO=)eOWCA;rrQwZ^|o|Pluq9PF}!Tlfz zh<}kum^>bUA|QZUV62CYndj5@Z1-Ez?zdX;PsFXP^b5`M=_FS7Snf!8BB#CmLrj*IVla^@^_>_%XJ`B2=*cnTjeCKM=kPOi zw)eh1gZq^FeE$lxghc))=ub0mVcD{_A}m`JDdFHBL>1U&Xuwe4!s3T?`>q?gHpQIut8mJ-0bA*KZ45r#O4WPF#ChO7Yj^a25G2WB{%_!f_#)cbCM>f<+gdXkdlAbi)L^Ed zwe2<2Sc1=p`7sW50?o_JehiWwcnOzlI9UUCZo(WxT!WcX0z1rph=uo~Z?55PU&HDx z@G~aizG+}^Vm^)t&eWv~D9fV8&QOhg@mfNfyj%OaqU+8VI4%71d2YX-at{HF20Hr?QMJpId@2! zw*^TEc^6ny5IR6(-{%a1p%z`R zVr!v!t<|=17BdcUxA9`0Ii+vYcMtbL4mNGLcdXdHjk$#&W6nt(EgmZ#(LaZs1kRYB z&_$ebplE_ckLsdFb$bp(rq~+2miMv}n1Y0G1 zLcCSvpRiTWl}(6S7PfwzH9N?>&j%jp`%{Fn&^L83NGi&zG<@26z#7#faE=J5G2F9f5tL;6e2ASBK~$M-Vf8*X7ifU<64kGl8pZX>iW>y2UU)a^ww9Y&is- z$S%=~O`O7Qn5K-9XMvi#+zHyjpjQA3T@kt>x%&DO&bAOtqxJrNz&dgCUVwGmI$)hR z8U-x;DSwU-{TEC+FfszRiKCyrBd|>zjew0}2JJNK%p*gC02g?~5YQ_Gp@U^=thW#QNs-0-erd@`1>My}ry*Qye5+KTX&CMS<@^1(oPsD`9aCgnS3m=U>_YyuQ z0U!0RnDh_|-JqB_`rCI13ZRMr3|;e&!XXe4pTr3@L#_zY4+YwFobj`=gHsF!5uAyj zFqS8PQl3d=WGFhqgv+@S|PgDCf`66Dc6HLI>vd7?V3&ZRFMz*vqETHk0vY zzM-H1UyBP>MPs9`h|Mfu!kjpI4-^Wg&4lqbdrT+7684yGd{q=&nO{1|)uXUJK8}%_ zQXIdMv3k_Wv#|Kcp+^osb}PC1Nbyl^05#OFqQJeOh^w6;*$L4X4zXB|q=;;yk z^lLbUEj!BW-3-EFE4Hn)N_Y)*BuLh?XTz5k&?{kA7WiUS6+AdSdWI0`=~VKI=-~H> zu%pPthDIT3HzjD&$j1vfD1My>Ln5L#mxv%T`5naze`Ov0Be9QQdq-|3^BUbc;va>- zDBY6i@`i;!OnR;x%lm2OMnJ(hSY{xMy|r#}ea3)u8!1t<@iz1$;MvZy3$PDq z)?S0Zy+cT+U6-&3o*=?Y$xO&V9`WJcioI_POREBLEU#kSPJwaUFg^PX`bD(Z+{%*N$dSzKXF$4q< zJsImM}tWAJ=vC`?$M%|-67d-nO=qP6 z_}OBIqsBZf+Md_ozvWdvl+ejnh~c8PZ-DvkE9rD(s@QE2A7_xUzW=VCzT=EgS2IjR zArnL7r+E4_6FMrY4>6%XiQ7+~liDn{t-aVZm8>hij~8XZk>*SFX(n7%(gvd+Wsb&3 z_0O676cd^E{Va2$XMdKtpJ(zfnfwxyUt#i#Ok}#)R%aw9z_^O5IUtHvLI%sp1G4gH z{TZ<26%>{VTbQQq5!D~-G#ET2K%50=j&?+450koSY-^T_+b@_oqr z!Semc`@!-9$d8&^#0h*5`K{(Q$qymV9qq-bUGHdL+JG|I%^t4dBgo5M_Q-EUUUsq< z$MzI<$=@UGHluv6xli(=$nQ7DCBFsvhs<|Kek<|^%!ehv4f&#ZQ1aW6KV%-3{C&tD zF&~lq4&;xTk4pZ2=gQ8VHlC6# zCoAv4cninyxM^qyR``#p8m+K!e2cCF`Z1TjH%n+$Q2L?+ydQX9I8k`6cHuzbnZ|5= z#jGAE&$OGANWG1w-&-se z-zQs5A1I8$Zg{$}TAW-m$8fefD;sLdrsQ4?RMs54L%ekCdh|ASZ2Ni~_zTZa{MiL~ zSYt2z6&sOa+?Y2In1R6Xlrrrxh&y__n0AH@Jdd5)mR6QR&m}_x1E*gq(|(O zAC&!*B=x6|Uc1n&=XU<2h$n=f|~dM>QyG+%%sJHjL9{un)cGz!=k-R_95|fC~cJg zAWJDqvGK1`9dkor^M@$o`cWeWC8=Kmkzj+|3cTSS{r<+oy#oZm03m!m7*Q~Zn$KBb z+*u4ptLrVb-$O{bxxMc2)!pr2^8WX@yEf1EnBT~S$M~XPA~YY4cD|l=%Zw-@w|lwU zILw7u%sqHR8P8sC$P1@$`-T#h5P3tQH&LFy)_EjUZs%dD`zWpX3Cy%kA;)F9qkwA5@In|bEcX=lJckz2{q*f}VH=kVULpynL*E1>p_&Y!+wR~usJ4Y^65 zLwt^2WpZ|$t5%luCq-sn#HTPAECqjFUE=J#-PJwO{T+yyWH}pghEY4GHHv*5^PZ(!C+MaE5U}TC7fD zYG(OLz@6Lo?+hc|jHg{VgHN7&?)fv5h?5s>BQl(#Ot*(H(0j2pJp3f3zEve8(*Qy& z59RkQXL}a}gQ^iAlGgo0_LUV{=gQr7kJd4f{TPh;jltkN$#d+n2x|=%?2&>;7}Ac` zm=`hi1+9DZZ-nUI2Co>&HQfN%Y*ATdAjN4R{1_kyiaTCjSMAGjO5Sn0dNs z*{>X*0Pkp@P8>z$|B5PZ0uA9DCIVaVNKoh+yLgoeZ5i4pN4C!(<+gV=gawtdR$99$ zo8OgEudqOf`umV8WiR6Pv>kP5`EKU?qyXo;h>eF(HI`3SMNm1GaHTVH4Vr&{4dSIFbcg6(2vZFD~v*zcVUJIX|BanDC+%uN(INtM|`j1G} ze`msx7Hb&IG_f3nJ0j*;cH>$K-Kx4GlTHRdHT*>o*B5An%1L) zs$FBgt_gZOpx|WpSQfmbs-~0V7&@6fFd#RS%?}1d$4-yz7tzRelNzLo^*fF1kqogk5 z?CvCZEk_GZz#+-NHMdVA42EN^=@vAoN7Bq*$F@3XkqdJ8&VZEZnz8{X@dBD6KCod9 zUC+#?<(}l>!_Ha{Jup1l0ZxnY?QUy)r96bPr$xvDmbw9;Irr(g-elOiHZxUS!Pl=e zT9gLhl+tgtK_Vj4cZXDD<;8%ke z33n=kDX@r(4H&^{tN7+j@#V{vhF`lh5X?^DxMexRfmkexK4*!mb7^Cbw<~2D`t{bq z=syNn{MlUsS`fb%DJIZPHk1>V!uj79h|xu~14bh(2=h7|)Ey1{_scwwyBsh`D2tgV zO21u5E*0_670jFeLo=gwQ;7G^IupJ_*QUjPrBn#>@*1K=7H3? zmDpp==oL}VWK2lHbVlXc&8*BS##D4djRJmxPy>$xe*;9iRI88<7Xe9xZ|y{Dk3N#? z&W79O%idTnzTkHZk2^C0`(psV#0$TI z#9tA675P%m)BGPf5@g{%`A4iPca(b*tZv48-Lt&)7)m&APJ=aa){ICL&XqZbeoL$F z{OvYmdwq0)hlnqH@;EXcQ@}S8k;6>c8l|ZWc?o~k_E-sd;w(BeXGTc#`+FiMKH?U* zEZ*A*Fzp~(?m1Z~i8Gw@V&8^qDAvRCS>|44a-Iob8APc3E(-+c!C1Q+v;+02XM?Fg zli<&yYAinj&2kW)T%9^&SDOg9BRqI7`sodBF*%5tg3}>Texm1erHGq#0N0<@-EFQ+ z*gE*UvdkF)S)Vlv+6!C>&7Q1z*awOKY#$&LHH#(`ox*xB^c$=X!eQJrm>Y^M62LN? z*Lq-L#~L3O%d`Vkfm;vp`^|S5X3hXsnx;=Zg%4IQ*PB<>=hg#I>b!OC)P;`|DrBfw z6W-hj5vdUY1HsKh2zM13ACt5+moo#F?nB4{leFmsKKd||Q15Q^OL>ZmDbT`cGQ~zz z66=_d&p$&Chhdi<1yGZqL#tL&mtzAd9pwnKE`Xiw8B?pjj(EC(&zawCu!?J_sJ-X3 z(Nhd18=s$+d+JYt&p-u5ENuF0)2d%>_+~G`)lUIbng@sq%jHVV2=w*^ZjP8BTNkwL znQltFRXX`Y#=GaIIdWvveylq+Sh#|LKfpH*8y$7CVy|UnL?gT*q@S(7TG96BZEFKh zpL_nf!qfZ+=*yV3TNj(lcNwkK4ZNr`(tRJFB@in$zZF>bnuQLtH6PM{#-An#Lt0xG zOXzG6fgA-`KntgEB3K)&^9ZIJV(<-{a~W?=1C(#h#bQO+oQpkGdPNfi#+8m>wLnJP zZE&}xnl|RbB*?h|MB8nwxjzFSxcy~TT+f`V{+i>oB}hci7<^kWLj$OL+cR%T_-bV5DhQJdS z_hJAPjj3Ws2SlO6UBjtXW`(H`+$sSAhKkGSn^fyuzn63p}Nl8_U*v$-pq5=UlAZ=(g2P?>t|W;f0#tEPayb30){vvliMz!gi$&I zlnD2vNkPJ=fqjV>zRElb8J1K#8_76!LiZF}NJUS#x{ZI>nO%1qoo?XSM25ktd5w92 z$xkuYi&ds|@bh00ESf=Xr_R*nHKwaYK$1tFY$AB_o5*O8z}!aToT!)7=WjqIz$&f3 z6KirI1!EXCGq{nVk?tmUr%c&d?!v0(>>M^c$jgqbnQe@hA=6B;6t;IbyI>lNcxs#{ z&75b+$2JN=^?jRSu*B!>KAiPq!z($TGq7jn0Cr?eVAo3cXuNOl3^oD5UX`*vJ@=@@ zruaE~sD&@6tIxFHXw8l4FMY=Bhw3rl+~&JUT&`DMFfrCo_zkYw1%HEtdi{<^wbP12 z^IM=@I>Xq?NZ(|Sd8laC>z>{1WkB0W>x~?p%*h6Vhh6*d7RwrAxX7Z&LF6NI?LY(V)1N@JkD!;E!-tBM z7=+yn_E0oeW^F~RfQgT+s+0>}K@=W-5spC^RjZVjR(cyJY$r?@>XR(RibMwd27AbO zr#-{`ht5xWG2I#n3EbN%pc$1V?w|l=2@6j6zNRsp=r@MHl1y=55E!-|=wyf;J)P@{ zk>PAWko_l-(N=jud0A!x+EJTL&12Gf6JiD*I~M7WGVZ^T#X;wQ{5+hCyz3N3)Qove z&^FYTeGTBihI4_$(>!((xry(^e+)~KINuCchm`sWdldOCK-farkV_3%HM7+nz zO9CZq87KTE3AVw&=2>9$+>0}g_*vryzBz)D6uu1-$0`W-b%Ou6dfd*~WXD)|y^c@T zw9?qECS%PoVDd)(CRjR{b>Bk&je!>Sb;9L%S}`!p|1pp@J?)@ z(LjVjA%rDC+=Tur2ZJHnd#DLAw!hEm;c7)AX?6KwtGbMj0W)%e{1MoT$Tn$%c!-8w zf$M!^KDhfzqjrgCkC>-Q1J3>6W3rtny!!NB#fT|FkeY7K=imm$L2Cxg^?K}L;cTUb zW_&B95c#3Q=cJdQvHoC>)vT{p!yg>EGeTyVT6bjJ={BK7K^WYWU=%Vb(*O@nu$~?M z#fZc5-wWU96t40JkpYbYP}E4Lu*d2-2K<`+k<{K!et6ZzwDCr`=mzHvy) zCkjs%p29@_RC{H%M?*B4eex8(A`Nsc)|;2BD%w^*TcN;Rd9DMJZlYqEifk8Rs_d~K zt6UyWyV(E>3%s1Z}h@AO<_?t@H3NQ#vGeV&R4{Q`3$U`6tZL=_SGm%PA*N-a!9 z{EFlixh$eKjjwgAJ~m9%XT`47t)d7QOW0Cr7lPAPmPJV~f`wF71Ko0`d{9o&o6M^m`YYYnUDK*v zDK0fvtCk>YDUH|^?1Qgp?Sa#nd~!#B&uNIyHw5Urea|c{;~OKVDc{sy7Vl%{qva)Q zb@nmXnU+bpR#`t|X-oU5r2=C<5GSbAHa4Y!Q|)GQl*w@>?_e^?p-tal+vZsxv$!}y4mPZ9mt4H*9@9ZU|U(@7(lzLf-e4AYX8$UcY~=8Q$3sYDs-qag+p2jC31YAUBXG6iwo z?(|&Fu&c|xS5D8b_vr=o4!s5sdn>%z3wevLV!X-M_&VAa-{3dUu8K9j$=`Y9oU`6K zzln3aYnp#5luq+p$Z>18P}S3;Zl#a=3_D&v4ZJi_9-yedqnbEV=fXK-6Q(w~^Npj~ zi97Ys>t8q*><9PEJ@Y2+#5oD>I%m{2rYjTof-y&j(R_$>0z~3W!3JepbH4T`{G!LeD|3eJUdZ?7kf(R zQKic=S9>H!VU|$c>eSrKYKB9NmJff#i*`=f6ndU|GyOAYok6EQ^v~>QFku%=b**N>25^8`4mi`0MrxhM?!kEV zp%|9WYi-6&xdQPrq>30Q$!g^)D$@`z0kg7tksG#0(n=9~a*JlYPt^xh(Z%cPBfOcd zQSs&le}NGNPXL5!YsASd~&o>QwDS`m_>gN;STHoT_9vP|-aa={^@yWo3~NS)=`^ z^Q)cc^LTux!f*+OzyP`@Wma^yJF+Zw3>lwpcVP6fjK`nVJLK6D%)S(x7CcIldL&6Y z?fIPUNN0IF9`FADnZvYy3^S0YnEubF-S+b#sOhnvD}HSZaABo z3}iV>R3-YI#rS-i?q6`vFSCLR*&U#%C(b1vULwIWNp{ky;>U3uj~~#{hEXXklK<;W z7XI#^?WrF@6_=-lkh?>|x?{y0K8_>8Z`e%|p7nK-EZ?x5z&+{XBx&zp;`rlE6&0n9 zvLYH*vvpOs_CPpc%*LM$tu%m?YAriUz#ZalsT75d<>Q@by92m$PT&pWpXMopWAj!*qnybUMf)@i)?Z>qpeS&4z&8lgsN{q4=Fr)Ij*QiY6eLF@} z$3wO~cP8KALpulw3~mE1Vv1;YL0@j|To6{^R1hxMG@y|mytCk}akerEh27 zK6epr5H56h?!1rq`~l1`_74o}{>Xl3SSxNCPibiaIM7^}zya}7jE zj`~X!wTa4sYu=qmU>LJ1ld7=|mwT{ReyV}zP6+H5} zdk$~`4jb=0L^zQ}q~Klzk0^vik}tMQyB6KwK)}PgK1t}HqKt(I zLph7Q!`YPL5Bm-dn@Dzn_F0R&K*AgUs};?jud?T&h|El$-*Uy0Kw&p$i`}?&txQ8WO&LQcv)9#aQza3v$0b}pfh(-6{;qi6YPTM;X zO`bJa^LVl7ksOJ+1bGMdKR{HZ2qSk$A&cBr~d6|rBE=FJ*% zQl0gOLLZl0(rK0mVxuR8a!KT%Y(P=44_)64Z-!y$`8WL_^upCJaG9M$Jh<|ZiQGp~ zbf86M&0S>49{0G97CAf!(J-5T5YI(kR`bhWp&EsJ59I+#qdY_-9fo<$OiM=SiamG( zQAydxM=umdN7n1hPw=^PFMA~d;t1t37x?h{?$$*o){oNOm(Ne6ANBss*iDgSK7H$^ zq>K}k%S~^+ebYLLIfw)K1t!aTRP9qmhpsic$ZQr`x{uKTinZmCg`T9Ic-1C%rb(WJ z@`yT@GfjjVY4h6NN8tJ_$L%6Z7P9E7>?OkgbD?T?0xz1v39s8!fEK1t@K5G0#9O`F ejg}CepUH$@)HK~E+-%|(g5jaN=7rwI;eP>8jhqqy literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/setuptools/__pycache__/package_index.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/__pycache__/package_index.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..0cb3c049904dcb39395a2683e49c2fe0f8976758 GIT binary patch literal 32970 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 literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/setuptools/__pycache__/py27compat.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/__pycache__/py27compat.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..c44177c1a809886c8bceb733c96897262d1c1700 GIT binary patch literal 1749 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 x+kbNS^y_b%pUIU;%xBY(*& z6F-23iF1Nb&$@SazIV^o-S>KJKs!0!kG?T}+G5jMSX`j12?7H~G6>|ZW{)3nEMJLZJ3PQflt3s9mX-S;m>UDqFgtj(a&oz7*MPpxLxe#t=qBJF~F z&+H_*D5cJlnd$$hqe>^4>D<(sI~E4cJCu(>iP3KDXOY P1B902kS^&H&u!u_$en6h literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/setuptools/__pycache__/sandbox.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/__pycache__/sandbox.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..3d9aa089403d6c5e135573292bc5937d3185a84f GIT binary patch literal 15536 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 Fe*vQ<4v7E& literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/setuptools/__pycache__/version.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/__pycache__/version.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..bebb447e154b4ee3140c078af579b38a4e7d184d GIT binary patch literal 292 zcmYjMJ5Iwu5S?8c#W6B+$pt7<7*m-BAsSj5ga~d{!8-|#o!!lTFmMWv03}!2mWnG- zu||>Ljb`SJ^yYVyWhn%lR!581kUz)bKax;f1UFR(960HrhL;@Sjd1!-*0hdpK^(?_ zahK{70;BP$j_yFvdC*_OEdC0;aOG2j)+sAxZ~VlGPRK#b_I#$g71L;>(+wJ*uh25y z8mrrTXIm-!%sajPyp%zVtycix3`(kUB j+qGE^<=++MZrZVW_Q}~sa@XTI38T#Tc0wu1$pQHR`X^BW literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/setuptools/__pycache__/wheel.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/__pycache__/wheel.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..8767df96fb3c15782f6a2060329965362794e84e GIT binary patch literal 7383 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 literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/setuptools/__pycache__/windows_support.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/__pycache__/windows_support.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..2ab9e442f11a6fa434985f752b759354eb5274d9 GIT binary patch literal 989 zcmZWo&u`N(6tR}4y99f zVY~59Y)AeT{sdn+?aYl6&nbfePx5=8pPoNIf3}a8mu&?0a_f2URYT~Tn%p-XCU0Qy z7vKmYI6~ecVh68zk?zgGcip7V)4RAzN8W~?j<#4u&CH2I7R8rQHihIumh(-<>>N>=Yv zl_0}a8sRFoFslOkOG0&Kb+SUjHUI(gU1E#`9&2NLY+PVKrLkG~@=%*&-zsngkWI7; z$js4PyVNf9xz6_mzFxXPpD@vt?B}0t2dqnlBSzF2g@n+=34~zbX)dUf!o(Sd5g_J} zkkNri*{p6CtM*tLJ0l^o*RIP22%UbQY#61}`XG(nvz&4frU`e~Uu|t{tZ#0*i)ANS zAVw!noO9uvQb*8_qF(TwuMEU2qr46Z72sA~f2UTJw(p0rx*p$`=AuZNO2;UY)`YTz zMw=VnDjZ`EdfmBepZ7iMj>|LK@A}=|kymQ=509GCf=5$q;u*V#hizGA&@SxmS^Y3+ zF_yBLAq~~4_wYYn`FQW3-ST&Oy`zKO<6g_(KWH{v9jP-a{=M%Ch)R8>;S!vNKLCd+ z7Pj#!wlzbuv4PnW$khy1fxuRjQ}3Y2-eW5sc=3d+?KmZQL>uaBa0{G;E!{FT{1d=R B_=Nxf literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/setuptools/_deprecation_warning.py b/venv/lib/python3.8/site-packages/setuptools/_deprecation_warning.py new file mode 100644 index 0000000..086b64d --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/_deprecation_warning.py @@ -0,0 +1,7 @@ +class SetuptoolsDeprecationWarning(Warning): + """ + Base class for warning deprecations in ``setuptools`` + + This class is not derived from ``DeprecationWarning``, and as such is + visible by default. + """ diff --git a/venv/lib/python3.8/site-packages/setuptools/_imp.py b/venv/lib/python3.8/site-packages/setuptools/_imp.py new file mode 100644 index 0000000..a3cce9b --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/_imp.py @@ -0,0 +1,73 @@ +""" +Re-implementation of find_module and get_frozen_object +from the deprecated imp module. +""" + +import os +import importlib.util +import importlib.machinery + +from .py34compat import module_from_spec + + +PY_SOURCE = 1 +PY_COMPILED = 2 +C_EXTENSION = 3 +C_BUILTIN = 6 +PY_FROZEN = 7 + + +def find_module(module, paths=None): + """Just like 'imp.find_module()', but with package support""" + spec = importlib.util.find_spec(module, paths) + if spec is None: + raise ImportError("Can't find %s" % module) + if not spec.has_location and hasattr(spec, 'submodule_search_locations'): + spec = importlib.util.spec_from_loader('__init__.py', spec.loader) + + kind = -1 + file = None + static = isinstance(spec.loader, type) + if spec.origin == 'frozen' or static and issubclass( + spec.loader, importlib.machinery.FrozenImporter): + kind = PY_FROZEN + path = None # imp compabilty + suffix = mode = '' # imp compability + elif spec.origin == 'built-in' or static and issubclass( + spec.loader, importlib.machinery.BuiltinImporter): + kind = C_BUILTIN + path = None # imp compabilty + suffix = mode = '' # imp compability + elif spec.has_location: + path = spec.origin + suffix = os.path.splitext(path)[1] + mode = 'r' if suffix in importlib.machinery.SOURCE_SUFFIXES else 'rb' + + if suffix in importlib.machinery.SOURCE_SUFFIXES: + kind = PY_SOURCE + elif suffix in importlib.machinery.BYTECODE_SUFFIXES: + kind = PY_COMPILED + elif suffix in importlib.machinery.EXTENSION_SUFFIXES: + kind = C_EXTENSION + + if kind in {PY_SOURCE, PY_COMPILED}: + file = open(path, mode) + else: + path = None + suffix = mode = '' + + return file, path, (suffix, mode, kind) + + +def get_frozen_object(module, paths=None): + spec = importlib.util.find_spec(module, paths) + if not spec: + raise ImportError("Can't find %s" % module) + return spec.loader.get_code(module) + + +def get_module(module, paths, info): + spec = importlib.util.find_spec(module, paths) + if not spec: + raise ImportError("Can't find %s" % module) + return module_from_spec(spec) diff --git a/venv/lib/python3.8/site-packages/setuptools/_vendor/__init__.py b/venv/lib/python3.8/site-packages/setuptools/_vendor/__init__.py new file mode 100644 index 0000000..e69de29 diff --git a/venv/lib/python3.8/site-packages/setuptools/_vendor/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/_vendor/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..350e481674a278b548c786cb8281247ead2525fd GIT binary patch literal 154 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 literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/setuptools/_vendor/__pycache__/six.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/_vendor/__pycache__/six.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..9571fb9eef54e7ec5f6044e412afd87b0d03ac60 GIT binary patch literal 24427 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

n-8Rhe#-G)j8eLlPP{ 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 v)>> OrderedSet([1, 1, 2, 3, 2]) + OrderedSet([1, 2, 3]) + """ + + def __init__(self, iterable=None): + self.items = [] + self.map = {} + if iterable is not None: + self |= iterable + + def __len__(self): + """ + Returns the number of unique elements in the ordered set + + Example: + >>> len(OrderedSet([])) + 0 + >>> len(OrderedSet([1, 2])) + 2 + """ + return len(self.items) + + def __getitem__(self, index): + """ + Get the item at a given index. + + If `index` is a slice, you will get back that slice of items, as a + new OrderedSet. + + If `index` is a list or a similar iterable, you'll get a list of + items corresponding to those indices. This is similar to NumPy's + "fancy indexing". The result is not an OrderedSet because you may ask + for duplicate indices, and the number of elements returned should be + the number of elements asked for. + + Example: + >>> oset = OrderedSet([1, 2, 3]) + >>> oset[1] + 2 + """ + if isinstance(index, slice) and index == SLICE_ALL: + return self.copy() + elif is_iterable(index): + return [self.items[i] for i in index] + elif hasattr(index, "__index__") or isinstance(index, slice): + result = self.items[index] + if isinstance(result, list): + return self.__class__(result) + else: + return result + else: + raise TypeError("Don't know how to index an OrderedSet by %r" % index) + + def copy(self): + """ + Return a shallow copy of this object. + + Example: + >>> this = OrderedSet([1, 2, 3]) + >>> other = this.copy() + >>> this == other + True + >>> this is other + False + """ + return self.__class__(self) + + def __getstate__(self): + if len(self) == 0: + # The state can't be an empty list. + # We need to return a truthy value, or else __setstate__ won't be run. + # + # This could have been done more gracefully by always putting the state + # in a tuple, but this way is backwards- and forwards- compatible with + # previous versions of OrderedSet. + return (None,) + else: + return list(self) + + def __setstate__(self, state): + if state == (None,): + self.__init__([]) + else: + self.__init__(state) + + def __contains__(self, key): + """ + Test if the item is in this ordered set + + Example: + >>> 1 in OrderedSet([1, 3, 2]) + True + >>> 5 in OrderedSet([1, 3, 2]) + False + """ + return key in self.map + + def add(self, key): + """ + Add `key` as an item to this OrderedSet, then return its index. + + If `key` is already in the OrderedSet, return the index it already + had. + + Example: + >>> oset = OrderedSet() + >>> oset.append(3) + 0 + >>> print(oset) + OrderedSet([3]) + """ + if key not in self.map: + self.map[key] = len(self.items) + self.items.append(key) + return self.map[key] + + append = add + + def update(self, sequence): + """ + Update the set with the given iterable sequence, then return the index + of the last element inserted. + + Example: + >>> oset = OrderedSet([1, 2, 3]) + >>> oset.update([3, 1, 5, 1, 4]) + 4 + >>> print(oset) + OrderedSet([1, 2, 3, 5, 4]) + """ + item_index = None + try: + for item in sequence: + item_index = self.add(item) + except TypeError: + raise ValueError( + "Argument needs to be an iterable, got %s" % type(sequence) + ) + return item_index + + def index(self, key): + """ + Get the index of a given entry, raising an IndexError if it's not + present. + + `key` can be an iterable of entries that is not a string, in which case + this returns a list of indices. + + Example: + >>> oset = OrderedSet([1, 2, 3]) + >>> oset.index(2) + 1 + """ + if is_iterable(key): + return [self.index(subkey) for subkey in key] + return self.map[key] + + # Provide some compatibility with pd.Index + get_loc = index + get_indexer = index + + def pop(self): + """ + Remove and return the last element from the set. + + Raises KeyError if the set is empty. + + Example: + >>> oset = OrderedSet([1, 2, 3]) + >>> oset.pop() + 3 + """ + if not self.items: + raise KeyError("Set is empty") + + elem = self.items[-1] + del self.items[-1] + del self.map[elem] + return elem + + def discard(self, key): + """ + Remove an element. Do not raise an exception if absent. + + The MutableSet mixin uses this to implement the .remove() method, which + *does* raise an error when asked to remove a non-existent item. + + Example: + >>> oset = OrderedSet([1, 2, 3]) + >>> oset.discard(2) + >>> print(oset) + OrderedSet([1, 3]) + >>> oset.discard(2) + >>> print(oset) + OrderedSet([1, 3]) + """ + if key in self: + i = self.map[key] + del self.items[i] + del self.map[key] + for k, v in self.map.items(): + if v >= i: + self.map[k] = v - 1 + + def clear(self): + """ + Remove all items from this OrderedSet. + """ + del self.items[:] + self.map.clear() + + def __iter__(self): + """ + Example: + >>> list(iter(OrderedSet([1, 2, 3]))) + [1, 2, 3] + """ + return iter(self.items) + + def __reversed__(self): + """ + Example: + >>> list(reversed(OrderedSet([1, 2, 3]))) + [3, 2, 1] + """ + return reversed(self.items) + + def __repr__(self): + if not self: + return "%s()" % (self.__class__.__name__,) + return "%s(%r)" % (self.__class__.__name__, list(self)) + + def __eq__(self, other): + """ + Returns true if the containers have the same items. If `other` is a + Sequence, then order is checked, otherwise it is ignored. + + Example: + >>> oset = OrderedSet([1, 3, 2]) + >>> oset == [1, 3, 2] + True + >>> oset == [1, 2, 3] + False + >>> oset == [2, 3] + False + >>> oset == OrderedSet([3, 2, 1]) + False + """ + # In Python 2 deque is not a Sequence, so treat it as one for + # consistent behavior with Python 3. + if isinstance(other, (Sequence, deque)): + # Check that this OrderedSet contains the same elements, in the + # same order, as the other object. + return list(self) == list(other) + try: + other_as_set = set(other) + except TypeError: + # If `other` can't be converted into a set, it's not equal. + return False + else: + return set(self) == other_as_set + + def union(self, *sets): + """ + Combines all unique items. + Each items order is defined by its first appearance. + + Example: + >>> oset = OrderedSet.union(OrderedSet([3, 1, 4, 1, 5]), [1, 3], [2, 0]) + >>> print(oset) + OrderedSet([3, 1, 4, 5, 2, 0]) + >>> oset.union([8, 9]) + OrderedSet([3, 1, 4, 5, 2, 0, 8, 9]) + >>> oset | {10} + OrderedSet([3, 1, 4, 5, 2, 0, 10]) + """ + cls = self.__class__ if isinstance(self, OrderedSet) else OrderedSet + containers = map(list, it.chain([self], sets)) + items = it.chain.from_iterable(containers) + return cls(items) + + def __and__(self, other): + # the parent implementation of this is backwards + return self.intersection(other) + + def intersection(self, *sets): + """ + Returns elements in common between all sets. Order is defined only + by the first set. + + Example: + >>> oset = OrderedSet.intersection(OrderedSet([0, 1, 2, 3]), [1, 2, 3]) + >>> print(oset) + OrderedSet([1, 2, 3]) + >>> oset.intersection([2, 4, 5], [1, 2, 3, 4]) + OrderedSet([2]) + >>> oset.intersection() + OrderedSet([1, 2, 3]) + """ + cls = self.__class__ if isinstance(self, OrderedSet) else OrderedSet + if sets: + common = set.intersection(*map(set, sets)) + items = (item for item in self if item in common) + else: + items = self + return cls(items) + + def difference(self, *sets): + """ + Returns all elements that are in this set but not the others. + + Example: + >>> OrderedSet([1, 2, 3]).difference(OrderedSet([2])) + OrderedSet([1, 3]) + >>> OrderedSet([1, 2, 3]).difference(OrderedSet([2]), OrderedSet([3])) + OrderedSet([1]) + >>> OrderedSet([1, 2, 3]) - OrderedSet([2]) + OrderedSet([1, 3]) + >>> OrderedSet([1, 2, 3]).difference() + OrderedSet([1, 2, 3]) + """ + cls = self.__class__ + if sets: + other = set.union(*map(set, sets)) + items = (item for item in self if item not in other) + else: + items = self + return cls(items) + + def issubset(self, other): + """ + Report whether another set contains this set. + + Example: + >>> OrderedSet([1, 2, 3]).issubset({1, 2}) + False + >>> OrderedSet([1, 2, 3]).issubset({1, 2, 3, 4}) + True + >>> OrderedSet([1, 2, 3]).issubset({1, 4, 3, 5}) + False + """ + if len(self) > len(other): # Fast check for obvious cases + return False + return all(item in other for item in self) + + def issuperset(self, other): + """ + Report whether this set contains another set. + + Example: + >>> OrderedSet([1, 2]).issuperset([1, 2, 3]) + False + >>> OrderedSet([1, 2, 3, 4]).issuperset({1, 2, 3}) + True + >>> OrderedSet([1, 4, 3, 5]).issuperset({1, 2, 3}) + False + """ + if len(self) < len(other): # Fast check for obvious cases + return False + return all(item in self for item in other) + + def symmetric_difference(self, other): + """ + Return the symmetric difference of two OrderedSets as a new set. + That is, the new set will contain all elements that are in exactly + one of the sets. + + Their order will be preserved, with elements from `self` preceding + elements from `other`. + + Example: + >>> this = OrderedSet([1, 4, 3, 5, 7]) + >>> other = OrderedSet([9, 7, 1, 3, 2]) + >>> this.symmetric_difference(other) + OrderedSet([4, 5, 9, 2]) + """ + cls = self.__class__ if isinstance(self, OrderedSet) else OrderedSet + diff1 = cls(self).difference(other) + diff2 = cls(other).difference(self) + return diff1.union(diff2) + + def _update_items(self, items): + """ + Replace the 'items' list of this OrderedSet with a new one, updating + self.map accordingly. + """ + self.items = items + self.map = {item: idx for (idx, item) in enumerate(items)} + + def difference_update(self, *sets): + """ + Update this OrderedSet to remove items from one or more other sets. + + Example: + >>> this = OrderedSet([1, 2, 3]) + >>> this.difference_update(OrderedSet([2, 4])) + >>> print(this) + OrderedSet([1, 3]) + + >>> this = OrderedSet([1, 2, 3, 4, 5]) + >>> this.difference_update(OrderedSet([2, 4]), OrderedSet([1, 4, 6])) + >>> print(this) + OrderedSet([3, 5]) + """ + items_to_remove = set() + for other in sets: + items_to_remove |= set(other) + self._update_items([item for item in self.items if item not in items_to_remove]) + + def intersection_update(self, other): + """ + Update this OrderedSet to keep only items in another set, preserving + their order in this set. + + Example: + >>> this = OrderedSet([1, 4, 3, 5, 7]) + >>> other = OrderedSet([9, 7, 1, 3, 2]) + >>> this.intersection_update(other) + >>> print(this) + OrderedSet([1, 3, 7]) + """ + other = set(other) + self._update_items([item for item in self.items if item in other]) + + def symmetric_difference_update(self, other): + """ + Update this OrderedSet to remove items from another set, then + add items from the other set that were not present in this set. + + Example: + >>> this = OrderedSet([1, 4, 3, 5, 7]) + >>> other = OrderedSet([9, 7, 1, 3, 2]) + >>> this.symmetric_difference_update(other) + >>> print(this) + OrderedSet([4, 5, 9, 2]) + """ + items_to_add = [item for item in other if item not in self] + items_to_remove = set(other) + self._update_items( + [item for item in self.items if item not in items_to_remove] + items_to_add + ) diff --git a/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__about__.py b/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__about__.py new file mode 100644 index 0000000..dc95138 --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__about__.py @@ -0,0 +1,27 @@ +# 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__", + "__summary__", + "__uri__", + "__version__", + "__author__", + "__email__", + "__license__", + "__copyright__", +] + +__title__ = "packaging" +__summary__ = "Core utilities for Python packages" +__uri__ = "https://github.com/pypa/packaging" + +__version__ = "19.2" + +__author__ = "Donald Stufft and individual contributors" +__email__ = "donald@stufft.io" + +__license__ = "BSD or Apache License, Version 2.0" +__copyright__ = "Copyright 2014-2019 %s" % __author__ diff --git a/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__init__.py b/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__init__.py new file mode 100644 index 0000000..a0cf67d --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__init__.py @@ -0,0 +1,26 @@ +# 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__, + __copyright__, + __email__, + __license__, + __summary__, + __title__, + __uri__, + __version__, +) + +__all__ = [ + "__title__", + "__summary__", + "__uri__", + "__version__", + "__author__", + "__email__", + "__license__", + "__copyright__", +] diff --git a/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/__about__.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/__about__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..2b22a7199e9f430b7dd7ff37adc86dcb010a406f GIT binary patch literal 704 zcmY+C%We}f6o%)PW^!x8MO~XnT|^?8HbS5xgbM8nAyg@Xg*Vn@jwj*Hc=;ICy@Bs{Q7e+XRL)?QS+=nq9z$4l_4)72jFN5im zpDt@Kjdw@+N{iYWN?0R>GP@MmhG{1F?ocYm4Jj=zjMqIv3^O$)WH%s0+os9Y)`>15 zRSAyp?prx^8 zX;97qG49I*o7boi+$grPMkw8m;of?o@2ztt+R6Ln6>_J)b6G2jKJG979DUhWiWc+J z_W1H|6=-pK_G0F6j!yKa>BzUCw8kn|u5!;DsMsTM@O{f`*Avz8O9viZ5C8J2=i&bl zHSicZd<)dr&pm#B$V?+M$>hv(UoVB(T}5d~Nj&_(3JGyDV9p3Qgw literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..179fd13932d7c8e87c4421276a6990d671265c73 GIT binary patch literal 542 zcmY+AJ#HH@5QVwBlJ?(50AC@1RVWLjNSYu>o5oF&hRt9tQW70&iDU zQhCM#0*4EJ*hjpXd6-{)-!MF%KfND6=8Qd(czY@o-|&W?2*E_AnaOx&a-N%l7a0?| zDD=WC`O>WT%9Ok`6|YRqYt!(?w7fMP@6fjpOR*BAs6;Iq(e5kWi|z+o_fOcFt&90` zybV^TC_x!#eVi+yjw&cS%@@wADZ(yI+lcxpql#*70LBy#)&tBvz}C8xSNlUmSp!Hj zDviG_fL2>M1$h=B88iCR*%VdO^j-oaug->}^fVQ~w>Zbsf_z8l2`d7v#n*%qakIXl zEV~qw$7UWE$$UXrASlatYZJyg7gNcb4zK-RC;b~jaYl{d|1kfK+=Rd1hiKg3l-s1q zjoaT+Y#t6$>dk%F-QR`X!w_UlE?TR@07p3q>jyH9do}F`05vHL@xh(u>Wi@=Y5A1` PhAYHXe%6^O?n96-vUSqUV#R233PaH^0HNbJRO*G{|bzG{0Lr7EXZ zYJUbC`)W5)qnN3yF6C=%dW^8}+jmKZt*ZTzI?VA@$aYBA$uqq6KccAVY7)>BY4(Lo zde?wWCOnMPuB-CK8<`b#WqpWrcAUAaD#Nh0S?T4hDN_&e&NULd2F4_%c>6{$(FN^+ zx|d)+k_&P{XG~Mg&Lhn(=^6jQJo!mandVw#1@Jq9rBU1yFoq;llZ34nPq^k#N}N1LMEMVIE3Zs(1*)%D=q!DK@D^X@&!^ZI zbzEolW>eNGJv4fAzHdyvdE{nC2W~cxo$*cWt15S~JT|4SY>WrhURLhKGOdbQ`Dwif zJt<2wm+~2s!?wpTfr#1-+!}dw2dVk^50+)AJU-^G-6%;7n~LJA^-pY literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/_structures.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/_structures.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..376e52fd22eb3e3c2e18a4f5c3cb34ae77c47fb8 GIT binary patch literal 2760 zcmcImOK%e~5Vm)d%_dFT^nprwUl3F%jgSzP5THsR5E9A-xa49jYbV{3>~3stt5&_G z2mVU_(q1|77dSEFuqADGlY+pJ$B(i7jc3N+=F{S0jX>FXdf)q6Cgd9qrb`J1yHM3@ z5S(z@Cj;7{1FK^V?2b*zTf!}FpAv41(#YL*&TU=T-Ar!Ef;0u@AIx)jSG)U2C?zJ{@nJEn^TgI%cVBM3n{l#`Cd zDYs5Z$L2OKK@0fYfws&m+=bTRRbGR(!WVcQT9+^KC1|UBnKz)V@fE%b?E+r|E7w!^ zUDyr6Kp*)OK(c~;tgoOdbPlJm+G;# z-aOnBqTd{jq4_iv;B-T;XS1ooRLLSK$F7$dq*lRJRW#a2Z3bh>{r7mMq#F8-= z4M0B-dc2aEx}9k+*=)l?V{;uknrM1LMsx(Wk7;{srKLSj?WH9=T2^4iZ~J8xh6sx* z7+Zi*9_&Qx8-rj87VKYg)!1skF^7*WiC0L=k=_&XBA&xoUo*A@D>Ag@sY{}6K9+32 z_Q}aBXFU@bb0@?QjG-zQ19X=#F1Yao+_+Ci)(0ZdG2qA=Bygy-7y2Tt!U26xDF{jd zz8EsLUVx9fVtn+BCK-O6{IWn^gZUz~5N@(H1>V2L~cct=!zNFcyj)WB1^wEKwTS4tQ}!*&f&N zk%Zm=EJ$mN4I-XkdZl&7hKbjoXe6?&Tt=~m0)sEFqu4}o6U8kQcTk*>$fSo^Yj_4< zs9FW#QrABJGkPCX=L$Z>U8w(&FC~U#w(EaU<#Dx{d2e#B9KtbvdWaSqMxn=>7enYQJ5YZDcPZta literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/markers.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/markers.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..22cd495e959e5175f09947c799b428ea1f821cd0 GIT binary patch literal 8927 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 Yk*$U8?fidj7o2^z=?plB9LJgXKYr28Q~&?~ literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/requirements.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/requirements.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..7b3ec72eb0f8fb13949c95e634621a4bffe502e0 GIT binary patch literal 3995 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 MZYn#C8Md4HKZ8PYVE_OC literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/utils.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/utils.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..bf810c428192922c0a08315e1d62bd50aaa5f0d8 GIT binary patch literal 1435 zcmbVM%aR*46qVF3yT^7y9#j@tG?15T;`XdyGc}bes8qpXHb4MFs;kG6?e_F*B-x%Z zo(_W3Ht~s>)|tBw0~cQkw?P=9$W>(sXK>l{y*C%Atn&;Y*5J znCX03&eJ^O&xEwRU^`g)KlYON`R)*TZyJtW=$}JZ*8wzHQ%+Z8!`5s=AQX1^n)V=) zo5?UOt1=sc@1;nj7>iTmsM(S6@@gSumm0TB3voeY8~nU}+Sf(hud}*0E9-Q4EO>7* z5hCxMsL{z(jTU_+^sLrZm8*U-7bUM`ABpKWE64qr&T#W7%W?wtjG&`PQD}M9hYc&9Ljr?;AcgA@&hFKJsFd8NP5aRJ$B^N6|7-HxX_lVBNoqN#23!F7$WNG~&8a8ZKoS#9YjA z;O+u;+cLntK7jE=T@5G3PwN^Uh4Dv~EK+Tl6cP*DxYH^tO|ZRokpV1cWu#mY0g0Po`HO=t2xu(~Z1Ch!-e zXHq1I#K$L5P>BM_y9l2kU}82!6AY`O&T=7}xP;HwI(jcUdy7`o#(q)pSuPIHo5JL8 Mu?D;Dgigcz8!X^mZU6uP literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/version.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/version.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..e850a418d873a3115964acfeff754c2857c8d131 GIT binary patch literal 12065 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 UGY70O>zHAWKDXY@>DJ)?1EAYZlK=n! literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/_compat.py b/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/_compat.py new file mode 100644 index 0000000..25da473 --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/_compat.py @@ -0,0 +1,31 @@ +# 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 + + +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): + """ + 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): + def __new__(cls, name, this_bases, d): + return meta(name, bases, d) + + return type.__new__(metaclass, "temporary_class", (), {}) diff --git a/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/_structures.py b/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/_structures.py new file mode 100644 index 0000000..68dcca6 --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/_structures.py @@ -0,0 +1,68 @@ +# 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 Infinity(object): + def __repr__(self): + return "Infinity" + + def __hash__(self): + return hash(repr(self)) + + def __lt__(self, other): + return False + + def __le__(self, other): + return False + + def __eq__(self, other): + return isinstance(other, self.__class__) + + def __ne__(self, other): + return not isinstance(other, self.__class__) + + def __gt__(self, other): + return True + + def __ge__(self, other): + return True + + def __neg__(self): + return NegativeInfinity + + +Infinity = Infinity() + + +class NegativeInfinity(object): + def __repr__(self): + return "-Infinity" + + def __hash__(self): + return hash(repr(self)) + + def __lt__(self, other): + return True + + def __le__(self, other): + return True + + def __eq__(self, other): + return isinstance(other, self.__class__) + + def __ne__(self, other): + return not isinstance(other, self.__class__) + + def __gt__(self, other): + return False + + def __ge__(self, other): + return False + + def __neg__(self): + return Infinity + + +NegativeInfinity = NegativeInfinity() diff --git a/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/markers.py b/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/markers.py new file mode 100644 index 0000000..4bdfdb2 --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/markers.py @@ -0,0 +1,296 @@ +# 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 setuptools.extern.pyparsing import ParseException, ParseResults, stringStart, stringEnd +from setuptools.extern.pyparsing import ZeroOrMore, Group, Forward, QuotedString +from setuptools.extern.pyparsing import Literal as L # noqa + +from ._compat import string_types +from .specifiers import Specifier, InvalidSpecifier + + +__all__ = [ + "InvalidMarker", + "UndefinedComparison", + "UndefinedEnvironmentName", + "Marker", + "default_environment", +] + + +class InvalidMarker(ValueError): + """ + An invalid marker was found, users should refer to PEP 508. + """ + + +class UndefinedComparison(ValueError): + """ + An invalid operation was attempted on a value that doesn't support it. + """ + + +class UndefinedEnvironmentName(ValueError): + """ + A name was attempted to be used that does not exist inside of the + environment. + """ + + +class Node(object): + def __init__(self, value): + self.value = value + + def __str__(self): + return str(self.value) + + def __repr__(self): + return "<{0}({1!r})>".format(self.__class__.__name__, str(self)) + + def serialize(self): + raise NotImplementedError + + +class Variable(Node): + def serialize(self): + return str(self) + + +class Value(Node): + def serialize(self): + return '"{0}"'.format(self) + + +class Op(Node): + def serialize(self): + return str(self) + + +VARIABLE = ( + L("implementation_version") + | L("platform_python_implementation") + | L("implementation_name") + | L("python_full_version") + | L("platform_release") + | L("platform_version") + | L("platform_machine") + | L("platform_system") + | L("python_version") + | L("sys_platform") + | L("os_name") + | L("os.name") + | L("sys.platform") # PEP-345 + | L("platform.version") # PEP-345 + | L("platform.machine") # PEP-345 + | L("platform.python_implementation") # PEP-345 + | L("python_implementation") # PEP-345 + | L("extra") # undocumented setuptools legacy +) +ALIASES = { + "os.name": "os_name", + "sys.platform": "sys_platform", + "platform.version": "platform_version", + "platform.machine": "platform_machine", + "platform.python_implementation": "platform_python_implementation", + "python_implementation": "platform_python_implementation", +} +VARIABLE.setParseAction(lambda s, l, t: Variable(ALIASES.get(t[0], t[0]))) + +VERSION_CMP = ( + L("===") | L("==") | L(">=") | L("<=") | L("!=") | L("~=") | L(">") | L("<") +) + +MARKER_OP = VERSION_CMP | L("not in") | L("in") +MARKER_OP.setParseAction(lambda s, l, t: Op(t[0])) + +MARKER_VALUE = QuotedString("'") | QuotedString('"') +MARKER_VALUE.setParseAction(lambda s, l, t: Value(t[0])) + +BOOLOP = L("and") | L("or") + +MARKER_VAR = VARIABLE | MARKER_VALUE + +MARKER_ITEM = Group(MARKER_VAR + MARKER_OP + MARKER_VAR) +MARKER_ITEM.setParseAction(lambda s, l, t: tuple(t[0])) + +LPAREN = L("(").suppress() +RPAREN = L(")").suppress() + +MARKER_EXPR = Forward() +MARKER_ATOM = MARKER_ITEM | Group(LPAREN + MARKER_EXPR + RPAREN) +MARKER_EXPR << MARKER_ATOM + ZeroOrMore(BOOLOP + MARKER_EXPR) + +MARKER = stringStart + MARKER_EXPR + stringEnd + + +def _coerce_parse_result(results): + if isinstance(results, ParseResults): + return [_coerce_parse_result(i) for i in results] + else: + return results + + +def _format_marker(marker, first=True): + assert isinstance(marker, (list, tuple, string_types)) + + # 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 + # the rest of this function so that we don't get extraneous () on the + # outside. + if ( + isinstance(marker, list) + and len(marker) == 1 + and isinstance(marker[0], (list, tuple)) + ): + return _format_marker(marker[0]) + + if isinstance(marker, list): + inner = (_format_marker(m, first=False) for m in marker) + if first: + return " ".join(inner) + else: + return "(" + " ".join(inner) + ")" + elif isinstance(marker, tuple): + return " ".join([m.serialize() for m in marker]) + else: + return marker + + +_operators = { + "in": lambda lhs, rhs: lhs in rhs, + "not in": lambda lhs, rhs: lhs not in rhs, + "<": operator.lt, + "<=": operator.le, + "==": operator.eq, + "!=": operator.ne, + ">=": operator.ge, + ">": operator.gt, +} + + +def _eval_op(lhs, op, rhs): + try: + spec = Specifier("".join([op.serialize(), rhs])) + except InvalidSpecifier: + pass + else: + return spec.contains(lhs) + + oper = _operators.get(op.serialize()) + if oper is None: + raise UndefinedComparison( + "Undefined {0!r} on {1!r} and {2!r}.".format(op, lhs, rhs) + ) + + return oper(lhs, rhs) + + +_undefined = object() + + +def _get_env(environment, name): + value = environment.get(name, _undefined) + + if value is _undefined: + raise UndefinedEnvironmentName( + "{0!r} does not exist in evaluation environment.".format(name) + ) + + return value + + +def _evaluate_markers(markers, environment): + groups = [[]] + + for marker in markers: + assert isinstance(marker, (list, tuple, string_types)) + + if isinstance(marker, list): + groups[-1].append(_evaluate_markers(marker, environment)) + elif isinstance(marker, tuple): + lhs, op, rhs = marker + + if isinstance(lhs, Variable): + lhs_value = _get_env(environment, lhs.value) + rhs_value = rhs.value + else: + lhs_value = lhs.value + rhs_value = _get_env(environment, rhs.value) + + groups[-1].append(_eval_op(lhs_value, op, rhs_value)) + else: + assert marker in ["and", "or"] + if marker == "or": + groups.append([]) + + return any(all(item) for item in groups) + + +def format_full_version(info): + version = "{0.major}.{0.minor}.{0.micro}".format(info) + kind = info.releaselevel + if kind != "final": + version += kind[0] + str(info.serial) + return version + + +def default_environment(): + if hasattr(sys, "implementation"): + iver = format_full_version(sys.implementation.version) + implementation_name = sys.implementation.name + else: + iver = "0" + implementation_name = "" + + return { + "implementation_name": implementation_name, + "implementation_version": iver, + "os_name": os.name, + "platform_machine": platform.machine(), + "platform_release": platform.release(), + "platform_system": platform.system(), + "platform_version": platform.version(), + "python_full_version": platform.python_version(), + "platform_python_implementation": platform.python_implementation(), + "python_version": ".".join(platform.python_version_tuple()[:2]), + "sys_platform": sys.platform, + } + + +class Marker(object): + def __init__(self, marker): + 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(err_str) + + def __str__(self): + return _format_marker(self._markers) + + def __repr__(self): + return "".format(str(self)) + + def evaluate(self, environment=None): + """Evaluate a marker. + + Return the boolean from evaluating the given marker against the + environment. environment is an optional argument to override all or + part of the determined environment. + + The environment is determined from the current Python process. + """ + current_environment = default_environment() + if environment is not None: + current_environment.update(environment) + + return _evaluate_markers(self._markers, current_environment) diff --git a/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/requirements.py b/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/requirements.py new file mode 100644 index 0000000..8a0c2cb --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/requirements.py @@ -0,0 +1,138 @@ +# 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 string +import re + +from setuptools.extern.pyparsing import stringStart, stringEnd, originalTextFor, ParseException +from setuptools.extern.pyparsing import ZeroOrMore, Word, Optional, Regex, Combine +from setuptools.extern.pyparsing import Literal as L # noqa +from setuptools.extern.six.moves.urllib import parse as urlparse + +from .markers import MARKER_EXPR, Marker +from .specifiers import LegacySpecifier, Specifier, SpecifierSet + + +class InvalidRequirement(ValueError): + """ + An invalid requirement was found, users should refer to PEP 508. + """ + + +ALPHANUM = Word(string.ascii_letters + string.digits) + +LBRACKET = L("[").suppress() +RBRACKET = L("]").suppress() +LPAREN = L("(").suppress() +RPAREN = L(")").suppress() +COMMA = L(",").suppress() +SEMICOLON = L(";").suppress() +AT = L("@").suppress() + +PUNCTUATION = Word("-_.") +IDENTIFIER_END = ALPHANUM | (ZeroOrMore(PUNCTUATION) + ALPHANUM) +IDENTIFIER = Combine(ALPHANUM + ZeroOrMore(IDENTIFIER_END)) + +NAME = IDENTIFIER("name") +EXTRA = IDENTIFIER + +URI = Regex(r"[^ ]+")("url") +URL = AT + URI + +EXTRAS_LIST = EXTRA + ZeroOrMore(COMMA + EXTRA) +EXTRAS = (LBRACKET + Optional(EXTRAS_LIST) + RBRACKET)("extras") + +VERSION_PEP440 = Regex(Specifier._regex_str, re.VERBOSE | re.IGNORECASE) +VERSION_LEGACY = Regex(LegacySpecifier._regex_str, re.VERBOSE | re.IGNORECASE) + +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.setParseAction(lambda s, l, t: t._raw_spec or "") + +VERSION_SPEC = originalTextFor(_VERSION_SPEC)("specifier") +VERSION_SPEC.setParseAction(lambda s, l, t: t[1]) + +MARKER_EXPR = originalTextFor(MARKER_EXPR())("marker") +MARKER_EXPR.setParseAction( + lambda s, l, t: Marker(s[t._original_start : t._original_end]) +) +MARKER_SEPARATOR = SEMICOLON +MARKER = MARKER_SEPARATOR + MARKER_EXPR + +VERSION_AND_MARKER = VERSION_SPEC + Optional(MARKER) +URL_AND_MARKER = URL + Optional(MARKER) + +NAMED_REQUIREMENT = NAME + Optional(EXTRAS) + (URL_AND_MARKER | VERSION_AND_MARKER) + +REQUIREMENT = stringStart + NAMED_REQUIREMENT + stringEnd +# setuptools.extern.pyparsing isn't thread safe during initialization, so we do it eagerly, see +# issue #104 +REQUIREMENT.parseString("x[]") + + +class Requirement(object): + """Parse a requirement. + + Parse a given requirement string into its parts, such as name, specifier, + URL, and extras. Raises InvalidRequirement on a badly-formed requirement + string. + """ + + # TODO: Can we test whether something is contained within a requirement? + # If so how do we do that? Do we need to test against the _name_ of + # 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): + 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 + ) + ) + + self.name = req.name + if req.url: + parsed_url = urlparse.urlparse(req.url) + if parsed_url.scheme == "file": + if urlparse.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 + else: + self.url = None + self.extras = set(req.extras.asList() if req.extras else []) + self.specifier = SpecifierSet(req.specifier) + self.marker = req.marker if req.marker else None + + def __str__(self): + parts = [self.name] + + if self.extras: + parts.append("[{0}]".format(",".join(sorted(self.extras)))) + + if self.specifier: + parts.append(str(self.specifier)) + + if self.url: + parts.append("@ {0}".format(self.url)) + if self.marker: + parts.append(" ") + + if self.marker: + parts.append("; {0}".format(self.marker)) + + return "".join(parts) + + def __repr__(self): + return "".format(str(self)) diff --git a/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/specifiers.py b/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/specifiers.py new file mode 100644 index 0000000..743576a --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/specifiers.py @@ -0,0 +1,749 @@ +# 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 + +from ._compat import string_types, with_metaclass +from .version import Version, LegacyVersion, parse + + +class InvalidSpecifier(ValueError): + """ + An invalid specifier was found, users should refer to PEP 440. + """ + + +class BaseSpecifier(with_metaclass(abc.ABCMeta, object)): + @abc.abstractmethod + def __str__(self): + """ + Returns the str representation of this Specifier like object. This + should be representative of the Specifier itself. + """ + + @abc.abstractmethod + def __hash__(self): + """ + Returns a hash value for this Specifier like object. + """ + + @abc.abstractmethod + def __eq__(self, other): + """ + Returns a boolean representing whether or not the two Specifier like + objects are equal. + """ + + @abc.abstractmethod + def __ne__(self, other): + """ + Returns a boolean representing whether or not the two Specifier like + objects are not equal. + """ + + @abc.abstractproperty + def prereleases(self): + """ + Returns whether or not pre-releases as a whole are allowed by this + specifier. + """ + + @prereleases.setter + def prereleases(self, value): + """ + Sets whether or not pre-releases as a whole are allowed by this + specifier. + """ + + @abc.abstractmethod + def contains(self, item, prereleases=None): + """ + Determines if the given item is contained within this specifier. + """ + + @abc.abstractmethod + def filter(self, iterable, prereleases=None): + """ + Takes an iterable of items and filters them so that only items which + are contained within this specifier are allowed in it. + """ + + +class _IndividualSpecifier(BaseSpecifier): + + _operators = {} + + def __init__(self, spec="", prereleases=None): + match = self._regex.search(spec) + if not match: + raise InvalidSpecifier("Invalid specifier: '{0}'".format(spec)) + + self._spec = (match.group("operator").strip(), match.group("version").strip()) + + # Store whether or not this Specifier should accept prereleases + self._prereleases = prereleases + + def __repr__(self): + pre = ( + ", prereleases={0!r}".format(self.prereleases) + if self._prereleases is not None + else "" + ) + + return "<{0}({1!r}{2})>".format(self.__class__.__name__, str(self), pre) + + def __str__(self): + return "{0}{1}".format(*self._spec) + + def __hash__(self): + return hash(self._spec) + + def __eq__(self, other): + if isinstance(other, string_types): + try: + other = self.__class__(other) + except InvalidSpecifier: + return NotImplemented + elif not isinstance(other, self.__class__): + return NotImplemented + + return self._spec == other._spec + + def __ne__(self, other): + if isinstance(other, string_types): + try: + other = self.__class__(other) + except InvalidSpecifier: + return NotImplemented + elif not isinstance(other, self.__class__): + return NotImplemented + + return self._spec != other._spec + + def _get_operator(self, op): + return getattr(self, "_compare_{0}".format(self._operators[op])) + + def _coerce_version(self, version): + if not isinstance(version, (LegacyVersion, Version)): + version = parse(version) + return version + + @property + def operator(self): + return self._spec[0] + + @property + def version(self): + return self._spec[1] + + @property + def prereleases(self): + return self._prereleases + + @prereleases.setter + def prereleases(self, value): + self._prereleases = value + + def __contains__(self, item): + return self.contains(item) + + def contains(self, item, prereleases=None): + # Determine if prereleases are to be allowed or not. + if prereleases is None: + prereleases = self.prereleases + + # Normalize item to a Version or LegacyVersion, this allows us to have + # a shortcut for ``"2.0" in Specifier(">=2") + item = self._coerce_version(item) + + # Determine if we should be supporting prereleases in this specifier + # or not, if we do not support prereleases than we can short circuit + # logic if this version is a prereleases. + if item.is_prerelease and not prereleases: + return False + + # Actually do the comparison to determine if this item is contained + # within this Specifier or not. + return self._get_operator(self.operator)(item, self.version) + + def filter(self, iterable, prereleases=None): + yielded = False + found_prereleases = [] + + kw = {"prereleases": prereleases if prereleases is not None else True} + + # Attempt to iterate over all the values in the iterable and if any of + # them match, yield them. + for version in iterable: + parsed_version = self._coerce_version(version) + + 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 + # else matches this specifier. + if parsed_version.is_prerelease and not ( + prereleases or self.prereleases + ): + found_prereleases.append(version) + # Either this is not a prerelease, or we should have been + # accepting prereleases from the beginning. + else: + yielded = True + yield version + + # Now that we've iterated over everything, determine if we've yielded + # any values, and if we have not and we have any prereleases stored up + # then we will go ahead and yield the prereleases. + if not yielded and found_prereleases: + for version in found_prereleases: + yield version + + +class LegacySpecifier(_IndividualSpecifier): + + _regex_str = r""" + (?P(==|!=|<=|>=|<|>)) + \s* + (?P + [^,;\s)]* # Since this is a "legacy" specifier, and the version + # string can be just about anything, we match everything + # except for whitespace, a semi-colon for marker support, + # a closing paren since versions can be enclosed in + # them, and a comma since it's a version separator. + ) + """ + + _regex = re.compile(r"^\s*" + _regex_str + r"\s*$", re.VERBOSE | re.IGNORECASE) + + _operators = { + "==": "equal", + "!=": "not_equal", + "<=": "less_than_equal", + ">=": "greater_than_equal", + "<": "less_than", + ">": "greater_than", + } + + def _coerce_version(self, version): + if not isinstance(version, LegacyVersion): + version = LegacyVersion(str(version)) + return version + + def _compare_equal(self, prospective, spec): + return prospective == self._coerce_version(spec) + + def _compare_not_equal(self, prospective, spec): + return prospective != self._coerce_version(spec) + + def _compare_less_than_equal(self, prospective, spec): + return prospective <= self._coerce_version(spec) + + def _compare_greater_than_equal(self, prospective, spec): + return prospective >= self._coerce_version(spec) + + def _compare_less_than(self, prospective, spec): + return prospective < self._coerce_version(spec) + + def _compare_greater_than(self, prospective, spec): + return prospective > self._coerce_version(spec) + + +def _require_version_compare(fn): + @functools.wraps(fn) + def wrapped(self, prospective, spec): + if not isinstance(prospective, Version): + return False + return fn(self, prospective, spec) + + return wrapped + + +class Specifier(_IndividualSpecifier): + + _regex_str = r""" + (?P(~=|==|!=|<=|>=|<|>|===)) + (?P + (?: + # The identity operators allow for an escape hatch that will + # do an exact string match of the version you wish to install. + # This will not be parsed by PEP 440 and we cannot determine + # any semantic meaning from it. This operator is discouraged + # but included entirely as an escape hatch. + (?<====) # Only match for the identity operator + \s* + [^\s]* # We just match everything, except for whitespace + # since we are only testing for strict identity. + ) + | + (?: + # The (non)equality operators allow for wild card and local + # versions to be specified so we have to define these two + # operators separately to enable that. + (?<===|!=) # Only match for equals and not equals + + \s* + v? + (?:[0-9]+!)? # epoch + [0-9]+(?:\.[0-9]+)* # release + (?: # pre release + [-_\.]? + (a|b|c|rc|alpha|beta|pre|preview) + [-_\.]? + [0-9]* + )? + (?: # post release + (?:-[0-9]+)|(?:[-_\.]?(post|rev|r)[-_\.]?[0-9]*) + )? + + # You cannot use a wild card and a dev or local version + # together so group them with a | and make them optional. + (?: + (?:[-_\.]?dev[-_\.]?[0-9]*)? # dev release + (?:\+[a-z0-9]+(?:[-_\.][a-z0-9]+)*)? # local + | + \.\* # Wild card syntax of .* + )? + ) + | + (?: + # The compatible operator requires at least two digits in the + # release segment. + (?<=~=) # Only match for the compatible operator + + \s* + v? + (?:[0-9]+!)? # epoch + [0-9]+(?:\.[0-9]+)+ # release (We have a + instead of a *) + (?: # pre release + [-_\.]? + (a|b|c|rc|alpha|beta|pre|preview) + [-_\.]? + [0-9]* + )? + (?: # post release + (?:-[0-9]+)|(?:[-_\.]?(post|rev|r)[-_\.]?[0-9]*) + )? + (?:[-_\.]?dev[-_\.]?[0-9]*)? # dev release + ) + | + (?: + # All other operators only allow a sub set of what the + # (non)equality operators do. Specifically they do not allow + # local versions to be specified nor do they allow the prefix + # matching wild cards. + (?=": "greater_than_equal", + "<": "less_than", + ">": "greater_than", + "===": "arbitrary", + } + + @_require_version_compare + def _compare_compatible(self, prospective, spec): + # Compatible releases have an equivalent combination of >= and ==. That + # is that ~=2.2 is equivalent to >=2.2,==2.*. This allows us to + # implement this in terms of the other specifiers instead of + # implementing it ourselves. The only thing we need to do is construct + # 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. + prefix = ".".join( + list( + itertools.takewhile( + lambda x: (not x.startswith("post") and not x.startswith("dev")), + _version_split(spec), + ) + )[:-1] + ) + + # Add the prefix notation to the end of our string + prefix += ".*" + + return self._get_operator(">=")(prospective, spec) and self._get_operator("==")( + prospective, prefix + ) + + @_require_version_compare + def _compare_equal(self, prospective, spec): + # We need special logic to handle prefix matching + if spec.endswith(".*"): + # In the case of prefix matching we want to ignore local segment. + prospective = Version(prospective.public) + # Split the spec out by dots, and pretend that there is an implicit + # dot in between a release segment and a pre-release segment. + spec = _version_split(spec[:-2]) # Remove the trailing .* + + # Split the prospective version out by dots, and pretend that there + # is an implicit dot in between a release segment and a pre-release + # segment. + prospective = _version_split(str(prospective)) + + # Shorten the prospective version to be the same length as the spec + # so that we can determine if the specifier is a prefix of the + # prospective version or not. + prospective = prospective[: len(spec)] + + # Pad out our two sides with zeros so that they both equal the same + # length. + spec, prospective = _pad_version(spec, prospective) + else: + # Convert our spec string into a Version + spec = Version(spec) + + # If the specifier does not have a local segment, then we want to + # act as if the prospective version also does not have a local + # segment. + if not spec.local: + prospective = Version(prospective.public) + + return prospective == spec + + @_require_version_compare + def _compare_not_equal(self, prospective, spec): + return not self._compare_equal(prospective, spec) + + @_require_version_compare + def _compare_less_than_equal(self, prospective, spec): + return prospective <= Version(spec) + + @_require_version_compare + def _compare_greater_than_equal(self, prospective, spec): + return prospective >= Version(spec) + + @_require_version_compare + def _compare_less_than(self, prospective, spec): + # Convert our spec to a Version instance, since we'll want to work with + # it as a version. + spec = Version(spec) + + # Check to see if the prospective version is less than the spec + # version. If it's not we can short circuit and just return False now + # instead of doing extra unneeded work. + if not prospective < spec: + return False + + # This special case is here so that, unless the specifier itself + # includes is a pre-release version, that we do not accept pre-release + # versions for the version mentioned in the specifier (e.g. <3.1 should + # not match 3.1.dev0, but should match 3.0.dev0). + if not spec.is_prerelease and prospective.is_prerelease: + if Version(prospective.base_version) == Version(spec.base_version): + return False + + # If we've gotten to here, it means that prospective version is both + # less than the spec version *and* it's not a pre-release of the same + # version in the spec. + return True + + @_require_version_compare + def _compare_greater_than(self, prospective, spec): + # Convert our spec to a Version instance, since we'll want to work with + # it as a version. + spec = Version(spec) + + # Check to see if the prospective version is greater than the spec + # version. If it's not we can short circuit and just return False now + # instead of doing extra unneeded work. + if not prospective > spec: + return False + + # This special case is here so that, unless the specifier itself + # includes is a post-release version, that we do not accept + # post-release versions for the version mentioned in the specifier + # (e.g. >3.1 should not match 3.0.post0, but should match 3.2.post0). + if not spec.is_postrelease and prospective.is_postrelease: + if Version(prospective.base_version) == Version(spec.base_version): + return False + + # Ensure that we do not allow a local version of the version mentioned + # in the specifier, which is technically greater than, to match. + if prospective.local is not None: + if Version(prospective.base_version) == Version(spec.base_version): + return False + + # If we've gotten to here, it means that prospective version is both + # greater than the spec version *and* it's not a pre-release of the + # same version in the spec. + return True + + def _compare_arbitrary(self, prospective, spec): + return str(prospective).lower() == str(spec).lower() + + @property + def prereleases(self): + # If there is an explicit prereleases set for this, then we'll just + # blindly use that. + if self._prereleases is not None: + return self._prereleases + + # Look at all of our specifiers and determine if they are inclusive + # operators, and if they are if they are including an explicit + # prerelease. + operator, version = self._spec + if operator in ["==", ">=", "<=", "~=", "==="]: + # The == specifier can include a trailing .*, if it does we + # want to remove before parsing. + if operator == "==" and version.endswith(".*"): + version = version[:-2] + + # Parse the version, and if it is a pre-release than this + # specifier allows pre-releases. + if parse(version).is_prerelease: + return True + + return False + + @prereleases.setter + def prereleases(self, value): + self._prereleases = value + + +_prefix_regex = re.compile(r"^([0-9]+)((?:a|b|c|rc)[0-9]+)$") + + +def _version_split(version): + result = [] + for item in version.split("."): + match = _prefix_regex.search(item) + if match: + result.extend(match.groups()) + else: + result.append(item) + return result + + +def _pad_version(left, right): + left_split, right_split = [], [] + + # Get the release segment of our versions + left_split.append(list(itertools.takewhile(lambda x: x.isdigit(), left))) + right_split.append(list(itertools.takewhile(lambda x: x.isdigit(), right))) + + # Get the rest of our versions + left_split.append(left[len(left_split[0]) :]) + right_split.append(right[len(right_split[0]) :]) + + # Insert our padding + left_split.insert(1, ["0"] * max(0, len(right_split[0]) - len(left_split[0]))) + right_split.insert(1, ["0"] * max(0, len(left_split[0]) - len(right_split[0]))) + + return (list(itertools.chain(*left_split)), list(itertools.chain(*right_split))) + + +class SpecifierSet(BaseSpecifier): + def __init__(self, specifiers="", prereleases=None): + # Split on , to break each indidivual specifier into it's own item, and + # strip each item to remove leading/trailing whitespace. + specifiers = [s.strip() for s in specifiers.split(",") if s.strip()] + + # Parsed each individual specifier, attempting first to make it a + # Specifier and falling back to a LegacySpecifier. + parsed = set() + for specifier in specifiers: + try: + parsed.add(Specifier(specifier)) + except InvalidSpecifier: + parsed.add(LegacySpecifier(specifier)) + + # Turn our parsed specifiers into a frozen set and save them for later. + self._specs = frozenset(parsed) + + # Store our prereleases value so we can use it later to determine if + # we accept prereleases or not. + self._prereleases = prereleases + + def __repr__(self): + pre = ( + ", prereleases={0!r}".format(self.prereleases) + if self._prereleases is not None + else "" + ) + + return "".format(str(self), pre) + + def __str__(self): + return ",".join(sorted(str(s) for s in self._specs)) + + def __hash__(self): + return hash(self._specs) + + def __and__(self, other): + if isinstance(other, string_types): + other = SpecifierSet(other) + elif not isinstance(other, SpecifierSet): + return NotImplemented + + specifier = SpecifierSet() + specifier._specs = frozenset(self._specs | other._specs) + + if self._prereleases is None and other._prereleases is not None: + specifier._prereleases = other._prereleases + elif self._prereleases is not None and other._prereleases is None: + specifier._prereleases = self._prereleases + elif self._prereleases == other._prereleases: + specifier._prereleases = self._prereleases + else: + raise ValueError( + "Cannot combine SpecifierSets with True and False prerelease " + "overrides." + ) + + return specifier + + def __eq__(self, other): + if isinstance(other, string_types): + other = SpecifierSet(other) + elif isinstance(other, _IndividualSpecifier): + other = SpecifierSet(str(other)) + elif not isinstance(other, SpecifierSet): + return NotImplemented + + return self._specs == other._specs + + def __ne__(self, other): + if isinstance(other, string_types): + other = SpecifierSet(other) + elif isinstance(other, _IndividualSpecifier): + other = SpecifierSet(str(other)) + elif not isinstance(other, SpecifierSet): + return NotImplemented + + return self._specs != other._specs + + def __len__(self): + return len(self._specs) + + def __iter__(self): + return iter(self._specs) + + @property + def prereleases(self): + # If we have been given an explicit prerelease modifier, then we'll + # pass that through here. + if self._prereleases is not None: + return self._prereleases + + # If we don't have any specifiers, and we don't have a forced value, + # then we'll just return None since we don't know if this should have + # pre-releases or not. + if not self._specs: + return None + + # Otherwise we'll see if any of the given specifiers accept + # prereleases, if any of them do we'll return True, otherwise False. + return any(s.prereleases for s in self._specs) + + @prereleases.setter + def prereleases(self, value): + self._prereleases = value + + def __contains__(self, item): + return self.contains(item) + + def contains(self, item, prereleases=None): + # Ensure that our item is a Version or LegacyVersion instance. + if not isinstance(item, (LegacyVersion, Version)): + item = parse(item) + + # 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 + # SpecifierSet thinks for whether or not we should support prereleases. + if prereleases is None: + prereleases = self.prereleases + + # We can determine if we're going to allow pre-releases by looking to + # see if any of the underlying items supports them. If none of them do + # and this item is a pre-release then we do not allow it and we can + # short circuit that here. + # Note: This means that 1.0.dev1 would not be contained in something + # like >=1.0.devabc however it would be in >=1.0.debabc,>0.0.dev0 + if not prereleases and item.is_prerelease: + return False + + # We simply dispatch to the underlying specs here to make sure that the + # given version is contained within all of them. + # Note: This use of all() here means that an empty set of specifiers + # will always return True, this is an explicit design decision. + return all(s.contains(item, prereleases=prereleases) for s in self._specs) + + def filter(self, iterable, prereleases=None): + # 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 + # SpecifierSet thinks for whether or not we should support prereleases. + if prereleases is None: + prereleases = self.prereleases + + # If we have any specifiers, then we want to wrap our iterable in the + # filter method for each one, this will act as a logical AND amongst + # each specifier. + if self._specs: + for spec in self._specs: + iterable = spec.filter(iterable, prereleases=bool(prereleases)) + return iterable + # If we do not have any specifiers, then we need to have a rough filter + # which will filter out any pre-releases, unless there are no final + # releases, and which will filter out LegacyVersion in general. + else: + filtered = [] + found_prereleases = [] + + for item in iterable: + # Ensure that we some kind of Version class for this item. + if not isinstance(item, (LegacyVersion, Version)): + parsed_version = parse(item) + else: + parsed_version = item + + # Filter out any item which is parsed as a LegacyVersion + if isinstance(parsed_version, LegacyVersion): + continue + + # Store any item which is a pre-release for later unless we've + # already found a final version or we are accepting prereleases + if parsed_version.is_prerelease and not prereleases: + if not filtered: + found_prereleases.append(item) + else: + filtered.append(item) + + # If we've found no items except for pre-releases, then we'll go + # ahead and use the pre-releases + if not filtered and found_prereleases and prereleases is None: + return found_prereleases + + return filtered diff --git a/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/tags.py b/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/tags.py new file mode 100644 index 0000000..ec9942f --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/tags.py @@ -0,0 +1,404 @@ +# 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 + +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 platform +import re +import sys +import sysconfig +import warnings + + +INTERPRETER_SHORT_NAMES = { + "python": "py", # Generic. + "cpython": "cp", + "pypy": "pp", + "ironpython": "ip", + "jython": "jy", +} + + +_32_BIT_INTERPRETER = sys.maxsize <= 2 ** 32 + + +class Tag(object): + + __slots__ = ["_interpreter", "_abi", "_platform"] + + def __init__(self, interpreter, abi, platform): + self._interpreter = interpreter.lower() + self._abi = abi.lower() + self._platform = platform.lower() + + @property + def interpreter(self): + return self._interpreter + + @property + def abi(self): + return self._abi + + @property + def platform(self): + return self._platform + + def __eq__(self, other): + return ( + (self.platform == other.platform) + and (self.abi == other.abi) + and (self.interpreter == other.interpreter) + ) + + def __hash__(self): + return hash((self._interpreter, self._abi, self._platform)) + + def __str__(self): + return "{}-{}-{}".format(self._interpreter, self._abi, self._platform) + + def __repr__(self): + return "<{self} @ {self_id}>".format(self=self, self_id=id(self)) + + +def parse_tag(tag): + tags = set() + interpreters, abis, platforms = tag.split("-") + for interpreter in interpreters.split("."): + for abi in abis.split("."): + for platform_ in platforms.split("."): + tags.add(Tag(interpreter, abi, platform_)) + return frozenset(tags) + + +def _normalize_string(string): + return string.replace(".", "_").replace("-", "_") + + +def _cpython_interpreter(py_version): + # TODO: Is using py_version_nodot for interpreter version critical? + return "cp{major}{minor}".format(major=py_version[0], minor=py_version[1]) + + +def _cpython_abis(py_version): + abis = [] + version = "{}{}".format(*py_version[:2]) + debug = pymalloc = ucs4 = "" + with_debug = sysconfig.get_config_var("Py_DEBUG") + has_refcount = hasattr(sys, "gettotalrefcount") + # Windows doesn't set Py_DEBUG, so checking for support of debug-compiled + # extension modules is the best option. + # https://github.com/pypa/pip/issues/3383#issuecomment-173267692 + has_ext = "_d.pyd" in EXTENSION_SUFFIXES + if with_debug or (with_debug is None and (has_refcount or has_ext)): + debug = "d" + if py_version < (3, 8): + with_pymalloc = sysconfig.get_config_var("WITH_PYMALLOC") + if with_pymalloc or with_pymalloc is None: + pymalloc = "m" + if py_version < (3, 3): + unicode_size = sysconfig.get_config_var("Py_UNICODE_SIZE") + if unicode_size == 4 or ( + unicode_size is None and sys.maxunicode == 0x10FFFF + ): + ucs4 = "u" + 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.insert( + 0, + "cp{version}{debug}{pymalloc}{ucs4}".format( + version=version, debug=debug, pymalloc=pymalloc, ucs4=ucs4 + ), + ) + return abis + + +def _cpython_tags(py_version, interpreter, abis, platforms): + for abi in abis: + for platform_ in platforms: + yield Tag(interpreter, abi, platform_) + 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 + # PEP 384 was first implemented in Python 3.2. + for minor_version in range(py_version[1] - 1, 1, -1): + for platform_ in platforms: + interpreter = "cp{major}{minor}".format( + major=py_version[0], minor=minor_version + ) + yield Tag(interpreter, "abi3", platform_) + + +def _pypy_interpreter(): + return "pp{py_major}{pypy_major}{pypy_minor}".format( + py_major=sys.version_info[0], + pypy_major=sys.pypy_version_info.major, + pypy_minor=sys.pypy_version_info.minor, + ) + + +def _generic_abi(): + abi = sysconfig.get_config_var("SOABI") + if abi: + return _normalize_string(abi) + else: + return "none" + + +def _pypy_tags(py_version, interpreter, abi, platforms): + for tag in (Tag(interpreter, abi, platform) for platform in platforms): + yield tag + for tag in (Tag(interpreter, "none", platform) for platform in platforms): + yield tag + + +def _generic_tags(interpreter, py_version, abi, platforms): + for tag in (Tag(interpreter, abi, platform) for platform in platforms): + yield tag + if abi != "none": + tags = (Tag(interpreter, "none", platform_) for platform_ in platforms) + for tag in tags: + yield tag + + +def _py_interpreter_range(py_version): + """ + Yield Python versions in descending order. + + After the latest version, the major-only version will be yielded, and then + all following versions up to 'end'. + """ + yield "py{major}{minor}".format(major=py_version[0], minor=py_version[1]) + yield "py{major}".format(major=py_version[0]) + for minor in range(py_version[1] - 1, -1, -1): + yield "py{major}{minor}".format(major=py_version[0], minor=minor) + + +def _independent_tags(interpreter, py_version, platforms): + """ + Return the sequence of tags that are consistent across implementations. + + The tags consist of: + - py*-none- + - -none-any + - py*-none-any + """ + for version in _py_interpreter_range(py_version): + for platform_ in platforms: + yield Tag(version, "none", platform_) + yield Tag(interpreter, "none", "any") + for version in _py_interpreter_range(py_version): + yield Tag(version, "none", "any") + + +def _mac_arch(arch, is_32bit=_32_BIT_INTERPRETER): + if not is_32bit: + return arch + + if arch.startswith("ppc"): + return "ppc" + + return "i386" + + +def _mac_binary_formats(version, cpu_arch): + formats = [cpu_arch] + if cpu_arch == "x86_64": + if version < (10, 4): + return [] + formats.extend(["intel", "fat64", "fat32"]) + + elif cpu_arch == "i386": + if version < (10, 4): + return [] + formats.extend(["intel", "fat32", "fat"]) + + elif cpu_arch == "ppc64": + # TODO: Need to care about 32-bit PPC for ppc64 through 10.2? + if version > (10, 5) or version < (10, 4): + return [] + formats.append("fat64") + + elif cpu_arch == "ppc": + if version > (10, 6): + return [] + formats.extend(["fat32", "fat"]) + + formats.append("universal") + return formats + + +def _mac_platforms(version=None, arch=None): + version_str, _, cpu_arch = platform.mac_ver() + if version is None: + version = tuple(map(int, version_str.split(".")[:2])) + if arch is None: + arch = _mac_arch(cpu_arch) + platforms = [] + for minor_version in range(version[1], -1, -1): + compat_version = version[0], minor_version + binary_formats = _mac_binary_formats(compat_version, arch) + for binary_format in binary_formats: + platforms.append( + "macosx_{major}_{minor}_{binary_format}".format( + major=compat_version[0], + minor=compat_version[1], + binary_format=binary_format, + ) + ) + return platforms + + +# From PEP 513. +def _is_manylinux_compatible(name, glibc_version): + # Check for presence of _manylinux module. + try: + import _manylinux + + return bool(getattr(_manylinux, name + "_compatible")) + except (ImportError, AttributeError): + # Fall through to heuristic check below. + pass + + return _have_compatible_glibc(*glibc_version) + + +def _glibc_version_string(): + # Returns glibc version string, or None if not using glibc. + import ctypes + + # 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. + process_namespace = ctypes.CDLL(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() + # py2 / py3 compatibility: + if not isinstance(version_str, str): + version_str = version_str.decode("ascii") + + return version_str + + +# Separated out from have_compatible_glibc for easier unit testing. +def _check_glibc_version(version_str, required_major, minimum_minor): + # Parse string and check against requested 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[0-9]+)\.(?P[0-9]+)", version_str) + if not m: + warnings.warn( + "Expected glibc version with 2 components major.minor," + " got: %s" % version_str, + RuntimeWarning, + ) + return False + return ( + int(m.group("major")) == required_major + and int(m.group("minor")) >= minimum_minor + ) + + +def _have_compatible_glibc(required_major, minimum_minor): + version_str = _glibc_version_string() + if version_str is None: + return False + return _check_glibc_version(version_str, required_major, minimum_minor) + + +def _linux_platforms(is_32bit=_32_BIT_INTERPRETER): + linux = _normalize_string(distutils.util.get_platform()) + if linux == "linux_x86_64" and is_32bit: + linux = "linux_i686" + manylinux_support = ( + ("manylinux2014", (2, 17)), # CentOS 7 w/ glibc 2.17 (PEP 599) + ("manylinux2010", (2, 12)), # CentOS 6 w/ glibc 2.12 (PEP 571) + ("manylinux1", (2, 5)), # CentOS 5 w/ glibc 2.5 (PEP 513) + ) + manylinux_support_iter = iter(manylinux_support) + for name, glibc_version in manylinux_support_iter: + if _is_manylinux_compatible(name, glibc_version): + platforms = [linux.replace("linux", name)] + break + else: + platforms = [] + # Support for a later manylinux implies support for an earlier version. + platforms += [linux.replace("linux", name) for name, _ in manylinux_support_iter] + platforms.append(linux) + return platforms + + +def _generic_platforms(): + platform = _normalize_string(distutils.util.get_platform()) + return [platform] + + +def _interpreter_name(): + name = platform.python_implementation().lower() + return INTERPRETER_SHORT_NAMES.get(name) or name + + +def _generic_interpreter(name, py_version): + version = sysconfig.get_config_var("py_version_nodot") + if not version: + version = "".join(map(str, py_version[:2])) + return "{name}{version}".format(name=name, version=version) + + +def sys_tags(): + """ + 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. + """ + py_version = sys.version_info[:2] + interpreter_name = _interpreter_name() + if platform.system() == "Darwin": + platforms = _mac_platforms() + elif platform.system() == "Linux": + platforms = _linux_platforms() + else: + platforms = _generic_platforms() + + if interpreter_name == "cp": + interpreter = _cpython_interpreter(py_version) + abis = _cpython_abis(py_version) + for tag in _cpython_tags(py_version, interpreter, abis, platforms): + yield tag + elif interpreter_name == "pp": + interpreter = _pypy_interpreter() + abi = _generic_abi() + for tag in _pypy_tags(py_version, interpreter, abi, platforms): + yield tag + else: + interpreter = _generic_interpreter(interpreter_name, py_version) + abi = _generic_abi() + for tag in _generic_tags(interpreter, py_version, abi, platforms): + yield tag + for tag in _independent_tags(interpreter, py_version, platforms): + yield tag diff --git a/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/utils.py b/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/utils.py new file mode 100644 index 0000000..8841878 --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/utils.py @@ -0,0 +1,57 @@ +# 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 .version import InvalidVersion, Version + + +_canonicalize_regex = re.compile(r"[-_.]+") + + +def canonicalize_name(name): + # This is taken from PEP 503. + return _canonicalize_regex.sub("-", name).lower() + + +def canonicalize_version(version): + """ + This is very similar to Version.__str__, but has one subtle differences + with the way it handles the release segment. + """ + + try: + version = Version(version) + except InvalidVersion: + # Legacy versions cannot be normalized + return version + + parts = [] + + # Epoch + if version.epoch != 0: + parts.append("{0}!".format(version.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))) + + # Pre-release + if version.pre is not None: + parts.append("".join(str(x) for x in version.pre)) + + # Post-release + if version.post is not None: + parts.append(".post{0}".format(version.post)) + + # Development release + if version.dev is not None: + parts.append(".dev{0}".format(version.dev)) + + # Local version segment + if version.local is not None: + parts.append("+{0}".format(version.local)) + + return "".join(parts) diff --git a/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/version.py b/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/version.py new file mode 100644 index 0000000..95157a1 --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/version.py @@ -0,0 +1,420 @@ +# 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 + +from ._structures import Infinity + + +__all__ = ["parse", "Version", "LegacyVersion", "InvalidVersion", "VERSION_PATTERN"] + + +_Version = collections.namedtuple( + "_Version", ["epoch", "release", "dev", "pre", "post", "local"] +) + + +def parse(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 + a valid PEP 440 version or a legacy version. + """ + try: + return Version(version) + except InvalidVersion: + return LegacyVersion(version) + + +class InvalidVersion(ValueError): + """ + An invalid version was found, users should refer to PEP 440. + """ + + +class _BaseVersion(object): + def __hash__(self): + return hash(self._key) + + def __lt__(self, other): + return self._compare(other, lambda s, o: s < o) + + def __le__(self, other): + return self._compare(other, lambda s, o: s <= o) + + def __eq__(self, other): + return self._compare(other, lambda s, o: s == o) + + def __ge__(self, other): + return self._compare(other, lambda s, o: s >= o) + + def __gt__(self, other): + return self._compare(other, lambda s, o: s > o) + + def __ne__(self, other): + return self._compare(other, lambda s, o: s != o) + + def _compare(self, other, method): + if not isinstance(other, _BaseVersion): + return NotImplemented + + return method(self._key, other._key) + + +class LegacyVersion(_BaseVersion): + def __init__(self, version): + self._version = str(version) + self._key = _legacy_cmpkey(self._version) + + def __str__(self): + return self._version + + def __repr__(self): + return "".format(repr(str(self))) + + @property + def public(self): + return self._version + + @property + def base_version(self): + return self._version + + @property + def epoch(self): + return -1 + + @property + def release(self): + return None + + @property + def pre(self): + return None + + @property + def post(self): + return None + + @property + def dev(self): + return None + + @property + def local(self): + return None + + @property + def is_prerelease(self): + return False + + @property + def is_postrelease(self): + return False + + @property + def is_devrelease(self): + return False + + +_legacy_version_component_re = re.compile(r"(\d+ | [a-z]+ | \.| -)", re.VERBOSE) + +_legacy_version_replacement_map = { + "pre": "c", + "preview": "c", + "-": "final-", + "rc": "c", + "dev": "@", +} + + +def _parse_version_parts(s): + for part in _legacy_version_component_re.split(s): + part = _legacy_version_replacement_map.get(part, part) + + if not part or part == ".": + continue + + if part[:1] in "0123456789": + # pad for numeric comparison + yield part.zfill(8) + else: + yield "*" + part + + # ensure that alpha/beta/candidate are before final + yield "*final" + + +def _legacy_cmpkey(version): + # 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, + # which uses the defacto standard originally implemented by setuptools, + # as before all PEP 440 versions. + epoch = -1 + + # This scheme is taken from pkg_resources.parse_version setuptools prior to + # it's adoption of the packaging library. + parts = [] + for part in _parse_version_parts(version.lower()): + if part.startswith("*"): + # remove "-" before a prerelease tag + if part < "*final": + while parts and parts[-1] == "*final-": + parts.pop() + + # remove trailing zeros from each series of numeric parts + while parts and parts[-1] == "00000000": + parts.pop() + + parts.append(part) + parts = tuple(parts) + + return epoch, parts + + +# Deliberately not anchored to the start and end of the string, to make it +# easier for 3rd party code to reuse +VERSION_PATTERN = r""" + v? + (?: + (?:(?P[0-9]+)!)? # epoch + (?P[0-9]+(?:\.[0-9]+)*) # release segment + (?P

                                          # pre-release
+            [-_\.]?
+            (?P(a|b|c|rc|alpha|beta|pre|preview))
+            [-_\.]?
+            (?P[0-9]+)?
+        )?
+        (?P                                         # post release
+            (?:-(?P[0-9]+))
+            |
+            (?:
+                [-_\.]?
+                (?Ppost|rev|r)
+                [-_\.]?
+                (?P[0-9]+)?
+            )
+        )?
+        (?P                                          # dev release
+            [-_\.]?
+            (?Pdev)
+            [-_\.]?
+            (?P[0-9]+)?
+        )?
+    )
+    (?:\+(?P[a-z0-9]+(?:[-_\.][a-z0-9]+)*))?       # local version
+"""
+
+
+class Version(_BaseVersion):
+
+    _regex = re.compile(r"^\s*" + VERSION_PATTERN + r"\s*$", re.VERBOSE | re.IGNORECASE)
+
+    def __init__(self, version):
+        # Validate the version and parse it into pieces
+        match = self._regex.search(version)
+        if not match:
+            raise InvalidVersion("Invalid version: '{0}'".format(version))
+
+        # Store the parsed out pieces of the version
+        self._version = _Version(
+            epoch=int(match.group("epoch")) if match.group("epoch") else 0,
+            release=tuple(int(i) for i in match.group("release").split(".")),
+            pre=_parse_letter_version(match.group("pre_l"), match.group("pre_n")),
+            post=_parse_letter_version(
+                match.group("post_l"), match.group("post_n1") or match.group("post_n2")
+            ),
+            dev=_parse_letter_version(match.group("dev_l"), match.group("dev_n")),
+            local=_parse_local_version(match.group("local")),
+        )
+
+        # Generate a key which will be used for sorting
+        self._key = _cmpkey(
+            self._version.epoch,
+            self._version.release,
+            self._version.pre,
+            self._version.post,
+            self._version.dev,
+            self._version.local,
+        )
+
+    def __repr__(self):
+        return "".format(repr(str(self)))
+
+    def __str__(self):
+        parts = []
+
+        # Epoch
+        if self.epoch != 0:
+            parts.append("{0}!".format(self.epoch))
+
+        # Release segment
+        parts.append(".".join(str(x) for x in self.release))
+
+        # Pre-release
+        if self.pre is not None:
+            parts.append("".join(str(x) for x in self.pre))
+
+        # Post-release
+        if self.post is not None:
+            parts.append(".post{0}".format(self.post))
+
+        # Development release
+        if self.dev is not None:
+            parts.append(".dev{0}".format(self.dev))
+
+        # Local version segment
+        if self.local is not None:
+            parts.append("+{0}".format(self.local))
+
+        return "".join(parts)
+
+    @property
+    def epoch(self):
+        return self._version.epoch
+
+    @property
+    def release(self):
+        return self._version.release
+
+    @property
+    def pre(self):
+        return self._version.pre
+
+    @property
+    def post(self):
+        return self._version.post[1] if self._version.post else None
+
+    @property
+    def dev(self):
+        return self._version.dev[1] if self._version.dev else None
+
+    @property
+    def local(self):
+        if self._version.local:
+            return ".".join(str(x) for x in self._version.local)
+        else:
+            return None
+
+    @property
+    def public(self):
+        return str(self).split("+", 1)[0]
+
+    @property
+    def base_version(self):
+        parts = []
+
+        # Epoch
+        if self.epoch != 0:
+            parts.append("{0}!".format(self.epoch))
+
+        # Release segment
+        parts.append(".".join(str(x) for x in self.release))
+
+        return "".join(parts)
+
+    @property
+    def is_prerelease(self):
+        return self.dev is not None or self.pre is not None
+
+    @property
+    def is_postrelease(self):
+        return self.post is not None
+
+    @property
+    def is_devrelease(self):
+        return self.dev is not None
+
+
+def _parse_letter_version(letter, number):
+    if letter:
+        # We consider there to be an implicit 0 in a pre-release if there is
+        # not a numeral associated with it.
+        if number is None:
+            number = 0
+
+        # We normalize any letters to their lower case form
+        letter = letter.lower()
+
+        # We consider some words to be alternate spellings of other words and
+        # in those cases we want to normalize the spellings to our preferred
+        # spelling.
+        if letter == "alpha":
+            letter = "a"
+        elif letter == "beta":
+            letter = "b"
+        elif letter in ["c", "pre", "preview"]:
+            letter = "rc"
+        elif letter in ["rev", "r"]:
+            letter = "post"
+
+        return letter, int(number)
+    if not letter and number:
+        # We assume if we are given a number, but we are not given a letter
+        # then this is using the implicit post release syntax (e.g. 1.0-1)
+        letter = "post"
+
+        return letter, int(number)
+
+
+_local_version_separators = re.compile(r"[\._-]")
+
+
+def _parse_local_version(local):
+    """
+    Takes a string like abc.1.twelve and turns it into ("abc", 1, "twelve").
+    """
+    if local is not None:
+        return tuple(
+            part.lower() if not part.isdigit() else int(part)
+            for part in _local_version_separators.split(local)
+        )
+
+
+def _cmpkey(epoch, release, pre, post, dev, local):
+    # 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
+    # leading zeros until we come to something non zero, then take the rest
+    # re-reverse it back into the correct order and make it a tuple and use
+    # that for our sorting key.
+    release = tuple(
+        reversed(list(itertools.dropwhile(lambda x: x == 0, reversed(release))))
+    )
+
+    # We need to "trick" the sorting algorithm to put 1.0.dev0 before 1.0a0.
+    # We'll do this by abusing the pre segment, but we _only_ want to do this
+    # 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 = -Infinity
+    # Versions without a pre-release (except as noted above) should sort after
+    # those with one.
+    elif pre is None:
+        pre = Infinity
+
+    # Versions without a post segment should sort before those with one.
+    if post is None:
+        post = -Infinity
+
+    # Versions without a development segment should sort after those with one.
+    if dev is None:
+        dev = Infinity
+
+    if local is None:
+        # Versions without a local segment should sort before those with one.
+        local = -Infinity
+    else:
+        # Versions with a local segment need that segment parsed to implement
+        # the sorting rules in PEP440.
+        # - Alpha numeric segments sort before numeric segments
+        # - Alpha numeric segments sort lexicographically
+        # - Numeric segments sort numerically
+        # - Shorter versions sort before longer versions when the prefixes
+        #   match exactly
+        local = tuple((i, "") if isinstance(i, int) else (-Infinity, i) for i in local)
+
+    return epoch, release, pre, post, dev, local
diff --git a/venv/lib/python3.8/site-packages/setuptools/_vendor/pyparsing.py b/venv/lib/python3.8/site-packages/setuptools/_vendor/pyparsing.py
new file mode 100644
index 0000000..cf75e1e
--- /dev/null
+++ b/venv/lib/python3.8/site-packages/setuptools/_vendor/pyparsing.py
@@ -0,0 +1,5742 @@
+# module pyparsing.py
+#
+# Copyright (c) 2003-2018  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 
+C{", !"}), built up using L{Word}, L{Literal}, and L{And} elements 
+(L{'+'} operator gives L{And} expressions, strings are auto-converted to
+L{Literal} expressions)::
+
+    from 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 L{ParseResults} object returned from L{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 L{ParserElement} and L{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 L{Literal} and L{CaselessLiteral} classes
+ - construct character word-group expressions using the L{Word} class
+ - see how to create repetitive expressions using L{ZeroOrMore} and L{OneOrMore} classes
+ - use L{'+'}, L{'|'}, L{'^'}, and L{'&'} operators to combine simple expressions into more complex ones
+ - associate names with your parsed results using L{ParserElement.setResultsName}
+ - find some helpful expression short-cuts like L{delimitedList} and L{oneOf}
+ - find more useful common expressions in the L{pyparsing_common} namespace class
+"""
+
+__version__ = "2.2.1"
+__versionTime__ = "18 Sep 2018 00:49 UTC"
+__author__ = "Paul McGuire "
+
+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
+
+try:
+    from _thread import RLock
+except ImportError:
+    from threading import RLock
+
+try:
+    # Python 3
+    from collections.abc import Iterable
+    from collections.abc import MutableMapping
+except ImportError:
+    # Python 2.7
+    from collections import Iterable
+    from collections import MutableMapping
+
+try:
+    from collections import OrderedDict as _OrderedDict
+except ImportError:
+    try:
+        from ordereddict import OrderedDict as _OrderedDict
+    except ImportError:
+        _OrderedDict = None
+
+#~ sys.stderr.write( "testing pyparsing module, version %s, %s\n" % (__version__,__versionTime__ ) )
+
+__all__ = [
+'And', 'CaselessKeyword', 'CaselessLiteral', 'CharsNotIn', 'Combine', 'Dict', 'Each', 'Empty',
+'FollowedBy', 'Forward', 'GoToColumn', 'Group', 'Keyword', 'LineEnd', 'LineStart', 'Literal',
+'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',
+'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',
+]
+
+system_version = tuple(sys.version_info)[:3]
+PY_3 = system_version[0] == 3
+if PY_3:
+    _MAX_INT = sys.maxsize
+    basestring = str
+    unichr = chr
+    _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
+
+class _Constants(object):
+    pass
+
+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)
+
+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 ):
+        return "%s (at char %d), (line:%d, col:%d)" % \
+                ( self.msg, 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
+    """
+    pass
+
+class ParseFatalException(ParseBaseException):
+    """user-throwable exception thrown when inconsistent parse content
+       is found; stops all parsing immediately"""
+    pass
+
+class ParseSyntaxException(ParseFatalException):
+    """just like L{ParseFatalException}, but thrown internally when an
+       L{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 L{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 (C{len(results)})
+       - by list index (C{results[0], results[1]}, etc.)
+       - by attribute (C{results.} - see L{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(toklist.copy(),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 (Python 3.x only)."""
+
+        values = _itervalues
+        """Returns an iterator of all named result values (Python 3.x only)."""
+
+        items = _iteritems
+        """Returns an iterator of all named result key-value tuples (Python 3.x only)."""
+
+    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=C{last}).
+        Supports both C{list} and C{dict} semantics for C{pop()}. If passed no
+        argument or an integer argument, it will use C{list} semantics
+        and pop tokens from the list of parsed tokens. If passed a 
+        non-integer argument (most likely a string), it will use C{dict}
+        semantics and pop the corresponding value from any defined 
+        results names. A second default return value argument is 
+        supported, just as in C{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 C{defaultValue} or C{None} if no
+        C{defaultValue} is specified.
+
+        Similar to C{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 C{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 += 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 ""
+            
+        if name in self.__tokdict:
+            if name not in self.__accumNames:
+                return self.__tokdict[name][-1][0]
+            else:
+                return ParseResults([ v[0] for v in self.__tokdict[name] ])
+        else:
+            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) # ->  ['sldkj', 'lsdkj', 'sldkj']
+            
+            # Use asList() to create an actual list
+            result_list = result.asList()
+            print(type(result_list), result_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)) # ->  (['12', '/', '31', '/', '1999'], {'day': [('1999', 4)], 'year': [('12', 0)], 'month': [('31', 2)]})
+            
+            result_dict = result.asDict()
+            print(type(result_dict), repr(result_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 C{ParseResults} object.
+        """
+        ret = ParseResults( self.__toklist )
+        ret.__tokdict = self.__tokdict.copy()
+        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,
+                                                "" ]
+
+        out += [ nl, indent, "" ]
+        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='', depth=0, full=True):
+        """
+        Diagnostic method for listing out the contents of a C{ParseResults}.
+        Accepts an optional C{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'
+        out.append( indent+_ustr(self.asList()) )
+        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,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,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 C{pprint} module.
+        Accepts additional positional or keyword args as defined for the 
+        C{pprint.pprint} method. (U{http://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()))
+
+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 L{I{ParserElement.parseString}} for more information
+   on parsing strings containing C{}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} for more information
+   on parsing strings containing C{}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:
+                        del tb
+
+                if limit[0] <= maxargs:
+                    limit[0] += 1
+                    continue
+                raise
+
+    # copy func name to wrapper for sensible debug output
+    func_name = ""
+    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,  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
+
+    def __init__( self, savelist=False ):
+        self.parseAction = list()
+        self.failAction = None
+        #~ self.name = ""  # don't define self.name, let subclasses try/except upcall
+        self.strRepr = None
+        self.resultsName = None
+        self.saveAsList = savelist
+        self.skipWhitespace = True
+        self.whiteChars = 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 C{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 C{expr.copy()} is just C{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 hasattr(self,"exception"):
+            self.exception.msg = self.errmsg
+        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 C{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,
+        C{expr("name")} in place of C{expr.setResultsName("name")} - 
+        see L{I{__call__}<__call__>}.
+
+        Example::
+            date_str = (integer.setResultsName("year") + '/' 
+                        + integer.setResultsName("month") + '/' 
+                        + integer.setResultsName("day"))
+
+            # equivalent form:
+            date_str = integer("year") + '/' + integer("month") + '/' + integer("day")
+        """
+        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 C{breakFlag} to True to enable, False to
+           disable.
+        """
+        if breakFlag:
+            _parseMethod = self._parse
+            def breaker(instring, loc, doActions=True, callPreParse=True):
+                import pdb
+                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 C{fn(s,loc,toks)},
+        C{fn(loc,toks)}, C{fn(toks)}, or just C{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 C{L{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.
+
+        Optional keyword arguments:
+         - callDuringTry = (default=C{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 L{I{parseString}} for more information
+        on parsing strings containing C{}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]
+        """
+        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 L{I{setParseAction}}.
+        
+        See examples in L{I{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 
+        L{I{setParseAction}} for function call signatures. Unlike C{setParseAction}, 
+        functions passed to C{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)
+        """
+        msg = kwargs.get("message", "failed user-defined condition")
+        exc_type = ParseFatalException if kwargs.get("fatal", False) else ParseException
+        for fn in fns:
+            def pa(s,l,t):
+                if not bool(_trim_arity(fn)(s,l,t)):
+                    raise exc_type(s,l,msg)
+            self.parseAction.append(pa)
+        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
+           C{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 C{L{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 ):
+        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[0] ):
+                self.debugActions[0]( instring, loc, self )
+            if callPreParse and self.callPreparse:
+                preloc = self.preParse( instring, loc )
+            else:
+                preloc = loc
+            tokensStart = preloc
+            try:
+                try:
+                    loc,tokens = self.parseImpl( instring, preloc, doActions )
+                except IndexError:
+                    raise ParseException( instring, len(instring), self.errmsg, self )
+            except ParseBaseException as err:
+                #~ print ("Exception raised:", err)
+                if self.debugActions[2]:
+                    self.debugActions[2]( 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:
+                        tokens = fn( instring, tokensStart, retTokens )
+                        if tokens is not None:
+                            retTokens = ParseResults( tokens,
+                                                      self.resultsName,
+                                                      asList=self.saveAsList and isinstance(tokens,(ParseResults,list)),
+                                                      modal=self.modalResults )
+                except ParseBaseException as err:
+                    #~ print "Exception raised in user parse action:", err
+                    if (self.debugActions[2] ):
+                        self.debugActions[2]( instring, tokensStart, self, err )
+                    raise
+            else:
+                for fn in self.parseAction:
+                    tokens = fn( instring, tokensStart, retTokens )
+                    if tokens is not None:
+                        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[1] ):
+                self.debugActions[1]( 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=C{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 C{ParserElement.enablePackrat()}.  If
+           your program uses C{psyco} to "compile as you go", you must call
+           C{enablePackrat} before calling C{psyco.full()}.  If you do not do this,
+           Python will crash.  For best results, call C{enablePackrat()} immediately
+           after importing pyparsing.
+           
+           Example::
+               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.
+
+        If you want the grammar to require that the entire input string be
+        successfully parsed, then set C{parseAll} to True (equivalent to ending
+        the grammar with C{L{StringEnd()}}).
+
+        Note: C{parseString} implicitly calls C{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 C{loc} argument to index into the
+        string being parsed, you can ensure you have a consistent view of the input
+        string by:
+         - calling C{parseWithTabs} on your grammar before calling C{parseString}
+           (see L{I{parseWithTabs}})
+         - define your parse action using the full C{(s,loc,toks)} signature, and
+           reference the input string using the parse action's C{s} argument
+         - explictly expand the tabs in your input string before calling
+           C{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, clears out pyparsing internal stack trace
+                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
+        C{maxMatches} argument, to clip scanning after 'n' matches are found.  If
+        C{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 L{I{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, clears out pyparsing internal stack trace
+                raise exc
+
+    def transformString( self, instring ):
+        """
+        Extension to C{L{scanString}}, to modify matching text with modified tokens that may
+        be returned from a parse action.  To use C{transformString}, define a grammar and
+        attach a parse action to it that modifies the returned token list.
+        Invoking C{transformString()} on a target string will then scan for matches,
+        and replace the matched text patterns according to the logic in the parse
+        action.  C{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 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, clears out pyparsing internal stack trace
+                raise exc
+
+    def searchString( self, instring, maxMatches=_MAX_INT ):
+        """
+        Another extension to C{L{scanString}}, simplifying the access to the tokens found
+        to match the given parse expression.  May be called with optional
+        C{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, clears out pyparsing internal stack trace
+                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 C{maxsplit} argument, to limit the number of splits;
+        and the optional C{includeSeparators} argument (default=C{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 C{L{And}}. Adding strings to a ParserElement
+        converts them to L{Literal}s by default.
+        
+        Example::
+            greet = Word(alphas) + "," + Word(alphas) + "!"
+            hello = "Hello, World!"
+            print (hello, "->", greet.parseString(hello))
+        Prints::
+            Hello, World! -> ['Hello', ',', 'World', '!']
+        """
+        if isinstance( other, basestring ):
+            other = ParserElement._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 C{L{ParserElement}}
+        """
+        if isinstance( other, basestring ):
+            other = ParserElement._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 C{L{And}} with error stop
+        """
+        if isinstance( other, basestring ):
+            other = ParserElement._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 C{L{ParserElement}}
+        """
+        if isinstance( other, basestring ):
+            other = ParserElement._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 C{expr * 3} in place of
+        C{expr + expr + expr}.  Expressions may also me multiplied by a 2-integer
+        tuple, similar to C{{min,max}} multipliers in regular expressions.  Tuples
+        may also include C{None} as in:
+         - C{expr*(n,None)} or C{expr*(n,)} is equivalent
+              to C{expr*n + L{ZeroOrMore}(expr)}
+              (read as "at least n instances of C{expr}")
+         - C{expr*(None,n)} is equivalent to C{expr*(0,n)}
+              (read as "0 to n instances of C{expr}")
+         - C{expr*(None,None)} is equivalent to C{L{ZeroOrMore}(expr)}
+         - C{expr*(1,None)} is equivalent to C{L{OneOrMore}(expr)}
+
+        Note that C{expr*(None,n)} does not raise an exception if
+        more than n exprs exist in the input stream; that is,
+        C{expr*(None,n)} does not enforce a maximum number of expr
+        occurrences.  If this behavior is desired, then write
+        C{expr*(None,n) + ~expr}
+        """
+        if isinstance(other,int):
+            minElements, optElements = other,0
+        elif isinstance(other,tuple):
+            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 C{L{MatchFirst}}
+        """
+        if isinstance( other, basestring ):
+            other = ParserElement._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 C{L{ParserElement}}
+        """
+        if isinstance( other, basestring ):
+            other = ParserElement._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 C{L{Or}}
+        """
+        if isinstance( other, basestring ):
+            other = ParserElement._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 C{L{ParserElement}}
+        """
+        if isinstance( other, basestring ):
+            other = ParserElement._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 C{L{Each}}
+        """
+        if isinstance( other, basestring ):
+            other = ParserElement._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 C{L{ParserElement}}
+        """
+        if isinstance( other, basestring ):
+            other = ParserElement._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 C{L{NotAny}}
+        """
+        return NotAny( self )
+
+    def __call__(self, name=None):
+        """
+        Shortcut for C{L{setResultsName}}, with C{listAllMatches=False}.
+        
+        If C{name} is given with a trailing C{'*'} character, then C{listAllMatches} will be
+        passed as C{True}.
+           
+        If C{name} is omitted, same as calling C{L{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 C{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
+        C{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 C{}s to spaces before parsing the input string.
+        Must be called before C{parseString} when the input grammar contains elements that
+        match C{} 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 C{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 L{setDebugActions}. Prior to attempting
+        to match the C{wd} expression, the debugging message C{"Match  at loc (,)"}
+        is shown. Then if the parse succeeds, a C{"Matched"} message is shown, or an C{"Exception raised"}
+        message is shown. Also note the use of L{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 C{Word} expression without calling C{setName} is C{"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=[] ):
+        """
+        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, clears out pyparsing internal stack trace
+                raise exc
+
+    def __eq__(self,other):
+        if isinstance(other, ParserElement):
+            return self is other or vars(self) == vars(other)
+        elif isinstance(other, basestring):
+            return self.matches(other)
+        else:
+            return super(ParserElement,self)==other
+
+    def __ne__(self,other):
+        return not (self == other)
+
+    def __hash__(self):
+        return hash(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=C{True}) - flag to pass to C{L{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):
+        """
+        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=C{True}) - flag to pass to C{L{parseString}} when running tests           
+         - comment - (default=C{'#'}) - expression for indicating embedded comments in the test 
+              string; pass None to disable comment filtering
+         - fullDump - (default=C{True}) - dump results as list followed by results names in nested outline;
+              if False, only dump nested list
+         - printResults - (default=C{True}) prints test output to stdout
+         - failureTests - (default=C{False}) indicates if these tests are expected to fail parsing
+
+        Returns: a (success, results) tuple, where success indicates that all tests succeeded
+        (or failed if C{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)
+        allResults = []
+        comments = []
+        success = True
+        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'.join(comments), t]
+            comments = []
+            try:
+                t = t.replace(r'\n','\n')
+                result = self.parseString(t, parseAll=parseAll)
+                out.append(result.dump(full=fullDump))
+                success = success and not failureTests
+            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
+
+            if printResults:
+                if fullDump:
+                    out.append('')
+                print('\n'.join(out))
+
+            allResults.append((t, result))
+        
+        return success, allResults
+
+        
+class Token(ParserElement):
+    """
+    Abstract C{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 L{CaselessLiteral}.
+    
+    For keyword matching (force word break before and after the matched string),
+    use L{Keyword} or L{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: this routine gets called a *lot*
+    # if this is a single character match string  and the first character matches,
+    # short-circuit as quickly as possible, and avoid calling startswith
+    #~ @profile
+    def parseImpl( self, instring, loc, doActions=True ):
+        if (instring[loc] == self.firstMatchChar and
+            (self.matchLen==1 or instring.startswith(self.match,loc)) ):
+            return loc+self.matchLen, 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 C{L{Literal}}:
+     - C{Literal("if")} will match the leading C{'if'} in C{'ifAndOnlyIf'}.
+     - C{Keyword("if")} will not; it will only match the leading C{'if'} in C{'if x=1'}, or C{'if(y==2)'}
+    Accepts two optional constructor arguments in addition to the keyword string:
+     - C{identChars} is a string of characters that would be valid identifier characters,
+          defaulting to all alphanumerics + "_" and "$"
+     - C{caseless} allows case-insensitive matching, default is C{False}.
+       
+    Example::
+        Keyword("start").parseString("start")  # -> ['start']
+        Keyword("start").parseString("starting")  # -> Exception
+
+    For case-insensitive matching, use L{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 and
+                (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 L{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 L{Keyword}.
+
+    Example::
+        OneOrMore(CaselessKeyword("CMD")).parseString("cmd CMD Cmd10") # -> ['CMD', 'CMD']
+        
+    (Contrast with example for L{CaselessLiteral}.)
+    """
+    def __init__( self, matchString, identChars=None ):
+        super(CaselessKeyword,self).__init__( matchString, identChars, caseless=True )
+
+    def parseImpl( self, instring, loc, doActions=True ):
+        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) ):
+            return loc+self.matchLen, self.match
+        raise ParseException(instring, loc, self.errmsg, self)
+
+class CloseMatch(Token):
+    """
+    A variation on L{Literal} which matches "close" matches, that is, 
+    strings with at most 'n' mismatching characters. C{CloseMatch} takes parameters:
+     - C{match_string} - string to be matched
+     - C{maxMismatches} - (C{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:
+     - C{mismatches} - a list of the positions within the match_string where mismatches were found
+     - C{original} - the original match_string used to compare against the input string
+    
+    If C{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], self.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'] = self.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 C{min} is 1 (a
+    minimum value < 1 is not valid); the default values for C{max} and C{exact}
+    are 0, meaning no maximum or exact length restriction. An optional
+    C{excludeChars} parameter can list characters that might be found in 
+    the input C{bodyChars} string; useful to define a word of all printables
+    except for one or two characters, for instance.
+    
+    L{srange} is useful for defining custom character set strings for defining 
+    C{Word} expressions, using range notation from regular expression character sets.
+    
+    A common mistake is to use C{Word} to match a specific literal string, as in 
+    C{Word("Address")}. Remember that C{Word} uses the string argument to define
+    I{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 L{Literal} or L{Keyword}.
+
+    pyparsing includes helper strings for building Words:
+     - L{alphas}
+     - L{nums}
+     - L{alphanums}
+     - L{hexnums}
+     - L{alphas8bit} (alphabetic characters in ASCII range 128-255 - accented, tilded, umlauted, etc.)
+     - L{punc8bit} (non-alphabetic characters in ASCII range 128-255 - currency, symbols, superscripts, diacriticals, etc.)
+     - L{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:
+            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
+
+    def parseImpl( self, instring, loc, doActions=True ):
+        if self.re:
+            result = self.re.match(instring,loc)
+            if not result:
+                raise ParseException(instring, loc, self.errmsg, self)
+
+            loc = result.end()
+            return loc, result.group()
+
+        if not(instring[ loc ] 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
+        if self.maxSpecified and loc < instrlen and instring[loc] in bodychars:
+            throwException = True
+        if self.asKeyword:
+            if (start>0 and instring[start-1] in bodychars) or (loc4:
+                    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 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 inbuilt Python re module.
+    If the given regex contains named groups (defined using C{(?P...)}), these will be preserved as 
+    named parse results.
+
+    Example::
+        realnum = Regex(r"[+-]?\d+\.\d*")
+        date = Regex(r'(?P\d{4})-(?P\d\d?)-(?P\d\d?)')
+        # ref: http://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?C{0,3})(XC|XL|L?X{0,3})(IX|IV|V?I{0,3})")
+    """
+    compiledREtype = type(re.compile("[A-Z]"))
+    def __init__( self, pattern, flags=0):
+        """The parameters C{pattern} and C{flags} are passed to the C{re.compile()} function as-is. See the Python C{re} 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 isinstance(pattern, Regex.compiledREtype):
+            self.re = pattern
+            self.pattern = \
+            self.reString = str(pattern)
+            self.flags = flags
+            
+        else:
+            raise ValueError("Regex may only be constructed with a string or a compiled RE object")
+
+        self.name = _ustr(self)
+        self.errmsg = "Expected " + self.name
+        self.mayIndexError = False
+        self.mayReturnEmpty = True
+
+    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()
+        d = result.groupdict()
+        ret = ParseResults(result.group())
+        if d:
+            for k in d:
+                ret[k] = d[k]
+        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
+
+
+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=C{None})
+        - escQuote - special quote sequence to escape an embedded quote string (such as SQL's "" to escape an embedded ") (default=C{None})
+        - multiline - boolean indicating whether quotes can span multiple lines (default=C{False})
+        - unquoteResults - boolean indicating whether the matched text should be unquoted (default=C{True})
+        - endQuoteChar - string of one or more characters defining the end of the quote delimited string (default=C{None} => same as quoteChar)
+        - convertWhitespaceEscapes - convert escaped whitespace (C{'\t'}, C{'\n'}, etc.) to actual whitespace (default=C{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
+        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 I{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 C{min} is 1 (a
+    minimum value < 1 is not valid); the default values for C{max} and C{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 C{" \\t\\r\\n"}.  Also takes optional C{min}, C{max}, and C{exact} arguments,
+    as defined for the C{L{Word}} class.
+    """
+    whiteStrs = {
+        " " : "",
+        "\t": "",
+        "\n": "",
+        "\r": "",
+        "\f": "",
+        }
+    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 not(instring[ loc ] 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):
+    """
+    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):
+            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 C{wordChars}
+    (default=C{printables}). To emulate the C{\b} behavior of regular expressions,
+    use C{WordStart(alphanums)}. C{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 C{wordChars}
+    (default=C{printables}). To emulate the C{\b} behavior of regular expressions,
+    use C{WordEnd(alphanums)}. C{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 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:
+            matches.sort(key=lambda x: -x[0])
+            for _,e in matches:
+                try:
+                    return e._parse( instring, loc, doActions )
+                except ParseException as err:
+                    err.__traceback__ = None
+                    if err.loc > maxExcLoc:
+                        maxException = err
+                        maxExcLoc = err.loc
+
+        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 = ParserElement._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 )
+
+
+class MatchFirst(ParseExpression):
+    """
+    Requires that at least one C{ParseExpression} is found.
+    If two expressions match, the first one listed is the one that will match.
+    May be constructed using the C{'|'} 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 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 = ParserElement._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 )
+
+
+class Each(ParseExpression):
+    """
+    Requires all given C{ParseExpression}s to be found, but in any order.
+    Expressions may be separated by whitespace.
+    May be constructed using the C{'&'} 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
+
+    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)]
+            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 C{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(ParserElement._literalStringClass, Token):
+                expr = ParserElement._literalStringClass(expr)
+            else:
+                expr = ParserElement._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=[] ):
+        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.  C{FollowedBy}
+    does I{not} advance the parsing position within the input string, it only
+    verifies that the specified parse expression matches at the current
+    position.  C{FollowedBy} always returns a null token list.
+
+    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 ):
+        self.expr.tryParse( instring, loc )
+        return loc, []
+
+
+class NotAny(ParseElementEnhance):
+    """
+    Lookahead to disallow matching with the given parse expression.  C{NotAny}
+    does I{not} advance the parsing position within the input string, it only
+    verifies that the specified parse expression does I{not} match at the current
+    position.  Also, C{NotAny} does I{not} skip over leading whitespace. C{NotAny}
+    always returns a null token list.  May be constructed using the '~' operator.
+
+    Example::
+        
+    """
+    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 = ParserElement._literalStringClass(ender)
+        self.not_ender = ~ender if ender is not None else None
+
+    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
+        
+class OneOrMore(_MultipleMatch):
+    """
+    Repetition of one or more of the given expression.
+    
+    Parameters:
+     - expr - expression that must match one or more times
+     - stopOn - (default=C{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=C{None}) - expression for a terminating sentinel
+          (only required if the sentinel would ordinarily match the repetition 
+          expression)          
+
+    Example: similar to L{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 ""
+
+_optionalNotMatched = _NullToken()
+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)
+    """
+    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 _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=C{False}) if True, the target expression is also parsed 
+          (the skipped text and target expression are returned as a 2-element list).
+     - ignore - (default=C{None}) used to define grammars (typically quoted strings and 
+          comments) that might contain false matches to the target expression
+     - failOn - (default=C{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.asList = False
+        if isinstance(failOn, basestring):
+            self.failOn = ParserElement._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 C{Forward} variable using the '<<' operator.
+
+    Note: take care when assigning to C{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 C{Forward}::
+        fwdExpr << (a | b | c)
+    Converting to use the '<<=' operator instead will avoid this problem.
+
+    See L{ParseResults.pprint} for an example of a recursive parser created using
+    C{Forward}.
+    """
+    def __init__( self, other=None ):
+        super(Forward,self).__init__( other, savelist=False )
+
+    def __lshift__( self, other ):
+        if isinstance( other, basestring ):
+            other = ParserElement._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=[] ):
+        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
+        return self.__class__.__name__ + ": ..."
+
+        # stubbed out for now - creates awful memory and perf issues
+        self._revertClass = self.__class__
+        self.__class__ = _ForwardNoRecurse
+        try:
+            if self.expr is not None:
+                retString = _ustr(self.expr)
+            else:
+                retString = "None"
+        finally:
+            self.__class__ = self._revertClass
+        return self.__class__.__name__ + ": " + retString
+
+    def copy(self):
+        if self.expr is not None:
+            return super(Forward,self).copy()
+        else:
+            ret = Forward()
+            ret <<= self
+            return ret
+
+class _ForwardNoRecurse(Forward):
+    def __str__( self ):
+        return "..."
+
+class TokenConverter(ParseElementEnhance):
+    """
+    Abstract subclass of C{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 C{'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 C{L{ZeroOrMore}} and C{L{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 L{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 L{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 C{">> entering I{method-name}(line:I{current_source_line}, I{parse_location}, I{matched_tokens})".}
+    When the parse action completes, the decorator will print C{"<<"} 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'], {}))
+        <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( "< ['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 C{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 C{"1:1"}, but not C{"1:2"}.  Because this matches a
+    previous literal, will also match the leading C{"1:1"} in C{"1:10"}.
+    If this is not desired, use C{matchPreviousExpr}.
+    Do I{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 C{"1:1"}, but not C{"1:2"}.  Because this matches by
+    expressions, will I{not} match the leading C{"1:1"} in C{"1:10"};
+    the expressions are evaluated first, and then compared, so
+    C{"1"} is compared with C{"10"}.
+    Do I{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 ):
+    """
+    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 C{L{MatchFirst}} for best performance.
+
+    Parameters:
+     - strs - a string of space-delimited literals, or a collection of string literals
+     - caseless - (default=C{False}) - treat all literals as caseless
+     - useRegex - (default=C{True}) - as an optimization, will generate a Regex
+          object; otherwise, will generate a C{MatchFirst} object (if C{caseless=True}, or
+          if creating a C{Regex} raises an exception)
+
+    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 caseless:
+        isequal = ( lambda a,b: a.upper() == b.upper() )
+        masks = ( lambda a,b: b.upper().startswith(a.upper()) )
+        parseElementClass = CaselessLiteral
+    else:
+        isequal = ( lambda a,b: a == b )
+        masks = ( lambda a,b: b.startswith(a) )
+        parseElementClass = 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()
+
+    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)
+                cur = other
+                break
+        else:
+            i += 1
+
+    if not caseless 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 C{L{Dict}}, C{L{ZeroOrMore}}, and C{L{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 C{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( ZeroOrMore( 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 C{asString} argument is passed as C{False}, then the return value is a 
+    C{L{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 C{L{originalTextFor}} contains expressions with defined
+    results names, you must set C{asString} to C{False} if you want to preserve those
+    results name values.
+
+    Example::
+        src = "this is test  bold text  normal text "
+        for tag in ("b","i"):
+            opener,closer = makeHTMLTags(tag)
+            patt = originalTextFor(opener + SkipTo(closer) + closer)
+            print(patt.searchString(src)[0])
+    prints::
+        [' bold text ']
+        ['text']
+    """
+    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).setParseAction(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 C{} characters, you may want to call
+    C{L{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 C{\-} or C{\]})
+     - an escaped hex character with a leading C{'\x'} (C{\x21}, which is a C{'!'} character) 
+         (C{\0x##} is also supported for backwards compatibility) 
+     - an escaped octal character with a leading C{'\0'} (C{\041}, which is a C{'!'} character)
+     - a range of any of the above, separated by a dash (C{'a-z'}, etc.)
+     - any combination of the above (C{'aeiouy'}, C{'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 C{L{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 C{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 L{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 L{pyparsing_common.upcaseTokens}"""
+
+downcaseTokens = tokenMap(lambda t: _ustr(t).lower())
+"""(Deprecated) Helper parse action to convert tokens to lower case. Deprecated in favor of L{pyparsing_common.downcaseTokens}"""
+    
+def _makeTags(tagStr, xml):
+    """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("<") + tagStr("tag") + \
+                Dict(ZeroOrMore(Group( tagAttrName + Suppress("=") + tagAttrValue ))) + \
+                Optional("/",default=[False]).setResultsName("empty").setParseAction(lambda s,l,t:t[0]=='/') + Suppress(">")
+    else:
+        printablesLessRAbrack = "".join(c for c in printables if c not in ">")
+        tagAttrValue = quotedString.copy().setParseAction( removeQuotes ) | Word(printablesLessRAbrack)
+        openTag = Suppress("<") + tagStr("tag") + \
+                Dict(ZeroOrMore(Group( tagAttrName.setParseAction(downcaseTokens) + \
+                Optional( Suppress("=") + tagAttrValue ) ))) + \
+                Optional("/",default=[False]).setResultsName("empty").setParseAction(lambda s,l,t:t[0]=='/') + Suppress(">")
+    closeTag = Combine(_L("")
+
+    openTag = openTag.setResultsName("start"+"".join(resname.replace(":"," ").title().split())).setName("<%s>" % resname)
+    closeTag = closeTag.setResultsName("end"+"".join(resname.replace(":"," ").title().split())).setName("" % resname)
+    openTag.tag = resname
+    closeTag.tag = resname
+    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 = 'More info at the pyparsing wiki page'
+        # 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  tag (like "href" shown here) are also accessible as named results
+            print(link.link_text, '->', link.href)
+    prints::
+        pyparsing -> http://pyparsing.wikispaces.com
+    """
+    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 L{makeHTMLTags}
+    """
+    return _makeTags( tagStr, True )
+
+def withAttribute(*args,**attrDict):
+    """
+    Helper to create a validating parse action to be used with start tags created
+    with C{L{makeXMLTags}} or C{L{makeHTMLTags}}. Use C{withAttribute} to qualify a starting tag
+    with a required attribute value, to avoid false matches on common tags such as
+    C{} or C{
}. + + Call C{withAttribute} with a series of attribute names and values. Specify the list + of filter attributes names and values as: + - keyword arguments, as in C{(align="right")}, or + - as an explicit dict with C{**} operator, when an attribute name is also a Python + reserved word, as in C{**{"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 C{class} (with or without a namespace), use C{L{withClass}}. + + To verify that the attribute exists, but without specifying a value, pass + C{withAttribute.ANY_VALUE} as the value. + + Example:: + html = ''' +
+ Some text +
1 4 0 1 0
+
1,3 2,3 1,1
+
this has no type
+
+ + ''' + 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 C{L{withAttribute}} when matching on a div class - made + difficult because C{class} is a reserved word in Python. + + Example:: + html = ''' +
+ Some text +
1 4 0 1 0
+
1,3 2,3 1,1
+
this <div> has no class
+
+ + ''' + 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 = _Constants() +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 L{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 C{opAssoc.RIGHT} and C{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 C{setParseAction(*fn)} (L{ParserElement.setParseAction}) + - lpar - expression for matching left-parentheses (default=C{Suppress('(')}) + - rpar - expression for matching right-parentheses (default=C{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]]] + """ + 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 = FollowedBy(lastExpr + opExpr) + Group( lastExpr + OneOrMore( opExpr ) ) + elif arity == 2: + if opExpr is not None: + matchExpr = FollowedBy(lastExpr + opExpr + lastExpr) + Group( lastExpr + OneOrMore( opExpr + lastExpr ) ) + else: + matchExpr = FollowedBy(lastExpr+lastExpr) + Group( lastExpr + OneOrMore(lastExpr) ) + elif arity == 3: + matchExpr = FollowedBy(lastExpr + opExpr1 + lastExpr + opExpr2 + lastExpr) + \ + Group( lastExpr + 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 = FollowedBy(opExpr.expr + thisExpr) + Group( opExpr + thisExpr ) + elif arity == 2: + if opExpr is not None: + matchExpr = FollowedBy(lastExpr + opExpr + thisExpr) + Group( lastExpr + OneOrMore( opExpr + thisExpr ) ) + else: + matchExpr = FollowedBy(lastExpr + thisExpr) + Group( lastExpr + OneOrMore( thisExpr ) ) + elif arity == 3: + matchExpr = FollowedBy(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 C{L{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=C{"("}); can also be a pyparsing expression + - closer - closing character for a nested list (default=C{")"}); can also be a pyparsing expression + - content - expression for items within the nested lists (default=C{None}) + - ignoreExpr - expression for ignoring opening and closing delimiters (default=C{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 C{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 C{L{Or}} or C{L{MatchFirst}}. + The default is L{quotedString}, but if no expressions are to be ignored, + then pass C{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 + the current level; set to False for block of left-most statements + (default=C{True}) + + A valid block must contain at least one C{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']]]]]]] + """ + def checkPeerIndent(s,l,t): + if l >= len(s): return + curCol = col(l,s) + if curCol != indentStack[-1]: + if curCol > indentStack[-1]: + raise ParseFatalException(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 < indentStack[-1] and curCol <= indentStack[-2]): + raise ParseException(s,l,"not an unindent") + indentStack.pop() + + NL = OneOrMore(LineEnd().setWhitespaceChars("\t ").suppress()) + INDENT = (Empty() + Empty().setParseAction(checkSubIndent)).setName('INDENT') + PEER = Empty().setParseAction(checkPeerIndent).setName('') + UNDENT = Empty().setParseAction(checkUnindent).setName('UNINDENT') + if indent: + smExpr = Group( Optional(NL) + + #~ FollowedBy(blockStatementExpr) + + INDENT + (OneOrMore( PEER + Group(blockStatementExpr) + Optional(NL) )) + UNDENT) + else: + smExpr = Group( Optional(NL) + + (OneOrMore( PEER + Group(blockStatementExpr) + Optional(NL) )) ) + 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' + '|'.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 C{/* ... */}" + +htmlComment = Regex(r"").setName("HTML comment") +"Comment of the form C{}" + +restOfLine = Regex(r".*").leaveWhitespace().setName("rest of line") +dblSlashComment = Regex(r"//(?:\\\n|[^\n])*").setName("// comment") +"Comment of the form C{// ... (to end of line)}" + +cppStyleComment = Combine(Regex(r"/\*(?:[^*]|\*(?!/))*") + '*/'| dblSlashComment).setName("C++ style comment") +"Comment of either form C{L{cStyleComment}} or C{L{dblSlashComment}}" + +javaStyleComment = cppStyleComment +"Same as C{L{cppStyleComment}}" + +pythonStyleComment = Regex(r"#.*").setName("Python style comment") +"Comment of the form C{# ... (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 L{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 (L{integers}, L{reals}, L{scientific notation}) + - common L{programming identifiers} + - network addresses (L{MAC}, L{IPv4}, L{IPv6}) + - ISO8601 L{dates} and L{datetime} + - L{UUID} + - L{comma-separated list} + Parse actions: + - C{L{convertToInteger}} + - C{L{convertToFloat}} + - C{L{convertToDate}} + - C{L{convertToDatetime}} + - C{L{stripHTMLTags}} + - C{L{upcaseTokens}} + - C{L{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*').setName("real number").setParseAction(convertToFloat) + """expression that parses a floating point number and returns a float""" + + sci_real = Regex(r'[+-]?\d+([eE][+-]?\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 (C{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=C{"%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=C{"%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\d{4})(?:-(?P\d\d)(?:-(?P\d\d))?)?').setName("ISO8601 date") + "ISO8601 date (C{yyyy-mm-dd})" + + iso8601_datetime = Regex(r'(?P\d{4})-(?P\d\d)-(?P\d\d)[T ](?P\d\d):(?P\d\d)(:(?P\d\d(\.\d*)?)?)?(?PZ|[+-]\d\d:?\d\d)?').setName("ISO8601 datetime") + "ISO8601 datetime (C{yyyy-mm-ddThh:mm:ss.s(Z|+-00:00)}) - trailing seconds, milliseconds, and timezone optional; accepts separating C{'T'} or C{' '}" + + uuid = Regex(r'[0-9a-fA-F]{8}(-[0-9a-fA-F]{4}){3}-[0-9a-fA-F]{12}').setName("UUID") + "UUID (C{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 = 'More info at the
pyparsing wiki page' + td,td_end = makeHTMLTags("TD") + table_text = td + SkipTo(td_end).setParseAction(pyparsing_common.stripHTMLTags)("body") + td_end + + print(table_text.parseString(text).body) # -> '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.""" + + +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/venv/lib/python3.8/site-packages/setuptools/_vendor/six.py b/venv/lib/python3.8/site-packages/setuptools/_vendor/six.py new file mode 100644 index 0000000..190c023 --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/_vendor/six.py @@ -0,0 +1,868 @@ +"""Utilities for writing code that runs on Python 2 and 3""" + +# Copyright (c) 2010-2015 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 +# 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 absolute_import + +import functools +import itertools +import operator +import sys +import types + +__author__ = "Benjamin Peterson " +__version__ = "1.10.0" + + +# Useful for very coarse version differentiation. +PY2 = sys.version_info[0] == 2 +PY3 = sys.version_info[0] == 3 +PY34 = sys.version_info[0:2] >= (3, 4) + +if PY3: + string_types = str, + integer_types = int, + class_types = type, + text_type = str + binary_type = bytes + + MAXSIZE = sys.maxsize +else: + string_types = basestring, + integer_types = (int, long) + class_types = (type, types.ClassType) + text_type = unicode + binary_type = str + + if sys.platform.startswith("java"): + # Jython always uses 32 bits. + MAXSIZE = int((1 << 31) - 1) + else: + # It's possible to have sizeof(long) != sizeof(Py_ssize_t). + class X(object): + + def __len__(self): + return 1 << 31 + try: + len(X()) + except OverflowError: + # 32-bit + MAXSIZE = int((1 << 31) - 1) + else: + # 64-bit + MAXSIZE = int((1 << 63) - 1) + del X + + +def _add_doc(func, doc): + """Add documentation to a function.""" + func.__doc__ = doc + + +def _import_module(name): + """Import module, returning the module after the last dot.""" + __import__(name) + return sys.modules[name] + + +class _LazyDescr(object): + + def __init__(self, name): + self.name = name + + def __get__(self, obj, tp): + result = self._resolve() + setattr(obj, self.name, result) # Invokes __set__. + try: + # This is a bit ugly, but it avoids running this again by + # removing this descriptor. + delattr(obj.__class__, self.name) + except AttributeError: + pass + return result + + +class MovedModule(_LazyDescr): + + def __init__(self, name, old, new=None): + super(MovedModule, self).__init__(name) + if PY3: + if new is None: + new = name + self.mod = new + else: + self.mod = old + + def _resolve(self): + return _import_module(self.mod) + + def __getattr__(self, attr): + _module = self._resolve() + value = getattr(_module, attr) + setattr(self, attr, value) + return value + + +class _LazyModule(types.ModuleType): + + def __init__(self, name): + super(_LazyModule, self).__init__(name) + self.__doc__ = self.__class__.__doc__ + + def __dir__(self): + attrs = ["__doc__", "__name__"] + attrs += [attr.name for attr in self._moved_attributes] + return attrs + + # Subclasses should override this + _moved_attributes = [] + + +class MovedAttribute(_LazyDescr): + + def __init__(self, name, old_mod, new_mod, old_attr=None, new_attr=None): + super(MovedAttribute, self).__init__(name) + if PY3: + if new_mod is None: + new_mod = name + self.mod = new_mod + if new_attr is None: + if old_attr is None: + new_attr = name + else: + new_attr = old_attr + self.attr = new_attr + else: + self.mod = old_mod + if old_attr is None: + old_attr = name + self.attr = old_attr + + def _resolve(self): + module = _import_module(self.mod) + return getattr(module, self.attr) + + +class _SixMetaPathImporter(object): + + """ + A meta path importer to import six.moves and its submodules. + + This class implements a PEP302 finder and loader. It should be compatible + with Python 2.5 and all existing versions of Python3 + """ + + def __init__(self, six_module_name): + self.name = six_module_name + self.known_modules = {} + + def _add_module(self, mod, *fullnames): + for fullname in fullnames: + self.known_modules[self.name + "." + fullname] = mod + + def _get_module(self, fullname): + return self.known_modules[self.name + "." + fullname] + + def find_module(self, fullname, path=None): + if fullname in self.known_modules: + return self + return None + + def __get_module(self, fullname): + try: + return self.known_modules[fullname] + except KeyError: + raise ImportError("This loader does not know module " + fullname) + + def load_module(self, fullname): + try: + # in case of a reload + return sys.modules[fullname] + except KeyError: + pass + mod = self.__get_module(fullname) + if isinstance(mod, MovedModule): + mod = mod._resolve() + else: + mod.__loader__ = self + sys.modules[fullname] = mod + return mod + + def is_package(self, fullname): + """ + Return true, if the named module is a package. + + We need this method to get correct spec objects with + Python 3.4 (see PEP451) + """ + return hasattr(self.__get_module(fullname), "__path__") + + def get_code(self, fullname): + """Return None + + Required, if is_package is implemented""" + self.__get_module(fullname) # eventually raises ImportError + return None + get_source = get_code # same as get_code + +_importer = _SixMetaPathImporter(__name__) + + +class _MovedItems(_LazyModule): + + """Lazy loading of moved objects""" + __path__ = [] # mark as package + + +_moved_attributes = [ + MovedAttribute("cStringIO", "cStringIO", "io", "StringIO"), + MovedAttribute("filter", "itertools", "builtins", "ifilter", "filter"), + MovedAttribute("filterfalse", "itertools", "itertools", "ifilterfalse", "filterfalse"), + MovedAttribute("input", "__builtin__", "builtins", "raw_input", "input"), + MovedAttribute("intern", "__builtin__", "sys"), + MovedAttribute("map", "itertools", "builtins", "imap", "map"), + MovedAttribute("getcwd", "os", "os", "getcwdu", "getcwd"), + MovedAttribute("getcwdb", "os", "os", "getcwd", "getcwdb"), + MovedAttribute("range", "__builtin__", "builtins", "xrange", "range"), + MovedAttribute("reload_module", "__builtin__", "importlib" if PY34 else "imp", "reload"), + MovedAttribute("reduce", "__builtin__", "functools"), + MovedAttribute("shlex_quote", "pipes", "shlex", "quote"), + MovedAttribute("StringIO", "StringIO", "io"), + MovedAttribute("UserDict", "UserDict", "collections"), + MovedAttribute("UserList", "UserList", "collections"), + MovedAttribute("UserString", "UserString", "collections"), + MovedAttribute("xrange", "__builtin__", "builtins", "xrange", "range"), + MovedAttribute("zip", "itertools", "builtins", "izip", "zip"), + MovedAttribute("zip_longest", "itertools", "itertools", "izip_longest", "zip_longest"), + MovedModule("builtins", "__builtin__"), + MovedModule("configparser", "ConfigParser"), + MovedModule("copyreg", "copy_reg"), + MovedModule("dbm_gnu", "gdbm", "dbm.gnu"), + MovedModule("_dummy_thread", "dummy_thread", "_dummy_thread"), + MovedModule("http_cookiejar", "cookielib", "http.cookiejar"), + MovedModule("http_cookies", "Cookie", "http.cookies"), + MovedModule("html_entities", "htmlentitydefs", "html.entities"), + MovedModule("html_parser", "HTMLParser", "html.parser"), + MovedModule("http_client", "httplib", "http.client"), + MovedModule("email_mime_multipart", "email.MIMEMultipart", "email.mime.multipart"), + MovedModule("email_mime_nonmultipart", "email.MIMENonMultipart", "email.mime.nonmultipart"), + MovedModule("email_mime_text", "email.MIMEText", "email.mime.text"), + MovedModule("email_mime_base", "email.MIMEBase", "email.mime.base"), + MovedModule("BaseHTTPServer", "BaseHTTPServer", "http.server"), + MovedModule("CGIHTTPServer", "CGIHTTPServer", "http.server"), + MovedModule("SimpleHTTPServer", "SimpleHTTPServer", "http.server"), + MovedModule("cPickle", "cPickle", "pickle"), + MovedModule("queue", "Queue"), + MovedModule("reprlib", "repr"), + MovedModule("socketserver", "SocketServer"), + MovedModule("_thread", "thread", "_thread"), + MovedModule("tkinter", "Tkinter"), + MovedModule("tkinter_dialog", "Dialog", "tkinter.dialog"), + MovedModule("tkinter_filedialog", "FileDialog", "tkinter.filedialog"), + MovedModule("tkinter_scrolledtext", "ScrolledText", "tkinter.scrolledtext"), + MovedModule("tkinter_simpledialog", "SimpleDialog", "tkinter.simpledialog"), + MovedModule("tkinter_tix", "Tix", "tkinter.tix"), + MovedModule("tkinter_ttk", "ttk", "tkinter.ttk"), + MovedModule("tkinter_constants", "Tkconstants", "tkinter.constants"), + MovedModule("tkinter_dnd", "Tkdnd", "tkinter.dnd"), + MovedModule("tkinter_colorchooser", "tkColorChooser", + "tkinter.colorchooser"), + MovedModule("tkinter_commondialog", "tkCommonDialog", + "tkinter.commondialog"), + MovedModule("tkinter_tkfiledialog", "tkFileDialog", "tkinter.filedialog"), + MovedModule("tkinter_font", "tkFont", "tkinter.font"), + MovedModule("tkinter_messagebox", "tkMessageBox", "tkinter.messagebox"), + MovedModule("tkinter_tksimpledialog", "tkSimpleDialog", + "tkinter.simpledialog"), + MovedModule("urllib_parse", __name__ + ".moves.urllib_parse", "urllib.parse"), + MovedModule("urllib_error", __name__ + ".moves.urllib_error", "urllib.error"), + MovedModule("urllib", __name__ + ".moves.urllib", __name__ + ".moves.urllib"), + MovedModule("urllib_robotparser", "robotparser", "urllib.robotparser"), + MovedModule("xmlrpc_client", "xmlrpclib", "xmlrpc.client"), + MovedModule("xmlrpc_server", "SimpleXMLRPCServer", "xmlrpc.server"), +] +# Add windows specific modules. +if sys.platform == "win32": + _moved_attributes += [ + MovedModule("winreg", "_winreg"), + ] + +for attr in _moved_attributes: + setattr(_MovedItems, attr.name, attr) + if isinstance(attr, MovedModule): + _importer._add_module(attr, "moves." + attr.name) +del attr + +_MovedItems._moved_attributes = _moved_attributes + +moves = _MovedItems(__name__ + ".moves") +_importer._add_module(moves, "moves") + + +class Module_six_moves_urllib_parse(_LazyModule): + + """Lazy loading of moved objects in six.moves.urllib_parse""" + + +_urllib_parse_moved_attributes = [ + MovedAttribute("ParseResult", "urlparse", "urllib.parse"), + MovedAttribute("SplitResult", "urlparse", "urllib.parse"), + MovedAttribute("parse_qs", "urlparse", "urllib.parse"), + MovedAttribute("parse_qsl", "urlparse", "urllib.parse"), + MovedAttribute("urldefrag", "urlparse", "urllib.parse"), + MovedAttribute("urljoin", "urlparse", "urllib.parse"), + MovedAttribute("urlparse", "urlparse", "urllib.parse"), + MovedAttribute("urlsplit", "urlparse", "urllib.parse"), + MovedAttribute("urlunparse", "urlparse", "urllib.parse"), + MovedAttribute("urlunsplit", "urlparse", "urllib.parse"), + MovedAttribute("quote", "urllib", "urllib.parse"), + MovedAttribute("quote_plus", "urllib", "urllib.parse"), + MovedAttribute("unquote", "urllib", "urllib.parse"), + MovedAttribute("unquote_plus", "urllib", "urllib.parse"), + MovedAttribute("urlencode", "urllib", "urllib.parse"), + MovedAttribute("splitquery", "urllib", "urllib.parse"), + MovedAttribute("splittag", "urllib", "urllib.parse"), + MovedAttribute("splituser", "urllib", "urllib.parse"), + MovedAttribute("uses_fragment", "urlparse", "urllib.parse"), + MovedAttribute("uses_netloc", "urlparse", "urllib.parse"), + MovedAttribute("uses_params", "urlparse", "urllib.parse"), + MovedAttribute("uses_query", "urlparse", "urllib.parse"), + MovedAttribute("uses_relative", "urlparse", "urllib.parse"), +] +for attr in _urllib_parse_moved_attributes: + setattr(Module_six_moves_urllib_parse, attr.name, attr) +del attr + +Module_six_moves_urllib_parse._moved_attributes = _urllib_parse_moved_attributes + +_importer._add_module(Module_six_moves_urllib_parse(__name__ + ".moves.urllib_parse"), + "moves.urllib_parse", "moves.urllib.parse") + + +class Module_six_moves_urllib_error(_LazyModule): + + """Lazy loading of moved objects in six.moves.urllib_error""" + + +_urllib_error_moved_attributes = [ + MovedAttribute("URLError", "urllib2", "urllib.error"), + MovedAttribute("HTTPError", "urllib2", "urllib.error"), + MovedAttribute("ContentTooShortError", "urllib", "urllib.error"), +] +for attr in _urllib_error_moved_attributes: + setattr(Module_six_moves_urllib_error, attr.name, attr) +del attr + +Module_six_moves_urllib_error._moved_attributes = _urllib_error_moved_attributes + +_importer._add_module(Module_six_moves_urllib_error(__name__ + ".moves.urllib.error"), + "moves.urllib_error", "moves.urllib.error") + + +class Module_six_moves_urllib_request(_LazyModule): + + """Lazy loading of moved objects in six.moves.urllib_request""" + + +_urllib_request_moved_attributes = [ + MovedAttribute("urlopen", "urllib2", "urllib.request"), + MovedAttribute("install_opener", "urllib2", "urllib.request"), + MovedAttribute("build_opener", "urllib2", "urllib.request"), + MovedAttribute("pathname2url", "urllib", "urllib.request"), + MovedAttribute("url2pathname", "urllib", "urllib.request"), + MovedAttribute("getproxies", "urllib", "urllib.request"), + MovedAttribute("Request", "urllib2", "urllib.request"), + MovedAttribute("OpenerDirector", "urllib2", "urllib.request"), + MovedAttribute("HTTPDefaultErrorHandler", "urllib2", "urllib.request"), + MovedAttribute("HTTPRedirectHandler", "urllib2", "urllib.request"), + MovedAttribute("HTTPCookieProcessor", "urllib2", "urllib.request"), + MovedAttribute("ProxyHandler", "urllib2", "urllib.request"), + MovedAttribute("BaseHandler", "urllib2", "urllib.request"), + MovedAttribute("HTTPPasswordMgr", "urllib2", "urllib.request"), + MovedAttribute("HTTPPasswordMgrWithDefaultRealm", "urllib2", "urllib.request"), + MovedAttribute("AbstractBasicAuthHandler", "urllib2", "urllib.request"), + MovedAttribute("HTTPBasicAuthHandler", "urllib2", "urllib.request"), + MovedAttribute("ProxyBasicAuthHandler", "urllib2", "urllib.request"), + MovedAttribute("AbstractDigestAuthHandler", "urllib2", "urllib.request"), + MovedAttribute("HTTPDigestAuthHandler", "urllib2", "urllib.request"), + MovedAttribute("ProxyDigestAuthHandler", "urllib2", "urllib.request"), + MovedAttribute("HTTPHandler", "urllib2", "urllib.request"), + MovedAttribute("HTTPSHandler", "urllib2", "urllib.request"), + MovedAttribute("FileHandler", "urllib2", "urllib.request"), + MovedAttribute("FTPHandler", "urllib2", "urllib.request"), + MovedAttribute("CacheFTPHandler", "urllib2", "urllib.request"), + MovedAttribute("UnknownHandler", "urllib2", "urllib.request"), + MovedAttribute("HTTPErrorProcessor", "urllib2", "urllib.request"), + MovedAttribute("urlretrieve", "urllib", "urllib.request"), + MovedAttribute("urlcleanup", "urllib", "urllib.request"), + MovedAttribute("URLopener", "urllib", "urllib.request"), + MovedAttribute("FancyURLopener", "urllib", "urllib.request"), + MovedAttribute("proxy_bypass", "urllib", "urllib.request"), +] +for attr in _urllib_request_moved_attributes: + setattr(Module_six_moves_urllib_request, attr.name, attr) +del attr + +Module_six_moves_urllib_request._moved_attributes = _urllib_request_moved_attributes + +_importer._add_module(Module_six_moves_urllib_request(__name__ + ".moves.urllib.request"), + "moves.urllib_request", "moves.urllib.request") + + +class Module_six_moves_urllib_response(_LazyModule): + + """Lazy loading of moved objects in six.moves.urllib_response""" + + +_urllib_response_moved_attributes = [ + MovedAttribute("addbase", "urllib", "urllib.response"), + MovedAttribute("addclosehook", "urllib", "urllib.response"), + MovedAttribute("addinfo", "urllib", "urllib.response"), + MovedAttribute("addinfourl", "urllib", "urllib.response"), +] +for attr in _urllib_response_moved_attributes: + setattr(Module_six_moves_urllib_response, attr.name, attr) +del attr + +Module_six_moves_urllib_response._moved_attributes = _urllib_response_moved_attributes + +_importer._add_module(Module_six_moves_urllib_response(__name__ + ".moves.urllib.response"), + "moves.urllib_response", "moves.urllib.response") + + +class Module_six_moves_urllib_robotparser(_LazyModule): + + """Lazy loading of moved objects in six.moves.urllib_robotparser""" + + +_urllib_robotparser_moved_attributes = [ + MovedAttribute("RobotFileParser", "robotparser", "urllib.robotparser"), +] +for attr in _urllib_robotparser_moved_attributes: + setattr(Module_six_moves_urllib_robotparser, attr.name, attr) +del attr + +Module_six_moves_urllib_robotparser._moved_attributes = _urllib_robotparser_moved_attributes + +_importer._add_module(Module_six_moves_urllib_robotparser(__name__ + ".moves.urllib.robotparser"), + "moves.urllib_robotparser", "moves.urllib.robotparser") + + +class Module_six_moves_urllib(types.ModuleType): + + """Create a six.moves.urllib namespace that resembles the Python 3 namespace""" + __path__ = [] # mark as package + parse = _importer._get_module("moves.urllib_parse") + error = _importer._get_module("moves.urllib_error") + request = _importer._get_module("moves.urllib_request") + response = _importer._get_module("moves.urllib_response") + robotparser = _importer._get_module("moves.urllib_robotparser") + + def __dir__(self): + return ['parse', 'error', 'request', 'response', 'robotparser'] + +_importer._add_module(Module_six_moves_urllib(__name__ + ".moves.urllib"), + "moves.urllib") + + +def add_move(move): + """Add an item to six.moves.""" + setattr(_MovedItems, move.name, move) + + +def remove_move(name): + """Remove item from six.moves.""" + try: + delattr(_MovedItems, name) + except AttributeError: + try: + del moves.__dict__[name] + except KeyError: + raise AttributeError("no such move, %r" % (name,)) + + +if PY3: + _meth_func = "__func__" + _meth_self = "__self__" + + _func_closure = "__closure__" + _func_code = "__code__" + _func_defaults = "__defaults__" + _func_globals = "__globals__" +else: + _meth_func = "im_func" + _meth_self = "im_self" + + _func_closure = "func_closure" + _func_code = "func_code" + _func_defaults = "func_defaults" + _func_globals = "func_globals" + + +try: + advance_iterator = next +except NameError: + def advance_iterator(it): + return it.next() +next = advance_iterator + + +try: + callable = callable +except NameError: + def callable(obj): + return any("__call__" in klass.__dict__ for klass in type(obj).__mro__) + + +if PY3: + def get_unbound_function(unbound): + return unbound + + create_bound_method = types.MethodType + + def create_unbound_method(func, cls): + return func + + Iterator = object +else: + def get_unbound_function(unbound): + return unbound.im_func + + def create_bound_method(func, obj): + return types.MethodType(func, obj, obj.__class__) + + def create_unbound_method(func, cls): + return types.MethodType(func, None, cls) + + class Iterator(object): + + def next(self): + return type(self).__next__(self) + + callable = callable +_add_doc(get_unbound_function, + """Get the function out of a possibly unbound function""") + + +get_method_function = operator.attrgetter(_meth_func) +get_method_self = operator.attrgetter(_meth_self) +get_function_closure = operator.attrgetter(_func_closure) +get_function_code = operator.attrgetter(_func_code) +get_function_defaults = operator.attrgetter(_func_defaults) +get_function_globals = operator.attrgetter(_func_globals) + + +if PY3: + def iterkeys(d, **kw): + return iter(d.keys(**kw)) + + def itervalues(d, **kw): + return iter(d.values(**kw)) + + def iteritems(d, **kw): + return iter(d.items(**kw)) + + def iterlists(d, **kw): + return iter(d.lists(**kw)) + + viewkeys = operator.methodcaller("keys") + + viewvalues = operator.methodcaller("values") + + viewitems = operator.methodcaller("items") +else: + def iterkeys(d, **kw): + return d.iterkeys(**kw) + + def itervalues(d, **kw): + return d.itervalues(**kw) + + def iteritems(d, **kw): + return d.iteritems(**kw) + + def iterlists(d, **kw): + return d.iterlists(**kw) + + viewkeys = operator.methodcaller("viewkeys") + + viewvalues = operator.methodcaller("viewvalues") + + viewitems = operator.methodcaller("viewitems") + +_add_doc(iterkeys, "Return an iterator over the keys of a dictionary.") +_add_doc(itervalues, "Return an iterator over the values of a dictionary.") +_add_doc(iteritems, + "Return an iterator over the (key, value) pairs of a dictionary.") +_add_doc(iterlists, + "Return an iterator over the (key, [values]) pairs of a dictionary.") + + +if PY3: + def b(s): + return s.encode("latin-1") + + def u(s): + return s + unichr = chr + import struct + int2byte = struct.Struct(">B").pack + del struct + byte2int = operator.itemgetter(0) + indexbytes = operator.getitem + iterbytes = iter + import io + StringIO = io.StringIO + BytesIO = io.BytesIO + _assertCountEqual = "assertCountEqual" + if sys.version_info[1] <= 1: + _assertRaisesRegex = "assertRaisesRegexp" + _assertRegex = "assertRegexpMatches" + else: + _assertRaisesRegex = "assertRaisesRegex" + _assertRegex = "assertRegex" +else: + def b(s): + return s + # Workaround for standalone backslash + + def u(s): + return unicode(s.replace(r'\\', r'\\\\'), "unicode_escape") + unichr = unichr + int2byte = chr + + def byte2int(bs): + return ord(bs[0]) + + def indexbytes(buf, i): + return ord(buf[i]) + iterbytes = functools.partial(itertools.imap, ord) + import StringIO + StringIO = BytesIO = StringIO.StringIO + _assertCountEqual = "assertItemsEqual" + _assertRaisesRegex = "assertRaisesRegexp" + _assertRegex = "assertRegexpMatches" +_add_doc(b, """Byte literal""") +_add_doc(u, """Text literal""") + + +def assertCountEqual(self, *args, **kwargs): + return getattr(self, _assertCountEqual)(*args, **kwargs) + + +def assertRaisesRegex(self, *args, **kwargs): + return getattr(self, _assertRaisesRegex)(*args, **kwargs) + + +def assertRegex(self, *args, **kwargs): + return getattr(self, _assertRegex)(*args, **kwargs) + + +if PY3: + exec_ = getattr(moves.builtins, "exec") + + def reraise(tp, value, tb=None): + if value is None: + value = tp() + if value.__traceback__ is not tb: + raise value.with_traceback(tb) + raise value + +else: + def exec_(_code_, _globs_=None, _locs_=None): + """Execute code in a namespace.""" + if _globs_ is None: + frame = sys._getframe(1) + _globs_ = frame.f_globals + if _locs_ is None: + _locs_ = frame.f_locals + del frame + elif _locs_ is None: + _locs_ = _globs_ + exec("""exec _code_ in _globs_, _locs_""") + + exec_("""def reraise(tp, value, tb=None): + raise tp, value, tb +""") + + +if sys.version_info[:2] == (3, 2): + exec_("""def raise_from(value, from_value): + if from_value is None: + raise value + raise value from from_value +""") +elif sys.version_info[:2] > (3, 2): + exec_("""def raise_from(value, from_value): + raise value from from_value +""") +else: + def raise_from(value, from_value): + raise value + + +print_ = getattr(moves.builtins, "print", None) +if print_ is None: + def print_(*args, **kwargs): + """The new-style print function for Python 2.4 and 2.5.""" + fp = kwargs.pop("file", sys.stdout) + if fp is None: + return + + def write(data): + if not isinstance(data, basestring): + data = str(data) + # If the file has an encoding, encode unicode with it. + if (isinstance(fp, file) and + isinstance(data, unicode) and + fp.encoding is not None): + errors = getattr(fp, "errors", None) + if errors is None: + errors = "strict" + data = data.encode(fp.encoding, errors) + fp.write(data) + want_unicode = False + sep = kwargs.pop("sep", None) + if sep is not None: + if isinstance(sep, unicode): + want_unicode = True + elif not isinstance(sep, str): + raise TypeError("sep must be None or a string") + end = kwargs.pop("end", None) + if end is not None: + if isinstance(end, unicode): + want_unicode = True + elif not isinstance(end, str): + raise TypeError("end must be None or a string") + if kwargs: + raise TypeError("invalid keyword arguments to print()") + if not want_unicode: + for arg in args: + if isinstance(arg, unicode): + want_unicode = True + break + if want_unicode: + newline = unicode("\n") + space = unicode(" ") + else: + newline = "\n" + space = " " + if sep is None: + sep = space + if end is None: + end = newline + for i, arg in enumerate(args): + if i: + write(sep) + write(arg) + write(end) +if sys.version_info[:2] < (3, 3): + _print = print_ + + def print_(*args, **kwargs): + fp = kwargs.get("file", sys.stdout) + flush = kwargs.pop("flush", False) + _print(*args, **kwargs) + if flush and fp is not None: + fp.flush() + +_add_doc(reraise, """Reraise an exception.""") + +if sys.version_info[0:2] < (3, 4): + 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 +else: + wraps = functools.wraps + + +def with_metaclass(meta, *bases): + """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): + + def __new__(cls, name, this_bases, d): + return meta(name, bases, d) + return type.__new__(metaclass, 'temporary_class', (), {}) + + +def add_metaclass(metaclass): + """Class decorator for creating a class with a metaclass.""" + def wrapper(cls): + orig_vars = cls.__dict__.copy() + slots = orig_vars.get('__slots__') + if slots is not None: + if isinstance(slots, str): + slots = [slots] + for slots_var in slots: + orig_vars.pop(slots_var) + orig_vars.pop('__dict__', None) + orig_vars.pop('__weakref__', None) + return metaclass(cls.__name__, cls.__bases__, orig_vars) + return wrapper + + +def python_2_unicode_compatible(klass): + """ + A 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 + returning text and apply this decorator to the class. + """ + if PY2: + if '__str__' not in klass.__dict__: + raise ValueError("@python_2_unicode_compatible cannot be applied " + "to %s because it doesn't define __str__()." % + klass.__name__) + klass.__unicode__ = klass.__str__ + klass.__str__ = lambda self: self.__unicode__().encode('utf-8') + return klass + + +# Complete the moves implementation. +# This code is at the end of this module to speed up module loading. +# Turn this module into a package. +__path__ = [] # required for PEP 302 and PEP 451 +__package__ = __name__ # see PEP 366 @ReservedAssignment +if globals().get("__spec__") is not None: + __spec__.submodule_search_locations = [] # PEP 451 @UndefinedVariable +# Remove other six meta path importers, since they cause problems. This can +# happen if six is removed from sys.modules and then reloaded. (Setuptools does +# this for some reason.) +if sys.meta_path: + for i, importer in enumerate(sys.meta_path): + # Here's some real nastiness: Another "instance" of the six module might + # be floating around. Therefore, we can't use isinstance() to check for + # the six meta path importer, since the other six instance will have + # inserted an importer with different class. + if (type(importer).__name__ == "_SixMetaPathImporter" and + importer.name == __name__): + del sys.meta_path[i] + break + del i, importer +# Finally, add the importer to the meta path import hook. +sys.meta_path.append(_importer) diff --git a/venv/lib/python3.8/site-packages/setuptools/archive_util.py b/venv/lib/python3.8/site-packages/setuptools/archive_util.py new file mode 100644 index 0000000..8143604 --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/archive_util.py @@ -0,0 +1,173 @@ +"""Utilities for extracting common archive formats""" + +import zipfile +import tarfile +import os +import shutil +import posixpath +import contextlib +from distutils.errors import DistutilsError + +from pkg_resources import ensure_directory + +__all__ = [ + "unpack_archive", "unpack_zipfile", "unpack_tarfile", "default_filter", + "UnrecognizedFormat", "extraction_drivers", "unpack_directory", +] + + +class UnrecognizedFormat(DistutilsError): + """Couldn't recognize the archive type""" + + +def default_filter(src, dst): + """The default progress/filter callback; returns True for all files""" + return dst + + +def unpack_archive(filename, extract_dir, progress_filter=default_filter, + drivers=None): + """Unpack `filename` to `extract_dir`, or raise ``UnrecognizedFormat`` + + `progress_filter` is a function taking two arguments: a source path + internal to the archive ('/'-separated), and a filesystem path where it + will be extracted. The callback must return the desired extract path + (which may be the same as the one passed in), or else ``None`` to skip + that file or directory. The callback can thus be used to report on the + progress of the extraction, as well as to filter the items extracted or + alter their extraction paths. + + `drivers`, if supplied, must be a non-empty sequence of functions with the + same signature as this function (minus the `drivers` argument), that raise + ``UnrecognizedFormat`` if they do not support extracting the designated + archive type. The `drivers` are tried in sequence until one is found that + does not raise an error, or until all are exhausted (in which case + ``UnrecognizedFormat`` is raised). If you do not supply a sequence of + drivers, the module's ``extraction_drivers`` constant will be used, which + means that ``unpack_zipfile`` and ``unpack_tarfile`` will be tried, in that + order. + """ + for driver in drivers or extraction_drivers: + try: + driver(filename, extract_dir, progress_filter) + except UnrecognizedFormat: + continue + else: + return + else: + raise UnrecognizedFormat( + "Not a recognized archive type: %s" % filename + ) + + +def unpack_directory(filename, extract_dir, progress_filter=default_filter): + """"Unpack" a directory, using the same interface as for archives + + Raises ``UnrecognizedFormat`` if `filename` is not a directory + """ + if not os.path.isdir(filename): + raise UnrecognizedFormat("%s is not a directory" % filename) + + paths = { + filename: ('', extract_dir), + } + for base, dirs, files in os.walk(filename): + src, dst = paths[base] + for d in dirs: + paths[os.path.join(base, d)] = src + d + '/', os.path.join(dst, d) + for f in files: + target = os.path.join(dst, f) + target = progress_filter(src + f, target) + if not target: + # skip non-files + continue + ensure_directory(target) + f = os.path.join(base, f) + shutil.copyfile(f, target) + shutil.copystat(f, target) + + +def unpack_zipfile(filename, extract_dir, progress_filter=default_filter): + """Unpack zip `filename` to `extract_dir` + + Raises ``UnrecognizedFormat`` if `filename` is not a zipfile (as determined + by ``zipfile.is_zipfile()``). See ``unpack_archive()`` for an explanation + of the `progress_filter` argument. + """ + + if not zipfile.is_zipfile(filename): + raise UnrecognizedFormat("%s is not a zip file" % (filename,)) + + with zipfile.ZipFile(filename) as z: + for info in z.infolist(): + name = info.filename + + # don't extract absolute paths or ones with .. in them + if name.startswith('/') or '..' in name.split('/'): + continue + + target = os.path.join(extract_dir, *name.split('/')) + target = progress_filter(name, target) + if not target: + continue + if name.endswith('/'): + # directory + ensure_directory(target) + else: + # file + ensure_directory(target) + data = z.read(info.filename) + with open(target, 'wb') as f: + f.write(data) + unix_attributes = info.external_attr >> 16 + if unix_attributes: + os.chmod(target, unix_attributes) + + +def unpack_tarfile(filename, extract_dir, progress_filter=default_filter): + """Unpack tar/tar.gz/tar.bz2 `filename` to `extract_dir` + + Raises ``UnrecognizedFormat`` if `filename` is not a tarfile (as determined + by ``tarfile.open()``). See ``unpack_archive()`` for an explanation + of the `progress_filter` argument. + """ + try: + tarobj = tarfile.open(filename) + except tarfile.TarError: + raise UnrecognizedFormat( + "%s is not a compressed or uncompressed tar file" % (filename,) + ) + with contextlib.closing(tarobj): + # don't do any chowning! + tarobj.chown = lambda *args: None + for member in tarobj: + name = member.name + # don't extract absolute paths or ones with .. in them + if not name.startswith('/') and '..' not in name.split('/'): + prelim_dst = os.path.join(extract_dir, *name.split('/')) + + # resolve any links and to extract the link targets as normal + # files + while member is not None and (member.islnk() or member.issym()): + linkpath = member.linkname + if member.issym(): + base = posixpath.dirname(member.name) + linkpath = posixpath.join(base, linkpath) + linkpath = posixpath.normpath(linkpath) + member = tarobj._getmember(linkpath) + + if member is not None and (member.isfile() or member.isdir()): + final_dst = progress_filter(name, prelim_dst) + if final_dst: + if final_dst.endswith(os.sep): + final_dst = final_dst[:-1] + try: + # XXX Ugh + tarobj._extract_member(member, final_dst) + except tarfile.ExtractError: + # chown/chmod/mkfifo/mknode/makedev failed + pass + return True + + +extraction_drivers = unpack_directory, unpack_zipfile, unpack_tarfile diff --git a/venv/lib/python3.8/site-packages/setuptools/build_meta.py b/venv/lib/python3.8/site-packages/setuptools/build_meta.py new file mode 100644 index 0000000..10c4b52 --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/build_meta.py @@ -0,0 +1,257 @@ +"""A PEP 517 interface to setuptools + +Previously, when a user or a command line tool (let's call it a "frontend") +needed to make a request of setuptools to take a certain action, for +example, generating a list of installation requirements, the frontend would +would call "setup.py egg_info" or "setup.py bdist_wheel" on the command line. + +PEP 517 defines a different method of interfacing with setuptools. Rather +than calling "setup.py" directly, the frontend should: + + 1. Set the current directory to the directory with a setup.py file + 2. Import this module into a safe python interpreter (one in which + setuptools can potentially set global variables or crash hard). + 3. Call one of the functions defined in PEP 517. + +What each function does is defined in PEP 517. However, here is a "casual" +definition of the functions (this definition should not be relied on for +bug reports or API stability): + + - `build_wheel`: build a wheel in the folder and return the basename + - `get_requires_for_build_wheel`: get the `setup_requires` to build + - `prepare_metadata_for_build_wheel`: get the `install_requires` + - `build_sdist`: build an sdist in the folder and return the basename + - `get_requires_for_build_sdist`: get the `setup_requires` to build + +Again, this is not a formal definition! Just a "taste" of the module. +""" + +import io +import os +import sys +import tokenize +import shutil +import contextlib + +import setuptools +import distutils +from setuptools.py31compat import TemporaryDirectory + +from pkg_resources import parse_requirements +from pkg_resources.py31compat import makedirs + +__all__ = ['get_requires_for_build_sdist', + 'get_requires_for_build_wheel', + 'prepare_metadata_for_build_wheel', + 'build_wheel', + 'build_sdist', + '__legacy__', + 'SetupRequirementsError'] + +class SetupRequirementsError(BaseException): + def __init__(self, specifiers): + self.specifiers = specifiers + + +class Distribution(setuptools.dist.Distribution): + def fetch_build_eggs(self, specifiers): + specifier_list = list(map(str, parse_requirements(specifiers))) + + raise SetupRequirementsError(specifier_list) + + @classmethod + @contextlib.contextmanager + def patch(cls): + """ + Replace + distutils.dist.Distribution with this class + for the duration of this context. + """ + orig = distutils.core.Distribution + distutils.core.Distribution = cls + try: + yield + finally: + distutils.core.Distribution = orig + + +def _to_str(s): + """ + Convert a filename to a string (on Python 2, explicitly + a byte string, not Unicode) as distutils checks for the + exact type str. + """ + if sys.version_info[0] == 2 and not isinstance(s, str): + # Assume it's Unicode, as that's what the PEP says + # should be provided. + return s.encode(sys.getfilesystemencoding()) + return s + + +def _get_immediate_subdirectories(a_dir): + return [name for name in os.listdir(a_dir) + if os.path.isdir(os.path.join(a_dir, name))] + + +def _file_with_extension(directory, extension): + matching = ( + f for f in os.listdir(directory) + if f.endswith(extension) + ) + file, = matching + return file + + +def _open_setup_script(setup_script): + if not os.path.exists(setup_script): + # Supply a default setup.py + return io.StringIO(u"from setuptools import setup; setup()") + + return getattr(tokenize, 'open', open)(setup_script) + + +class _BuildMetaBackend(object): + + def _fix_config(self, config_settings): + config_settings = config_settings or {} + config_settings.setdefault('--global-option', []) + return config_settings + + def _get_build_requires(self, config_settings, requirements): + config_settings = self._fix_config(config_settings) + + sys.argv = sys.argv[:1] + ['egg_info'] + \ + config_settings["--global-option"] + try: + with Distribution.patch(): + self.run_setup() + except SetupRequirementsError as e: + requirements += e.specifiers + + return requirements + + def run_setup(self, setup_script='setup.py'): + # Note that we can reuse our build directory between calls + # Correctness comes first, then optimization later + __file__ = setup_script + __name__ = '__main__' + + with _open_setup_script(__file__) as f: + code = f.read().replace(r'\r\n', r'\n') + + exec(compile(code, __file__, 'exec'), locals()) + + def get_requires_for_build_wheel(self, config_settings=None): + config_settings = self._fix_config(config_settings) + return self._get_build_requires(config_settings, requirements=['wheel']) + + def get_requires_for_build_sdist(self, config_settings=None): + config_settings = self._fix_config(config_settings) + return self._get_build_requires(config_settings, requirements=[]) + + def prepare_metadata_for_build_wheel(self, metadata_directory, + config_settings=None): + sys.argv = sys.argv[:1] + ['dist_info', '--egg-base', + _to_str(metadata_directory)] + self.run_setup() + + dist_info_directory = metadata_directory + while True: + dist_infos = [f for f in os.listdir(dist_info_directory) + if f.endswith('.dist-info')] + + if (len(dist_infos) == 0 and + len(_get_immediate_subdirectories(dist_info_directory)) == 1): + + dist_info_directory = os.path.join( + dist_info_directory, os.listdir(dist_info_directory)[0]) + continue + + assert len(dist_infos) == 1 + break + + # PEP 517 requires that the .dist-info directory be placed in the + # metadata_directory. To comply, we MUST copy the directory to the root + if dist_info_directory != metadata_directory: + shutil.move( + os.path.join(dist_info_directory, dist_infos[0]), + metadata_directory) + shutil.rmtree(dist_info_directory, ignore_errors=True) + + return dist_infos[0] + + def _build_with_temp_dir(self, setup_command, result_extension, + result_directory, config_settings): + config_settings = self._fix_config(config_settings) + result_directory = os.path.abspath(result_directory) + + # Build in a temporary directory, then copy to the target. + makedirs(result_directory, exist_ok=True) + with TemporaryDirectory(dir=result_directory) as tmp_dist_dir: + sys.argv = (sys.argv[:1] + setup_command + + ['--dist-dir', tmp_dist_dir] + + config_settings["--global-option"]) + self.run_setup() + + result_basename = _file_with_extension(tmp_dist_dir, result_extension) + result_path = os.path.join(result_directory, result_basename) + if os.path.exists(result_path): + # os.rename will fail overwriting on non-Unix. + os.remove(result_path) + os.rename(os.path.join(tmp_dist_dir, result_basename), result_path) + + return result_basename + + + def build_wheel(self, wheel_directory, config_settings=None, + metadata_directory=None): + return self._build_with_temp_dir(['bdist_wheel'], '.whl', + wheel_directory, config_settings) + + def build_sdist(self, sdist_directory, config_settings=None): + return self._build_with_temp_dir(['sdist', '--formats', 'gztar'], + '.tar.gz', sdist_directory, + config_settings) + + +class _BuildMetaLegacyBackend(_BuildMetaBackend): + """Compatibility backend for setuptools + + This is a version of setuptools.build_meta that endeavors to maintain backwards + compatibility with pre-PEP 517 modes of invocation. It exists as a temporary + bridge between the old packaging mechanism and the new packaging mechanism, + and will eventually be removed. + """ + def run_setup(self, setup_script='setup.py'): + # In order to maintain compatibility with scripts assuming that + # the setup.py script is in a directory on the PYTHONPATH, inject + # '' into sys.path. (pypa/setuptools#1642) + sys_path = list(sys.path) # Save the original path + + script_dir = os.path.dirname(os.path.abspath(setup_script)) + if script_dir not in sys.path: + sys.path.insert(0, script_dir) + + try: + super(_BuildMetaLegacyBackend, + self).run_setup(setup_script=setup_script) + finally: + # While PEP 517 frontends should be calling each hook in a fresh + # subprocess according to the standard (and thus it should not be + # strictly necessary to restore the old sys.path), we'll restore + # the original path so that the path manipulation does not persist + # within the hook after run_setup is called. + sys.path[:] = sys_path + +# The primary backend +_BACKEND = _BuildMetaBackend() + +get_requires_for_build_wheel = _BACKEND.get_requires_for_build_wheel +get_requires_for_build_sdist = _BACKEND.get_requires_for_build_sdist +prepare_metadata_for_build_wheel = _BACKEND.prepare_metadata_for_build_wheel +build_wheel = _BACKEND.build_wheel +build_sdist = _BACKEND.build_sdist + + +# The legacy backend +__legacy__ = _BuildMetaLegacyBackend() diff --git a/venv/lib/python3.8/site-packages/setuptools/cli-32.exe b/venv/lib/python3.8/site-packages/setuptools/cli-32.exe new file mode 100644 index 0000000000000000000000000000000000000000..b1487b7819e7286577a043c7726fbe0ca1543083 GIT binary patch literal 65536 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

@|$jDp4t7maBT@by!vG1&J_?=DS4W3Hu6w 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[c}iI#RErv3nvcIClH@!{vM)zJ_weD zu_-L8NU*GlC{d0L!!VW10^+~>qmNB~Y8H+F}!P8_d(PpvjzMJQmr z)FkX;2B~<|3JfJeWv@IXo~nTtp$}Gjie> zs8UDG*kid(%i5QCBp~MA;#I186PI-nZ&k7!k8BiLJSuR>h7ArSYHD~B0I z=T6L{zqglekt0JjG5z&|GWb4?+B5+{p^fgTufl_KesA{@I&g7rNq==^SGc5GcM%$N zDBG2)qExz*Z;jGN_-iD-y8i2BCq)p}2lKcspLg>w-;qwg(()HXrZa3jd!}spuwBVX zwmX!iwU?#7uoQnunw|OlU~+c z^L5Ak3zWhaA4B^FhMMboO0k*O2GL)lD9_<$5b>czbCvKcSt+u*gA*=%dH>Q-Bc11h zzO7jbXN)&5mBf=w2anK6P$YcJZQoWa2#E!v{hFKxxm7Fc)Fc9iC35{|Lp7bIDjrhC zgMiGf4r2yquH{U7WdMio;XS4Y%Ry{q7#kv#gZ07i`7eo#MMh_o68E*Fd_#nrri^4b zX+slbsv>+8pmck%oLDUL()8NRJ#Z z8DReF_eq2zsjEXGs)yS{k}ykS1B!ZrY0f6O65^lslJv3g&wfpDg-&EwF8wrc=hSwm zPlV&n%%yE_@onOwK?)`GNJ6MQ0drMuBYWCH5dkD)uErh@*k}#GcFl<-;;TN+5vb|b zctkCv;*zL7f)A;QuO%(81r0)&aUz4EQu;kA!k@7i8RZ)koMaWW`5cC6n@{w!!J$5d zx}l)4VP4xL=BKi&c^{n_Qi`q@G{vimblcVR53b#*X$FUOQFm!A8JKahNSiBdY+x3bJZfD8n{--FLUM4+Mx@{vM_ep zkk)U=K8R(rhU(X_faI*ZO}cn`5t*O}lx^j8|0rt-)o=Axn^DGcQTi!#7hxLTq?|HQ zB;T6(nrsCeYK0_o%)IO+CP{n#+|;w1ZmvD2c-J{i88bp63RjyKOE!B!D3U{RCs*Zh z&^%65VM(J34230U4bHS}M@SYS9TEK}c%)2<$h1|T;##zRtjRt@#1T%J=kAhOiw+Z% z7DpyWVK@6%9K^uVD9LDKj)dR^aZK6$@Lt)l;sj@`QSzBm{TlLG{JKM_^60Zr2w~nr zr>P-BaV8OjjWm?hQ3$ZCx+lyD%q`~4iNF9xWKi$t&pzBhwN9Dq-o^v9@=abLR#|

KZqkLal4YCRR9VNhIM|rBqmzzcImvcx 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 literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/setuptools/cli-64.exe b/venv/lib/python3.8/site-packages/setuptools/cli-64.exe new file mode 100644 index 0000000000000000000000000000000000000000..675e6bf3743f3d3011c238657e7128ee9960ef7f GIT binary patch literal 74752 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 literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/setuptools/cli.exe b/venv/lib/python3.8/site-packages/setuptools/cli.exe new file mode 100644 index 0000000000000000000000000000000000000000..b1487b7819e7286577a043c7726fbe0ca1543083 GIT binary patch literal 65536 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

@|$jDp4t7maBT@by!vG1&J_?=DS4W3Hu6w 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[c}iI#RErv3nvcIClH@!{vM)zJ_weD zu_-L8NU*GlC{d0L!!VW10^+~>qmNB~Y8H+F}!P8_d(PpvjzMJQmr z)FkX;2B~<|3JfJeWv@IXo~nTtp$}Gjie> zs8UDG*kid(%i5QCBp~MA;#I186PI-nZ&k7!k8BiLJSuR>h7ArSYHD~B0I z=T6L{zqglekt0JjG5z&|GWb4?+B5+{p^fgTufl_KesA{@I&g7rNq==^SGc5GcM%$N zDBG2)qExz*Z;jGN_-iD-y8i2BCq)p}2lKcspLg>w-;qwg(()HXrZa3jd!}spuwBVX zwmX!iwU?#7uoQnunw|OlU~+c z^L5Ak3zWhaA4B^FhMMboO0k*O2GL)lD9_<$5b>czbCvKcSt+u*gA*=%dH>Q-Bc11h zzO7jbXN)&5mBf=w2anK6P$YcJZQoWa2#E!v{hFKxxm7Fc)Fc9iC35{|Lp7bIDjrhC zgMiGf4r2yquH{U7WdMio;XS4Y%Ry{q7#kv#gZ07i`7eo#MMh_o68E*Fd_#nrri^4b zX+slbsv>+8pmck%oLDUL()8NRJ#Z z8DReF_eq2zsjEXGs)yS{k}ykS1B!ZrY0f6O65^lslJv3g&wfpDg-&EwF8wrc=hSwm zPlV&n%%yE_@onOwK?)`GNJ6MQ0drMuBYWCH5dkD)uErh@*k}#GcFl<-;;TN+5vb|b zctkCv;*zL7f)A;QuO%(81r0)&aUz4EQu;kA!k@7i8RZ)koMaWW`5cC6n@{w!!J$5d zx}l)4VP4xL=BKi&c^{n_Qi`q@G{vimblcVR53b#*X$FUOQFm!A8JKahNSiBdY+x3bJZfD8n{--FLUM4+Mx@{vM_ep zkk)U=K8R(rhU(X_faI*ZO}cn`5t*O}lx^j8|0rt-)o=Axn^DGcQTi!#7hxLTq?|HQ zB;T6(nrsCeYK0_o%)IO+CP{n#+|;w1ZmvD2c-J{i88bp63RjyKOE!B!D3U{RCs*Zh z&^%65VM(J34230U4bHS}M@SYS9TEK}c%)2<$h1|T;##zRtjRt@#1T%J=kAhOiw+Z% z7DpyWVK@6%9K^uVD9LDKj)dR^aZK6$@Lt)l;sj@`QSzBm{TlLG{JKM_^60Zr2w~nr zr>P-BaV8OjjWm?hQ3$ZCx+lyD%q`~4iNF9xWKi$t&pzBhwN9Dq-o^v9@=abLR#|

KZqkLal4YCRR9VNhIM|rBqmzzcImvcx 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 literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/setuptools/command/__init__.py b/venv/lib/python3.8/site-packages/setuptools/command/__init__.py new file mode 100644 index 0000000..743f558 --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/command/__init__.py @@ -0,0 +1,17 @@ +__all__ = [ + 'alias', 'bdist_egg', 'bdist_rpm', 'build_ext', 'build_py', 'develop', + 'easy_install', 'egg_info', 'install', 'install_lib', 'rotate', 'saveopts', + 'sdist', 'setopt', 'test', 'install_egg_info', 'install_scripts', + 'bdist_wininst', 'upload_docs', 'build_clib', 'dist_info', +] + +from distutils.command.bdist import bdist +import sys + +from setuptools.command import install_scripts + +if 'egg' not in bdist.format_commands: + bdist.format_command['egg'] = ('bdist_egg', "Python .egg file") + bdist.format_commands.append('egg') + +del bdist, sys diff --git a/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..42affd9ea5691aa52c9c8b431a5214d1446eb442 GIT binary patch literal 712 zcmZuuO>@&Q5S8ROcD|a>5<=k83x^z%+@OaJ@Cz7b7%u8Tqh^)Xt!$~5oDhBu9QjMS za^f#A99ZXrzzp(u{r1W4?XL8(*J~48uU@{87mSeab@KNbV)7PWx55AfC@_ei0WmZo zffQQMh7NS02Pe>n0X%|JID^MGLr!1_Pc+RLXSBv69q|aiPjw@Yd5qjxvAgDdQWo$G zQ3B&jQZrvt7=NXdT(PSNMjy!Jd5ERXqzkQU$eb7I=H>uPnBc{2??l` z(#D3al5Qii!g;B6NKuQ)(uCwdb@o8$>^d|{vf$K^$zb;RvQTd%)*8CuFVBj?T7BJg7m1igok=rso3?3} F{RSTs)4Kow literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/alias.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/alias.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..a97d6971e455a75aee69e2d486df4bd963e8245c GIT binary patch literal 2392 zcmZ`*O>^8d7?$LZb#^yRD53c%bPT1T1~%yo9pF%yLQBhq028=)%6J@0yK&-=jihZ8 z&xQkA?)-%I*gHRjv#*@`7jmGyue?b&E!ZPjdM(MXp7(hl`RDohHi7H2Pp`$*93g*W zXZEt8a~q2K0V+;7%}7o|O0mr{mRq4^+E!-gPUz%r=;p1k1vZ;Ik4fm=C*0+&$Aq_p zJF&t!?(sRWw|RS;1fA!wDhX)4bT?Icq|;1&Kh$Yid?RHk!EWX8FtF;5;Hi$1vgoIS zx>K4V(N3&H-D!+bKg~o!akc5i;Aug*14Vrf6{mN}FDu7%Ovhy3m9{2hGNFu6vP}-` zF?m9tf@MJWEqSwfw+(%8l2tc<9F-t{eCI^EY?E$!&s`c82CF!zS_;i z;f5M!slFZr_6dFOgnn>BADqyu0jq5(hO&0dYv@|AR!x&u|my+^x3WW58`KiE_KN1ICM(NLFVrZ$r@&*Oq`##tJxjp0$R@ms0rC?WpPo ze|=Ipo${YEegbm1Qsm`BQBzs1G)@2dr~tGA_#!xf7|Azbljrz>Tsh;%8gw);U`(DG zYL7|8I7C0PI5L241-5ixOnoseQk}w*m53S|s@jG?HXnFKYg>t|Zz9@Mi!e*R1=STO z%7u#1Hg##W(!}od_5R<>4`K34FUMq$$#reP)1FX{yj|B0XA}Axgc7{Aww~iAt9### zl=jt7Bx(Q17l(18vm=A%8Jn-40p%BQE&?B@SNJ2t>t3$`HE9Kd}9P9y55la)*;+ z>)=nE0YdTXtMkoli@RfX2?PYyZ<`eF;|jdBN{$)#p0u>5=ZwYSzh0R zrj`XL)u`Y`udYdnggBu-q-mFf;>vUfM7J#Jg@MphLPtDJw25Tx3}ssAx(i~L$2v0J z$;+@r6LNd6ObdxgWE4hXjA{>+7)eyOxIBvFsDRvA!7*=RbrHw3rV0NFL23&|e*^>6 zI#h&qnG5QL_eE+mR5BNCk1j&5OI_BcYpj}U$OALCf^O|a5q>+0>UI?6B_Czj?ncqU zD9)yDT2aKy1k4>SR3cMznuKdppYW7Xpz$g?%?{P@zB^Jvo+bUl4hXS`i&KNiafu9< z=={viOcEFwz`bKpm?j=F9h{Wr$Xr9`L#+Ouw!;? zjhTjXZ9;*58+*>ANYZ(;-DCiEd zawpEJ#a^#z^_m0LuWj6ab)nb8=b6>X$|TNeQqA{zr;+~xi1rS68c>OX7udCp&>I5O zt|~_|5%LiNsTYyE=5Jv`;E#ebniF1rc|vZ8 zLpYm@4V4~l;NhSQO~cih5z}~YfC-e`kk literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/bdist_egg.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/bdist_egg.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..85af1763f5e5c7b09953a6d573fe9fe39fe9b543 GIT binary patch literal 14182 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 literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/bdist_rpm.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/bdist_rpm.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..da76680e033277cf097930c07e788a91a83d310f GIT binary patch literal 1784 zcma)6U2oh(6rCA+y_-!!DFqc;B<3Zw``}Gz3rJNI1%bp90kz^~C1iO$vm2+gwliZl z&DQ(WN-dB4gUw_Al3(GaKY$Mv330~W%?AOAvF5|$JNKSB_gsI!zTPEhpMSOy{?a1k zXZv!#xp>({H@7heBB&x0$_OPBHgG8Ung}MG=R`QtIbhG60Tc8g>AA0AP4*%?o^K2< zyXb~vkYqpwu_p#j<7MCqSG1m!K}&e>(yms9A~t!Tvq?CjgmgLDw~wXPv5-99mt4qE zSg4$z+VP>>4u36pRv1)|rEa5LOB94cvn86GG6!FS)-yxX8aAI14TFA@Q`Q3|X$X{lMlPm0M9pZExz3}ue^*6}iCluoiRkB6~}^W(;U1g1}$ zT|4MsqMI8SN-~EEPADZgJz#UEBz7$b^2PS5&XUxgTdjhT0RC}NQMsv($J*w<6SEQ}sW;UDcwsr*ATIy^9=qfI08BFocMnazdI&C{g! zvt#YS%@uTG6-!u`P1n!9BjSZySz~KwZ)OyRk{pmZJs~q%(m50<*a@4l+&OUPEqlY6 zBb<_6CqF{zCBsZ#kQa2sYQ1(!=PU9IHl;K7UVi*)iVmm&Myf7u%FnW zi$LD=qlamsBe`{-Z#=cap7|S37s8nJ^H5KF|6))iNEuWsf(xcs>lA=%D6CdFpMH92 z>;EWz>TT5LrXM#m_mgw*E=Px0+PYDEk5#O{Rk;eRyGw*e(wez)Gt&U~B9}%lojBJDK2sj7b#xelX!PQG>8eVL5)a2-Qv3d{PypMsv>ft2&|xjpy~#}Bo&3S>$M;_EJC&T(hdTVMnO;)XC1XcVoUxkS2YK= z8jV$Zhq~R4SMT-Q!A;8{etydI7ggUsMOC#ITeWdR=b7hvRZF3>-N4(iIWxAZ-f{j0 DO|I=S literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/bdist_wininst.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/bdist_wininst.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..b024add4b0154e936c2614d8f66de235b53f043c GIT binary patch literal 954 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 F{|8XCn7IG| literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/build_py.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/build_py.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..fec2b09bcfabfbe0a8b4074dadc71401492a5629 GIT binary patch literal 8641 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 MW$pL1&+4oH10&LbC;$Ke literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/develop.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/develop.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..ce7caf161a9dd384795942664926653fc7be47f0 GIT binary patch literal 6501 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 HH(vcOcpSTW literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/dist_info.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/dist_info.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..59ad70156ad683f094716c9672469984afad603f GIT binary patch literal 1361 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 RY3QbHgSQ(f>;{j#{{!Ig?l=Gd literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/install_lib.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/install_lib.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..0c2e60328969c0106b385318ff1a8fff8206b93f GIT binary patch literal 5083 zcmb7IO>^7E8Qujz0;DKec5TZ^os`K`wV7CSn|7LJ#?>@+{E?YN%|wZtvh`pfE=Yj_ z0cZhQ7Kgl4?nu65+Fp7~rK4~CH9hRLC;x@cH16{*NRX19=@c9+b{E*)_v3lL_~qha zmEn5-=d0e|zsK0WXfS_S82k!%dLNBof`_b?KY5E|Y=lPNY?*zlW$}Ez)Gr&1v%cMO zIJ?J$DXb?8nX=Q&lYK8~)0_FLprD6YpV6r; zL-3X<3}HTDElXIUgl9>Vg^g!fIHH25EvjMxPsgu_npk|o4tT37mc%*CEnse0oY!+T z@tU|OEFhB#nH8_?g>$E$NeM-eNpd(UN^00 zalM0K0$opBT zR|e9oKN+tvQQ9fV`_MEC?J*zmV@KF098#;0yc*7ivM0ne3|YbUx>2U^x1Q6{4dXdU zU!JFibfGGre)-84AAk7y?fZ?YB&KpnFL#3Iw45(NIPM@4KHm6ZD*nm->3*tek9?Uz zC2kOPVpYLZJB~U*S1on1GVi;OJSiQV0`eB>AU=F>BzD^m`l%S1Zy$UroH#_-%c;rQYdtwbjwf}ZKm&>XT3Clow! zjx^OD!E(nu1I-v4C+xr&8=09|N32&G83)Dzc@%T_w`zTIeGU}MsP4f~!_aSQGih$Z zX2^7BGq>X?^Po#fMw@uqwl?K0zu3or+ztnV>^zqBG>E#P?@o2>KhAs!goOJp%*5;B zs|k}{eqOQ5E1CT%G5a=}5qtRhm>6TEhL708>ev_=51^{u zp(UgF<5oFJ-DIb$Of-_e;rJO~1WSY(l0q$b7u@>zzRuo>|;1K2*F3?_WxjFvye*h^c&*VWmj3?K ziyQUn@LJxz_OSR;lGEF0a8;GWKZ0f)!DJl5A!&_3ny6BHoBZ4v_e&Vl_NhZ$*`g5l z+IJHBO37%5-O!ThA-<=zE}%rdmSjWTw`Y=>%j*Ce-fuE`52!sY7`W$W8eS=|=1)PC z)~}P~8uhI~R*$1_pFC5sDm zkyJP$b%`9qG#Uwt6qGl#-uj>9OnpHC<#u1Rtn`uJKdX_qAjx0i&Mn_@xMfs%**I-ejG;i` ztW01oDn+ka^cM0S?a-(VcM8qigCCY2Y@TAKb`g_MliU6@#1z7v(>F!mb}VK=sqMAN zaZvDW%+xhpaFKQdnd>4+8`kCq?Ng%|IbuHv{l1UbM=IS=SefkWU0rurDOL_G?9|q6 zJghd6ZLa-9&*c60sNb-az3ru5mPvUDVwKmaX;AYHHSeKOm3;5a>%ttZEid)Ys+Ypk zr?}ILXqa6#%1~|iYb|3ot~Wo=~P zF3IJL{gEG)C?9&tj##>moP&kN*gh&D2-rQ#EoJ4Nee4{SMhFon<|bf+dZ*H_j#1g5 zZ-xu~+Ee7JUG~(XRq`KtkHv9iR5@M})(L;gkNEL9dUwP{NifP`0VXd0EZ9>ss*5t_ zk=4@t>90EGWqfhS4*8*RXdYUJr4HaIoF~q>I&z4jQT4#&?8pMxDjS-22zWV9?OlWg zWInOn$DA3)T~)pF)fevOmv`@e{MGaSym;|qXs@PgtLbXmrcge;s80f<6f_;8p`>f4 zEUz3H3m!{ek4)~+{%`I62iqPixT-6rjP>i`4pr4Hs>!)xs8Sr$TA7uIO{zJO5#<~Gf=;LuCunx_>gEdGNOIqe z1E!&R zkEy4Hd53zsnA$*(T)xiun6-?0#DZX}eAz-_1<{uE=n7m;-MG9|LS)WT&6?;)@Ms=#Q$RK z!q8`)6P4JT_)ziAGcNCB@B8lRefM@d50wAZT3pPqVoRVYXx8yhmuU4F8wAx_t&9~JX z`uj#DcN`QJRV6^NsQ*^cb(1cRT5lA#(wyW>%{kF1dorna%M~%pQ)dptxs^*~og}7f LJgT{u`33X8$GsFN literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/install_scripts.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/install_scripts.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..614473e317cb520fc9c8ba47fc86b8f3cb165cbd GIT binary patch literal 2273 zcmZuy&5k2A5VqaF=_EU|v%f5h2%rT5?2G^jkU(e!t6gzmgoMzdmXOucb~2smzqK90 zL>&&yO5Avc%n=@eNAVF(yZ{FdKvgH1ogL_rYwU8RT(0`Q@>l(SMBsb>y*tT|9YTJ` z#re;L#XT7MYY>76nv;UYl;WJ_tZ*2iq;O+zt?^^O-3j6V{yTYCbmC4C#Zl3XyOca6 z!WG^VB0T9$+!H5u1^bc={Xf7v8B*)y)p&pC*xvn28o(=e|-LPU~vzIeglLgF%=|cg2s+u!g)gA&^CzJ6Ojl+_=G~x9SEaq zx3W^3B+t1{RaP54|L}e_C@WPY`Cz3QtS#Oe)cI5olJa;U$77zAqiQfyNnJ~|w$v$w z<2N79F|JQx=<6U1nb0L`$SEe1HiSEZKn!gE!O*pCrLwW|!OZStWoEJ@&*qX>HReNG zudKMNAz!YR`RHe&x?uU&gFRE!dv#XdotAZy9!YU`b|__j_pu&5p6JnRPfIhcO;zQ3 zFRh9qDaGD}3-8v)DgK74$4V_$tm1nL^t{*Y=YvYY6 zXv5`=Qv&*Maua9E=Nk0W0sXDUX*$d2Psu5}PrkXdh#=bAP4p8m;_+{7F+2MT>u$ph zL~Q?Hn&n~xFB{44WI8p;K`voS0O zZ5(DE0aRTUChC^QfXv#0B#avRNVWrCE6pE8L8qc zkFru!GksoZ9eu3T7CLheBqU~MeF3g(nesGGw6@VmRRymTl@vC_5EC`laVOFIP$ohu z+neDD>%0%U3cH?VGK+ng@w5=u#cag>fyPzb)@9`nbhDKX>ai}4^;>t!I_*#Ku$F== zf!t9yKy1U%AAlfqheb4`mzYm|=E9s&m-Jw`f4go36vN?D7yf)2IX(;NHoZ#cS1u9{ zOF~WBG7}xchgU(eJ%piu00CrUNVbJnu!T>Fah9%d8t5?-@6>_ynrIV%{3!z(kV$75 zH9<>8{{+EKCSCnK5G^nIoq>tb_`yPH(PftFR;x;4Bi)}2&Yscxd3 zkKMZzHW2C+X4A?+>YZ6&wr$ z8}c?R&TYgw1T@Vh%zK9lu4a!Vu1dg^gUbc*eH~JAlU5A*3z~ z-SCyRPYipugXDp?I@fK+43Ze{=g literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/py36compat.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/py36compat.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..9f2c0bf29927c68d7f677e16aa7796a9357fe879 GIT binary patch literal 4610 zcmb_g&2JmW72nxiE|(M~%S!ANNziUwyA~aZ0-7Re+`x_N#6=Gwg2qJw!o_yAGnAHI z?yhErwnb1aP#Ng8r=F=}|Cas-d+n+JKo7mNzc?deqt}8?qi_)OS*Q==2=ZcT;y*>(xxZmU_c_ zug9c_#6@VC%z^0&e4jdI5@6GoheT=b(+s@3>k z%>cizl9&5Q78Ejnp710)3i`Qx5lOxu=R-)6942X^PiZ#jkFr=Nc@~+ONMUl6@gT{} zK_u-+C#eeZEcp6VAEWuG^GT;^R=>!DEZ2eHi4OF!2;!UzP@Kz$qK z5sLZ@)x?@w7Z#(I&02fbID@lcGUm>Xl5 z^AT}D%7Yav{h2cZ70aYpzl^9Wu8TY|+CDrDiYR^-9f=U;iGtn3QIhhoIBl;nv?PS^ z$?O^;2+eVo5#}<#z8NO2xKXd~d=#jBBxA@x+JgYtTtrd_c^~M}B2$nH_>;jS>^PK> zOoUotE~pR(M35$D_XN8<7b?4}gE-RhF-VVrA|cfWOSygg%@D9Y^_G69dg7iRMwWymVe_PydJ_f-J?i}eMK0{uIpqRx7X~!adRz*94_k#xyf;TW7#>!-f&=9KK(6~hy zF2VLhj>O{1|MQg2s3?ToZ7)xI906~O;~uxY(#}=s67Qu~@le*ILuDpvsz7Wn>*QWM zk!=^r%dE&7&|=xZoQQQUPfMSiIg5tEz@VzOY0tIG0%B5`?A>fJ*KV)Gj9*Y1a)Iq_EoM4IvioA`UGesDi;#oopn6QBd z@b5i!DX5*fXSGQU<9E+Iv$L-KL1WsSI1}%}IKs*OlY2&GcDM8wnSGnR}e|V*0m#nTSm%MC| zrFSt{C>LO!;!9`-@HJS^Av%Ku+_UXfTDeAA!FYki4{_uYka8cxwq0TDr?hklIvbc9 zp(qcPg`n1CNP9BMJjsfT$YObfPlLy)zz+0JpsQv z!8R+w=5NTE#Wu)dv$=1Ri@wV)%e9HQKVFh+_eyKcF6*|pNjdbm>9SGzX82f4OO@8$Ol-L zKc|Xz{!b?Uj73F$=(BdSiWxL2x0avP^hs|*N_l-bInM&*zPRrOPO_4^0G6; oXSk{|EXiBeVQu70`6gyc|FbHCJRsrB`=6o={_K{sHEG%Z1uq+{R{#J2 literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/register.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/register.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..3746fe9ed6785e70a61f1d799cc18beb95fef6c7 GIT binary patch literal 811 zcmYjP&5qMB5VoD9$u8Xk%K^kGLP8>fCO42)2v%Axh)Y=&xI{uxh}|~Dj#E3KYE>@m zJ_sCnA5Ok<;uW~SINNqR(v0WFnfbnnKO7w$B9LcKALhR>LceXWFD?Y9pxPRWDCS7u z6l3cXPJ}}cM#4?KF5~c?@KYb7*ND2*yF%1s-psvpQkRl?lk53{*b=L-ALWWs5#!%vJ=Q0YiMv1r0(QC47O*w$R;G%PEC4CkY1 z)71JTN$O=?#!^j^I_d64EB|~ndOJD^Bi96ZRmrw0n6glf*Hx4QengC`86O)*=*dr{ z4j}jUWzvW`smprMR+c%VgT<6FKA7wAe5S{XM6;%?8!5R?Hn@}RuHt%W9Mx9#h3Ehb zBIF)ROy8`8*U452SxnNml4zo;1+H&jnvuxhxd{gnWjLIU*)Gg@L!P_%-hO(RY zLA7-P?2;}M1?GUle{GwR>yCDMe;3Ca(D4?L@i&?7TjNSqPSV>qEMsQhnC@1#H{Whc WSr8_8evSWyeHXe1rjL(F-}w(VAkirR literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/rotate.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/rotate.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..f30b7a2087943b1caa2ff514801d9e6d9a399e98 GIT binary patch literal 2520 zcmZ`*UvC^W5VyU5Zg20>rXjQxg|di-dRiy^;L;zL%J5eo{v+uIW{)_FS z&Fb<(iqu!W!QEr|2z&-UfnRyzD^x;d#&;pPmhQ^q+40yjWlk!LB(oQ`98Cv`Kg<5}KK{f-agZd&Wqp!d=st9R;l z%umCt(P>cfIpH-PJRv*~jT5KSf|76a&(w-cp@ zI!V=+rA~_cGbszXgX1cB3|;Mhk!9VS_i&l>j{_g~ps7!R2-2aPbQq@{hqI2$9qw{( z;B>qJ0mpq_dqTkRfY+f9c*q;j*Lf2hTrj>YbXSY&?QM|?EutdjLPi|?lF2T(R^+Ps zguiy|W^^D#ndF0LC(6Ymp>)(wQlVN-p+q+|ER;@tTTF6{Qx`?beT9@K*m`K4} zpjtn>s5u%cR^G=4H2cAovEvAkvLP)j!-<{YRTh=wYdgB2}BcX?8cKDQK5RW+}-N zopjTr5^-T6q25C0d?1AS@K#r6+OKN95*r+VX>3n{8IgU6>>!X!nsRzVf1x0O_&{bziS}?!?eEu4n0$q-R{YT5@lBcEO~1Nm;V5? zF4}{3wAQYYat&v#wZ&kt)~c@0EqMk9i^kLJS64SSFl$kU_IE|p&7&mOVj$$)<{>CN zXb+&-1PmaIhl|HllMx-$3550=JA@N%lip$yCm0XUOxa?FwLdbnv}03p35Ub26rcm~ zm3MF8x>$;Q%1HI$ETjD-pUZrED=m86RNV#Ubmnt<(|EgxL9p6{6)b6mvVlA+&71LNu%5JE%BD0|_$Aq{|Aq!;Y#)9^*$R99XT?py{C@Yw9p{1X^}5mf65 zR%*tblxFl8cm(Sv*5r7j@@I=>INeZVGTML)l+M2 z5hPUpp)ZY>kfY=fA+ZWUt#=1$v1{m!xowyO;tD8QATA>i z_vsiyoX`>Nv-4nd3@emz@uD%oK-nEM{C(MV17KSaPmE{U?FOn=gYEnFwVP~knf|$bs)yw zFOuBC8cJ&+wW&z~cc&5(Z$0DUroja&@+s15Tpq<>%Xo>xvh1rpyiws|%d`~2_`^I+ z@`IKyFQN(b#MEZx#CWzm7^>w5IQSC89awe~X(UnF3 literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/saveopts.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/saveopts.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..7e274d04d8030952fa528411cc000ca16b468ea5 GIT binary patch literal 889 zcmYjP&2AGh5cbb*vZSdRK{G;_9jmEFSfT;qs^&( z0-m5f@=CsP;uSbC-fkh5W;7m;zxn2~zwYi15Uk^)xA6~x&@Z>yULI^dfawEp9C4hX z97i}O5y9vS;)K&%#Hk=RG@{%)Lu3CpRH8AlJAzBYlCntU-0qZ>k!8WoV=WR_u)U!1 zLz7n!2ozzCBEm5MlE~u#dy68U`vBgvfsQW)fa&#{Gl;^Z%=5V5lS~#Od}yLWQ-*Pv z%1o?}U3sYMs>-C`+XY&fx|$~GJS zm-sXK{&7Pa%JBtJuUDf6-;svi<2!nf;OyWV*?3_7rq}qKK+R#(Ysj6~P>JqI;>R+`<@H%(bOS&Mk!wmTHw) zdKqUwk$MIwf8NhbUd<|5P3oeGlMBHoR|_Gs$x5fIrB1JAt=Oh4Gd=6L&K}=!T3uTT zjh_ILehLoZ9`?w91elPQIKca4J^WV;g{STpFy>e@W(SPrC9g9V4;fq4an_ym8RKOF z=^ZX~qGbC4)pKajvfgt0F6VT1rhDK5VBnE9cRKc>7ytQBJN{Ehff%ifiar8tfjVWB SL$<-m1H*UjPid$7i2eoQFYhS; literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/sdist.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/sdist.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..2d8e5b6a68f0b10a751a3f770dc3fa5535179346 GIT binary patch literal 7859 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 literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/setopt.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/setopt.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..03803a133fff8237df9c8ac0e5ce9c448f4f70c0 GIT binary patch literal 4537 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 F|384rfiwUB literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/upload.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/upload.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..9938b658e72c4ea25ba197870aa2c1462b08d42c GIT binary patch literal 784 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 literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/setuptools/command/alias.py b/venv/lib/python3.8/site-packages/setuptools/command/alias.py new file mode 100644 index 0000000..4532b1c --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/command/alias.py @@ -0,0 +1,80 @@ +from distutils.errors import DistutilsOptionError + +from setuptools.extern.six.moves import map + +from setuptools.command.setopt import edit_config, option_base, config_file + + +def shquote(arg): + """Quote an argument for later parsing by shlex.split()""" + for c in '"', "'", "\\", "#": + if c in arg: + return repr(arg) + if arg.split() != [arg]: + return repr(arg) + return arg + + +class alias(option_base): + """Define a shortcut that invokes one or more commands""" + + description = "define a shortcut to invoke one or more commands" + command_consumes_arguments = True + + user_options = [ + ('remove', 'r', 'remove (unset) the alias'), + ] + option_base.user_options + + boolean_options = option_base.boolean_options + ['remove'] + + def initialize_options(self): + option_base.initialize_options(self) + self.args = None + self.remove = None + + def finalize_options(self): + option_base.finalize_options(self) + if self.remove and len(self.args) != 1: + raise DistutilsOptionError( + "Must specify exactly one argument (the alias name) when " + "using --remove" + ) + + def run(self): + aliases = self.distribution.get_option_dict('aliases') + + if not self.args: + print("Command Aliases") + print("---------------") + for alias in aliases: + print("setup.py alias", format_alias(alias, aliases)) + return + + elif len(self.args) == 1: + alias, = self.args + if self.remove: + command = None + elif alias in aliases: + print("setup.py alias", format_alias(alias, aliases)) + return + else: + print("No alias definition found for %r" % alias) + return + else: + alias = self.args[0] + command = ' '.join(map(shquote, self.args[1:])) + + edit_config(self.filename, {'aliases': {alias: command}}, self.dry_run) + + +def format_alias(name, aliases): + source, command = aliases[name] + if source == config_file('global'): + source = '--global-config ' + elif source == config_file('user'): + source = '--user-config ' + elif source == config_file('local'): + source = '' + else: + source = '--filename=%r' % source + return source + name + ' ' + command diff --git a/venv/lib/python3.8/site-packages/setuptools/command/bdist_egg.py b/venv/lib/python3.8/site-packages/setuptools/command/bdist_egg.py new file mode 100644 index 0000000..98470f1 --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/command/bdist_egg.py @@ -0,0 +1,502 @@ +"""setuptools.command.bdist_egg + +Build .egg distributions""" + +from distutils.errors import DistutilsSetupError +from distutils.dir_util import remove_tree, mkpath +from distutils import log +from types import CodeType +import sys +import os +import re +import textwrap +import marshal + +from setuptools.extern import six + +from pkg_resources import get_build_platform, Distribution, ensure_directory +from pkg_resources import EntryPoint +from setuptools.extension import Library +from setuptools import Command + +try: + # Python 2.7 or >=3.2 + from sysconfig import get_path, get_python_version + + def _get_purelib(): + return get_path("purelib") +except ImportError: + from distutils.sysconfig import get_python_lib, get_python_version + + def _get_purelib(): + return get_python_lib(False) + + +def strip_module(filename): + if '.' in filename: + filename = os.path.splitext(filename)[0] + if filename.endswith('module'): + filename = filename[:-6] + return filename + + +def sorted_walk(dir): + """Do os.walk in a reproducible way, + independent of indeterministic filesystem readdir order + """ + for base, dirs, files in os.walk(dir): + dirs.sort() + files.sort() + yield base, dirs, files + + +def write_stub(resource, pyfile): + _stub_template = textwrap.dedent(""" + def __bootstrap__(): + global __bootstrap__, __loader__, __file__ + import sys, pkg_resources, imp + __file__ = pkg_resources.resource_filename(__name__, %r) + __loader__ = None; del __bootstrap__, __loader__ + imp.load_dynamic(__name__,__file__) + __bootstrap__() + """).lstrip() + with open(pyfile, 'w') as f: + f.write(_stub_template % resource) + + +class bdist_egg(Command): + description = "create an \"egg\" distribution" + + user_options = [ + ('bdist-dir=', 'b', + "temporary directory for creating the distribution"), + ('plat-name=', 'p', "platform name to embed in generated filenames " + "(default: %s)" % get_build_platform()), + ('exclude-source-files', None, + "remove all .py files from the generated egg"), + ('keep-temp', 'k', + "keep the pseudo-installation tree around after " + + "creating the distribution archive"), + ('dist-dir=', 'd', + "directory to put final built distributions in"), + ('skip-build', None, + "skip rebuilding everything (for testing/debugging)"), + ] + + boolean_options = [ + 'keep-temp', 'skip-build', 'exclude-source-files' + ] + + def initialize_options(self): + self.bdist_dir = None + self.plat_name = None + self.keep_temp = 0 + self.dist_dir = None + self.skip_build = 0 + self.egg_output = None + self.exclude_source_files = None + + def finalize_options(self): + ei_cmd = self.ei_cmd = self.get_finalized_command("egg_info") + self.egg_info = ei_cmd.egg_info + + if self.bdist_dir is None: + bdist_base = self.get_finalized_command('bdist').bdist_base + self.bdist_dir = os.path.join(bdist_base, 'egg') + + if self.plat_name is None: + self.plat_name = get_build_platform() + + self.set_undefined_options('bdist', ('dist_dir', 'dist_dir')) + + if self.egg_output is None: + + # Compute filename of the output egg + basename = Distribution( + None, None, ei_cmd.egg_name, ei_cmd.egg_version, + get_python_version(), + self.distribution.has_ext_modules() and self.plat_name + ).egg_name() + + self.egg_output = os.path.join(self.dist_dir, basename + '.egg') + + def do_install_data(self): + # Hack for packages that install data to install's --install-lib + self.get_finalized_command('install').install_lib = self.bdist_dir + + site_packages = os.path.normcase(os.path.realpath(_get_purelib())) + old, self.distribution.data_files = self.distribution.data_files, [] + + for item in old: + if isinstance(item, tuple) and len(item) == 2: + if os.path.isabs(item[0]): + realpath = os.path.realpath(item[0]) + normalized = os.path.normcase(realpath) + if normalized == site_packages or normalized.startswith( + site_packages + os.sep + ): + item = realpath[len(site_packages) + 1:], item[1] + # XXX else: raise ??? + self.distribution.data_files.append(item) + + try: + log.info("installing package data to %s", self.bdist_dir) + self.call_command('install_data', force=0, root=None) + finally: + self.distribution.data_files = old + + def get_outputs(self): + return [self.egg_output] + + def call_command(self, cmdname, **kw): + """Invoke reinitialized command `cmdname` with keyword args""" + for dirname in INSTALL_DIRECTORY_ATTRS: + kw.setdefault(dirname, self.bdist_dir) + kw.setdefault('skip_build', self.skip_build) + kw.setdefault('dry_run', self.dry_run) + cmd = self.reinitialize_command(cmdname, **kw) + self.run_command(cmdname) + return cmd + + def run(self): + # Generate metadata first + self.run_command("egg_info") + # We run install_lib before install_data, because some data hacks + # pull their data path from the install_lib command. + log.info("installing library code to %s", self.bdist_dir) + instcmd = self.get_finalized_command('install') + old_root = instcmd.root + instcmd.root = None + if self.distribution.has_c_libraries() and not self.skip_build: + self.run_command('build_clib') + cmd = self.call_command('install_lib', warn_dir=0) + instcmd.root = old_root + + all_outputs, ext_outputs = self.get_ext_outputs() + self.stubs = [] + to_compile = [] + for (p, ext_name) in enumerate(ext_outputs): + filename, ext = os.path.splitext(ext_name) + pyfile = os.path.join(self.bdist_dir, strip_module(filename) + + '.py') + self.stubs.append(pyfile) + log.info("creating stub loader for %s", ext_name) + if not self.dry_run: + write_stub(os.path.basename(ext_name), pyfile) + to_compile.append(pyfile) + ext_outputs[p] = ext_name.replace(os.sep, '/') + + if to_compile: + cmd.byte_compile(to_compile) + if self.distribution.data_files: + self.do_install_data() + + # Make the EGG-INFO directory + archive_root = self.bdist_dir + egg_info = os.path.join(archive_root, 'EGG-INFO') + self.mkpath(egg_info) + if self.distribution.scripts: + script_dir = os.path.join(egg_info, 'scripts') + log.info("installing scripts to %s", script_dir) + self.call_command('install_scripts', install_dir=script_dir, + no_ep=1) + + self.copy_metadata_to(egg_info) + native_libs = os.path.join(egg_info, "native_libs.txt") + if all_outputs: + log.info("writing %s", native_libs) + if not self.dry_run: + ensure_directory(native_libs) + libs_file = open(native_libs, 'wt') + libs_file.write('\n'.join(all_outputs)) + libs_file.write('\n') + libs_file.close() + elif os.path.isfile(native_libs): + log.info("removing %s", native_libs) + if not self.dry_run: + os.unlink(native_libs) + + write_safety_flag( + os.path.join(archive_root, 'EGG-INFO'), self.zip_safe() + ) + + if os.path.exists(os.path.join(self.egg_info, 'depends.txt')): + log.warn( + "WARNING: 'depends.txt' will not be used by setuptools 0.6!\n" + "Use the install_requires/extras_require setup() args instead." + ) + + if self.exclude_source_files: + self.zap_pyfiles() + + # Make the archive + make_zipfile(self.egg_output, archive_root, verbose=self.verbose, + dry_run=self.dry_run, mode=self.gen_header()) + if not self.keep_temp: + remove_tree(self.bdist_dir, dry_run=self.dry_run) + + # Add to 'Distribution.dist_files' so that the "upload" command works + getattr(self.distribution, 'dist_files', []).append( + ('bdist_egg', get_python_version(), self.egg_output)) + + def zap_pyfiles(self): + log.info("Removing .py files from temporary directory") + for base, dirs, files in walk_egg(self.bdist_dir): + for name in files: + path = os.path.join(base, name) + + if name.endswith('.py'): + log.debug("Deleting %s", path) + os.unlink(path) + + if base.endswith('__pycache__'): + path_old = path + + pattern = r'(?P.+)\.(?P[^.]+)\.pyc' + m = re.match(pattern, name) + path_new = os.path.join( + base, os.pardir, m.group('name') + '.pyc') + log.info( + "Renaming file from [%s] to [%s]" + % (path_old, path_new)) + try: + os.remove(path_new) + except OSError: + pass + os.rename(path_old, path_new) + + def zip_safe(self): + safe = getattr(self.distribution, 'zip_safe', None) + if safe is not None: + return safe + log.warn("zip_safe flag not set; analyzing archive contents...") + return analyze_egg(self.bdist_dir, self.stubs) + + def gen_header(self): + epm = EntryPoint.parse_map(self.distribution.entry_points or '') + ep = epm.get('setuptools.installation', {}).get('eggsecutable') + if ep is None: + return 'w' # not an eggsecutable, do it the usual way. + + if not ep.attrs or ep.extras: + raise DistutilsSetupError( + "eggsecutable entry point (%r) cannot have 'extras' " + "or refer to a module" % (ep,) + ) + + pyver = '{}.{}'.format(*sys.version_info) + pkg = ep.module_name + full = '.'.join(ep.attrs) + base = ep.attrs[0] + basename = os.path.basename(self.egg_output) + + header = ( + "#!/bin/sh\n" + 'if [ `basename $0` = "%(basename)s" ]\n' + 'then exec python%(pyver)s -c "' + "import sys, os; sys.path.insert(0, os.path.abspath('$0')); " + "from %(pkg)s import %(base)s; sys.exit(%(full)s())" + '" "$@"\n' + 'else\n' + ' echo $0 is not the correct name for this egg file.\n' + ' echo Please rename it back to %(basename)s and try again.\n' + ' exec false\n' + 'fi\n' + ) % locals() + + if not self.dry_run: + mkpath(os.path.dirname(self.egg_output), dry_run=self.dry_run) + f = open(self.egg_output, 'w') + f.write(header) + f.close() + return 'a' + + def copy_metadata_to(self, target_dir): + "Copy metadata (egg info) to the target_dir" + # normalize the path (so that a forward-slash in egg_info will + # match using startswith below) + norm_egg_info = os.path.normpath(self.egg_info) + prefix = os.path.join(norm_egg_info, '') + for path in self.ei_cmd.filelist.files: + if path.startswith(prefix): + target = os.path.join(target_dir, path[len(prefix):]) + ensure_directory(target) + self.copy_file(path, target) + + def get_ext_outputs(self): + """Get a list of relative paths to C extensions in the output distro""" + + all_outputs = [] + ext_outputs = [] + + paths = {self.bdist_dir: ''} + for base, dirs, files in sorted_walk(self.bdist_dir): + for filename in files: + if os.path.splitext(filename)[1].lower() in NATIVE_EXTENSIONS: + all_outputs.append(paths[base] + filename) + for filename in dirs: + paths[os.path.join(base, filename)] = (paths[base] + + filename + '/') + + if self.distribution.has_ext_modules(): + build_cmd = self.get_finalized_command('build_ext') + for ext in build_cmd.extensions: + if isinstance(ext, Library): + continue + fullname = build_cmd.get_ext_fullname(ext.name) + filename = build_cmd.get_ext_filename(fullname) + if not os.path.basename(filename).startswith('dl-'): + if os.path.exists(os.path.join(self.bdist_dir, filename)): + ext_outputs.append(filename) + + return all_outputs, ext_outputs + + +NATIVE_EXTENSIONS = dict.fromkeys('.dll .so .dylib .pyd'.split()) + + +def walk_egg(egg_dir): + """Walk an unpacked egg's contents, skipping the metadata directory""" + walker = sorted_walk(egg_dir) + base, dirs, files = next(walker) + if 'EGG-INFO' in dirs: + dirs.remove('EGG-INFO') + yield base, dirs, files + for bdf in walker: + yield bdf + + +def analyze_egg(egg_dir, stubs): + # check for existing flag in EGG-INFO + for flag, fn in safety_flags.items(): + if os.path.exists(os.path.join(egg_dir, 'EGG-INFO', fn)): + return flag + if not can_scan(): + return False + safe = True + for base, dirs, files in walk_egg(egg_dir): + for name in files: + if name.endswith('.py') or name.endswith('.pyw'): + continue + elif name.endswith('.pyc') or name.endswith('.pyo'): + # always scan, even if we already know we're not safe + safe = scan_module(egg_dir, base, name, stubs) and safe + return safe + + +def write_safety_flag(egg_dir, safe): + # Write or remove zip safety flag file(s) + for flag, fn in safety_flags.items(): + fn = os.path.join(egg_dir, fn) + if os.path.exists(fn): + if safe is None or bool(safe) != flag: + os.unlink(fn) + elif safe is not None and bool(safe) == flag: + f = open(fn, 'wt') + f.write('\n') + f.close() + + +safety_flags = { + True: 'zip-safe', + False: 'not-zip-safe', +} + + +def scan_module(egg_dir, base, name, stubs): + """Check whether module possibly uses unsafe-for-zipfile stuff""" + + filename = os.path.join(base, name) + if filename[:-1] in stubs: + return True # Extension module + pkg = base[len(egg_dir) + 1:].replace(os.sep, '.') + module = pkg + (pkg and '.' or '') + os.path.splitext(name)[0] + if six.PY2: + skip = 8 # skip magic & date + elif sys.version_info < (3, 7): + skip = 12 # skip magic & date & file size + else: + skip = 16 # skip magic & reserved? & date & file size + f = open(filename, 'rb') + f.read(skip) + code = marshal.load(f) + f.close() + safe = True + symbols = dict.fromkeys(iter_symbols(code)) + for bad in ['__file__', '__path__']: + if bad in symbols: + log.warn("%s: module references %s", module, bad) + safe = False + if 'inspect' in symbols: + for bad in [ + 'getsource', 'getabsfile', 'getsourcefile', 'getfile' + 'getsourcelines', 'findsource', 'getcomments', 'getframeinfo', + 'getinnerframes', 'getouterframes', 'stack', 'trace' + ]: + if bad in symbols: + log.warn("%s: module MAY be using inspect.%s", module, bad) + safe = False + return safe + + +def iter_symbols(code): + """Yield names and strings used by `code` and its nested code objects""" + for name in code.co_names: + yield name + for const in code.co_consts: + if isinstance(const, six.string_types): + yield const + elif isinstance(const, CodeType): + for name in iter_symbols(const): + yield name + + +def can_scan(): + if not sys.platform.startswith('java') and sys.platform != 'cli': + # CPython, PyPy, etc. + return True + log.warn("Unable to analyze compiled code on this platform.") + log.warn("Please ask the author to include a 'zip_safe'" + " setting (either True or False) in the package's setup.py") + + +# Attribute names of options for commands that might need to be convinced to +# install to the egg build directory + +INSTALL_DIRECTORY_ATTRS = [ + 'install_lib', 'install_dir', 'install_data', 'install_base' +] + + +def make_zipfile(zip_filename, base_dir, verbose=0, dry_run=0, compress=True, + mode='w'): + """Create a zip file from all the files under 'base_dir'. The output + zip file will be named 'base_dir' + ".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 DistutilsExecError. Returns the name of the output zip file. + """ + import zipfile + + mkpath(os.path.dirname(zip_filename), dry_run=dry_run) + log.info("creating '%s' and adding '%s' to it", zip_filename, base_dir) + + def visit(z, dirname, names): + for name in names: + path = os.path.normpath(os.path.join(dirname, name)) + if os.path.isfile(path): + p = path[len(base_dir) + 1:] + if not dry_run: + z.write(path, p) + log.debug("adding '%s'", p) + + compression = zipfile.ZIP_DEFLATED if compress else zipfile.ZIP_STORED + if not dry_run: + z = zipfile.ZipFile(zip_filename, mode, compression=compression) + for dirname, dirs, files in sorted_walk(base_dir): + visit(z, dirname, files) + z.close() + else: + for dirname, dirs, files in sorted_walk(base_dir): + visit(None, dirname, files) + return zip_filename diff --git a/venv/lib/python3.8/site-packages/setuptools/command/bdist_rpm.py b/venv/lib/python3.8/site-packages/setuptools/command/bdist_rpm.py new file mode 100644 index 0000000..7073092 --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/command/bdist_rpm.py @@ -0,0 +1,43 @@ +import distutils.command.bdist_rpm as orig + + +class bdist_rpm(orig.bdist_rpm): + """ + Override the default bdist_rpm behavior to do the following: + + 1. Run egg_info to ensure the name and version are properly calculated. + 2. Always run 'install' using --single-version-externally-managed to + disable eggs in RPM distributions. + 3. Replace dash with underscore in the version numbers for better RPM + compatibility. + """ + + def run(self): + # ensure distro name is up-to-date + self.run_command('egg_info') + + orig.bdist_rpm.run(self) + + def _make_spec_file(self): + version = self.distribution.get_version() + rpmversion = version.replace('-', '_') + spec = orig.bdist_rpm._make_spec_file(self) + line23 = '%define version ' + version + line24 = '%define version ' + rpmversion + spec = [ + line.replace( + "Source0: %{name}-%{version}.tar", + "Source0: %{name}-%{unmangled_version}.tar" + ).replace( + "setup.py install ", + "setup.py install --single-version-externally-managed " + ).replace( + "%setup", + "%setup -n %{name}-%{unmangled_version}" + ).replace(line23, line24) + for line in spec + ] + insert_loc = spec.index(line24) + 1 + unmangled_version = "%define unmangled_version " + version + spec.insert(insert_loc, unmangled_version) + return spec diff --git a/venv/lib/python3.8/site-packages/setuptools/command/bdist_wininst.py b/venv/lib/python3.8/site-packages/setuptools/command/bdist_wininst.py new file mode 100644 index 0000000..073de97 --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/command/bdist_wininst.py @@ -0,0 +1,21 @@ +import distutils.command.bdist_wininst as orig + + +class bdist_wininst(orig.bdist_wininst): + def reinitialize_command(self, command, reinit_subcommands=0): + """ + Supplement reinitialize_command to work around + http://bugs.python.org/issue20819 + """ + cmd = self.distribution.reinitialize_command( + command, reinit_subcommands) + if command in ('install', 'install_lib'): + cmd.install_lib = None + return cmd + + def run(self): + self._is_running = True + try: + orig.bdist_wininst.run(self) + finally: + self._is_running = False diff --git a/venv/lib/python3.8/site-packages/setuptools/command/build_clib.py b/venv/lib/python3.8/site-packages/setuptools/command/build_clib.py new file mode 100644 index 0000000..09caff6 --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/command/build_clib.py @@ -0,0 +1,98 @@ +import distutils.command.build_clib as orig +from distutils.errors import DistutilsSetupError +from distutils import log +from setuptools.dep_util import newer_pairwise_group + + +class build_clib(orig.build_clib): + """ + Override the default build_clib behaviour to do the following: + + 1. Implement a rudimentary timestamp-based dependency system + so 'compile()' doesn't run every time. + 2. Add more keys to the 'build_info' dictionary: + * obj_deps - specify dependencies for each object compiled. + this should be a dictionary mapping a key + with the source filename to a list of + dependencies. Use an empty string for global + dependencies. + * cflags - specify a list of additional flags to pass to + the compiler. + """ + + def build_libraries(self, libraries): + for (lib_name, build_info) in libraries: + sources = build_info.get('sources') + if sources is None or not isinstance(sources, (list, tuple)): + raise DistutilsSetupError( + "in 'libraries' option (library '%s'), " + "'sources' must be present and must be " + "a list of source filenames" % lib_name) + sources = list(sources) + + log.info("building '%s' library", lib_name) + + # Make sure everything is the correct type. + # obj_deps should be a dictionary of keys as sources + # and a list/tuple of files that are its dependencies. + obj_deps = build_info.get('obj_deps', dict()) + if not isinstance(obj_deps, dict): + raise DistutilsSetupError( + "in 'libraries' option (library '%s'), " + "'obj_deps' must be a dictionary of " + "type 'source: list'" % lib_name) + dependencies = [] + + # Get the global dependencies that are specified by the '' key. + # These will go into every source's dependency list. + global_deps = obj_deps.get('', list()) + if not isinstance(global_deps, (list, tuple)): + raise DistutilsSetupError( + "in 'libraries' option (library '%s'), " + "'obj_deps' must be a dictionary of " + "type 'source: list'" % lib_name) + + # Build the list to be used by newer_pairwise_group + # each source will be auto-added to its dependencies. + for source in sources: + src_deps = [source] + src_deps.extend(global_deps) + extra_deps = obj_deps.get(source, list()) + if not isinstance(extra_deps, (list, tuple)): + raise DistutilsSetupError( + "in 'libraries' option (library '%s'), " + "'obj_deps' must be a dictionary of " + "type 'source: list'" % lib_name) + src_deps.extend(extra_deps) + dependencies.append(src_deps) + + expected_objects = self.compiler.object_filenames( + sources, + output_dir=self.build_temp + ) + + if newer_pairwise_group(dependencies, expected_objects) != ([], []): + # First, compile the source code to object files in the library + # directory. (This should probably change to putting object + # files in a temporary build directory.) + macros = build_info.get('macros') + include_dirs = build_info.get('include_dirs') + cflags = build_info.get('cflags') + objects = self.compiler.compile( + sources, + output_dir=self.build_temp, + macros=macros, + include_dirs=include_dirs, + extra_postargs=cflags, + debug=self.debug + ) + + # Now "link" the object files together into a static library. + # (On Unix at least, this isn't really linking -- it just + # builds an archive. Whatever.) + self.compiler.create_static_lib( + expected_objects, + lib_name, + output_dir=self.build_clib, + debug=self.debug + ) diff --git a/venv/lib/python3.8/site-packages/setuptools/command/build_ext.py b/venv/lib/python3.8/site-packages/setuptools/command/build_ext.py new file mode 100644 index 0000000..daa8e4f --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/command/build_ext.py @@ -0,0 +1,327 @@ +import os +import sys +import itertools +from distutils.command.build_ext import build_ext as _du_build_ext +from distutils.file_util import copy_file +from distutils.ccompiler import new_compiler +from distutils.sysconfig import customize_compiler, get_config_var +from distutils.errors import DistutilsError +from distutils import log + +from setuptools.extension import Library +from setuptools.extern import six + +if six.PY2: + import imp + + EXTENSION_SUFFIXES = [s for s, _, tp in imp.get_suffixes() if tp == imp.C_EXTENSION] +else: + from importlib.machinery import EXTENSION_SUFFIXES + +try: + # Attempt to use Cython for building extensions, if available + from Cython.Distutils.build_ext import build_ext as _build_ext + # Additionally, assert that the compiler module will load + # also. Ref #1229. + __import__('Cython.Compiler.Main') +except ImportError: + _build_ext = _du_build_ext + +# make sure _config_vars is initialized +get_config_var("LDSHARED") +from distutils.sysconfig import _config_vars as _CONFIG_VARS + + +def _customize_compiler_for_shlib(compiler): + if sys.platform == "darwin": + # building .dylib requires additional compiler flags on OSX; here we + # temporarily substitute the pyconfig.h variables so that distutils' + # 'customize_compiler' uses them before we build the shared libraries. + tmp = _CONFIG_VARS.copy() + try: + # XXX Help! I don't have any idea whether these are right... + _CONFIG_VARS['LDSHARED'] = ( + "gcc -Wl,-x -dynamiclib -undefined dynamic_lookup") + _CONFIG_VARS['CCSHARED'] = " -dynamiclib" + _CONFIG_VARS['SO'] = ".dylib" + customize_compiler(compiler) + finally: + _CONFIG_VARS.clear() + _CONFIG_VARS.update(tmp) + else: + customize_compiler(compiler) + + +have_rtld = False +use_stubs = False +libtype = 'shared' + +if sys.platform == "darwin": + use_stubs = True +elif os.name != 'nt': + try: + import dl + use_stubs = have_rtld = hasattr(dl, 'RTLD_NOW') + except ImportError: + pass + +if_dl = lambda s: s if have_rtld else '' + + +def get_abi3_suffix(): + """Return the file extension for an abi3-compliant Extension()""" + for suffix in EXTENSION_SUFFIXES: + if '.abi3' in suffix: # Unix + return suffix + elif suffix == '.pyd': # Windows + return suffix + + +class build_ext(_build_ext): + def run(self): + """Build extensions in build directory, then copy if --inplace""" + old_inplace, self.inplace = self.inplace, 0 + _build_ext.run(self) + self.inplace = old_inplace + if old_inplace: + self.copy_extensions_to_source() + + def copy_extensions_to_source(self): + build_py = self.get_finalized_command('build_py') + for ext in self.extensions: + fullname = self.get_ext_fullname(ext.name) + filename = self.get_ext_filename(fullname) + modpath = fullname.split('.') + package = '.'.join(modpath[:-1]) + package_dir = build_py.get_package_dir(package) + dest_filename = os.path.join(package_dir, + os.path.basename(filename)) + src_filename = os.path.join(self.build_lib, filename) + + # Always copy, even if source is older than destination, to ensure + # that the right extensions for the current Python/platform are + # used. + copy_file( + src_filename, dest_filename, verbose=self.verbose, + dry_run=self.dry_run + ) + if ext._needs_stub: + self.write_stub(package_dir or os.curdir, ext, True) + + def get_ext_filename(self, fullname): + filename = _build_ext.get_ext_filename(self, fullname) + if fullname in self.ext_map: + ext = self.ext_map[fullname] + use_abi3 = ( + six.PY3 + and getattr(ext, 'py_limited_api') + and get_abi3_suffix() + ) + if use_abi3: + so_ext = get_config_var('EXT_SUFFIX') + filename = filename[:-len(so_ext)] + filename = filename + get_abi3_suffix() + if isinstance(ext, Library): + fn, ext = os.path.splitext(filename) + return self.shlib_compiler.library_filename(fn, libtype) + elif use_stubs and ext._links_to_dynamic: + d, fn = os.path.split(filename) + return os.path.join(d, 'dl-' + fn) + return filename + + def initialize_options(self): + _build_ext.initialize_options(self) + self.shlib_compiler = None + self.shlibs = [] + self.ext_map = {} + + def finalize_options(self): + _build_ext.finalize_options(self) + self.extensions = self.extensions or [] + self.check_extensions_list(self.extensions) + self.shlibs = [ext for ext in self.extensions + if isinstance(ext, Library)] + if self.shlibs: + self.setup_shlib_compiler() + for ext in self.extensions: + ext._full_name = self.get_ext_fullname(ext.name) + for ext in self.extensions: + fullname = ext._full_name + self.ext_map[fullname] = ext + + # distutils 3.1 will also ask for module names + # XXX what to do with conflicts? + self.ext_map[fullname.split('.')[-1]] = ext + + ltd = self.shlibs and self.links_to_dynamic(ext) or False + ns = ltd and use_stubs and not isinstance(ext, Library) + ext._links_to_dynamic = ltd + ext._needs_stub = ns + filename = ext._file_name = self.get_ext_filename(fullname) + libdir = os.path.dirname(os.path.join(self.build_lib, filename)) + if ltd and libdir not in ext.library_dirs: + ext.library_dirs.append(libdir) + if ltd and use_stubs and os.curdir not in ext.runtime_library_dirs: + ext.runtime_library_dirs.append(os.curdir) + + def setup_shlib_compiler(self): + compiler = self.shlib_compiler = new_compiler( + compiler=self.compiler, dry_run=self.dry_run, force=self.force + ) + _customize_compiler_for_shlib(compiler) + + if self.include_dirs is not None: + compiler.set_include_dirs(self.include_dirs) + if self.define is not None: + # 'define' option is a list of (name,value) tuples + for (name, value) in self.define: + compiler.define_macro(name, value) + if self.undef is not None: + for macro in self.undef: + compiler.undefine_macro(macro) + if self.libraries is not None: + compiler.set_libraries(self.libraries) + if self.library_dirs is not None: + compiler.set_library_dirs(self.library_dirs) + if self.rpath is not None: + compiler.set_runtime_library_dirs(self.rpath) + if self.link_objects is not None: + compiler.set_link_objects(self.link_objects) + + # hack so distutils' build_extension() builds a library instead + compiler.link_shared_object = link_shared_object.__get__(compiler) + + def get_export_symbols(self, ext): + if isinstance(ext, Library): + return ext.export_symbols + return _build_ext.get_export_symbols(self, ext) + + def build_extension(self, ext): + ext._convert_pyx_sources_to_lang() + _compiler = self.compiler + try: + if isinstance(ext, Library): + self.compiler = self.shlib_compiler + _build_ext.build_extension(self, ext) + if ext._needs_stub: + cmd = self.get_finalized_command('build_py').build_lib + self.write_stub(cmd, ext) + finally: + self.compiler = _compiler + + def links_to_dynamic(self, ext): + """Return true if 'ext' links to a dynamic lib in the same package""" + # XXX this should check to ensure the lib is actually being built + # XXX as dynamic, and not just using a locally-found version or a + # XXX static-compiled version + libnames = dict.fromkeys([lib._full_name for lib in self.shlibs]) + pkg = '.'.join(ext._full_name.split('.')[:-1] + ['']) + return any(pkg + libname in libnames for libname in ext.libraries) + + def get_outputs(self): + return _build_ext.get_outputs(self) + self.__get_stubs_outputs() + + def __get_stubs_outputs(self): + # assemble the base name for each extension that needs a stub + ns_ext_bases = ( + os.path.join(self.build_lib, *ext._full_name.split('.')) + for ext in self.extensions + if ext._needs_stub + ) + # pair each base with the extension + pairs = itertools.product(ns_ext_bases, self.__get_output_extensions()) + return list(base + fnext for base, fnext in pairs) + + def __get_output_extensions(self): + yield '.py' + yield '.pyc' + if self.get_finalized_command('build_py').optimize: + yield '.pyo' + + def write_stub(self, output_dir, ext, compile=False): + log.info("writing stub loader for %s to %s", ext._full_name, + output_dir) + stub_file = (os.path.join(output_dir, *ext._full_name.split('.')) + + '.py') + if compile and os.path.exists(stub_file): + raise DistutilsError(stub_file + " already exists! Please delete.") + if not self.dry_run: + f = open(stub_file, 'w') + f.write( + '\n'.join([ + "def __bootstrap__():", + " global __bootstrap__, __file__, __loader__", + " import sys, os, pkg_resources, imp" + if_dl(", dl"), + " __file__ = pkg_resources.resource_filename" + "(__name__,%r)" + % os.path.basename(ext._file_name), + " del __bootstrap__", + " if '__loader__' in globals():", + " del __loader__", + if_dl(" old_flags = sys.getdlopenflags()"), + " old_dir = os.getcwd()", + " try:", + " os.chdir(os.path.dirname(__file__))", + if_dl(" sys.setdlopenflags(dl.RTLD_NOW)"), + " imp.load_dynamic(__name__,__file__)", + " finally:", + if_dl(" sys.setdlopenflags(old_flags)"), + " os.chdir(old_dir)", + "__bootstrap__()", + "" # terminal \n + ]) + ) + f.close() + if compile: + from distutils.util import byte_compile + + byte_compile([stub_file], optimize=0, + force=True, dry_run=self.dry_run) + optimize = self.get_finalized_command('install_lib').optimize + if optimize > 0: + byte_compile([stub_file], optimize=optimize, + force=True, dry_run=self.dry_run) + if os.path.exists(stub_file) and not self.dry_run: + os.unlink(stub_file) + + +if use_stubs or os.name == 'nt': + # Build shared libraries + # + def link_shared_object( + self, objects, output_libname, output_dir=None, libraries=None, + library_dirs=None, runtime_library_dirs=None, export_symbols=None, + debug=0, extra_preargs=None, extra_postargs=None, build_temp=None, + target_lang=None): + self.link( + self.SHARED_LIBRARY, objects, output_libname, + output_dir, libraries, library_dirs, runtime_library_dirs, + export_symbols, debug, extra_preargs, extra_postargs, + build_temp, target_lang + ) +else: + # Build static libraries everywhere else + libtype = 'static' + + def link_shared_object( + self, objects, output_libname, output_dir=None, libraries=None, + library_dirs=None, runtime_library_dirs=None, export_symbols=None, + debug=0, extra_preargs=None, extra_postargs=None, build_temp=None, + target_lang=None): + # XXX we need to either disallow these attrs on Library instances, + # or warn/abort here if set, or something... + # libraries=None, library_dirs=None, runtime_library_dirs=None, + # export_symbols=None, extra_preargs=None, extra_postargs=None, + # build_temp=None + + assert output_dir is None # distutils build_ext doesn't pass this + output_dir, filename = os.path.split(output_libname) + basename, ext = os.path.splitext(filename) + if self.library_filename("x").startswith('lib'): + # strip 'lib' prefix; this is kludgy if some platform uses + # a different prefix + basename = basename[3:] + + self.create_static_lib( + objects, basename, output_dir, debug, target_lang + ) diff --git a/venv/lib/python3.8/site-packages/setuptools/command/build_py.py b/venv/lib/python3.8/site-packages/setuptools/command/build_py.py new file mode 100644 index 0000000..b0314fd --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/command/build_py.py @@ -0,0 +1,270 @@ +from glob import glob +from distutils.util import convert_path +import distutils.command.build_py as orig +import os +import fnmatch +import textwrap +import io +import distutils.errors +import itertools + +from setuptools.extern import six +from setuptools.extern.six.moves import map, filter, filterfalse + +try: + from setuptools.lib2to3_ex import Mixin2to3 +except ImportError: + + class Mixin2to3: + def run_2to3(self, files, doctests=True): + "do nothing" + + +class build_py(orig.build_py, Mixin2to3): + """Enhanced 'build_py' command that includes data files with packages + + The data files are specified via a 'package_data' argument to 'setup()'. + See 'setuptools.dist.Distribution' for more details. + + Also, this version of the 'build_py' command allows you to specify both + 'py_modules' and 'packages' in the same setup operation. + """ + + def finalize_options(self): + orig.build_py.finalize_options(self) + self.package_data = self.distribution.package_data + self.exclude_package_data = (self.distribution.exclude_package_data or + {}) + if 'data_files' in self.__dict__: + del self.__dict__['data_files'] + self.__updated_files = [] + self.__doctests_2to3 = [] + + def run(self): + """Build modules, packages, and copy data files to build directory""" + if not self.py_modules and not self.packages: + return + + if self.py_modules: + self.build_modules() + + if self.packages: + self.build_packages() + self.build_package_data() + + self.run_2to3(self.__updated_files, False) + self.run_2to3(self.__updated_files, True) + self.run_2to3(self.__doctests_2to3, True) + + # Only compile actual .py files, using our base class' idea of what our + # output files are. + self.byte_compile(orig.build_py.get_outputs(self, include_bytecode=0)) + + def __getattr__(self, attr): + "lazily compute data files" + if attr == 'data_files': + self.data_files = self._get_data_files() + return self.data_files + return orig.build_py.__getattr__(self, attr) + + def build_module(self, module, module_file, package): + if six.PY2 and isinstance(package, six.string_types): + # avoid errors on Python 2 when unicode is passed (#190) + package = package.split('.') + outfile, copied = orig.build_py.build_module(self, module, module_file, + package) + if copied: + self.__updated_files.append(outfile) + return outfile, copied + + def _get_data_files(self): + """Generate list of '(package,src_dir,build_dir,filenames)' tuples""" + self.analyze_manifest() + return list(map(self._get_pkg_data_files, self.packages or ())) + + def _get_pkg_data_files(self, package): + # Locate package source directory + src_dir = self.get_package_dir(package) + + # Compute package build directory + build_dir = os.path.join(*([self.build_lib] + package.split('.'))) + + # Strip directory from globbed filenames + filenames = [ + os.path.relpath(file, src_dir) + for file in self.find_data_files(package, src_dir) + ] + return package, src_dir, build_dir, filenames + + def find_data_files(self, package, src_dir): + """Return filenames for package's data files in 'src_dir'""" + patterns = self._get_platform_patterns( + self.package_data, + package, + src_dir, + ) + globs_expanded = map(glob, patterns) + # flatten the expanded globs into an iterable of matches + globs_matches = itertools.chain.from_iterable(globs_expanded) + glob_files = filter(os.path.isfile, globs_matches) + files = itertools.chain( + self.manifest_files.get(package, []), + glob_files, + ) + return self.exclude_data_files(package, src_dir, files) + + def build_package_data(self): + """Copy data files into build directory""" + for package, src_dir, build_dir, filenames in self.data_files: + for filename in filenames: + target = os.path.join(build_dir, filename) + self.mkpath(os.path.dirname(target)) + srcfile = os.path.join(src_dir, filename) + outf, copied = self.copy_file(srcfile, target) + srcfile = os.path.abspath(srcfile) + if (copied and + srcfile in self.distribution.convert_2to3_doctests): + self.__doctests_2to3.append(outf) + + def analyze_manifest(self): + self.manifest_files = mf = {} + if not self.distribution.include_package_data: + return + src_dirs = {} + for package in self.packages or (): + # Locate package source directory + src_dirs[assert_relative(self.get_package_dir(package))] = package + + self.run_command('egg_info') + ei_cmd = self.get_finalized_command('egg_info') + for path in ei_cmd.filelist.files: + d, f = os.path.split(assert_relative(path)) + prev = None + oldf = f + while d and d != prev and d not in src_dirs: + prev = d + d, df = os.path.split(d) + f = os.path.join(df, f) + if d in src_dirs: + if path.endswith('.py') and f == oldf: + continue # it's a module, not data + mf.setdefault(src_dirs[d], []).append(path) + + def get_data_files(self): + pass # Lazily compute data files in _get_data_files() function. + + def check_package(self, package, package_dir): + """Check namespace packages' __init__ for declare_namespace""" + try: + return self.packages_checked[package] + except KeyError: + pass + + init_py = orig.build_py.check_package(self, package, package_dir) + self.packages_checked[package] = init_py + + if not init_py or not self.distribution.namespace_packages: + return init_py + + for pkg in self.distribution.namespace_packages: + if pkg == package or pkg.startswith(package + '.'): + break + else: + return init_py + + with io.open(init_py, 'rb') as f: + contents = f.read() + if b'declare_namespace' not in contents: + raise distutils.errors.DistutilsError( + "Namespace package problem: %s is a namespace package, but " + "its\n__init__.py does not call declare_namespace()! Please " + 'fix it.\n(See the setuptools manual under ' + '"Namespace Packages" for details.)\n"' % (package,) + ) + return init_py + + def initialize_options(self): + self.packages_checked = {} + orig.build_py.initialize_options(self) + + def get_package_dir(self, package): + res = orig.build_py.get_package_dir(self, package) + if self.distribution.src_root is not None: + return os.path.join(self.distribution.src_root, res) + return res + + def exclude_data_files(self, package, src_dir, files): + """Filter filenames for package's data files in 'src_dir'""" + files = list(files) + patterns = self._get_platform_patterns( + self.exclude_package_data, + package, + src_dir, + ) + match_groups = ( + fnmatch.filter(files, pattern) + for pattern in patterns + ) + # flatten the groups of matches into an iterable of matches + matches = itertools.chain.from_iterable(match_groups) + bad = set(matches) + keepers = ( + fn + for fn in files + if fn not in bad + ) + # ditch dupes + return list(_unique_everseen(keepers)) + + @staticmethod + def _get_platform_patterns(spec, package, src_dir): + """ + yield platform-specific path patterns (suitable for glob + or fn_match) from a glob-based spec (such as + self.package_data or self.exclude_package_data) + matching package in src_dir. + """ + raw_patterns = itertools.chain( + spec.get('', []), + spec.get(package, []), + ) + return ( + # Each pattern has to be converted to a platform-specific path + os.path.join(src_dir, convert_path(pattern)) + for pattern in raw_patterns + ) + + +# from Python docs +def _unique_everseen(iterable, key=None): + "List unique elements, preserving order. Remember all elements ever seen." + # unique_everseen('AAAABBBCCDAABBB') --> A B C D + # unique_everseen('ABBCcAD', str.lower) --> A B C D + seen = set() + seen_add = seen.add + if key is None: + for element in filterfalse(seen.__contains__, iterable): + seen_add(element) + yield element + else: + for element in iterable: + k = key(element) + if k not in seen: + seen_add(k) + yield element + + +def assert_relative(path): + if not os.path.isabs(path): + return path + from distutils.errors import DistutilsSetupError + + msg = textwrap.dedent(""" + Error: setup script specifies an absolute path: + + %s + + setup() arguments must *always* be /-separated paths relative to the + setup.py directory, *never* absolute paths. + """).lstrip() % path + raise DistutilsSetupError(msg) diff --git a/venv/lib/python3.8/site-packages/setuptools/command/develop.py b/venv/lib/python3.8/site-packages/setuptools/command/develop.py new file mode 100644 index 0000000..009e4f9 --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/command/develop.py @@ -0,0 +1,221 @@ +from distutils.util import convert_path +from distutils import log +from distutils.errors import DistutilsError, DistutilsOptionError +import os +import glob +import io + +from setuptools.extern import six + +import pkg_resources +from setuptools.command.easy_install import easy_install +from setuptools import namespaces +import setuptools + +__metaclass__ = type + + +class develop(namespaces.DevelopInstaller, easy_install): + """Set up package for development""" + + description = "install package in 'development mode'" + + user_options = easy_install.user_options + [ + ("uninstall", "u", "Uninstall this source package"), + ("egg-path=", None, "Set the path to be used in the .egg-link file"), + ] + + boolean_options = easy_install.boolean_options + ['uninstall'] + + command_consumes_arguments = False # override base + + def run(self): + if self.uninstall: + self.multi_version = True + self.uninstall_link() + self.uninstall_namespaces() + else: + self.install_for_development() + self.warn_deprecated_options() + + def initialize_options(self): + self.uninstall = None + self.egg_path = None + easy_install.initialize_options(self) + self.setup_path = None + self.always_copy_from = '.' # always copy eggs installed in curdir + + def finalize_options(self): + ei = self.get_finalized_command("egg_info") + if ei.broken_egg_info: + template = "Please rename %r to %r before using 'develop'" + args = ei.egg_info, ei.broken_egg_info + raise DistutilsError(template % args) + self.args = [ei.egg_name] + + easy_install.finalize_options(self) + self.expand_basedirs() + self.expand_dirs() + # pick up setup-dir .egg files only: no .egg-info + self.package_index.scan(glob.glob('*.egg')) + + egg_link_fn = ei.egg_name + '.egg-link' + self.egg_link = os.path.join(self.install_dir, egg_link_fn) + self.egg_base = ei.egg_base + if self.egg_path is None: + self.egg_path = os.path.abspath(ei.egg_base) + + target = pkg_resources.normalize_path(self.egg_base) + egg_path = pkg_resources.normalize_path( + os.path.join(self.install_dir, self.egg_path)) + if egg_path != target: + raise DistutilsOptionError( + "--egg-path must be a relative path from the install" + " directory to " + target + ) + + # Make a distribution for the package's source + self.dist = pkg_resources.Distribution( + target, + pkg_resources.PathMetadata(target, os.path.abspath(ei.egg_info)), + project_name=ei.egg_name + ) + + self.setup_path = self._resolve_setup_path( + self.egg_base, + self.install_dir, + self.egg_path, + ) + + @staticmethod + def _resolve_setup_path(egg_base, install_dir, egg_path): + """ + Generate a path from egg_base back to '.' where the + setup script resides and ensure that path points to the + setup path from $install_dir/$egg_path. + """ + path_to_setup = egg_base.replace(os.sep, '/').rstrip('/') + if path_to_setup != os.curdir: + path_to_setup = '../' * (path_to_setup.count('/') + 1) + resolved = pkg_resources.normalize_path( + os.path.join(install_dir, egg_path, path_to_setup) + ) + if resolved != pkg_resources.normalize_path(os.curdir): + raise DistutilsOptionError( + "Can't get a consistent path to setup script from" + " installation directory", resolved, + pkg_resources.normalize_path(os.curdir)) + return path_to_setup + + def install_for_development(self): + if six.PY3 and getattr(self.distribution, 'use_2to3', False): + # If we run 2to3 we can not do this inplace: + + # Ensure metadata is up-to-date + self.reinitialize_command('build_py', inplace=0) + self.run_command('build_py') + bpy_cmd = self.get_finalized_command("build_py") + build_path = pkg_resources.normalize_path(bpy_cmd.build_lib) + + # Build extensions + self.reinitialize_command('egg_info', egg_base=build_path) + self.run_command('egg_info') + + self.reinitialize_command('build_ext', inplace=0) + self.run_command('build_ext') + + # Fixup egg-link and easy-install.pth + ei_cmd = self.get_finalized_command("egg_info") + self.egg_path = build_path + self.dist.location = build_path + # XXX + self.dist._provider = pkg_resources.PathMetadata( + build_path, ei_cmd.egg_info) + else: + # Without 2to3 inplace works fine: + self.run_command('egg_info') + + # Build extensions in-place + self.reinitialize_command('build_ext', inplace=1) + self.run_command('build_ext') + + self.install_site_py() # ensure that target dir is site-safe + if setuptools.bootstrap_install_from: + self.easy_install(setuptools.bootstrap_install_from) + setuptools.bootstrap_install_from = None + + self.install_namespaces() + + # create an .egg-link in the installation dir, pointing to our egg + log.info("Creating %s (link to %s)", self.egg_link, self.egg_base) + if not self.dry_run: + with open(self.egg_link, "w") as f: + f.write(self.egg_path + "\n" + self.setup_path) + # postprocess the installed distro, fixing up .pth, installing scripts, + # and handling requirements + self.process_distribution(None, self.dist, not self.no_deps) + + def uninstall_link(self): + if os.path.exists(self.egg_link): + log.info("Removing %s (link to %s)", self.egg_link, self.egg_base) + egg_link_file = open(self.egg_link) + contents = [line.rstrip() for line in egg_link_file] + egg_link_file.close() + if contents not in ([self.egg_path], + [self.egg_path, self.setup_path]): + log.warn("Link points to %s: uninstall aborted", contents) + return + if not self.dry_run: + os.unlink(self.egg_link) + if not self.dry_run: + self.update_pth(self.dist) # remove any .pth link to us + if self.distribution.scripts: + # XXX should also check for entry point scripts! + log.warn("Note: you must uninstall or replace scripts manually!") + + def install_egg_scripts(self, dist): + if dist is not self.dist: + # Installing a dependency, so fall back to normal behavior + return easy_install.install_egg_scripts(self, dist) + + # create wrapper scripts in the script dir, pointing to dist.scripts + + # new-style... + self.install_wrapper_scripts(dist) + + # ...and old-style + for script_name in self.distribution.scripts or []: + script_path = os.path.abspath(convert_path(script_name)) + script_name = os.path.basename(script_path) + with io.open(script_path) as strm: + script_text = strm.read() + self.install_script(dist, script_name, script_text, script_path) + + def install_wrapper_scripts(self, dist): + dist = VersionlessRequirement(dist) + return easy_install.install_wrapper_scripts(self, dist) + + +class VersionlessRequirement: + """ + Adapt a pkg_resources.Distribution to simply return the project + name as the 'requirement' so that scripts will work across + multiple versions. + + >>> from pkg_resources import Distribution + >>> dist = Distribution(project_name='foo', version='1.0') + >>> str(dist.as_requirement()) + 'foo==1.0' + >>> adapted_dist = VersionlessRequirement(dist) + >>> str(adapted_dist.as_requirement()) + 'foo' + """ + + def __init__(self, dist): + self.__dist = dist + + def __getattr__(self, name): + return getattr(self.__dist, name) + + def as_requirement(self): + return self.project_name diff --git a/venv/lib/python3.8/site-packages/setuptools/command/dist_info.py b/venv/lib/python3.8/site-packages/setuptools/command/dist_info.py new file mode 100644 index 0000000..c45258f --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/command/dist_info.py @@ -0,0 +1,36 @@ +""" +Create a dist_info directory +As defined in the wheel specification +""" + +import os + +from distutils.core import Command +from distutils import log + + +class dist_info(Command): + + description = 'create a .dist-info directory' + + user_options = [ + ('egg-base=', 'e', "directory containing .egg-info directories" + " (default: top of the source tree)"), + ] + + def initialize_options(self): + self.egg_base = None + + def finalize_options(self): + pass + + def run(self): + egg_info = self.get_finalized_command('egg_info') + egg_info.egg_base = self.egg_base + egg_info.finalize_options() + egg_info.run() + dist_info_dir = egg_info.egg_info[:-len('.egg-info')] + '.dist-info' + log.info("creating '{}'".format(os.path.abspath(dist_info_dir))) + + bdist_wheel = self.get_finalized_command('bdist_wheel') + bdist_wheel.egg2dist(egg_info.egg_info, dist_info_dir) diff --git a/venv/lib/python3.8/site-packages/setuptools/command/easy_install.py b/venv/lib/python3.8/site-packages/setuptools/command/easy_install.py new file mode 100644 index 0000000..1f6839c --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/command/easy_install.py @@ -0,0 +1,2402 @@ +#!/usr/bin/env python +""" +Easy Install +------------ + +A tool for doing automatic download/extract/build of distutils-based Python +packages. For detailed documentation, see the accompanying EasyInstall.txt +file, or visit the `EasyInstall home page`__. + +__ https://setuptools.readthedocs.io/en/latest/easy_install.html + +""" + +from glob import glob +from distutils.util import get_platform +from distutils.util import convert_path, subst_vars +from distutils.errors import ( + DistutilsArgError, DistutilsOptionError, + DistutilsError, DistutilsPlatformError, +) +from distutils.command.install import INSTALL_SCHEMES, SCHEME_KEYS +from distutils import log, dir_util +from distutils.command.build_scripts import first_line_re +from distutils.spawn import find_executable +import sys +import os +import zipimport +import shutil +import tempfile +import zipfile +import re +import stat +import random +import textwrap +import warnings +import site +import struct +import contextlib +import subprocess +import shlex +import io + + +from sysconfig import get_config_vars, get_path + +from setuptools import SetuptoolsDeprecationWarning + +from setuptools.extern import six +from setuptools.extern.six.moves import configparser, map + +from setuptools import Command +from setuptools.sandbox import run_setup +from setuptools.py27compat import rmtree_safe +from setuptools.command import setopt +from setuptools.archive_util import unpack_archive +from setuptools.package_index import ( + PackageIndex, parse_requirement_arg, URL_SCHEME, +) +from setuptools.command import bdist_egg, egg_info +from setuptools.wheel import Wheel +from pkg_resources import ( + yield_lines, normalize_path, resource_string, ensure_directory, + get_distribution, find_distributions, Environment, Requirement, + Distribution, PathMetadata, EggMetadata, WorkingSet, DistributionNotFound, + VersionConflict, DEVELOP_DIST, +) +import pkg_resources.py31compat + +__metaclass__ = type + +# Turn on PEP440Warnings +warnings.filterwarnings("default", category=pkg_resources.PEP440Warning) + +__all__ = [ + 'samefile', 'easy_install', 'PthDistributions', 'extract_wininst_cfg', + 'main', 'get_exe_prefixes', +] + + +def is_64bit(): + return struct.calcsize("P") == 8 + + +def samefile(p1, p2): + """ + Determine if two paths reference the same file. + + Augments os.path.samefile to work on Windows and + suppresses errors if the path doesn't exist. + """ + both_exist = os.path.exists(p1) and os.path.exists(p2) + use_samefile = hasattr(os.path, 'samefile') and both_exist + if use_samefile: + return os.path.samefile(p1, p2) + norm_p1 = os.path.normpath(os.path.normcase(p1)) + norm_p2 = os.path.normpath(os.path.normcase(p2)) + return norm_p1 == norm_p2 + + +if six.PY2: + + def _to_bytes(s): + return s + + def isascii(s): + try: + six.text_type(s, 'ascii') + return True + except UnicodeError: + return False +else: + + def _to_bytes(s): + return s.encode('utf8') + + def isascii(s): + try: + s.encode('ascii') + return True + except UnicodeError: + return False + + +_one_liner = lambda text: textwrap.dedent(text).strip().replace('\n', '; ') + + +class easy_install(Command): + """Manage a download/build/install process""" + description = "Find/get/install Python packages" + command_consumes_arguments = True + + user_options = [ + ('prefix=', None, "installation prefix"), + ("zip-ok", "z", "install package as a zipfile"), + ("multi-version", "m", "make apps have to require() a version"), + ("upgrade", "U", "force upgrade (searches PyPI for latest versions)"), + ("install-dir=", "d", "install package to DIR"), + ("script-dir=", "s", "install scripts to DIR"), + ("exclude-scripts", "x", "Don't install scripts"), + ("always-copy", "a", "Copy all needed packages to install dir"), + ("index-url=", "i", "base URL of Python Package Index"), + ("find-links=", "f", "additional URL(s) to search for packages"), + ("build-directory=", "b", + "download/extract/build in DIR; keep the results"), + ('optimize=', 'O', + "also compile with optimization: -O1 for \"python -O\", " + "-O2 for \"python -OO\", and -O0 to disable [default: -O0]"), + ('record=', None, + "filename in which to record list of installed files"), + ('always-unzip', 'Z', "don't install as a zipfile, no matter what"), + ('site-dirs=', 'S', "list of directories where .pth files work"), + ('editable', 'e', "Install specified packages in editable form"), + ('no-deps', 'N', "don't install dependencies"), + ('allow-hosts=', 'H', "pattern(s) that hostnames must match"), + ('local-snapshots-ok', 'l', + "allow building eggs from local checkouts"), + ('version', None, "print version information and exit"), + ('install-layout=', None, "installation layout to choose (known values: deb)"), + ('force-installation-into-system-dir', '0', "force installation into /usr"), + ('no-find-links', None, + "Don't load find-links defined in packages being installed") + ] + boolean_options = [ + 'zip-ok', 'multi-version', 'exclude-scripts', 'upgrade', 'always-copy', + 'editable', + 'no-deps', 'local-snapshots-ok', 'version', 'force-installation-into-system-dir' + ] + + if site.ENABLE_USER_SITE: + help_msg = "install in user site-package '%s'" % site.USER_SITE + user_options.append(('user', None, help_msg)) + boolean_options.append('user') + + negative_opt = {'always-unzip': 'zip-ok'} + create_index = PackageIndex + + def initialize_options(self): + # the --user option seems to be an opt-in one, + # so the default should be False. + self.user = 0 + self.zip_ok = self.local_snapshots_ok = None + self.install_dir = self.script_dir = self.exclude_scripts = None + self.index_url = None + self.find_links = None + self.build_directory = None + self.args = None + self.optimize = self.record = None + self.upgrade = self.always_copy = self.multi_version = None + self.editable = self.no_deps = self.allow_hosts = None + self.root = self.prefix = self.no_report = None + self.version = None + self.install_purelib = None # for pure module distributions + self.install_platlib = None # non-pure (dists w/ extensions) + self.install_headers = None # for C/C++ headers + self.install_lib = None # set to either purelib or platlib + self.install_scripts = None + self.install_data = None + self.install_base = None + self.install_platbase = None + if site.ENABLE_USER_SITE: + self.install_userbase = site.USER_BASE + self.install_usersite = site.USER_SITE + else: + self.install_userbase = None + self.install_usersite = None + self.no_find_links = None + + # Options not specifiable via command line + self.package_index = None + self.pth_file = self.always_copy_from = None + self.site_dirs = None + self.installed_projects = {} + self.sitepy_installed = False + # enable custom installation, known values: deb + self.install_layout = None + self.force_installation_into_system_dir = None + self.multiarch = None + + # Always read easy_install options, even if we are subclassed, or have + # an independent instance created. This ensures that defaults will + # always come from the standard configuration file(s)' "easy_install" + # section, even if this is a "develop" or "install" command, or some + # other embedding. + self._dry_run = None + self.verbose = self.distribution.verbose + self.distribution._set_command_options( + self, self.distribution.get_option_dict('easy_install') + ) + + def delete_blockers(self, blockers): + extant_blockers = ( + filename for filename in blockers + if os.path.exists(filename) or os.path.islink(filename) + ) + list(map(self._delete_path, extant_blockers)) + + def _delete_path(self, path): + log.info("Deleting %s", path) + if self.dry_run: + return + + is_tree = os.path.isdir(path) and not os.path.islink(path) + remover = rmtree if is_tree else os.unlink + remover(path) + + @staticmethod + def _render_version(): + """ + Render the Setuptools version and installation details, then exit. + """ + ver = '{}.{}'.format(*sys.version_info) + dist = get_distribution('setuptools') + tmpl = 'setuptools {dist.version} from {dist.location} (Python {ver})' + print(tmpl.format(**locals())) + raise SystemExit() + + def finalize_options(self): + self.version and self._render_version() + + py_version = sys.version.split()[0] + prefix, exec_prefix = get_config_vars('prefix', 'exec_prefix') + + self.config_vars = { + 'dist_name': self.distribution.get_name(), + 'dist_version': self.distribution.get_version(), + 'dist_fullname': self.distribution.get_fullname(), + 'py_version': py_version, + 'py_version_short': py_version[0:3], + 'py_version_nodot': py_version[0] + py_version[2], + 'sys_prefix': prefix, + 'prefix': prefix, + 'sys_exec_prefix': exec_prefix, + 'exec_prefix': exec_prefix, + # Only python 3.2+ has abiflags + 'abiflags': getattr(sys, 'abiflags', ''), + } + + if site.ENABLE_USER_SITE: + self.config_vars['userbase'] = self.install_userbase + self.config_vars['usersite'] = self.install_usersite + + self._fix_install_dir_for_user_site() + + self.expand_basedirs() + self.expand_dirs() + + if self.install_layout: + if not self.install_layout.lower() in ['deb']: + raise DistutilsOptionError("unknown value for --install-layout") + self.install_layout = self.install_layout.lower() + + import sysconfig + if sys.version_info[:2] >= (3, 3): + self.multiarch = sysconfig.get_config_var('MULTIARCH') + + self._expand( + 'install_dir', 'script_dir', 'build_directory', + 'site_dirs', + ) + # If a non-default installation directory was specified, default the + # script directory to match it. + if self.script_dir is None: + self.script_dir = self.install_dir + + if self.no_find_links is None: + self.no_find_links = False + + # Let install_dir get set by install_lib command, which in turn + # gets its info from the install command, and takes into account + # --prefix and --home and all that other crud. + self.set_undefined_options( + 'install_lib', ('install_dir', 'install_dir') + ) + # Likewise, set default script_dir from 'install_scripts.install_dir' + self.set_undefined_options( + 'install_scripts', ('install_dir', 'script_dir') + ) + + if self.user and self.install_purelib: + self.install_dir = self.install_purelib + self.script_dir = self.install_scripts + + if self.prefix == '/usr' and not self.force_installation_into_system_dir: + raise DistutilsOptionError("""installation into /usr + +Trying to install into the system managed parts of the file system. Please +consider to install to another location, or use the option +--force-installation-into-system-dir to overwrite this warning. +""") + + # default --record from the install command + self.set_undefined_options('install', ('record', 'record')) + # Should this be moved to the if statement below? It's not used + # elsewhere + normpath = map(normalize_path, sys.path) + self.all_site_dirs = get_site_dirs() + if self.site_dirs is not None: + site_dirs = [ + os.path.expanduser(s.strip()) for s in + self.site_dirs.split(',') + ] + for d in site_dirs: + if not os.path.isdir(d): + log.warn("%s (in --site-dirs) does not exist", d) + elif normalize_path(d) not in normpath: + raise DistutilsOptionError( + d + " (in --site-dirs) is not on sys.path" + ) + else: + self.all_site_dirs.append(normalize_path(d)) + if not self.editable: + self.check_site_dir() + self.index_url = self.index_url or "https://pypi.org/simple/" + self.shadow_path = self.all_site_dirs[:] + for path_item in self.install_dir, normalize_path(self.script_dir): + if path_item not in self.shadow_path: + self.shadow_path.insert(0, path_item) + + if self.allow_hosts is not None: + hosts = [s.strip() for s in self.allow_hosts.split(',')] + else: + hosts = ['*'] + if self.package_index is None: + self.package_index = self.create_index( + self.index_url, search_path=self.shadow_path, hosts=hosts, + ) + self.local_index = Environment(self.shadow_path + sys.path) + + if self.find_links is not None: + if isinstance(self.find_links, six.string_types): + self.find_links = self.find_links.split() + else: + self.find_links = [] + if self.local_snapshots_ok: + self.package_index.scan_egg_links(self.shadow_path + sys.path) + if not self.no_find_links: + self.package_index.add_find_links(self.find_links) + self.set_undefined_options('install_lib', ('optimize', 'optimize')) + if not isinstance(self.optimize, int): + try: + self.optimize = int(self.optimize) + if not (0 <= self.optimize <= 2): + raise ValueError + except ValueError: + raise DistutilsOptionError("--optimize must be 0, 1, or 2") + + if self.editable and not self.build_directory: + raise DistutilsArgError( + "Must specify a build directory (-b) when using --editable" + ) + if not self.args: + raise DistutilsArgError( + "No urls, filenames, or requirements specified (see --help)") + + self.outputs = [] + + def _fix_install_dir_for_user_site(self): + """ + Fix the install_dir if "--user" was used. + """ + if not self.user or not site.ENABLE_USER_SITE: + return + + self.create_home_path() + if self.install_userbase is None: + msg = "User base directory is not specified" + raise DistutilsPlatformError(msg) + self.install_base = self.install_platbase = self.install_userbase + scheme_name = os.name.replace('posix', 'unix') + '_user' + self.select_scheme(scheme_name) + + def _expand_attrs(self, attrs): + for attr in attrs: + val = getattr(self, attr) + if val is not None: + if os.name == 'posix' or os.name == 'nt': + val = os.path.expanduser(val) + val = subst_vars(val, self.config_vars) + setattr(self, attr, val) + + def expand_basedirs(self): + """Calls `os.path.expanduser` on install_base, install_platbase and + root.""" + self._expand_attrs(['install_base', 'install_platbase', 'root']) + + def expand_dirs(self): + """Calls `os.path.expanduser` on install dirs.""" + dirs = [ + 'install_purelib', + 'install_platlib', + 'install_lib', + 'install_headers', + 'install_scripts', + 'install_data', + ] + self._expand_attrs(dirs) + + def run(self, show_deprecation=True): + if show_deprecation: + self.announce( + "WARNING: The easy_install command is deprecated " + "and will be removed in a future version." + , log.WARN, + ) + if self.verbose != self.distribution.verbose: + log.set_verbosity(self.verbose) + try: + for spec in self.args: + self.easy_install(spec, not self.no_deps) + if self.record: + outputs = list(sorted(self.outputs)) + if self.root: # strip any package prefix + root_len = len(self.root) + for counter in range(len(outputs)): + outputs[counter] = outputs[counter][root_len:] + from distutils import file_util + + self.execute( + file_util.write_file, (self.record, outputs), + "writing list of installed files to '%s'" % + self.record + ) + self.warn_deprecated_options() + finally: + log.set_verbosity(self.distribution.verbose) + + def pseudo_tempname(self): + """Return a pseudo-tempname base in the install directory. + This code is intentionally naive; if a malicious party can write to + the target directory you're already in deep doodoo. + """ + try: + pid = os.getpid() + except Exception: + pid = random.randint(0, sys.maxsize) + return os.path.join(self.install_dir, "test-easy-install-%s" % pid) + + def warn_deprecated_options(self): + pass + + def check_site_dir(self): + """Verify that self.install_dir is .pth-capable dir, if needed""" + + instdir = normalize_path(self.install_dir) + pth_file = os.path.join(instdir, 'easy-install.pth') + + # Is it a configured, PYTHONPATH, implicit, or explicit site dir? + is_site_dir = instdir in self.all_site_dirs + + if not is_site_dir and not self.multi_version: + # No? Then directly test whether it does .pth file processing + is_site_dir = self.check_pth_processing() + else: + # make sure we can write to target dir + testfile = self.pseudo_tempname() + '.write-test' + test_exists = os.path.exists(testfile) + try: + if test_exists: + os.unlink(testfile) + open(testfile, 'w').close() + os.unlink(testfile) + except (OSError, IOError): + self.cant_write_to_target() + + if not is_site_dir and not self.multi_version: + # Can't install non-multi to non-site dir + raise DistutilsError(self.no_default_version_msg()) + + if is_site_dir: + if self.pth_file is None: + self.pth_file = PthDistributions(pth_file, self.all_site_dirs) + else: + self.pth_file = None + + if instdir not in map(normalize_path, _pythonpath()): + # only PYTHONPATH dirs need a site.py, so pretend it's there + self.sitepy_installed = True + elif self.multi_version and not os.path.exists(pth_file): + self.sitepy_installed = True # don't need site.py in this case + self.pth_file = None # and don't create a .pth file + self.install_dir = instdir + + __cant_write_msg = textwrap.dedent(""" + can't create or remove files in install directory + + The following error occurred while trying to add or remove files in the + installation directory: + + %s + + The installation directory you specified (via --install-dir, --prefix, or + the distutils default setting) was: + + %s + """).lstrip() + + __not_exists_id = textwrap.dedent(""" + This directory does not currently exist. Please create it and try again, or + choose a different installation directory (using the -d or --install-dir + option). + """).lstrip() + + __access_msg = textwrap.dedent(""" + Perhaps your account does not have write access to this directory? If the + installation directory is a system-owned directory, you may need to sign in + as the administrator or "root" account. If you do not have administrative + access to this machine, you may wish to choose a different installation + directory, preferably one that is listed in your PYTHONPATH environment + variable. + + For information on other options, you may wish to consult the + documentation at: + + https://setuptools.readthedocs.io/en/latest/easy_install.html + + Please make the appropriate changes for your system and try again. + """).lstrip() + + def cant_write_to_target(self): + msg = self.__cant_write_msg % (sys.exc_info()[1], self.install_dir,) + + if not os.path.exists(self.install_dir): + msg += '\n' + self.__not_exists_id + else: + msg += '\n' + self.__access_msg + raise DistutilsError(msg) + + def check_pth_processing(self): + """Empirically verify whether .pth files are supported in inst. dir""" + instdir = self.install_dir + log.info("Checking .pth file support in %s", instdir) + pth_file = self.pseudo_tempname() + ".pth" + ok_file = pth_file + '.ok' + ok_exists = os.path.exists(ok_file) + tmpl = _one_liner(""" + import os + f = open({ok_file!r}, 'w') + f.write('OK') + f.close() + """) + '\n' + try: + if ok_exists: + os.unlink(ok_file) + dirname = os.path.dirname(ok_file) + pkg_resources.py31compat.makedirs(dirname, exist_ok=True) + f = open(pth_file, 'w') + except (OSError, IOError): + self.cant_write_to_target() + else: + try: + f.write(tmpl.format(**locals())) + f.close() + f = None + executable = sys.executable + if os.name == 'nt': + dirname, basename = os.path.split(executable) + alt = os.path.join(dirname, 'pythonw.exe') + use_alt = ( + basename.lower() == 'python.exe' and + os.path.exists(alt) + ) + if use_alt: + # use pythonw.exe to avoid opening a console window + executable = alt + + from distutils.spawn import spawn + + spawn([executable, '-E', '-c', 'pass'], 0) + + if os.path.exists(ok_file): + log.info( + "TEST PASSED: %s appears to support .pth files", + instdir + ) + return True + finally: + if f: + f.close() + if os.path.exists(ok_file): + os.unlink(ok_file) + if os.path.exists(pth_file): + os.unlink(pth_file) + if not self.multi_version: + log.warn("TEST FAILED: %s does NOT support .pth files", instdir) + return False + + def install_egg_scripts(self, dist): + """Write all the scripts for `dist`, unless scripts are excluded""" + if not self.exclude_scripts and dist.metadata_isdir('scripts'): + for script_name in dist.metadata_listdir('scripts'): + if dist.metadata_isdir('scripts/' + script_name): + # The "script" is a directory, likely a Python 3 + # __pycache__ directory, so skip it. + continue + self.install_script( + dist, script_name, + dist.get_metadata('scripts/' + script_name) + ) + self.install_wrapper_scripts(dist) + + def add_output(self, path): + if os.path.isdir(path): + for base, dirs, files in os.walk(path): + for filename in files: + self.outputs.append(os.path.join(base, filename)) + else: + self.outputs.append(path) + + def not_editable(self, spec): + if self.editable: + raise DistutilsArgError( + "Invalid argument %r: you can't use filenames or URLs " + "with --editable (except via the --find-links option)." + % (spec,) + ) + + def check_editable(self, spec): + if not self.editable: + return + + if os.path.exists(os.path.join(self.build_directory, spec.key)): + raise DistutilsArgError( + "%r already exists in %s; can't do a checkout there" % + (spec.key, self.build_directory) + ) + + @contextlib.contextmanager + def _tmpdir(self): + tmpdir = tempfile.mkdtemp(prefix=u"easy_install-") + try: + # cast to str as workaround for #709 and #710 and #712 + yield str(tmpdir) + finally: + os.path.exists(tmpdir) and rmtree(rmtree_safe(tmpdir)) + + def easy_install(self, spec, deps=False): + if not self.editable: + self.install_site_py() + + with self._tmpdir() as tmpdir: + if not isinstance(spec, Requirement): + if URL_SCHEME(spec): + # It's a url, download it to tmpdir and process + self.not_editable(spec) + dl = self.package_index.download(spec, tmpdir) + return self.install_item(None, dl, tmpdir, deps, True) + + elif os.path.exists(spec): + # Existing file or directory, just process it directly + self.not_editable(spec) + return self.install_item(None, spec, tmpdir, deps, True) + else: + spec = parse_requirement_arg(spec) + + self.check_editable(spec) + dist = self.package_index.fetch_distribution( + spec, tmpdir, self.upgrade, self.editable, + not self.always_copy, self.local_index + ) + if dist is None: + msg = "Could not find suitable distribution for %r" % spec + if self.always_copy: + msg += " (--always-copy skips system and development eggs)" + raise DistutilsError(msg) + elif dist.precedence == DEVELOP_DIST: + # .egg-info dists don't need installing, just process deps + self.process_distribution(spec, dist, deps, "Using") + return dist + else: + return self.install_item(spec, dist.location, tmpdir, deps) + + def install_item(self, spec, download, tmpdir, deps, install_needed=False): + + # Installation is also needed if file in tmpdir or is not an egg + install_needed = install_needed or self.always_copy + install_needed = install_needed or os.path.dirname(download) == tmpdir + install_needed = install_needed or not download.endswith('.egg') + install_needed = install_needed or ( + self.always_copy_from is not None and + os.path.dirname(normalize_path(download)) == + normalize_path(self.always_copy_from) + ) + + if spec and not install_needed: + # at this point, we know it's a local .egg, we just don't know if + # it's already installed. + for dist in self.local_index[spec.project_name]: + if dist.location == download: + break + else: + install_needed = True # it's not in the local index + + log.info("Processing %s", os.path.basename(download)) + + if install_needed: + dists = self.install_eggs(spec, download, tmpdir) + for dist in dists: + self.process_distribution(spec, dist, deps) + else: + dists = [self.egg_distribution(download)] + self.process_distribution(spec, dists[0], deps, "Using") + + if spec is not None: + for dist in dists: + if dist in spec: + return dist + + def select_scheme(self, name): + """Sets the install directories by applying the install schemes.""" + # it's the caller's problem if they supply a bad name! + scheme = INSTALL_SCHEMES[name] + for key in SCHEME_KEYS: + attrname = 'install_' + key + if getattr(self, attrname) is None: + setattr(self, attrname, scheme[key]) + + def process_distribution(self, requirement, dist, deps=True, *info): + self.update_pth(dist) + self.package_index.add(dist) + if dist in self.local_index[dist.key]: + self.local_index.remove(dist) + self.local_index.add(dist) + self.install_egg_scripts(dist) + self.installed_projects[dist.key] = dist + log.info(self.installation_report(requirement, dist, *info)) + if (dist.has_metadata('dependency_links.txt') and + not self.no_find_links): + self.package_index.add_find_links( + dist.get_metadata_lines('dependency_links.txt') + ) + if not deps and not self.always_copy: + return + elif requirement is not None and dist.key != requirement.key: + log.warn("Skipping dependencies for %s", dist) + return # XXX this is not the distribution we were looking for + elif requirement is None or dist not in requirement: + # if we wound up with a different version, resolve what we've got + distreq = dist.as_requirement() + requirement = Requirement(str(distreq)) + log.info("Processing dependencies for %s", requirement) + try: + distros = WorkingSet([]).resolve( + [requirement], self.local_index, self.easy_install + ) + except DistributionNotFound as e: + raise DistutilsError(str(e)) + except VersionConflict as e: + raise DistutilsError(e.report()) + if self.always_copy or self.always_copy_from: + # Force all the relevant distros to be copied or activated + for dist in distros: + if dist.key not in self.installed_projects: + self.easy_install(dist.as_requirement()) + log.info("Finished processing dependencies for %s", requirement) + + def should_unzip(self, dist): + if self.zip_ok is not None: + return not self.zip_ok + if dist.has_metadata('not-zip-safe'): + return True + if not dist.has_metadata('zip-safe'): + return True + return False + + def maybe_move(self, spec, dist_filename, setup_base): + dst = os.path.join(self.build_directory, spec.key) + if os.path.exists(dst): + msg = ( + "%r already exists in %s; build directory %s will not be kept" + ) + log.warn(msg, spec.key, self.build_directory, setup_base) + return setup_base + if os.path.isdir(dist_filename): + setup_base = dist_filename + else: + if os.path.dirname(dist_filename) == setup_base: + os.unlink(dist_filename) # get it out of the tmp dir + contents = os.listdir(setup_base) + if len(contents) == 1: + dist_filename = os.path.join(setup_base, contents[0]) + if os.path.isdir(dist_filename): + # if the only thing there is a directory, move it instead + setup_base = dist_filename + ensure_directory(dst) + shutil.move(setup_base, dst) + return dst + + def install_wrapper_scripts(self, dist): + if self.exclude_scripts: + return + for args in ScriptWriter.best().get_args(dist): + self.write_script(*args) + + def install_script(self, dist, script_name, script_text, dev_path=None): + """Generate a legacy script wrapper and install it""" + spec = str(dist.as_requirement()) + is_script = is_python_script(script_text, script_name) + + if is_script: + body = self._load_template(dev_path) % locals() + script_text = ScriptWriter.get_header(script_text) + body + self.write_script(script_name, _to_bytes(script_text), 'b') + + @staticmethod + def _load_template(dev_path): + """ + There are a couple of template scripts in the package. This + function loads one of them and prepares it for use. + """ + # See https://github.com/pypa/setuptools/issues/134 for info + # on script file naming and downstream issues with SVR4 + name = 'script.tmpl' + if dev_path: + name = name.replace('.tmpl', ' (dev).tmpl') + + raw_bytes = resource_string('setuptools', name) + return raw_bytes.decode('utf-8') + + def write_script(self, script_name, contents, mode="t", blockers=()): + """Write an executable file to the scripts directory""" + self.delete_blockers( # clean up old .py/.pyw w/o a script + [os.path.join(self.script_dir, x) for x in blockers] + ) + log.info("Installing %s script to %s", script_name, self.script_dir) + target = os.path.join(self.script_dir, script_name) + self.add_output(target) + + if self.dry_run: + return + + mask = current_umask() + ensure_directory(target) + if os.path.exists(target): + os.unlink(target) + with open(target, "w" + mode) as f: + f.write(contents) + chmod(target, 0o777 - mask) + + def install_eggs(self, spec, dist_filename, tmpdir): + # .egg dirs or files are already built, so just return them + if dist_filename.lower().endswith('.egg'): + return [self.install_egg(dist_filename, tmpdir)] + elif dist_filename.lower().endswith('.exe'): + return [self.install_exe(dist_filename, tmpdir)] + elif dist_filename.lower().endswith('.whl'): + return [self.install_wheel(dist_filename, tmpdir)] + + # Anything else, try to extract and build + setup_base = tmpdir + if os.path.isfile(dist_filename) and not dist_filename.endswith('.py'): + unpack_archive(dist_filename, tmpdir, self.unpack_progress) + elif os.path.isdir(dist_filename): + setup_base = os.path.abspath(dist_filename) + + if (setup_base.startswith(tmpdir) # something we downloaded + and self.build_directory and spec is not None): + setup_base = self.maybe_move(spec, dist_filename, setup_base) + + # Find the setup.py file + setup_script = os.path.join(setup_base, 'setup.py') + + if not os.path.exists(setup_script): + setups = glob(os.path.join(setup_base, '*', 'setup.py')) + if not setups: + raise DistutilsError( + "Couldn't find a setup script in %s" % + os.path.abspath(dist_filename) + ) + if len(setups) > 1: + raise DistutilsError( + "Multiple setup scripts in %s" % + os.path.abspath(dist_filename) + ) + setup_script = setups[0] + + # Now run it, and return the result + if self.editable: + log.info(self.report_editable(spec, setup_script)) + return [] + else: + return self.build_and_install(setup_script, setup_base) + + def egg_distribution(self, egg_path): + if os.path.isdir(egg_path): + metadata = PathMetadata(egg_path, os.path.join(egg_path, + 'EGG-INFO')) + else: + metadata = EggMetadata(zipimport.zipimporter(egg_path)) + return Distribution.from_filename(egg_path, metadata=metadata) + + def install_egg(self, egg_path, tmpdir): + destination = os.path.join( + self.install_dir, + os.path.basename(egg_path), + ) + destination = os.path.abspath(destination) + if not self.dry_run: + ensure_directory(destination) + + dist = self.egg_distribution(egg_path) + if not samefile(egg_path, destination): + if os.path.isdir(destination) and not os.path.islink(destination): + dir_util.remove_tree(destination, dry_run=self.dry_run) + elif os.path.exists(destination): + self.execute( + os.unlink, + (destination,), + "Removing " + destination, + ) + try: + new_dist_is_zipped = False + if os.path.isdir(egg_path): + if egg_path.startswith(tmpdir): + f, m = shutil.move, "Moving" + else: + f, m = shutil.copytree, "Copying" + elif self.should_unzip(dist): + self.mkpath(destination) + f, m = self.unpack_and_compile, "Extracting" + else: + new_dist_is_zipped = True + if egg_path.startswith(tmpdir): + f, m = shutil.move, "Moving" + else: + f, m = shutil.copy2, "Copying" + self.execute( + f, + (egg_path, destination), + (m + " %s to %s") % ( + os.path.basename(egg_path), + os.path.dirname(destination) + ), + ) + update_dist_caches( + destination, + fix_zipimporter_caches=new_dist_is_zipped, + ) + except Exception: + update_dist_caches(destination, fix_zipimporter_caches=False) + raise + + self.add_output(destination) + return self.egg_distribution(destination) + + def install_exe(self, dist_filename, tmpdir): + # See if it's valid, get data + cfg = extract_wininst_cfg(dist_filename) + if cfg is None: + raise DistutilsError( + "%s is not a valid distutils Windows .exe" % dist_filename + ) + # Create a dummy distribution object until we build the real distro + dist = Distribution( + None, + project_name=cfg.get('metadata', 'name'), + version=cfg.get('metadata', 'version'), platform=get_platform(), + ) + + # Convert the .exe to an unpacked egg + egg_path = os.path.join(tmpdir, dist.egg_name() + '.egg') + dist.location = egg_path + egg_tmp = egg_path + '.tmp' + _egg_info = os.path.join(egg_tmp, 'EGG-INFO') + pkg_inf = os.path.join(_egg_info, 'PKG-INFO') + ensure_directory(pkg_inf) # make sure EGG-INFO dir exists + dist._provider = PathMetadata(egg_tmp, _egg_info) # XXX + self.exe_to_egg(dist_filename, egg_tmp) + + # Write EGG-INFO/PKG-INFO + if not os.path.exists(pkg_inf): + f = open(pkg_inf, 'w') + f.write('Metadata-Version: 1.0\n') + for k, v in cfg.items('metadata'): + if k != 'target_version': + f.write('%s: %s\n' % (k.replace('_', '-').title(), v)) + f.close() + script_dir = os.path.join(_egg_info, 'scripts') + # delete entry-point scripts to avoid duping + self.delete_blockers([ + os.path.join(script_dir, args[0]) + for args in ScriptWriter.get_args(dist) + ]) + # Build .egg file from tmpdir + bdist_egg.make_zipfile( + egg_path, egg_tmp, verbose=self.verbose, dry_run=self.dry_run, + ) + # install the .egg + return self.install_egg(egg_path, tmpdir) + + def exe_to_egg(self, dist_filename, egg_tmp): + """Extract a bdist_wininst to the directories an egg would use""" + # Check for .pth file and set up prefix translations + prefixes = get_exe_prefixes(dist_filename) + to_compile = [] + native_libs = [] + top_level = {} + + def process(src, dst): + s = src.lower() + for old, new in prefixes: + if s.startswith(old): + src = new + src[len(old):] + parts = src.split('/') + dst = os.path.join(egg_tmp, *parts) + dl = dst.lower() + if dl.endswith('.pyd') or dl.endswith('.dll'): + parts[-1] = bdist_egg.strip_module(parts[-1]) + top_level[os.path.splitext(parts[0])[0]] = 1 + native_libs.append(src) + elif dl.endswith('.py') and old != 'SCRIPTS/': + top_level[os.path.splitext(parts[0])[0]] = 1 + to_compile.append(dst) + return dst + if not src.endswith('.pth'): + log.warn("WARNING: can't process %s", src) + return None + + # extract, tracking .pyd/.dll->native_libs and .py -> to_compile + unpack_archive(dist_filename, egg_tmp, process) + stubs = [] + for res in native_libs: + if res.lower().endswith('.pyd'): # create stubs for .pyd's + parts = res.split('/') + resource = parts[-1] + parts[-1] = bdist_egg.strip_module(parts[-1]) + '.py' + pyfile = os.path.join(egg_tmp, *parts) + to_compile.append(pyfile) + stubs.append(pyfile) + bdist_egg.write_stub(resource, pyfile) + self.byte_compile(to_compile) # compile .py's + bdist_egg.write_safety_flag( + os.path.join(egg_tmp, 'EGG-INFO'), + bdist_egg.analyze_egg(egg_tmp, stubs)) # write zip-safety flag + + for name in 'top_level', 'native_libs': + if locals()[name]: + txt = os.path.join(egg_tmp, 'EGG-INFO', name + '.txt') + if not os.path.exists(txt): + f = open(txt, 'w') + f.write('\n'.join(locals()[name]) + '\n') + f.close() + + def install_wheel(self, wheel_path, tmpdir): + wheel = Wheel(wheel_path) + assert wheel.is_compatible() + destination = os.path.join(self.install_dir, wheel.egg_name()) + destination = os.path.abspath(destination) + if not self.dry_run: + ensure_directory(destination) + if os.path.isdir(destination) and not os.path.islink(destination): + dir_util.remove_tree(destination, dry_run=self.dry_run) + elif os.path.exists(destination): + self.execute( + os.unlink, + (destination,), + "Removing " + destination, + ) + try: + self.execute( + wheel.install_as_egg, + (destination,), + ("Installing %s to %s") % ( + os.path.basename(wheel_path), + os.path.dirname(destination) + ), + ) + finally: + update_dist_caches(destination, fix_zipimporter_caches=False) + self.add_output(destination) + return self.egg_distribution(destination) + + __mv_warning = textwrap.dedent(""" + Because this distribution was installed --multi-version, before you can + import modules from this package in an application, you will need to + 'import pkg_resources' and then use a 'require()' call similar to one of + these examples, in order to select the desired version: + + pkg_resources.require("%(name)s") # latest installed version + pkg_resources.require("%(name)s==%(version)s") # this exact version + pkg_resources.require("%(name)s>=%(version)s") # this version or higher + """).lstrip() + + __id_warning = textwrap.dedent(""" + Note also that the installation directory must be on sys.path at runtime for + this to work. (e.g. by being the application's script directory, by being on + PYTHONPATH, or by being added to sys.path by your code.) + """) + + def installation_report(self, req, dist, what="Installed"): + """Helpful installation message for display to package users""" + msg = "\n%(what)s %(eggloc)s%(extras)s" + if self.multi_version and not self.no_report: + msg += '\n' + self.__mv_warning + if self.install_dir not in map(normalize_path, sys.path): + msg += '\n' + self.__id_warning + + eggloc = dist.location + name = dist.project_name + version = dist.version + extras = '' # TODO: self.report_extras(req, dist) + return msg % locals() + + __editable_msg = textwrap.dedent(""" + Extracted editable version of %(spec)s to %(dirname)s + + If it uses setuptools in its setup script, you can activate it in + "development" mode by going to that directory and running:: + + %(python)s setup.py develop + + See the setuptools documentation for the "develop" command for more info. + """).lstrip() + + def report_editable(self, spec, setup_script): + dirname = os.path.dirname(setup_script) + python = sys.executable + return '\n' + self.__editable_msg % locals() + + def run_setup(self, setup_script, setup_base, args): + sys.modules.setdefault('distutils.command.bdist_egg', bdist_egg) + sys.modules.setdefault('distutils.command.egg_info', egg_info) + + args = list(args) + if self.verbose > 2: + v = 'v' * (self.verbose - 1) + args.insert(0, '-' + v) + elif self.verbose < 2: + args.insert(0, '-q') + if self.dry_run: + args.insert(0, '-n') + log.info( + "Running %s %s", setup_script[len(setup_base) + 1:], ' '.join(args) + ) + try: + run_setup(setup_script, args) + except SystemExit as v: + raise DistutilsError("Setup script exited with %s" % (v.args[0],)) + + def build_and_install(self, setup_script, setup_base): + args = ['bdist_egg', '--dist-dir'] + + dist_dir = tempfile.mkdtemp( + prefix='egg-dist-tmp-', dir=os.path.dirname(setup_script) + ) + try: + self._set_fetcher_options(os.path.dirname(setup_script)) + args.append(dist_dir) + + self.run_setup(setup_script, setup_base, args) + all_eggs = Environment([dist_dir]) + eggs = [] + for key in all_eggs: + for dist in all_eggs[key]: + eggs.append(self.install_egg(dist.location, setup_base)) + if not eggs and not self.dry_run: + log.warn("No eggs found in %s (setup script problem?)", + dist_dir) + return eggs + finally: + rmtree(dist_dir) + log.set_verbosity(self.verbose) # restore our log verbosity + + def _set_fetcher_options(self, base): + """ + When easy_install is about to run bdist_egg on a source dist, that + source dist might have 'setup_requires' directives, requiring + additional fetching. Ensure the fetcher options given to easy_install + are available to that command as well. + """ + # find the fetch options from easy_install and write them out + # to the setup.cfg file. + ei_opts = self.distribution.get_option_dict('easy_install').copy() + fetch_directives = ( + 'find_links', 'site_dirs', 'index_url', 'optimize', 'allow_hosts', + ) + fetch_options = {} + for key, val in ei_opts.items(): + if key not in fetch_directives: + continue + fetch_options[key.replace('_', '-')] = val[1] + # create a settings dictionary suitable for `edit_config` + settings = dict(easy_install=fetch_options) + cfg_filename = os.path.join(base, 'setup.cfg') + setopt.edit_config(cfg_filename, settings) + + def update_pth(self, dist): + if self.pth_file is None: + return + + for d in self.pth_file[dist.key]: # drop old entries + if self.multi_version or d.location != dist.location: + log.info("Removing %s from easy-install.pth file", d) + self.pth_file.remove(d) + if d.location in self.shadow_path: + self.shadow_path.remove(d.location) + + if not self.multi_version: + if dist.location in self.pth_file.paths: + log.info( + "%s is already the active version in easy-install.pth", + dist, + ) + else: + log.info("Adding %s to easy-install.pth file", dist) + self.pth_file.add(dist) # add new entry + if dist.location not in self.shadow_path: + self.shadow_path.append(dist.location) + + if not self.dry_run: + + self.pth_file.save() + + if dist.key == 'setuptools': + # Ensure that setuptools itself never becomes unavailable! + # XXX should this check for latest version? + filename = os.path.join(self.install_dir, 'setuptools.pth') + if os.path.islink(filename): + os.unlink(filename) + f = open(filename, 'wt') + f.write(self.pth_file.make_relative(dist.location) + '\n') + f.close() + + def unpack_progress(self, src, dst): + # Progress filter for unpacking + log.debug("Unpacking %s to %s", src, dst) + return dst # only unpack-and-compile skips files for dry run + + def unpack_and_compile(self, egg_path, destination): + to_compile = [] + to_chmod = [] + + def pf(src, dst): + if dst.endswith('.py') and not src.startswith('EGG-INFO/'): + to_compile.append(dst) + elif dst.endswith('.dll') or dst.endswith('.so'): + to_chmod.append(dst) + self.unpack_progress(src, dst) + return not self.dry_run and dst or None + + unpack_archive(egg_path, destination, pf) + self.byte_compile(to_compile) + if not self.dry_run: + for f in to_chmod: + mode = ((os.stat(f)[stat.ST_MODE]) | 0o555) & 0o7755 + chmod(f, mode) + + def byte_compile(self, to_compile): + if sys.dont_write_bytecode: + return + + from distutils.util import byte_compile + + try: + # try to make the byte compile messages quieter + log.set_verbosity(self.verbose - 1) + + byte_compile(to_compile, optimize=0, force=1, dry_run=self.dry_run) + if self.optimize: + byte_compile( + to_compile, optimize=self.optimize, force=1, + dry_run=self.dry_run, + ) + finally: + log.set_verbosity(self.verbose) # restore original verbosity + + __no_default_msg = textwrap.dedent(""" + bad install directory or PYTHONPATH + + You are attempting to install a package to a directory that is not + on PYTHONPATH and which Python does not read ".pth" files from. The + installation directory you specified (via --install-dir, --prefix, or + the distutils default setting) was: + + %s + + and your PYTHONPATH environment variable currently contains: + + %r + + Here are some of your options for correcting the problem: + + * You can choose a different installation directory, i.e., one that is + on PYTHONPATH or supports .pth files + + * You can add the installation directory to the PYTHONPATH environment + variable. (It must then also be on PYTHONPATH whenever you run + Python and want to use the package(s) you are installing.) + + * You can set up the installation directory to support ".pth" files by + using one of the approaches described here: + + https://setuptools.readthedocs.io/en/latest/easy_install.html#custom-installation-locations + + + Please make the appropriate changes for your system and try again.""").lstrip() + + def no_default_version_msg(self): + template = self.__no_default_msg + return template % (self.install_dir, os.environ.get('PYTHONPATH', '')) + + def install_site_py(self): + """Make sure there's a site.py in the target dir, if needed""" + + if self.sitepy_installed: + return # already did it, or don't need to + + sitepy = os.path.join(self.install_dir, "site.py") + source = resource_string("setuptools", "site-patch.py") + source = source.decode('utf-8') + current = "" + + if os.path.exists(sitepy): + log.debug("Checking existing site.py in %s", self.install_dir) + with io.open(sitepy) as strm: + current = strm.read() + + if not current.startswith('def __boot():'): + raise DistutilsError( + "%s is not a setuptools-generated site.py; please" + " remove it." % sitepy + ) + + if current != source: + log.info("Creating %s", sitepy) + if not self.dry_run: + ensure_directory(sitepy) + with io.open(sitepy, 'w', encoding='utf-8') as strm: + strm.write(source) + self.byte_compile([sitepy]) + + self.sitepy_installed = True + + def create_home_path(self): + """Create directories under ~.""" + if not self.user: + return + home = convert_path(os.path.expanduser("~")) + for name, path in six.iteritems(self.config_vars): + if path.startswith(home) and not os.path.isdir(path): + self.debug_print("os.makedirs('%s', 0o700)" % path) + os.makedirs(path, 0o700) + + if sys.version[:3] in ('2.3', '2.4', '2.5') or 'real_prefix' in sys.__dict__: + sitedir_name = 'site-packages' + else: + sitedir_name = 'dist-packages' + + INSTALL_SCHEMES = dict( + posix=dict( + install_dir='$base/lib/python$py_version_short/site-packages', + script_dir='$base/bin', + ), + unix_local = dict( + install_dir = '$base/local/lib/python$py_version_short/%s' % sitedir_name, + script_dir = '$base/local/bin', + ), + posix_local = dict( + install_dir = '$base/local/lib/python$py_version_short/%s' % sitedir_name, + script_dir = '$base/local/bin', + ), + deb_system = dict( + install_dir = '$base/lib/python3/%s' % sitedir_name, + script_dir = '$base/bin', + ), + ) + + DEFAULT_SCHEME = dict( + install_dir='$base/Lib/site-packages', + script_dir='$base/Scripts', + ) + + def _expand(self, *attrs): + config_vars = self.get_finalized_command('install').config_vars + + if self.prefix or self.install_layout: + if self.install_layout and self.install_layout in ['deb']: + scheme_name = "deb_system" + self.prefix = '/usr' + elif self.prefix or 'real_prefix' in sys.__dict__: + scheme_name = os.name + else: + scheme_name = "posix_local" + # Set default install_dir/scripts from --prefix + config_vars = config_vars.copy() + config_vars['base'] = self.prefix + scheme = self.INSTALL_SCHEMES.get(scheme_name,self.DEFAULT_SCHEME) + for attr, val in scheme.items(): + if getattr(self, attr, None) is None: + setattr(self, attr, val) + + from distutils.util import subst_vars + + for attr in attrs: + val = getattr(self, attr) + if val is not None: + val = subst_vars(val, config_vars) + if os.name == 'posix': + val = os.path.expanduser(val) + setattr(self, attr, val) + + +def _pythonpath(): + items = os.environ.get('PYTHONPATH', '').split(os.pathsep) + return filter(None, items) + + +def get_site_dirs(): + """ + Return a list of 'site' dirs + """ + + sitedirs = [] + + # start with PYTHONPATH + sitedirs.extend(_pythonpath()) + + prefixes = [sys.prefix] + if sys.exec_prefix != sys.prefix: + prefixes.append(sys.exec_prefix) + for prefix in prefixes: + if prefix: + if sys.platform in ('os2emx', 'riscos'): + sitedirs.append(os.path.join(prefix, "Lib", "site-packages")) + elif os.sep == '/': + sitedirs.extend([ + os.path.join( + prefix, + "local/lib", + "python" + sys.version[:3], + "dist-packages", + ), + os.path.join( + prefix, + "lib", + "python{}.{}".format(*sys.version_info), + "dist-packages", + ), + os.path.join(prefix, "lib", "site-python"), + ]) + else: + sitedirs.extend([ + prefix, + os.path.join(prefix, "lib", "site-packages"), + ]) + if sys.platform == 'darwin': + # for framework builds *only* we add the standard Apple + # locations. Currently only per-user, but /Library and + # /Network/Library could be added too + if 'Python.framework' in prefix: + home = os.environ.get('HOME') + if home: + home_sp = os.path.join( + home, + 'Library', + 'Python', + '{}.{}'.format(*sys.version_info), + 'site-packages', + ) + sitedirs.append(home_sp) + lib_paths = get_path('purelib'), get_path('platlib') + for site_lib in lib_paths: + if site_lib not in sitedirs: + sitedirs.append(site_lib) + + if site.ENABLE_USER_SITE: + sitedirs.append(site.USER_SITE) + + try: + sitedirs.extend(site.getsitepackages()) + except AttributeError: + pass + + sitedirs = list(map(normalize_path, sitedirs)) + + return sitedirs + + +def expand_paths(inputs): + """Yield sys.path directories that might contain "old-style" packages""" + + seen = {} + + for dirname in inputs: + dirname = normalize_path(dirname) + if dirname in seen: + continue + + seen[dirname] = 1 + if not os.path.isdir(dirname): + continue + + files = os.listdir(dirname) + yield dirname, files + + for name in files: + if not name.endswith('.pth'): + # We only care about the .pth files + continue + if name in ('easy-install.pth', 'setuptools.pth'): + # Ignore .pth files that we control + continue + + # Read the .pth file + f = open(os.path.join(dirname, name)) + lines = list(yield_lines(f)) + f.close() + + # Yield existing non-dupe, non-import directory lines from it + for line in lines: + if not line.startswith("import"): + line = normalize_path(line.rstrip()) + if line not in seen: + seen[line] = 1 + if not os.path.isdir(line): + continue + yield line, os.listdir(line) + + +def extract_wininst_cfg(dist_filename): + """Extract configuration data from a bdist_wininst .exe + + Returns a configparser.RawConfigParser, or None + """ + f = open(dist_filename, 'rb') + try: + endrec = zipfile._EndRecData(f) + if endrec is None: + return None + + prepended = (endrec[9] - endrec[5]) - endrec[6] + if prepended < 12: # no wininst data here + return None + f.seek(prepended - 12) + + tag, cfglen, bmlen = struct.unpack("egg path translations for a given .exe file""" + + prefixes = [ + ('PURELIB/', ''), + ('PLATLIB/pywin32_system32', ''), + ('PLATLIB/', ''), + ('SCRIPTS/', 'EGG-INFO/scripts/'), + ('DATA/lib/site-packages', ''), + ] + z = zipfile.ZipFile(exe_filename) + try: + for info in z.infolist(): + name = info.filename + parts = name.split('/') + if len(parts) == 3 and parts[2] == 'PKG-INFO': + if parts[1].endswith('.egg-info'): + prefixes.insert(0, ('/'.join(parts[:2]), 'EGG-INFO/')) + break + if len(parts) != 2 or not name.endswith('.pth'): + continue + if name.endswith('-nspkg.pth'): + continue + if parts[0].upper() in ('PURELIB', 'PLATLIB'): + contents = z.read(name) + if six.PY3: + contents = contents.decode() + for pth in yield_lines(contents): + pth = pth.strip().replace('\\', '/') + if not pth.startswith('import'): + prefixes.append((('%s/%s/' % (parts[0], pth)), '')) + finally: + z.close() + prefixes = [(x.lower(), y) for x, y in prefixes] + prefixes.sort() + prefixes.reverse() + return prefixes + + +class PthDistributions(Environment): + """A .pth file with Distribution paths in it""" + + dirty = False + + def __init__(self, filename, sitedirs=()): + self.filename = filename + self.sitedirs = list(map(normalize_path, sitedirs)) + self.basedir = normalize_path(os.path.dirname(self.filename)) + self._load() + Environment.__init__(self, [], None, None) + for path in yield_lines(self.paths): + list(map(self.add, find_distributions(path, True))) + + def _load(self): + self.paths = [] + saw_import = False + seen = dict.fromkeys(self.sitedirs) + if os.path.isfile(self.filename): + f = open(self.filename, 'rt') + for line in f: + if line.startswith('import'): + saw_import = True + continue + path = line.rstrip() + self.paths.append(path) + if not path.strip() or path.strip().startswith('#'): + continue + # skip non-existent paths, in case somebody deleted a package + # manually, and duplicate paths as well + path = self.paths[-1] = normalize_path( + os.path.join(self.basedir, path) + ) + if not os.path.exists(path) or path in seen: + self.paths.pop() # skip it + self.dirty = True # we cleaned up, so we're dirty now :) + continue + seen[path] = 1 + f.close() + + if self.paths and not saw_import: + self.dirty = True # ensure anything we touch has import wrappers + while self.paths and not self.paths[-1].strip(): + self.paths.pop() + + def save(self): + """Write changed .pth file back to disk""" + if not self.dirty: + return + + rel_paths = list(map(self.make_relative, self.paths)) + if rel_paths: + log.debug("Saving %s", self.filename) + lines = self._wrap_lines(rel_paths) + data = '\n'.join(lines) + '\n' + + if os.path.islink(self.filename): + os.unlink(self.filename) + with open(self.filename, 'wt') as f: + f.write(data) + + elif os.path.exists(self.filename): + log.debug("Deleting empty %s", self.filename) + os.unlink(self.filename) + + self.dirty = False + + @staticmethod + def _wrap_lines(lines): + return lines + + def add(self, dist): + """Add `dist` to the distribution map""" + new_path = ( + dist.location not in self.paths and ( + dist.location not in self.sitedirs or + # account for '.' being in PYTHONPATH + dist.location == os.getcwd() + ) + ) + if new_path: + self.paths.append(dist.location) + self.dirty = True + Environment.add(self, dist) + + def remove(self, dist): + """Remove `dist` from the distribution map""" + while dist.location in self.paths: + self.paths.remove(dist.location) + self.dirty = True + Environment.remove(self, dist) + + def make_relative(self, path): + npath, last = os.path.split(normalize_path(path)) + baselen = len(self.basedir) + parts = [last] + sep = os.altsep == '/' and '/' or os.sep + while len(npath) >= baselen: + if npath == self.basedir: + parts.append(os.curdir) + parts.reverse() + return sep.join(parts) + npath, last = os.path.split(npath) + parts.append(last) + else: + return path + + +class RewritePthDistributions(PthDistributions): + @classmethod + def _wrap_lines(cls, lines): + yield cls.prelude + for line in lines: + yield line + yield cls.postlude + + prelude = _one_liner(""" + import sys + sys.__plen = len(sys.path) + """) + postlude = _one_liner(""" + import sys + new = sys.path[sys.__plen:] + del sys.path[sys.__plen:] + p = getattr(sys, '__egginsert', 0) + sys.path[p:p] = new + sys.__egginsert = p + len(new) + """) + + +if os.environ.get('SETUPTOOLS_SYS_PATH_TECHNIQUE', 'raw') == 'rewrite': + PthDistributions = RewritePthDistributions + + +def _first_line_re(): + """ + Return a regular expression based on first_line_re suitable for matching + strings. + """ + if isinstance(first_line_re.pattern, str): + return first_line_re + + # first_line_re in Python >=3.1.4 and >=3.2.1 is a bytes pattern. + return re.compile(first_line_re.pattern.decode()) + + +def auto_chmod(func, arg, exc): + if func in [os.unlink, os.remove] and os.name == 'nt': + chmod(arg, stat.S_IWRITE) + return func(arg) + et, ev, _ = sys.exc_info() + six.reraise(et, (ev[0], ev[1] + (" %s %s" % (func, arg)))) + + +def update_dist_caches(dist_path, fix_zipimporter_caches): + """ + Fix any globally cached `dist_path` related data + + `dist_path` should be a path of a newly installed egg distribution (zipped + or unzipped). + + sys.path_importer_cache contains finder objects that have been cached when + importing data from the original distribution. Any such finders need to be + cleared since the replacement distribution might be packaged differently, + e.g. a zipped egg distribution might get replaced with an unzipped egg + folder or vice versa. Having the old finders cached may then cause Python + to attempt loading modules from the replacement distribution using an + incorrect loader. + + zipimport.zipimporter objects are Python loaders charged with importing + data packaged inside zip archives. If stale loaders referencing the + original distribution, are left behind, they can fail to load modules from + the replacement distribution. E.g. if an old zipimport.zipimporter instance + is used to load data from a new zipped egg archive, it may cause the + operation to attempt to locate the requested data in the wrong location - + one indicated by the original distribution's zip archive directory + information. Such an operation may then fail outright, e.g. report having + read a 'bad local file header', or even worse, it may fail silently & + return invalid data. + + zipimport._zip_directory_cache contains cached zip archive directory + information for all existing zipimport.zipimporter instances and all such + instances connected to the same archive share the same cached directory + information. + + If asked, and the underlying Python implementation allows it, we can fix + all existing zipimport.zipimporter instances instead of having to track + them down and remove them one by one, by updating their shared cached zip + archive directory information. This, of course, assumes that the + replacement distribution is packaged as a zipped egg. + + If not asked to fix existing zipimport.zipimporter instances, we still do + our best to clear any remaining zipimport.zipimporter related cached data + that might somehow later get used when attempting to load data from the new + distribution and thus cause such load operations to fail. Note that when + tracking down such remaining stale data, we can not catch every conceivable + usage from here, and we clear only those that we know of and have found to + cause problems if left alive. Any remaining caches should be updated by + whomever is in charge of maintaining them, i.e. they should be ready to + handle us replacing their zip archives with new distributions at runtime. + + """ + # There are several other known sources of stale zipimport.zipimporter + # instances that we do not clear here, but might if ever given a reason to + # do so: + # * Global setuptools pkg_resources.working_set (a.k.a. 'master working + # set') may contain distributions which may in turn contain their + # zipimport.zipimporter loaders. + # * Several zipimport.zipimporter loaders held by local variables further + # up the function call stack when running the setuptools installation. + # * Already loaded modules may have their __loader__ attribute set to the + # exact loader instance used when importing them. Python 3.4 docs state + # that this information is intended mostly for introspection and so is + # not expected to cause us problems. + normalized_path = normalize_path(dist_path) + _uncache(normalized_path, sys.path_importer_cache) + if fix_zipimporter_caches: + _replace_zip_directory_cache_data(normalized_path) + else: + # Here, even though we do not want to fix existing and now stale + # zipimporter cache information, we still want to remove it. Related to + # Python's zip archive directory information cache, we clear each of + # its stale entries in two phases: + # 1. Clear the entry so attempting to access zip archive information + # via any existing stale zipimport.zipimporter instances fails. + # 2. Remove the entry from the cache so any newly constructed + # zipimport.zipimporter instances do not end up using old stale + # zip archive directory information. + # This whole stale data removal step does not seem strictly necessary, + # but has been left in because it was done before we started replacing + # the zip archive directory information cache content if possible, and + # there are no relevant unit tests that we can depend on to tell us if + # this is really needed. + _remove_and_clear_zip_directory_cache_data(normalized_path) + + +def _collect_zipimporter_cache_entries(normalized_path, cache): + """ + Return zipimporter cache entry keys related to a given normalized path. + + Alternative path spellings (e.g. those using different character case or + those using alternative path separators) related to the same path are + included. Any sub-path entries are included as well, i.e. those + corresponding to zip archives embedded in other zip archives. + + """ + result = [] + prefix_len = len(normalized_path) + for p in cache: + np = normalize_path(p) + if (np.startswith(normalized_path) and + np[prefix_len:prefix_len + 1] in (os.sep, '')): + result.append(p) + return result + + +def _update_zipimporter_cache(normalized_path, cache, updater=None): + """ + Update zipimporter cache data for a given normalized path. + + Any sub-path entries are processed as well, i.e. those corresponding to zip + archives embedded in other zip archives. + + Given updater is a callable taking a cache entry key and the original entry + (after already removing the entry from the cache), and expected to update + the entry and possibly return a new one to be inserted in its place. + Returning None indicates that the entry should not be replaced with a new + one. If no updater is given, the cache entries are simply removed without + any additional processing, the same as if the updater simply returned None. + + """ + for p in _collect_zipimporter_cache_entries(normalized_path, cache): + # N.B. pypy's custom zipimport._zip_directory_cache implementation does + # not support the complete dict interface: + # * Does not support item assignment, thus not allowing this function + # to be used only for removing existing cache entries. + # * Does not support the dict.pop() method, forcing us to use the + # get/del patterns instead. For more detailed information see the + # following links: + # https://github.com/pypa/setuptools/issues/202#issuecomment-202913420 + # http://bit.ly/2h9itJX + old_entry = cache[p] + del cache[p] + new_entry = updater and updater(p, old_entry) + if new_entry is not None: + cache[p] = new_entry + + +def _uncache(normalized_path, cache): + _update_zipimporter_cache(normalized_path, cache) + + +def _remove_and_clear_zip_directory_cache_data(normalized_path): + def clear_and_remove_cached_zip_archive_directory_data(path, old_entry): + old_entry.clear() + + _update_zipimporter_cache( + normalized_path, zipimport._zip_directory_cache, + updater=clear_and_remove_cached_zip_archive_directory_data) + + +# PyPy Python implementation does not allow directly writing to the +# zipimport._zip_directory_cache and so prevents us from attempting to correct +# its content. The best we can do there is clear the problematic cache content +# and have PyPy repopulate it as needed. The downside is that if there are any +# stale zipimport.zipimporter instances laying around, attempting to use them +# will fail due to not having its zip archive directory information available +# instead of being automatically corrected to use the new correct zip archive +# directory information. +if '__pypy__' in sys.builtin_module_names: + _replace_zip_directory_cache_data = \ + _remove_and_clear_zip_directory_cache_data +else: + + def _replace_zip_directory_cache_data(normalized_path): + def replace_cached_zip_archive_directory_data(path, old_entry): + # N.B. In theory, we could load the zip directory information just + # once for all updated path spellings, and then copy it locally and + # update its contained path strings to contain the correct + # spelling, but that seems like a way too invasive move (this cache + # structure is not officially documented anywhere and could in + # theory change with new Python releases) for no significant + # benefit. + old_entry.clear() + zipimport.zipimporter(path) + old_entry.update(zipimport._zip_directory_cache[path]) + return old_entry + + _update_zipimporter_cache( + normalized_path, zipimport._zip_directory_cache, + updater=replace_cached_zip_archive_directory_data) + + +def is_python(text, filename=''): + "Is this string a valid Python script?" + try: + compile(text, filename, 'exec') + except (SyntaxError, TypeError): + return False + else: + return True + + +def is_sh(executable): + """Determine if the specified executable is a .sh (contains a #! line)""" + try: + with io.open(executable, encoding='latin-1') as fp: + magic = fp.read(2) + except (OSError, IOError): + return executable + return magic == '#!' + + +def nt_quote_arg(arg): + """Quote a command line argument according to Windows parsing rules""" + return subprocess.list2cmdline([arg]) + + +def is_python_script(script_text, filename): + """Is this text, as a whole, a Python script? (as opposed to shell/bat/etc. + """ + if filename.endswith('.py') or filename.endswith('.pyw'): + return True # extension says it's Python + if is_python(script_text, filename): + return True # it's syntactically valid Python + if script_text.startswith('#!'): + # It begins with a '#!' line, so check if 'python' is in it somewhere + return 'python' in script_text.splitlines()[0].lower() + + return False # Not any Python I can recognize + + +try: + from os import chmod as _chmod +except ImportError: + # Jython compatibility + def _chmod(*args): + pass + + +def chmod(path, mode): + log.debug("changing mode of %s to %o", path, mode) + try: + _chmod(path, mode) + except os.error as e: + log.debug("chmod failed: %s", e) + + +class CommandSpec(list): + """ + A command spec for a #! header, specified as a list of arguments akin to + those passed to Popen. + """ + + options = [] + split_args = dict() + + @classmethod + def best(cls): + """ + Choose the best CommandSpec class based on environmental conditions. + """ + return cls + + @classmethod + def _sys_executable(cls): + _default = os.path.normpath(sys.executable) + return os.environ.get('__PYVENV_LAUNCHER__', _default) + + @classmethod + def from_param(cls, param): + """ + Construct a CommandSpec from a parameter to build_scripts, which may + be None. + """ + if isinstance(param, cls): + return param + if isinstance(param, list): + return cls(param) + if param is None: + return cls.from_environment() + # otherwise, assume it's a string. + return cls.from_string(param) + + @classmethod + def from_environment(cls): + return cls([cls._sys_executable()]) + + @classmethod + def from_string(cls, string): + """ + Construct a command spec from a simple string representing a command + line parseable by shlex.split. + """ + items = shlex.split(string, **cls.split_args) + return cls(items) + + def install_options(self, script_text): + self.options = shlex.split(self._extract_options(script_text)) + cmdline = subprocess.list2cmdline(self) + if not isascii(cmdline): + self.options[:0] = ['-x'] + + @staticmethod + def _extract_options(orig_script): + """ + Extract any options from the first line of the script. + """ + first = (orig_script + '\n').splitlines()[0] + match = _first_line_re().match(first) + options = match.group(1) or '' if match else '' + return options.strip() + + def as_header(self): + return self._render(self + list(self.options)) + + @staticmethod + def _strip_quotes(item): + _QUOTES = '"\'' + for q in _QUOTES: + if item.startswith(q) and item.endswith(q): + return item[1:-1] + return item + + @staticmethod + def _render(items): + cmdline = subprocess.list2cmdline( + CommandSpec._strip_quotes(item.strip()) for item in items) + return '#!' + cmdline + '\n' + + +# For pbr compat; will be removed in a future version. +sys_executable = CommandSpec._sys_executable() + + +class WindowsCommandSpec(CommandSpec): + split_args = dict(posix=False) + + +class ScriptWriter: + """ + Encapsulates behavior around writing entry point scripts for console and + gui apps. + """ + + template = textwrap.dedent(r""" + # EASY-INSTALL-ENTRY-SCRIPT: %(spec)r,%(group)r,%(name)r + __requires__ = %(spec)r + import re + import sys + from pkg_resources import load_entry_point + + if __name__ == '__main__': + sys.argv[0] = re.sub(r'(-script\.pyw?|\.exe)?$', '', sys.argv[0]) + sys.exit( + load_entry_point(%(spec)r, %(group)r, %(name)r)() + ) + """).lstrip() + + command_spec_class = CommandSpec + + @classmethod + def get_script_args(cls, dist, executable=None, wininst=False): + # for backward compatibility + warnings.warn("Use get_args", EasyInstallDeprecationWarning) + writer = (WindowsScriptWriter if wininst else ScriptWriter).best() + header = cls.get_script_header("", executable, wininst) + return writer.get_args(dist, header) + + @classmethod + def get_script_header(cls, script_text, executable=None, wininst=False): + # for backward compatibility + warnings.warn("Use get_header", EasyInstallDeprecationWarning, stacklevel=2) + if wininst: + executable = "python.exe" + return cls.get_header(script_text, executable) + + @classmethod + def get_args(cls, dist, header=None): + """ + Yield write_script() argument tuples for a distribution's + console_scripts and gui_scripts entry points. + """ + if header is None: + header = cls.get_header() + spec = str(dist.as_requirement()) + for type_ in 'console', 'gui': + group = type_ + '_scripts' + for name, ep in dist.get_entry_map(group).items(): + cls._ensure_safe_name(name) + script_text = cls.template % locals() + args = cls._get_script_args(type_, name, header, script_text) + for res in args: + yield res + + @staticmethod + def _ensure_safe_name(name): + """ + Prevent paths in *_scripts entry point names. + """ + has_path_sep = re.search(r'[\\/]', name) + if has_path_sep: + raise ValueError("Path separators not allowed in script names") + + @classmethod + def get_writer(cls, force_windows): + # for backward compatibility + warnings.warn("Use best", EasyInstallDeprecationWarning) + return WindowsScriptWriter.best() if force_windows else cls.best() + + @classmethod + def best(cls): + """ + Select the best ScriptWriter for this environment. + """ + if sys.platform == 'win32' or (os.name == 'java' and os._name == 'nt'): + return WindowsScriptWriter.best() + else: + return cls + + @classmethod + def _get_script_args(cls, type_, name, header, script_text): + # Simply write the stub with no extension. + yield (name, header + script_text) + + @classmethod + def get_header(cls, script_text="", executable=None): + """Create a #! line, getting options (if any) from script_text""" + cmd = cls.command_spec_class.best().from_param(executable) + cmd.install_options(script_text) + return cmd.as_header() + + +class WindowsScriptWriter(ScriptWriter): + command_spec_class = WindowsCommandSpec + + @classmethod + def get_writer(cls): + # for backward compatibility + warnings.warn("Use best", EasyInstallDeprecationWarning) + return cls.best() + + @classmethod + def best(cls): + """ + Select the best ScriptWriter suitable for Windows + """ + writer_lookup = dict( + executable=WindowsExecutableLauncherWriter, + natural=cls, + ) + # for compatibility, use the executable launcher by default + launcher = os.environ.get('SETUPTOOLS_LAUNCHER', 'executable') + return writer_lookup[launcher] + + @classmethod + def _get_script_args(cls, type_, name, header, script_text): + "For Windows, add a .py extension" + ext = dict(console='.pya', gui='.pyw')[type_] + if ext not in os.environ['PATHEXT'].lower().split(';'): + msg = ( + "{ext} not listed in PATHEXT; scripts will not be " + "recognized as executables." + ).format(**locals()) + warnings.warn(msg, UserWarning) + old = ['.pya', '.py', '-script.py', '.pyc', '.pyo', '.pyw', '.exe'] + old.remove(ext) + header = cls._adjust_header(type_, header) + blockers = [name + x for x in old] + yield name + ext, header + script_text, 't', blockers + + @classmethod + def _adjust_header(cls, type_, orig_header): + """ + Make sure 'pythonw' is used for gui and and 'python' is used for + console (regardless of what sys.executable is). + """ + pattern = 'pythonw.exe' + repl = 'python.exe' + if type_ == 'gui': + pattern, repl = repl, pattern + pattern_ob = re.compile(re.escape(pattern), re.IGNORECASE) + new_header = pattern_ob.sub(string=orig_header, repl=repl) + return new_header if cls._use_header(new_header) else orig_header + + @staticmethod + def _use_header(new_header): + """ + Should _adjust_header use the replaced header? + + On non-windows systems, always use. On + Windows systems, only use the replaced header if it resolves + to an executable on the system. + """ + clean_header = new_header[2:-1].strip('"') + return sys.platform != 'win32' or find_executable(clean_header) + + +class WindowsExecutableLauncherWriter(WindowsScriptWriter): + @classmethod + def _get_script_args(cls, type_, name, header, script_text): + """ + For Windows, add a .py extension and an .exe launcher + """ + if type_ == 'gui': + launcher_type = 'gui' + ext = '-script.pyw' + old = ['.pyw'] + else: + launcher_type = 'cli' + ext = '-script.py' + old = ['.py', '.pyc', '.pyo'] + hdr = cls._adjust_header(type_, header) + blockers = [name + x for x in old] + yield (name + ext, hdr + script_text, 't', blockers) + yield ( + name + '.exe', get_win_launcher(launcher_type), + 'b' # write in binary mode + ) + if not is_64bit(): + # install a manifest for the launcher to prevent Windows + # from detecting it as an installer (which it will for + # launchers like easy_install.exe). Consider only + # adding a manifest for launchers detected as installers. + # See Distribute #143 for details. + m_name = name + '.exe.manifest' + yield (m_name, load_launcher_manifest(name), 't') + + +# for backward-compatibility +get_script_args = ScriptWriter.get_script_args +get_script_header = ScriptWriter.get_script_header + + +def get_win_launcher(type): + """ + Load the Windows launcher (executable) suitable for launching a script. + + `type` should be either 'cli' or 'gui' + + Returns the executable as a byte string. + """ + launcher_fn = '%s.exe' % type + if is_64bit(): + launcher_fn = launcher_fn.replace(".", "-64.") + else: + launcher_fn = launcher_fn.replace(".", "-32.") + return resource_string('setuptools', launcher_fn) + + +def load_launcher_manifest(name): + manifest = pkg_resources.resource_string(__name__, 'launcher manifest.xml') + if six.PY2: + return manifest % vars() + else: + return manifest.decode('utf-8') % vars() + + +def rmtree(path, ignore_errors=False, onerror=auto_chmod): + return shutil.rmtree(path, ignore_errors, onerror) + + +def current_umask(): + tmp = os.umask(0o022) + os.umask(tmp) + return tmp + + +def bootstrap(): + # This function is called when setuptools*.egg is run using /bin/sh + import setuptools + + argv0 = os.path.dirname(setuptools.__path__[0]) + sys.argv[0] = argv0 + sys.argv.append(argv0) + main() + + +def main(argv=None, **kw): + from setuptools import setup + from setuptools.dist import Distribution + + class DistributionWithoutHelpCommands(Distribution): + common_usage = "" + + def _show_help(self, *args, **kw): + with _patch_usage(): + Distribution._show_help(self, *args, **kw) + + if argv is None: + argv = sys.argv[1:] + + with _patch_usage(): + setup( + script_args=['-q', 'easy_install', '-v'] + argv, + script_name=sys.argv[0] or 'easy_install', + distclass=DistributionWithoutHelpCommands, + **kw + ) + + +@contextlib.contextmanager +def _patch_usage(): + import distutils.core + USAGE = textwrap.dedent(""" + usage: %(script)s [options] requirement_or_url ... + or: %(script)s --help + """).lstrip() + + def gen_usage(script_name): + return USAGE % dict( + script=os.path.basename(script_name), + ) + + saved = distutils.core.gen_usage + distutils.core.gen_usage = gen_usage + try: + yield + finally: + distutils.core.gen_usage = saved + +class EasyInstallDeprecationWarning(SetuptoolsDeprecationWarning): + """Class for warning about deprecations in EasyInstall in SetupTools. Not ignored by default, unlike DeprecationWarning.""" + diff --git a/venv/lib/python3.8/site-packages/setuptools/command/egg_info.py b/venv/lib/python3.8/site-packages/setuptools/command/egg_info.py new file mode 100644 index 0000000..b767ef3 --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/command/egg_info.py @@ -0,0 +1,717 @@ +"""setuptools.command.egg_info + +Create a distribution's .egg-info directory and contents""" + +from distutils.filelist import FileList as _FileList +from distutils.errors import DistutilsInternalError +from distutils.util import convert_path +from distutils import log +import distutils.errors +import distutils.filelist +import os +import re +import sys +import io +import warnings +import time +import collections + +from setuptools.extern import six +from setuptools.extern.six.moves import map + +from setuptools import Command +from setuptools.command.sdist import sdist +from setuptools.command.sdist import walk_revctrl +from setuptools.command.setopt import edit_config +from setuptools.command import bdist_egg +from pkg_resources import ( + parse_requirements, safe_name, parse_version, + safe_version, yield_lines, EntryPoint, iter_entry_points, to_filename) +import setuptools.unicode_utils as unicode_utils +from setuptools.glob import glob + +from setuptools.extern import packaging +from setuptools import SetuptoolsDeprecationWarning + +def translate_pattern(glob): + """ + Translate a file path glob like '*.txt' in to a regular expression. + This differs from fnmatch.translate which allows wildcards to match + directory separators. It also knows about '**/' which matches any number of + directories. + """ + pat = '' + + # This will split on '/' within [character classes]. This is deliberate. + chunks = glob.split(os.path.sep) + + sep = re.escape(os.sep) + valid_char = '[^%s]' % (sep,) + + for c, chunk in enumerate(chunks): + last_chunk = c == len(chunks) - 1 + + # Chunks that are a literal ** are globstars. They match anything. + if chunk == '**': + if last_chunk: + # Match anything if this is the last component + pat += '.*' + else: + # Match '(name/)*' + pat += '(?:%s+%s)*' % (valid_char, sep) + continue # Break here as the whole path component has been handled + + # Find any special characters in the remainder + i = 0 + chunk_len = len(chunk) + while i < chunk_len: + char = chunk[i] + if char == '*': + # Match any number of name characters + pat += valid_char + '*' + elif char == '?': + # Match a name character + pat += valid_char + elif char == '[': + # Character class + inner_i = i + 1 + # Skip initial !/] chars + if inner_i < chunk_len and chunk[inner_i] == '!': + inner_i = inner_i + 1 + if inner_i < chunk_len and chunk[inner_i] == ']': + inner_i = inner_i + 1 + + # Loop till the closing ] is found + while inner_i < chunk_len and chunk[inner_i] != ']': + inner_i = inner_i + 1 + + if inner_i >= chunk_len: + # Got to the end of the string without finding a closing ] + # Do not treat this as a matching group, but as a literal [ + pat += re.escape(char) + else: + # Grab the insides of the [brackets] + inner = chunk[i + 1:inner_i] + char_class = '' + + # Class negation + if inner[0] == '!': + char_class = '^' + inner = inner[1:] + + char_class += re.escape(inner) + pat += '[%s]' % (char_class,) + + # Skip to the end ] + i = inner_i + else: + pat += re.escape(char) + i += 1 + + # Join each chunk with the dir separator + if not last_chunk: + pat += sep + + pat += r'\Z' + return re.compile(pat, flags=re.MULTILINE|re.DOTALL) + + +class InfoCommon: + tag_build = None + tag_date = None + + @property + def name(self): + return safe_name(self.distribution.get_name()) + + def tagged_version(self): + version = self.distribution.get_version() + # egg_info may be called more than once for a distribution, + # in which case the version string already contains all tags. + if self.vtags and version.endswith(self.vtags): + return safe_version(version) + return safe_version(version + self.vtags) + + def tags(self): + version = '' + if self.tag_build: + version += self.tag_build + if self.tag_date: + version += time.strftime("-%Y%m%d") + return version + vtags = property(tags) + + +class egg_info(InfoCommon, Command): + description = "create a distribution's .egg-info directory" + + user_options = [ + ('egg-base=', 'e', "directory containing .egg-info directories" + " (default: top of the source tree)"), + ('tag-date', 'd', "Add date stamp (e.g. 20050528) to version number"), + ('tag-build=', 'b', "Specify explicit tag to add to version number"), + ('no-date', 'D', "Don't include date stamp [default]"), + ] + + boolean_options = ['tag-date'] + negative_opt = { + 'no-date': 'tag-date', + } + + def initialize_options(self): + self.egg_base = None + self.egg_name = None + self.egg_info = None + self.egg_version = None + self.broken_egg_info = False + + #################################### + # allow the 'tag_svn_revision' to be detected and + # set, supporting sdists built on older Setuptools. + @property + def tag_svn_revision(self): + pass + + @tag_svn_revision.setter + def tag_svn_revision(self, value): + pass + #################################### + + def save_version_info(self, filename): + """ + Materialize the value of date into the + build tag. Install build keys in a deterministic order + to avoid arbitrary reordering on subsequent builds. + """ + egg_info = collections.OrderedDict() + # follow the order these keys would have been added + # when PYTHONHASHSEED=0 + egg_info['tag_build'] = self.tags() + egg_info['tag_date'] = 0 + edit_config(filename, dict(egg_info=egg_info)) + + def finalize_options(self): + # Note: we need to capture the current value returned + # by `self.tagged_version()`, so we can later update + # `self.distribution.metadata.version` without + # repercussions. + self.egg_name = self.name + self.egg_version = self.tagged_version() + parsed_version = parse_version(self.egg_version) + + try: + is_version = isinstance(parsed_version, packaging.version.Version) + spec = ( + "%s==%s" if is_version else "%s===%s" + ) + list( + parse_requirements(spec % (self.egg_name, self.egg_version)) + ) + except ValueError: + raise distutils.errors.DistutilsOptionError( + "Invalid distribution name or version syntax: %s-%s" % + (self.egg_name, self.egg_version) + ) + + if self.egg_base is None: + dirs = self.distribution.package_dir + self.egg_base = (dirs or {}).get('', os.curdir) + + self.ensure_dirname('egg_base') + self.egg_info = to_filename(self.egg_name) + '.egg-info' + if self.egg_base != os.curdir: + self.egg_info = os.path.join(self.egg_base, self.egg_info) + if '-' in self.egg_name: + self.check_broken_egg_info() + + # Set package version for the benefit of dumber commands + # (e.g. sdist, bdist_wininst, etc.) + # + self.distribution.metadata.version = self.egg_version + + # If we bootstrapped around the lack of a PKG-INFO, as might be the + # case in a fresh checkout, make sure that any special tags get added + # to the version info + # + pd = self.distribution._patched_dist + if pd is not None and pd.key == self.egg_name.lower(): + pd._version = self.egg_version + pd._parsed_version = parse_version(self.egg_version) + self.distribution._patched_dist = None + + def write_or_delete_file(self, what, filename, data, force=False): + """Write `data` to `filename` or delete if empty + + If `data` is non-empty, this routine is the same as ``write_file()``. + If `data` is empty but not ``None``, this is the same as calling + ``delete_file(filename)`. If `data` is ``None``, then this is a no-op + unless `filename` exists, in which case a warning is issued about the + orphaned file (if `force` is false), or deleted (if `force` is true). + """ + if data: + self.write_file(what, filename, data) + elif os.path.exists(filename): + if data is None and not force: + log.warn( + "%s not set in setup(), but %s exists", what, filename + ) + return + else: + self.delete_file(filename) + + def write_file(self, what, filename, data): + """Write `data` to `filename` (if not a dry run) after announcing it + + `what` is used in a log message to identify what is being written + to the file. + """ + log.info("writing %s to %s", what, filename) + if six.PY3: + data = data.encode("utf-8") + if not self.dry_run: + f = open(filename, 'wb') + f.write(data) + f.close() + + def delete_file(self, filename): + """Delete `filename` (if not a dry run) after announcing it""" + log.info("deleting %s", filename) + if not self.dry_run: + os.unlink(filename) + + def run(self): + self.mkpath(self.egg_info) + os.utime(self.egg_info, None) + installer = self.distribution.fetch_build_egg + for ep in iter_entry_points('egg_info.writers'): + ep.require(installer=installer) + writer = ep.resolve() + writer(self, ep.name, os.path.join(self.egg_info, ep.name)) + + # Get rid of native_libs.txt if it was put there by older bdist_egg + nl = os.path.join(self.egg_info, "native_libs.txt") + if os.path.exists(nl): + self.delete_file(nl) + + self.find_sources() + + def find_sources(self): + """Generate SOURCES.txt manifest file""" + manifest_filename = os.path.join(self.egg_info, "SOURCES.txt") + mm = manifest_maker(self.distribution) + mm.manifest = manifest_filename + mm.run() + self.filelist = mm.filelist + + def check_broken_egg_info(self): + bei = self.egg_name + '.egg-info' + if self.egg_base != os.curdir: + bei = os.path.join(self.egg_base, bei) + if os.path.exists(bei): + log.warn( + "-" * 78 + '\n' + "Note: Your current .egg-info directory has a '-' in its name;" + '\nthis will not work correctly with "setup.py develop".\n\n' + 'Please rename %s to %s to correct this problem.\n' + '-' * 78, + bei, self.egg_info + ) + self.broken_egg_info = self.egg_info + self.egg_info = bei # make it work for now + + +class FileList(_FileList): + # Implementations of the various MANIFEST.in commands + + def process_template_line(self, line): + # Parse the line: split it up, make sure the right number of words + # is there, and return the relevant words. 'action' is always + # defined: it's the first word of the line. Which of the other + # three are defined depends on the action; it'll be either + # patterns, (dir and patterns), or (dir_pattern). + (action, patterns, dir, dir_pattern) = self._parse_template_line(line) + + # OK, now we know that the action is valid and we have the + # right number of words on the line for that action -- so we + # can proceed with minimal error-checking. + if action == 'include': + self.debug_print("include " + ' '.join(patterns)) + for pattern in patterns: + if not self.include(pattern): + log.warn("warning: no files found matching '%s'", pattern) + + elif action == 'exclude': + self.debug_print("exclude " + ' '.join(patterns)) + for pattern in patterns: + if not self.exclude(pattern): + log.warn(("warning: no previously-included files " + "found matching '%s'"), pattern) + + elif action == 'global-include': + self.debug_print("global-include " + ' '.join(patterns)) + for pattern in patterns: + if not self.global_include(pattern): + log.warn(("warning: no files found matching '%s' " + "anywhere in distribution"), pattern) + + elif action == 'global-exclude': + self.debug_print("global-exclude " + ' '.join(patterns)) + for pattern in patterns: + if not self.global_exclude(pattern): + log.warn(("warning: no previously-included files matching " + "'%s' found anywhere in distribution"), + pattern) + + elif action == 'recursive-include': + self.debug_print("recursive-include %s %s" % + (dir, ' '.join(patterns))) + for pattern in patterns: + if not self.recursive_include(dir, pattern): + log.warn(("warning: no files found matching '%s' " + "under directory '%s'"), + pattern, dir) + + elif action == 'recursive-exclude': + self.debug_print("recursive-exclude %s %s" % + (dir, ' '.join(patterns))) + for pattern in patterns: + if not self.recursive_exclude(dir, pattern): + log.warn(("warning: no previously-included files matching " + "'%s' found under directory '%s'"), + pattern, dir) + + elif action == 'graft': + self.debug_print("graft " + dir_pattern) + if not self.graft(dir_pattern): + log.warn("warning: no directories found matching '%s'", + dir_pattern) + + elif action == 'prune': + self.debug_print("prune " + dir_pattern) + if not self.prune(dir_pattern): + log.warn(("no previously-included directories found " + "matching '%s'"), dir_pattern) + + else: + raise DistutilsInternalError( + "this cannot happen: invalid action '%s'" % action) + + def _remove_files(self, predicate): + """ + Remove all files from the file list that match the predicate. + Return True if any matching files were removed + """ + found = False + for i in range(len(self.files) - 1, -1, -1): + if predicate(self.files[i]): + self.debug_print(" removing " + self.files[i]) + del self.files[i] + found = True + return found + + def include(self, pattern): + """Include files that match 'pattern'.""" + found = [f for f in glob(pattern) if not os.path.isdir(f)] + self.extend(found) + return bool(found) + + def exclude(self, pattern): + """Exclude files that match 'pattern'.""" + match = translate_pattern(pattern) + return self._remove_files(match.match) + + def recursive_include(self, dir, pattern): + """ + Include all files anywhere in 'dir/' that match the pattern. + """ + full_pattern = os.path.join(dir, '**', pattern) + found = [f for f in glob(full_pattern, recursive=True) + if not os.path.isdir(f)] + self.extend(found) + return bool(found) + + def recursive_exclude(self, dir, pattern): + """ + Exclude any file anywhere in 'dir/' that match the pattern. + """ + match = translate_pattern(os.path.join(dir, '**', pattern)) + return self._remove_files(match.match) + + def graft(self, dir): + """Include all files from 'dir/'.""" + found = [ + item + for match_dir in glob(dir) + for item in distutils.filelist.findall(match_dir) + ] + self.extend(found) + return bool(found) + + def prune(self, dir): + """Filter out files from 'dir/'.""" + match = translate_pattern(os.path.join(dir, '**')) + return self._remove_files(match.match) + + def global_include(self, pattern): + """ + Include all files anywhere in the current directory that match the + pattern. This is very inefficient on large file trees. + """ + if self.allfiles is None: + self.findall() + match = translate_pattern(os.path.join('**', pattern)) + found = [f for f in self.allfiles if match.match(f)] + self.extend(found) + return bool(found) + + def global_exclude(self, pattern): + """ + Exclude all files anywhere that match the pattern. + """ + match = translate_pattern(os.path.join('**', pattern)) + return self._remove_files(match.match) + + def append(self, item): + if item.endswith('\r'): # Fix older sdists built on Windows + item = item[:-1] + path = convert_path(item) + + if self._safe_path(path): + self.files.append(path) + + def extend(self, paths): + self.files.extend(filter(self._safe_path, paths)) + + def _repair(self): + """ + Replace self.files with only safe paths + + Because some owners of FileList manipulate the underlying + ``files`` attribute directly, this method must be called to + repair those paths. + """ + self.files = list(filter(self._safe_path, self.files)) + + def _safe_path(self, path): + enc_warn = "'%s' not %s encodable -- skipping" + + # To avoid accidental trans-codings errors, first to unicode + u_path = unicode_utils.filesys_decode(path) + if u_path is None: + log.warn("'%s' in unexpected encoding -- skipping" % path) + return False + + # Must ensure utf-8 encodability + utf8_path = unicode_utils.try_encode(u_path, "utf-8") + if utf8_path is None: + log.warn(enc_warn, path, 'utf-8') + return False + + try: + # accept is either way checks out + if os.path.exists(u_path) or os.path.exists(utf8_path): + return True + # this will catch any encode errors decoding u_path + except UnicodeEncodeError: + log.warn(enc_warn, path, sys.getfilesystemencoding()) + + +class manifest_maker(sdist): + template = "MANIFEST.in" + + def initialize_options(self): + self.use_defaults = 1 + self.prune = 1 + self.manifest_only = 1 + self.force_manifest = 1 + + def finalize_options(self): + pass + + def run(self): + self.filelist = FileList() + if not os.path.exists(self.manifest): + self.write_manifest() # it must exist so it'll get in the list + self.add_defaults() + if os.path.exists(self.template): + self.read_template() + self.prune_file_list() + self.filelist.sort() + self.filelist.remove_duplicates() + self.write_manifest() + + def _manifest_normalize(self, path): + path = unicode_utils.filesys_decode(path) + return path.replace(os.sep, '/') + + def write_manifest(self): + """ + Write the file list in 'self.filelist' to the manifest file + named by 'self.manifest'. + """ + self.filelist._repair() + + # Now _repairs should encodability, but not unicode + files = [self._manifest_normalize(f) for f in self.filelist.files] + msg = "writing manifest file '%s'" % self.manifest + self.execute(write_file, (self.manifest, files), msg) + + def warn(self, msg): + if not self._should_suppress_warning(msg): + sdist.warn(self, msg) + + @staticmethod + def _should_suppress_warning(msg): + """ + suppress missing-file warnings from sdist + """ + return re.match(r"standard file .*not found", msg) + + def add_defaults(self): + sdist.add_defaults(self) + self.check_license() + self.filelist.append(self.template) + self.filelist.append(self.manifest) + rcfiles = list(walk_revctrl()) + if rcfiles: + self.filelist.extend(rcfiles) + elif os.path.exists(self.manifest): + self.read_manifest() + + if os.path.exists("setup.py"): + # setup.py should be included by default, even if it's not + # the script called to create the sdist + self.filelist.append("setup.py") + + ei_cmd = self.get_finalized_command('egg_info') + self.filelist.graft(ei_cmd.egg_info) + + def prune_file_list(self): + build = self.get_finalized_command('build') + base_dir = self.distribution.get_fullname() + self.filelist.prune(build.build_base) + self.filelist.prune(base_dir) + sep = re.escape(os.sep) + self.filelist.exclude_pattern(r'(^|' + sep + r')(RCS|CVS|\.svn)' + sep, + is_regex=1) + + +def write_file(filename, contents): + """Create a file with the specified name and write 'contents' (a + sequence of strings without line terminators) to it. + """ + contents = "\n".join(contents) + + # assuming the contents has been vetted for utf-8 encoding + contents = contents.encode("utf-8") + + with open(filename, "wb") as f: # always write POSIX-style manifest + f.write(contents) + + +def write_pkg_info(cmd, basename, filename): + log.info("writing %s", filename) + if not cmd.dry_run: + metadata = cmd.distribution.metadata + metadata.version, oldver = cmd.egg_version, metadata.version + metadata.name, oldname = cmd.egg_name, metadata.name + + try: + # write unescaped data to PKG-INFO, so older pkg_resources + # can still parse it + metadata.write_pkg_info(cmd.egg_info) + finally: + metadata.name, metadata.version = oldname, oldver + + safe = getattr(cmd.distribution, 'zip_safe', None) + + bdist_egg.write_safety_flag(cmd.egg_info, safe) + + +def warn_depends_obsolete(cmd, basename, filename): + if os.path.exists(filename): + log.warn( + "WARNING: 'depends.txt' is not used by setuptools 0.6!\n" + "Use the install_requires/extras_require setup() args instead." + ) + + +def _write_requirements(stream, reqs): + lines = yield_lines(reqs or ()) + append_cr = lambda line: line + '\n' + lines = map(append_cr, sorted(lines)) + stream.writelines(lines) + + +def write_requirements(cmd, basename, filename): + dist = cmd.distribution + data = six.StringIO() + _write_requirements(data, dist.install_requires) + extras_require = dist.extras_require or {} + for extra in sorted(extras_require): + data.write('\n[{extra}]\n'.format(**vars())) + _write_requirements(data, extras_require[extra]) + cmd.write_or_delete_file("requirements", filename, data.getvalue()) + + +def write_setup_requirements(cmd, basename, filename): + data = io.StringIO() + _write_requirements(data, cmd.distribution.setup_requires) + cmd.write_or_delete_file("setup-requirements", filename, data.getvalue()) + + +def write_toplevel_names(cmd, basename, filename): + pkgs = dict.fromkeys( + [ + k.split('.', 1)[0] + for k in cmd.distribution.iter_distribution_names() + ] + ) + cmd.write_file("top-level names", filename, '\n'.join(sorted(pkgs)) + '\n') + + +def overwrite_arg(cmd, basename, filename): + write_arg(cmd, basename, filename, True) + + +def write_arg(cmd, basename, filename, force=False): + argname = os.path.splitext(basename)[0] + value = getattr(cmd.distribution, argname, None) + if value is not None: + value = '\n'.join(value) + '\n' + cmd.write_or_delete_file(argname, filename, value, force) + + +def write_entries(cmd, basename, filename): + ep = cmd.distribution.entry_points + + if isinstance(ep, six.string_types) or ep is None: + data = ep + elif ep is not None: + data = [] + for section, contents in sorted(ep.items()): + if not isinstance(contents, six.string_types): + contents = EntryPoint.parse_group(section, contents) + contents = '\n'.join(sorted(map(str, contents.values()))) + data.append('[%s]\n%s\n\n' % (section, contents)) + data = ''.join(data) + + cmd.write_or_delete_file('entry points', filename, data, True) + + +def get_pkg_info_revision(): + """ + Get a -r### off of PKG-INFO Version in case this is an sdist of + a subversion revision. + """ + warnings.warn("get_pkg_info_revision is deprecated.", EggInfoDeprecationWarning) + if os.path.exists('PKG-INFO'): + with io.open('PKG-INFO') as f: + for line in f: + match = re.match(r"Version:.*-r(\d+)\s*$", line) + if match: + return int(match.group(1)) + return 0 + + +class EggInfoDeprecationWarning(SetuptoolsDeprecationWarning): + """Class for warning about deprecations in eggInfo in setupTools. Not ignored by default, unlike DeprecationWarning.""" diff --git a/venv/lib/python3.8/site-packages/setuptools/command/install.py b/venv/lib/python3.8/site-packages/setuptools/command/install.py new file mode 100644 index 0000000..72b9a3e --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/command/install.py @@ -0,0 +1,125 @@ +from distutils.errors import DistutilsArgError +import inspect +import glob +import warnings +import platform +import distutils.command.install as orig + +import setuptools + +# Prior to numpy 1.9, NumPy relies on the '_install' name, so provide it for +# now. See https://github.com/pypa/setuptools/issues/199/ +_install = orig.install + + +class install(orig.install): + """Use easy_install to install the package, w/dependencies""" + + user_options = orig.install.user_options + [ + ('old-and-unmanageable', None, "Try not to use this!"), + ('single-version-externally-managed', None, + "used by system package builders to create 'flat' eggs"), + ] + boolean_options = orig.install.boolean_options + [ + 'old-and-unmanageable', 'single-version-externally-managed', + ] + new_commands = [ + ('install_egg_info', lambda self: True), + ('install_scripts', lambda self: True), + ] + _nc = dict(new_commands) + + def initialize_options(self): + orig.install.initialize_options(self) + self.old_and_unmanageable = None + self.single_version_externally_managed = None + + def finalize_options(self): + orig.install.finalize_options(self) + if self.root: + self.single_version_externally_managed = True + elif self.single_version_externally_managed: + if not self.root and not self.record: + raise DistutilsArgError( + "You must specify --record or --root when building system" + " packages" + ) + + def handle_extra_path(self): + if self.root or self.single_version_externally_managed: + # explicit backward-compatibility mode, allow extra_path to work + return orig.install.handle_extra_path(self) + + # Ignore extra_path when installing an egg (or being run by another + # command without --root or --single-version-externally-managed + self.path_file = None + self.extra_dirs = '' + + def run(self): + # Explicit request for old-style install? Just do it + if self.old_and_unmanageable or self.single_version_externally_managed: + return orig.install.run(self) + + if not self._called_from_setup(inspect.currentframe()): + # Run in backward-compatibility mode to support bdist_* commands. + orig.install.run(self) + else: + self.do_egg_install() + + @staticmethod + def _called_from_setup(run_frame): + """ + Attempt to detect whether run() was called from setup() or by another + command. If called by setup(), the parent caller will be the + 'run_command' method in 'distutils.dist', and *its* caller will be + the 'run_commands' method. If called any other way, the + immediate caller *might* be 'run_command', but it won't have been + called by 'run_commands'. Return True in that case or if a call stack + is unavailable. Return False otherwise. + """ + if run_frame is None: + msg = "Call stack not available. bdist_* commands may fail." + warnings.warn(msg) + if platform.python_implementation() == 'IronPython': + msg = "For best results, pass -X:Frames to enable call stack." + warnings.warn(msg) + return True + res = inspect.getouterframes(run_frame)[2] + caller, = res[:1] + info = inspect.getframeinfo(caller) + caller_module = caller.f_globals.get('__name__', '') + return ( + caller_module == 'distutils.dist' + and info.function == 'run_commands' + ) + + def do_egg_install(self): + + easy_install = self.distribution.get_command_class('easy_install') + + cmd = easy_install( + self.distribution, args="x", root=self.root, record=self.record, + ) + cmd.ensure_finalized() # finalize before bdist_egg munges install cmd + cmd.always_copy_from = '.' # make sure local-dir eggs get installed + + # pick up setup-dir .egg files only: no .egg-info + cmd.package_index.scan(glob.glob('*.egg')) + + self.run_command('bdist_egg') + args = [self.distribution.get_command_obj('bdist_egg').egg_output] + + if setuptools.bootstrap_install_from: + # Bootstrap self-installation of setuptools + args.insert(0, setuptools.bootstrap_install_from) + + cmd.args = args + cmd.run(show_deprecation=False) + setuptools.bootstrap_install_from = None + + +# XXX Python 3.1 doesn't see _nc if this is inside the class +install.sub_commands = ( + [cmd for cmd in orig.install.sub_commands if cmd[0] not in install._nc] + + install.new_commands +) diff --git a/venv/lib/python3.8/site-packages/setuptools/command/install_egg_info.py b/venv/lib/python3.8/site-packages/setuptools/command/install_egg_info.py new file mode 100644 index 0000000..5f405bc --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/command/install_egg_info.py @@ -0,0 +1,82 @@ +from distutils import log, dir_util +import os, sys + +from setuptools import Command +from setuptools import namespaces +from setuptools.archive_util import unpack_archive +import pkg_resources + + +class install_egg_info(namespaces.Installer, Command): + """Install an .egg-info directory for the package""" + + description = "Install an .egg-info directory for the package" + + user_options = [ + ('install-dir=', 'd', "directory to install to"), + ] + + def initialize_options(self): + self.install_dir = None + self.install_layout = None + self.prefix_option = None + + def finalize_options(self): + self.set_undefined_options('install_lib', + ('install_dir', 'install_dir')) + self.set_undefined_options('install',('install_layout','install_layout')) + if sys.hexversion > 0x2060000: + self.set_undefined_options('install',('prefix_option','prefix_option')) + ei_cmd = self.get_finalized_command("egg_info") + basename = pkg_resources.Distribution( + None, None, ei_cmd.egg_name, ei_cmd.egg_version + ).egg_name() + '.egg-info' + + if self.install_layout: + if not self.install_layout.lower() in ['deb']: + raise DistutilsOptionError("unknown value for --install-layout") + self.install_layout = self.install_layout.lower() + basename = basename.replace('-py%s' % pkg_resources.PY_MAJOR, '') + elif self.prefix_option or 'real_prefix' in sys.__dict__: + # don't modify for virtualenv + pass + else: + basename = basename.replace('-py%s' % pkg_resources.PY_MAJOR, '') + + self.source = ei_cmd.egg_info + self.target = os.path.join(self.install_dir, basename) + self.outputs = [] + + def run(self): + self.run_command('egg_info') + if os.path.isdir(self.target) and not os.path.islink(self.target): + dir_util.remove_tree(self.target, dry_run=self.dry_run) + elif os.path.exists(self.target): + self.execute(os.unlink, (self.target,), "Removing " + self.target) + if not self.dry_run: + pkg_resources.ensure_directory(self.target) + self.execute( + self.copytree, (), "Copying %s to %s" % (self.source, self.target) + ) + self.install_namespaces() + + def get_outputs(self): + return self.outputs + + def copytree(self): + # Copy the .egg-info tree to site-packages + def skimmer(src, dst): + # filter out source-control directories; note that 'src' is always + # a '/'-separated path, regardless of platform. 'dst' is a + # platform-specific path. + for skip in '.svn/', 'CVS/': + if src.startswith(skip) or '/' + skip in src: + return None + if self.install_layout and self.install_layout in ['deb'] and src.startswith('SOURCES.txt'): + log.info("Skipping SOURCES.txt") + return None + self.outputs.append(dst) + log.debug("Copying %s to %s", src, dst) + return dst + + unpack_archive(self.source, self.target, skimmer) diff --git a/venv/lib/python3.8/site-packages/setuptools/command/install_lib.py b/venv/lib/python3.8/site-packages/setuptools/command/install_lib.py new file mode 100644 index 0000000..bf81519 --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/command/install_lib.py @@ -0,0 +1,147 @@ +import os +import sys +from itertools import product, starmap +import distutils.command.install_lib as orig + + +class install_lib(orig.install_lib): + """Don't add compiled flags to filenames of non-Python files""" + + def initialize_options(self): + orig.install_lib.initialize_options(self) + self.multiarch = None + self.install_layout = None + + def finalize_options(self): + orig.install_lib.finalize_options(self) + self.set_undefined_options('install',('install_layout','install_layout')) + if self.install_layout == 'deb' and sys.version_info[:2] >= (3, 3): + import sysconfig + self.multiarch = sysconfig.get_config_var('MULTIARCH') + + def run(self): + self.build() + outfiles = self.install() + if outfiles is not None: + # always compile, in case we have any extension stubs to deal with + self.byte_compile(outfiles) + + def get_exclusions(self): + """ + Return a collections.Sized collections.Container of paths to be + excluded for single_version_externally_managed installations. + """ + all_packages = ( + pkg + for ns_pkg in self._get_SVEM_NSPs() + for pkg in self._all_packages(ns_pkg) + ) + + excl_specs = product(all_packages, self._gen_exclusion_paths()) + return set(starmap(self._exclude_pkg_path, excl_specs)) + + def _exclude_pkg_path(self, pkg, exclusion_path): + """ + Given a package name and exclusion path within that package, + compute the full exclusion path. + """ + parts = pkg.split('.') + [exclusion_path] + return os.path.join(self.install_dir, *parts) + + @staticmethod + def _all_packages(pkg_name): + """ + >>> list(install_lib._all_packages('foo.bar.baz')) + ['foo.bar.baz', 'foo.bar', 'foo'] + """ + while pkg_name: + yield pkg_name + pkg_name, sep, child = pkg_name.rpartition('.') + + def _get_SVEM_NSPs(self): + """ + Get namespace packages (list) but only for + single_version_externally_managed installations and empty otherwise. + """ + # TODO: is it necessary to short-circuit here? i.e. what's the cost + # if get_finalized_command is called even when namespace_packages is + # False? + if not self.distribution.namespace_packages: + return [] + + install_cmd = self.get_finalized_command('install') + svem = install_cmd.single_version_externally_managed + + return self.distribution.namespace_packages if svem else [] + + @staticmethod + def _gen_exclusion_paths(): + """ + Generate file paths to be excluded for namespace packages (bytecode + cache files). + """ + # always exclude the package module itself + yield '__init__.py' + + yield '__init__.pyc' + yield '__init__.pyo' + + if not hasattr(sys, 'implementation'): + return + + base = os.path.join('__pycache__', '__init__.' + sys.implementation.cache_tag) + yield base + '.pyc' + yield base + '.pyo' + yield base + '.opt-1.pyc' + yield base + '.opt-2.pyc' + + def copy_tree( + self, infile, outfile, + preserve_mode=1, preserve_times=1, preserve_symlinks=0, level=1 + ): + assert preserve_mode and preserve_times and not preserve_symlinks + exclude = self.get_exclusions() + + if not exclude: + import distutils.dir_util + distutils.dir_util._multiarch = self.multiarch + return orig.install_lib.copy_tree(self, infile, outfile) + + # Exclude namespace package __init__.py* files from the output + + from setuptools.archive_util import unpack_directory + from distutils import log + + outfiles = [] + + if self.multiarch: + import sysconfig + ext_suffix = sysconfig.get_config_var ('EXT_SUFFIX') + if ext_suffix.endswith(self.multiarch + ext_suffix[-3:]): + new_suffix = None + else: + new_suffix = "%s-%s%s" % (ext_suffix[:-3], self.multiarch, ext_suffix[-3:]) + + def pf(src, dst): + if dst in exclude: + log.warn("Skipping installation of %s (namespace package)", + dst) + return False + + if self.multiarch and new_suffix and dst.endswith(ext_suffix) and not dst.endswith(new_suffix): + dst = dst.replace(ext_suffix, new_suffix) + log.info("renaming extension to %s", os.path.basename(dst)) + + log.info("copying %s -> %s", src, os.path.dirname(dst)) + outfiles.append(dst) + return dst + + unpack_directory(infile, outfile, pf) + return outfiles + + def get_outputs(self): + outputs = orig.install_lib.get_outputs(self) + exclude = self.get_exclusions() + if exclude: + return [f for f in outputs if f not in exclude] + return outputs diff --git a/venv/lib/python3.8/site-packages/setuptools/command/install_scripts.py b/venv/lib/python3.8/site-packages/setuptools/command/install_scripts.py new file mode 100644 index 0000000..1623427 --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/command/install_scripts.py @@ -0,0 +1,65 @@ +from distutils import log +import distutils.command.install_scripts as orig +import os +import sys + +from pkg_resources import Distribution, PathMetadata, ensure_directory + + +class install_scripts(orig.install_scripts): + """Do normal script install, plus any egg_info wrapper scripts""" + + def initialize_options(self): + orig.install_scripts.initialize_options(self) + self.no_ep = False + + def run(self): + import setuptools.command.easy_install as ei + + self.run_command("egg_info") + if self.distribution.scripts: + orig.install_scripts.run(self) # run first to set up self.outfiles + else: + self.outfiles = [] + if self.no_ep: + # don't install entry point scripts into .egg file! + return + + ei_cmd = self.get_finalized_command("egg_info") + dist = Distribution( + ei_cmd.egg_base, PathMetadata(ei_cmd.egg_base, ei_cmd.egg_info), + ei_cmd.egg_name, ei_cmd.egg_version, + ) + bs_cmd = self.get_finalized_command('build_scripts') + exec_param = getattr(bs_cmd, 'executable', None) + bw_cmd = self.get_finalized_command("bdist_wininst") + is_wininst = getattr(bw_cmd, '_is_running', False) + writer = ei.ScriptWriter + if is_wininst: + exec_param = "python.exe" + writer = ei.WindowsScriptWriter + if exec_param == sys.executable: + # In case the path to the Python executable contains a space, wrap + # it so it's not split up. + exec_param = [exec_param] + # resolve the writer to the environment + writer = writer.best() + cmd = writer.command_spec_class.best().from_param(exec_param) + for args in writer.get_args(dist, cmd.as_header()): + self.write_script(*args) + + def write_script(self, script_name, contents, mode="t", *ignored): + """Write an executable file to the scripts directory""" + from setuptools.command.easy_install import chmod, current_umask + + log.info("Installing %s script to %s", script_name, self.install_dir) + target = os.path.join(self.install_dir, script_name) + self.outfiles.append(target) + + mask = current_umask() + if not self.dry_run: + ensure_directory(target) + f = open(target, "w" + mode) + f.write(contents) + f.close() + chmod(target, 0o777 - mask) diff --git a/venv/lib/python3.8/site-packages/setuptools/command/launcher manifest.xml b/venv/lib/python3.8/site-packages/setuptools/command/launcher manifest.xml new file mode 100644 index 0000000..5972a96 --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/command/launcher manifest.xml @@ -0,0 +1,15 @@ + + + + + + + + + + + + diff --git a/venv/lib/python3.8/site-packages/setuptools/command/py36compat.py b/venv/lib/python3.8/site-packages/setuptools/command/py36compat.py new file mode 100644 index 0000000..61063e7 --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/command/py36compat.py @@ -0,0 +1,136 @@ +import os +from glob import glob +from distutils.util import convert_path +from distutils.command import sdist + +from setuptools.extern.six.moves import filter + + +class sdist_add_defaults: + """ + Mix-in providing forward-compatibility for functionality as found in + distutils on Python 3.7. + + Do not edit the code in this class except to update functionality + as implemented in distutils. Instead, override in the subclass. + """ + + def add_defaults(self): + """Add all the default files to self.filelist: + - README or README.txt + - setup.py + - test/test*.py + - all pure Python modules mentioned in setup script + - all files pointed by package_data (build_py) + - all files defined in data_files. + - all files defined as scripts. + - all C sources listed as part of extensions or C libraries + in the setup script (doesn't catch C headers!) + Warns if (README or README.txt) or setup.py are missing; everything + else is optional. + """ + self._add_defaults_standards() + self._add_defaults_optional() + self._add_defaults_python() + self._add_defaults_data_files() + self._add_defaults_ext() + self._add_defaults_c_libs() + self._add_defaults_scripts() + + @staticmethod + def _cs_path_exists(fspath): + """ + Case-sensitive path existence check + + >>> sdist_add_defaults._cs_path_exists(__file__) + True + >>> sdist_add_defaults._cs_path_exists(__file__.upper()) + False + """ + if not os.path.exists(fspath): + return False + # make absolute so we always have a directory + abspath = os.path.abspath(fspath) + directory, filename = os.path.split(abspath) + return filename in os.listdir(directory) + + def _add_defaults_standards(self): + standards = [self.READMES, self.distribution.script_name] + for fn in standards: + if isinstance(fn, tuple): + alts = fn + got_it = False + for fn in alts: + if self._cs_path_exists(fn): + got_it = True + self.filelist.append(fn) + break + + if not got_it: + self.warn("standard file not found: should have one of " + + ', '.join(alts)) + else: + if self._cs_path_exists(fn): + self.filelist.append(fn) + else: + self.warn("standard file '%s' not found" % fn) + + def _add_defaults_optional(self): + optional = ['test/test*.py', 'setup.cfg'] + for pattern in optional: + files = filter(os.path.isfile, glob(pattern)) + self.filelist.extend(files) + + def _add_defaults_python(self): + # build_py is used to get: + # - python modules + # - files defined in package_data + build_py = self.get_finalized_command('build_py') + + # getting python files + if self.distribution.has_pure_modules(): + self.filelist.extend(build_py.get_source_files()) + + # getting package_data files + # (computed in build_py.data_files by build_py.finalize_options) + for pkg, src_dir, build_dir, filenames in build_py.data_files: + for filename in filenames: + self.filelist.append(os.path.join(src_dir, filename)) + + def _add_defaults_data_files(self): + # getting distribution.data_files + if self.distribution.has_data_files(): + for item in self.distribution.data_files: + if isinstance(item, str): + # plain file + item = convert_path(item) + if os.path.isfile(item): + self.filelist.append(item) + else: + # a (dirname, filenames) tuple + dirname, filenames = item + for f in filenames: + f = convert_path(f) + if os.path.isfile(f): + self.filelist.append(f) + + def _add_defaults_ext(self): + if self.distribution.has_ext_modules(): + build_ext = self.get_finalized_command('build_ext') + self.filelist.extend(build_ext.get_source_files()) + + def _add_defaults_c_libs(self): + if self.distribution.has_c_libraries(): + build_clib = self.get_finalized_command('build_clib') + self.filelist.extend(build_clib.get_source_files()) + + def _add_defaults_scripts(self): + if self.distribution.has_scripts(): + build_scripts = self.get_finalized_command('build_scripts') + self.filelist.extend(build_scripts.get_source_files()) + + +if hasattr(sdist.sdist, '_add_defaults_standards'): + # disable the functionality already available upstream + class sdist_add_defaults: + pass diff --git a/venv/lib/python3.8/site-packages/setuptools/command/register.py b/venv/lib/python3.8/site-packages/setuptools/command/register.py new file mode 100644 index 0000000..b8266b9 --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/command/register.py @@ -0,0 +1,18 @@ +from distutils import log +import distutils.command.register as orig + +from setuptools.errors import RemovedCommandError + + +class register(orig.register): + """Formerly used to register packages on PyPI.""" + + def run(self): + msg = ( + "The register command has been removed, use twine to upload " + + "instead (https://pypi.org/p/twine)" + ) + + self.announce("ERROR: " + msg, log.ERROR) + + raise RemovedCommandError(msg) diff --git a/venv/lib/python3.8/site-packages/setuptools/command/rotate.py b/venv/lib/python3.8/site-packages/setuptools/command/rotate.py new file mode 100644 index 0000000..b89353f --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/command/rotate.py @@ -0,0 +1,66 @@ +from distutils.util import convert_path +from distutils import log +from distutils.errors import DistutilsOptionError +import os +import shutil + +from setuptools.extern import six + +from setuptools import Command + + +class rotate(Command): + """Delete older distributions""" + + description = "delete older distributions, keeping N newest files" + user_options = [ + ('match=', 'm', "patterns to match (required)"), + ('dist-dir=', 'd', "directory where the distributions are"), + ('keep=', 'k', "number of matching distributions to keep"), + ] + + boolean_options = [] + + def initialize_options(self): + self.match = None + self.dist_dir = None + self.keep = None + + def finalize_options(self): + if self.match is None: + raise DistutilsOptionError( + "Must specify one or more (comma-separated) match patterns " + "(e.g. '.zip' or '.egg')" + ) + if self.keep is None: + raise DistutilsOptionError("Must specify number of files to keep") + try: + self.keep = int(self.keep) + except ValueError: + raise DistutilsOptionError("--keep must be an integer") + if isinstance(self.match, six.string_types): + self.match = [ + convert_path(p.strip()) for p in self.match.split(',') + ] + self.set_undefined_options('bdist', ('dist_dir', 'dist_dir')) + + def run(self): + self.run_command("egg_info") + from glob import glob + + for pattern in self.match: + pattern = self.distribution.get_name() + '*' + pattern + files = glob(os.path.join(self.dist_dir, pattern)) + files = [(os.path.getmtime(f), f) for f in files] + files.sort() + files.reverse() + + log.info("%d file(s) matching %s", len(files), pattern) + files = files[self.keep:] + for (t, f) in files: + log.info("Deleting %s", f) + if not self.dry_run: + if os.path.isdir(f): + shutil.rmtree(f) + else: + os.unlink(f) diff --git a/venv/lib/python3.8/site-packages/setuptools/command/saveopts.py b/venv/lib/python3.8/site-packages/setuptools/command/saveopts.py new file mode 100644 index 0000000..611cec5 --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/command/saveopts.py @@ -0,0 +1,22 @@ +from setuptools.command.setopt import edit_config, option_base + + +class saveopts(option_base): + """Save command-line options to a file""" + + description = "save supplied options to setup.cfg or other config file" + + def run(self): + dist = self.distribution + settings = {} + + for cmd in dist.command_options: + + if cmd == 'saveopts': + continue # don't save our own options! + + for opt, (src, val) in dist.get_option_dict(cmd).items(): + if src == "command line": + settings.setdefault(cmd, {})[opt] = val + + edit_config(self.filename, settings, self.dry_run) diff --git a/venv/lib/python3.8/site-packages/setuptools/command/sdist.py b/venv/lib/python3.8/site-packages/setuptools/command/sdist.py new file mode 100644 index 0000000..a851453 --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/command/sdist.py @@ -0,0 +1,252 @@ +from distutils import log +import distutils.command.sdist as orig +import os +import sys +import io +import contextlib + +from setuptools.extern import six, ordered_set + +from .py36compat import sdist_add_defaults + +import pkg_resources + +_default_revctrl = list + + +def walk_revctrl(dirname=''): + """Find all files under revision control""" + for ep in pkg_resources.iter_entry_points('setuptools.file_finders'): + for item in ep.load()(dirname): + yield item + + +class sdist(sdist_add_defaults, orig.sdist): + """Smart sdist that finds anything supported by revision control""" + + user_options = [ + ('formats=', None, + "formats for source distribution (comma-separated list)"), + ('keep-temp', 'k', + "keep the distribution tree around after creating " + + "archive file(s)"), + ('dist-dir=', 'd', + "directory to put the source distribution archive(s) in " + "[default: dist]"), + ] + + negative_opt = {} + + README_EXTENSIONS = ['', '.rst', '.txt', '.md'] + READMES = tuple('README{0}'.format(ext) for ext in README_EXTENSIONS) + + def run(self): + self.run_command('egg_info') + ei_cmd = self.get_finalized_command('egg_info') + self.filelist = ei_cmd.filelist + self.filelist.append(os.path.join(ei_cmd.egg_info, 'SOURCES.txt')) + self.check_readme() + + # Run sub commands + for cmd_name in self.get_sub_commands(): + self.run_command(cmd_name) + + self.make_distribution() + + dist_files = getattr(self.distribution, 'dist_files', []) + for file in self.archive_files: + data = ('sdist', '', file) + if data not in dist_files: + dist_files.append(data) + + def initialize_options(self): + orig.sdist.initialize_options(self) + + self._default_to_gztar() + + def _default_to_gztar(self): + # only needed on Python prior to 3.6. + if sys.version_info >= (3, 6, 0, 'beta', 1): + return + self.formats = ['gztar'] + + def make_distribution(self): + """ + Workaround for #516 + """ + with self._remove_os_link(): + orig.sdist.make_distribution(self) + + @staticmethod + @contextlib.contextmanager + def _remove_os_link(): + """ + In a context, remove and restore os.link if it exists + """ + + class NoValue: + pass + + orig_val = getattr(os, 'link', NoValue) + try: + del os.link + except Exception: + pass + try: + yield + finally: + if orig_val is not NoValue: + setattr(os, 'link', orig_val) + + def __read_template_hack(self): + # This grody hack closes the template file (MANIFEST.in) if an + # exception occurs during read_template. + # Doing so prevents an error when easy_install attempts to delete the + # file. + try: + orig.sdist.read_template(self) + except Exception: + _, _, tb = sys.exc_info() + tb.tb_next.tb_frame.f_locals['template'].close() + raise + + # Beginning with Python 2.7.2, 3.1.4, and 3.2.1, this leaky file handle + # has been fixed, so only override the method if we're using an earlier + # Python. + has_leaky_handle = ( + sys.version_info < (2, 7, 2) + or (3, 0) <= sys.version_info < (3, 1, 4) + or (3, 2) <= sys.version_info < (3, 2, 1) + ) + if has_leaky_handle: + read_template = __read_template_hack + + def _add_defaults_optional(self): + if six.PY2: + sdist_add_defaults._add_defaults_optional(self) + else: + super()._add_defaults_optional() + if os.path.isfile('pyproject.toml'): + self.filelist.append('pyproject.toml') + + def _add_defaults_python(self): + """getting python files""" + if self.distribution.has_pure_modules(): + build_py = self.get_finalized_command('build_py') + self.filelist.extend(build_py.get_source_files()) + self._add_data_files(self._safe_data_files(build_py)) + + def _safe_data_files(self, build_py): + """ + Extracting data_files from build_py is known to cause + infinite recursion errors when `include_package_data` + is enabled, so suppress it in that case. + """ + if self.distribution.include_package_data: + return () + return build_py.data_files + + def _add_data_files(self, data_files): + """ + Add data files as found in build_py.data_files. + """ + self.filelist.extend( + os.path.join(src_dir, name) + for _, src_dir, _, filenames in data_files + for name in filenames + ) + + def _add_defaults_data_files(self): + try: + if six.PY2: + sdist_add_defaults._add_defaults_data_files(self) + else: + super()._add_defaults_data_files() + except TypeError: + log.warn("data_files contains unexpected objects") + + def check_readme(self): + for f in self.READMES: + if os.path.exists(f): + return + else: + self.warn( + "standard file not found: should have one of " + + ', '.join(self.READMES) + ) + + def make_release_tree(self, base_dir, files): + orig.sdist.make_release_tree(self, base_dir, files) + + # Save any egg_info command line options used to create this sdist + dest = os.path.join(base_dir, 'setup.cfg') + if hasattr(os, 'link') and os.path.exists(dest): + # unlink and re-copy, since it might be hard-linked, and + # we don't want to change the source version + os.unlink(dest) + self.copy_file('setup.cfg', dest) + + self.get_finalized_command('egg_info').save_version_info(dest) + + def _manifest_is_not_generated(self): + # check for special comment used in 2.7.1 and higher + if not os.path.isfile(self.manifest): + return False + + with io.open(self.manifest, 'rb') as fp: + first_line = fp.readline() + return (first_line != + '# file GENERATED by distutils, do NOT edit\n'.encode()) + + def read_manifest(self): + """Read the manifest file (named by 'self.manifest') and use it to + fill in 'self.filelist', the list of files to include in the source + distribution. + """ + log.info("reading manifest file '%s'", self.manifest) + manifest = open(self.manifest, 'rb') + for line in manifest: + # The manifest must contain UTF-8. See #303. + if six.PY3: + try: + line = line.decode('UTF-8') + except UnicodeDecodeError: + log.warn("%r not UTF-8 decodable -- skipping" % line) + continue + # ignore comments and blank lines + line = line.strip() + if line.startswith('#') or not line: + continue + self.filelist.append(line) + manifest.close() + + def check_license(self): + """Checks if license_file' or 'license_files' is configured and adds any + valid paths to 'self.filelist'. + """ + + files = ordered_set.OrderedSet() + + opts = self.distribution.get_option_dict('metadata') + + # ignore the source of the value + _, license_file = opts.get('license_file', (None, None)) + + if license_file is None: + log.debug("'license_file' option was not specified") + else: + files.add(license_file) + + try: + files.update(self.distribution.metadata.license_files) + except TypeError: + log.warn("warning: 'license_files' option is malformed") + + for f in files: + if not os.path.exists(f): + log.warn( + "warning: Failed to find the configured license file '%s'", + f) + files.remove(f) + + self.filelist.extend(files) diff --git a/venv/lib/python3.8/site-packages/setuptools/command/setopt.py b/venv/lib/python3.8/site-packages/setuptools/command/setopt.py new file mode 100644 index 0000000..7e57cc0 --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/command/setopt.py @@ -0,0 +1,149 @@ +from distutils.util import convert_path +from distutils import log +from distutils.errors import DistutilsOptionError +import distutils +import os + +from setuptools.extern.six.moves import configparser + +from setuptools import Command + +__all__ = ['config_file', 'edit_config', 'option_base', 'setopt'] + + +def config_file(kind="local"): + """Get the filename of the distutils, local, global, or per-user config + + `kind` must be one of "local", "global", or "user" + """ + if kind == 'local': + return 'setup.cfg' + if kind == 'global': + return os.path.join( + os.path.dirname(distutils.__file__), 'distutils.cfg' + ) + if kind == 'user': + dot = os.name == 'posix' and '.' or '' + return os.path.expanduser(convert_path("~/%spydistutils.cfg" % dot)) + raise ValueError( + "config_file() type must be 'local', 'global', or 'user'", kind + ) + + +def edit_config(filename, settings, dry_run=False): + """Edit a configuration file to include `settings` + + `settings` is a dictionary of dictionaries or ``None`` values, keyed by + command/section name. A ``None`` value means to delete the entire section, + while a dictionary lists settings to be changed or deleted in that section. + A setting of ``None`` means to delete that setting. + """ + log.debug("Reading configuration from %s", filename) + opts = configparser.RawConfigParser() + opts.read([filename]) + for section, options in settings.items(): + if options is None: + log.info("Deleting section [%s] from %s", section, filename) + opts.remove_section(section) + else: + if not opts.has_section(section): + log.debug("Adding new section [%s] to %s", section, filename) + opts.add_section(section) + for option, value in options.items(): + if value is None: + log.debug( + "Deleting %s.%s from %s", + section, option, filename + ) + opts.remove_option(section, option) + if not opts.options(section): + log.info("Deleting empty [%s] section from %s", + section, filename) + opts.remove_section(section) + else: + log.debug( + "Setting %s.%s to %r in %s", + section, option, value, filename + ) + opts.set(section, option, value) + + log.info("Writing %s", filename) + if not dry_run: + with open(filename, 'w') as f: + opts.write(f) + + +class option_base(Command): + """Abstract base class for commands that mess with config files""" + + user_options = [ + ('global-config', 'g', + "save options to the site-wide distutils.cfg file"), + ('user-config', 'u', + "save options to the current user's pydistutils.cfg file"), + ('filename=', 'f', + "configuration file to use (default=setup.cfg)"), + ] + + boolean_options = [ + 'global-config', 'user-config', + ] + + def initialize_options(self): + self.global_config = None + self.user_config = None + self.filename = None + + def finalize_options(self): + filenames = [] + if self.global_config: + filenames.append(config_file('global')) + if self.user_config: + filenames.append(config_file('user')) + if self.filename is not None: + filenames.append(self.filename) + if not filenames: + filenames.append(config_file('local')) + if len(filenames) > 1: + raise DistutilsOptionError( + "Must specify only one configuration file option", + filenames + ) + self.filename, = filenames + + +class setopt(option_base): + """Save command-line options to a file""" + + description = "set an option in setup.cfg or another config file" + + user_options = [ + ('command=', 'c', 'command to set an option for'), + ('option=', 'o', 'option to set'), + ('set-value=', 's', 'value of the option'), + ('remove', 'r', 'remove (unset) the value'), + ] + option_base.user_options + + boolean_options = option_base.boolean_options + ['remove'] + + def initialize_options(self): + option_base.initialize_options(self) + self.command = None + self.option = None + self.set_value = None + self.remove = None + + def finalize_options(self): + option_base.finalize_options(self) + if self.command is None or self.option is None: + raise DistutilsOptionError("Must specify --command *and* --option") + if self.set_value is None and not self.remove: + raise DistutilsOptionError("Must specify --set-value or --remove") + + def run(self): + edit_config( + self.filename, { + self.command: {self.option.replace('-', '_'): self.set_value} + }, + self.dry_run + ) diff --git a/venv/lib/python3.8/site-packages/setuptools/command/test.py b/venv/lib/python3.8/site-packages/setuptools/command/test.py new file mode 100644 index 0000000..c148b38 --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/command/test.py @@ -0,0 +1,279 @@ +import os +import operator +import sys +import contextlib +import itertools +import unittest +from distutils.errors import DistutilsError, DistutilsOptionError +from distutils import log +from unittest import TestLoader + +from setuptools.extern import six +from setuptools.extern.six.moves import map, filter + +from pkg_resources import (resource_listdir, resource_exists, normalize_path, + working_set, _namespace_packages, evaluate_marker, + add_activation_listener, require, EntryPoint) +from setuptools import Command +from .build_py import _unique_everseen + +__metaclass__ = type + + +class ScanningLoader(TestLoader): + + def __init__(self): + TestLoader.__init__(self) + self._visited = set() + + def loadTestsFromModule(self, module, pattern=None): + """Return a suite of all tests cases contained in the given module + + If the module is a package, load tests from all the modules in it. + If the module has an ``additional_tests`` function, call it and add + the return value to the tests. + """ + if module in self._visited: + return None + self._visited.add(module) + + tests = [] + tests.append(TestLoader.loadTestsFromModule(self, module)) + + if hasattr(module, "additional_tests"): + tests.append(module.additional_tests()) + + if hasattr(module, '__path__'): + for file in resource_listdir(module.__name__, ''): + if file.endswith('.py') and file != '__init__.py': + submodule = module.__name__ + '.' + file[:-3] + else: + if resource_exists(module.__name__, file + '/__init__.py'): + submodule = module.__name__ + '.' + file + else: + continue + tests.append(self.loadTestsFromName(submodule)) + + if len(tests) != 1: + return self.suiteClass(tests) + else: + return tests[0] # don't create a nested suite for only one return + + +# adapted from jaraco.classes.properties:NonDataProperty +class NonDataProperty: + def __init__(self, fget): + self.fget = fget + + def __get__(self, obj, objtype=None): + if obj is None: + return self + return self.fget(obj) + + +class test(Command): + """Command to run unit tests after in-place build""" + + description = "run unit tests after in-place build (deprecated)" + + user_options = [ + ('test-module=', 'm', "Run 'test_suite' in specified module"), + ('test-suite=', 's', + "Run single test, case or suite (e.g. 'module.test_suite')"), + ('test-runner=', 'r', "Test runner to use"), + ] + + def initialize_options(self): + self.test_suite = None + self.test_module = None + self.test_loader = None + self.test_runner = None + + def finalize_options(self): + + if self.test_suite and self.test_module: + msg = "You may specify a module or a suite, but not both" + raise DistutilsOptionError(msg) + + if self.test_suite is None: + if self.test_module is None: + self.test_suite = self.distribution.test_suite + else: + self.test_suite = self.test_module + ".test_suite" + + if self.test_loader is None: + self.test_loader = getattr(self.distribution, 'test_loader', None) + if self.test_loader is None: + self.test_loader = "setuptools.command.test:ScanningLoader" + if self.test_runner is None: + self.test_runner = getattr(self.distribution, 'test_runner', None) + + @NonDataProperty + def test_args(self): + return list(self._test_args()) + + def _test_args(self): + if not self.test_suite and sys.version_info >= (2, 7): + yield 'discover' + if self.verbose: + yield '--verbose' + if self.test_suite: + yield self.test_suite + + def with_project_on_sys_path(self, func): + """ + Backward compatibility for project_on_sys_path context. + """ + with self.project_on_sys_path(): + func() + + @contextlib.contextmanager + def project_on_sys_path(self, include_dists=[]): + with_2to3 = six.PY3 and getattr(self.distribution, 'use_2to3', False) + + if with_2to3: + # If we run 2to3 we can not do this inplace: + + # Ensure metadata is up-to-date + self.reinitialize_command('build_py', inplace=0) + self.run_command('build_py') + bpy_cmd = self.get_finalized_command("build_py") + build_path = normalize_path(bpy_cmd.build_lib) + + # Build extensions + self.reinitialize_command('egg_info', egg_base=build_path) + self.run_command('egg_info') + + self.reinitialize_command('build_ext', inplace=0) + self.run_command('build_ext') + else: + # Without 2to3 inplace works fine: + self.run_command('egg_info') + + # Build extensions in-place + self.reinitialize_command('build_ext', inplace=1) + self.run_command('build_ext') + + ei_cmd = self.get_finalized_command("egg_info") + + old_path = sys.path[:] + old_modules = sys.modules.copy() + + try: + project_path = normalize_path(ei_cmd.egg_base) + sys.path.insert(0, project_path) + working_set.__init__() + add_activation_listener(lambda dist: dist.activate()) + require('%s==%s' % (ei_cmd.egg_name, ei_cmd.egg_version)) + with self.paths_on_pythonpath([project_path]): + yield + finally: + sys.path[:] = old_path + sys.modules.clear() + sys.modules.update(old_modules) + working_set.__init__() + + @staticmethod + @contextlib.contextmanager + def paths_on_pythonpath(paths): + """ + Add the indicated paths to the head of the PYTHONPATH environment + variable so that subprocesses will also see the packages at + these paths. + + Do this in a context that restores the value on exit. + """ + nothing = object() + orig_pythonpath = os.environ.get('PYTHONPATH', nothing) + current_pythonpath = os.environ.get('PYTHONPATH', '') + try: + prefix = os.pathsep.join(_unique_everseen(paths)) + to_join = filter(None, [prefix, current_pythonpath]) + new_path = os.pathsep.join(to_join) + if new_path: + os.environ['PYTHONPATH'] = new_path + yield + finally: + if orig_pythonpath is nothing: + os.environ.pop('PYTHONPATH', None) + else: + os.environ['PYTHONPATH'] = orig_pythonpath + + @staticmethod + def install_dists(dist): + """ + Install the requirements indicated by self.distribution and + return an iterable of the dists that were built. + """ + ir_d = dist.fetch_build_eggs(dist.install_requires) + tr_d = dist.fetch_build_eggs(dist.tests_require or []) + er_d = dist.fetch_build_eggs( + v for k, v in dist.extras_require.items() + if k.startswith(':') and evaluate_marker(k[1:]) + ) + return itertools.chain(ir_d, tr_d, er_d) + + def run(self): + self.announce( + "WARNING: Testing via this command is deprecated and will be " + "removed in a future version. Users looking for a generic test " + "entry point independent of test runner are encouraged to use " + "tox.", + log.WARN, + ) + + installed_dists = self.install_dists(self.distribution) + + cmd = ' '.join(self._argv) + if self.dry_run: + self.announce('skipping "%s" (dry run)' % cmd) + return + + self.announce('running "%s"' % cmd) + + paths = map(operator.attrgetter('location'), installed_dists) + with self.paths_on_pythonpath(paths): + with self.project_on_sys_path(): + self.run_tests() + + def run_tests(self): + # Purge modules under test from sys.modules. The test loader will + # re-import them from the build location. Required when 2to3 is used + # with namespace packages. + if six.PY3 and getattr(self.distribution, 'use_2to3', False): + module = self.test_suite.split('.')[0] + if module in _namespace_packages: + del_modules = [] + if module in sys.modules: + del_modules.append(module) + module += '.' + for name in sys.modules: + if name.startswith(module): + del_modules.append(name) + list(map(sys.modules.__delitem__, del_modules)) + + test = unittest.main( + None, None, self._argv, + testLoader=self._resolve_as_ep(self.test_loader), + testRunner=self._resolve_as_ep(self.test_runner), + exit=False, + ) + if not test.result.wasSuccessful(): + msg = 'Test failed: %s' % test.result + self.announce(msg, log.ERROR) + raise DistutilsError(msg) + + @property + def _argv(self): + return ['unittest'] + self.test_args + + @staticmethod + def _resolve_as_ep(val): + """ + Load the indicated attribute value, called, as a as if it were + specified as an entry point. + """ + if val is None: + return + parsed = EntryPoint.parse("x=" + val) + return parsed.resolve()() diff --git a/venv/lib/python3.8/site-packages/setuptools/command/upload.py b/venv/lib/python3.8/site-packages/setuptools/command/upload.py new file mode 100644 index 0000000..ec7f81e --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/command/upload.py @@ -0,0 +1,17 @@ +from distutils import log +from distutils.command import upload as orig + +from setuptools.errors import RemovedCommandError + + +class upload(orig.upload): + """Formerly used to upload packages to PyPI.""" + + def run(self): + msg = ( + "The upload command has been removed, use twine to upload " + + "instead (https://pypi.org/p/twine)" + ) + + self.announce("ERROR: " + msg, log.ERROR) + raise RemovedCommandError(msg) diff --git a/venv/lib/python3.8/site-packages/setuptools/command/upload_docs.py b/venv/lib/python3.8/site-packages/setuptools/command/upload_docs.py new file mode 100644 index 0000000..07aa564 --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/command/upload_docs.py @@ -0,0 +1,206 @@ +# -*- coding: utf-8 -*- +"""upload_docs + +Implements a Distutils 'upload_docs' subcommand (upload documentation to +PyPI's pythonhosted.org). +""" + +from base64 import standard_b64encode +from distutils import log +from distutils.errors import DistutilsOptionError +import os +import socket +import zipfile +import tempfile +import shutil +import itertools +import functools + +from setuptools.extern import six +from setuptools.extern.six.moves import http_client, urllib + +from pkg_resources import iter_entry_points +from .upload import upload + + +def _encode(s): + errors = 'surrogateescape' if six.PY3 else 'strict' + return s.encode('utf-8', errors) + + +class upload_docs(upload): + # override the default repository as upload_docs isn't + # supported by Warehouse (and won't be). + DEFAULT_REPOSITORY = 'https://pypi.python.org/pypi/' + + description = 'Upload documentation to PyPI' + + user_options = [ + ('repository=', 'r', + "url of repository [default: %s]" % upload.DEFAULT_REPOSITORY), + ('show-response', None, + 'display full response text from server'), + ('upload-dir=', None, 'directory to upload'), + ] + boolean_options = upload.boolean_options + + def has_sphinx(self): + if self.upload_dir is None: + for ep in iter_entry_points('distutils.commands', 'build_sphinx'): + return True + + sub_commands = [('build_sphinx', has_sphinx)] + + def initialize_options(self): + upload.initialize_options(self) + self.upload_dir = None + self.target_dir = None + + def finalize_options(self): + upload.finalize_options(self) + if self.upload_dir is None: + if self.has_sphinx(): + build_sphinx = self.get_finalized_command('build_sphinx') + self.target_dir = build_sphinx.builder_target_dir + else: + build = self.get_finalized_command('build') + self.target_dir = os.path.join(build.build_base, 'docs') + else: + self.ensure_dirname('upload_dir') + self.target_dir = self.upload_dir + if 'pypi.python.org' in self.repository: + log.warn("Upload_docs command is deprecated. Use RTD instead.") + self.announce('Using upload directory %s' % self.target_dir) + + def create_zipfile(self, filename): + zip_file = zipfile.ZipFile(filename, "w") + try: + self.mkpath(self.target_dir) # just in case + for root, dirs, files in os.walk(self.target_dir): + if root == self.target_dir and not files: + tmpl = "no files found in upload directory '%s'" + raise DistutilsOptionError(tmpl % self.target_dir) + for name in files: + full = os.path.join(root, name) + relative = root[len(self.target_dir):].lstrip(os.path.sep) + dest = os.path.join(relative, name) + zip_file.write(full, dest) + finally: + zip_file.close() + + def run(self): + # Run sub commands + for cmd_name in self.get_sub_commands(): + self.run_command(cmd_name) + + tmp_dir = tempfile.mkdtemp() + name = self.distribution.metadata.get_name() + zip_file = os.path.join(tmp_dir, "%s.zip" % name) + try: + self.create_zipfile(zip_file) + self.upload_file(zip_file) + finally: + shutil.rmtree(tmp_dir) + + @staticmethod + def _build_part(item, sep_boundary): + key, values = item + title = '\nContent-Disposition: form-data; name="%s"' % key + # handle multiple entries for the same name + if not isinstance(values, list): + values = [values] + for value in values: + if isinstance(value, tuple): + title += '; filename="%s"' % value[0] + value = value[1] + else: + value = _encode(value) + yield sep_boundary + yield _encode(title) + yield b"\n\n" + yield value + if value and value[-1:] == b'\r': + yield b'\n' # write an extra newline (lurve Macs) + + @classmethod + def _build_multipart(cls, data): + """ + Build up the MIME payload for the POST data + """ + boundary = b'--------------GHSKFJDLGDS7543FJKLFHRE75642756743254' + sep_boundary = b'\n--' + boundary + end_boundary = sep_boundary + b'--' + end_items = end_boundary, b"\n", + builder = functools.partial( + cls._build_part, + sep_boundary=sep_boundary, + ) + part_groups = map(builder, data.items()) + parts = itertools.chain.from_iterable(part_groups) + body_items = itertools.chain(parts, end_items) + content_type = 'multipart/form-data; boundary=%s' % boundary.decode('ascii') + return b''.join(body_items), content_type + + def upload_file(self, filename): + with open(filename, 'rb') as f: + content = f.read() + meta = self.distribution.metadata + data = { + ':action': 'doc_upload', + 'name': meta.get_name(), + 'content': (os.path.basename(filename), content), + } + # set up the authentication + credentials = _encode(self.username + ':' + self.password) + credentials = standard_b64encode(credentials) + if six.PY3: + credentials = credentials.decode('ascii') + auth = "Basic " + credentials + + body, ct = self._build_multipart(data) + + msg = "Submitting documentation to %s" % (self.repository) + self.announce(msg, log.INFO) + + # build the Request + # We can't use urllib2 since we need to send the Basic + # auth right with the first request + schema, netloc, url, params, query, fragments = \ + urllib.parse.urlparse(self.repository) + assert not params and not query and not fragments + if schema == 'http': + conn = http_client.HTTPConnection(netloc) + elif schema == 'https': + conn = http_client.HTTPSConnection(netloc) + else: + raise AssertionError("unsupported schema " + schema) + + data = '' + try: + conn.connect() + conn.putrequest("POST", url) + content_type = ct + conn.putheader('Content-type', content_type) + conn.putheader('Content-length', str(len(body))) + conn.putheader('Authorization', auth) + conn.endheaders() + conn.send(body) + except socket.error as e: + self.announce(str(e), log.ERROR) + return + + r = conn.getresponse() + if r.status == 200: + msg = 'Server response (%s): %s' % (r.status, r.reason) + self.announce(msg, log.INFO) + elif r.status == 301: + location = r.getheader('Location') + if location is None: + location = 'https://pythonhosted.org/%s/' % meta.get_name() + msg = 'Upload successful. Visit %s' % location + self.announce(msg, log.INFO) + else: + msg = 'Upload failed (%s): %s' % (r.status, r.reason) + self.announce(msg, log.ERROR) + if self.show_response: + print('-' * 75, r.read(), '-' * 75) diff --git a/venv/lib/python3.8/site-packages/setuptools/config.py b/venv/lib/python3.8/site-packages/setuptools/config.py new file mode 100644 index 0000000..9b9a0c4 --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/config.py @@ -0,0 +1,659 @@ +from __future__ import absolute_import, unicode_literals +import io +import os +import sys + +import warnings +import functools +from collections import defaultdict +from functools import partial +from functools import wraps +from importlib import import_module + +from distutils.errors import DistutilsOptionError, DistutilsFileError +from setuptools.extern.packaging.version import LegacyVersion, parse +from setuptools.extern.packaging.specifiers import SpecifierSet +from setuptools.extern.six import string_types, PY3 + + +__metaclass__ = type + + +def read_configuration( + filepath, find_others=False, ignore_option_errors=False): + """Read given configuration file and returns options from it as a dict. + + :param str|unicode filepath: Path to configuration file + to get options from. + + :param bool find_others: Whether to search for other configuration files + which could be on in various places. + + :param bool ignore_option_errors: Whether to silently ignore + options, values of which could not be resolved (e.g. due to exceptions + in directives such as file:, attr:, etc.). + If False exceptions are propagated as expected. + + :rtype: dict + """ + from setuptools.dist import Distribution, _Distribution + + filepath = os.path.abspath(filepath) + + if not os.path.isfile(filepath): + raise DistutilsFileError( + 'Configuration file %s does not exist.' % filepath) + + current_directory = os.getcwd() + os.chdir(os.path.dirname(filepath)) + + try: + dist = Distribution() + + filenames = dist.find_config_files() if find_others else [] + if filepath not in filenames: + filenames.append(filepath) + + _Distribution.parse_config_files(dist, filenames=filenames) + + handlers = parse_configuration( + dist, dist.command_options, + ignore_option_errors=ignore_option_errors) + + finally: + os.chdir(current_directory) + + return configuration_to_dict(handlers) + + +def _get_option(target_obj, key): + """ + Given a target object and option key, get that option from + the target object, either through a get_{key} method or + from an attribute directly. + """ + getter_name = 'get_{key}'.format(**locals()) + by_attribute = functools.partial(getattr, target_obj, key) + getter = getattr(target_obj, getter_name, by_attribute) + return getter() + + +def configuration_to_dict(handlers): + """Returns configuration data gathered by given handlers as a dict. + + :param list[ConfigHandler] handlers: Handlers list, + usually from parse_configuration() + + :rtype: dict + """ + config_dict = defaultdict(dict) + + for handler in handlers: + for option in handler.set_options: + value = _get_option(handler.target_obj, option) + config_dict[handler.section_prefix][option] = value + + return config_dict + + +def parse_configuration( + distribution, command_options, ignore_option_errors=False): + """Performs additional parsing of configuration options + for a distribution. + + Returns a list of used option handlers. + + :param Distribution distribution: + :param dict command_options: + :param bool ignore_option_errors: Whether to silently ignore + options, values of which could not be resolved (e.g. due to exceptions + in directives such as file:, attr:, etc.). + If False exceptions are propagated as expected. + :rtype: list + """ + options = ConfigOptionsHandler( + distribution, command_options, ignore_option_errors) + options.parse() + + meta = ConfigMetadataHandler( + distribution.metadata, command_options, ignore_option_errors, + distribution.package_dir) + meta.parse() + + return meta, options + + +class ConfigHandler: + """Handles metadata supplied in configuration files.""" + + section_prefix = None + """Prefix for config sections handled by this handler. + Must be provided by class heirs. + + """ + + aliases = {} + """Options aliases. + For compatibility with various packages. E.g.: d2to1 and pbr. + Note: `-` in keys is replaced with `_` by config parser. + + """ + + def __init__(self, target_obj, options, ignore_option_errors=False): + sections = {} + + section_prefix = self.section_prefix + for section_name, section_options in options.items(): + if not section_name.startswith(section_prefix): + continue + + section_name = section_name.replace(section_prefix, '').strip('.') + sections[section_name] = section_options + + self.ignore_option_errors = ignore_option_errors + self.target_obj = target_obj + self.sections = sections + self.set_options = [] + + @property + def parsers(self): + """Metadata item name to parser function mapping.""" + raise NotImplementedError( + '%s must provide .parsers property' % self.__class__.__name__) + + def __setitem__(self, option_name, value): + unknown = tuple() + target_obj = self.target_obj + + # Translate alias into real name. + option_name = self.aliases.get(option_name, option_name) + + current_value = getattr(target_obj, option_name, unknown) + + if current_value is unknown: + raise KeyError(option_name) + + if current_value: + # Already inhabited. Skipping. + return + + skip_option = False + parser = self.parsers.get(option_name) + if parser: + try: + value = parser(value) + + except Exception: + skip_option = True + if not self.ignore_option_errors: + raise + + if skip_option: + return + + setter = getattr(target_obj, 'set_%s' % option_name, None) + if setter is None: + setattr(target_obj, option_name, value) + else: + setter(value) + + self.set_options.append(option_name) + + @classmethod + def _parse_list(cls, value, separator=','): + """Represents value as a list. + + Value is split either by separator (defaults to comma) or by lines. + + :param value: + :param separator: List items separator character. + :rtype: list + """ + if isinstance(value, list): # _get_parser_compound case + return value + + if '\n' in value: + value = value.splitlines() + else: + value = value.split(separator) + + return [chunk.strip() for chunk in value if chunk.strip()] + + @classmethod + def _parse_dict(cls, value): + """Represents value as a dict. + + :param value: + :rtype: dict + """ + separator = '=' + result = {} + for line in cls._parse_list(value): + key, sep, val = line.partition(separator) + if sep != separator: + raise DistutilsOptionError( + 'Unable to parse option value to dict: %s' % value) + result[key.strip()] = val.strip() + + return result + + @classmethod + def _parse_bool(cls, value): + """Represents value as boolean. + + :param value: + :rtype: bool + """ + value = value.lower() + return value in ('1', 'true', 'yes') + + @classmethod + def _exclude_files_parser(cls, key): + """Returns a parser function to make sure field inputs + are not files. + + Parses a value after getting the key so error messages are + more informative. + + :param key: + :rtype: callable + """ + def parser(value): + exclude_directive = 'file:' + if value.startswith(exclude_directive): + raise ValueError( + 'Only strings are accepted for the {0} field, ' + 'files are not accepted'.format(key)) + return value + return parser + + @classmethod + def _parse_file(cls, value): + """Represents value as a string, allowing including text + from nearest files using `file:` directive. + + Directive is sandboxed and won't reach anything outside + directory with setup.py. + + Examples: + file: README.rst, CHANGELOG.md, src/file.txt + + :param str value: + :rtype: str + """ + include_directive = 'file:' + + if not isinstance(value, string_types): + return value + + if not value.startswith(include_directive): + return value + + spec = value[len(include_directive):] + filepaths = (os.path.abspath(path.strip()) for path in spec.split(',')) + return '\n'.join( + cls._read_file(path) + for path in filepaths + if (cls._assert_local(path) or True) + and os.path.isfile(path) + ) + + @staticmethod + def _assert_local(filepath): + if not filepath.startswith(os.getcwd()): + raise DistutilsOptionError( + '`file:` directive can not access %s' % filepath) + + @staticmethod + def _read_file(filepath): + with io.open(filepath, encoding='utf-8') as f: + return f.read() + + @classmethod + def _parse_attr(cls, value, package_dir=None): + """Represents value as a module attribute. + + Examples: + attr: package.attr + attr: package.module.attr + + :param str value: + :rtype: str + """ + attr_directive = 'attr:' + if not value.startswith(attr_directive): + return value + + attrs_path = value.replace(attr_directive, '').strip().split('.') + attr_name = attrs_path.pop() + + module_name = '.'.join(attrs_path) + module_name = module_name or '__init__' + + parent_path = os.getcwd() + if package_dir: + if attrs_path[0] in package_dir: + # A custom path was specified for the module we want to import + custom_path = package_dir[attrs_path[0]] + parts = custom_path.rsplit('/', 1) + if len(parts) > 1: + parent_path = os.path.join(os.getcwd(), parts[0]) + module_name = parts[1] + else: + module_name = custom_path + elif '' in package_dir: + # A custom parent directory was specified for all root modules + parent_path = os.path.join(os.getcwd(), package_dir['']) + sys.path.insert(0, parent_path) + try: + module = import_module(module_name) + value = getattr(module, attr_name) + + finally: + sys.path = sys.path[1:] + + return value + + @classmethod + def _get_parser_compound(cls, *parse_methods): + """Returns parser function to represents value as a list. + + Parses a value applying given methods one after another. + + :param parse_methods: + :rtype: callable + """ + def parse(value): + parsed = value + + for method in parse_methods: + parsed = method(parsed) + + return parsed + + return parse + + @classmethod + def _parse_section_to_dict(cls, section_options, values_parser=None): + """Parses section options into a dictionary. + + Optionally applies a given parser to values. + + :param dict section_options: + :param callable values_parser: + :rtype: dict + """ + value = {} + values_parser = values_parser or (lambda val: val) + for key, (_, val) in section_options.items(): + value[key] = values_parser(val) + return value + + def parse_section(self, section_options): + """Parses configuration file section. + + :param dict section_options: + """ + for (name, (_, value)) in section_options.items(): + try: + self[name] = value + + except KeyError: + pass # Keep silent for a new option may appear anytime. + + def parse(self): + """Parses configuration file items from one + or more related sections. + + """ + for section_name, section_options in self.sections.items(): + + method_postfix = '' + if section_name: # [section.option] variant + method_postfix = '_%s' % section_name + + section_parser_method = getattr( + self, + # Dots in section names are translated into dunderscores. + ('parse_section%s' % method_postfix).replace('.', '__'), + None) + + if section_parser_method is None: + raise DistutilsOptionError( + 'Unsupported distribution option section: [%s.%s]' % ( + self.section_prefix, section_name)) + + section_parser_method(section_options) + + def _deprecated_config_handler(self, func, msg, warning_class): + """ this function will wrap around parameters that are deprecated + + :param msg: deprecation message + :param warning_class: class of warning exception to be raised + :param func: function to be wrapped around + """ + @wraps(func) + def config_handler(*args, **kwargs): + warnings.warn(msg, warning_class) + return func(*args, **kwargs) + + return config_handler + + +class ConfigMetadataHandler(ConfigHandler): + + section_prefix = 'metadata' + + aliases = { + 'home_page': 'url', + 'summary': 'description', + 'classifier': 'classifiers', + 'platform': 'platforms', + } + + strict_mode = False + """We need to keep it loose, to be partially compatible with + `pbr` and `d2to1` packages which also uses `metadata` section. + + """ + + def __init__(self, target_obj, options, ignore_option_errors=False, + package_dir=None): + super(ConfigMetadataHandler, self).__init__(target_obj, options, + ignore_option_errors) + self.package_dir = package_dir + + @property + def parsers(self): + """Metadata item name to parser function mapping.""" + parse_list = self._parse_list + parse_file = self._parse_file + parse_dict = self._parse_dict + exclude_files_parser = self._exclude_files_parser + + return { + 'platforms': parse_list, + 'keywords': parse_list, + 'provides': parse_list, + 'requires': self._deprecated_config_handler( + parse_list, + "The requires parameter is deprecated, please use " + "install_requires for runtime dependencies.", + DeprecationWarning), + 'obsoletes': parse_list, + 'classifiers': self._get_parser_compound(parse_file, parse_list), + 'license': exclude_files_parser('license'), + 'license_files': parse_list, + 'description': parse_file, + 'long_description': parse_file, + 'version': self._parse_version, + 'project_urls': parse_dict, + } + + def _parse_version(self, value): + """Parses `version` option value. + + :param value: + :rtype: str + + """ + version = self._parse_file(value) + + if version != value: + version = version.strip() + # Be strict about versions loaded from file because it's easy to + # accidentally include newlines and other unintended content + if isinstance(parse(version), LegacyVersion): + tmpl = ( + 'Version loaded from {value} does not ' + 'comply with PEP 440: {version}' + ) + raise DistutilsOptionError(tmpl.format(**locals())) + + return version + + version = self._parse_attr(value, self.package_dir) + + if callable(version): + version = version() + + if not isinstance(version, string_types): + if hasattr(version, '__iter__'): + version = '.'.join(map(str, version)) + else: + version = '%s' % version + + return version + + +class ConfigOptionsHandler(ConfigHandler): + + section_prefix = 'options' + + @property + def parsers(self): + """Metadata item name to parser function mapping.""" + parse_list = self._parse_list + parse_list_semicolon = partial(self._parse_list, separator=';') + parse_bool = self._parse_bool + parse_dict = self._parse_dict + + return { + 'zip_safe': parse_bool, + 'use_2to3': parse_bool, + 'include_package_data': parse_bool, + 'package_dir': parse_dict, + 'use_2to3_fixers': parse_list, + 'use_2to3_exclude_fixers': parse_list, + 'convert_2to3_doctests': parse_list, + 'scripts': parse_list, + 'eager_resources': parse_list, + 'dependency_links': parse_list, + 'namespace_packages': parse_list, + 'install_requires': parse_list_semicolon, + 'setup_requires': parse_list_semicolon, + 'tests_require': parse_list_semicolon, + 'packages': self._parse_packages, + 'entry_points': self._parse_file, + 'py_modules': parse_list, + 'python_requires': SpecifierSet, + } + + def _parse_packages(self, value): + """Parses `packages` option value. + + :param value: + :rtype: list + """ + find_directives = ['find:', 'find_namespace:'] + trimmed_value = value.strip() + + if trimmed_value not in find_directives: + return self._parse_list(value) + + findns = trimmed_value == find_directives[1] + if findns and not PY3: + raise DistutilsOptionError( + 'find_namespace: directive is unsupported on Python < 3.3') + + # Read function arguments from a dedicated section. + find_kwargs = self.parse_section_packages__find( + self.sections.get('packages.find', {})) + + if findns: + from setuptools import find_namespace_packages as find_packages + else: + from setuptools import find_packages + + return find_packages(**find_kwargs) + + def parse_section_packages__find(self, section_options): + """Parses `packages.find` configuration file section. + + To be used in conjunction with _parse_packages(). + + :param dict section_options: + """ + section_data = self._parse_section_to_dict( + section_options, self._parse_list) + + valid_keys = ['where', 'include', 'exclude'] + + find_kwargs = dict( + [(k, v) for k, v in section_data.items() if k in valid_keys and v]) + + where = find_kwargs.get('where') + if where is not None: + find_kwargs['where'] = where[0] # cast list to single val + + return find_kwargs + + def parse_section_entry_points(self, section_options): + """Parses `entry_points` configuration file section. + + :param dict section_options: + """ + parsed = self._parse_section_to_dict(section_options, self._parse_list) + self['entry_points'] = parsed + + def _parse_package_data(self, section_options): + parsed = self._parse_section_to_dict(section_options, self._parse_list) + + root = parsed.get('*') + if root: + parsed[''] = root + del parsed['*'] + + return parsed + + def parse_section_package_data(self, section_options): + """Parses `package_data` configuration file section. + + :param dict section_options: + """ + self['package_data'] = self._parse_package_data(section_options) + + def parse_section_exclude_package_data(self, section_options): + """Parses `exclude_package_data` configuration file section. + + :param dict section_options: + """ + self['exclude_package_data'] = self._parse_package_data( + section_options) + + def parse_section_extras_require(self, section_options): + """Parses `extras_require` configuration file section. + + :param dict section_options: + """ + parse_list = partial(self._parse_list, separator=';') + self['extras_require'] = self._parse_section_to_dict( + section_options, parse_list) + + def parse_section_data_files(self, section_options): + """Parses `data_files` configuration file section. + + :param dict section_options: + """ + parsed = self._parse_section_to_dict(section_options, self._parse_list) + self['data_files'] = [(k, v) for k, v in parsed.items()] diff --git a/venv/lib/python3.8/site-packages/setuptools/dep_util.py b/venv/lib/python3.8/site-packages/setuptools/dep_util.py new file mode 100644 index 0000000..2931c13 --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/dep_util.py @@ -0,0 +1,23 @@ +from distutils.dep_util import newer_group + +# yes, this is was almost entirely copy-pasted from +# 'newer_pairwise()', this is just another convenience +# function. +def newer_pairwise_group(sources_groups, targets): + """Walk both arguments in parallel, testing if each source group is newer + than its corresponding target. Returns a pair of lists (sources_groups, + targets) where sources is newer than target, according to the semantics + of 'newer_group()'. + """ + if len(sources_groups) != len(targets): + raise ValueError("'sources_group' and 'targets' must be the same length") + + # build a pair of lists (sources_groups, targets) where source is newer + n_sources = [] + n_targets = [] + for i in range(len(sources_groups)): + if newer_group(sources_groups[i], targets[i]): + n_sources.append(sources_groups[i]) + n_targets.append(targets[i]) + + return n_sources, n_targets diff --git a/venv/lib/python3.8/site-packages/setuptools/depends.py b/venv/lib/python3.8/site-packages/setuptools/depends.py new file mode 100644 index 0000000..a37675c --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/depends.py @@ -0,0 +1,176 @@ +import sys +import marshal +import contextlib +from distutils.version import StrictVersion + +from .py33compat import Bytecode + +from .py27compat import find_module, PY_COMPILED, PY_FROZEN, PY_SOURCE +from . import py27compat + + +__all__ = [ + 'Require', 'find_module', 'get_module_constant', 'extract_constant' +] + + +class Require: + """A prerequisite to building or installing a distribution""" + + def __init__( + self, name, requested_version, module, homepage='', + attribute=None, format=None): + + if format is None and requested_version is not None: + format = StrictVersion + + if format is not None: + requested_version = format(requested_version) + if attribute is None: + attribute = '__version__' + + self.__dict__.update(locals()) + del self.self + + def full_name(self): + """Return full package/distribution name, w/version""" + if self.requested_version is not None: + return '%s-%s' % (self.name, self.requested_version) + return self.name + + def version_ok(self, version): + """Is 'version' sufficiently up-to-date?""" + return self.attribute is None or self.format is None or \ + str(version) != "unknown" and version >= self.requested_version + + def get_version(self, paths=None, default="unknown"): + """Get version number of installed module, 'None', or 'default' + + Search 'paths' for module. If not found, return 'None'. If found, + return the extracted version attribute, or 'default' if no version + attribute was specified, or the value cannot be determined without + importing the module. The version is formatted according to the + requirement's version format (if any), unless it is 'None' or the + supplied 'default'. + """ + + if self.attribute is None: + try: + f, p, i = find_module(self.module, paths) + if f: + f.close() + return default + except ImportError: + return None + + v = get_module_constant(self.module, self.attribute, default, paths) + + if v is not None and v is not default and self.format is not None: + return self.format(v) + + return v + + def is_present(self, paths=None): + """Return true if dependency is present on 'paths'""" + return self.get_version(paths) is not None + + def is_current(self, paths=None): + """Return true if dependency is present and up-to-date on 'paths'""" + version = self.get_version(paths) + if version is None: + return False + return self.version_ok(version) + + +def maybe_close(f): + @contextlib.contextmanager + def empty(): + yield + return + if not f: + return empty() + + return contextlib.closing(f) + + +def get_module_constant(module, symbol, default=-1, paths=None): + """Find 'module' by searching 'paths', and extract 'symbol' + + Return 'None' if 'module' does not exist on 'paths', or it does not define + 'symbol'. If the module defines 'symbol' as a constant, return the + constant. Otherwise, return 'default'.""" + + try: + f, path, (suffix, mode, kind) = info = find_module(module, paths) + except ImportError: + # Module doesn't exist + return None + + with maybe_close(f): + if kind == PY_COMPILED: + f.read(8) # skip magic & date + code = marshal.load(f) + elif kind == PY_FROZEN: + code = py27compat.get_frozen_object(module, paths) + elif kind == PY_SOURCE: + code = compile(f.read(), path, 'exec') + else: + # Not something we can parse; we'll have to import it. :( + imported = py27compat.get_module(module, paths, info) + return getattr(imported, symbol, None) + + return extract_constant(code, symbol, default) + + +def extract_constant(code, symbol, default=-1): + """Extract the constant value of 'symbol' from 'code' + + If the name 'symbol' is bound to a constant value by the Python code + object 'code', return that value. If 'symbol' is bound to an expression, + return 'default'. Otherwise, return 'None'. + + Return value is based on the first assignment to 'symbol'. 'symbol' must + be a global, or at least a non-"fast" local in the code block. That is, + only 'STORE_NAME' and 'STORE_GLOBAL' opcodes are checked, and 'symbol' + must be present in 'code.co_names'. + """ + if symbol not in code.co_names: + # name's not there, can't possibly be an assignment + return None + + name_idx = list(code.co_names).index(symbol) + + STORE_NAME = 90 + STORE_GLOBAL = 97 + LOAD_CONST = 100 + + const = default + + for byte_code in Bytecode(code): + op = byte_code.opcode + arg = byte_code.arg + + if op == LOAD_CONST: + const = code.co_consts[arg] + elif arg == name_idx and (op == STORE_NAME or op == STORE_GLOBAL): + return const + else: + const = default + + +def _update_globals(): + """ + Patch the globals to remove the objects not available on some platforms. + + XXX it'd be better to test assertions about bytecode instead. + """ + + if not sys.platform.startswith('java') and sys.platform != 'cli': + return + incompatible = 'extract_constant', 'get_module_constant' + for name in incompatible: + del globals()[name] + __all__.remove(name) + + +_update_globals() diff --git a/venv/lib/python3.8/site-packages/setuptools/dist.py b/venv/lib/python3.8/site-packages/setuptools/dist.py new file mode 100644 index 0000000..f22429e --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/dist.py @@ -0,0 +1,1274 @@ +# -*- coding: utf-8 -*- +__all__ = ['Distribution'] + +import io +import sys +import re +import os +import warnings +import numbers +import distutils.log +import distutils.core +import distutils.cmd +import distutils.dist +from distutils.util import strtobool +from distutils.debug import DEBUG +from distutils.fancy_getopt import translate_longopt +import itertools + +from collections import defaultdict +from email import message_from_file + +from distutils.errors import ( + DistutilsOptionError, DistutilsPlatformError, DistutilsSetupError, +) +from distutils.util import rfc822_escape +from distutils.version import StrictVersion + +from setuptools.extern import six +from setuptools.extern import packaging +from setuptools.extern import ordered_set +from setuptools.extern.six.moves import map, filter, filterfalse + +from . import SetuptoolsDeprecationWarning + +from setuptools.depends import Require +from setuptools import windows_support +from setuptools.monkey import get_unpatched +from setuptools.config import parse_configuration +import pkg_resources + +__import__('setuptools.extern.packaging.specifiers') +__import__('setuptools.extern.packaging.version') + + +def _get_unpatched(cls): + warnings.warn("Do not call this function", DistDeprecationWarning) + return get_unpatched(cls) + + +def get_metadata_version(self): + mv = getattr(self, 'metadata_version', None) + + if mv is None: + if self.long_description_content_type or self.provides_extras: + mv = StrictVersion('2.1') + elif (self.maintainer is not None or + self.maintainer_email is not None or + getattr(self, 'python_requires', None) is not None or + self.project_urls): + mv = StrictVersion('1.2') + elif (self.provides or self.requires or self.obsoletes or + self.classifiers or self.download_url): + mv = StrictVersion('1.1') + else: + mv = StrictVersion('1.0') + + self.metadata_version = mv + + return mv + + +def read_pkg_file(self, file): + """Reads the metadata values from a file object.""" + msg = message_from_file(file) + + def _read_field(name): + value = msg[name] + if value == 'UNKNOWN': + return None + return value + + def _read_list(name): + values = msg.get_all(name, None) + if values == []: + return None + return values + + self.metadata_version = StrictVersion(msg['metadata-version']) + self.name = _read_field('name') + self.version = _read_field('version') + self.description = _read_field('summary') + # we are filling author only. + self.author = _read_field('author') + self.maintainer = None + self.author_email = _read_field('author-email') + self.maintainer_email = None + self.url = _read_field('home-page') + self.license = _read_field('license') + + if 'download-url' in msg: + self.download_url = _read_field('download-url') + else: + self.download_url = None + + self.long_description = _read_field('description') + self.description = _read_field('summary') + + if 'keywords' in msg: + self.keywords = _read_field('keywords').split(',') + + self.platforms = _read_list('platform') + self.classifiers = _read_list('classifier') + + # PEP 314 - these fields only exist in 1.1 + if self.metadata_version == StrictVersion('1.1'): + self.requires = _read_list('requires') + self.provides = _read_list('provides') + self.obsoletes = _read_list('obsoletes') + else: + self.requires = None + self.provides = None + self.obsoletes = None + + +# Based on Python 3.5 version +def write_pkg_file(self, file): + """Write the PKG-INFO format data to a file object. + """ + version = self.get_metadata_version() + + if six.PY2: + def write_field(key, value): + file.write("%s: %s\n" % (key, self._encode_field(value))) + else: + def write_field(key, value): + file.write("%s: %s\n" % (key, value)) + + write_field('Metadata-Version', str(version)) + write_field('Name', self.get_name()) + write_field('Version', self.get_version()) + write_field('Summary', self.get_description()) + write_field('Home-page', self.get_url()) + + if version < StrictVersion('1.2'): + write_field('Author', self.get_contact()) + write_field('Author-email', self.get_contact_email()) + else: + optional_fields = ( + ('Author', 'author'), + ('Author-email', 'author_email'), + ('Maintainer', 'maintainer'), + ('Maintainer-email', 'maintainer_email'), + ) + + for field, attr in optional_fields: + attr_val = getattr(self, attr) + + if attr_val is not None: + write_field(field, attr_val) + + write_field('License', self.get_license()) + if self.download_url: + write_field('Download-URL', self.download_url) + for project_url in self.project_urls.items(): + write_field('Project-URL', '%s, %s' % project_url) + + long_desc = rfc822_escape(self.get_long_description()) + write_field('Description', long_desc) + + keywords = ','.join(self.get_keywords()) + if keywords: + write_field('Keywords', keywords) + + if version >= StrictVersion('1.2'): + for platform in self.get_platforms(): + write_field('Platform', platform) + else: + self._write_list(file, 'Platform', self.get_platforms()) + + self._write_list(file, 'Classifier', self.get_classifiers()) + + # PEP 314 + self._write_list(file, 'Requires', self.get_requires()) + self._write_list(file, 'Provides', self.get_provides()) + self._write_list(file, 'Obsoletes', self.get_obsoletes()) + + # Setuptools specific for PEP 345 + if hasattr(self, 'python_requires'): + write_field('Requires-Python', self.python_requires) + + # PEP 566 + if self.long_description_content_type: + write_field( + 'Description-Content-Type', + self.long_description_content_type + ) + if self.provides_extras: + for extra in sorted(self.provides_extras): + write_field('Provides-Extra', extra) + + +sequence = tuple, list + + +def check_importable(dist, attr, value): + try: + ep = pkg_resources.EntryPoint.parse('x=' + value) + assert not ep.extras + except (TypeError, ValueError, AttributeError, AssertionError): + raise DistutilsSetupError( + "%r must be importable 'module:attrs' string (got %r)" + % (attr, value) + ) + + +def assert_string_list(dist, attr, value): + """Verify that value is a string list""" + try: + # verify that value is a list or tuple to exclude unordered + # or single-use iterables + assert isinstance(value, (list, tuple)) + # verify that elements of value are strings + assert ''.join(value) != value + except (TypeError, ValueError, AttributeError, AssertionError): + raise DistutilsSetupError( + "%r must be a list of strings (got %r)" % (attr, value) + ) + + +def check_nsp(dist, attr, value): + """Verify that namespace packages are valid""" + ns_packages = value + assert_string_list(dist, attr, ns_packages) + for nsp in ns_packages: + if not dist.has_contents_for(nsp): + raise DistutilsSetupError( + "Distribution contains no modules or packages for " + + "namespace package %r" % nsp + ) + parent, sep, child = nsp.rpartition('.') + if parent and parent not in ns_packages: + distutils.log.warn( + "WARNING: %r is declared as a package namespace, but %r" + " is not: please correct this in setup.py", nsp, parent + ) + + +def check_extras(dist, attr, value): + """Verify that extras_require mapping is valid""" + try: + list(itertools.starmap(_check_extra, value.items())) + except (TypeError, ValueError, AttributeError): + raise DistutilsSetupError( + "'extras_require' must be a dictionary whose values are " + "strings or lists of strings containing valid project/version " + "requirement specifiers." + ) + + +def _check_extra(extra, reqs): + name, sep, marker = extra.partition(':') + if marker and pkg_resources.invalid_marker(marker): + raise DistutilsSetupError("Invalid environment marker: " + marker) + list(pkg_resources.parse_requirements(reqs)) + + +def assert_bool(dist, attr, value): + """Verify that value is True, False, 0, or 1""" + if bool(value) != value: + tmpl = "{attr!r} must be a boolean value (got {value!r})" + raise DistutilsSetupError(tmpl.format(attr=attr, value=value)) + + +def check_requirements(dist, attr, value): + """Verify that install_requires is a valid requirements list""" + try: + list(pkg_resources.parse_requirements(value)) + if isinstance(value, (dict, set)): + raise TypeError("Unordered types are not allowed") + except (TypeError, ValueError) as error: + tmpl = ( + "{attr!r} must be a string or list of strings " + "containing valid project/version requirement specifiers; {error}" + ) + raise DistutilsSetupError(tmpl.format(attr=attr, error=error)) + + +def check_specifier(dist, attr, value): + """Verify that value is a valid version specifier""" + try: + packaging.specifiers.SpecifierSet(value) + except packaging.specifiers.InvalidSpecifier as error: + tmpl = ( + "{attr!r} must be a string " + "containing valid version specifiers; {error}" + ) + raise DistutilsSetupError(tmpl.format(attr=attr, error=error)) + + +def check_entry_points(dist, attr, value): + """Verify that entry_points map is parseable""" + try: + pkg_resources.EntryPoint.parse_map(value) + except ValueError as e: + raise DistutilsSetupError(e) + + +def check_test_suite(dist, attr, value): + if not isinstance(value, six.string_types): + raise DistutilsSetupError("test_suite must be a string") + + +def check_package_data(dist, attr, value): + """Verify that value is a dictionary of package names to glob lists""" + if not isinstance(value, dict): + raise DistutilsSetupError( + "{!r} must be a dictionary mapping package names to lists of " + "string wildcard patterns".format(attr)) + for k, v in value.items(): + if not isinstance(k, six.string_types): + raise DistutilsSetupError( + "keys of {!r} dict must be strings (got {!r})" + .format(attr, k) + ) + assert_string_list(dist, 'values of {!r} dict'.format(attr), v) + + +def check_packages(dist, attr, value): + for pkgname in value: + if not re.match(r'\w+(\.\w+)*', pkgname): + distutils.log.warn( + "WARNING: %r not a valid package name; please use only " + ".-separated package names in setup.py", pkgname + ) + + +_Distribution = get_unpatched(distutils.core.Distribution) + + +class Distribution(_Distribution): + """Distribution with support for features, tests, and package data + + This is an enhanced version of 'distutils.dist.Distribution' that + effectively adds the following new optional keyword arguments to 'setup()': + + 'install_requires' -- a string or sequence of strings specifying project + versions that the distribution requires when installed, in the format + used by 'pkg_resources.require()'. They will be installed + automatically when the package is installed. If you wish to use + packages that are not available in PyPI, or want to give your users an + alternate download location, you can add a 'find_links' option to the + '[easy_install]' section of your project's 'setup.cfg' file, and then + setuptools will scan the listed web pages for links that satisfy the + requirements. + + 'extras_require' -- a dictionary mapping names of optional "extras" to the + additional requirement(s) that using those extras incurs. For example, + this:: + + extras_require = dict(reST = ["docutils>=0.3", "reSTedit"]) + + indicates that the distribution can optionally provide an extra + capability called "reST", but it can only be used if docutils and + reSTedit are installed. If the user installs your package using + EasyInstall and requests one of your extras, the corresponding + additional requirements will be installed if needed. + + 'features' **deprecated** -- a dictionary mapping option names to + 'setuptools.Feature' + objects. Features are a portion of the distribution that can be + included or excluded based on user options, inter-feature dependencies, + and availability on the current system. Excluded features are omitted + from all setup commands, including source and binary distributions, so + you can create multiple distributions from the same source tree. + Feature names should be valid Python identifiers, except that they may + contain the '-' (minus) sign. Features can be included or excluded + via the command line options '--with-X' and '--without-X', where 'X' is + the name of the feature. Whether a feature is included by default, and + whether you are allowed to control this from the command line, is + determined by the Feature object. See the 'Feature' class for more + information. + + 'test_suite' -- the name of a test suite to run for the 'test' command. + If the user runs 'python setup.py test', the package will be installed, + and the named test suite will be run. The format is the same as + would be used on a 'unittest.py' command line. That is, it is the + dotted name of an object to import and call to generate a test suite. + + 'package_data' -- a dictionary mapping package names to lists of filenames + or globs to use to find data files contained in the named packages. + If the dictionary has filenames or globs listed under '""' (the empty + string), those names will be searched for in every package, in addition + to any names for the specific package. Data files found using these + names/globs will be installed along with the package, in the same + location as the package. Note that globs are allowed to reference + the contents of non-package subdirectories, as long as you use '/' as + a path separator. (Globs are automatically converted to + platform-specific paths at runtime.) + + In addition to these new keywords, this class also has several new methods + for manipulating the distribution's contents. For example, the 'include()' + and 'exclude()' methods can be thought of as in-place add and subtract + commands that add or remove packages, modules, extensions, and so on from + the distribution. They are used by the feature subsystem to configure the + distribution for the included and excluded features. + """ + + _DISTUTILS_UNSUPPORTED_METADATA = { + 'long_description_content_type': None, + 'project_urls': dict, + 'provides_extras': ordered_set.OrderedSet, + 'license_files': ordered_set.OrderedSet, + } + + _patched_dist = None + + def patch_missing_pkg_info(self, attrs): + # Fake up a replacement for the data that would normally come from + # PKG-INFO, but which might not yet be built if this is a fresh + # checkout. + # + if not attrs or 'name' not in attrs or 'version' not in attrs: + return + key = pkg_resources.safe_name(str(attrs['name'])).lower() + dist = pkg_resources.working_set.by_key.get(key) + if dist is not None and not dist.has_metadata('PKG-INFO'): + dist._version = pkg_resources.safe_version(str(attrs['version'])) + self._patched_dist = dist + + def __init__(self, attrs=None): + have_package_data = hasattr(self, "package_data") + if not have_package_data: + self.package_data = {} + attrs = attrs or {} + if 'features' in attrs or 'require_features' in attrs: + Feature.warn_deprecated() + self.require_features = [] + self.features = {} + self.dist_files = [] + # Filter-out setuptools' specific options. + self.src_root = attrs.pop("src_root", None) + self.patch_missing_pkg_info(attrs) + self.dependency_links = attrs.pop('dependency_links', []) + self.setup_requires = attrs.pop('setup_requires', []) + for ep in pkg_resources.iter_entry_points('distutils.setup_keywords'): + vars(self).setdefault(ep.name, None) + _Distribution.__init__(self, { + k: v for k, v in attrs.items() + if k not in self._DISTUTILS_UNSUPPORTED_METADATA + }) + + # Fill-in missing metadata fields not supported by distutils. + # Note some fields may have been set by other tools (e.g. pbr) + # above; they are taken preferrentially to setup() arguments + for option, default in self._DISTUTILS_UNSUPPORTED_METADATA.items(): + for source in self.metadata.__dict__, attrs: + if option in source: + value = source[option] + break + else: + value = default() if default else None + setattr(self.metadata, option, value) + + if isinstance(self.metadata.version, numbers.Number): + # Some people apparently take "version number" too literally :) + self.metadata.version = str(self.metadata.version) + + if self.metadata.version is not None: + try: + ver = packaging.version.Version(self.metadata.version) + normalized_version = str(ver) + if self.metadata.version != normalized_version: + warnings.warn( + "Normalizing '%s' to '%s'" % ( + self.metadata.version, + normalized_version, + ) + ) + self.metadata.version = normalized_version + except (packaging.version.InvalidVersion, TypeError): + warnings.warn( + "The version specified (%r) is an invalid version, this " + "may not work as expected with newer versions of " + "setuptools, pip, and PyPI. Please see PEP 440 for more " + "details." % self.metadata.version + ) + self._finalize_requires() + + def _finalize_requires(self): + """ + Set `metadata.python_requires` and fix environment markers + in `install_requires` and `extras_require`. + """ + if getattr(self, 'python_requires', None): + self.metadata.python_requires = self.python_requires + + if getattr(self, 'extras_require', None): + for extra in self.extras_require.keys(): + # Since this gets called multiple times at points where the + # keys have become 'converted' extras, ensure that we are only + # truly adding extras we haven't seen before here. + extra = extra.split(':')[0] + if extra: + self.metadata.provides_extras.add(extra) + + self._convert_extras_requirements() + self._move_install_requirements_markers() + + def _convert_extras_requirements(self): + """ + Convert requirements in `extras_require` of the form + `"extra": ["barbazquux; {marker}"]` to + `"extra:{marker}": ["barbazquux"]`. + """ + spec_ext_reqs = getattr(self, 'extras_require', None) or {} + self._tmp_extras_require = defaultdict(list) + for section, v in spec_ext_reqs.items(): + # Do not strip empty sections. + self._tmp_extras_require[section] + for r in pkg_resources.parse_requirements(v): + suffix = self._suffix_for(r) + self._tmp_extras_require[section + suffix].append(r) + + @staticmethod + def _suffix_for(req): + """ + For a requirement, return the 'extras_require' suffix for + that requirement. + """ + return ':' + str(req.marker) if req.marker else '' + + def _move_install_requirements_markers(self): + """ + Move requirements in `install_requires` that are using environment + markers `extras_require`. + """ + + # divide the install_requires into two sets, simple ones still + # handled by install_requires and more complex ones handled + # by extras_require. + + def is_simple_req(req): + return not req.marker + + spec_inst_reqs = getattr(self, 'install_requires', None) or () + inst_reqs = list(pkg_resources.parse_requirements(spec_inst_reqs)) + simple_reqs = filter(is_simple_req, inst_reqs) + complex_reqs = filterfalse(is_simple_req, inst_reqs) + self.install_requires = list(map(str, simple_reqs)) + + for r in complex_reqs: + self._tmp_extras_require[':' + str(r.marker)].append(r) + self.extras_require = dict( + (k, [str(r) for r in map(self._clean_req, v)]) + for k, v in self._tmp_extras_require.items() + ) + + def _clean_req(self, req): + """ + Given a Requirement, remove environment markers and return it. + """ + req.marker = None + return req + + def _parse_config_files(self, filenames=None): + """ + Adapted from distutils.dist.Distribution.parse_config_files, + this method provides the same functionality in subtly-improved + ways. + """ + from setuptools.extern.six.moves.configparser import ConfigParser + + # Ignore install directory options if we have a venv + if six.PY3 and sys.prefix != sys.base_prefix: + ignore_options = [ + 'install-base', 'install-platbase', 'install-lib', + 'install-platlib', 'install-purelib', 'install-headers', + 'install-scripts', 'install-data', 'prefix', 'exec-prefix', + 'home', 'user', 'root'] + else: + ignore_options = [] + + ignore_options = frozenset(ignore_options) + + if filenames is None: + filenames = self.find_config_files() + + if DEBUG: + self.announce("Distribution.parse_config_files():") + + parser = ConfigParser() + for filename in filenames: + with io.open(filename, encoding='utf-8') as reader: + if DEBUG: + self.announce(" reading {filename}".format(**locals())) + (parser.read_file if six.PY3 else parser.readfp)(reader) + for section in parser.sections(): + options = parser.options(section) + opt_dict = self.get_option_dict(section) + + for opt in options: + if opt != '__name__' and opt not in ignore_options: + val = self._try_str(parser.get(section, opt)) + opt = opt.replace('-', '_') + opt_dict[opt] = (filename, val) + + # Make the ConfigParser forget everything (so we retain + # the original filenames that options come from) + parser.__init__() + + # If there was a "global" section in the config file, use it + # to set Distribution options. + + if 'global' in self.command_options: + for (opt, (src, val)) in self.command_options['global'].items(): + alias = self.negative_opt.get(opt) + try: + if alias: + setattr(self, alias, not strtobool(val)) + elif opt in ('verbose', 'dry_run'): # ugh! + setattr(self, opt, strtobool(val)) + else: + setattr(self, opt, val) + except ValueError as msg: + raise DistutilsOptionError(msg) + + @staticmethod + def _try_str(val): + """ + On Python 2, much of distutils relies on string values being of + type 'str' (bytes) and not unicode text. If the value can be safely + encoded to bytes using the default encoding, prefer that. + + Why the default encoding? Because that value can be implicitly + decoded back to text if needed. + + Ref #1653 + """ + if six.PY3: + return val + try: + return val.encode() + except UnicodeEncodeError: + pass + return val + + def _set_command_options(self, command_obj, option_dict=None): + """ + Set the options for 'command_obj' from 'option_dict'. Basically + this means copying elements of a dictionary ('option_dict') to + attributes of an instance ('command'). + + 'command_obj' must be a Command instance. If 'option_dict' is not + supplied, uses the standard option dictionary for this command + (from 'self.command_options'). + + (Adopted from distutils.dist.Distribution._set_command_options) + """ + command_name = command_obj.get_command_name() + if option_dict is None: + option_dict = self.get_option_dict(command_name) + + if DEBUG: + self.announce(" setting options for '%s' command:" % command_name) + for (option, (source, value)) in option_dict.items(): + if DEBUG: + self.announce(" %s = %s (from %s)" % (option, value, + source)) + try: + bool_opts = [translate_longopt(o) + for o in command_obj.boolean_options] + except AttributeError: + bool_opts = [] + try: + neg_opt = command_obj.negative_opt + except AttributeError: + neg_opt = {} + + try: + is_string = isinstance(value, six.string_types) + if option in neg_opt and is_string: + setattr(command_obj, neg_opt[option], not strtobool(value)) + elif option in bool_opts and is_string: + setattr(command_obj, option, strtobool(value)) + elif hasattr(command_obj, option): + setattr(command_obj, option, value) + else: + raise DistutilsOptionError( + "error in %s: command '%s' has no such option '%s'" + % (source, command_name, option)) + except ValueError as msg: + raise DistutilsOptionError(msg) + + def parse_config_files(self, filenames=None, ignore_option_errors=False): + """Parses configuration files from various levels + and loads configuration. + + """ + self._parse_config_files(filenames=filenames) + + parse_configuration(self, self.command_options, + ignore_option_errors=ignore_option_errors) + self._finalize_requires() + + def parse_command_line(self): + """Process features after parsing command line options""" + result = _Distribution.parse_command_line(self) + if self.features: + self._finalize_features() + return result + + def _feature_attrname(self, name): + """Convert feature name to corresponding option attribute name""" + return 'with_' + name.replace('-', '_') + + def fetch_build_eggs(self, requires): + """Resolve pre-setup requirements""" + resolved_dists = pkg_resources.working_set.resolve( + pkg_resources.parse_requirements(requires), + installer=self.fetch_build_egg, + replace_conflicting=True, + ) + for dist in resolved_dists: + pkg_resources.working_set.add(dist, replace=True) + return resolved_dists + + def finalize_options(self): + """ + Allow plugins to apply arbitrary operations to the + distribution. Each hook may optionally define a 'order' + to influence the order of execution. Smaller numbers + go first and the default is 0. + """ + hook_key = 'setuptools.finalize_distribution_options' + + def by_order(hook): + return getattr(hook, 'order', 0) + eps = pkg_resources.iter_entry_points(hook_key) + for ep in sorted(eps, key=by_order): + ep.load()(self) + + def _finalize_setup_keywords(self): + for ep in pkg_resources.iter_entry_points('distutils.setup_keywords'): + value = getattr(self, ep.name, None) + if value is not None: + ep.require(installer=self.fetch_build_egg) + ep.load()(self, ep.name, value) + + def _finalize_2to3_doctests(self): + if getattr(self, 'convert_2to3_doctests', None): + # XXX may convert to set here when we can rely on set being builtin + self.convert_2to3_doctests = [ + os.path.abspath(p) + for p in self.convert_2to3_doctests + ] + else: + self.convert_2to3_doctests = [] + + def get_egg_cache_dir(self): + egg_cache_dir = os.path.join(os.curdir, '.eggs') + if not os.path.exists(egg_cache_dir): + os.mkdir(egg_cache_dir) + windows_support.hide_file(egg_cache_dir) + readme_txt_filename = os.path.join(egg_cache_dir, 'README.txt') + with open(readme_txt_filename, 'w') as f: + f.write('This directory contains eggs that were downloaded ' + 'by setuptools to build, test, and run plug-ins.\n\n') + f.write('This directory caches those eggs to prevent ' + 'repeated downloads.\n\n') + f.write('However, it is safe to delete this directory.\n\n') + + return egg_cache_dir + + def fetch_build_egg(self, req): + """Fetch an egg needed for building""" + from setuptools.installer import fetch_build_egg + return fetch_build_egg(self, req) + + def _finalize_feature_opts(self): + """Add --with-X/--without-X options based on optional features""" + + if not self.features: + return + + go = [] + no = self.negative_opt.copy() + + for name, feature in self.features.items(): + self._set_feature(name, None) + feature.validate(self) + + if feature.optional: + descr = feature.description + incdef = ' (default)' + excdef = '' + if not feature.include_by_default(): + excdef, incdef = incdef, excdef + + new = ( + ('with-' + name, None, 'include ' + descr + incdef), + ('without-' + name, None, 'exclude ' + descr + excdef), + ) + go.extend(new) + no['without-' + name] = 'with-' + name + + self.global_options = self.feature_options = go + self.global_options + self.negative_opt = self.feature_negopt = no + + def _finalize_features(self): + """Add/remove features and resolve dependencies between them""" + + # First, flag all the enabled items (and thus their dependencies) + for name, feature in self.features.items(): + enabled = self.feature_is_included(name) + if enabled or (enabled is None and feature.include_by_default()): + feature.include_in(self) + self._set_feature(name, 1) + + # Then disable the rest, so that off-by-default features don't + # get flagged as errors when they're required by an enabled feature + for name, feature in self.features.items(): + if not self.feature_is_included(name): + feature.exclude_from(self) + self._set_feature(name, 0) + + def get_command_class(self, command): + """Pluggable version of get_command_class()""" + if command in self.cmdclass: + return self.cmdclass[command] + + eps = pkg_resources.iter_entry_points('distutils.commands', command) + for ep in eps: + ep.require(installer=self.fetch_build_egg) + self.cmdclass[command] = cmdclass = ep.load() + return cmdclass + else: + return _Distribution.get_command_class(self, command) + + def print_commands(self): + for ep in pkg_resources.iter_entry_points('distutils.commands'): + if ep.name not in self.cmdclass: + # don't require extras as the commands won't be invoked + cmdclass = ep.resolve() + self.cmdclass[ep.name] = cmdclass + return _Distribution.print_commands(self) + + def get_command_list(self): + for ep in pkg_resources.iter_entry_points('distutils.commands'): + if ep.name not in self.cmdclass: + # don't require extras as the commands won't be invoked + cmdclass = ep.resolve() + self.cmdclass[ep.name] = cmdclass + return _Distribution.get_command_list(self) + + def _set_feature(self, name, status): + """Set feature's inclusion status""" + setattr(self, self._feature_attrname(name), status) + + def feature_is_included(self, name): + """Return 1 if feature is included, 0 if excluded, 'None' if unknown""" + return getattr(self, self._feature_attrname(name)) + + def include_feature(self, name): + """Request inclusion of feature named 'name'""" + + if self.feature_is_included(name) == 0: + descr = self.features[name].description + raise DistutilsOptionError( + descr + " is required, but was excluded or is not available" + ) + self.features[name].include_in(self) + self._set_feature(name, 1) + + def include(self, **attrs): + """Add items to distribution that are named in keyword arguments + + For example, 'dist.include(py_modules=["x"])' would add 'x' to + the distribution's 'py_modules' attribute, if it was not already + there. + + Currently, this method only supports inclusion for attributes that are + lists or tuples. If you need to add support for adding to other + attributes in this or a subclass, you can add an '_include_X' method, + where 'X' is the name of the attribute. The method will be called with + the value passed to 'include()'. So, 'dist.include(foo={"bar":"baz"})' + will try to call 'dist._include_foo({"bar":"baz"})', which can then + handle whatever special inclusion logic is needed. + """ + for k, v in attrs.items(): + include = getattr(self, '_include_' + k, None) + if include: + include(v) + else: + self._include_misc(k, v) + + def exclude_package(self, package): + """Remove packages, modules, and extensions in named package""" + + pfx = package + '.' + if self.packages: + self.packages = [ + p for p in self.packages + if p != package and not p.startswith(pfx) + ] + + if self.py_modules: + self.py_modules = [ + p for p in self.py_modules + if p != package and not p.startswith(pfx) + ] + + if self.ext_modules: + self.ext_modules = [ + p for p in self.ext_modules + if p.name != package and not p.name.startswith(pfx) + ] + + def has_contents_for(self, package): + """Return true if 'exclude_package(package)' would do something""" + + pfx = package + '.' + + for p in self.iter_distribution_names(): + if p == package or p.startswith(pfx): + return True + + def _exclude_misc(self, name, value): + """Handle 'exclude()' for list/tuple attrs without a special handler""" + if not isinstance(value, sequence): + raise DistutilsSetupError( + "%s: setting must be a list or tuple (%r)" % (name, value) + ) + try: + old = getattr(self, name) + except AttributeError: + raise DistutilsSetupError( + "%s: No such distribution setting" % name + ) + if old is not None and not isinstance(old, sequence): + raise DistutilsSetupError( + name + ": this setting cannot be changed via include/exclude" + ) + elif old: + setattr(self, name, [item for item in old if item not in value]) + + def _include_misc(self, name, value): + """Handle 'include()' for list/tuple attrs without a special handler""" + + if not isinstance(value, sequence): + raise DistutilsSetupError( + "%s: setting must be a list (%r)" % (name, value) + ) + try: + old = getattr(self, name) + except AttributeError: + raise DistutilsSetupError( + "%s: No such distribution setting" % name + ) + if old is None: + setattr(self, name, value) + elif not isinstance(old, sequence): + raise DistutilsSetupError( + name + ": this setting cannot be changed via include/exclude" + ) + else: + new = [item for item in value if item not in old] + setattr(self, name, old + new) + + def exclude(self, **attrs): + """Remove items from distribution that are named in keyword arguments + + For example, 'dist.exclude(py_modules=["x"])' would remove 'x' from + the distribution's 'py_modules' attribute. Excluding packages uses + the 'exclude_package()' method, so all of the package's contained + packages, modules, and extensions are also excluded. + + Currently, this method only supports exclusion from attributes that are + lists or tuples. If you need to add support for excluding from other + attributes in this or a subclass, you can add an '_exclude_X' method, + where 'X' is the name of the attribute. The method will be called with + the value passed to 'exclude()'. So, 'dist.exclude(foo={"bar":"baz"})' + will try to call 'dist._exclude_foo({"bar":"baz"})', which can then + handle whatever special exclusion logic is needed. + """ + for k, v in attrs.items(): + exclude = getattr(self, '_exclude_' + k, None) + if exclude: + exclude(v) + else: + self._exclude_misc(k, v) + + def _exclude_packages(self, packages): + if not isinstance(packages, sequence): + raise DistutilsSetupError( + "packages: setting must be a list or tuple (%r)" % (packages,) + ) + list(map(self.exclude_package, packages)) + + def _parse_command_opts(self, parser, args): + # Remove --with-X/--without-X options when processing command args + self.global_options = self.__class__.global_options + self.negative_opt = self.__class__.negative_opt + + # First, expand any aliases + command = args[0] + aliases = self.get_option_dict('aliases') + while command in aliases: + src, alias = aliases[command] + del aliases[command] # ensure each alias can expand only once! + import shlex + args[:1] = shlex.split(alias, True) + command = args[0] + + nargs = _Distribution._parse_command_opts(self, parser, args) + + # Handle commands that want to consume all remaining arguments + cmd_class = self.get_command_class(command) + if getattr(cmd_class, 'command_consumes_arguments', None): + self.get_option_dict(command)['args'] = ("command line", nargs) + if nargs is not None: + return [] + + return nargs + + def get_cmdline_options(self): + """Return a '{cmd: {opt:val}}' map of all command-line options + + Option names are all long, but do not include the leading '--', and + contain dashes rather than underscores. If the option doesn't take + an argument (e.g. '--quiet'), the 'val' is 'None'. + + Note that options provided by config files are intentionally excluded. + """ + + d = {} + + for cmd, opts in self.command_options.items(): + + for opt, (src, val) in opts.items(): + + if src != "command line": + continue + + opt = opt.replace('_', '-') + + if val == 0: + cmdobj = self.get_command_obj(cmd) + neg_opt = self.negative_opt.copy() + neg_opt.update(getattr(cmdobj, 'negative_opt', {})) + for neg, pos in neg_opt.items(): + if pos == opt: + opt = neg + val = None + break + else: + raise AssertionError("Shouldn't be able to get here") + + elif val == 1: + val = None + + d.setdefault(cmd, {})[opt] = val + + return d + + def iter_distribution_names(self): + """Yield all packages, modules, and extension names in distribution""" + + for pkg in self.packages or (): + yield pkg + + for module in self.py_modules or (): + yield module + + for ext in self.ext_modules or (): + if isinstance(ext, tuple): + name, buildinfo = ext + else: + name = ext.name + if name.endswith('module'): + name = name[:-6] + yield name + + def handle_display_options(self, option_order): + """If there were any non-global "display-only" options + (--help-commands or the metadata display options) on the command + line, display the requested info and return true; else return + false. + """ + import sys + + if six.PY2 or self.help_commands: + return _Distribution.handle_display_options(self, option_order) + + # Stdout may be StringIO (e.g. in tests) + if not isinstance(sys.stdout, io.TextIOWrapper): + return _Distribution.handle_display_options(self, option_order) + + # Don't wrap stdout if utf-8 is already the encoding. Provides + # workaround for #334. + if sys.stdout.encoding.lower() in ('utf-8', 'utf8'): + return _Distribution.handle_display_options(self, option_order) + + # Print metadata in UTF-8 no matter the platform + encoding = sys.stdout.encoding + errors = sys.stdout.errors + newline = sys.platform != 'win32' and '\n' or None + line_buffering = sys.stdout.line_buffering + + sys.stdout = io.TextIOWrapper( + sys.stdout.detach(), 'utf-8', errors, newline, line_buffering) + try: + return _Distribution.handle_display_options(self, option_order) + finally: + sys.stdout = io.TextIOWrapper( + sys.stdout.detach(), encoding, errors, newline, line_buffering) + + +class Feature: + """ + **deprecated** -- The `Feature` facility was never completely implemented + or supported, `has reported issues + `_ and will be removed in + a future version. + + A subset of the distribution that can be excluded if unneeded/wanted + + Features are created using these keyword arguments: + + 'description' -- a short, human readable description of the feature, to + be used in error messages, and option help messages. + + 'standard' -- if true, the feature is included by default if it is + available on the current system. Otherwise, the feature is only + included if requested via a command line '--with-X' option, or if + another included feature requires it. The default setting is 'False'. + + 'available' -- if true, the feature is available for installation on the + current system. The default setting is 'True'. + + 'optional' -- if true, the feature's inclusion can be controlled from the + command line, using the '--with-X' or '--without-X' options. If + false, the feature's inclusion status is determined automatically, + based on 'availabile', 'standard', and whether any other feature + requires it. The default setting is 'True'. + + 'require_features' -- a string or sequence of strings naming features + that should also be included if this feature is included. Defaults to + empty list. May also contain 'Require' objects that should be + added/removed from the distribution. + + 'remove' -- a string or list of strings naming packages to be removed + from the distribution if this feature is *not* included. If the + feature *is* included, this argument is ignored. This argument exists + to support removing features that "crosscut" a distribution, such as + defining a 'tests' feature that removes all the 'tests' subpackages + provided by other features. The default for this argument is an empty + list. (Note: the named package(s) or modules must exist in the base + distribution when the 'setup()' function is initially called.) + + other keywords -- any other keyword arguments are saved, and passed to + the distribution's 'include()' and 'exclude()' methods when the + feature is included or excluded, respectively. So, for example, you + could pass 'packages=["a","b"]' to cause packages 'a' and 'b' to be + added or removed from the distribution as appropriate. + + A feature must include at least one 'requires', 'remove', or other + keyword argument. Otherwise, it can't affect the distribution in any way. + Note also that you can subclass 'Feature' to create your own specialized + feature types that modify the distribution in other ways when included or + excluded. See the docstrings for the various methods here for more detail. + Aside from the methods, the only feature attributes that distributions look + at are 'description' and 'optional'. + """ + + @staticmethod + def warn_deprecated(): + msg = ( + "Features are deprecated and will be removed in a future " + "version. See https://github.com/pypa/setuptools/issues/65." + ) + warnings.warn(msg, DistDeprecationWarning, stacklevel=3) + + def __init__( + self, description, standard=False, available=True, + optional=True, require_features=(), remove=(), **extras): + self.warn_deprecated() + + self.description = description + self.standard = standard + self.available = available + self.optional = optional + if isinstance(require_features, (str, Require)): + require_features = require_features, + + self.require_features = [ + r for r in require_features if isinstance(r, str) + ] + er = [r for r in require_features if not isinstance(r, str)] + if er: + extras['require_features'] = er + + if isinstance(remove, str): + remove = remove, + self.remove = remove + self.extras = extras + + if not remove and not require_features and not extras: + raise DistutilsSetupError( + "Feature %s: must define 'require_features', 'remove', or " + "at least one of 'packages', 'py_modules', etc." + ) + + def include_by_default(self): + """Should this feature be included by default?""" + return self.available and self.standard + + def include_in(self, dist): + """Ensure feature and its requirements are included in distribution + + You may override this in a subclass to perform additional operations on + the distribution. Note that this method may be called more than once + per feature, and so should be idempotent. + + """ + + if not self.available: + raise DistutilsPlatformError( + self.description + " is required, " + "but is not available on this platform" + ) + + dist.include(**self.extras) + + for f in self.require_features: + dist.include_feature(f) + + def exclude_from(self, dist): + """Ensure feature is excluded from distribution + + You may override this in a subclass to perform additional operations on + the distribution. This method will be called at most once per + feature, and only after all included features have been asked to + include themselves. + """ + + dist.exclude(**self.extras) + + if self.remove: + for item in self.remove: + dist.exclude_package(item) + + def validate(self, dist): + """Verify that feature makes sense in context of distribution + + This method is called by the distribution just before it parses its + command line. It checks to ensure that the 'remove' attribute, if any, + contains only valid package/module names that are present in the base + distribution when 'setup()' is called. You may override it in a + subclass to perform any other required validation of the feature + against a target distribution. + """ + + for item in self.remove: + if not dist.has_contents_for(item): + raise DistutilsSetupError( + "%s wants to be able to remove %s, but the distribution" + " doesn't contain any packages or modules under %s" + % (self.description, item, item) + ) + + +class DistDeprecationWarning(SetuptoolsDeprecationWarning): + """Class for warning about deprecations in dist in + setuptools. Not ignored by default, unlike DeprecationWarning.""" diff --git a/venv/lib/python3.8/site-packages/setuptools/errors.py b/venv/lib/python3.8/site-packages/setuptools/errors.py new file mode 100644 index 0000000..2701747 --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/errors.py @@ -0,0 +1,16 @@ +"""setuptools.errors + +Provides exceptions used by setuptools modules. +""" + +from distutils.errors import DistutilsError + + +class RemovedCommandError(DistutilsError, RuntimeError): + """Error used for commands that have been removed in setuptools. + + Since ``setuptools`` is built on ``distutils``, simply removing a command + from ``setuptools`` will make the behavior fall back to ``distutils``; this + error is raised if a command exists in ``distutils`` but has been actively + removed in ``setuptools``. + """ diff --git a/venv/lib/python3.8/site-packages/setuptools/extension.py b/venv/lib/python3.8/site-packages/setuptools/extension.py new file mode 100644 index 0000000..2946889 --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/extension.py @@ -0,0 +1,57 @@ +import re +import functools +import distutils.core +import distutils.errors +import distutils.extension + +from setuptools.extern.six.moves import map + +from .monkey import get_unpatched + + +def _have_cython(): + """ + Return True if Cython can be imported. + """ + cython_impl = 'Cython.Distutils.build_ext' + try: + # from (cython_impl) import build_ext + __import__(cython_impl, fromlist=['build_ext']).build_ext + return True + except Exception: + pass + return False + + +# for compatibility +have_pyrex = _have_cython + +_Extension = get_unpatched(distutils.core.Extension) + + +class Extension(_Extension): + """Extension that uses '.c' files in place of '.pyx' files""" + + def __init__(self, name, sources, *args, **kw): + # The *args is needed for compatibility as calls may use positional + # arguments. py_limited_api may be set only via keyword. + self.py_limited_api = kw.pop("py_limited_api", False) + _Extension.__init__(self, name, sources, *args, **kw) + + def _convert_pyx_sources_to_lang(self): + """ + Replace sources with .pyx extensions to sources with the target + language extension. This mechanism allows language authors to supply + pre-converted sources but to prefer the .pyx sources. + """ + if _have_cython(): + # the build has Cython, so allow it to compile the .pyx files + return + lang = self.language or '' + target_ext = '.cpp' if lang.lower() == 'c++' else '.c' + sub = functools.partial(re.sub, '.pyx$', target_ext) + self.sources = list(map(sub, self.sources)) + + +class Library(Extension): + """Just like a regular Extension, but built as a library instead""" diff --git a/venv/lib/python3.8/site-packages/setuptools/extern/__init__.py b/venv/lib/python3.8/site-packages/setuptools/extern/__init__.py new file mode 100644 index 0000000..e8c616f --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/extern/__init__.py @@ -0,0 +1,73 @@ +import sys + + +class VendorImporter: + """ + A PEP 302 meta path importer for finding optionally-vendored + or otherwise naturally-installed packages from root_name. + """ + + def __init__(self, root_name, vendored_names=(), vendor_pkg=None): + self.root_name = root_name + self.vendored_names = set(vendored_names) + self.vendor_pkg = vendor_pkg or root_name.replace('extern', '_vendor') + + @property + def search_path(self): + """ + Search first the vendor package then as a natural package. + """ + yield self.vendor_pkg + '.' + yield '' + + def find_module(self, fullname, path=None): + """ + Return self when fullname starts with root_name and the + target module is one vendored through this importer. + """ + root, base, target = fullname.partition(self.root_name + '.') + if root: + return + if not any(map(target.startswith, self.vendored_names)): + return + return self + + def load_module(self, fullname): + """ + Iterate over the search path to locate and load fullname. + """ + root, base, target = fullname.partition(self.root_name + '.') + for prefix in self.search_path: + try: + extant = prefix + target + __import__(extant) + mod = sys.modules[extant] + sys.modules[fullname] = mod + # mysterious hack: + # Remove the reference to the extant package/module + # on later Python versions to cause relative imports + # in the vendor package to resolve the same modules + # as those going through this importer. + if sys.version_info >= (3, ): + del sys.modules[extant] + return mod + except ImportError: + pass + else: + raise ImportError( + "The '{target}' package is required; " + "normally this is bundled with this package so if you get " + "this warning, consult the packager of your " + "distribution.".format(**locals()) + ) + + def install(self): + """ + Install this importer into sys.meta_path if not already present. + """ + if self not in sys.meta_path: + sys.meta_path.append(self) + + +names = 'six', 'packaging', 'pyparsing', 'ordered_set', +VendorImporter(__name__, names, 'setuptools._vendor').install() diff --git a/venv/lib/python3.8/site-packages/setuptools/extern/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/extern/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..2fac5a78fc5ea5f5e9455a769d38085817f8cf87 GIT binary patch literal 2420 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 literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/setuptools/gui.exe b/venv/lib/python3.8/site-packages/setuptools/gui.exe new file mode 100644 index 0000000000000000000000000000000000000000..f8d3509653ba8f80ca7f3aa7f95616142ba83a94 GIT binary patch literal 65536 zcmeFae|%KMxj%k3yGc&SCTD>S1PQP}R5YmQ5=~qJi^+zl1UE)DtPsG8blp-*!#RLg z0>QIub24npZS_`f-)#|`^OhvIcH|hGc(UT^E}VYJoC(K^_@EDjE;rth;Yer@_4k$X3I);E0Tn+-Zb>&yT9Ew!oxAMfl)C z#Z+d`C?Ev=lGJ)}%Ksnx|0)G)SVf_n2-;d?f9!~MzIJJ-=wKb=iHfW2QCpC29wSNm zA=ztsPZ<@3t`2ENV!bW?>DIbrM&c*bCbqaRzr~R~Z-r)Gl=RG-p}ugUHp=<&@N<(0nQZ)pc;t^f@UfdU)Xs*a2q9hEj|W&QGS`}Q+V zaO>`-aSJ8yAtP2OBNk%M7Utt!$6gfgmQ40WtW_PKSW_r1oOg}p=vZj3XtBjwwJ#E} zLMNCsnAlP1f|%AM?kIHMo~S5v2kZEcbEs|ZrY(iCq{N>@V-R$%P-2fEhzyjmCh@Sy zXyr*PE_By~_)26%86IRFp9Ya zkBHB1hGv2=t60ZM@2flwcy2#L^lN{0=%0Q@MjzL)ErkWFb2Ro*N07ImOt!9YmgwvP zqh2yflmnST)@Q6JEa3kv=;e&Js^gRcx7ile@Me+Xh_`B=wJ3|47Z(=9j;P;M4jj9k ze|zYYnyGIobV=&smWsjxVw3XZ39!ke-gcWd&f8i_T!k-^@^CA0*s%-oQ>v?$_-7%o z(GNN8XT7J;F$I$PlNQv_oLiavAq4>E7I2dQhlE)vSn!y;BSSI+5(`L`#@q*i(+$dj ziMR82oKzstr3NgrEei6^p%m@2rUhVv>rK-H3%XZ<_rUh;c(a2dG)%uOg$_v@w_EZo zlu%GsR0^7TQkP%ahpqsf^)t)7t)|hz?tCY-06G}<$V~#?~heoED!!4L2akG@t z3k(cUbnpdgqwk%>`n0WAC7vv#rU2V~=4eiAwpse1#pRD3*UlGpF7&;UP%~^>-Uq9> zqqY#gDuX1JM-HRLrTl?xL1RW6Nzt8%&-UwXtnfuqbCmh#A4k1U7-%L3c7Zx(d zuhG+B-K2d4zoLVczO#ufnYJw*t5&k#)-NC8`0Z!%(?;tLH)1SS=)o%@p*m1Hza}bC zH<@{EP=$nZv|K=--J~^q2RFJ=UsK7|s*{A7>2riBOI3;B9VN6@g>xk)TvhhOKNMSeI?sb zNT@@qXG7GtAEH*Z*I7+?xX^=^+#cd{e*xu~c+oK%QC`k~8T1Fj`XSd4etuu)23Ly= znHbY_evF#lbUsH*M$@PjpbB6kZlDn4%Pfry7Wc9o2a;HxjOT7A9>$Ks0zkIpxF}-P z4%J+UwB{X!v+x4JvU3b1r4SD4dNJCLBe`P~a!!^eLzUU1z9JMV04G)5v%Ur4xPh4u|g#Tc-(r0PB00 z<2OM*Q-Cajywm3kTRsx?bLZ%s;?w6_FF__SF*1GDPvs6}`fAHZ`iq5gfrnJz3GS7o z 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 -1: + # For VC++ 9.0, if IA64 support is needed, redirect user + # to Windows SDK 7.0. + # Note: No download link available from Microsoft. + message += ' Get it with "Microsoft Windows SDK 7.0"' + else: + # For VC++ 9.0 redirect user to Vc++ for Python 2.7 : + # This redirection link is maintained by Microsoft. + # Contact vspython@microsoft.com if it needs updating. + message += ' Get it from http://aka.ms/vcpython27' + elif version == 10.0: + # For VC++ 10.0 Redirect user to Windows SDK 7.1 + message += ' Get it with "Microsoft Windows SDK 7.1": ' + message += msdownload % 8279 + elif version >= 14.0: + # For VC++ 14.X Redirect user to latest Visual C++ Build Tools + message += (' Get it with "Build Tools for Visual Studio": ' + r'https://visualstudio.microsoft.com/downloads/') + + exc.args = (message, ) + + +class PlatformInfo: + """ + Current and Target Architectures information. + + Parameters + ---------- + arch: str + Target architecture. + """ + current_cpu = environ.get('processor_architecture', '').lower() + + def __init__(self, arch): + self.arch = arch.lower().replace('x64', 'amd64') + + @property + def target_cpu(self): + """ + Return Target CPU architecture. + + Return + ------ + str + Target CPU + """ + return self.arch[self.arch.find('_') + 1:] + + def target_is_x86(self): + """ + Return True if target CPU is x86 32 bits.. + + Return + ------ + bool + CPU is x86 32 bits + """ + return self.target_cpu == 'x86' + + def current_is_x86(self): + """ + Return True if current CPU is x86 32 bits.. + + Return + ------ + bool + CPU is x86 32 bits + """ + return self.current_cpu == 'x86' + + def current_dir(self, hidex86=False, x64=False): + """ + Current platform specific subfolder. + + Parameters + ---------- + hidex86: bool + return '' and not '\x86' if architecture is x86. + x64: bool + return '\x64' and not '\amd64' if architecture is amd64. + + Return + ------ + str + subfolder: '\target', or '' (see hidex86 parameter) + """ + return ( + '' if (self.current_cpu == 'x86' and hidex86) else + r'\x64' if (self.current_cpu == 'amd64' and x64) else + r'\%s' % self.current_cpu + ) + + def target_dir(self, hidex86=False, x64=False): + r""" + Target platform specific subfolder. + + Parameters + ---------- + hidex86: bool + return '' and not '\x86' if architecture is x86. + x64: bool + return '\x64' and not '\amd64' if architecture is amd64. + + Return + ------ + str + subfolder: '\current', or '' (see hidex86 parameter) + """ + return ( + '' if (self.target_cpu == 'x86' and hidex86) else + r'\x64' if (self.target_cpu == 'amd64' and x64) else + r'\%s' % self.target_cpu + ) + + def cross_dir(self, forcex86=False): + r""" + Cross platform specific subfolder. + + Parameters + ---------- + forcex86: bool + Use 'x86' as current architecture even if current architecture is + not x86. + + Return + ------ + str + subfolder: '' if target architecture is current architecture, + '\current_target' if not. + """ + current = 'x86' if forcex86 else self.current_cpu + return ( + '' if self.target_cpu == current else + self.target_dir().replace('\\', '\\%s_' % current) + ) + + +class RegistryInfo: + """ + Microsoft Visual Studio related registry information. + + Parameters + ---------- + platform_info: PlatformInfo + "PlatformInfo" instance. + """ + HKEYS = (winreg.HKEY_USERS, + winreg.HKEY_CURRENT_USER, + winreg.HKEY_LOCAL_MACHINE, + winreg.HKEY_CLASSES_ROOT) + + def __init__(self, platform_info): + self.pi = platform_info + + @property + def visualstudio(self): + """ + Microsoft Visual Studio root registry key. + + Return + ------ + str + Registry key + """ + return 'VisualStudio' + + @property + def sxs(self): + """ + Microsoft Visual Studio SxS registry key. + + Return + ------ + str + Registry key + """ + return join(self.visualstudio, 'SxS') + + @property + def vc(self): + """ + Microsoft Visual C++ VC7 registry key. + + Return + ------ + str + Registry key + """ + return join(self.sxs, 'VC7') + + @property + def vs(self): + """ + Microsoft Visual Studio VS7 registry key. + + Return + ------ + str + Registry key + """ + return join(self.sxs, 'VS7') + + @property + def vc_for_python(self): + """ + Microsoft Visual C++ for Python registry key. + + Return + ------ + str + Registry key + """ + return r'DevDiv\VCForPython' + + @property + def microsoft_sdk(self): + """ + Microsoft SDK registry key. + + Return + ------ + str + Registry key + """ + return 'Microsoft SDKs' + + @property + def windows_sdk(self): + """ + Microsoft Windows/Platform SDK registry key. + + Return + ------ + str + Registry key + """ + return join(self.microsoft_sdk, 'Windows') + + @property + def netfx_sdk(self): + """ + Microsoft .NET Framework SDK registry key. + + Return + ------ + str + Registry key + """ + return join(self.microsoft_sdk, 'NETFXSDK') + + @property + def windows_kits_roots(self): + """ + Microsoft Windows Kits Roots registry key. + + Return + ------ + str + Registry key + """ + return r'Windows Kits\Installed Roots' + + def microsoft(self, key, x86=False): + """ + Return key in Microsoft software registry. + + Parameters + ---------- + key: str + Registry key path where look. + x86: str + Force x86 software registry. + + Return + ------ + str + Registry key + """ + node64 = '' if self.pi.current_is_x86() or x86 else 'Wow6432Node' + return join('Software', node64, 'Microsoft', key) + + def lookup(self, key, name): + """ + Look for values in registry in Microsoft software registry. + + Parameters + ---------- + key: str + Registry key path where look. + name: str + Value name to find. + + Return + ------ + str + value + """ + key_read = winreg.KEY_READ + openkey = winreg.OpenKey + ms = self.microsoft + for hkey in self.HKEYS: + try: + bkey = openkey(hkey, ms(key), 0, key_read) + except (OSError, IOError): + if not self.pi.current_is_x86(): + try: + bkey = openkey(hkey, ms(key, True), 0, key_read) + except (OSError, IOError): + continue + else: + continue + try: + return winreg.QueryValueEx(bkey, name)[0] + except (OSError, IOError): + pass + + +class SystemInfo: + """ + Microsoft Windows and Visual Studio related system information. + + Parameters + ---------- + registry_info: RegistryInfo + "RegistryInfo" instance. + vc_ver: float + Required Microsoft Visual C++ version. + """ + + # Variables and properties in this class use originals CamelCase variables + # names from Microsoft source files for more easy comparison. + WinDir = environ.get('WinDir', '') + ProgramFiles = environ.get('ProgramFiles', '') + ProgramFilesx86 = environ.get('ProgramFiles(x86)', ProgramFiles) + + def __init__(self, registry_info, vc_ver=None): + self.ri = registry_info + self.pi = self.ri.pi + + self.known_vs_paths = self.find_programdata_vs_vers() + + # Except for VS15+, VC version is aligned with VS version + self.vs_ver = self.vc_ver = ( + vc_ver or self._find_latest_available_vs_ver()) + + def _find_latest_available_vs_ver(self): + """ + Find the latest VC version + + Return + ------ + float + version + """ + reg_vc_vers = self.find_reg_vs_vers() + + if not (reg_vc_vers or self.known_vs_paths): + raise distutils.errors.DistutilsPlatformError( + 'No Microsoft Visual C++ version found') + + vc_vers = set(reg_vc_vers) + vc_vers.update(self.known_vs_paths) + return sorted(vc_vers)[-1] + + def find_reg_vs_vers(self): + """ + Find Microsoft Visual Studio versions available in registry. + + Return + ------ + list of float + Versions + """ + ms = self.ri.microsoft + vckeys = (self.ri.vc, self.ri.vc_for_python, self.ri.vs) + vs_vers = [] + for hkey in self.ri.HKEYS: + for key in vckeys: + try: + bkey = winreg.OpenKey(hkey, ms(key), 0, winreg.KEY_READ) + except (OSError, IOError): + continue + subkeys, values, _ = winreg.QueryInfoKey(bkey) + for i in range(values): + try: + ver = float(winreg.EnumValue(bkey, i)[0]) + if ver not in vs_vers: + vs_vers.append(ver) + except ValueError: + pass + for i in range(subkeys): + try: + ver = float(winreg.EnumKey(bkey, i)) + if ver not in vs_vers: + vs_vers.append(ver) + except ValueError: + pass + return sorted(vs_vers) + + def find_programdata_vs_vers(self): + r""" + Find Visual studio 2017+ versions from information in + "C:\ProgramData\Microsoft\VisualStudio\Packages\_Instances". + + Return + ------ + dict + float version as key, path as value. + """ + vs_versions = {} + instances_dir = \ + r'C:\ProgramData\Microsoft\VisualStudio\Packages\_Instances' + + try: + hashed_names = listdir(instances_dir) + + except (OSError, IOError): + # Directory not exists with all Visual Studio versions + return vs_versions + + for name in hashed_names: + try: + # Get VS installation path from "state.json" file + state_path = join(instances_dir, name, 'state.json') + with open(state_path, 'rt', encoding='utf-8') as state_file: + state = json.load(state_file) + vs_path = state['installationPath'] + + # Raises OSError if this VS installation does not contain VC + listdir(join(vs_path, r'VC\Tools\MSVC')) + + # Store version and path + vs_versions[self._as_float_version( + state['installationVersion'])] = vs_path + + except (OSError, IOError, KeyError): + # Skip if "state.json" file is missing or bad format + continue + + return vs_versions + + @staticmethod + def _as_float_version(version): + """ + Return a string version as a simplified float version (major.minor) + + Parameters + ---------- + version: str + Version. + + Return + ------ + float + version + """ + return float('.'.join(version.split('.')[:2])) + + @property + def VSInstallDir(self): + """ + Microsoft Visual Studio directory. + + Return + ------ + str + path + """ + # Default path + default = join(self.ProgramFilesx86, + 'Microsoft Visual Studio %0.1f' % self.vs_ver) + + # Try to get path from registry, if fail use default path + return self.ri.lookup(self.ri.vs, '%0.1f' % self.vs_ver) or default + + @property + def VCInstallDir(self): + """ + Microsoft Visual C++ directory. + + Return + ------ + str + path + """ + path = self._guess_vc() or self._guess_vc_legacy() + + if not isdir(path): + msg = 'Microsoft Visual C++ directory not found' + raise distutils.errors.DistutilsPlatformError(msg) + + return path + + def _guess_vc(self): + """ + Locate Visual C++ for VS2017+. + + Return + ------ + str + path + """ + if self.vs_ver <= 14.0: + return '' + + try: + # First search in known VS paths + vs_dir = self.known_vs_paths[self.vs_ver] + except KeyError: + # Else, search with path from registry + vs_dir = self.VSInstallDir + + guess_vc = join(vs_dir, r'VC\Tools\MSVC') + + # Subdir with VC exact version as name + try: + # Update the VC version with real one instead of VS version + vc_ver = listdir(guess_vc)[-1] + self.vc_ver = self._as_float_version(vc_ver) + return join(guess_vc, vc_ver) + except (OSError, IOError, IndexError): + return '' + + def _guess_vc_legacy(self): + """ + Locate Visual C++ for versions prior to 2017. + + Return + ------ + str + path + """ + default = join(self.ProgramFilesx86, + r'Microsoft Visual Studio %0.1f\VC' % self.vs_ver) + + # Try to get "VC++ for Python" path from registry as default path + reg_path = join(self.ri.vc_for_python, '%0.1f' % self.vs_ver) + python_vc = self.ri.lookup(reg_path, 'installdir') + default_vc = join(python_vc, 'VC') if python_vc else default + + # Try to get path from registry, if fail use default path + return self.ri.lookup(self.ri.vc, '%0.1f' % self.vs_ver) or default_vc + + @property + def WindowsSdkVersion(self): + """ + Microsoft Windows SDK versions for specified MSVC++ version. + + Return + ------ + tuple of str + versions + """ + if self.vs_ver <= 9.0: + return '7.0', '6.1', '6.0a' + elif self.vs_ver == 10.0: + return '7.1', '7.0a' + elif self.vs_ver == 11.0: + return '8.0', '8.0a' + elif self.vs_ver == 12.0: + return '8.1', '8.1a' + elif self.vs_ver >= 14.0: + return '10.0', '8.1' + + @property + def WindowsSdkLastVersion(self): + """ + Microsoft Windows SDK last version. + + Return + ------ + str + version + """ + return self._use_last_dir_name(join(self.WindowsSdkDir, 'lib')) + + @property + def WindowsSdkDir(self): + """ + Microsoft Windows SDK directory. + + Return + ------ + str + path + """ + sdkdir = '' + for ver in self.WindowsSdkVersion: + # Try to get it from registry + loc = join(self.ri.windows_sdk, 'v%s' % ver) + sdkdir = self.ri.lookup(loc, 'installationfolder') + if sdkdir: + break + if not sdkdir or not isdir(sdkdir): + # Try to get "VC++ for Python" version from registry + path = join(self.ri.vc_for_python, '%0.1f' % self.vc_ver) + install_base = self.ri.lookup(path, 'installdir') + if install_base: + sdkdir = join(install_base, 'WinSDK') + if not sdkdir or not isdir(sdkdir): + # If fail, use default new path + for ver in self.WindowsSdkVersion: + intver = ver[:ver.rfind('.')] + path = r'Microsoft SDKs\Windows Kits\%s' % intver + d = join(self.ProgramFiles, path) + if isdir(d): + sdkdir = d + if not sdkdir or not isdir(sdkdir): + # If fail, use default old path + for ver in self.WindowsSdkVersion: + path = r'Microsoft SDKs\Windows\v%s' % ver + d = join(self.ProgramFiles, path) + if isdir(d): + sdkdir = d + if not sdkdir: + # If fail, use Platform SDK + sdkdir = join(self.VCInstallDir, 'PlatformSDK') + return sdkdir + + @property + def WindowsSDKExecutablePath(self): + """ + Microsoft Windows SDK executable directory. + + Return + ------ + str + path + """ + # Find WinSDK NetFx Tools registry dir name + if self.vs_ver <= 11.0: + netfxver = 35 + arch = '' + else: + netfxver = 40 + hidex86 = True if self.vs_ver <= 12.0 else False + arch = self.pi.current_dir(x64=True, hidex86=hidex86) + fx = 'WinSDK-NetFx%dTools%s' % (netfxver, arch.replace('\\', '-')) + + # list all possibles registry paths + regpaths = [] + if self.vs_ver >= 14.0: + for ver in self.NetFxSdkVersion: + regpaths += [join(self.ri.netfx_sdk, ver, fx)] + + for ver in self.WindowsSdkVersion: + regpaths += [join(self.ri.windows_sdk, 'v%sA' % ver, fx)] + + # Return installation folder from the more recent path + for path in regpaths: + execpath = self.ri.lookup(path, 'installationfolder') + if execpath: + return execpath + + @property + def FSharpInstallDir(self): + """ + Microsoft Visual F# directory. + + Return + ------ + str + path + """ + path = join(self.ri.visualstudio, r'%0.1f\Setup\F#' % self.vs_ver) + return self.ri.lookup(path, 'productdir') or '' + + @property + def UniversalCRTSdkDir(self): + """ + Microsoft Universal CRT SDK directory. + + Return + ------ + str + path + """ + # Set Kit Roots versions for specified MSVC++ version + vers = ('10', '81') if self.vs_ver >= 14.0 else () + + # Find path of the more recent Kit + for ver in vers: + sdkdir = self.ri.lookup(self.ri.windows_kits_roots, + 'kitsroot%s' % ver) + if sdkdir: + return sdkdir or '' + + @property + def UniversalCRTSdkLastVersion(self): + """ + Microsoft Universal C Runtime SDK last version. + + Return + ------ + str + version + """ + return self._use_last_dir_name(join(self.UniversalCRTSdkDir, 'lib')) + + @property + def NetFxSdkVersion(self): + """ + Microsoft .NET Framework SDK versions. + + Return + ------ + tuple of str + versions + """ + # Set FxSdk versions for specified VS version + return (('4.7.2', '4.7.1', '4.7', + '4.6.2', '4.6.1', '4.6', + '4.5.2', '4.5.1', '4.5') + if self.vs_ver >= 14.0 else ()) + + @property + def NetFxSdkDir(self): + """ + Microsoft .NET Framework SDK directory. + + Return + ------ + str + path + """ + sdkdir = '' + for ver in self.NetFxSdkVersion: + loc = join(self.ri.netfx_sdk, ver) + sdkdir = self.ri.lookup(loc, 'kitsinstallationfolder') + if sdkdir: + break + return sdkdir + + @property + def FrameworkDir32(self): + """ + Microsoft .NET Framework 32bit directory. + + Return + ------ + str + path + """ + # Default path + guess_fw = join(self.WinDir, r'Microsoft.NET\Framework') + + # Try to get path from registry, if fail use default path + return self.ri.lookup(self.ri.vc, 'frameworkdir32') or guess_fw + + @property + def FrameworkDir64(self): + """ + Microsoft .NET Framework 64bit directory. + + Return + ------ + str + path + """ + # Default path + guess_fw = join(self.WinDir, r'Microsoft.NET\Framework64') + + # Try to get path from registry, if fail use default path + return self.ri.lookup(self.ri.vc, 'frameworkdir64') or guess_fw + + @property + def FrameworkVersion32(self): + """ + Microsoft .NET Framework 32bit versions. + + Return + ------ + tuple of str + versions + """ + return self._find_dot_net_versions(32) + + @property + def FrameworkVersion64(self): + """ + Microsoft .NET Framework 64bit versions. + + Return + ------ + tuple of str + versions + """ + return self._find_dot_net_versions(64) + + def _find_dot_net_versions(self, bits): + """ + Find Microsoft .NET Framework versions. + + Parameters + ---------- + bits: int + Platform number of bits: 32 or 64. + + Return + ------ + tuple of str + versions + """ + # Find actual .NET version in registry + reg_ver = self.ri.lookup(self.ri.vc, 'frameworkver%d' % bits) + dot_net_dir = getattr(self, 'FrameworkDir%d' % bits) + ver = reg_ver or self._use_last_dir_name(dot_net_dir, 'v') or '' + + # Set .NET versions for specified MSVC++ version + if self.vs_ver >= 12.0: + return ver, 'v4.0' + elif self.vs_ver >= 10.0: + return 'v4.0.30319' if ver.lower()[:2] != 'v4' else ver, 'v3.5' + elif self.vs_ver == 9.0: + return 'v3.5', 'v2.0.50727' + elif self.vs_ver == 8.0: + return 'v3.0', 'v2.0.50727' + + @staticmethod + def _use_last_dir_name(path, prefix=''): + """ + Return name of the last dir in path or '' if no dir found. + + Parameters + ---------- + path: str + Use dirs in this path + prefix: str + Use only dirs starting by this prefix + + Return + ------ + str + name + """ + matching_dirs = ( + dir_name + for dir_name in reversed(listdir(path)) + if isdir(join(path, dir_name)) and + dir_name.startswith(prefix) + ) + return next(matching_dirs, None) or '' + + +class EnvironmentInfo: + """ + Return environment variables for specified Microsoft Visual C++ version + and platform : Lib, Include, Path and libpath. + + This function is compatible with Microsoft Visual C++ 9.0 to 14.X. + + Script created by analysing Microsoft environment configuration files like + "vcvars[...].bat", "SetEnv.Cmd", "vcbuildtools.bat", ... + + Parameters + ---------- + arch: str + Target architecture. + vc_ver: float + Required Microsoft Visual C++ version. If not set, autodetect the last + version. + vc_min_ver: float + Minimum Microsoft Visual C++ version. + """ + + # Variables and properties in this class use originals CamelCase variables + # names from Microsoft source files for more easy comparison. + + def __init__(self, arch, vc_ver=None, vc_min_ver=0): + self.pi = PlatformInfo(arch) + self.ri = RegistryInfo(self.pi) + self.si = SystemInfo(self.ri, vc_ver) + + if self.vc_ver < vc_min_ver: + err = 'No suitable Microsoft Visual C++ version found' + raise distutils.errors.DistutilsPlatformError(err) + + @property + def vs_ver(self): + """ + Microsoft Visual Studio. + + Return + ------ + float + version + """ + return self.si.vs_ver + + @property + def vc_ver(self): + """ + Microsoft Visual C++ version. + + Return + ------ + float + version + """ + return self.si.vc_ver + + @property + def VSTools(self): + """ + Microsoft Visual Studio Tools. + + Return + ------ + list of str + paths + """ + paths = [r'Common7\IDE', r'Common7\Tools'] + + if self.vs_ver >= 14.0: + arch_subdir = self.pi.current_dir(hidex86=True, x64=True) + paths += [r'Common7\IDE\CommonExtensions\Microsoft\TestWindow'] + paths += [r'Team Tools\Performance Tools'] + paths += [r'Team Tools\Performance Tools%s' % arch_subdir] + + return [join(self.si.VSInstallDir, path) for path in paths] + + @property + def VCIncludes(self): + """ + Microsoft Visual C++ & Microsoft Foundation Class Includes. + + Return + ------ + list of str + paths + """ + return [join(self.si.VCInstallDir, 'Include'), + join(self.si.VCInstallDir, r'ATLMFC\Include')] + + @property + def VCLibraries(self): + """ + Microsoft Visual C++ & Microsoft Foundation Class Libraries. + + Return + ------ + list of str + paths + """ + if self.vs_ver >= 15.0: + arch_subdir = self.pi.target_dir(x64=True) + else: + arch_subdir = self.pi.target_dir(hidex86=True) + paths = ['Lib%s' % arch_subdir, r'ATLMFC\Lib%s' % arch_subdir] + + if self.vs_ver >= 14.0: + paths += [r'Lib\store%s' % arch_subdir] + + return [join(self.si.VCInstallDir, path) for path in paths] + + @property + def VCStoreRefs(self): + """ + Microsoft Visual C++ store references Libraries. + + Return + ------ + list of str + paths + """ + if self.vs_ver < 14.0: + return [] + return [join(self.si.VCInstallDir, r'Lib\store\references')] + + @property + def VCTools(self): + """ + Microsoft Visual C++ Tools. + + Return + ------ + list of str + paths + """ + si = self.si + tools = [join(si.VCInstallDir, 'VCPackages')] + + forcex86 = True if self.vs_ver <= 10.0 else False + arch_subdir = self.pi.cross_dir(forcex86) + if arch_subdir: + tools += [join(si.VCInstallDir, 'Bin%s' % arch_subdir)] + + if self.vs_ver == 14.0: + path = 'Bin%s' % self.pi.current_dir(hidex86=True) + tools += [join(si.VCInstallDir, path)] + + elif self.vs_ver >= 15.0: + host_dir = (r'bin\HostX86%s' if self.pi.current_is_x86() else + r'bin\HostX64%s') + tools += [join( + si.VCInstallDir, host_dir % self.pi.target_dir(x64=True))] + + if self.pi.current_cpu != self.pi.target_cpu: + tools += [join( + si.VCInstallDir, host_dir % self.pi.current_dir(x64=True))] + + else: + tools += [join(si.VCInstallDir, 'Bin')] + + return tools + + @property + def OSLibraries(self): + """ + Microsoft Windows SDK Libraries. + + Return + ------ + list of str + paths + """ + if self.vs_ver <= 10.0: + arch_subdir = self.pi.target_dir(hidex86=True, x64=True) + return [join(self.si.WindowsSdkDir, 'Lib%s' % arch_subdir)] + + else: + arch_subdir = self.pi.target_dir(x64=True) + lib = join(self.si.WindowsSdkDir, 'lib') + libver = self._sdk_subdir + return [join(lib, '%sum%s' % (libver , arch_subdir))] + + @property + def OSIncludes(self): + """ + Microsoft Windows SDK Include. + + Return + ------ + list of str + paths + """ + include = join(self.si.WindowsSdkDir, 'include') + + if self.vs_ver <= 10.0: + return [include, join(include, 'gl')] + + else: + if self.vs_ver >= 14.0: + sdkver = self._sdk_subdir + else: + sdkver = '' + return [join(include, '%sshared' % sdkver), + join(include, '%sum' % sdkver), + join(include, '%swinrt' % sdkver)] + + @property + def OSLibpath(self): + """ + Microsoft Windows SDK Libraries Paths. + + Return + ------ + list of str + paths + """ + ref = join(self.si.WindowsSdkDir, 'References') + libpath = [] + + if self.vs_ver <= 9.0: + libpath += self.OSLibraries + + if self.vs_ver >= 11.0: + libpath += [join(ref, r'CommonConfiguration\Neutral')] + + if self.vs_ver >= 14.0: + libpath += [ + ref, + join(self.si.WindowsSdkDir, 'UnionMetadata'), + join(ref, 'Windows.Foundation.UniversalApiContract', '1.0.0.0'), + join(ref, 'Windows.Foundation.FoundationContract', '1.0.0.0'), + join(ref,'Windows.Networking.Connectivity.WwanContract', + '1.0.0.0'), + join(self.si.WindowsSdkDir, 'ExtensionSDKs', 'Microsoft.VCLibs', + '%0.1f' % self.vs_ver, 'References', 'CommonConfiguration', + 'neutral'), + ] + return libpath + + @property + def SdkTools(self): + """ + Microsoft Windows SDK Tools. + + Return + ------ + list of str + paths + """ + return list(self._sdk_tools()) + + def _sdk_tools(self): + """ + Microsoft Windows SDK Tools paths generator. + + Return + ------ + generator of str + paths + """ + if self.vs_ver < 15.0: + bin_dir = 'Bin' if self.vs_ver <= 11.0 else r'Bin\x86' + yield join(self.si.WindowsSdkDir, bin_dir) + + if not self.pi.current_is_x86(): + arch_subdir = self.pi.current_dir(x64=True) + path = 'Bin%s' % arch_subdir + yield join(self.si.WindowsSdkDir, path) + + if self.vs_ver in (10.0, 11.0): + if self.pi.target_is_x86(): + arch_subdir = '' + else: + arch_subdir = self.pi.current_dir(hidex86=True, x64=True) + path = r'Bin\NETFX 4.0 Tools%s' % arch_subdir + yield join(self.si.WindowsSdkDir, path) + + elif self.vs_ver >= 15.0: + path = join(self.si.WindowsSdkDir, 'Bin') + arch_subdir = self.pi.current_dir(x64=True) + sdkver = self.si.WindowsSdkLastVersion + yield join(path, '%s%s' % (sdkver, arch_subdir)) + + if self.si.WindowsSDKExecutablePath: + yield self.si.WindowsSDKExecutablePath + + @property + def _sdk_subdir(self): + """ + Microsoft Windows SDK version subdir. + + Return + ------ + str + subdir + """ + ucrtver = self.si.WindowsSdkLastVersion + return ('%s\\' % ucrtver) if ucrtver else '' + + @property + def SdkSetup(self): + """ + Microsoft Windows SDK Setup. + + Return + ------ + list of str + paths + """ + if self.vs_ver > 9.0: + return [] + + return [join(self.si.WindowsSdkDir, 'Setup')] + + @property + def FxTools(self): + """ + Microsoft .NET Framework Tools. + + Return + ------ + list of str + paths + """ + pi = self.pi + si = self.si + + if self.vs_ver <= 10.0: + include32 = True + include64 = not pi.target_is_x86() and not pi.current_is_x86() + else: + include32 = pi.target_is_x86() or pi.current_is_x86() + include64 = pi.current_cpu == 'amd64' or pi.target_cpu == 'amd64' + + tools = [] + if include32: + tools += [join(si.FrameworkDir32, ver) + for ver in si.FrameworkVersion32] + if include64: + tools += [join(si.FrameworkDir64, ver) + for ver in si.FrameworkVersion64] + return tools + + @property + def NetFxSDKLibraries(self): + """ + Microsoft .Net Framework SDK Libraries. + + Return + ------ + list of str + paths + """ + if self.vs_ver < 14.0 or not self.si.NetFxSdkDir: + return [] + + arch_subdir = self.pi.target_dir(x64=True) + return [join(self.si.NetFxSdkDir, r'lib\um%s' % arch_subdir)] + + @property + def NetFxSDKIncludes(self): + """ + Microsoft .Net Framework SDK Includes. + + Return + ------ + list of str + paths + """ + if self.vs_ver < 14.0 or not self.si.NetFxSdkDir: + return [] + + return [join(self.si.NetFxSdkDir, r'include\um')] + + @property + def VsTDb(self): + """ + Microsoft Visual Studio Team System Database. + + Return + ------ + list of str + paths + """ + return [join(self.si.VSInstallDir, r'VSTSDB\Deploy')] + + @property + def MSBuild(self): + """ + Microsoft Build Engine. + + Return + ------ + list of str + paths + """ + if self.vs_ver < 12.0: + return [] + elif self.vs_ver < 15.0: + base_path = self.si.ProgramFilesx86 + arch_subdir = self.pi.current_dir(hidex86=True) + else: + base_path = self.si.VSInstallDir + arch_subdir = '' + + path = r'MSBuild\%0.1f\bin%s' % (self.vs_ver, arch_subdir) + build = [join(base_path, path)] + + if self.vs_ver >= 15.0: + # Add Roslyn C# & Visual Basic Compiler + build += [join(base_path, path, 'Roslyn')] + + return build + + @property + def HTMLHelpWorkshop(self): + """ + Microsoft HTML Help Workshop. + + Return + ------ + list of str + paths + """ + if self.vs_ver < 11.0: + return [] + + return [join(self.si.ProgramFilesx86, 'HTML Help Workshop')] + + @property + def UCRTLibraries(self): + """ + Microsoft Universal C Runtime SDK Libraries. + + Return + ------ + list of str + paths + """ + if self.vs_ver < 14.0: + return [] + + arch_subdir = self.pi.target_dir(x64=True) + lib = join(self.si.UniversalCRTSdkDir, 'lib') + ucrtver = self._ucrt_subdir + return [join(lib, '%sucrt%s' % (ucrtver, arch_subdir))] + + @property + def UCRTIncludes(self): + """ + Microsoft Universal C Runtime SDK Include. + + Return + ------ + list of str + paths + """ + if self.vs_ver < 14.0: + return [] + + include = join(self.si.UniversalCRTSdkDir, 'include') + return [join(include, '%sucrt' % self._ucrt_subdir)] + + @property + def _ucrt_subdir(self): + """ + Microsoft Universal C Runtime SDK version subdir. + + Return + ------ + str + subdir + """ + ucrtver = self.si.UniversalCRTSdkLastVersion + return ('%s\\' % ucrtver) if ucrtver else '' + + @property + def FSharp(self): + """ + Microsoft Visual F#. + + Return + ------ + list of str + paths + """ + if 11.0 > self.vs_ver > 12.0: + return [] + + return [self.si.FSharpInstallDir] + + @property + def VCRuntimeRedist(self): + """ + Microsoft Visual C++ runtime redistributable dll. + + Return + ------ + str + path + """ + vcruntime = 'vcruntime%d0.dll' % self.vc_ver + arch_subdir = self.pi.target_dir(x64=True).strip('\\') + + # Installation prefixes candidates + prefixes = [] + tools_path = self.si.VCInstallDir + redist_path = dirname(tools_path.replace(r'\Tools', r'\Redist')) + if isdir(redist_path): + # Redist version may not be exactly the same as tools + redist_path = join(redist_path, listdir(redist_path)[-1]) + prefixes += [redist_path, join(redist_path, 'onecore')] + + prefixes += [join(tools_path, 'redist')] # VS14 legacy path + + # CRT directory + crt_dirs = ('Microsoft.VC%d.CRT' % (self.vc_ver * 10), + # Sometime store in directory with VS version instead of VC + 'Microsoft.VC%d.CRT' % (int(self.vs_ver) * 10)) + + # vcruntime path + for prefix, crt_dir in itertools.product(prefixes, crt_dirs): + path = join(prefix, arch_subdir, crt_dir, vcruntime) + if isfile(path): + return path + + def return_env(self, exists=True): + """ + Return environment dict. + + Parameters + ---------- + exists: bool + It True, only return existing paths. + + Return + ------ + dict + environment + """ + env = dict( + include=self._build_paths('include', + [self.VCIncludes, + self.OSIncludes, + self.UCRTIncludes, + self.NetFxSDKIncludes], + exists), + lib=self._build_paths('lib', + [self.VCLibraries, + self.OSLibraries, + self.FxTools, + self.UCRTLibraries, + self.NetFxSDKLibraries], + exists), + libpath=self._build_paths('libpath', + [self.VCLibraries, + self.FxTools, + self.VCStoreRefs, + self.OSLibpath], + exists), + path=self._build_paths('path', + [self.VCTools, + self.VSTools, + self.VsTDb, + self.SdkTools, + self.SdkSetup, + self.FxTools, + self.MSBuild, + self.HTMLHelpWorkshop, + self.FSharp], + exists), + ) + if self.vs_ver >= 14 and isfile(self.VCRuntimeRedist): + env['py_vcruntime_redist'] = self.VCRuntimeRedist + return env + + def _build_paths(self, name, spec_path_lists, exists): + """ + Given an environment variable name and specified paths, + return a pathsep-separated string of paths containing + unique, extant, directories from those paths and from + the environment variable. Raise an error if no paths + are resolved. + + Parameters + ---------- + name: str + Environment variable name + spec_path_lists: list of str + Paths + exists: bool + It True, only return existing paths. + + Return + ------ + str + Pathsep-separated paths + """ + # flatten spec_path_lists + spec_paths = itertools.chain.from_iterable(spec_path_lists) + env_paths = environ.get(name, '').split(pathsep) + paths = itertools.chain(spec_paths, env_paths) + extant_paths = list(filter(isdir, paths)) if exists else paths + if not extant_paths: + msg = "%s environment variable is empty" % name.upper() + raise distutils.errors.DistutilsPlatformError(msg) + unique_paths = self._unique_everseen(extant_paths) + return pathsep.join(unique_paths) + + # from Python docs + @staticmethod + def _unique_everseen(iterable, key=None): + """ + List unique elements, preserving order. + Remember all elements ever seen. + + _unique_everseen('AAAABBBCCDAABBB') --> A B C D + + _unique_everseen('ABBCcAD', str.lower) --> A B C D + """ + seen = set() + seen_add = seen.add + if key is None: + for element in filterfalse(seen.__contains__, iterable): + seen_add(element) + yield element + else: + for element in iterable: + k = key(element) + if k not in seen: + seen_add(k) + yield element diff --git a/venv/lib/python3.8/site-packages/setuptools/namespaces.py b/venv/lib/python3.8/site-packages/setuptools/namespaces.py new file mode 100644 index 0000000..dc16106 --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/namespaces.py @@ -0,0 +1,107 @@ +import os +from distutils import log +import itertools + +from setuptools.extern.six.moves import map + + +flatten = itertools.chain.from_iterable + + +class Installer: + + nspkg_ext = '-nspkg.pth' + + def install_namespaces(self): + nsp = self._get_all_ns_packages() + if not nsp: + return + filename, ext = os.path.splitext(self._get_target()) + filename += self.nspkg_ext + self.outputs.append(filename) + log.info("Installing %s", filename) + lines = map(self._gen_nspkg_line, nsp) + + if self.dry_run: + # always generate the lines, even in dry run + list(lines) + return + + with open(filename, 'wt') as f: + f.writelines(lines) + + def uninstall_namespaces(self): + filename, ext = os.path.splitext(self._get_target()) + filename += self.nspkg_ext + if not os.path.exists(filename): + return + log.info("Removing %s", filename) + os.remove(filename) + + def _get_target(self): + return self.target + + _nspkg_tmpl = ( + "import sys, types, os", + "has_mfs = sys.version_info > (3, 5)", + "p = os.path.join(%(root)s, *%(pth)r)", + "importlib = has_mfs and __import__('importlib.util')", + "has_mfs and __import__('importlib.machinery')", + "m = has_mfs and " + "sys.modules.setdefault(%(pkg)r, " + "importlib.util.module_from_spec(" + "importlib.machinery.PathFinder.find_spec(%(pkg)r, " + "[os.path.dirname(p)])))", + "m = m or " + "sys.modules.setdefault(%(pkg)r, types.ModuleType(%(pkg)r))", + "mp = (m or []) and m.__dict__.setdefault('__path__',[])", + "(p not in mp) and mp.append(p)", + ) + "lines for the namespace installer" + + _nspkg_tmpl_multi = ( + 'm and setattr(sys.modules[%(parent)r], %(child)r, m)', + ) + "additional line(s) when a parent package is indicated" + + def _get_root(self): + return "sys._getframe(1).f_locals['sitedir']" + + def _gen_nspkg_line(self, pkg): + # ensure pkg is not a unicode string under Python 2.7 + pkg = str(pkg) + pth = tuple(pkg.split('.')) + root = self._get_root() + tmpl_lines = self._nspkg_tmpl + parent, sep, child = pkg.rpartition('.') + if parent: + tmpl_lines += self._nspkg_tmpl_multi + return ';'.join(tmpl_lines) % locals() + '\n' + + def _get_all_ns_packages(self): + """Return sorted list of all package namespaces""" + pkgs = self.distribution.namespace_packages or [] + return sorted(flatten(map(self._pkg_names, pkgs))) + + @staticmethod + def _pkg_names(pkg): + """ + Given a namespace package, yield the components of that + package. + + >>> names = Installer._pkg_names('a.b.c') + >>> set(names) == set(['a', 'a.b', 'a.b.c']) + True + """ + parts = pkg.split('.') + while parts: + yield '.'.join(parts) + parts.pop() + + +class DevelopInstaller(Installer): + def _get_root(self): + return repr(str(self.egg_path)) + + def _get_target(self): + return self.egg_link diff --git a/venv/lib/python3.8/site-packages/setuptools/package_index.py b/venv/lib/python3.8/site-packages/setuptools/package_index.py new file mode 100644 index 0000000..f419d47 --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/package_index.py @@ -0,0 +1,1136 @@ +"""PyPI and direct package downloading""" +import sys +import os +import re +import shutil +import socket +import base64 +import hashlib +import itertools +import warnings +from functools import wraps + +from setuptools.extern import six +from setuptools.extern.six.moves import urllib, http_client, configparser, map + +import setuptools +from pkg_resources import ( + CHECKOUT_DIST, Distribution, BINARY_DIST, normalize_path, SOURCE_DIST, + Environment, find_distributions, safe_name, safe_version, + to_filename, Requirement, DEVELOP_DIST, EGG_DIST, +) +from setuptools import ssl_support +from distutils import log +from distutils.errors import DistutilsError +from fnmatch import translate +from setuptools.py27compat import get_all_headers +from setuptools.py33compat import unescape +from setuptools.wheel import Wheel + +__metaclass__ = type + +EGG_FRAGMENT = re.compile(r'^egg=([-A-Za-z0-9_.+!]+)$') +HREF = re.compile(r"""href\s*=\s*['"]?([^'"> ]+)""", re.I) +PYPI_MD5 = re.compile( + r'([^<]+)\n\s+\(md5\)' +) +URL_SCHEME = re.compile('([-+.a-z0-9]{2,}):', re.I).match +EXTENSIONS = ".tar.gz .tar.bz2 .tar .zip .tgz".split() + +__all__ = [ + 'PackageIndex', 'distros_for_url', 'parse_bdist_wininst', + 'interpret_distro_name', +] + +_SOCKET_TIMEOUT = 15 + +_tmpl = "setuptools/{setuptools.__version__} Python-urllib/{py_major}" +user_agent = _tmpl.format(py_major='{}.{}'.format(*sys.version_info), setuptools=setuptools) + + +def parse_requirement_arg(spec): + try: + return Requirement.parse(spec) + except ValueError: + raise DistutilsError( + "Not a URL, existing file, or requirement spec: %r" % (spec,) + ) + + +def parse_bdist_wininst(name): + """Return (base,pyversion) or (None,None) for possible .exe name""" + + lower = name.lower() + base, py_ver, plat = None, None, None + + if lower.endswith('.exe'): + if lower.endswith('.win32.exe'): + base = name[:-10] + plat = 'win32' + elif lower.startswith('.win32-py', -16): + py_ver = name[-7:-4] + base = name[:-16] + plat = 'win32' + elif lower.endswith('.win-amd64.exe'): + base = name[:-14] + plat = 'win-amd64' + elif lower.startswith('.win-amd64-py', -20): + py_ver = name[-7:-4] + base = name[:-20] + plat = 'win-amd64' + return base, py_ver, plat + + +def egg_info_for_url(url): + parts = urllib.parse.urlparse(url) + scheme, server, path, parameters, query, fragment = parts + base = urllib.parse.unquote(path.split('/')[-1]) + if server == 'sourceforge.net' and base == 'download': # XXX Yuck + base = urllib.parse.unquote(path.split('/')[-2]) + if '#' in base: + base, fragment = base.split('#', 1) + return base, fragment + + +def distros_for_url(url, metadata=None): + """Yield egg or source distribution objects that might be found at a URL""" + base, fragment = egg_info_for_url(url) + for dist in distros_for_location(url, base, metadata): + yield dist + if fragment: + match = EGG_FRAGMENT.match(fragment) + if match: + for dist in interpret_distro_name( + url, match.group(1), metadata, precedence=CHECKOUT_DIST + ): + yield dist + + +def distros_for_location(location, basename, metadata=None): + """Yield egg or source distribution objects based on basename""" + if basename.endswith('.egg.zip'): + basename = basename[:-4] # strip the .zip + if basename.endswith('.egg') and '-' in basename: + # only one, unambiguous interpretation + return [Distribution.from_location(location, basename, metadata)] + if basename.endswith('.whl') and '-' in basename: + wheel = Wheel(basename) + if not wheel.is_compatible(): + return [] + return [Distribution( + location=location, + project_name=wheel.project_name, + version=wheel.version, + # Increase priority over eggs. + precedence=EGG_DIST + 1, + )] + if basename.endswith('.exe'): + win_base, py_ver, platform = parse_bdist_wininst(basename) + if win_base is not None: + return interpret_distro_name( + location, win_base, metadata, py_ver, BINARY_DIST, platform + ) + # Try source distro extensions (.zip, .tgz, etc.) + # + for ext in EXTENSIONS: + if basename.endswith(ext): + basename = basename[:-len(ext)] + return interpret_distro_name(location, basename, metadata) + return [] # no extension matched + + +def distros_for_filename(filename, metadata=None): + """Yield possible egg or source distribution objects based on a filename""" + return distros_for_location( + normalize_path(filename), os.path.basename(filename), metadata + ) + + +def interpret_distro_name( + location, basename, metadata, py_version=None, precedence=SOURCE_DIST, + platform=None +): + """Generate alternative interpretations of a source distro name + + Note: if `location` is a filesystem filename, you should call + ``pkg_resources.normalize_path()`` on it before passing it to this + routine! + """ + # Generate alternative interpretations of a source distro name + # Because some packages are ambiguous as to name/versions split + # e.g. "adns-python-1.1.0", "egenix-mx-commercial", etc. + # So, we generate each possible interepretation (e.g. "adns, python-1.1.0" + # "adns-python, 1.1.0", and "adns-python-1.1.0, no version"). In practice, + # the spurious interpretations should be ignored, because in the event + # there's also an "adns" package, the spurious "python-1.1.0" version will + # compare lower than any numeric version number, and is therefore unlikely + # to match a request for it. It's still a potential problem, though, and + # in the long run PyPI and the distutils should go for "safe" names and + # versions in distribution archive names (sdist and bdist). + + parts = basename.split('-') + if not py_version and any(re.match(r'py\d\.\d$', p) for p in parts[2:]): + # it is a bdist_dumb, not an sdist -- bail out + return + + for p in range(1, len(parts) + 1): + yield Distribution( + location, metadata, '-'.join(parts[:p]), '-'.join(parts[p:]), + py_version=py_version, precedence=precedence, + platform=platform + ) + + +# From Python 2.7 docs +def unique_everseen(iterable, key=None): + "List unique elements, preserving order. Remember all elements ever seen." + # unique_everseen('AAAABBBCCDAABBB') --> A B C D + # unique_everseen('ABBCcAD', str.lower) --> A B C D + seen = set() + seen_add = seen.add + if key is None: + for element in six.moves.filterfalse(seen.__contains__, iterable): + seen_add(element) + yield element + else: + for element in iterable: + k = key(element) + if k not in seen: + seen_add(k) + yield element + + +def unique_values(func): + """ + Wrap a function returning an iterable such that the resulting iterable + only ever yields unique items. + """ + + @wraps(func) + def wrapper(*args, **kwargs): + return unique_everseen(func(*args, **kwargs)) + + return wrapper + + +REL = re.compile(r"""<([^>]*\srel\s*=\s*['"]?([^'">]+)[^>]*)>""", re.I) +# this line is here to fix emacs' cruddy broken syntax highlighting + + +@unique_values +def find_external_links(url, page): + """Find rel="homepage" and rel="download" links in `page`, yielding URLs""" + + for match in REL.finditer(page): + tag, rel = match.groups() + rels = set(map(str.strip, rel.lower().split(','))) + if 'homepage' in rels or 'download' in rels: + for match in HREF.finditer(tag): + yield urllib.parse.urljoin(url, htmldecode(match.group(1))) + + for tag in ("Home Page", "Download URL"): + pos = page.find(tag) + if pos != -1: + match = HREF.search(page, pos) + if match: + yield urllib.parse.urljoin(url, htmldecode(match.group(1))) + + +class ContentChecker: + """ + A null content checker that defines the interface for checking content + """ + + def feed(self, block): + """ + Feed a block of data to the hash. + """ + return + + def is_valid(self): + """ + Check the hash. Return False if validation fails. + """ + return True + + def report(self, reporter, template): + """ + Call reporter with information about the checker (hash name) + substituted into the template. + """ + return + + +class HashChecker(ContentChecker): + pattern = re.compile( + r'(?Psha1|sha224|sha384|sha256|sha512|md5)=' + r'(?P[a-f0-9]+)' + ) + + def __init__(self, hash_name, expected): + self.hash_name = hash_name + self.hash = hashlib.new(hash_name) + self.expected = expected + + @classmethod + def from_url(cls, url): + "Construct a (possibly null) ContentChecker from a URL" + fragment = urllib.parse.urlparse(url)[-1] + if not fragment: + return ContentChecker() + match = cls.pattern.search(fragment) + if not match: + return ContentChecker() + return cls(**match.groupdict()) + + def feed(self, block): + self.hash.update(block) + + def is_valid(self): + return self.hash.hexdigest() == self.expected + + def report(self, reporter, template): + msg = template % self.hash_name + return reporter(msg) + + +class PackageIndex(Environment): + """A distribution index that scans web pages for download URLs""" + + def __init__( + self, index_url="https://pypi.org/simple/", hosts=('*',), + ca_bundle=None, verify_ssl=True, *args, **kw + ): + Environment.__init__(self, *args, **kw) + self.index_url = index_url + "/" [:not index_url.endswith('/')] + self.scanned_urls = {} + self.fetched_urls = {} + self.package_pages = {} + self.allows = re.compile('|'.join(map(translate, hosts))).match + self.to_scan = [] + use_ssl = ( + verify_ssl + and ssl_support.is_available + and (ca_bundle or ssl_support.find_ca_bundle()) + ) + if use_ssl: + self.opener = ssl_support.opener_for(ca_bundle) + else: + self.opener = urllib.request.urlopen + + def process_url(self, url, retrieve=False): + """Evaluate a URL as a possible download, and maybe retrieve it""" + if url in self.scanned_urls and not retrieve: + return + self.scanned_urls[url] = True + if not URL_SCHEME(url): + self.process_filename(url) + return + else: + dists = list(distros_for_url(url)) + if dists: + if not self.url_ok(url): + return + self.debug("Found link: %s", url) + + if dists or not retrieve or url in self.fetched_urls: + list(map(self.add, dists)) + return # don't need the actual page + + if not self.url_ok(url): + self.fetched_urls[url] = True + return + + self.info("Reading %s", url) + self.fetched_urls[url] = True # prevent multiple fetch attempts + tmpl = "Download error on %s: %%s -- Some packages may not be found!" + f = self.open_url(url, tmpl % url) + if f is None: + return + self.fetched_urls[f.url] = True + if 'html' not in f.headers.get('content-type', '').lower(): + f.close() # not html, we can't process it + return + + base = f.url # handle redirects + page = f.read() + if not isinstance(page, str): + # In Python 3 and got bytes but want str. + if isinstance(f, urllib.error.HTTPError): + # Errors have no charset, assume latin1: + charset = 'latin-1' + else: + charset = f.headers.get_param('charset') or 'latin-1' + page = page.decode(charset, "ignore") + f.close() + for match in HREF.finditer(page): + link = urllib.parse.urljoin(base, htmldecode(match.group(1))) + self.process_url(link) + if url.startswith(self.index_url) and getattr(f, 'code', None) != 404: + page = self.process_index(url, page) + + def process_filename(self, fn, nested=False): + # process filenames or directories + if not os.path.exists(fn): + self.warn("Not found: %s", fn) + return + + if os.path.isdir(fn) and not nested: + path = os.path.realpath(fn) + for item in os.listdir(path): + self.process_filename(os.path.join(path, item), True) + + dists = distros_for_filename(fn) + if dists: + self.debug("Found: %s", fn) + list(map(self.add, dists)) + + def url_ok(self, url, fatal=False): + s = URL_SCHEME(url) + is_file = s and s.group(1).lower() == 'file' + if is_file or self.allows(urllib.parse.urlparse(url)[1]): + return True + msg = ( + "\nNote: Bypassing %s (disallowed host; see " + "http://bit.ly/2hrImnY for details).\n") + if fatal: + raise DistutilsError(msg % url) + else: + self.warn(msg, url) + + def scan_egg_links(self, search_path): + dirs = filter(os.path.isdir, search_path) + egg_links = ( + (path, entry) + for path in dirs + for entry in os.listdir(path) + if entry.endswith('.egg-link') + ) + list(itertools.starmap(self.scan_egg_link, egg_links)) + + def scan_egg_link(self, path, entry): + with open(os.path.join(path, entry)) as raw_lines: + # filter non-empty lines + lines = list(filter(None, map(str.strip, raw_lines))) + + if len(lines) != 2: + # format is not recognized; punt + return + + egg_path, setup_path = lines + + for dist in find_distributions(os.path.join(path, egg_path)): + dist.location = os.path.join(path, *lines) + dist.precedence = SOURCE_DIST + self.add(dist) + + def process_index(self, url, page): + """Process the contents of a PyPI page""" + + def scan(link): + # Process a URL to see if it's for a package page + if link.startswith(self.index_url): + parts = list(map( + urllib.parse.unquote, link[len(self.index_url):].split('/') + )) + if len(parts) == 2 and '#' not in parts[1]: + # it's a package page, sanitize and index it + pkg = safe_name(parts[0]) + ver = safe_version(parts[1]) + self.package_pages.setdefault(pkg.lower(), {})[link] = True + return to_filename(pkg), to_filename(ver) + return None, None + + # process an index page into the package-page index + for match in HREF.finditer(page): + try: + scan(urllib.parse.urljoin(url, htmldecode(match.group(1)))) + except ValueError: + pass + + pkg, ver = scan(url) # ensure this page is in the page index + if pkg: + # process individual package page + for new_url in find_external_links(url, page): + # Process the found URL + base, frag = egg_info_for_url(new_url) + if base.endswith('.py') and not frag: + if ver: + new_url += '#egg=%s-%s' % (pkg, ver) + else: + self.need_version_info(url) + self.scan_url(new_url) + + return PYPI_MD5.sub( + lambda m: '%s' % m.group(1, 3, 2), page + ) + else: + return "" # no sense double-scanning non-package pages + + def need_version_info(self, url): + self.scan_all( + "Page at %s links to .py file(s) without version info; an index " + "scan is required.", url + ) + + def scan_all(self, msg=None, *args): + if self.index_url not in self.fetched_urls: + if msg: + self.warn(msg, *args) + self.info( + "Scanning index of all packages (this may take a while)" + ) + self.scan_url(self.index_url) + + def find_packages(self, requirement): + self.scan_url(self.index_url + requirement.unsafe_name + '/') + + if not self.package_pages.get(requirement.key): + # Fall back to safe version of the name + self.scan_url(self.index_url + requirement.project_name + '/') + + if not self.package_pages.get(requirement.key): + # We couldn't find the target package, so search the index page too + self.not_found_in_index(requirement) + + for url in list(self.package_pages.get(requirement.key, ())): + # scan each page that might be related to the desired package + self.scan_url(url) + + def obtain(self, requirement, installer=None): + self.prescan() + self.find_packages(requirement) + for dist in self[requirement.key]: + if dist in requirement: + return dist + self.debug("%s does not match %s", requirement, dist) + return super(PackageIndex, self).obtain(requirement, installer) + + def check_hash(self, checker, filename, tfp): + """ + checker is a ContentChecker + """ + checker.report( + self.debug, + "Validating %%s checksum for %s" % filename) + if not checker.is_valid(): + tfp.close() + os.unlink(filename) + raise DistutilsError( + "%s validation failed for %s; " + "possible download problem?" + % (checker.hash.name, os.path.basename(filename)) + ) + + def add_find_links(self, urls): + """Add `urls` to the list that will be prescanned for searches""" + for url in urls: + if ( + self.to_scan is None # if we have already "gone online" + or not URL_SCHEME(url) # or it's a local file/directory + or url.startswith('file:') + or list(distros_for_url(url)) # or a direct package link + ): + # then go ahead and process it now + self.scan_url(url) + else: + # otherwise, defer retrieval till later + self.to_scan.append(url) + + def prescan(self): + """Scan urls scheduled for prescanning (e.g. --find-links)""" + if self.to_scan: + list(map(self.scan_url, self.to_scan)) + self.to_scan = None # from now on, go ahead and process immediately + + def not_found_in_index(self, requirement): + if self[requirement.key]: # we've seen at least one distro + meth, msg = self.info, "Couldn't retrieve index page for %r" + else: # no distros seen for this name, might be misspelled + meth, msg = ( + self.warn, + "Couldn't find index page for %r (maybe misspelled?)") + meth(msg, requirement.unsafe_name) + self.scan_all() + + def download(self, spec, tmpdir): + """Locate and/or download `spec` to `tmpdir`, returning a local path + + `spec` may be a ``Requirement`` object, or a string containing a URL, + an existing local filename, or a project/version requirement spec + (i.e. the string form of a ``Requirement`` object). If it is the URL + of a .py file with an unambiguous ``#egg=name-version`` tag (i.e., one + that escapes ``-`` as ``_`` throughout), a trivial ``setup.py`` is + automatically created alongside the downloaded file. + + If `spec` is a ``Requirement`` object or a string containing a + project/version requirement spec, this method returns the location of + a matching distribution (possibly after downloading it to `tmpdir`). + If `spec` is a locally existing file or directory name, it is simply + returned unchanged. If `spec` is a URL, it is downloaded to a subpath + of `tmpdir`, and the local filename is returned. Various errors may be + raised if a problem occurs during downloading. + """ + if not isinstance(spec, Requirement): + scheme = URL_SCHEME(spec) + if scheme: + # It's a url, download it to tmpdir + found = self._download_url(scheme.group(1), spec, tmpdir) + base, fragment = egg_info_for_url(spec) + if base.endswith('.py'): + found = self.gen_setup(found, fragment, tmpdir) + return found + elif os.path.exists(spec): + # Existing file or directory, just return it + return spec + else: + spec = parse_requirement_arg(spec) + return getattr(self.fetch_distribution(spec, tmpdir), 'location', None) + + def fetch_distribution( + self, requirement, tmpdir, force_scan=False, source=False, + develop_ok=False, local_index=None): + """Obtain a distribution suitable for fulfilling `requirement` + + `requirement` must be a ``pkg_resources.Requirement`` instance. + If necessary, or if the `force_scan` flag is set, the requirement is + searched for in the (online) package index as well as the locally + installed packages. If a distribution matching `requirement` is found, + the returned distribution's ``location`` is the value you would have + gotten from calling the ``download()`` method with the matching + distribution's URL or filename. If no matching distribution is found, + ``None`` is returned. + + If the `source` flag is set, only source distributions and source + checkout links will be considered. Unless the `develop_ok` flag is + set, development and system eggs (i.e., those using the ``.egg-info`` + format) will be ignored. + """ + # process a Requirement + self.info("Searching for %s", requirement) + skipped = {} + dist = None + + def find(req, env=None): + if env is None: + env = self + # Find a matching distribution; may be called more than once + + for dist in env[req.key]: + + if dist.precedence == DEVELOP_DIST and not develop_ok: + if dist not in skipped: + self.warn( + "Skipping development or system egg: %s", dist, + ) + skipped[dist] = 1 + continue + + test = ( + dist in req + and (dist.precedence <= SOURCE_DIST or not source) + ) + if test: + loc = self.download(dist.location, tmpdir) + dist.download_location = loc + if os.path.exists(dist.download_location): + return dist + + if force_scan: + self.prescan() + self.find_packages(requirement) + dist = find(requirement) + + if not dist and local_index is not None: + dist = find(requirement, local_index) + + if dist is None: + if self.to_scan is not None: + self.prescan() + dist = find(requirement) + + if dist is None and not force_scan: + self.find_packages(requirement) + dist = find(requirement) + + if dist is None: + self.warn( + "No local packages or working download links found for %s%s", + (source and "a source distribution of " or ""), + requirement, + ) + else: + self.info("Best match: %s", dist) + return dist.clone(location=dist.download_location) + + def fetch(self, requirement, tmpdir, force_scan=False, source=False): + """Obtain a file suitable for fulfilling `requirement` + + DEPRECATED; use the ``fetch_distribution()`` method now instead. For + backward compatibility, this routine is identical but returns the + ``location`` of the downloaded distribution instead of a distribution + object. + """ + dist = self.fetch_distribution(requirement, tmpdir, force_scan, source) + if dist is not None: + return dist.location + return None + + def gen_setup(self, filename, fragment, tmpdir): + match = EGG_FRAGMENT.match(fragment) + dists = match and [ + d for d in + interpret_distro_name(filename, match.group(1), None) if d.version + ] or [] + + if len(dists) == 1: # unambiguous ``#egg`` fragment + basename = os.path.basename(filename) + + # Make sure the file has been downloaded to the temp dir. + if os.path.dirname(filename) != tmpdir: + dst = os.path.join(tmpdir, basename) + from setuptools.command.easy_install import samefile + if not samefile(filename, dst): + shutil.copy2(filename, dst) + filename = dst + + with open(os.path.join(tmpdir, 'setup.py'), 'w') as file: + file.write( + "from setuptools import setup\n" + "setup(name=%r, version=%r, py_modules=[%r])\n" + % ( + dists[0].project_name, dists[0].version, + os.path.splitext(basename)[0] + ) + ) + return filename + + elif match: + raise DistutilsError( + "Can't unambiguously interpret project/version identifier %r; " + "any dashes in the name or version should be escaped using " + "underscores. %r" % (fragment, dists) + ) + else: + raise DistutilsError( + "Can't process plain .py files without an '#egg=name-version'" + " suffix to enable automatic setup script generation." + ) + + dl_blocksize = 8192 + + def _download_to(self, url, filename): + self.info("Downloading %s", url) + # Download the file + fp = None + try: + checker = HashChecker.from_url(url) + fp = self.open_url(url) + if isinstance(fp, urllib.error.HTTPError): + raise DistutilsError( + "Can't download %s: %s %s" % (url, fp.code, fp.msg) + ) + headers = fp.info() + blocknum = 0 + bs = self.dl_blocksize + size = -1 + if "content-length" in headers: + # Some servers return multiple Content-Length headers :( + sizes = get_all_headers(headers, 'Content-Length') + size = max(map(int, sizes)) + self.reporthook(url, filename, blocknum, bs, size) + with open(filename, 'wb') as tfp: + while True: + block = fp.read(bs) + if block: + checker.feed(block) + tfp.write(block) + blocknum += 1 + self.reporthook(url, filename, blocknum, bs, size) + else: + break + self.check_hash(checker, filename, tfp) + return headers + finally: + if fp: + fp.close() + + def reporthook(self, url, filename, blocknum, blksize, size): + pass # no-op + + def open_url(self, url, warning=None): + if url.startswith('file:'): + return local_open(url) + try: + return open_with_auth(url, self.opener) + except (ValueError, http_client.InvalidURL) as v: + msg = ' '.join([str(arg) for arg in v.args]) + if warning: + self.warn(warning, msg) + else: + raise DistutilsError('%s %s' % (url, msg)) + except urllib.error.HTTPError as v: + return v + except urllib.error.URLError as v: + if warning: + self.warn(warning, v.reason) + else: + raise DistutilsError("Download error for %s: %s" + % (url, v.reason)) + except http_client.BadStatusLine as v: + if warning: + self.warn(warning, v.line) + else: + raise DistutilsError( + '%s returned a bad status line. The server might be ' + 'down, %s' % + (url, v.line) + ) + except (http_client.HTTPException, socket.error) as v: + if warning: + self.warn(warning, v) + else: + raise DistutilsError("Download error for %s: %s" + % (url, v)) + + def _download_url(self, scheme, url, tmpdir): + # Determine download filename + # + name, fragment = egg_info_for_url(url) + if name: + while '..' in name: + name = name.replace('..', '.').replace('\\', '_') + else: + name = "__downloaded__" # default if URL has no path contents + + if name.endswith('.egg.zip'): + name = name[:-4] # strip the extra .zip before download + + filename = os.path.join(tmpdir, name) + + # Download the file + # + if scheme == 'svn' or scheme.startswith('svn+'): + return self._download_svn(url, filename) + elif scheme == 'git' or scheme.startswith('git+'): + return self._download_git(url, filename) + elif scheme.startswith('hg+'): + return self._download_hg(url, filename) + elif scheme == 'file': + return urllib.request.url2pathname(urllib.parse.urlparse(url)[2]) + else: + self.url_ok(url, True) # raises error if not allowed + return self._attempt_download(url, filename) + + def scan_url(self, url): + self.process_url(url, True) + + def _attempt_download(self, url, filename): + headers = self._download_to(url, filename) + if 'html' in headers.get('content-type', '').lower(): + return self._download_html(url, headers, filename) + else: + return filename + + def _download_html(self, url, headers, filename): + file = open(filename) + for line in file: + if line.strip(): + # Check for a subversion index page + if re.search(r'([^- ]+ - )?Revision \d+:', line): + # it's a subversion index page: + file.close() + os.unlink(filename) + return self._download_svn(url, filename) + break # not an index page + file.close() + os.unlink(filename) + raise DistutilsError("Unexpected HTML page found at " + url) + + def _download_svn(self, url, filename): + warnings.warn("SVN download support is deprecated", UserWarning) + url = url.split('#', 1)[0] # remove any fragment for svn's sake + creds = '' + if url.lower().startswith('svn:') and '@' in url: + scheme, netloc, path, p, q, f = urllib.parse.urlparse(url) + if not netloc and path.startswith('//') and '/' in path[2:]: + netloc, path = path[2:].split('/', 1) + auth, host = _splituser(netloc) + if auth: + if ':' in auth: + user, pw = auth.split(':', 1) + creds = " --username=%s --password=%s" % (user, pw) + else: + creds = " --username=" + auth + netloc = host + parts = scheme, netloc, url, p, q, f + url = urllib.parse.urlunparse(parts) + self.info("Doing subversion checkout from %s to %s", url, filename) + os.system("svn checkout%s -q %s %s" % (creds, url, filename)) + return filename + + @staticmethod + def _vcs_split_rev_from_url(url, pop_prefix=False): + scheme, netloc, path, query, frag = urllib.parse.urlsplit(url) + + scheme = scheme.split('+', 1)[-1] + + # Some fragment identification fails + path = path.split('#', 1)[0] + + rev = None + if '@' in path: + path, rev = path.rsplit('@', 1) + + # Also, discard fragment + url = urllib.parse.urlunsplit((scheme, netloc, path, query, '')) + + return url, rev + + def _download_git(self, url, filename): + filename = filename.split('#', 1)[0] + url, rev = self._vcs_split_rev_from_url(url, pop_prefix=True) + + self.info("Doing git clone from %s to %s", url, filename) + os.system("git clone --quiet %s %s" % (url, filename)) + + if rev is not None: + self.info("Checking out %s", rev) + os.system("git -C %s checkout --quiet %s" % ( + filename, + rev, + )) + + return filename + + def _download_hg(self, url, filename): + filename = filename.split('#', 1)[0] + url, rev = self._vcs_split_rev_from_url(url, pop_prefix=True) + + self.info("Doing hg clone from %s to %s", url, filename) + os.system("hg clone --quiet %s %s" % (url, filename)) + + if rev is not None: + self.info("Updating to %s", rev) + os.system("hg --cwd %s up -C -r %s -q" % ( + filename, + rev, + )) + + return filename + + def debug(self, msg, *args): + log.debug(msg, *args) + + def info(self, msg, *args): + log.info(msg, *args) + + def warn(self, msg, *args): + log.warn(msg, *args) + + +# This pattern matches a character entity reference (a decimal numeric +# references, a hexadecimal numeric reference, or a named reference). +entity_sub = re.compile(r'&(#(\d+|x[\da-fA-F]+)|[\w.:-]+);?').sub + + +def decode_entity(match): + what = match.group(0) + return unescape(what) + + +def htmldecode(text): + """ + Decode HTML entities in the given text. + + >>> htmldecode( + ... 'https://../package_name-0.1.2.tar.gz' + ... '?tokena=A&tokenb=B">package_name-0.1.2.tar.gz') + 'https://../package_name-0.1.2.tar.gz?tokena=A&tokenb=B">package_name-0.1.2.tar.gz' + """ + return entity_sub(decode_entity, text) + + +def socket_timeout(timeout=15): + def _socket_timeout(func): + def _socket_timeout(*args, **kwargs): + old_timeout = socket.getdefaulttimeout() + socket.setdefaulttimeout(timeout) + try: + return func(*args, **kwargs) + finally: + socket.setdefaulttimeout(old_timeout) + + return _socket_timeout + + return _socket_timeout + + +def _encode_auth(auth): + """ + A function compatible with Python 2.3-3.3 that will encode + auth from a URL suitable for an HTTP header. + >>> str(_encode_auth('username%3Apassword')) + 'dXNlcm5hbWU6cGFzc3dvcmQ=' + + Long auth strings should not cause a newline to be inserted. + >>> long_auth = 'username:' + 'password'*10 + >>> chr(10) in str(_encode_auth(long_auth)) + False + """ + auth_s = urllib.parse.unquote(auth) + # convert to bytes + auth_bytes = auth_s.encode() + encoded_bytes = base64.b64encode(auth_bytes) + # convert back to a string + encoded = encoded_bytes.decode() + # strip the trailing carriage return + return encoded.replace('\n', '') + + +class Credential: + """ + A username/password pair. Use like a namedtuple. + """ + + def __init__(self, username, password): + self.username = username + self.password = password + + def __iter__(self): + yield self.username + yield self.password + + def __str__(self): + return '%(username)s:%(password)s' % vars(self) + + +class PyPIConfig(configparser.RawConfigParser): + def __init__(self): + """ + Load from ~/.pypirc + """ + defaults = dict.fromkeys(['username', 'password', 'repository'], '') + configparser.RawConfigParser.__init__(self, defaults) + + rc = os.path.join(os.path.expanduser('~'), '.pypirc') + if os.path.exists(rc): + self.read(rc) + + @property + def creds_by_repository(self): + sections_with_repositories = [ + section for section in self.sections() + if self.get(section, 'repository').strip() + ] + + return dict(map(self._get_repo_cred, sections_with_repositories)) + + def _get_repo_cred(self, section): + repo = self.get(section, 'repository').strip() + return repo, Credential( + self.get(section, 'username').strip(), + self.get(section, 'password').strip(), + ) + + def find_credential(self, url): + """ + If the URL indicated appears to be a repository defined in this + config, return the credential for that repository. + """ + for repository, cred in self.creds_by_repository.items(): + if url.startswith(repository): + return cred + + +def open_with_auth(url, opener=urllib.request.urlopen): + """Open a urllib2 request, handling HTTP authentication""" + + parsed = urllib.parse.urlparse(url) + scheme, netloc, path, params, query, frag = parsed + + # Double scheme does not raise on Mac OS X as revealed by a + # failing test. We would expect "nonnumeric port". Refs #20. + if netloc.endswith(':'): + raise http_client.InvalidURL("nonnumeric port: ''") + + if scheme in ('http', 'https'): + auth, address = _splituser(netloc) + else: + auth = None + + if not auth: + cred = PyPIConfig().find_credential(url) + if cred: + auth = str(cred) + info = cred.username, url + log.info('Authenticating as %s for %s (from .pypirc)', *info) + + if auth: + auth = "Basic " + _encode_auth(auth) + parts = scheme, address, path, params, query, frag + new_url = urllib.parse.urlunparse(parts) + request = urllib.request.Request(new_url) + request.add_header("Authorization", auth) + else: + request = urllib.request.Request(url) + + request.add_header('User-Agent', user_agent) + fp = opener(request) + + if auth: + # Put authentication info back into request URL if same host, + # so that links found on the page will work + s2, h2, path2, param2, query2, frag2 = urllib.parse.urlparse(fp.url) + if s2 == scheme and h2 == address: + parts = s2, netloc, path2, param2, query2, frag2 + fp.url = urllib.parse.urlunparse(parts) + + return fp + + +# copy of urllib.parse._splituser from Python 3.8 +def _splituser(host): + """splituser('user[:passwd]@host[:port]') --> 'user[:passwd]', 'host[:port]'.""" + user, delim, host = host.rpartition('@') + return (user if delim else None), host + + +# adding a timeout to avoid freezing package_index +open_with_auth = socket_timeout(_SOCKET_TIMEOUT)(open_with_auth) + + +def fix_sf_url(url): + return url # backward compatibility + + +def local_open(url): + """Read a local path, with special support for directories""" + scheme, server, path, param, query, frag = urllib.parse.urlparse(url) + filename = urllib.request.url2pathname(path) + if os.path.isfile(filename): + return urllib.request.urlopen(url) + elif path.endswith('/') and os.path.isdir(filename): + files = [] + for f in os.listdir(filename): + filepath = os.path.join(filename, f) + if f == 'index.html': + with open(filepath, 'r') as fp: + body = fp.read() + break + elif os.path.isdir(filepath): + f += '/' + files.append('<a href="{name}">{name}</a>'.format(name=f)) + else: + tmpl = ( + "<html><head><title>{url}" + "{files}") + body = tmpl.format(url=url, files='\n'.join(files)) + status, message = 200, "OK" + else: + status, message, body = 404, "Path not found", "Not found" + + headers = {'content-type': 'text/html'} + body_stream = six.StringIO(body) + return urllib.error.HTTPError(url, status, message, headers, body_stream) diff --git a/venv/lib/python3.8/site-packages/setuptools/py27compat.py b/venv/lib/python3.8/site-packages/setuptools/py27compat.py new file mode 100644 index 0000000..1d57360 --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/py27compat.py @@ -0,0 +1,60 @@ +""" +Compatibility Support for Python 2.7 and earlier +""" + +import sys +import platform + +from setuptools.extern import six + + +def get_all_headers(message, key): + """ + Given an HTTPMessage, return all headers matching a given key. + """ + return message.get_all(key) + + +if six.PY2: + def get_all_headers(message, key): + return message.getheaders(key) + + +linux_py2_ascii = ( + platform.system() == 'Linux' and + six.PY2 +) + +rmtree_safe = str if linux_py2_ascii else lambda x: x +"""Workaround for http://bugs.python.org/issue24672""" + + +try: + from ._imp import find_module, PY_COMPILED, PY_FROZEN, PY_SOURCE + from ._imp import get_frozen_object, get_module +except ImportError: + import imp + from imp import PY_COMPILED, PY_FROZEN, PY_SOURCE # noqa + + def find_module(module, paths=None): + """Just like 'imp.find_module()', but with package support""" + parts = module.split('.') + while parts: + part = parts.pop(0) + f, path, (suffix, mode, kind) = info = imp.find_module(part, paths) + + if kind == imp.PKG_DIRECTORY: + parts = parts or ['__init__'] + paths = [path] + + elif parts: + raise ImportError("Can't find %r in %s" % (parts, module)) + + return info + + def get_frozen_object(module, paths): + return imp.get_frozen_object(module) + + def get_module(module, paths, info): + imp.load_module(module, *info) + return sys.modules[module] diff --git a/venv/lib/python3.8/site-packages/setuptools/py31compat.py b/venv/lib/python3.8/site-packages/setuptools/py31compat.py new file mode 100644 index 0000000..e1da7ee --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/py31compat.py @@ -0,0 +1,32 @@ +__all__ = [] + +__metaclass__ = type + + +try: + # Python >=3.2 + from tempfile import TemporaryDirectory +except ImportError: + import shutil + import tempfile + + class TemporaryDirectory: + """ + Very simple temporary directory context manager. + Will try to delete afterward, but will also ignore OS and similar + errors on deletion. + """ + + def __init__(self, **kwargs): + self.name = None # Handle mkdtemp raising an exception + self.name = tempfile.mkdtemp(**kwargs) + + def __enter__(self): + return self.name + + def __exit__(self, exctype, excvalue, exctrace): + try: + shutil.rmtree(self.name, True) + except OSError: # removal errors are not the only possible + pass + self.name = None diff --git a/venv/lib/python3.8/site-packages/setuptools/py33compat.py b/venv/lib/python3.8/site-packages/setuptools/py33compat.py new file mode 100644 index 0000000..cb69443 --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/py33compat.py @@ -0,0 +1,59 @@ +import dis +import array +import collections + +try: + import html +except ImportError: + html = None + +from setuptools.extern import six +from setuptools.extern.six.moves import html_parser + +__metaclass__ = type + +OpArg = collections.namedtuple('OpArg', 'opcode arg') + + +class Bytecode_compat: + def __init__(self, code): + self.code = code + + def __iter__(self): + """Yield '(op,arg)' pair for each operation in code object 'code'""" + + bytes = array.array('b', self.code.co_code) + eof = len(self.code.co_code) + + ptr = 0 + extended_arg = 0 + + while ptr < eof: + + op = bytes[ptr] + + if op >= dis.HAVE_ARGUMENT: + + arg = bytes[ptr + 1] + bytes[ptr + 2] * 256 + extended_arg + ptr += 3 + + if op == dis.EXTENDED_ARG: + long_type = six.integer_types[-1] + extended_arg = arg * long_type(65536) + continue + + else: + arg = None + ptr += 1 + + yield OpArg(op, arg) + + +Bytecode = getattr(dis, 'Bytecode', Bytecode_compat) + + +unescape = getattr(html, 'unescape', None) +if unescape is None: + # HTMLParser.unescape is deprecated since Python 3.4, and will be removed + # from 3.9. + unescape = html_parser.HTMLParser().unescape diff --git a/venv/lib/python3.8/site-packages/setuptools/py34compat.py b/venv/lib/python3.8/site-packages/setuptools/py34compat.py new file mode 100644 index 0000000..3ad9172 --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/py34compat.py @@ -0,0 +1,13 @@ +import importlib + +try: + import importlib.util +except ImportError: + pass + + +try: + module_from_spec = importlib.util.module_from_spec +except AttributeError: + def module_from_spec(spec): + return spec.loader.load_module(spec.name) diff --git a/venv/lib/python3.8/site-packages/setuptools/sandbox.py b/venv/lib/python3.8/site-packages/setuptools/sandbox.py new file mode 100644 index 0000000..685f3f7 --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/sandbox.py @@ -0,0 +1,491 @@ +import os +import sys +import tempfile +import operator +import functools +import itertools +import re +import contextlib +import pickle +import textwrap + +from setuptools.extern import six +from setuptools.extern.six.moves import builtins, map + +import pkg_resources.py31compat + +if sys.platform.startswith('java'): + import org.python.modules.posix.PosixModule as _os +else: + _os = sys.modules[os.name] +try: + _file = file +except NameError: + _file = None +_open = open +from distutils.errors import DistutilsError +from pkg_resources import working_set + + +__all__ = [ + "AbstractSandbox", "DirectorySandbox", "SandboxViolation", "run_setup", +] + + +def _execfile(filename, globals, locals=None): + """ + Python 3 implementation of execfile. + """ + mode = 'rb' + with open(filename, mode) as stream: + script = stream.read() + if locals is None: + locals = globals + code = compile(script, filename, 'exec') + exec(code, globals, locals) + + +@contextlib.contextmanager +def save_argv(repl=None): + saved = sys.argv[:] + if repl is not None: + sys.argv[:] = repl + try: + yield saved + finally: + sys.argv[:] = saved + + +@contextlib.contextmanager +def save_path(): + saved = sys.path[:] + try: + yield saved + finally: + sys.path[:] = saved + + +@contextlib.contextmanager +def override_temp(replacement): + """ + Monkey-patch tempfile.tempdir with replacement, ensuring it exists + """ + pkg_resources.py31compat.makedirs(replacement, exist_ok=True) + + saved = tempfile.tempdir + + tempfile.tempdir = replacement + + try: + yield + finally: + tempfile.tempdir = saved + + +@contextlib.contextmanager +def pushd(target): + saved = os.getcwd() + os.chdir(target) + try: + yield saved + finally: + os.chdir(saved) + + +class UnpickleableException(Exception): + """ + An exception representing another Exception that could not be pickled. + """ + + @staticmethod + def dump(type, exc): + """ + Always return a dumped (pickled) type and exc. If exc can't be pickled, + wrap it in UnpickleableException first. + """ + try: + return pickle.dumps(type), pickle.dumps(exc) + except Exception: + # get UnpickleableException inside the sandbox + from setuptools.sandbox import UnpickleableException as cls + return cls.dump(cls, cls(repr(exc))) + + +class ExceptionSaver: + """ + A Context Manager that will save an exception, serialized, and restore it + later. + """ + + def __enter__(self): + return self + + def __exit__(self, type, exc, tb): + if not exc: + return + + # dump the exception + self._saved = UnpickleableException.dump(type, exc) + self._tb = tb + + # suppress the exception + return True + + def resume(self): + "restore and re-raise any exception" + + if '_saved' not in vars(self): + return + + type, exc = map(pickle.loads, self._saved) + six.reraise(type, exc, self._tb) + + +@contextlib.contextmanager +def save_modules(): + """ + Context in which imported modules are saved. + + Translates exceptions internal to the context into the equivalent exception + outside the context. + """ + saved = sys.modules.copy() + with ExceptionSaver() as saved_exc: + yield saved + + sys.modules.update(saved) + # remove any modules imported since + del_modules = ( + mod_name for mod_name in sys.modules + if mod_name not in saved + # exclude any encodings modules. See #285 + and not mod_name.startswith('encodings.') + ) + _clear_modules(del_modules) + + saved_exc.resume() + + +def _clear_modules(module_names): + for mod_name in list(module_names): + del sys.modules[mod_name] + + +@contextlib.contextmanager +def save_pkg_resources_state(): + saved = pkg_resources.__getstate__() + try: + yield saved + finally: + pkg_resources.__setstate__(saved) + + +@contextlib.contextmanager +def setup_context(setup_dir): + temp_dir = os.path.join(setup_dir, 'temp') + with save_pkg_resources_state(): + with save_modules(): + hide_setuptools() + with save_path(): + with save_argv(): + with override_temp(temp_dir): + with pushd(setup_dir): + # ensure setuptools commands are available + __import__('setuptools') + yield + + +def _needs_hiding(mod_name): + """ + >>> _needs_hiding('setuptools') + True + >>> _needs_hiding('pkg_resources') + True + >>> _needs_hiding('setuptools_plugin') + False + >>> _needs_hiding('setuptools.__init__') + True + >>> _needs_hiding('distutils') + True + >>> _needs_hiding('os') + False + >>> _needs_hiding('Cython') + True + """ + pattern = re.compile(r'(setuptools|pkg_resources|distutils|Cython)(\.|$)') + return bool(pattern.match(mod_name)) + + +def hide_setuptools(): + """ + Remove references to setuptools' modules from sys.modules to allow the + invocation to import the most appropriate setuptools. This technique is + necessary to avoid issues such as #315 where setuptools upgrading itself + would fail to find a function declared in the metadata. + """ + modules = filter(_needs_hiding, sys.modules) + _clear_modules(modules) + + +def run_setup(setup_script, args): + """Run a distutils setup script, sandboxed in its directory""" + setup_dir = os.path.abspath(os.path.dirname(setup_script)) + with setup_context(setup_dir): + try: + sys.argv[:] = [setup_script] + list(args) + sys.path.insert(0, setup_dir) + # reset to include setup dir, w/clean callback list + working_set.__init__() + working_set.callbacks.append(lambda dist: dist.activate()) + + # __file__ should be a byte string on Python 2 (#712) + dunder_file = ( + setup_script + if isinstance(setup_script, str) else + setup_script.encode(sys.getfilesystemencoding()) + ) + + with DirectorySandbox(setup_dir): + ns = dict(__file__=dunder_file, __name__='__main__') + _execfile(setup_script, ns) + except SystemExit as v: + if v.args and v.args[0]: + raise + # Normal exit, just return + + +class AbstractSandbox: + """Wrap 'os' module and 'open()' builtin for virtualizing setup scripts""" + + _active = False + + def __init__(self): + self._attrs = [ + name for name in dir(_os) + if not name.startswith('_') and hasattr(self, name) + ] + + def _copy(self, source): + for name in self._attrs: + setattr(os, name, getattr(source, name)) + + def __enter__(self): + self._copy(self) + if _file: + builtins.file = self._file + builtins.open = self._open + self._active = True + + def __exit__(self, exc_type, exc_value, traceback): + self._active = False + if _file: + builtins.file = _file + builtins.open = _open + self._copy(_os) + + def run(self, func): + """Run 'func' under os sandboxing""" + with self: + return func() + + def _mk_dual_path_wrapper(name): + original = getattr(_os, name) + + def wrap(self, src, dst, *args, **kw): + if self._active: + src, dst = self._remap_pair(name, src, dst, *args, **kw) + return original(src, dst, *args, **kw) + + return wrap + + for name in ["rename", "link", "symlink"]: + if hasattr(_os, name): + locals()[name] = _mk_dual_path_wrapper(name) + + def _mk_single_path_wrapper(name, original=None): + original = original or getattr(_os, name) + + def wrap(self, path, *args, **kw): + if self._active: + path = self._remap_input(name, path, *args, **kw) + return original(path, *args, **kw) + + return wrap + + if _file: + _file = _mk_single_path_wrapper('file', _file) + _open = _mk_single_path_wrapper('open', _open) + for name in [ + "stat", "listdir", "chdir", "open", "chmod", "chown", "mkdir", + "remove", "unlink", "rmdir", "utime", "lchown", "chroot", "lstat", + "startfile", "mkfifo", "mknod", "pathconf", "access" + ]: + if hasattr(_os, name): + locals()[name] = _mk_single_path_wrapper(name) + + def _mk_single_with_return(name): + original = getattr(_os, name) + + def wrap(self, path, *args, **kw): + if self._active: + path = self._remap_input(name, path, *args, **kw) + return self._remap_output(name, original(path, *args, **kw)) + return original(path, *args, **kw) + + return wrap + + for name in ['readlink', 'tempnam']: + if hasattr(_os, name): + locals()[name] = _mk_single_with_return(name) + + def _mk_query(name): + original = getattr(_os, name) + + def wrap(self, *args, **kw): + retval = original(*args, **kw) + if self._active: + return self._remap_output(name, retval) + return retval + + return wrap + + for name in ['getcwd', 'tmpnam']: + if hasattr(_os, name): + locals()[name] = _mk_query(name) + + def _validate_path(self, path): + """Called to remap or validate any path, whether input or output""" + return path + + def _remap_input(self, operation, path, *args, **kw): + """Called for path inputs""" + return self._validate_path(path) + + def _remap_output(self, operation, path): + """Called for path outputs""" + return self._validate_path(path) + + def _remap_pair(self, operation, src, dst, *args, **kw): + """Called for path pairs like rename, link, and symlink operations""" + return ( + self._remap_input(operation + '-from', src, *args, **kw), + self._remap_input(operation + '-to', dst, *args, **kw) + ) + + +if hasattr(os, 'devnull'): + _EXCEPTIONS = [os.devnull,] +else: + _EXCEPTIONS = [] + + +class DirectorySandbox(AbstractSandbox): + """Restrict operations to a single subdirectory - pseudo-chroot""" + + write_ops = dict.fromkeys([ + "open", "chmod", "chown", "mkdir", "remove", "unlink", "rmdir", + "utime", "lchown", "chroot", "mkfifo", "mknod", "tempnam", + ]) + + _exception_patterns = [ + # Allow lib2to3 to attempt to save a pickled grammar object (#121) + r'.*lib2to3.*\.pickle$', + ] + "exempt writing to paths that match the pattern" + + def __init__(self, sandbox, exceptions=_EXCEPTIONS): + self._sandbox = os.path.normcase(os.path.realpath(sandbox)) + self._prefix = os.path.join(self._sandbox, '') + self._exceptions = [ + os.path.normcase(os.path.realpath(path)) + for path in exceptions + ] + AbstractSandbox.__init__(self) + + def _violation(self, operation, *args, **kw): + from setuptools.sandbox import SandboxViolation + raise SandboxViolation(operation, args, kw) + + if _file: + + def _file(self, path, mode='r', *args, **kw): + if mode not in ('r', 'rt', 'rb', 'rU', 'U') and not self._ok(path): + self._violation("file", path, mode, *args, **kw) + return _file(path, mode, *args, **kw) + + def _open(self, path, mode='r', *args, **kw): + if mode not in ('r', 'rt', 'rb', 'rU', 'U') and not self._ok(path): + self._violation("open", path, mode, *args, **kw) + return _open(path, mode, *args, **kw) + + def tmpnam(self): + self._violation("tmpnam") + + def _ok(self, path): + active = self._active + try: + self._active = False + realpath = os.path.normcase(os.path.realpath(path)) + return ( + self._exempted(realpath) + or realpath == self._sandbox + or realpath.startswith(self._prefix) + ) + finally: + self._active = active + + def _exempted(self, filepath): + start_matches = ( + filepath.startswith(exception) + for exception in self._exceptions + ) + pattern_matches = ( + re.match(pattern, filepath) + for pattern in self._exception_patterns + ) + candidates = itertools.chain(start_matches, pattern_matches) + return any(candidates) + + def _remap_input(self, operation, path, *args, **kw): + """Called for path inputs""" + if operation in self.write_ops and not self._ok(path): + self._violation(operation, os.path.realpath(path), *args, **kw) + return path + + def _remap_pair(self, operation, src, dst, *args, **kw): + """Called for path pairs like rename, link, and symlink operations""" + if not self._ok(src) or not self._ok(dst): + self._violation(operation, src, dst, *args, **kw) + return (src, dst) + + def open(self, file, flags, mode=0o777, *args, **kw): + """Called for low-level os.open()""" + if flags & WRITE_FLAGS and not self._ok(file): + self._violation("os.open", file, flags, mode, *args, **kw) + return _os.open(file, flags, mode, *args, **kw) + + +WRITE_FLAGS = functools.reduce( + operator.or_, [getattr(_os, a, 0) for a in + "O_WRONLY O_RDWR O_APPEND O_CREAT O_TRUNC O_TEMPORARY".split()] +) + + +class SandboxViolation(DistutilsError): + """A setup script attempted to modify the filesystem outside the sandbox""" + + tmpl = textwrap.dedent(""" + SandboxViolation: {cmd}{args!r} {kwargs} + + The package setup script has attempted to modify files on your system + that are not within the EasyInstall build area, and has been aborted. + + This package cannot be safely installed by EasyInstall, and may not + support alternate installation locations even if you run its setup + script by hand. Please inform the package's author and the EasyInstall + maintainers to find out if a fix or workaround is available. + """).lstrip() + + def __str__(self): + cmd, args, kwargs = self.args + return self.tmpl.format(**locals()) diff --git a/venv/lib/python3.8/site-packages/setuptools/script (dev).tmpl b/venv/lib/python3.8/site-packages/setuptools/script (dev).tmpl new file mode 100644 index 0000000..39a24b0 --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/script (dev).tmpl @@ -0,0 +1,6 @@ +# EASY-INSTALL-DEV-SCRIPT: %(spec)r,%(script_name)r +__requires__ = %(spec)r +__import__('pkg_resources').require(%(spec)r) +__file__ = %(dev_path)r +with open(__file__) as f: + exec(compile(f.read(), __file__, 'exec')) diff --git a/venv/lib/python3.8/site-packages/setuptools/script.tmpl b/venv/lib/python3.8/site-packages/setuptools/script.tmpl new file mode 100644 index 0000000..ff5efbc --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/script.tmpl @@ -0,0 +1,3 @@ +# EASY-INSTALL-SCRIPT: %(spec)r,%(script_name)r +__requires__ = %(spec)r +__import__('pkg_resources').run_script(%(spec)r, %(script_name)r) diff --git a/venv/lib/python3.8/site-packages/setuptools/site-patch.py b/venv/lib/python3.8/site-packages/setuptools/site-patch.py new file mode 100644 index 0000000..40b00de --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/site-patch.py @@ -0,0 +1,74 @@ +def __boot(): + import sys + import os + PYTHONPATH = os.environ.get('PYTHONPATH') + if PYTHONPATH is None or (sys.platform == 'win32' and not PYTHONPATH): + PYTHONPATH = [] + else: + PYTHONPATH = PYTHONPATH.split(os.pathsep) + + pic = getattr(sys, 'path_importer_cache', {}) + stdpath = sys.path[len(PYTHONPATH):] + mydir = os.path.dirname(__file__) + + for item in stdpath: + if item == mydir or not item: + continue # skip if current dir. on Windows, or my own directory + importer = pic.get(item) + if importer is not None: + loader = importer.find_module('site') + if loader is not None: + # This should actually reload the current module + loader.load_module('site') + break + else: + try: + import imp # Avoid import loop in Python 3 + stream, path, descr = imp.find_module('site', [item]) + except ImportError: + continue + if stream is None: + continue + try: + # This should actually reload the current module + imp.load_module('site', stream, path, descr) + finally: + stream.close() + break + else: + raise ImportError("Couldn't find the real 'site' module") + + known_paths = dict([(makepath(item)[1], 1) for item in sys.path]) # 2.2 comp + + oldpos = getattr(sys, '__egginsert', 0) # save old insertion position + sys.__egginsert = 0 # and reset the current one + + for item in PYTHONPATH: + addsitedir(item) + + sys.__egginsert += oldpos # restore effective old position + + d, nd = makepath(stdpath[0]) + insert_at = None + new_path = [] + + for item in sys.path: + p, np = makepath(item) + + if np == nd and insert_at is None: + # We've hit the first 'system' path entry, so added entries go here + insert_at = len(new_path) + + if np in known_paths or insert_at is None: + new_path.append(item) + else: + # new path after the insert point, back-insert it + new_path.insert(insert_at, item) + insert_at += 1 + + sys.path[:] = new_path + + +if __name__ == 'site': + __boot() + del __boot diff --git a/venv/lib/python3.8/site-packages/setuptools/ssl_support.py b/venv/lib/python3.8/site-packages/setuptools/ssl_support.py new file mode 100644 index 0000000..226db69 --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/ssl_support.py @@ -0,0 +1,260 @@ +import os +import socket +import atexit +import re +import functools + +from setuptools.extern.six.moves import urllib, http_client, map, filter + +from pkg_resources import ResolutionError, ExtractionError + +try: + import ssl +except ImportError: + ssl = None + +__all__ = [ + 'VerifyingHTTPSHandler', 'find_ca_bundle', 'is_available', 'cert_paths', + 'opener_for' +] + +cert_paths = """ +/etc/pki/tls/certs/ca-bundle.crt +/etc/ssl/certs/ca-certificates.crt +/usr/share/ssl/certs/ca-bundle.crt +/usr/local/share/certs/ca-root.crt +/etc/ssl/cert.pem +/System/Library/OpenSSL/certs/cert.pem +/usr/local/share/certs/ca-root-nss.crt +/etc/ssl/ca-bundle.pem +""".strip().split() + +try: + HTTPSHandler = urllib.request.HTTPSHandler + HTTPSConnection = http_client.HTTPSConnection +except AttributeError: + HTTPSHandler = HTTPSConnection = object + +is_available = ssl is not None and object not in (HTTPSHandler, HTTPSConnection) + + +try: + from ssl import CertificateError, match_hostname +except ImportError: + try: + from backports.ssl_match_hostname import CertificateError + from backports.ssl_match_hostname import match_hostname + except ImportError: + CertificateError = None + match_hostname = None + +if not CertificateError: + + class CertificateError(ValueError): + pass + + +if not match_hostname: + + def _dnsname_match(dn, hostname, max_wildcards=1): + """Matching according to RFC 6125, section 6.4.3 + + https://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 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") + dnsnames = [] + san = cert.get('subjectAltName', ()) + for key, value in san: + if key == 'DNS': + if _dnsname_match(value, hostname): + 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") + + +class VerifyingHTTPSHandler(HTTPSHandler): + """Simple verifying handler: no auth, subclasses, timeouts, etc.""" + + def __init__(self, ca_bundle): + self.ca_bundle = ca_bundle + HTTPSHandler.__init__(self) + + def https_open(self, req): + return self.do_open( + lambda host, **kw: VerifyingHTTPSConn(host, self.ca_bundle, **kw), req + ) + + +class VerifyingHTTPSConn(HTTPSConnection): + """Simple verifying connection: no auth, subclasses, timeouts, etc.""" + + def __init__(self, host, ca_bundle, **kw): + HTTPSConnection.__init__(self, host, **kw) + self.ca_bundle = ca_bundle + + def connect(self): + sock = socket.create_connection( + (self.host, self.port), getattr(self, 'source_address', None) + ) + + # Handle the socket if a (proxy) tunnel is present + if hasattr(self, '_tunnel') and getattr(self, '_tunnel_host', None): + self.sock = sock + self._tunnel() + # http://bugs.python.org/issue7776: Python>=3.4.1 and >=2.7.7 + # change self.host to mean the proxy server host when tunneling is + # being used. Adapt, since we are interested in the destination + # host for the match_hostname() comparison. + actual_host = self._tunnel_host + else: + actual_host = self.host + + if hasattr(ssl, 'create_default_context'): + ctx = ssl.create_default_context(cafile=self.ca_bundle) + self.sock = ctx.wrap_socket(sock, server_hostname=actual_host) + else: + # This is for python < 2.7.9 and < 3.4? + self.sock = ssl.wrap_socket( + sock, cert_reqs=ssl.CERT_REQUIRED, ca_certs=self.ca_bundle + ) + try: + match_hostname(self.sock.getpeercert(), actual_host) + except CertificateError: + self.sock.shutdown(socket.SHUT_RDWR) + self.sock.close() + raise + + +def opener_for(ca_bundle=None): + """Get a urlopen() replacement that uses ca_bundle for verification""" + return urllib.request.build_opener( + VerifyingHTTPSHandler(ca_bundle or find_ca_bundle()) + ).open + + +# from jaraco.functools +def once(func): + @functools.wraps(func) + def wrapper(*args, **kwargs): + if not hasattr(func, 'always_returns'): + func.always_returns = func(*args, **kwargs) + return func.always_returns + return wrapper + + +@once +def get_win_certfile(): + try: + import wincertstore + except ImportError: + return None + + class CertFile(wincertstore.CertFile): + def __init__(self): + super(CertFile, self).__init__() + atexit.register(self.close) + + def close(self): + try: + super(CertFile, self).close() + except OSError: + pass + + _wincerts = CertFile() + _wincerts.addstore('CA') + _wincerts.addstore('ROOT') + return _wincerts.name + + +def find_ca_bundle(): + """Return an existing CA bundle path, or None""" + extant_cert_paths = filter(os.path.isfile, cert_paths) + return ( + get_win_certfile() + or next(extant_cert_paths, None) + or _certifi_where() + ) + + +def _certifi_where(): + try: + return __import__('certifi').where() + except (ImportError, ResolutionError, ExtractionError): + pass diff --git a/venv/lib/python3.8/site-packages/setuptools/unicode_utils.py b/venv/lib/python3.8/site-packages/setuptools/unicode_utils.py new file mode 100644 index 0000000..7c63efd --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/unicode_utils.py @@ -0,0 +1,44 @@ +import unicodedata +import sys + +from setuptools.extern import six + + +# HFS Plus uses decomposed UTF-8 +def decompose(path): + if isinstance(path, six.text_type): + return unicodedata.normalize('NFD', path) + try: + path = path.decode('utf-8') + path = unicodedata.normalize('NFD', path) + path = path.encode('utf-8') + except UnicodeError: + pass # Not UTF-8 + return path + + +def filesys_decode(path): + """ + Ensure that the given path is decoded, + NONE when no expected encoding works + """ + + if isinstance(path, six.text_type): + return path + + fs_enc = sys.getfilesystemencoding() or 'utf-8' + candidates = fs_enc, 'utf-8' + + for enc in candidates: + try: + return path.decode(enc) + except UnicodeDecodeError: + continue + + +def try_encode(string, enc): + "turn unicode encoding into a functional routine" + try: + return string.encode(enc) + except UnicodeEncodeError: + return None diff --git a/venv/lib/python3.8/site-packages/setuptools/version.py b/venv/lib/python3.8/site-packages/setuptools/version.py new file mode 100644 index 0000000..95e1869 --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/version.py @@ -0,0 +1,6 @@ +import pkg_resources + +try: + __version__ = pkg_resources.get_distribution('setuptools').version +except Exception: + __version__ = 'unknown' diff --git a/venv/lib/python3.8/site-packages/setuptools/wheel.py b/venv/lib/python3.8/site-packages/setuptools/wheel.py new file mode 100644 index 0000000..025aaa8 --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/wheel.py @@ -0,0 +1,220 @@ +"""Wheels support.""" + +from distutils.util import get_platform +from distutils import log +import email +import itertools +import os +import posixpath +import re +import zipfile + +import pkg_resources +import setuptools +from pkg_resources import parse_version +from setuptools.extern.packaging.tags import sys_tags +from setuptools.extern.packaging.utils import canonicalize_name +from setuptools.extern.six import PY3 +from setuptools.command.egg_info import write_requirements + + +__metaclass__ = type + + +WHEEL_NAME = re.compile( + r"""^(?P.+?)-(?P\d.*?) + ((-(?P\d.*?))?-(?P.+?)-(?P.+?)-(?P.+?) + )\.whl$""", + re.VERBOSE).match + +NAMESPACE_PACKAGE_INIT = '''\ +try: + __import__('pkg_resources').declare_namespace(__name__) +except ImportError: + __path__ = __import__('pkgutil').extend_path(__path__, __name__) +''' + + +def unpack(src_dir, dst_dir): + '''Move everything under `src_dir` to `dst_dir`, and delete the former.''' + for dirpath, dirnames, filenames in os.walk(src_dir): + subdir = os.path.relpath(dirpath, src_dir) + for f in filenames: + src = os.path.join(dirpath, f) + dst = os.path.join(dst_dir, subdir, f) + os.renames(src, dst) + for n, d in reversed(list(enumerate(dirnames))): + src = os.path.join(dirpath, d) + dst = os.path.join(dst_dir, subdir, d) + if not os.path.exists(dst): + # Directory does not exist in destination, + # rename it and prune it from os.walk list. + os.renames(src, dst) + del dirnames[n] + # Cleanup. + for dirpath, dirnames, filenames in os.walk(src_dir, topdown=True): + assert not filenames + os.rmdir(dirpath) + + +class Wheel: + + def __init__(self, filename): + match = WHEEL_NAME(os.path.basename(filename)) + if match is None: + raise ValueError('invalid wheel name: %r' % filename) + self.filename = filename + for k, v in match.groupdict().items(): + setattr(self, k, v) + + def tags(self): + '''List tags (py_version, abi, platform) supported by this wheel.''' + return itertools.product( + self.py_version.split('.'), + self.abi.split('.'), + self.platform.split('.'), + ) + + def is_compatible(self): + '''Is the wheel is compatible with the current platform?''' + supported_tags = set((t.interpreter, t.abi, t.platform) for t in sys_tags()) + return next((True for t in self.tags() if t in supported_tags), False) + + def egg_name(self): + return pkg_resources.Distribution( + project_name=self.project_name, version=self.version, + platform=(None if self.platform == 'any' else get_platform()), + ).egg_name() + '.egg' + + def get_dist_info(self, zf): + # find the correct name of the .dist-info dir in the wheel file + for member in zf.namelist(): + dirname = posixpath.dirname(member) + if (dirname.endswith('.dist-info') and + canonicalize_name(dirname).startswith( + canonicalize_name(self.project_name))): + return dirname + raise ValueError("unsupported wheel format. .dist-info not found") + + def install_as_egg(self, destination_eggdir): + '''Install wheel as an egg directory.''' + with zipfile.ZipFile(self.filename) as zf: + self._install_as_egg(destination_eggdir, zf) + + def _install_as_egg(self, destination_eggdir, zf): + dist_basename = '%s-%s' % (self.project_name, self.version) + dist_info = self.get_dist_info(zf) + dist_data = '%s.data' % dist_basename + egg_info = os.path.join(destination_eggdir, 'EGG-INFO') + + self._convert_metadata(zf, destination_eggdir, dist_info, egg_info) + self._move_data_entries(destination_eggdir, dist_data) + self._fix_namespace_packages(egg_info, destination_eggdir) + + @staticmethod + def _convert_metadata(zf, destination_eggdir, dist_info, egg_info): + def get_metadata(name): + with zf.open(posixpath.join(dist_info, name)) as fp: + value = fp.read().decode('utf-8') if PY3 else fp.read() + return email.parser.Parser().parsestr(value) + + wheel_metadata = get_metadata('WHEEL') + # Check wheel format version is supported. + wheel_version = parse_version(wheel_metadata.get('Wheel-Version')) + wheel_v1 = ( + parse_version('1.0') <= wheel_version < parse_version('2.0dev0') + ) + if not wheel_v1: + raise ValueError( + 'unsupported wheel format version: %s' % wheel_version) + # Extract to target directory. + os.mkdir(destination_eggdir) + zf.extractall(destination_eggdir) + # Convert metadata. + dist_info = os.path.join(destination_eggdir, dist_info) + dist = pkg_resources.Distribution.from_location( + destination_eggdir, dist_info, + metadata=pkg_resources.PathMetadata(destination_eggdir, dist_info), + ) + + # Note: Evaluate and strip markers now, + # as it's difficult to convert back from the syntax: + # foobar; "linux" in sys_platform and extra == 'test' + def raw_req(req): + req.marker = None + return str(req) + install_requires = list(sorted(map(raw_req, dist.requires()))) + extras_require = { + extra: sorted( + req + for req in map(raw_req, dist.requires((extra,))) + if req not in install_requires + ) + for extra in dist.extras + } + os.rename(dist_info, egg_info) + os.rename( + os.path.join(egg_info, 'METADATA'), + os.path.join(egg_info, 'PKG-INFO'), + ) + setup_dist = setuptools.Distribution( + attrs=dict( + install_requires=install_requires, + extras_require=extras_require, + ), + ) + # Temporarily disable info traces. + log_threshold = log._global_log.threshold + log.set_threshold(log.WARN) + try: + write_requirements( + setup_dist.get_command_obj('egg_info'), + None, + os.path.join(egg_info, 'requires.txt'), + ) + finally: + log.set_threshold(log_threshold) + + @staticmethod + def _move_data_entries(destination_eggdir, dist_data): + """Move data entries to their correct location.""" + dist_data = os.path.join(destination_eggdir, dist_data) + dist_data_scripts = os.path.join(dist_data, 'scripts') + if os.path.exists(dist_data_scripts): + egg_info_scripts = os.path.join( + destination_eggdir, 'EGG-INFO', 'scripts') + os.mkdir(egg_info_scripts) + for entry in os.listdir(dist_data_scripts): + # Remove bytecode, as it's not properly handled + # during easy_install scripts install phase. + if entry.endswith('.pyc'): + os.unlink(os.path.join(dist_data_scripts, entry)) + else: + os.rename( + os.path.join(dist_data_scripts, entry), + os.path.join(egg_info_scripts, entry), + ) + os.rmdir(dist_data_scripts) + for subdir in filter(os.path.exists, ( + os.path.join(dist_data, d) + for d in ('data', 'headers', 'purelib', 'platlib') + )): + unpack(subdir, destination_eggdir) + if os.path.exists(dist_data): + os.rmdir(dist_data) + + @staticmethod + def _fix_namespace_packages(egg_info, destination_eggdir): + namespace_packages = os.path.join( + egg_info, 'namespace_packages.txt') + if os.path.exists(namespace_packages): + with open(namespace_packages) as fp: + namespace_packages = fp.read().split() + for mod in namespace_packages: + mod_dir = os.path.join(destination_eggdir, *mod.split('.')) + mod_init = os.path.join(mod_dir, '__init__.py') + if not os.path.exists(mod_dir): + os.mkdir(mod_dir) + if not os.path.exists(mod_init): + with open(mod_init, 'w') as fp: + fp.write(NAMESPACE_PACKAGE_INIT) diff --git a/venv/lib/python3.8/site-packages/setuptools/windows_support.py b/venv/lib/python3.8/site-packages/setuptools/windows_support.py new file mode 100644 index 0000000..cb977cf --- /dev/null +++ b/venv/lib/python3.8/site-packages/setuptools/windows_support.py @@ -0,0 +1,29 @@ +import platform +import ctypes + + +def windows_only(func): + if platform.system() != 'Windows': + return lambda *args, **kwargs: None + return func + + +@windows_only +def hide_file(path): + """ + Set the hidden attribute on a file or directory. + + From http://stackoverflow.com/questions/19622133/ + + `path` must be text. + """ + __import__('ctypes.wintypes') + SetFileAttributes = ctypes.windll.kernel32.SetFileAttributesW + SetFileAttributes.argtypes = ctypes.wintypes.LPWSTR, ctypes.wintypes.DWORD + SetFileAttributes.restype = ctypes.wintypes.BOOL + + FILE_ATTRIBUTE_HIDDEN = 0x02 + + ret = SetFileAttributes(path, FILE_ATTRIBUTE_HIDDEN) + if not ret: + raise ctypes.WinError() diff --git a/venv/lib/python3.8/site-packages/urllib3-1.26.6.dist-info/INSTALLER b/venv/lib/python3.8/site-packages/urllib3-1.26.6.dist-info/INSTALLER new file mode 100644 index 0000000..a1b589e --- /dev/null +++ b/venv/lib/python3.8/site-packages/urllib3-1.26.6.dist-info/INSTALLER @@ -0,0 +1 @@ +pip diff --git a/venv/lib/python3.8/site-packages/urllib3-1.26.6.dist-info/LICENSE.txt b/venv/lib/python3.8/site-packages/urllib3-1.26.6.dist-info/LICENSE.txt new file mode 100644 index 0000000..429a176 --- /dev/null +++ b/venv/lib/python3.8/site-packages/urllib3-1.26.6.dist-info/LICENSE.txt @@ -0,0 +1,21 @@ +MIT License + +Copyright (c) 2008-2020 Andrey Petrov and contributors (see CONTRIBUTORS.txt) + +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/venv/lib/python3.8/site-packages/urllib3-1.26.6.dist-info/METADATA b/venv/lib/python3.8/site-packages/urllib3-1.26.6.dist-info/METADATA new file mode 100644 index 0000000..af99541 --- /dev/null +++ b/venv/lib/python3.8/site-packages/urllib3-1.26.6.dist-info/METADATA @@ -0,0 +1,1388 @@ +Metadata-Version: 2.1 +Name: urllib3 +Version: 1.26.6 +Summary: HTTP library with thread-safe connection pooling, file post, and more. +Home-page: https://urllib3.readthedocs.io/ +Author: Andrey Petrov +Author-email: andrey.petrov@shazow.net +License: MIT +Project-URL: Documentation, https://urllib3.readthedocs.io/ +Project-URL: Code, https://github.com/urllib3/urllib3 +Project-URL: Issue tracker, https://github.com/urllib3/urllib3/issues +Keywords: urllib httplib threadsafe filepost http https ssl pooling +Platform: UNKNOWN +Classifier: Environment :: Web Environment +Classifier: Intended Audience :: Developers +Classifier: License :: OSI Approved :: MIT License +Classifier: Operating System :: OS Independent +Classifier: Programming Language :: Python +Classifier: Programming Language :: Python :: 2 +Classifier: Programming Language :: Python :: 2.7 +Classifier: Programming Language :: Python :: 3 +Classifier: Programming Language :: Python :: 3.5 +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 :: 3.10 +Classifier: Programming Language :: Python :: Implementation :: CPython +Classifier: Programming Language :: Python :: Implementation :: PyPy +Classifier: Topic :: Internet :: WWW/HTTP +Classifier: Topic :: Software Development :: Libraries +Requires-Python: >=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*, !=3.4.*, <4 +Description-Content-Type: text/x-rst +License-File: LICENSE.txt +Provides-Extra: brotli +Requires-Dist: brotlipy (>=0.6.0) ; extra == 'brotli' +Provides-Extra: secure +Requires-Dist: pyOpenSSL (>=0.14) ; extra == 'secure' +Requires-Dist: cryptography (>=1.3.4) ; extra == 'secure' +Requires-Dist: idna (>=2.0.0) ; extra == 'secure' +Requires-Dist: certifi ; extra == 'secure' +Requires-Dist: ipaddress ; (python_version == "2.7") and extra == 'secure' +Provides-Extra: socks +Requires-Dist: PySocks (!=1.5.7,<2.0,>=1.5.6) ; extra == 'socks' + + +urllib3 is a powerful, *user-friendly* HTTP client for Python. Much of the +Python ecosystem already uses urllib3 and you should too. +urllib3 brings many critical features that are missing from the Python +standard libraries: + +- Thread safety. +- Connection pooling. +- Client-side SSL/TLS verification. +- File uploads with multipart encoding. +- Helpers for retrying requests and dealing with HTTP redirects. +- Support for gzip, deflate, and brotli encoding. +- Proxy support for HTTP and SOCKS. +- 100% test coverage. + +urllib3 is powerful and easy to use: + +.. code-block:: python + + >>> import urllib3 + >>> http = urllib3.PoolManager() + >>> r = http.request('GET', 'http://httpbin.org/robots.txt') + >>> r.status + 200 + >>> r.data + 'User-agent: *\nDisallow: /deny\n' + + +Installing +---------- + +urllib3 can be installed with `pip `_:: + + $ python -m pip install urllib3 + +Alternatively, you can grab the latest source code from `GitHub `_:: + + $ git clone git://github.com/urllib3/urllib3.git + $ python setup.py install + + +Documentation +------------- + +urllib3 has usage and reference documentation at `urllib3.readthedocs.io `_. + + +Contributing +------------ + +urllib3 happily accepts contributions. Please see our +`contributing documentation `_ +for some tips on getting started. + + +Security Disclosures +-------------------- + +To report a security vulnerability, please use the +`Tidelift security contact `_. +Tidelift will coordinate the fix and disclosure with maintainers. + + +Maintainers +----------- + +- `@sethmlarson `__ (Seth M. Larson) +- `@pquentin `__ (Quentin Pradet) +- `@theacodes `__ (Thea Flowers) +- `@haikuginger `__ (Jess Shapiro) +- `@lukasa `__ (Cory Benfield) +- `@sigmavirus24 `__ (Ian Stapleton Cordasco) +- `@shazow `__ (Andrey Petrov) + +👋 + + +Sponsorship +----------- + +If your company benefits from this library, please consider `sponsoring its +development `_. + + +For Enterprise +-------------- + +.. |tideliftlogo| image:: https://nedbatchelder.com/pix/Tidelift_Logos_RGB_Tidelift_Shorthand_On-White_small.png + :width: 75 + :alt: Tidelift + +.. list-table:: + :widths: 10 100 + + * - |tideliftlogo| + - Professional support for urllib3 is available as part of the `Tidelift + Subscription`_. Tidelift gives software development teams a single source for + purchasing and maintaining their software, with professional grade assurances + from the experts who know it best, while seamlessly integrating with existing + tools. + +.. _Tidelift Subscription: https://tidelift.com/subscription/pkg/pypi-urllib3?utm_source=pypi-urllib3&utm_medium=referral&utm_campaign=readme + + +Changes +======= + +1.26.6 (2021-06-25) +------------------- + +* Deprecated the ``urllib3.contrib.ntlmpool`` module. urllib3 is not able to support + it properly due to `reasons listed in this issue `_. + If you are a user of this module please leave a comment. +* Changed ``HTTPConnection.request_chunked()`` to not erroneously emit multiple + ``Transfer-Encoding`` headers in the case that one is already specified. +* Fixed typo in deprecation message to recommend ``Retry.DEFAULT_ALLOWED_METHODS``. + + +1.26.5 (2021-05-26) +------------------- + +* Fixed deprecation warnings emitted in Python 3.10. +* Updated vendored ``six`` library to 1.16.0. +* Improved performance of URL parser when splitting + the authority component. + + +1.26.4 (2021-03-15) +------------------- + +* Changed behavior of the default ``SSLContext`` when connecting to HTTPS proxy + during HTTPS requests. The default ``SSLContext`` now sets ``check_hostname=True``. + + +1.26.3 (2021-01-26) +------------------- + +* Fixed bytes and string comparison issue with headers (Pull #2141) + +* Changed ``ProxySchemeUnknown`` error message to be + more actionable if the user supplies a proxy URL without + a scheme. (Pull #2107) + + +1.26.2 (2020-11-12) +------------------- + +* Fixed an issue where ``wrap_socket`` and ``CERT_REQUIRED`` wouldn't + be imported properly on Python 2.7.8 and earlier (Pull #2052) + + +1.26.1 (2020-11-11) +------------------- + +* Fixed an issue where two ``User-Agent`` headers would be sent if a + ``User-Agent`` header key is passed as ``bytes`` (Pull #2047) + + +1.26.0 (2020-11-10) +------------------- + +* **NOTE: urllib3 v2.0 will drop support for Python 2**. + `Read more in the v2.0 Roadmap `_. + +* Added support for HTTPS proxies contacting HTTPS servers (Pull #1923, Pull #1806) + +* Deprecated negotiating TLSv1 and TLSv1.1 by default. Users that + still wish to use TLS earlier than 1.2 without a deprecation warning + should opt-in explicitly by setting ``ssl_version=ssl.PROTOCOL_TLSv1_1`` (Pull #2002) + **Starting in urllib3 v2.0: Connections that receive a ``DeprecationWarning`` will fail** + +* Deprecated ``Retry`` options ``Retry.DEFAULT_METHOD_WHITELIST``, ``Retry.DEFAULT_REDIRECT_HEADERS_BLACKLIST`` + and ``Retry(method_whitelist=...)`` in favor of ``Retry.DEFAULT_ALLOWED_METHODS``, + ``Retry.DEFAULT_REMOVE_HEADERS_ON_REDIRECT``, and ``Retry(allowed_methods=...)`` + (Pull #2000) **Starting in urllib3 v2.0: Deprecated options will be removed** + +* Added default ``User-Agent`` header to every request (Pull #1750) + +* Added ``urllib3.util.SKIP_HEADER`` for skipping ``User-Agent``, ``Accept-Encoding``, + and ``Host`` headers from being automatically emitted with requests (Pull #2018) + +* Collapse ``transfer-encoding: chunked`` request data and framing into + the same ``socket.send()`` call (Pull #1906) + +* Send ``http/1.1`` ALPN identifier with every TLS handshake by default (Pull #1894) + +* Properly terminate SecureTransport connections when CA verification fails (Pull #1977) + +* Don't emit an ``SNIMissingWarning`` when passing ``server_hostname=None`` + to SecureTransport (Pull #1903) + +* Disabled requesting TLSv1.2 session tickets as they weren't being used by urllib3 (Pull #1970) + +* Suppress ``BrokenPipeError`` when writing request body after the server + has closed the socket (Pull #1524) + +* Wrap ``ssl.SSLError`` that can be raised from reading a socket (e.g. "bad MAC") + into an ``urllib3.exceptions.SSLError`` (Pull #1939) + + +1.25.11 (2020-10-19) +-------------------- + +* Fix retry backoff time parsed from ``Retry-After`` header when given + in the HTTP date format. The HTTP date was parsed as the local timezone + rather than accounting for the timezone in the HTTP date (typically + UTC) (Pull #1932, Pull #1935, Pull #1938, Pull #1949) + +* Fix issue where an error would be raised when the ``SSLKEYLOGFILE`` + environment variable was set to the empty string. Now ``SSLContext.keylog_file`` + is not set in this situation (Pull #2016) + + +1.25.10 (2020-07-22) +-------------------- + +* Added support for ``SSLKEYLOGFILE`` environment variable for + logging TLS session keys with use with programs like + Wireshark for decrypting captured web traffic (Pull #1867) + +* Fixed loading of SecureTransport libraries on macOS Big Sur + due to the new dynamic linker cache (Pull #1905) + +* Collapse chunked request bodies data and framing into one + call to ``send()`` to reduce the number of TCP packets by 2-4x (Pull #1906) + +* Don't insert ``None`` into ``ConnectionPool`` if the pool + was empty when requesting a connection (Pull #1866) + +* Avoid ``hasattr`` call in ``BrotliDecoder.decompress()`` (Pull #1858) + + +1.25.9 (2020-04-16) +------------------- + +* Added ``InvalidProxyConfigurationWarning`` which is raised when + erroneously specifying an HTTPS proxy URL. urllib3 doesn't currently + support connecting to HTTPS proxies but will soon be able to + and we would like users to migrate properly without much breakage. + + See `this GitHub issue `_ + for more information on how to fix your proxy config. (Pull #1851) + +* Drain connection after ``PoolManager`` redirect (Pull #1817) + +* Ensure ``load_verify_locations`` raises ``SSLError`` for all backends (Pull #1812) + +* Rename ``VerifiedHTTPSConnection`` to ``HTTPSConnection`` (Pull #1805) + +* Allow the CA certificate data to be passed as a string (Pull #1804) + +* Raise ``ValueError`` if method contains control characters (Pull #1800) + +* Add ``__repr__`` to ``Timeout`` (Pull #1795) + + +1.25.8 (2020-01-20) +------------------- + +* Drop support for EOL Python 3.4 (Pull #1774) + +* Optimize _encode_invalid_chars (Pull #1787) + + +1.25.7 (2019-11-11) +------------------- + +* Preserve ``chunked`` parameter on retries (Pull #1715, Pull #1734) + +* Allow unset ``SERVER_SOFTWARE`` in App Engine (Pull #1704, Issue #1470) + +* Fix issue where URL fragment was sent within the request target. (Pull #1732) + +* Fix issue where an empty query section in a URL would fail to parse. (Pull #1732) + +* Remove TLS 1.3 support in SecureTransport due to Apple removing support (Pull #1703) + + +1.25.6 (2019-09-24) +------------------- + +* Fix issue where tilde (``~``) characters were incorrectly + percent-encoded in the path. (Pull #1692) + + +1.25.5 (2019-09-19) +------------------- + +* Add mitigation for BPO-37428 affecting Python <3.7.4 and OpenSSL 1.1.1+ which + caused certificate verification to be enabled when using ``cert_reqs=CERT_NONE``. + (Issue #1682) + + +1.25.4 (2019-09-19) +------------------- + +* Propagate Retry-After header settings to subsequent retries. (Pull #1607) + +* Fix edge case where Retry-After header was still respected even when + explicitly opted out of. (Pull #1607) + +* Remove dependency on ``rfc3986`` for URL parsing. + +* Fix issue where URLs containing invalid characters within ``Url.auth`` would + raise an exception instead of percent-encoding those characters. + +* Add support for ``HTTPResponse.auto_close = False`` which makes HTTP responses + work well with BufferedReaders and other ``io`` module features. (Pull #1652) + +* Percent-encode invalid characters in URL for ``HTTPConnectionPool.request()`` (Pull #1673) + + +1.25.3 (2019-05-23) +------------------- + +* Change ``HTTPSConnection`` to load system CA certificates + when ``ca_certs``, ``ca_cert_dir``, and ``ssl_context`` are + unspecified. (Pull #1608, Issue #1603) + +* Upgrade bundled rfc3986 to v1.3.2. (Pull #1609, Issue #1605) + + +1.25.2 (2019-04-28) +------------------- + +* Change ``is_ipaddress`` to not detect IPvFuture addresses. (Pull #1583) + +* Change ``parse_url`` to percent-encode invalid characters within the + path, query, and target components. (Pull #1586) + + +1.25.1 (2019-04-24) +------------------- + +* Add support for Google's ``Brotli`` package. (Pull #1572, Pull #1579) + +* Upgrade bundled rfc3986 to v1.3.1 (Pull #1578) + + +1.25 (2019-04-22) +----------------- + +* Require and validate certificates by default when using HTTPS (Pull #1507) + +* Upgraded ``urllib3.utils.parse_url()`` to be RFC 3986 compliant. (Pull #1487) + +* Added support for ``key_password`` for ``HTTPSConnectionPool`` to use + encrypted ``key_file`` without creating your own ``SSLContext`` object. (Pull #1489) + +* Add TLSv1.3 support to CPython, pyOpenSSL, and SecureTransport ``SSLContext`` + implementations. (Pull #1496) + +* Switched the default multipart header encoder from RFC 2231 to HTML 5 working draft. (Issue #303, Pull #1492) + +* Fixed issue where OpenSSL would block if an encrypted client private key was + given and no password was given. Instead an ``SSLError`` is raised. (Pull #1489) + +* Added support for Brotli content encoding. It is enabled automatically if + ``brotlipy`` package is installed which can be requested with + ``urllib3[brotli]`` extra. (Pull #1532) + +* Drop ciphers using DSS key exchange from default TLS cipher suites. + Improve default ciphers when using SecureTransport. (Pull #1496) + +* Implemented a more efficient ``HTTPResponse.__iter__()`` method. (Issue #1483) + +1.24.3 (2019-05-01) +------------------- + +* Apply fix for CVE-2019-9740. (Pull #1591) + +1.24.2 (2019-04-17) +------------------- + +* Don't load system certificates by default when any other ``ca_certs``, ``ca_certs_dir`` or + ``ssl_context`` parameters are specified. + +* Remove Authorization header regardless of case when redirecting to cross-site. (Issue #1510) + +* Add support for IPv6 addresses in subjectAltName section of certificates. (Issue #1269) + + +1.24.1 (2018-11-02) +------------------- + +* Remove quadratic behavior within ``GzipDecoder.decompress()`` (Issue #1467) + +* Restored functionality of ``ciphers`` parameter for ``create_urllib3_context()``. (Issue #1462) + + +1.24 (2018-10-16) +----------------- + +* Allow key_server_hostname to be specified when initializing a PoolManager to allow custom SNI to be overridden. (Pull #1449) + +* Test against Python 3.7 on AppVeyor. (Pull #1453) + +* Early-out ipv6 checks when running on App Engine. (Pull #1450) + +* Change ambiguous description of backoff_factor (Pull #1436) + +* Add ability to handle multiple Content-Encodings (Issue #1441 and Pull #1442) + +* Skip DNS names that can't be idna-decoded when using pyOpenSSL (Issue #1405). + +* Add a server_hostname parameter to HTTPSConnection which allows for + overriding the SNI hostname sent in the handshake. (Pull #1397) + +* Drop support for EOL Python 2.6 (Pull #1429 and Pull #1430) + +* Fixed bug where responses with header Content-Type: message/* erroneously + raised HeaderParsingError, resulting in a warning being logged. (Pull #1439) + +* Move urllib3 to src/urllib3 (Pull #1409) + + +1.23 (2018-06-04) +----------------- + +* Allow providing a list of headers to strip from requests when redirecting + to a different host. Defaults to the ``Authorization`` header. Different + headers can be set via ``Retry.remove_headers_on_redirect``. (Issue #1316) + +* Fix ``util.selectors._fileobj_to_fd`` to accept ``long`` (Issue #1247). + +* Dropped Python 3.3 support. (Pull #1242) + +* Put the connection back in the pool when calling stream() or read_chunked() on + a chunked HEAD response. (Issue #1234) + +* Fixed pyOpenSSL-specific ssl client authentication issue when clients + attempted to auth via certificate + chain (Issue #1060) + +* Add the port to the connectionpool connect print (Pull #1251) + +* Don't use the ``uuid`` module to create multipart data boundaries. (Pull #1380) + +* ``read_chunked()`` on a closed response returns no chunks. (Issue #1088) + +* Add Python 2.6 support to ``contrib.securetransport`` (Pull #1359) + +* Added support for auth info in url for SOCKS proxy (Pull #1363) + + +1.22 (2017-07-20) +----------------- + +* Fixed missing brackets in ``HTTP CONNECT`` when connecting to IPv6 address via + IPv6 proxy. (Issue #1222) + +* Made the connection pool retry on ``SSLError``. The original ``SSLError`` + is available on ``MaxRetryError.reason``. (Issue #1112) + +* Drain and release connection before recursing on retry/redirect. Fixes + deadlocks with a blocking connectionpool. (Issue #1167) + +* Fixed compatibility for cookiejar. (Issue #1229) + +* pyopenssl: Use vendored version of ``six``. (Issue #1231) + + +1.21.1 (2017-05-02) +------------------- + +* Fixed SecureTransport issue that would cause long delays in response body + delivery. (Pull #1154) + +* Fixed regression in 1.21 that threw exceptions when users passed the + ``socket_options`` flag to the ``PoolManager``. (Issue #1165) + +* Fixed regression in 1.21 that threw exceptions when users passed the + ``assert_hostname`` or ``assert_fingerprint`` flag to the ``PoolManager``. + (Pull #1157) + + +1.21 (2017-04-25) +----------------- + +* Improved performance of certain selector system calls on Python 3.5 and + later. (Pull #1095) + +* Resolved issue where the PyOpenSSL backend would not wrap SysCallError + exceptions appropriately when sending data. (Pull #1125) + +* Selectors now detects a monkey-patched select module after import for modules + that patch the select module like eventlet, greenlet. (Pull #1128) + +* Reduced memory consumption when streaming zlib-compressed responses + (as opposed to raw deflate streams). (Pull #1129) + +* Connection pools now use the entire request context when constructing the + pool key. (Pull #1016) + +* ``PoolManager.connection_from_*`` methods now accept a new keyword argument, + ``pool_kwargs``, which are merged with the existing ``connection_pool_kw``. + (Pull #1016) + +* Add retry counter for ``status_forcelist``. (Issue #1147) + +* Added ``contrib`` module for using SecureTransport on macOS: + ``urllib3.contrib.securetransport``. (Pull #1122) + +* urllib3 now only normalizes the case of ``http://`` and ``https://`` schemes: + for schemes it does not recognise, it assumes they are case-sensitive and + leaves them unchanged. + (Issue #1080) + + +1.20 (2017-01-19) +----------------- + +* Added support for waiting for I/O using selectors other than select, + improving urllib3's behaviour with large numbers of concurrent connections. + (Pull #1001) + +* Updated the date for the system clock check. (Issue #1005) + +* ConnectionPools now correctly consider hostnames to be case-insensitive. + (Issue #1032) + +* Outdated versions of PyOpenSSL now cause the PyOpenSSL contrib module + to fail when it is injected, rather than at first use. (Pull #1063) + +* Outdated versions of cryptography now cause the PyOpenSSL contrib module + to fail when it is injected, rather than at first use. (Issue #1044) + +* Automatically attempt to rewind a file-like body object when a request is + retried or redirected. (Pull #1039) + +* Fix some bugs that occur when modules incautiously patch the queue module. + (Pull #1061) + +* Prevent retries from occurring on read timeouts for which the request method + was not in the method whitelist. (Issue #1059) + +* Changed the PyOpenSSL contrib module to lazily load idna to avoid + unnecessarily bloating the memory of programs that don't need it. (Pull + #1076) + +* Add support for IPv6 literals with zone identifiers. (Pull #1013) + +* Added support for socks5h:// and socks4a:// schemes when working with SOCKS + proxies, and controlled remote DNS appropriately. (Issue #1035) + + +1.19.1 (2016-11-16) +------------------- + +* Fixed AppEngine import that didn't function on Python 3.5. (Pull #1025) + + +1.19 (2016-11-03) +----------------- + +* urllib3 now respects Retry-After headers on 413, 429, and 503 responses when + using the default retry logic. (Pull #955) + +* Remove markers from setup.py to assist ancient setuptools versions. (Issue + #986) + +* Disallow superscripts and other integerish things in URL ports. (Issue #989) + +* Allow urllib3's HTTPResponse.stream() method to continue to work with + non-httplib underlying FPs. (Pull #990) + +* Empty filenames in multipart headers are now emitted as such, rather than + being suppressed. (Issue #1015) + +* Prefer user-supplied Host headers on chunked uploads. (Issue #1009) + + +1.18.1 (2016-10-27) +------------------- + +* CVE-2016-9015. Users who are using urllib3 version 1.17 or 1.18 along with + PyOpenSSL injection and OpenSSL 1.1.0 *must* upgrade to this version. This + release fixes a vulnerability whereby urllib3 in the above configuration + would silently fail to validate TLS certificates due to erroneously setting + invalid flags in OpenSSL's ``SSL_CTX_set_verify`` function. These erroneous + flags do not cause a problem in OpenSSL versions before 1.1.0, which + interprets the presence of any flag as requesting certificate validation. + + There is no PR for this patch, as it was prepared for simultaneous disclosure + and release. The master branch received the same fix in Pull #1010. + + +1.18 (2016-09-26) +----------------- + +* Fixed incorrect message for IncompleteRead exception. (Pull #973) + +* Accept ``iPAddress`` subject alternative name fields in TLS certificates. + (Issue #258) + +* Fixed consistency of ``HTTPResponse.closed`` between Python 2 and 3. + (Issue #977) + +* Fixed handling of wildcard certificates when using PyOpenSSL. (Issue #979) + + +1.17 (2016-09-06) +----------------- + +* Accept ``SSLContext`` objects for use in SSL/TLS negotiation. (Issue #835) + +* ConnectionPool debug log now includes scheme, host, and port. (Issue #897) + +* Substantially refactored documentation. (Issue #887) + +* Used URLFetch default timeout on AppEngine, rather than hardcoding our own. + (Issue #858) + +* Normalize the scheme and host in the URL parser (Issue #833) + +* ``HTTPResponse`` contains the last ``Retry`` object, which now also + contains retries history. (Issue #848) + +* Timeout can no longer be set as boolean, and must be greater than zero. + (Pull #924) + +* Removed pyasn1 and ndg-httpsclient from dependencies used for PyOpenSSL. We + now use cryptography and idna, both of which are already dependencies of + PyOpenSSL. (Pull #930) + +* Fixed infinite loop in ``stream`` when amt=None. (Issue #928) + +* Try to use the operating system's certificates when we are using an + ``SSLContext``. (Pull #941) + +* Updated cipher suite list to allow ChaCha20+Poly1305. AES-GCM is preferred to + ChaCha20, but ChaCha20 is then preferred to everything else. (Pull #947) + +* Updated cipher suite list to remove 3DES-based cipher suites. (Pull #958) + +* Removed the cipher suite fallback to allow HIGH ciphers. (Pull #958) + +* Implemented ``length_remaining`` to determine remaining content + to be read. (Pull #949) + +* Implemented ``enforce_content_length`` to enable exceptions when + incomplete data chunks are received. (Pull #949) + +* Dropped connection start, dropped connection reset, redirect, forced retry, + and new HTTPS connection log levels to DEBUG, from INFO. (Pull #967) + + +1.16 (2016-06-11) +----------------- + +* Disable IPv6 DNS when IPv6 connections are not possible. (Issue #840) + +* Provide ``key_fn_by_scheme`` pool keying mechanism that can be + overridden. (Issue #830) + +* Normalize scheme and host to lowercase for pool keys, and include + ``source_address``. (Issue #830) + +* Cleaner exception chain in Python 3 for ``_make_request``. + (Issue #861) + +* Fixed installing ``urllib3[socks]`` extra. (Issue #864) + +* Fixed signature of ``ConnectionPool.close`` so it can actually safely be + called by subclasses. (Issue #873) + +* Retain ``release_conn`` state across retries. (Issues #651, #866) + +* Add customizable ``HTTPConnectionPool.ResponseCls``, which defaults to + ``HTTPResponse`` but can be replaced with a subclass. (Issue #879) + + +1.15.1 (2016-04-11) +------------------- + +* Fix packaging to include backports module. (Issue #841) + + +1.15 (2016-04-06) +----------------- + +* Added Retry(raise_on_status=False). (Issue #720) + +* Always use setuptools, no more distutils fallback. (Issue #785) + +* Dropped support for Python 3.2. (Issue #786) + +* Chunked transfer encoding when requesting with ``chunked=True``. + (Issue #790) + +* Fixed regression with IPv6 port parsing. (Issue #801) + +* Append SNIMissingWarning messages to allow users to specify it in + the PYTHONWARNINGS environment variable. (Issue #816) + +* Handle unicode headers in Py2. (Issue #818) + +* Log certificate when there is a hostname mismatch. (Issue #820) + +* Preserve order of request/response headers. (Issue #821) + + +1.14 (2015-12-29) +----------------- + +* contrib: SOCKS proxy support! (Issue #762) + +* Fixed AppEngine handling of transfer-encoding header and bug + in Timeout defaults checking. (Issue #763) + + +1.13.1 (2015-12-18) +------------------- + +* Fixed regression in IPv6 + SSL for match_hostname. (Issue #761) + + +1.13 (2015-12-14) +----------------- + +* Fixed ``pip install urllib3[secure]`` on modern pip. (Issue #706) + +* pyopenssl: Fixed SSL3_WRITE_PENDING error. (Issue #717) + +* pyopenssl: Support for TLSv1.1 and TLSv1.2. (Issue #696) + +* Close connections more defensively on exception. (Issue #734) + +* Adjusted ``read_chunked`` to handle gzipped, chunk-encoded bodies without + repeatedly flushing the decoder, to function better on Jython. (Issue #743) + +* Accept ``ca_cert_dir`` for SSL-related PoolManager configuration. (Issue #758) + + +1.12 (2015-09-03) +----------------- + +* Rely on ``six`` for importing ``httplib`` to work around + conflicts with other Python 3 shims. (Issue #688) + +* Add support for directories of certificate authorities, as supported by + OpenSSL. (Issue #701) + +* New exception: ``NewConnectionError``, raised when we fail to establish + a new connection, usually ``ECONNREFUSED`` socket error. + + +1.11 (2015-07-21) +----------------- + +* When ``ca_certs`` is given, ``cert_reqs`` defaults to + ``'CERT_REQUIRED'``. (Issue #650) + +* ``pip install urllib3[secure]`` will install Certifi and + PyOpenSSL as dependencies. (Issue #678) + +* Made ``HTTPHeaderDict`` usable as a ``headers`` input value + (Issues #632, #679) + +* Added `urllib3.contrib.appengine `_ + which has an ``AppEngineManager`` for using ``URLFetch`` in a + Google AppEngine environment. (Issue #664) + +* Dev: Added test suite for AppEngine. (Issue #631) + +* Fix performance regression when using PyOpenSSL. (Issue #626) + +* Passing incorrect scheme (e.g. ``foo://``) will raise + ``ValueError`` instead of ``AssertionError`` (backwards + compatible for now, but please migrate). (Issue #640) + +* Fix pools not getting replenished when an error occurs during a + request using ``release_conn=False``. (Issue #644) + +* Fix pool-default headers not applying for url-encoded requests + like GET. (Issue #657) + +* log.warning in Python 3 when headers are skipped due to parsing + errors. (Issue #642) + +* Close and discard connections if an error occurs during read. + (Issue #660) + +* Fix host parsing for IPv6 proxies. (Issue #668) + +* Separate warning type SubjectAltNameWarning, now issued once + per host. (Issue #671) + +* Fix ``httplib.IncompleteRead`` not getting converted to + ``ProtocolError`` when using ``HTTPResponse.stream()`` + (Issue #674) + +1.10.4 (2015-05-03) +------------------- + +* Migrate tests to Tornado 4. (Issue #594) + +* Append default warning configuration rather than overwrite. + (Issue #603) + +* Fix streaming decoding regression. (Issue #595) + +* Fix chunked requests losing state across keep-alive connections. + (Issue #599) + +* Fix hanging when chunked HEAD response has no body. (Issue #605) + + +1.10.3 (2015-04-21) +------------------- + +* Emit ``InsecurePlatformWarning`` when SSLContext object is missing. + (Issue #558) + +* Fix regression of duplicate header keys being discarded. + (Issue #563) + +* ``Response.stream()`` returns a generator for chunked responses. + (Issue #560) + +* Set upper-bound timeout when waiting for a socket in PyOpenSSL. + (Issue #585) + +* Work on platforms without `ssl` module for plain HTTP requests. + (Issue #587) + +* Stop relying on the stdlib's default cipher list. (Issue #588) + + +1.10.2 (2015-02-25) +------------------- + +* Fix file descriptor leakage on retries. (Issue #548) + +* Removed RC4 from default cipher list. (Issue #551) + +* Header performance improvements. (Issue #544) + +* Fix PoolManager not obeying redirect retry settings. (Issue #553) + + +1.10.1 (2015-02-10) +------------------- + +* Pools can be used as context managers. (Issue #545) + +* Don't re-use connections which experienced an SSLError. (Issue #529) + +* Don't fail when gzip decoding an empty stream. (Issue #535) + +* Add sha256 support for fingerprint verification. (Issue #540) + +* Fixed handling of header values containing commas. (Issue #533) + + +1.10 (2014-12-14) +----------------- + +* Disabled SSLv3. (Issue #473) + +* Add ``Url.url`` property to return the composed url string. (Issue #394) + +* Fixed PyOpenSSL + gevent ``WantWriteError``. (Issue #412) + +* ``MaxRetryError.reason`` will always be an exception, not string. + (Issue #481) + +* Fixed SSL-related timeouts not being detected as timeouts. (Issue #492) + +* Py3: Use ``ssl.create_default_context()`` when available. (Issue #473) + +* Emit ``InsecureRequestWarning`` for *every* insecure HTTPS request. + (Issue #496) + +* Emit ``SecurityWarning`` when certificate has no ``subjectAltName``. + (Issue #499) + +* Close and discard sockets which experienced SSL-related errors. + (Issue #501) + +* Handle ``body`` param in ``.request(...)``. (Issue #513) + +* Respect timeout with HTTPS proxy. (Issue #505) + +* PyOpenSSL: Handle ZeroReturnError exception. (Issue #520) + + +1.9.1 (2014-09-13) +------------------ + +* Apply socket arguments before binding. (Issue #427) + +* More careful checks if fp-like object is closed. (Issue #435) + +* Fixed packaging issues of some development-related files not + getting included. (Issue #440) + +* Allow performing *only* fingerprint verification. (Issue #444) + +* Emit ``SecurityWarning`` if system clock is waaay off. (Issue #445) + +* Fixed PyOpenSSL compatibility with PyPy. (Issue #450) + +* Fixed ``BrokenPipeError`` and ``ConnectionError`` handling in Py3. + (Issue #443) + + + +1.9 (2014-07-04) +---------------- + +* Shuffled around development-related files. If you're maintaining a distro + package of urllib3, you may need to tweak things. (Issue #415) + +* Unverified HTTPS requests will trigger a warning on the first request. See + our new `security documentation + `_ for details. + (Issue #426) + +* New retry logic and ``urllib3.util.retry.Retry`` configuration object. + (Issue #326) + +* All raised exceptions should now wrapped in a + ``urllib3.exceptions.HTTPException``-extending exception. (Issue #326) + +* All errors during a retry-enabled request should be wrapped in + ``urllib3.exceptions.MaxRetryError``, including timeout-related exceptions + which were previously exempt. Underlying error is accessible from the + ``.reason`` property. (Issue #326) + +* ``urllib3.exceptions.ConnectionError`` renamed to + ``urllib3.exceptions.ProtocolError``. (Issue #326) + +* Errors during response read (such as IncompleteRead) are now wrapped in + ``urllib3.exceptions.ProtocolError``. (Issue #418) + +* Requesting an empty host will raise ``urllib3.exceptions.LocationValueError``. + (Issue #417) + +* Catch read timeouts over SSL connections as + ``urllib3.exceptions.ReadTimeoutError``. (Issue #419) + +* Apply socket arguments before connecting. (Issue #427) + + +1.8.3 (2014-06-23) +------------------ + +* Fix TLS verification when using a proxy in Python 3.4.1. (Issue #385) + +* Add ``disable_cache`` option to ``urllib3.util.make_headers``. (Issue #393) + +* Wrap ``socket.timeout`` exception with + ``urllib3.exceptions.ReadTimeoutError``. (Issue #399) + +* Fixed proxy-related bug where connections were being reused incorrectly. + (Issues #366, #369) + +* Added ``socket_options`` keyword parameter which allows to define + ``setsockopt`` configuration of new sockets. (Issue #397) + +* Removed ``HTTPConnection.tcp_nodelay`` in favor of + ``HTTPConnection.default_socket_options``. (Issue #397) + +* Fixed ``TypeError`` bug in Python 2.6.4. (Issue #411) + + +1.8.2 (2014-04-17) +------------------ + +* Fix ``urllib3.util`` not being included in the package. + + +1.8.1 (2014-04-17) +------------------ + +* Fix AppEngine bug of HTTPS requests going out as HTTP. (Issue #356) + +* Don't install ``dummyserver`` into ``site-packages`` as it's only needed + for the test suite. (Issue #362) + +* Added support for specifying ``source_address``. (Issue #352) + + +1.8 (2014-03-04) +---------------- + +* Improved url parsing in ``urllib3.util.parse_url`` (properly parse '@' in + username, and blank ports like 'hostname:'). + +* New ``urllib3.connection`` module which contains all the HTTPConnection + objects. + +* Several ``urllib3.util.Timeout``-related fixes. Also changed constructor + signature to a more sensible order. [Backwards incompatible] + (Issues #252, #262, #263) + +* Use ``backports.ssl_match_hostname`` if it's installed. (Issue #274) + +* Added ``.tell()`` method to ``urllib3.response.HTTPResponse`` which + returns the number of bytes read so far. (Issue #277) + +* Support for platforms without threading. (Issue #289) + +* Expand default-port comparison in ``HTTPConnectionPool.is_same_host`` + to allow a pool with no specified port to be considered equal to to an + HTTP/HTTPS url with port 80/443 explicitly provided. (Issue #305) + +* Improved default SSL/TLS settings to avoid vulnerabilities. + (Issue #309) + +* Fixed ``urllib3.poolmanager.ProxyManager`` not retrying on connect errors. + (Issue #310) + +* Disable Nagle's Algorithm on the socket for non-proxies. A subset of requests + will send the entire HTTP request ~200 milliseconds faster; however, some of + the resulting TCP packets will be smaller. (Issue #254) + +* Increased maximum number of SubjectAltNames in ``urllib3.contrib.pyopenssl`` + from the default 64 to 1024 in a single certificate. (Issue #318) + +* Headers are now passed and stored as a custom + ``urllib3.collections_.HTTPHeaderDict`` object rather than a plain ``dict``. + (Issue #329, #333) + +* Headers no longer lose their case on Python 3. (Issue #236) + +* ``urllib3.contrib.pyopenssl`` now uses the operating system's default CA + certificates on inject. (Issue #332) + +* Requests with ``retries=False`` will immediately raise any exceptions without + wrapping them in ``MaxRetryError``. (Issue #348) + +* Fixed open socket leak with SSL-related failures. (Issue #344, #348) + + +1.7.1 (2013-09-25) +------------------ + +* Added granular timeout support with new ``urllib3.util.Timeout`` class. + (Issue #231) + +* Fixed Python 3.4 support. (Issue #238) + + +1.7 (2013-08-14) +---------------- + +* More exceptions are now pickle-able, with tests. (Issue #174) + +* Fixed redirecting with relative URLs in Location header. (Issue #178) + +* Support for relative urls in ``Location: ...`` header. (Issue #179) + +* ``urllib3.response.HTTPResponse`` now inherits from ``io.IOBase`` for bonus + file-like functionality. (Issue #187) + +* Passing ``assert_hostname=False`` when creating a HTTPSConnectionPool will + skip hostname verification for SSL connections. (Issue #194) + +* New method ``urllib3.response.HTTPResponse.stream(...)`` which acts as a + generator wrapped around ``.read(...)``. (Issue #198) + +* IPv6 url parsing enforces brackets around the hostname. (Issue #199) + +* Fixed thread race condition in + ``urllib3.poolmanager.PoolManager.connection_from_host(...)`` (Issue #204) + +* ``ProxyManager`` requests now include non-default port in ``Host: ...`` + header. (Issue #217) + +* Added HTTPS proxy support in ``ProxyManager``. (Issue #170 #139) + +* New ``RequestField`` object can be passed to the ``fields=...`` param which + can specify headers. (Issue #220) + +* Raise ``urllib3.exceptions.ProxyError`` when connecting to proxy fails. + (Issue #221) + +* Use international headers when posting file names. (Issue #119) + +* Improved IPv6 support. (Issue #203) + + +1.6 (2013-04-25) +---------------- + +* Contrib: Optional SNI support for Py2 using PyOpenSSL. (Issue #156) + +* ``ProxyManager`` automatically adds ``Host: ...`` header if not given. + +* Improved SSL-related code. ``cert_req`` now optionally takes a string like + "REQUIRED" or "NONE". Same with ``ssl_version`` takes strings like "SSLv23" + The string values reflect the suffix of the respective constant variable. + (Issue #130) + +* Vendored ``socksipy`` now based on Anorov's fork which handles unexpectedly + closed proxy connections and larger read buffers. (Issue #135) + +* Ensure the connection is closed if no data is received, fixes connection leak + on some platforms. (Issue #133) + +* Added SNI support for SSL/TLS connections on Py32+. (Issue #89) + +* Tests fixed to be compatible with Py26 again. (Issue #125) + +* Added ability to choose SSL version by passing an ``ssl.PROTOCOL_*`` constant + to the ``ssl_version`` parameter of ``HTTPSConnectionPool``. (Issue #109) + +* Allow an explicit content type to be specified when encoding file fields. + (Issue #126) + +* Exceptions are now pickleable, with tests. (Issue #101) + +* Fixed default headers not getting passed in some cases. (Issue #99) + +* Treat "content-encoding" header value as case-insensitive, per RFC 2616 + Section 3.5. (Issue #110) + +* "Connection Refused" SocketErrors will get retried rather than raised. + (Issue #92) + +* Updated vendored ``six``, no longer overrides the global ``six`` module + namespace. (Issue #113) + +* ``urllib3.exceptions.MaxRetryError`` contains a ``reason`` property holding + the exception that prompted the final retry. If ``reason is None`` then it + was due to a redirect. (Issue #92, #114) + +* Fixed ``PoolManager.urlopen()`` from not redirecting more than once. + (Issue #149) + +* Don't assume ``Content-Type: text/plain`` for multi-part encoding parameters + that are not files. (Issue #111) + +* Pass `strict` param down to ``httplib.HTTPConnection``. (Issue #122) + +* Added mechanism to verify SSL certificates by fingerprint (md5, sha1) or + against an arbitrary hostname (when connecting by IP or for misconfigured + servers). (Issue #140) + +* Streaming decompression support. (Issue #159) + + +1.5 (2012-08-02) +---------------- + +* Added ``urllib3.add_stderr_logger()`` for quickly enabling STDERR debug + logging in urllib3. + +* Native full URL parsing (including auth, path, query, fragment) available in + ``urllib3.util.parse_url(url)``. + +* Built-in redirect will switch method to 'GET' if status code is 303. + (Issue #11) + +* ``urllib3.PoolManager`` strips the scheme and host before sending the request + uri. (Issue #8) + +* New ``urllib3.exceptions.DecodeError`` exception for when automatic decoding, + based on the Content-Type header, fails. + +* Fixed bug with pool depletion and leaking connections (Issue #76). Added + explicit connection closing on pool eviction. Added + ``urllib3.PoolManager.clear()``. + +* 99% -> 100% unit test coverage. + + +1.4 (2012-06-16) +---------------- + +* Minor AppEngine-related fixes. + +* Switched from ``mimetools.choose_boundary`` to ``uuid.uuid4()``. + +* Improved url parsing. (Issue #73) + +* IPv6 url support. (Issue #72) + + +1.3 (2012-03-25) +---------------- + +* Removed pre-1.0 deprecated API. + +* Refactored helpers into a ``urllib3.util`` submodule. + +* Fixed multipart encoding to support list-of-tuples for keys with multiple + values. (Issue #48) + +* Fixed multiple Set-Cookie headers in response not getting merged properly in + Python 3. (Issue #53) + +* AppEngine support with Py27. (Issue #61) + +* Minor ``encode_multipart_formdata`` fixes related to Python 3 strings vs + bytes. + + +1.2.2 (2012-02-06) +------------------ + +* Fixed packaging bug of not shipping ``test-requirements.txt``. (Issue #47) + + +1.2.1 (2012-02-05) +------------------ + +* Fixed another bug related to when ``ssl`` module is not available. (Issue #41) + +* Location parsing errors now raise ``urllib3.exceptions.LocationParseError`` + which inherits from ``ValueError``. + + +1.2 (2012-01-29) +---------------- + +* Added Python 3 support (tested on 3.2.2) + +* Dropped Python 2.5 support (tested on 2.6.7, 2.7.2) + +* Use ``select.poll`` instead of ``select.select`` for platforms that support + it. + +* Use ``Queue.LifoQueue`` instead of ``Queue.Queue`` for more aggressive + connection reusing. Configurable by overriding ``ConnectionPool.QueueCls``. + +* Fixed ``ImportError`` during install when ``ssl`` module is not available. + (Issue #41) + +* Fixed ``PoolManager`` redirects between schemes (such as HTTP -> HTTPS) not + completing properly. (Issue #28, uncovered by Issue #10 in v1.1) + +* Ported ``dummyserver`` to use ``tornado`` instead of ``webob`` + + ``eventlet``. Removed extraneous unsupported dummyserver testing backends. + Added socket-level tests. + +* More tests. Achievement Unlocked: 99% Coverage. + + +1.1 (2012-01-07) +---------------- + +* Refactored ``dummyserver`` to its own root namespace module (used for + testing). + +* Added hostname verification for ``VerifiedHTTPSConnection`` by vendoring in + Py32's ``ssl_match_hostname``. (Issue #25) + +* Fixed cross-host HTTP redirects when using ``PoolManager``. (Issue #10) + +* Fixed ``decode_content`` being ignored when set through ``urlopen``. (Issue + #27) + +* Fixed timeout-related bugs. (Issues #17, #23) + + +1.0.2 (2011-11-04) +------------------ + +* Fixed typo in ``VerifiedHTTPSConnection`` which would only present as a bug if + you're using the object manually. (Thanks pyos) + +* Made RecentlyUsedContainer (and consequently PoolManager) more thread-safe by + wrapping the access log in a mutex. (Thanks @christer) + +* Made RecentlyUsedContainer more dict-like (corrected ``__delitem__`` and + ``__getitem__`` behaviour), with tests. Shouldn't affect core urllib3 code. + + +1.0.1 (2011-10-10) +------------------ + +* Fixed a bug where the same connection would get returned into the pool twice, + causing extraneous "HttpConnectionPool is full" log warnings. + + +1.0 (2011-10-08) +---------------- + +* Added ``PoolManager`` with LRU expiration of connections (tested and + documented). +* Added ``ProxyManager`` (needs tests, docs, and confirmation that it works + with HTTPS proxies). +* Added optional partial-read support for responses when + ``preload_content=False``. You can now make requests and just read the headers + without loading the content. +* Made response decoding optional (default on, same as before). +* Added optional explicit boundary string for ``encode_multipart_formdata``. +* Convenience request methods are now inherited from ``RequestMethods``. Old + helpers like ``get_url`` and ``post_url`` should be abandoned in favour of + the new ``request(method, url, ...)``. +* Refactored code to be even more decoupled, reusable, and extendable. +* License header added to ``.py`` files. +* Embiggened the documentation: Lots of Sphinx-friendly docstrings in the code + and docs in ``docs/`` and on https://urllib3.readthedocs.io/. +* Embettered all the things! +* Started writing this file. + + +0.4.1 (2011-07-17) +------------------ + +* Minor bug fixes, code cleanup. + + +0.4 (2011-03-01) +---------------- + +* Better unicode support. +* Added ``VerifiedHTTPSConnection``. +* Added ``NTLMConnectionPool`` in contrib. +* Minor improvements. + + +0.3.1 (2010-07-13) +------------------ + +* Added ``assert_host_name`` optional parameter. Now compatible with proxies. + + +0.3 (2009-12-10) +---------------- + +* Added HTTPS support. +* Minor bug fixes. +* Refactored, broken backwards compatibility with 0.2. +* API to be treated as stable from this version forward. + + +0.2 (2008-11-17) +---------------- + +* Added unit tests. +* Bug fixes. + + +0.1 (2008-11-16) +---------------- + +* First release. + + diff --git a/venv/lib/python3.8/site-packages/urllib3-1.26.6.dist-info/RECORD b/venv/lib/python3.8/site-packages/urllib3-1.26.6.dist-info/RECORD new file mode 100644 index 0000000..712b755 --- /dev/null +++ b/venv/lib/python3.8/site-packages/urllib3-1.26.6.dist-info/RECORD @@ -0,0 +1,84 @@ +urllib3-1.26.6.dist-info/INSTALLER,sha256=zuuue4knoyJ-UwPPXg8fezS7VCrXJQrAP7zeNuwvFQg,4 +urllib3-1.26.6.dist-info/LICENSE.txt,sha256=w3vxhuJ8-dvpYZ5V7f486nswCRzrPaY8fay-Dm13kHs,1115 +urllib3-1.26.6.dist-info/METADATA,sha256=GTqag0OUj9vLryU3xGQO2LJGvkatmJYgTZxnWYT8fpc,44267 +urllib3-1.26.6.dist-info/RECORD,, +urllib3-1.26.6.dist-info/WHEEL,sha256=Z-nyYpwrcSqxfdux5Mbn_DQ525iP7J2DG3JgGvOYyTQ,110 +urllib3-1.26.6.dist-info/top_level.txt,sha256=EMiXL2sKrTcmrMxIHTqdc3ET54pQI2Y072LexFEemvo,8 +urllib3/__init__.py,sha256=j3yzHIbmW7CS-IKQJ9-PPQf_YKO8EOAey_rMW0UR7us,2763 +urllib3/__pycache__/__init__.cpython-38.pyc,, +urllib3/__pycache__/_collections.cpython-38.pyc,, +urllib3/__pycache__/_version.cpython-38.pyc,, +urllib3/__pycache__/connection.cpython-38.pyc,, +urllib3/__pycache__/connectionpool.cpython-38.pyc,, +urllib3/__pycache__/exceptions.cpython-38.pyc,, +urllib3/__pycache__/fields.cpython-38.pyc,, +urllib3/__pycache__/filepost.cpython-38.pyc,, +urllib3/__pycache__/poolmanager.cpython-38.pyc,, +urllib3/__pycache__/request.cpython-38.pyc,, +urllib3/__pycache__/response.cpython-38.pyc,, +urllib3/_collections.py,sha256=Rp1mVyBgc_UlAcp6M3at1skJBXR5J43NawRTvW2g_XY,10811 +urllib3/_version.py,sha256=6fJAIPnJkT0m9wzVjHrFcq5wYt65dStDpaRcjj5ugoo,63 +urllib3/connection.py,sha256=kAlubwsW33FUSUroPSVHMF_Zzv-uzX_BwUFMXX9Pt8c,18754 +urllib3/connectionpool.py,sha256=jXNmm4y3LJWYgteNeGcYJx8-0k7bzKRU__AVTXzaIak,37131 +urllib3/contrib/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 +urllib3/contrib/__pycache__/__init__.cpython-38.pyc,, +urllib3/contrib/__pycache__/_appengine_environ.cpython-38.pyc,, +urllib3/contrib/__pycache__/appengine.cpython-38.pyc,, +urllib3/contrib/__pycache__/ntlmpool.cpython-38.pyc,, +urllib3/contrib/__pycache__/pyopenssl.cpython-38.pyc,, +urllib3/contrib/__pycache__/securetransport.cpython-38.pyc,, +urllib3/contrib/__pycache__/socks.cpython-38.pyc,, +urllib3/contrib/_appengine_environ.py,sha256=bDbyOEhW2CKLJcQqAKAyrEHN-aklsyHFKq6vF8ZFsmk,957 +urllib3/contrib/_securetransport/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 +urllib3/contrib/_securetransport/__pycache__/__init__.cpython-38.pyc,, +urllib3/contrib/_securetransport/__pycache__/bindings.cpython-38.pyc,, +urllib3/contrib/_securetransport/__pycache__/low_level.cpython-38.pyc,, +urllib3/contrib/_securetransport/bindings.py,sha256=E1_7ScsgOchfxneozbAueK7ziCwF35fna4DuDCYJ9_o,17637 +urllib3/contrib/_securetransport/low_level.py,sha256=lgIdsSycqfB0Xm5BiJzXGeIKT7ybCQMFPJAgkcwPa1s,13908 +urllib3/contrib/appengine.py,sha256=jz515jZYBDFTnhR4zqfeaCo6JdDgAQqYbqzHK9sDkfw,11010 +urllib3/contrib/ntlmpool.py,sha256=ej9gGvfAb2Gt00lafFp45SIoRz-QwrQ4WChm6gQmAlM,4538 +urllib3/contrib/pyopenssl.py,sha256=YIMyTiXiLPV_QfFw3PjZ31mGqJmM5EzxIjhSLxZ7VUM,16874 +urllib3/contrib/securetransport.py,sha256=izdx43gFoUGFSgxasZlOCL42FaM4vSsAVTmhO0EH1vM,34417 +urllib3/contrib/socks.py,sha256=aRi9eWXo9ZEb95XUxef4Z21CFlnnjbEiAo9HOseoMt4,7097 +urllib3/exceptions.py,sha256=0Mnno3KHTNfXRfY7638NufOPkUb6mXOm-Lqj-4x2w8A,8217 +urllib3/fields.py,sha256=kvLDCg_JmH1lLjUUEY_FLS8UhY7hBvDPuVETbY8mdrM,8579 +urllib3/filepost.py,sha256=5b_qqgRHVlL7uLtdAYBzBh-GHmU5AfJVt_2N0XS3PeY,2440 +urllib3/packages/__init__.py,sha256=h4BLhD4tLaBx1adaDtKXfupsgqY0wWLXb_f1_yVlV6A,108 +urllib3/packages/__pycache__/__init__.cpython-38.pyc,, +urllib3/packages/__pycache__/six.cpython-38.pyc,, +urllib3/packages/backports/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 +urllib3/packages/backports/__pycache__/__init__.cpython-38.pyc,, +urllib3/packages/backports/__pycache__/makefile.cpython-38.pyc,, +urllib3/packages/backports/makefile.py,sha256=nbzt3i0agPVP07jqqgjhaYjMmuAi_W5E0EywZivVO8E,1417 +urllib3/packages/six.py,sha256=1LVW7ljqRirFlfExjwl-v1B7vSAUNTmzGMs-qays2zg,34666 +urllib3/packages/ssl_match_hostname/__init__.py,sha256=ZVMwCkHx-py8ERsxxM3Il-MiREZktV-8iLBmCfRRHI4,927 +urllib3/packages/ssl_match_hostname/__pycache__/__init__.cpython-38.pyc,, +urllib3/packages/ssl_match_hostname/__pycache__/_implementation.cpython-38.pyc,, +urllib3/packages/ssl_match_hostname/_implementation.py,sha256=6dZ-q074g7XhsJ27MFCgkct8iVNZB3sMZvKhf-KUVy0,5679 +urllib3/poolmanager.py,sha256=whzlX6UTEgODMOCy0ZDMUONRBCz5wyIM8Z9opXAY-Lk,19763 +urllib3/request.py,sha256=ZFSIqX0C6WizixecChZ3_okyu7BEv0lZu1VT0s6h4SM,5985 +urllib3/response.py,sha256=hGhGBh7TkEkh_IQg5C1W_xuPNrgIKv5BUXPyE-q0LuE,28203 +urllib3/util/__init__.py,sha256=JEmSmmqqLyaw8P51gUImZh8Gwg9i1zSe-DoqAitn2nc,1155 +urllib3/util/__pycache__/__init__.cpython-38.pyc,, +urllib3/util/__pycache__/connection.cpython-38.pyc,, +urllib3/util/__pycache__/proxy.cpython-38.pyc,, +urllib3/util/__pycache__/queue.cpython-38.pyc,, +urllib3/util/__pycache__/request.cpython-38.pyc,, +urllib3/util/__pycache__/response.cpython-38.pyc,, +urllib3/util/__pycache__/retry.cpython-38.pyc,, +urllib3/util/__pycache__/ssl_.cpython-38.pyc,, +urllib3/util/__pycache__/ssltransport.cpython-38.pyc,, +urllib3/util/__pycache__/timeout.cpython-38.pyc,, +urllib3/util/__pycache__/url.cpython-38.pyc,, +urllib3/util/__pycache__/wait.cpython-38.pyc,, +urllib3/util/connection.py,sha256=Z9JufD13VNcga6RTW1wRIULbWdxsPE0WCUi5VTebALA,4908 +urllib3/util/proxy.py,sha256=FGipAEnvZteyldXNjce4DEB7YzwU-a5lep8y5S0qHQg,1604 +urllib3/util/queue.py,sha256=nRgX8_eX-_VkvxoX096QWoz8Ps0QHUAExILCY_7PncM,498 +urllib3/util/request.py,sha256=NnzaEKQ1Pauw5MFMV6HmgEMHITf0Aua9fQuzi2uZzGc,4123 +urllib3/util/response.py,sha256=GJpg3Egi9qaJXRwBh5wv-MNuRWan5BIu40oReoxWP28,3510 +urllib3/util/retry.py,sha256=tOWfZpLsuc7Vbk5nWpMwkHdMoXCp90IAvH4xtjSDRqQ,21391 +urllib3/util/ssl_.py,sha256=c0sYiSC6272r6uPkxQpo5rYPP9QC1eR6oI7004gYqZo,17165 +urllib3/util/ssltransport.py,sha256=3bLBqYPryT9UMGbx5iRgMgb2sj7VEKp5pmRD1g8d6VI,6907 +urllib3/util/timeout.py,sha256=QSbBUNOB9yh6AnDn61SrLQ0hg5oz0I9-uXEG91AJuIg,10003 +urllib3/util/url.py,sha256=au9jkUMnVr9Qp_9kg4HfZx9q9ur6yXQ4u5M17In-UKY,14030 +urllib3/util/wait.py,sha256=3MUKRSAUJDB2tgco7qRUskW0zXGAWYvRRE4Q1_6xlLs,5404 diff --git a/venv/lib/python3.8/site-packages/urllib3-1.26.6.dist-info/WHEEL b/venv/lib/python3.8/site-packages/urllib3-1.26.6.dist-info/WHEEL new file mode 100644 index 0000000..01b8fc7 --- /dev/null +++ b/venv/lib/python3.8/site-packages/urllib3-1.26.6.dist-info/WHEEL @@ -0,0 +1,6 @@ +Wheel-Version: 1.0 +Generator: bdist_wheel (0.36.2) +Root-Is-Purelib: true +Tag: py2-none-any +Tag: py3-none-any + diff --git a/venv/lib/python3.8/site-packages/urllib3-1.26.6.dist-info/top_level.txt b/venv/lib/python3.8/site-packages/urllib3-1.26.6.dist-info/top_level.txt new file mode 100644 index 0000000..a42590b --- /dev/null +++ b/venv/lib/python3.8/site-packages/urllib3-1.26.6.dist-info/top_level.txt @@ -0,0 +1 @@ +urllib3 diff --git a/venv/lib/python3.8/site-packages/urllib3/__init__.py b/venv/lib/python3.8/site-packages/urllib3/__init__.py new file mode 100644 index 0000000..fe86b59 --- /dev/null +++ b/venv/lib/python3.8/site-packages/urllib3/__init__.py @@ -0,0 +1,85 @@ +""" +Python HTTP library with thread-safe connection pooling, file post support, user friendly, and more +""" +from __future__ import absolute_import + +# Set default logging handler to avoid "No handler found" warnings. +import logging +import warnings +from logging import NullHandler + +from . import exceptions +from ._version import __version__ +from .connectionpool import HTTPConnectionPool, HTTPSConnectionPool, connection_from_url +from .filepost import encode_multipart_formdata +from .poolmanager import PoolManager, ProxyManager, proxy_from_url +from .response import HTTPResponse +from .util.request import make_headers +from .util.retry import Retry +from .util.timeout import Timeout +from .util.url import get_host + +__author__ = "Andrey Petrov (andrey.petrov@shazow.net)" +__license__ = "MIT" +__version__ = __version__ + +__all__ = ( + "HTTPConnectionPool", + "HTTPSConnectionPool", + "PoolManager", + "ProxyManager", + "HTTPResponse", + "Retry", + "Timeout", + "add_stderr_logger", + "connection_from_url", + "disable_warnings", + "encode_multipart_formdata", + "get_host", + "make_headers", + "proxy_from_url", +) + +logging.getLogger(__name__).addHandler(NullHandler()) + + +def add_stderr_logger(level=logging.DEBUG): + """ + Helper for quickly adding a StreamHandler to the logger. Useful for + debugging. + + Returns the handler after adding it. + """ + # This method needs to be in this __init__.py to get the __name__ correct + # even if urllib3 is vendored within another package. + logger = logging.getLogger(__name__) + handler = logging.StreamHandler() + handler.setFormatter(logging.Formatter("%(asctime)s %(levelname)s %(message)s")) + logger.addHandler(handler) + logger.setLevel(level) + logger.debug("Added a stderr logging handler to logger: %s", __name__) + return handler + + +# ... Clean up. +del NullHandler + + +# All warning filters *must* be appended unless you're really certain that they +# shouldn't be: otherwise, it's very hard for users to use most Python +# mechanisms to silence them. +# SecurityWarning's always go off by default. +warnings.simplefilter("always", exceptions.SecurityWarning, append=True) +# SubjectAltNameWarning's should go off once per host +warnings.simplefilter("default", exceptions.SubjectAltNameWarning, append=True) +# InsecurePlatformWarning's don't vary between requests, so we keep it default. +warnings.simplefilter("default", exceptions.InsecurePlatformWarning, append=True) +# SNIMissingWarnings should go off only once. +warnings.simplefilter("default", exceptions.SNIMissingWarning, append=True) + + +def disable_warnings(category=exceptions.HTTPWarning): + """ + Helper for quickly disabling all urllib3 warnings. + """ + warnings.simplefilter("ignore", category) diff --git a/venv/lib/python3.8/site-packages/urllib3/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/urllib3/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..2e36c93d54fcc1d34d2116eda89cc327992f57e8 GIT binary patch literal 2141 zcmZ`)&2HO95GF(*#HiH+E2fJrHZ{N}|0>GRtLb z8P2IiZ+!>**k|b*@Y+*ep{IVck`gCDx!`DKI6FH#^UdhR%uLh4b8>f`{SEFP5-vX# z2>0=3_g%-~PT+8tm!zvoLCGcFlV0H2-*QmKZ&`Y(5>)W5!mF~XYC+BNHCb1UpkevC zY^qk!QthCvW`Y^3YsgtO7tC3{Dd*Kfu%H%$MYR+xSzSvmtCe8I@@;uVtp=->pOIJ9 zTCisMS$R!e53XB&PTo*AgPY*zgHQNE@TtJ*d@=BacmA2Ub>W`h7M0(e3)gjocldeV z=b6xcUq>S5abm}?1lYa;F? zT!bo@CQ6w$VL#D|GsED#Med%lm<@z3+PgYA8BL|xl%&g^+H~r3k)?=Jz;j!%BM}af zHG~Vf@?01_0#n)KnfssQ!C!jhU_#s?#9A& z3h&vI{m!heAvwBEq(!7nWR}Q0kp+-qfpH#Y2IuQgCIehTH%LFvql_I$5gs!gqk5U9 zHq(nl=7`LI^eFq&#{)yn_7HFO2*fz&t|?u(uU&B7h4Z>}Ryr?(uWNEOiTlWOt>NkV`UcB@X(c+D zzrG>GDB!{{kRS5)k60n>_&wy2IzE^3ot{&Ms! zlm)ldCW%HK44sBX^Ji{YFzXg8tFak5RS@tEp`Z;gdOez5j3R7 zD7g23C>SHv0zpcD5~n}K?YMSDH5$YiEIXZ2QJ;Q7GBH)8z+6HysnvSSh(V%9HYsCr z8`0<$ke~5pB@m}<<<3@73qzjtP^4xU_H)1p1=D1ruMpWF;(-*7rp`cBCu2!hNt}H* zZfHhcYFFEWb()tnE^X@-EwWMLL362}sSk^~p3D^6-a$Jzk?d;mG8foQ?HV*EDvTG~ z{SzAkGscXa1wq}~Ac3~c=~67msMok4CaR2j0#geDuFa&xRafCzUnO#bqNx1vu{-71Z7PHE9&=D!gDFUBV=WFK+0a*s{^3zQXBAGp1j0kmC7zwsl2f0 N%`TN{izU0f{{Uw^UH||9 literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/urllib3/__pycache__/_collections.cpython-38.pyc b/venv/lib/python3.8/site-packages/urllib3/__pycache__/_collections.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..e07a70540f53365fae9524afee545caa23694f2d GIT binary patch literal 10654 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 adGjRj-~uq;V!jCMS2PzOfvmmo;r{`K54rCE literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/urllib3/__pycache__/_version.cpython-38.pyc b/venv/lib/python3.8/site-packages/urllib3/__pycache__/_version.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..2125a832767572077a1ab9808022778fd2d604af GIT binary patch literal 165 zcmWIL<>g`kf(lF3M0+6p7{oyaj6jY95EpX*i4=w?h7`tN22G|aHbXrlGd(juO~zZ? z@$qG;Ma7x724V&PDK{tC literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/urllib3/__pycache__/connection.cpython-38.pyc b/venv/lib/python3.8/site-packages/urllib3/__pycache__/connection.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..2a382cc0eacd50afbe3284bdc6cfb77444cc416c GIT binary patch literal 13332 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 literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/urllib3/__pycache__/exceptions.cpython-38.pyc b/venv/lib/python3.8/site-packages/urllib3/__pycache__/exceptions.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..371f166c3b719b60f7e9e1a1e7253981f8a1cc02 GIT binary patch literal 11598 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 literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/urllib3/__pycache__/fields.cpython-38.pyc b/venv/lib/python3.8/site-packages/urllib3/__pycache__/fields.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..51b2158050ae422a95b6061eea5e12aec8e6755b GIT binary patch literal 8135 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 literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/urllib3/__pycache__/filepost.cpython-38.pyc b/venv/lib/python3.8/site-packages/urllib3/__pycache__/filepost.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..ea50ac6d573043db9fa45a66cf1722fd801225ac GIT binary patch literal 2722 zcmbVOTW{P%6rQoYj^k`D-G)L@DWgJBSITa<3AIZo2wJ2dH3b4ltXl1QJ+oOSzIA4t zn;c$Rp+4~&lE?l7ev4mu%3t7#bL`zs8bB(HH8W>!XU?3o|~tt_^!EUJGX;r|Xoo9nMB> z*DdLpa4xEM>y!xdc%C~al+Ruz-39LQxo4!i$m@I_`X#==7ooqz8+?ghdPchqZfug~ z0k)^q^S0Am1Xe zQVul4TB0^}sayuyN4-r7D%FCDidEl0qd`lWJ~iYO)MQRTZ!~tam6NAH<@6qTeB;P~ zU52i~uG_is6QShE4PD!|bK^HsjW`8O8;8G^3R>4fdRnk#S4cKQ^QyL6u54y0x`Se2 zpfpQ{?AFc-+ifzPfgKbBg)tuZTCJ2MZc?zTJlgR?uv@49%UBWZG2`=I)E{570cLRn zFtXBK?2E!erj;RP0}u{sqzVg3i4IlF4P_GbDk+*~VOP8h8WgpXER9q(mvMgskM_!? zUNYDgAo5jI=mIpvacSLf3V%))5DU(lU`?p}0+*|jYZ zi~UsI?I1(6t3_;bc>V14s=XE_z89*y?dj(KE0Vkp7gRF5J*5ypB)X-12bwjgQ#qQJ zd<_?_V1qy;Ux%hiCBFRPTjtKm+=6w52T0we%Z5a>^$i@43$9@;z4&(^G zav2bX904{XiU5M7M`jM_qAdpL+xCw$3 z#E;>TReoZV6KpRCLpBf$JsR{SA2QQJe%mNPJ0*cDwYND*^@;SnH@kbviCgVNs% zGl(_(P-r;@eJ%ENPamYBaJGcr^}J&a>!E{__*=hU*Q0uj~ literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/urllib3/__pycache__/poolmanager.cpython-38.pyc b/venv/lib/python3.8/site-packages/urllib3/__pycache__/poolmanager.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..1e71b0ed326044e5fad7ced63985d334d29a40d0 GIT binary patch literal 15080 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 v#Ka^rSTU{R&sI{;G1&5cNHy-S`$VjJBCx! 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 literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/urllib3/_collections.py b/venv/lib/python3.8/site-packages/urllib3/_collections.py new file mode 100644 index 0000000..da9857e --- /dev/null +++ b/venv/lib/python3.8/site-packages/urllib3/_collections.py @@ -0,0 +1,337 @@ +from __future__ import absolute_import + +try: + from collections.abc import Mapping, MutableMapping +except ImportError: + from collections import Mapping, MutableMapping +try: + from threading import RLock +except ImportError: # Platform-specific: No threads available + + class RLock: + def __enter__(self): + pass + + def __exit__(self, exc_type, exc_value, traceback): + pass + + +from collections import OrderedDict + +from .exceptions import InvalidHeader +from .packages import six +from .packages.six import iterkeys, itervalues + +__all__ = ["RecentlyUsedContainer", "HTTPHeaderDict"] + + +_Null = object() + + +class RecentlyUsedContainer(MutableMapping): + """ + Provides a thread-safe dict-like container which maintains up to + ``maxsize`` keys while throwing away the least-recently-used keys beyond + ``maxsize``. + + :param maxsize: + Maximum number of recent elements to retain. + + :param dispose_func: + Every time an item is evicted from the container, + ``dispose_func(value)`` is called. Callback which will get called + """ + + ContainerCls = OrderedDict + + def __init__(self, maxsize=10, dispose_func=None): + self._maxsize = maxsize + self.dispose_func = dispose_func + + self._container = self.ContainerCls() + self.lock = RLock() + + def __getitem__(self, key): + # Re-insert the item, moving it to the end of the eviction line. + with self.lock: + item = self._container.pop(key) + self._container[key] = item + return item + + def __setitem__(self, key, value): + evicted_value = _Null + with self.lock: + # Possibly evict the existing value of 'key' + evicted_value = self._container.get(key, _Null) + self._container[key] = value + + # If we didn't evict an existing value, we might have to evict the + # least recently used item from the beginning of the container. + if len(self._container) > self._maxsize: + _key, evicted_value = self._container.popitem(last=False) + + if self.dispose_func and evicted_value is not _Null: + self.dispose_func(evicted_value) + + def __delitem__(self, key): + with self.lock: + value = self._container.pop(key) + + if self.dispose_func: + self.dispose_func(value) + + def __len__(self): + with self.lock: + return len(self._container) + + def __iter__(self): + raise NotImplementedError( + "Iteration over this class is unlikely to be threadsafe." + ) + + def clear(self): + with self.lock: + # Copy pointers to all values, then wipe the mapping + values = list(itervalues(self._container)) + self._container.clear() + + if self.dispose_func: + for value in values: + self.dispose_func(value) + + def keys(self): + with self.lock: + return list(iterkeys(self._container)) + + +class HTTPHeaderDict(MutableMapping): + """ + :param headers: + An iterable of field-value pairs. Must not contain multiple field names + when compared case-insensitively. + + :param kwargs: + Additional field-value pairs to pass in to ``dict.update``. + + A ``dict`` like container for storing HTTP Headers. + + Field names are stored and compared case-insensitively in compliance with + RFC 7230. Iteration provides the first case-sensitive key seen for each + case-insensitive pair. + + Using ``__setitem__`` syntax overwrites fields that compare equal + case-insensitively in order to maintain ``dict``'s api. For fields that + compare equal, instead create a new ``HTTPHeaderDict`` and use ``.add`` + in a loop. + + If multiple fields that are equal case-insensitively are passed to the + constructor or ``.update``, the behavior is undefined and some will be + lost. + + >>> headers = HTTPHeaderDict() + >>> headers.add('Set-Cookie', 'foo=bar') + >>> headers.add('set-cookie', 'baz=quxx') + >>> headers['content-length'] = '7' + >>> headers['SET-cookie'] + 'foo=bar, baz=quxx' + >>> headers['Content-Length'] + '7' + """ + + def __init__(self, headers=None, **kwargs): + super(HTTPHeaderDict, self).__init__() + self._container = OrderedDict() + if headers is not None: + if isinstance(headers, HTTPHeaderDict): + self._copy_from(headers) + else: + self.extend(headers) + if kwargs: + self.extend(kwargs) + + def __setitem__(self, key, val): + self._container[key.lower()] = [key, val] + return self._container[key.lower()] + + def __getitem__(self, key): + val = self._container[key.lower()] + return ", ".join(val[1:]) + + def __delitem__(self, key): + del self._container[key.lower()] + + def __contains__(self, key): + return key.lower() in self._container + + def __eq__(self, other): + if not isinstance(other, Mapping) and not hasattr(other, "keys"): + return False + if not isinstance(other, type(self)): + other = type(self)(other) + return dict((k.lower(), v) for k, v in self.itermerged()) == dict( + (k.lower(), v) for k, v in other.itermerged() + ) + + def __ne__(self, other): + return not self.__eq__(other) + + if six.PY2: # Python 2 + iterkeys = MutableMapping.iterkeys + itervalues = MutableMapping.itervalues + + __marker = object() + + def __len__(self): + return len(self._container) + + def __iter__(self): + # Only provide the originally cased names + for vals in self._container.values(): + yield vals[0] + + def pop(self, key, default=__marker): + """D.pop(k[,d]) -> v, remove specified key and return the corresponding value. + If key is not found, d is returned if given, otherwise KeyError is raised. + """ + # Using the MutableMapping function directly fails due to the private marker. + # Using ordinary dict.pop would expose the internal structures. + # So let's reinvent the wheel. + try: + value = self[key] + except KeyError: + if default is self.__marker: + raise + return default + else: + del self[key] + return value + + def discard(self, key): + try: + del self[key] + except KeyError: + pass + + def add(self, key, val): + """Adds a (name, value) pair, doesn't overwrite the value if it already + exists. + + >>> headers = HTTPHeaderDict(foo='bar') + >>> headers.add('Foo', 'baz') + >>> headers['foo'] + 'bar, baz' + """ + key_lower = key.lower() + new_vals = [key, val] + # Keep the common case aka no item present as fast as possible + vals = self._container.setdefault(key_lower, new_vals) + if new_vals is not vals: + vals.append(val) + + def extend(self, *args, **kwargs): + """Generic import function for any type of header-like object. + Adapted version of MutableMapping.update in order to insert items + with self.add instead of self.__setitem__ + """ + if len(args) > 1: + raise TypeError( + "extend() takes at most 1 positional " + "arguments ({0} given)".format(len(args)) + ) + other = args[0] if len(args) >= 1 else () + + if isinstance(other, HTTPHeaderDict): + for key, val in other.iteritems(): + self.add(key, val) + elif isinstance(other, Mapping): + for key in other: + self.add(key, other[key]) + elif hasattr(other, "keys"): + for key in other.keys(): + self.add(key, other[key]) + else: + for key, value in other: + self.add(key, value) + + for key, value in kwargs.items(): + self.add(key, value) + + def getlist(self, key, default=__marker): + """Returns a list of all the values for the named field. Returns an + empty list if the key doesn't exist.""" + try: + vals = self._container[key.lower()] + except KeyError: + if default is self.__marker: + return [] + return default + else: + return vals[1:] + + # Backwards compatibility for httplib + getheaders = getlist + getallmatchingheaders = getlist + iget = getlist + + # Backwards compatibility for http.cookiejar + get_all = getlist + + def __repr__(self): + return "%s(%s)" % (type(self).__name__, dict(self.itermerged())) + + def _copy_from(self, other): + for key in other: + val = other.getlist(key) + if isinstance(val, list): + # Don't need to convert tuples + val = list(val) + self._container[key.lower()] = [key] + val + + def copy(self): + clone = type(self)() + clone._copy_from(self) + return clone + + def iteritems(self): + """Iterate over all header lines, including duplicate ones.""" + for key in self: + vals = self._container[key.lower()] + for val in vals[1:]: + yield vals[0], val + + def itermerged(self): + """Iterate over all headers, merging duplicate ones together.""" + for key in self: + val = self._container[key.lower()] + yield val[0], ", ".join(val[1:]) + + def items(self): + return list(self.iteritems()) + + @classmethod + def from_httplib(cls, message): # Python 2 + """Read headers from a Python 2 httplib message object.""" + # python2.7 does not expose a proper API for exporting multiheaders + # efficiently. This function re-reads raw lines from the message + # object and extracts the multiheaders properly. + obs_fold_continued_leaders = (" ", "\t") + headers = [] + + for line in message.headers: + if line.startswith(obs_fold_continued_leaders): + if not headers: + # We received a header line that starts with OWS as described + # in RFC-7230 S3.2.4. This indicates a multiline header, but + # there exists no previous header to which we can attach it. + raise InvalidHeader( + "Header continuation with no previous header: %s" % line + ) + else: + key, value = headers[-1] + headers[-1] = (key, value + " " + line.strip()) + continue + + key, value = line.split(":", 1) + headers.append((key, value.strip())) + + return cls(headers) diff --git a/venv/lib/python3.8/site-packages/urllib3/_version.py b/venv/lib/python3.8/site-packages/urllib3/_version.py new file mode 100644 index 0000000..e8ebee9 --- /dev/null +++ b/venv/lib/python3.8/site-packages/urllib3/_version.py @@ -0,0 +1,2 @@ +# This file is protected via CODEOWNERS +__version__ = "1.26.6" diff --git a/venv/lib/python3.8/site-packages/urllib3/connection.py b/venv/lib/python3.8/site-packages/urllib3/connection.py new file mode 100644 index 0000000..4c99665 --- /dev/null +++ b/venv/lib/python3.8/site-packages/urllib3/connection.py @@ -0,0 +1,539 @@ +from __future__ import absolute_import + +import datetime +import logging +import os +import re +import socket +import warnings +from socket import error as SocketError +from socket import timeout as SocketTimeout + +from .packages import six +from .packages.six.moves.http_client import HTTPConnection as _HTTPConnection +from .packages.six.moves.http_client import HTTPException # noqa: F401 +from .util.proxy import create_proxy_ssl_context + +try: # Compiled with SSL? + import ssl + + BaseSSLError = ssl.SSLError +except (ImportError, AttributeError): # Platform-specific: No SSL. + ssl = None + + class BaseSSLError(BaseException): + pass + + +try: + # Python 3: not a no-op, we're adding this to the namespace so it can be imported. + ConnectionError = ConnectionError +except NameError: + # Python 2 + class ConnectionError(Exception): + pass + + +try: # Python 3: + # Not a no-op, we're adding this to the namespace so it can be imported. + BrokenPipeError = BrokenPipeError +except NameError: # Python 2: + + class BrokenPipeError(Exception): + pass + + +from ._collections import HTTPHeaderDict # noqa (historical, removed in v2) +from ._version import __version__ +from .exceptions import ( + ConnectTimeoutError, + NewConnectionError, + 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, + resolve_cert_reqs, + resolve_ssl_version, + ssl_wrap_socket, +) + +log = logging.getLogger(__name__) + +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) + +_CONTAINS_CONTROL_CHAR_RE = re.compile(r"[^-!#$%&'*+.^_`|~0-9a-zA-Z]") + + +class HTTPConnection(_HTTPConnection, object): + """ + Based on :class:`http.client.HTTPConnection` but provides an extra constructor + backwards-compatibility layer between older and newer Pythons. + + Additional keyword parameters are used to configure attributes of the connection. + Accepted parameters include: + + - ``strict``: See the documentation on :class:`urllib3.connectionpool.HTTPConnectionPool` + - ``source_address``: Set the source address for the current connection. + - ``socket_options``: Set specific options on the underlying socket. If not specified, then + defaults are loaded from ``HTTPConnection.default_socket_options`` which includes disabling + Nagle's algorithm (sets TCP_NODELAY to 1) unless the connection is behind a proxy. + + For example, if you wish to enable TCP Keep Alive in addition to the defaults, + you might pass: + + .. code-block:: python + + HTTPConnection.default_socket_options + [ + (socket.SOL_SOCKET, socket.SO_KEEPALIVE, 1), + ] + + Or you may want to disable the defaults by passing an empty list (e.g., ``[]``). + """ + + default_port = port_by_scheme["http"] + + #: Disable Nagle's algorithm by default. + #: ``[(socket.IPPROTO_TCP, socket.TCP_NODELAY, 1)]`` + default_socket_options = [(socket.IPPROTO_TCP, socket.TCP_NODELAY, 1)] + + #: Whether this connection verifies the host's certificate. + is_verified = False + + def __init__(self, *args, **kw): + if not six.PY2: + kw.pop("strict", None) + + # Pre-set source_address. + self.source_address = kw.get("source_address") + + #: The socket options provided by the user. If no options are + #: provided, we use the default options. + self.socket_options = kw.pop("socket_options", self.default_socket_options) + + # Proxy options provided by the user. + self.proxy = kw.pop("proxy", None) + self.proxy_config = kw.pop("proxy_config", None) + + _HTTPConnection.__init__(self, *args, **kw) + + @property + def host(self): + """ + Getter method to remove any trailing dots that indicate the hostname is an FQDN. + + In general, SSL certificates don't include the trailing dot indicating a + fully-qualified domain name, and thus, they don't validate properly when + checked against a domain name that includes the dot. In addition, some + servers may not expect to receive the trailing dot when provided. + + However, the hostname with trailing dot is critical to DNS resolution; doing a + lookup with the trailing dot will properly only resolve the appropriate FQDN, + whereas a lookup without a trailing dot will search the system's search domain + list. Thus, it's important to keep the original host around for use only in + those cases where it's appropriate (i.e., when doing DNS lookup to establish the + actual TCP connection across which we're going to send HTTP requests). + """ + return self._dns_host.rstrip(".") + + @host.setter + def host(self, value): + """ + Setter for the `host` property. + + We assume that only urllib3 uses the _dns_host attribute; httplib itself + only uses `host`, and it seems reasonable that other libraries follow suit. + """ + self._dns_host = value + + def _new_conn(self): + """Establish a socket connection and set nodelay settings on it. + + :return: New socket connection. + """ + extra_kw = {} + if self.source_address: + extra_kw["source_address"] = self.source_address + + if self.socket_options: + extra_kw["socket_options"] = self.socket_options + + try: + conn = connection.create_connection( + (self._dns_host, self.port), self.timeout, **extra_kw + ) + + except SocketTimeout: + raise ConnectTimeoutError( + self, + "Connection to %s timed out. (connect timeout=%s)" + % (self.host, self.timeout), + ) + + except SocketError as e: + raise NewConnectionError( + self, "Failed to establish a new connection: %s" % e + ) + + return conn + + def _is_using_tunnel(self): + # Google App Engine's httplib does not define _tunnel_host + return getattr(self, "_tunnel_host", None) + + def _prepare_conn(self, conn): + self.sock = conn + if self._is_using_tunnel(): + # TODO: Fix tunnel so it doesn't depend on self.sock state. + self._tunnel() + # Mark this connection as not reusable + self.auto_open = 0 + + def connect(self): + conn = self._new_conn() + 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) + if match: + raise ValueError( + "Method cannot contain non-token characters %r (found at least %r)" + % (method, match.group()) + ) + + 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: + raise ValueError( + "urllib3.util.SKIP_HEADER only supports '%s'" + % ("', '".join(map(str.title, sorted(SKIPPABLE_HEADERS))),) + ) + + def request(self, method, url, body=None, headers=None): + if headers is None: + headers = {} + else: + # Avoid modifying the headers passed into .request() + headers = headers.copy() + if "user-agent" not in (six.ensure_str(k.lower()) for k in headers): + headers["User-Agent"] = _get_default_user_agent() + super(HTTPConnection, self).request(method, url, body=body, headers=headers) + + def request_chunked(self, method, url, body=None, headers=None): + """ + Alternative to the common request method, which sends the + body with chunked encoding and not as one block + """ + headers = headers or {} + header_keys = set([six.ensure_str(k.lower()) for k in headers]) + skip_accept_encoding = "accept-encoding" in header_keys + skip_host = "host" in header_keys + self.putrequest( + method, url, skip_accept_encoding=skip_accept_encoding, skip_host=skip_host + ) + if "user-agent" not in header_keys: + self.putheader("User-Agent", _get_default_user_agent()) + for header, value in headers.items(): + self.putheader(header, value) + if "transfer-encoding" not in header_keys: + self.putheader("Transfer-Encoding", "chunked") + self.endheaders() + + if body is not None: + stringish_types = six.string_types + (bytes,) + if isinstance(body, stringish_types): + body = (body,) + for chunk in body: + if not chunk: + continue + if not isinstance(chunk, bytes): + chunk = chunk.encode("utf8") + len_str = hex(len(chunk))[2:] + to_send = bytearray(len_str.encode()) + to_send += b"\r\n" + to_send += chunk + to_send += b"\r\n" + self.send(to_send) + + # After the if clause, to always have a closed body + self.send(b"0\r\n\r\n") + + +class HTTPSConnection(HTTPConnection): + """ + Many of the parameters to this constructor are passed to the underlying SSL + socket by means of :py:func:`urllib3.util.ssl_wrap_socket`. + """ + + default_port = port_by_scheme["https"] + + cert_reqs = None + ca_certs = None + ca_cert_dir = None + ca_cert_data = None + ssl_version = None + assert_fingerprint = None + tls_in_tls_required = False + + def __init__( + self, + host, + port=None, + key_file=None, + cert_file=None, + key_password=None, + strict=None, + timeout=socket._GLOBAL_DEFAULT_TIMEOUT, + ssl_context=None, + server_hostname=None, + **kw + ): + + HTTPConnection.__init__(self, host, port, strict=strict, timeout=timeout, **kw) + + self.key_file = key_file + self.cert_file = cert_file + self.key_password = key_password + self.ssl_context = ssl_context + self.server_hostname = server_hostname + + # Required property for Google AppEngine 1.9.0 which otherwise causes + # HTTPS requests to go out as HTTP. (See Issue #356) + self._protocol = "https" + + def set_cert( + self, + key_file=None, + cert_file=None, + cert_reqs=None, + key_password=None, + ca_certs=None, + assert_hostname=None, + assert_fingerprint=None, + ca_cert_dir=None, + ca_cert_data=None, + ): + """ + This method should only be called once, before the connection is used. + """ + # If cert_reqs is not provided we'll assume CERT_REQUIRED unless we also + # have an SSLContext object in which case we'll use its verify_mode. + if cert_reqs is None: + if self.ssl_context is not None: + cert_reqs = self.ssl_context.verify_mode + else: + cert_reqs = resolve_cert_reqs(None) + + self.key_file = key_file + self.cert_file = cert_file + self.cert_reqs = cert_reqs + self.key_password = key_password + self.assert_hostname = assert_hostname + self.assert_fingerprint = assert_fingerprint + self.ca_certs = ca_certs and os.path.expanduser(ca_certs) + self.ca_cert_dir = ca_cert_dir and os.path.expanduser(ca_cert_dir) + self.ca_cert_data = ca_cert_data + + def connect(self): + # Add certificate verification + 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) + tls_in_tls = True + + self.sock = conn + + # Calls self._set_hostport(), so self.host is + # self._tunnel_host below. + self._tunnel() + # Mark this connection as not reusable + self.auto_open = 0 + + # Override the host with the one we're requesting data from. + hostname = self._tunnel_host + + server_hostname = hostname + if self.server_hostname is not None: + server_hostname = self.server_hostname + + is_time_off = datetime.date.today() < RECENT_DATE + if is_time_off: + warnings.warn( + ( + "System time is way off (before {0}). This will probably " + "lead to SSL verification errors" + ).format(RECENT_DATE), + SystemTimeWarning, + ) + + # Wrap socket using verification with the root certs in + # trusted_root_certs + default_ssl_context = False + if self.ssl_context is None: + default_ssl_context = True + self.ssl_context = create_urllib3_context( + ssl_version=resolve_ssl_version(self.ssl_version), + cert_reqs=resolve_cert_reqs(self.cert_reqs), + ) + + context = self.ssl_context + context.verify_mode = resolve_cert_reqs(self.cert_reqs) + + # Try to load OS default certs if none are given. + # Works well on Windows (requires Python3.4+) + if ( + not self.ca_certs + and not self.ca_cert_dir + and not self.ca_cert_data + and default_ssl_context + and hasattr(context, "load_default_certs") + ): + context.load_default_certs() + + self.sock = ssl_wrap_socket( + sock=conn, + keyfile=self.key_file, + certfile=self.cert_file, + key_password=self.key_password, + ca_certs=self.ca_certs, + ca_cert_dir=self.ca_cert_dir, + ca_cert_data=self.ca_cert_data, + server_hostname=server_hostname, + ssl_context=context, + tls_in_tls=tls_in_tls, + ) + + # If we're using all defaults and the connection + # is TLSv1 or TLSv1.1 we throw a DeprecationWarning + # for the host. + if ( + default_ssl_context + and self.ssl_version is None + and hasattr(self.sock, "version") + and self.sock.version() in {"TLSv1", "TLSv1.1"} + ): + warnings.warn( + "Negotiating TLSv1/TLSv1.1 by default is deprecated " + "and will be disabled in urllib3 v2.0.0. Connecting to " + "'%s' with '%s' can be enabled by explicitly opting-in " + "with 'ssl_version'" % (self.host, self.sock.version()), + DeprecationWarning, + ) + + if self.assert_fingerprint: + assert_fingerprint( + self.sock.getpeercert(binary_form=True), self.assert_fingerprint + ) + elif ( + context.verify_mode != ssl.CERT_NONE + and not getattr(context, "check_hostname", False) + and self.assert_hostname is not 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 = self.sock.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, self.assert_hostname or server_hostname) + + self.is_verified = ( + context.verify_mode == ssl.CERT_REQUIRED + or self.assert_fingerprint is not None + ) + + def _connect_tls_proxy(self, hostname, conn): + """ + Establish a TLS connection to the proxy using the provided SSL context. + """ + proxy_config = self.proxy_config + ssl_context = proxy_config.ssl_context + if ssl_context: + # If the user provided a proxy context, we assume CA and client + # certificates have already been set + return ssl_wrap_socket( + sock=conn, + server_hostname=hostname, + ssl_context=ssl_context, + ) + + ssl_context = create_proxy_ssl_context( + self.ssl_version, + self.cert_reqs, + self.ca_certs, + 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( + sock=conn, + ca_certs=self.ca_certs, + ca_cert_dir=self.ca_cert_dir, + ca_cert_data=self.ca_cert_data, + server_hostname=hostname, + ssl_context=ssl_context, + ) + + +def _match_hostname(cert, asserted_hostname): + try: + match_hostname(cert, asserted_hostname) + except CertificateError as e: + log.warning( + "Certificate did not match expected hostname: %s. Certificate: %s", + asserted_hostname, + cert, + ) + # Add cert to exception and reraise so client code can inspect + # the cert when catching the exception, if they want to + e._peer_cert = cert + raise + + +def _get_default_user_agent(): + return "python-urllib3/%s" % __version__ + + +class DummyConnection(object): + """Used to detect a failed ConnectionCls import.""" + + pass + + +if not ssl: + HTTPSConnection = DummyConnection # noqa: F811 + + +VerifiedHTTPSConnection = HTTPSConnection diff --git a/venv/lib/python3.8/site-packages/urllib3/connectionpool.py b/venv/lib/python3.8/site-packages/urllib3/connectionpool.py new file mode 100644 index 0000000..459bbe0 --- /dev/null +++ b/venv/lib/python3.8/site-packages/urllib3/connectionpool.py @@ -0,0 +1,1067 @@ +from __future__ import absolute_import + +import errno +import logging +import socket +import sys +import warnings +from socket import error as SocketError +from socket import timeout as SocketTimeout + +from .connection import ( + BaseSSLError, + BrokenPipeError, + DummyConnection, + HTTPConnection, + HTTPException, + HTTPSConnection, + VerifiedHTTPSConnection, + port_by_scheme, +) +from .exceptions import ( + ClosedPoolError, + EmptyPoolError, + HeaderParsingError, + HostChangedError, + InsecureRequestWarning, + LocationValueError, + MaxRetryError, + NewConnectionError, + ProtocolError, + ProxyError, + ReadTimeoutError, + SSLError, + TimeoutError, +) +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 +from .util.proxy import connection_requires_http_tunnel +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.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 + +xrange = six.moves.xrange + +log = logging.getLogger(__name__) + +_Default = object() + + +# Pool objects +class ConnectionPool(object): + """ + Base class for all connection pools, such as + :class:`.HTTPConnectionPool` and :class:`.HTTPSConnectionPool`. + + .. note:: + ConnectionPool.urlopen() does not normalize or percent-encode target URIs + which is useful if your target server doesn't support percent-encoded + target URIs. + """ + + scheme = None + QueueCls = LifoQueue + + def __init__(self, host, port=None): + if not host: + raise LocationValueError("No host specified.") + + self.host = _normalize_host(host, scheme=self.scheme) + self._proxy_host = host.lower() + self.port = port + + def __str__(self): + return "%s(host=%r, port=%r)" % (type(self).__name__, self.host, self.port) + + def __enter__(self): + return self + + def __exit__(self, exc_type, exc_val, exc_tb): + self.close() + # Return False to re-raise any potential exceptions + return False + + def close(self): + """ + Close all pooled connections and disable the pool. + """ + pass + + +# This is taken from http://hg.python.org/cpython/file/7aaba721ebc0/Lib/socket.py#l252 +_blocking_errnos = {errno.EAGAIN, errno.EWOULDBLOCK} + + +class HTTPConnectionPool(ConnectionPool, RequestMethods): + """ + Thread-safe connection pool for one host. + + :param host: + Host used for this HTTP Connection (e.g. "localhost"), passed into + :class:`http.client.HTTPConnection`. + + :param port: + Port used for this HTTP Connection (None is equivalent to 80), passed + into :class:`http.client.HTTPConnection`. + + :param strict: + Causes BadStatusLine to be raised if the status line can't be parsed + as a valid HTTP/1.0 or 1.1 status line, passed into + :class:`http.client.HTTPConnection`. + + .. note:: + Only works in Python 2. This parameter is ignored in Python 3. + + :param timeout: + Socket timeout in seconds for each individual connection. This can + be a float or integer, which sets the timeout for the HTTP request, + or an instance of :class:`urllib3.util.Timeout` which gives you more + fine-grained control over request timeouts. After the constructor has + been parsed, this is always a `urllib3.util.Timeout` object. + + :param maxsize: + Number of connections to save that can be reused. More than 1 is useful + in multithreaded situations. If ``block`` is set to False, more + connections will be created but they will not be saved once they've + been used. + + :param block: + If set to True, no more than ``maxsize`` connections will be used at + a time. When no free connections are available, the call will block + until a connection has been released. This is a useful side effect for + particular multithreaded situations where one does not want to use more + than maxsize connections per host to prevent flooding. + + :param headers: + Headers to include with all requests, unless other headers are given + explicitly. + + :param retries: + Retry configuration to use by default with requests in this pool. + + :param _proxy: + Parsed proxy URL, should not be used directly, instead, see + :class:`urllib3.ProxyManager` + + :param _proxy_headers: + A dictionary with proxy headers, should not be used directly, + instead, see :class:`urllib3.ProxyManager` + + :param \\**conn_kw: + Additional parameters are used to create fresh :class:`urllib3.connection.HTTPConnection`, + :class:`urllib3.connection.HTTPSConnection` instances. + """ + + scheme = "http" + ConnectionCls = HTTPConnection + ResponseCls = HTTPResponse + + def __init__( + self, + host, + port=None, + strict=False, + timeout=Timeout.DEFAULT_TIMEOUT, + maxsize=1, + block=False, + headers=None, + retries=None, + _proxy=None, + _proxy_headers=None, + _proxy_config=None, + **conn_kw + ): + ConnectionPool.__init__(self, host, port) + RequestMethods.__init__(self, headers) + + self.strict = strict + + if not isinstance(timeout, Timeout): + timeout = Timeout.from_float(timeout) + + if retries is None: + retries = Retry.DEFAULT + + self.timeout = timeout + self.retries = retries + + self.pool = self.QueueCls(maxsize) + self.block = block + + self.proxy = _proxy + self.proxy_headers = _proxy_headers or {} + self.proxy_config = _proxy_config + + # Fill the queue up so that doing get() on it will block properly + for _ in xrange(maxsize): + self.pool.put(None) + + # These are mostly for testing and debugging purposes. + self.num_connections = 0 + self.num_requests = 0 + self.conn_kw = conn_kw + + if self.proxy: + # Enable Nagle's algorithm for proxies, to avoid packet fragmentation. + # We cannot know if the user has added default socket options, so we cannot replace the + # list. + self.conn_kw.setdefault("socket_options", []) + + self.conn_kw["proxy"] = self.proxy + self.conn_kw["proxy_config"] = self.proxy_config + + def _new_conn(self): + """ + Return a fresh :class:`HTTPConnection`. + """ + self.num_connections += 1 + log.debug( + "Starting new HTTP connection (%d): %s:%s", + self.num_connections, + self.host, + self.port or "80", + ) + + conn = self.ConnectionCls( + host=self.host, + port=self.port, + timeout=self.timeout.connect_timeout, + strict=self.strict, + **self.conn_kw + ) + return conn + + def _get_conn(self, timeout=None): + """ + Get a connection. Will return a pooled connection if one is available. + + If no connections are available and :prop:`.block` is ``False``, then a + fresh connection is returned. + + :param timeout: + Seconds to wait before giving up and raising + :class:`urllib3.exceptions.EmptyPoolError` if the pool is empty and + :prop:`.block` is ``True``. + """ + conn = None + try: + conn = self.pool.get(block=self.block, timeout=timeout) + + except AttributeError: # self.pool is None + raise ClosedPoolError(self, "Pool is closed.") + + except queue.Empty: + if self.block: + raise EmptyPoolError( + self, + "Pool reached maximum size and no more connections are allowed.", + ) + pass # Oh well, we'll create a new connection then + + # If this is a persistent connection, check if it got disconnected + if conn and is_connection_dropped(conn): + log.debug("Resetting dropped connection: %s", self.host) + conn.close() + if getattr(conn, "auto_open", 1) == 0: + # This is a proxied connection that has been mutated by + # http.client._tunnel() and cannot be reused (since it would + # attempt to bypass the proxy) + conn = None + + return conn or self._new_conn() + + def _put_conn(self, conn): + """ + Put a connection back into the pool. + + :param conn: + Connection object for the current host and port as returned by + :meth:`._new_conn` or :meth:`._get_conn`. + + If the pool is already full, the connection is closed and discarded + because we exceeded maxsize. If connections are discarded frequently, + then maxsize should be increased. + + If the pool is closed, then the connection will be closed and discarded. + """ + try: + self.pool.put(conn, block=False) + return # Everything is dandy, done. + except AttributeError: + # self.pool is None. + pass + except queue.Full: + # This should never happen if self.block == True + log.warning("Connection pool is full, discarding connection: %s", self.host) + + # Connection never got put back into the pool, close it. + if conn: + conn.close() + + def _validate_conn(self, conn): + """ + Called right before a request is made, after the socket is created. + """ + pass + + def _prepare_proxy(self, conn): + # Nothing to do for HTTP connections. + pass + + def _get_timeout(self, timeout): + """Helper that always returns a :class:`urllib3.util.Timeout`""" + if timeout is _Default: + return self.timeout.clone() + + if isinstance(timeout, Timeout): + return timeout.clone() + else: + # User passed us an int/float. This is for backwards compatibility, + # can be removed later + return Timeout.from_float(timeout) + + def _raise_timeout(self, err, url, timeout_value): + """Is the error actually a timeout? Will raise a ReadTimeout or pass""" + + if isinstance(err, SocketTimeout): + raise ReadTimeoutError( + self, url, "Read timed out. (read timeout=%s)" % timeout_value + ) + + # See the above comment about EAGAIN in Python 3. In Python 2 we have + # to specifically catch it and throw the timeout error + if hasattr(err, "errno") and err.errno in _blocking_errnos: + raise ReadTimeoutError( + self, url, "Read timed out. (read timeout=%s)" % timeout_value + ) + + # Catch possible read timeouts thrown as SSL errors. If not the + # case, rethrow the original. We need to do this because of: + # http://bugs.python.org/issue10272 + if "timed out" in str(err) or "did not complete (read)" in str( + err + ): # Python < 2.7.4 + raise ReadTimeoutError( + self, url, "Read timed out. (read timeout=%s)" % timeout_value + ) + + def _make_request( + self, conn, method, url, timeout=_Default, chunked=False, **httplib_request_kw + ): + """ + Perform a request on a given urllib connection object taken from our + pool. + + :param conn: + a connection from one of our connection pools + + :param timeout: + Socket timeout in seconds for the request. This can be a + float or integer, which will set the same timeout value for + the socket connect and the socket read, or an instance of + :class:`urllib3.util.Timeout`, which gives you more fine-grained + control over your timeouts. + """ + self.num_requests += 1 + + timeout_obj = self._get_timeout(timeout) + timeout_obj.start_connect() + conn.timeout = timeout_obj.connect_timeout + + # Trigger any extra validation we need to do. + try: + self._validate_conn(conn) + except (SocketTimeout, BaseSSLError) as e: + # Py2 raises this as a BaseSSLError, Py3 raises it as socket timeout. + self._raise_timeout(err=e, url=url, timeout_value=conn.timeout) + raise + + # conn.request() calls http.client.*.request, not the method in + # urllib3.request. It also calls makefile (recv) on the socket. + try: + if chunked: + conn.request_chunked(method, url, **httplib_request_kw) + else: + conn.request(method, url, **httplib_request_kw) + + # We are swallowing BrokenPipeError (errno.EPIPE) since the server is + # legitimately able to close the connection after sending a valid response. + # With this behaviour, the received response is still readable. + except BrokenPipeError: + # Python 3 + pass + except IOError as e: + # Python 2 and macOS/Linux + # EPIPE and ESHUTDOWN are BrokenPipeError on Python 2, and EPROTOTYPE is needed on macOS + # https://erickt.github.io/blog/2014/11/19/adventures-in-debugging-a-potential-osx-kernel-bug/ + if e.errno not in { + errno.EPIPE, + errno.ESHUTDOWN, + errno.EPROTOTYPE, + }: + raise + + # Reset the timeout for the recv() on the socket + read_timeout = timeout_obj.read_timeout + + # App Engine doesn't have a sock attr + if getattr(conn, "sock", None): + # In Python 3 socket.py will catch EAGAIN and return None when you + # try and read into the file pointer created by http.client, which + # instead raises a BadStatusLine exception. Instead of catching + # the exception and assuming all BadStatusLine exceptions are read + # timeouts, check for a zero timeout before making the request. + if read_timeout == 0: + raise ReadTimeoutError( + self, url, "Read timed out. (read timeout=%s)" % read_timeout + ) + if read_timeout is Timeout.DEFAULT_TIMEOUT: + conn.sock.settimeout(socket.getdefaulttimeout()) + else: # None or a value + conn.sock.settimeout(read_timeout) + + # Receive the response from the server + try: + try: + # Python 2.7, use buffering of HTTP responses + httplib_response = conn.getresponse(buffering=True) + except TypeError: + # Python 3 + try: + httplib_response = conn.getresponse() + except BaseException as e: + # Remove the TypeError from the exception chain in + # Python 3 (including for exceptions like SystemExit). + # Otherwise it looks like a bug in the code. + six.raise_from(e, None) + except (SocketTimeout, BaseSSLError, SocketError) as e: + self._raise_timeout(err=e, url=url, timeout_value=read_timeout) + raise + + # AppEngine doesn't have a version attr. + http_version = getattr(conn, "_http_vsn_str", "HTTP/?") + log.debug( + '%s://%s:%s "%s %s %s" %s %s', + self.scheme, + self.host, + self.port, + method, + url, + http_version, + httplib_response.status, + httplib_response.length, + ) + + try: + assert_header_parsing(httplib_response.msg) + except (HeaderParsingError, TypeError) as hpe: # Platform-specific: Python 3 + log.warning( + "Failed to parse headers (url=%s): %s", + self._absolute_url(url), + hpe, + exc_info=True, + ) + + return httplib_response + + def _absolute_url(self, path): + return Url(scheme=self.scheme, host=self.host, port=self.port, path=path).url + + def close(self): + """ + Close all pooled connections and disable the pool. + """ + if self.pool is None: + return + # 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. + + def is_same_host(self, url): + """ + Check if the given ``url`` is a member of the same host as this + connection pool. + """ + if url.startswith("/"): + return True + + # TODO: Add optional support for socket.gethostbyname checking. + scheme, host, port = get_host(url) + if host is not None: + host = _normalize_host(host, scheme=scheme) + + # Use explicit default port for comparison when none is given + if self.port and not port: + port = port_by_scheme.get(scheme) + elif not self.port and port == port_by_scheme.get(scheme): + port = None + + return (scheme, host, port) == (self.scheme, self.host, self.port) + + def urlopen( + self, + method, + url, + body=None, + headers=None, + retries=None, + redirect=True, + assert_same_host=True, + timeout=_Default, + pool_timeout=None, + release_conn=None, + chunked=False, + body_pos=None, + **response_kw + ): + """ + Get a connection from the pool and perform an HTTP request. This is the + lowest level call for making a request, so you'll need to specify all + the raw details. + + .. note:: + + More commonly, it's appropriate to use a convenience method provided + by :class:`.RequestMethods`, such as :meth:`request`. + + .. note:: + + `release_conn` will only behave as expected if + `preload_content=False` because we want to make + `preload_content=False` the default behaviour someday soon without + breaking backwards compatibility. + + :param method: + HTTP request method (such as GET, POST, PUT, etc.) + + :param url: + The URL to perform the request on. + + :param body: + Data to send in the request body, either :class:`str`, :class:`bytes`, + an iterable of :class:`str`/:class:`bytes`, or a file-like object. + + :param headers: + Dictionary of custom headers to send, such as User-Agent, + If-None-Match, etc. If None, pool headers are used. If provided, + these headers completely replace any pool-specific headers. + + :param retries: + Configure the number of retries to allow before raising a + :class:`~urllib3.exceptions.MaxRetryError` exception. + + Pass ``None`` to retry until you receive a response. Pass a + :class:`~urllib3.util.retry.Retry` object for fine-grained control + over different types of retries. + Pass an integer number to retry connection errors that many times, + but no other types of errors. Pass zero to never retry. + + If ``False``, then retries are disabled and any exception is raised + immediately. Also, instead of raising a MaxRetryError on redirects, + the redirect response will be returned. + + :type retries: :class:`~urllib3.util.retry.Retry`, False, or an int. + + :param redirect: + If True, automatically handle redirects (status codes 301, 302, + 303, 307, 308). Each redirect counts as a retry. Disabling retries + will disable redirect, too. + + :param assert_same_host: + If ``True``, will make sure that the host of the pool requests is + consistent else will raise HostChangedError. When ``False``, you can + use the pool on an HTTP proxy and request foreign hosts. + + :param timeout: + If specified, overrides the default timeout for this one + request. It may be a float (in seconds) or an instance of + :class:`urllib3.util.Timeout`. + + :param pool_timeout: + If set and the pool is set to block=True, then this method will + block for ``pool_timeout`` seconds and raise EmptyPoolError if no + connection is available within the time period. + + :param release_conn: + If False, then the urlopen call will not release the connection + back into the pool once a response is received (but will release if + you read the entire contents of the response such as when + `preload_content=True`). This is useful if you're not preloading + the response's content immediately. You will need to call + ``r.release_conn()`` on the response ``r`` to return the connection + back into the pool. If None, it takes the value of + ``response_kw.get('preload_content', True)``. + + :param chunked: + If True, urllib3 will send the body using chunked transfer + encoding. Otherwise, urllib3 will send the body using the standard + content-length form. Defaults to False. + + :param int body_pos: + Position to seek to in file-like body in the event of a retry or + redirect. Typically this won't need to be set because urllib3 will + auto-populate the value when needed. + + :param \\**response_kw: + Additional parameters are passed to + :meth:`urllib3.response.HTTPResponse.from_httplib` + """ + + parsed_url = parse_url(url) + destination_scheme = parsed_url.scheme + + if headers is None: + headers = self.headers + + if not isinstance(retries, Retry): + retries = Retry.from_int(retries, redirect=redirect, default=self.retries) + + if release_conn is None: + release_conn = response_kw.get("preload_content", True) + + # Check host + if assert_same_host and not self.is_same_host(url): + raise HostChangedError(self, url, retries) + + # Ensure that the URL we're connecting to is properly encoded + if url.startswith("/"): + url = six.ensure_str(_encode_target(url)) + else: + url = six.ensure_str(parsed_url.url) + + conn = None + + # Track whether `conn` needs to be released before + # returning/raising/recursing. Update this variable if necessary, and + # leave `release_conn` constant throughout the function. That way, if + # the function recurses, the original value of `release_conn` will be + # passed down into the recursive call, and its value will be respected. + # + # See issue #651 [1] for details. + # + # [1] + release_this_conn = release_conn + + http_tunnel_required = connection_requires_http_tunnel( + self.proxy, self.proxy_config, destination_scheme + ) + + # Merge the proxy headers. Only done when not using HTTP CONNECT. We + # have to copy the headers dict so we can safely change it without those + # changes being reflected in anyone else's copy. + if not http_tunnel_required: + headers = headers.copy() + headers.update(self.proxy_headers) + + # Must keep the exception bound to a separate variable or else Python 3 + # complains about UnboundLocalError. + err = None + + # Keep track of whether we cleanly exited the except block. This + # ensures we do proper cleanup in finally. + clean_exit = False + + # Rewind body position, if needed. Record current position + # for future rewinds in the event of a redirect/retry. + body_pos = set_file_position(body, body_pos) + + try: + # Request a connection from the queue. + timeout_obj = self._get_timeout(timeout) + conn = self._get_conn(timeout=pool_timeout) + + conn.timeout = timeout_obj.connect_timeout + + is_new_proxy_conn = self.proxy is not None and not getattr( + conn, "sock", None + ) + if is_new_proxy_conn and http_tunnel_required: + self._prepare_proxy(conn) + + # Make the request on the httplib connection object. + httplib_response = self._make_request( + conn, + method, + url, + timeout=timeout_obj, + body=body, + headers=headers, + chunked=chunked, + ) + + # If we're going to release the connection in ``finally:``, then + # the response doesn't need to know about the connection. Otherwise + # it will also try to release it and we'll have a double-release + # mess. + response_conn = conn if not release_conn else None + + # Pass method to Response for length checking + response_kw["request_method"] = method + + # Import httplib's response into our own wrapper object + response = self.ResponseCls.from_httplib( + httplib_response, + pool=self, + connection=response_conn, + retries=retries, + **response_kw + ) + + # Everything went great! + clean_exit = True + + except EmptyPoolError: + # Didn't get a connection from the pool, no need to clean up + clean_exit = True + release_this_conn = False + raise + + except ( + TimeoutError, + HTTPException, + SocketError, + ProtocolError, + BaseSSLError, + SSLError, + CertificateError, + ) as e: + # Discard the connection for these exceptions. It will be + # replaced during the next _get_conn() call. + clean_exit = False + if isinstance(e, (BaseSSLError, CertificateError)): + e = SSLError(e) + elif isinstance(e, (SocketError, NewConnectionError)) and self.proxy: + e = ProxyError("Cannot connect to proxy.", e) + elif isinstance(e, (SocketError, HTTPException)): + e = ProtocolError("Connection aborted.", e) + + retries = retries.increment( + method, url, error=e, _pool=self, _stacktrace=sys.exc_info()[2] + ) + retries.sleep() + + # Keep track of the error for the retry warning. + err = e + + finally: + if not clean_exit: + # We hit some kind of exception, handled or otherwise. We need + # to throw the connection away unless explicitly told not to. + # Close the connection, set the variable to None, and make sure + # we put the None back in the pool to avoid leaking it. + conn = conn and conn.close() + release_this_conn = True + + if release_this_conn: + # Put the connection back to be reused. If the connection is + # expired then it will be None, which will get replaced with a + # fresh connection during _get_conn. + self._put_conn(conn) + + if not conn: + # Try again + log.warning( + "Retrying (%r) after connection broken by '%r': %s", retries, err, url + ) + return self.urlopen( + method, + url, + body, + headers, + retries, + redirect, + assert_same_host, + timeout=timeout, + pool_timeout=pool_timeout, + release_conn=release_conn, + chunked=chunked, + body_pos=body_pos, + **response_kw + ) + + # Handle redirect? + redirect_location = redirect and response.get_redirect_location() + if redirect_location: + if response.status == 303: + method = "GET" + + try: + retries = retries.increment(method, url, response=response, _pool=self) + except MaxRetryError: + if retries.raise_on_redirect: + response.drain_conn() + raise + return response + + response.drain_conn() + retries.sleep_for_retry(response) + log.debug("Redirecting %s -> %s", url, redirect_location) + return self.urlopen( + method, + redirect_location, + body, + headers, + retries=retries, + redirect=redirect, + assert_same_host=assert_same_host, + timeout=timeout, + pool_timeout=pool_timeout, + release_conn=release_conn, + chunked=chunked, + body_pos=body_pos, + **response_kw + ) + + # Check if we should retry the HTTP response. + has_retry_after = bool(response.getheader("Retry-After")) + if retries.is_retry(method, response.status, has_retry_after): + try: + retries = retries.increment(method, url, response=response, _pool=self) + except MaxRetryError: + if retries.raise_on_status: + response.drain_conn() + raise + return response + + response.drain_conn() + retries.sleep(response) + log.debug("Retry: %s", url) + return self.urlopen( + method, + url, + body, + headers, + retries=retries, + redirect=redirect, + assert_same_host=assert_same_host, + timeout=timeout, + pool_timeout=pool_timeout, + release_conn=release_conn, + chunked=chunked, + body_pos=body_pos, + **response_kw + ) + + return response + + +class HTTPSConnectionPool(HTTPConnectionPool): + """ + Same as :class:`.HTTPConnectionPool`, but HTTPS. + + :class:`.HTTPSConnection` uses one of ``assert_fingerprint``, + ``assert_hostname`` and ``host`` in this order to verify connections. + If ``assert_hostname`` is False, no verification is done. + + The ``key_file``, ``cert_file``, ``cert_reqs``, ``ca_certs``, + ``ca_cert_dir``, ``ssl_version``, ``key_password`` are only used if :mod:`ssl` + is available and are fed into :meth:`urllib3.util.ssl_wrap_socket` to upgrade + the connection socket into an SSL socket. + """ + + scheme = "https" + ConnectionCls = HTTPSConnection + + def __init__( + self, + host, + port=None, + strict=False, + timeout=Timeout.DEFAULT_TIMEOUT, + maxsize=1, + block=False, + headers=None, + retries=None, + _proxy=None, + _proxy_headers=None, + key_file=None, + cert_file=None, + cert_reqs=None, + key_password=None, + ca_certs=None, + ssl_version=None, + assert_hostname=None, + assert_fingerprint=None, + ca_cert_dir=None, + **conn_kw + ): + + HTTPConnectionPool.__init__( + self, + host, + port, + strict, + timeout, + maxsize, + block, + headers, + retries, + _proxy, + _proxy_headers, + **conn_kw + ) + + self.key_file = key_file + self.cert_file = cert_file + self.cert_reqs = cert_reqs + self.key_password = key_password + self.ca_certs = ca_certs + self.ca_cert_dir = ca_cert_dir + self.ssl_version = ssl_version + self.assert_hostname = assert_hostname + self.assert_fingerprint = assert_fingerprint + + def _prepare_conn(self, conn): + """ + Prepare the ``connection`` for :meth:`urllib3.util.ssl_wrap_socket` + and establish the tunnel if proxy is used. + """ + + if isinstance(conn, VerifiedHTTPSConnection): + conn.set_cert( + key_file=self.key_file, + key_password=self.key_password, + cert_file=self.cert_file, + cert_reqs=self.cert_reqs, + ca_certs=self.ca_certs, + ca_cert_dir=self.ca_cert_dir, + assert_hostname=self.assert_hostname, + assert_fingerprint=self.assert_fingerprint, + ) + conn.ssl_version = self.ssl_version + return conn + + def _prepare_proxy(self, conn): + """ + Establishes a tunnel connection through HTTP CONNECT. + + Tunnel connection is established early because otherwise httplib would + improperly set Host: header to proxy's IP:port. + """ + + conn.set_tunnel(self._proxy_host, self.port, self.proxy_headers) + + if self.proxy.scheme == "https": + conn.tls_in_tls_required = True + + conn.connect() + + def _new_conn(self): + """ + Return a fresh :class:`http.client.HTTPSConnection`. + """ + self.num_connections += 1 + log.debug( + "Starting new HTTPS connection (%d): %s:%s", + self.num_connections, + self.host, + self.port or "443", + ) + + if not self.ConnectionCls or self.ConnectionCls is DummyConnection: + raise SSLError( + "Can't connect to HTTPS URL because the SSL module is not available." + ) + + actual_host = self.host + actual_port = self.port + if self.proxy is not None: + actual_host = self.proxy.host + actual_port = self.proxy.port + + conn = self.ConnectionCls( + host=actual_host, + port=actual_port, + timeout=self.timeout.connect_timeout, + strict=self.strict, + cert_file=self.cert_file, + key_file=self.key_file, + key_password=self.key_password, + **self.conn_kw + ) + + return self._prepare_conn(conn) + + def _validate_conn(self, conn): + """ + Called right before a request is made, after the socket is created. + """ + super(HTTPSConnectionPool, self)._validate_conn(conn) + + # Force connect early to allow us to validate the connection. + if not getattr(conn, "sock", None): # AppEngine might not have `.sock` + conn.connect() + + if not conn.is_verified: + warnings.warn( + ( + "Unverified HTTPS request is being made to host '%s'. " + "Adding certificate verification is strongly advised. See: " + "https://urllib3.readthedocs.io/en/1.26.x/advanced-usage.html" + "#ssl-warnings" % conn.host + ), + InsecureRequestWarning, + ) + + +def connection_from_url(url, **kw): + """ + Given a url, return an :class:`.ConnectionPool` instance of its host. + + This is a shortcut for not having to parse out the scheme, host, and port + of the url before creating an :class:`.ConnectionPool` instance. + + :param url: + Absolute URL string that must include the scheme. Port is optional. + + :param \\**kw: + Passes additional parameters to the constructor of the appropriate + :class:`.ConnectionPool`. Useful for specifying things like + timeout, maxsize, headers, etc. + + Example:: + + >>> conn = connection_from_url('http://google.com/') + >>> r = conn.request('GET', '/') + """ + scheme, host, port = get_host(url) + port = port or port_by_scheme.get(scheme, 80) + if scheme == "https": + return HTTPSConnectionPool(host, port=port, **kw) + else: + return HTTPConnectionPool(host, port=port, **kw) + + +def _normalize_host(host, scheme): + """ + Normalize hosts for comparisons and use with sockets. + """ + + host = normalize_host(host, scheme) + + # httplib doesn't like it when we include brackets in IPv6 addresses + # Specifically, if we include brackets but also pass the port then + # httplib crazily doubles up the square brackets on the Host header. + # Instead, we need to make sure we never pass ``None`` as the port. + # However, for backward compatibility reasons we can't actually + # *assert* that. See http://bugs.python.org/issue28539 + if host.startswith("[") and host.endswith("]"): + host = host[1:-1] + return host diff --git a/venv/lib/python3.8/site-packages/urllib3/contrib/__init__.py b/venv/lib/python3.8/site-packages/urllib3/contrib/__init__.py new file mode 100644 index 0000000..e69de29 diff --git a/venv/lib/python3.8/site-packages/urllib3/contrib/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/urllib3/contrib/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..608fb1a665455acfe66f8136d1864b2cef785d68 GIT binary patch literal 151 zcmWIL<>g`kf(lF3L=gQLL?8o3AjbiSi&=m~3PUi1CZpdQUs{xtlbK|!pPZjpQk0pbA0MBYmst`YuUAlc Ui^C>2KczG$)edCpXCP((0OX4z{Qv*} literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/urllib3/contrib/__pycache__/_appengine_environ.cpython-38.pyc b/venv/lib/python3.8/site-packages/urllib3/contrib/__pycache__/_appengine_environ.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..4164d6578253ba1d97d15eba8e477be4c8480ef6 GIT binary patch literal 1375 zcmb_cL2nc{6!v&FyTc?YO@xq;5VEK$6p8Fe?V$u!6#+Jg0}I*&D&;boo#*U0J8N6E zXGwB}9|A{y1b<|%J@qg2PRTgz#Xw8G$b_2g51i1S2iI@)lJeYs>GB?wi7J9pp zx+td{w%=Bq*V`xKsXN)((OF~aT8w|qN+q2UWJg>p<17rVPgc(rh`Rhs8JO!-*NHQW(xqj!FvTtv+SeiMsZ#i*J7JvvK2? zaKW3`wJ9rBbBjQ@MM_F1=KMah>cYSGa;h3;E7jB>?>Qzp2QPeC@p8(JltFL(;LdW+ zD(AF)m}O~VIcd4J$Pt0c3-_344*w84)W3K;lcA4 zgErBpu2S-s-?rkwe@m5Zdlzb5iGRLZK?&L$i}K|c1o|R7m$7G7ala&^FQXvi9o#_V z$Z<67s@s13K!HO1k$%9|`52*~D?`)6SMBxv!RXCkl<&XXJNR>VG-%1$+EYH~wbH)y zvrip!4c{5xs%<>su1zsevBxgUpkcj8*cs&(8e=i*3q18 zJ`4IRG;U^o@VA#Ob;YWQ@!~elWn}(l3E5?Ldtcy5qi3s6xi-8k9Ebki_d!C;px@1< zF3)H4nZ4_Sheo7k1NU3KwwLEvO?iIKvhU8IZQv>Z4iCSN6oMqbpZ}%(;em#nI-Mj= KI!T&zlkQh22uHO5 literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/urllib3/contrib/__pycache__/appengine.cpython-38.pyc b/venv/lib/python3.8/site-packages/urllib3/contrib/__pycache__/appengine.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..99e8b78238fbf741ef8562f42af788f5b902f1f8 GIT binary patch literal 8200 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 OhVL(>HB>6Z_kRI`S|Sbr literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/urllib3/contrib/__pycache__/ntlmpool.cpython-38.pyc b/venv/lib/python3.8/site-packages/urllib3/contrib/__pycache__/ntlmpool.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..44e528b9803053242fd09618db5aa7e49914ad2c GIT binary patch literal 3594 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 literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/urllib3/contrib/__pycache__/socks.cpython-38.pyc b/venv/lib/python3.8/site-packages/urllib3/contrib/__pycache__/socks.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..df514ff7e17dae35555eff2cb5b700f73704d7aa GIT binary patch literal 5589 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 literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/urllib3/contrib/_appengine_environ.py b/venv/lib/python3.8/site-packages/urllib3/contrib/_appengine_environ.py new file mode 100644 index 0000000..8765b90 --- /dev/null +++ b/venv/lib/python3.8/site-packages/urllib3/contrib/_appengine_environ.py @@ -0,0 +1,36 @@ +""" +This module provides means to detect the App Engine environment. +""" + +import os + + +def is_appengine(): + return is_local_appengine() or is_prod_appengine() + + +def is_appengine_sandbox(): + """Reports if the app is running in the first generation sandbox. + + The second generation runtimes are technically still in a sandbox, but it + is much less restrictive, so generally you shouldn't need to check for it. + see https://cloud.google.com/appengine/docs/standard/runtimes + """ + return is_appengine() and os.environ["APPENGINE_RUNTIME"] == "python27" + + +def is_local_appengine(): + return "APPENGINE_RUNTIME" in os.environ and os.environ.get( + "SERVER_SOFTWARE", "" + ).startswith("Development/") + + +def is_prod_appengine(): + return "APPENGINE_RUNTIME" in os.environ and os.environ.get( + "SERVER_SOFTWARE", "" + ).startswith("Google App Engine/") + + +def is_prod_appengine_mvms(): + """Deprecated.""" + return False diff --git a/venv/lib/python3.8/site-packages/urllib3/contrib/_securetransport/__init__.py b/venv/lib/python3.8/site-packages/urllib3/contrib/_securetransport/__init__.py new file mode 100644 index 0000000..e69de29 diff --git a/venv/lib/python3.8/site-packages/urllib3/contrib/_securetransport/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/urllib3/contrib/_securetransport/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..420ef327274053181ece9475a37fd7c160ea4175 GIT binary patch literal 168 zcmWIL<>g`kf(lF3L=gQLL?8o3AjbiSi&=m~3PUi1CZpdQUs{xtlbK|!pPZjpQk0pbA77lBTw0V`Qk0li lT##Q>q8}fhnU`4-AFo$Xd5gm)H$SB`C)EyQ&1WEH006aEDi8nw literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/urllib3/contrib/_securetransport/__pycache__/bindings.cpython-38.pyc b/venv/lib/python3.8/site-packages/urllib3/contrib/_securetransport/__pycache__/bindings.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..5b77b875839981c0f977abc3511e54a1a5eefa90 GIT binary patch literal 10689 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 QKPcm#q$z0M*U{hoe+0Rd2LJ#7 literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/urllib3/contrib/_securetransport/__pycache__/low_level.cpython-38.pyc b/venv/lib/python3.8/site-packages/urllib3/contrib/_securetransport/__pycache__/low_level.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..7f08e1276fbd32c4b638892c0f08840074a835dc GIT binary patch literal 9056 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àOJ2V_z$$92v)v(AgoIrp@)=+N(5&aXPxM_%+l?b`nU DV&P^- literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/urllib3/contrib/_securetransport/bindings.py b/venv/lib/python3.8/site-packages/urllib3/contrib/_securetransport/bindings.py new file mode 100644 index 0000000..11524d4 --- /dev/null +++ b/venv/lib/python3.8/site-packages/urllib3/contrib/_securetransport/bindings.py @@ -0,0 +1,519 @@ +""" +This module uses ctypes to bind a whole bunch of functions and constants from +SecureTransport. The goal here is to provide the low-level API to +SecureTransport. These are essentially the C-level functions and constants, and +they're pretty gross to work with. + +This code is a bastardised version of the code found in Will Bond's oscrypto +library. An enormous debt is owed to him for blazing this trail for us. For +that reason, this code should be considered to be covered both by urllib3's +license and by oscrypto's: + + Copyright (c) 2015-2016 Will Bond + + 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 absolute_import + +import platform +from ctypes import ( + CDLL, + CFUNCTYPE, + POINTER, + c_bool, + c_byte, + c_char_p, + c_int32, + c_long, + c_size_t, + c_uint32, + c_ulong, + c_void_p, +) +from ctypes.util import find_library + +from urllib3.packages.six import raise_from + +if platform.system() != "Darwin": + raise ImportError("Only macOS is supported") + +version = platform.mac_ver()[0] +version_info = tuple(map(int, version.split("."))) +if version_info < (10, 8): + raise OSError( + "Only OS X 10.8 and newer are supported, not %s.%s" + % (version_info[0], version_info[1]) + ) + + +def load_cdll(name, macos10_16_path): + """Loads a CDLL by name, falling back to known path on 10.16+""" + try: + # Big Sur is technically 11 but we use 10.16 due to the Big Sur + # beta being labeled as 10.16. + if version_info >= (10, 16): + path = macos10_16_path + else: + path = find_library(name) + if not path: + raise OSError # Caught and reraised as 'ImportError' + return CDLL(path, use_errno=True) + except OSError: + raise_from(ImportError("The library %s failed to load" % name), None) + + +Security = load_cdll( + "Security", "/System/Library/Frameworks/Security.framework/Security" +) +CoreFoundation = load_cdll( + "CoreFoundation", + "/System/Library/Frameworks/CoreFoundation.framework/CoreFoundation", +) + + +Boolean = c_bool +CFIndex = c_long +CFStringEncoding = c_uint32 +CFData = c_void_p +CFString = c_void_p +CFArray = c_void_p +CFMutableArray = c_void_p +CFDictionary = c_void_p +CFError = c_void_p +CFType = c_void_p +CFTypeID = c_ulong + +CFTypeRef = POINTER(CFType) +CFAllocatorRef = c_void_p + +OSStatus = c_int32 + +CFDataRef = POINTER(CFData) +CFStringRef = POINTER(CFString) +CFArrayRef = POINTER(CFArray) +CFMutableArrayRef = POINTER(CFMutableArray) +CFDictionaryRef = POINTER(CFDictionary) +CFArrayCallBacks = c_void_p +CFDictionaryKeyCallBacks = c_void_p +CFDictionaryValueCallBacks = c_void_p + +SecCertificateRef = POINTER(c_void_p) +SecExternalFormat = c_uint32 +SecExternalItemType = c_uint32 +SecIdentityRef = POINTER(c_void_p) +SecItemImportExportFlags = c_uint32 +SecItemImportExportKeyParameters = c_void_p +SecKeychainRef = POINTER(c_void_p) +SSLProtocol = c_uint32 +SSLCipherSuite = c_uint32 +SSLContextRef = POINTER(c_void_p) +SecTrustRef = POINTER(c_void_p) +SSLConnectionRef = c_uint32 +SecTrustResultType = c_uint32 +SecTrustOptionFlags = c_uint32 +SSLProtocolSide = c_uint32 +SSLConnectionType = c_uint32 +SSLSessionOption = c_uint32 + + +try: + Security.SecItemImport.argtypes = [ + CFDataRef, + CFStringRef, + POINTER(SecExternalFormat), + POINTER(SecExternalItemType), + SecItemImportExportFlags, + POINTER(SecItemImportExportKeyParameters), + SecKeychainRef, + POINTER(CFArrayRef), + ] + Security.SecItemImport.restype = OSStatus + + Security.SecCertificateGetTypeID.argtypes = [] + Security.SecCertificateGetTypeID.restype = CFTypeID + + Security.SecIdentityGetTypeID.argtypes = [] + Security.SecIdentityGetTypeID.restype = CFTypeID + + Security.SecKeyGetTypeID.argtypes = [] + Security.SecKeyGetTypeID.restype = CFTypeID + + Security.SecCertificateCreateWithData.argtypes = [CFAllocatorRef, CFDataRef] + Security.SecCertificateCreateWithData.restype = SecCertificateRef + + Security.SecCertificateCopyData.argtypes = [SecCertificateRef] + Security.SecCertificateCopyData.restype = CFDataRef + + Security.SecCopyErrorMessageString.argtypes = [OSStatus, c_void_p] + Security.SecCopyErrorMessageString.restype = CFStringRef + + Security.SecIdentityCreateWithCertificate.argtypes = [ + CFTypeRef, + SecCertificateRef, + POINTER(SecIdentityRef), + ] + Security.SecIdentityCreateWithCertificate.restype = OSStatus + + Security.SecKeychainCreate.argtypes = [ + c_char_p, + c_uint32, + c_void_p, + Boolean, + c_void_p, + POINTER(SecKeychainRef), + ] + Security.SecKeychainCreate.restype = OSStatus + + Security.SecKeychainDelete.argtypes = [SecKeychainRef] + Security.SecKeychainDelete.restype = OSStatus + + Security.SecPKCS12Import.argtypes = [ + CFDataRef, + CFDictionaryRef, + POINTER(CFArrayRef), + ] + Security.SecPKCS12Import.restype = OSStatus + + SSLReadFunc = CFUNCTYPE(OSStatus, SSLConnectionRef, c_void_p, POINTER(c_size_t)) + SSLWriteFunc = CFUNCTYPE( + OSStatus, SSLConnectionRef, POINTER(c_byte), POINTER(c_size_t) + ) + + Security.SSLSetIOFuncs.argtypes = [SSLContextRef, SSLReadFunc, SSLWriteFunc] + Security.SSLSetIOFuncs.restype = OSStatus + + Security.SSLSetPeerID.argtypes = [SSLContextRef, c_char_p, c_size_t] + Security.SSLSetPeerID.restype = OSStatus + + Security.SSLSetCertificate.argtypes = [SSLContextRef, CFArrayRef] + Security.SSLSetCertificate.restype = OSStatus + + Security.SSLSetCertificateAuthorities.argtypes = [SSLContextRef, CFTypeRef, Boolean] + Security.SSLSetCertificateAuthorities.restype = OSStatus + + Security.SSLSetConnection.argtypes = [SSLContextRef, SSLConnectionRef] + Security.SSLSetConnection.restype = OSStatus + + Security.SSLSetPeerDomainName.argtypes = [SSLContextRef, c_char_p, c_size_t] + Security.SSLSetPeerDomainName.restype = OSStatus + + Security.SSLHandshake.argtypes = [SSLContextRef] + Security.SSLHandshake.restype = OSStatus + + Security.SSLRead.argtypes = [SSLContextRef, c_char_p, c_size_t, POINTER(c_size_t)] + Security.SSLRead.restype = OSStatus + + Security.SSLWrite.argtypes = [SSLContextRef, c_char_p, c_size_t, POINTER(c_size_t)] + Security.SSLWrite.restype = OSStatus + + Security.SSLClose.argtypes = [SSLContextRef] + Security.SSLClose.restype = OSStatus + + Security.SSLGetNumberSupportedCiphers.argtypes = [SSLContextRef, POINTER(c_size_t)] + Security.SSLGetNumberSupportedCiphers.restype = OSStatus + + Security.SSLGetSupportedCiphers.argtypes = [ + SSLContextRef, + POINTER(SSLCipherSuite), + POINTER(c_size_t), + ] + Security.SSLGetSupportedCiphers.restype = OSStatus + + Security.SSLSetEnabledCiphers.argtypes = [ + SSLContextRef, + POINTER(SSLCipherSuite), + c_size_t, + ] + Security.SSLSetEnabledCiphers.restype = OSStatus + + Security.SSLGetNumberEnabledCiphers.argtype = [SSLContextRef, POINTER(c_size_t)] + Security.SSLGetNumberEnabledCiphers.restype = OSStatus + + Security.SSLGetEnabledCiphers.argtypes = [ + SSLContextRef, + POINTER(SSLCipherSuite), + POINTER(c_size_t), + ] + Security.SSLGetEnabledCiphers.restype = OSStatus + + Security.SSLGetNegotiatedCipher.argtypes = [SSLContextRef, POINTER(SSLCipherSuite)] + Security.SSLGetNegotiatedCipher.restype = OSStatus + + Security.SSLGetNegotiatedProtocolVersion.argtypes = [ + SSLContextRef, + POINTER(SSLProtocol), + ] + Security.SSLGetNegotiatedProtocolVersion.restype = OSStatus + + Security.SSLCopyPeerTrust.argtypes = [SSLContextRef, POINTER(SecTrustRef)] + Security.SSLCopyPeerTrust.restype = OSStatus + + Security.SecTrustSetAnchorCertificates.argtypes = [SecTrustRef, CFArrayRef] + Security.SecTrustSetAnchorCertificates.restype = OSStatus + + Security.SecTrustSetAnchorCertificatesOnly.argstypes = [SecTrustRef, Boolean] + Security.SecTrustSetAnchorCertificatesOnly.restype = OSStatus + + Security.SecTrustEvaluate.argtypes = [SecTrustRef, POINTER(SecTrustResultType)] + Security.SecTrustEvaluate.restype = OSStatus + + Security.SecTrustGetCertificateCount.argtypes = [SecTrustRef] + Security.SecTrustGetCertificateCount.restype = CFIndex + + Security.SecTrustGetCertificateAtIndex.argtypes = [SecTrustRef, CFIndex] + Security.SecTrustGetCertificateAtIndex.restype = SecCertificateRef + + Security.SSLCreateContext.argtypes = [ + CFAllocatorRef, + SSLProtocolSide, + SSLConnectionType, + ] + Security.SSLCreateContext.restype = SSLContextRef + + Security.SSLSetSessionOption.argtypes = [SSLContextRef, SSLSessionOption, Boolean] + Security.SSLSetSessionOption.restype = OSStatus + + Security.SSLSetProtocolVersionMin.argtypes = [SSLContextRef, SSLProtocol] + Security.SSLSetProtocolVersionMin.restype = OSStatus + + Security.SSLSetProtocolVersionMax.argtypes = [SSLContextRef, SSLProtocol] + Security.SSLSetProtocolVersionMax.restype = OSStatus + + try: + Security.SSLSetALPNProtocols.argtypes = [SSLContextRef, CFArrayRef] + Security.SSLSetALPNProtocols.restype = OSStatus + except AttributeError: + # Supported only in 10.12+ + pass + + Security.SecCopyErrorMessageString.argtypes = [OSStatus, c_void_p] + Security.SecCopyErrorMessageString.restype = CFStringRef + + Security.SSLReadFunc = SSLReadFunc + Security.SSLWriteFunc = SSLWriteFunc + Security.SSLContextRef = SSLContextRef + Security.SSLProtocol = SSLProtocol + Security.SSLCipherSuite = SSLCipherSuite + Security.SecIdentityRef = SecIdentityRef + Security.SecKeychainRef = SecKeychainRef + Security.SecTrustRef = SecTrustRef + Security.SecTrustResultType = SecTrustResultType + Security.SecExternalFormat = SecExternalFormat + Security.OSStatus = OSStatus + + Security.kSecImportExportPassphrase = CFStringRef.in_dll( + Security, "kSecImportExportPassphrase" + ) + Security.kSecImportItemIdentity = CFStringRef.in_dll( + Security, "kSecImportItemIdentity" + ) + + # CoreFoundation time! + CoreFoundation.CFRetain.argtypes = [CFTypeRef] + CoreFoundation.CFRetain.restype = CFTypeRef + + CoreFoundation.CFRelease.argtypes = [CFTypeRef] + CoreFoundation.CFRelease.restype = None + + CoreFoundation.CFGetTypeID.argtypes = [CFTypeRef] + CoreFoundation.CFGetTypeID.restype = CFTypeID + + CoreFoundation.CFStringCreateWithCString.argtypes = [ + CFAllocatorRef, + c_char_p, + CFStringEncoding, + ] + CoreFoundation.CFStringCreateWithCString.restype = CFStringRef + + CoreFoundation.CFStringGetCStringPtr.argtypes = [CFStringRef, CFStringEncoding] + CoreFoundation.CFStringGetCStringPtr.restype = c_char_p + + CoreFoundation.CFStringGetCString.argtypes = [ + CFStringRef, + c_char_p, + CFIndex, + CFStringEncoding, + ] + CoreFoundation.CFStringGetCString.restype = c_bool + + CoreFoundation.CFDataCreate.argtypes = [CFAllocatorRef, c_char_p, CFIndex] + CoreFoundation.CFDataCreate.restype = CFDataRef + + CoreFoundation.CFDataGetLength.argtypes = [CFDataRef] + CoreFoundation.CFDataGetLength.restype = CFIndex + + CoreFoundation.CFDataGetBytePtr.argtypes = [CFDataRef] + CoreFoundation.CFDataGetBytePtr.restype = c_void_p + + CoreFoundation.CFDictionaryCreate.argtypes = [ + CFAllocatorRef, + POINTER(CFTypeRef), + POINTER(CFTypeRef), + CFIndex, + CFDictionaryKeyCallBacks, + CFDictionaryValueCallBacks, + ] + CoreFoundation.CFDictionaryCreate.restype = CFDictionaryRef + + CoreFoundation.CFDictionaryGetValue.argtypes = [CFDictionaryRef, CFTypeRef] + CoreFoundation.CFDictionaryGetValue.restype = CFTypeRef + + CoreFoundation.CFArrayCreate.argtypes = [ + CFAllocatorRef, + POINTER(CFTypeRef), + CFIndex, + CFArrayCallBacks, + ] + CoreFoundation.CFArrayCreate.restype = CFArrayRef + + CoreFoundation.CFArrayCreateMutable.argtypes = [ + CFAllocatorRef, + CFIndex, + CFArrayCallBacks, + ] + CoreFoundation.CFArrayCreateMutable.restype = CFMutableArrayRef + + CoreFoundation.CFArrayAppendValue.argtypes = [CFMutableArrayRef, c_void_p] + CoreFoundation.CFArrayAppendValue.restype = None + + CoreFoundation.CFArrayGetCount.argtypes = [CFArrayRef] + CoreFoundation.CFArrayGetCount.restype = CFIndex + + CoreFoundation.CFArrayGetValueAtIndex.argtypes = [CFArrayRef, CFIndex] + CoreFoundation.CFArrayGetValueAtIndex.restype = c_void_p + + CoreFoundation.kCFAllocatorDefault = CFAllocatorRef.in_dll( + CoreFoundation, "kCFAllocatorDefault" + ) + CoreFoundation.kCFTypeArrayCallBacks = c_void_p.in_dll( + CoreFoundation, "kCFTypeArrayCallBacks" + ) + CoreFoundation.kCFTypeDictionaryKeyCallBacks = c_void_p.in_dll( + CoreFoundation, "kCFTypeDictionaryKeyCallBacks" + ) + CoreFoundation.kCFTypeDictionaryValueCallBacks = c_void_p.in_dll( + CoreFoundation, "kCFTypeDictionaryValueCallBacks" + ) + + CoreFoundation.CFTypeRef = CFTypeRef + CoreFoundation.CFArrayRef = CFArrayRef + CoreFoundation.CFStringRef = CFStringRef + CoreFoundation.CFDictionaryRef = CFDictionaryRef + +except (AttributeError): + raise ImportError("Error initializing ctypes") + + +class CFConst(object): + """ + A class object that acts as essentially a namespace for CoreFoundation + constants. + """ + + kCFStringEncodingUTF8 = CFStringEncoding(0x08000100) + + +class SecurityConst(object): + """ + A class object that acts as essentially a namespace for Security constants. + """ + + kSSLSessionOptionBreakOnServerAuth = 0 + + kSSLProtocol2 = 1 + kSSLProtocol3 = 2 + kTLSProtocol1 = 4 + kTLSProtocol11 = 7 + kTLSProtocol12 = 8 + # SecureTransport does not support TLS 1.3 even if there's a constant for it + kTLSProtocol13 = 10 + kTLSProtocolMaxSupported = 999 + + kSSLClientSide = 1 + kSSLStreamType = 0 + + kSecFormatPEMSequence = 10 + + kSecTrustResultInvalid = 0 + kSecTrustResultProceed = 1 + # This gap is present on purpose: this was kSecTrustResultConfirm, which + # is deprecated. + kSecTrustResultDeny = 3 + kSecTrustResultUnspecified = 4 + kSecTrustResultRecoverableTrustFailure = 5 + kSecTrustResultFatalTrustFailure = 6 + kSecTrustResultOtherError = 7 + + errSSLProtocol = -9800 + errSSLWouldBlock = -9803 + errSSLClosedGraceful = -9805 + errSSLClosedNoNotify = -9816 + errSSLClosedAbort = -9806 + + errSSLXCertChainInvalid = -9807 + errSSLCrypto = -9809 + errSSLInternal = -9810 + errSSLCertExpired = -9814 + errSSLCertNotYetValid = -9815 + errSSLUnknownRootCert = -9812 + errSSLNoRootCert = -9813 + errSSLHostNameMismatch = -9843 + errSSLPeerHandshakeFail = -9824 + errSSLPeerUserCancelled = -9839 + errSSLWeakPeerEphemeralDHKey = -9850 + errSSLServerAuthCompleted = -9841 + errSSLRecordOverflow = -9847 + + errSecVerifyFailed = -67808 + errSecNoTrustSettings = -25263 + errSecItemNotFound = -25300 + errSecInvalidTrustSettings = -25262 + + # Cipher suites. We only pick the ones our default cipher string allows. + # Source: https://developer.apple.com/documentation/security/1550981-ssl_cipher_suite_values + TLS_ECDHE_ECDSA_WITH_AES_256_GCM_SHA384 = 0xC02C + TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384 = 0xC030 + TLS_ECDHE_ECDSA_WITH_AES_128_GCM_SHA256 = 0xC02B + TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256 = 0xC02F + TLS_ECDHE_ECDSA_WITH_CHACHA20_POLY1305_SHA256 = 0xCCA9 + TLS_ECDHE_RSA_WITH_CHACHA20_POLY1305_SHA256 = 0xCCA8 + TLS_DHE_RSA_WITH_AES_256_GCM_SHA384 = 0x009F + TLS_DHE_RSA_WITH_AES_128_GCM_SHA256 = 0x009E + TLS_ECDHE_ECDSA_WITH_AES_256_CBC_SHA384 = 0xC024 + TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384 = 0xC028 + TLS_ECDHE_ECDSA_WITH_AES_256_CBC_SHA = 0xC00A + TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA = 0xC014 + TLS_DHE_RSA_WITH_AES_256_CBC_SHA256 = 0x006B + TLS_DHE_RSA_WITH_AES_256_CBC_SHA = 0x0039 + TLS_ECDHE_ECDSA_WITH_AES_128_CBC_SHA256 = 0xC023 + TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256 = 0xC027 + TLS_ECDHE_ECDSA_WITH_AES_128_CBC_SHA = 0xC009 + TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA = 0xC013 + TLS_DHE_RSA_WITH_AES_128_CBC_SHA256 = 0x0067 + TLS_DHE_RSA_WITH_AES_128_CBC_SHA = 0x0033 + TLS_RSA_WITH_AES_256_GCM_SHA384 = 0x009D + TLS_RSA_WITH_AES_128_GCM_SHA256 = 0x009C + TLS_RSA_WITH_AES_256_CBC_SHA256 = 0x003D + TLS_RSA_WITH_AES_128_CBC_SHA256 = 0x003C + TLS_RSA_WITH_AES_256_CBC_SHA = 0x0035 + TLS_RSA_WITH_AES_128_CBC_SHA = 0x002F + TLS_AES_128_GCM_SHA256 = 0x1301 + TLS_AES_256_GCM_SHA384 = 0x1302 + TLS_AES_128_CCM_8_SHA256 = 0x1305 + TLS_AES_128_CCM_SHA256 = 0x1304 diff --git a/venv/lib/python3.8/site-packages/urllib3/contrib/_securetransport/low_level.py b/venv/lib/python3.8/site-packages/urllib3/contrib/_securetransport/low_level.py new file mode 100644 index 0000000..ed81201 --- /dev/null +++ b/venv/lib/python3.8/site-packages/urllib3/contrib/_securetransport/low_level.py @@ -0,0 +1,396 @@ +""" +Low-level helpers for the SecureTransport bindings. + +These are Python functions that are not directly related to the high-level APIs +but are necessary to get them to work. They include a whole bunch of low-level +CoreFoundation messing about and memory management. The concerns in this module +are almost entirely about trying to avoid memory leaks and providing +appropriate and useful assistance to the higher-level code. +""" +import base64 +import ctypes +import itertools +import os +import re +import ssl +import struct +import tempfile + +from .bindings import CFConst, CoreFoundation, Security + +# This regular expression is used to grab PEM data out of a PEM bundle. +_PEM_CERTS_RE = re.compile( + b"-----BEGIN CERTIFICATE-----\n(.*?)\n-----END CERTIFICATE-----", re.DOTALL +) + + +def _cf_data_from_bytes(bytestring): + """ + Given a bytestring, create a CFData object from it. This CFData object must + be CFReleased by the caller. + """ + return CoreFoundation.CFDataCreate( + CoreFoundation.kCFAllocatorDefault, bytestring, len(bytestring) + ) + + +def _cf_dictionary_from_tuples(tuples): + """ + Given a list of Python tuples, create an associated CFDictionary. + """ + dictionary_size = len(tuples) + + # We need to get the dictionary keys and values out in the same order. + keys = (t[0] for t in tuples) + values = (t[1] for t in tuples) + cf_keys = (CoreFoundation.CFTypeRef * dictionary_size)(*keys) + cf_values = (CoreFoundation.CFTypeRef * dictionary_size)(*values) + + return CoreFoundation.CFDictionaryCreate( + CoreFoundation.kCFAllocatorDefault, + cf_keys, + cf_values, + dictionary_size, + CoreFoundation.kCFTypeDictionaryKeyCallBacks, + CoreFoundation.kCFTypeDictionaryValueCallBacks, + ) + + +def _cfstr(py_bstr): + """ + Given a Python binary data, create a CFString. + The string must be CFReleased by the caller. + """ + c_str = ctypes.c_char_p(py_bstr) + cf_str = CoreFoundation.CFStringCreateWithCString( + CoreFoundation.kCFAllocatorDefault, + c_str, + CFConst.kCFStringEncodingUTF8, + ) + return cf_str + + +def _create_cfstring_array(lst): + """ + Given a list of Python binary data, create an associated CFMutableArray. + The array must be CFReleased by the caller. + + Raises an ssl.SSLError on failure. + """ + cf_arr = None + try: + cf_arr = CoreFoundation.CFArrayCreateMutable( + CoreFoundation.kCFAllocatorDefault, + 0, + ctypes.byref(CoreFoundation.kCFTypeArrayCallBacks), + ) + if not cf_arr: + raise MemoryError("Unable to allocate memory!") + for item in lst: + cf_str = _cfstr(item) + if not cf_str: + raise MemoryError("Unable to allocate memory!") + try: + CoreFoundation.CFArrayAppendValue(cf_arr, cf_str) + finally: + CoreFoundation.CFRelease(cf_str) + except BaseException as e: + if cf_arr: + CoreFoundation.CFRelease(cf_arr) + raise ssl.SSLError("Unable to allocate array: %s" % (e,)) + return cf_arr + + +def _cf_string_to_unicode(value): + """ + Creates a Unicode string from a CFString object. Used entirely for error + reporting. + + Yes, it annoys me quite a lot that this function is this complex. + """ + value_as_void_p = ctypes.cast(value, ctypes.POINTER(ctypes.c_void_p)) + + string = CoreFoundation.CFStringGetCStringPtr( + value_as_void_p, CFConst.kCFStringEncodingUTF8 + ) + if string is None: + buffer = ctypes.create_string_buffer(1024) + result = CoreFoundation.CFStringGetCString( + value_as_void_p, buffer, 1024, CFConst.kCFStringEncodingUTF8 + ) + if not result: + raise OSError("Error copying C string from CFStringRef") + string = buffer.value + if string is not None: + string = string.decode("utf-8") + return string + + +def _assert_no_error(error, exception_class=None): + """ + Checks the return code and throws an exception if there is an error to + report + """ + if error == 0: + return + + cf_error_string = Security.SecCopyErrorMessageString(error, None) + output = _cf_string_to_unicode(cf_error_string) + CoreFoundation.CFRelease(cf_error_string) + + if output is None or output == u"": + output = u"OSStatus %s" % error + + if exception_class is None: + exception_class = ssl.SSLError + + raise exception_class(output) + + +def _cert_array_from_pem(pem_bundle): + """ + Given a bundle of certs in PEM format, turns them into a CFArray of certs + that can be used to validate a cert chain. + """ + # Normalize the PEM bundle's line endings. + pem_bundle = pem_bundle.replace(b"\r\n", b"\n") + + der_certs = [ + base64.b64decode(match.group(1)) for match in _PEM_CERTS_RE.finditer(pem_bundle) + ] + if not der_certs: + raise ssl.SSLError("No root certificates specified") + + cert_array = CoreFoundation.CFArrayCreateMutable( + CoreFoundation.kCFAllocatorDefault, + 0, + ctypes.byref(CoreFoundation.kCFTypeArrayCallBacks), + ) + if not cert_array: + raise ssl.SSLError("Unable to allocate memory!") + + try: + for der_bytes in der_certs: + certdata = _cf_data_from_bytes(der_bytes) + if not certdata: + raise ssl.SSLError("Unable to allocate memory!") + cert = Security.SecCertificateCreateWithData( + CoreFoundation.kCFAllocatorDefault, certdata + ) + CoreFoundation.CFRelease(certdata) + if not cert: + raise ssl.SSLError("Unable to build cert object!") + + CoreFoundation.CFArrayAppendValue(cert_array, cert) + CoreFoundation.CFRelease(cert) + except Exception: + # We need to free the array before the exception bubbles further. + # We only want to do that if an error occurs: otherwise, the caller + # should free. + CoreFoundation.CFRelease(cert_array) + + return cert_array + + +def _is_cert(item): + """ + Returns True if a given CFTypeRef is a certificate. + """ + expected = Security.SecCertificateGetTypeID() + return CoreFoundation.CFGetTypeID(item) == expected + + +def _is_identity(item): + """ + Returns True if a given CFTypeRef is an identity. + """ + expected = Security.SecIdentityGetTypeID() + return CoreFoundation.CFGetTypeID(item) == expected + + +def _temporary_keychain(): + """ + This function creates a temporary Mac keychain that we can use to work with + credentials. This keychain uses a one-time password and a temporary file to + store the data. We expect to have one keychain per socket. The returned + SecKeychainRef must be freed by the caller, including calling + SecKeychainDelete. + + Returns a tuple of the SecKeychainRef and the path to the temporary + directory that contains it. + """ + # Unfortunately, SecKeychainCreate requires a path to a keychain. This + # means we cannot use mkstemp to use a generic temporary file. Instead, + # we're going to create a temporary directory and a filename to use there. + # This filename will be 8 random bytes expanded into base64. We also need + # some random bytes to password-protect the keychain we're creating, so we + # ask for 40 random bytes. + random_bytes = os.urandom(40) + filename = base64.b16encode(random_bytes[:8]).decode("utf-8") + password = base64.b16encode(random_bytes[8:]) # Must be valid UTF-8 + tempdirectory = tempfile.mkdtemp() + + keychain_path = os.path.join(tempdirectory, filename).encode("utf-8") + + # We now want to create the keychain itself. + keychain = Security.SecKeychainRef() + status = Security.SecKeychainCreate( + keychain_path, len(password), password, False, None, ctypes.byref(keychain) + ) + _assert_no_error(status) + + # Having created the keychain, we want to pass it off to the caller. + return keychain, tempdirectory + + +def _load_items_from_file(keychain, path): + """ + Given a single file, loads all the trust objects from it into arrays and + the keychain. + Returns a tuple of lists: the first list is a list of identities, the + second a list of certs. + """ + certificates = [] + identities = [] + result_array = None + + with open(path, "rb") as f: + raw_filedata = f.read() + + try: + filedata = CoreFoundation.CFDataCreate( + CoreFoundation.kCFAllocatorDefault, raw_filedata, len(raw_filedata) + ) + result_array = CoreFoundation.CFArrayRef() + result = Security.SecItemImport( + filedata, # cert data + None, # Filename, leaving it out for now + None, # What the type of the file is, we don't care + None, # what's in the file, we don't care + 0, # import flags + None, # key params, can include passphrase in the future + keychain, # The keychain to insert into + ctypes.byref(result_array), # Results + ) + _assert_no_error(result) + + # A CFArray is not very useful to us as an intermediary + # representation, so we are going to extract the objects we want + # and then free the array. We don't need to keep hold of keys: the + # keychain already has them! + result_count = CoreFoundation.CFArrayGetCount(result_array) + for index in range(result_count): + item = CoreFoundation.CFArrayGetValueAtIndex(result_array, index) + item = ctypes.cast(item, CoreFoundation.CFTypeRef) + + if _is_cert(item): + CoreFoundation.CFRetain(item) + certificates.append(item) + elif _is_identity(item): + CoreFoundation.CFRetain(item) + identities.append(item) + finally: + if result_array: + CoreFoundation.CFRelease(result_array) + + CoreFoundation.CFRelease(filedata) + + return (identities, certificates) + + +def _load_client_cert_chain(keychain, *paths): + """ + Load certificates and maybe keys from a number of files. Has the end goal + of returning a CFArray containing one SecIdentityRef, and then zero or more + SecCertificateRef objects, suitable for use as a client certificate trust + chain. + """ + # Ok, the strategy. + # + # This relies on knowing that macOS will not give you a SecIdentityRef + # unless you have imported a key into a keychain. This is a somewhat + # artificial limitation of macOS (for example, it doesn't necessarily + # affect iOS), but there is nothing inside Security.framework that lets you + # get a SecIdentityRef without having a key in a keychain. + # + # So the policy here is we take all the files and iterate them in order. + # Each one will use SecItemImport to have one or more objects loaded from + # it. We will also point at a keychain that macOS can use to work with the + # private key. + # + # Once we have all the objects, we'll check what we actually have. If we + # already have a SecIdentityRef in hand, fab: we'll use that. Otherwise, + # we'll take the first certificate (which we assume to be our leaf) and + # ask the keychain to give us a SecIdentityRef with that cert's associated + # key. + # + # We'll then return a CFArray containing the trust chain: one + # SecIdentityRef and then zero-or-more SecCertificateRef objects. The + # responsibility for freeing this CFArray will be with the caller. This + # CFArray must remain alive for the entire connection, so in practice it + # will be stored with a single SSLSocket, along with the reference to the + # keychain. + certificates = [] + identities = [] + + # Filter out bad paths. + paths = (path for path in paths if path) + + try: + for file_path in paths: + new_identities, new_certs = _load_items_from_file(keychain, file_path) + identities.extend(new_identities) + certificates.extend(new_certs) + + # Ok, we have everything. The question is: do we have an identity? If + # not, we want to grab one from the first cert we have. + if not identities: + new_identity = Security.SecIdentityRef() + status = Security.SecIdentityCreateWithCertificate( + keychain, certificates[0], ctypes.byref(new_identity) + ) + _assert_no_error(status) + identities.append(new_identity) + + # We now want to release the original certificate, as we no longer + # need it. + CoreFoundation.CFRelease(certificates.pop(0)) + + # We now need to build a new CFArray that holds the trust chain. + trust_chain = CoreFoundation.CFArrayCreateMutable( + CoreFoundation.kCFAllocatorDefault, + 0, + ctypes.byref(CoreFoundation.kCFTypeArrayCallBacks), + ) + for item in itertools.chain(identities, certificates): + # ArrayAppendValue does a CFRetain on the item. That's fine, + # because the finally block will release our other refs to them. + CoreFoundation.CFArrayAppendValue(trust_chain, item) + + return trust_chain + finally: + for obj in itertools.chain(identities, certificates): + CoreFoundation.CFRelease(obj) + + +TLS_PROTOCOL_VERSIONS = { + "SSLv2": (0, 2), + "SSLv3": (3, 0), + "TLSv1": (3, 1), + "TLSv1.1": (3, 2), + "TLSv1.2": (3, 3), +} + + +def _build_tls_unknown_ca_alert(version): + """ + Builds a TLS alert record for an unknown CA. + """ + ver_maj, ver_min = TLS_PROTOCOL_VERSIONS[version] + severity_fatal = 0x02 + description_unknown_ca = 0x30 + msg = struct.pack(">BB", severity_fatal, description_unknown_ca) + msg_len = len(msg) + record_type_alert = 0x15 + record = struct.pack(">BBBH", record_type_alert, ver_maj, ver_min, msg_len) + msg + return record diff --git a/venv/lib/python3.8/site-packages/urllib3/contrib/appengine.py b/venv/lib/python3.8/site-packages/urllib3/contrib/appengine.py new file mode 100644 index 0000000..f91bdd6 --- /dev/null +++ b/venv/lib/python3.8/site-packages/urllib3/contrib/appengine.py @@ -0,0 +1,314 @@ +""" +This module provides a pool manager that uses Google App Engine's +`URLFetch Service `_. + +Example usage:: + + from urllib3 import PoolManager + from urllib3.contrib.appengine import AppEngineManager, is_appengine_sandbox + + if is_appengine_sandbox(): + # AppEngineManager uses AppEngine's URLFetch API behind the scenes + http = AppEngineManager() + else: + # PoolManager uses a socket-level API behind the scenes + http = PoolManager() + + r = http.request('GET', 'https://google.com/') + +There are `limitations `_ to the URLFetch service and it may not be +the best choice for your application. There are three options for using +urllib3 on Google App Engine: + +1. You can use :class:`AppEngineManager` with URLFetch. URLFetch is + cost-effective in many circumstances as long as your usage is within the + limitations. +2. You can use a normal :class:`~urllib3.PoolManager` by enabling sockets. + Sockets also have `limitations and restrictions + `_ and have a lower free quota than URLFetch. + To use sockets, be sure to specify the following in your ``app.yaml``:: + + env_variables: + GAE_USE_SOCKETS_HTTPLIB : 'true' + +3. If you are using `App Engine Flexible +`_, you can use the standard +:class:`PoolManager` without any configuration or special environment variables. +""" + +from __future__ import absolute_import + +import io +import logging +import warnings + +from ..exceptions import ( + HTTPError, + HTTPWarning, + MaxRetryError, + ProtocolError, + SSLError, + TimeoutError, +) +from ..packages.six.moves.urllib.parse import urljoin +from ..request import RequestMethods +from ..response import HTTPResponse +from ..util.retry import Retry +from ..util.timeout import Timeout +from . import _appengine_environ + +try: + from google.appengine.api import urlfetch +except ImportError: + urlfetch = None + + +log = logging.getLogger(__name__) + + +class AppEnginePlatformWarning(HTTPWarning): + pass + + +class AppEnginePlatformError(HTTPError): + pass + + +class AppEngineManager(RequestMethods): + """ + Connection manager for Google App Engine sandbox applications. + + This manager uses the URLFetch service directly instead of using the + emulated httplib, and is subject to URLFetch limitations as described in + the App Engine documentation `here + `_. + + Notably it will raise an :class:`AppEnginePlatformError` if: + * URLFetch is not available. + * If you attempt to use this on App Engine Flexible, as full socket + support is available. + * If a request size is more than 10 megabytes. + * If a response size is more than 32 megabytes. + * If you use an unsupported request method such as OPTIONS. + + Beyond those cases, it will raise normal urllib3 errors. + """ + + def __init__( + self, + headers=None, + retries=None, + validate_certificate=True, + urlfetch_retries=True, + ): + if not urlfetch: + raise AppEnginePlatformError( + "URLFetch is not available in this environment." + ) + + 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/1.26.x/reference/urllib3.contrib.html.", + AppEnginePlatformWarning, + ) + + RequestMethods.__init__(self, headers) + self.validate_certificate = validate_certificate + self.urlfetch_retries = urlfetch_retries + + self.retries = retries or Retry.DEFAULT + + def __enter__(self): + return self + + def __exit__(self, exc_type, exc_val, exc_tb): + # Return False to re-raise any potential exceptions + return False + + def urlopen( + self, + method, + url, + body=None, + headers=None, + retries=None, + redirect=True, + timeout=Timeout.DEFAULT_TIMEOUT, + **response_kw + ): + + retries = self._get_retries(retries, redirect) + + try: + follow_redirects = redirect and retries.redirect != 0 and retries.total + response = urlfetch.fetch( + url, + payload=body, + method=method, + headers=headers or {}, + allow_truncated=False, + follow_redirects=self.urlfetch_retries and follow_redirects, + deadline=self._get_absolute_timeout(timeout), + validate_certificate=self.validate_certificate, + ) + except urlfetch.DeadlineExceededError as e: + raise TimeoutError(self, e) + + except urlfetch.InvalidURLError as e: + if "too large" in str(e): + raise AppEnginePlatformError( + "URLFetch request too large, URLFetch only " + "supports requests up to 10mb in size.", + e, + ) + raise ProtocolError(e) + + except urlfetch.DownloadError as e: + if "Too many redirects" in str(e): + raise MaxRetryError(self, url, reason=e) + raise ProtocolError(e) + + except urlfetch.ResponseTooLargeError as e: + raise AppEnginePlatformError( + "URLFetch response too large, URLFetch only supports" + "responses up to 32mb in size.", + e, + ) + + except urlfetch.SSLCertificateError as e: + raise SSLError(e) + + except urlfetch.InvalidMethodError as e: + raise AppEnginePlatformError( + "URLFetch does not support method: %s" % method, e + ) + + http_response = self._urlfetch_response_to_http_response( + response, retries=retries, **response_kw + ) + + # Handle redirect? + redirect_location = redirect and http_response.get_redirect_location() + if redirect_location: + # Check for redirect response + if self.urlfetch_retries and retries.raise_on_redirect: + raise MaxRetryError(self, url, "too many redirects") + else: + if http_response.status == 303: + method = "GET" + + try: + retries = retries.increment( + method, url, response=http_response, _pool=self + ) + except MaxRetryError: + if retries.raise_on_redirect: + raise MaxRetryError(self, url, "too many redirects") + return http_response + + retries.sleep_for_retry(http_response) + log.debug("Redirecting %s -> %s", url, redirect_location) + redirect_url = urljoin(url, redirect_location) + return self.urlopen( + method, + redirect_url, + body, + headers, + retries=retries, + redirect=redirect, + timeout=timeout, + **response_kw + ) + + # Check if we should retry the HTTP response. + has_retry_after = bool(http_response.getheader("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) + retries.sleep(http_response) + return self.urlopen( + method, + url, + body=body, + headers=headers, + retries=retries, + redirect=redirect, + timeout=timeout, + **response_kw + ) + + return http_response + + def _urlfetch_response_to_http_response(self, urlfetch_resp, **response_kw): + + if is_prod_appengine(): + # Production GAE handles deflate encoding automatically, but does + # not remove the encoding header. + content_encoding = urlfetch_resp.headers.get("content-encoding") + + if content_encoding == "deflate": + del urlfetch_resp.headers["content-encoding"] + + transfer_encoding = urlfetch_resp.headers.get("transfer-encoding") + # We have a full response's content, + # so let's make sure we don't report ourselves as chunked data. + if transfer_encoding == "chunked": + encodings = transfer_encoding.split(",") + encodings.remove("chunked") + urlfetch_resp.headers["transfer-encoding"] = ",".join(encodings) + + original_response = HTTPResponse( + # In order for decoding to work, we must present the content as + # a file-like object. + body=io.BytesIO(urlfetch_resp.content), + msg=urlfetch_resp.header_msg, + headers=urlfetch_resp.headers, + status=urlfetch_resp.status_code, + **response_kw + ) + + return HTTPResponse( + body=io.BytesIO(urlfetch_resp.content), + headers=urlfetch_resp.headers, + status=urlfetch_resp.status_code, + original_response=original_response, + **response_kw + ) + + def _get_absolute_timeout(self, timeout): + if timeout is Timeout.DEFAULT_TIMEOUT: + return None # Defer to URLFetch's default. + if isinstance(timeout, Timeout): + if timeout._read is not None or timeout._connect is not None: + warnings.warn( + "URLFetch does not support granular timeout settings, " + "reverting to total or default URLFetch timeout.", + AppEnginePlatformWarning, + ) + return timeout.total + return timeout + + def _get_retries(self, retries, redirect): + if not isinstance(retries, Retry): + retries = Retry.from_int(retries, redirect=redirect, default=self.retries) + + if retries.connect or retries.read or retries.redirect: + warnings.warn( + "URLFetch only supports total retries and does not " + "recognize connect, read, or redirect retry parameters.", + AppEnginePlatformWarning, + ) + + return retries + + +# Alias methods from _appengine_environ to maintain public API interface. + +is_appengine = _appengine_environ.is_appengine +is_appengine_sandbox = _appengine_environ.is_appengine_sandbox +is_local_appengine = _appengine_environ.is_local_appengine +is_prod_appengine = _appengine_environ.is_prod_appengine +is_prod_appengine_mvms = _appengine_environ.is_prod_appengine_mvms diff --git a/venv/lib/python3.8/site-packages/urllib3/contrib/ntlmpool.py b/venv/lib/python3.8/site-packages/urllib3/contrib/ntlmpool.py new file mode 100644 index 0000000..41a8fd1 --- /dev/null +++ b/venv/lib/python3.8/site-packages/urllib3/contrib/ntlmpool.py @@ -0,0 +1,130 @@ +""" +NTLM authenticating pool, contributed by erikcederstran + +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 + +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__) + + +class NTLMConnectionPool(HTTPSConnectionPool): + """ + Implements an NTLM authentication version of an urllib3 connection pool + """ + + scheme = "https" + + def __init__(self, user, pw, authurl, *args, **kwargs): + """ + authurl is a random URL on the server that is protected by NTLM. + user is the Windows user, probably in the DOMAIN\\username format. + pw is the password for the user. + """ + super(NTLMConnectionPool, self).__init__(*args, **kwargs) + self.authurl = authurl + self.rawuser = user + user_parts = user.split("\\", 1) + self.domain = user_parts[0].upper() + self.user = user_parts[1] + self.pw = pw + + def _new_conn(self): + # Performs the NTLM handshake that secures the connection. The socket + # must be kept open while requests are performed. + self.num_connections += 1 + log.debug( + "Starting NTLM HTTPS connection no. %d: https://%s%s", + self.num_connections, + self.host, + self.authurl, + ) + + headers = {"Connection": "Keep-Alive"} + req_header = "Authorization" + resp_header = "www-authenticate" + + conn = HTTPSConnection(host=self.host, port=self.port) + + # Send negotiation message + headers[req_header] = "NTLM %s" % ntlm.create_NTLM_NEGOTIATE_MESSAGE( + self.rawuser + ) + log.debug("Request headers: %s", headers) + conn.request("GET", self.authurl, None, headers) + res = conn.getresponse() + reshdr = dict(res.getheaders()) + log.debug("Response status: %s %s", res.status, res.reason) + log.debug("Response headers: %s", reshdr) + log.debug("Response data: %s [...]", res.read(100)) + + # Remove the reference to the socket, so that it can not be closed by + # the response object (we want to keep the socket open) + res.fp = None + + # Server should respond with a challenge message + auth_header_values = reshdr[resp_header].split(", ") + auth_header_value = None + for s in auth_header_values: + if s[:5] == "NTLM ": + auth_header_value = s[5:] + if auth_header_value is None: + raise Exception( + "Unexpected %s response header: %s" % (resp_header, reshdr[resp_header]) + ) + + # Send authentication message + ServerChallenge, NegotiateFlags = ntlm.parse_NTLM_CHALLENGE_MESSAGE( + auth_header_value + ) + auth_msg = ntlm.create_NTLM_AUTHENTICATE_MESSAGE( + ServerChallenge, self.user, self.domain, self.pw, NegotiateFlags + ) + headers[req_header] = "NTLM %s" % auth_msg + log.debug("Request headers: %s", headers) + 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 data: %s [...]", res.read()[:100]) + if res.status != 200: + if res.status == 401: + raise Exception("Server rejected request: wrong username or password") + raise Exception("Wrong server response: %s %s" % (res.status, res.reason)) + + res.fp = None + log.debug("Connection established") + return conn + + def urlopen( + self, + method, + url, + body=None, + headers=None, + retries=3, + redirect=True, + assert_same_host=True, + ): + if headers is None: + headers = {} + headers["Connection"] = "Keep-Alive" + return super(NTLMConnectionPool, self).urlopen( + method, url, body, headers, retries, redirect, assert_same_host + ) diff --git a/venv/lib/python3.8/site-packages/urllib3/contrib/pyopenssl.py b/venv/lib/python3.8/site-packages/urllib3/contrib/pyopenssl.py new file mode 100644 index 0000000..def83af --- /dev/null +++ b/venv/lib/python3.8/site-packages/urllib3/contrib/pyopenssl.py @@ -0,0 +1,511 @@ +""" +TLS with SNI_-support for Python 2. Follow these instructions if you would +like to verify TLS certificates in Python 2. Note, the default libraries do +*not* do certificate checking; you need to do additional work to validate +certificates yourself. + +This needs the following packages installed: + +* `pyOpenSSL`_ (tested with 16.0.0) +* `cryptography`_ (minimum 1.3.4, from pyopenssl) +* `idna`_ (minimum 2.0, from cryptography) + +However, pyopenssl depends on cryptography, which depends on idna, so while we +use all three directly here we end up having relatively few packages required. + +You can install them with the following command: + +.. code-block:: bash + + $ python -m pip install pyopenssl cryptography idna + +To activate certificate checking, call +:func:`~urllib3.contrib.pyopenssl.inject_into_urllib3` from your Python code +before you begin making HTTP requests. This can be done in a ``sitecustomize`` +module, or at any other time before your application begins using ``urllib3``, +like this: + +.. code-block:: python + + try: + import urllib3.contrib.pyopenssl + urllib3.contrib.pyopenssl.inject_into_urllib3() + except ImportError: + pass + +Now you can use :mod:`urllib3` as you normally would, and it will support SNI +when the required modules are installed. + +Activating this module also has the positive side effect of disabling SSL/TLS +compression in Python 2 (see `CRIME attack`_). + +.. _sni: https://en.wikipedia.org/wiki/Server_Name_Indication +.. _crime attack: https://en.wikipedia.org/wiki/CRIME_(security_exploit) +.. _pyopenssl: https://www.pyopenssl.org +.. _cryptography: https://cryptography.io +.. _idna: https://github.com/kjd/idna +""" +from __future__ import absolute_import + +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 +except ImportError: + # UnsupportedExtension is gone in cryptography >= 2.1.0 + class UnsupportedExtension(Exception): + pass + + +from io import BytesIO +from socket import error as SocketError +from socket import timeout + +try: # Platform-specific: Python 2 + from socket import _fileobject +except ImportError: # Platform-specific: Python 3 + _fileobject = None + from ..packages.backports.makefile import backport_makefile + +import logging +import ssl +import sys + +from .. import util +from ..packages import six +from ..util.ssl_ import PROTOCOL_TLS_CLIENT + +__all__ = ["inject_into_urllib3", "extract_from_urllib3"] + +# SNI always works. +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, +} + +if hasattr(ssl, "PROTOCOL_SSLv3") and hasattr(OpenSSL.SSL, "SSLv3_METHOD"): + _openssl_versions[ssl.PROTOCOL_SSLv3] = OpenSSL.SSL.SSLv3_METHOD + +if hasattr(ssl, "PROTOCOL_TLSv1_1") and hasattr(OpenSSL.SSL, "TLSv1_1_METHOD"): + _openssl_versions[ssl.PROTOCOL_TLSv1_1] = OpenSSL.SSL.TLSv1_1_METHOD + +if hasattr(ssl, "PROTOCOL_TLSv1_2") and hasattr(OpenSSL.SSL, "TLSv1_2_METHOD"): + _openssl_versions[ssl.PROTOCOL_TLSv1_2] = OpenSSL.SSL.TLSv1_2_METHOD + + +_stdlib_to_openssl_verify = { + ssl.CERT_NONE: OpenSSL.SSL.VERIFY_NONE, + ssl.CERT_OPTIONAL: OpenSSL.SSL.VERIFY_PEER, + ssl.CERT_REQUIRED: OpenSSL.SSL.VERIFY_PEER + + OpenSSL.SSL.VERIFY_FAIL_IF_NO_PEER_CERT, +} +_openssl_to_stdlib_verify = dict((v, k) for k, v in _stdlib_to_openssl_verify.items()) + +# OpenSSL will only write 16K at a time +SSL_WRITE_BLOCKSIZE = 16384 + +orig_util_HAS_SNI = util.HAS_SNI +orig_util_SSLContext = util.ssl_.SSLContext + + +log = logging.getLogger(__name__) + + +def inject_into_urllib3(): + "Monkey-patch urllib3 with PyOpenSSL-backed SSL-support." + + _validate_dependencies_met() + + util.SSLContext = PyOpenSSLContext + util.ssl_.SSLContext = PyOpenSSLContext + util.HAS_SNI = HAS_SNI + util.ssl_.HAS_SNI = HAS_SNI + util.IS_PYOPENSSL = True + util.ssl_.IS_PYOPENSSL = True + + +def extract_from_urllib3(): + "Undo monkey-patching by :func:`inject_into_urllib3`." + + util.SSLContext = orig_util_SSLContext + util.ssl_.SSLContext = orig_util_SSLContext + util.HAS_SNI = orig_util_HAS_SNI + util.ssl_.HAS_SNI = orig_util_HAS_SNI + util.IS_PYOPENSSL = False + util.ssl_.IS_PYOPENSSL = False + + +def _validate_dependencies_met(): + """ + Verifies that PyOpenSSL's package-level dependencies have been met. + Throws `ImportError` if they are not met. + """ + # Method added in `cryptography==1.1`; not available in older versions + from cryptography.x509.extensions import Extensions + + if getattr(Extensions, "get_extension_for_class", None) is None: + raise ImportError( + "'cryptography' module missing required functionality. " + "Try upgrading to v1.3.4 or newer." + ) + + # pyOpenSSL 0.14 and above use cryptography for OpenSSL bindings. The _x509 + # attribute is only present on those versions. + from OpenSSL.crypto import X509 + + x509 = X509() + if getattr(x509, "_x509", None) is None: + raise ImportError( + "'pyOpenSSL' module missing required functionality. " + "Try upgrading to v0.14 or newer." + ) + + +def _dnsname_to_stdlib(name): + """ + Converts a dNSName SubjectAlternativeName field to the form used by the + standard library on the given Python version. + + Cryptography produces a dNSName as a unicode string that was idna-decoded + from ASCII bytes. We need to idna-encode that string to get it back, and + then on Python 3 we also need to convert to unicode via UTF-8 (the stdlib + uses PyUnicode_FromStringAndSize on it, which decodes via UTF-8). + + If the name cannot be idna-encoded then we return None signalling that + the name given should be skipped. + """ + + def idna_encode(name): + """ + Borrowed wholesale from the Python Cryptography Project. It turns out + that we can't just safely call `idna.encode`: it can explode for + wildcard names. This avoids that problem. + """ + import idna + + try: + for prefix in [u"*.", u"."]: + if name.startswith(prefix): + name = name[len(prefix) :] + return prefix.encode("ascii") + idna.encode(name) + return idna.encode(name) + except idna.core.IDNAError: + return None + + # Don't send IPv6 addresses through the IDNA encoder. + if ":" in name: + return name + + name = idna_encode(name) + if name is None: + return None + elif sys.version_info >= (3, 0): + name = name.decode("utf-8") + return name + + +def get_subj_alt_name(peer_cert): + """ + Given an PyOpenSSL certificate, provides all the subject alternative names. + """ + # Pass the cert to cryptography, which has much better APIs for this. + 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) + + # We want to find the SAN extension. Ask Cryptography to locate it (it's + # faster than looping in Python) + try: + ext = cert.extensions.get_extension_for_class(x509.SubjectAlternativeName).value + except x509.ExtensionNotFound: + # No such extension, return the empty list. + return [] + except ( + x509.DuplicateExtension, + UnsupportedExtension, + x509.UnsupportedGeneralNameType, + UnicodeError, + ) as e: + # A problem has been found with the quality of the certificate. Assume + # no SAN field is present. + log.warning( + "A problem was encountered with the certificate that prevented " + "urllib3 from finding the SubjectAlternativeName field. This can " + "affect certificate validation. The error was %s", + e, + ) + return [] + + # We want to return dNSName and iPAddress fields. We need to cast the IPs + # back to strings because the match_hostname function wants them as + # strings. + # Sadly the DNS names need to be idna encoded and then, on Python 3, UTF-8 + # decoded. This is pretty frustrating, but that's what the standard library + # does with certificates, and so we need to attempt to do the same. + # We also want to skip over names which cannot be idna encoded. + names = [ + ("DNS", name) + for name in map(_dnsname_to_stdlib, ext.get_values_for_type(x509.DNSName)) + if name is not None + ] + names.extend( + ("IP Address", str(name)) for name in ext.get_values_for_type(x509.IPAddress) + ) + + return names + + +class WrappedSocket(object): + """API-compatibility wrapper for Python OpenSSL's Connection-class. + + Note: _makefile_refs, _drop() and _reuse() are needed for the garbage + collector of pypy. + """ + + def __init__(self, connection, socket, suppress_ragged_eofs=True): + self.connection = connection + self.socket = socket + self.suppress_ragged_eofs = suppress_ragged_eofs + self._makefile_refs = 0 + self._closed = False + + def fileno(self): + return self.socket.fileno() + + # Copy-pasted from Python 3.5 source code + def _decref_socketios(self): + if self._makefile_refs > 0: + self._makefile_refs -= 1 + if self._closed: + self.close() + + def recv(self, *args, **kwargs): + try: + data = self.connection.recv(*args, **kwargs) + except OpenSSL.SSL.SysCallError as e: + if self.suppress_ragged_eofs and e.args == (-1, "Unexpected EOF"): + return b"" + else: + raise SocketError(str(e)) + except OpenSSL.SSL.ZeroReturnError: + if self.connection.get_shutdown() == OpenSSL.SSL.RECEIVED_SHUTDOWN: + return b"" + else: + raise + except OpenSSL.SSL.WantReadError: + if not util.wait_for_read(self.socket, self.socket.gettimeout()): + raise timeout("The read operation timed out") + else: + return self.recv(*args, **kwargs) + + # TLS 1.3 post-handshake authentication + except OpenSSL.SSL.Error as e: + raise ssl.SSLError("read error: %r" % e) + else: + return data + + def recv_into(self, *args, **kwargs): + try: + return self.connection.recv_into(*args, **kwargs) + except OpenSSL.SSL.SysCallError as e: + if self.suppress_ragged_eofs and e.args == (-1, "Unexpected EOF"): + return 0 + else: + raise SocketError(str(e)) + except OpenSSL.SSL.ZeroReturnError: + if self.connection.get_shutdown() == OpenSSL.SSL.RECEIVED_SHUTDOWN: + return 0 + else: + raise + except OpenSSL.SSL.WantReadError: + if not util.wait_for_read(self.socket, self.socket.gettimeout()): + raise timeout("The read operation timed out") + else: + return self.recv_into(*args, **kwargs) + + # TLS 1.3 post-handshake authentication + except OpenSSL.SSL.Error as e: + raise ssl.SSLError("read error: %r" % e) + + def settimeout(self, timeout): + return self.socket.settimeout(timeout) + + def _send_until_done(self, data): + while True: + try: + return self.connection.send(data) + except OpenSSL.SSL.WantWriteError: + if not util.wait_for_write(self.socket, self.socket.gettimeout()): + raise timeout() + continue + except OpenSSL.SSL.SysCallError as e: + raise SocketError(str(e)) + + def sendall(self, data): + total_sent = 0 + while total_sent < len(data): + sent = self._send_until_done( + data[total_sent : total_sent + SSL_WRITE_BLOCKSIZE] + ) + total_sent += sent + + def shutdown(self): + # FIXME rethrow compatible exceptions should we ever use this + self.connection.shutdown() + + def close(self): + if self._makefile_refs < 1: + try: + self._closed = True + return self.connection.close() + except OpenSSL.SSL.Error: + return + else: + self._makefile_refs -= 1 + + def getpeercert(self, binary_form=False): + x509 = self.connection.get_peer_certificate() + + if not x509: + return x509 + + if binary_form: + return OpenSSL.crypto.dump_certificate(OpenSSL.crypto.FILETYPE_ASN1, x509) + + return { + "subject": ((("commonName", x509.get_subject().CN),),), + "subjectAltName": get_subj_alt_name(x509), + } + + def version(self): + return self.connection.get_protocol_version_name() + + def _reuse(self): + self._makefile_refs += 1 + + def _drop(self): + if self._makefile_refs < 1: + self.close() + else: + self._makefile_refs -= 1 + + +if _fileobject: # Platform-specific: Python 2 + + def makefile(self, mode, bufsize=-1): + self._makefile_refs += 1 + return _fileobject(self, mode, bufsize, close=True) + + +else: # Platform-specific: Python 3 + makefile = backport_makefile + +WrappedSocket.makefile = makefile + + +class PyOpenSSLContext(object): + """ + I am a wrapper class for the PyOpenSSL ``Context`` object. I am responsible + for translating the interface of the standard library ``SSLContext`` object + to calls into PyOpenSSL. + """ + + def __init__(self, protocol): + self.protocol = _openssl_versions[protocol] + self._ctx = OpenSSL.SSL.Context(self.protocol) + self._options = 0 + self.check_hostname = False + + @property + def options(self): + return self._options + + @options.setter + def options(self, value): + self._options = value + self._ctx.set_options(value) + + @property + def verify_mode(self): + return _openssl_to_stdlib_verify[self._ctx.get_verify_mode()] + + @verify_mode.setter + def verify_mode(self, value): + self._ctx.set_verify(_stdlib_to_openssl_verify[value], _verify_callback) + + def set_default_verify_paths(self): + self._ctx.set_default_verify_paths() + + def set_ciphers(self, ciphers): + if isinstance(ciphers, six.text_type): + ciphers = ciphers.encode("utf-8") + self._ctx.set_cipher_list(ciphers) + + def load_verify_locations(self, cafile=None, capath=None, cadata=None): + if cafile is not None: + cafile = cafile.encode("utf-8") + if capath is not None: + capath = capath.encode("utf-8") + try: + self._ctx.load_verify_locations(cafile, capath) + if cadata is not None: + self._ctx.load_verify_locations(BytesIO(cadata)) + except OpenSSL.SSL.Error as e: + raise ssl.SSLError("unable to load trusted certificates: %r" % e) + + def load_cert_chain(self, certfile, keyfile=None, password=None): + self._ctx.use_certificate_chain_file(certfile) + if password is not None: + if not isinstance(password, six.binary_type): + password = password.encode("utf-8") + self._ctx.set_passwd_cb(lambda *_: password) + self._ctx.use_privatekey_file(keyfile or certfile) + + def set_alpn_protocols(self, protocols): + protocols = [six.ensure_binary(p) for p in protocols] + return self._ctx.set_alpn_protos(protocols) + + def wrap_socket( + self, + sock, + server_side=False, + do_handshake_on_connect=True, + suppress_ragged_eofs=True, + server_hostname=None, + ): + cnx = OpenSSL.SSL.Connection(self._ctx, sock) + + if isinstance(server_hostname, six.text_type): # Platform-specific: Python 3 + server_hostname = server_hostname.encode("utf-8") + + if server_hostname is not None: + cnx.set_tlsext_host_name(server_hostname) + + cnx.set_connect_state() + + while True: + try: + cnx.do_handshake() + except OpenSSL.SSL.WantReadError: + if not util.wait_for_read(sock, sock.gettimeout()): + raise timeout("select timed out") + continue + except OpenSSL.SSL.Error as e: + raise ssl.SSLError("bad handshake: %r" % e) + break + + return WrappedSocket(cnx, sock) + + +def _verify_callback(cnx, x509, err_no, err_depth, return_code): + return err_no == 0 diff --git a/venv/lib/python3.8/site-packages/urllib3/contrib/securetransport.py b/venv/lib/python3.8/site-packages/urllib3/contrib/securetransport.py new file mode 100644 index 0000000..554c015 --- /dev/null +++ b/venv/lib/python3.8/site-packages/urllib3/contrib/securetransport.py @@ -0,0 +1,922 @@ +""" +SecureTranport support for urllib3 via ctypes. + +This makes platform-native TLS available to urllib3 users on macOS without the +use of a compiler. This is an important feature because the Python Package +Index is moving to become a TLSv1.2-or-higher server, and the default OpenSSL +that ships with macOS is not capable of doing TLSv1.2. The only way to resolve +this is to give macOS users an alternative solution to the problem, and that +solution is to use SecureTransport. + +We use ctypes here because this solution must not require a compiler. That's +because pip is not allowed to require a compiler either. + +This is not intended to be a seriously long-term solution to this problem. +The hope is that PEP 543 will eventually solve this issue for us, at which +point we can retire this contrib module. But in the short term, we need to +solve the impending tire fire that is Python on Mac without this kind of +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() + +Happy TLSing! + +This code is a bastardised version of the code found in Will Bond's oscrypto +library. An enormous debt is owed to him for blazing this trail for us. For +that reason, this code should be considered to be covered both by urllib3's +license and by oscrypto's: + +.. code-block:: + + Copyright (c) 2015-2016 Will Bond + + 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 absolute_import + +import contextlib +import ctypes +import errno +import os.path +import shutil +import socket +import ssl +import struct +import threading +import weakref + +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, + _build_tls_unknown_ca_alert, + _cert_array_from_pem, + _create_cfstring_array, + _load_client_cert_chain, + _temporary_keychain, +) + +try: # Platform-specific: Python 2 + from socket import _fileobject +except ImportError: # Platform-specific: Python 3 + _fileobject = None + from ..packages.backports.makefile import backport_makefile + +__all__ = ["inject_into_urllib3", "extract_from_urllib3"] + +# SNI always works +HAS_SNI = True + +orig_util_HAS_SNI = util.HAS_SNI +orig_util_SSLContext = util.ssl_.SSLContext + +# This dictionary is used by the read callback to obtain a handle to the +# calling wrapped socket. This is a pretty silly approach, but for now it'll +# do. I feel like I should be able to smuggle a handle to the wrapped socket +# directly in the SSLConnectionRef, but for now this approach will work I +# guess. +# +# We need to lock around this structure for inserts, but we don't do it for +# reads/writes in the callbacks. The reasoning here goes as follows: +# +# 1. It is not possible to call into the callbacks before the dictionary is +# populated, so once in the callback the id must be in the dictionary. +# 2. The callbacks don't mutate the dictionary, they only read from it, and +# so cannot conflict with any of the insertions. +# +# This is good: if we had to lock in the callbacks we'd drastically slow down +# the performance of this code. +_connection_refs = weakref.WeakValueDictionary() +_connection_ref_lock = threading.Lock() + +# Limit writes to 16kB. This is OpenSSL's limit, but we'll cargo-cult it over +# for no better reason than we need *a* limit, and this one is right there. +SSL_WRITE_BLOCKSIZE = 16384 + +# This is our equivalent of util.ssl_.DEFAULT_CIPHERS, but expanded out to +# individual cipher suites. We need to do this because this is how +# SecureTransport wants them. +CIPHER_SUITES = [ + SecurityConst.TLS_ECDHE_ECDSA_WITH_AES_256_GCM_SHA384, + SecurityConst.TLS_ECDHE_ECDSA_WITH_AES_128_GCM_SHA256, + SecurityConst.TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384, + SecurityConst.TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256, + SecurityConst.TLS_ECDHE_ECDSA_WITH_CHACHA20_POLY1305_SHA256, + SecurityConst.TLS_ECDHE_RSA_WITH_CHACHA20_POLY1305_SHA256, + SecurityConst.TLS_DHE_RSA_WITH_AES_256_GCM_SHA384, + SecurityConst.TLS_DHE_RSA_WITH_AES_128_GCM_SHA256, + SecurityConst.TLS_ECDHE_ECDSA_WITH_AES_256_CBC_SHA384, + SecurityConst.TLS_ECDHE_ECDSA_WITH_AES_256_CBC_SHA, + SecurityConst.TLS_ECDHE_ECDSA_WITH_AES_128_CBC_SHA256, + SecurityConst.TLS_ECDHE_ECDSA_WITH_AES_128_CBC_SHA, + SecurityConst.TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384, + SecurityConst.TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA, + SecurityConst.TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256, + SecurityConst.TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA, + SecurityConst.TLS_DHE_RSA_WITH_AES_256_CBC_SHA256, + SecurityConst.TLS_DHE_RSA_WITH_AES_256_CBC_SHA, + SecurityConst.TLS_DHE_RSA_WITH_AES_128_CBC_SHA256, + SecurityConst.TLS_DHE_RSA_WITH_AES_128_CBC_SHA, + SecurityConst.TLS_AES_256_GCM_SHA384, + SecurityConst.TLS_AES_128_GCM_SHA256, + SecurityConst.TLS_RSA_WITH_AES_256_GCM_SHA384, + SecurityConst.TLS_RSA_WITH_AES_128_GCM_SHA256, + SecurityConst.TLS_AES_128_CCM_8_SHA256, + SecurityConst.TLS_AES_128_CCM_SHA256, + SecurityConst.TLS_RSA_WITH_AES_256_CBC_SHA256, + SecurityConst.TLS_RSA_WITH_AES_128_CBC_SHA256, + SecurityConst.TLS_RSA_WITH_AES_256_CBC_SHA, + SecurityConst.TLS_RSA_WITH_AES_128_CBC_SHA, +] + +# Basically this is simple: for PROTOCOL_SSLv23 we turn it into a low of +# 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), + PROTOCOL_TLS_CLIENT: (SecurityConst.kTLSProtocol1, SecurityConst.kTLSProtocol12), +} + +if hasattr(ssl, "PROTOCOL_SSLv2"): + _protocol_to_min_max[ssl.PROTOCOL_SSLv2] = ( + SecurityConst.kSSLProtocol2, + SecurityConst.kSSLProtocol2, + ) +if hasattr(ssl, "PROTOCOL_SSLv3"): + _protocol_to_min_max[ssl.PROTOCOL_SSLv3] = ( + SecurityConst.kSSLProtocol3, + SecurityConst.kSSLProtocol3, + ) +if hasattr(ssl, "PROTOCOL_TLSv1"): + _protocol_to_min_max[ssl.PROTOCOL_TLSv1] = ( + SecurityConst.kTLSProtocol1, + SecurityConst.kTLSProtocol1, + ) +if hasattr(ssl, "PROTOCOL_TLSv1_1"): + _protocol_to_min_max[ssl.PROTOCOL_TLSv1_1] = ( + SecurityConst.kTLSProtocol11, + SecurityConst.kTLSProtocol11, + ) +if hasattr(ssl, "PROTOCOL_TLSv1_2"): + _protocol_to_min_max[ssl.PROTOCOL_TLSv1_2] = ( + SecurityConst.kTLSProtocol12, + SecurityConst.kTLSProtocol12, + ) + + +def inject_into_urllib3(): + """ + Monkey-patch urllib3 with SecureTransport-backed SSL-support. + """ + util.SSLContext = SecureTransportContext + util.ssl_.SSLContext = SecureTransportContext + util.HAS_SNI = HAS_SNI + util.ssl_.HAS_SNI = HAS_SNI + util.IS_SECURETRANSPORT = True + util.ssl_.IS_SECURETRANSPORT = True + + +def extract_from_urllib3(): + """ + Undo monkey-patching by :func:`inject_into_urllib3`. + """ + util.SSLContext = orig_util_SSLContext + util.ssl_.SSLContext = orig_util_SSLContext + util.HAS_SNI = orig_util_HAS_SNI + util.ssl_.HAS_SNI = orig_util_HAS_SNI + util.IS_SECURETRANSPORT = False + util.ssl_.IS_SECURETRANSPORT = False + + +def _read_callback(connection_id, data_buffer, data_length_pointer): + """ + SecureTransport read callback. This is called by ST to request that data + be returned from the socket. + """ + wrapped_socket = None + try: + wrapped_socket = _connection_refs.get(connection_id) + if wrapped_socket is None: + return SecurityConst.errSSLInternal + base_socket = wrapped_socket.socket + + requested_length = data_length_pointer[0] + + timeout = wrapped_socket.gettimeout() + error = None + read_count = 0 + + try: + while read_count < requested_length: + if timeout is None or timeout >= 0: + if not util.wait_for_read(base_socket, timeout): + raise socket.error(errno.EAGAIN, "timed out") + + remaining = requested_length - read_count + buffer = (ctypes.c_char * remaining).from_address( + data_buffer + read_count + ) + chunk_size = base_socket.recv_into(buffer, remaining) + read_count += chunk_size + if not chunk_size: + if not read_count: + return SecurityConst.errSSLClosedGraceful + break + except (socket.error) as e: + error = e.errno + + if error is not None and error != errno.EAGAIN: + data_length_pointer[0] = read_count + if error == errno.ECONNRESET or error == errno.EPIPE: + return SecurityConst.errSSLClosedAbort + raise + + data_length_pointer[0] = read_count + + if read_count != requested_length: + return SecurityConst.errSSLWouldBlock + + return 0 + except Exception as e: + if wrapped_socket is not None: + wrapped_socket._exception = e + return SecurityConst.errSSLInternal + + +def _write_callback(connection_id, data_buffer, data_length_pointer): + """ + SecureTransport write callback. This is called by ST to request that data + actually be sent on the network. + """ + wrapped_socket = None + try: + wrapped_socket = _connection_refs.get(connection_id) + if wrapped_socket is None: + return SecurityConst.errSSLInternal + base_socket = wrapped_socket.socket + + bytes_to_write = data_length_pointer[0] + data = ctypes.string_at(data_buffer, bytes_to_write) + + timeout = wrapped_socket.gettimeout() + error = None + sent = 0 + + try: + while sent < bytes_to_write: + if timeout is None or timeout >= 0: + if not util.wait_for_write(base_socket, timeout): + raise socket.error(errno.EAGAIN, "timed out") + chunk_sent = base_socket.send(data) + sent += chunk_sent + + # This has some needless copying here, but I'm not sure there's + # much value in optimising this data path. + data = data[chunk_sent:] + except (socket.error) as e: + error = e.errno + + if error is not None and error != errno.EAGAIN: + data_length_pointer[0] = sent + if error == errno.ECONNRESET or error == errno.EPIPE: + return SecurityConst.errSSLClosedAbort + raise + + data_length_pointer[0] = sent + + if sent != bytes_to_write: + return SecurityConst.errSSLWouldBlock + + return 0 + except Exception as e: + if wrapped_socket is not None: + wrapped_socket._exception = e + return SecurityConst.errSSLInternal + + +# We need to keep these two objects references alive: if they get GC'd while +# in use then SecureTransport could attempt to call a function that is in freed +# memory. That would be...uh...bad. Yeah, that's the word. Bad. +_read_callback_pointer = Security.SSLReadFunc(_read_callback) +_write_callback_pointer = Security.SSLWriteFunc(_write_callback) + + +class WrappedSocket(object): + """ + API-compatibility wrapper for Python's OpenSSL wrapped socket object. + + Note: _makefile_refs, _drop(), and _reuse() are needed for the garbage + collector of PyPy. + """ + + def __init__(self, socket): + self.socket = socket + self.context = None + self._makefile_refs = 0 + self._closed = False + self._exception = None + self._keychain = None + self._keychain_dir = None + self._client_cert_chain = None + + # We save off the previously-configured timeout and then set it to + # zero. This is done because we use select and friends to handle the + # timeouts, but if we leave the timeout set on the lower socket then + # Python will "kindly" call select on that socket again for us. Avoid + # that by forcing the timeout to zero. + self._timeout = self.socket.gettimeout() + self.socket.settimeout(0) + + @contextlib.contextmanager + def _raise_on_error(self): + """ + A context manager that can be used to wrap calls that do I/O from + SecureTransport. If any of the I/O callbacks hit an exception, this + context manager will correctly propagate the exception after the fact. + This avoids silently swallowing those exceptions. + + It also correctly forces the socket closed. + """ + self._exception = None + + # We explicitly don't catch around this yield because in the unlikely + # event that an exception was hit in the block we don't want to swallow + # it. + yield + if self._exception is not None: + exception, self._exception = self._exception, None + self.close() + raise exception + + def _set_ciphers(self): + """ + Sets up the allowed ciphers. By default this matches the set in + util.ssl_.DEFAULT_CIPHERS, at least as supported by macOS. This is done + custom and doesn't allow changing at this time, mostly because parsing + OpenSSL cipher strings is going to be a freaking nightmare. + """ + ciphers = (Security.SSLCipherSuite * len(CIPHER_SUITES))(*CIPHER_SUITES) + result = Security.SSLSetEnabledCiphers( + self.context, ciphers, len(CIPHER_SUITES) + ) + _assert_no_error(result) + + def _set_alpn_protocols(self, protocols): + """ + Sets up the ALPN protocols on the context. + """ + if not protocols: + return + protocols_arr = _create_cfstring_array(protocols) + try: + result = Security.SSLSetALPNProtocols(self.context, protocols_arr) + _assert_no_error(result) + finally: + CoreFoundation.CFRelease(protocols_arr) + + def _custom_validate(self, verify, trust_bundle): + """ + Called when we have set custom validation. We do this in two cases: + first, when cert validation is entirely disabled; and second, when + using a custom trust DB. + Raises an SSLError if the connection is not trusted. + """ + # If we disabled cert validation, just say: cool. + if not verify: + return + + successes = ( + SecurityConst.kSecTrustResultUnspecified, + SecurityConst.kSecTrustResultProceed, + ) + try: + trust_result = self._evaluate_trust(trust_bundle) + if trust_result in successes: + return + reason = "error code: %d" % (trust_result,) + except Exception as e: + # Do not trust on error + reason = "exception: %r" % (e,) + + # SecureTransport does not send an alert nor shuts down the connection. + rec = _build_tls_unknown_ca_alert(self.version()) + self.socket.sendall(rec) + # close the connection immediately + # l_onoff = 1, activate linger + # l_linger = 0, linger for 0 seoncds + opts = struct.pack("ii", 1, 0) + self.socket.setsockopt(socket.SOL_SOCKET, socket.SO_LINGER, opts) + self.close() + raise ssl.SSLError("certificate verify failed, %s" % reason) + + def _evaluate_trust(self, trust_bundle): + # We want data in memory, so load it up. + if os.path.isfile(trust_bundle): + with open(trust_bundle, "rb") as f: + trust_bundle = f.read() + + cert_array = None + trust = Security.SecTrustRef() + + try: + # Get a CFArray that contains the certs we want. + cert_array = _cert_array_from_pem(trust_bundle) + + # Ok, now the hard part. We want to get the SecTrustRef that ST has + # created for this connection, shove our CAs into it, tell ST to + # ignore everything else it knows, and then ask if it can build a + # chain. This is a buuuunch of code. + result = Security.SSLCopyPeerTrust(self.context, ctypes.byref(trust)) + _assert_no_error(result) + if not trust: + raise ssl.SSLError("Failed to copy trust reference") + + result = Security.SecTrustSetAnchorCertificates(trust, cert_array) + _assert_no_error(result) + + result = Security.SecTrustSetAnchorCertificatesOnly(trust, True) + _assert_no_error(result) + + trust_result = Security.SecTrustResultType() + result = Security.SecTrustEvaluate(trust, ctypes.byref(trust_result)) + _assert_no_error(result) + finally: + if trust: + CoreFoundation.CFRelease(trust) + + if cert_array is not None: + CoreFoundation.CFRelease(cert_array) + + return trust_result.value + + def handshake( + self, + server_hostname, + verify, + trust_bundle, + min_version, + max_version, + client_cert, + client_key, + client_key_passphrase, + alpn_protocols, + ): + """ + Actually performs the TLS handshake. This is run automatically by + wrapped socket, and shouldn't be needed in user code. + """ + # First, we do the initial bits of connection setup. We need to create + # a context, set its I/O funcs, and set the connection reference. + self.context = Security.SSLCreateContext( + None, SecurityConst.kSSLClientSide, SecurityConst.kSSLStreamType + ) + result = Security.SSLSetIOFuncs( + self.context, _read_callback_pointer, _write_callback_pointer + ) + _assert_no_error(result) + + # Here we need to compute the handle to use. We do this by taking the + # id of self modulo 2**31 - 1. If this is already in the dictionary, we + # just keep incrementing by one until we find a free space. + with _connection_ref_lock: + handle = id(self) % 2147483647 + while handle in _connection_refs: + handle = (handle + 1) % 2147483647 + _connection_refs[handle] = self + + result = Security.SSLSetConnection(self.context, handle) + _assert_no_error(result) + + # If we have a server hostname, we should set that too. + if server_hostname: + if not isinstance(server_hostname, bytes): + server_hostname = server_hostname.encode("utf-8") + + result = Security.SSLSetPeerDomainName( + self.context, server_hostname, len(server_hostname) + ) + _assert_no_error(result) + + # Setup the ciphers. + self._set_ciphers() + + # Setup the ALPN protocols. + self._set_alpn_protocols(alpn_protocols) + + # Set the minimum and maximum TLS versions. + result = Security.SSLSetProtocolVersionMin(self.context, min_version) + _assert_no_error(result) + + result = Security.SSLSetProtocolVersionMax(self.context, max_version) + _assert_no_error(result) + + # If there's a trust DB, we need to use it. We do that by telling + # SecureTransport to break on server auth. We also do that if we don't + # want to validate the certs at all: we just won't actually do any + # authing in that case. + if not verify or trust_bundle is not None: + result = Security.SSLSetSessionOption( + self.context, SecurityConst.kSSLSessionOptionBreakOnServerAuth, True + ) + _assert_no_error(result) + + # If there's a client cert, we need to use it. + if client_cert: + self._keychain, self._keychain_dir = _temporary_keychain() + self._client_cert_chain = _load_client_cert_chain( + self._keychain, client_cert, client_key + ) + result = Security.SSLSetCertificate(self.context, self._client_cert_chain) + _assert_no_error(result) + + while True: + with self._raise_on_error(): + result = Security.SSLHandshake(self.context) + + if result == SecurityConst.errSSLWouldBlock: + raise socket.timeout("handshake timed out") + elif result == SecurityConst.errSSLServerAuthCompleted: + self._custom_validate(verify, trust_bundle) + continue + else: + _assert_no_error(result) + break + + def fileno(self): + return self.socket.fileno() + + # Copy-pasted from Python 3.5 source code + def _decref_socketios(self): + if self._makefile_refs > 0: + self._makefile_refs -= 1 + if self._closed: + self.close() + + def recv(self, bufsiz): + buffer = ctypes.create_string_buffer(bufsiz) + bytes_read = self.recv_into(buffer, bufsiz) + data = buffer[:bytes_read] + return data + + def recv_into(self, buffer, nbytes=None): + # Read short on EOF. + if self._closed: + return 0 + + if nbytes is None: + nbytes = len(buffer) + + buffer = (ctypes.c_char * nbytes).from_buffer(buffer) + processed_bytes = ctypes.c_size_t(0) + + with self._raise_on_error(): + result = Security.SSLRead( + self.context, buffer, nbytes, ctypes.byref(processed_bytes) + ) + + # There are some result codes that we want to treat as "not always + # errors". Specifically, those are errSSLWouldBlock, + # errSSLClosedGraceful, and errSSLClosedNoNotify. + if result == SecurityConst.errSSLWouldBlock: + # If we didn't process any bytes, then this was just a time out. + # However, we can get errSSLWouldBlock in situations when we *did* + # read some data, and in those cases we should just read "short" + # and return. + if processed_bytes.value == 0: + # Timed out, no data read. + raise socket.timeout("recv timed out") + elif result in ( + SecurityConst.errSSLClosedGraceful, + SecurityConst.errSSLClosedNoNotify, + ): + # The remote peer has closed this connection. We should do so as + # well. Note that we don't actually return here because in + # principle this could actually be fired along with return data. + # It's unlikely though. + self.close() + else: + _assert_no_error(result) + + # Ok, we read and probably succeeded. We should return whatever data + # was actually read. + return processed_bytes.value + + def settimeout(self, timeout): + self._timeout = timeout + + def gettimeout(self): + return self._timeout + + def send(self, data): + processed_bytes = ctypes.c_size_t(0) + + with self._raise_on_error(): + result = Security.SSLWrite( + self.context, data, len(data), ctypes.byref(processed_bytes) + ) + + if result == SecurityConst.errSSLWouldBlock and processed_bytes.value == 0: + # Timed out + raise socket.timeout("send timed out") + else: + _assert_no_error(result) + + # We sent, and probably succeeded. Tell them how much we sent. + return processed_bytes.value + + def sendall(self, data): + total_sent = 0 + while total_sent < len(data): + sent = self.send(data[total_sent : total_sent + SSL_WRITE_BLOCKSIZE]) + total_sent += sent + + def shutdown(self): + with self._raise_on_error(): + Security.SSLClose(self.context) + + def close(self): + # TODO: should I do clean shutdown here? Do I have to? + if self._makefile_refs < 1: + self._closed = True + if self.context: + CoreFoundation.CFRelease(self.context) + self.context = None + if self._client_cert_chain: + CoreFoundation.CFRelease(self._client_cert_chain) + self._client_cert_chain = None + if self._keychain: + Security.SecKeychainDelete(self._keychain) + CoreFoundation.CFRelease(self._keychain) + shutil.rmtree(self._keychain_dir) + self._keychain = self._keychain_dir = None + return self.socket.close() + else: + self._makefile_refs -= 1 + + def getpeercert(self, binary_form=False): + # Urgh, annoying. + # + # Here's how we do this: + # + # 1. Call SSLCopyPeerTrust to get hold of the trust object for this + # connection. + # 2. Call SecTrustGetCertificateAtIndex for index 0 to get the leaf. + # 3. To get the CN, call SecCertificateCopyCommonName and process that + # string so that it's of the appropriate type. + # 4. To get the SAN, we need to do something a bit more complex: + # a. Call SecCertificateCopyValues to get the data, requesting + # kSecOIDSubjectAltName. + # b. Mess about with this dictionary to try to get the SANs out. + # + # This is gross. Really gross. It's going to be a few hundred LoC extra + # just to repeat something that SecureTransport can *already do*. So my + # operating assumption at this time is that what we want to do is + # instead to just flag to urllib3 that it shouldn't do its own hostname + # validation when using SecureTransport. + if not binary_form: + raise ValueError("SecureTransport only supports dumping binary certs") + trust = Security.SecTrustRef() + certdata = None + der_bytes = None + + try: + # Grab the trust store. + result = Security.SSLCopyPeerTrust(self.context, ctypes.byref(trust)) + _assert_no_error(result) + if not trust: + # Probably we haven't done the handshake yet. No biggie. + return None + + cert_count = Security.SecTrustGetCertificateCount(trust) + if not cert_count: + # Also a case that might happen if we haven't handshaked. + # Handshook? Handshaken? + return None + + leaf = Security.SecTrustGetCertificateAtIndex(trust, 0) + assert leaf + + # Ok, now we want the DER bytes. + certdata = Security.SecCertificateCopyData(leaf) + assert certdata + + data_length = CoreFoundation.CFDataGetLength(certdata) + data_buffer = CoreFoundation.CFDataGetBytePtr(certdata) + der_bytes = ctypes.string_at(data_buffer, data_length) + finally: + if certdata: + CoreFoundation.CFRelease(certdata) + if trust: + CoreFoundation.CFRelease(trust) + + return der_bytes + + def version(self): + protocol = Security.SSLProtocol() + result = Security.SSLGetNegotiatedProtocolVersion( + self.context, ctypes.byref(protocol) + ) + _assert_no_error(result) + if protocol.value == SecurityConst.kTLSProtocol13: + raise ssl.SSLError("SecureTransport does not support TLS 1.3") + elif protocol.value == SecurityConst.kTLSProtocol12: + return "TLSv1.2" + elif protocol.value == SecurityConst.kTLSProtocol11: + return "TLSv1.1" + elif protocol.value == SecurityConst.kTLSProtocol1: + return "TLSv1" + elif protocol.value == SecurityConst.kSSLProtocol3: + return "SSLv3" + elif protocol.value == SecurityConst.kSSLProtocol2: + return "SSLv2" + else: + raise ssl.SSLError("Unknown TLS version: %r" % protocol) + + def _reuse(self): + self._makefile_refs += 1 + + def _drop(self): + if self._makefile_refs < 1: + self.close() + else: + self._makefile_refs -= 1 + + +if _fileobject: # Platform-specific: Python 2 + + def makefile(self, mode, bufsize=-1): + 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): + # We disable buffering with SecureTransport because it conflicts with + # the buffering that ST does internally (see issue #1153 for more). + buffering = 0 + return backport_makefile(self, mode, buffering, *args, **kwargs) + + +WrappedSocket.makefile = makefile + + +class SecureTransportContext(object): + """ + I am a wrapper class for the SecureTransport library, to translate the + interface of the standard library ``SSLContext`` object to calls into + SecureTransport. + """ + + def __init__(self, protocol): + self._min_version, self._max_version = _protocol_to_min_max[protocol] + self._options = 0 + self._verify = False + self._trust_bundle = None + self._client_cert = None + self._client_key = None + self._client_key_passphrase = None + self._alpn_protocols = None + + @property + def check_hostname(self): + """ + SecureTransport cannot have its hostname checking disabled. For more, + see the comment on getpeercert() in this file. + """ + return True + + @check_hostname.setter + def check_hostname(self, value): + """ + SecureTransport cannot have its hostname checking disabled. For more, + see the comment on getpeercert() in this file. + """ + pass + + @property + def options(self): + # TODO: Well, crap. + # + # So this is the bit of the code that is the most likely to cause us + # trouble. Essentially we need to enumerate all of the SSL options that + # users might want to use and try to see if we can sensibly translate + # them, or whether we should just ignore them. + return self._options + + @options.setter + def options(self, value): + # TODO: Update in line with above. + self._options = value + + @property + def verify_mode(self): + return ssl.CERT_REQUIRED if self._verify else ssl.CERT_NONE + + @verify_mode.setter + def verify_mode(self, value): + self._verify = True if value == ssl.CERT_REQUIRED else False + + def set_default_verify_paths(self): + # So, this has to do something a bit weird. Specifically, what it does + # is nothing. + # + # This means that, if we had previously had load_verify_locations + # called, this does not undo that. We need to do that because it turns + # out that the rest of the urllib3 code will attempt to load the + # default verify paths if it hasn't been told about any paths, even if + # the context itself was sometime earlier. We resolve that by just + # ignoring it. + pass + + def load_default_certs(self): + return self.set_default_verify_paths() + + def set_ciphers(self, ciphers): + # For now, we just require the default cipher string. + if ciphers != util.ssl_.DEFAULT_CIPHERS: + raise ValueError("SecureTransport doesn't support custom cipher strings") + + def load_verify_locations(self, cafile=None, capath=None, cadata=None): + # OK, we only really support cadata and cafile. + if capath is not None: + raise ValueError("SecureTransport does not support cert directories") + + # Raise if cafile does not exist. + if cafile is not None: + with open(cafile): + pass + + self._trust_bundle = cafile or cadata + + def load_cert_chain(self, certfile, keyfile=None, password=None): + self._client_cert = certfile + self._client_key = keyfile + self._client_cert_passphrase = password + + def set_alpn_protocols(self, protocols): + """ + Sets the ALPN protocols that will later be set on the context. + + Raises a NotImplementedError if ALPN is not supported. + """ + if not hasattr(Security, "SSLSetALPNProtocols"): + raise NotImplementedError( + "SecureTransport supports ALPN only in macOS 10.12+" + ) + self._alpn_protocols = [six.ensure_binary(p) for p in protocols] + + def wrap_socket( + self, + sock, + server_side=False, + do_handshake_on_connect=True, + suppress_ragged_eofs=True, + server_hostname=None, + ): + # So, what do we do here? Firstly, we assert some properties. This is a + # stripped down shim, so there is some functionality we don't support. + # See PEP 543 for the real deal. + assert not server_side + assert do_handshake_on_connect + assert suppress_ragged_eofs + + # Ok, we're good to go. Now we want to create the wrapped socket object + # and store it in the appropriate place. + wrapped_socket = WrappedSocket(sock) + + # Now we can handshake + wrapped_socket.handshake( + server_hostname, + self._verify, + self._trust_bundle, + self._min_version, + self._max_version, + self._client_cert, + self._client_key, + self._client_key_passphrase, + self._alpn_protocols, + ) + return wrapped_socket diff --git a/venv/lib/python3.8/site-packages/urllib3/contrib/socks.py b/venv/lib/python3.8/site-packages/urllib3/contrib/socks.py new file mode 100644 index 0000000..c326e80 --- /dev/null +++ b/venv/lib/python3.8/site-packages/urllib3/contrib/socks.py @@ -0,0 +1,216 @@ +# -*- coding: utf-8 -*- +""" +This module contains provisional support for SOCKS proxies from within +urllib3. This module supports SOCKS4, SOCKS4A (an extension of SOCKS4), and +SOCKS5. To enable its functionality, either install PySocks or install this +module with the ``socks`` extra. + +The SOCKS implementation supports the full range of urllib3 features. It also +supports the following SOCKS features: + +- SOCKS4A (``proxy_url='socks4a://...``) +- SOCKS4 (``proxy_url='socks4://...``) +- SOCKS5 with remote DNS (``proxy_url='socks5h://...``) +- SOCKS5 with local DNS (``proxy_url='socks5://...``) +- Usernames and passwords for the SOCKS proxy + +.. note:: + It is recommended to use ``socks5h://`` or ``socks4a://`` schemes in + your ``proxy_url`` to ensure that DNS resolution is done from the remote + server instead of client-side when connecting to a domain name. + +SOCKS4 supports IPv4 and domain names with the SOCKS4A extension. SOCKS5 +supports IPv4, IPv6, and domain names. + +When connecting to a SOCKS4 proxy the ``username`` portion of the ``proxy_url`` +will be sent as the ``userid`` section of the SOCKS request: + +.. code-block:: python + + proxy_url="socks4a://@proxy-host" + +When connecting to a SOCKS5 proxy the ``username`` and ``password`` portion +of the ``proxy_url`` will be sent as the username/password to authenticate +with the proxy: + +.. code-block:: python + + proxy_url="socks5h://:@proxy-host" + +""" +from __future__ import absolute_import + +try: + import socks +except ImportError: + import warnings + + from ..exceptions import DependencyWarning + + warnings.warn( + ( + "SOCKS support in urllib3 requires the installation of optional " + "dependencies: specifically, PySocks. For more information, see " + "https://urllib3.readthedocs.io/en/1.26.x/contrib.html#socks-proxies" + ), + DependencyWarning, + ) + raise + +from socket import error as SocketError +from socket import timeout as SocketTimeout + +from ..connection import HTTPConnection, HTTPSConnection +from ..connectionpool import HTTPConnectionPool, HTTPSConnectionPool +from ..exceptions import ConnectTimeoutError, NewConnectionError +from ..poolmanager import PoolManager +from ..util.url import parse_url + +try: + import ssl +except ImportError: + ssl = None + + +class SOCKSConnection(HTTPConnection): + """ + A plain-text HTTP connection that connects via a SOCKS proxy. + """ + + def __init__(self, *args, **kwargs): + self._socks_options = kwargs.pop("_socks_options") + super(SOCKSConnection, self).__init__(*args, **kwargs) + + def _new_conn(self): + """ + Establish a new connection via the SOCKS proxy. + """ + extra_kw = {} + if self.source_address: + extra_kw["source_address"] = self.source_address + + if self.socket_options: + extra_kw["socket_options"] = self.socket_options + + try: + conn = socks.create_connection( + (self.host, self.port), + proxy_type=self._socks_options["socks_version"], + proxy_addr=self._socks_options["proxy_host"], + proxy_port=self._socks_options["proxy_port"], + proxy_username=self._socks_options["username"], + proxy_password=self._socks_options["password"], + proxy_rdns=self._socks_options["rdns"], + timeout=self.timeout, + **extra_kw + ) + + except SocketTimeout: + raise ConnectTimeoutError( + self, + "Connection to %s timed out. (connect timeout=%s)" + % (self.host, self.timeout), + ) + + except socks.ProxyError as e: + # This is fragile as hell, but it seems to be the only way to raise + # useful errors here. + if e.socket_err: + error = e.socket_err + if isinstance(error, SocketTimeout): + raise ConnectTimeoutError( + self, + "Connection to %s timed out. (connect timeout=%s)" + % (self.host, self.timeout), + ) + else: + raise NewConnectionError( + self, "Failed to establish a new connection: %s" % error + ) + else: + raise NewConnectionError( + self, "Failed to establish a new connection: %s" % e + ) + + except SocketError as e: # Defensive: PySocks should catch all these. + raise NewConnectionError( + self, "Failed to establish a new connection: %s" % e + ) + + return conn + + +# We don't need to duplicate the Verified/Unverified distinction from +# urllib3/connection.py here because the HTTPSConnection will already have been +# correctly set to either the Verified or Unverified form by that module. This +# means the SOCKSHTTPSConnection will automatically be the correct type. +class SOCKSHTTPSConnection(SOCKSConnection, HTTPSConnection): + pass + + +class SOCKSHTTPConnectionPool(HTTPConnectionPool): + ConnectionCls = SOCKSConnection + + +class SOCKSHTTPSConnectionPool(HTTPSConnectionPool): + ConnectionCls = SOCKSHTTPSConnection + + +class SOCKSProxyManager(PoolManager): + """ + A version of the urllib3 ProxyManager that routes connections via the + defined SOCKS proxy. + """ + + pool_classes_by_scheme = { + "http": SOCKSHTTPConnectionPool, + "https": SOCKSHTTPSConnectionPool, + } + + def __init__( + self, + proxy_url, + username=None, + password=None, + num_pools=10, + headers=None, + **connection_pool_kw + ): + parsed = parse_url(proxy_url) + + if username is None and password is None and parsed.auth is not None: + split = parsed.auth.split(":") + if len(split) == 2: + username, password = split + if parsed.scheme == "socks5": + socks_version = socks.PROXY_TYPE_SOCKS5 + rdns = False + elif parsed.scheme == "socks5h": + socks_version = socks.PROXY_TYPE_SOCKS5 + rdns = True + elif parsed.scheme == "socks4": + socks_version = socks.PROXY_TYPE_SOCKS4 + rdns = False + elif parsed.scheme == "socks4a": + socks_version = socks.PROXY_TYPE_SOCKS4 + rdns = True + else: + raise ValueError("Unable to determine SOCKS version from %s" % proxy_url) + + self.proxy_url = proxy_url + + socks_options = { + "socks_version": socks_version, + "proxy_host": parsed.host, + "proxy_port": parsed.port, + "username": username, + "password": password, + "rdns": rdns, + } + connection_pool_kw["_socks_options"] = socks_options + + super(SOCKSProxyManager, self).__init__( + num_pools, headers, **connection_pool_kw + ) + + self.pool_classes_by_scheme = SOCKSProxyManager.pool_classes_by_scheme diff --git a/venv/lib/python3.8/site-packages/urllib3/exceptions.py b/venv/lib/python3.8/site-packages/urllib3/exceptions.py new file mode 100644 index 0000000..cba6f3f --- /dev/null +++ b/venv/lib/python3.8/site-packages/urllib3/exceptions.py @@ -0,0 +1,323 @@ +from __future__ import absolute_import + +from .packages.six.moves.http_client import IncompleteRead as httplib_IncompleteRead + +# Base Exceptions + + +class HTTPError(Exception): + """Base exception used by this module.""" + + pass + + +class HTTPWarning(Warning): + """Base warning used by this module.""" + + pass + + +class PoolError(HTTPError): + """Base exception for errors caused within a pool.""" + + def __init__(self, pool, message): + self.pool = pool + HTTPError.__init__(self, "%s: %s" % (pool, message)) + + def __reduce__(self): + # For pickling purposes. + return self.__class__, (None, None) + + +class RequestError(PoolError): + """Base exception for PoolErrors that have associated URLs.""" + + def __init__(self, pool, url, message): + self.url = url + PoolError.__init__(self, pool, message) + + def __reduce__(self): + # For pickling purposes. + return self.__class__, (None, self.url, None) + + +class SSLError(HTTPError): + """Raised when SSL certificate fails in an HTTPS connection.""" + + pass + + +class ProxyError(HTTPError): + """Raised when the connection to a proxy fails.""" + + def __init__(self, message, error, *args): + super(ProxyError, self).__init__(message, error, *args) + self.original_error = error + + +class DecodeError(HTTPError): + """Raised when automatic decoding based on Content-Type fails.""" + + pass + + +class ProtocolError(HTTPError): + """Raised when something unexpected happens mid-request/response.""" + + pass + + +#: Renamed to ProtocolError but aliased for backwards compatibility. +ConnectionError = ProtocolError + + +# Leaf Exceptions + + +class MaxRetryError(RequestError): + """Raised when the maximum number of retries is exceeded. + + :param pool: The connection pool + :type pool: :class:`~urllib3.connectionpool.HTTPConnectionPool` + :param string url: The requested Url + :param exceptions.Exception reason: The underlying error + + """ + + def __init__(self, pool, url, reason=None): + self.reason = reason + + message = "Max retries exceeded with url: %s (Caused by %r)" % (url, reason) + + RequestError.__init__(self, pool, url, message) + + +class HostChangedError(RequestError): + """Raised when an existing pool gets a request for a foreign host.""" + + def __init__(self, pool, url, retries=3): + message = "Tried to open a foreign host with url: %s" % url + RequestError.__init__(self, pool, url, message) + self.retries = retries + + +class TimeoutStateError(HTTPError): + """Raised when passing an invalid state to a timeout""" + + pass + + +class TimeoutError(HTTPError): + """Raised when a socket timeout error occurs. + + Catching this error will catch both :exc:`ReadTimeoutErrors + ` and :exc:`ConnectTimeoutErrors `. + """ + + pass + + +class ReadTimeoutError(TimeoutError, RequestError): + """Raised when a socket timeout occurs while receiving data from a server""" + + pass + + +# This timeout error does not have a URL attached and needs to inherit from the +# base HTTPError +class ConnectTimeoutError(TimeoutError): + """Raised when a socket timeout occurs while connecting to a server""" + + pass + + +class NewConnectionError(ConnectTimeoutError, PoolError): + """Raised when we fail to establish a new connection. Usually ECONNREFUSED.""" + + pass + + +class EmptyPoolError(PoolError): + """Raised when a pool runs out of connections and no more are allowed.""" + + pass + + +class ClosedPoolError(PoolError): + """Raised when a request enters a pool after the pool has been closed.""" + + pass + + +class LocationValueError(ValueError, HTTPError): + """Raised when there is something wrong with a given URL input.""" + + pass + + +class LocationParseError(LocationValueError): + """Raised when get_host or similar fails to parse the URL input.""" + + def __init__(self, location): + message = "Failed to parse: %s" % location + HTTPError.__init__(self, message) + + self.location = location + + +class URLSchemeUnknown(LocationValueError): + """Raised when a URL input has an unsupported scheme.""" + + def __init__(self, scheme): + message = "Not supported URL scheme %s" % scheme + super(URLSchemeUnknown, self).__init__(message) + + self.scheme = scheme + + +class ResponseError(HTTPError): + """Used as a container for an error reason supplied in a MaxRetryError.""" + + GENERIC_ERROR = "too many error responses" + SPECIFIC_ERROR = "too many {status_code} error responses" + + +class SecurityWarning(HTTPWarning): + """Warned when performing security reducing actions""" + + pass + + +class SubjectAltNameWarning(SecurityWarning): + """Warned when connecting to a host with a certificate missing a SAN.""" + + pass + + +class InsecureRequestWarning(SecurityWarning): + """Warned when making an unverified HTTPS request.""" + + pass + + +class SystemTimeWarning(SecurityWarning): + """Warned when system time is suspected to be wrong""" + + pass + + +class InsecurePlatformWarning(SecurityWarning): + """Warned when certain TLS/SSL configuration is not available on a platform.""" + + pass + + +class SNIMissingWarning(HTTPWarning): + """Warned when making a HTTPS request without SNI available.""" + + pass + + +class DependencyWarning(HTTPWarning): + """ + Warned when an attempt is made to import a module with missing optional + dependencies. + """ + + pass + + +class ResponseNotChunked(ProtocolError, ValueError): + """Response needs to be chunked in order to read it as chunks.""" + + pass + + +class BodyNotHttplibCompatible(HTTPError): + """ + Body should be :class:`http.client.HTTPResponse` like + (have an fp attribute which returns raw chunks) for read_chunked(). + """ + + pass + + +class IncompleteRead(HTTPError, httplib_IncompleteRead): + """ + Response length doesn't match expected Content-Length + + Subclass of :class:`http.client.IncompleteRead` to allow int value + for ``partial`` to avoid creating large objects on streamed reads. + """ + + def __init__(self, partial, expected): + super(IncompleteRead, self).__init__(partial, expected) + + def __repr__(self): + return "IncompleteRead(%i bytes read, %i more expected)" % ( + self.partial, + self.expected, + ) + + +class InvalidChunkLength(HTTPError, httplib_IncompleteRead): + """Invalid chunk length in a chunked response.""" + + def __init__(self, response, length): + super(InvalidChunkLength, self).__init__( + response.tell(), response.length_remaining + ) + self.response = response + self.length = length + + def __repr__(self): + return "InvalidChunkLength(got length %r, %i bytes read)" % ( + self.length, + self.partial, + ) + + +class InvalidHeader(HTTPError): + """The header provided was somehow invalid.""" + + pass + + +class ProxySchemeUnknown(AssertionError, URLSchemeUnknown): + """ProxyManager does not support the supplied scheme""" + + # TODO(t-8ch): Stop inheriting from AssertionError in v2.0. + + def __init__(self, scheme): + # 'localhost' is here because our URL parser parses + # localhost:8080 -> scheme=localhost, remove if we fix this. + if scheme == "localhost": + scheme = None + if scheme is None: + message = "Proxy URL had no scheme, should start with http:// or https://" + else: + message = ( + "Proxy URL had unsupported scheme %s, should use http:// or https://" + % scheme + ) + super(ProxySchemeUnknown, self).__init__(message) + + +class ProxySchemeUnsupported(ValueError): + """Fetching HTTPS resources through HTTPS proxies is unsupported""" + + pass + + +class HeaderParsingError(HTTPError): + """Raised by assert_header_parsing, but we convert it to a log.warning statement.""" + + def __init__(self, defects, unparsed_data): + message = "%s, unparsed data: %r" % (defects or "Unknown", unparsed_data) + super(HeaderParsingError, self).__init__(message) + + +class UnrewindableBodyError(HTTPError): + """urllib3 encountered an error when trying to rewind a body""" + + pass diff --git a/venv/lib/python3.8/site-packages/urllib3/fields.py b/venv/lib/python3.8/site-packages/urllib3/fields.py new file mode 100644 index 0000000..9d630f4 --- /dev/null +++ b/venv/lib/python3.8/site-packages/urllib3/fields.py @@ -0,0 +1,274 @@ +from __future__ import absolute_import + +import email.utils +import mimetypes +import re + +from .packages import six + + +def guess_content_type(filename, default="application/octet-stream"): + """ + Guess the "Content-Type" of a file. + + :param filename: + The filename to guess the "Content-Type" of using :mod:`mimetypes`. + :param default: + If no "Content-Type" can be guessed, default to `default`. + """ + if filename: + return mimetypes.guess_type(filename)[0] or default + return default + + +def format_header_param_rfc2231(name, value): + """ + Helper function to format and quote a single header parameter using the + strategy defined in RFC 2231. + + Particularly useful for header parameters which might contain + non-ASCII values, like file names. This follows + `RFC 2388 Section 4.4 `_. + + :param name: + The name of the parameter, a string expected to be ASCII only. + :param value: + The value of the parameter, provided as ``bytes`` or `str``. + :ret: + An RFC-2231-formatted unicode string. + """ + if isinstance(value, six.binary_type): + value = value.decode("utf-8") + + if not any(ch in value for ch in '"\\\r\n'): + result = u'%s="%s"' % (name, value) + try: + result.encode("ascii") + except (UnicodeEncodeError, UnicodeDecodeError): + pass + else: + return result + + if six.PY2: # Python 2: + value = value.encode("utf-8") + + # encode_rfc2231 accepts an encoded string and returns an ascii-encoded + # string in Python 2 but accepts and returns unicode strings in Python 3 + value = email.utils.encode_rfc2231(value, "utf-8") + value = "%s*=%s" % (name, value) + + if six.PY2: # Python 2: + value = value.decode("utf-8") + + return value + + +_HTML5_REPLACEMENTS = { + u"\u0022": u"%22", + # Replace "\" with "\\". + u"\u005C": u"\u005C\u005C", +} + +# All control characters from 0x00 to 0x1F *except* 0x1B. +_HTML5_REPLACEMENTS.update( + { + six.unichr(cc): u"%{:02X}".format(cc) + for cc in range(0x00, 0x1F + 1) + if cc not in (0x1B,) + } +) + + +def _replace_multiple(value, needles_and_replacements): + def replacer(match): + return needles_and_replacements[match.group(0)] + + pattern = re.compile( + r"|".join([re.escape(needle) for needle in needles_and_replacements.keys()]) + ) + + result = pattern.sub(replacer, value) + + return result + + +def format_header_param_html5(name, value): + """ + Helper function to format and quote a single header parameter using the + HTML5 strategy. + + Particularly useful for header parameters which might contain + non-ASCII values, like file names. This follows the `HTML5 Working Draft + Section 4.10.22.7`_ and matches the behavior of curl and modern browsers. + + .. _HTML5 Working Draft Section 4.10.22.7: + https://w3c.github.io/html/sec-forms.html#multipart-form-data + + :param name: + The name of the parameter, a string expected to be ASCII only. + :param value: + The value of the parameter, provided as ``bytes`` or `str``. + :ret: + A unicode string, stripped of troublesome characters. + """ + if isinstance(value, six.binary_type): + value = value.decode("utf-8") + + value = _replace_multiple(value, _HTML5_REPLACEMENTS) + + return u'%s="%s"' % (name, value) + + +# For backwards-compatibility. +format_header_param = format_header_param_html5 + + +class RequestField(object): + """ + A data container for request body parameters. + + :param name: + The name of this request field. Must be unicode. + :param data: + The data/value body. + :param filename: + An optional filename of the request field. Must be unicode. + :param headers: + An optional dict-like object of headers to initially use for the field. + :param header_formatter: + An optional callable that is used to encode and format the headers. By + default, this is :func:`format_header_param_html5`. + """ + + def __init__( + self, + name, + data, + filename=None, + headers=None, + header_formatter=format_header_param_html5, + ): + self._name = name + self._filename = filename + self.data = data + self.headers = {} + if headers: + self.headers = dict(headers) + self.header_formatter = header_formatter + + @classmethod + def from_tuples(cls, fieldname, value, header_formatter=format_header_param_html5): + """ + A :class:`~urllib3.fields.RequestField` factory from old-style tuple parameters. + + Supports constructing :class:`~urllib3.fields.RequestField` from + parameter of key/value strings AND key/filetuple. A filetuple is a + (filename, data, MIME type) tuple where the MIME type is optional. + For example:: + + 'foo': 'bar', + 'fakefile': ('foofile.txt', 'contents of foofile'), + 'realfile': ('barfile.txt', open('realfile').read()), + 'typedfile': ('bazfile.bin', open('bazfile').read(), 'image/jpeg'), + 'nonamefile': 'contents of nonamefile field', + + Field names and filenames must be unicode. + """ + if isinstance(value, tuple): + if len(value) == 3: + filename, data, content_type = value + else: + filename, data = value + content_type = guess_content_type(filename) + else: + filename = None + content_type = None + data = value + + request_param = cls( + fieldname, data, filename=filename, header_formatter=header_formatter + ) + request_param.make_multipart(content_type=content_type) + + return request_param + + def _render_part(self, name, value): + """ + Overridable helper function to format a single header parameter. By + default, this calls ``self.header_formatter``. + + :param name: + The name of the parameter, a string expected to be ASCII only. + :param value: + The value of the parameter, provided as a unicode string. + """ + + return self.header_formatter(name, value) + + def _render_parts(self, header_parts): + """ + Helper function to format and quote a single header. + + Useful for single headers that are composed of multiple items. E.g., + 'Content-Disposition' fields. + + :param header_parts: + A sequence of (k, v) tuples or a :class:`dict` of (k, v) to format + as `k1="v1"; k2="v2"; ...`. + """ + parts = [] + iterable = header_parts + if isinstance(header_parts, dict): + iterable = header_parts.items() + + for name, value in iterable: + if value is not None: + parts.append(self._render_part(name, value)) + + return u"; ".join(parts) + + def render_headers(self): + """ + Renders the headers for this request field. + """ + lines = [] + + sort_keys = ["Content-Disposition", "Content-Type", "Content-Location"] + for sort_key in sort_keys: + if self.headers.get(sort_key, False): + lines.append(u"%s: %s" % (sort_key, self.headers[sort_key])) + + for header_name, header_value in self.headers.items(): + if header_name not in sort_keys: + if header_value: + lines.append(u"%s: %s" % (header_name, header_value)) + + lines.append(u"\r\n") + return u"\r\n".join(lines) + + def make_multipart( + self, content_disposition=None, content_type=None, content_location=None + ): + """ + Makes this request field into a multipart request field. + + This method overrides "Content-Disposition", "Content-Type" and + "Content-Location" headers to the request parameter. + + :param content_type: + The 'Content-Type' of the request body. + :param content_location: + The 'Content-Location' of the request body. + + """ + self.headers["Content-Disposition"] = content_disposition or u"form-data" + self.headers["Content-Disposition"] += u"; ".join( + [ + u"", + self._render_parts( + ((u"name", self._name), (u"filename", self._filename)) + ), + ] + ) + self.headers["Content-Type"] = content_type + self.headers["Content-Location"] = content_location diff --git a/venv/lib/python3.8/site-packages/urllib3/filepost.py b/venv/lib/python3.8/site-packages/urllib3/filepost.py new file mode 100644 index 0000000..36c9252 --- /dev/null +++ b/venv/lib/python3.8/site-packages/urllib3/filepost.py @@ -0,0 +1,98 @@ +from __future__ import absolute_import + +import binascii +import codecs +import os +from io import BytesIO + +from .fields import RequestField +from .packages import six +from .packages.six import b + +writer = codecs.lookup("utf-8")[3] + + +def choose_boundary(): + """ + Our embarrassingly-simple replacement for mimetools.choose_boundary. + """ + boundary = binascii.hexlify(os.urandom(16)) + if not six.PY2: + boundary = boundary.decode("ascii") + return boundary + + +def iter_field_objects(fields): + """ + Iterate over fields. + + Supports list of (k, v) tuples and dicts, and lists of + :class:`~urllib3.fields.RequestField`. + + """ + if isinstance(fields, dict): + i = six.iteritems(fields) + else: + i = iter(fields) + + for field in i: + if isinstance(field, RequestField): + yield field + else: + yield RequestField.from_tuples(*field) + + +def iter_fields(fields): + """ + .. deprecated:: 1.6 + + Iterate over fields. + + The addition of :class:`~urllib3.fields.RequestField` makes this function + obsolete. Instead, use :func:`iter_field_objects`, which returns + :class:`~urllib3.fields.RequestField` objects. + + Supports list of (k, v) tuples and dicts. + """ + if isinstance(fields, dict): + return ((k, v) for k, v in six.iteritems(fields)) + + return ((k, v) for k, v in fields) + + +def encode_multipart_formdata(fields, boundary=None): + """ + Encode a dictionary of ``fields`` using the multipart/form-data MIME format. + + :param fields: + Dictionary of fields or list of (key, :class:`~urllib3.fields.RequestField`). + + :param boundary: + If not specified, then a random boundary will be generated using + :func:`urllib3.filepost.choose_boundary`. + """ + body = BytesIO() + if boundary is None: + boundary = choose_boundary() + + for field in iter_field_objects(fields): + body.write(b("--%s\r\n" % (boundary))) + + writer(body).write(field.render_headers()) + data = field.data + + if isinstance(data, int): + data = str(data) # Backwards compatibility + + if isinstance(data, six.text_type): + writer(body).write(data) + else: + body.write(data) + + body.write(b"\r\n") + + body.write(b("--%s--\r\n" % (boundary))) + + content_type = str("multipart/form-data; boundary=%s" % boundary) + + return body.getvalue(), content_type diff --git a/venv/lib/python3.8/site-packages/urllib3/packages/__init__.py b/venv/lib/python3.8/site-packages/urllib3/packages/__init__.py new file mode 100644 index 0000000..fce4caa --- /dev/null +++ b/venv/lib/python3.8/site-packages/urllib3/packages/__init__.py @@ -0,0 +1,5 @@ +from __future__ import absolute_import + +from . import ssl_match_hostname + +__all__ = ("ssl_match_hostname",) diff --git a/venv/lib/python3.8/site-packages/urllib3/packages/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/urllib3/packages/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..0a536eb9b400fa760d601bea136ba3d546fc72b1 GIT binary patch literal 265 zcmYjLyKciU43uOC4T1y(`UPD&cyKgiGLQuQf-XfDFN7Q^u@K4@^g!KD>Mwcilwasn zsa<*i?|3AEmwb*{vo-qxQzAq; literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/urllib3/packages/__pycache__/six.cpython-38.pyc b/venv/lib/python3.8/site-packages/urllib3/packages/__pycache__/six.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..312612264fa9be437dc410814b52ca04f770cc0b GIT binary patch literal 27547 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 TeQDY%wtzVvq;Wu4(Z_!Qh{kH; literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/urllib3/packages/backports/makefile.py b/venv/lib/python3.8/site-packages/urllib3/packages/backports/makefile.py new file mode 100644 index 0000000..b8fb215 --- /dev/null +++ b/venv/lib/python3.8/site-packages/urllib3/packages/backports/makefile.py @@ -0,0 +1,51 @@ +# -*- coding: utf-8 -*- +""" +backports.makefile +~~~~~~~~~~~~~~~~~~ + +Backports the Python 3 ``socket.makefile`` method for use with anything that +wants to create a "fake" socket object. +""" +import io +from socket import SocketIO + + +def backport_makefile( + self, mode="r", buffering=None, encoding=None, errors=None, newline=None +): + """ + Backport of ``socket.makefile`` from Python 3.5. + """ + if not set(mode) <= {"r", "w", "b"}: + raise ValueError("invalid mode %r (only r, w, b allowed)" % (mode,)) + writing = "w" in mode + reading = "r" in mode or not writing + assert reading or writing + binary = "b" in mode + rawmode = "" + if reading: + rawmode += "r" + if writing: + rawmode += "w" + raw = SocketIO(self, rawmode) + self._makefile_refs += 1 + if buffering is None: + buffering = -1 + if buffering < 0: + buffering = io.DEFAULT_BUFFER_SIZE + if buffering == 0: + if not binary: + raise ValueError("unbuffered streams must be binary") + return raw + if reading and writing: + buffer = io.BufferedRWPair(raw, raw, buffering) + elif reading: + buffer = io.BufferedReader(raw, buffering) + else: + assert writing + buffer = io.BufferedWriter(raw, buffering) + if binary: + return buffer + text = io.TextIOWrapper(buffer, encoding, errors, newline) + text.mode = mode + return text diff --git a/venv/lib/python3.8/site-packages/urllib3/packages/six.py b/venv/lib/python3.8/site-packages/urllib3/packages/six.py new file mode 100644 index 0000000..ba50acb --- /dev/null +++ b/venv/lib/python3.8/site-packages/urllib3/packages/six.py @@ -0,0 +1,1077 @@ +# 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 +# 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. + +"""Utilities for writing code that runs on Python 2 and 3""" + +from __future__ import absolute_import + +import functools +import itertools +import operator +import sys +import types + +__author__ = "Benjamin Peterson " +__version__ = "1.16.0" + + +# Useful for very coarse version differentiation. +PY2 = sys.version_info[0] == 2 +PY3 = sys.version_info[0] == 3 +PY34 = sys.version_info[0:2] >= (3, 4) + +if PY3: + string_types = (str,) + integer_types = (int,) + class_types = (type,) + text_type = str + binary_type = bytes + + MAXSIZE = sys.maxsize +else: + string_types = (basestring,) + integer_types = (int, long) + class_types = (type, types.ClassType) + text_type = unicode + binary_type = str + + if sys.platform.startswith("java"): + # Jython always uses 32 bits. + MAXSIZE = int((1 << 31) - 1) + else: + # It's possible to have sizeof(long) != sizeof(Py_ssize_t). + class X(object): + def __len__(self): + return 1 << 31 + + try: + len(X()) + except OverflowError: + # 32-bit + MAXSIZE = int((1 << 31) - 1) + else: + # 64-bit + 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.""" + func.__doc__ = doc + + +def _import_module(name): + """Import module, returning the module after the last dot.""" + __import__(name) + return sys.modules[name] + + +class _LazyDescr(object): + def __init__(self, name): + self.name = name + + def __get__(self, obj, tp): + result = self._resolve() + setattr(obj, self.name, result) # Invokes __set__. + try: + # This is a bit ugly, but it avoids running this again by + # removing this descriptor. + delattr(obj.__class__, self.name) + except AttributeError: + pass + return result + + +class MovedModule(_LazyDescr): + def __init__(self, name, old, new=None): + super(MovedModule, self).__init__(name) + if PY3: + if new is None: + new = name + self.mod = new + else: + self.mod = old + + def _resolve(self): + return _import_module(self.mod) + + def __getattr__(self, attr): + _module = self._resolve() + value = getattr(_module, attr) + setattr(self, attr, value) + return value + + +class _LazyModule(types.ModuleType): + def __init__(self, name): + super(_LazyModule, self).__init__(name) + self.__doc__ = self.__class__.__doc__ + + def __dir__(self): + attrs = ["__doc__", "__name__"] + attrs += [attr.name for attr in self._moved_attributes] + return attrs + + # Subclasses should override this + _moved_attributes = [] + + +class MovedAttribute(_LazyDescr): + def __init__(self, name, old_mod, new_mod, old_attr=None, new_attr=None): + super(MovedAttribute, self).__init__(name) + if PY3: + if new_mod is None: + new_mod = name + self.mod = new_mod + if new_attr is None: + if old_attr is None: + new_attr = name + else: + new_attr = old_attr + self.attr = new_attr + else: + self.mod = old_mod + if old_attr is None: + old_attr = name + self.attr = old_attr + + def _resolve(self): + module = _import_module(self.mod) + return getattr(module, self.attr) + + +class _SixMetaPathImporter(object): + + """ + A meta path importer to import six.moves and its submodules. + + This class implements a PEP302 finder and loader. It should be compatible + with Python 2.5 and all existing versions of Python3 + """ + + def __init__(self, six_module_name): + self.name = six_module_name + self.known_modules = {} + + def _add_module(self, mod, *fullnames): + for fullname in fullnames: + self.known_modules[self.name + "." + fullname] = mod + + def _get_module(self, fullname): + return self.known_modules[self.name + "." + fullname] + + def find_module(self, fullname, path=None): + if fullname in self.known_modules: + 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] + except KeyError: + raise ImportError("This loader does not know module " + fullname) + + def load_module(self, fullname): + try: + # in case of a reload + return sys.modules[fullname] + except KeyError: + pass + mod = self.__get_module(fullname) + if isinstance(mod, MovedModule): + mod = mod._resolve() + else: + mod.__loader__ = self + sys.modules[fullname] = mod + return mod + + def is_package(self, fullname): + """ + Return true, if the named module is a package. + + We need this method to get correct spec objects with + Python 3.4 (see PEP451) + """ + return hasattr(self.__get_module(fullname), "__path__") + + def get_code(self, fullname): + """Return None + + Required, if is_package is implemented""" + self.__get_module(fullname) # eventually raises ImportError + 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__) + + +class _MovedItems(_LazyModule): + + """Lazy loading of moved objects""" + + __path__ = [] # mark as package + + +_moved_attributes = [ + MovedAttribute("cStringIO", "cStringIO", "io", "StringIO"), + MovedAttribute("filter", "itertools", "builtins", "ifilter", "filter"), + MovedAttribute( + "filterfalse", "itertools", "itertools", "ifilterfalse", "filterfalse" + ), + MovedAttribute("input", "__builtin__", "builtins", "raw_input", "input"), + MovedAttribute("intern", "__builtin__", "sys"), + MovedAttribute("map", "itertools", "builtins", "imap", "map"), + MovedAttribute("getcwd", "os", "os", "getcwdu", "getcwd"), + MovedAttribute("getcwdb", "os", "os", "getcwd", "getcwdb"), + MovedAttribute("getoutput", "commands", "subprocess"), + MovedAttribute("range", "__builtin__", "builtins", "xrange", "range"), + MovedAttribute( + "reload_module", "__builtin__", "importlib" if PY34 else "imp", "reload" + ), + MovedAttribute("reduce", "__builtin__", "functools"), + MovedAttribute("shlex_quote", "pipes", "shlex", "quote"), + MovedAttribute("StringIO", "StringIO", "io"), + MovedAttribute("UserDict", "UserDict", "collections"), + MovedAttribute("UserList", "UserList", "collections"), + MovedAttribute("UserString", "UserString", "collections"), + MovedAttribute("xrange", "__builtin__", "builtins", "xrange", "range"), + MovedAttribute("zip", "itertools", "builtins", "izip", "zip"), + MovedAttribute( + "zip_longest", "itertools", "itertools", "izip_longest", "zip_longest" + ), + 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("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"), + MovedModule("html_parser", "HTMLParser", "html.parser"), + MovedModule("http_client", "httplib", "http.client"), + MovedModule("email_mime_base", "email.MIMEBase", "email.mime.base"), + MovedModule("email_mime_image", "email.MIMEImage", "email.mime.image"), + MovedModule("email_mime_multipart", "email.MIMEMultipart", "email.mime.multipart"), + MovedModule( + "email_mime_nonmultipart", "email.MIMENonMultipart", "email.mime.nonmultipart" + ), + MovedModule("email_mime_text", "email.MIMEText", "email.mime.text"), + MovedModule("BaseHTTPServer", "BaseHTTPServer", "http.server"), + MovedModule("CGIHTTPServer", "CGIHTTPServer", "http.server"), + MovedModule("SimpleHTTPServer", "SimpleHTTPServer", "http.server"), + MovedModule("cPickle", "cPickle", "pickle"), + MovedModule("queue", "Queue"), + MovedModule("reprlib", "repr"), + MovedModule("socketserver", "SocketServer"), + MovedModule("_thread", "thread", "_thread"), + MovedModule("tkinter", "Tkinter"), + MovedModule("tkinter_dialog", "Dialog", "tkinter.dialog"), + MovedModule("tkinter_filedialog", "FileDialog", "tkinter.filedialog"), + MovedModule("tkinter_scrolledtext", "ScrolledText", "tkinter.scrolledtext"), + MovedModule("tkinter_simpledialog", "SimpleDialog", "tkinter.simpledialog"), + MovedModule("tkinter_tix", "Tix", "tkinter.tix"), + MovedModule("tkinter_ttk", "ttk", "tkinter.ttk"), + MovedModule("tkinter_constants", "Tkconstants", "tkinter.constants"), + MovedModule("tkinter_dnd", "Tkdnd", "tkinter.dnd"), + MovedModule("tkinter_colorchooser", "tkColorChooser", "tkinter.colorchooser"), + MovedModule("tkinter_commondialog", "tkCommonDialog", "tkinter.commondialog"), + MovedModule("tkinter_tkfiledialog", "tkFileDialog", "tkinter.filedialog"), + MovedModule("tkinter_font", "tkFont", "tkinter.font"), + MovedModule("tkinter_messagebox", "tkMessageBox", "tkinter.messagebox"), + MovedModule("tkinter_tksimpledialog", "tkSimpleDialog", "tkinter.simpledialog"), + MovedModule("urllib_parse", __name__ + ".moves.urllib_parse", "urllib.parse"), + MovedModule("urllib_error", __name__ + ".moves.urllib_error", "urllib.error"), + MovedModule("urllib", __name__ + ".moves.urllib", __name__ + ".moves.urllib"), + MovedModule("urllib_robotparser", "robotparser", "urllib.robotparser"), + MovedModule("xmlrpc_client", "xmlrpclib", "xmlrpc.client"), + MovedModule("xmlrpc_server", "SimpleXMLRPCServer", "xmlrpc.server"), +] +# Add windows specific modules. +if sys.platform == "win32": + _moved_attributes += [ + MovedModule("winreg", "_winreg"), + ] + +for attr in _moved_attributes: + setattr(_MovedItems, attr.name, attr) + if isinstance(attr, MovedModule): + _importer._add_module(attr, "moves." + attr.name) +del attr + +_MovedItems._moved_attributes = _moved_attributes + +moves = _MovedItems(__name__ + ".moves") +_importer._add_module(moves, "moves") + + +class Module_six_moves_urllib_parse(_LazyModule): + + """Lazy loading of moved objects in six.moves.urllib_parse""" + + +_urllib_parse_moved_attributes = [ + MovedAttribute("ParseResult", "urlparse", "urllib.parse"), + MovedAttribute("SplitResult", "urlparse", "urllib.parse"), + MovedAttribute("parse_qs", "urlparse", "urllib.parse"), + MovedAttribute("parse_qsl", "urlparse", "urllib.parse"), + MovedAttribute("urldefrag", "urlparse", "urllib.parse"), + MovedAttribute("urljoin", "urlparse", "urllib.parse"), + MovedAttribute("urlparse", "urlparse", "urllib.parse"), + MovedAttribute("urlsplit", "urlparse", "urllib.parse"), + MovedAttribute("urlunparse", "urlparse", "urllib.parse"), + MovedAttribute("urlunsplit", "urlparse", "urllib.parse"), + MovedAttribute("quote", "urllib", "urllib.parse"), + MovedAttribute("quote_plus", "urllib", "urllib.parse"), + MovedAttribute("unquote", "urllib", "urllib.parse"), + MovedAttribute("unquote_plus", "urllib", "urllib.parse"), + MovedAttribute( + "unquote_to_bytes", "urllib", "urllib.parse", "unquote", "unquote_to_bytes" + ), + MovedAttribute("urlencode", "urllib", "urllib.parse"), + MovedAttribute("splitquery", "urllib", "urllib.parse"), + MovedAttribute("splittag", "urllib", "urllib.parse"), + MovedAttribute("splituser", "urllib", "urllib.parse"), + MovedAttribute("splitvalue", "urllib", "urllib.parse"), + MovedAttribute("uses_fragment", "urlparse", "urllib.parse"), + MovedAttribute("uses_netloc", "urlparse", "urllib.parse"), + MovedAttribute("uses_params", "urlparse", "urllib.parse"), + MovedAttribute("uses_query", "urlparse", "urllib.parse"), + MovedAttribute("uses_relative", "urlparse", "urllib.parse"), +] +for attr in _urllib_parse_moved_attributes: + setattr(Module_six_moves_urllib_parse, attr.name, attr) +del attr + +Module_six_moves_urllib_parse._moved_attributes = _urllib_parse_moved_attributes + +_importer._add_module( + Module_six_moves_urllib_parse(__name__ + ".moves.urllib_parse"), + "moves.urllib_parse", + "moves.urllib.parse", +) + + +class Module_six_moves_urllib_error(_LazyModule): + + """Lazy loading of moved objects in six.moves.urllib_error""" + + +_urllib_error_moved_attributes = [ + MovedAttribute("URLError", "urllib2", "urllib.error"), + MovedAttribute("HTTPError", "urllib2", "urllib.error"), + MovedAttribute("ContentTooShortError", "urllib", "urllib.error"), +] +for attr in _urllib_error_moved_attributes: + setattr(Module_six_moves_urllib_error, attr.name, attr) +del attr + +Module_six_moves_urllib_error._moved_attributes = _urllib_error_moved_attributes + +_importer._add_module( + Module_six_moves_urllib_error(__name__ + ".moves.urllib.error"), + "moves.urllib_error", + "moves.urllib.error", +) + + +class Module_six_moves_urllib_request(_LazyModule): + + """Lazy loading of moved objects in six.moves.urllib_request""" + + +_urllib_request_moved_attributes = [ + MovedAttribute("urlopen", "urllib2", "urllib.request"), + MovedAttribute("install_opener", "urllib2", "urllib.request"), + MovedAttribute("build_opener", "urllib2", "urllib.request"), + MovedAttribute("pathname2url", "urllib", "urllib.request"), + MovedAttribute("url2pathname", "urllib", "urllib.request"), + MovedAttribute("getproxies", "urllib", "urllib.request"), + MovedAttribute("Request", "urllib2", "urllib.request"), + MovedAttribute("OpenerDirector", "urllib2", "urllib.request"), + MovedAttribute("HTTPDefaultErrorHandler", "urllib2", "urllib.request"), + MovedAttribute("HTTPRedirectHandler", "urllib2", "urllib.request"), + MovedAttribute("HTTPCookieProcessor", "urllib2", "urllib.request"), + MovedAttribute("ProxyHandler", "urllib2", "urllib.request"), + MovedAttribute("BaseHandler", "urllib2", "urllib.request"), + MovedAttribute("HTTPPasswordMgr", "urllib2", "urllib.request"), + MovedAttribute("HTTPPasswordMgrWithDefaultRealm", "urllib2", "urllib.request"), + MovedAttribute("AbstractBasicAuthHandler", "urllib2", "urllib.request"), + MovedAttribute("HTTPBasicAuthHandler", "urllib2", "urllib.request"), + MovedAttribute("ProxyBasicAuthHandler", "urllib2", "urllib.request"), + MovedAttribute("AbstractDigestAuthHandler", "urllib2", "urllib.request"), + MovedAttribute("HTTPDigestAuthHandler", "urllib2", "urllib.request"), + MovedAttribute("ProxyDigestAuthHandler", "urllib2", "urllib.request"), + MovedAttribute("HTTPHandler", "urllib2", "urllib.request"), + MovedAttribute("HTTPSHandler", "urllib2", "urllib.request"), + MovedAttribute("FileHandler", "urllib2", "urllib.request"), + MovedAttribute("FTPHandler", "urllib2", "urllib.request"), + MovedAttribute("CacheFTPHandler", "urllib2", "urllib.request"), + MovedAttribute("UnknownHandler", "urllib2", "urllib.request"), + MovedAttribute("HTTPErrorProcessor", "urllib2", "urllib.request"), + MovedAttribute("urlretrieve", "urllib", "urllib.request"), + MovedAttribute("urlcleanup", "urllib", "urllib.request"), + MovedAttribute("URLopener", "urllib", "urllib.request"), + MovedAttribute("FancyURLopener", "urllib", "urllib.request"), + MovedAttribute("proxy_bypass", "urllib", "urllib.request"), + MovedAttribute("parse_http_list", "urllib2", "urllib.request"), + MovedAttribute("parse_keqv_list", "urllib2", "urllib.request"), +] +for attr in _urllib_request_moved_attributes: + setattr(Module_six_moves_urllib_request, attr.name, attr) +del attr + +Module_six_moves_urllib_request._moved_attributes = _urllib_request_moved_attributes + +_importer._add_module( + Module_six_moves_urllib_request(__name__ + ".moves.urllib.request"), + "moves.urllib_request", + "moves.urllib.request", +) + + +class Module_six_moves_urllib_response(_LazyModule): + + """Lazy loading of moved objects in six.moves.urllib_response""" + + +_urllib_response_moved_attributes = [ + MovedAttribute("addbase", "urllib", "urllib.response"), + MovedAttribute("addclosehook", "urllib", "urllib.response"), + MovedAttribute("addinfo", "urllib", "urllib.response"), + MovedAttribute("addinfourl", "urllib", "urllib.response"), +] +for attr in _urllib_response_moved_attributes: + setattr(Module_six_moves_urllib_response, attr.name, attr) +del attr + +Module_six_moves_urllib_response._moved_attributes = _urllib_response_moved_attributes + +_importer._add_module( + Module_six_moves_urllib_response(__name__ + ".moves.urllib.response"), + "moves.urllib_response", + "moves.urllib.response", +) + + +class Module_six_moves_urllib_robotparser(_LazyModule): + + """Lazy loading of moved objects in six.moves.urllib_robotparser""" + + +_urllib_robotparser_moved_attributes = [ + MovedAttribute("RobotFileParser", "robotparser", "urllib.robotparser"), +] +for attr in _urllib_robotparser_moved_attributes: + setattr(Module_six_moves_urllib_robotparser, attr.name, attr) +del attr + +Module_six_moves_urllib_robotparser._moved_attributes = ( + _urllib_robotparser_moved_attributes +) + +_importer._add_module( + Module_six_moves_urllib_robotparser(__name__ + ".moves.urllib.robotparser"), + "moves.urllib_robotparser", + "moves.urllib.robotparser", +) + + +class Module_six_moves_urllib(types.ModuleType): + + """Create a six.moves.urllib namespace that resembles the Python 3 namespace""" + + __path__ = [] # mark as package + parse = _importer._get_module("moves.urllib_parse") + error = _importer._get_module("moves.urllib_error") + request = _importer._get_module("moves.urllib_request") + response = _importer._get_module("moves.urllib_response") + robotparser = _importer._get_module("moves.urllib_robotparser") + + def __dir__(self): + return ["parse", "error", "request", "response", "robotparser"] + + +_importer._add_module( + Module_six_moves_urllib(__name__ + ".moves.urllib"), "moves.urllib" +) + + +def add_move(move): + """Add an item to six.moves.""" + setattr(_MovedItems, move.name, move) + + +def remove_move(name): + """Remove item from six.moves.""" + try: + delattr(_MovedItems, name) + except AttributeError: + try: + del moves.__dict__[name] + except KeyError: + raise AttributeError("no such move, %r" % (name,)) + + +if PY3: + _meth_func = "__func__" + _meth_self = "__self__" + + _func_closure = "__closure__" + _func_code = "__code__" + _func_defaults = "__defaults__" + _func_globals = "__globals__" +else: + _meth_func = "im_func" + _meth_self = "im_self" + + _func_closure = "func_closure" + _func_code = "func_code" + _func_defaults = "func_defaults" + _func_globals = "func_globals" + + +try: + advance_iterator = next +except NameError: + + def advance_iterator(it): + return it.next() + + +next = advance_iterator + + +try: + callable = callable +except NameError: + + def callable(obj): + return any("__call__" in klass.__dict__ for klass in type(obj).__mro__) + + +if PY3: + + def get_unbound_function(unbound): + return unbound + + create_bound_method = types.MethodType + + def create_unbound_method(func, cls): + return func + + Iterator = object +else: + + def get_unbound_function(unbound): + return unbound.im_func + + def create_bound_method(func, obj): + return types.MethodType(func, obj, obj.__class__) + + def create_unbound_method(func, cls): + return types.MethodType(func, None, cls) + + class Iterator(object): + def next(self): + return type(self).__next__(self) + + callable = callable +_add_doc( + get_unbound_function, """Get the function out of a possibly unbound function""" +) + + +get_method_function = operator.attrgetter(_meth_func) +get_method_self = operator.attrgetter(_meth_self) +get_function_closure = operator.attrgetter(_func_closure) +get_function_code = operator.attrgetter(_func_code) +get_function_defaults = operator.attrgetter(_func_defaults) +get_function_globals = operator.attrgetter(_func_globals) + + +if PY3: + + def iterkeys(d, **kw): + return iter(d.keys(**kw)) + + def itervalues(d, **kw): + return iter(d.values(**kw)) + + def iteritems(d, **kw): + return iter(d.items(**kw)) + + def iterlists(d, **kw): + return iter(d.lists(**kw)) + + viewkeys = operator.methodcaller("keys") + + viewvalues = operator.methodcaller("values") + + viewitems = operator.methodcaller("items") +else: + + def iterkeys(d, **kw): + return d.iterkeys(**kw) + + def itervalues(d, **kw): + return d.itervalues(**kw) + + def iteritems(d, **kw): + return d.iteritems(**kw) + + def iterlists(d, **kw): + return d.iterlists(**kw) + + viewkeys = operator.methodcaller("viewkeys") + + viewvalues = operator.methodcaller("viewvalues") + + viewitems = operator.methodcaller("viewitems") + +_add_doc(iterkeys, "Return an iterator over the keys of a dictionary.") +_add_doc(itervalues, "Return an iterator over the values of a dictionary.") +_add_doc(iteritems, "Return an iterator over the (key, value) pairs of a dictionary.") +_add_doc( + iterlists, "Return an iterator over the (key, [values]) pairs of a dictionary." +) + + +if PY3: + + def b(s): + return s.encode("latin-1") + + def u(s): + return s + + unichr = chr + import struct + + int2byte = struct.Struct(">B").pack + del struct + byte2int = operator.itemgetter(0) + indexbytes = operator.getitem + iterbytes = iter + import io + + StringIO = io.StringIO + BytesIO = io.BytesIO + del io + _assertCountEqual = "assertCountEqual" + if sys.version_info[1] <= 1: + _assertRaisesRegex = "assertRaisesRegexp" + _assertRegex = "assertRegexpMatches" + _assertNotRegex = "assertNotRegexpMatches" + else: + _assertRaisesRegex = "assertRaisesRegex" + _assertRegex = "assertRegex" + _assertNotRegex = "assertNotRegex" +else: + + def b(s): + return s + + # Workaround for standalone backslash + + def u(s): + return unicode(s.replace(r"\\", r"\\\\"), "unicode_escape") + + unichr = unichr + int2byte = chr + + def byte2int(bs): + return ord(bs[0]) + + def indexbytes(buf, i): + return ord(buf[i]) + + iterbytes = functools.partial(itertools.imap, ord) + import StringIO + + StringIO = BytesIO = StringIO.StringIO + _assertCountEqual = "assertItemsEqual" + _assertRaisesRegex = "assertRaisesRegexp" + _assertRegex = "assertRegexpMatches" + _assertNotRegex = "assertNotRegexpMatches" +_add_doc(b, """Byte literal""") +_add_doc(u, """Text literal""") + + +def assertCountEqual(self, *args, **kwargs): + return getattr(self, _assertCountEqual)(*args, **kwargs) + + +def assertRaisesRegex(self, *args, **kwargs): + return getattr(self, _assertRaisesRegex)(*args, **kwargs) + + +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") + + def reraise(tp, value, tb=None): + try: + if value is None: + value = tp() + if value.__traceback__ is not tb: + raise value.with_traceback(tb) + raise value + finally: + value = None + tb = None + + +else: + + def exec_(_code_, _globs_=None, _locs_=None): + """Execute code in a namespace.""" + if _globs_ is None: + frame = sys._getframe(1) + _globs_ = frame.f_globals + if _locs_ is None: + _locs_ = frame.f_locals + del frame + elif _locs_ is None: + _locs_ = _globs_ + exec ("""exec _code_ in _globs_, _locs_""") + + exec_( + """def reraise(tp, value, tb=None): + try: + raise tp, value, tb + finally: + tb = None +""" + ) + + +if sys.version_info[:2] > (3,): + exec_( + """def raise_from(value, from_value): + try: + raise value from from_value + finally: + value = None +""" + ) +else: + + def raise_from(value, from_value): + raise value + + +print_ = getattr(moves.builtins, "print", None) +if print_ is None: + + def print_(*args, **kwargs): + """The new-style print function for Python 2.4 and 2.5.""" + fp = kwargs.pop("file", sys.stdout) + if fp is None: + return + + def write(data): + if not isinstance(data, basestring): + data = str(data) + # If the file has an encoding, encode unicode with it. + if ( + isinstance(fp, file) + and isinstance(data, unicode) + and fp.encoding is not None + ): + errors = getattr(fp, "errors", None) + if errors is None: + errors = "strict" + data = data.encode(fp.encoding, errors) + fp.write(data) + + want_unicode = False + sep = kwargs.pop("sep", None) + if sep is not None: + if isinstance(sep, unicode): + want_unicode = True + elif not isinstance(sep, str): + raise TypeError("sep must be None or a string") + end = kwargs.pop("end", None) + if end is not None: + if isinstance(end, unicode): + want_unicode = True + elif not isinstance(end, str): + raise TypeError("end must be None or a string") + if kwargs: + raise TypeError("invalid keyword arguments to print()") + if not want_unicode: + for arg in args: + if isinstance(arg, unicode): + want_unicode = True + break + if want_unicode: + newline = unicode("\n") + space = unicode(" ") + else: + newline = "\n" + space = " " + if sep is None: + sep = space + if end is None: + end = newline + for i, arg in enumerate(args): + if i: + write(sep) + write(arg) + write(end) + + +if sys.version_info[:2] < (3, 3): + _print = print_ + + def print_(*args, **kwargs): + fp = kwargs.get("file", sys.stdout) + flush = kwargs.pop("flush", False) + _print(*args, **kwargs) + if flush and fp is not None: + fp.flush() + + +_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, + ): + return functools.partial( + _update_wrapper, wrapped=wrapped, assigned=assigned, updated=updated + ) + + wraps.__doc__ = functools.wraps.__doc__ + +else: + wraps = functools.wraps + + +def with_metaclass(meta, *bases): + """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(type): + def __new__(cls, name, this_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): + return meta.__prepare__(name, bases) + + return type.__new__(metaclass, "temporary_class", (), {}) + + +def add_metaclass(metaclass): + """Class decorator for creating a class with a metaclass.""" + + def wrapper(cls): + orig_vars = cls.__dict__.copy() + slots = orig_vars.get("__slots__") + if slots is not None: + if isinstance(slots, str): + slots = [slots] + for slots_var in slots: + orig_vars.pop(slots_var) + orig_vars.pop("__dict__", None) + orig_vars.pop("__weakref__", None) + if hasattr(cls, "__qualname__"): + orig_vars["__qualname__"] = cls.__qualname__ + return metaclass(cls.__name__, cls.__bases__, orig_vars) + + return wrapper + + +def ensure_binary(s, encoding="utf-8", errors="strict"): + """Coerce **s** to six.binary_type. + + For Python 2: + - `unicode` -> encoded to `str` + - `str` -> `str` + + For Python 3: + - `str` -> encoded to `bytes` + - `bytes` -> `bytes` + """ + if isinstance(s, binary_type): + return s + if isinstance(s, text_type): + return s.encode(encoding, errors) + raise TypeError("not expecting type '%s'" % type(s)) + + +def ensure_str(s, encoding="utf-8", errors="strict"): + """Coerce *s* to `str`. + + For Python 2: + - `unicode` -> encoded to `str` + - `str` -> `str` + + For Python 3: + - `str` -> `str` + - `bytes` -> decoded to `str` + """ + # Optimization: Fast return for the common case. + if type(s) is str: + return s + if PY2 and isinstance(s, text_type): + return s.encode(encoding, errors) + elif PY3 and isinstance(s, binary_type): + return s.decode(encoding, errors) + elif not isinstance(s, (text_type, binary_type)): + raise TypeError("not expecting type '%s'" % type(s)) + return s + + +def ensure_text(s, encoding="utf-8", errors="strict"): + """Coerce *s* to six.text_type. + + For Python 2: + - `unicode` -> `unicode` + - `str` -> `unicode` + + For Python 3: + - `str` -> `str` + - `bytes` -> decoded to `str` + """ + if isinstance(s, binary_type): + return s.decode(encoding, errors) + elif isinstance(s, text_type): + return s + else: + raise TypeError("not expecting type '%s'" % type(s)) + + +def python_2_unicode_compatible(klass): + """ + 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 + returning text and apply this decorator to the class. + """ + if PY2: + if "__str__" not in klass.__dict__: + raise ValueError( + "@python_2_unicode_compatible cannot be applied " + "to %s because it doesn't define __str__()." % klass.__name__ + ) + klass.__unicode__ = klass.__str__ + klass.__str__ = lambda self: self.__unicode__().encode("utf-8") + return klass + + +# Complete the moves implementation. +# This code is at the end of this module to speed up module loading. +# Turn this module into a package. +__path__ = [] # required for PEP 302 and PEP 451 +__package__ = __name__ # see PEP 366 @ReservedAssignment +if globals().get("__spec__") is not None: + __spec__.submodule_search_locations = [] # PEP 451 @UndefinedVariable +# Remove other six meta path importers, since they cause problems. This can +# happen if six is removed from sys.modules and then reloaded. (Setuptools does +# this for some reason.) +if sys.meta_path: + for i, importer in enumerate(sys.meta_path): + # Here's some real nastiness: Another "instance" of the six module might + # be floating around. Therefore, we can't use isinstance() to check for + # the six meta path importer, since the other six instance will have + # inserted an importer with different class. + if ( + type(importer).__name__ == "_SixMetaPathImporter" + and importer.name == __name__ + ): + del sys.meta_path[i] + break + del i, importer +# Finally, add the importer to the meta path import hook. +sys.meta_path.append(_importer) diff --git a/venv/lib/python3.8/site-packages/urllib3/packages/ssl_match_hostname/__init__.py b/venv/lib/python3.8/site-packages/urllib3/packages/ssl_match_hostname/__init__.py new file mode 100644 index 0000000..ef3fde5 --- /dev/null +++ b/venv/lib/python3.8/site-packages/urllib3/packages/ssl_match_hostname/__init__.py @@ -0,0 +1,24 @@ +import sys + +try: + # Our match_hostname function is the same as 3.10's, so we only want to + # import the match_hostname function if it's at least that good. + # We also fallback on Python 3.10+ because our code doesn't emit + # deprecation warnings and is the same as Python 3.10 otherwise. + if sys.version_info < (3, 5) or sys.version_info >= (3, 10): + 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/venv/lib/python3.8/site-packages/urllib3/packages/ssl_match_hostname/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/urllib3/packages/ssl_match_hostname/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..3cb3ca3d647fb28a753892c00a1026abe9704067 GIT binary patch literal 528 zcmZWk!D<^Z5FKfEZP#v`9QG10!G|{BgS~;A3?URk3%Qs=2u=4Q*48-QuC!VtIdyz0 zE%e+!=()eN*PiwldWsYmn$Qt?%rI}>yt&@n>w=5T^mX<#0Ql{Tr_po88~4o*2OKyN zkizx^;S=Gs0CV)11x2Kfk@D~x`AQrs5`hfUP)2D)-~*Ji5RevK{hfe++xU^wdd7M6 zm-A)E;Vq}q{>S(TCB1uQFn#jS3YU*=;*7opSCd52j6ho_q zcUW?zkq;M&S=w#-vXujl(`21P}F4i=O}h literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/urllib3/packages/ssl_match_hostname/__pycache__/_implementation.cpython-38.pyc b/venv/lib/python3.8/site-packages/urllib3/packages/ssl_match_hostname/__pycache__/_implementation.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..b4e5b83f5e3209ea9eb2c28188fe6138ed1cce52 GIT binary patch literal 3263 zcmZ`*&u`qg6&5LJMjnqRu90SwVh=>xY%{JslOIi*1npvt#95?B?KDoZt(#p{7C9cp z8c88J8+#xF#U=&z&;onz$vzg?^P+#sg4dpM?V*PrHvK4hyiU+cAVobsl8=w?eIFms z&9xjnyEiXH{WFg9Py2K73Gnj~iqfdKv*~ccX-YOp^`)D1(ym(Wru&JLo%I~y?X=_# z;@FqdP51XsMt|pUchmpa;U4#2IoubGm+oehpW;m(yds+cpW&@n&gKlCCR7n{b(rIDAMsT9Og=A(MVkEvcWiub&_XnAoCG>u&0M;U+v*tVnQjA=_E?o zi=oKaSS8su+t|3@dyQQ$)ZgLu*eMnpPN&az0LNyB&tl$5C4M{N0fa%vM$Z`J}H$MZZXj<#AR- z@s8ljFj1t-yIVVY_vX!_KbC2lY+dc!-e_B>zEWxU_U`*(GAdFr!X6{*f?lyFDVF%5 zwcIuWQvJWS+lgIN)5jjRHRd*o`WLEgXWuQcUAxE9Ilz$}l6|lAxO>jo_wmJ%{h6ZO zDE$M%8|ZD8&64hT^1i0LsWJK`c@O0aQa05eF^6~Pl*HCMIKI;7jU6g==^pqzI3&c$ zKEzB7K66Oam(Z(P@^7|ZHxGi+KO~jb*^`n31PGr!gl)tr8+V*fPwxlE{g~CtpMQh# zE#BsH2eYMn2%C84Jx4d6wGZk3OgVEfS3(abd1^BJjSVIn6Hy%JlG~Qf*~7cH+4aj; zt}QVo>d?C0`+4tbtHtmPwJvV;`#R54)k}mP^m4h~AL>!smxI_2`|;7J<$9DIbk~rc zw1*&V9<3R&I9b9B2E% zL#Q|^glR%Kjbb$7d{iWSv6Y{F5d6Y@+|*;B204l=cb z%JDsd*K3i0v?*$zlGYm!(s@5{+vK#r;GT5@vOwP_@;vlo>-_0s+dfJa{2!p95%QY6 zr1HF`&syp?tm=K68&Tag_mlhIK z*Eg*Ma05?gaHtDSRC~&_KNnIVSHmP5191u-yULLrI4lTVS48cuE8=L2@{ z0gE`77Bp3_j`nFPFtLl!iW8mgF`f&R{Zun921zDZl(8t?&Lx6r#0I%!dYGsxRW44` z=W_2Cy(?^)onIeoyU<3Q7vg-kS7~)UGm{iY3&Uwec+{?TXd2Qwxd6mAlEQ|9Y1*I* zlfuxXc-LX`kRJ`NvGOtepsZJ%V1dYM_`c;cn~t_rKKly-!(yNYxmg^WENF5-fo%A* z-UG2c@ZePt+x022?NbojEl4fh-G58^6G(kXvs$V_m^*2?*T)@nTi1c*CMOzP;m>1FZbrbj7cbMKzJXwd!}z|E*i4`;zdP9S=HB z^(=3dgwGzd^_=dY2S`1jXDU|6mX38PbpHh1c1cQ?&z*CQbpl8`*7p_VpNhITk|#nY zgFS>*q}igy$3=D#NXdmw9BxAn;J_lqq|jrTLA143MHYyDBL}tW-nP(%5Yi65*zMLq zFBGN}Y;g)1oF%496Nf5eXkrY@jwP?zh*cPJsWX@FGSq@v`SQNUp z?c@S=PQ815U|dN`TI_0&k{&XFN=SBl_2Hv%{lTMq>uW3b ztzsp3xcb}2_a3g^Su-6q-g*Y6TuJpB612)mwUd1qC@RF!FcOktm{-R zI=%`=m_j{4jH(m3&Lxbvh9!n8ddyckaw-q1G< zuS3pIJDa?VnY*OAz;xTD8HPNM!%+SJV!3E5>nbyQZ&c(`*Z!Fe!ztT^@|M-Hd{ukM vy0h|7HSvkPS&FOKKlo*Rk^ayUwmOT-^8*qzD9r4T7WLeDuXR0W1nvI 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/venv/lib/python3.8/site-packages/urllib3/poolmanager.py b/venv/lib/python3.8/site-packages/urllib3/poolmanager.py new file mode 100644 index 0000000..3a31a28 --- /dev/null +++ b/venv/lib/python3.8/site-packages/urllib3/poolmanager.py @@ -0,0 +1,536 @@ +from __future__ import absolute_import + +import collections +import functools +import logging + +from ._collections import RecentlyUsedContainer +from .connectionpool import HTTPConnectionPool, HTTPSConnectionPool, port_by_scheme +from .exceptions import ( + LocationValueError, + MaxRetryError, + ProxySchemeUnknown, + ProxySchemeUnsupported, + URLSchemeUnknown, +) +from .packages import six +from .packages.six.moves.urllib.parse import urljoin +from .request import RequestMethods +from .util.proxy import connection_requires_http_tunnel +from .util.retry import Retry +from .util.url import parse_url + +__all__ = ["PoolManager", "ProxyManager", "proxy_from_url"] + + +log = logging.getLogger(__name__) + +SSL_KEYWORDS = ( + "key_file", + "cert_file", + "cert_reqs", + "ca_certs", + "ssl_version", + "ca_cert_dir", + "ssl_context", + "key_password", +) + +# All known keyword arguments that could be provided to the pool manager, its +# pools, or the underlying connections. This is used to construct a pool key. +_key_fields = ( + "key_scheme", # str + "key_host", # str + "key_port", # int + "key_timeout", # int or float or Timeout + "key_retries", # int or Retry + "key_strict", # bool + "key_block", # bool + "key_source_address", # str + "key_key_file", # str + "key_key_password", # str + "key_cert_file", # str + "key_cert_reqs", # str + "key_ca_certs", # str + "key_ssl_version", # str + "key_ca_cert_dir", # str + "key_ssl_context", # instance of ssl.SSLContext or urllib3.util.ssl_.SSLContext + "key_maxsize", # int + "key_headers", # dict + "key__proxy", # parsed proxy url + "key__proxy_headers", # dict + "key__proxy_config", # class + "key_socket_options", # list of (level (int), optname (int), value (int or str)) tuples + "key__socks_options", # dict + "key_assert_hostname", # bool or string + "key_assert_fingerprint", # str + "key_server_hostname", # str +) + +#: The namedtuple class used to construct keys for the connection pool. +#: All custom key schemes should include the fields in this key at a minimum. +PoolKey = collections.namedtuple("PoolKey", _key_fields) + +_proxy_config_fields = ("ssl_context", "use_forwarding_for_https") +ProxyConfig = collections.namedtuple("ProxyConfig", _proxy_config_fields) + + +def _default_key_normalizer(key_class, request_context): + """ + Create a pool key out of a request context dictionary. + + According to RFC 3986, both the scheme and host are case-insensitive. + Therefore, this function normalizes both before constructing the pool + key for an HTTPS request. If you wish to change this behaviour, provide + alternate callables to ``key_fn_by_scheme``. + + :param key_class: + The class to use when constructing the key. This should be a namedtuple + with the ``scheme`` and ``host`` keys at a minimum. + :type key_class: namedtuple + :param request_context: + A dictionary-like object that contain the context for a request. + :type request_context: dict + + :return: A namedtuple that can be used as a connection pool key. + :rtype: PoolKey + """ + # Since we mutate the dictionary, make a copy first + context = request_context.copy() + context["scheme"] = context["scheme"].lower() + context["host"] = context["host"].lower() + + # These are both dictionaries and need to be transformed into frozensets + for key in ("headers", "_proxy_headers", "_socks_options"): + if key in context and context[key] is not None: + context[key] = frozenset(context[key].items()) + + # The socket_options key may be a list and needs to be transformed into a + # tuple. + socket_opts = context.get("socket_options") + if socket_opts is not None: + context["socket_options"] = tuple(socket_opts) + + # Map the kwargs to the names in the namedtuple - this is necessary since + # namedtuples can't have fields starting with '_'. + for key in list(context.keys()): + context["key_" + key] = context.pop(key) + + # Default to ``None`` for keys missing from the context + for field in key_class._fields: + if field not in context: + context[field] = None + + return key_class(**context) + + +#: A dictionary that maps a scheme to a callable that creates a pool key. +#: This can be used to alter the way pool keys are constructed, if desired. +#: Each PoolManager makes a copy of this dictionary so they can be configured +#: globally here, or individually on the instance. +key_fn_by_scheme = { + "http": functools.partial(_default_key_normalizer, PoolKey), + "https": functools.partial(_default_key_normalizer, PoolKey), +} + +pool_classes_by_scheme = {"http": HTTPConnectionPool, "https": HTTPSConnectionPool} + + +class PoolManager(RequestMethods): + """ + Allows for arbitrary requests while transparently keeping track of + necessary connection pools for you. + + :param num_pools: + Number of connection pools to cache before discarding the least + recently used pool. + + :param headers: + Headers to include with all requests, unless other headers are given + explicitly. + + :param \\**connection_pool_kw: + Additional parameters are used to create fresh + :class:`urllib3.connectionpool.ConnectionPool` instances. + + Example:: + + >>> manager = PoolManager(num_pools=2) + >>> r = manager.request('GET', 'http://google.com/') + >>> r = manager.request('GET', 'http://google.com/mail') + >>> r = manager.request('GET', 'http://yahoo.com/') + >>> len(manager.pools) + 2 + + """ + + proxy = None + proxy_config = None + + 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()) + + # Locally set the pool classes and keys so other PoolManagers can + # override them. + self.pool_classes_by_scheme = pool_classes_by_scheme + self.key_fn_by_scheme = key_fn_by_scheme.copy() + + def __enter__(self): + return self + + def __exit__(self, exc_type, exc_val, exc_tb): + self.clear() + # Return False to re-raise any potential exceptions + return False + + def _new_pool(self, scheme, host, port, request_context=None): + """ + Create a new :class:`urllib3.connectionpool.ConnectionPool` based on host, port, scheme, and + any additional pool keyword arguments. + + If ``request_context`` is provided, it is provided as keyword arguments + to the pool class used. This method is used to actually create the + connection pools handed out by :meth:`connection_from_url` and + companion methods. It is intended to be overridden for customization. + """ + pool_cls = self.pool_classes_by_scheme[scheme] + if request_context is None: + request_context = self.connection_pool_kw.copy() + + # Although the context has everything necessary to create the pool, + # this function has historically only used the scheme, host, and port + # in the positional args. When an API change is acceptable these can + # be removed. + for key in ("scheme", "host", "port"): + request_context.pop(key, None) + + if scheme == "http": + for kw in SSL_KEYWORDS: + request_context.pop(kw, None) + + return pool_cls(host, port, **request_context) + + def clear(self): + """ + Empty our store of pools and direct them all to close. + + This will not affect in-flight connections, but they will not be + re-used after completion. + """ + self.pools.clear() + + def connection_from_host(self, host, port=None, scheme="http", pool_kwargs=None): + """ + Get a :class:`urllib3.connectionpool.ConnectionPool` based on the host, port, and scheme. + + If ``port`` isn't given, it will be derived from the ``scheme`` using + ``urllib3.connectionpool.port_by_scheme``. If ``pool_kwargs`` is + provided, it is merged with the instance's ``connection_pool_kw`` + variable and used to create the new connection pool, if one is + needed. + """ + + if not host: + raise LocationValueError("No host specified.") + + request_context = self._merge_pool_kwargs(pool_kwargs) + request_context["scheme"] = scheme or "http" + if not port: + port = port_by_scheme.get(request_context["scheme"].lower(), 80) + request_context["port"] = port + request_context["host"] = host + + return self.connection_from_context(request_context) + + def connection_from_context(self, request_context): + """ + Get a :class:`urllib3.connectionpool.ConnectionPool` based on the request context. + + ``request_context`` must at least contain the ``scheme`` key and its + value must be a key in ``key_fn_by_scheme`` instance variable. + """ + scheme = request_context["scheme"].lower() + pool_key_constructor = self.key_fn_by_scheme.get(scheme) + if not pool_key_constructor: + raise URLSchemeUnknown(scheme) + pool_key = pool_key_constructor(request_context) + + return self.connection_from_pool_key(pool_key, request_context=request_context) + + def connection_from_pool_key(self, pool_key, request_context=None): + """ + Get a :class:`urllib3.connectionpool.ConnectionPool` based on the provided pool key. + + ``pool_key`` should be a namedtuple that only contains immutable + objects. At a minimum it must have the ``scheme``, ``host``, and + ``port`` fields. + """ + with self.pools.lock: + # If the scheme, host, or port doesn't match existing open + # connections, open a new ConnectionPool. + pool = self.pools.get(pool_key) + if pool: + return pool + + # Make a fresh ConnectionPool of the desired type + scheme = request_context["scheme"] + host = request_context["host"] + port = request_context["port"] + pool = self._new_pool(scheme, host, port, request_context=request_context) + self.pools[pool_key] = pool + + return pool + + def connection_from_url(self, url, pool_kwargs=None): + """ + Similar to :func:`urllib3.connectionpool.connection_from_url`. + + If ``pool_kwargs`` is not provided and a new pool needs to be + constructed, ``self.connection_pool_kw`` is used to initialize + the :class:`urllib3.connectionpool.ConnectionPool`. If ``pool_kwargs`` + is provided, it is used instead. Note that if a new pool does not + need to be created for the request, the provided ``pool_kwargs`` are + not used. + """ + u = parse_url(url) + return self.connection_from_host( + u.host, port=u.port, scheme=u.scheme, pool_kwargs=pool_kwargs + ) + + def _merge_pool_kwargs(self, override): + """ + Merge a dictionary of override values for self.connection_pool_kw. + + This does not modify self.connection_pool_kw and returns a new dict. + Any keys in the override dictionary with a value of ``None`` are + removed from the merged dictionary. + """ + base_pool_kwargs = self.connection_pool_kw.copy() + if override: + for key, value in override.items(): + if value is None: + try: + del base_pool_kwargs[key] + except KeyError: + pass + else: + base_pool_kwargs[key] = value + return base_pool_kwargs + + def _proxy_requires_url_absolute_form(self, parsed_url): + """ + Indicates if the proxy requires the complete destination URL in the + request. Normally this is only needed when not using an HTTP CONNECT + tunnel. + """ + if self.proxy is None: + return False + + return not connection_requires_http_tunnel( + self.proxy, self.proxy_config, parsed_url.scheme + ) + + def _validate_proxy_scheme_url_selection(self, url_scheme): + """ + Validates that were not attempting to do TLS in TLS connections on + Python2 or with unsupported SSL implementations. + """ + if self.proxy is None or url_scheme != "https": + return + + if self.proxy.scheme != "https": + return + + if six.PY2 and not self.proxy_config.use_forwarding_for_https: + raise ProxySchemeUnsupported( + "Contacting HTTPS destinations through HTTPS proxies " + "'via CONNECT tunnels' is not supported in Python 2" + ) + + def urlopen(self, method, url, redirect=True, **kw): + """ + Same as :meth:`urllib3.HTTPConnectionPool.urlopen` + with custom cross-host redirect logic and only sends the request-uri + portion of the ``url``. + + The given ``url`` parameter must be absolute, such that an appropriate + :class:`urllib3.connectionpool.ConnectionPool` can be chosen for it. + """ + u = parse_url(url) + self._validate_proxy_scheme_url_selection(u.scheme) + + conn = self.connection_from_host(u.host, port=u.port, scheme=u.scheme) + + kw["assert_same_host"] = False + kw["redirect"] = False + + if "headers" not in kw: + kw["headers"] = self.headers.copy() + + if self._proxy_requires_url_absolute_form(u): + response = conn.urlopen(method, url, **kw) + else: + response = conn.urlopen(method, u.request_uri, **kw) + + redirect_location = redirect and response.get_redirect_location() + if not redirect_location: + return response + + # Support relative URLs for redirecting. + redirect_location = urljoin(url, redirect_location) + + # RFC 7231, Section 6.4.4 + if response.status == 303: + method = "GET" + + retries = kw.get("retries") + if not isinstance(retries, Retry): + retries = Retry.from_int(retries, redirect=redirect) + + # Strip headers marked as unsafe to forward to the redirected location. + # Check remove_headers_on_redirect to avoid a potential network call within + # conn.is_same_host() which may use socket.gethostbyname() in the future. + if retries.remove_headers_on_redirect and not conn.is_same_host( + redirect_location + ): + headers = list(six.iterkeys(kw["headers"])) + for header in headers: + if header.lower() in retries.remove_headers_on_redirect: + kw["headers"].pop(header, None) + + try: + retries = retries.increment(method, url, response=response, _pool=conn) + except MaxRetryError: + if retries.raise_on_redirect: + response.drain_conn() + raise + return response + + kw["retries"] = retries + kw["redirect"] = redirect + + log.info("Redirecting %s -> %s", url, redirect_location) + + response.drain_conn() + return self.urlopen(method, redirect_location, **kw) + + +class ProxyManager(PoolManager): + """ + Behaves just like :class:`PoolManager`, but sends all requests through + the defined proxy, using the CONNECT method for HTTPS URLs. + + :param proxy_url: + The URL of the proxy to be used. + + :param proxy_headers: + A dictionary containing headers that will be sent to the proxy. In case + of HTTP they are being sent with each request, while in the + HTTPS/CONNECT case they are sent only once. Could be used for proxy + authentication. + + :param proxy_ssl_context: + The proxy SSL context is used to establish the TLS connection to the + proxy when using HTTPS proxies. + + :param use_forwarding_for_https: + (Defaults to False) If set to True will forward requests to the HTTPS + proxy to be made on behalf of the client instead of creating a TLS + tunnel via the CONNECT method. **Enabling this flag means that request + and response headers and content will be visible from the HTTPS proxy** + whereas tunneling keeps request and response headers and content + private. IP address, target hostname, SNI, and port are always visible + to an HTTPS proxy even when this flag is disabled. + + Example: + >>> proxy = urllib3.ProxyManager('http://localhost:3128/') + >>> r1 = proxy.request('GET', 'http://google.com/') + >>> r2 = proxy.request('GET', 'http://httpbin.org/') + >>> len(proxy.pools) + 1 + >>> r3 = proxy.request('GET', 'https://httpbin.org/') + >>> r4 = proxy.request('GET', 'https://twitter.com/') + >>> len(proxy.pools) + 3 + + """ + + def __init__( + self, + proxy_url, + num_pools=10, + headers=None, + proxy_headers=None, + proxy_ssl_context=None, + use_forwarding_for_https=False, + **connection_pool_kw + ): + + if isinstance(proxy_url, HTTPConnectionPool): + proxy_url = "%s://%s:%i" % ( + proxy_url.scheme, + proxy_url.host, + proxy_url.port, + ) + proxy = parse_url(proxy_url) + + if proxy.scheme not in ("http", "https"): + raise ProxySchemeUnknown(proxy.scheme) + + if not proxy.port: + port = port_by_scheme.get(proxy.scheme, 80) + proxy = proxy._replace(port=port) + + self.proxy = proxy + self.proxy_headers = proxy_headers or {} + self.proxy_ssl_context = proxy_ssl_context + self.proxy_config = ProxyConfig(proxy_ssl_context, use_forwarding_for_https) + + connection_pool_kw["_proxy"] = self.proxy + connection_pool_kw["_proxy_headers"] = self.proxy_headers + connection_pool_kw["_proxy_config"] = self.proxy_config + + super(ProxyManager, self).__init__(num_pools, headers, **connection_pool_kw) + + def connection_from_host(self, host, port=None, scheme="http", pool_kwargs=None): + if scheme == "https": + return super(ProxyManager, self).connection_from_host( + host, port, scheme, pool_kwargs=pool_kwargs + ) + + return super(ProxyManager, self).connection_from_host( + self.proxy.host, self.proxy.port, self.proxy.scheme, pool_kwargs=pool_kwargs + ) + + def _set_proxy_headers(self, url, headers=None): + """ + Sets headers needed by proxies: specifically, the Accept and Host + headers. Only sets headers not provided by the user. + """ + headers_ = {"Accept": "*/*"} + + netloc = parse_url(url).netloc + if netloc: + headers_["Host"] = netloc + + if headers: + headers_.update(headers) + return headers_ + + def urlopen(self, method, url, redirect=True, **kw): + "Same as HTTP(S)ConnectionPool.urlopen, ``url`` must be absolute." + u = parse_url(url) + if not connection_requires_http_tunnel(self.proxy, self.proxy_config, u.scheme): + # For connections using HTTP CONNECT, httplib sets the necessary + # headers on the CONNECT to the proxy. If we're not using CONNECT, + # we'll definitely need to set 'Host' at the very least. + headers = kw.get("headers", self.headers) + kw["headers"] = self._set_proxy_headers(url, headers) + + return super(ProxyManager, self).urlopen(method, url, redirect=redirect, **kw) + + +def proxy_from_url(url, **kw): + return ProxyManager(proxy_url=url, **kw) diff --git a/venv/lib/python3.8/site-packages/urllib3/request.py b/venv/lib/python3.8/site-packages/urllib3/request.py new file mode 100644 index 0000000..398386a --- /dev/null +++ b/venv/lib/python3.8/site-packages/urllib3/request.py @@ -0,0 +1,170 @@ +from __future__ import absolute_import + +from .filepost import encode_multipart_formdata +from .packages.six.moves.urllib.parse import urlencode + +__all__ = ["RequestMethods"] + + +class RequestMethods(object): + """ + Convenience mixin for classes who implement a :meth:`urlopen` method, such + as :class:`urllib3.HTTPConnectionPool` and + :class:`urllib3.PoolManager`. + + Provides behavior for making common types of HTTP request methods and + decides which type of request field encoding to use. + + Specifically, + + :meth:`.request_encode_url` is for sending requests whose fields are + encoded in the URL (such as GET, HEAD, DELETE). + + :meth:`.request_encode_body` is for sending requests whose fields are + encoded in the *body* of the request using multipart or www-form-urlencoded + (such as for POST, PUT, PATCH). + + :meth:`.request` is for making any kind of request, it will look up the + appropriate encoding format and use one of the above two methods to make + the request. + + Initializer parameters: + + :param headers: + Headers to include with all requests, unless other headers are given + explicitly. + """ + + _encode_url_methods = {"DELETE", "GET", "HEAD", "OPTIONS"} + + def __init__(self, headers=None): + self.headers = headers or {} + + def urlopen( + self, + method, + url, + body=None, + headers=None, + encode_multipart=True, + multipart_boundary=None, + **kw + ): # Abstract + raise NotImplementedError( + "Classes extending RequestMethods must implement " + "their own ``urlopen`` method." + ) + + def request(self, method, url, fields=None, headers=None, **urlopen_kw): + """ + Make a request using :meth:`urlopen` with the appropriate encoding of + ``fields`` based on the ``method`` used. + + This is a convenience method that requires the least amount of manual + effort. It can be used in most situations, while still having the + option to drop down to more specific methods when necessary, such as + :meth:`request_encode_url`, :meth:`request_encode_body`, + or even the lowest level :meth:`urlopen`. + """ + method = method.upper() + + urlopen_kw["request_url"] = url + + if method in self._encode_url_methods: + return self.request_encode_url( + method, url, fields=fields, headers=headers, **urlopen_kw + ) + else: + return self.request_encode_body( + method, url, fields=fields, headers=headers, **urlopen_kw + ) + + def request_encode_url(self, method, url, fields=None, headers=None, **urlopen_kw): + """ + Make a request using :meth:`urlopen` with the ``fields`` encoded in + the url. This is useful for request methods like GET, HEAD, DELETE, etc. + """ + if headers is None: + headers = self.headers + + extra_kw = {"headers": headers} + extra_kw.update(urlopen_kw) + + if fields: + url += "?" + urlencode(fields) + + return self.urlopen(method, url, **extra_kw) + + def request_encode_body( + self, + method, + url, + fields=None, + headers=None, + encode_multipart=True, + multipart_boundary=None, + **urlopen_kw + ): + """ + Make a request using :meth:`urlopen` with the ``fields`` encoded in + the body. This is useful for request methods like POST, PUT, PATCH, etc. + + When ``encode_multipart=True`` (default), then + :func:`urllib3.encode_multipart_formdata` is used to encode + the payload with the appropriate content type. Otherwise + :func:`urllib.parse.urlencode` is used with the + 'application/x-www-form-urlencoded' content type. + + Multipart encoding must be used when posting files, and it's reasonably + safe to use it in other times too. However, it may break request + signing, such as with OAuth. + + Supports an optional ``fields`` parameter of key/value strings AND + key/filetuple. A filetuple is a (filename, data, MIME type) tuple where + the MIME type is optional. For example:: + + fields = { + 'foo': 'bar', + 'fakefile': ('foofile.txt', 'contents of foofile'), + 'realfile': ('barfile.txt', open('realfile').read()), + 'typedfile': ('bazfile.bin', open('bazfile').read(), + 'image/jpeg'), + 'nonamefile': 'contents of nonamefile field', + } + + When uploading a file, providing a filename (the first parameter of the + tuple) is optional but recommended to best mimic behavior of browsers. + + Note that if ``headers`` are supplied, the 'Content-Type' header will + be overwritten because it depends on the dynamic random boundary string + which is used to compose the body of the request. The random boundary + string can be explicitly set with the ``multipart_boundary`` parameter. + """ + if headers is None: + headers = self.headers + + extra_kw = {"headers": {}} + + if fields: + if "body" in urlopen_kw: + raise TypeError( + "request got values for both 'fields' and 'body', can only specify one." + ) + + if encode_multipart: + body, content_type = encode_multipart_formdata( + fields, boundary=multipart_boundary + ) + else: + body, content_type = ( + urlencode(fields), + "application/x-www-form-urlencoded", + ) + + extra_kw["body"] = body + extra_kw["headers"] = {"Content-Type": content_type} + + extra_kw["headers"].update(headers) + extra_kw.update(urlopen_kw) + + return self.urlopen(method, url, **extra_kw) diff --git a/venv/lib/python3.8/site-packages/urllib3/response.py b/venv/lib/python3.8/site-packages/urllib3/response.py new file mode 100644 index 0000000..38693f4 --- /dev/null +++ b/venv/lib/python3.8/site-packages/urllib3/response.py @@ -0,0 +1,821 @@ +from __future__ import absolute_import + +import io +import logging +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 + +from ._collections import HTTPHeaderDict +from .connection import BaseSSLError, HTTPException +from .exceptions import ( + BodyNotHttplibCompatible, + DecodeError, + HTTPError, + IncompleteRead, + InvalidChunkLength, + InvalidHeader, + ProtocolError, + ReadTimeoutError, + ResponseNotChunked, + SSLError, +) +from .packages import six +from .util.response import is_fp_closed, is_response_to_head + +log = logging.getLogger(__name__) + + +class DeflateDecoder(object): + def __init__(self): + self._first_try = True + self._data = b"" + self._obj = zlib.decompressobj() + + def __getattr__(self, name): + return getattr(self._obj, name) + + def decompress(self, data): + if not data: + return data + + if not self._first_try: + return self._obj.decompress(data) + + self._data += data + try: + decompressed = self._obj.decompress(data) + if decompressed: + self._first_try = False + self._data = None + return decompressed + except zlib.error: + self._first_try = False + self._obj = zlib.decompressobj(-zlib.MAX_WBITS) + try: + return self.decompress(self._data) + finally: + self._data = None + + +class GzipDecoderState(object): + + FIRST_MEMBER = 0 + OTHER_MEMBERS = 1 + SWALLOW_DATA = 2 + + +class GzipDecoder(object): + def __init__(self): + self._obj = zlib.decompressobj(16 + zlib.MAX_WBITS) + self._state = GzipDecoderState.FIRST_MEMBER + + def __getattr__(self, name): + return getattr(self._obj, name) + + def decompress(self, data): + ret = bytearray() + if self._state == GzipDecoderState.SWALLOW_DATA or not data: + return bytes(ret) + while True: + try: + ret += self._obj.decompress(data) + except zlib.error: + previous_state = self._state + # Ignore data after the first error + self._state = GzipDecoderState.SWALLOW_DATA + if previous_state == GzipDecoderState.OTHER_MEMBERS: + # Allow trailing garbage acceptable in other gzip clients + return bytes(ret) + raise + data = self._obj.unused_data + if not data: + return bytes(ret) + self._state = GzipDecoderState.OTHER_MEMBERS + self._obj = zlib.decompressobj(16 + zlib.MAX_WBITS) + + +if brotli is not None: + + class BrotliDecoder(object): + # Supports both 'brotlipy' and 'Brotli' packages + # since they share an import name. The top branches + # are for 'brotlipy' and bottom branches for 'Brotli' + def __init__(self): + self._obj = brotli.Decompressor() + if hasattr(self._obj, "decompress"): + self.decompress = self._obj.decompress + else: + self.decompress = self._obj.process + + def flush(self): + if hasattr(self._obj, "flush"): + return self._obj.flush() + return b"" + + +class MultiDecoder(object): + """ + From RFC7231: + If one or more encodings have been applied to a representation, the + sender that applied the encodings MUST generate a Content-Encoding + header field that lists the content codings in the order in which + they were applied. + """ + + def __init__(self, modes): + self._decoders = [_get_decoder(m.strip()) for m in modes.split(",")] + + def flush(self): + return self._decoders[0].flush() + + def decompress(self, data): + for d in reversed(self._decoders): + data = d.decompress(data) + return data + + +def _get_decoder(mode): + if "," in mode: + return MultiDecoder(mode) + + if mode == "gzip": + return GzipDecoder() + + if brotli is not None and mode == "br": + return BrotliDecoder() + + return DeflateDecoder() + + +class HTTPResponse(io.IOBase): + """ + HTTP Response container. + + Backwards-compatible with :class:`http.client.HTTPResponse` but the response ``body`` is + loaded and decoded on-demand when the ``data`` property is accessed. This + class is also compatible with the Python standard library's :mod:`io` + module, and can hence be treated as a readable object in the context of that + framework. + + Extra parameters for behaviour not present in :class:`http.client.HTTPResponse`: + + :param preload_content: + If True, the response's body will be preloaded during construction. + + :param decode_content: + If True, will attempt to decode the body based on the + 'content-encoding' header. + + :param original_response: + When this HTTPResponse wrapper is generated from an :class:`http.client.HTTPResponse` + object, it's convenient to include the original for debug purposes. It's + otherwise unused. + + :param retries: + The retries contains the last :class:`~urllib3.util.retry.Retry` that + was used during the request. + + :param enforce_content_length: + Enforce content length checking. Body returned by server must match + value of Content-Length header, if present. Otherwise, raise error. + """ + + CONTENT_DECODERS = ["gzip", "deflate"] + if brotli is not None: + CONTENT_DECODERS += ["br"] + REDIRECT_STATUSES = [301, 302, 303, 307, 308] + + def __init__( + self, + body="", + headers=None, + status=0, + version=0, + reason=None, + strict=0, + preload_content=True, + decode_content=True, + original_response=None, + pool=None, + connection=None, + msg=None, + retries=None, + enforce_content_length=False, + request_method=None, + request_url=None, + auto_close=True, + ): + + if isinstance(headers, HTTPHeaderDict): + self.headers = headers + else: + self.headers = HTTPHeaderDict(headers) + self.status = status + self.version = version + self.reason = reason + self.strict = strict + self.decode_content = decode_content + self.retries = retries + self.enforce_content_length = enforce_content_length + self.auto_close = auto_close + + self._decoder = None + self._body = None + self._fp = None + self._original_response = original_response + self._fp_bytes_read = 0 + self.msg = msg + self._request_url = request_url + + if body and isinstance(body, (six.string_types, bytes)): + self._body = body + + self._pool = pool + self._connection = connection + + if hasattr(body, "read"): + self._fp = body + + # Are we using the chunked-style of transfer encoding? + self.chunked = False + self.chunk_left = None + tr_enc = self.headers.get("transfer-encoding", "").lower() + # Don't incur the penalty of creating a list and then discarding it + encodings = (enc.strip() for enc in tr_enc.split(",")) + if "chunked" in encodings: + self.chunked = True + + # Determine length of response + self.length_remaining = self._init_length(request_method) + + # If requested, preload the body. + if preload_content and not self._body: + self._body = self.read(decode_content=decode_content) + + def get_redirect_location(self): + """ + Should we redirect and where to? + + :returns: Truthy redirect location string if we got a redirect status + code and valid location. ``None`` if redirect status and no + location. ``False`` if not a redirect status code. + """ + if self.status in self.REDIRECT_STATUSES: + return self.headers.get("location") + + return False + + def release_conn(self): + if not self._pool or not self._connection: + return + + self._pool._put_conn(self._connection) + self._connection = None + + def drain_conn(self): + """ + Read and discard any remaining HTTP response data in the response connection. + + Unread data in the HTTPResponse connection blocks the connection from being released back to the pool. + """ + try: + self.read() + except (HTTPError, SocketError, BaseSSLError, HTTPException): + pass + + @property + def data(self): + # For backwards-compat with earlier urllib3 0.4 and earlier. + if self._body: + return self._body + + if self._fp: + return self.read(cache_content=True) + + @property + def connection(self): + return self._connection + + def isclosed(self): + return is_fp_closed(self._fp) + + def tell(self): + """ + Obtain the number of bytes pulled over the wire so far. May differ from + the amount of content returned by :meth:``urllib3.response.HTTPResponse.read`` + if bytes are encoded on the wire (e.g, compressed). + """ + return self._fp_bytes_read + + def _init_length(self, request_method): + """ + Set initial length value for Response content if available. + """ + length = self.headers.get("content-length") + + if length is not None: + if self.chunked: + # This Response will fail with an IncompleteRead if it can't be + # received as chunked. This method falls back to attempt reading + # the response before raising an exception. + log.warning( + "Received response with both Content-Length and " + "Transfer-Encoding set. This is expressly forbidden " + "by RFC 7230 sec 3.3.2. Ignoring Content-Length and " + "attempting to process response as Transfer-Encoding: " + "chunked." + ) + return None + + try: + # RFC 7230 section 3.3.2 specifies multiple content lengths can + # be sent in a single Content-Length header + # (e.g. Content-Length: 42, 42). This line ensures the values + # are all valid ints and that as long as the `set` length is 1, + # all values are the same. Otherwise, the header is invalid. + lengths = set([int(val) for val in length.split(",")]) + if len(lengths) > 1: + raise InvalidHeader( + "Content-Length contained multiple " + "unmatching values (%s)" % length + ) + length = lengths.pop() + except ValueError: + length = None + else: + if length < 0: + length = None + + # Convert status to int for comparison + # In some cases, httplib returns a status of "_UNKNOWN" + try: + status = int(self.status) + except ValueError: + status = 0 + + # Check for responses that shouldn't include a body + if status in (204, 304) or 100 <= status < 200 or request_method == "HEAD": + length = 0 + + return length + + def _init_decoder(self): + """ + Set-up the _decoder attribute if necessary. + """ + # Note: content-encoding value should be case-insensitive, per RFC 7230 + # Section 3.2 + content_encoding = self.headers.get("content-encoding", "").lower() + if self._decoder is None: + if content_encoding in self.CONTENT_DECODERS: + self._decoder = _get_decoder(content_encoding) + elif "," in content_encoding: + encodings = [ + e.strip() + for e in content_encoding.split(",") + if e.strip() in self.CONTENT_DECODERS + ] + if len(encodings): + self._decoder = _get_decoder(content_encoding) + + DECODER_ERROR_CLASSES = (IOError, zlib.error) + if brotli is not None: + DECODER_ERROR_CLASSES += (brotli.error,) + + def _decode(self, data, decode_content, flush_decoder): + """ + Decode the data passed in and potentially flush the decoder. + """ + if not decode_content: + return data + + try: + if self._decoder: + data = self._decoder.decompress(data) + except self.DECODER_ERROR_CLASSES as e: + content_encoding = self.headers.get("content-encoding", "").lower() + raise DecodeError( + "Received response with content-encoding: %s, but " + "failed to decode it." % content_encoding, + e, + ) + if flush_decoder: + data += self._flush_decoder() + + return data + + def _flush_decoder(self): + """ + Flushes the decoder. Should only be called if the decoder is actually + being used. + """ + if self._decoder: + buf = self._decoder.decompress(b"") + return buf + self._decoder.flush() + + return b"" + + @contextmanager + def _error_catcher(self): + """ + Catch low-level python exceptions, instead re-raising urllib3 + variants, so that low-level exceptions are not leaked in the + high-level api. + + On exit, release the connection back to the pool. + """ + clean_exit = False + + try: + try: + yield + + except SocketTimeout: + # FIXME: Ideally we'd like to include the url in the ReadTimeoutError but + # there is yet no clean way to get at it from this context. + raise ReadTimeoutError(self._pool, None, "Read timed out.") + + except BaseSSLError as e: + # FIXME: Is there a better way to differentiate between SSLErrors? + if "read operation timed out" not in str(e): + # SSL errors related to framing/MAC get wrapped and reraised here + raise SSLError(e) + + raise ReadTimeoutError(self._pool, None, "Read timed out.") + + except (HTTPException, SocketError) as e: + # This includes IncompleteRead. + raise ProtocolError("Connection broken: %r" % e, e) + + # If no exception is thrown, we should avoid cleaning up + # unnecessarily. + clean_exit = True + finally: + # If we didn't terminate cleanly, we need to throw away our + # connection. + if not clean_exit: + # The response may not be closed but we're not going to use it + # anymore so close it now to ensure that the connection is + # released back to the pool. + if self._original_response: + self._original_response.close() + + # Closing the response may not actually be sufficient to close + # everything, so if we have a hold of the connection close that + # too. + if self._connection: + self._connection.close() + + # If we hold the original response but it's closed now, we should + # return the connection back to the pool. + if self._original_response and self._original_response.isclosed(): + self.release_conn() + + def read(self, amt=None, decode_content=None, cache_content=False): + """ + Similar to :meth:`http.client.HTTPResponse.read`, but with two additional + parameters: ``decode_content`` and ``cache_content``. + + :param amt: + How much of the content to read. If specified, caching is skipped + because it doesn't make sense to cache partial content as the full + response. + + :param decode_content: + If True, will attempt to decode the body based on the + 'content-encoding' header. + + :param cache_content: + If True, will save the returned data such that the same result is + returned despite of the state of the underlying file object. This + is useful if you want the ``.data`` property to continue working + after having ``.read()`` the file object. (Overridden if ``amt`` is + set.) + """ + self._init_decoder() + if decode_content is None: + decode_content = self.decode_content + + if self._fp is None: + return + + flush_decoder = False + fp_closed = getattr(self._fp, "closed", False) + + with self._error_catcher(): + 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. + # Close the connection when no data is returned + # + # This is redundant to what httplib/http.client _should_ + # already do. However, versions of python released before + # December 15, 2012 (http://bugs.python.org/issue16298) do + # not properly close the connection in all cases. There is + # no harm in redundantly calling close. + self._fp.close() + flush_decoder = True + if self.enforce_content_length and self.length_remaining not in ( + 0, + None, + ): + # This is an edge case that httplib failed to cover due + # to concerns of backward compatibility. We're + # addressing it here to make sure IncompleteRead is + # raised during streaming, so all calls with incorrect + # Content-Length are caught. + raise IncompleteRead(self._fp_bytes_read, self.length_remaining) + + if data: + self._fp_bytes_read += len(data) + if self.length_remaining is not None: + self.length_remaining -= len(data) + + data = self._decode(data, decode_content, flush_decoder) + + if cache_content: + self._body = data + + return data + + def stream(self, amt=2 ** 16, decode_content=None): + """ + A generator wrapper for the read() method. A call will block until + ``amt`` bytes have been read from the connection or until the + connection is closed. + + :param amt: + How much of the content to read. The generator will return up to + much data per iteration, but may return less. This is particularly + likely when using compressed data. However, the empty string will + never be returned. + + :param decode_content: + If True, will attempt to decode the body based on the + 'content-encoding' header. + """ + if self.chunked and self.supports_chunked_reads(): + for line in self.read_chunked(amt, decode_content=decode_content): + yield line + else: + while not is_fp_closed(self._fp): + data = self.read(amt=amt, decode_content=decode_content) + + if data: + yield data + + @classmethod + def from_httplib(ResponseCls, r, **response_kw): + """ + Given an :class:`http.client.HTTPResponse` instance ``r``, return a + corresponding :class:`urllib3.response.HTTPResponse` object. + + Remaining parameters are passed to the HTTPResponse constructor, along + with ``original_response=r``. + """ + headers = r.msg + + if not isinstance(headers, HTTPHeaderDict): + if six.PY2: + # Python 2.7 + headers = HTTPHeaderDict.from_httplib(headers) + else: + headers = HTTPHeaderDict(headers.items()) + + # HTTPResponse objects in Python 3 don't have a .strict attribute + strict = getattr(r, "strict", 0) + resp = ResponseCls( + body=r, + headers=headers, + status=r.status, + version=r.version, + reason=r.reason, + strict=strict, + original_response=r, + **response_kw + ) + return resp + + # Backwards-compatibility methods for http.client.HTTPResponse + def getheaders(self): + return self.headers + + def getheader(self, name, default=None): + return self.headers.get(name, default) + + # Backwards compatibility for http.cookiejar + def info(self): + return self.headers + + # Overrides from io.IOBase + def close(self): + if not self.closed: + self._fp.close() + + if self._connection: + self._connection.close() + + if not self.auto_close: + io.IOBase.close(self) + + @property + def closed(self): + if not self.auto_close: + return io.IOBase.closed.__get__(self) + elif self._fp is None: + return True + elif hasattr(self._fp, "isclosed"): + return self._fp.isclosed() + elif hasattr(self._fp, "closed"): + return self._fp.closed + else: + return True + + def fileno(self): + if self._fp is None: + raise IOError("HTTPResponse has no file to get a fileno from") + elif hasattr(self._fp, "fileno"): + return self._fp.fileno() + else: + raise IOError( + "The file-like object this HTTPResponse is wrapped " + "around has no file descriptor" + ) + + def flush(self): + if ( + self._fp is not None + and hasattr(self._fp, "flush") + and not getattr(self._fp, "closed", False) + ): + return self._fp.flush() + + def readable(self): + # This method is required for `io` module compatibility. + return True + + def readinto(self, b): + # This method is required for `io` module compatibility. + temp = self.read(len(b)) + if len(temp) == 0: + return 0 + else: + b[: len(temp)] = temp + return len(temp) + + def supports_chunked_reads(self): + """ + Checks if the underlying file-like object looks like a + :class:`http.client.HTTPResponse` object. We do this by testing for + the fp attribute. If it is present we assume it returns raw chunks as + processed by read_chunked(). + """ + return hasattr(self._fp, "fp") + + def _update_chunk_length(self): + # First, we'll figure out length of a chunk and then + # we'll try to read it from socket. + if self.chunk_left is not None: + return + line = self._fp.fp.readline() + line = line.split(b";", 1)[0] + try: + self.chunk_left = int(line, 16) + except ValueError: + # Invalid chunked protocol response, abort. + self.close() + raise InvalidChunkLength(self, line) + + def _handle_chunk(self, amt): + returned_chunk = None + if amt is None: + chunk = self._fp._safe_read(self.chunk_left) + returned_chunk = chunk + self._fp._safe_read(2) # Toss the CRLF at the end of the chunk. + self.chunk_left = None + elif amt < self.chunk_left: + value = self._fp._safe_read(amt) + self.chunk_left = self.chunk_left - amt + returned_chunk = value + elif amt == self.chunk_left: + value = self._fp._safe_read(amt) + self._fp._safe_read(2) # Toss the CRLF at the end of the chunk. + self.chunk_left = None + returned_chunk = value + else: # amt > self.chunk_left + returned_chunk = self._fp._safe_read(self.chunk_left) + self._fp._safe_read(2) # Toss the CRLF at the end of the chunk. + self.chunk_left = None + return returned_chunk + + def read_chunked(self, amt=None, decode_content=None): + """ + Similar to :meth:`HTTPResponse.read`, but with an additional + parameter: ``decode_content``. + + :param amt: + How much of the content to read. If specified, caching is skipped + because it doesn't make sense to cache partial content as the full + response. + + :param decode_content: + If True, will attempt to decode the body based on the + 'content-encoding' header. + """ + self._init_decoder() + # FIXME: Rewrite this method and make it a class with a better structured logic. + if not self.chunked: + raise ResponseNotChunked( + "Response is not chunked. " + "Header 'transfer-encoding: chunked' is missing." + ) + if not self.supports_chunked_reads(): + raise BodyNotHttplibCompatible( + "Body should be http.client.HTTPResponse like. " + "It should have have an fp attribute which returns raw chunks." + ) + + with self._error_catcher(): + # Don't bother reading the body of a HEAD request. + if self._original_response and is_response_to_head(self._original_response): + self._original_response.close() + return + + # If a response is already read and closed + # then return immediately. + if self._fp.fp is None: + return + + while True: + self._update_chunk_length() + if self.chunk_left == 0: + break + chunk = self._handle_chunk(amt) + decoded = self._decode( + chunk, decode_content=decode_content, flush_decoder=False + ) + if decoded: + yield decoded + + if decode_content: + # On CPython and PyPy, we should never need to flush the + # decoder. However, on Jython we *might* need to, so + # lets defensively do it anyway. + decoded = self._flush_decoder() + if decoded: # Platform-specific: Jython. + yield decoded + + # Chunk content ends with \r\n: discard it. + while True: + line = self._fp.fp.readline() + if not line: + # Some sites may not end with '\r\n'. + break + if line == b"\r\n": + break + + # We read everything; close the "file". + if self._original_response: + self._original_response.close() + + def geturl(self): + """ + Returns the URL that was the source of this response. + If the request that generated this response redirected, this method + will return the final redirect location. + """ + if self.retries is not None and len(self.retries.history): + return self.retries.history[-1].redirect_location + else: + return self._request_url + + def __iter__(self): + buffer = [] + for chunk in self.stream(decode_content=True): + if b"\n" in chunk: + chunk = chunk.split(b"\n") + yield b"".join(buffer) + chunk[0] + b"\n" + for x in chunk[1:-1]: + yield x + b"\n" + if chunk[-1]: + buffer = [chunk[-1]] + else: + buffer = [] + else: + buffer.append(chunk) + if buffer: + yield b"".join(buffer) diff --git a/venv/lib/python3.8/site-packages/urllib3/util/__init__.py b/venv/lib/python3.8/site-packages/urllib3/util/__init__.py new file mode 100644 index 0000000..4547fc5 --- /dev/null +++ b/venv/lib/python3.8/site-packages/urllib3/util/__init__.py @@ -0,0 +1,49 @@ +from __future__ import absolute_import + +# For backwards compatibility, provide imports that used to be here. +from .connection import is_connection_dropped +from .request import SKIP_HEADER, SKIPPABLE_HEADERS, make_headers +from .response import is_fp_closed +from .retry import Retry +from .ssl_ import ( + ALPN_PROTOCOLS, + HAS_SNI, + IS_PYOPENSSL, + IS_SECURETRANSPORT, + PROTOCOL_TLS, + SSLContext, + assert_fingerprint, + resolve_cert_reqs, + resolve_ssl_version, + ssl_wrap_socket, +) +from .timeout import Timeout, current_time +from .url import Url, get_host, parse_url, split_first +from .wait import wait_for_read, wait_for_write + +__all__ = ( + "HAS_SNI", + "IS_PYOPENSSL", + "IS_SECURETRANSPORT", + "SSLContext", + "PROTOCOL_TLS", + "ALPN_PROTOCOLS", + "Retry", + "Timeout", + "Url", + "assert_fingerprint", + "current_time", + "is_connection_dropped", + "is_fp_closed", + "get_host", + "parse_url", + "make_headers", + "resolve_cert_reqs", + "resolve_ssl_version", + "split_first", + "ssl_wrap_socket", + "wait_for_read", + "wait_for_write", + "SKIP_HEADER", + "SKIPPABLE_HEADERS", +) diff --git a/venv/lib/python3.8/site-packages/urllib3/util/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/urllib3/util/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..04312453008190153bd7de4922afda33857ae2f8 GIT binary patch literal 1061 zcmZ9L%Wl&^6o&2GoQrc$+w@8c0?CUKBvz3SB9ut2h>|Ey7tChl#?#j7jBRGdO}gf3 z*z+{AWz|<;#T5d8aObnroc;)jNB_$D=& ziA>Y*Gk%t4SQcf|c8=y)9_3j96_|yrG?%AERzjt;U7%%FL6x*^QJYm!mDNy<)lr=_ zP=hs5leJKbwNaaOP={@yEw+ue)A2>R!@8);cF}Gcm*^hbNBism9k4@m$d1ranlIC5 z>=+%h6Lg~E3VQC_uHjT4b>)U*s=9Y2BAQ5o0~SYIKAP+NRv_>q3PZAxK@?)2M{!Ji zC#x#%=Zh&m9}YeZXQ~OobntOB{F8B&&AdB;Z;9stSb6D9K8ymL~+^5?=@54dF2lLaCaZXo>d(FQA8$uR^t-QbJICuM5>0RULvQ z_hKxf#T}7OMp^TKktmVMUL>58P-3YQPEKVnIaS3QBJph`q$a|+XsIuD6weF2Z5T$b9;zpISF!m_L z_`AVh>HZYI`aQ|wUL3@yNf>+jK>gF@Eg|%Db#*6K{eIlj%hTZMZ7-1l?O_~*`lRsd g_(2ulvB*y-c@IB>05k2ZZFWpszi;e@*)I z-OLOviCFd`4tm$3k09Ly=ym%9eT=>Bm0uw!(0((!`f(6+iCNB^ojG&lzhWA>YLkv8#Vi7wG){4di> zbOryH*d==TmDyjRR@Z2)zJ@GD%gmR8p-7^sWPUhF6D~WTtvpUffee#)E8v1{aGvnj zR57LyyJ7LUx7QYO6661g^!o%05+F|AIc9LhoQ4gi0RU+cloUw$Qg4T*Y;Dg6AodQyvS_<5Nb$F_F8BjFLEJBc(D41))5F zl9U87C1N+3MwAS(CrSjP?Yd^NmIgeS=yPkDpg6CMqCkkX!LF2PdlZE%mhFeV-q!sy z?gNqx_i$0krISduMqnk9MuCK3CW1uaJ|pXCx}lAH6XHRlgD{Fn5FG?Zf^aQA84Naq zNU*_x$V5vJF{yPqWkq%&fAofKoQ;kkSG+?c4`KlwAYybxa5I^Twq}z%0xsL^^mgC{ z{lLLh8BSO-l`T83?l2ih$$1SQx$+sD?kEFt1%tmEyotZ>etBC?(%Wg6-kQc~fEb{+ z4t5!fZXFKy<>9@1>Fp_xqHy^0+fx}vx6d8WPLJ}pLgAlN{L&u{@D(d~8TE$gnT{To z)ij$XUj}vLsBh(?2n!fGpzgr;neoD!JM&8B93!w!OnwD31lEZ;cc?vgrS-~~S7%L7 zZR(turt!>(uOp-!gw%^7q-5pTl~oEJZyT==h$ohdFjGM$z2jQuWR z+qsu{FDmoeygpx;H|C4Dr8(3 z|MwBH1?1_#hAc^{kQ_vs!HqI>Zx9VxCK)f_Buc!L-wCjPL6I;PGJxQk$B+Rbj3DgU z1iTe~lGB_4g&vJb4AY!l1i*@Enj!&Eh2Mh5PLvFTh)^~TrV)@@0E$2g&9E>flFsmm ztSMuy4GNRCfw%Hdd1jzx!X;CckM#97L^91p=oE&ZOiFPTCZcVE@$G=RhqI$a+ka`v@+&c8#dq1{ac_63L=S z=xd&ImHi;SUX{ufhrctwm|0(Z*~y)d#=-2pYafbhH%Sx>SwxiWj}$|hBqU1Wo!L)R zEY9UGJRext(sSuD!+L}SD)5$ zUM(HLRdUOlZ~9%W6%5aAbd)D@M|mK(!6|o3ZEb)!w}Nr*sT1-jWqBp#iA?g^D2S2F zg9*zm5$K$rn@lJ5;(mV9Ny0xlyAe+Afs$=nw!DFNvg40LYT#fq};woM!`UaYS21N$UOyt_;+{%nS zL0+)%!H}>E42ga3==Nfq;XA?~|}dJ20eVhYB?s zkrx8%CPCpu_9;B~tHQ(W^-X`f)7{#*ub3+Ao+cI)ea%6)3@PJ)>x2a4L8pt15b)8i zuJ*%3?vh7aFYoHSipd?|XOwU%+AW8_3ytzBu6Weh=;hwS^{)SD>koJH+S#owlee(x z`{sKKvI(Y=<(EBMb>(VCpMzyj7DCWnQ=yxlsn?5K=LqLP!XP= z;QP#8Tl=_mIj{Tvc!~y>`94<|(xUZO%4Vz0P9+gVCR2F^DREdR=c!ID*kPi`dyeYY zb&FRtd#b16@2Qu9s78hMtrmdaRkU+W^i1ap?~_SFrxE+LGNjg~VR=@=YCw-=+q>eJ QmTCQ`{u|Hp7QFZW2Z`#QjsO4v literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/urllib3/util/__pycache__/proxy.cpython-38.pyc b/venv/lib/python3.8/site-packages/urllib3/util/__pycache__/proxy.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..c982450e4ecb6f00c1ee39e59801297e037dff51 GIT binary patch literal 1305 zcmYjROKTKC5bo)DWb+bVNDhLH5Og8gl_)|)REV#GtRb$KMHo8Mz1d0TWp_`qk?|C- z{s%q!m*(opzaU1f>X{_l&^6Wd{JN`Z-Y+jN5LnaARsK960xmkWnyu=N@cL4=c# z)EPM`9nsVsxegI?!WG^ZXXJ^F@I?TeFX%hco&V*4OV_P$L`rfa!%`(lyn8>4^32Go zsjn!h^W;#5kyIvB@}sV=or$zg!b7QaoM(dwF`O;rDeNuS`T>v%FdcN%66UO^a1W?j zu{_x)!h_Sj%E7%46y?GPYyp1?;1(FH9cfCHX*N`)Wbv4piDZB-+9BV7_a@vYA_p$^Cn5_gwob$ z8^dhn**M;7eE|p@F5ImJ!UJikxJ5WtdCH1BPg0)oJ*j%d@hlK+6cbXLIJ4%VjwUjd z7a@mm-$r%@Y{t6B?#4aICdL$c&3@LHG*Q=pr92+66;G(9JgBLtqRsPDM@}Lo4UR5zbfo*{`VHs9e~d-Y{+j193vtM&*C= zz7vO3*n;k-5B3#b$xK2evBRKFV_qhvDL#W4z*6I^U}NSP6oTvQj$yk}W@vO63n|#{ zF*czM2G6c~mV;s}&J0mKe=%fNlbnmN&1HvAcYTFJrSM`3N35QMRNNS)F2SiAs3p`a zqoxz_#;IOxxlqJvv~+&phBvue@V0~v!GBG?(*6&c;v>k`a22%rCJ-`5oxlnH20m@8 zK~JgI`9p&aRo6h@bq9k%LxS4F5Dk8W-dqCfW=&_ZV=E~Oq4PM+MVZJa_>0n)fn3L{ L6Y_82cJuuY>8Whi literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/urllib3/util/__pycache__/queue.cpython-38.pyc b/venv/lib/python3.8/site-packages/urllib3/util/__pycache__/queue.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..2abe015b65960f5249113ad265c51ee538b3d31d GIT binary patch literal 1016 zcmZ`&O>fgc5Zw>kanhu%3j72PJ|saPAw@!{5=dN71gbdT%PP%oiqo~@tZfKYZp{yA zj`>S_<>Vq-bJFwyyTuJWemaK_jl3b7-9Y@?AO&40LX_+jt!unDHL*v7@5wl*Q z^vqJRBc=i~X-LAv-31t%&0^!26n-3yMNiYluLC2NW<>$?7ngbm;9M|q1X7N}mxy0psz G7V^K1kMP%YbXJ{Y3#_B!FxA2j`bjJ` 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 L9CQ7T{IC84dq;Qa literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/urllib3/util/__pycache__/retry.cpython-38.pyc b/venv/lib/python3.8/site-packages/urllib3/util/__pycache__/retry.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..d7fce50e7a542216f221ef41ee482a2e1ba34b0b GIT binary patch literal 15804 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 Q8AA4#|6bfShK-^B0m(irS^xk5 literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/urllib3/util/__pycache__/ssltransport.cpython-38.pyc b/venv/lib/python3.8/site-packages/urllib3/util/__pycache__/ssltransport.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..1b717b3a6816f0420501619b92b688bb6a62c0bb GIT binary patch literal 7406 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 MS|x0JMKkpO0zu~ToB#j- literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/urllib3/util/__pycache__/timeout.cpython-38.pyc b/venv/lib/python3.8/site-packages/urllib3/util/__pycache__/timeout.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..768d79ee4e377fd8ae44231114125a721c88ed85 GIT binary patch literal 8903 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 KVfL9x)BZou2Azli literal 0 HcmV?d00001 diff --git a/venv/lib/python3.8/site-packages/urllib3/util/__pycache__/wait.cpython-38.pyc b/venv/lib/python3.8/site-packages/urllib3/util/__pycache__/wait.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..2625f220e75d3c83c2b54c662c4e2984c5ecc118 GIT binary patch literal 3063 zcmc&$OK%iM5bo}I?y|NQW6aATlSq(Egl$3~kt2eL5JpI79brd?Rg}qiyVoA??99^B z>z8H|30rv_f^vzJBhHO~lk;4234ei8s(NgLSDbRm*!`&P-tMZezN+r8M@FgyzOA`S z;nZnD{zl==&jsN&lxV&9bFUs%6$>(6ZR*noX0EojOQHY<2CXP02DzJd+5g zQ^ zf^N$DG4^Xg@T4Ec<;)8rPrzzjy}B{0y1m(6)SK=ny%1F6)0=BT#M4_V9kn$#*PHFj zIF436neD46o<$93dfWQAQB;LNDjw_(v zE*-F>s^~6^o*@IaQ!O=FCX2)*iYa5=Y%`$RZm;tPENCW&a!%G z?Nho+1|}3Mr}A=cKBqa^rS`7G?%vSeQEOEWJ$$qb*x&0%q(@-D-dfTjIKH7(8gV zbUOrdF8v3R_|e@qsHupSw~($S*JwIFJzPa zb|kp9X4EYCG0eB19DRrBZvjSh);P-8B$uqD+VRtq$4Ga@+BIyIjL%=0?l?%<-EQ0<&m33pDLD< zbqWa+NCP+Uc}R|iDpTXN@)mv!H})cdyVqC*K0rD%8=5=wOTJZx8hW9Ox6v<^lF>?E zm0>9-a7LqibOn`oj|Xevh6pxO*@==>%@2vnA!CTi0O2|vr!JG9f_%&tw9$Z~F~+SG z*###m8nR>pbw^v|l(IlJl^rs)FsIK-)@p@)M{leBSBwn-SvYH97J?b2Z5XZ+0hQOV zI&Oyi490$dQtEBn)P_*EnMw7`vFi%;K1#26mnw`eeX;xs$oj_4kIQh|W*)o`bkYM{ zJe7JY;x#`YCwif`8f}QgE3?f^)r0S$P<@$X9;QhzYI|x;9L#%BrZ+=&UGZS&c?hnf zH3zq_C$@T#6ujJQ37!`o=%+*GMQI5zQpXcU(J%%W($Aoj>@)wn(U_P2Pot0Wgq%Y& zKYxp@4vhW&+E(9~pNCf%R#g8_$g}t>ynqTL+s=wgyPvcaTtZoSHDRJJZ~hbayS-E% zybPTn2qC6}qH=euC3-4K6P*c)+J=xBNbnp2USMj|7l@{ANlOe6%{GaSkf`As9@2c( vY1qA4J`ZnUGRQ7Nh1U~gGR7d*M(H>_66)vSsbITjs;8>> make_headers(keep_alive=True, user_agent="Batman/1.0") + {'connection': 'keep-alive', 'user-agent': 'Batman/1.0'} + >>> make_headers(accept_encoding=True) + {'accept-encoding': 'gzip,deflate'} + """ + headers = {} + if accept_encoding: + if isinstance(accept_encoding, str): + pass + elif isinstance(accept_encoding, list): + accept_encoding = ",".join(accept_encoding) + else: + accept_encoding = ACCEPT_ENCODING + headers["accept-encoding"] = accept_encoding + + if user_agent: + headers["user-agent"] = user_agent + + if keep_alive: + headers["connection"] = "keep-alive" + + if basic_auth: + headers["authorization"] = "Basic " + b64encode(b(basic_auth)).decode("utf-8") + + if proxy_basic_auth: + headers["proxy-authorization"] = "Basic " + b64encode( + b(proxy_basic_auth) + ).decode("utf-8") + + if disable_cache: + headers["cache-control"] = "no-cache" + + return headers + + +def set_file_position(body, pos): + """ + If a position is provided, move file to that point. + Otherwise, we'll attempt to record a position for future use. + """ + if pos is not None: + rewind_body(body, pos) + elif getattr(body, "tell", None) is not None: + try: + pos = body.tell() + except (IOError, OSError): + # This differentiates from None, allowing us to catch + # a failed `tell()` later when trying to rewind the body. + pos = _FAILEDTELL + + return pos + + +def rewind_body(body, body_pos): + """ + Attempt to rewind body to a certain position. + Primarily used for request redirects and retries. + + :param body: + File-like object that supports seek. + + :param int pos: + Position to seek to in file. + """ + body_seek = getattr(body, "seek", None) + if body_seek is not None and isinstance(body_pos, integer_types): + try: + body_seek(body_pos) + except (IOError, OSError): + raise UnrewindableBodyError( + "An error occurred when rewinding request body for redirect/retry." + ) + elif body_pos is _FAILEDTELL: + raise UnrewindableBodyError( + "Unable to record file position for rewinding " + "request body during a redirect/retry." + ) + else: + raise ValueError( + "body_pos must be of type integer, instead it was %s." % type(body_pos) + ) diff --git a/venv/lib/python3.8/site-packages/urllib3/util/response.py b/venv/lib/python3.8/site-packages/urllib3/util/response.py new file mode 100644 index 0000000..5ea609c --- /dev/null +++ b/venv/lib/python3.8/site-packages/urllib3/util/response.py @@ -0,0 +1,107 @@ +from __future__ import absolute_import + +from email.errors import MultipartInvariantViolationDefect, StartBoundaryNotFoundDefect + +from ..exceptions import HeaderParsingError +from ..packages.six.moves import http_client as httplib + + +def is_fp_closed(obj): + """ + Checks whether a given file-like object is closed. + + :param obj: + The file-like object to check. + """ + + try: + # Check `isclosed()` first, in case Python3 doesn't set `closed`. + # GH Issue #928 + return obj.isclosed() + except AttributeError: + pass + + try: + # Check via the official file-like-object way. + return obj.closed + except AttributeError: + pass + + try: + # Check if the object is a container for another file-like object that + # gets released on exhaustion (e.g. HTTPResponse). + return obj.fp is None + except AttributeError: + pass + + raise ValueError("Unable to determine whether fp is closed.") + + +def assert_header_parsing(headers): + """ + Asserts whether all headers have been successfully parsed. + Extracts encountered errors from the result of parsing headers. + + Only works on Python 3. + + :param http.client.HTTPMessage headers: Headers to verify. + + :raises urllib3.exceptions.HeaderParsingError: + If parsing errors are found. + """ + + # This will fail silently if we pass in the wrong kind of parameter. + # To make debugging easier add an explicit check. + if not isinstance(headers, httplib.HTTPMessage): + raise TypeError("expected httplib.Message, got {0}.".format(type(headers))) + + defects = getattr(headers, "defects", None) + get_payload = getattr(headers, "get_payload", None) + + unparsed_data = None + if get_payload: + # get_payload is actually email.message.Message.get_payload; + # we're only interested in the result if it's not a multipart message + if not headers.is_multipart(): + payload = get_payload() + + if isinstance(payload, (bytes, str)): + unparsed_data = payload + if defects: + # httplib is assuming a response body is available + # when parsing headers even when httplib only sends + # header data to parse_headers() This results in + # defects on multipart responses in particular. + # See: https://github.com/urllib3/urllib3/issues/800 + + # So we ignore the following defects: + # - StartBoundaryNotFoundDefect: + # The claimed start boundary was never found. + # - MultipartInvariantViolationDefect: + # A message claimed to be a multipart but no subparts were found. + defects = [ + defect + for defect in defects + if not isinstance( + defect, (StartBoundaryNotFoundDefect, MultipartInvariantViolationDefect) + ) + ] + + if defects or unparsed_data: + raise HeaderParsingError(defects=defects, unparsed_data=unparsed_data) + + +def is_response_to_head(response): + """ + Checks whether the request of a response has been a HEAD-request. + Handles the quirks of AppEngine. + + :param http.client.HTTPResponse response: + Response to check if the originating request + used 'HEAD' as a method. + """ + # FIXME: Can we do this somehow without accessing private httplib _method? + method = response._method + if isinstance(method, int): # Platform-specific: Appengine + return method == 3 + return method.upper() == "HEAD" diff --git a/venv/lib/python3.8/site-packages/urllib3/util/retry.py b/venv/lib/python3.8/site-packages/urllib3/util/retry.py new file mode 100644 index 0000000..c7dc42f --- /dev/null +++ b/venv/lib/python3.8/site-packages/urllib3/util/retry.py @@ -0,0 +1,602 @@ +from __future__ import absolute_import + +import email +import logging +import re +import time +import warnings +from collections import namedtuple +from itertools import takewhile + +from ..exceptions import ( + ConnectTimeoutError, + InvalidHeader, + MaxRetryError, + ProtocolError, + ProxyError, + ReadTimeoutError, + ResponseError, +) +from ..packages import six + +log = logging.getLogger(__name__) + + +# Data structure for representing the metadata of requests that result in a retry. +RequestHistory = namedtuple( + "RequestHistory", ["method", "url", "error", "status", "redirect_location"] +) + + +# TODO: In v2 we can remove this sentinel and metaclass with deprecated options. +_Default = object() + + +class _RetryMeta(type): + @property + def DEFAULT_METHOD_WHITELIST(cls): + warnings.warn( + "Using 'Retry.DEFAULT_METHOD_WHITELIST' is deprecated and " + "will be removed in v2.0. Use 'Retry.DEFAULT_ALLOWED_METHODS' instead", + DeprecationWarning, + ) + return cls.DEFAULT_ALLOWED_METHODS + + @DEFAULT_METHOD_WHITELIST.setter + def DEFAULT_METHOD_WHITELIST(cls, value): + warnings.warn( + "Using 'Retry.DEFAULT_METHOD_WHITELIST' is deprecated and " + "will be removed in v2.0. Use 'Retry.DEFAULT_ALLOWED_METHODS' instead", + DeprecationWarning, + ) + cls.DEFAULT_ALLOWED_METHODS = value + + @property + def DEFAULT_REDIRECT_HEADERS_BLACKLIST(cls): + warnings.warn( + "Using 'Retry.DEFAULT_REDIRECT_HEADERS_BLACKLIST' is deprecated and " + "will be removed in v2.0. Use 'Retry.DEFAULT_REMOVE_HEADERS_ON_REDIRECT' instead", + DeprecationWarning, + ) + return cls.DEFAULT_REMOVE_HEADERS_ON_REDIRECT + + @DEFAULT_REDIRECT_HEADERS_BLACKLIST.setter + def DEFAULT_REDIRECT_HEADERS_BLACKLIST(cls, value): + warnings.warn( + "Using 'Retry.DEFAULT_REDIRECT_HEADERS_BLACKLIST' is deprecated and " + "will be removed in v2.0. Use 'Retry.DEFAULT_REMOVE_HEADERS_ON_REDIRECT' instead", + DeprecationWarning, + ) + cls.DEFAULT_REMOVE_HEADERS_ON_REDIRECT = value + + +@six.add_metaclass(_RetryMeta) +class Retry(object): + """Retry configuration. + + Each retry attempt will create a new Retry object with updated values, so + they can be safely reused. + + Retries can be defined as a default for a pool:: + + retries = Retry(connect=5, read=2, redirect=5) + http = PoolManager(retries=retries) + response = http.request('GET', 'http://example.com/') + + Or per-request (which overrides the default for the pool):: + + response = http.request('GET', 'http://example.com/', retries=Retry(10)) + + Retries can be disabled by passing ``False``:: + + response = http.request('GET', 'http://example.com/', retries=False) + + Errors will be wrapped in :class:`~urllib3.exceptions.MaxRetryError` unless + retries are disabled, in which case the causing exception will be raised. + + :param int total: + Total number of retries to allow. Takes precedence over other counts. + + Set to ``None`` to remove this constraint and fall back on other + counts. + + Set to ``0`` to fail on the first retry. + + Set to ``False`` to disable and imply ``raise_on_redirect=False``. + + :param int connect: + How many connection-related errors to retry on. + + These are errors raised before the request is sent to the remote server, + which we assume has not triggered the server to process the request. + + Set to ``0`` to fail on the first retry of this type. + + :param int read: + How many times to retry on read errors. + + These errors are raised after the request was sent to the server, so the + request may have side-effects. + + Set to ``0`` to fail on the first retry of this type. + + :param int redirect: + How many redirects to perform. Limit this to avoid infinite redirect + loops. + + A redirect is a HTTP response with a status code 301, 302, 303, 307 or + 308. + + Set to ``0`` to fail on the first retry of this type. + + Set to ``False`` to disable and imply ``raise_on_redirect=False``. + + :param int status: + How many times to retry on bad status codes. + + These are retries made on responses, where status code matches + ``status_forcelist``. + + Set to ``0`` to fail on the first retry of this type. + + :param int other: + How many times to retry on other errors. + + Other errors are errors that are not connect, read, redirect or status errors. + These errors might be raised after the request was sent to the server, so the + request might have side-effects. + + Set to ``0`` to fail on the first retry of this type. + + If ``total`` is not set, it's a good idea to set this to 0 to account + for unexpected edge cases and avoid infinite retry loops. + + :param iterable allowed_methods: + Set of uppercased HTTP method verbs that we should retry on. + + By default, we only retry on methods which are considered to be + idempotent (multiple requests with the same parameters end with the + same state). See :attr:`Retry.DEFAULT_ALLOWED_METHODS`. + + Set to a ``False`` value to retry on any verb. + + .. warning:: + + Previously this parameter was named ``method_whitelist``, that + usage is deprecated in v1.26.0 and will be removed in v2.0. + + :param iterable status_forcelist: + A set of integer HTTP status codes that we should force a retry on. + A retry is initiated if the request method is in ``allowed_methods`` + and the response status code is in ``status_forcelist``. + + By default, this is disabled with ``None``. + + :param float backoff_factor: + A backoff factor to apply between attempts after the second try + (most errors are resolved immediately by a second try without a + delay). urllib3 will sleep for:: + + {backoff factor} * (2 ** ({number of total retries} - 1)) + + 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`. + + By default, backoff is disabled (set to 0). + + :param bool raise_on_redirect: Whether, if the number of redirects is + exhausted, to raise a MaxRetryError, or to return a response with a + response code in the 3xx range. + + :param bool raise_on_status: Similar meaning to ``raise_on_redirect``: + whether we should raise an exception, or return a response, + if status falls in ``status_forcelist`` range and retries have + been exhausted. + + :param tuple history: The history of the request encountered during + each call to :meth:`~Retry.increment`. The list is in the order + the requests occurred. Each list item is of class :class:`RequestHistory`. + + :param bool respect_retry_after_header: + Whether to respect Retry-After header on status codes defined as + :attr:`Retry.RETRY_AFTER_STATUS_CODES` or not. + + :param iterable remove_headers_on_redirect: + Sequence of headers to remove from the request when a response + indicating a redirect is returned before firing off the redirected + request. + """ + + #: Default methods to be used for ``allowed_methods`` + DEFAULT_ALLOWED_METHODS = frozenset( + ["HEAD", "GET", "PUT", "DELETE", "OPTIONS", "TRACE"] + ) + + #: Default status codes to be used for ``status_forcelist`` + RETRY_AFTER_STATUS_CODES = frozenset([413, 429, 503]) + + #: Default headers to be used for ``remove_headers_on_redirect`` + DEFAULT_REMOVE_HEADERS_ON_REDIRECT = frozenset(["Authorization"]) + + #: Maximum backoff time. + BACKOFF_MAX = 120 + + def __init__( + self, + total=10, + connect=None, + read=None, + redirect=None, + status=None, + other=None, + allowed_methods=_Default, + status_forcelist=None, + backoff_factor=0, + raise_on_redirect=True, + raise_on_status=True, + history=None, + respect_retry_after_header=True, + remove_headers_on_redirect=_Default, + # TODO: Deprecated, remove in v2.0 + method_whitelist=_Default, + ): + + if method_whitelist is not _Default: + if allowed_methods is not _Default: + raise ValueError( + "Using both 'allowed_methods' and " + "'method_whitelist' together is not allowed. " + "Instead only use 'allowed_methods'" + ) + warnings.warn( + "Using 'method_whitelist' with Retry is deprecated and " + "will be removed in v2.0. Use 'allowed_methods' instead", + DeprecationWarning, + stacklevel=2, + ) + allowed_methods = method_whitelist + if allowed_methods is _Default: + allowed_methods = self.DEFAULT_ALLOWED_METHODS + if remove_headers_on_redirect is _Default: + remove_headers_on_redirect = self.DEFAULT_REMOVE_HEADERS_ON_REDIRECT + + self.total = total + self.connect = connect + self.read = read + self.status = status + self.other = other + + if redirect is False or total is False: + redirect = 0 + raise_on_redirect = False + + self.redirect = redirect + self.status_forcelist = status_forcelist or set() + self.allowed_methods = allowed_methods + self.backoff_factor = backoff_factor + self.raise_on_redirect = raise_on_redirect + self.raise_on_status = raise_on_status + self.history = history or tuple() + self.respect_retry_after_header = respect_retry_after_header + self.remove_headers_on_redirect = frozenset( + [h.lower() for h in remove_headers_on_redirect] + ) + + def new(self, **kw): + params = dict( + total=self.total, + connect=self.connect, + read=self.read, + redirect=self.redirect, + status=self.status, + other=self.other, + status_forcelist=self.status_forcelist, + backoff_factor=self.backoff_factor, + raise_on_redirect=self.raise_on_redirect, + raise_on_status=self.raise_on_status, + history=self.history, + remove_headers_on_redirect=self.remove_headers_on_redirect, + respect_retry_after_header=self.respect_retry_after_header, + ) + + # TODO: If already given in **kw we use what's given to us + # If not given we need to figure out what to pass. We decide + # based on whether our class has the 'method_whitelist' property + # and if so we pass the deprecated 'method_whitelist' otherwise + # we use 'allowed_methods'. Remove in v2.0 + if "method_whitelist" not in kw and "allowed_methods" not in kw: + if "method_whitelist" in self.__dict__: + warnings.warn( + "Using 'method_whitelist' with Retry is deprecated and " + "will be removed in v2.0. Use 'allowed_methods' instead", + DeprecationWarning, + ) + params["method_whitelist"] = self.allowed_methods + else: + params["allowed_methods"] = self.allowed_methods + + params.update(kw) + return type(self)(**params) + + @classmethod + def from_int(cls, retries, redirect=True, default=None): + """Backwards-compatibility for the old retries format.""" + if retries is None: + retries = default if default is not None else cls.DEFAULT + + if isinstance(retries, Retry): + return retries + + redirect = bool(redirect) and None + new_retries = cls(retries, redirect=redirect) + log.debug("Converted retries value: %r -> %r", retries, new_retries) + return new_retries + + def get_backoff_time(self): + """Formula for computing the current backoff + + :rtype: float + """ + # We want to consider only the last consecutive errors sequence (Ignore redirects). + consecutive_errors_len = len( + list( + takewhile(lambda x: x.redirect_location is None, reversed(self.history)) + ) + ) + if consecutive_errors_len <= 1: + return 0 + + backoff_value = self.backoff_factor * (2 ** (consecutive_errors_len - 1)) + return min(self.BACKOFF_MAX, backoff_value) + + def parse_retry_after(self, retry_after): + # Whitespace: https://tools.ietf.org/html/rfc7230#section-3.2.4 + if re.match(r"^\s*[0-9]+\s*$", retry_after): + seconds = int(retry_after) + else: + retry_date_tuple = email.utils.parsedate_tz(retry_after) + if retry_date_tuple is None: + raise InvalidHeader("Invalid Retry-After header: %s" % retry_after) + if retry_date_tuple[9] is None: # Python 2 + # Assume UTC if no timezone was specified + # On Python2.7, parsedate_tz returns None for a timezone offset + # instead of 0 if no timezone is given, where mktime_tz treats + # a None timezone offset as local time. + retry_date_tuple = retry_date_tuple[:9] + (0,) + retry_date_tuple[10:] + + retry_date = email.utils.mktime_tz(retry_date_tuple) + seconds = retry_date - time.time() + + if seconds < 0: + seconds = 0 + + return seconds + + def get_retry_after(self, response): + """Get the value of Retry-After in seconds.""" + + retry_after = response.getheader("Retry-After") + + if retry_after is None: + return None + + return self.parse_retry_after(retry_after) + + def sleep_for_retry(self, response=None): + retry_after = self.get_retry_after(response) + if retry_after: + time.sleep(retry_after) + return True + + return False + + def _sleep_backoff(self): + backoff = self.get_backoff_time() + if backoff <= 0: + return + time.sleep(backoff) + + def sleep(self, response=None): + """Sleep between retry attempts. + + This method will respect a server's ``Retry-After`` response header + and sleep the duration of the time requested. If that is not present, it + will use an exponential backoff. By default, the backoff factor is 0 and + this method will return immediately. + """ + + if self.respect_retry_after_header and response: + slept = self.sleep_for_retry(response) + if slept: + return + + self._sleep_backoff() + + def _is_connection_error(self, err): + """Errors when we're fairly sure that the server did not receive the + request, so it should be safe to retry. + """ + if isinstance(err, ProxyError): + err = err.original_error + return isinstance(err, ConnectTimeoutError) + + def _is_read_error(self, err): + """Errors that occur after the request has been started, so we should + assume that the server began processing it. + """ + return isinstance(err, (ReadTimeoutError, ProtocolError)) + + def _is_method_retryable(self, method): + """Checks if a given HTTP method should be retried upon, depending if + it is included in the allowed_methods + """ + # TODO: For now favor if the Retry implementation sets its own method_whitelist + # property outside of our constructor to avoid breaking custom implementations. + if "method_whitelist" in self.__dict__: + warnings.warn( + "Using 'method_whitelist' with Retry is deprecated and " + "will be removed in v2.0. Use 'allowed_methods' instead", + DeprecationWarning, + ) + allowed_methods = self.method_whitelist + else: + allowed_methods = self.allowed_methods + + if allowed_methods and method.upper() not in allowed_methods: + return False + return True + + def is_retry(self, method, status_code, has_retry_after=False): + """Is this method/status code retryable? (Based on allowlists and control + variables such as the number of total retries to allow, whether to + respect the Retry-After header, whether this header is present, and + whether the returned status code is on the list of status codes to + be retried upon on the presence of the aforementioned header) + """ + if not self._is_method_retryable(method): + return False + + if self.status_forcelist and status_code in self.status_forcelist: + return True + + return ( + self.total + and self.respect_retry_after_header + and has_retry_after + and (status_code in self.RETRY_AFTER_STATUS_CODES) + ) + + def is_exhausted(self): + """Are we out of retries?""" + retry_counts = ( + self.total, + self.connect, + self.read, + self.redirect, + self.status, + self.other, + ) + retry_counts = list(filter(None, retry_counts)) + if not retry_counts: + return False + + return min(retry_counts) < 0 + + def increment( + self, + method=None, + url=None, + response=None, + error=None, + _pool=None, + _stacktrace=None, + ): + """Return a new Retry object with incremented retry counters. + + :param response: A response object, or None, if the server did not + return a response. + :type response: :class:`~urllib3.response.HTTPResponse` + :param Exception error: An error encountered during the request, or + None if the response was received successfully. + + :return: A new ``Retry`` object. + """ + if self.total is False and error: + # Disabled, indicate to re-raise the error. + raise six.reraise(type(error), error, _stacktrace) + + total = self.total + if total is not None: + total -= 1 + + connect = self.connect + read = self.read + redirect = self.redirect + status_count = self.status + other = self.other + cause = "unknown" + status = None + redirect_location = None + + if error and self._is_connection_error(error): + # Connect retry? + if connect is False: + raise six.reraise(type(error), error, _stacktrace) + elif connect is not None: + connect -= 1 + + elif error and self._is_read_error(error): + # Read retry? + if read is False or not self._is_method_retryable(method): + raise six.reraise(type(error), error, _stacktrace) + elif read is not None: + read -= 1 + + elif error: + # Other retry? + if other is not None: + other -= 1 + + elif response and response.get_redirect_location(): + # Redirect retry? + if redirect is not None: + redirect -= 1 + cause = "too many redirects" + redirect_location = response.get_redirect_location() + status = response.status + + else: + # Incrementing because of a server error like a 500 in + # status_forcelist and the given method is in the allowed_methods + cause = ResponseError.GENERIC_ERROR + if response and response.status: + if status_count is not None: + status_count -= 1 + cause = ResponseError.SPECIFIC_ERROR.format(status_code=response.status) + status = response.status + + history = self.history + ( + RequestHistory(method, url, error, status, redirect_location), + ) + + new_retry = self.new( + total=total, + connect=connect, + read=read, + redirect=redirect, + status=status_count, + other=other, + history=history, + ) + + if new_retry.is_exhausted(): + raise MaxRetryError(_pool, url, error or ResponseError(cause)) + + log.debug("Incremented Retry for (url='%s'): %r", url, new_retry) + + return new_retry + + def __repr__(self): + return ( + "{cls.__name__}(total={self.total}, connect={self.connect}, " + "read={self.read}, redirect={self.redirect}, status={self.status})" + ).format(cls=type(self), self=self) + + def __getattr__(self, item): + if item == "method_whitelist": + # TODO: Remove this deprecated alias in v2.0 + warnings.warn( + "Using 'method_whitelist' with Retry is deprecated and " + "will be removed in v2.0. Use 'allowed_methods' instead", + DeprecationWarning, + ) + return self.allowed_methods + try: + return getattr(super(Retry, self), item) + except AttributeError: + return getattr(Retry, item) + + +# For backwards compatibility (equivalent to pre-v1.9): +Retry.DEFAULT = Retry(3) diff --git a/venv/lib/python3.8/site-packages/urllib3/util/ssl_.py b/venv/lib/python3.8/site-packages/urllib3/util/ssl_.py new file mode 100644 index 0000000..8f86781 --- /dev/null +++ b/venv/lib/python3.8/site-packages/urllib3/util/ssl_.py @@ -0,0 +1,495 @@ +from __future__ import absolute_import + +import hmac +import os +import sys +import warnings +from binascii import hexlify, unhexlify +from hashlib import md5, sha1, sha256 + +from ..exceptions import ( + InsecurePlatformWarning, + ProxySchemeUnsupported, + SNIMissingWarning, + SSLError, +) +from ..packages import six +from .url import BRACELESS_IPV6_ADDRZ_RE, IPV4_RE + +SSLContext = None +SSLTransport = None +HAS_SNI = False +IS_PYOPENSSL = False +IS_SECURETRANSPORT = False +ALPN_PROTOCOLS = ["http/1.1"] + +# Maps the length of a digest to a possible hash function producing this digest +HASHFUNC_MAP = {32: md5, 40: sha1, 64: sha256} + + +def _const_compare_digest_backport(a, b): + """ + Compare two digests of equal length in constant time. + + The digests must be of type str/bytes. + Returns True if the digests match, and False otherwise. + """ + result = abs(len(a) - len(b)) + for left, right in zip(bytearray(a), bytearray(b)): + result |= left ^ right + return result == 0 + + +_const_compare_digest = getattr(hmac, "compare_digest", _const_compare_digest_backport) + +try: # Test for SSL features + import ssl + from ssl import CERT_REQUIRED, wrap_socket +except ImportError: + pass + +try: + from ssl import HAS_SNI # Has SNI? +except ImportError: + pass + +try: + from .ssltransport import SSLTransport +except ImportError: + pass + + +try: # Platform-specific: Python 3.6 + from ssl import PROTOCOL_TLS + + PROTOCOL_SSLv23 = PROTOCOL_TLS +except ImportError: + try: + from ssl import PROTOCOL_SSLv23 as PROTOCOL_TLS + + PROTOCOL_SSLv23 = PROTOCOL_TLS + 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 +except ImportError: + OP_NO_SSLv2, OP_NO_SSLv3 = 0x1000000, 0x2000000 + OP_NO_COMPRESSION = 0x20000 + + +try: # OP_NO_TICKET was added in Python 3.6 + from ssl import OP_NO_TICKET +except ImportError: + OP_NO_TICKET = 0x4000 + + +# A secure default. +# Sources for more information on TLS ciphers: +# +# - https://wiki.mozilla.org/Security/Server_Side_TLS +# - https://www.ssllabs.com/projects/best-practices/index.html +# - https://hynek.me/articles/hardening-your-web-servers-ssl-ciphers/ +# +# The general intent is: +# - prefer cipher suites that offer perfect forward secrecy (DHE/ECDHE), +# - prefer ECDHE over DHE for better performance, +# - prefer any AES-GCM and ChaCha20 over any AES-CBC for better performance and +# security, +# - prefer AES-GCM over ChaCha20 because hardware-accelerated AES is common, +# - disable NULL authentication, MD5 MACs, DSS, and other +# insecure ciphers for security reasons. +# - NOTE: TLS 1.3 cipher suites are managed through a different interface +# not exposed by CPython (yet!) and are enabled by default if they're available. +DEFAULT_CIPHERS = ":".join( + [ + "ECDHE+AESGCM", + "ECDHE+CHACHA20", + "DHE+AESGCM", + "DHE+CHACHA20", + "ECDH+AESGCM", + "DH+AESGCM", + "ECDH+AES", + "DH+AES", + "RSA+AESGCM", + "RSA+AES", + "!aNULL", + "!eNULL", + "!MD5", + "!DSS", + ] +) + +try: + from ssl import SSLContext # Modern SSL? +except ImportError: + + class SSLContext(object): # Platform-specific: Python 2 + def __init__(self, protocol_version): + self.protocol = protocol_version + # Use default values from a real SSLContext + self.check_hostname = False + self.verify_mode = ssl.CERT_NONE + self.ca_certs = None + self.options = 0 + self.certfile = None + self.keyfile = None + self.ciphers = None + + def load_cert_chain(self, certfile, keyfile): + self.certfile = certfile + self.keyfile = keyfile + + def load_verify_locations(self, cafile=None, capath=None, cadata=None): + self.ca_certs = cafile + + if capath is not None: + raise SSLError("CA directories not supported in older Pythons") + + if cadata is not None: + raise SSLError("CA data not supported in older Pythons") + + def set_ciphers(self, cipher_suite): + self.ciphers = cipher_suite + + def wrap_socket(self, socket, server_hostname=None, server_side=False): + warnings.warn( + "A true SSLContext object is not available. This prevents " + "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/1.26.x/advanced-usage.html" + "#ssl-warnings", + InsecurePlatformWarning, + ) + kwargs = { + "keyfile": self.keyfile, + "certfile": self.certfile, + "ca_certs": self.ca_certs, + "cert_reqs": self.verify_mode, + "ssl_version": self.protocol, + "server_side": server_side, + } + return wrap_socket(socket, ciphers=self.ciphers, **kwargs) + + +def assert_fingerprint(cert, fingerprint): + """ + Checks if given fingerprint matches the supplied certificate. + + :param cert: + Certificate as bytes object. + :param fingerprint: + Fingerprint as string of hexdigits, can be interspersed by colons. + """ + + fingerprint = fingerprint.replace(":", "").lower() + digest_length = len(fingerprint) + hashfunc = HASHFUNC_MAP.get(digest_length) + if not hashfunc: + raise SSLError("Fingerprint of invalid length: {0}".format(fingerprint)) + + # We need encode() here for py32; works on py2 and p33. + fingerprint_bytes = unhexlify(fingerprint.encode()) + + cert_digest = hashfunc(cert).digest() + + if not _const_compare_digest(cert_digest, fingerprint_bytes): + raise SSLError( + 'Fingerprints did not match. Expected "{0}", got "{1}".'.format( + fingerprint, hexlify(cert_digest) + ) + ) + + +def resolve_cert_reqs(candidate): + """ + Resolves the argument to a numeric constant, which can be passed to + the wrap_socket function/method from the ssl module. + Defaults to :data:`ssl.CERT_REQUIRED`. + If given a string it is assumed to be the name of the constant in the + :mod:`ssl` module or its abbreviation. + (So you can specify `REQUIRED` instead of `CERT_REQUIRED`. + If it's neither `None` nor a string we assume it is already the numeric + constant which can directly be passed to wrap_socket. + """ + if candidate is None: + return CERT_REQUIRED + + if isinstance(candidate, str): + res = getattr(ssl, candidate, None) + if res is None: + res = getattr(ssl, "CERT_" + candidate) + return res + + return candidate + + +def resolve_ssl_version(candidate): + """ + like resolve_cert_reqs + """ + if candidate is None: + return PROTOCOL_TLS + + if isinstance(candidate, str): + res = getattr(ssl, candidate, None) + if res is None: + res = getattr(ssl, "PROTOCOL_" + candidate) + return res + + return candidate + + +def create_urllib3_context( + ssl_version=None, cert_reqs=None, options=None, ciphers=None +): + """All arguments have the same meaning as ``ssl_wrap_socket``. + + By default, this function does a lot of the same work that + ``ssl.create_default_context`` does on Python 3.4+. It: + + - Disables SSLv2, SSLv3, and compression + - Sets a restricted set of server ciphers + + If you wish to enable SSLv3, you can do:: + + from urllib3.util import ssl_ + context = ssl_.create_urllib3_context() + context.options &= ~ssl_.OP_NO_SSLv3 + + You can do the same to enable compression (substituting ``COMPRESSION`` + for ``SSLv3`` in the last line above). + + :param ssl_version: + The desired protocol version to use. This will default to + PROTOCOL_SSLv23 which will negotiate the highest protocol that both + the server and your installation of OpenSSL support. + :param cert_reqs: + Whether to require the certificate verification. This defaults to + ``ssl.CERT_REQUIRED``. + :param options: + Specific OpenSSL options. These default to ``ssl.OP_NO_SSLv2``, + ``ssl.OP_NO_SSLv3``, ``ssl.OP_NO_COMPRESSION``, and ``ssl.OP_NO_TICKET``. + :param ciphers: + Which cipher suites to allow the server to select. + :returns: + Constructed SSLContext object with specified options + :rtype: SSLContext + """ + # 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) + + # Setting the default here, as we may have no ssl module on import + cert_reqs = ssl.CERT_REQUIRED if cert_reqs is None else cert_reqs + + if options is None: + options = 0 + # SSLv2 is easily broken and is considered harmful and dangerous + options |= OP_NO_SSLv2 + # SSLv3 has several problems and is now dangerous + options |= OP_NO_SSLv3 + # Disable compression to prevent CRIME attacks for OpenSSL 1.0+ + # (issue #309) + options |= OP_NO_COMPRESSION + # TLSv1.2 only. Unless set explicitly, do not request tickets. + # This may save some bandwidth on wire, and although the ticket is encrypted, + # there is a risk associated with it being on wire, + # if the server is not rotating its ticketing keys properly. + options |= OP_NO_TICKET + + context.options |= options + + # Enable post-handshake authentication for TLS 1.3, see GH #1634. PHA is + # necessary for conditional client cert authentication with TLS 1.3. + # The attribute is None for OpenSSL <= 1.1.0 or does not exist in older + # versions of Python. We only enable on Python 3.7.4+ or if certificate + # verification is enabled to work around Python issue #37428 + # See: https://bugs.python.org/issue37428 + if (cert_reqs == ssl.CERT_REQUIRED or sys.version_info >= (3, 7, 4)) and getattr( + context, "post_handshake_auth", None + ) is not None: + context.post_handshake_auth = True + + 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. + if hasattr(context, "keylog_filename"): + sslkeylogfile = os.environ.get("SSLKEYLOGFILE") + if sslkeylogfile: + context.keylog_filename = sslkeylogfile + + return context + + +def ssl_wrap_socket( + sock, + keyfile=None, + certfile=None, + cert_reqs=None, + ca_certs=None, + server_hostname=None, + ssl_version=None, + ciphers=None, + ssl_context=None, + ca_cert_dir=None, + key_password=None, + ca_cert_data=None, + tls_in_tls=False, +): + """ + All arguments except for server_hostname, ssl_context, and ca_cert_dir have + the same meaning as they do when using :func:`ssl.wrap_socket`. + + :param server_hostname: + When SNI is supported, the expected hostname of the certificate + :param ssl_context: + A pre-made :class:`SSLContext` object. If none is provided, one will + be created using :func:`create_urllib3_context`. + :param ciphers: + A string of ciphers we wish the client to support. + :param ca_cert_dir: + A directory containing CA certificates in multiple separate files, as + supported by OpenSSL's -CApath flag or the capath argument to + SSLContext.load_verify_locations(). + :param key_password: + Optional password if the keyfile is encrypted. + :param ca_cert_data: + Optional string containing CA certificates in PEM format suitable for + passing as the cadata parameter to SSLContext.load_verify_locations() + :param tls_in_tls: + Use SSLTransport to wrap the existing socket. + """ + context = ssl_context + if context is None: + # Note: This branch of code and all the variables in it are no longer + # used by urllib3 itself. We should consider deprecating and removing + # this code. + context = create_urllib3_context(ssl_version, cert_reqs, ciphers=ciphers) + + if ca_certs or ca_cert_dir or ca_cert_data: + try: + context.load_verify_locations(ca_certs, ca_cert_dir, ca_cert_data) + except (IOError, OSError) as e: + raise SSLError(e) + + elif ssl_context is None and hasattr(context, "load_default_certs"): + # try to load OS default certs; works well on Windows (require Python3.4+) + context.load_default_certs() + + # Attempt to detect if we get the goofy behavior of the + # keyfile being encrypted and OpenSSL asking for the + # passphrase via the terminal and instead error out. + if keyfile and key_password is None and _is_key_file_encrypted(keyfile): + raise SSLError("Client private key is encrypted, password is required") + + if certfile: + if key_password is None: + context.load_cert_chain(certfile, keyfile) + else: + context.load_cert_chain(certfile, keyfile, key_password) + + try: + if hasattr(context, "set_alpn_protocols"): + context.set_alpn_protocols(ALPN_PROTOCOLS) + except NotImplementedError: # Defensive: in CI, we always have set_alpn_protocols + pass + + # If we detect server_hostname is an IP address then the SNI + # extension should not be used according to RFC3546 Section 3.1 + use_sni_hostname = server_hostname and not is_ipaddress(server_hostname) + # SecureTransport uses server_hostname in certificate verification. + send_sni = (use_sni_hostname and HAS_SNI) or ( + IS_SECURETRANSPORT and server_hostname + ) + # Do not warn the user if server_hostname is an invalid SNI hostname. + if not HAS_SNI and use_sni_hostname: + warnings.warn( + "An HTTPS request has been made, but the SNI (Server Name " + "Indication) extension to TLS is not available on this platform. " + "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/1.26.x/advanced-usage.html" + "#ssl-warnings", + SNIMissingWarning, + ) + + if send_sni: + ssl_sock = _ssl_wrap_socket_impl( + sock, context, tls_in_tls, server_hostname=server_hostname + ) + else: + ssl_sock = _ssl_wrap_socket_impl(sock, context, tls_in_tls) + return ssl_sock + + +def is_ipaddress(hostname): + """Detects whether the hostname given is an IPv4 or IPv6 address. + Also detects IPv6 addresses with Zone IDs. + + :param str hostname: Hostname to examine. + :return: True if the hostname is an IP address, False otherwise. + """ + if not six.PY2 and isinstance(hostname, bytes): + # IDN A-label bytes are ASCII compatible. + hostname = hostname.decode("ascii") + return bool(IPV4_RE.match(hostname) or BRACELESS_IPV6_ADDRZ_RE.match(hostname)) + + +def _is_key_file_encrypted(key_file): + """Detects if a key file is encrypted or not.""" + with open(key_file, "r") as f: + for line in f: + # Look for Proc-Type: 4,ENCRYPTED + if "ENCRYPTED" in line: + return True + + return False + + +def _ssl_wrap_socket_impl(sock, ssl_context, tls_in_tls, server_hostname=None): + if tls_in_tls: + if not SSLTransport: + # Import error, ssl is not available. + raise ProxySchemeUnsupported( + "TLS in TLS requires support for the 'ssl' module" + ) + + SSLTransport._validate_ssl_context_for_tls_in_tls(ssl_context) + return SSLTransport(sock, ssl_context, server_hostname) + + if server_hostname: + return ssl_context.wrap_socket(sock, server_hostname=server_hostname) + else: + return ssl_context.wrap_socket(sock) diff --git a/venv/lib/python3.8/site-packages/urllib3/util/ssltransport.py b/venv/lib/python3.8/site-packages/urllib3/util/ssltransport.py new file mode 100644 index 0000000..c2186bc --- /dev/null +++ b/venv/lib/python3.8/site-packages/urllib3/util/ssltransport.py @@ -0,0 +1,221 @@ +import io +import socket +import ssl + +from urllib3.exceptions import ProxySchemeUnsupported +from urllib3.packages import six + +SSL_BLOCKSIZE = 16384 + + +class SSLTransport: + """ + The SSLTransport wraps an existing socket and establishes an SSL connection. + + Contrary to Python's implementation of SSLSocket, it allows you to chain + multiple TLS connections together. It's particularly useful if you need to + implement TLS within TLS. + + The class supports most of the socket API operations. + """ + + @staticmethod + def _validate_ssl_context_for_tls_in_tls(ssl_context): + """ + Raises a ProxySchemeUnsupported if the provided ssl_context can't be used + for TLS in TLS. + + The only requirement is that the ssl_context provides the 'wrap_bio' + methods. + """ + + if not hasattr(ssl_context, "wrap_bio"): + if six.PY2: + raise ProxySchemeUnsupported( + "TLS in TLS requires SSLContext.wrap_bio() which isn't " + "supported on Python 2" + ) + else: + raise ProxySchemeUnsupported( + "TLS in TLS requires SSLContext.wrap_bio() which isn't " + "available on non-native SSLContext" + ) + + def __init__( + self, socket, ssl_context, server_hostname=None, suppress_ragged_eofs=True + ): + """ + Create an SSLTransport around socket using the provided ssl_context. + """ + self.incoming = ssl.MemoryBIO() + self.outgoing = ssl.MemoryBIO() + + self.suppress_ragged_eofs = suppress_ragged_eofs + self.socket = socket + + self.sslobj = ssl_context.wrap_bio( + self.incoming, self.outgoing, server_hostname=server_hostname + ) + + # Perform initial handshake. + self._ssl_io_loop(self.sslobj.do_handshake) + + def __enter__(self): + return self + + def __exit__(self, *_): + self.close() + + def fileno(self): + return self.socket.fileno() + + def read(self, len=1024, buffer=None): + return self._wrap_ssl_read(len, buffer) + + def recv(self, len=1024, flags=0): + if flags != 0: + raise ValueError("non-zero flags not allowed in calls to recv") + return self._wrap_ssl_read(len) + + def recv_into(self, buffer, nbytes=None, flags=0): + if flags != 0: + raise ValueError("non-zero flags not allowed in calls to recv_into") + if buffer and (nbytes is None): + nbytes = len(buffer) + elif nbytes is None: + nbytes = 1024 + return self.read(nbytes, buffer) + + def sendall(self, data, flags=0): + if flags != 0: + raise ValueError("non-zero flags not allowed in calls to sendall") + count = 0 + with memoryview(data) as view, view.cast("B") as byte_view: + amount = len(byte_view) + while count < amount: + v = self.send(byte_view[count:]) + count += v + + def send(self, data, flags=0): + if flags != 0: + raise ValueError("non-zero flags not allowed in calls to send") + response = self._ssl_io_loop(self.sslobj.write, data) + return response + + def makefile( + self, mode="r", buffering=None, encoding=None, errors=None, newline=None + ): + """ + Python's httpclient uses makefile and buffered io when reading HTTP + messages and we need to support it. + + This is unfortunately a copy and paste of socket.py makefile with small + changes to point to the socket directly. + """ + if not set(mode) <= {"r", "w", "b"}: + raise ValueError("invalid mode %r (only r, w, b allowed)" % (mode,)) + + writing = "w" in mode + reading = "r" in mode or not writing + assert reading or writing + binary = "b" in mode + rawmode = "" + if reading: + rawmode += "r" + if writing: + rawmode += "w" + raw = socket.SocketIO(self, rawmode) + self.socket._io_refs += 1 + if buffering is None: + buffering = -1 + if buffering < 0: + buffering = io.DEFAULT_BUFFER_SIZE + if buffering == 0: + if not binary: + raise ValueError("unbuffered streams must be binary") + return raw + if reading and writing: + buffer = io.BufferedRWPair(raw, raw, buffering) + elif reading: + buffer = io.BufferedReader(raw, buffering) + else: + assert writing + buffer = io.BufferedWriter(raw, buffering) + if binary: + return buffer + text = io.TextIOWrapper(buffer, encoding, errors, newline) + text.mode = mode + return text + + def unwrap(self): + self._ssl_io_loop(self.sslobj.unwrap) + + def close(self): + self.socket.close() + + def getpeercert(self, binary_form=False): + return self.sslobj.getpeercert(binary_form) + + def version(self): + return self.sslobj.version() + + def cipher(self): + return self.sslobj.cipher() + + def selected_alpn_protocol(self): + return self.sslobj.selected_alpn_protocol() + + def selected_npn_protocol(self): + return self.sslobj.selected_npn_protocol() + + def shared_ciphers(self): + return self.sslobj.shared_ciphers() + + def compression(self): + return self.sslobj.compression() + + def settimeout(self, value): + self.socket.settimeout(value) + + def gettimeout(self): + return self.socket.gettimeout() + + def _decref_socketios(self): + self.socket._decref_socketios() + + def _wrap_ssl_read(self, len, buffer=None): + try: + return self._ssl_io_loop(self.sslobj.read, len, buffer) + except ssl.SSLError as e: + if e.errno == ssl.SSL_ERROR_EOF and self.suppress_ragged_eofs: + return 0 # eof, return 0. + else: + raise + + def _ssl_io_loop(self, func, *args): + """Performs an I/O loop between incoming/outgoing and the socket.""" + should_loop = True + ret = None + + while should_loop: + errno = None + try: + ret = func(*args) + except ssl.SSLError as e: + if e.errno not in (ssl.SSL_ERROR_WANT_READ, ssl.SSL_ERROR_WANT_WRITE): + # WANT_READ, and WANT_WRITE are expected, others are not. + raise e + errno = e.errno + + buf = self.outgoing.read() + self.socket.sendall(buf) + + if errno is None: + should_loop = False + elif errno == ssl.SSL_ERROR_WANT_READ: + buf = self.socket.recv(SSL_BLOCKSIZE) + if buf: + self.incoming.write(buf) + else: + self.incoming.write_eof() + return ret diff --git a/venv/lib/python3.8/site-packages/urllib3/util/timeout.py b/venv/lib/python3.8/site-packages/urllib3/util/timeout.py new file mode 100644 index 0000000..ff69593 --- /dev/null +++ b/venv/lib/python3.8/site-packages/urllib3/util/timeout.py @@ -0,0 +1,268 @@ +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 + +from ..exceptions import TimeoutStateError + +# A sentinel value to indicate that no timeout was specified by the user in +# urllib3 +_Default = object() + + +# Use time.monotonic if available. +current_time = getattr(time, "monotonic", time.time) + + +class Timeout(object): + """Timeout configuration. + + Timeouts can be defined as a default for a pool: + + .. code-block:: python + + timeout = Timeout(connect=2.0, read=7.0) + http = PoolManager(timeout=timeout) + response = http.request('GET', 'http://example.com/') + + Or per-request (which overrides the default for the pool): + + .. code-block:: python + + response = http.request('GET', 'http://example.com/', timeout=Timeout(10)) + + Timeouts can be disabled by setting all the parameters to ``None``: + + .. code-block:: python + + no_timeout = Timeout(connect=None, read=None) + response = http.request('GET', 'http://example.com/, timeout=no_timeout) + + + :param total: + This combines the connect and read timeouts into one; the read timeout + will be set to the time leftover from the connect attempt. In the + event that both a connect timeout and a total are specified, or a read + timeout and a total are specified, the shorter timeout will be applied. + + Defaults to None. + + :type total: int, float, or None + + :param connect: + The maximum amount of time (in seconds) to wait for a connection + attempt to a server to succeed. Omitting the parameter will default the + connect timeout to the system default, probably `the global default + timeout in socket.py + `_. + None will set an infinite timeout for connection attempts. + + :type connect: int, float, or None + + :param read: + The maximum amount of time (in seconds) to wait between consecutive + read operations for a response from the server. Omitting the parameter + will default the read timeout to the system default, probably `the + global default timeout in socket.py + `_. + None will set an infinite timeout. + + :type read: int, float, or None + + .. note:: + + Many factors can affect the total amount of time for urllib3 to return + an HTTP response. + + For example, Python's DNS resolver does not obey the timeout specified + on the socket. Other factors that can affect total request time include + high CPU load, high swap, the program running at a low priority level, + or other behaviors. + + In addition, the read and total timeouts only measure the time between + read operations on the socket connecting the client and the server, + not the total amount of time for the request to return a complete + response. For most requests, the timeout is raised because the server + has not sent the first byte in the specified time. This is not always + the case; if a server streams one byte every fifteen seconds, a timeout + of 20 seconds will not trigger, even though the request will take + several minutes to complete. + + If your goal is to cut off any request after a set amount of wall clock + time, consider having a second "watcher" thread to cut off a slow + request. + """ + + #: A sentinel object representing the default timeout value + DEFAULT_TIMEOUT = _GLOBAL_DEFAULT_TIMEOUT + + def __init__(self, total=None, connect=_Default, read=_Default): + self._connect = self._validate_timeout(connect, "connect") + self._read = self._validate_timeout(read, "read") + self.total = self._validate_timeout(total, "total") + self._start_connect = None + + def __repr__(self): + return "%s(connect=%r, read=%r, total=%r)" % ( + type(self).__name__, + self._connect, + self._read, + self.total, + ) + + # __str__ provided for backwards compatibility + __str__ = __repr__ + + @classmethod + def _validate_timeout(cls, value, name): + """Check that a timeout attribute is valid. + + :param value: The timeout value to validate + :param name: The name of the timeout attribute to validate. This is + used to specify in error messages. + :return: The validated and casted version of the given value. + :raises ValueError: If it is a numeric value less than or equal to + zero, or the type is not an integer, float, or None. + """ + if value is _Default: + return cls.DEFAULT_TIMEOUT + + if value is None or value is cls.DEFAULT_TIMEOUT: + return value + + if isinstance(value, bool): + raise ValueError( + "Timeout cannot be a boolean value. It must " + "be an int, float or None." + ) + try: + float(value) + except (TypeError, ValueError): + raise ValueError( + "Timeout value %s was %s, but it must be an " + "int, float or None." % (name, value) + ) + + try: + if value <= 0: + raise ValueError( + "Attempted to set %s timeout to %s, but the " + "timeout cannot be set to a value less " + "than or equal to 0." % (name, value) + ) + except TypeError: + # Python 3 + raise ValueError( + "Timeout value %s was %s, but it must be an " + "int, float or None." % (name, value) + ) + + return value + + @classmethod + def from_float(cls, timeout): + """Create a new Timeout from a legacy timeout value. + + The timeout value used by httplib.py sets the same timeout on the + connect(), and recv() socket requests. This creates a :class:`Timeout` + object that sets the individual timeouts to the ``timeout`` value + passed to this function. + + :param timeout: The legacy timeout value. + :type timeout: integer, float, sentinel default object, or None + :return: Timeout object + :rtype: :class:`Timeout` + """ + return Timeout(read=timeout, connect=timeout) + + def clone(self): + """Create a copy of the timeout object + + Timeout properties are stored per-pool but each request needs a fresh + Timeout object to ensure each one has its own start/stop configured. + + :return: a copy of the timeout object + :rtype: :class:`Timeout` + """ + # We can't use copy.deepcopy because that will also create a new object + # for _GLOBAL_DEFAULT_TIMEOUT, which socket.py uses as a sentinel to + # detect the user default. + return Timeout(connect=self._connect, read=self._read, total=self.total) + + def start_connect(self): + """Start the timeout clock, used during a connect() attempt + + :raises urllib3.exceptions.TimeoutStateError: if you attempt + to start a timer that has been started already. + """ + if self._start_connect is not None: + raise TimeoutStateError("Timeout timer has already been started.") + self._start_connect = current_time() + return self._start_connect + + def get_connect_duration(self): + """Gets the time elapsed since the call to :meth:`start_connect`. + + :return: Elapsed time in seconds. + :rtype: float + :raises urllib3.exceptions.TimeoutStateError: if you attempt + to get duration for a timer that hasn't been started. + """ + if self._start_connect is None: + raise TimeoutStateError( + "Can't get connect duration for timer that has not started." + ) + return current_time() - self._start_connect + + @property + def connect_timeout(self): + """Get the value to use when setting a connection timeout. + + This will be a positive float or integer, the value None + (never timeout), or the default system timeout. + + :return: Connect timeout. + :rtype: int, float, :attr:`Timeout.DEFAULT_TIMEOUT` or None + """ + if self.total is None: + return self._connect + + if self._connect is None or self._connect is self.DEFAULT_TIMEOUT: + return self.total + + return min(self._connect, self.total) + + @property + def read_timeout(self): + """Get the value for the read timeout. + + This assumes some time has elapsed in the connection timeout and + computes the read timeout appropriately. + + If self.total is set, the read timeout is dependent on the amount of + time taken by the connect timeout. If the connection time has not been + established, a :exc:`~urllib3.exceptions.TimeoutStateError` will be + raised. + + :return: Value to use for the read timeout. + :rtype: int, float, :attr:`Timeout.DEFAULT_TIMEOUT` or None + :raises urllib3.exceptions.TimeoutStateError: If :meth:`start_connect` + has not yet been called on this object. + """ + if ( + self.total is not None + and self.total is not self.DEFAULT_TIMEOUT + and self._read is not None + and self._read is not self.DEFAULT_TIMEOUT + ): + # In case the connect timeout has not yet been established. + if self._start_connect is None: + return self._read + return max(0, min(self.total - self.get_connect_duration(), self._read)) + elif self.total is not None and self.total is not self.DEFAULT_TIMEOUT: + return max(0, self.total - self.get_connect_duration()) + else: + return self._read diff --git a/venv/lib/python3.8/site-packages/urllib3/util/url.py b/venv/lib/python3.8/site-packages/urllib3/util/url.py new file mode 100644 index 0000000..81a03da --- /dev/null +++ b/venv/lib/python3.8/site-packages/urllib3/util/url.py @@ -0,0 +1,432 @@ +from __future__ import absolute_import + +import re +from collections import namedtuple + +from ..exceptions import LocationParseError +from ..packages import six + +url_attrs = ["scheme", "auth", "host", "port", "path", "query", "fragment"] + +# We only want to normalize urls with an HTTP(S) scheme. +# urllib3 infers URLs without a scheme (None) to be http. +NORMALIZABLE_SCHEMES = ("http", "https", None) + +# Almost all of these patterns were derived from the +# 'rfc3986' module: https://github.com/python-hyper/rfc3986 +PERCENT_RE = re.compile(r"%[a-fA-F0-9]{2}") +SCHEME_RE = re.compile(r"^(?:[a-zA-Z][a-zA-Z0-9+-]*:|/)") +URI_RE = re.compile( + r"^(?:([a-zA-Z][a-zA-Z0-9+.-]*):)?" + r"(?://([^\\/?#]*))?" + r"([^?#]*)" + r"(?:\?([^#]*))?" + r"(?:#(.*))?$", + re.UNICODE | re.DOTALL, +) + +IPV4_PAT = r"(?:[0-9]{1,3}\.){3}[0-9]{1,3}" +HEX_PAT = "[0-9A-Fa-f]{1,4}" +LS32_PAT = "(?:{hex}:{hex}|{ipv4})".format(hex=HEX_PAT, ipv4=IPV4_PAT) +_subs = {"hex": HEX_PAT, "ls32": LS32_PAT} +_variations = [ + # 6( h16 ":" ) ls32 + "(?:%(hex)s:){6}%(ls32)s", + # "::" 5( h16 ":" ) ls32 + "::(?:%(hex)s:){5}%(ls32)s", + # [ h16 ] "::" 4( h16 ":" ) ls32 + "(?:%(hex)s)?::(?:%(hex)s:){4}%(ls32)s", + # [ *1( h16 ":" ) h16 ] "::" 3( h16 ":" ) ls32 + "(?:(?:%(hex)s:)?%(hex)s)?::(?:%(hex)s:){3}%(ls32)s", + # [ *2( h16 ":" ) h16 ] "::" 2( h16 ":" ) ls32 + "(?:(?:%(hex)s:){0,2}%(hex)s)?::(?:%(hex)s:){2}%(ls32)s", + # [ *3( h16 ":" ) h16 ] "::" h16 ":" ls32 + "(?:(?:%(hex)s:){0,3}%(hex)s)?::%(hex)s:%(ls32)s", + # [ *4( h16 ":" ) h16 ] "::" ls32 + "(?:(?:%(hex)s:){0,4}%(hex)s)?::%(ls32)s", + # [ *5( h16 ":" ) h16 ] "::" h16 + "(?:(?:%(hex)s:){0,5}%(hex)s)?::%(hex)s", + # [ *6( h16 ":" ) h16 ] "::" + "(?:(?:%(hex)s:){0,6}%(hex)s)?::", +] + +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")?\]" +REG_NAME_PAT = r"(?:[^\[\]%:/?#]|%[a-fA-F0-9]{2})*" +TARGET_RE = re.compile(r"^(/[^?#]*)(?:\?([^#]*))?(?:#.*)?$") + +IPV4_RE = re.compile("^" + IPV4_PAT + "$") +IPV6_RE = re.compile("^" + IPV6_PAT + "$") +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")\]$") + +_HOST_PORT_PAT = ("^(%s|%s|%s)(?::([0-9]{0,5}))?$") % ( + REG_NAME_PAT, + IPV4_PAT, + IPV6_ADDRZ_PAT, +) +_HOST_PORT_RE = re.compile(_HOST_PORT_PAT, re.UNICODE | re.DOTALL) + +UNRESERVED_CHARS = set( + "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789._-~" +) +SUB_DELIM_CHARS = set("!$&'()*+,;=") +USERINFO_CHARS = UNRESERVED_CHARS | SUB_DELIM_CHARS | {":"} +PATH_CHARS = USERINFO_CHARS | {"@", "/"} +QUERY_CHARS = FRAGMENT_CHARS = PATH_CHARS | {"?"} + + +class Url(namedtuple("Url", url_attrs)): + """ + Data structure for representing an HTTP URL. Used as a return value for + :func:`parse_url`. Both the scheme and host are normalized as they are + both case-insensitive according to RFC 3986. + """ + + __slots__ = () + + def __new__( + cls, + scheme=None, + auth=None, + host=None, + port=None, + path=None, + query=None, + fragment=None, + ): + if path and not path.startswith("/"): + path = "/" + path + if scheme is not None: + scheme = scheme.lower() + return super(Url, cls).__new__( + cls, scheme, auth, host, port, path, query, fragment + ) + + @property + def hostname(self): + """For backwards-compatibility with urlparse. We're nice like that.""" + return self.host + + @property + def request_uri(self): + """Absolute path including the query string.""" + uri = self.path or "/" + + if self.query is not None: + uri += "?" + self.query + + return uri + + @property + def netloc(self): + """Network location including host and port""" + if self.port: + return "%s:%d" % (self.host, self.port) + return self.host + + @property + def url(self): + """ + Convert self into a url + + This function should more or less round-trip with :func:`.parse_url`. The + returned url may not be exactly the same as the url inputted to + :func:`.parse_url`, but it should be equivalent by the RFC (e.g., urls + with a blank port will have : removed). + + Example: :: + + >>> U = parse_url('http://google.com/mail/') + >>> U.url + 'http://google.com/mail/' + >>> Url('http', 'username:password', 'host.com', 80, + ... '/path', 'query', 'fragment').url + 'http://username:password@host.com:80/path?query#fragment' + """ + scheme, auth, host, port, path, query, fragment = self + url = u"" + + # We use "is not None" we want things to happen with empty strings (or 0 port) + if scheme is not None: + url += scheme + u"://" + if auth is not None: + url += auth + u"@" + if host is not None: + url += host + if port is not None: + url += u":" + str(port) + if path is not None: + url += path + if query is not None: + url += u"?" + query + if fragment is not None: + url += u"#" + fragment + + return url + + def __str__(self): + return self.url + + +def split_first(s, delims): + """ + .. deprecated:: 1.25 + + Given a string and an iterable of delimiters, split on the first found + delimiter. Return two split parts and the matched delimiter. + + If not found, then the first part is the full input string. + + Example:: + + >>> split_first('foo/bar?baz', '?/=') + ('foo', 'bar?baz', '/') + >>> split_first('foo/bar?baz', '123') + ('foo/bar?baz', '', None) + + Scales linearly with number of delims. Not ideal for large number of delims. + """ + min_idx = None + min_delim = None + for d in delims: + idx = s.find(d) + if idx < 0: + continue + + if min_idx is None or idx < min_idx: + min_idx = idx + min_delim = d + + if min_idx is None or min_idx < 0: + return s, "", None + + return s[:min_idx], s[min_idx + 1 :], min_delim + + +def _encode_invalid_chars(component, allowed_chars, encoding="utf-8"): + """Percent-encodes a URI component without reapplying + onto an already percent-encoded component. + """ + if component is None: + return component + + component = six.ensure_text(component) + + # Normalize existing percent-encoded bytes. + # Try to see if the component we're encoding is already percent-encoded + # so we can skip all '%' characters but still encode all others. + component, percent_encodings = PERCENT_RE.subn( + lambda match: match.group(0).upper(), component + ) + + uri_bytes = component.encode("utf-8", "surrogatepass") + is_percent_encoded = percent_encodings == uri_bytes.count(b"%") + encoded_component = bytearray() + + for i in range(0, len(uri_bytes)): + # Will return a single character bytestring on both Python 2 & 3 + byte = uri_bytes[i : i + 1] + byte_ord = ord(byte) + if (is_percent_encoded and byte == b"%") or ( + byte_ord < 128 and byte.decode() in allowed_chars + ): + encoded_component += byte + continue + encoded_component.extend(b"%" + (hex(byte_ord)[2:].encode().zfill(2).upper())) + + return encoded_component.decode(encoding) + + +def _remove_path_dot_segments(path): + # See http://tools.ietf.org/html/rfc3986#section-5.2.4 for pseudo-code + segments = path.split("/") # Turn the path into a list of segments + output = [] # Initialize the variable to use to store output + + for segment in segments: + # '.' is the current directory, so ignore it, it is superfluous + if segment == ".": + continue + # Anything other than '..', should be appended to the output + elif segment != "..": + output.append(segment) + # In this case segment == '..', if we can, we should pop the last + # element + elif output: + output.pop() + + # If the path starts with '/' and the output is empty or the first string + # is non-empty + if path.startswith("/") and (not output or output[0]): + output.insert(0, "") + + # If the path starts with '/.' or '/..' ensure we add one more empty + # string to add a trailing '/' + if path.endswith(("/.", "/..")): + output.append("") + + return "/".join(output) + + +def _normalize_host(host, scheme): + if host: + if isinstance(host, six.binary_type): + host = six.ensure_str(host) + + if scheme in NORMALIZABLE_SCHEMES: + is_ipv6 = IPV6_ADDRZ_RE.match(host) + if is_ipv6: + match = ZONE_ID_RE.search(host) + if match: + start, end = match.span(1) + zone_id = host[start:end] + + if zone_id.startswith("%25") and zone_id != "%25": + zone_id = zone_id[3:] + else: + zone_id = zone_id[1:] + zone_id = "%" + _encode_invalid_chars(zone_id, UNRESERVED_CHARS) + return host[:start].lower() + zone_id + host[end:] + else: + return host.lower() + elif not IPV4_RE.match(host): + return six.ensure_str( + b".".join([_idna_encode(label) for label in host.split(".")]) + ) + return host + + +def _idna_encode(name): + if name and any([ord(x) > 128 for x in name]): + try: + import idna + except ImportError: + six.raise_from( + LocationParseError("Unable to parse URL without the 'idna' module"), + None, + ) + try: + return idna.encode(name.lower(), strict=True, std3_rules=True) + except idna.IDNAError: + six.raise_from( + LocationParseError(u"Name '%s' is not a valid IDNA label" % name), None + ) + return name.lower().encode("ascii") + + +def _encode_target(target): + """Percent-encodes a request target so that there are no invalid characters""" + path, query = TARGET_RE.match(target).groups() + target = _encode_invalid_chars(path, PATH_CHARS) + query = _encode_invalid_chars(query, QUERY_CHARS) + if query is not None: + target += "?" + query + return target + + +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. + + The parser logic and helper functions are based heavily on + work done in the ``rfc3986`` module. + + :param str url: URL to parse into a :class:`.Url` namedtuple. + + Partly backwards-compatible with :mod:`urlparse`. + + Example:: + + >>> parse_url('http://google.com/mail/') + Url(scheme='http', host='google.com', port=None, path='/mail/', ...) + >>> parse_url('google.com:80') + Url(scheme=None, host='google.com', port=80, path=None, ...) + >>> parse_url('/foo?bar') + Url(scheme=None, host=None, port=None, path='/foo', query='bar', ...) + """ + if not url: + # Empty + return Url() + + source_url = url + if not SCHEME_RE.search(url): + url = "//" + url + + try: + scheme, authority, path, query, fragment = URI_RE.match(url).groups() + normalize_uri = scheme is None or scheme.lower() in NORMALIZABLE_SCHEMES + + if scheme: + scheme = scheme.lower() + + if authority: + 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 == "": + port = None + else: + auth, host, port = None, None, None + + if port is not None: + port = int(port) + if not (0 <= port <= 65535): + raise LocationParseError(url) + + host = _normalize_host(host, scheme) + + if normalize_uri and path: + path = _remove_path_dot_segments(path) + path = _encode_invalid_chars(path, PATH_CHARS) + if normalize_uri and query: + query = _encode_invalid_chars(query, QUERY_CHARS) + if normalize_uri and fragment: + fragment = _encode_invalid_chars(fragment, FRAGMENT_CHARS) + + except (ValueError, AttributeError): + return six.raise_from(LocationParseError(source_url), None) + + # For the sake of backwards compatibility we put empty + # string values for path if there are any defined values + # beyond the path in the URL. + # TODO: Remove this when we break backwards compatibility. + if not path: + if query is not None or fragment is not None: + path = "" + else: + path = None + + # Ensure that each part of the URL is a `str` for + # backwards compatibility. + if isinstance(url, six.text_type): + ensure_func = six.ensure_text + else: + ensure_func = six.ensure_str + + def ensure_type(x): + return x if x is None else ensure_func(x) + + return Url( + scheme=ensure_type(scheme), + auth=ensure_type(auth), + host=ensure_type(host), + port=port, + path=ensure_type(path), + query=ensure_type(query), + fragment=ensure_type(fragment), + ) + + +def get_host(url): + """ + Deprecated. Use :func:`parse_url` instead. + """ + p = parse_url(url) + return p.scheme or "http", p.hostname, p.port diff --git a/venv/lib/python3.8/site-packages/urllib3/util/wait.py b/venv/lib/python3.8/site-packages/urllib3/util/wait.py new file mode 100644 index 0000000..c280646 --- /dev/null +++ b/venv/lib/python3.8/site-packages/urllib3/util/wait.py @@ -0,0 +1,153 @@ +import errno +import select +import sys +from functools import partial + +try: + from time import monotonic +except ImportError: + from time import time as monotonic + +__all__ = ["NoWayToWaitForSocketError", "wait_for_read", "wait_for_write"] + + +class NoWayToWaitForSocketError(Exception): + pass + + +# How should we wait on sockets? +# +# There are two types of APIs you can use for waiting on sockets: the fancy +# modern stateful APIs like epoll/kqueue, and the older stateless APIs like +# select/poll. The stateful APIs are more efficient when you have a lots of +# sockets to keep track of, because you can set them up once and then use them +# lots of times. But we only ever want to wait on a single socket at a time +# and don't want to keep track of state, so the stateless APIs are actually +# more efficient. So we want to use select() or poll(). +# +# Now, how do we choose between select() and poll()? On traditional Unixes, +# select() has a strange calling convention that makes it slow, or fail +# altogether, for high-numbered file descriptors. The point of poll() is to fix +# that, so on Unixes, we prefer poll(). +# +# On Windows, there is no poll() (or at least Python doesn't provide a wrapper +# for it), but that's OK, because on Windows, select() doesn't have this +# strange calling convention; plain select() works fine. +# +# So: on Windows we use select(), and everywhere else we use poll(). We also +# fall back to select() in case poll() is somehow broken or missing. + +if sys.version_info >= (3, 5): + # Modern Python, that retries syscalls by default + def _retry_on_intr(fn, timeout): + return fn(timeout) + + +else: + # Old and broken Pythons. + def _retry_on_intr(fn, timeout): + if timeout is None: + deadline = float("inf") + else: + deadline = monotonic() + timeout + + while True: + try: + return fn(timeout) + # OSError for 3 <= pyver < 3.5, select.error for pyver <= 2.7 + except (OSError, select.error) as e: + # 'e.args[0]' incantation works for both OSError and select.error + if e.args[0] != errno.EINTR: + raise + else: + timeout = deadline - monotonic() + if timeout < 0: + timeout = 0 + if timeout == float("inf"): + timeout = None + continue + + +def select_wait_for_socket(sock, read=False, write=False, timeout=None): + if not read and not write: + raise RuntimeError("must specify at least one of read=True, write=True") + rcheck = [] + wcheck = [] + if read: + rcheck.append(sock) + if write: + wcheck.append(sock) + # When doing a non-blocking connect, most systems signal success by + # marking the socket writable. Windows, though, signals success by marked + # it as "exceptional". We paper over the difference by checking the write + # sockets for both conditions. (The stdlib selectors module does the same + # thing.) + fn = partial(select.select, rcheck, wcheck, wcheck) + rready, wready, xready = _retry_on_intr(fn, timeout) + return bool(rready or wready or xready) + + +def poll_wait_for_socket(sock, read=False, write=False, timeout=None): + if not read and not write: + raise RuntimeError("must specify at least one of read=True, write=True") + mask = 0 + if read: + mask |= select.POLLIN + if write: + mask |= select.POLLOUT + poll_obj = select.poll() + poll_obj.register(sock, mask) + + # For some reason, poll() takes timeout in milliseconds + def do_poll(t): + if t is not None: + t *= 1000 + return poll_obj.poll(t) + + return bool(_retry_on_intr(do_poll, timeout)) + + +def null_wait_for_socket(*args, **kwargs): + raise NoWayToWaitForSocketError("no select-equivalent available") + + +def _have_working_poll(): + # Apparently some systems have a select.poll that fails as soon as you try + # to use it, either due to strange configuration or broken monkeypatching + # from libraries like eventlet/greenlet. + try: + poll_obj = select.poll() + _retry_on_intr(poll_obj.poll, 0) + except (AttributeError, OSError): + return False + else: + return True + + +def wait_for_socket(*args, **kwargs): + # We delay choosing which implementation to use until the first time we're + # called. We could do it at import time, but then we might make the wrong + # decision if someone goes wild with monkeypatching select.poll after + # we're imported. + global wait_for_socket + if _have_working_poll(): + wait_for_socket = poll_wait_for_socket + elif hasattr(select, "select"): + wait_for_socket = select_wait_for_socket + else: # Platform-specific: Appengine. + wait_for_socket = null_wait_for_socket + return wait_for_socket(*args, **kwargs) + + +def wait_for_read(sock, timeout=None): + """Waits for reading to be available on a given socket. + Returns True if the socket is readable, or False if the timeout expired. + """ + return wait_for_socket(sock, read=True, timeout=timeout) + + +def wait_for_write(sock, timeout=None): + """Waits for writing to be available on a given socket. + Returns True if the socket is readable, or False if the timeout expired. + """ + return wait_for_socket(sock, write=True, timeout=timeout) diff --git a/venv/lib64 b/venv/lib64 new file mode 120000 index 0000000..7951405 --- /dev/null +++ b/venv/lib64 @@ -0,0 +1 @@ +lib \ No newline at end of file diff --git a/venv/pyvenv.cfg b/venv/pyvenv.cfg new file mode 100644 index 0000000..853404e --- /dev/null +++ b/venv/pyvenv.cfg @@ -0,0 +1,3 @@ +home = /usr/bin +include-system-site-packages = false +version = 3.8.10 diff --git a/venv/share/python-wheels/CacheControl-0.12.6-py2.py3-none-any.whl b/venv/share/python-wheels/CacheControl-0.12.6-py2.py3-none-any.whl new file mode 100644 index 0000000000000000000000000000000000000000..69e46f489d3d286241a238ef91f81582a1210907 GIT binary patch literal 28023 zcma&OV~{98w=LMVZQHhO+qP}nJZ;;yZQIsq+uiTnnV5}_Zn=op#k*yv0w zon2@x?ab`y1yxlfTug-lhmVD9;vAD|IC6`tt@>CjiPfZ zQ>%=cjgQCY^>gxa`skfc&K~+JQH{ z?ZFeDy)0hkjt?a=!}p*D;xBYn>pQexM8zVu%sRkr++?u<Owh3f1CX`D<4b@hOx;!VII!yF?d{y;CqdsA4S&;~(GW z{dOm56m!w2QPN-uAYiVx>N=w8(yO-PPQFKKt*S8B3J%gP za7Lw)a!fJogco(gm5SzOs)8A%nrw-_TeC#hN(V165q}e9cTEF^J>^@(FzeR0*UyQ| z+Z3z3(JD5UWv{cX>FDIAx=jZ9^EwJAQ?ExP4$`97c z$82-X^=Z*ERy9{reqa?C5^olbiq;=-0$rINQeDyqF;}~k((CjeC^H)uMOxH9O|f(>*5l*zYP!bU;|{N=ez-k|fV%=2g2gHb zN6HX?R#TY}>;&-{o(&KhG3bJ+#11x|nt;%NKPp0-LT%(rt-3GJ7pSu+t+sUh0Ci*t z`n*4HUgzit(VGGU%88hFK8@SMmj%IHuzgHcUI_gwtnexmh^J1m1#4ZKmfr4AEP zRm?cub`)**Ho*@6Y*$DK!+>)sT7sW1TtM8g9Q&=NVL_H(0$*K1PySewB74-LY3fLO z&2w?r9YmvcGhUPbt^Z_olR6u~CG$!XT;Nm-OPswWKWeqPE1k0e~3pS|whL`ZG9mVzy~Xzz%x z@(2{or}D=GICs(j&wi`1G}SfiahS$ZAZ9uO0a_mRxtfe znVz?xG}-i@IxAa(=EifbI6ka$hkE)wbJkL1hDJFwlf~J!+yhQ#gB%*+mYN8-&d&>~K@?{}vew8Llh`SikB338&oP_H zGMXHldkn!D0WN)>FKk>SkCBhTo6)6i2iNty-o0R!6EM`~xOWNEyC8p1M_RI9ReIij zpe)^!`qp3IsSR;MDIDda?@MjMz%1Otk}I}#GUokGyM4+TvdSX#I%m{LyIIS~O>UH^ zw-%;@hU92nR^pOK-Oj7aDM^sfE|>j0P^8d3QR%&7>1be(jx#plJ-BI0%gY%sXJ_Mh z+?yk4GS_CoMdipDWNMY;p)Qc2xZRyO-Dgv;Vc-ImWVtDY6-?xGJ9ztVg=1QJYRf0WMOj= z$~sCuN^T0qkQi?6-{X+ggaV82pOdBZCBvKp;;ad6m!6IZK$!`uo6@(A=oU*e7L5-4 z!Sc-EYhw_6FbY_e)ZS3L72?~pstrF}i5ga4iCFDiE-f9G9m|fCdkgYjGf(N#cW6k> zuCs2TJ(=J0+yHc4t7gXR7?u8uz^pczx}e-un(UvO6lE?XOI3$*mGz{#qRb805>|ce z^bEYDh4FpHu2IlT3)d{RouiT$dC>b3n9gE0Fuov;!H)udVMJO%vc$~X8FFWP(cSmR zd>JuOU7TcKHSn<2Uk-ix&KynY!s3sKIPXv;IRx-xY^~(i#Rn3&8Wxs|ty{2#y4tSp z#(d38fS)q~Ee9WwT1<{mCWEJIXu(y4{Q$;%=ro;f1pd<=tY>3kUPkQymcT6diXh?e zXcI08A@TtABkm0PO#YZ$dw|DWD@M<-Q;L84sWxX=k-xI{JgNys&1ag_u(j@-!e4`u z3SkD{`|Ed*qlKjrcRuggdMD|e^1_T;DjW3)75Bjz0~m9 z?7US@HD%yqD5=UkYgO%45d+}>y*_daaS@Zq&;_bPrEw-FBnETj``4E2&$NaOHPlV@ zK7BRD-o)kfCGBC$bNcdZr<%DNpwVq?WC!*B=29EJ2P=3Ka~*3qUj!XRbb)(K)mV@0mObXNH^|ne4r`o>6WY` z_e`b(D6p7%6({i6HY{9zAmWbbqCT8JOqTyNyclmpmk=H0_YaJTdA$y>tFTjq)DiMl zNcitSkMq!oS)Gkn$_Eiqi$!f*eo?s<2 z9*9ePt_b2j>v-=xXP6Zaa*p2z;z`BM(t^v*7|b~xrzgfe9Z8C)_4lDce?kyFsFpBA z2AT+sdFGQ#Xb+LJH~N3`4+<5}Pncf8PEkM?cGc$1aib;4bSD_jY?0{;zD7Bw_!452 zj4h5@FlT14iM&{B4>2_^%H#?2cP$B<9XP)#QAZ$np&JEOe4rjhd|1Zw`*ErBu6iJU z&mYHy>6j%=53?+f`%<^qxjdm5gvBruCd1){)v1s-GVPY{{hW%9mNyv8;^F!K-W>0hFvLV~9)?=bmjqA{imauYo#(|`IQCFSi3zNqqSW_*a!N+*e){V7#3^qw( zYaSzbun^DTnag$jR_dXWy z1WiUtOjyS=o{Aa|qoc*)f)Q(5-JEG|RpJ>}2Ho_J>&Q+Yr|@=r*Z0eXj<{N*l_2`B^*kxi&f0h*&M}P8?Lp?u*r-e$Z=b@O;3v zspK-=(10>e#JIajVEey{Q482Xg|0=|8MY{joRnOtm+7eB!(!S25DGe1@7c_ivRWTG z+mv?C4Z?JM0Uxb(T;^Xjha`yLvxx{bolgZ)XdEainxo-x_;j?f!~9ku9_CE zLnWEZlQlsRYqNFRpLSaAPv@W$5-XyLR_uNJH z#4mmR^F#1S_T)cAOazSW=B11v8ThG%AlUDyPOOJ(^G zJ%Kud;n4?+C|n_b-w3S*?z=~oPgV_;?b(XSP0sJ=qi3{n`8d8X;l=S+2;YhS;}u;9WQSobC`fYxL8lrvfS15#J4S5teq#&7n(?sh9Swbi+ zF-DfT4adPet2$`|WATVXL3ejlgSa)M~)5s(UdWHco!2bkVhSit-Ju7I@06~ zmrykp$^emV_2(o{G1-LVK->rhdMEu8nL>sm)Y+We=!cbN!b{f7+63v;H#y5>=d5Fd z29_4$n4A?|w|-sXaDEy4BpR;}!&i?$H{&}eZA}BK*=mroE)?(+J|(0{AG@|5dc6<< zX>P)^HMIH$i8A5K@W+Pm^H)iFn<=qaA(45{gd_rf!5FAFipQIEp zI!lvv7)lZ5_N&G;q8K^kK{o%zN|EOSF}CyF$IiClG>=jSMhA=!bqFfj191(Qbz}j| z$J&KWIThn$hK+Z`a|cafPQ^dEIui^|QLF!>O*WlCV>D^IDnB3ie5m{rh}scU44X4h z{AsapLF^B*gp4BrdCOD14-J{|<9mEH_@x~)>{{;)wWDY|I+zFnvP8f$xCV_MkXK0; z(bX3n3Gr+=OzqRY6w-vPyRLSaESeBmw9I*6j@mn=J{PUAg$2iYkv~n|p|P~r%)^#wyniO~X6 z5O2EUD0DK6W@EgX(6Z$^tODTHaWUk~cek}`U(yjM=|nr+F^amUM5eUZr{`6I!s+lx zIm>B&S`fuEzH%zaBq+XB^GMW zRsyTUdMp>;P-f1w82kpdZrNH)SbbWtA?}Khe8Q#Fww64kuU=5pmcVr(g-?fGO30U6 zg-4Kg(N}3>eR(&3XOO4B3yt7#34$Z($rAa#01GZL)HY3}M%OV(6X6;3?D;wFkx1h% z^@K!sAbgdngURi2Z0mOUJrgG?1pURuLI-<2xPFFd0FC9|>+>|smX$rj-&U*ho4t)) z>QN-paIU^OVBlUx+9Ci{zwC)p^6XuK28hoAPr7`uN*4(-B+I$c*nD_1m9P{Yc=4GwLr+(8l;`|TKnm;{%nwaSUSUEcPA4w zyG%wNcYf+d#1qt+fKDFohqta`&DX%+MExK|PrZ>l4TTC*Za849hanr?DmnUg-2n&^ zowUvHJdbyqZO90{jIxA4St}T`=fmB>&;<=>`tZaF$*=dU?0FS%e!N5wr zh4;;Ec5W`8=hyM4IDA;P@Z24Mn2X=n_eOH~82mlRg|NqZh@QH2<9B*?H!=-3srDD4 zqYDKRYY;u(GYjkT3niPL*>T7s&W?`rm;hb^$Wb@suthhVxoa(^$l&{sLm-n~Q6@cfc%z>hjx;AI61-I1raMV% zbGLT4C$(Vd!nFnQeFX`thNvl~ED**$D?3A>tjLC?JAfk^h4|8i*)|M^Cvy5>l96(W zztqFJ=q@4IlQhYyhUFAfxWnGcX+ws95Vx7`MPB|7=QedzQ?hque-?Jg6cngVP*l*a zc;>L`Tg5D5+UJ!?rl*6#4GG`?vppqc*}r$S94l_}y*#p85Si|U!cd=Dl~esjt}~rg zQZpJaUf9qwO~pJXuAk_#MwRwvTs5t8&BuH;>4)h?XFbELEFlf79(dxrxGaom8JVa} zx)GQfDkiT$Uhx+D1ek4LdgrH4xdRD}%E|OF$DG#^rgy6{t}nmAK!+71P_;l{&oWqI z(B7&Ib#?`>1R$Syf*5WqXlk~QlBw!CvVhSY0pn=mZEU%-mgB<)H*1RUQRB_?w2PD9 z35@p^2>Mcp?V4wxbMpC^u?M?vd2YFF<(u-f7w?I7@x1nI{gHb>e{xTMbF*^=b8H^rEC6?739b2W&1ZwSH)W8PDuF>(RVc>>Hxm*)vanQ7W@|fx z+=mSI*0*C26Yd+>tw@b}YI+-c!lJmet$5D>vwC9s*6g*~Z6_4%r6pxz`muMByA~bx zaIJ5uFe;_SFSY<(ZE0--*mB2WI?w9>>{H#LrdQdL-YUOx^zTt(S&T`)Q9}@=@d$l~ z%5|7^dI@^9pM(igIlKTAG=0feHK;iy-|mfjMd<98k&XZzzk#k7w)SCHSmg)t`MLOf zJwEo`dsb(dqaAs85~!n$P+zt;4x_?%me;)R*gI)ZQ9jQ2Iip(Dgk_myCb6@ejDhP; z`F|CoF!F0*uD*uR-9V{rs)Op|E0Nkr`qhN4*@l-E#d9E0CI2e?7Ra!)R7T|r!oEsJ z@R2rDu=S(?%dn%g(C3UUT0qBf{!H&!KuTP|lJt#V0zfPydU}CBHOvLxA2W#~cM z&=RxW8cjn|2C(bP`H`sfuY6jyr~l?sIy`S?soip|iW7kxH>Iw=>%~=PjW0}Xyr6Et zyY9KV{^M`aM!Lt7H~=0!vgyW>QrNXiE5nYV?9N6#?r9|CiS$_-$+PYJDBDsq9cZ$A z|GES{({Fm2YpA}fLmX8+_sVcwV_lDH@4NO8P5DNYW}m%^JNFvAH&IG*M3=yW8Gf<_ zXlDQf$3A=y(nFBzlS*7)l&^GNAv2RXD+XmjK3-k3jLoUhy6|x24qEK7qpHH&HF29wZWr+-FW@1eq!EdR(dVRf_4FNOF&`AEpa@cz6{~%hritg zGHKl&?C|!k`0ZJ1sI^PxjT=V-Bm*Qu;)|{bzunjq$f3IAb%WGN_cXb%m|gdu+U4Q# zTCTzkm_~j^M}FPy(gr1@vBi62dnQ?S<`9S z>?~s^r#tU(4bdIJoR)=E`-Fmv#^2%i3ytoTT12qSe^*%mthkc=re(I%IagakI6Q5w zH!_~B4CUqUb8-1MZ08;mVA_y{`c)*DpW_BcuTu}uBI=2WLwk=-wZ<_Gv_fMM^jzZ@ z*K5LNgp3et`RS8BpW7py%gl#(H`aL2iP4M0vpono8yF6LM33p`b{P2vJQ!%%N|Q9_ zex|8mXpSAZ_!2HnpB5#GmyIXWJE%Lor{t4~mE&Qn&a3xed5(2O@`jusIC(S31! z`+3x@b6Eo+;c!X)!;4_uw-*nGr_g2A71T+-hP*!uG71|Hyb)>8fEu~KkVv|{)ito{ z*Cy}8V$h?G<^$)JwI*7$4S|)NiI0OJ*8;wkkigMib8Lipj*Rl9rkr~GxA+L`7@m8w z%~HL4VZI@G4={q!JlgFghG7bB#h;FUh%gziR7?)rGJSPIuSk%SkS~tRnMg&?@Ea#{kUp>!&()KHYQN8w)0O&8VL3GvM8D#cWBE7q*82Yw> z>Z*QwQKmxXqy)xU(~?txEhA(_~W4EXc6+BT(Xt->n!zBP>zwcwUkE$xI21&xVca#2!@ zDcm6h{PIeuY)EzJ748p$2JH2v&I@`|&XEmf*gT8*m~czhPkG7vbM?7pNWn+x>k_?< zkHP^FRl3v^?b=BKB6?Coi#mUL^O2@DN+e(-3fD{EZVgik4QVs$ArPzOdWzB>SWt?7 zCNk4KHiOiBJid(T#d)oc`_36ZA^_71$qHM{(*TQu*zIzVVgzXbxhjqMm+#k3 zajcXnLUA0U$=s5-oFDx1J7d`XvNT>8nzGjj@Sf!96K}Qu2I0F!Wq${Cdd8QB8XE@! zKB+^hXqvAc40@G1p>>MR5TBOIHPpcAs(xa)9&x0<7j-W_Cie2$of}@PwX8j7!S%*(G)r?F8_L#46 z+#QqIs&G%D_-|?w!_O4GzHz6zba`Unw(U`t!su6DzP5JFJ1w{!3gfb?eT4;J${sMY zTYTa^=jANNjq9MxuI>9+^d$1U!b}u7Ift*COr> z9pQhi;E+%@9Pf`y{(ES^taI3PG1xumbrRHy_RyaDM|}SueE#3tzVEWUU(%2FzOS#n z-pdAEB@O#(cYdY*hKyea{&Q^2T@b)lxG@bnFN;;0JlI^G6M zH}Akm*lG@N%xL(+>M-Jw!cGqM!`(lSoZLf+;PZD3`C`Ku=mB$Rg7rmU&n${H`!(m; z7Kimu`RiFgS}vXS5;Bytj~lValIyU+!fVR&&JIg3)q+51n6_y0O^Iunf3ksS_~Uv} zv1MsH9Ca3oe+Cxpbnl;+S$yQ0x9}wu_6D47?RUzVv zKLSDQR0D`@F{?VH)I5!$;~~2v^(b8Av!qE(6zPjZ8zwS>4T_;OoRejWbk2$NsFioD zbI&-cicoLNc=w8nV`<&ZM0L&q?bslL%WQAy(iDHW9nrAZTW|B8fUOCY2@ zQbVi4{@Q?upLbKfccrB?!E{Ig`Qzk@`vd%^A!~0%JEj2x0B}P90FeEU95q={6+sa} z6~R>1EvGFu1m7`rn>-V9n)yG@8I48FwMTL+iZ<*{f5l-XYAJ?6`hoIQzJ1a2C8BH1 zxfX-LM{}FHc)SPHp9&H5Vt$1#ix((m-axxhp_JRv-m&UpUshGB+wvZxA^qpjVwDDO zlr+5c)tRycAkF-+OfpjxTN}evsjye<}Ih)D+rGQW$eT%C` z>tbaOMkjGj2f2z~-Hla*)F=rw{kEJt8c4IIa9WBm_U!w%cX@Xk>D#xkwA-8KNWyNN zw~a<`s1GRBpQk%(L!6yR6AS$ZVbx02%6VzJ?_z^lLfaU^_9PntpTz8oS-FHDA0svn zRscHXS^96#nAl(y9oryMk zTT4-=K!tS7n+m%^qiN5UNOI)~iRR$MI6OFd&HD3&>H`3SmMUXBS1eaBic-oTq;t{Bxey0XThGZicb< zhi4ryk&NnaI<)LQ^!vk;74@Sz*5yb?%)IUzMep)qZ5k@4u1sqFSmQ-X>-RRiK{z8o z1x*3_a-h0@>CWv^RHdY$`7{N%;uE$brmCUfelIE3HOmqbPWO$2VFP}e*WBjRkQ&Ek zB3v96GnIdyOPp9--K1eZlWP<{u4_L9^%`MWMv`7SsV=|SNPz0?ibx^oYEJA_J`UySO0?*>wBHd8D^qG2EhBMLX+-2R zJg`=6m4YLs4H(voksw%r;d;V{etm*+qcGU0BOFIbesITff5~Q<>}uzNFkAUqUQBTL zjtWy*4MVR4QPIqnx6eOIcwAOOwq&(S??{Ft$yJt0Nk2ESU1hP-DhHelb&WL@eg%F1 zyvd>&I>TEk6HgZD4xTEVsrj@-FM}BZOTiKge+Z4teTw3g31E{QAfGh)G8d)TqgFG9@p9sNID+g}sYCg`7Qvw;Bs zko=FXtt2WeuOt$>G?7%OfdaPg%Li@Zc)&#K6(}=F5EZl^CSZnXI$CC5#l<946EllC z5OjOC{kYc;zerJD)msy-pPQztdFz=s6Xa46pS;W;yXf4@ik;J2^~VpGZV<2 z>e$w!yc47o(y)3MgplEj*yBEk$)^$H6v{nBiQ<8_z-*TBpk%MHVGAy$9481Y_xr_I-oWHQy9 z`)%8`X|%2iTLaZ;ecMeZ+ij0qLY3U|n42RgC8~_*~g$boI0!+wQcZQAFW!pgj1+< z9G*$EP}>PwLVPVbC{FY}Vh%}!Ix{R-+tp{ydEP|oe=OYLM)=eF?46^`5ti$ifg*RZ z9N^m+rJXidTUQNq0tD|pDfE^MeUsO-846QzY;cM?2hqlx;9lxUU;ev6-gZ4vl)2jL z&ITMj{S6Eu<7I98AH2+E92Q?cficha)$K zhg6Qw7jBK023eE&07c=^zNNgN*H6vtA|^F5f+7H}8fJgx=SPUi9mH><(QgK6?-y1? z>ds5*wMXh`;AbXVVE-mCIzjDfIZ4D(Oz@KRpX0wRY5jXm$DJ0>vMd*EnWGK68Tm&^ z59m(T1RamN-kke+h|O{K&s+QAei{Gm8g-O3}TV?{{|nfx%7(R|LqI* z-=O{<_vd2opl@U9W@__aNLX4!LWc8;2Ia_#`=zs;-lR(N0iZ$3Ie004}CSL6Sp z&Kv)q)OmV+eM>t_7kzy?2T$90L8w6n1kqQ{kpy56*8@3)C}_bsg)okm0$VZ}rRX;H z7RvVXm%i6t@AnBkic@kJHCMn)}Vh2cwBXFcTDPo?0oUT?E@-!_x z4y>`-ng6MkZ>`Df??nc29W`fHde>rwlp^diyq zjPC)Q7NtHwGbETm6W!-u8OFOvLR;)KP}GL61^X^eHU0mL&PVKCT(AG6+x%BS{MRP~ z|0$udt;s*>e3b{{vKSD09#QFf0#F)WC2(51RK3^5RN1{-Y0?p@43xdkE5ASD#@GmV znsp+~ce_3P;?FHx;YKXN1+xk$TzI(O8Un=iQOM277bSYY>tSOMn&ksm=_L-(!$|`r! zgK{O76mB8?1~p3D9^dYVrphu2%}qb*+h_b(=FSCV^Nf2c+e9jFoq1+jf_V9LqxI5F9td{!*TEMN#9l}N|<2#R-mqcO>d1Y$JZ5odHENveq|aHcciR#2YwbCxUaOoOjWJ^|&RTgE$zL9>CG%0w{UD`CGc{JXz9Yl*ExnVNDQzni47r_M zT*ySxE3|{_3gb$<(e;CK*~-VxAZEPB^V}C%~410o@nH z;=%^GKs2`auzl#~^F|^PiInRCkBlHf1TWtG)z_UzD;ukXwkZv4TIem_S36CO5)-Uf zvO$~XMJp#gtWS$!^|<>m7SvXQ{Bg?d^SuZEQshx-MU9$L@Kxxwn`h7$TR_z}n} zMb$9d^}VS%{njZ~Z9k8h-2VgqC{I#12F+nDK8eA5MHW|8gucV^9r0 zhO8R9F=j%LP-gGO`2aMFJ@)zJNaAKK4C={cIUn)@cQdBnu*+af-(F9iu6Q~eyE(L> zbke~#x7^wX1i-p!N=?y)^MGv_3^Qu7m+GN42BxS$mi_Rx*XYcZ7_tP2n`FeR#7GO%pZnnSxbxV8OPow6Hs^L2-_oG4h5* zvKB>Yy-A5aTcqGUZ8Kz3;A0{MaJq4gd#D<6Jxr#4@D5p3sRoO*G|c!uaW8b+)^`fA zK^In13mzXfo{I>Rh@U1*fDBl(PLPV;t*IA}kcbppOB6{~A6oI5s474}AZxR2QYf4B`{Aq=Sl8_u6Jz@UwwC|Y| z(=4Y&L-vehu7)D}(%00W=7!QV-*6{8h3$d|Ies?f0EHP1(RM=$FEY*5KXH?aAHNu+!$5WxKk* zmUs5HTUR$IL(_CRmKVs^-VWilc{ijui6bttO0**1cNL0^KE(7BLFEqE+=?jPS2AXy z4{;zLgn7{-eu3f225e_njmZ9vq6dPkVw_LGZhx3w;E3Td61XE*ae;t40~Z^-rj}v1 zAWK+y^a_3PijFj3TRKL}HTjUS3bGAfUxs4Ipz!ZeSYnonfGwKjR=-9#mDq{$DrO#C z4h8ZKB8RzAh=ZUQMV`VojmclejfxSHXi_3f2x7SJ^ud&*xU*|dy2y;sy^IJDXPdbS z*xA|r2_V%R`U_QyMRHf0C!k?Pf%{#d>K@X609J?UY$1%5;I0W;Qi&i2g64Tsb@R7` z)lNOBt_j3~cu=N4i;SL-VD8IEY-W0Et1F*SPCsD{>CJ97$b>nOqcMCC$v)Kx4J#%s zul=NOE6E(*{JUnNj3ozmpeCeNF@IM4ZYQS!VjNO=_suI1F8u{$1sVd)o2wm}z1iB5 zqguPnxvVed6n4#}v;?&W?|Aqkcey!pi_v@!(yK2r|S}<_013WDJ5tP;paB?v;~cO0b+X}x2o?my@)$*XbzUa?ncZpw@rdBZX%D; zN7^(~hj&!Lqq9v*ud91r$KEUMmhnm0K22RislgLIn&_4HQ*Th}EgW(yg`a8%U@IQn1s8P2p)4wcF`mYW{{qMp1 z|48}&LU)ehlwB|bLiZ=NTDE}Hdw>MzlWT;EDDP98j<@7C2KI(DHOk3eR~SowiPR-9 zgqxY0S+;402R8vl#oNUmzXIZRpIyNVpv;n%&3vNcCnBP>ghg!26-{6yK_DDp37X<6 z#OMy|`rCXkTU3lY(^JW~ha|3#b08V(pO?V>k*XpDAx%tTp7DryOKH9jid7*1{9Q2b zVxGbpb%)_xa0gDo%!vBO=I{Hc4^9yL2P2{}PEXLhMYlI~*jO~k-&;XVeDRN%4W}#X zFLFDZ7=K!$T>({0^YThMw6J)U2eY#s9$BokKi;7;3iMeTG0h|sMb!9jh4N?EnPPu~ zvREcTa6WKgwzpr>3WiLaKKd9m+-Un4_#1}3QaJY9F#9I5xB@vpnk^tTyexdPfY1)H z|MQSB``Q`U{~fN{zk&b%dC1QHPs}JyJvpa3FFiFa87u!^7*ut9ns%I?O3?v0iX#{l zB?a~20UEhuv7ahhNtr2HF%>K@L}BH>1Jtis`U%K?g*7Jv0080tW=%6o8&m!NOUbF~ zw*Qr%e{S>#I`GNd!;qS_!9gJE*<=F%DqxE@77Hmrw75j8NtFmHIPgA>+{Kmb)wYd( zj3UK%r<~_-JsP=ZtkG7P#|1Vs&_^97mw>c3xb60X z(6}m+)T$amcI+GvqwPG|n!NnkjNiJDNUKwNlwzmpTGYJ2M-sz2`!Kr&wfV()HX{w$m3EUJ`Dq{n zTQUB+`wd&%%_zXN`6hrR0yeVE)r0~xVQmL9MBI*+!WsEDCmKA_kDnh&9sAjPq_~l0 zY`F@T`Lhzm$$C6cYlwIeO1MfuQbqQw;!SNFd~_>kwl5zl2imHAngNinEuvRAka=!u zS9lotA8~CZQ3&Gf(xjzVYj3;y_KfgyiDMJD=F@uOCUkmvHve58@jmL(RvvN`QJb)1 z7r)`{#_Rdz<aAo<;aZROUU9=`lxW$gJB( zgaz*Okwc`Vh&stme5IL$VMs2xX=d4ZNK!_}Cbn72G@w<*k8(iqnNiE9X>s z^i)2ij=y6oTYy(+Ak8R^>&UW(VwArkG_`6ctfhcyse)_I8p{BdO%Z9%6th2*FwqU$w_W~p+Kx6E3zmx49=&2DPY_?~CPcD>ur=9mh%1WFQ;2*fUgEA>K0_`3pQfw*QLgBQ%{QwWD?Mw?L69 zyuis$smmZBIJoOlT*?7i?|{41_eW*oc*5(wyu^%zmBdaOM^s6Wow0yk~!35TUYh2QATa@-)2 z?sj}olh(31`0l<^Th$87rqlV=VTK7@euU3cFbd$JtIczOXgD3LX9PuDGQ%b`X(g7k z-DF$jU=hbShS${r0KC2f^*wZy|S0zu43@( z=@y^7Y8ILfUwdEx7SAlCw@Nr{x*g!LF3?i0Rgn&GdkC|Rc%c$0{zAK?XT0z*c#|(tnYoDeqIN= zm0k2(77|`qE}ZnsA|;MNs4s;$fLWJRcl$jPV3s1^F*cwjdw>9qsIvA4*`a+2EZYj{^wy znQlKYnN{EzI@1|*2TtnLA;U7htTo@S?Scyf{&E_-u!cM~f}iLcJPrBNjou)EcNM9-qZSP#r@IEuQ?{0Nadtq7nXL839$)D%-E3>R=^Lk-*bBx z{JdCNq$=b{9s(XB9Sv@rB}V8uz%FfDZrTob{%?8#u}yGr@+A?;*XIk_%XvFr3gz9S zC_8lcW3G2!^WPnQpb!sSpSaJtcaU$QJ)d#g#1^}kyC3lX%w0(M74Q200D{avfI#%W z$s>CNq_xGHxqCP z7RlqCdx-}5dkEXDcpfqvZHF;Jvas14oDPhXzs&i}F;{UKi&NgSTE_nKqy3a#yu7vT z>cVe-fTbueVG(_d&Mcr*Nj3W@K%Ka*MxvnOwpxjve1QwGNMNTX1apk*^OUG>1G*Lb z?(K&pC}KlX%b6L3)u?PMV6$WJ8vwgu=m@X*jrwDAF9}6@&DP#xxn-RbMXTv3oXHhY8ZR)8GH-uic44n2+&`4rL~q?&XS94L4>c zFuS*;u2g<3?Bl1$g}BSecR>(O%rj%!x&a8s=v}ct%po9f?{iSg%v1~Xv~Z2vRr&v? zdhDODYry`gC;VTp7w!M09(!8{LzjO5E>?k8eux2K=bKv2Xl^iUI6?(YMRkXGtQSF< z+YTZzqOaAk=fvNUk-*b@P4aw3gQxK+T*z+`TL1nFsS5SWkpXV#OGx9YTV?Z`-gv_KCTAT z$#c`=1ERT?T*u~Vm6?8t^tHa2bZwrR9GloSp`A`BlJ<)d{cM$Oh)9^;Ox~u}f?YKT z@6i-IDOx0n1XLwq)t9nmZBaJhqV%#P5OH319d#|^Gej~_)Kx!xsC;8;tOOz7i=)r) zl^OQGU%7t_!La(La-n7IxXO>JrFV>m8Q8zn&dc!zMq$mOOKeM)3rU_65vRd9%Dap|9e@IyAEYz zsRbQ#W4XlwWe@%q)%SreoZNb;DB=__k5{kQH z@j@6X&;7hgMd;k5#8>UiDmVXFog}w&y@J&lcqKEPff^=%RbzVgxoxy?W4oeW^l`bZ9a&n^R`1yDs zp`-gdhUp}QSjrn=1scdP%~8SXoSWvnXvQy#5w6iji+coJEL)NM*NZ-_IU@jUD2V=L zI0JYaiWZC@r?1OznTttA%V)pm9_EzXFDC{0i`L1s>C#i<9MPpqW}1oi*PUZckqjz{ z9N1XR5b6~MXKuQ@p|pZg279K|hLfRB6C@|@$+yHk(4Bx4yzZFWR=oL5US>QSwCwJ= z1J*+bf;yVZFt`k3EsNJ7bR;nrH2|C47Z{Sz=|MIvD5Q?_Uq<}_CD!>0ilO{*(jT9S?456-TgfU)@@t~}_=<;ZZa zOPx8Q>ttk!oj0K@?!QWjZ(O1#a8Y}dFWjT2oTe-TgwDy$E83K;F-G8H=lZLbz|hWX zWadWlUDVYO_juyj!q2j_Px<}uqp3J(^p(}o%Bg~M$yGbJbdHGmE0TY2PUyAssEIw+ zb&>D)9G7fGvveX)gGUf)$YBLn4Lfl{JoB81d5sc5zy}XIGzOx!Z%CJyn+(bt#6W+` z@7GV6(btkkoMmG`OEI|UpMuf0Cr>uHIS%U)&A%>3ztg{g`kaN?VUFG+lZ~x1`UEO5 zKfil>o;VMeP$%y5b^^yEyT8!h9ej+olgvpRHdan1HhWH1n7gd{#2ii@-)*U1Y?iPg zg&AeguweGd&*?h_ObjVfmRLL^@v_3+q=-HRhrKPKJt$6`F-erWV8uehGYGaxhxF3( zl_X>P>ULqOyQ9ld5*+lAJNH_^hD{NwjIRs?>0_t+tnLPcBlsTVt$fW(QRR1ciKXr_ zQj`c2H1S26P$EpF^!LWJUndtiJ!7;?+taY0P@My$jkb#;54@|%^$8P%Rg>8u2~@w> zPd4&?9Th(zE2qo$`QaE6nvo-BlxXfibJzNGiaXeXPDj+&JXfVpbHO?sy-OZB@u8x; z4abFxQR}=`6i58q=(pA0nCjEclAlZ|#52DG*-jGvHV6!S?#gZf#RTQ0sC2<5V8bFc zH)7BcVk7dhxoRCRyrl{S}b>Kqq{jBO0O^sSaVpuXSBbGgt79R2cgu??)rWEkaI#!F=d9*cPLd1tT15&pbn z1;k{vL#}+ncX@*D7gD<%YLUz(4rpuW0Rl{vz2Bdd?Sk@C4Zi>2Rr0kMb$|x{z%pCf^d`s~3?`Q9 zw&e`1R5vtmIdjr8$0)5Y`$hRl%`g~T<|}6QVnIGz7lzKgFSF|*InaJBr3g82=iX}I z3mkFD2+Bz;CHR=1l3KpKitKt2L1a6sDK3mr#B72DwJo1O2lfjyc;8BGNyWslhB@Pt zuE4k&h));?B1{eJSrVQCH;=7li2AT}l{@DxTeh@D==HZ9ut5t0LvZXCNva4so;88J zjfN75VSKDZLI8iju|H@gl5d3=n=h*oRSGO-d_M;as)6Ckr-QSc*eM>E29N-pqHdIU z7(2G_V^F_pUFUhV8^J@rhWT#If*R;ke#Sp-MoPoVF_i zTny8B4GBB=w0MRh`Rz+nio#4Qe0boQ>4R6DH9v1u@p zvk-!q(*-*PM~sJ_BOHIyNi~NnPGv{xm(2k3RWqzS9fIK8*?r}2HsdiUotl1 z6~VVX8?1bt#jXIZTv}BVvIKQ#1BWTCAajq`VFFQ_0dWL_f{(M&k>-*9+AVR>y^1~N zre8a2g;=`;`pr3I%XN4(QBq#hp5ZP;yFPQ4iEryj|s9^MXaS&u=E_y@D z9qekX(_hou<^H)=%PN|rtH_w}_#pyQ-9^iTSbXVlHSer2s61FwQElAfWYkn7R`0Rk zPSu5gceaO(nB+6$f_U8RaHq_hOz#Xg>zdIb1#|c&(0O<~Kp}_FB8-l%1W*kwHrz=B zmiWtGSrL4Tx;nGiZ&`sbAPaJ6fb||80&>pKZgo(gG)v+(ub{gp%<@{-S6l$<{0W;- z=T!735o%troT>>jFzBSt>Q__sePwRi5Y;U1(W58@D*X1S)=i+Md5Mx>dA}p>tvkMh zlapWMt-2G8H)9*y&^)*N8c&Dm(E`6+nuR73v(Qw@laZ;nGt70of<5ivgBko7>u3~VfxBfX?ihV?BK61i-fzBB zXgkx>s!_{Lmd!Ixil;msqHlsJPm{u<%m^sZ%=8_F&{IYR)e%+|RK=tIfNF z%W0=6t2x2)%*xyI}AZzy+nQ`9`b8IvXg%{z{YW>v4Y7n5sv%@a_zcwjaZ=ZP~5oBubj!U^u z2>QAMM@hQV80xL+EsRlimPO*!6%8) zsgO0^3@-fG6r`iK&40?=p6%pwOXay+ovd1x$Gx>Gga9I%G%3>5_Veb8z?>wwS5vIh zC9*_a_xEmO_u`l@u#}ondjm>hN$Y{k^zq=?a@9?%bcL*~JWcxsO-x>}Y}*i%cBHoR zIcliLd#-%wFjmg>TyUJcOOFa(i)4G!)6yPshcR2@n7bs;cm|Z zz6l&C->ZM<9T!V6i*>>79y%gw0`C}82h7z4j%K7e4g?lHMORN}#jM>@;33KP8k7io zd+P%U|KzV=CKHQy(kHV)tji3Mx1OAg!r)nIF{=j!Co^tehSFsyR#z%QoaK-bauR-b z$6tWs6Dd$oJI%YG@S3j(M^eC_FBJ-C1Dfa#8_gfdxN%U$2K3dTbgAd^-vrs(4?fjc^We&g;~Mli zPbIHciGNQg>bK;sgY<+$F)IYzx(|}Ha;gx#L1un+?*VC9R*-LfIW_jl#ZBrxtFdvj zzeQFR`@s<7z6FiCv(zdo$Qe@9hm9N5Gx%L*{IF=;j7yT-lB7B#Ee&hn5Mel%^k8v* zLFGJtjJ=vo8BQ7 zU;1`QkV@V7XzF5TdS=(}BRjM6xKp*!UItLfLxgDUf6BGvj1;tgPpkT`eRsM-hyQLMbTaroyN z=L*q-!b9S_JH^`Ts7wTur}XKfY^Xd(c2YI3MMMzZxs94hD91|IiOQ)Ou`o z*^xS)XdosGtO*k%cp=V-WN~r?rcu{HJPy!7M8DBiQvKCed41~4wbFD601pSbA*!j^ zPUo=QfLjOKjJ^2Mx)CD6kBjmnTMs=VsF7OCU1>p0>MZ-)-lX6SZ%ATQXRX{(2>5n` zHvQF`JRb3H#^4wjZ#y<&+QNl#u_()46qZp$=J2<^ z*J{U$cK9zs+Kl0d&f&3STuIJQSIELol5&StOVq&yFX2On=&x%9XiN=l5PSuFN zRLQaed{?tK-@plv5M#^lJOnWxarq5=EAcpY!HgY{_e>b0_q(%&&JF6Rtu#HNPKEth zWWoB5V^i9F)A2?u8SPn6cd>utea5(ql*n9KVkl4IH4O=#(c*;Y4Eadmzk7P*q za!ae|sO_zFIV+Mu%J3bvWm994$+_)3aw? zJiFmTXUp>(m=EF**h>gDdhJcL^og(8Gq3P}|I0`qv(~M8H%k3_HzfX>;%H{D-Du$&J`|Q)3nYC`rjqOD~_?n1V2H1D*qfPt8!|7LKT!MlG(F**+FKCBv5s#)3 zuMc@|&@axNaPA$tVh$oUQq+?Ejq*;M~b&WY{;? zLZp0kFxlcdF}DimmQW)kW9mGS{n(h~3jhXflH22@8M{vrp)K|OJttSxFS9!GxEy%F zjF@t!{2(gUe5!e?2-J;6V&uh`&1u{UQL^nY`Ta^5h9|bQT=QikS1s?&6eftEETFj5e#5 znnVKnAaU|U$YT0nkzbVI^LP^y@WKfryT&}(#FT{=MusBg8I*l4x0(QuHc6~j%lll$ zDM+Lj`!-O7WU^JhNcC@)zx;wKS@RSj-wh>@Xya|I5o#d1WS78;GX~=3Q%Vj;3tlpZ z==MYpx2prSRgzaviMeq=bj*FG)4=!Jm_A^Y{XILn--Nok8Mn?fbuL{G|#ZESS|@06Td@^EN6E;~(*>|?g$1C7An zbIq{`_zmGM%xIwgEUm8#skbV66_#1AnV*}5bg4=)>t}?-f7h4W@>Kiv!g;E3k@ITW z$C-B40QT+y*myN(SH+GFypG(z7SL1PHft(ZSo&aYeU~`CbCHJ_!dMX^Tz#u2nxGck z;LDWbn~-jA^RWNJnF%RLx-wz&9otSZPUgxO4ZYSBOpqniIN8p%yk|MWHv6gvh7QZX_m3R3en zUkCg2l1>miE%ay|w1^-nRtvdI_i72!CY8|=gvkBh#94HUjBhLOEobC8Yw=Um~`l?coM;7O^nsI5#QZS?;gM_&`1L>uIycy*2mCD^uk32M(l`z3->X)ANVFfF-B4 zjE(ONK#h;JEq~z>a=fzP`y4##WJrJhl_wQ&vYKr+hEp5`D90^%ay}Sx2w!ebjxs1?abYQH2zB@tlncIF3n^|TVIbg=nAG}4orS=u`N3(D0avQqZ6Cfq`J;OTw>#HP zQ0vwiiLWL(FIx%>^~7xUwCNqUJvpKEF|PXNK%)h!qG8h^K`V(^+(i=7Ruhe2|Fo;q zD}MGq5z4y_RXeXdXi>YRPM{c;|4wOFD7L-RAeOF@YFf-|7zI1eQ7&U|fCff+W@+aY zERnEAGR2#_4vJfciBZot6W>Zmr}3F)QI$vlO02zYxjC(0wHD6V@o8P##cnkemWRN1q+NI z)W&hfo9lN6>d*9J7AZL3%Q{cR`4tIWQ1$sU<&XhqXE~bfAn#B}$3D<{)UH zL7u7ht2DL+wB}l{hh{GELvVLaBwc`Pa(mfU24y!;3LkS0VZpcv?UmCPSlV3+LSp0f zF=2DLn^1^kR;uMu61zosAx-_nI4Y-2aiVCJUgk?Vmmn797!vJ0NgjtO<<5dg=w<$6 z`{LYbXd^UFPAw(b9x?B1Oa%frl<-PZX&0;$sHAfm9Zi={Xf6qu<`~@PD2T&U-ZK6w zXasSA0$&NEsXpi6jO{uNvRSHR&?>~UDGB^;6_K#9wU$L=+HfE15 z2>A@WkVRMmnkoa`%VFtJtVzbhqLZ5SV#LA+&VGrFkOmSk)JX#QZk&%l=*P4XM5snz z&sB|7h(TT#DnZFMEXG1^v{!@p?b_+pOrmT(?u=VFt&&;d(}rQ2zN5ncw&!94D!Zf} z7Hi#RNaNz=n&UhP=T}sVDRb;+4jG#UqYn*qnW8TM)*ISLi;>lAFIT3cvB9D^T(KTe z1}*;$aBGYU#rj0r5^8%@LfNRUc$hC}0!tkzOSC8KJQ$Q~NJyT*~P=UUschWyu6WDA93py-TYate!D^g z9p$+sW52a2*r`Rbxmu;W4&UK#$xZIkjpoD`Bj0<=tE*YS?sxh!OT3{i zU8akQoxFXRKpEz(y2w&3&pY>2qDwnl9a&hgJ(5HpMHML_&xPLVwpxQ8UYGlt;n7|y zH`=|QPx%NXr<#c#1_t9f2fLvQw;Y_d6ML-#k9WT3i|kTfDKXYd(~C4)3*w1M*~0}j z=k9HfpbL4oVg}<0dIz5`l*#Zs$luO1I=G35KUWtukO?NSu#TuQ_$Lw& z78$mK%zSylk+#&?*GkQ@o__0Lh#NX81x15+XNX=VQi0zPV!scq!PoT)tqmeX^t&7j zbi#C?Z=ZSgx9E$*gvBw)8MM4*9&4#cf^f6iQ8hNhnJ|ei2!s>e)zczI%CKn(fgIwn zHzLh>oXgzf#PsH6&A}&hWyUf4;qIBwCNu}!ofoG`0`a5=PBacSj4P~+w3Z?GUY_BA zLAza`ow-%IT_sBjV?rcc^{W)3eT>Oz_0b7KDW!&7r1K0nBgEAvdTaS@pmgvNOT3c` za@`fui-q&j9md?nQ8$R+)&*|Pok~D$!S;Q{baKFYC52+rm=XwdKj9clTJ5V3!%e_Z z4no9x^79ylN7R`2K`tfSqeBD8BUFWAQhF49o{{Bamt55mh{3b>^tT~Ob2?yoS(72H z22J$Q_8Lm5O_(*zH^uE^9h;BVSp6FDPPJIZSRBLfJ=ii3t1I)spW;Wb2Ay37lW3*- z7?0DGwPyPb(7W4NGW838?iiX&35Fdg|6F893R|ijjpDcSD^25lcjXCXmsXco+`BB@ zJvZjUD>PS=`@4ODq!5nlVaKTtg8;!2V9Z#%&-jg85Vq%smeKMhbzG$W=jlA`8ePVZ zfsqQFev`(y#(DqEE1?TcL>)OV35mv`r7P`@FWc!1CcvgkQNXwc>AmH^FbPIx?DIN| zn9;aJCQw;Sp59DUFNX7GVzj>?cG1bDmt^)H;aF@L$_IL7QtI`4*mev{~RTusjDbJ~i)V#kwMVnTuF3C7h$ z4@}3V{rsl)FuWJxcPwjbVlRAn@f+h_(T=p?N(ncCdY~pMaNGnWJ;%3~B&w?scbn9cFNTcg=)4v%uBODl`t(*4C0ee9hXmp50HoJwLsuuj+cZ z^v@{{$w#=Nq7f-eCzNUW*75$OctQC2q0~q1fuW0h* z2y|3GAO|a&dlYHdq)6m<2yemDlR!FG~j@(K&Hz5&e8ZLQ?I#9DF<#lX!&Ccu{`ob`yl2qO{EN4XY2q zg0Gn_<&~-N{ni*xnVY18(41ZJO3Mmrceav9Q$>7P8>NL-$hr=K6GzYhCXJM{Ti)cl z$^D%6#c+&{sNsZdzEfvM>X1?*F2cCLC|D~|J1Zm=beY?Q2tS69zUhr0(FVVT^JZ-J z#^JN-(a0uQf_XcXpDAvKTKjth5f}s&^sg}9e|~AU~Yzwam_!0)Q^;pG0#5~JjRcde}+Ck z5}XscaiGqO*&Ocx=%VM3evzJ zC;$Ke5CC?VH%gVpgApmj003|*0093j0EP|@CYDalw2X8tbj)-nmd-A;mUd?L^n$7? z67ovQbS@q)u|Bf#+gzQyetw~8Z-W*CJGXpeU|7H{{9o-mZt`tovz*z0(ngXrz6xZe zRkd0tL=$v^38n!yV3{)n*#PK}jpH+;%mQiVze0YJd1s|6bg8~pae(d*r1*&_ACEso zmC^j$n><|VnN>%%^(~JLO&xB#Y?6A^$|IFE{$JV9s#Rsrp;2^BU3QEzVACj;$!i7JPL$+%wO|I z^7Q`SKTpy4#o1fYZ|Lj`JMi}Uxk}uRdE@g`gA4rhd+{xHq?+YLyjFEY$lPuW`0+4?+MmzAPcRhIGvsWdn-0`7A zX80b|K>S6nYJG?Hi>O${me~imjhiesfc%l)FXC%dzESBsosMj^HdR!sM=^Fq)>klQ zu^x+#xaT|UN}*cZE0=aP5nn>NB+M|nyi0WP*gJ)@gDTddF#hp<-tYI4MllzS8l?@E z00QP}tF9xeF1>0y?&N!<)~Xs)VTVN^1uDG}w>g?rdzGYDMsa&)IeeTSeoWh_Trb6^ z?W)$XfzrNcS24l5g~qziy>s6B=cIts5}ky^Zrbw;|Mc`^BRIexj$N35loId-bW}Q@ z7nXVt=EELyyj#ofj&ve= zRs$UK|IC%wtMCkGp)y%Mdx8DOoS6ysG_I(7z~GYUCrIv9%fLa}1~3hlu%~>B8D`!3_WC(-d7EODH(JHU(#>c2 zuzGqMG%BZ(dZM=obKkW(>`F~#hkHKJG?;pM6gAFV%hJ8Hy-g!FEtGMz>{=rAu=3Gb z93*U$J_KOvb}PVW{A*;!E+sU3a(Z2hxwLDF-?(VGXjEWK*vZPQ6Sqs!8;f#F9O{xcGRBNT= z$na%^OiN*}z=qHGzs@^qPs;?&@pAKce}A8!-vj%7&>rDoul-=He9SiIT%Q*$V^#Ac zsA&BWC-CaTp9u;gI;*@Ys?Kvn%JL04+k=7H7#B|J(gI=~ebWSwcvbVH z$yze?3fWlEWc23*Hha`70(8L;-ATX-DUg}~rFC9u-1sJJ_?2hg8CdL_;%;rwRgxYF zQ=eNTqZ3WJtg&!)-*$~-pvRRQfWSeIFru>0cbGzjK-nh;LEqG*Z{p(R%XCQ}#a!)D z%5E}#q0DSt6lqb@nqui%tjEXa)pU)y#~t2K{cw8_0e1y51xr*Aj+7zNR#TY}>;&-{ zUJMW#G3bJ+#11x|n}E=OKPy9 zvS3~+8+gT9@SMmj%IQ!!gHcUI_gwtnf1~w`J1m1#4ZKmfr4AEPRm?cub`)**Ho*?l zwksusVZgZ*Ey2$hE+B4Mj{R2Cu^=n1fUmEhCx5L;kv(eBG%Umtq|OF#$-L497dX|z5@+wok6LZ+%jRqVxsSI!%FRYi%O>0zC8`G9Up*G-Wv`P0qpzD$15jpXuDMT!vn_qi+)O27SyK zj_?iq4TZoVJ77{OR?0of&uof;@Mm3;_x;h%3!wn$ZaR|}fg&Y;va0uaF$X5>d9>Sk zMXHM1sPv^lDa(Q`jePOf3SUBr_;&*MbJpFP2&paCQm_RV?H%z|o`9nHRMI?v^Ck`O z?6(@rqU~bbv;=GlTD}9S=kaa zH=c9F@nKas)YI>ovz8$z-4V0gGxR7^)E`4P=@Y1_9XS zOcd>WiW4>latb#E8)_P*j8$1W0PO_;DK$c9w%$AHXZk%hum_YL`sH=JaaHo;+X^0K z9SF)_p{)7K3=}jL&cb17iO6%HmSAipv)2Y9R?zIj^ToGA7B&~5?4#tPFJmNl$oHqDShjRZn1P@(dfWmEYDoNHU_~*qkvUO z?G3d%A-+wk+VI1bsA2V$h}F*Jva)g6v7AV`_aN^z^OP=qhlbRgI_nnNlleW*4M5km zYG%xiQRzzrX0^%G1?8@?WdFRRD03lMsydYG>}SmtWp2QhuLG2@da@VeiZNvBhpHeC1&Q%kbB#U?!G7HtB8r}k|YDGfyb@> z3h2`h=4eV67Jp2{d53?JLjbSF)=GX|d?10VVPSdLx`kV)tL^G;%s0#g__-6%a_|wU zCFBU@GI+X%7F@;Hk6_G)PSY7i;J@v`dNvm3<;4E)3Cx0T2oerYHsO*GB9BnN;?AHi zmzp%7cq$pU7$Kt8fS7sVlYR(m$qbS(;7C^P`B0l^wk)96Iat$w1+J( z8OyVsYUXZ$Mt8B19n|}qOKs3UalQq8VwdNjU^C1~g?HNAN7(op3`fH3vt?w;#y?z| zMp=Yq&guIm!{yWg)Jaq>yi@MPL zZrM+)pS(8MH>1BULL;$NFA(n#z{D}N3)E$ORYP>LS~0dKSjmhB;u2pgg19d_-a9Xu zW+j81;}3y&Qn9nN;IcCYb56$@iE+_RiLnQ5u z{y+SKLM8JPrq{4j6wpOowfS@0Xh|~N35GLUWcq?{QI09Tgczk`i=!6IS($7iuNK=w zOpS{&`NI5NOTuOc&TmT85eQ!BMuC-|s7Dc>mht?4T_oQ$8ljgW=Ye-EX(7* z)Gc-{&nO0AG0cR?aCl*LD&&n!yA^xCr=p`34FaI)$APm}6CCpsx#7PU8}sAAU1dr=8ZtCIx`Gy#oBkHUi;R&Md~?y0 zBJP$AK?9J`T3>`8CXLBY&;=qL&HX`FcmG}PibE&E1ojm@HcOSw!By-lF`B}%A=|Fj zW1>@y>(GpruyT0Dfuwp-*PRs$lgA@iQ!Svu$9T}zjkS6VHc4V@9wT_L5HI0b%XS!1 zx0cUT8i$}~Khj*8nM(Es2T?_+`=q{x?=01GB@V^FoVIBkTZXULD)c>j!s+-Gt!Xh;#nw+ao>8sU7it zB-*o?&9FMGeRDF-z}{!$ZTr^yy$Il|%hJl3XhfCGyWcN+pNsc`CL^ULtmB!_#f^v2 z(c*Byh_$V5&NO!_@r)~jZu&>|ggQ>VM=Eo|YS*LHl0QnR@&iLp9CxhMcGFjFh-(^j zo79`W*8^l_4duT4tR4DXn;dIItd{pD4yt4iCF)SW=ruKXKH%C^a+&XFKv^eZ+}$Lw z{of_1h3ue0HzMo|TNK4kO0Lw)bX4$RG3@{dg`KMpZ01VYtxue7O1tNWPx+X(cuYxB z==YhyPCG@nShbi*R}Dx_R80%W&`r6w|+ zrl-23iMydpRRu4UmYY{8Y5D+0~7Y*v$f=@u#CU^t<`qOeHvc|LvM51^;3rbX*eN#^ooO;E(zY~A*! zotFF4x#)z%il`z5csl9Q_9>{)AVm-bQf;{3r#GA-Q+#K9h`)63qI)2(V0jcaC@m^+ zZib4k2)D^}h@e}jaikwjsWzg26vIPayElANl_mMsEOJD!xA^0SFavBj6 z0b@Hld?u(ejdpl=WPo-KC8CPP&{M}Hz~Q(II&@+qZzzag{G43eTl5{*idxndbzkpf z{C$<^?_#hnC{aa#<%PoV%&ZXXz%ss*MyUD^m|7Km`>J%AEFYpLP-iea`d~4IE9Boh zp|!w6_o(v8s-dzyTL~FzPmhNmVvlNC7AO#1n{(>q?G_(@(>s=6L zY30xpv?`W*R7;cW?dqRa>Q4;v`AGmU1n8DbMV%r3>Ta5KC8QS8u70HAc1$Tlr{a)N zXuilVnDJ#x(bZS=;RJBzA}I4>VqR+_xGNR2!h!1g-p5EPLY}uJjxlIxn0K-SvADC@ zjgi<$s|9ESWR3W^D}8e#9Qc#Rd%tqwD+A4 zB2dLs!d23u3&YyW`?Zf88~T$eWAgAWCR!kmIv86;AvkrU$vZBgYAloiBHQZkNxovT z3CV%D5e)QB#uqY$3`eN5Il0j%1>!K;-b&nIGR=ZBA-ZNq6kr3{P?7$52oRI~@;8Zhg~0+^4r3!8E(#^($h?}+CP zn!=ole{^*g7@VS3|7V+Q27$(C()PcC0^swZiZ38)M^G_r&Oq_!#i9kVG-L@GM*{Me z=XxI+GUKO@_-gPgJ7(Cm-dk!%(ROq&5dvh1fEREL8b2Vf(k`OwZ#oj<*>ITJ=Y1)p z30rqv?J!w1A+l(h^T1rS4@!M5T4M_fj`d=HntyMsIZnts&oO!PCO}D?k@mLcr@=Yh zN-V1y8dS+djy{hLZ>6;=HB=e+u<$!B`#eC2Bh1zp3?ZdP3rs=08IGgS$uOFY@oGZL zmg}$zfLq5UkTXBs)~Yfr=(qdnp*9i)z!y_5YqU`559>6)fwiV}6 z$JNOj0`iJ&7B0j_y)c|{n0-*h(&tjn=8u;2jEP8O;g)73qgWbT*YJ%Qh3_%t6xz*1xyAH`;y6?248y-wVJO>m@LTH_f7dHjlZ;gxy+l@#$<@*J2 zp=8&!%9ugW$PoY-OR=XUW3V*Ajix%M-OaQx*9*hFK^l};s6AT=tP<<7Tzo@Wxzl3s z8`!$#YcXN<=_Q7^D?;)KS5n(r@{qoIK~Y-*H$@aa9eODt-)@y2LEgpRWsUU}-Ta+F zo&v8lg2SZ=`awt5;kx0Y2`s#pzdl_kq z0Z{#NCd$Zjb_E(Bz6Lz$3dE{hB*>5~=SE`-*nOdR@2AH%0-{86k}{T8q&0A))`L+W zJArs<$DrE5l$A?VT1d#$*09gt*2JPym0#HOB)C4FEi=}4>3UP(Li?)m|M>yS?IFOJ zyE+4WoIc?*uH^q|dJq!P`}`6QH6Dlc!+deO^u3D+{5dJ#gDP$8R^CuWz?hJHJD0R} zaL>P0)vn40JdBe>>=2Tcy&W}#%m4eKfY*hmal0SM;M#6Oxr*1?%L7fTc z# z)DoIy-5S{U0Lc^$G5i47$MjT-liPOlQIyLp?tfN+_#}f(#o}na=oc?~ zcfhG5n45V3!*Sk@b6%H#^|V-b;!^+(*?865({gLN`tEHouu^Z~eS4Ram&fP%ef%X3 zAC@CLcMl-u;`jZtksLk-{{V6!?6DrAr*7T&labSnOv6p8{Y~iTLV?5@M9=ra!n*uQ z$!g;B?-bq9rBvsiskCeV*h#`u4R|fphBm52YDj*Pr}8?5YKXc_W%A7AY-`-qJi-il zo2^k7Vxj?a?Z{(Qge$x)T%$UaD@>y`;6dTf5t{TCjA{+JgAL zf`nB=)D%-T2;-iWouN>6WW&-uz!8l?eA&Wm8-~L(IsGunNQJ~D^{_6wOGwTnO|q(C z1;rHZu(xvhkRc$%U6y;Xm;d9rO&!&g?0tFK!VZ~&0@VqM3feW#99Dg+m_T|1ds^7>>ma|G~X5+;x8(NmBnCHaJ zGhOzm(%y`#rgfhAn9nBtFx}{^XPA{Gq=D5VPka}bg)uE76SYY<0#iffQEY*|Q+Rh;NA%ng3?HI&_hX!^l zQlp-l-o~D=C@yU)-ZQ}Lo|wKhd#!fc2}OHpNtu{_>|NxpMTb3H>)U@ARZ`;@TY#>% zw6+0kd1Eo1=XC(~sqRqIt87W{Ro}V#4=AxL#-u-}A&Am=guX)+I?Ot~1ijkN!UU-t zUH}T3zT~SK)SQy<55~PBboR?gM}Uq$KsO6p`>-pl@`L#NTztMBpZo4Tt24~ejyyaG z)KNyLuiG1kQQQLSpivdl4)*x63Tz;&nme~M8U1+_5O-^1u` zpwu?iLG|%fNNptjYC<<`!%K_exsa%mmkNJ{GAu1sQF(%}Z_*Kbqz#p9J?X$Q>?ket zxuc5~&~co<(>oTB5*M%}edAXE5X*?3Uf|CS^F;y?8(XxdoYjkK`F|$}!Fn_IX(lT6z9<&WDG3%|-G$iE!yS|*C ziAw*KPpkIyKU_+O=glm&Tdx1&L?FjasjKgMan)Jli&7ges2lKZdaiHM{4Lr@_jnQq zz@tYt-B?nJx^`)0*fEsd*{H`ojf6arzRDtbww<43TWY2QO_m?tmY`?)O|S9{)pvD> zqe|x97>;YK>v8RU*B+xO--*)gb5?QZ-h%fg%1Dmr5_mAfPqqN<41nO+haW(C2=aVV ziHmIul3%At`>@*HQau?`7YW!W8(>{VIIkAno)5Y=ap`$m;2UU)|%%Y*G#%#4eoHSKwVwd0OA zOfWlaM)RiOXd<+AvGrc9D;aQ)ePw0W;|gmmA6gw274zb~cFl(toW--PiE8X+vnECB ztW(uT%P3Ey!lQQ*@YlLNyyYiz>kb6!xY3**>OEN=V(n<(!0n-Y<=c`kTIb)qA?&(s z;ElR4-;OioqTGNwLK74*FDm3})Tui&$})(RkKpN8GJ9lFJ#86_H)gIx;mM zuBFumj{sNQA@}T@n7eu_us2b;;`nsgoXP@?bH$9=^0I!sE4OIhCrv`~2VZJrgNz zy#B(A=A1orxXDTSK+7Q2>&)j5gSUH6NbloUqb?3sKd7>&)3w=I#!gOmKHwUnJAyea zi~j8s3N9M|gySzXx>sot!7^X2vH)0dCHYOuY-ez;wuEqa+FEa9zE~N`%i-tY@^9GA zJte@jAq(}ZNHD*|4UXQV9-u|k6BCE_9-V59V;X3M#v?0A5AklS@t_lSj#*HV4hz;)v@#Wf#bngu>GOf@1xRQP`&EE&MxGpm=G)O@W1PJ zxnT(TvpVm0H}`aYoxl5~yE-~Pz52E?w(MS&e~@eL%-wK1uTPAr=U~M92gZWyFo9oh zp_=dKJ&sqc8irdcJ{u& zOTyTZYwIV%Oc!R^#c0m;D4;w5`b%sOUG?_{S-n+AA8sm!zHOkosy|+osgSuTfpONf z9<~+8Ho-<;_9u~HK{CPoN*ob>v`L8$%1 zBtpO-{H2Qh^$M=^b5Gmb0`lHl^QSnP$jjrotA>?!@pKTk5zXMQ+ zxT5o|wYY}?X_wWuDgV|gt%4s~(-~0M+9YVmbu7%2nREOT+ z(hxLYZ?1G+(VKFQY%s&-S>^x%s3aj8Nz>NZDu0z z_y+l%Sj8-2R?dJJ{ZyNC8y}4r{&i_<$l#;aVIa`Q<&{q%)Ox_{9h|LB$N%u`}2zb z0U9v-9Clp{b`N@;1huj~wCCXo-~Sh%|L?Bvr#%0U^z)*{q>~-N+ zg{{S!{6mj4UIthgal}MAfR}Aq@nm5J1Xuci7>W9CgiXD-@Qb0WnuU@JMX~PS4wPcS z!m%s5-CJrB;IY*6<;&nz33#0XMun`4G(Cl%}FOW$kd(*(m;*TnNyy z_&RGH&|<<9y$vbj{_#ZrQA^zE%_g06{qKOZdbA2aVeYhhct2W&?!1w8p@ns;+ddJ@ zNj&i#9?-h*w>d6;@SWp6so_d>E@_o%xr!^waG-0#@`I}&?=1&<|LB}IQhpodSCgvnNgh%3_sg4n4B5Zhu_bx5gs z8bilJc1P+_xX5Qolb9$n7Kt`YWCR-&LuoiC%N6OI6X{W_?pfzva8wnc-kI?VbQ)-~ zOYHoS9@EE-%7>SvhNR3W$EHBznFi1>`=ksjNQ{keg(p|9BjqU~X`n2wPwl!6mrySm zze%*lc?RW>GOa_$FqEl&&^u8{;{z!bl?bIt6Z0-bLUJS!(x0fIRbl^ZK*Z0xDL=Z> zQ<`8pq=5W!^2GfC{&xu5aDxzrJh!E0ck^!Isl-}pIe0xA8BHzg367#aG2N5DP z@1OcEjnkfbp3^kC5%5&ztvxa3d4Z52!@B=>w#S+Rj(|p(rNzbHu zLrZfiO`7WY%4rieQaY^@EhlP?JcsC)W@{(J32aP8q5}=HS`z+Qi}Z&`-DgZq@5nW}b?c#N4>8uSfm<)@cY*jso< z-%*~r{!IHQX7}gRui?LvTF6?cIg=75U~WD99WZ`~CqftN9O>jthiJEC=n>;ox{V^T zn#0AJ2FC>k8lDYve0e`kZogNW4k-@C`|?bO8q=ahk0~;QXDDGWU)KSy8+`~@Xcv-Z zqG-_>uu&ROG)N+vH{#RU&8dSTj((1VU??k`t*^O|FHY7|oEiNn2Kz-UY9)U3C8I>- z9htU?@GV(Zd1cK9DdtN+j^(td-S@Wkx}WzWo7{S}9mf8;pANdzuR|}UIMqEzADi5( zFE^4|C+y6ekI}Sz=~Uu&1BaoV4bZisS1QktGsrV7C}jgbJyZH*5J3zk zOr_OFOL2m`j6_t;5H+XHmYs<(sd;=UfrC8RU@-Z;Ctg(7Opd%A%n&qi9C9llU|{xY z`2_E-qqfAj8JSc`8L3tCDGU^p?bX)xQhC~D3-}uouuGz+j|`gQ#9RS=t`_zR4S=qF z_#C-^m!5qoJ%YsWx+tEt%{M)x!c;Kff&i@=@2X}ES{SXMH%J4qrhl_#ku1zwhJCPY znWQ7soXMpb#lPnoqM###40$8hLK;%YX3w9*D*QOCrT9Z}3zbnGiv+-d@>k)-VQLP7 zwE=;WN`5^R;vUKVV_J^jvLF{?KvdVRsN0dvhDxt~6v;mm(L)cc*(j^n^pe#=CcYk% z3=p%-{q)p)1NI8zb-vRH{IHxd3I*IT;)qm0kWG`kxPNZn&H|>+l*<~|XB5~6v1mkS zr>j-lh1P?y0O;zb+WegrID_jBW=kMeZUwtkuZBW;x0out3ovdBc_N1B~!L%ljcr@eWvpHaMRgV2k-8ijjXiSnpnG#MyG|^^KfLA=$Y^d{n zQ(CdWTUhZI1FXF5qrndzU1gCfZp7uZRDb7mxzug6OkRyeOh`X6%0#^F#0v|}q+C_t zq)LhQlS6k|L<9x*!xZM!f>70t%OW>i#Z)+|l{9Ayw2$e5n3&0$DJTsDZNWWS2AWfx z?o}tH<`zhtxf>-W5;>T&Kx)QZhp2e}hJ|Hg2yKrNa;aRe8fQm8?vJmJziohn0!rGs z?0zK@4-=z&{j{b*cq>g4wj(RFhDCxX>&@mL7#|{)v&^gNJq_`NGPy-vx&9IQczBH4 zHA`KMqDtl

Ju{8U@-I*sp^%X3Yb9h&d;A1P7yxp{psirxR`7f5Jq(a8MZ%J@ui)~oF)vx#0Fkw(28 zRyPNee*lVH=H8;cI+b-YybDwH@=ss`tcLmJ26f@VCO5Q>Dv)|5jo_~;tL;#Ez&n=+9YnaW%b8z7 z_^24E{B`KT>5cl*-Q0(cs=ffb$_?A9BHf)|r}_Nz>=vupbii>yG?@<(a7;9*_Yeqz zVzh{xvg_GCyt8v!vAp}4n`(Eb)C^9ufSHJ3=+Euk#VXOB&27m151r(t|J`0_3Anl! zOELaI3tcr2p3jvc&WtA;s=gz>3N;b`z%3hp8^90W&tR{|$5C|;|8)pmU^R!F$*le2 z0Y@F?!Tdlhq+#3BCD+$K8g;fLhSo82`zEMXT!xtelEg9=&b~Az@r#`{I?+;Wv@;0N5Jc@E~`AwjF-s`yF9_rQ{p?O-$U~?-t z*h1<+@Gf;$vkh+hlc;K8^wPMlDBtPhayue>^<)oZx{iiT>h_&K&HY95_4l2P{yA(J z?^iqY2&KFD82q@pq0(LOUFmiQDp_|i6T%V($&N`_z~P;waV0?0qcZhZ{70w@*&(P# zSM&vbAaDx#4Or96mE?rDq4<5fQ-+10z0QVUQky}Zz!YUU6`fU@x^?ixDo&VOD?4aQ zRY7&L?wgv&EzKNLM5Z<8fjGE0NSS&*plsBar`Rf_|wdi zNAOO;i*3VX^l$b-FFO``dfCs%-S(3nj0|Pp3x`kqeP2N^@Olrhu!cdGyHss11a&3!2-^cn~%gl$x z(aA?kS4&UD0~ap_93?iee6gSE$u#I~ikIdm@z?t2yHMb!vq)Z&Be&ga4$8*j!orr9 zl};vr{z-w$(i)9|XiUmxh?vl71R_nX3k)VB!zf&96u!0m#X|zh&XF-FU^61`G~1@y zn5dQ{US9bmhc|9!-EWXV&{M24RTsmmwPk{zyV9?<0b$;AZuz107>rePl5zD?X;sp?T{2zUo7Gore$$FEBiaT9%At>ubnmkS_40vfnZ_+iC)Vs>u^iR#=*%klp z7pvII^O;xwW^oDG?3LdS1h96Tg-zk*PM38H+IK*t@l_67?r3iVRZhU%7J?=m%t=6l=?7`5ZN#_28h_n zeDSw#I1j3$_`2TA4Rf@WKwo=-;aVCD`|N0&Mi&tB_Bi>`Z=Ur^D z>Bt(j6?-q=j=v|J&u;a|>|j)s0>P#=x8GJNV&?sM7J8iC?JhwlzL1nx#>9Zw2F_4& zSlI&WM_=G<#R73j07sO}ZU7Ls8X|uJ)-J|@q-Y#rJ__riF9?#DA)lQGZ@o5PPv2%1 zmhzP-T1>L0K8Pcu6aEyg*o_4EGZ|*I@JGq>udYE<>LResVAar`zSr~MFhwgt`h9Hu zI~vO{qEG*z8&LDdb(XZl?#1H6eGi3S72%1z+y|8~wys|RCI6LDB%G2PH}4vXC*}D8 z{_nb}zkEqU|36>Y{U^BphfmZcL`7ww=Okoj7GR}msb;6=nv@upnfIOKXQXMRXeQ_z zl_aDlXy_v8!7CN#8RnVU7MK^0p(f|(7hY&qVJT>(W+r4Bl_)5wWKW7T)9Nl3!2MzW`6ZxghzmMDQj}m8|$c`~ueY(1F`}(?6 zvvZSc>vlf63u`|jH?2v1J%&tvcunJQlf=mFeOF6 zk!f5GIn?kZExY#MGmuj-hI9ba9_tL8JoX)y8_tOS)$a9L=IS#$7$6&lgN76?Gfb!h zK)dQ}6#l}i?`A49Lzncx5o6?i+@VMz05U8Q|CT!(Zz~>C{)bSz#@&AVn+vWT`Tn&# z`+ECCj*YKXSEqM#!{guB)Ya6~)du`H0R8T+?R40FT{OaXeHH2T9rksQAZxv(4$wW(v1j}8JRhsURa?*=f4Atq>Z%_6?X4iffye;7Wsvqc!l$DZd%ec|K49!X zT=olcfdI<(5Y)3n#p>WcfMNg{)y-Bs@+`0_b`-Z~umj?P_Rd_E4xt74d=?`=@NSe?+?c6;MMmKbwj*%TUqqqZd)%s3SgIb= z%0pT|0L8%y0*~j)fa22sY`q^z@fG~Uun!x9BnK48qSTkFSf#IcE?|I-lf%W3+*k_{ zG_Q?EuGs$>dDql{46hj0E|f!w{>JdxpF)Cww7sX9 zFA3I1LZF9J1Om_$XftFHRzh@`^k!pB)}a%!NYLSilFL%(lVnb8Q1!@pxhKaTr;H^3GQT$Z57 z4(?(IQ_RvLE;;w+JwCO0 z2_wGL5|J-ZIy~4XQ|`VX;{-A64vvz5=SJQ>6kc^dyw+QtI>!dhDcmx@QK|F~INFYS zsv-&ITFEvON$88-R9|$3|KKACMUQ2$EQdzvT{yDSHi~0W3W^<_h306)v?(C_^y0h$ zZ6g+H48p?EAJUd09KQkD0Vy@JZC$=J&;C%x_bd8wDKPHnq8qx99n9NO0I+mJoR;}m z9d~$odOIBSjQWn3ucJ!_Yl#R2I}U(T6XmNg5AK0z4fDPu`1?)3ycYnOB~yPN+0}Ub zgoC4`1v!fNj2)>m^7H6F952gr$;(j-KW{HgM4_roC6@DTeG;U8R|3uEUM*M8>B?HP zxlNu^^bA;_(tf-SHCC9GO^TxygThs;PVM9l8;;DJ$zSM`bmHPpDJG;*MSD<-Q1quR zKrKkofJItDTB))(2n&3`8+H&2W&I4~z4b@~6_^NW8OcsB#Owr8S+Vdu?qSzLPlr&A z1tT7U}@>zLb z08_c5W;QF2KKy~7>-TzN1_3qTkP_HN!t~&2a-nbvdS-Muf+HiMblEff$||y!CpQcu zy7U)d8r7I11=vl>nE)Ei-4J&q^+$CRs{ihBGK5=<3FXj*PS)ST?dRrZ{Ws0W2r)&l z5E}`kyGV${q&I~k4fLPC@57W4a$(Hj!{1jyt)U)qb-O*C9rKKO|K84RGv|Kw)@_4Z zvAnhd(2TLnYKcKjqavFJWR5tff>P??2t=|%5iGtbZ$a^=Kz(wcO99CLX(CklO=iNz zmDKz9^QA#}Scyk4kFr_>LteUS-J!70FRKPDA8CyW{w#5UafZ{sXl)NPr_iYE zzfDZ)U>*7%{kG3ezoDNJKXH**>60xX=`pn0AW@CtG$f8IwNbbw%-2}!3gTyQkuP}8 z)Lg#W+J3^E*4V|)e($6{m3C*%dQ2Nusj-|jg1X^Q2d*t*ogQ4os>8(?&!UDe^lMYR zc5~Q;Ql;Z)NG-}pbW{BEnVFL^D_Q~!m@a}=gK)RZ9l@)Rx`Y|{vNRY7B%v9F4T6X4w`D8ZEO8 zVZaf|dP%U62*>fmXv7TY7u^;K9rz9m2ef>ctX}?nrAdu(qjr8wpj@2i8t@UIY^*TgKT<;Igva5o*K53% zMeMTv$@qGI&egI-rGYe{8L%2bC=8o;dE;6=SRJ3|v>It>pOY!jvVz~{Gy9E6HNKcQ z>QCyNfyC;5di>UE5M(~HhcTL8TayQGYN{SMaHF0qCE;FBP&<=U%D~aAQtfHP$8VF| z%jCzot>wIg4{i0lERMwKD3yGLGn@-O%LnX;K5tE^HRn22N+OSVQA#4w(8`x6CD!lr zQ9kZ}MtHHDy_@i-HIrJMpTTnM10DZgBX|DIX1)h-eC&-1!=$A(Ev?#$AT<A6It33d zY?$t6`{l`k)AYM-E4K*9(t;Tg5Q;gW;*k<1@z364^ucJTFUr**M-GG$mZo@Qq`O-b zTm5lmD{dh2dCcI7p{epvJ3XGXWd7*5A1j=y3KB$;LBe{l<$(A9k}$_NzCnsCG@pWs z$-|%J10^J}g#v0xhP15rVeqI3j?0S|j6ZZ%&3mn;p13N-s4x&D^4L6VR7k4>$n}8d*~p=A@{nkVs9{!GZ0r<8uvU0 z@{)RidM%i$b=xmUe|GKbeE?w#?C(b8bEG6`d`U|ct+cKNo&7+cqy{fG*l`MtAVK}2YwSe0_ej^vv$pGl5>2m&L(?;L;0-~)uD)& z>p!2v2#$h#B)cVLe43AZK64JKZ3`8hb(4DJEp_6Sb$4U_ngVWqv)Uz8OToU_V8uuL zWKnW;CO7`fW~hcVCE}~$==IFpz~S2&{3G`H!-dOI@?;}XltKsUDC(iI_f9PS#~ayu z-`2ISqy)))%<2tCGevj!`{sK?GN$0;%L{X9I78IZM7<&+**58kL+R1O03#7^RL{GR3uiu;%rxh&=b|SB9E-4AP8m{pn<7=;iMdH)MD~7oZ zJ269sU#8|aR_8R!eOmh@Pthk3Z+tCe6~Yq|1WV_7GMkHHCMhAEe!0dpc$0=yThn`| zLQ)Hj11r@-W?lqlJ~n%UFR$bz)>Zkb29FaXHyl-NUNt5)7wE1Cd;!77J9=WdXi!xD zF5Lm~wi>iUECx(sF zCDbiuiP9AS01j*5;LMV69H)I6SGH>_kRoRGBaE@9EadO#WkH z^?uIku^Z*XZgzM0z)5rF$Ae#6YIeeIJ@;=Q*Ki1kehB3r5FeGV8-IGGURaP=(we&F zFPmtQ*_G-M&Zg9M7Mf9q_oxk6{2B&S{NWe(0{~$0TsZy zcM3%8C~vR5!-DSiRl#b5T6N!%ddlMXcJ##2RrdFvB#}dmBGpujGaw(!R|f~Cw))Y7 z?%*19@E`yqv8h>&6GdbEy8TVA7gA|YaGIBOa%@NuZ#x5GO!fWy=%4h7w#OBIY0IE6sr1}hwOVrvco^I~p%zPx?OiyuzVgAh&FiaQyz@@HxJcfj+6^sLLq30<*B z5oA`-f8PRWLk zLkl-dUEkW7`SQJa^6`TN4&RuwU!VSb=n>yve`9|RFUUKs^B4ES5A=wE{f#__f&VkR z!wd4xP8@&_l@160J4wN-@mAgg4F)+}`>Xl#TD*1g!0NkjxbYSXnbpjK8oFqks^uPd#x??(oGAT(-NwW^}Dw!`e+SNS4uTnPCoCq?Lo28 z*c@(of?cN1xkEWR->>h-NW8+#&B#}Dw)t&%TV3sf#YTf|Q;TiR<#N_~Z?(UgA!18Y zxj4Dp9KcY?t3REiiK`ONRNGD^3-j+tkeOVGSf6k6AVCb_Ij9rNne_aSztjfX@W!{@ zxMDMxMJrsf!GtDwZd5>g1!zxZas@tw)yCjw>>XRV{1t59KJz+Ole<^p%NiGdyc1^N) zIo^F3w@^8s3s2fqETjFUywNVB0=4rEwV!%sJ$27W0H?$|2#8!X=jJPQbY#NV!S9cp z7=aYy@c6ZqJD%njd-mr-&n4yOUQT?V`~nujmDVb7^=F{cnLm1feMcRc@ORZOsk*`766wZ??^H^_LE89F zDV39s$cG$oBW^g8(Ois`F(OnF&Cz$N7in8);rYj7Zz622sll)&y$k7QTzYr=IB<9x zqm|ZML`PFiXLvEYd+OE8Clk6OHwm)eG}>*7jb(}f4r7x9Wv1b4mdp(uhW*NH=59y%FW}YRhQjnBHRfRhe^bS<_nRv70sY<{Z zc##=Z^-rtRNXnApNedbm!(M_7o$`I2wbz`K2$T|RO0<|*CAJ?Y% zMcaF)2psaLUGj$835O~27I z+cw7BSfMK?JP;&5HA_Us8*^G>;%L9_7)C*lDcS*ngC72g$UNI-3>E}sn-~CnRh7Dq ziIpqSCV3Ebwn-|vPWyo}v2s$NK}~6lrfs$y8=F(rHsl(!dqwrZ=|%+H;ZGMRQbssb zf=F3OW<;i^>s*YAmwrAdmd@YpWn(U(Plf^~yv>%7mBUNCYLp3CR=9cWR#pCnrkBgmHBECmcW9oJ)ZI- zP$aK%iW_jwgdVQ#WP|Ku1J2%Wgy6sXO zPXQ^?sgzm^Yy75$GtL-Z%rd(=x?NM25@h-eT(E5c06`5`#wy|iAYn!|n;I_aUHQUk zCh46{RTlGk#{?3hdLdDSV>xrk-={^n`S&!=zH2%2=`K4`8soa==egv>Rsg@tI|G`P zUFx`c!he++mG4PoY?|)@C$c~e3~)+}_?_qG1XLl4G9g*2r45N~6w1azpx0)ZOk^00 zj!fMK;S2y5KhNgZ&l5+M>k)Z|9oClCpC4gq_xutrd+hqm2N9m?p zTEiVvAv?M$<5tpwp!gBYn7c?rL1X5~ACeLeKLctG#8NbQsV8Is%{(|;cs*cdbrQ@x zOgv0%4E!TL)YP}jF7p=(EVge}hQgZ^V-|>`I=D@0D#{OKI-qt^*D|b2G}TZf(*Fn3 zJ)5_cUf{vNZ$(0LUG-Lwcf+D4^k6w+NNqW6rDLh2WK3o>D_r(1z;o3!sZ-akJ~^w_ zvYF<1Zr6Ps(0R3r38Q^P>H>jDbs~9Qsk0=}Hzy&&R8WSp7Ue4Q>F=@<7hrQp)se$9 z@S?__?^8DQ{3aT>Cef{I<=pW7o)`Z#W|RK0d9goyDB$M?B;~}5OiUd?ch=`!y^lMAvsvu`J1RKZE7w| z*G%|$+2hc%@L|bCWC*3wxZ3(=oP}5qU`z)NQ)vd^KW%|JR%WK9M80ovOaiY6;&zW# zp%M_n4^Tg1j-bzEkBK$=xJ)&oboARLc(3OdWDnCgUHJN7SR$PX#$=kr*_RtX;^xVaCY*C>;FuMNa0NX z>(uP*0)CI#;7F~rKfBeDffN3zh(H=i`>>-769WL^QHuy5`jbwwesARkO;Ja?Xc@k1 zH04K*$=IVXj?21k=JW#*b4VNU;Q(T^lv4jn zyA3_YUAynJpbg#UlKIH;!DEGWJ@VruI2>K^4Dkj5OcYf!PgT-eF-R+;5oLXhnaHp& zCjPlBfb*>7x&54OQZ&FZcJGfX89hS-E;Fq+>u{77AMs@cZr2}Lg?iisc*4mYG$nXG|vr)>AleceQqqUvqZ65U7DI(TfoeG z!`Dn`fg${ycQ$fD*wwr~pdS)ivYQjrkL$`T^+aw-jf3x}vS#enbK49*MX98*|lckzFA$hjj}3=7KN> z-4R>8v*DgKR#=+88+H)BmTOxT<0V3%B{fuTh8~av2euFmY_jLq9=Tva?EK@-^jJOL z7r+`Nvc*O+K$I_NfVu;=Mm>z?Ia4+8kgl9W<98ew_U&e!wq$HJX} z(QvU5%UJqTVZ%XWq!?TvVoi&SBlWFvEW`4Ei|(NeWb<#J6IyT>s!B z`z=eA&D3Qp;;K6B2Gxf5RX=G-eW^DeOS>-T2Ky=@i}~HLoeJrFks8zwdUZ9f7q}*+ zZ2B7-P{y$+R~IpC-&YZ8J{zduwJ;m~CV8QQqBGSJEhT(NR2u+7e#go^tEpmU%Ogjt z;?CK@V=jg@E@Ofu`dxaU!*;<9W;Vl%5EI`kG5e{Z%pVN(E$kqzu%j!OiNf0_+96>) zWfD$le$tzRVk7Ae;}dO?_?=+Jio9nEjQUBk?b+#)7WZCWQUh_>iOH#wtyEtxua~o< zC;vHc_UB}4f>!-G9kJ8c7`*K4z1=`gv77ruGI)5Nx0`RSoBpyGE*Z1StE2nCuD6?~ zIU#pT$(e?WY>g587s2jYJ@5z|$wIYxFYD?+f4#UFmC}+m79$i8BT`x%FhYAQPT>0T zxrGwrKl_MKAxk%n2t|>&tbyg`%lu8&tQHf!sb)!HVA#RHBCtquIbOZs_n;>$#szCo z38r$SjZj3ItX;Mz9p-ye+2{mB3aG+)xLT=Fwn?baAO#S4lC3yjC)XT7lf0+Ah(EOO zBD)|jU^(PgD9y?-F8T`22seqeh@hLOF(kwVNS!yg%h&+DCD4{5GI@Da%}9~mcj4W! zi=Y3#L+}Z<#1ukCe1LsfP*n$Otp9|VCMufU( z7_HyqUH+Y)-QTZaLPn6K@+>NdJxe>DHIvV&cK!p->?Nt2_WDfeMo)Yz!r*3euJtgV zYDF&SNN7dmm)ii0;_|^qXcbJgh~`F_o0VUUSgd9(E zY(voC5YI$$A~8pkYXi~Y7BkR#$O>y=yCNxww%K37AmUZz5#XTwM79khjTdBb!PNLD z8KzcjJJZang!MlQhwSp&J0t2uEjjMI*Yqk9Zy1-M$YAEx#eYl;%1s*Q?|iFO9G^(y z!d`=)Eiwx=r95xF5P`}b<1P~xoak4d->$r5S{^OrP+fWP00*?Sg6N6WK1lLkWRc4GmW-S+lQ%P zX&{csSkSfW*2E9ymavW^aSQ%<>)>mre`lwzs$(`;3{cbt1Af9M1vTno)zm?+6(AtZ zj=Q%6SKS~{#C_@iSP^{wDoSlJ#uv#aQo+e7f%eU7TXfQPoKd2(4xo)i@h};(7~Q}@ zMslUCc=&}p)$(KiL1g|!;a$>-3I^R6^v&-{;=9$i?e9x?V8<#O*BaLchf(SyE&+_p z{L3-~r2upLRc#zrgdFrBllNkw!2N+3-SO^aV_koeOCb%T1;&dy2o>puxC+cNJP+n& z>BOp({O4num1o#}8%=&z**CH(0}M_*`Kiu}n$+;|J+=z`(uN6kwdaP)UZf2jOc)Wh|`XeJb<=4nq7Y24aXTQfukO^`HF`piFD^_@bOlg7}@jD4-pm%8$mCCdSM`zb1C z&Il-hBiz>7^dvB=OObg+U7a$K(BA98?zOl^xtcN!4;FsgX^$HyewfMfoIa@7V4g96 zC(V8YIuYh?L#(RclKC2}JmBV05#;oDm!)%W!XYThcpKaiikiE4hLq^1`&FF$$$k<^)_qv?Y=9YZ`4X{fmg@d&0m z=M{WITE1&OQdy*;*MT;%*HFib3Y)Xinb2jO-~<_;oDp($%Pty3`_loMl0|xJ$_`4LL|}oq&i<{_6sAuXdfJpf8tl zw*b$=uabtkvM#=k0C)ZuYJs6*1bdR>MY279W*j1@E$RyO&LiSRf>Y?3vooAS;f5Wm zaq%vH_)23tquZnCmaVdTMh;X6y7Tk-cD6cj-E?C=YV+OK=P8&?3tRe&7K^i+-Sr)+ z5hRjO&fZ#J;2s8=LI6~stnm`EtR4P(h|hj^+C0$;Cvj3F^VyN;JT`AAp1Y~Bb-xJV ztc0|sWhr%R$+bY#hYlbfno+1WFeRlTmbq_;*Ml&(mEgotEKTxp{+%y>=Cd!LNyKE` zkw`s^tw;9HJA!;;9OgD<`%x4d5SKZC+ryuCInGS^PzH8J)fJW|A1|d-)55FdxC}?N z896ipZF1qmiyRT)xjkF0gNEs(mBjf=TfmsyAMW-CJvhQ^PHhvaeIh>pCVzk!K{ zv?jA@4VZYKcnx;ox7W}0^tDdh6PklFEL;40?;#l@A%^Y&dl?^Vu(MmQ-wU#t#C%W7 z5Fe$nD4Fdo7kpwxZudE~1hUijVc5^wu+M7aFdr9ckG=AsAsa56x|?r|SKd7J`j_j> zJa2BZa&maxzm7h|;6t*6X72z*oqWE&*AqiW;qO7th1}MHbkr;xzSFY0kg2&yG`|S! zoyd_`0_b?3nOT-zC|HcVDo@buor<+8jisFXMvvnjtHEn1*ELbil7n&++?CeIRf5!{ z%M+(3W?Et<=MbjJTCG*fx=E#;-+NV>9%xY7-E^CGkt7y(Ex8OHb8c^x;SKRjAZCk} z6ELX8i&zTS7C-v0=W$+hj?RRl@`EFm+^A68PGb2rLcOAaI!au*+EY8mkGhUqC-nEV zy*VB(UP@Xxl+Uc3AY;$ye)|*H_(?&>k~#(H&uZL_qY)eX@`(&@&igYyF&#aYz*|__ z-s?k1HPxI{EiM_yw9|4TUK7F2KhX#?1Vlt2yd<)xZVp%A4SuTGQyrj)ag((h?<6cu zUD{lpR0E|7R_Dd`)!|NCC01m0;V@u{|TL0KRk|Fz699rfCv8=@VVaSyRDht#up;EwI&G&7`OV5BnY zLSU>fpSS{f#a-y-XR?CnnVUM{@+UATBh|qebzF^`+Nn&xzWfFQ9g-JE)c}D#O=pfm zd#lpd+7YOTvgXQMiVYdqs4m1qjWx~HEJ}RG zH{6}a?@c1IX_|)4&f{gm8tA&^zU8u(Ys}SLxF_7f_1LxcMeYXu4aYKKvmafud57(K zO16=-Vad+Q$;uJPwt9p!1Kf!wu;jZnoeALDkVaap00vo6rWhUAh>Lg2#8f$+sp$xC z9n{-h+loSryRT=nATj8!?rG=_iQv?<;5h}%?2hVPwbf{|9#^oHl8}z-!`eaaT(H~4 zvAn7LQz1Eaz6t1TO=IoHnll>JaaIdpo9qfTwZfY4R`Hdsdyf*$Y)JBr8iXi?OW-|N zrp2VygWse1B!r*L?g1eG*PCobor*)^?cT6QnAUa)=@8KV8|Zp|a}RczMQ#9(kCWHi z?PJfidu5s_(w>_;jw-?c^<``QAR=^oY1Q+Nt%DjB<>Qo(BcerBNQNnD0xQ$O5V-b) z?^hw>PhJho)z=WZ3n-OURX|;A1yU<(JtYST-c8#D)BCzBF@lMMRDO?5k85 zFG+nlYj-NJG#g4YUG~U=8FUQC&(yXVr1&{3aqrkA0K^iay9fAF{agWm*!m`oF-O(H zYVL26QrlS-G`$;;qosQl!IZ6^_F#QdbBKiD#op$9xT@Ig1%{g@3(RkeiYV^N4(;{-=`H@x^GU!gR>^)noZ}*7-7gUW2&mV9vn56*n;GSbE+Y-T6koGel3nije(=cQ4HxF5g3cWpX|_K~uB=pJ?goPHNS`I)+*^*1GR@Uf{zgmp zuZz&rea4qL`f58`L=i=^uk=UNmUTF`-m4Fh6mNv7wplAUv#)`><0Zt0v~k=Rp~stm zHhMsCY(w`T-S|0P$wYnusl;Nd~A2$ zhh(PJM^`RiuG}JoU=zhdWA1rJi^39m!;c6KL;8JKS-wzCTTtDRUD1VhoDUtY4nyO{ z%|%FWI~Z~uFzhU)?myB3)Q?FK$e0HNEHZ5NNVY00rAGk*tB7jT$h{+qWzRe#;iZAL z%O-{ek$-Ku12tog){QXQtwwUD;HbkiwXt+wEX(O}j=W`L)?)Ij&F@?678G(~J$6h7 z=N-i|EeWe_Wilp2YAuu1MoK77B0?j#EjT0mc43Vp2Wykn4p1fBQ|G{9bl!hzmW9S@ z%y1}Hef9dj>bl31Uwiz97R)-jX>pMe_kxx{s@0m#9RzOm9FyF|u0)*gue?)cPNizH zF^?XfY`??RN45uYm={#;5eO_8euv`CH@H@45W+HDtS|#ua3=UnNpGcbtTYF)yIWhX zr$1Zh%gN&9;P9bKI znWBQBKCjbm;co{U>Hi*Ax-H$)F0{Y|;Q%Ld z@V=ZgG(c^9`-cRh^6$kNo(@IS-`CjqEt1s2z#<;#QZ)6xU&*z{x<|@md(zArPcdeo zn~4FR(sJ4{(!b|Z1Dq92Hm)9!BY&}U8V|KVjHaXXH_S+;-QH}ac{sCY{tfLW_k`tS zO!g(e2ZtLwU2S#03Y#cN?xiJ>l07uEum@^$KAiU|B_mZaW&NUOv6H9pR+VRE#=^+( zp)>lZI6@C1gG^r>cYeY$ouRfC_&?qwbOSX^qX6dkbd&8np6=Q24F%fn3w_?pZ3WaS z{!MlvH$(+laE2@!BkuYuVU(11}0;g|Dt13o)LXWEP@1)}erM1L!WYLUh*M>1Fg(AicXN>wC9? zYO8#EP$WZUC;7)%(vVStEg@t*eVsoPNtkjoDUU`|9Bk40GdVwbVGUuEHZeWNa}#Fr z-5%pBjiQDIu$wY6IAw;c3UR!N-=qvkp3d)-w;}ndR&&ozKqENp0G*HFnPFy(Jb!nc zCK9leudd8XU79Q~MP^v@v?lTTkUM6?$mY9?BL;s3OsB=$4T`C?U|m!2-VrP{7V$=Q z78@BL>~hfQ4h5k04G{|hgYXqA^wr5b)6G6^ZSl)_ZqA)x|3zLJ%U;nhw~3{NxG5F1 zM}~Kq@T{;cK>q26Lc|f7YpKCG@JqR1~Z%Ji9&A+8lO+98sL1W~TSdb89 z47Cdazq}GG9aI^7g-bzDhrPbkdO>f@KD5FJnPWB`6>84>DJy<|t~xUh%Ks>NU8J+} zlHVt!Op~0XSv`(JL{F%1R^v-+I{d4N5)Rma!ujIAQ_Yw}P13}20K{UxmZZ1~7LcTy zfy{W1MK3uQizlseepaL9x_!!r2*CJ4yv!Q))X!`udb<>$5JnQt=Z3ThEXQBW-N67N zHWY9aYW`&5AqdN!SmQbC2=&MPZP~O`P8K(ZM;#8d`3NuV1-?WH^^e^2nF_V(m-p9p zQM9BnLQxEZ(d?p_tPlLsJ449ck`!(Tnv%yb@UFzk6Hk@zI>EbHMPEBrTKbopDl0nz z9*JGDNUFCE40@#+fn}1`Ag_kgH>pPp`1bOF*~}#inR9&R$w}qi&h|wB1`h)~I=zf6)h|a#}hJYt-8? z=8n;1MW{Po>^C`q{%4X-*RVrPsx01r%la@=e&nk+PgAq{od(zIo9T;NsCwWB;3}#C&l}e#WglZ=Pzr- z_oept<@Wal@ApNH@0ZSKPTx;%Adtf{q&XB?`WH|BKgga->F1>YAOHYCkpBm=M_NKi zL{>@UzsMeKB{|y-dX(N%C2o6*;wWbx>(2Bc6ib2_Y^4zf;t)3|dz8!upU-aevke(R z!Is_I+rS~%+CrWdz?%zCH!ruhkMsNeNw&Fa|9-f+H1x&x{wUm=E`~l<4-yp)_+DUa zE7P08GWx@D4_j^c6(LK}M&IB=_2+(O25eE`cHkvz7F-#aeu3p)AO^y|YawILO}s)V zizdOud=boBxP8TFuu!bBF4yMjICxC8T)7f>6?`5CzY#&pg1_!UQ#WMsBg!~yxa%-o zJpIEVE7`zNBcbyvLx_j++u2wTcmI0i#BK@%uZvOS^L0a@2aLgSmKXkAlL(fq*X(C& zY?hR=*HgdL99qjoWGF{37b3Ss=OMlM*QDp|ZRSAAdH&!KO_9W#V&_udL_Lwv$F;&D z^O80=s!SB$bWQ~5Xgsaec4$$d@t*pmG2d9ie|(86oymlQw(l*FMz=;DD9o*9H_v;E z;H@XJHnfm-RqF?WDX}}A-91_--WL1$H=bk62Nhhg)&-3cwlHLH!Ytu2#guyZ>0cO4 zf4;_Ouq=7%RjxQGy>~dDFz#rgpGNsEY5_`wOG0GsXn`Y%7739b5a^*}MIq7^L89^$ z{s1=0e#F+O6)h4f?uOv8pq=456i%`kk_1Nbv<1R-BWZzpg8vB(eS!3W@|$B=I>H!a-T$2&s=$ z&?>OMRv=<$T@>$~sY#76?UF#g*g0ap0RQP@6_4#U^nV`SgaiN}`JV_i84+axVF6`< zY*kI$O;!}2(^__5Fk(PLN|!}eT4WPZe{T7;Y`Oy$aTL(HWms5>ixuCUU_tuauH)39a=c z8HO0A8AZOZVG#S+)WO{1yVHRVWthY1+o zZQm~6x5pf9%YB~gz^3ooHc{(JBpJWI2>CB@#&>8)X`Gp>jB&#hG}O#D_cqe}iH2~A zoN8voq8hCj@8#))lXBY(wzNZ*zE6~+Pe#F~$(qKceiQU~d5(UVZHo3qM`!t+U|#Mr!Z#-F|NLMm~WtY~h9<2Qf~;nRale*q4-S z$CR!*Xp;1OSUZDlWF!1?zQ6DS>)k_h`2rvC`JqB5H7;qyCF}UlDXLf2Pyp6QxHYg| zX2MuzRs^XouoP^_5dtc`*VNIWjORYbA{UNmt(C~5>qJXaHgifHD)>-aq9Ej2naHc) za|UJn1l`o}G5dN0kQpyDI5kAj z^2d&-Ifspors3v%S;oQ72oWtAynj9dL6dRh4z8}IAOy46jax5Jw5JsLIzUYk zi{fchJ5{Qs2_6?vDsuf=I5AX&vpD$r03Lq^2(tm$K5?5`25rbH&mOk z;eIv@Q|vu;6~Xu$=G-(Yu00xq3x%l1ehb<<Q*= zR2@td6)EYu%JC%%Qvo}R4P`rhKKE;w!9|^EDUfFKYd9Q#OTn?;m>(VtmGk`fux>$c zq~HQMRWZy$SRs7`dIsFoynfr&%f)B@N-9IOh%C=CMsF7zaq#+_g1?n5lq!kP#JILg zO$I+>yYflgq{w#cV*6urKbe2UR{pZYqddvJnp%74@}+`1-O?y4 z$dCHig}2fJ@o9irk#>x&>_<-Xqc4-mD{~P}4tcHsoylnNXi2g7&RaY_ch8vyqXtA{(Xxh1FgjUZ`omsE`lorSjG;s+wszK-)n}Y?{ko?>l@gOk8h$l3vi|yAfGjc6K zNMu(o$72NFY>N*EQE}Iy7YQ^y2Xvipd(;qK!0#MPhX;D;n4QJS-NKe(9!#19tvA!p zz;qyAfSt7W)$F5Abi{4e0fkoJ_{ST&Ip)uaEI}eRKNT!h!HWe7+I{^rA7KQUH6|oZ2kq||6~(2aS;(|=vi@@>3LWw8p@fe*+xbBC8j+GxoIgHN$PRB z21RknacbIdI`DFZIr=#!)_JCdBdCd4y7_176B(8CWtpkUpzuFL!fpTUeAFJjd4c*T3*ui;{!j9pZ0&Tdj9rYa{;SiIlBJ;>m!3QV z`fnMLJ2 z@j*l^-T!{=$XK;H6?sNR`lcl&<|U>E`GfynCXi~QpX^_HivM33YkhN@|5HZ%f6G+< zk3y8>6H`?40F5lnEbaeIe)}`X)Tta0fV~t50Mh?QzM=kq!R@qm#@18ae;YH$ddNOz zO6{C_v*5NHhq=iQxapxK@cq+tZRp{FV5jcRZ3~W%8?;|)v_H3EZlJijD9IEd9@xHq z)1g0db(31I6HQ)&SAV2xaP{T2Bd>mj-MBmGxId4-y!XA|W?A1HT7E7qX`c9cwLa^l z3vPC=eV_)4HoV{Qd~ZJZR{9f5Aoy8i4M9K+$wdx9g!)k=80n?+=;1cXfbK;oZ~iWD zXCAL;=r6@cxDqrJmg7uZo#}N?<%sxT122Wn z#}K$WwME`*N8F~li4|}$uYo?rK)NtDNb%M9Ri#4R;UL|bIgJYA9p;0)ABK&4;)Cq$ z-_iEF>bC(uMwQ{j+z^_i>RpC0v^yC9YgyC9mS-;9~z zAOLIg(*S>;e&CT!M7#u}!z#t2yC$t8#*f-IJq>T-xoEoVHhAv9XTYg+O801R!tgbOxMFJp&YUb!@HB4%i#?- z-rYDOQpy(e;rm7~~*3CCU^blFk50l?AYu zlW+-E^nvEtfd%K`d!pAESD?sz4dC*EJxjm1#3>)LN*0o>b@-r=+2Bn`1G>)`fyr)B zG5Y6d(Wt??pftD^CbEyLA{gt5EU_<}iT(9W4Yb7D$zJW5>uhxT)8muGFgYY>te@W7 zb5x0B5J2ltWm8XGV>d8X^DOoPXwyOqB8c}Uj}cD-XB%@)FAZ9w+J91h)p}6Lv)odq zi=ol;#|>w7vT0~?iDDGC92FOX*>U=#|1PKmqi4nlE8WxOmwvynV!*}R+Mc?n0?kwe zh42YkPJh$Uxi}Xoa5Akr{cFA39NK%6k6_4r;>Dim`XMB=Pz>Dx71uWHNw~(XY-`!W zv+#7sIAWTi-Md$X-7LQ>2Cq6D3i=jo`)+~rU~ z+K4w#)FnmL+o8Mv3DWqqdg8nMc2tqPM;PjY3={JS&uTf=&zhT%f*Xp6LkG{6v5((9 z$%0%wu_kJKID)99dGX&Dt3O-XEC*}z)&#~@&)k#8DJx~}q}=Snx`PRD57`{Y;KO{( zf0G|rSXR-)U`09?N8i$sW)r)+8v zxv~S0x}g_SVGhxgf01}84AJ_#3bY-71LXy;5dd_Sp;GGknE)s(Xk*_R*nxgTivmF3 z<3Q0Se}VNB=!sOk@c=^kzJfpIt93!8<3!!iJA{gMCan(xG%w%;SA}8VUuMPM!CC^8 z+~K6(gxQ7G#x)mEo&i~;AJOes(gAvP$M^=&0lr!g2Kqwkmf#001OEEa`6y}wXM@$I zXh2ur==XbTKBD5zR4Jwp1+(zxNB_cQ;{(X;s#NeP2Xxryie*r`0VE3xqcZwQU!7GM z7r)U4_MoO@Rp_kS|AuobeZlJc0Hs|y9oOVFmIrJ;+#@&sQgt9w^dvD zaNWbNYYPKz69tfWJ^+>H|FhRWi|q+R2cEK(W$~e)$;yYb8Ev2|lr!J*u7f{(;t&AF zEnE628bV?0)EsB77(OsVdxO(8NP~``-a(92wJGd2uMwNo(KB$!a+kQuppdOql7D1x z5iTHsX z60i>UDSZqd{0CR+T2i}FITwQI_+Dx0#L=`BF60=#2MzChyK3n393Kz%xM>Jsw(ZBE zy%+AVFg&c=i|xZjH5A+jWe>SOcd7}m*^A%!l?3oEi|4SaE!5ftD_1m_57^Az8k1N? z$Lnq?#O+=?BwZKIvIApsT2)9#{BbziVun}TXNJ}*dXbwef*LEUy|d3z-r5JDuv@lw zAA(zYPxDSxznBWls%C7c9xV?ZU;vHv$1E~Zu|)G(bX|xQQ{*$n(;jEvHB>B=p)eQy zt<3lqP%)--G;y4D@6i-|t1_S)P;9`EJ%0oHVF>5rqlxBn(WN4s@+95e8(y}CG1p>F zTyODJrM7|`x+>9s6=c?6HFv})36C*Ig+&WpJ;J`(i_#Zl^tQhKg_tR~L@XE_%=sjy zyDV3yZA%c`?J`Oq?OeScA~b|FG9J#7fw}r+{H>{}H$=;~22_<-eEYIwtL&qEpjxe! zjC=HvDTr~b$R5_zQtrJ0aq6)0(&{HD>oT!q4C~=+TYGBvm7WnjH5KKeJQFE~AS5NsqAHr&6n~=z$^FiyNw9oH)Q~N;hlW`|t78R8vZDXJ@cG)axc zHiCc^Cy2i59}$WmN@4xx?`3lBBNeY*TNc8*nYs3)*=m#;5pBWGkQ3SLt+FzH2LF)~ zAYBvG`Z7*;=|RYGAHXAN%R~SkVwFHy&?wAfWU#8*!Pwp68Ne60C4-$nEM@eV^bKp( z1PIbyA6^^K@*Uva{-m!WtV=7S0BrIeESFIu9!Y){G5QU?>H1zs(SgCA76nNEb@lV> zrEoLPr^^4unz#OB{VF2GdB?cj@{9OgO9wGXuj_MhpQ~FW_DJ&f$5rBh&O6h~eXH`F z4C1HPJttSZ*TwvIn!`s9Tt1E1Jj+Nt$-oY37~v0zT~dJ=l&D!6frNYrQ7uB9eF6#xaG5h%GSzJkA?Y+y4}#?71^jqpE+5eNe- zxYJMl7kx~fAE(T%n#8Y+)P?xI1Z7?Wt_&FUh8)E!tCtYGpetaz?5Nyvux>vJgd^+#eF6rP=kQ|!BJLgy^GivjSW3ve2($vPL z2)SA@p}pfCzPnSeF{j0Bz1FgS;ql%s;2j>VOSD)RPL6z6Z?%(QEv;^GD+N#oVGqTm z+HtoTNo08mTVdM_Gu=ulr2g3Pzktj-wzhqi;Sg;DR z{gfy@g2GKlk0tzEXX;WvN--8nz+rSa17W5jVu@oM^f`eA9Y2UEP!{tz$x9QFn{x;I zeaK~={DmA>$G9CbswmkbQ(X(VFWi(x+)^*ZU`0~Np;`^NY@_wvlL{&~@X}P0{10o; zBM3b>)|)+1N*>fy0SGSseEBAzXehCyVzFE=a{=JP*a z5$1pG-57cJZ`z{NJ^52t(V#<+%fSWmWl#L=a!I5Sf=AdBZVych6m1z+NjwkrIGvV| z+FaP>WZ_Yr1=fV01Ujd77m?@NI1T4?-=&&(=AXN+qxWJmAcJNWNPKtp+McwjO|Frz zoz9JlF+J32v)x_Iw~W)#)=`Akmah7a(cYkL^Sw@!C>7cbbSv+!`giz_XKT46kI{Oh~~k!V?E({Z;7{7Zk*Iu}^HR5?4X zg3Y6letQ`B z-|Vq}C97pU!fxrmXl{J1xe+Q!>I27@-N1uD>LQkT$Xo;(6rt$B_@4)eS_XzdGVcua|@eh-a{iuK_>l(7mvUMP8ae>2Yx&RR{GXBCs@~Z=QLKHY} z+;1M|)#3cREeecXJ;SAkir5VXVDNOU>BmssdxSQctSP-41%6KroKE#+pbhv?gDfm{ zoFwwW_%FN0OU zwMq5hFaHucL3ejWE;l<@zGrr_(H9?~WS$d%0|zE z=HP)L)_$#9JRsVld`Wi(0Y5_TBDPrAVTGs6i+b2GLF19hCtA%E3zP8l*|+%hDB(lc z)W$vISv2}`-NI?-0o0uHMXikjUilfm9nqCHJ-ujPdzIr~S&04U)s1rHcchNAiRgmG zFadjEnTVy<-r$L@NM+L|40>)V)y|Xu#*#2M(DA+*<_n{v{qd;UqqIoO#qA?$bA9Dl z=6g%?HM}Qoof&6IJM-<-f&C0^PYBz64P!iBwf=%xQVpweR*M_ju0LS~q0`W~Wt5B6 zs+8kEbI8vl^cjjr_8Q7V%&d8$s_%&Cc?j&N7cOKM*NVl!a@#W<%bBlFu1(i;K{1oR z!q6{3=mNjrL0HE*$)jhy6x?e&#Gfl0m953G7Pp>H1=p>UWT9~i{&Mm}`${JzIf*yiP_Trcr*7k!9MTJC7=lb6Zap=;t8Dd!yFAL{JE zkA_qC*XM;5w(kJS1H#d;;~enq}nt=2a1OF zAmWSkXpM4A&L!4?K73RFhzogt$2PvGgM@nK1f$uEvLt;URW*4YBHJDvEE6K%M=BL1 z=fxaf?MFnVY)Q4OA0O&Yx_7oa;^_l2jkUG{Pt}RiBDgo-$rwOYKLd z`P`}=W*6<(d7vLuMQsTlAnpsBbUKvd?&W%RcNy^Qr|^SJ_U<>GIx9CoM`cEI3Yuwq2J_SSaN=HElF_U@UNrWtL~~c z-%y&(ShoKa`(H!GUq$Oz&3b?gQ@pAi`w80zy_QAMqgUaEqV6KwdTEhakCU~PNJzPjI z738B(Sv2#u7LHE&5q$rQyWdAJ9_>@YLrn}37?0K6T4xVj(~U~&5l z6ZqeMJOJ~A2Q)fle*o-95MKBjBKD|?{d{boT0mTq_vgB?3535Fcv9HeNgi>eKOg5h z@U>0uCMdY`c8AVcztqRV8%Vg&9#?WH8%XgnR=>8Kb?=p!QKOPh$lfcEAiLkAO=jrF z)L7JKQC_jC9Q)eRjt@&!ALQUP2QN87_0x-9PJ&;?#b&nERh+lH%-Cae;V&b1I&y6v z;PD+Sv`-8f%C=9XhanymkvXyB>)JzZEo{1%Cv8t=%po@(k#1fsUy!GB$!_e#xS=8^ z!&xHx!D2}w$ps?aPHq>33*Zs{48;+HSvPE%eYWjQteUTyd70>2%}WtS+@3?^k<>Zv z^YYnLm{F<}@{oo7m?#K3Z07_jEBKYaV(q4lce%WMjU9l6QB;BEdn41C<2+G1JF#Q( zyn&Qzb9pGX5Xi~$LLg4W#;*)C7C*w^ipqK`#DT9&{m6JQ;L8WR0T9eY`FnQ^`n1Q^ zECyERB|$>Zgv=O$s7MbDrOY|1a`wzHsL7n-Xv9ffmo`Iiyw+%9GAP94H&dZ9ogXUi zsTp~6f<@1HT#G!l`392)fuoWBrXD<0*2QhR9JS3^^)S)ec9@e*P9)fyBB4d~zLP9PuCH4zJ_UJSq?x(<}4yA)nU zBmh|?-O=%SrTD`oe@EBJWcAR2LQR5ID=^-AR5T z8uv>tOW=l|(98s2WgSu5itukmi1E>Q?_jB18EpV{GgdsA_spz@4%$;wE6^yiDbDE9k)ddw-6vnEseeuf>qXx- zupsy6%d)XMOKO~It}W-mk5{(|PfwSDdiAx{maN;CKraQzXt(KTF58FtB;dI%bo+dl z-I2lX{*%41Wa|abL{c_MPD(FJTU@BVkpmZ=>&U-GQK;!2+w4UG#yQ;MU+4M}Ts`l0 z?9^7I%h&R}E)>A#Z6dKgw4^kuo)a%5faW_lC*Un@8?mPm<8Sv< z01NqyPS=MK8S(LsVx1O>)N9co5x!#cb%^y5(6d@50_W)|lZ-u=^Toc~J`=%D1P(C1 z=&G*M_;7OOem_vuriv}bf+44fzJ<^+f#*>3$EbJ{qFz#7;lq%U6YpEpcxG_kJlWi1 zgeyGQBv7=R@j*N@24+T#w&L-d9Hl0-v);MJn}1#NMllE`p4A63IO$w z=EnQUguXtSoL-8x%IlvbE&kmTXiJ9veGCLrN;dm6YUJO%vhO^WclOA2wGn=JYM~#5 z=!p+;#j3{6EAedOaL;3``$dF$29d?L#F_NHviMa=30_R~t?o>F$Wt_1V;V2i0C4BGAm;U!tLeRb(S;&B+uC_Mow)*z^i8lt+4=s! zdwC@*iRCU%1L&iuS9g`~Y_(iN6}lNt4{8^OLRpPiOK2qd-WUBw-r;rKJs|W$=z?C-Iv59mi`%9sCYGWAT~+&Y&xf zuM8ypomdXBuV!&by>qv*HS?Or*POQ)$l2&^DC1w*1^59F0i0PSbISaNT2Sv4ZonA; zdBD>(0WKm}77@g2N*rJ(aI)4W)S9vfVR@k z;1eY~Jo-y&aa&WtvHF`>Hk?kke`9I4!jISt*|s`KC2M_RvtWI5XTL>wSKs$r(02c$ z%??Vo zREnL-x1S(?`=kC_wqFIUzV`2I?XSEARZVf$7I2YLh1KfKTfUV+n)xmqvylA>0c=w> zyisC55dita-u@coSAo2TwDBu>SvV}lqTc_}SRQnQGZnd7zS-MgcHZhp^IVZ!IiUBQ zHF9l(O6$jXdhz!DXH{U)@2vlC-^`jC_O>!tC^`Jm;9K%Nz#uqq{HKRX;9sT(bn7#e z4kzXxgb4a;MikiHP2)GM-yLg4!3aY=+mS@I8X;QJ1JZh|-98^&Ns9RKvS6a<*QXnt z$c-47ZD@=KM`_jjR`uG2WqK^b+Kr+Z2^Aik<1xh{{8X`#nMyMpovZl?;QnZPxf>eH z9fA2_o85*(V^WE!^?D|;Ti$z#>>1!t342RAFwn881BI~MljtOSln@dJR^3CnxgJwV zf#b*>ke--Gn5lCK_5#5nkH<3Hmq$<799&s}nvkSRa=KQx{$+XCO znhK_tETS&@?36#J1{x3Ob~f(Mqi<$vBKt3MVqhSA@hcPl#M6QU_^9Nyws2ve*TIcW z5Jm6Ew0{(W@f0f7seYGk~MBqncRI_6z z5ZgtLkmN%RGDB z&E{H0qAmQX!6SE0RN<-Pl#xxwGAg&L7FkI!rWrq#+@YXYV?a_AE?OC7!?+W)EX4@3aRaq5>OAf?s}xgcDl+dz#2J&z|V zm{Zg{xjx;BWqyzX&iC;VB$qK{(odbOB0kAk^Rv{k%C?|F>5ctUYGXVa8T9e=z za<#Z=z%J0=kN_|WO|0%V8t+hIr65tf`tC8d`tbz$rULNWKnFC1UbE}KM+n{qI-nsG zv%3Ejx^_?SHKH97t7(qCQvklM|IcVI1@m$nAZH`4r$E zAotTIs_*JQcVoSU_SeLDWz43f_n>i|{e>xqSf!f2Tp884# zLY2FHl7Z{@_0VUs{Cm&W-w4m5?dW-nz(5Qam2%~89EPStp}a+5jNjrb{fKjQbIgS< zyFAUSxaXBJaCoLZUu%YQi__gKA6yu}p!6=^h}OuSjWA^A>*2_5l0zJJ+4kH$pZk5S zR=g}&);$2y?5Xr7-Ap;qveMIbPqr{X#T8|fD(UE+NCQS;%kXAxINjFbJ8Qf&DryU3 zpey@GV|uj!%~YEzMw5c~; z&7KmQEo*}xsm+Ovj+3j$gKLX zGGiiwcDW=X-j5NQ%f~259uA~ljCACON8}8*&1ZNPQAf-Caog6fcWs$0lsxlC>D{T< zXx{`*VqSNo>eWUy|AbX0`>VFl*T%oi6Vnp)8T8iR+Sl{Z=B+z%3#9Y)lJL)>Ix2U_ zCn$ZHo{6!!bM4E#V3rtg78zbQ#4$wdYdc?aZEPBU@4ZgNvTV%`xt+FT6qoypnO>nz zcWkezYwU4jw0n!kaN#ybFDqxVp7n)qpOwU_=~=YJLh1R6Y&`qQRyVRDF7YLjpi7$^ zt!xRU5WucKR8u2a!SP-OK9ANf>(ZZYTV;>-*T%u`XFcv-LtPzRZon83rA*e{+ZHP!khc`q7 z36}7%m&Vf}2ao*C?X-PqU4aTrN*mUui+09%&I#B@G}P+&ceZ$auKm`%7?P&_Tj25+ zeg1?m-?#ru_Zlcjl34SQXs|k?t02SPxk^CfeeB!~-=SJ6*ug*;(!WF(pykka+B8P2 znh>n*0Fs#CotjOr2~`Y$hG4}T3SXUQgjls}0@nZENz4FVv%8sa-Rn$Zt0xUGhG15S zng**B#-r7W2HG}#r)904G_uBBadbs9>}|uRZ__<|>ti5N@ptYvz&+$I-D@dW(FNiE z%Dt9;ap;hVrS?I=9hMY8+A1sd(HefZ+5bSi%5B`Y7wDO;5j zxK~HdhU|bZr=CsA1Dso0$_+&qcEL4y#MSJaU{;3btry*_z2)#P+5^(UW5|h*&M&4r zTnZYBbUEP$n|3FP6Ds$Z5l>$|;{LpFN|nHchGX#c`JDZd?5aq}q)Y&+jc!z(ax2L+ zA-z0j8V4ta8^$L6@U+b=N$$hvFN-}9%SgX&y?CszM2UEp;N}FvIK)@cOXnPWCQ=Sb zR8o^^meg^#goA#36jDoduUGCL>SpVc0e%YlLQyn*d(j6G+0;#+7Hzc%4}*}=0g9*t zx(|SQz2|rNr4xHeJo!i zJ=+kBau7_%!aVM55vkkhm8i(NBLN{`N~#uUl>NFNv>S@@Lf1z_w1H`4iXnUdeDZ$i zpwpf!UFXrMG%>3iG* z>#5H82~Vv@lXcF3$tPv5xbhK7SL8sUd%4-;5Bpj6g44wwYwu-K-1|_<bN7Kb3{?O3^8?vO9~7^EIh&spGWI^GmJ|QNA%kt=mBNyzi!oS+MJLksX&w z35^wb>Pnws`d;9VOMRocQ3vKw>5H%&r|i` zD8a~Y=W|=u7ejIyUoj#m2=01aX7r}FQZ2DX9OsBiE^a-2O#!EY7n73yO>m_cvykbyJx&cOK4y)>Iv)#h*UF7a z$B%?jG%pRh+{2=e9(TIhq!dc{f*yLuDY?P-sp%2gl5fRDzAg6_j-v85Nyk~}uiEyG z>GfGYmI0(I==G3GrsrxgNn!U%gr6F^ZyMp&`7`bygT-dJlP`M)yl>d8gS(mmFGqHktkZf^n!B<{RymyDtG(KgF&lN~h}Jt@*nP`Nrk zsRaXx#x`x*>Nut9-LC_=kqcwX+-qwZF9k9^ef?3-91f2NVkAuRyt6^Bb(mfFR~k+9 z4iY5%5VD1v9#tkiT(%cdw4U?^ag!lLr$vmrjnapR#Q9d(43iw(=HYt2oSSTWP5YsS z!ozgQoG0lYXX?_q_Zjp0DFBbTJ?jEJD3@&m#p`7-Qm<~wXbOe|AaE3Z$BOj*9bp>uD&~9 zZX~+;0)TAM$m-Ao?gWNjGtT38?K=TIdS|;M?+*p8M5XJwENcQfz4E2i(f`X7HYt2l zrt4o(rv1M|ncmyrzfvampHimPSpN{^KzJ`Jb+Wz_<+mTp%0FiF{SL6d66L>~4fOqV zzMl=CM87*{h5tBbMOn{T;UQM%7h5`Uvq{ZpJWm#Qp^r&2jj;6~;?$rbSGtn&E8cf* z13&7mRwC{z?&Y|H1(8M|XHiaUatTT7iD}8}<@BrNE4kH$*B_YSRH8nz6A_t3FCFez zKFKEZAv0?NQup928Iq(8U@Hh!B6+T9$oMG`vbDHW$b2`4B z`S$c;&Lkcshkg8l+%SANutQ?%Ip-Y4DIc_cc-e<>rd-{N3S8XCbIl{AgjRCylaSG>47`oJ1D z&tGa3C4D)D&{6XnTMb?glN2Ye^_QcTS2X+8a~zyA$KWAJamp?&)LO)*Cy?UX{I{w-F+VdvPFJ zsl;0?^2@C@>g0%)ua2V^ZLdRs9rY7u1X!Q>xJk*&QGXIMDZVmqO!mGN&4uTfWyZ2d z0mBDI@i+a&e5pwK!~`R2ASokKt>4qf#u^Xm7Id2^hif)<_~gY#HkkeNz}xcC%*$(b z$-bW-j9|Etc5qO6e|d5G0x4-X-CJX})o9vz=A7E$s$%s+fY zm}%sZVhmj}-GrNc;6Wy0k=Eui(8D#Iu*GwZ^iz2zIDSHnQ^TPv(_1$5)3{uox%S42q*7!d!cAMs;lH^1H|_&2+L5~#0rYwvG8ntvr_5@+5f z5x!_Ru!d*wH)TTK1Pl}=@R~=to=yPT|Mf8d>N{of^;Zmv`iVj9^->I>&p-js zj#mRaRBO0BDmcvpoF$O$WzDnt?##Hoz{aNMOm&DIZmRJZA^B@OMBpSLM3KRl>31&S zce}~*ud)^>)X@Wz;XZfSt=S0BdPPNA3)b+vz5L-`iKF^XrTpez;i{=D>tD^hA!qwB zCX0B2zR%MzVCB2R_A*tx#k227u45~={;}*qrmvlJfWtu}Pk3if!rpH8PbqeFm z;N8_KAGodE^q1B;k{j&RE{=yVOQ}7iI>_*s+PaD08&Gqu6K0>0Wkg?43#=OK+?)vd z%*GU09jgO<#nNVPXfjbC2JKeIcu(B8a_>FoO-4sGlq}@&5Tz{UW3}dFx^h4-s775! z{2B>1^*GVDZy5xmz;nY-p?c`SiAQB29a>LY{6#-0{8*(7J3dePZ*~y;m{tjW+C9nm z^;Dw0K1L;rKZGFD6mS0NRHE|ZePK%Py8a9g(E4)xxVzH+;~|=fGOEW>d$I6CILfM= z!||RaPcyTYuL(09v_7g|GmSVf*pE-7{l`o8^~j??trO5^{D+r9njQF%ylifp&Znl^ zm0fOIaY{YbQRljAM(gTiV%(QCRbefgF&Xkebnq_FwVCZpqTws5+0e0MaKjd(#irbw zNCOuRE2SupaaOZ1!=4}LD-kOJdUBCw(M}6wbnr0s+-sy&n4Kr4>X2Z}$UFbMbDY;V z0>52cp}B-YZ1Y~4STNT*=Plj6x+=^}6apWH#-)cnJt?2ID@Em{iba=}yh;moXoW|@ zVoku>va%)n>~wz4^Hb#17CBqW;nfyUg$nphB4Ffr3@i$pUrw1lYKlkDd3ubSWY}~M z0tx44IF-jGBY96o0^D_n0_!f*3xnGFQZSCvW}We3MMK0LZ80n$Za08Kzd( z14h=dX=Y73jDG8y;A;}aI&Qe0X$$7SL~E=nLDtyUx@SM#MezCqNv{M0Tyl+)z0)no zbj^BP=S;2p3&B;_0|MdoyhHMx3jx&NU%4hQ01WO_{INa1@%3W)CGKy3!hIexP0?4m z=+mpvE!Q6GTDq-iiQmEY4;#n7Pn3gxpD8EyD*r7?ReeA3zc|2qSN)3n0OxPhSx^^s z(cZi2Kgyza8MGFvd-~@yaJ8S#z%^oraXiO(Ml+`d4)R0! zl2?2@eeMLAZ3Fsl!(vPaw4-&rv}pEyK#H3$h)+>}Y>fC>O{ zpEYV^VW2dKJ-xhsaJ#rfXf!6RpzKZ(y|+sWsm{X7h6TjdZd97s(R9oy&vEPniktRRF zW53*EaVGln9u}NaU|$Wi7K`vPWfO{@wR+w><7W}}L^P#?lib;Bbbho?3z|ZStPEt@ z-yY8*12^L4a!;;G!X?y3@;G)|B08TB*Wr?j`XhT`}0tqp$dFY9;he_;7< z(hvd7Gaery9`*`;7DothKJES8ujFu@1uJhHmgQ7sPl3M{mt_r?tqe2b*^=j`>BUXb zp$g?H4{NQ0)+3&jz3~8y)A)<0vU+D3%Tk|QxzPh}BKS9lB1}U<$6i213CO`1%PUc~ zvJmw$@Mc!;!5uvFTy9*Chw_|53of>-?R;69A)n{gT^t>_DwvX<0V)D2s`u*+$_BsS zkO;L}MgH?U673H;5rX3iR#k%S1=2 zzY(K%mht*EeSAx5@73^+!8oNmg$ZUt$M7c0$w-`o`&i+|Yu;>ARgwG8WST7S#w<9q zpB;W~53L;@o-95UnfrHECg^i%`gd0*=yPfMyDL+c>10>&tC0HTLDIj?5h^;}>QV}> zpU1l#UvE%)SG=boWZMNG+o}y<^4n6Xiu4?&Ko$^A0oA-c|9G% z)0w%ZG(_=?`MPTqyC87bd(OS@t5bX3+C{7%(IYwB+UO$Lk#4}Z;h|&(f`RpoAf>uY zQwuSmXrH@#Q%$z|(Z92c#%K0rqWbf5?~>OVoiYVK*i9YDwXkucy_Mmi2ms-j}))A)_I#W>g}aF z&?G4yS?teky03F(U-hqAK3)z2(2du7FeYeFR($=srzF2WM%%ftFpE;%g19%jR-BK} z^{%6vzjK(>&(!K2y!x4{{d30m+djXeZ$E{*Q2LkLjd&k_M1|`Pl$2hNL0IES=<10C z(aN|<&_^Pv0$E9yiRG|VDjde(Yp#K-l?!}yNIIRzexdG zSt6jN0kLMrM)>O2(Bxlow{ArN;@hDOJg47&d5-h%tO%av+Pa3RMGmjo% zXcw#V0VJ!>Q^msUDWHX;*Ng(bSDM@C=LW3Y$@Xa|?sCHAPR&W(Xf|bDc)@-kHhV53 z-NOWE$NV5;1yIX9lH1(=L?WKFjL+I`o7^_k*vRc9JTdhkOWQo&24=7& z2ta(EORa9aTQx-6zG|EO{(+30f8V~k+ETjiD6pB&;;&z{4X((=#+ZJ|R1iH0n z1Myx8d=Oep#*!jBRFNN?1pUI?PfRGi<}12sHiO}4-#R6SA`LR7- zf_*3$?Nzfd*g(Ss;ZRkcmBu&s8jbAZIgjVZMDQ3wByKpLg)QL;E{~owXuF(qfqJx( z;l3*Ba(y(;hJMV>K7U>I&V2LCgvjse0(v_4LSwR*p=QZ3hr{RHC9FO4m?MMAJw2f& z>3W-IPCJ6H&1D2>f41a@qNcThX7k0D0G(T2Cq-cT(utUJ7j9C!SD@LZs72mK#iC&_ ztk0TW72H8_z=ux`a7vx$eYrWevGa{~$|GPE-KTQ|{k$WW|6q-O?A-k!0;UJKe59}9 zxEyrTqB;SESX%duPPT%D`^HuLg{!h(H2&6>lnzfZdM_~0&nwK|U0|S}SD0@L%;UF9 z+ecVUz>m@mO(Cx8AI)8gPop*X8_zVni>QHzZR9;w2<^QuVR*Mc9gLSH$b4)UZqCI0 z%h43pRkY;}W!pmAvI&k>jCQJ%Ilo}OahWhn+1KgGJP3L>TiYDv#+Wk*Pu*;I{_xc7 z@`4w8@Z3VFw7nmi3#LAK&(d@(vR(96NH{~-#Ae94!y~TklEa>5jH`&EJ4bx$dDI*< z`$66lN62w5$1*rLNDvK! zDtI429K3m2+Dk8eL&i;NtS&IPO(k;PK-$q~m6%1w|TlC&6v=4L$hGZyqP44=H(E3+UU7o5DnJxp+0ju2n_*x$H{BS3Y? z;=HhZy2B0OHs-;r2{$EUy-E{uJ`8pFQn)Gh>jA5BdKn`;ta(>LvvG6xt|!=s9=T}A z4msy}_qg0LOnwxY>-))FO@{-jDEL$KUF|d}F-l7Ck*_eBvljVz-};Q#Ff)V)XLBFT z$3yivoHgN$j3_HL2L3c(ds9J=&)Al$tnQn7l0*Fq|6UA(d z6477$>~e?vE?PM&`LV-`=Z04!xc~QQ8TN0`vfuRiEiJ=-+#5vEzf44WCk|n62FBp) zu~}=bG_&rqN#CbR;_uucGF>B4(XUS)LDF^C4}!lL5xvISnD=fTK&yge-6R~ryYT%x zJh1m(AHe!3VhzsG#P811qTg}1XiXym#EW=S#^60-60U_{GBCCNFF~#GI50zu+7ZF( zyy5Y>RharX{v>?6g2>9u)?gp9R$;_n(K7jN@;s+Ff6%hX`#(X;mY-6r4HYG+zEnp)ygZ~w2BRb5-(2%@Ycf$k!u)lS zn?XU1K+7^Ae{c|fdo9(#~ZxK}buQ<7>t@hMC7P+V;p5D}yx|^PZHeE~X3mmbPp3^Ig8 zZB~bB2e^VS;eEMZ#|M!;-54ONEeJ5Rsknz1kkKwjf>Jn6SGz&YC!6N&qkk@%S*2+Ee3W2F)s8FpG~0lXPl_VARsQKWKNM@QRKscuUNkDxSuA2*L$R(+pwtmSiH>VHhyWDP>?6Z>D3_~sAW*bgb zIUSagjY%p>e2)MV<1ak1CRJdj1y&y(@~{?{1C#~i78}dvat%eIi>yJl$>emFNELg= zFw1w(vX2XH1RR=oRr%Tp?UY6E)ekzwGAtZ?SpDgxsD*l+Wx~md2oEIgWaWpd#y=7s;Y~@82(!&a7>rfhjSUfHT>ay1}{is$4YOQ1nuCskC)-C#k zUXNo%(EwVUrSYtnCKceRl^uGaR3YLiL{YUqIg)4$`wUMMjsIB3^!9y;tU2>l0r)5#&Jw!?e1gyl+|9u-Nwinr zcvr;0;IqP(uth$N1_FVrL)%yN*EPA*FQTsHrxN@2Y_|}8bskb?=jD@0_Y<>tjt1^6 zM(L!1`(1>N{RCnbozLG_Ml;@#oL`mJwC0P$%9lRm8P;YXTIuswqSeQ6_7AnUodmOm zVz-qbh=OX=&VyX-i7wmIs=^olqF9>sMim_T?-sXKUFz#!rfPn>(ecBy3AMFj!k8FlcWh2w+e;F!B@0VhGiY;%F2%vzG7 zK6;W=Jemn-7R;Z^;4ZvMv29@VrWZz112NR15OEmtX??ohg=B_MkKy4O8n?+nx}lpB zXL(-u28X5M1wT$L6#DtL1x&^{)6Ow)ILq*SoKYTcRiu=%E@W|_UrD=IoMluCvF*y~@gXLQ+kEl2FF9Pjtp~j2Oy38kJtO_D&z}7@k+4m$BBeNZHgGjT1U-@WB1V z?K`q;OKXb3W7u7=K8xuZe*v7w@N+VHrrwpzU^Dql}B>K@aqwsc%_y=B+Mh+1VJ@XUc=n=xah3Td_5PMz-#f!>Ti4I# zTl;s9MOhm9KD7PMPX89={>{RlI?108!oQ{6w-6T(_V{oMBSUPbXr*u6)r8oG7k7SF zyvx|3pBtkh_}k1S+=Jef+Bxx5vKJ3`N4Gb%3nBjnrn{gG_GXjqEcs|JQ2w$CnY_pF z_fB!VPb+Sxfp5C~E~SU=pDXANEmuoH@Aovq4se|^4+T@-WD=j437qT zb9sxr@x8JAkAv{e&KfI~KUrg+D&a7^c@X)_je6uCy9+f>|oy^&<UHbvR;25QbmG%O`EzQbRXT&fxRtUq_W_A2YdBBtWIdr}E@F zJnTZBRf4)EhfCpi*3I$dakWLEd%e1j5<4VLg;lrd<0@UG9!XCj&RHF6Q zt0!+KVj_)FXAd7`kf;`)YjJ@z>}oMtbfsZ0ta( z#4H-zUjvbE?OEU_nV4TTy8@o=`twwp5QGi01Dyyh;}4SnlogVJvDP1_=b?t-<7>7@ zXG2Hv$|7*9dvtxp4JMpS+&WWW?~(UIBH)l1z}E}Qrw_ooQ)r`5+GD!gCV2>Iw!PiV z%6MsrU(du;&cbsj2qoa9@>VbNu(pRaX#zvN*~_890A@ZI7GEofDY!1#bQ<0gj^nr$ zca{f?JX~tods+49W!S4TmHtcya$IUO|I(UkAX|W}b7#_gEO7b=4LcyZ32$zu%b`-9 zFWy~5R_`WtxsN{>pAOsS!h#LAexcZ`*ug)tg_VN z>ty?H8;#1eYuuf9nP{yVV*ZeO$dNCo$vx0#(;`sk&;mYQAL-Xiy9?x^Q#KPQH!*dXR@h<_apTyT_-D9{QtML8P#RX6!a2fVJk`J~*Qinc$_kH=X|DI@a;!W)^Cj>iM0tZ-m@Iu!F_yFdd#GPYeKJ*0$O1>2@sN)cc7JWy`6(_?oU5 zZq7>63TSktnc{G}+u|xcrs5`MtP_p8wZi-zm@W^ZxhXan23TZv9m|o|@p58c=pDLZ zMcWZ=go>vZ0p)IHGq@{^pq}B|r{d1t`}_%zjkknF!p+TfMVNa#%GW-&^amr*S!5?- zlU@$3Oy93wTcUBB!=(C^(yP9ub%9@qf9cFna2b{DAih*TW#&jG^U4BWZ2ezCbCQCj3amyu< zVIxlru5t@cy&rN;H`Mt-PmT>nfC>(nC7!HXx>jkculuir;J1hgCqOqcUi`Q!7d(45 zx*jmDgAiJLM;|RTZf|Uv+=IqnVZeV_-h=LIoAp4IlEOLGkHWpbuz0(K<3yT^lfvd% ztg3E)Xq5Wf+rO&^b@w5J^-G@Wmt`Mm!^e<`)I{IpJ714&$?$c>{};9OPXO|N_nE#y z(2vhT|5Z2~Bp{HaK#~Lz9D^{B!YP;{K?p`+1R=IxGlWvu=Y|>3zV)MD#*2d;31V{J z=(qfWig)OW-x+0^i z>U(HdHNaW<27!z20oH!yuVP|vEwR6MV){1H{8BfJ+_|%W#?jzApIWW?eUP(OZRN2o z8)Sax9`hMr-0e|=Ue&^)@-@m?}ld`|b$vm0CsZ(g+0752eXC&~29y^loFFiXy zB^`=%jm%vay~kH9Nguj0;=w55M8@P{QA3mOBl^Sj*ejs;upm%%#QFIc=XC2_^lA_( zr55WHRn=G8(vQ(wH%J-ueB{n;>%pF4+NvavutVGc?zMdqu{bs1Q$Su!tPG|`G@m4{ z9>HJ%!So_ap1xd2_{6WmAv5~g8h9kY@DfZK2?csyRIl<)Pm@XN+6BpnNm19yznaPU zfV79aSeuB76dQk)^{aVMG|974KhUqp_pf>Y$cCb6?6OdG7V|Y?7CCCcgK_Pi(mjuD zoC~2Iy)@f*BOz}2*z|=v>Ykb(RZ&hgy8y1!V|f{fd5rbyTT+(!yQKI$^YaIjmDOH1 zmZ80bp&5?m`47Maz96pfOKtKWD#faQZSSDqp*Oivu>zxw0l3=>goj?Ja_@{k7U$c} z+MN}g?pihxWar2Em_*z^k<9un;RlkhQ#TGDb2sD5a1Bp?f9n?WC0*n{B{2YBLOb5R z+*C$@Q^LqsjIEiljXSM^&zO8t8wiz4v!kCgScVGrh>l8*`m6gAH#i5TFqY642Xirb z1cw^#E2lKhEelhaf6ndjf`LwIrLK19Qq%Pe?J=YfE-(!5W$p4Bf!;@%^iFnb#+t|x zk;~>H7mkr&%T$UoKY)+sl1A91`i+S_2t(|+nbmd7WiJmiJ_mrLQ(EoTF&dFg^I}6$ z%Ctf1%9|;mT)o_6#Ry$dxIQ1_L1d;dXz8mIt{sdA$n9z@K!MjU>~aW%k){H_dG>5^ zN6lp=xA3M>De`s+V+_=&cFgcGs5SC#Y+LQ^hTcMo^=>!dav*r~Y7R2;V&_IDv$mC& z@W#pE?@E7M{URGKO{r`a>_rKEh%W9 zF9Gp=EHwyskWAlj2N64GG7R7HnZ#Rfb64N~6u@C(m*foJewIkO8-HwgzF{h{ormw@ zX2IJ;Yx^ew?xjQW-Fi=w4^i;H0yy%1x^T}((YJyL^^PxabT6rHVE~xyRnRS=g|;7} zy~ep+7fpAF4x%02h&}%)Sk2GpZ&d6h7sG|&_a1rqE))up!bq|HaVnTVAVuomI`gB(@qJLx;{4_&RqElk0+ofIo=%crYjb zwSvA=tTrNKZj%s%Kgzhv(!kaBJa5h?csi>fM;+1RId=?sSpYN`NC&lj`NcYA9@YCBl!}#FpI#wo**J3!DjEdSJ?5&ap=PeE{^Rz zV=3&2d7zCZ)A=&G1;F=`d5(+A10s!UKugT6fL+C|F0_8Cb^PuL4EVByDypT>8>}>h z$l&%sS<7*@Z?@_I!Sq6DywXyX;|~289F-H@sjYvS@MXDBNi-wRn1BPSslDmUi#{&d zTnuN9>hsCm9ssY%(`U(x7IeSzE{evgiyjHPE2RS;UwT)-cjKzdJ&U#=Cj4n;K|Axn zpeZ`U&w3PU`Le?KafI7oH1Db;Xdg2Ro;7ElLhmR1ydL;=LhB@@Z+`xT`Md86@H=0a zzx%!bpU)!jv`WukBZ5DpfnVb*{CFK`yd|JADfhN$E<+E#N znKDX9)!oAaHY4H+m}tQb@An4B;E@(d75`x-QQovwn-$6MCu08j z_`e0h|C5*fDEj{OoPUPm4Rz7CENS?bXu#hxTf66E@+Q6oZzGF%r@x{2uVzq#w=x72 z?NbCHxZ`D#?s$v8r&%{d+<Sc2^N?}m;c_AfH{6=4qDC0Nto&6Y#<7T}hz z6Zn24!1s~VfZEHtK#--9NweZ+8y-r?>v?9N^!*^=-e)e%*q+ zz0+OkYr2c5!~KA}Ld{6d$T6o9Au)|0Gft4AV;fAwRS8mnR4+L^nqF9pW_caTj>CCU zCR+EfRx)TpisBs;ipZ3SlOB*dHA8!%eKonmUUb>H9fxgei{@M9KSv}z#Qv-7eOcEn zd6=>}imkYi-?q{?FHbcc|LkYlD^ISC2^KtZj#%$J6KT+8bWPpnw8PtK$8ZZ);= zLI%+TT4kg?I)-*a={2k{#q}FmY!k52A2a|tsHquRf?#8MO^yzQge-o?iG&8DTOB_b z?T$iYHx);jZ)xE{XFS)U;z^Z6_U9Jl(IrxS9ly% zps06x{#MCR?49TJaSjLkZan)dcm{rH|4cja6)j>gDg!$Zh9JGJPTYsI7X>Dibgf&; z$~YmwnUIoIjgxKX=5kzc39y8&O(Xz2K*Yb??7Wyz%zM&Zb3H68Vw`G`tgJ(GRLMryk+Y?Vu4Qa zO1R}LSHNq5@Gj^{3-w3DPReDx@>m z&tC`FhV0SowMSnvr`V&&YOs29x{B%Vl@xT$C|h|IRupI&51tCfNn4An*=UoAL6O3H zfOEUb(!;nmnw=&JZ8r!{$X)1iSMp5v(Lfm8WjyyaZ!3%qXM?7=3f(-%R=K{*X6SJ^W|shiE76Kp%2XHxYw;XN;yf^ZCxBr6AD~ z>NB1qM<0Qo0L`*jepXrZo7_>O!xX&x@$C%I@6DtBHfaBvedhP`aTjr>w zgrhJEqJ=e=?r15J>mx_JMqbUuGQkkx`4Tzwxo_A|4`jF4A=?MWj2sfNvNoP$=4mSE zkg~5Cn~%{IG7(ScVL?NwF*n10+d11?8C8bx8kGfD^7)c@qBFWo!P5NGEXfO`3sWB) ztNL+_Rw*9krzzX`nW&~lMNP`Q3okY8Mw6w-0XQAUW>J-Kh+uk@(Eda$`q(;G358c<-%pCN45c!o zBW1Um;p50PBFH0jswsiEAzOrXJh6Z+^d3pWV|Azu_u1G%b54RO3O&XIyTpJaC+Wq* zqcEcrd%I%I7IdL!Fgiy5^27{L0Xzd58NA?A7I|8R`|>b0IVLB!5T>apv~frR>WU-! z)%VW1hiJi)5aaBG#QCZBw^juBOmWSEy^&W^6Q443p)~sPOf)y{YK&H922wni#xLrI z{$1x1wq89=34a>%ftt-+1Kjq&i%zJ$9M&06a=>`?rE+_3_Ia{0E?W$wW20J;v(@I` zitNE2mVTWI1it!#sO#mZDh^v-2*DWdE3Vec^}$;9W!(V!i=W7!qMBSOFhbNbGtC2E zr7l={iypUq;k3Q!9G$oOW+5_}-6&hYN$(*hHqBCgJyu2rgVd7D+?i0#UI8q}`t^h# z&(g-!)=PvXss>&2ZF_O9&T~N3HBodtW+ERjpOrC&O~y8Q(bsn+Q5dyu(Lq`WJIJMS zqVyI-A2(QD(vcxmJ z1}8U>%7G#7h8%b{m{_*kUT@)v2juIOIp*DCLhsZZgh2^2NoMuFB)=p-uOV8jERM*A zGx#KX8wx$~pys%{ZEb2ljTr&t7HuDM9QMuQ$)LK!=(dm&sL!O!GpWCVsS#h!Ne{-{ zx<%->m3z_p#HbAPv@RfVfB?Qf=elvFS2}-sVIueF^)53+?cUNxTMpg`#%YtiUkb=GxFMZYoQyE~yBk+*qHn%9~2+2iIO4Hygo`BKXuC=Hc-0 ziCaw57o33fN5mz-S>?DbubB|~*&NC+^|WWyRn;vvv@XIf%ORava0}O>2))ryw7E;> z@xfaf4=tSfq${BFydk~beqTA0E3#q_i~gXuV~-^ML*hOL@h*Qp`W+V_-i}4vu}=sG z|MkVbg<*elp&zIP1cadkL{JC{!5~HwBo0G3K~N~Qg=PeV!Wc+?s=`SU|BBuuHzM3a z95C5Q(OXEgYhRIjNJWKv^&%kOLJaWd#^u<1=I~uh0pooTF@DeTeJQYPQ5ux&^_Do@ zD}?qm@0Fb`^u+#|PyJSP=sr{(Zrml!Fg^A33BO_vM+!%JzI?9C zS^XTA?R5rQWj-n-sxDMbVC`Yp7d7$kxN&Fx#UQ}jO>Ai{pGH(2acH z#NE5Zz%tA(`4iQ4xn+m^_w$Ee%Okr1BL78s^P33z%Kv!m&QzZ{ll@z_{rz17|H*BC zyX&0?@E7XVFNgpmm%A5?ztHYk5J@7=4lZwW0TBW6wk!3Md7%s%Q%-rtT?-oSOS>}V z{Caj?iexBT%9FC$!kv)*S}KczA(iQJ0ccGQ9gFNb;0Xr}+EZ7VT=P9= zi|(QV@ki(=6vhlbj`O&{9hQL-e$yf!1#B{#jH?T8BwKIf?*#@9VW0sizt`P7}{AMMQmhS5(ru1u7CK4*7+w7h52EkaDf zh{UabvEuy8THw3IzhrZ_8BQXH^GIH_B|^HgIvj-4aBSmFG|sZgEIW@<9?&4QLLO7B>Ml>}N{foUmWPYK|5- zCC{%A4TVFkw>Zj=)n#PIW3P%MRBVyX%_rhvO0O?Kga=j2A}3wrE#w%-Wa16IW;tky z_^F&O6+v+R(zSeips{&g{Re4sy8a{)GWA|`0vuW}lpSce;|}88gcsOvQJK!XngA*0 zW5d<9fGBe$tp!nAXQer0-RX>K$F5K zlEPpR1rY+JFo;B83P(2RL@^XW@y|e$p!WKEK)o%r-_k=!u=nOS*xT}dG~K)M=$l8k zArbs}En~+)avv?)PQ~AvLtkWv!Z&)x_|7Ls!LQ8-INj-V)LUH%`4t^+e@1dA0qiQ( z=>F^kxzp}o{N1?6cHa1or0++=w-WYttJ`hw+D-AkEPnG4h;(0rynRBqYevKl!8r7f zp!s-%=0^+R#&T0;cMPjPggka0vg3=Q@o6oC$^UPGCOwNE=o5dBJ|DESZzT!fW_~xU z|4pj;dkv-Uj;R9wnW3n)v!%WoioU*ow!NqNofykt@?RXq%YBXaUW46%5C&foM<*X{ zY@puxaP_X1NPIkmu)G_weGK*gTPl?3ead-vOFR_QY@wvL6y?ey$!!UgipbBGsu~!8 zH8_>_FO7L;5$hOpFQKGu3@Pr$InHOFrX^lp2Q76SdCmxOn(W6>9B^XF&bd_tCgR$><*LrFxm<`3Lih3-GBQ#phJ^A0(@33cG1`r~~GC ztV!is2(O8&2#Er1YZm9P{RSqRPc8ki__MXYF5s)rNW(jce@V(=g!qQ1jNxjgkIaM; zx0KrD<{kOr0c?OjK4VurP9`Hl_w!SLqogsLn%#ggbnlVE=Bu?xwSQ4dmn-_2jHd3= z9pS5u(QyWV_~qExgG|QG1%3yX0_k1f z39#F*iC|%hC8*N`u~?s8A2rPzkEoDdT?V=+s9e>sgM7yhWAr}&O0mfDFNs~yM9Ck# z{Xc-2|K&CR0-wLU-uFm~U>JgeAV}aS1a65a1yKZy5(r2jC_<3X_7M3guRTWJ<_^iO z0)s{SDC`b@$eWyw?V5ZMwj=6>k6Ttsem>2My<6YOn_Y(>JM?1Ij$}c+Q|tDb-Zx`z zyXuxhLL1mZJEX| z;Y4*^$-Z9aWVutU*C`d_m=6>fft)Ib~>G%wzShmY_*WmqO7E*dy8795mEK0Hjq)N z`+f5eK>BoQ`H^T%9O9LFgA70_vC8uj=4P{XVlOh1SBgzpPpkqXYk3`N6%3d>CPR~t6aT^^K)x~#bFuW1-L}o?gk8L%pz{+c!&};Mj!|-Gm7XgeY;Cd= z?8lX7GOb}HIRpk4J!AksyqG79o-MOL4RZK89H!m3=<5>;hrhDVfluk@XZ|q5C3iSe zA{`r^oVODFr0zaDao;<3?uMPf-!A^;a2Xv5S>PgC5&_M+NPgx?_9BLom7+?W^wTR_ z;*!4Eq@a+q{mIn(?pK^M_8 zO50rwq46fRWu2MgA(no@M+1*oKQ09}0VaNMS>pgMFN_P+Qj|&2aIa}Eg;mRUGufOE z$x&jW8op`-pY*a3H!YX0v?NoumUO`3Qa*WHLvV&tejjBG^8@-^m+2PXq|2C}KlN0z(jr+WtbY4I_7(1RNu`ymP}y4Exk1 z3EBx|7`)>ZnC@f77`Ritp*JTCeA_yP!9JUeZb*rJZkQ14-i}|0+t@qp+f5SEw^|(X zW{5$%IK`I#A>^C=9lUAe(Z8Tym1j4kCEuj;-DVrw4U^#asB%p0^IqwD?s$V->btqF zy&WF!%eJRX-`X1cBr^DRZF)<3d{N@v=bEX11W04=n%_UIKP1$~`X+WyeUM$N1d?>806Uy5>KOSH0oL)%V=a-0tS-x%vi0);Fn( z>;{uhRgdP=R|E$58RISJ&vyFF*pj4wuqFB)rT|(yOt>H4SV?n7^;P(3aLb;nxP3<- zs@jEw)^KSQ)3csg#er*8#Fv$)dX%i%eDLT6c&wPT!0z*?sW}I`hBB7R9bGF5NoKxz zLRG}dEneeL=Dd<+D%}si9mFPHW}+9d*w+5lb2s0{evWPR zj6x3~d7HlX54a{?*Mfjtx`?h?zyU#WyVb9$P~Ew)c48?^zlup{EcX%xb1}`+Zr9xfq5WD*h1K zotjMl@xT5Mc1iX>AE1SwB`$vRoDb&nr|W;HZX)Qe-hyE`M1nZAK@j;VFKgS9w|#fp zjQ4^hv=0Ywxl9_oxl{4mKQG<2C8Bswt|;Vlgdz7tZ9@<8Ep&l=fvE7E_iUGc=U=~NA-6otp9OxO zsCR18PX$3UhO0G#c9cQ0n-#spuLYoYt*_FMz|~d@t{NaL7%_z3d}2mo!EF0<{@Kgp zBuM2p#NkxvOE2%IV|V8Ca}vlI+>c41g~Z*K@VwDx%iTm({~9E}3#GmZe1EGtOudPv zH-jD}K3cZ-hn4E(GoF4N%xBsTC6~+3-loS>c_YeBj+RFr=d#T5 zOHcZC!rnN{l~w3gELK0lM-m|LEh1&eEthG{swMCI!D}6wz3XHobm;A_5KpQq#-klA z=h==@u9ho~0x7%gR=CFwKp6InC~hFb(hzKET7K<$7?K8ZMw@sZAJdDUqNYgCV|Kvu z3~`EXImBI2%8I?@hX}w!l~l-SrS;3v8IH_&>$Xe`hH6JQp9<>?@Uf7aM898{f~S>K zqYowIORE**hkMxbKvL7>7A~gBVNH;XKZYezSyFf&mE)-M+-a$L6&|HWs@$JbzvXRx zd+B2GWIba0wa77`*1cP8c{5BlVPg73Zg$GcR^)?WHjSHXw?o;YV!r}o(&@rnh9$HD zs^#s(W!NDe0hLQ`%F{?roR*yO?W*<@T2@0YCn1*GL(Wj9Ff{oMo@bRs=JTBw-DlFo zcj=C_AiMzTuzDxzp^YR~H?c{%(}Aj1w2PDY(803zSS+x!MDZHVnx(c|7Eek}ey}4X zFD9H?fRj*Oy2RqRrntyO&XRO=_6qvuuUpdEm)uI<(4-D0NxDFHzH{y!Pah>L%0^sj z)oTF+0!G~vl0+OAbc2^pEC&7PJEww=*uzBv&pdeXx>RN8MRzs~{6Lb!NG$Bj1zXCO z3S`n2l)!8tjt7`5vxIwe7h8Zm^db~OFC&(E=&ySF#rcnQ;6I!NAG=aOZ+_x2 zeEYqcuCv$#Q1yCcxj1@BuXG~#3C=wl@`C=Qrn@ixY%Q=a*0ZmQr5rh5O`2e`D$Cs) z0b8Dq7XPEauo^Gx<#4WXTE$!U%vnA{{4R!NQ}>?vfjimHo*ZD z(@8QQXe3W-EWX>6ZOqxxAXXbaCEy{AonX3NawnZ$OTuLwY>b64v)JKMWoxuv0Ly!b z7I%80R(B9ss&hh*@+JO(q8A=36!G358IdWz7iI}{&K?D`eU4P=Rj!4j1_1_KAoVye zhG|!0S3cL%91bXbxeh11MiDh8Y44J%WrACU1d67Nvv$y=tOfTbbcP3(1;V)}_@NMu zCDIQ%I=(RV*ogx6w00g1TSNR}@jP&qb z+P3a|Agk1*8rn@nU)TF`Nl`zQ|ATPND5@!W{JR0$Kb`g0knP7az7N_k0t68f0Wk!E2#lgI9QiC} z+r`uIe+AH<*AwxcWN$yD(Vl8Y;7)fUuy;F}+*`ZQ=P}!soCm>PpnIt=jDhl_G z?@rxH_GoSQR!sNwJ_YwW_ZAyM+cSi}h}puoaU&Y<=7?dqhizf7*WyF`&G3H@wQa!| zLi`Jb_j3APS_k(Kj-vK?_Pw2+?qv$_J$#qM`%P@&;}%nH@mu`QG265kYVi-vcgcKB z))_L0GdO&%{r(+!9e9hsgV~R@=F^`s**?Cde>X)-zf|x0C<@ri2chWie#?JGN*|SP zdeKZ8RaXhrs(0o4=VLRV|HP&Lckc%HA*lQ8ZvG)|+uua?Tio`#3SvrWsG3ITlHR%6 zx{$A9LTZQj5{2FQj@zqfzn-;%ayE{l8mLadX$8|o#adoHp^v=eloyAe#hRm@1s0qu zo6K~+TN~_18)tD63e!k2&wb+K!6|qmd;p$F+(J#P563PcbQo-U8gg*KSdPrL>)|Ih zvkur;p3(9^AhLxVWwBH5RsrfHZWhT2XhPbqxO3p$AklOf_R+~AE@^>vx_3qU#N0rP z5WiBy)o-5Qz03#?!NClF%v5uKMIwOHrb58&E2m6)oN6m_$HqSwaA|dH0$Wd2XjRJR zo>dYqt9KsY;G_`OU@;E%DNp}6WacsOdn zTCX2=gM|g^VJBZGd3KfowPmsayVAZz+^uHe`R;g#ZQ=Z?jdly=V#(>&eR`b`m%ZTP#ZZJH1FsH$MWUdR&J)r@ zIr$N{0ej%~-^6Xe3Fovq(V6kyg%@%>H6a+y-5t-X>@RWKXKR6Pi~lBWoSc&{`D37f z7yIy`7qt)*rniR73@*=lubv$Q<>6M5AyUUP;yT;A2w|l(hvY9v#$wS&e*m00clA1 zr~cHojN(WbZnnY>K{-56P+&4t9V1nJ-az1hpC&mBN|h6f-cx<&KA!?kC`cgCtL+m= z9je(mzLK)EY{G)9(In#X?%X}j53UT2LyUUW1Oat!57>dAP%KZ?h{ihXZb=~I_eOtB zD1yt;@>W~bny48y**p}p51VwcPFQ;4LV(p%?t-f;=cN#cM7BC+eA9uL9{Xc9a7RV6 zZL~QU!}IC9qSJC!G-*AV7fl+2`+<(zmxufNVPQz8Nrpq^8$>5YJr*8`{=?^5z#YL z5d=9gV02F?<@#V98e501fLZMKEqR2b{nCZGK8iYcEPo^H_px*r8~7=Z`!6o@Aqe!F zm-vA)0TUDn!#IXPTOdW@2m+%BgpeSPA~;1t+k@NxKMVf02nl`%PhW`fAi3Au_Mi&c zL#P=18WC@R*`APkKf`W} z{VVd}_VDh5{SHhcY&UmIf}H@d1)#f{5VUuNcE8BzEm8=*b;U2t9@buu@&l&sPXPgN~Wp3Zf zWttA#)3;{K&)Pg&=+y$>FR(@S2vRrlu87Z+;<;Acqm9qL=x>SqxbZWnR+?(y4p2czf8*tdC5;CHRAf5kBb-d5L- z%ubF+D;1&U;b~<;=B%|KDb?O2Nf4baIO`jJ_i?1)qi-M9nxCJ@7U9ea1<+2Y5V@m; zI6pUMIM03Dx=fl=(DZAi?$4m}SU3T>`*noEB<-Ik%VG2&pe{@@cy}7`B|AD91uSz^}+C_2FY*q2ukyf`vviy{%W)GljZLZfz4UlJ`H|k7f1H0)u+&y#s};-vWk6a9Ri>7 z22b6bE^9ol`jzs0y*Gk`K@>gd@){zDVtZ*pvFQ+QzCi%aCf87AkEQOF`W;iu0ezfC z>ulu+DZ)uXm)6T9iS>|On#709U~B?!eW00^nsp*n02&gO?Fyb|_J{J&KOdH|l)^DP zvL{V*)U~i0rv?e-wWT8LjYHreooYw%V!@0q=B^p|G6?~* z@&!W9rGRI?7@Vs1H6Cj)@@T`5t0jUu-y%-($?CVy0UEhs5VKSDK z>nR)z@thbIdA&o*G3}Qo7obO>9|KQQUabYtCQg&Ql2x}j2_r-`aQ$=-1_M7|6X)q< z=_R{LITYY_`TM-VF%RZ3`2d+ed3|3V_)|*fNBH@WvE_=X7`7wF|0nu?|A0Xd|Ko=f z|JNU<_VGvX1+3O2{^L0$f3!`t`~;Z)KitHsQ1`F2=7;<-aRvl*cXIvmA~!gw`Wb!cb^R1J9T8Ziv&^sNJ-@1g7EX7 zQo9;Y*!IHNMDmg;_IS~#;Sv5yYPUE4Dtq!nWkb|k&y7Lf_|VvCRo45)=}Uo6v~;Pbn=weP0wkRPY*ycy6|9#-!vbTO^BKJUN#o&Z0; zDgW+!0{r}@{JZZ7@bjDUJMYQ&n!dn4%<>KGl_RoKV>N10t{9v6^vgJM4}VaZYCaRXHN# zC?sKo(3+o_-<)SRXs|7NpXE%$N_w>Q*oPG>y?J)mE9MS=#Tm-p3Ju|%lDi9rqq%-< zYo~NGBoOAv=1#k0M~$_M3T1LRdM5R$!iT_jtb5K8wDRb-53)oo{?#M<^Ab^(a<(L3 zS$Xanh}xqQiX1hz+EMJ1f-8A^mCY$K&pk`CX_2jHGuUN}k^D2$nW9wt^jW1oJkHxY@FYb%M zHORa=7^*xJU-W`~hhLKNPPlGV@JYxPFguW&sy}A^CMuB)(Z3E#9_Al%19r`^(62Ol ze`Zwv=veGfA$-_FH=5FmCp|CwCa`*>dAD6C6a&hVT^GAw;a2np%g z9?lJ;TkO0Y&{H@nL8&YC1wD)N-B;3ctfUUrl--3&zHvyfhPB9?I^3*DB@81=*+plP3lWadTL zvsW{0E~OJ4Ts?|OP6c`{hU9UnN~AE&n7!sAeLOy%KB1@u`Opzc?YAhjy-sXVgm+P< znR*(C{QMM6$~elZ*P4}Zi(Y*EDEf^tx|E$Qm;Kp_%X3AQ5j@O9TS!+@FCwNGi#8o@ zla<~mn0^VAnVK16yGMCc+LRaZR{15b&BEg{ak+^zndLqkZqHFr9VAA={*C#(V1dT9 z{qUxhhy82+NSD0*w|VdX`j<>B=>DS z|H(OiR|UXej3RLyAt{2SVS;8T7$Lz>BECF9kqC_7#HX~KECqVO#X6}#QXtAGRWK?7Dzl7rSzy3WoouP(>I zabOux{AzLns3(>n?Wc-$bZ`xlXn4)x*FnT3+h^8+k5!gD z?SgS@f8~o#>Q~~74vAA7E)aZq@6deY+E#pUuoTm7hIbw<_I=c17SGYEseqE3dE(aX zptlX*gP;@W+QiT7#2r6$0}C)M|86>(b`xRv{%C(B`12G(-yHozrgc^&4vD(y61{%T z`hQINp^vQpjdkRI6VtHxk1@@UAq}{GKhJLbjSC2_AM~GGz<2W0Kfi$Ad<*~V0)p!Y zeR~1_hN;0*TW;Ci;fz3i#~Rm1u3IpbmHJ3K&WqY@gw4*@iC{d{vFZof_AuSDYB~k* ziR7=>OS7Bn?THA|VuA+vF>lYzhC|9b1@F_iQ-dgDDk1SA>{(YMs;c|I_DHzjg@G$+ z5C2wAkCNPm$0k!}$jy&Jw1gZkv)hvj=XklSC5NYy?UNbfG#JH(+(lBaz0pBV$|JK= zTlz|8O_xPPY0D62ZR|&3vxEtggVS%>+YR1ZRCU_ivD0Q=R=N4bJXz+(AV}jGvEoeZ z3$q*9l|9t)Hqec~xD&n&II(Z)&{R&sbg6)t4+Y=KW-GM`ZuPn6*fiH?8^h-ns@)UJ z{1A-YjKEvSREzNRAUu-ygD<8AsXA5({g<@dk9HCC(JxBB_06?MG4i zsQ#ep=&Rl+{Q#Bz z`FNFeK6TxRJNxdXIF$+}+_J-?IZdqyHxkK(?G6e>rh4@xpHz4Ldh!oedPvJnA;#`C zINeYgYe`Nz8-r-f#Wp$dyAD1pBdkx>p_fll4B@5iq!W*{wrcMJ&Mxj*=uzqA-SjI=`8L*$!Z6y87RtYvhrwG>;_~VRBGu zK=XAp68)7g5lsQ})9kIKfdh&zw$6>@YdM2K!2^N;5e}7u_# z|E7K`>L@%wvE<5sRS(+p)`6|UOM>v_R=8=?F@`_aS5`mkMJ$UK{?Us#ynFDpUx!1O zSGJ(eI|@zEx3elj`)2GD2hMBB;eQ;*1Q1RDF(B*BWsfktW$j;HAWVTpz^sb66DF+q$^mGI?ogxt~zx zc_uFl8se=5U*y5HAh~r=HfC^7j3KM>B8F$#c3jw{m1o*- zx_uE}C-kDoHAD%CpC}jXqAR^{+Hl2Vhh*pUdF~!M&2Cc|X||7kM?1Wm;g~fuBy-SV zwd<1>epH+b(aqEJu}R_QL=w8>!fRP*N+lOR3l`rXV_*~>&f{k(=#yJYs>}C}i>zp{w)cYr>o4>TpdU#UcD+NT=ULpAMDAiYVO!>g%^`_R z(xb_)J199|`ZKSlKNX}!-vXogN_pbl@h5=aZlE{QA0Kf(HT{9Uy8is+f$_DuAqay9 z-;SYhakKV;T&`v-?-I)Q1`Hx&>GVLd%k4s5&QsGt0?|BpU3hN8e&0D~tuCy-e?2v`b|_6ZaZmFP7dGmYTip0{ zTt;#k_l7U!?6Z$wdl%yOFO^J4z1)Z+BjlTH7QN6DS~yE6pIW$r4Jy1f^{u^+bw-Y5 zu5~-QR(H`W8WZB_K$toxkB3Ykp>ChA0vwM4z6*^c9lda4#KxJpPA27=gnQJL7{8CV zZ% za(ER=#(^{5f=2k8mfh;#m*F5)FW0FWb-fK?=J43#6j( zYJZM^$x>|9LM~H41YJG?k^zz_08$b(?}5!a0?sU7u{c>i-S1~LpDP%CZOkvZ)ahc? z{^{JB47XS5eSN)r-k9J0=V16%b7w&{=^d-wZ%paFtJ{N~djlJ_ioe;EH=r>OL<$;Y zNi%_o!0zv!5%l9J{mB{qovQiMbgAejPeEeG6XBTWWl`9p#&~qL^%Myw4LaHT%d@x? zPHSkGG$Y}o#vJ#|le2V0Ud`+olv1*1tgJSqajB0=Ts&*K%wFCpq?vmHZ6#$$jMPrA z4y~E;!@i$FUp5~2o}0E4d8MbL)7$3Mt)zXtv>%4)m;x zE9MeKi6Hp%W;rm&Mu8&8EJdE9gw~c=_GWE7qe9A%Nor%LY>$HO((L!U{prAA_0`vq zL;v*i4NV04P2-PMDqdPm$B+7wZ=T@8zOS*1@YM+q9-%5e|B)5m-_s)4F(PMZT-lri z6vhemG2f5Mt()&%V+i(#6W(C(_YvA9Y=7oMSw+9M!pq+8xcu#odrKA(Q(11LM}%p2 z1DvjVmzSu@=Bhdimj8m{KKmE$xV2mz*)nkoe?%};xjsNf1^G@SP}7lqS=KXYPo5<6 z&i(9VCz0G((V3(-34aP;&ZMlHwzC7_q9S2)5f2S<*z^YrQsCN(pEhmtiQCCzN}U{8 z;ELJ59@0xJJM&z6=_c!W;bO@SO4=Pc~YI-&DgPTs* zAdq^=ziv#sY>-13nOHMQ=Ka!#vy^0$5+v%#&{GDLv@Ueqbn}i0OJWy1_QMm)U7t(5 z9K?d7KC~S{r;fcVwY@rRlXN$hj-})(c635I3;!4pdCRZ_>o3@7A8%m)rJuUfP~<-V z<3HNL2SEPy#^0;x;TW;NBu3&iiZcsTGWe2C(gaK|f6*9@lQ=zwktG<9_xsC)- zC;%CP1QlW+3y`h$Hpqw3`RC#WBnc|u3#Kj@R<7ba%v#l6vb>xCB0RueZ`CwNSC9i# zw;V|QQ@;YtWdn4TBUs?Ne3S1f|D9l)k zJhSl|;w-N=`6~`3I6kPA7Xr1LW1C@4o7JNI!5LFfa5o)E<^7WIN+xDT5{8`6gXAp zen4NvuEo^g-aanR8LoqAEpRmea}OpEBTD2YOOS(?;jnKFPTN+*G54Zy>QYQ=4Cg$` z?1vbHBzQ2gha8axFkE?ZJ1i?pyIh0b;QbG}U-8W~`0FbApK|9wmlPIx{e^QjViEzLc;h%J^6Wp^qn9Yrqi$(MBWq2=Ue%OD*JDgWHgOL^ zs(6^1vO#3Elf@+2Z=T$ylixEB?wqnJ7-T^itGQfKCLMoU_B)fU5UhYPep^T94U z+DhRU8mc^<%IAHEW4)z5@xeN2=coLT0^wwd_5ONrHKDyan9J0p-rgISJV>7rNVQ%duDOBU5D zM{@j~eL^bFa3?~^Trs5SEG-^=d^6~Z)fe>lEUfRdjoR+%d6d$#rbgYvtZ>VuuL%RY zvyp8fXUdK9U6tFa578~Y-HS1YA@wP!XxgI1teFq7CGGCiy}s);XSG5IYaF8&a-YzZ zibJy&xXqSZV(l(d%QKP80bTlWaE+4^p!*$R+7zkR=mF z86c6n{8=!cA_x+rNg6?Mnp&Rtv^>1_pcfEcQea^9o&eND^0mT>fWk0Cf_cFu8(jeP z7dp8V4iI+1-wazFdKUb~KvKM0s%KY0}OK#2mX7&@|IXF=!;)j?GXT~m!M$D ziy66e2}5s;2QUd4^$$(lSN^59s!GdRqy+1_ll_3(OMd#ryAJy5yB7f;vgy0F@RBmG z8S|I6Fn9X#jG@1K%0Hel^mkABM|1h#q|`$5R7ls5F&S0y8&53()PwEYfhsoT*@fqE zhBC?!b!wVwD=deTR_$9RpR0abRb$$5Pm!%i^m%@;`_@BmE!4^8 z#bv{d{-o#O(H+9D$K$DcG^iXp+`-Fk?Di>N7)m^D>&&`cd-3L@E$7cJa@Tta;;Nf? z7Y~RXAdizDPO=Rq0(CCel4*uX~qDW`3{35r4jkhWZe^uPJo~QfmAAY?v3vSGhz0 zFd3oe;<_97UcX7Kk>ti_0`w5~D+PKjU#q`PFNWYk);#I zhXN^C!^%goJY*sD6 zi3>aSNwT^_*Md=O;&|S%-jp2+d%7G?&Nn1T+x3``3dWvy6W6JP^#$BP(t%==H zuDD(CGg|xibao{8l^(IjlzOlHCiO4ISwg4kW@&|!*_nrs=VNR!wqimTd1{lLq~+}- zyz&!mcKQ7hy9i>uh$Un}f|F99#{RaUA5A2_#vtLV<%+%jZYnME{C}QK|NWi(kW&A} z4!$$mLkNmS=>=gam|g%FUBDI$ilN9#5~CQ5hM7;9VLnV zePeqi38*43Su^?zae#Geya3_=z(FrxZRb}B!exI;dQ8CUxEKj4(R8sw`HIlL?8zc4 zBaJ};)-KSEtfqYnnl5>Bk^`1Kx*F($&h9#Bmaa^8aJ&Q<=q9Vb%yJ&+I!3lYc%FiD zTJn9cIrTfxHDx9HL% z`&QMtJHfHa=78JhX3xPKXDw0f8P?iyuJXboH(0UTJ$)e(@91fYYUv7VP*yrShCkZF zo>UbX-=;kM}vaE*&2?T z6TMgb!MHl~4O!{?TXi(gz z9p|T;?jrV;&zG*8k#TQW@zSmOmj`C|G|><*LOZ zU7b49C=SQaOy^p8^ydkarMjN@uTXW1UGe(Pu0v+u`gtF(ftjN7<#jt% z$KhY^^j%{6w!L(I^!eL*D)#yLcK>Ms|KE9>k2U@`$M|-EUlw+RrYVZ15Cp>zf?1Yx zn1%_0U=V~xF#@MCOuZ2{4H5EgPRpo^O%m0!aW~(#UvXBGFq5%|uq>cn>9n=ceG2P?n0jlf1I~74`R2|E#?t3U9whKy%@cT=UUDj}Of^E8~4x8O>*= zv@ZyVpyxdMm67T#=?4GBCOr1w)(b=*4A&rO=X|W$((?G3^=1n#OXipHo+YO$KQ;)K z|Hl5%7Vb}$C5r6={>)nm6*57&)DtJOW@l4y-lmA>FV7LCCxH^`j}1&94fwV4yDZkq zmm_-L)K(|MwNYj)4%#I~kFd%g>z&I2Cv?Pc)lp?50eYkGwtF`)eaGeG6bl}){89A< zkC|77294oXqxQv>h52~@0a_lkE*cO&d!6LmXMQI?mQ$f`>!|=rK()Uwcr&xwoiPWD zfc^HGOq`}{=4eOh@rFKesPln1;OLdY$|N~8g69nU7x30ewD-< zf~GYk9xd`D%AZo8;JYY&y)Bp+upP!OZ8*)rYt}K3Ms5W*ie)R?{ZI z@PR!}@s1g3XS$WoRLBXq$*^Z5sPhr^(qk9hC8)EXgX4+X>#nlsHh-P9A>{@~J!1^o$$gE-3oI2^Q@3aYIt!v z($I51n0KBVY-*?s<t5?-+lO(zWbHxGW1b^#UOm^9CzmXlQsW-KoTNhn z9nHXIsq}Q*S)F-3J65F}W$_t0@@d|et(U9r>|7+dt$3_jP7f~(8y_Ag;&s}yaeRWL z8fWq8)tYB9IyaM>-&yC3Qr&Wu>hOl6KJ9PvXd@?X8~Ie2JpYz9KPFM1zvWAc^#1a9@R5=E#_mC}>7 zAGhEMk*-8h6p%ZS)j=|+SJ)x{jnW_yD)R+uK1D@Plq|qx?ElYj#1Z&C3I*f$sctB&oS%J5O#zx;apsgA8+ z|EOadyGwuyXmx9oOki6vk=vmN88|r@ljyzGV3yyg!GH9_P~r$!rjP&_H9`bhdC0O< zjpmyo`j5|z<_|1Wr&T9$iSD5fA93Dy&Pj+6Ddt?VS#;jn6(T#1>U*Bhr=9rIv<37R zRX#P@D;hE+v#I!9b)@ctPF)X{*inw8M1_1Rxfq9RUTGqYNM7>(IO%fOJn1M6n;LhA z6T@I9^R#g|s#WKax)*75CuT>_*s49xFGZgE7gX8V-qP3@o|Mh;=DpwmFO*AaR`P6F zv+NDeT?OyDKV&7-x)3il@TYWyX0E&k$o6ust`WZg)q$9vm{`|G`yPbX zgzU*l#mDZ&Z0#4;;_&l0;Rjz!=L$d7Fls{x2ESz8&~^E`t!vsBqoxx2%pW||=hYI^ z94feXEKAAsb;k#fU5!W4l(qYr5LGTkA?;qZw<_2TR$l9S%aB@gbJ*Vhu| zYrF1f8%5JAsD0fY&!}9G+dV66cP(OG17b)vi4ZYmhnJpud%`w-gwlX){cdlG&-%F= zE>Cg>j80v7&G(JkJ(I{KwuquKm?s>SW@6=N+#}2FSj`;ONqq*DSwaYWYn(mnM4}lP zN1oR{^dWD8v8Mdn5{lGF(?0f`i%b_9QCh(sBj%ckHXq#|4@e1*+=aXxNXfc#j4CsO z?{n3|VKM)nDmx^K!{w|Wgiw?ShIl6SNF$_b)E3>hqf3s^0NdTjr|b>!$G(0B=II=B zdnZ$#+r6%rTX>HuHm3xlYf-Mj9t_4 zd>HcE>jO>?kBt}Wf5)_vf29lNtW42wvo-6R7uK=RA93u@H~WHZpKkJ9$&bbe3dT^1 z#tDX`(Iq*=X&fUzukxW_FcMFI5yt{DB(oY(t<9<>nF9{V80b_1@pfS5{43`y90T35 zbY;*0A`1;@D+{av@(l$txaA07sFMWgBANn54z^@=zfyr((l$5&=^P9L3|&%Fkd&@^ zq<~h#0D=tAbx(k76-fa)EWA=#(;Sdumy@RuaLDB&EawN z9^TRw=p$eGI$@zs=EvZq^lk?7{c~TAzLp99lcR%!L+jE12I*vDoam?H*zs|{rA?E7 zD1QGMrkhfq50ltiot&I)bcreBgOlVl;gms&V!VYS7E*?~ha>Rj>~37V z`i3=SiUcsRRZl(5WY>JJoWrY1^#~8B^^%!sb{rqF2-lxjx-6UVbb5v63`qlf5#a9P z?)mw8%kNW?jh4^lx4U;bxUokYc&3iW<8|5oQ8_2u8cR#zFtLiK%gjd5!S(x#{e^VW zE@}7avj*0$`d85R3>6pUmAhHomy}R^$w93ZGdVntE;0r)yZs=YSOTc@x|MNdN9cGW zzK~9UBbsp{#yr&SNoWk;@kH053Z~A%|CLp?W9?@_KRRJadZZR3Le9If^3*sqT55kq zNl8C&htJ|j=$%L!QscQkOODmXrM6M~WLfO}^T@UgM|)SQsE@(%GS>Wna^X%d_Szgt z$wo11D7@x0SMC|LzFV-Jis&30+2~qC%AN@0FzeSttZppaYtGdL#d%GmPm!EcrwMuS znLj}Xt0j7zQ}zjZ_)&KLa1@%{Lgkrx_ z-}RF|?@4_NeE*G|eZb*w-}@~xqBKL0FikI@NMQs*GbBO47)&gy9kD!tQY4I1pUz|; zYuW{`x&pwjYBg~LSds&!1d!ShAgKcd)b!u!=e5!Wrxw_PSD7WM0PU{j?iSz=|QWUKS@vik*&GvLtm3z*Dckf<)3fdLT=q=z8gTV)%8{9*}Y637)Jmj?@2 zE?}P*?>ty+ZIvxK-~#Q$+DIElTrN0K=FfFte2Sitxi~tiH#nSw9C&qDpr9U+~W{5)>j{`WdWODDCY5LSF`8$ zBC4T=f$hT07dNZlF-D=4GAf8KP-uN)o8)ih&L5sLB>V@_MCV|*#t5nQdltZ5ghUA* zF?z%zm-FLrYQeGyrWp0pveGF|qu1iq;NN>$<9Lh%PKR9gi~ZLxWdPm@pr1-^L*II( zd`NENuD_?wSb7pnB&N|p!C=zs&>VizK8>32YZQ-3U0#n8t3d86PI=$Ft1)qXnZCe; z+@+@HQGM7YvCXe)En_-&c;S1TO`84oh#us@xp5bG8q}UWLZ@1JwV12%j@l_2wL_iV zsrBZB42vzl;~Jca`2jvW+pUK(d4ae`pAQu@3dNy%8rYKD$7jz#_D)o`B$DU&ojA|T z$jkE)FAn6T<;)h4%H9lqCz@D@Q6?o4wr#kGUOsysYT+thm<_ zKl+^~UAl72?M!YtmkY9}Cs=te(b6@`i;cT|_)w@I8_}~S`OEMM65nQBbT<0r+}h||Ty7LMakv<6 zk2PJ8!pl!`{?;nmk?V5$c-))AU=tY6@?tohN%|1G2aWS6HvvYH+2|rG+*Y^2j zj)|W4GBw~{gjwq}6FT4$ zHP`07XXN6^LpsqUV_Odz&;OF}xqu{d!o5@_5Eiuj#)pL$?H*^K! z+nA=>0T;9bAxnGia-1XaS4`REhsLLt;3EyUzXaN&lsV|}Y*CfB5Dn#EM83wRMBG_v zANSi`cXw^Yk(Nc!+lVjo(7mrNqb@BR7w6xVk6bLed;=MKIXQ z@LXu*hzhqulHN=suRC#X9vZA^z5wp3;W=BHAqur4$zY|c|Qy%Id7wXswp?k1Nlq2c5 zQW>R@BwcT?{8;EN->N%_xY6=$$-*8!2c1y^Q~gPtw87~d(aMNXt`Yljc^wN!=#=0D zW6vlMTT3+D*DD)|on*?2E>Ne`ZA=&1);3wD^<|e&=ryax4d+ai5fx^0gw;mMmKf?R zE3$4!tw>-*6p|;rcJ`MGIt$JQogw*xoNi}y$q(ED3mSVQu^ex(+Q<(IW!10yo^+LC zw3DB6OmC}xxOW>Rb?&joZ5hiGp^(Y2TccW7Vkar~QUk*e(}zSRJcU~~+Pnxa&B9K- z*I5F`i)xHxud3U~ZfVnk%>-X@LuUeBlE4Ubse^}J8{y$*n?W(c~ zLb5N99n13m#k1dsbH91#N38baOW#|6qX>+m6pAwl@oBpnS^LRL$OH5+8NlZ$GcY2P zzD=dRP5-2TQwy5R)Tbd>nY?>^Vyf<5M3haR- z!QSu!^aya^e)8K&g#|*e)0e`$tg?|L^(_B+QU3lzHM7!`g z-y32_pgb;_ngipN-!S`NiLfC1%is+t(A$$a13k#Mrtvxk`^|Gd9vvJU`cIAyBp;wZ zcGT9h`Ej6B&A(bh{(yJf;~Egc8G>Eii}jn=Y-<0e#z$MeQ~`SQk0MGZt<7`gw(N-W z_1415@?#Qq%J#W=J;|a}lv~N#kpFV+6PjvQ^>n)-*P6Au&7(;lA!brKSMXIpob;W@ z$En3k?wu{~9?j0?K`5}(=1%00lSlaMh3NgR*u5(4t`GOc24h|$n|RXYVTlEgB*CiH zS(uHTDG(QaL2>`=7D$SajSX2WwW;AL?cnrkm*L1Oo&c-WJoNJ+H@Df*lmwyoiL)E9 zJL`hKM*ObVU0$ohLpqL6NIR=G{xI8?J&U76VTa&}ijS+}4mr^??P>44JfpcIvu4o@92b7U)b)@yBV)U+?In{fXAfF~N%@Gw zy!a}z2r_z`c4d6u!%v@?D6hfeCeZRaYlR@lwxp^V{Q2?}RKm2RHbBn`N2D2iRA~CC zr(+D^cr|ULCaIP$u_a@8LIp9Tr$c?ykgap)`Fw~|Z099qHre@-eCr$KeuKlJ?5>1P zs*si=N9|=~gC{DSkihbVXU>W<`D!~nIj z>^Y-^y-gFfe{r9NHG9t0*t8?%)sR6DwKo*yv4H>BJ*GQcHyAzp8_>& zpnwDl9cw25l#!|Q zk@zhXZoxdvBl%j5NTx^2b+5u7IObGb#;MvXKe>6|-~LI58DCll24;8*AbaX;dJSR)XHYdO=6-ux#L*-HokLmwPo{oAW8aW5c?m-Wr>=*kteTxI3&IGD5Md^&Vmq$jOG_n@3x%$6y4V;QP>?jX&EmEJ?gQSi{Y}J z-$BQF(w<6zL~ystcFbPBWLvKBf>$xTLQAK}Z zdJ?~PMfpUBjen@x%Vm>467|JoH$u7E2c8PlN`;`;>5eNsipGe zdLA+Kc+8lRsL!EBjYQG9$KCE!>_ruSECGwiUZ_M+@>XbU6Kb9qbDtt~a}-S_8Z8cQ zue%_{vZt3z@r0RSe7H`ghpH538;659#YuKAmW)pki<>M!Y$*kXDe7Mgs0 z4v&ef*=2#0URVAgNI9sUFR?|Mo2|5A9QJ;=UK1Xbq5Gvd;hA`wh#9Am&AB@2H`x(~ z|I}&X-QV&@pNDr0rv9sT692Vh{k3PrPY#?EvH&=S!X$;#D1jp|ygVima>;TRd|$wR z$#h}z(~dm;E_eurQ1Lad%t6*%Fi3BgWIQ2Pi7DjW)M>$Yz;i3X z9~yY01G-tc`hX(qP%Bk}Ss{W1u)c%}1Ov7$-hzQYn7aXsc7=X5jwr|OV0NNMH;h&z zhmNEU!Dn+f!e?T_e{CA^llKGk=5vt!Bku=IU{7CwO~(Gx=b&2gtA070*MMRsAFAOUW(N za&tN+TZk*t@;qvL!7gQ1l9%OBb9Hyu*mW;%&)e%OlQ)QnZF}rm;5Uixu4sR(+WE*R zefKa)=#pF>8|pe|2G^fG3UpI{qFwn%-rlRHS*R}P*oUsn~W@1I=+(OF`%V_c~dYhpMq5Z9V?E-9~4Risy0JiQ$^lhCI#$ddkFS9_?Smi*1X#CPn{mQJ;RjAY%XA%!mGOgTVjH zx%?g^zRLg+lv?6MgrH!81PTZYvkvYo-~d!}8D_x^oT5HW0hg5(Nr8^+vcA%*7=E^@ z+GgaxDe~VX3ZBQ8)t3U99rihIt3<#`4YIu)?5tow;SZxv|PuC%2f_2DZr`^q;qpn9|dL3Y?WZh-doYj;TIT5 z-@4JOwKN#pS+#ZX-%28gJCFiSyDumavGQSnlb*b}a5u!dzAfy{uTsFlOBHpG2pDBFA(!}I7b(!pCxHj33R-{ zzk^v7olD-e^D0&ID{NZw%3osBx6lOr6Kwhhnr7(l5Z~@My4Uy56qTNNq1@BH&pW8f z?whCbdeCIlcePt5f;3rzc_Q}a6!+b94a52pJ%bu$hdrzt*Y5rr`Ms`-N=}$t8j9li zlu_!bbtFNSw&HMP4k>$pQY=zqtOSC!DoIpM8l*_d|MZG1=h$o&SN4m#EVp?&pkB#3z)*m_*{tAYn z4;;RQuWKvw8C7`OO^xqzeyG`PfrjZ%p2zx^Ng(dRLZ}wBH@0(6Swt|L&|Yn#^AQBc zp68}XpS>d~<#dc-{=r{#q3kTbp0B{hW3{2)Bs(B5PG#drmSv*3XBD)-mB zaj}oj(t>B!n4Q#)PTS-)w6|CNygv`ZwM(r6NgvQa*LqAVTF;%MC1?{|dp|`iVb6Xl z(O6C}R21MsoleW|$_;JB=V8Upq(!}YCT;p)Sahqai)!y#<1zN+c>Z4 zVIBEQxv*UC?FVN}sLOP@UZUI6rO5DwQg~@V9rfH=MI1)CvAfVt=E)qz9kQ;tZ6gj* z@6j_KBc>sqGM$ZmpXI0SIp6(z%sRzMh?k#p?yz#F!e&h)Y(m~6lKu10;_sAJ(Z49` zQvU;G<^R_4|4CW-yUde@0q2`sa!(AS5tsz}56BWlz%)f56oZopgW{j+D83m1=k&^9 z%K@tm%K=So$r`bBo)@_B!k`OFEnz_Nxe9;2iWK5NAOcwZVjv)(^0n{_1FjsgN*EFd zpo0S`L=u#*7mQDTMREhDl&&LA_^J|tfnn3~0M9;Rdq2eQDdn+kptKPr&T}gR~X2b>Iel970 z9sl}=C1rs8(2|z^=aDiH2u+R_1g=j_X!ZgmXXxq7YmvXSjhqFQQa z6lI?q*iEHS5XT*Vm=6J3KlG%922CGQ{#B9;BAgPHcHxtwEPK?3Z5Z(+qyDDM3Vl{* z{hnqOlxC1SL3wZQS6E2Oky~==jTjsPgFVX-&%b?kph?K08EeQkZ^&*KCh3{aN&WG> zBqy~V6+-cxYyEPYk&m{+{V><5-pC$wwW+Sp$4Sw5)n%%(qEHmGQb(&zo?Y+Undd{m zg}uj1n`3WiX%DC2aDO;lXPvmm5|}N}dafMZeo;5OsUB#5Nv<5b+5LU%I=??Xi`)HU z-saarJb%{(j{c9`>i+LIwVw>?{_M2A!y(YdBq*H1aG1sk8etX`A~A|UNgRhUghEOB zbFwwPI>rIHcmyPXcn$;~mTZyE)^g=4Hi6)PjSZ@d%;y65B!Gh@W5o!-s#(B-LV+y( zva{vygaD<<T(}$bT0ATe4>C_qpu@%p{TWS78e7CdRzH zBx|A|+@6hiyh+MWWb60b_W7Aj?Ei!(-IBKbLr=P|dEko!%fIJuR4o3C z?)_uJ`-^;+`6S;xKnCZ3B)nG81+OGnZM8nq(QgcG@1FF{1y!Xt*nw1$XmcfBPU${b zHH&{idiR^&vGnsd@d0+wU!ffs-1*W!MZP_H@JJ5JzkBoRXxSeS&Ogn8q0f@w2^F!! zP2@~-I3ZJ*ZjobB^G1zyyw&7|-Ki!?v{h`Wvjj1ZpgE>XQdK^OXWA#T53_?&4H+;+1k2%6sFa9jkk&KnhA4r9_9SB#H2W+XtIltyp`bD2NDU zDgF+J-pJ2=cg$|Z$YMn!&V?n;_|vfEexpFTPN7Vh^Y|m&9?_k47&#rI4>_R(qS1(? z(o2sdyX(0hsc?34cf`S-w-3UWho+Wt6WVfyQ$*fyXg$=_Xq7DuTeG8sJKQGaaOo1_ zSjAT_rWo~6J(ZCf`>SI#LGn+siWxhtO^W&qG1dG5-v%=32{FqXMdG`QtPK9Ev=mhK}IdfdT~{E!dZAqw+W zNApWuvp`RCqVy*{7$0ZF=pzM=Ge!PvDSMxJcAqs4 z-PwJo%Q;184i?eV!`ruvP+{3iZ;;1wUqst;v*}(!Ef%?j?&t2=qQ)h3?uUZDY1a*O zFYHOp60Qy6M7SwDqRU;F%u_@^aF0XcMqE}^E;=j7^&##boG(;HYRuC<+auA&nj!q9 zXqwPpwocGFPdgQJ&df-Yah?rBCC4%vylKC!t6a)%vW9YlVV}{9d$=5g+l@mv5H~3! zl0S1Inn%RjjnyVT;OEWud6lov8P12?#>t@=55i@i)SLY%$4dfzyP%03GOFT0tz%nd zh6bkDyEVqm)!~tqH#Ca!qjV%r_EbD%!-$aQR@jb6s8;av$;GOil{>uCEDWLyl#fag zCz{Qn<1b15cO;7c1NU0|9|SPe{{bi9|Ly1bUvL7(zm2*`48bul?v2w3fe|oCk_3hz z3{4Qg1DGap7$%UKpT3*T5DYAT3 zVT4goI9LKUdbL1cau8!>C1_ZnIgmci7@$Z(f}Zv-qArpFjp}@zMh9Wjs?L(FHhu^O z`XAY<#R6Iu88|k+ve}ln3Q*P<8;g6jwUCl~PjTlnV}5L`d#;{yJ*RHfSo{e||2OVf?`a4?U>O;ed|rF4+&pBafY z^-ah2s@VyruqOi}No0u#cAZyn&%|`=#~=z*yN~%L`0Fb}mgidwa~JGcK&8F|UGXEU zCJ*$?P_Wt!o`b|)BTrAUU@?t2joa>*&bZKD@xA`U85jD@8u#xw<3gWVT^>Xf>YWOVD*EQW*i|k?*S`6>G>oZ^+S6;HoZ?&Uk^uJcRE`+B`c> zL4Z~^3|L>UC9bHwK2)zPj>Rsz`Yx#g+ z$e!O36LhQB(@h%c`$=2YCK1;zi;jcq2{Y+!25~kWPC%U^~q^v?nm1} zq}&$%wDkTz{%l$BfB9;@^E>ztuH?tGJcgq1uEYZ2(5H=GA@+93Bi;g*$Q$Y2O8 z?ym%wH*m(GU0@}A512>qHZkPw^0%!OgL@Bp1it||-sjjMYHvo^JGP;>^AWWpbo3r= z+OBCAZhrT)p>HQZiu~KOhp?wTrf-d3qG|I3M$`Idt)E+r)O;VgZ*h_=-K;-!zL;I- ztGSi#ovA`Z|GvDha(i&jFOv%osR?_aQt$|%a`wl>_VXqR&zb06GY)~#aLIzE>U~Ej zXF}^GHv6>14SdwN&$~<+r+%o74ZB%^B~pdIGE7(t&)B3}9bU2!QBwn^29GUMV{i;0 z`qQg^Q)OP%g5R*zo-drVe6dZ~kL`jnUyp4#3Usd@Q$MC)e({(K#Ils{-hKTp@3)zrd2Mj-+6$2QXbMEVllVX=?|**PeGFgySWgWYaHF9riprbr=}Zq11JxqS5r@iS z&iWAa>W>dMVMVjZ5%1O;C~+3)XSUwk$Ae6k+7JOriRR?>icRh5*hGj$2i-@9(8*5z z-B}NWXgI<_tOd%en@1vn9bUs-dL;wYrEaGM1{itl4>l9goOM#V3Tk3UqVY~U&{tD$ z0$SYtk;HbkDu6T~i)e_^Gkg%n&d82&;fi9XJSc ze_ggek4GY#orgD*w$7$A!%K`Gdss~}xnN{KFo~FWhR%J0Gdg>*mE#B{EZLf{RHm+^ zP|j&Ni8$(7MV}^J-ddyYju+bttqiMS7C5kE6)I9D55j622USroe5q=FLG)MZ993QX zbirg0hSGxsQ+ovHtxzRyhCDPm8!r|Jwu^Ocu{M?ZJ=}A9Z^8QyA`exDlw~PGfLb(42 zeQHuqgnQB-d<&dm!Ct>6qW5esxVN=!F(&qomr;1fN%HgZ_y&P{e>A)oCn#udb=&ni z(YLS}u}fHo@9E<$#@zuj*r7XmN6pZ$q|)}{M);PxM&D+-Zz~1jtpu|H>=w>%c)L*s zy|+7Bc=ldM`ViXt@Cay&`u|n~X5Gu<#J83^o|bc` z_>*YDUWQ=&pR(!~z~cB=W#$jfmz#|knS0k$PrR*rvV8w{3!I+YzfaX1=JQwaGLDt4 z4H&b%r?`B(32dR*1}%f@V5R4vKR0!)f6POvtM*3CbkU%8mloZN0oy@qZ?;yKT}#dR zsS(gB=jBw;;RjO?ZW`!10w{^b2Jrb7Q98yJiY{4D8&y#7y~>s!K%f8BE$wZ2z>lrp z`!x5jMwg^7qf6;Ny0pF7>dnL8jki4tOlcGc?PXNKu8p@o#;71{jF*&q51rD>fu~Ke zzrs&m)ECivWO~Ivz#ONUQ76p~cwX!zx5s931c^8zCMvQL7L=~b7F@JG$AOC<8ikdP z*@?Gva=s||SA)4^5ZzNDQ6ilbajmx7&dh9} z6clx#WR;6OITxgTVjIAWph0BjhRnzIqQaiG3fFsL=K|Z+MTSE_-l5FZ^2g6I4m&a=r*9qiobSx0J>r{1N zF${@61F?pkUzKw_MR#w6f{8o@M;57}o+r$9SC*V@${c6w;#)GaP0 zq4_w#;L&plNxR$bzAP*^P449B20!i$0k-*>-1G}u3g!!aFlpX=F|x{s zA|u$5MAP&2MN>?g_Ds6#E`}^^xXVXq4=6~4L@PFLJal@;_u{SdSnL_F)EvOeM#Za* zdQ$6N15@tI#wx2KHlcmy;_|g?@Gn{N78MJ{!gA@Uq{il zMc7uiyXM@TnY3b_Xq33at0c%-y0JILAXb=?PfsZ;CTvtz6JR|bqXxE@U|Njb*|4gU z8N2lBfI-sqT$qg@B}p04r^^jz)yE@8oKa9M78hMIO*ibr@|bm&qUK=2vpM{%XKAucpB5GgvWZtCpZ7WoXMO|b<(a@ov&d>=Os*L_0#~ za4=_MM@Wt$V|ErpyS>0fjhvflj>J5ilalRR1vuaci{=hLj7T}%F)xs(nbeAAoi^h6 z$_{xzsE1d1cP(m#Uk?KoZALWU(LNh@wpkQll9wf1JHa+;;Uy82fk$9vY`=s)brA@m zlZW#o7NTIW;Rf?iLBOo@P#sd!$TjU!)m zXPFIst<$m6)(s?wt!?XELlr>|0t>hVvqfa~7^9DHn(q(qX1}OcsV`>wknU}e4|;j9 z$lEHnH|cu2xm_>@o~BP1^AVpB4_N1}%5blqLz8Kd5O)|0hWof&_&ImmvoZef+e$FF7c@X>&wD`F z+f54H8$IA;XK)C*OV9@JJ_8Z#L~#4!7u+p*_djl|4MDzIv4C$Cnh@OSWQgy19}s@m zO7NWrZoD#n%k=JYywF=B7koECzU{dpa%XTGnS{WdMh5WT7B|$LPGsNo`&jz$xwNhE za|(eU7U0KL#%v1es1IPQkpyPib1Pdg7=QF52;iR{Pl4|^+VYj3y;RQL(*nDq`=Wi3 zy8So?YL>L_&4nLV1AKou|H;(=-(SuTSMv`i0DwK8&|gV(d{#AGHbvW8S$VDK0%|IEN)kgL0d9}`tWGZl`7=>;hz znV!=;iH=v{G?>0!yRj({1yB1|sVg$TbJ5^#YW0Q4E44aF+2fHtJnR^C7TeV;q9@#K zrCk&obrqdd!V)39P)$xIc`Fl23TT=eIF2cMFCKb4Fs#-ngI^*cLFzQJsO}9S>sT!u zwyBWm7*8YOW1arw1qjsf`j`O^%r@>YNVd?TrO>nvOMOnILCHS+mREO{xj*L9O0K*@1uSjrbpn8`zt5P<0Nwj$i;SceUC_T;0nTHf7{_52u0_3B$k*%z#O z38S#L<7_<11r3`$*t#+Sg%ty|xynRbcFX4jrqppR(K-TmvjQ$*hDwKfY#CF=r|kBb z4Y0!C8%&rfiHS4*%AO;60Qk(>2s=FRG8<UFY)98juN&eH$AKe8=RB<`ri8GqvRN>+=HUcd`BA}*)_W09URfdPCpMLF zT!lC;DlaFO0oRR70(3oj&c7KPG~@8u$M2%|zL&E!v~T{h-}%jNpJ(L1)YE^?68z`O ze9IC1d5IrDq7;w_ts?xH0Wyl=ZCxLXq@@E**^=#C}(=o-9Nu3`N1CdFV+g;U91 zwNA*r%uXPCm`;UnTgB*WrXhg#h zyT%=CsCO&Y*vF%7_*O)Bx%yi9 zeRsTVA@*K({xbGv?OlNBtZ_E1ac|Mrbw37te^3?DAN9)0PX8_kapqU~?B1DdFYbP% z{(;ZN+x{p{&$IZ=uS&B#M}xxp_O(fGAJ8*)MK%5(!_U5#9q;j@Ggh6kCdHD67m!1( zZTMDGGJ%0Wi76RuDIAfc*S4_qULbN7_-UxgxJ4Cu>s+O0_!Ot}jSVDWw2e!I^XcR_tCe;XV4o3)(ILSC zz2#`82m3hiFpJzh13HVx{(2$kr7mvIRT@NaW(~5_CC^?Ljdtm{ZE}EAL(U10yCZR< z_Sd@RS#b%$hHob|CUJzfmfWSo;+l_i(3v#r!0-T5Nbs^H`?>)_M%st`#{sk-veV8n z(=6g#WuuORlTg$T_P{3IeWcKLFCOrxX1uSRdw*)&`-K%1K%d#{!g#gvh@8_ZhRoDP zL{R37mDVtiU5T@Hj3Z2xeDM^aT+ z=v-{4o9y9t5L(I1T$=-P9IGBYhFf%UPY#y^1G;OsR;Xcd{#{qI%!sPe4(MY~2nV`2 z-MEyz2=$dxn;g`zQ_Phh4pnKaoS92dFtrBgW+dwuBF1u!zeH;$jXq8vrGE}lY999O z5Qo3T|I>VJ@X&sXI$#i_HkkQ#!meHZ6EOYjCx5`vUqA5&WI{m*B_Nm}aEQVP5=Dtm zC%ZNrL8-UnJhH2Tpy(b`kjQ&(irg#1#9MX?fA>iRpZ9icm=V40eD@))@V!{_HVy&b z(1PsaUc}pWYKxMncauK&9vma%Uw{>|g*?gL+rO>2cjWtfOFSIzm$BiP|3=O@+!N;E zTa7b*+mdWoNaA}8=D&?a;`f}{?m8L0`_$gkVmp%leQBB9v#rzl4^t~uKIpS?FMcImyJ&&$E>ETnSN9#P4nU?-?i#*hO0Z&W^atX>s^u=bQzNz)tYsFUEz)cnr4n>g-Qhy(DBaK3i{r-Gi_iSC*wdGpnMbJ8A=oL~mq=JLyi0wi1)w&fZ{U z$F$MW6CT#MdPoklV7Cf=rn{wqnsK?=^W`4Tk#xiw0?^R5T!coo8Kx*6k524aUTg#G zPCOS|#7j``Rp>4pw$(QDzga;pC+j-Z&}oVKF<^l$lBpQ|yvXyy7CWW}(*?CR z>DzB!`1OOO)EV@vwC#R%GN@y*GTzkznGfr6rj9e%R-VeQ%F%z_YgEU$xl@RVe3BVZ zD=!-oK#_W4EWt5Ddwz85Bu@F%9$7?tT%YYzKcPuq8Ce_;PnJvW(($4;1R4#oSOQV> zOwmfWhoBA5zV1@l8E-S)MqfO%^4xJe&_Yxt%t>h0gK{hh^OoNwYfc(883+Oc#+5f- z+dF-0*oK#-SbUkx=>do0pz_xX$hwgmGn1BF+GIT+1tB}wRIi;*H`JtjoCpE;+>x>Sclk-puro9H{=4bcMJ2|g>e_4_V++7e5-uzV$`2Ect!X= z(fnl!ZI2qkeXe;!#cgdAd;1FdXTj7i)P;Z1#z%UP zEx$Tl3EGZ8=ywmQKRmcS_O;cjoYfbPs@8Wc%f**tz_)`1qpBu7pT3EnL|=`Tm+vCH zZ>3&yd$P3~{(abmoqxE6;>&|y1KOV+`w{Yhzr;LsuA+{?m?q7I=}xDF&#!qNAN3o| zht8Ov6cR8}nOlhSxzUY8R)?o~5Yn^^GW#*8sU6LM29;nuLCRUZrUj^;ar_PuuAOBJ z_IwQ%ke*_dy$CW`ce%1q@uBlt1TCA&$`fV`4{JEojt;$$o|ACXy`;-sB%r4PrbfD! z^%ksLz3y@hl$Fg5%!AMFEkyd0ZX+ivy*#m1S@G~dvBY$=Df+U3#vy0VIA(Q4>xAel z0(2csF9Qp9_^BJpgRT^Eir*6Dshg%R7S)CI(kM75(eYpim%~%y8?v|Qo2l`v>hKXwvUM9ZE@@5{07YBb&{`@wN6h z9le(KZDS?1yBQFfl0&2`O`Lw?EeS&|)JyIwT5Rh$8~}A8@ymKQvy!`9)>VwvDpM8{ zC&uv>PzRn!ZP^OI7CtE#5SDe%Ao{Y4IW?+ZW7wSlhoh2z3{UiPZ2LU&qu-+Vk6dH8 z=Ng5)ul=rXlX#aB^Q+%jN%)P%VH`n0ocsx;{wwQzfYpDz#t+j&AWFal3R48UE07^1 z`RRZ*fxJa1(YI?V92UO)BzGZaatEpq+z{<^iOP5TQ4;KJ%GFb#*%#Wrh{(OB zM!l7@cMTDESEJm}bVK3oI*?$WD@VZnYYN=ICf<2a6#PB@+fFD^*!SJz`T=B;eV7Si zdakDMX`W}cznjSh-gd<|b!Wzne@FY)O zeS3>&?PJk8ScwwP!)oEaG>(QZ+_y*&dWTt@x&hkli&X>1ufPUK-wvt*|5NVsW~sI` z>-5+DE3Vo_GWI#-(slOcCOiE>{>+8nsany$%i|U-Z|SoQ#5P=(jhtb$LW0$o zK5Iofr>T?!Kks&54VT$3hRf1!xV!-ycdqK^1)mCn^d$&AQ7Zi8ID3pJV9Yp)uJD(> z_Phl@)-_wAv)rM)(RI!(o<@^lF=@DB;}+4R7gIUf1|}+Zwc$}%*Hs|&2g<&qSB9br z=Jx6)%$R1gW@p9n?SNyh%5&7fE?g%;(NeU05JxUMCDcRUz#&dVK%u13aUq;7amT+& z?4$5q;`+h`NmaGwD3?WagaAB1!@p2|#6lB8ITSqB33#mo13Vh^3&L_hqp6uG&{P!q z3x!C5?5tMAm{yBi7Vhyl@vP?ES6UG5Wb`*M<%cdhYHmMt5-F+247lTDIz1RTL4t~4 z9-?ch2Ml?FSDd~Uk2B`i2P|8+NXS{GuHq=aRu#%q9dW6z!xIjGnyht7=T&4WDei@$ z5?M~g{4(eX4Q`Ql0VR;^!9z(N@##FOLUS*rHr&FbzzkQJT>G6o}Pq)b%s6G4FChrR$;Dh0=cy+|DhDee39F`B4 zgp99|2>HV^TPgqblo@tZHaI%2ux~WNX)2ZEIiCXRbhLo8L@v&4vR3_EkAiXzx`fb4 zTaxR;nNlXIS@Q=M-2`$`@l#aLu|zT6YmO_?e8%%60Jv5%Iam4>>XmwA6WP2x59v{y z?9`rKl?KTeGqwlkvIlYO!z|&R>A0}5~XdL z$>@_xdpa`#G)vPS%~bop!T!MZubwg!EuyrmGf!G1=_vhjT%&2^>*L!3679}R1<>M5 z2lIX+Pw$;y8@;7fnqFuw{6*q?+jyCXYOghjg!k>oh(n63I2rwzqR!3ELrUGub-Wkc zRH+eiSU6?Dps}n9cNH&dr8dbO1x{1nS80%`O(Yp9Vv^o zg@a%o&s^nub%&u9cPJGV6DqdqIryfV0OB7xD@7BzLN!FWXoTi4p+=b7heIIYrTNJ)xp@ALj5zm(@GrL8M?!b-r5trfwQVX$BHIYXLJ5vq1DNzyC8M?;@n!bIU> zR1YPctHNM(6D@Fq%hF)pXWdf(kZ6kVhYY7DjiS7nUwB8uh%(GE;sGIdBkWIcWLu5i zAo&d*DMYTxtE;wn%UVTvQvoj&<}^srBd;#QDxul;q%nPG?#BRZV~s(wbQ-;S*@ z_$DclO*ys6@#&fHK>$<09E}7cpf-l@t6&i3d>Tjh>nnJa`FBeT@ zTm5=^UC$PGW-sb74_|-|vZ?TT^?31|!-roy?M}I8o5glZ?d4vnW$%fI?AooFB zr{(aC`UT+I;Ogxz8u@#T00Z}KsEr#U)Xt~iWan8p@jLN3CEOk-$UTn_V|#6V*BB?> zj#}8eZ3}wmDZ;%lK!tm@WA|K5_M-NO2GE~1d$66&h2h@pPQ9t$_8bu2b1f0|o@ozu zp17x8g7*~MI}-!Hzu2oA?|Jf#-cs+PIP&hT-yO)%T{Rc_`{sCZPft_de8hEHVG(Eh zy}1*|Y&|*(v@~_{sb&w2{%nvc*e~AxiW_^gykg!u!KxTR64Wis{UME^vSoz>o`cPv zi4_41{xN!8@UK1Jf8iwb%josjV_dpwF9~uA8vVJ(@vmR`#ETFK2?jw7AXr0rM7#-(EEej* z_QD-_`j>O9UWd!e5-MBhlIG4{Sx#_+&Mh-|mpbqqk zT~bzVw2`O4lSqIgb{Z3rOcT%ZHz2SNwI+n)dBv;AxY&Un9<%I`oI&xCO#G?=OriO0 zd#_5)N!@C8tcfeyspZ68AHqO$l?@PBYVf(k6iWsvMzhNeYBSZzi+C>T^v(6JWTf3V$#=cw=_2jbF_lm50>dA{*afIJkNOUQN-vLSxV{)ms_IH<{96nW7L* zDsO*$xDG#kxb|crXWDMMo9!*?OGUPbZdPvc76-_MQhD8%5Ro4ZSa?O^t&4NU-W3)! zlM%NVE45$gqQ4mCs|i7=UP=M>M1CJh*@7{s^27?<7F%5htAdpg_66N7vhy51RV{tH z0(#ySTmY429REw$mnn9Xg@{r4_x2xqy8wR{9Rx#9$6GSL5u<#%Vv4w6J#>r2S@d*OMRFA6yzc&)hI@pxThyiAk_YXP@)iZlI+`BtJd zP4-{{OHl8*Oq?D~7K>Q?dc{+QVVR02A&q%+VLwZ@UEtUd;!-RDCA$O~jny$&_nw^S z#-L%%UDjRP-=YMcGDXC_xY~?!_nC>r$8@;{E3G_|E6l=!8~}FVJZtVTJ`2Z^@Gvno z5Hh-a<;9}xtP{&_pGVQ<_4UR;$4lo618P7AVzQ-lbQAIj=#45={Pk88%Z0XDuQMpo zY7+e(JB*Zzr{i`Y({ihiyjBPE6+VnF`4SrmWR_z~AArVJN$aF+TdSEu>Ws=Habr3> zH?^i~NSqBh->Qo#sq$0d1fdFdJVIU}&*?ATDpmuauP&oGT6%L!?$X@dXW4tV>+y-S zoU24U3f<6=#WLzzzk(y{Z@(1(qBWAu{5pvH;kP#Vjcw~X?!)*?4eEb>k#fBJZ<_s$ z^|uF-J-PQ81^iFf_~3_s_xvCFP@uQ!FpQEY32uy$fY47R4zT#$B^mDm!I=L$81LK; zd|M1`tSos~!=SfYJ+jO5e##PeN4a9~(ZsUa8@r~|ntaBrD+l%<*??k*e zmr(xiVZ3WB{vvUR?=QCz&EzdIypg>q*$oGf_a%YvMCL|oQF!N?D8659MDD$wdw*xV zXA{wQFN$Xeb<=_+kr#`OV3G#pA zXg5pXRQ^lJh*?zJa)feE&q-|d@*F#Lk=q*9w`asMnI{^nci-rqD1d-;dXG#Mt^-wJ z{Uw|DRk`ikiD!#9cm3P<;)W{g*3K67ms+FQ8{VQnr!H@* ztt&W+LVaNBKuzgTLo7^4(?w?S+8 zQSD20INMIzR&UfafZgqTYTTdX!uHoO1$zAANR)nK*TCP?Yj&d5an{x+?UXGZoN_zy zwWF9FVJ&hf044{`I7tV&KkIhi6_+)01KfE9o>`L=RC2-{rk=?vX{pzq{W*QT^y#vt;O{>Drd_tArJN@*oF<(|!hwE8AZ~G!c zK@lWi9pIj4uQi?`H$Hr}9~AdSi}obO2@(wJeAG`Va;+_zI;n=h3;6(z*A_b5AB)bP zBFZxWEY*%1>{XVNLC?4*n-cZH#9mEo8C|AS4&)j|(R!2z_*x<<7T>j4)`|1|G9rAM zD1gTcr?9*9wtDT^yH{$OgpG)6usQ@Aq1p8X^yrBj<(UV2qjkgmv`)$M42xQ$*C6Ht zW_0MhbW*SCKJXuhr}%m)s>^|iu#|(RN*sqHdf>CwY#1^gPK_W1v~3vI(@;UARRMNo zM6#Zog`7qE*kFjJm5yCCrMPdQ-mb)0LqjP_hD8eVn;7DTK-_ zF%`>IThCbXoUTn1W?ccIX);Q1!BgkMMW!Man(jnutGby7YEfq!&D<7y1_u&Vmkj2= zNnlD$uoqaIbmr6V>1Mjo?LCPqF&y`k^~1q52aY&Hhf_lzYE}|S%d_-zEG*@m#&0o} zNSaLsez6QJ(cjJo{``bGO9Qh^1O6XvFu>0{%)i}WfS-4mf4ji|KkqRAc7yrqd6u)R z&K7VfA38;R!o}wTUe_<2KHWC{S>xz+Pc{SZY%|-=XZkyJuatLA;y20AFEhDFx!toc zZdg#i>qTEv7QioayfSU}s|3vt6(d<9#)EqopB8B^!{n9L4vl@Fi;`?3E_ zxaSR)aC)PGt9nIp8@~_BwF^Z^@#hk((i8GfuD)xe>LJxR z(Rn1HSDfYoJf^}?R>@uwbQyU{ec&nL#U>rRSPpR+*oM=IkIM)FY2`N$oFRQieNi1a zlOow%OuaaF996OSWE>?cNfm5eJ9#g2}IN|bG?oF@3KxZ<GAg!5Axm2k)fRvbH;WE+{F zTlK!Xj1P+hzQXg1kK&_VurrN>#XjH@CK zLc&%O6?4(Ws+6JGKC}_LJSMT}Io)~XRSj`5kYu?#+BQKoHHcqBKc0Q=K(PwkPp8Sq zdsZaLR2=E+QhLwYIb+)%f7etPI#9Ho8!2!RLtc&7D~T#1(pNX~H7w<=4@W({^>?>o zQ;1O7BVsmtAkaeGu?({b&E2`~PPv{Mh&Qt7re% ze~zIL20;XYK-=FWiBg|-zEN-9pS<(CAoM#J?k!{?v}aWJDW~|&mBGDv8{EgBKIQ!z zKi|%c?1KEyKNA4W@oi@LfO6-=d6P@qP%|yVSN-P-JK7 zd#ak)yXCe^h46h2Yl{J3beB9M;Jue%WBK4)#gqv47lYq&q-3&R7V-AJ-Yu--y{UeS zKSKX+dB17xykGpT|Gd$_Lvu^a>*W``fB63)@Bgj~+&X=<*Rc!-_~OP<>h1ErZ`xzQ zFJ0i=H;1yfyNFt-i}r^HCZfLh1^77l{TuUd-WTArH|F2GFTiJS%)fbGfY08TzkXkS zREPooS|Wx^ZsWDQbR%p8x&UWw0c2NEg08>aa-@nz3?xgCWN7_MsU?mO=M=g@MgKs6*@wV>4Qk>xao9=amr z{Or;a<+-ofw6|}jOLX<*6zL&A{f8tHr&2(HD7rGol(`L3WaDhCYX+pMID9|K;j@;^ zqoUTuM2YV9AspRfajvDz6|iPB^vgXdRuMS0xjIc}Ba^5~(^A?x!P}29^3V77EVBCC zzG5hTluTj<&Oyg7PI98e*9AIT!~Ft^Fd#*UJ#*X73nLR9;^Zf>3~?8`!~mE zllZd0t~C0?Y~6zvr>i4!hN29KfgmmiFJH_|V}x=*LoBvmr)WOekXbxhiKvTkLNqw_ zE=`RD@bf5|!pT~jRS)9qO7#FP4*pej@&Qzcd@c|7IWren;UW6AOr%j_*E~xP>4EQ_ z?P=6u%cK^n1zW1UbUYKfb7t!g@MXj93&A!qYfe0oV2Y z6SB$M(_#wyc`sN7{X$a6n~ZRfeY!j;Lk&1Pf#;b(kz+Rp>NoLDaWTj_US z-L_bJmqrdj^(CR&iw{)h+nlVa+dG~AV==%r8A~bor)q|?tba_KVqbfa=kK`xyTSRV zghI{&tj@`==-NSduz39ozW+h@f&Y~6|GcIB!S^LrN)RqC^TK01Lp);4{gLn!vb36i z>_{$KWcgG!Fz-KtwekSF&1U}DN7uv&Y{-~Uhs_^!jS-j8OH>ykquIq1p~3tEZp5^V z3?0vr(w%E!!??FE;0_%eMa-4ij<2;mQ1j)bP?5uytqy?!3SR_oRd3@-@!NYRY6d>H zOn*NPk+;!6S{}VBzJQUXM-(3^6PjcxC*Hi zKDnn>=h4dT1^BR8!7Xms*}4~Z zrbx;&wXPB1W-qwEzoM?-491sx0vuEBL_w4d4uN3!uJRTUc^ z`k@6>Q0WZ4BZK5D#^zB-vx;KfiX18f&d)?VCs!49h(L{etMBTRShqE?Ty|dVlSk7S zm`K*FI6Xku7|9oG(x+pCTXA4B;Mh(jOAMpyaNRPAMe!KK>BOc->Uz6AjPaGCEzflp<3HYSbuUw!B|x*y|j+ofnvs3XBX zXR?ucP5-8#=D+K~ z2rahKiU2Xd5H_+vv=_0U-H#*@z}wMeywgzSmt6KY`#pYEKGf^i>=djFze7@N{%9El zd{wEhelS@2QD+f*kIejN5{Rg~me2MF_~sJmsy}AZ-X?+cmoY(Im-snicBi8N#xm7V zXZ~x34dCa_+Ae)V6|HogrBaP{7C)Q?7vU6u#!l6-FSPxeNW`-DJ-)lG=|yb~m`uOE z51)ESdFG#u0M)OvH$SJQKA*i&sKrf-jz9K1Kxwv`e03HtniC38mYAslM zlbbbpP^}(V4;F+G)?Ho_GwAk#0f{Gd?XC(`&eFDHh&QiCTlxeXH?9`BG-ltY>R>r= z#N%DzN*1QL$A^C54v+I8&u))|LY0|tJ%PTT@!`@kvQ8MyyaHUJ(q6vNZl@Zxb~Z#M zv4(6(N3Ou>_H_X%NMtDVe0`2lqGsfQpnDrPO}DNLS-)j~Sei`1uAPp#1%l6b>a~}1 zXoruuicY;BHwAsZgv63d9AQF;sy83X=A@ptkh4No!ZvgslOb`Fg^AHfYho9-8?yWgY9DRzh zg{P#7Hk=;gU(epK9t=Skl+<^?aYD{bgu`Wam&k-ONy4t48-ouJL^$QE(MI_jy(-imD^&A%v!9K6& z1R^mk-fm&I!6J9P0Lqn~tTTcPadNTng0I2OW`^4_iEN2GNa3+T@7q1a)Tlc{smdIW zz#aSqYuBjO<{<&-Q|71Yh2Yr>`Zp@WeUfj#YX1Q1{y5i)!>nnmHqC#fCiLI8>~{*p z|7^*>h0_S%8zD((mxkNLhu(QJoZ2N3w*Nzamx+s`eXumyAnS9@p$*ue@NGyKz6Vc( zJsXF7ks88wn1!Pq?UJ|7!}e+sx@*pX$p*Q_KH6Bb|Ki{ z8-{juyX~4oWEaJYqWx937mMPzFE9C)ae&^1c4SB0T}9&U$e3V%3#Z5qr-Spia9aF# z!KrM~#Wy%T2^#3`k&JU2JeILNM{9%nZHCr)clDb&;GVqsNcNm>e>`XRtN+ZB?;pb} z@H4*t0k7mgf>+>YeEk!=n)WQsAMm>D%FBDPstQCsy@|I1@I`Feol~~^`9tk!7gnY} z=tT9ylYWL<;P3GE@8A~rg15*x>sOL$k0jj-lY>zb>_Hg%I3qMHIN}!ejAL@XTJ|%y zuSo0E0n)bq(NI&MQ4BeHN!@LNF+zGp($uX88)emjfSuMFf~>}J^A%>obc?QIe*>OPJdaGJ;B`Fcc$> z6AvPlVGXcOiQ!2MQ_^T!jlLs-bBRW*wPyiq%Z1@m=9;7c*&OXh+8^}{L2Q$*sA{gbFCCVZM3W_c;mwJ-CjDt)R(NAQ$1~6=N4=VF=jqbAXZoy9Hv?r& zVF4+DIz^>3oU7~_(Px@f$OV}c)-eS3HPUGkQ3ZuvIoSw>QS_hug2ipDd%nAgZq2QY*%I=-w`Ld z4@T@7w#hG$7{m9qHbSs50RKILOA>qB>Z7~P|AxmK22FB8a0g1oU7X0_9 z4E$Bp`wf-7^p~g%{8iNZPf!{79+p2xjWQAYykEjgaRv_B$b9=M?bwvEn)F?Dt zy$t%}U=ukNpk4(XF1c`7POqc#!pM||!49|#={2!lh>y6aOO>#D&Vze3)2Sj&&ix2y z$FkDVpz)2-tUE3XGllAF(alpf?~9jL1(}kD6X`o<~F)?sE#Jlj8tFr&BUEBBMDenB`rsn z`c$1kgF0YH$5er?ToqZYyJr#unUTqf=v~@ZH$H;Q74=b`og?>HHkBz zeG}Ern==Y!xw7K2z#BqhECIY0m|kt{n|3%UWS9?mpf*rt`|^>T@^)GTJB(~56;PYK zS+$bP_D^aQ|6xQd$V)Z`Mn>_d6bVD$-ykVygDhvS*DaRiUIz&rW-~gi&22hn@v7Y!V2W`w zc**}Sb?>$0HnwbwzT+#_JMP|uH!EU4zxm1NPn5mBXRrbgD_{5W}SAMC23=12%>@3BXALtN;d2FC!&>a=F#7I54!oN94W_zbsEkD zI;SH3z8gipsX4xkr2Q(`UIApN%K}-YMTaCO$poNlO#=G@a7-! zsScd_;+Y$5QjKi4_oJc>*`nRX58usdDeS9+BmP_mz813mtS+W`1 zZpMPpztd!sY!lgruiKyr*mm*?>d==tI@vDs-mxFw zT`5pv!{=znetOSwZ^nwy?u3+YtBJ_p!l%1!m9_KDKq5sGX^s7#-Ff`f1?j~9WFWDR zNd4-Ry?OF+ka*j5fc}>O^xus~<#{$_!!L@2eKP7cN{5dTcq_}*Q6P3-P)!&&a|p{7 zAY-fbH9M${UqJ2KWBW?}Jni-$t_1j4%AZ#9Pwd#~vOk7n(mqaSn5}eO9;F#WO_9Bx zR9){?_2dRiXQ8ioI!@P>nTk0fywaE-v?Cx-gd|1Tt9KCmJR;io0!8zDo%Og&E_FV4 zey<&q)=d1v({2fmFzO6+R3$Xx=0#mvAdVoBI<`JXff1gw_EYJ|6XDeX`XoT!I1CmT zHlR_A>E%%+pa+tTNMJw~k(KqDkw|Cf5q@!S- zF9bX4s(C==6G%R&^CeBD^V|>)49xNqM?7uiymWHtu$xPmx55qHC;jQkr%pih(Q&%{%_Nr#20yaii?-Sl0}{h zwhPS~c*hHNxp2`+-!1#jSFbZ9sb}c^$niI+8<}dZ7!G?8!*_7cze5;?#=}K$t9%W# zs&@~Blw-}FHJ_!A7@ zT-g`7Tkfr=t>=ytPE zW=gkAM0Tj7)<6^ZWEOB!K4^0&3BIrW6Cu8$%R4;i9ns#K2+rLgiH8Wda%OvLGbL3L zLvBF)UZKPbHd<8gk>k@`_tDCbUrH^Tr&sG}#LX6lI5_L?>U8s+lMdK|Gf8w_j*l~g zmdxRpA=nx|PYQfY-biqc={s)Al9|Vd4;uvd5V5;Llk~G^ZhXN!0b-dXiieB$LfcS3 z-fUmWM1FlqHFNZdA}&Fw2k-BpX4?7{M5>hZESSQAd6SRWJ(X6BLJ?ZkSo4j>=24vU zw_%7a0*QYCG3<13aD0iz8&Lta?u=Q(*q-bPvkv`75cAD*ol%-|SBAvP&}q28#ka-f z?z%mT0&;(vhwlB#Ku|cwS2wqSo>vA>^di&45gQc>5;sw|^hf=X^WzEbQDcBr+Fk<& z(eak20Nszu#CBrnKdb9=836kNO$eAkL~|`+TO?q_!9xCS&KdG1y^eRZthm_{gGxbd zzVIgS%42bTD`764<;)KOy?7jAvp&(8r}omcQn9uWJw#3e1P#QbUW4fRpiY?ykjb|5-=(&*yTw>&XmUNl?Yp(K7``CXeE$S zkFhA^)1%JiQ;1Q(gl6wht6cODJ_}4OsO!pEEI49BN0iwMaxJC=d`116?*4ZWb8NF) zHQfF-zWnO=&%ovDvEL&LNzo{|VG2Z|7>Xk+s()(Zif#Kdv|FdIk$;qI+He%w<>9;7 zWy=8WVsL8ZA)k|%l-jutx)GBM+U)LDmJq{Ro9Rk=2z0X>A-{OA5*v;oJIz_|gZzrT zkbD0rns2SJD7nq%UfBn>&FTOw#Cz9CC|8NE|0-M9h!8Ci@CS?r(P?|#3Z|1my;XU#t$ zi=Ev3K05pTpHRhRmM_G`{sUFMJoarBz~4ue&sPC_MU_8Rp(xxh5vAA>h1-XC6aq7` zdJeq&18ApcN{66^9ik3%C+yZP7fPmy2XDMk1u6mp>tir;5jPy8TYan>sV@Eg&T5Pe zs1luOiq1B0esQ>~+Yb_W_0YVuCs$G*nX0MB`oLAC{nlx&IY6(|g{(qzj$V%pZ$kjA z>+B>ZKAu;`Y&Hs3K!G|z*{oQi8fV0-@!5qjDrZJc^$KZKMBgUxe$c=x)tapXbkwno z)L8}P2jll7dtzTLTom2N;dObKM$d$VVHD3d2uW_3;ec$|lScdb zTQnRIpF@9cZYd&^hMf$mcT1(CK2UQ%)p|f!cB-a_<*h$8o4r82j;16)Le{}tQ4%>e z%X404NX!RKz;0&@v?J#F9*%Xw4%gvUMTSD1&hx;Lq1_|&%i+~?KmXc4N zxRwXHuRsNXvNtUtu~;TlMqDM|j%fSnq(fZRIz)A}sW_mnfHLR+FFBO%g4!Hkb~f4x zA6zf}pyo?Y2ea?U@1dUzM$Ji4_3j3Fc-T-XK}8jcH-^03Ne93O2qT7(mFr3Iuh;br z7*R$g6ux5@ETC`1S(ObQvvIrQ=kUof(jqo8UQSAz=a>=!9DEl7S4BH=DkA@aA7Wd| z<|PREIDC6`U$Qj#bhM+^mK?2UC@flbCSbkvM%Wl~&ww?GP;=D_#!`j|Y(?^}bpv?- ziP!4^nhVn1Z(4u*(f{^GS&fRW@9f1;`sN+0ouaA!JKpfX9|pQVW*m9u z+fdELhamfM#RyzmUIRP7jq0d$P!oCKgaDcXurVOKB>4VW6V$ zh8W-W%My~4-f^;{;a=urKi(@EYaYhRzj~bFk*iy2K5RY<<=Mq~YmjwdM(D982ny^V z+pMZ0_p#%A@Sph-KKfI}GT6DzaTcJgU{2mop{Pxc;NS}lN5-WF3A^PIUYtPv=H1Ss zxpICL%U^43+ zic;x({7%4vqGtD-8uX49N(lhf&BBR!cC#ZWz#*F*WRB4)Ocov-SFW3(Cu<-!!pa%p ztfThyRUtG(%Zq~tF~zzK4A@P&f>k`*6!An~*du4L)4Qe2`Os7kcR>%BfJEZs!BJPN zxcO`!`12rKo1v%Zry&9Z2rq<#o>KRI#%DK11U$DfFoRedf5ZOhsLgI0NnT$U2EU9l z!boJ<)rW^zDAQ90E{~vD*eg^>;L@^feLt|IqoF>NHuwJ3%vbQyhixzqmQ5dZ{k`t) zFJjCNuO(PN`4I(3S_HpD0xFQHjXd7H)5|m>O*>>_&*kp)YFLE3Kk2N@N+gJ1-~Xo#c;c>RVD zp9V$S%ob>~P{Z+k_$0gq7&N_6*Oh?7=$2MpBc3&I%2pblelAU-w&|N|wTbP4{* z=&DImb;%)X?2#)j$`%wYHMH)Z#&~jnEQ$iZ4MqNNn_okb^oM|Gi$s8rP(%@Y-d^^8 zy2;>~$*8ZBxwU)Lr>&n3+5)AmpYG!^L-6(zCGca7(*DwTZ`&Hr^grJ1s~!K>ndfIa z2){I=__7M`!!>2KiGv1?9agj@TI4Pia-(4eEW;L>l1Cr%Gn^ydioQnxI*=3E=*GM}(#-)Qr#-h7yU8cpIv?c5L} zE5N1`o(zWPqc_gL5g8nL=JB6IbkQTR|DsY*LD`n#787E7L%8?Sg3o8_> zVF?{QF9iu`yv{*KC_vsM^j)O6=-|nEd>)JE5f1`z2#?PTe(5p{vB3T!oAIa_**_Wl zy9p@P9b?}=vh*Wgx6R40{>QslOV&SrP-g6n#@p>pLRE|J6*QRGBIe&)4|kNO(sTc^p2vpiHqxw1La#cGWq#jkCmydJaFZB z>sMrVJ6}&-*&Ix7Tj5FqSMC?>;~3FsdocQ<$t3;p)xq;qkAv(1N@oYd?=p(Bv&bbug)EJgZpX@IIVx3 z+tZP^E&T^s$}>i=!an;@w0QxZPx$uw0m_H`a%%XG*W=5Md}_k)5}@0ll+O~Nz^{f* zVuzl7pc*m0c~w+$I2uI@3vh-dpS=ph2O94B4sK<@^TGDXYq!fKL*fFIpqg2UXMK+R ztd#gBjczA=D#Wnm$H}Qn3MyR3nd^rlQY1_02H>8LF-73V36A~Xl?7GaE-$3^6f6u? zic(c_?&7<~%RD=yAXgEoUZ%1azMWT=O}+=P?E7plx88SZ5i4ILZSdE&E>(k?kTRt3 zQ>tC>Z)N?hjOCWy=ZBy>gI#bZg&vAq1GsuB>T+lG%9n5Cz#AZjWet1<;efU9!h4Wj zgA33=IA-?-&$??REhy6kl)MATUhe`h$+1IAp%-B&A4L9iE^qfJ#bjfyHBUX`PuSIc zCA3e`9d~|AfF8fN+5C(uKUjg=O4^}1d!Vj#cQ(m*u-}#@m{17QUlX9fXBp5>6QEl3 zXdT^RT;%pR&=n+9X$9jm(8;BM(PPq%cUpmJ;_bA;;Cn)U;_BMTGY(U0$RabIPjTDt zs;=cC+n;ZV#e0yP>wrRUP&frTC_Z@`4PPx)7Cs-cui$aOJrvSf5NnU{&4I;IX&bw^ zpHoJ8)7brT%Wf2)(kHo&ALgl?&}DM2vVOZ7iIZru&6`JRk({U@Y#8bn;ym5shl)pa z*rR3pR@s1hT>$@KE{WwxQm;&Q{CK}B$PMn{+Z{@)u(3lh8r6f=eSJ~@2)*3zE5&19u}boH=S2_st?2Gd?L9k>^YO#|aTfzcTKQAIxNzQK_^rQU zlrN+1JpO%9b%Pbze$prY09-5Vxr`Dp=6`Jv=>5;v*;GHF=6`UR4_N%|C4M_3d2`>O zw!+mKf9Le3mWcO}$SXZqkp<2+sl?XMw_AIV^ry(U0?}q4LT&=d6y1aVWXozI#1_x5 z(6l1h`gM)uBWTxe&^uhB|Hi0a4@pkktvCk3If~9Nbe+=DEOw&%mBw#>6{_+tQw{y9$JB3YpP?iA=J?ps&4t*-6%97Sk zdg2}x;;?LQkLLk9mT%QB99@UCxQ&{CNaVx%{ZcL*QsmhgIOSvLFI^jhCz)0o@lc`@ zsAhG=LZ~dxM@+snw}!_aqI)>0ETYiLJatyfwg(C%4-3$q5$95B5k&lZ0L6 z5Br9lLNS>12?6>$z;=3BVt1=kLJ!{RF>4%NI@LAD2e;vCoC5st2eZd10&_Hd^q97J z6~APjDZQv-?Q2Vnwu|8E&EdJ~@URW;tZ^9!7(%OF5A+KsE=-O!+^xTyaQ|rO)G{N* zSvU-;J@GFoPnIYz8P&oSSZl2LFmx@OHXU%zVwu?ez!ilkBxHSpcmgth;olGD+(3B<3x1MKR+)1;p{R78I`Tm@PhqYwE;oTn> zn|t{e7m9Nbf$<>M1f|gio?6J9f8T+qd&-x@BtX+zKRh6&C~j#sb}&JFW?|0-H4hT! zEjekn2Us+@M{=JpB~%s5e4g@a2wYam6gv7DS{4bv5VJ>3>e7zm;oeyW&XZ)Sc-Ipp zw|_f%W&MvMaF+3fPyNf8S5kHB{>54U{r~7LzcVu@ONJeTHWlG;{{WT^Yd8k^9?AX> zT>?xsi%RjB4uu`g(jK#=C(o$kWkgc?aY`Tqfh^vRy3+ON3swQXE7z9qJ( zeR2XEZHBhVKAdZPkbpM$`+~(N@s$H2`#8y!_eFbB4BBn1a^kmGmTp+qfWMLav*}OZ zpn1H|00w7#P@%+weBOmV2#Q^JXtVLJer0&PJ7b+Io`j#-5a1#HX05oZ(RUNWvp;+X z4m+x>r0u)DId9$vVDZdi`HwTeyUNcGj_02eaZbbh&}blwrf5U7xpL7N*b;GyXyO~E zidWWVL)5S`Q1A4^_~Xu%8?)Igr#5o-)$0~sNo@^$u(w@szX9OiYjIw(Sf#b%yD|NBixcwrHkPNWlyPKyIkiNY``R^1$7Q}Gm^X}`=ELHVHOs0#Je;p+-hu3S zsbrs&p5%OXk%FMJ>%d(tq=nPuaw{pIKOlAWaEeyaKyAFq=8=6d@ephNWsMpbbeYYL z@`zV|KS{!EK9RNSlj`e)Lk@W5#TkITD@PZ4L$ilAH*bL--4CSF;x{ipnEr!%6|P=2 zgPb_G(>rpYtU&17+dnHKBP*xm066vi#Cli#NnX$*^3z&-Ea!*t$hDMK!H#Jk5c;=? zn4C3Dw!*}}nDz6J-PRwXd-|_a)@4zfl>buhU0?OXh9TWo5cwAZ!SD)M|K!Y#TK)Gg zbD#fTt>FVR|CjgwEtsy@wuvQIx)g6Xw-P9l-gs6X?ZbGIO|2z4d80Oig zX(8~9M6PE;`(0cXH0igULlppHzDS_2!z~CX?Ay-m471X78~H$N(T4ZQndBblko4r zR4}$q_UZN)VCwDtbInf(b%K=%IPom^0Z|rIHnB7{8^S1pSYLwER)47#NgTF*^YFZ) z(Wb87+QRN8w4xFW?4Wr!zR)c0r+lKvjK|`mZ!A^9VCupEe_rNwN8GH61NaH7|0v_z z*52(eVIa;Iq}Z%iRv2%fbcZ>7`NHK+yuEw73)5Gz&Ym^}%vxAX{t6pk+6?vw4foq) zV-b2kSudxK;n}18wJrq+OaJN8{?^I_vjLL3J^aw(=ZcKMV;|1Rs3ZAZENwx?`Z}$F zMz}^O+s~H(zphVhy#V5u$<2Ih&4z1Cutp~9ix|+uM?c{<{@JM4OSzxJJn$*bYmLiT z#_)Vc7I@6NnY{c?dFNlr{#|20)H`B{p-lR3H5@1|z69@H7%z3;V zyiXO_2Cr7t2xeT!^sPw!1j4+WGgMv@TkNO;dDfsU2t^qVox#{jEs;4snn6T?i7)*ENV0uoU?A03q4ANdk4hDqTK4tqz?je5xSeMXc;8e3vbi)Qxrxl zzqab6$cXi#B}uz<;)*XZIZ!iuvYQtVkhn!er}K1qBKgg|agR8K^vBzq?4HyQyu$Sl zI;Z^T^}Zg+eml_qI8gZGK-(U^ z9QWt43h=deJ}1#;{Tu6tBdHl>opR0&KdysD;1Pr^9O`S8lnK;NT{Ujezgj-98@eSfC2~#H~6I9?x4#<9S#SWkCV% zi*@g@LfoyPxvN6ZUl9&tM$yrlj!qVA#$mNTGTbwVM+QVRB?<-s3)OKkm-ia!0IAZQ zPflovPl-R=QhM>=Iy|%sGigD#hGt!m_jL_|cZlNX*iiL@X_PeensJ|ElDPxS`|I$y zn*@y=*gkxfqOKhcoHEH-Pr~~kygl#C)(|zf4QeU}jp(R@;gWS_S&ZYH6`&!5^!9Ab zj$bgR;Ns9ka?5+4R64`{zLF#9qo(S1fX(jx_r&u{74zc&=f9u-&HVQPT4QtyMaz|IhyZ;ccsHy%Q~_3MiK34x3$avmKuwD0hIWb=2iUhacUr4z^KpL`J&|~MXcl7Yedf&U%TH8)`Oq%ir|K0 zjLKJoVV-@m7j)}}ZvtzH57qX+QE$9`D;u3!02mcOkY_)nI-{8AL(T|NXNHC`7b@l6t0yA2NE#Pg&UDBrVP+T za3pwITqy8;Lk?tVnrQI!->vEh_ko~B;dOMLN9@GOmErlNCtx;W8E`I)VQ*q0@FooD zPF3)d**QEV5`TXAspy#z+paM}Uxg~%V`@;0xGno5}iq%zlCdEBa1q1R%|W5t8!@5ImAHxv=I8GT3baNpN6BHvuIG z@oec-pPEsdG*smxZ7$v(9wB9Qi13Pqj!5)wFduLX=p@E>M)PNgP-^s8M?;V3w0zUE zL@sPuC}X6Zua^G2lfDO@n>>dZlW`U43SH?Mc#aLnom`61?pz_8N4;Yil-Kb$B~0Sp&tr2ZY?Bs-&-9?|5^djUI~|>n(#<+mUShoZYN7)VvQ? z4oTsg&E{8nCl1jR6$E*f531?``rMt=*+Vm7Iz=tNEMl38NAcyb=fhZJNOysbbu-zg z)}Y^`ba6>F^o0a8<@H{EQ-$cGRyn+ka%?d^+}QbADr{8BLC;#ejl!(1cajm2B9R5(lmr(D1@z{ z8%AI7&eQ2WSd z0^ORelD!VI86Q$x_5X`e(Hc5#K1a!>)P<0*b3E2{Y~f|L`z`Hfk?C)X8{rngUB4AK zY-s}fzT$D!G?3_!%hY8qg3pWh;?LuoWxEzG27CD^cpSefv9>72hywVziOs(2F46&E zGQX&6x7bJsZSN0DqOXA&vpEZG(%so`?XTtx$`?7WyN$`{bD*z*sLSa~}NLh0xojx%FV6`H#rGOQjw$ zj&a2e?pX7Vxjd@N<(iZpPSreN4P_qz3)f9ct+Ks zx!S#d0H=3gdi|W@MtGNwyqO3{k>BL9u7S66ZBJK{h^bb_O zwTNlz*x3>JAkwddLDbr1rNiabZdkx--4Z+K1Z7;c$5l>WnZZw3;ak(59{X~%Jm49?)xcrge0JaRr z@P1C}`KJ4j&?uLSo@B!uGK8)K$*%=vGJZK6AQ)J~!9)_ktm6i%evIB>o(trf#v=%_ zdPIrD{iFm319XdAj+0=yQdDL7Gjc?|`+2+tz_N{ozB0y{ReeykxVgGN&+8lQV;yF` zQ&GB(k0r#}!GZ%}tIVKH@?AR4rC@h4)k{41yxBH=r2MLR z7Lds!a`p`IG!KIE$maK#=vySg%VZJ?Kn}a`1LTgBJo(CldiD>g#sb*V*?|ecxmQ%m zxZGrag*2XYP!?&Rr}pp;t#lsBf)ar`WOEcGa#}wOaz0#e8MHO*gb57ZIsWl2`h9b{ zKGT+LN$akpOMYo8mN+k*lxVhK0%6v#A8Pa5w7s%igukySV~6<}b=|+XX8VeKmoE7D z4deV5O`$M>qR7uFhktzX2Uh*!#2+NppBgt1yXqME_m}+s%EyU)SnSHsae8-Ih_`w< zhHXC}pO*$OdP4_tcj!xZ@!0xLY@gPOQ=5CwicHDgB)eik$aPm=QVNo~~#YP(-dYy#{}B#>;Nw<*MS{lJPzP_{L% z!21)#sNW_Nf^D0Hq(4dnf1+OXNie(pJFol*N7XO$ z>Oaj#GIRO-&RLc|p&(?G^wEW*%pHtEjvv@1$Hl8T3@Kc|dJ7QcREl0j%66{R8Zn}3 zloFj;Tptmq$yVYQ@xejdk>?($6Q7%9oG9`wY6EJFVSe-h9kY;pINs@yXfMaRONEG& zD(zKPqb|VsXP?_sNtmaDk%Er^v^+HT8cOsHTmdDHh5=YZBqtgC7Ph6>EF=Mg;{zz% zB>&E+`io7@D{6}DLsd`tpc^O3Y1m6-vh!>pa3Ze(LBrVY{Q#BEV^^A%^%jQ1nGr2^ zK@(AVdECo=C5KM;vchGjn&96;3;DL6yGu!vb_m$Fv^wAO;?bPDzHgo)?GY{H_D&aM zxcs>1mJh>3tE*X_M`IiF5aPP8s#wn5Ks8quh}y&))(=_!=rC!iZ(Ngw#|$e8?FjR1 zoL1ln)z9%IGmI}{@S~vB@jeyGauOeK(zJlrp~C5LNc#ME@lhiqLK|oGgNxR6){Dn3 zI?YwyIY*rB$2Qk0Fn^=s?R1MmTJ<8m0>o2!XRpr#9L%sA8w)1M?Kvi&H-?(w3D%Ds z9x=Xl;&MGF9_WR=vh}N!uZPY+@8!t>jt93|j%sRa? z&Svv+>tsL6NLyCas!VGQbA#y!{3x*d1(p9k7hv3&6lAOGLx)e#WdVkFYK%02JyyQ( z3&FylHi;TMypY9UDd{z;Z>5t3UZ9+=1D%E^68M3E505A1f0D1NDQ}8 zR#QP2C$gQ67=d&EgFr*#5bw#d`UeRaLX<%V=rw248nF=R*^YIlecN4-hO(g4i{cAU z!*~|uiAujX~pFDZY&8i%BPsR}!fcygfbS!>UV zHh}{I@QTCf3ftP3hca426VYHObb|)_#QKuTg<2GdW1I<#72v}h@OrKiZ@Q)HH_^VG-xG^YjH+C+86jqDyvd`U-P)BFVPCj%?X0UbmOuaD)0f(pO>-fSofsR9~)dP8bIGj7BNuq&S-f|^Uq}%~cqGXgH^-25c^)e>Y zDQ|2-udg(=xt`13bjEVItWNXAY}F$0U(EkDSVI4kVCiq1{CTj1{_S9CjXGA^4ez6A zHV@%FQp%`JHL1%c@6$PvEy{{_^~V2Cf~7z4_3whEx_~Y5r(o&JWB=EKCF6e?ENSP6 zdwPLqSw7VeX<7@Caeu|siA4s6i+W!{7Uv{)Ds=%ueU9jN>t|_YU#?@N(-?M4VaF`w+8S;kj2V)pL>I`Tlzbr=kAP#W*nu+K>BV1g#o>xe&?jq7bCMgu8 zIXMbjlDrnvJEI?3<{zT`RypnkSdY&n(IVC^m_P7)uc1wBh^6oS*AXPPy+9o!V-7;yG!m%Ys%_2o{Dg zh(kDgs(d@@W-Uce5k9edEkclv$=;_IZC^YXkJ`g}YV+MTXgJnmzp^12m#eIRk{neGamYNr>d zT3uJ<+!;T_i&1H>7JtQ{s0zk7!5BvlRDF3A_|*qr6`g2L<8*caMQXbPr?8pQdfx~?9c zS_z6I8&dOQA;=zlO2adXR(GqsHK$0P8(!pcuCzh8lDi17a0itG?%s#XT??9X@EqLi zYK+o&JYTw!dA?dIv`!j~i!KutMI{l*8FJR(iepV{dIJ!OMvi!BdzGW~=$dfEn8182W1^Z zqq|r|a5=rI)OkDL?1Hv0mD0n`$Vb37DY=<0bHw}J!K*XvnvWjTBs zx6o@+Nr(C4+x4F`5BWPr|Q`y$YpJ2OIbdAwIcO2bD zFcI6hada2IZU$`0Zc~bG9gW+RacE0F(dk$H3Jm`{L$|mrg?|x?<>^-VSYx~t-A659 zn@A_$3oGbuz76d+*xXTw%`64lry-{FZeEvdwG}ek>OSj@$=#lGE54-r{PQ)w`+W^% z+-(4czi4*+I_&VLpywob6QC{3^CRj}8oU3lDMXC#rzW|xb96QvMcmrqwSvc=9)!=}kHko|W(VI}Ae>?cSICF7(Z2)3kmaojZL5b01;UcUAzK zo|Bm^*F(NEM;c#!RyGmK-W~b*^ZPqb5BRI+_jjHi@K?|8ub$pVHzn}9c1p(P=rlZz zmr8xB8d+rbsLNwCRLubE4~q#pN>m*Zx^vD_*zj)@8x1Dv%OY<&@ zP-_AW;>kJ7?9pdl6dVjFUuUG6I~;i#i*MeEq-;^8^pZ*y+Z>6T5qU8k=PoD~iq#Pc zb2O0U37n+yxv1iR17XH=zEKtsaycJC+3ZpGF3T^Ro-kuniXO z8cGDOr~@hcn8j^O%ZhT%^~IoABh*95GOBlR&7>NSy5ZFF;)%#T(;Adp17vho9m7ak zj>^sC;MetuL{iU;SOZ(E&gRw3f+;1?%|$<*o)7XUS6EEQHXk@u#$r#veIEIzXnVmw z@d6WspIY!Y;t9PiqO6hKLvZC~N>hkWdhBWui$`vpVgoAakX>0Oin|13%nPwsbyG{qR&zOl~% z+D!q@rzH&hc@rljNZ+jg!$7hK4}-gWXfgBC%0@qN5!jI@xq08E8osC>z6TSPIbGC5 z>Yui3w))L)3{JW5%hvO;f+uf$`yQ0V(WseaQ#JsGo6N@I;ilU}hWv9wh%bI`9mKN@ z>&^RAr+tc1DzA{f{^J=3%@VC(8lnDTIK`-b%b3vO$@y{Y(bm4PHHWN-JckbJ0N;{2 zr(zU~?^7pNRxFw^LK-GPx*-g_Pb~?6&q0(|6ocim zMh@QdZ2|GUZ>YMOMopPXM4KavEj>y=n*7i;`U7d7WAa>-BYvKt=|)3`b9W)M=}g*} z!dc%TAQ0d564kdyK8a1Q6)jtA(ujm#FREzc zWlOVpGBXQ-w=12VkhPMtwb7A(Y^!RD2e0lanMuiURIF$Cgi9 zyfv1js?`q83c64Npkgk1{|a@5t39+v^wv#84|Tz~n<;xrr}O(RF6`@h$w)LUmL++g z<~E^croPB0>hK06pHnZ!@>EstICfo1-Du=$7boEf6M^st%h z?H#7uxF-1D$=_(k+;DdKhO<0(IWC{+n+*Z_34=}|V4S>B7(d)HCqe(}+4(`<{;&pE z`PimG6II`X|Co#m#Cz3&+0ypxrf=BB2V3s$;kka_Ix@V`;tkkz%gw`c{`oQBvt|90 zRRNzZ>+@CplTJp{nw^d&P9P26<|AQMhrkm8)pT1aqTe7gvX7U=@WN^RsCrD5yWaEB z@WJBIl6N7J!hany?_76UjV_K*+Q*{JPfeh!2+9irWL|xhN0hucdl&-rj;x)RhG9i| zB`9+}Rm0O}$=dw>xvYfJgdp!L-pPIudIm*n1J^{0Hd?YUddW#n| zpLAW;rMDI`+U%bVp0*%qfMwHvYGgPqEGOHq7BU3VW9BOCCaE)kMtu2=`Lu6u`S5i5 zn-RIHrSZ9Z0x`}ZmnT@>z1QH&Ap8H4_g+hnV(YfxJx{UjiQdASx&z?_2oSBJxZQh)A@GnCo6DV)gOEsenYJ z-{}pnRqxBwratf{In$h7!N(JLa~%Dy*z)q_A-lh|uQ7;YpZ4C-&c1{FyeN-;Ao=J# z8to1K{`em6SqNO-&MRl!Ex|zktl4=G;UW?86`VfSK1R*OBv`iNK+$juD3KUKebZ=y z#&d9np)cVRd=5PG<)g|7sE9cwUkYHe_?V_ZSD)VkOl{siu(v7M=eKaftN8Kn?OlH` z)S!oKoQ&>>DZ2?oE^$|ZRr->>IX-W)gR1r#4@P%Qc_0#@YpSzoX^q?cdj=p&d}hM+ENoZ+_GV-#kxWkJHX-9KZ)MGAxZ6Y#xB5izCU%-#(af$5*ubu zZ!Ht!Vk9udW-n1~pB26G-^A8T8!7I7frwhI;E`dhAq)1V07G^k;nF?0^lU%G^PG)- z-C%v;;o>#uWu@36y*xy+Ux5V++HMT>7iqGK2kHY#S1d62v^JZ--{aYgnnCnh ztAXJS>_GW{!cgnF2#ty!q-TTD9 za2R}KtM-lP=M9%Mag_Y;X8DNt;vfAe=%7#7ZD$t#mV8KpcE5D@V6*h-cs!^X=no?| z`m3~mdeGnQcANO{Fi;=yMT$5~^nT_(x7{H|J{(8Lr$91FkIU?UAw!RG4|XE#aG;Nd z0qn5$yO+Gbm3%BY_16~LJS_J6PZk^csl^tUe{Qia71MpQjq?3(SZvGje_^%ni_Qf< zSnc})96NtDwZA(v;8#=o_00Z>cCXT|1!paD38LENe0_Nfzma(PQd&Civs;??EznfC zLKp0{xhdPj-wn$RZP{!I;`aru`kZ-j3q4$f5u^iLxz7`&tu@l+;3dk9bD}{2Y8$XW zNyTQhJy{fnEtE4>kS-^TjyvVVteJkml9fhY;L=O3oO%ixakLwRy6sL+06a}w6Vf#g zxoA2|GfGFGO}hS?W1AS;H_0xt=YY*tWv#9mVx^Vbc1viX)K^8@kifv#AQGw zagYkZID^*$!8dqb!xsUKcR%l5V|qooSB)2RC0$)=^j?K`o-VhD0;Jpor3>eC)O5=c zg(ADjZh~{~5bD!6Js-TIymIR2Aw_W*me7#+gXO-N%h5EE|E)~5e!Z9VTJrBMP{;Qx z?s{6E(h!jJwf%Xf`plx{cgyYUmix9_ZmE++e*e!FEjv?M>1j`Ck_Y{j>lh!yga4inbL+yMi<<2c$y$zCC%X+lW()jj zx`_Uc&h&Qx;-Mc7lFa`U>gbsU?*lv3+d~}0+dlYW1`fObYr$g%BE2azF1LGmr9$4j zODbuAhS8<>TQn3WzX#BnTVc(w&uPnU@I9J1F4&3zWE=4zgyuw&iu!spopRryN)@2` zwWv|}vhs1Vr6Ys`?Rc3gi7%+89|oGD?8beKoz)2P15c>&sYRsGA*c~Sk&}#l+h(4{1C`pJwC|yybc_VafHK2}DJM=1llJr?o{=Qe(l8M)&lU zg-)DelWhpBeJVn-%Hg~+od&K9cGZLHNOFUuyJrALP$Fm-`Rt+&eU`{Ki;c$qwvut-O!L zD&E(a!uaU79x$tAj8yjV@gGA!JPa6{VexhwRI_?A{a`v8JzW06P6gLIH%mR zt2F|xs$C5$Eyv2d!7cHA@(&X7y3SOIQYcOt&czw;8D!1$jY-IQX5=E{+_x-Z^x3ds zV0b!b2VD@}UrBE?xz=Ct_9xW$Khsk=Kn?Ii{oS9an5Lk`2J(ETQ!R({=d{(h+wac2 zIYa-3bic|=?<>;T-(5+r4QxZsA7s$7F(IP;W6UKa<)+>%PtOxX;ur1eUmk)6OlR{} zw(ztsb!e-47kqf93WjT9T=p+-VBpQaM!xgj&7#;nPy}rCDkIl9HS@UjpBW%_z1>eG ziP(-aT9WWIuLl_jUMO1WwIoXy%B=*uF(5ZkuXpsRovaah+^)3NbA25F%_}Kp?!{lo z0E<+!icTC2kxH6aV9&DYnQV{Ba( z;;cTQY5!3;d3eH@Yu zVP~eN=lyb{5T^5Sm7Nz^MCs`nRlF;i2Y}&OUT{(T0j^VzW&IXH+RkL{xv&bY|O=8p_h|MAH0 z3{u~Y`ct@qLMR;CaS=vh6hRXd^i%4`-R0kr#L=dZ9)bKFTR`;DLy5o#b0e92iqnuI zL_i_GLCDWz7wB;+86L#}F#d^!WJkBd{u0TKNCgca5e57snR<{b$49oGz;-0|>;BGz zZxTBCK+}&pLGpn(QF>r2m_B+JcBr-Eo`n2}hJU&)5ahslI{<<|(?-6i0DbtS68K=f zI+`B#sr)58lA!H;W~1-13)vg5XkY86{>uDRnA@y=C)WpmF7!&vw z89CpD-K7X_=Di7bEMtCMvHA0|NOykvGRunBzw+rFH3$5$4{&}gk8_R!w7-pbBH$U$ zC;$HRhBxR1eGhpw7c?)_*nRy6xl)<68E5NaWRD5UCdW<$Z|!wUc+FIq0^U}##M4YbcCI@BL7~`CR8~s#oI~k6>QnO^_~G5$r!dA_YCIB zUVG@$ISChrs~33>GrhX-#J&6%|JE-TvF(VIU}~&^ZqJzvF-{(e0gxGLxd=BW1G#z2 z`$wAyjOt?LfJ5P8-UH}yVyOOvrKEN?Uz7Q?ps8M{>PbZ`hpQ(5y2uXgXi98tC(F9> zcp0SN^(;%wKnX+G#Y>1$;+1EfoaoLw_R#5NcwRXr9o!X9C7>oUvFy67K^T9fX%_rmd~CBXjsHU}!N&X~;2~5#>d%3vy@E$G z0)Z>kk=x8FbWoiZee$3;^^Zvr*LuZo`t7?7;k$a3RQ&9t3Z${r=R&~OE3rkPf4@?M z=v#co3m?%D_2F!Pt}nE21!-647PmF*A%HVKS=^4aip5SZ`xj`A{SxEa@t&`-AtUG) zX}TJj{!VSc$pV+?q(&d#npA=GAwLy=$vWliz8xMk>8`)80Yb^#d_LX~SmMlB3}c!s%t$5^E$o{SYbMw~B_o=Q%&;{h-jBcB@fV157Wy2Jvppkf zjBoBpbAL@O?97}Q=AQ2-ULhvUnfw?aFps~>e%$_-=NZ6U_K^gCACc*f9l^pjjEFJ* zatz4-@rw83uYU|IQcT3KFGh?RfHe0j>{m)ZBWn8<_9^dE4^8%Q%w#{IIA#`_+;$AS z4O7+|Uk19FtoZo|CIc~?&u9#@G91t7CWA2iow=CI=OZ2; z!DIyO7`gd+h3*(RVc3P?I!0ZX7bC??val#~#=hPojY;x-fX_|bnB@-@E&Dg%*P&!V zp9JCl=qB&qA1D=Bn*eFHNEE80=E_5M$9+F|(u6N{HPT{T_us;Dd$MxJhoU9^Id%7W zluNwXAMHozuFd|KPeABmFY}-}78@i&wU_^gVzofre;24ygkJxdh33$8;K}os*x%26 z4e!gN%=0|ABV2R+oM?*Qe}TU$(%H?r60b~uYEO5)z3o;HKR+b$zI4HKHuR*|{V2IK z5CS7Om$NtQy0)!J^+^wKB*a_v14PJskMyr#cs>F+(I`zZ;Qe!TCnnS_!@dZ;LuvF{ zmPC$%=gdFfpopaMJD|MJeZbo%bqe6;W7YlrVZ7b-yH5}0ruGl~PV;H=3c`*bO#RRy z=XWo1lgWE&WgPeb812MgJZ*OZ2vM|&ge)Exk#-l-$LRJvFkF(;!K_hSggT9|mDn?e z#l>XkiVmx^=YW?3DpJ_8;|{~I8e-1VpeXRG<#9H~jr-O$&V*hW#lC^7(u{3lGRi6{ z=*29uwt0-e)Dlw*n~R(qtkeqi=~ZLr-uF>cz7J4B}C^EtToeeLJAih&qi_~ zDjO+X2_VzLv3Nw@VF6euJvJEe)v4<%Txkv5S*H0|a=w6`a70j4duDry&0o0-KX8n< zRJ;IWV(a_cP2>IZ-F;rl`QF}^WV3n@TKU^M6~k!89IsfegTeWBEs$xMUA)w}-9>WT z7@&Yx1{vRu0eiU~r&ys9kQc*5z6fu!%O2i}%#-hl%5-`x!O%;&BDL@5(T5Uk;3@zK z3i=A(y}jE|6<1Pti2kc7nf+H(aSEL-U`7U6jG8S*se({g?Hg2=EuYZ2G~f=AfZlLi za}5L4xYf>JLbJ%D?^yA3cFr3@qFf*C`7E+HXmWJkf0md}{xjXOFKsh_s3!iqN@aid z#6M}1{rRLnF`*&EPy3~_4^KRq9`csyA)a|KvykZ57G)Ybu>2w3nH}9N^e+;p@evlq zsKcc=7|yVdx-fcp8~b)j9j(gy_Muk{9m>ZU{$YK|ek1T-G1bzCaM_ouXCIYKJUQe& z-{9ykW3!(= z;P-dl`7@_tKV_)B|3D<>2=NN=A1&XnflbHS9gu{zOZcex{T=?Vn)HWC;P@M{*wHrw zI6`v7W54#HEPp5&{_2QS45C%>qE|AeZTcS_kyW?vIPj?i7Wf}jM6G?jk{AA)i0IPX zcc;WN@7QEQ{Cce3-?Ui(7XB(Qw!a~9O!z$(3tQen*lr=~%YO*tcOf!}|C4h9{DpV2 zu*pj%u#Jzpt{^d7ZzcXB!OB9q$hlQA0f3?PYTaAa6ItNM`{jhM%QYD7`Lgg*J>50{V$|$z1kQl?*Eh&Y{+SxIs)p}X*X5^z6h_~l zMb)+5uC=|GfUl9sKY6x+I@u*V7l6ht&rT^HLWIsIt465n#WJxI@t%BBff|jZQI_(Z z>1wyjmR=A_VQU_0vG&$IczY|%$Lo^t)bv;p%Q9g1 za^b)k3!ZPIkI!%wul0lg@5@*so@Vr!6*66YvT>};XQE65?P)k#8(Q#KRq_}x%)>`` z#D41Hw9)kVM#d;Omp~J$*NuLj@g;`DAnNC{_`G<;%G+m2!$c>1?WdxA6h7`>9btf$9T)bd+?Dv7*}h5kNi;s)=ZvA(QQfukx$5( zi3>-9cWfnG0g#B7pj&_Hy{)x(<;MW zc9dRC$9V-ObbI>5WNMp@MivgQcg8{0)UXv!JsEt5dFoB?nrk|oo{#tLh({)?{euc{ zJ8jDF*0t#neupxzBb54wH-1DvfA5so)uPx5_Z`jY-WH9u=Jkf!kj*#d< zL_-|)-!XjjKoQ~56n(JoeKcWF>{D}29-&_JSE1QMvW`BA%Cqzc5@*y=3r>>9hzNSb zjKhz7-SHCn4Z#isg?!-Gp>LNSc<<=(B0gg2=%-2@Ir8X-96S0OMgJu_x*j2g_xT$- zvKYk$g(ruqb+o42;~c-9>K6P|R(S#RjlXNG{4Ln29*wu5E7%dT`>7B94_&;PCNx$P ziA`}w=-rc4iUV!{U-3qsRNu76<8?76Ot-#l?S~CK4Ycgact>9|rV*fW+0RgKHL! zF~_YTy@Kr9l{T?*^|K#(4xNSeqzzgGqP6uiljr z#^Sd7r#i-wF>0?;r;czrU;I#>K|G@0@kF{H zLqiX8|F%ibtt410V4(sPw|k)il-+GZx|LoH+BV`pMJWZY1$hGnjKefZk>t&;?x@|^ z;iezePx!bA1~Vy-$a!|o=tjm!5HH7{<8HBs?4(~zSQ76$ZrLgsfLVdW@EZBJ@$3prjiPfwjq zBCXg>Pa#pTO^Oa?hJ)L5?$9fGRv++;U&w3(#)iK&u-3biz3>GW+slRId->&0<|(}E z6qiJlE8W>rfqkKVrSlF`twmJW$AEa`#RS4ZJNNlTev!JAl|uk$eV1~M{;faE*ckd( zrFZAAJ!8ht8?5c6f@_RX4YL-o8tS3SMPK>ORSf1wFIYV5Ajy!{^IB7`nk8(Wh_XVV1mkvt8-jkEm_<2UBz-FLXPFSS_lhS=)AxQ$jp*4d(9nS17t$OFI$p+HDF^eh z!HZN{q^?EPm`fR}t8&2EH#zM=g zui0G9YQLCT+yat%;+@7Ie8e-Ub-4;JXDFIN7j?Vle4=Tc*+M11zVDve<@E|C{0+l% zWFl!El&iA>w+n(2QxTN<&3vulhNO?tb%pzzeG~6dx?oYA+cHJe*rVyR_X#=$a4)%T z~A+pg)V9S#rWzh3FT zq;h+t)8`fQU!TL$j|%X&3w>=}ufy@ZUr0-bI^D`2d*J`yGO6$F^#6H6e?)iWf$K05 zfd~>p5gbEt{AWlm`p6(2rGDs9U>_w1LLxsbE>w8v7Va1g4G)+`(mUY$c}pLBB-RfF zMC!nVJA5M2BhW;D>h$sW!(yBq#e_SKIvVpn4fObqe9R;}AR+SU6HGo8i~HR6 z5%>LgawOT~PnTi%0dO(&X>h=fNY;)`DfG}INW)KKBK?t*!awc&_(7C|#(#z6#M_Z% z=YCgY3LiPx3S#tz|1E6)iFf7EzttdGH_fDugFiKh922n7V=4|Lw;KiU8<~p^-6u!# z_!iw!9Pga1H+u%c9e}L?-A6Ze2V>J5A?quAG~>~aE=xfp^F^ON;3g5*9fZ}nc_W3k z#8#zZ>aQ~xHR*ng?6e=0_C1xc&j9`O-Rt{cL*VuOk4^2WW5Gc1na-b@qdwZhe^Pq< zQU$pkefRpO8nTAIFcr!h@M+55zVH0g4f;Fx2l!7n=mZ!_P}qaj9VW!#R$yVk=fhTuB99F zN(wVU3hI4QaYx%Eq&1>d0yw-_K>005?d@7Wpvct4fQu$L8p}S!2d3b}*Sj{MAh9SIRCH$%fh6qNJ4V$F83M35azlGLsy*^P=? z397K&C8J0J73F{$#=3r^TFS>#=-r!as5?mfYOjvLJQPB6#EYs79Gdwsg==9N)QXeW zSvxkR9=u`+$j;dAt1z)aPn@E;r=m{q5v^ky9v~iEN02*}t_3<|ErWB2bXw;q4HSX5 zO*Gtbo`8gpGa?XC^quqale=>;TBi5YGm>5L6_$@}wuuE4w_(DldrGQ2y095$UOh*= zw}qwwQ%N+oQR6Weyqd9_Io@*CcpyCUQlWHESHg2+%x6EDy(FAYulmkBtEV7dE78X- zi2^otQk)%9&k0*R9&{63BksN7@GT>Z9=s^4n|bZsx9v(muJ7B{7D7`zrxUrNcTnA0 zU=aFv+HJA`Q9!Q0CwNyUGRxSRqVtI}&OCcKPMu(jXRN(H-ge9i>@k zX{KEGQl3m7z4B~PK~Hy97!&}-NJr8%gVptyNlW+$Qy@|Ga&IZm3VX2RTDRqWeN zPN!RziBC5RqHsC$sZ0Pu>9#IYsS&KREuUi+l5bFwNfm8Da$<9Az!E2la7&eUE)G;Z zX*TaH#Xw)Cx7lg~ymvpsBv4xI$aMf!=wWm>>CO4eCDw}AHEC{~nlfBf6+fceE7T1N zg61~2VoK{G2EZuP85t!)LVMyITNk{`pA8NwzciuU0CoM51LR)_K$;H^gb>9+~%V z%sOXO0_f@ql<^pas+KU!{gEZ@=t^9N2wsw@-4{VjhDbAr73LohKm7+nLgarN!Q%hG zmHr07BJ!66i$_W}I&!utcJ!|h@zI+CK?hwT93Es!J9Z?=PYX--8xj5-)Y1oLMUqe6 zlsd{r4^5Bs$eWVs5lP&EEQ%Z*J3G{jvtuKnJ`x|lR0e?${^}ixlGKOQf;#$W4?ZdK zAa~kd9_i)eC@RH2YNphOR54DD1|SSSQngY15g_?+Uqjd@`1;|vKz4MC{Qs9=QT~x& z@ldvc{y#&oDE}jZ#ivJikp~uAoqC~X+)BL88VV^KpSdRh^So^jxZR}g`O+^a#l>oH zW7|3OPl{|T#WRlsGGgOF^dt|2&Y3h(s`YZ`;lV6Lc?N{eCW3*H*T$^!)Yj*FeWGi6 z)}g$+GAH3RCtYkncmtug6)&y(W#BDUt1`Qh2uCRaxVYHf5U))w3m_V{($j#K*Vd<_ zGd?}RAjS!MiRaf!le-C;!K}JAQGeqo&L-sW^#rQ+k{g7bYQpPP)bO)$CeFI#reJLi z<7C3akREJVTF;UbCRlsi@7MQv6&?2~F&r8Nz#_v`p6Tyc!C$B1c|{xwUI*o+OKdI^s zUQ*yJfXsJCfcbe^T?UT^FP(}g@fIO18!4;Loo4Cic4x>*5TvxkEDVY*w1*#%{Bj&I zB7hwBo|z{1rS<9~(zs%|%fD|Fn95EWjZLN?s+}6?3`%&D}>m3epcHGZr2^e+4^8L2Eg9Z zD^CdX^0&nskG6-Y`)ae&!G{?E8Q0koeDses7WZ*S2zwJKEjFdZ^$oMh0!BB7^RA+)*E@3iMOPbfobW2Qf9YwyPG zr__SKupUlf&tCNINVR$y{Y&csegAQamj!%IEoO%dDApKa+HxB&cU4UwN?2j!fOE6XZKyXK`tp& z95v-sB$6y6Wnfqv=2qdXZd2#*jJ!D0Fa_fe<2D5h-rZkX= z4mMAEn{FZ{aTBBhagXfFyDv31)p0LWNba-^x3_RQn{$<4tPPEX$BH|NvSM;1Eo#QA zEu}h5k!O@(mO$Dq-_1v6v*ZsJq3zAxW4ZW>e3mFYHIxc?El1WiGT8^fgflM z9?51$4PT0vT1-?96Kj#1}mH#EBHzVR0X_(YzyJ-MZRFBpTMFf z_)GEJUb4>OOax=}+WN|l+xA&K=E4n^cNQZ&Wo)|xd%|l2;Cf+5tf-K)%~!@mnuy47 zC1uTqp|Ar-x>Ao<6pGN2z7={fjjQUFfxa{w5k&;v$G{_$gtJc4_%t|h(+iw-Lzm%x zCrQ&fEtoT99*j^SO~B8V68!RMuZ^Sm&QnFic0@R!c@#wKiwb7G3Zmenkg2pVAjh^A zQ;U-y>3osSEl(4m752IstuZR15B4-?x?w5m3%CriZ#?4wF(-Po6V@EggwLYyQ(jx6 zah6gdP5!niGUv_-lXCoC-U0thJSgtJ@BgY6{DWEg2d8~AQ9nK9&mDavgdNo*1VRu5 zjo=W85(o)HC`mvBj$;IZK_o>Y5QOea#ZNO4`+6RI#1hf$DBwUpR0xOC5cZ+;`;ZOo zz7CokK2R9_)PC(A(QZ1@@ZdY3iKET#@b^ARfPH5~9VM?6eC#}YtuG9`9~DO8S2ZPv zA4VK`kmS>BND>E?;O+qK7uc^vBOj`K{3uH~*mn_y{_jv0#*bPV^ke%D zo+9i>VeE4{jPhUFFTp=*CZO`0{ko?@k*QB;6z{J}Ut(BiwQdTcdl3A4X5wflSZ>^( zErMA?f1nZQY+exH2o8$iBObgSgtt)OnjbUtty|9)oIf1&du?m3-B?N6zE|JwCP`j* zmj%^1>#%PS@Z(O6&wrpTQuIGiE?oGPwGx+hefNvrG4Q+KF}5$E-*_3EKOXd5J4xpF z+}gB%RB@ZX8pf>V_8swOh*jRgY)cpPjMjWu^9DOPz>+5W5)0LnX1t1o(A2BM8VPvD zYjCo#WF&=2S?+@~W2dno)>Ga;MUsQKha%*M0eY>cakW0SL;==7oqC8Idq7#|k$ij4>TB_8PNR z>2J6JkHG~xoeg`VJzjy@ysh5R`LZv8x2^y%W5J(|5oX?Q%k##536Q{QU~%g}HR)u% z%c|SDTBwUN2#bl4kw?V6!K*d&nbXtjfqOCCra;EyTvPl3*=4Cx&A;ijfd`B zX?L?oi>D?hn6?lwe#u<(Wi#}81v?;&7VJUX>Shv3>*`d6pEx9r`_a=|*ib3oKj~mh*fvw7sDZqeyvBb*qe-~(;%uc2fk19Tv)tm~x$(Un+RC|SEzipl*1)jw{&{7!&EMkeT&Dtk9ek}oD@&=;A{Z3(oirT+P=x^vAfv1Z z|BQ?*Z$pAC>aL64F$L@GoN zNVuQ4#_N5UYDU6+gI8E3Qf6e)-o${y!ls;`|qPFhxgrE?NMDSmbD1;x~9_mw)5q*haCr4ml$56YE4BnV_3j>0 zMgMZej+jm>GuPOanbZcpA*j98^_YBydYC2Z>K&Vn|tZCLM}OP zGKX{XU0qLHfn{sx#RL<(D0T}+5V(?048|B1B)q{T4Z(XbPc1yZbTH4aJ=kgGvVV(p z0^!8fi&pJ%B?a+Okfd;Z5S9r89evVsWjCG17}JJ$x(yWp`|Ele<7~)q_Ay*JFT3#0 z3^opATrVM_Jz@8>8dJn1PzA{0(KWt7JEG?A)Hr7~Y$1q&PMMPO3B zZ0@)9(ZaJFbSkW;qkee;axD6I#Z>|9Ne_e=#jtSt`Yu9ejX=Pu+0moLXAEgm{X}y% zAE)+-5eCG&V3jXB8$hL|Io{kE4lX25@fyap;k2*fQ#kHUv|L;<4aPSqOG{y%Ia$su z=v`aRWk){-hNcDZ((jgt?s#&ka?^Zq#JYdliy0u{Wf(xYy*K{AbloVNZTtnv=hr)u z*Y1=@RYBk1XakTzxi#(%VNW$o>!7^43|x;a63Jf+t)!U7H zm#P-MW>gV~&lo${iv#~pp(-*>UP<#j`PWr(sjx}N=`FNkv~tjYKvjyAx1n*&Oys@>9Xt9b+gFySEW?h0A!rtGOo9`@Yw z-oFd~^-#%dnlIBL+V;|OSnZZgq1~8MSBTQnkS>n|w9dfLm6Zt>c=jYOy`$+*8(v;F zCh$XRyc#Q~%@S*!P8ezMmRw!jR#OoddARAD(M(7T0rwOHqF<$spQCqk!aSx+J4mHh z9FaMSd#8+CJIeJ{`l+HXzRSNGI zGZq0c=oS~r4gFjl!n>d3H33y z6q=La4wW}!cGwE!Nb;3+)?kAA^3bOQNFrHx%~TL>8VY(?R$w_?qxC@{xbL>oY z3isR)uek1j`z^8dLY0p$!~pj;Al3#2RO$Ud_G*!Y6`~NHFX~x z+Jf4DA623MJyiAU(|(Dn&>v9M4wxVsA_*8Kp&d>gp(z5TcYK8-FixTfiC_qfk`P5B zD2-D;EigD>PjaMN!sJNS6JIhD@BxRYk8%Wr{zj7rdFQ8k_2>Oh)PcIb6t(W~Dx^NS zn@{;{O8$mI9~F#G7%Tnsj>p-jZ7JQa{3}#N9WsrF#$$Rgbnb`lS3dv|er)fP$*3cm zMj}T|?hz!*j?2T@hfw=N=LvmusSch_`bhgE)Dbfy=%WP+`%A&8e?wL3%Z-?_Y!P%g z!Qr(h2Z-x5>J}FNz7YOzKvnO5Lsf@J0P-WM`o8mjF{;x3F{;|$3uXow`4p72)ynST zRKY3aH)%vDLSAnca9W#FA3sNO(2>>~`f{CzaFZf1pKSYb5_+r04Y}7&#Fi-uenouw zeTMAxJb<;2aifIE3z$g{U4*6&wG%-Wf?oqg z@|JbA06}8JY6UY;PWsU#Ukg?T1lYxXwi1y%#Bi>uZ5a~$gx($QF(^-MBU+b5N>t~d z-8*Jz=_Lel6ylt~^k+NB6R+Rxf+s%*?4Ow#^MPmBk`uh>1A7h z^gXZp1JExJTdMXXhsjbId^My?gFjs~d~#=h!`L^2l@AvR=eTXCGouwjNT8VYZh-Oj zEVTrGutvrt*J4Ev-o^OsD#b-D0>=}d(~y`GZ&-Y1NK-L^7bAd94au#VFS9-1Yj)ja6XCx04D9%mPuNPL!lL5)eKCuNnEn7~*NAtMvD3=nuH*BB-*-t!-@ zb^b?GwHBHAx>Qf5Hs0bA2HtHpWwkv*7XJZNaaMsiAD$KHrvAY{EEIjU+C;D=ArKx zC4m4j3bR-um3={`?cNWw!3@ph~sd$Tu3}TRH4k3nJZTs!;ucLi`$Yi@$yeM zZ7^6#xS#yw;k$#}u+i%!j|F{SB_*31&BX4n7x0*!Cw)ZC95zdkJRA7MB#emHOsA@G zyrZZKIG-EZ>Y_FFW@WP|cJ{g^Ug<>h$rVyyJTmTPB}4WY-!7HaOnlD-=IC*e7S*uQ zTq$nk!nS^i`mKE;!%@YGP6&^l;oSO%e*-|eIF4u63I?JQ4@(zcZF3CVBhGRd_{ zXQmHgYq z{uo{ICUx5VG8j@Y{^ z9YXi2VF2%?L6my`#r8%fKiEO$J_~%i5$vZ-mueTfYw$nDeX^Jws)LJphb_b)j$DUz zpz)F92FFz2kNdQ(mA7R^{=_ZGWLZB|jc@JLM=dq(Sn(AOx^6fK0p1gl_BY+%ZyH^g z8f0Ua;rfDu2Hw9%?Rx|$%P=9LKw)i{7rx^EXkXXY&s0uRp42y$b8l0pKew)@(=N30 z$FYK`zUSKf?QMU(Yv7-3`^&C(iVg5<92?HVmh@#6BpjCYrCiPRaC*eDZO}l2LzWiU zX9V*fkaVE0K`E_>L*>3riMOt}q*M12Er(sz>;rlskZHY@xMJr8jh0zod?^8N0- zBG~~mEGMbgGZ0w$hH7%vACP6brArNG0zU|_t5N*(CwzPFZ4m+w-NU07fq=*_nIu_^R!DQiRYD5CfpqXw@^2mDk8ejHL3O> zTTmP0AU!hIIec7_?1WQ#(Ifr!)}hB5nbc<4{E*&M=IPy?4eT77zsJx#eZ$ZM7{*j5 z@QKy7vy94+zVPbs+CW6L`VI6K49(?f+l6|&0NNdEMLdG|m?X2pdx0%-in%oMJwGq& za#T-CkZ7ir`}ge;kEO*p%TIV!@_F&0j=BI~A=Z=I(d0tn1i3}`;^_o#Q9ex#YXno0 zYTpJV56*)Fza;Rw1sK=D$a{8%m@9f}a-gawRX@3!emM+G{6b@YsZWO#QAEgG?x*LY zl3qqb-?RRLFIV0Sxxify1jrVqeFs+xV6Y`0hmr}abv46t#C3egg?jONBA{>^MM4r8 zu3Y6sh_;6w<(@q#7mwPj@9T8q*cYHG)axaw2g#tDCt@D?MMRM{GHe~^23t$%13peX zbw`Rso{+aaClRLyaLJT4kja{IA1(HGMqvNg{UHC7PVpBP`?*s@zIBQy zwyTm;Bm{yah9Lw3Q80;+D1~jf6GLH~pgx>|O}zP@n-@f&cg5#ZG9ucGJ4n3GnU3FK zzaPDub3dlfB-q|i;J=4~?Q=-Ty{|WX``PUv2=3x2n^TLzcS3;N9q#6&5O5bq`GHgX zRKa-{jnHrx#@@Uj_~|r!FCam|XGZ7dT7$iIvu9Ga)%Thd{#Jp(_KH;iz56$y{T|V` zrZ=*uEq>+{S$%hkA^abwhztH9Lz2hU7Io>Uh!WEi94#?vx_zd%Pw!^)>GhLm0sf6c z+&v5MZye(8S%5u5@J}7$zH8v$IK+L|z&~?{@)W(r{=z5l>8E;OnAGZ0O`|WVlGC*2 zVZ_qwCudkU+kU@|N^i%l&VquFTwm;w)FSZ!xs{jzUV|oBGzGd-URT*O*%nqD?YhNc zO-xrETp16wFf%DHo6}2nIhBqQJ8BQ?oyZf2&;Z?_Z+FMlpe=SJStM3oVlSEXFFOg~ zBQLQzi7R-8ThvPh%NG;{m$*2@m9x>6*>?{VKu=1u!K{)l=&HR40$ulpf!Lr)rUi;{ zOXOVRRp#k?qbc2{%r%r&Z7xqw)B6clSS}}d`dIeU0==xv>%$j-w_f4bwotYfGyI*tvOnzB*AkllD!lk73;oH8 ze!Ixm78Hdkgg`e-34$n25t{{lM;Qc#fd~x3Ft)w)VNN$jcS}V2d*K>GcTzhB@3W3j z{9UDv_Pptyvwc(OQS?It8olF&U0RBI3mD)#`<}qxC*k{uV*=UHKZx&i!Z3UfQBL+~ z!AE~!KsVF5t+@TWGw;FOxX0KYm_W!L+-&DZ$Xk00*)JKzyM;|Y$t%1wzTrE(K;P+J znAl1Dn@Pp|_hjSXcP#m7R8hR63jYrSO0V6FJwyHJvxIaq=Cjt|*oTc|O!mJORnXJ< z4{H>CZH>NH20iaN-A@VMl}6u;{es?%&km@dLl^qqTh};r=eC!X)j!Ym3_vpxAEP8)FoRQY zqCbO*ia31_cHr0=$MPBEgE|;qdvz<^8#;Q6g4`Q*yI7@5!LbHBVgA%yj>|aKAnsij zpKwPxGk{z3Jk1Dm?uaeZ+_di)->E8 z*>yuIo-}_eGu?-eF-}%Jy;s>x~LV~>y32tR)Ntdy$QH% zHpGjmE8Rp1oaBj*;7K&{2FX#m&Av-p0>7HK%)U!onz?9QnA`@iQ5muHh#$JrAT-x0 z*7C!=<$HwYiD@KJe{p42;OjZU>(B)@Z%Ezb`_*WU?Q7^efjUeMq99UnF;!P+w1-xZ zrQIm;a(Nx|TYutZMKZ<HL(e9w-W(AJCw6H}4c#HqnqB z#eRa$QUQBcVhBgVu`cS#b0Fme2+{DUkK8IN)AvA3DD(P>9FvguGRgb!N_* zE;uKPpbH#5&7x%r3mJ%;0|UtJq}IOh;t7EX6Z|6e*^Orz8#>CC9y_UiGoKk|E#*WU zEHJ>YB67?Z2{Wit)O|As+UpiGDPWM;Qc_eEmtRh0lLvNyBM}$6ND_nF&+Ju28)znq zMVSTYe#ft#SL3TBzXu}V<_BR4BJeGa zK=vVoB#PiDgnk%2?D9C#p6tTjij7I|9)}a}janNP2cz9rQTU!+!?u9n}TdGS>I1K+nfJOACkwz=Kp-7UQn z>B*fCw*9*c48{AN5%@hK5!s8UJ7dh>Yo6PN!S`&SJ=&pu-=ZV<-3bsUJIQQYIr=F} zjJ@r>W8wV|-^bYY{dE)Lmb0J<*KUwM2x0N3;350p3Lbvl@9lL?;NSSY-R%MY#_#QJ z5BM8?ZQ0kG(9uMN2mV^J8>~)`+8rdiNG%1Sgkurp zv;(T~@Vp>T{LM?hPC?w;A>~lQ^Tdb)!7{7qf(w_{;src zUXuptPHgI4KHodP|6Y8Wo;>X`1GEH_WIY}EveU0-!?9`Ygh%6|JeG?{yz2Y{X_+4t z2M=A4+Bdo5S?;y^hTNC#P!C7oL0=~I?gdkAD5HpJo5!#X|2oXnsv8dJ&_Qv@9+bMz z9eRq-Ht!vsz9OitNN!Cwsa+K=&m7-gWdz*a3NyHn1P5 zr$y0jZ}+k0(VqL?Ow)Gi7ANc(m$x9qp6MVzb7Z$~_wLpSb3(SuZ(+)3X2?4(qNv|V@~1qI za_4~{`G4%D*9SI+s~7W{t6EI8NCY|D_c6n?#|-)ZR?NVEk{5d0&g^Sz_D5syS4kJ` z?<8IF|E;9UuWxzZ@!uhm9I=*J{SC@v0wmoyI+su7O2|^Pq3#V5BMXoZnKzAm+pduN zM0|hsG2(=3%FJy>ZyrmP2|By?oj`}XzG;>vI~$mAyffx(aL^?I<`%VE2R}4;gd)Ei1%whUhe*(1Ozk#G1Wi#_Yqqu^2`mdsphh__RR zTJ%tVP$fkQZGQIMsDM1j65$N39p7m$q{`+1pAB{0m=aRQ zZrsJ8ZTXWi9465K!CDyb_2$hHb!BKy1`>U-C-jJ10%_rcm`ILSyExOmc4wdcU3PWR z@}pWjP!D!G9I~=4ZhEdI*(*qD4cA;?lstrv`CCO#**Op`X}e;eTB=nE=je*o-PL2F z2*W$!pxnrs1VLWst5?MfTqlQ)1caHJvk^s_XY1%5rpzI=)VdF^-XBjncx0i{P8x$F zA37mSm&4|JP)TeX2s@RpngIuZit4t{km~eL>ABxWWQ39w=^)O|U6+vsYi@@auO&3( zK=S*5O#Tm%CNsbq-!|r=(SQEG-51lra?HCSf;gh z+QWchL%e%nhemW=FY61=gfRRLbx>uZV6ie9$c|^5gRIx0sl@2k_o|!8Q}aCKrARFi za4_OgzT7dYjuf@nTb9b)0?lp_KyDc!EpDLvqCM&5tkj@S3$Ac{w1Lrdc!31wJp>Zr zDM8N*S|0fmLhL+4tqVJx%1>Nu)s?3y;%KAszr(3oJWSmK zFpaLV+!{QmrD8SDw@Jmi%UPSik;W8;6)w8Puxe(@12!8``4AvR!8%L%LLblD~^_T^a3e8Q&WxYP^ZC~jzOOJu@M-pl;st5i2-zkq@0+7qZLV9 zL^WQ6FL&^)sRt8OkJ|PdYF<;N(U#9jQs1btyxRC9KYem1YhgB>iw zYn>^2;k- zf+@J18mEDonKSRh=bM)3QLx@f*gO0(Xk%4b<<#GFgZ>Mx+s|)e=^v1F|M4PUpxVzD z_@-0_LKH}CAPqwZjD$f7L3Y{*gy0AUqvT#VL!kE<*FV8FDA-|E@GdBAum^c7r0lX< z_)hiMCm6gXwvy=gcsovhOdv`2Ol1Mc|`*{2Rk@bpRI(15Dd{ z?@x-TAi@gjO(d3`f-BSoq3JM~O@uUYDU)snLTYvgC*fH_T<0hn6X^i$iWEJqXT*!t zD>4DI0+kL079PA?t(-egIK7(YstS*bh(}LqE|sJ|Y6#w(RvaN%7N8jYa0m##&8b_0 zRmUNjn=NFeIGVfX@z7nB+fZO>C`iKriG47bxX@T>jtQKBZ z*6`fcNroC6BS1cqapo+zw`r*=zImMzZpm@jKeVTr4AaMzPXI5%F6{MLn$KoQK^Mu? z*JIs2EgBrDVg3x9De zx6H+9pqzy}khqQTHBJe2EEV_M0LN!_zlGH6`J%-8m6(9%?Ffz%(kjOhA8*=KeKija zyu^8w^UHjj;oz0!cNQ(!?A|e2)X-fM#;+SUfYj6TGr+iRrVu|soFU2+b7Ba=C8$Bo z(P~8cRLiaQPM2`=D9X7aJ)XNd3`md9t2bM%Z(mqoq>{uswYJ_J(#Miz$@bVxxb(cT zr>9P$kB0Vys5`JHHU=Rd2N#H|{i7~t4L{+2kO0CXNZ}hrBgsqC9@+7+%J{XKVog6W zE{VF~z3&Lgmxfgc)w(^SvVz?sH$6R%i{Iu?Anazx7{qH6^xE;t$Xe_SXA_Dg5f0bu zVYQ-XqaW`4cg^sBKs{i`dLvF9=mNpp7f)svd?1S4C6scJhaV}({-+!ad{Ynp02sb; zA>GZ8ro~&dsK|}{s(?u_Zx8ma(yxZUP#g=lM90D7<>iLOKzO2t)Pi&E zx-uQJdCVS9e!BPi(*xKsGq2*dL9KKnZLXf@*Y!e#{*>p!G{24@JLCke6RdY~J#@0@ z5PC3mTU;EA+YFZk1dsD6OQg1Ck%p42lILS?=@GDSD!14C0Gl6A*aH~|(Ze3F;rtDZ1#d z7r~FhH+3rZlLXIc6g24Dr1QO^tm@TbqjKrzg%hYFxPIwq!72l?gBBZLKwU za#-Zw13*)=ErN|Bqig7BIVndpS&(j#i8)CIu)KnaILdVIb0r27`kAES>fSf-afU&u zM3)KxWfndMC~me!4#8N@l9H6%9w|whB^H9pQy%rQ6UZ!HAYt;v*{RkfI za56-8Za^4pfcB?25!opLNbI2xzE44P2gAV^RI3b_^bQ; z6}$+128=XcTaJUDpGDWY5C+1!K%Xg;ZUiGojJbOkYsfvN!N0AF)Fqu17#NBr9TQ!n$+rx_E@;V{cB{pyPi}76O3`PEMJgNs1My}TY25benVDkkx zeN4`~D6BgJxp0V-EElkAP{KdCjIM@^S$bx@Dk+5-2WySB5WKB&ub2Qqjn8AFt9}@D z#fdeM-aK>4F_WK!T&{y2i*}PAP|ALxGI%O)r|GzghS$k3f&^uP1KUbflH!%u@omCM zybImMnMRlr(x#KH_8tJr{{smJ6J&zv~0N6n__r=|0h*fcg8$AHC9jxD8!qoWsBLeM;|sqg${ z)aF(mZgizX4bCvQ32gwus92^S@I!n}NN;ws#g2L4oKgieR{1!1iER*1M|L0Eqgkmz zs!DjXm|_?*E2&s7XCRgX%YBCzzbVjJNPWCNADz)tR;r%enq(ugyKr9L{}3+%AMyu( zgcpU?N@(OpO#-EPRmGie0${br>p?zvOhX26DccQ(ZU!U13pc^IvGKWLi{ZRJ7zG#M zqo8Qh#R%qlP{+rVnY*%-eV23+E^YX_Tu{<@vPb0gRI96PJWiJrWXEjj5fwQ(d|&eR z7OIKu=;V)%*nXD{azp^y%q>B*H+<6&uGEZYsW%FV^_^$z`c*aLD|tDPg|7RgE8Go@ zPpMU62?5P@^(YiQK;CrWm`f|Z98_?q1XpvI3O+odM!Mzb1a}0fFd;S)whk1 z&rzYJ$VDdap$_EQ67t}@D9V9^oOAMQ&Jh|^eZftJb9elg9U8+H;vEl8Y~Een+9Jws zoSb39o29$PfRPZ9;+%59h^@0sW$5A)0j@NnAw<{!M(lz;PV2~ahlTS{$EpPZ?1S1% zFU>JQQV(#>mE^Lxp-GsmERTK(qkN&Uh+4g18MkL!JAsJ)I5+2zzENBV#S;bHp2Uq@ z1gNHtz|%mIQQJOTUhEI1<4ZS*?`)Z_8DyV;e7kQTbAH$3PY^^`z#lKkRo6I7NfDl5$2myl-MWH0L z;Y19lwr^1sp(p|)U6nKMM(8mSg zH#al%-;{XxJq62ubNk=48JyVbz#HC7z@5msuNv+od1AW`_yfdttRibISAfqrRaN7*C!oIuS|Cv+|;Bts?$k1OF>G>Pj=;q-L zgR!@UJ`pvFE4v92JT4_S(w0RCiAq%95zSBQ`bw<4X;R>UDu=6=Xl`iEbu?AwUG0)} zca2;=LX-9$*f9Kf(OCe)q^u%46@QqzfAMaQ@CJYgtVUbGGmUdY2hsUB{=E3FSkCEmgbd zu{{&#q%Fr7y=$F%%=?Qtt83X?AS-KJE7iie5JbrUQ8&B=cR*LXk#bc$uyaaOs=J|f zuUQgLshd63GSHvipe*;Z589C9XX&p~9Y1jjjXZ5OgZlM1*4N+d_VbIZ%76W)qu&|q zf4s;SOZ^w``o=z^2u?sK2~#Kq!xWC9BuHWu2*c1@2ah5Mk|I#zLkkUqyXAz5-A+fJ zX1RdBQ_(vB$KNDDfA5^aJ_XA0hZcIX#M@sCf6Ja-mQjwQu(UlklWBWX>*h31| z^yNF2+GVmhz650U^VsTH4s>{L=M;JiuA0qOyp70zhD6iDc4bi3<%!q6a0}Zr@Okcu z>EEOAs~5Tb#cy8wG;(m+?B~vGeA`r6csKxO%5R#ZYSOE0YLfyz-dp?CodG}E+OO^m zkcD#Z6Zo3G_~i$+g&QHKr8Gav9tNURFKT#lElTf9tL63pRH_z=fY7(ahDT3_OY2N_ zqH3>peI!w(y~udd*d=IW^+<*prsw5zsOB49SYwFGXJ29E?RNqEET8?&sI{+WwF$-) z?0>>+VZUUyuy5o%VS>a63I?g|4~T&T4C6Qn;uHx&yUr(t5_{_>`k~pP z-bix$*h6n(GZgPBzP(A3*pqk&xhMMezDoE#B@WHL56l+yE^`O(;`z28B-+!OVDc`D$GbU1(B1fLaCeu& zN_Hw@g1zx4w0Av4?@_Hjwr4LBd}mGW^>*;xze;U;{VA|K@2N=N_`__uLM5WCJC2Zp zu}v(6NhQIj>3eeRKQdd;|GQ@EPh0zSv-JV%`fJj)4q9sU8Ym|?wra#@2a&uEgH4>< z3vLKy2#}}Cd<_{~x}kmxE$h%P4hA~b{nqIb3~`U1J$t4mosllW*J*u(_sI11m*!b$ zLY6U*sV}`LYa_#qGsiszqxO@=u1(X6GUnk)pYt?-3zdDt_qxSyYlyEWLq0N{f7D1# z#NgwmHBk9}E`X0%*R*Q4d|!<)>CR(XF{qcIha>Ex4QMPeM0(2Y${6>nJ=7_HL0Dv_ zBi9H6Ecvu3=EBoWFH;yvPyww^^&o5y<^2(P7h(}s%1}uqVxL$l5PyhV#caJOB%aLb#nv-gR_TU`93zLfAC5`%l8278Z{2#|dh`V`vKz-F+S^n%9JiUpy)!=9Nk^L*-ZKU7K6v=&{OV{Y>OjjE ztH;w~o~s}CVEW&YlU2a{YQPbjPPT>Und@k&ce0l~GTgrgCt=*aj??;WA(0@*07I2WYuCL4vh^ulrF`Y^oN za-7rI13r;d7fSJZ5gTTS&;FUm8{~cmE~P8YRe#vz?f4`mg47e&0-`L#q`jx z@eMV*!c5naZkNmP0j;bz%aO1El6dv*i!ykfJuu+4Ym1v&4lkOj=OUI7$t++9v!#Fx zPy(y;v_H8q>-XnlWr)0W)d6ZTaQB@0^(_(k1iVkC<=bcHrBS!4D+v`tUff(_nPrV# zUE0@&PBAYlGX+N|S=3(v%)k%pQwt`e<{zDNWmyH*mP>h_LmoQe;ryD9672fKrK_Nx zQmDHu4zqVmAS3H~A?)1dXpeogD}tTb6+y(;y@=>M%7s=*W|qRZQ>06G zc9HXYJLiAX#6l|6>#J&nqXr83A z5LMwK9f4r$`33}XNrd6q&aZa$lDUU4hiAUCL-5(BC1KX-Lz$G`Q64Bfj|IRK7Tug`mT^&XlD*-MHj)VPZ!gpPBu;lqnVqTtKqsgDE?fL|Y6s9Rmqoy#g7 zm*O5?vnzpJ+X%QQi)DYLEA<|8&eO73M~r#BI4MfhG>_*`vtf=Aeo$i{fi@6hVd3)@ zK1dx)M^v{7(z~v1^wdP%t0s}M91Z1EXh60nm>*KubyhP{;Ttn9*2}iM=y9v_1siwZ8hDR*@{#8P4O~1u&WD*29iFYqevVNa5@p{ za&3}IRJ@0ORqC}e8~fZ|ku6rOt_O<>%=Ti^MToJfAzd*_vDYVnGTwoohbOcWPV<_E zD7Z3$V(p?uK``})m?agYP!*wzE*Pr%sYVf#r6`+oaa6w50m!cN+%e6DKx2bSPC*b~ z#1oa4zQJbpaMyxW)1~3b6NG*ha)d7ww=bdsVQx^xfJZ(m-M8aD zI%v(w49eafRxWvNp+RQl{rTQS>b)sZr$S#nD(oz5fI=DKau1s=nE&+{^kcNc+kXI_ ze}lY!X_>#qUH@6)d(^doF66@^Mz~ih{C5jkOzzEK3ABq$?2T>Y9@`P`R<{i_ZNXgd zgKl7a=c5quj(ql*GT7t2?f=_J8_pqiy3C%w3gR7j!PI;0Xn)%eQ)K9S=mQ1qI1UYW zVh)A9t0DLvHSQ7@ZwR#^sttQ>kSl((V7AB-ek=UJyA&~9u6yw@>T>@j>MAF3`hvQczeZiU?fwUOeVH`5PnF!KA)7oV7uDYMy8v?W z$H7T1GG7+HS2xDwuS*9UW52Kb<-)*sSDq!4ZobT^ya@k+XMaLxThMCfi~)R+KHdZO z%b#@AJ_}r=Z-EQ;EpV|p50s1!c~X|f+8MwWEJN2*(<5|UqR{Cf8Ur@cDTRtBJi9oj z%r_;hFGmYEMUf#W`|iz-u?p@f7+NM^51HRVj` z*rRZy%nUB|+_k*}BlnIv%{+>?K$j@7zxnJFhcVJ39EryeF_Rx@q}Hx}73S#yr19d!bvBualWsc&f+(?aw6Z{C zRmJW^aJh9L$sS^9W&uga>eljxkiI(nt-9K`Im*iCc}0$r?oax?vr@|iUpXH;YRKKj zo?&T=^$eE3`gmdhM=!9!06R5Sld`yBVRE=ZNFreo_L!6oS5B{6yN74faCgcM&p~r z><#Z|k#(EgB%k5r=dZpQujCXwQ{qorlb=U(Zi{fYXqiX5!_=PeH!EdyI$0`U6P&Y_ zj2LQ*IStD(R*UXop+`{np_v#C#^uu=LZ=>`~;23zB zE^1iynW9mPRO|D|9U2p9{i12C@?a3YAo1O4ZAmPfZ0E8ZOrw*)8d?n|$G8>;JXr0j zVII0R>5n1>+mCegdMX(Dy6lxu7)QRjVk#l#&%7k)fJE`b*)^l!Jv#RpCme!(ja zy~h%#=j9az^$_*$u_~3;fI%;E zyoLG786;1q_=-Jm8lFB+OKd3^^n_k<9&0piKE+FTgagFG6EU&)G6aZmb*_JB2KQxy zHJ=C_?4z#ZF3i8kp}a?vs{eVzcNpt$o%jV+{q;%TU@8QrND_uX1f@_ML1BafF?dgJ zk-MS*P9hWvf2bo6AbYWd*?p>p8d5;9>?#|58+-2Mf~4k>_-i0(O!kzu1f{`xUT5U5Fvvd zV(mpz@SXCH_u>Qb9v_B*`(Gs3FF?F&3fslD6F2C!ZDMa=1NY=zjO`Q{KmNP(Bs4Y^ z*p%M>SXQy{2DJZ|{z#COW2BFC1dJ`x{nBhD8XH6jDt(C@1(c1=m48W*&zQKQFyPb3 zZ7tQ{Er7Y(iwjp@36{L4jecf%Xgi?;mdy=Z6_@oB$zu!2zByPh(%;aCO3Twa+&r|3GNm#BM4KL)ou7_4Zfl6-9RfQ_E*+zd{A`^~ zJ=Gv`_4@1y-tta@;;bfC)_o-RLZTkyXaR>f3)yi!){68B0~NF|O3e-j<8?)PbG=MC z-#bo~@D_Q6={8p2`=xs=TH-#CWFpcQFu)4EiAtKYSF(;C@FGh&#LgCd3ZbA;k91W` zt%6j&bgARMOO>bP2``5l4u|muau5*M5B?aU;F6nR#L9tVZoiib;c3HxWd&p%@0dbX zObu!uJc2BOB)AUrs)*OMFMY1n`rozADIC+U=nt2>>5o?1N<@LUiXHKZbHDy0P9 z9J#`iL&y*ulD&Y6Sj_rWhkVPR@q;}JQMByjujri5<0yHdXMuDP2D-3w?yRzLf#6G;dOF6Z3eD?Rh+CV_4gAt}2cD7xN@& zcr3Xq+?E5WpIy(@(MFP?*jCBvrOKD`R<;n1Jy`W*(L(XM=Gei4BzdT&Gk`yGymkkz zQerk$sEpNEv(vVZL{Bhe5nJ($5DH4!i>iSrW|0UG1rSvd--Kp7q zT<8sacFr-At#;fV9KK~E#pEKWT344ky($YOj@_d)uTP+YQvNca=tM4L5SFW2KP2Bg zq>I`v1v(d5u2O-y+?&=(4QqKmy7GC#COCD9VLD_d0L?v5KU*>E+(jz{wM>LES018+ z7v`pmyV$54scIy;9+8ZP&^hUAwPFF34%I=#6A!4ZNLUEH>b_be^jSep3Hf}HTH-MIVWJfX6fp~@0pj?a9WFh!`XHgvgkH@xe9i~$G}uz3 z5_))AW#Xkf2PVg}6Mp^&!0I*zRUU50CLA8!-^5nGcJ80y)ep}5Il_V{Vgt80i6Rt& z;1u~0!a|65P7B-1cFCJwK)toGcV29;*At=lr1>z~IkG>D)cb4kz+Wj3rvk#9Xa z^j%3zb|I);dK=pT5d0oOzqeLJ`!I*(M-#g?K(xcCcNuXP+p}P|&-JAKM9B z5wvI8wu2D3=gmm`ox$?ovsT03i8qOZ!uCG12z{3z$(@z~|5V*o@OJ(Lh<}K%R?s8= z0%0kC6Jb3j>B~s0MfetBS!X*BPE~Ocl*&c)SD615$_gQQm6si50Xxk4=3v1ne`i;~ zN89?=wsIqq*GB2LZ(8qnC}RTm)=8twQ%aM{vga zaCZ?{PAfXw&WZSylb(Ytj}v@-@=5D9Zp_E%wz1O!=u80O1Bah;Du&5n)qI?!uZ$#t z?9!<`VUU-hiH)p2Oum{C6MMaB7^^`Hb_fT#GJqiJ&&%Tg-H$9sg2(gKcP?Ex+80Ti zB_VR}qoJIzXV;{lOs0=j-Rv{lh9e0n$Y|*TaCFV9lCxW62>SsHU5wLNG8M`Mead+8 zM)F*!E=8`d$mM*d*brD)_%7)wt3TIri0A-P;Afr-veDOZ0%o+ne@Sf>qzZoM6h_9x zIK{ltaO3C0sKwdy9`2z_PSa+uPaN`^0N(162d@t?IX;T>8H9qnuJr39gl>maywiJ; zY;o{h*%iq+;Bbj7`ZWp7qr!-`S{Hy?u5(GlCXBbdbr0mkaXB1*KBOY`D#TTMw9O8| z3KLC0h3qSm%oSxbEYPy$YUh* z#+|g5V1WD{d-gVM3P#s=rU$@D;eX&mEIDr=`H5T{n)X#aUan{%QwjC(^bOC3{Vlol z!D0_)`9OsDq_ekmjXjezq^m(-Rx_{=zSGXuGXf&lgB5 zfB}9)7a^(WyT}NXEW(I$4Jt#664Y-{UYZ8Pp{7Q=BNrQEP|+{Im0V6fmf45SKHC7N zb3Eb}pbz0b3fn?*;F7yj^JM#x<5gjV(9c2Q~?MAZJFs^ZAZvk(Tc?2rbc3PX(_8(gHIm|r@*82z;)g_8g&f;ruRI;%8Bd@glO zRXHRkHzDOE)}g(cpOfuF90jHSyqxc07O%4=&x$Ufv2;ywla&*cOMtsVl4Bm<(FY9% zvFd`b)^vP!kj_y!=XNG0xxk$qeC95%)=LHKmR`Ntz0VH`m9qu|4nc(>%u&I&k1scX z0Sr22JccaV+R^dUOx6~*R*sFa5N2aV8dg%}$ry179UV)clL!o3Ksj>U#V-mjXo*aj zgC}zr<@+q22|osVD7(*KvnI3nU`=5rPY7z32?0HvakeuWIQd%C9;>UiCZR91xApL1 zy|Wn)jN?&)Zk=*6gs^C~MOK9kHnNuC_(YF6Ua+LaB`<)qVkmK@o>AvV6X>GOa9~*W zp{FJ!R*xETuP8qOY5RFcx~o47Se}oFrU@sGf)O*4gzE4j9!yQ0@@f(pL zJ6mk$+53CBF@Qfrh2;ATn0Su}cn>#0{2j63_`BaLdY4e+y~S!nX+f~Bx#?Pz&?9kz(09lpFJ<&pFFV7o)_>>9@uBk3;0hDY;#Ndomm?2 z#Vw5|i&LluRgAs-y@I(m^L2A zLvYrn<5K1jmcJS!YuKJbl!H;8MU0env%u!R8##HFYcBG)$jXT!eo7I6|xuvB6 zo!t8nO)a{t{LCt5P4K11vo49C^fdD+TujEiKtN^Pp7TXzER5H>E7Xa!adM87EfJxw zy_fdsswFFjPuIPVT!DbE(_N^7auNo!K<739%v<&*p`@B^Ry0)aIzU&Xu0p8u3$$cS zhvUb%!01qazra&yhp2u%dVR+{4@i$n=ma2{j;^T@RUY!PaTlxZ4Q9fXD6qi#fS?_8 zb{8@3kY^mymxLF{b1TJ9PCr{me0t+1(6HmJ3EF~&_=taVI7-WL0bjsLI)_W|@v_#) zRYp_7Jy(dQ&rovPThn;B_qcYEYI)6+&$pOXEeH{eC+FB~Qqf!_9b0dO?!@DWFt2lp zKa>a`MCPBg(*7`}3Ow@P2YUql-vuK7|J~d_L?Y{reGf$lgur)x4~;MwOyUfJ;0Qt@ z*jBXqv@1yN9t_D&^`tmEV|)>!qk)pc5F~E(dRTXs?^$8l=x7$#G=oGSRz3{kmsLY^28Z{<7ctobupCRcyb>RO+l6 zp3>`WFICw(Z-Um}iR9D!OV9=WQ`G&FpbPw`sQaITuCQ!D_vg_5Cn)8;9{dq>JK#S> z-CqV>TYG)5kO0k6Ugv{=XqEle@9nx#!#=jHC}rC==MnvhCxkzX?8dm+Sw@H$HDAhT zr!Srmqjt^bWB#FQ&RBtK=gEpwPW88kJ4W>iE>7s{9-v}>^0qNC z-11#zspS54k?rjOn|h|Qro4$%OmTfD1J}sco$iXnjFEiXSXQqOTDyAtcJ;rAQ=1D# z=mrlT71#eWqau7e8Jz9}2Irtz9J*Bwx#bK0ahr(dt|PYw%@SZyh2<2(S`wa&Y>~q2 zw?QIK7UW8JyqHnx-esJs_$-qbws*7k5=4mKOOhX4>=!ox++s9sc)$@m4t)E?EDxezTM$2@eUj|dr)>LsGyWq^BAnxcN4G5RmKpTIt2bV@4X z^-QYtrabQM;c@0VTM+MpeLVie{XDQ}%xaRsYm!KyXNLz&hK`^2b0AW|B+FPay(Akp z&PtMA^)kGw2^^)7D^Kj?Q9}Z0(2atiuBjihGP^|M0fiMygV!ri+BYTK*icf{X4&e`;?MVDN4)jqeuG(UyDC z$hz^<0Fdrk9IW-8wpm z)fND-Z)zffBs{fGeR&U@`%^dI09chUYdrojh}#%w@rY_6H|updc8L`)i~WCEQGqWK z8{bUf4hQyiFmIb)uj4A>@nRt#?h(r79)W8IZA%Padp=m*UVv7uYw^d%>hHJsyE_Da zcZr*SwN#(>_S`kEilqKT0=xcBl>e634~XS?Ps_D3hQ z(X;5H*)-45Jn~h*_}WvW%V)=64*xg-mh!Od=6Rq>D(x}hKBxEOlCG&9dBN1`eN`*NlRegKSdpd+5Hc8Y$gcdF&n!WS8|o$W+-7vemgb}@(nk$VxNLCCXX%jB zx_%qr<<+J)9lW{kt{s3-rPbWE$yk%3r;QAb)^;a*6ea4+5)CIF+#%I74mwk1Ot9u$ zn#%pgv}%1l=3%YpfYta?Es#u3!ilT2_aZsTfr$@QA7w)y6&ctFTWInpd@Z$vEMGjzT5}90K}sHjGetW!Z>w9ggG!WM4q5TYqIhb$$a1~s!&k$QkR9T@-POZeHmnF+WJ4?twR2AV)0s3HFkjalj>5SW5&^Nd z+zW>k@5v0g7=mSaB{i_ia7!_pNxoY60hM5WIv;Vn+hR&!94F&+qwk-dW9P}QDES{?kni+^! zzd8kBBLm~p+ksqD&znh{PBv9jZcJRDgmvs$_Azh@0HTQ|m_Jiz@=o-O&8snbYzhBz zt-Qv%o!BIXYD%Vs^mmj?gxi7S)kDskM`v}ZAU_>K33q3( zXieggZ3K3OK@qhRljyz9Pwf8c@HVTvCe29lDV~F~4Na}tJhk)2lO2hX;jZgOZwYot zZ)alC9d{)gI1G2tmHui7h1?b4V0vp*kb6d+QCkup?}8vCu?@v+cS!ylMYak=y4NA_ zaN8%_5#@^iHn%ZkFAO02>twN?rR!dYCQWPs}Wf1c1N&tz^oZ0s?85^GjV-AZE|YC zL1;DJ|H!+uj|0A)@cPAe5%}JB(J237Vd*;yOL*y<3f%kn#d^{D*tTN4w-{;?`~rSt zVd;uyeog51G&}LGj()$Q4xwF@Sz$lY>-%NhZktz50wT;A1L-4?-Ci?Gj5@dP^6~YW z%*O%WPWWNN2>dlfobX>6THG%gT0dD3qg;vsve4etA@utAS<2JEoX?=oL<&(0cr$Wh zk}}Huu9UoZ4La#9QJvTq%60M&FqyfN^a9+`B#=s}R8X{5m?L`fuwtzRD&Y2XC6cha z1PUc1)FFloZU9p;L%8x*V#?)Oq{ZL?h=>>v^=MH39LRJI;S2>u$bj|kFpk;^TR>Sg zZ2zo!vN2vS^x}(|H6;^9fx^?%Z@@?;d{s9nBKt}9K$}raRohJ#gt@lk(XkC#J22xD zCLz2vniy)XTGT&%Cg%*<;)x5uFt#e@C==W?EGzXxy2klpax^vR&UFXt592DA94X@9 z-9my%DQCS(&r>ehk8xa>C!nFGe&>3N4q$v4zVQD(<_df^ ze4!hVqStzgcb6WthFXjX(;m-eUBR31%Tb+uj$&UVu2p%a=~yx@Ts;b_?wx)j`2)wDba&L zY9I&;=9AmD`11?|lYKF0v{8|S^5LNCO5%!MtO0k?K@B+kdU_TL*;Qq_ARQ60gD{qI zkf!N$91U5{fbb&Tt(aJWC}Ra-eWy>7$H}Z?=4T(#RmeGAb5};L5%X}5^~px{@u<0U zO!FrmMwJ-QV?+y0$Ce(vkBxom(GToJkLQc6Kbqsihk1j-UITk?aOCOBveigr$!Y(9 za2&9rVty$_@a)!wSD#_k&f&k5cNDHs>wPcdciNQOrtAM<|Ig1%Lb&6EuaVe(f6kIhLb+$JKi>?^An-Q`cCWD9WU7w_ObD6TPX4PMdi zOq~2ma6jDLg_&ggitc=9c&}!!fsoj3jn{wZuFREETX4qqy8U|p48C2G*mbWq4cBzz z$H4gJq?x2!+>W=wg5L(nc{AU)o2)fiDNHPR;5ZXn(a*J=8u`VyHRN7Z1Y~s5 z5ewlEuc>jc0PJ!#kV01vN0y!;D}-BIzg5q;k7Q^~P7Y&EN8s79yl+^d~%F$H3Gdyr|D&FVdb7=NtJ&@O;3h0 zkwgT*U3>iwbMxiY^@-EPh>a#}{=8m^p}xYtETZnvpo_xlb6KW`BGA`l=^zrmwNT4V z)&Wmy+2t_f)xDhllO)Nn6iI-;OOhC)*xgm>ATlkBE^r$hTMD~*e$y|;Op_IotiQo65){$cI@ zfAKos%KN{*#t+s06_zs0CcLp}iDNVdGaHYABJnkP5(r8#B=dPM_=`=;8ub!pYuv8i zt_d58ZLWV?_Jwcy-$=UUU2C+3Sr1h!~+e6Jzvqe*<*i}FZx zl*mh}Mt@K)wsIqkrr+97`f zXUj(2B45`%7S^}E!NH%;2aV8I=&C6a`%`voScmVj;6e)kXASOa7=@#SvjbOeqncS$ z!sHQnT5c}{cdCSDeKH?ubNcO0zxE%1Up64F#;knHJ%{~yBrcqPVON-2i~AgSCblN8 z$LAMHh4N3V3K`I=aAI&-;2>R-q8QykiXo+H)5H+h+;4~j{C#|juV)v?^=O~&iZDj# zW1z<1o}j_VUYS%d_`U&Puq3rp5AtT$T(`PE%--flCO<$jI;LRD=e$=qUDqV@V@VZ+ z1BcnNpY9y#?x>0!a6V2Z_!glG_2(mlG;zc|;CWYL)3s3#>K? zu(!Zy3G^?@;O@_ad0Z|I<_1jGNm8BQJq5Z@WyMpPT%FN<6P`mMuw-({D+$xHbFj|@ zq?}#g95_^@aG~|mm)DRms`n7ayLwXxhcokA4wY&?-21tTmg7P9y!cYe_JoBL`7%#= z`Ub3tGWg^%Q$$5NV=$nU<6W8e{lweOa>U0}pm22k1s3I7bs#My;__O)I{w}~50l7V zfiTI>?kzl>$G!&3%W-(}+;mge$E8}|0z1B#qr{BvImxi)eQJyXnKZ88@)6gN0U;Uy zyJdZCSFeXEI8cXbev1>1O%vj?e)$9j4ZpFl2L3)=cST#rAlUw#UvN^LE>9cemKwI& zGi3dpk^$_Tj2|-q{Trh~mhOk1x{(pRLQePS_6F}~gZ45F@8k~`8|@81gkJYTi;Zh= zNKrbjZ+Kp>pF@|u<3xK&FC7sg4^xkG(;N=1v@Xh{YW2b8kszgfvoe5p8ra3+lMdD= zMT>C$hL0}yern9&Qq+edI*sg!AT(bw@yk`bA=ALgulz#LcO;Hb2JmzoF5U#!vlKce zKE#`6SLC6zE|73^qO)#wvxjlIH);?1s5@ zFgbV$*n{(sn<5l;1l>#1sQwH=+)_47B9r_c&De9#^@3j*BgEy=Fs59@;ds9t0z z#wQd+3aOu7??%Ub@+wF0%RKAR&7;$7XoZeY93^#%^bA!Iz_!O`wwh?h%+tm4Q}9|_ zrBppS2Aja5AnZ>^E}rVkd}f3!zP zz8xq_uvDkGL8T|Kai{U_V~mT}cxKu+kAO_dfd^b|frtvpNYM`ojjFdIEt>m)ixnc` zmA+u9STB#pT4K9~45a0Ra2$p@s!n(?J!Oe5nhNmPlX}vN>6&N3VtJt~Gi%Mu-&x{*xm&p!a`%2{r$3-NOeA{V%WoJw$~+ zL!VonVz;wi!R3n5Rty?PTgPFuEZn;UG``PoL|aQD{@gSH-UZ5Ga;wXP{g>Wl8t^AD{>#nai9Xg&{ zp^$#}y<-(_lXr~{udoi;yClsQ1#%$y3fnZx{yOqvf8{`|pw?3Mkr#b)MX9v;+qUYj z=K*~GK>nNO0et^J{+s6keE&fHo96+1|3JQf9)AjD*N}bSLG=bnctc+fv*1~%p+DEC z*WBpf{+uG~#$C-09%u%#uDUf4>p5Opr>g#o4g?m!m#Tl3BKIz!5c1%wJ4=THRnH#L z6m+2;asieu1K2;o75Yg1>k08En9JXzK8Rsu!E3l;Z|lAAV&J4n+3K~`+Ab8G7UWC| zFwB*Q)IOR6Kk+BO>dvlLJp*m%LGr>HL5jcteg&IMr5pX!KeAv%-*cl7iKaqIaSuF0 z#bhn^G=%NVw>`91%@PlnP$644r1&FD@<3a8iFh$Gh&p13A5UFPFh@RXUVUE^qX!0a zQlWyaW7Z=Gth=8+)F7_VxDZK2i7E$R_&1Gu+||NLe6r?eNw_`}UCdCUb5SNVPlTEh z^bp+_0-cFX{*=_ypsVjz_t?Yp0OVQjErf!4iBzGo9pQf8kj+CeGDMV&a5xh8^Xzdl z7P(pOXjdYVw5tfej8|4wT0jCm5u8+uI~M{`N)ArHAF1*1XpSVX98|_5c6I$rprY9b z1+*iY*%huA=^pqg--pk<1N1@=(mT&+?G-#RuLVisM7(7;6ZP{8bah`LcxJuse!w0# z#(@2TsmD_H$U+myS-Q2rDO2=NlscSruvd3A4xNCNZ=o`2;mDtdk-^Fc!B2F-^TE}u zQQ;Q8K-h7_uC9V`i2-hgx{#T(Qywgo60Z4@F`x)7oIC)M2#KU@o)Fm_~+#I(5<;)B#yHw@|9v$7U{h+X{-D}XmR z{i3AIz!MT($#`~t@I#=vPO=mSPR-F;1P@5z$Edlyz(TBs4R3x3HE*cH?e*bJ0noZ5}!!wu$Q%*}}=jom~O#CVz)+Krzie zg|$q!QE(|_WBM|?TO+gEeo@Kpw@q!QkKzq@t{9o5H@q2z8_Fer1#9sy{2O9-T-@aO zwt;FQ+^D@P4o8TsD7(>(dG9<3AAGc|~x*e+y|%TR(ht zhcLfXTsMx)7t#!(9pV+*ZbLiqOWQd!##U_Im^mNY<~(foUMBF@Fi&#TjD7TTtAonI z9B_%Wg3Lzy?zY?gw!gn?;Gf*~UXkU0EWQGoZOq0;_4Pd{f&1#WKCZuToR5mPz(uy# zMO1H`80Q_h;^L!uesziWdSVzz_L45~-gq#^@?|<`bIjOSIr@L##q6}0qnZOoTAcC~ zDd1E75`tO^1pIisf{AgZ)o0~glB2uWuKBFoslH&mL$i)xlEHEoIrMHE*D%)MZ8O~l z>(NXnp_nY*evrEOav3_AJsTVJj7+fy-$;C46_Kg>loyA(g+wN7GVfp~>SBsU(G}fwVO@dsq zOEa7kbgM{-tCEljb9E1w2jO2A$O~TDSuvEEOGSiDh?csx8L;LNN1ny{D~a61rD~Fx z5CcysM7l2xgVY2f$LqT})bz8=&Moiqs`=+)UsqH5GUDj%+FZ?$KAUvd^tZ;H!1!&A zm7eYR_*w4jA0Pcq@awxHf0(PJP?{zglqN}rVqlyiVG<`P7{xIH#u1W%Nd!SZUB}_w zjyBtEeUdMpXxLUfNRv$~3r{xPuT4r7-Uc-A&&w0*(i$cElm@dIm%;l`C5CKe1SHwH zlH@j58Se!UCfOzBnf=7{FV=B}+!p?HuX&)mj_TGc!?v*SRX{AY#ocVh;iZH*9Hgc4= zrFQe-alZ+C*|T1;@TO0%A65+aML^-ljc&zVJ`wnOXngz;VYW34UIWDltf^;iqfV80 zd!+bbp);}Llz8k*v{>sSdK`qiW#8hDVNM^=tbbq)q+;z+zQE!kd)Ea1be22@3W|yc zhQ@EoYrLETuazq-iPaLCoGzMt)>^6vt4k>ouGa7rE66miAw_5K*uLsT1OeF6=0#vYj4x>px zQHMr-$-zjo(EZ3IC5IU3-x8FNb?SM3 ziuW`;B2YYp$CnXsszn5s0j`;=brixRY~dFx!(mZJZUda};#gE;nt5s?@fFiVVR}pC$Qc6mI^3}9dugl&s0x}}AJvSA!%Ke}^4PDaL3}9# zu28iaFuu~2?NamaQ^(}95w)#$FhbeoG9j9u(F}C*BAwx|z4D!c$zhm0=`8GQM)INO z`J&&jK7SsJwuPW9!V8B-_>*x&uwo53K7sKH@U*EK^?UL)z>V!v&?H%i2J4qU(SZ0o zxBpQCf*8c6PO0clu;M#kKQs&X@R_lWqOW7bz-QJ#j>-64v@D%?Fb*f#m+D)7TyDx! z5)n^%jG%J5hgZm9?!gHdqv9=yjim$$NWiZbNS&^}3KJbWb>bqrMJ5`Dd-HscTtG(8 zqnLtHg+|0W^EDpXiSu!(Il@~3iwA7P?_B3>6Y-pesSj-@1DPc*#@gT&XB6`x91VO9| z3)H4GHnz;gjVny~ku&a0a}-J&4%R1?$I$wBa>+f@#Jvuq0=UATRE}J8L3qzEmY@jA0~@vf~H6ercrqF!=_jKv}V8r zPSWTKq}CS{@#$Pqif+ErFutX!3AW=4WRtu?_J+<1K(+*v+9?zOqg4 zpj*^h|k==^2;C%>q#c?FH zWwk3fLeMRr-KLh%jjaOjeIF9pMxZt~T52QKtVl50PqN9O?m0fQt8Zn$_xi~<=!A|R z(COj@XI+zGbYVA6N@5q%P5#V*Lp$_8^Eo!%1mQ~}vdy!yg=F0j`{W!CmL&ul_Z7Iz zvtig;Zr{Ws;FjEXJMGi7^La}&tJ|7<+52?QHcYD>*w>zbZYGMG*W-HipAyi2e)a9* zz+XH46LZAJE0-TyQ4QSPW_~aW;~aKdVVZU z;+k@#mn3GJan>1m25?+_bJZ5R7F9-AjqN~~H(wW%4dnHMXdGs-q7yjlt2Y4~RM+bY zqMzlUsh$TVdb4l9mBo0tIL~M>IQx`aS^ZL5xG@#387GZ>NRr!N6E$H*XDDeL2E=je zY-iS+r!U1z1P1Qlg~FON3I~$FVlN&2Q-wOwMXy797?CL;r1u+p-VB?ckKvN6zZ~J{ zQ@5#$vl$EkjKVA3wo~^028XbW>Z=!elUB~}1|j%%glRu}NlW)KUma^W>WMjtbC|=& zJ5oOqg$I=E<_~j(SdaVEse@*x)y3v2F`;vUzrK#QN)5VG?}=DFyS-Ppv>60;jN}OU zAP@ElsH5rjz8<6+Zl!bNv=Fb7)ZNuonCfUsuAoyG)Puu=ji~b)D9iQZm1T`Joa=k+ zixe>52>IT5Xwtfssz8riA~~CM29GKfFg_7_=a1J6#P7YTanv~~*WU{H>SL@#X8e&} z0Zo;TIQ4QmK69@iYCQdk^cN>Mg*k%7ou^Un`#Vk(IDJoEPN+B5uYD3FP|F@T>VX2m zb?F_PVHh^G5nSN!ceLW*#@VzSL33)>WgqFD9AWfB8ynTbKfy#8Q}C14T|-L;!0wbI zA%T*Kw;8$Qjpu9mbGD9=7=|SrAs+}R_q93q|6Vcx{2K8?bSRh0&UjU9 zL<<4wCbbALta%}+cf06; zBPf(3`q1cay2Ns!8V>D+)Zj(UMjS78LJQOZ*h8s16(-r%|44PTd?7A88bgd@GqVsrbDn-}r$Avm|IJ zWW2IE3zjbEA4TNQ z=?sb-ZM|M2C!8ZN@hRn1Jpi($Ov?^++L~@*-;v;Q#%ibw*y}xX#dg4<#*PfUe#YXc zpXLQ*XA!L33VrujzMLKaGQ1WILK3>%fUou$;t!$_G{!OCA#0V zkk!G-y4Zl}WVGVIZ~${F*LM?NY_IMGb+Rc|uZg;w$4a^yH?EtirxlN4rz0-?VK|sF02AG|oJeepo&DupoEpc&^ptS>Lg5as5ZRzTH(|R)52X}G{&~etQ)ai znFS$tU!Pr=biKx=9J9My$I)(?O>S@S%TN#bdrFhB1B?0tU|C$fWN)H|Dz+u?iNnj= zrM_1|w0xrL0<4QB@ktfvvLUjsRUpZ5ks_^`Q8RC|_)&U#aa`nzB(M!De`i%PBjo6nYT0)DQH{WZMOZk><8_a0MJ{RObrOBf$_^n(NSUShib z3SbFe0G6=!5=oUOen8%!RzV-BqdKE0 z;#tECTtp^%7uRo_I6>VEC?YFG^3%vqY7K@^Z@%h_eaK}@Rpql&;p5;wK)YzPV>I67 zB8~96vSW5G>aZ}~kOZ9bSj~h?T=h2ur}=#H;2~N6_7Ob4F$5*JE=k3B?9tUxQcuMJ ze8x%FcQE~+Z-){&0SqR_Ufn?C!{(QFsXp&49x)Sja+T;6$EkA`FpA9m(KR&G!;k(vOCnFr_wqz_Z6gXUPYFtR1!xu+@1%{q1y<39rZ(k2E}}8S|drlRALX&?XdvQ&NH*9 zHJUc)CA=eC>$2v(S7Vwa;=c_j=pP0Y^bZ0G`bj{cQJN+g5+ewNMraIQ!wXCjG=mZ_ zyoQ_gHHKoJX6##-AhvFEoNkFVzB}D+ejxDHy&&R$Q}ITxLHD3TejZSWa7(DuZ0j;7 z)YoxLVsB7T`;X{o(;3@37{ul;5@%Zx0FTzN@QZ+gM7y~Px;L%kEl}a`-oHS%v#bgH z8t<~b`@NaF7y{3gdEcnL#DB3ctxw0JtzzS?65R zZ(sO?!J#AO8t)2Bl% zp%s);^3fr&dR@|{Bs=k>tWh*}qmiViFQA-fVHKEWnG`Nqr@$NHOUFa#qyLyrlqJ4# zV^kqnw@t1G5jvW<0epoxRkOnDHqj>sx`zGp?vdd%9lXc{=raYs+pxhU>M=-lfuRkm z(ZS>Nh^?k`os8i4Ry}n66>xj*%h|nEy$OM zhSf|^kY})ES&H`#k2CFd6$+e`*HV!63zC^PAHR# z*Te)lz0#z3ys{Hb-mbun(4P-5pH{FY_+mM~*`q0mqgc7ez^B4t(8&;7B8=rT)^ltu zIW|XIhAQ_;2>3GJ0cw0{T9d-f>-o4MaQ;f3jI6}&>vn08Q(xCNXZE_=Nk=ZF+4K#R zauVIv*jrH1WyxzG8tVIEJr%>$a|YoxF(jABY#r&I;KW1eP}eo`is{)79EGZF?v*bf zFSN|1^P`63J1{;?T0C**B@(hkq;cjhcQw@ZZ6Vv;6>g-P`+8Exb8KL&D@1N+L?@fx z%q9o!ZHpj~+4Cink3@QJbnn)lpU3f0%Q}&rEckt@ac*9g6`bHN6ja)PZy5DSOlV9p zTWi8c0zI0*X#9E5#_gVz5Tn1LyhL>Zh~!4I~k(`#}KGi#DfuRkUj?9-u- z%^?@xFwBZ6GHL@V3B6D25gQKLQtiDDv6;OgYj*oNCnecnPLgbp1&hDhz^(rXdZUSu z_;%w*f|&N zx^AOIX*vmGih0t%vwJXC&tM=c;GalZd=izOz%Wc6_rS5|ftNT!oL|ISkRlPEf1bn4 z^&@-WB(@aRG}67cuN14Y+Y{hA*LrfDA4=i^j#2?%`Z$&N+8`Qn)C^uR_?R7`*ZsJ> z?^E-9l}~&q-{ASd+TxIEfWMfEtkZLrIPLkLNILxVfye)F@xcFJ@xVV@JQ#|gVR~IW zFowdB-E5o0wr^>QS_1}3<23cD65pmTv`^6{#4dSHZ3)#jIlEKAl3k5>-3Q;tcjM37 zo*B7mCeZlS_DskvyIDWO207nC&aR=Yeb974M|EYh`dGUDv4=*0@|GmXSKm2C8Rac*7m8>90 z)1h8cQ+RAsI5_zfR{~54N9bICDt+M$w1+=%p?5h-qTBG>&6O8>eju!XQ?Em33lI6|3Spv{`trcb zxExLGI*cxWsLLrthof-U-p?evO{GN-#sfuEmloK6uo|7l*B58m@AW*lg3Y%de4>u_ z#|M3^Q=cF3gYgH$tP2)KqbNaPII{N+m~FYDF^XI<4uZhg`VETWG((`sr&b{7R%+iS zHQ;T`AP;n=zV$Ev^~*n1O(s7 zxFor;4&W~X6U;`;#j;;1!Q;E`d$!eXP-a_p;N3pt%fQH1@nN>!077nKtmv-tzP?z$ z!svFNE5J$iv5<6MBFSA#eg$#N4v3Q9T7if=Q-S;jc5J>OYYZNQW_WZ*#Z8H4?!d1A z8Y$s(VKnn68iOU;-`j$$E6oc@zlySa=%2}76&5$OL`}SXx5HOC&2MU&2j$yjtM+CQ z&C-_jHTE&s3jDCK;-sHeP|dLfSL2KiC3xME9sHX+?Lu(CsS>iU@L^pKX7~FYO!PJR zwb*|wZl4u~fL~UI^i;f4v{|2<*>832qGW`Pwipj7m-Y2IV&+vz9u4e?;?GAVHf1HM#BagDFF(QPW z8^_O*deu~65QA$Dm#oCQL>HyrbD$`jz6egHOttlFt+&uOfcLo3B7$CWkA7cl$hy3y z-aA0^MR+06q}E7)g(oAa*gjau;7VIU?O1qmUG%99{Sywn4`!rHy!60p=E^>XpcRKj zD{kQW+h@*livEApz1fzd=GG;8&r|rGQziOlk5L!20t7Ke-MnE{B<5~WgItp@8D!*6iZ<8F3*jNe(r8$^+9=#( zbb1hdR{JSf8Lnx}FH#EC6k&QVFF~a45lOH$J!l3jVGe!;0#tc1g@k$q7G16t<&4qs zphbw3id_)+_s2mj7fX&jTP-^azuL*`j4B??N&KC+Go%2n`17EKGk%}-22L*s}oYG$9$&Kh3wQ-@KWn(ezDaMzn{*Ty>35^xi5-xbaBFrV_!`9&S)WAH|@ z7(w4~i^j*BuOC_9H0=}G?WFR|V*@umn+qaq#2jP#X(*XcENO(g&`WS-Uolca5vt&7 zy?yAHV3K{h5FMaO7?X=;We$I*ybzL?=?Q0Z@2S!%zIJhdFPPS0%I7a_e70 ze_Y1JIo#At)xI=oAM>%tHV}1qOk-iV(Z)HJ$Sd6x3OAYhtV()`^57uajJAC-H(+*s zO@|6AE;PWd0Tbs~_^i7C&iN|j_(W~wvxIb|W^qF1)U{V+y&2aco!HX$DV6Z<>Eg`V zJ|bHO3UP!5cfH(m>*PZ z9x;ni&B3D@oYI)R3}_`O2AXr7gUXgOS&$vSf@^2G+HV|FbSuM{w=yJ=Fp4meyQTKMAE2kaRcpjxe^#}V%p z>eIvpkMAdJa{08N+DFM7FyB2W{&{@9-$FA$h%&U-%ln^haf zsAkVEN6`;x5h_|6JZzI+oyn)Z|J%6Ec39bFPQRVPdi>4OezPp~w^Lj0 zcx$KWE5qUb+yB@=T|d_Eh7Wt}%lnf4#@?%YJ*3rduk<%NEqAuR;$Hs7^x^Ql_jUN& zX+LD#j{Q7??)i2{g`p)ld zs1Ztb3YV1H7fX_TA}an>EfRYRCdKHUV*3y{O5T&P*qabILiey83*Quj$v#q>zU!4c z7$){qT^jC)b;GmUX?DtCVjl_H*4fj6JDB}T{ak;CrO^2M0PUX`2tRmXpr55+MR^8( zr`L^b9!e^|>8f4x%tGkG_uL`0#Xb7_46AWha+eUP@W5iZ(3?9Tx}K{If+E`nC-9zQ zv;o1eu6kJz7yr5sk19{!V%6lTz|qy&1?U{tQ507YRn3B?%@Ka%m|slQ_h5J*@A{@S z)Nc#md$4YM`&nHgd~2mWZ~HY9DxVK&AJ;urb?7~} z1>TYa=U_W)aP7K}xB25a0k$n58gG0iE1s_Ca+YguIDq|pSI*myZFBqW3_mW6l=fY853w{V4ckU&W5fy&D0ZRd~2QwBoF=72wq$|j7;4LEqND5bT|<*Q{S zyS-qwfjzN>BIE+UFIEqzj|+STO{TczRqCH%X?-1{Qz6b(ggtfSWS;as5>`q|_?SfQ z^a@&!^~Jh0Aw#fy?twEp#nX#`8F0R?{Q^DX>yu$<`@D2#TA;N2FdkRx1r`E9-wt(i zU&L!8^%;YtimD)2zz<_%6gQVRVNYefLFfjYkrJ~o2y*3Il`);Ccmg@WROL9@MDkSY z<+5!!Zp0T=Z~*R>ysBU*ay?Q#*a1PGmsmYQQgDw#eEL$Ee@Gum*% zF=sV6rVN$=jB-9=DcOPPd=Y;nP5A-m1@=L@x6$!(hA3B@V36;hPCiS3OXdGa-tQNn zaKpA-d%!YbDIVml7H9Q3(7jZ*3Uohp!jPmc3a@T$F*oU9<4lbU8j_vv*$rT%6tuJ) ze#plRSMy=HQu=UK)H94e#>7#tg+q_?U-%oHUV**$AF5M4Ofa-HDf$`9v!e;sYUz#YEl{ly_;fGUK=9lH`tA8=y^ zwb7_+M(eZYT&PaQu9OEA58SN56H4;aZB*{?L7ZY`XjjtFxNL)^=;ir>n8t0Lx~Dkv za%HEEx?dmirA_}q-|CU)m=Bs@#<8W}O#D+)@aQn-<8Qpa{rbZazwNKmP1*K;(s)TvL07hFF;aRz13~QTZRaGh z@9X`Ut~lEhTpO53ptp=7`sT$*_N+e@?kRTYT>wNr8=>fI&uK-`j%Rj_Lu9W6e(O_0 z-;5i`o?PF>Y&WFwm&_XCeNVBV-=%Bi%&4!27b_7>`{fk2{|A5o>@HSgxUORfw6!^oVDo9`i+Z0mS1?A+{3ZmtQ{}UP zWbV{u-||@RgE-bYTOXwU-*WK~pxMHnc;9nY^V$8DjJM@=+rGKs64u@JhfDtXih+N6 z$vj!;qC7??^lr@5g$*AkXY><4I>Hmh{J+QqSb#G~M*M1J$`jZ8lWr8;ph zwZC840(}10(T;iPJdj6)aZxJ$rXnbWG*KNs^>?4=K|7woVeTV(4YO9 z&$d_@I5`;otjVDtq)EZY5j)reN#F+>^Xa(h`!0J1_9N>nf4b|}=B66=%c?HsC`hQN z2?g+o^=DnW!a%B5RYQ-bR564T9xvEQ7v~(wf~>wPkIA+Th2|FAtNq8orcralk;dt2 zKy#$*a(IdCNJY;E3(X=zgQG@bYw62i(j=zsCT?n-NdydUL+xB-M9D*AzA|iZgb^SZ zk0yd((sVpBYA=r}HcuTbkQY@q@gsrE{Bxq}#j2*}Y@(1qU39X^58j=?q-WJ$fHfa9 zlgO$|f2XrJjm{x^tJaQ9%uGAs0eb4>oAj*R?)4=i@QufZ`~nqq>?Z zzLGr6^rZPj#?-*wtiW0m!5%Hc*s|IT4W*3gG_@RcrrlFoyi#kJT4wtwvraWd`Cw$h zJkfD*g{a7_uDFg=MOrZqPPrDr&h)LlVRSdKchMK+R7}wNkvAm={IOyAhw6^5D%%@( zUdMabUe^m>(A8|!a(JuEKY|9}FALLOG%WA*h1+h^avTk>$3Qr@-9@A4Ne@K8x=}U&key!_il{^e|o|FvV9Kf3iF{2>eP$BrrH_t#Q507-c&7P z2p1PsO2Essyw>!HtD|0X2{_&;54$oZm2cQa@#IBWd|zv=>@YEeKt4h{GcO}+PI51u zPB^chVsWB5Fv$)lLwW`wN+!pH9v;Erl>=LJL5z<`rLSx1KfL)4l4)LtC%b4TX$6^u zfSNI%Q<&yvcj(YKI>AXO8V`r%MM`b~B&Mx9{E~gzrUdx&TB!RZ`##YJf+VR_=T=UrX}XL@|=&7+!noqZ5kCE^$!EMnwYSzStdPh_293yeC%Hb;if0bjq8`{rPjR!qNo`Z z!hMx}CaXi97gXqFTh=u955T56FfJiAmY3R6$GSD`op4#GO>2DQqaB7!r#O#lSzgJ# z_9d~&T^AK1^5ROji=J+tDIwr1RraYx9Wqpl+Dpry?x^8S5*k6&t&3k!{trrrZw$n> z{Rf>`+V3q0|Kpvj`P^YG!!xaSsfgc_^f&W=s&B!F@4J7Oj7Wb;ulB#~B;S)gU!LG6 zF+&`|Fbtycy$lHv81=RM#D=!;z2KO<5fTKwHILqOXA$yl`;K?DKa|{gYB2okeu-=! zFW<+G$h|E*ruMwgUa@>5Lxk8fExWdK_?9qyr)xIkw*fxrSBahk+bf!MydSx(y8*lO z&9N54JG~A;zlWmUViO^`1H&xbMXI+KQ`pYH7GrzM$F2qSW)c2Srr2(9SCHCeEdDal zqwRQZ{@yR4Fy}`^O47=ZOz`D+xO^->^Ay0RCWB%Bp-+ODj?PgWw*dd9nZ_i1aCk{P z^E7-9zeS#q8_0)(1h7j;d@Bt`-((f|2$gdOt=8n|KI4V8)jL}T8z@rCY1FKEJKaZa zhi7pIh#PlJg!3!D|EO279q?Y zJahj9#Ygz}OO(YkzROKSZ#@ev4~|am+;Qzw*8=!9{+|Bv0UF;^Dd$_V9q^;D_7A}M zhllvVlJ@3f+q+nxzm;|YKJzXwj6kbY<&>M!YjYzRVt#tS^`kJj;vn;qBaJ%DG4)u; z7Q&q!%W@34yC;D8RM{oK_2YsKd{L~&yW2{qAY@ZNy+ijytpw1eZcaqxVx19Eu)(IB z(JuAo$oVS3SCwE(tulW``zeY0Xa2Yt@oI$RrGb$r=L!E=Hy!3bgZ*DA}gOePv z4?)tlFV88x&ctIZNYyzd3NK|>b%Eg}1IiRM?_?H}UU*+Iyw=Gj({nXfXvnKI&V`vr ziOa_@2@JSV*zC^7$KI`7uIJ5w)&gK@n?|czMB)kVAwKNa5E+4TL{_>+j@lv0o=Vjc zkx<;?dCHz(@_gC1^z08!LL|j=092TXar%V>XqnOe$*uFW5l`S{iNbS z>HL4_OF~E(CTI+YA(*DOUj+TNYVo`GD5Lg3;lHPTYV5j=zPF(Y=WqMs}}{rMo*uv3=oPIT6`ACgWdG#6aYpOiJHU z$lKZX*6rxs&57=Lp$)H~^xjMvrtkj9Xx~V`^%t@C={F>@L5IC7^DVXrV_2>1j-|1J*t{UQDd2mL)QE8v@$RU;os?(|UZisBi`kYicPTMz0O z1%~I)ns5@%4%h2QR#K_7s7!N$WbI6X9~ue8OvvdX^6W2I-km^SM)TLSZuAxbw^XX>E7@tlV-Q;LC{k zZYRm4?T3+t>Q5HBFf-ixvz|Pp4nUSir5}2IxX@sDFKA_6VwT;PipL~yv zd>P5tmuVhGO83{6jHCV%!OaQabv?Q|HD>F|bqMY!qe|msJiK0s*gnoG#6?f^9AQEU8{kx#LJDwxmh*dt9%Tiw z_--CdeTz+V-G`#SU*bpt>ziQvg<1_asat! z-k+GdzZo}$3Q(Xfbmk)B$IBt(hfqIiRMcK`1V3BL!yJwx(|Am)4<$Hz5B!)Mq9#7j zjCE4cnZ)Mg22f{6d04#s%Igx6aA6|l$tv!TM>_eN7v@g%h&Al}iHz(~B-YE-_z_eA ze?(PChTV)K;WYgcU4ogeIVQmUY4UsdPoV1awZK;|{wJUc_@!Eaf{RT)kVxgQMem2Bh1>{;)2~2siU*1*{M7BQUTd8Y_O!wNioOc)G>2FG0eZ#VZxSZ! z2Q+KCvdf}D2sny9-yhu-1T-&pLicWPk5(m%xR_zq-0&LMjAxPtZOtg;r)8|_0V=h6 z#-M|Tk5${@3>mzTsZoKQ>QLmfn|`^jz8Uzqx_x#~5APFbd4&u}ktrjW9cx9XjhCUeP{dFUg7tcQ~%W#Mp>UihkqB{6&x*S=K zF^ABBA0%)lLiD9R1j59Jo$d0ZddW)?PAt2c zx#rZPfR#=SAu#Dcgo@mpV%mV#r+6*8)J8t4uSd*?sy%yt z2jCmTHcy6rk_G!5Uy%s0Ya_N@m6{;ax?T)}^Da(1PF?8R5PoWu6h&sx(uU%|!{P|Q zmcNwv_a6l{04=4Gx>%D z$@tCtOzg=h`rS;vGy0SNBED{k$EmkAX|_+#?1Y8nejM>;V9uaD`vkwq1b3Q(=soEZ z?P)7=1GCAmTH?ce#rQr^NTd7S{dc_g@Nd95dCQ){;SP5I7FCRrqMC0Y@1AfY@2JbaX8UI$ZM71KH&Tu>B!Sw$_XnxgL=M$RiKR|QS z`AEh6eW`Q)Qh<#448S&NqG$s|v_qoj;^d#6CKVRp<{hr<1v6l&I~KaBnQ5MAw$n{g zJ#;b{cIcCTRZuPP_GQu;fNd3qP^EhZ9~;Tn>X3M);4L*zbaCuiVs36F3kPXUS6+f?%`sWxIlcyVedP%=%t3prSM+HVPeXaB z!`g^9ww7lN1cIkU)MCMYHl_P3d;5tsS!l`vUXQR0pI9|J;DN${e1+HHtza_X$DZ;3 z^2L9W65Rn4@KrPV?F&M!Pg!)<#^5XKPBqm?F(STz`2KRH_OKW*#I1wnjDcb1NRnW6 zG9=gVFiy+kJcLgZKNl#AgYXj@4`Uf@Uo1YGZ3JK>ZSW%D#*Px%vv-$2T@G~+p{FH{ zV9VB|1ZDM+^G%f(a2`j8tKJ3Nib#w|U0_%QZZRj~i+8D#=}N6jcC3kM8MWjzR+@ik zOW#vHq#+RLxWdd0bxu#%E%o6cI5DMGI0Ou>eDAKXEkV~|!+|uu$R44w?fF?8DQEl8 z^D2%dk|~9K`Z$d-djg*_gO{~{R3XL6fTskVolH_89_{uCX8ek%zG`tr*vfXjeb_Fg z3XObz5nt(55*j5|>+QL#f_T~RpLYkI%HfLtliHJIssA%>>u-~d9xGJ?ek?{Czi;6h0)&01HD~&8t#ofB)Mm);LV*vZ$`UtFEB;Pze0NN zD8lHy&u24pzo5p$_hup@-1AgOx=Tt#>0Xyg-@@xLyn_nrJwdmNNfLXpicI(IyQE~Y zw-e#nTf8#dOHMnVQMQlq!taqcg8s`UA#`UlqP*{krF2;$Xbu^zE5A%EW&BS~Lhtd{ zg3-PgQCzc1kK(GC%txL7?Y)!DA#Bd+xDVuRk=Qq<1@H|0?$6yFP<*79Z`$5lq|3ZM z9q#Gfc8V7f0)1ya`gGR7mxAY;yLX^J)`m8RY{#o^Yxsvqr0{(k@ZMOk)ED!_y0(Fl zZ=ghUk1pn4wOQal;=$b^v(WAJ_MiJD|K3U6YCQbzl->NJGHpM%w|Y(?%o<01`q0*a z&zf4FUqEDi8{qrV0sl$kTox7E_<|w%*JE{;@`8q1pT#fZ^dg4<^J;v-qOr+t*ui^s z`bt<8Vgj?6Na1`#Lo`|r!FH5!;KUA7gW>E|3U-kC#52hihNb6T4DV~sCP!~j$$%x@a7Bcv9yAbuMlX6fU)@Z%f zF$Zusa&$e3PItn%Q4Sb2d9^NkPp$^lUV2#xPEgde_xX^gZK^M5Ak2?tNZ1QlS-F7% zgzuHw@}jY4;GU%^=!CAF$x{oF+4h`tnV^o>m%QRqQr>Tz3C)v1hmW!=skI-)*9|yS zRP`uKf6;`(RiLP5C08nK)XUID0A7zBz7&xtFyAW-9jeaZq~^@Od=I z*uotijh$R`KEA6beb6#;Su6F?5Y2r-94Dgt>EaPJ+Y+tgo$FB~Op+OBQ~;Fo!kk)> zjRFH)bY97~&q-4ehm3OM`Xu|Rplsn|_0qXSwOby#_@ac#H;TBe`t$0>fMa3t38ljL zUNnq)H4`nm;tKd=aUF412R`swIURyT?6F%+6BhTn=RWeFs!n-aUUv!zTrWaj&iQWn z!hv(b?(TLAr978ry?ZWr?e*7&TkaG*KZ6VR(x_V_m&nlgb8|W9WetE@H`gd=9}2U% z2}D2~mNjL{HCDU2Yog~7z4XV2bDlZbmKD?EN^FP(Vm`!R%tenopn;n+{w0F36P78Z z_T>_ptJp$!a>?S(CnNFuB0UY;IOuLn<8bV7?8rG#>k_?PSc`?(c?(6IKm=vEZD{Ui3(ugWcT96 zU#6qjIcalo!sVqq_wbUC%{d={OWxiV4qAKlAm%|iCz=Syu?G$rQ<#~Rgoi2cain-L z_VLIJ)d=efPwI?w#znF;55NOAu|O$o`d%bA`Zfhuo8X>UM4JTirXCh@c5AGf>9JV0vYsWHoY;x1oa$kT#Cd^m~2)wqDv ztzsUVOLwwl^Zx9ME_xs&W)L0cLYqBQp6-`92hWDvC&l351?Y+ww1~#192u$v#twAA zp%nugw=6#snQ6EL@S!GxzgrVDTu@F-${M z*2=4=^L2$c^XCI6I)jyZRoKGv#Ic(^vt80_sXp7=frl0O643*4QUvuW>Q7YhA*{5k z3>O}U;(DK-BhaYR(26fN%(>Tf&2Dhk8XSI)Z)02+6giPc;^a;vgF(bHo!G(;IKuUE zG&w$y@;PQe>-+a-?KJ$jAPuDC_%Y+2Nyl=OZQl_gdR^MAv|d+}Nz(CN4@i9NNcb#! zg&(3|=t+*hQD zJy%4(84#%O%^H*L(`Gv_1F|oTg?s1wws%+k`nZB!i|pMJ^%kx8>zX51>|o<&eTRlg z8f6P5wjPmBT<*&|09gxYHsuqb(sF4vVHkTcMVdtosUI@u+jT1@58RWOLX7>PUHo=`J)QFX|0udDvCaTeUaj<`+a zZ=2}{FbY9PjK)wL*?yt;mt1`5o2(aw_nb8x?rjyDsm0&MGd&y1&13d%&*-iN2a6D%PMfbjh=0{`%CbBT~N}fCgn}`%=+aM9`{@ zP6%4uZjWm)=G8US;p^qW8=P?D@#V%U?4gKnSA#Ko^4c)PW?C{pPcN6*A&+GZ)pIkF z1Kl=_@i-E`fU+4m#aC&V=C$()`6?>t>xg9b&2>2D87NCUhX58yXtbWPB{9gmaBLeD zRUh>8nNDTamh)1c+n&3umy2lY!34G|jCe=mC19x9_lZaYl9j#6aWG!+tJjIcB|oDq z)cJykc3^iZDP0Onza?_rB_9bzCyZEMg8Kxr#HnB{-vq)Sd)%Vd934P`)F{jY$qgxE%*ikoCqOm7pVTgXOY3aVY@hCur zDx@c(C=e-G^PAnLi+o_OWu2q-<^s^QTrMMPxWL6b#kV3qGDqLS#R~DN3&V8xyTCnL zQyTR&##XBdA08%nN76eXXNE~({QhJb?^bI%(B+?)Fd^F>*59sE=dlOa$(> zh33>8w5nPer`(aU$jZmdYjikYV%h7{8Ucqd?;;neL-AY_(Un-VX7wEwoKKbm&mN^wkdw>uLV7hg!PMizJwS+8zG~F$%;Th_fW8Z zICR8%z<`k|*TG8BgXOFo$>0`?PH=-k(B0zBM@pGC@u2n7}Ma%%aPozbJ=p5cpLWtra*# zNxPi;V*v})@ET2&U7H$5Z_f!{3h-3UrwRkp!RfVtXJe((t=wk@of|qxeAU+{P*rr5 z@GHsL&Y0qpeK3d1HBO$n-FZAUkyuD^>T(*)p*vnqOl+S6;VEL{m33<_6>8v=kw>RK z62tX!n5HGhz4=k`l(UqKSNZnph4pZS=39xNrcN#Q%9!q5oirv#;7D>h0Y-GLIk+b? zORuQgV>-}8l;g$-*@vv`Q?s8OGKkYWQl+zhQ~8p86-tajuOp2ny)P}wOh>fzX~Cq(v&&Q2?x>|8SYsCv9_Ny+^RBYa1t zy9)Q4ONOHMx$q4u;%~i-{W0b;z<#-Q)%^v|C9qQZipF(}$y|G{q|0gOykjBfOp??3z z3XtgD|7I2Fi*O(K6Km|LwM?AzkB8T5f*2`ZSe>#tuFWHp>P|;LQxVxKPK;(tM5!@= zD@XCcJY++hd!68s{`1HJ$Bj7b` z$c_j|osQG;WRz3*MYu1%PS^38LhbRfhWRrPj|g%-MHLuafL{@e{2cCkRF~ojY2{&m zesFNnA``7RLYQ=G=5h`i*rtpz!7!?n65WmxKak6u?((nvzFm-^Ul zvA{vIcw`*|zgKQVfwLfcuiH7c{z<9+gYwn7=gm&I@rOU0KmPSeVf{aTGl`$sJN}&o zzO!|F{fZxnvSE@W2m&T)62&l#-W7&6qYR-COu#gbl3!}pWxGk;g5nh0L+;%^zcaBr zgX~*)ZWkSTGswPW-@ewYgZ3c~;ys}my)9n|?^7P|yDtuYpCQ5bR4xU-ldkAn<8BN5 z;a{2Mcu(4H=grc0Dj3@1`pr=96DXUH_%QC!ZspPB8?P-w@7aX-or~BmWqS?w=Jwc$ z#op?`Ve(E6WPhhH|C1=NZl)p0VA?uiZe{7w!F2z`GOO)jz0C{xhQ2?-b#B(KpVX`l zQZ>=}|UCosrq_RLHp1WYPX}|B(zVH0D@0)eqXD>cQftl%pZPu89 zA2t@OrdiA+<=?2j=0u8)^xgMnJM@z8jMzINwra7~xe)B_7KBgMvC|K?uSNf73HF;qb zBXX2lg%CWoZfEEAI2~IKJ^F&44c6&(G&R|rc_2K;^hNH)p^n^Ad7zpRiLX(4YI#^o zuNo(aM=`1(nAc}xvwHqLIg~uwz{Eq&PETb5)aKQ^6rGIR%iWR|O<-c|fP_neh#;mv zw9DxMb(d(ZoYrCylrGehveKK^zh<&0SrY(r8bQMlu{_kMF`D%17|-%@WLGz}z=oh4 z#w^Zfx-aKD7_Q->r`DkGAxh~WBC+QyP?AwPyo&oRO4hc|;YWF0Fa<(dk9O`aadB&G zylbv$l!jaBL^0cUuZD2l%byZ8`3PWL}B7K=xCu`(6bgQ_L6ApV zH%`(Nk0WbvDT48yk~J|KU=83oGorh%2N-%cMAj})cE~hV!f!FPT9?g%d4{7(oo~}; zl@l7V@{G`*aQu>aYoT>M&<8VTUaOIBf|Lz-0S>MM zaawiKMNxrW`qQPaR|g!7{MM$KV5|wQ^#lyy_%zt+%%6f<*UtJNr+gu0z0a;^#NB|? zsjtp5hfm?TubjieU(b3%y=Z|K%$j>aR0dE{o}YiuQkfBi9$ZXkvZHQ z^pKyT@HBJR_%hP*8dD+*L&XM`8$BS|Gd;3(ji7m}SYj;^=-~KLS3c^BCvi!#^~p!Q z_2n#xR;OZ0H8Qxuw*2z40q7W7GqZy|+DySh%SBMZWA&^9ueSnsUdmM++`Fq2D&t&m z%}S4v;GfT~)doAD=iYj=Q!B}-O1}L2)J|2hv+7?&WU@;#F9~W) zh34fRCvB*y445T1V%WIGZ&om#i}B=w$w~XIx#isEQU2alvt*ok{%F{XN(r)W#Lxk67gM-ef%dbd5(8#SfLkCBidBBz?WtZyx859nh;|D3*yLl*#$x>wDu4C8l0AH_%fQjOn%#NDD)S3A zyM7A1lfj~HD}Lo(k4TIeGliq`rXbt>2WV%e%i3~n=}S+Xwzr*glkJfrkMLD5{B_5z za`u4$DTI7)k}lnou2wj31;#VsuY#_oUeiUaW!(^rs{|pZ@8IJlwhgF5bW4%hL1Ka* zT-$UGw70=^TpP?5+%as|o}Sz-MZisw{R=`YllM(9ELh)2dk#xrmBwJY@JFMjm%{@aMr`wCU^dS?13Yeh+YVKRmSU&?at z0p45@7jWvI=GSQF+*^G3X88@j40?$of82Rrn)Gr85nWVCG=#*AQ2BmOR%|j=?0ivc zeTsapB^Z}1F?i3_wSJDvKP5E=Y#Iw!=#m>FSKP18%AD*RC}z$jsH1?VtjN04ptFG-JE=_Arm#0@|wg3^6xF^6;$ zR@8}+csiDjB>0v zjMu)6d=B|J+-%m`rTyN>^Aa9w0GUW#WzQQdhL zSnW6}>HSi0p(wwnq=oNOZx}+(%_t@ww>gB|NE%8A8ak}nLsD24d#~) z&h>DzHeaBWe;Zgv<#C)v4FFf^G>qmHmERmHy+9D?I!g~_*Ta*?laIM z-ep`VXV#3lj_)@-#7$QxCRKKET&6ALaV9W&KSf%b&;>K{ROLLn`r{ZEsC=*J1h8&zjnCie5T8ZPX+C%~z~672 zK2NPW(?6ko@xQ*}jS7E?>WY^r5b_C5~%buZ1A^-QsR*#ls$JG_<#1AHiZizm7NJi5X%D&~+o5V{ z8vBY>e-`dKbq$uRmxYz{!%rWZ_0=|2vW-Vbr!4I=<}wx*rYUR>(>&J7%jpIVlD_lx zMHG1LXL%Cy3Z$|F%Y};He7P6bkWs({C=vPinWhMZlDDD(|J)0zFU9)pf4M3i;yvU^ z-HsDb;6pSVA^Pg~fzBhOW?!to(_W)%b~|pp!ZitsSX{bC7mJ#NPUmDQ$65NS;`Ez| z-)3^*1z>0+M7*|$WR!Bl6U?&~O`)5y>DwTk81qlL4F_47PZ*uKyV(_-5N(i;di>UL zerCLRh)1N8GfYv^(5>_W5(GVxQDf8hbQkW^pEogkMf8RZ^u2x|(k?C@d$+cQM^Uk6 zYZv!4asf&SUM^lrkEnOcXZ(4IPKqRlsYJ|${N3LgbSll*JfFcjvfEe&S^R2s?|7-H zuLiV`<&es%pL zPT(4;GCs2_7g_2S3ASSbWQ^Z_BI8+danhF0t9DOUa*H0S#!ga1a^$E4Jk}qx()1+p zAd6x%!-uIrOBe<%xe|kId)+iVM|MiOc$gYTb?Y%Z-nj4cL?xIf6;qhW79M4Dq8*!B((6qYE9M427K(_!;9Zhk}2`EpiPKP(|eF7K~$=h;+R=p ziK9WUg(*miGT2^gdlV#}FcZ(QsZ;!ym7dRak@b*c&yzsKf#sB13Lh*nxgvm5O%WGy zDWHAU-*kFj%;1@1==O20VQAAID)DxbL%Poz9BYhikY2Msv;1vfhhS`5P}V-iUBF;! zgcStL>n1tKq@M)oEGm6*Nax~LVF5B(bs;~sJo--c_?Iuq&XqsZOSAu+!LJAN?O<=n zOcV9F#IB!FSNYN9 z%a@5gqh*95yJOtyh}a_EUua>+n@f4Ft#L(5jBygEy}Xiph4`*3{(h(V#2iRErGdXs^Cm!<^sxz&M|yOSf=2_1C+E zkF1~e&w)Zf&3G(Jx(|4;aD%93Fq`KLk$kIa0+2Q#W_y*+m=3 zu7pf-u6)CX7nHy{`pD1K41FORq}*(dUHY#8I$vT@WM31_zE%*$iAg*ZK&^1Y#-a}w zNpW^ceZaR6`hXK3G%fM*ldJrm)DSVZ+8XyR4nJp&xA(chF}hrZ;9zkzC#U(0^NG9{ z^}}{m*NRLln zz-)=(WZri@$TvbKp17#NAyP8fxjSW6VEMNb68F=?^R@+XIpDYZ2XVqvbrIaV$%w7z zL~T^>kcc8Nr8}SudZKgINRl1Q?U!R}AFO3*i3{slCq!<3N^!;juy}Aaj2IU@ay`UYI4|_}c+y+86S3ah6gfVcSk<4J0u_sL zOAb{Qj#;}hZDQNpJFNFIZ05P>-yxE5`MAzMhL_Y2mqT)E8a2#uGGkLeFTX_&F zPTcX4aDVt&YVC?>6bu)w`8ONk-;9n;JV0qyJ~KMseK_%7E8t}%wLkLoVzr8^+!Ho1>NW_(c;X2ysD`qe-< z6_20P(wIQ;nO_F$1uf(=mmHI?RQlspz*jKqMFZ$3jwN$(i=q5E-|IU9dP)ay>g}W- zYoOMRw?Bjq!d{>;bN{*Cd;zo$V;yJ?tgfD3&gIv2`t$SffCNp z(Kn=UO(2I2iA9nPU}_27_r5OeBv~o_d1w@%|@h`BPGc;8Z1^WLG>LEnvzT*yb zlyanY`zrHm;`+SUow>LBa2J#%-2A!TRdE@?!?Za4rF=-{@n> z;+-Ul;nwjNVA*tO+lzK0e=HOts28=CPIoZhvzDf%=4>2^_VRuXq-&`Xg^FGUfynLT z7!Opf&(leb@K+FPjNDh~mBJBKg}@thwp86-SZD=c@_NItM3U8xSbMOhF-3hLKKFjo zJ-;rf`Gqi?i#!XX{2U;%>7!2THu_0I`7>`sZyY|6pqXOpV{$W_3Kt1w`txSXh;q5% zn6-na&~V4js;Nh=g$VtI$lJCKAMZ+oWdHJS6Ng3cQz?AxrkL?HkVCNDcqf!n>G_iN z1vb+6aKBzi?%pkarO5ik?h9x{`v|28x4PpZGLEv5xUZuc(fy{s50$hggs@@V|7aKA z4}_y#Hb;R3kU8Bq!EgRvyIumu=-y~NYbVY88uSKiohN5->wFn}7YP4SxpsZU@aD3n z)sf3Zcrv#%GTUzmO-7*P zzjFT(u$TUeb*Q?F(xYMCat&h=aaPV@xqZ0F>0SEk zIDU;oV7cIp$G6|oJ+ui>Jf))lgfp0cG9Xi_Mb=Oy@@F}RRl89cAF*|`Y=8y(U<58p z@0fb6Qj>>o^nxJ1`4+D%1k~89AjdkxV}-I{J43x*E9w4KBDSwWb(w<7}QtgJGZf0p&gi^9cmcG>&`& z%Db|ke*GrGmYRj=V4_RvH}npoO$%kh>yd&BBTOJv#3mB3u@LUq=$zyDF7}+9CH_Sm z-=XX;zm;LxlMM~GspCQQ!1P;*2X}2UaBJOygah{|uIMq=m{QaEfQ~!0diiURXHj`R z)(uxud3dmPlLdYg-G=A+EK&_1Q5o_ashNtM`R7zA9v|%WAD}C%673~bc42cOCC_hM z^+uk^+miF2hBb9|oO_NpoI*n*b29@Zr0_o-_Il=Pu_MEp(UNko&x)dFece~Bj#1wP zPVaj3FR$_KJe=q1mPS^(zE9oR$7I|3%S?9(N2XuA|a#L{Y~J zZ64diIYF(sCpY2SM!#=6=v7F+o889tX+FBi2#I*7-9|Vy-Yd=STtb+P_gs#>xygy^ z+Df+V5oGsW?KoyD=cqubg#?CxqH&4Cw$-T&8VI2xhVlwE_e8D}mNd^tL@gW#NfcPV zW&fp31LYe=I;Z{M;N<3<&&(eT%+|F9)QGZs%M&s}rXOAaG9)9u%o8W^o-+ALs@oTs zZ6tjzCC;yeZO`Zj(GZCkM)(u1$Y$1j?TwqdQ6Q9Rss5CS3wv4gsgP!uP68~ZG$;aF zc($6xiQd|1HCm5q2~a)=8aZFG!k9S?)oPAsLyClZdHeM?r!o6})^OtHg!n|mKMV@- zKwtDZbE#h94d-xej;@`T{@GvCRM!yMW@t(9nACLad}EdY$^gY1G7S{h@Bm>9 zi>o1XTnb{dWp4<6=|^2$z)w59OY<@HS7x@X_Mm@<|0rt|eKxFt<-fs(liMk9tD*PG z`iiOQ%@*n>avif}JMiK-%4E*Fy*lBZsD&2f?iW&aapDPZn$s5#VKn<;NBgj`oV2qO z3oGJ7Pt#j)ey11G>yeSW9WKy6+2Xd^SFrgTu%&-&atLF>8HYG#3%Ha>wHhWuuVeoB zy({v1mmojbn&sLuJk-;K_aUfGx2ZG!H!OI68q+_PAKKZ&=E@4aho`=+`^8bKpeUx^ z%ENGZ#<6eDnK%sS?DdN#xwB)M*6B|k0hI$_9VBy^N=7)lWN>;`06NSYg@a4-%7}j1 z&J>+L%|3?`JdzfR>K78hLzu}yYrE(!XCVfNz)v(ei$Zn6(5pO@b{&hEdJXJ%hi(Igf1(-Sr?%ub!=t>G<=v;*0{g3CUWDRP zW%*i4pueBFWhWx|{(0pUMeYg<##g7Qt{0BwHw``KPX3+YH5Bo(f=k}8SCfo1^s5ej zHTq%RWfOF^6A0Murfz1=ByjiV&^=g1la;xnp~4uc;2b69#k&l(3|#^RF_qH*@E}YNzf}wytbV(Uj1qd<2HLL`c7hi zZpFSIjufya;^VywNyOYvm%;URj?(9u455x>MZ;Yy?(efWAhrDW(Nh>@%YU0+_!<%< zF7D5+Ji2X;cD8*D)| z%Qz4QI}jzI-w~{!DL!_S*gLSex!XPn()$gHnCN(qo$;E!rGJi(J95)U+buOV#=Q_g z9wGZ!Ro~HJ-+r}0HXIgBCHO?0i{i!M-S_AtxL>s+JFSQGU3E?95kdKNlD6pTXWo5P ztngPcB;Kohq-_A+XZ1DFR!8WGdt$RKVYo*{MJb;NX`Va!&kt*3JJ{Bo%uqlK%44j| zj)_3aQ1x)A0u)bvm`7;dxkceCnKeB#*12-4%Ctd1Yqf*WCORX9n)glVvb*=q{@C z%RN%tXqH{O$4&w1XrNf+rS3aZ!xbePu&f5hP!?Mizg0Jaz7^_ArghT?TFm%}u zO=r&pV+Z)!Bek?sGp+_H1}l#eL9b9eprX?K63%hl?2j3<8Q*|7++HE3NP&G`yVoB+ap`0 zC{r6G)WSC$9DS}?G{*HqspIZk-w>D4f2ImD7^q~L8an#Yy{nw_Tq=o%NhO=x{Ne2z zJn>rK!dp=<0kgf9m}I4MRbW+IlIxLnCJb!Skq_~KFpcb+sz{$!q{T{fPF^V0cv7WsF#ee?bjtsmvu=y{|mC?lw=V=hiqjYk0A} z{yXN~W`H?taR9_jTf+D6IW3wgAKZ*pRhgSw168F=Ed^`l$(TD}G7o@#IKp*N%f?*k zb^N(jtx*Y|IN0L58*u;D(Qy^rJ$xX#t&`MWGJ}(R6jy` z6acF_KOXT}#&XlSI1%q{re7lCL)fwF;*nfW!X6icOld6m(>NBbw5N|Rj2RQO_{ZL= z;IvXQ3#^{WFPhB+0^bJlqw9gum!P7H41Cx6SxnSV>}*wIg2kvYhhC#56Y}}j7jH0L z_BPlR=aiFSn05+OJ-E_@9~phao#<1GGGHtc0HwP9>6wd&EP1J>&HdX_{;P-bZ9&m{ zx7J1II zA){)_W=!Ouc#shpdR9k_s^Qk@H>;Gy;`638mMK8*?^n3}vP*PNz2QAvdro%CQ(rXO z#!vZ8k(xTF>?=Wew#AW{j{js#g0jeiQ=rAa=-R>0G8igowoeh_F|IZ4ldF^BL}?jY z_{l>pv-yai;nE#u{~5vF%t}x5 z;0b!N_E#rG(qm97l+}Up%b5IuJ-daYXGz)o%{t2k^GW=Ksh=?xL` zxQ-@#x#r~2ausWvNhbLiWOVID)b}J$MEc^0PyLC7egz0+Y)UNd*tp=qYGk5?*?dC& zahxS8{itmYw{_LvbAhNbozp-~?VGApz+)WQ#|MvT2oTtS*h1T8eVM$IcoTd(+y<_} z;aqywgm0Fi;h%fQ`&w57x(7V5_X1gu4f+{=F_QY(S5tVq$~WNbtw?FI04VxwdT?>Y z77XI6BZ9LB%qfeb#v!LB8?qZ|9~=Hq9B7wr7aDyH@9h#Km$a`Sxt7jIxo`KgloE2Z`k<1XFk6XSiLg^Z(> zpdF6VTnPXk8`Gt>8Ka5d)HSaLt651KqOYphhj2Ylp7|fk9_SdGJ>OGfJrQM)0R2&Z z<#);RIjHV~^J!XgCTyczof1usR5ccyFlzHCsAgZMk6max4wnBK>SDa{1S}U@i(jwx=-V!x@iLXkXRg zYA8IPVW9EB^FO&_E1^ck?CTZ*H)l}DJyz!UuY42eIj^*qepCzRB{7+UzmFOu9W*%I zJNFfPLbW%sFOkGq^ivvTG7SZ2c?mAIc?nn>XMJgy^G*aV|p}-g9H_kA(~Tc;Z`xN3l4KY8;oYZQA6G0COYBZ7L2|JRnQ>hEpf; z)V=oqX3H1Iv`^g_DENM0M6_{B=?lA#r$XV+ciwIvcT;5NJ2We+bG1OI`c-0dAq9bk z;`z0c7KsWRqBE>$QZ1q^?L~$A_mepDVV)E9A`M_N*ont9U?ns-5N5#HnWeY(RwK&^ z-YstjX=#a|&olq9qgAUUB)LR_4*M1FF%hU#OmC2eU0mzm7-sRPV5&wSUE3*V2TGhV zwmBTj6rNnnqVr?3_?q%)1QPH$F!>(j98g06U!p+4Lb1C2Ho~nJazXDNYQCA$fVU*G zR-$OavAjkc#-4IPrM-rgTX6Ge&#M0=nsu{CS#vfJw3!`}(0oe6_0!(vM}B=Mj>>-n!KSxIu zI@}>VZi6`PvAW-(8Cgr~+8GpJyt ziGR~GAptsHkB&EjiuEq-tO)yn^5095g6iGh0klqKsA^2jhEYVdmIbYbIcz`RRS{5k zj3cnvHGxY9gLfE_Ax9|Vhl3)=64R(zP!p;9vwBINhWaQf)a@^3|A@?z9FZC&O{B~5 z0{SncfLfSzhgB`s6EY6?jfz7_<_1DJ03t2@QyKF7+r4a><}_`C2_q__ZQsl>w9ENr z-Y$LQ;aRJ*VkL~UqUOKL>e(>1mTzFTHnEqI6rvML7OO%6qQiH5U zb)rxh%^LcQ>Xwi(nJAa`OzN)Os#mrh=`d<{12vg)PUxk)pEC=DirtyY+P_Y%-Q18q zSGLc7L}cVrGKd-V)cy`_bb=8PLdYE)U+MvCE+rwoMTeFbwU32UWMBApFciNSq8mFOq+5yTPKn952%h;2T# zjZ6_yUtF~c=!9pz~d+0I({N{bW&In+o@)SAJ)@V==yLK{yl{|Xg{HG?TE`yy&Pf(RD0DqBoGCN z(|f&D{&}7x4{~?zy3d-9n%zLQ14KxFiirsj)xNFt+dU%X0iEb_-A~r-1ktaE(eSoj zPTb;bZ)Y-0?VA<0HcFcl^Ei$+#Fvwu>0F}f~7U~V-aQv7sU*v7EHDsWDU z+Bc6jn-vLOIDaj_FNZ3)b}}vQn27*iuFc)?)dhHjO&tcYeu%p`8$FYojy;UGbx&}t z)fT^@L;%+YT6l0Zp|JoA>|dj9%@{*3&fQn%z9!wz<0f?3o;vlmg%49%OAl|xq39oi zCN%JjHpZy@9FJ(l)o>lnA~PEpPz#*E#9L1d^|YhWRu5Cc3S5DI6*LJkM9f|OxXNlX zy+3i4wltb&YfGeFwN30kxwf$`eaxW5!VfQY8s1{*u6I%{PC87-I-6}2z*K}uq@DxB z-5g+e%%Ok3nSdplB+1jn6O&^e$ChyrBkX!N4wn6 z?rh^!5-@hPVUGnII};VDCk1&n<+@N8Vb5VEFNW9!*9$QOi+7UW1UHG^oFdRKGmrMs zaR^cV90K#m6{Irlka57o7>#yOGO=2C@wa3d0HI{>wn{~w@e-ZlAc1SWT;`Z1woKB~ zuFq%Jpj)Dh5v6dvl7u{3yp0K?Ni7l#Spsw6@R7mSv3u)6&^HrqjWcr@uhcDs1wA|9 z+lmw)bx$`qT_pebX+jEsikxKh{Ai|;E-LGhVGe29-}{% z22#KsYS_5XzcVqorhmgEl$rh0i8weK`jDALQTYORMF_bYX_|uv_*ups_^Zp@whT(ddHD~r2yn7lB~GyXq7))R67AD9^_L9G z@7FX7x8u`*x$rWWO=g9=8?6uNf+Ody=N>er5JHP+>5n9x(uMnNAUXH?#KZ7 zZ<|DauY|$_Z={B=32e+NG1Rb^juFj5G>f! zyuG{O!aXab^!Q*v_|_wAc0J$Nj%^>D`2!P=ZaWAF3~LPLH=j20(APfoyKD;nzM(!} z)a|~VTs1&{CjPIrZ*k3gB@#p1T;NF)lC^~OB{Zu!bBtvqH6Kv2EmIHXnn7MbehH>z z`2hB?04cJvMD$X`gEqL`!Gn!A)I)18e0n7y5j`Pgo5qb-9tmP<3`f#H$hFAjInby; z1V-bekT>Qn2sjdNFgr`(dGOSsR5mt<1hL9=YiAO`7Ddd*kSIRfl;~GsbNT@V&Yuw0 zrEk_GKPvS&g)g&NW0VnfjVg3`r=68F^33U}x&i*-kiL9% z#M>lEKm_C94Dk((2Sh3UCLr^u=;8ob2jLKOn=pA!aaA6sFJFfu-h^qL$dq(jCK>f4+RKx|2LZxQT%j3cDt**?TN++BMx`0 zb~@Z&O)_WIiJZ-QdTAqL(6hNw8%VzscGgM~U6~dYaJu*K9e9B6KbJmN0b1^1djqjK zaYV1bQ>v1hTfBBYuulFQf}flmV%sv}995|WjCr7DJyY2;!sL2yd1k#FQ{5Q3qR2_i z4xnD)%4FFf@QM_Khu=QHkP{cJeSUZ?@=|Fl?C0~w*+_Pp;h2Cc^R*tNMK{ig_<2(7|pXdjz zoW{+lj6%$2ZB9AYw4hfMae#=W-ejyB8Z(2ac^(f+5cnwryHR)NkE&FOUfZ6&EXVE0 z6c%{+I@}^&wY&#MAUV5Pg;CGihT7Mo~^C@C;)7}rp z!3++cEK-1}MQ%ml{tfS?&I2gt;+-ZWXSeOjrl;X5;2FDMD=Dz2RI=gB?Mm+N#`)uD zIy9k1jGJ0AtG0Cp4d&Gc%N-=oBB=s~3*E|Gdf59FRuHirOGY59s3o&r(eJ! zs^G!Wm_;<~K#{doNFl~h5dv;%yJ&0)_rELRz8rz=_E8DIH$Ul%SnVCahW`l1`;}=T zfqRATQK1{?25@MBeVm;X=c=`wbc5<)Q;~3^>v2QP+kI_QMQKe~_}%0JZfijaxZ>7g z0HSggqiMBOzoFN?tCx}5`Gyh?Fz$0twrq!n=+D@Ieg-PuWy!9|Z&n8;_-F;~>dj!~ zcbPn`cDjWaSZ6juB*z0V422s+Fph$X^pR@+S=>}R8ZD!OS&X7^>@K4Z9NQ(ovE9Wmig+`Y%V$NV$Nfq0&;!p@ z0i!R1bRSvBj3|?XsLd1dFijW%w|>V^Se(yasP zix=21!W7xffLvjsS=c@xs;vNh^jy(PwGA9Cy8?n=Z@EDGqr~psq6^_kk;tPQn$$xH zKvRNE6ZtDKalV4#9y7VQbH*5OSI9}6dowEw1R-HZ+6L7o0vc?}tq_4To@+H?9l$wi z5INq3V(XQn`yCt!G?RV{X;fNxVB#1P{e>9zQ_Ixl2}ggI)7tvj#T3C%6G7+iX(WTK zj$82KkGqOakPU_E=Sj&Fe<_QlH)V9WUdoU?^bo~sdTk<<^g^ZRLP>NoqhMjeQ<3+e zoh&_Zkcr ziP;W=ZlKCmC#e5G?)rMH0r;E-*aCYO-j{`jN(c~kvpS96k^pSLQP0z9GQxE5# zk{hwt+ZP&-a{f(h6j1JWJ;_t(!8OnSp+<_VcM@iePwgR?h)?n*jN1crU~xo7w+cKWGGx_(ZzP} zDN!Its85#YVN?!H<@pfU{>LkosN69$x>pyHH=ws!vT!Mp{mZ||?7wJJlhLx9=f~fvc@|0{&gl9-se{VsnNY6-Lyg9`yxX*;Y zHYGh+L81kT2RYYgsFS%r9mtk)lmzpysdQwF3FWV|Qzm<(z^RIR9P@II%H{_QL4C4Z}t; z)iqCjD~;_U9@HW9WuoEe3~mxxm=65U#@qXk+!J?d&IsMb?G5zgS!SzkYF<>#jC&#v!zSjCzQ3D4nb>}a2FWWN^nzsXx1OR$_>IkS_{UX)Zj<1;ZA<+ zYdSFFlpo_p9K27LAE$(SV0Sn}0^Ry~QHkcVnVQOM@CC-UD^gq8x)D5zX2NPq`n`V3YA1GqZkN2xk$hq@@LA@if0!WNgdfB1X2 z!)4OTL68Z`8#p2!WJP&)#?f*z4XLe*f71J+InF1orP^nO!3JtHFI-tpUC*Dxqg|_b z)?<6Y3NMc8@#lP(Z_F7UqvIes7hE^j6+mmgb0BwtCDclelv4;OpRFSK=k=#wrLJ zW6D6|6tT$m2k|uChCM>oo4;3Q)S>axYpy2wo9Hqwk0Acjw4`Qmsz062)S2rSsw_4x zO{K9~1POC_@?Q)rNBFBfE4V|G7?%*{0rhQg2=}H>z}w}g*MoA}gB7dyW?DQS&u9== zu_sPy+mxzuynmQ=N^v&hZ`wd~A);a3tsMpK#3ScY09&I+J%m?i@%Me(Y&fihGGQkT z@M$cZojtg3mpA~+ZO9>HQ}H?Zux1`mO7a{Ci2Xs{G$GornJ{6(y&sM?E_H)8XIVl) zKX9?ZMgP;&EP1)Z8D-A!Z_g@(7CVht%mv7^qw-y)TOSGuj#s_id z&%AYo_!xNtJC24P1qZ*4iHr9 zAza#thIl>2x4p9*{wywoOfUGR1;u+p{grjDGh&*i6e2t6%yf&2%fZ)ZQQgUc*59jf zRl6-mXY+UsUx`mK7XmxIg#0kBreN(`bK0}d*#B4}n7y32d0GGRi_`xCARA0c-43zJ zePwxj?Q~_BaH@{*m3~@FX1n@5f8~EYK!f!>6Kom082A-l+{JCrU0b7mF+GkD*s9P8 zFphpL9X^IMf9`qubP-7upi3LFh8P2e<$vJ*5kr9?V@e=*$Rv~md($iz?f@d%-CQ1p zg6-3j=52;pzx7x=kqehK>&$clo``}%>Nx($K4vltw>OMWe+uYm#?8Iq;Bs{rf5gU5ezg34ZgMq7}W~buyYQ3%2#8U8(PpF_xGyMmB;74-G9r| zkbsY2+Z}&dVha8_3;J>94$Su`z{jK<ToUB1k50W-c1*@E zVLJq2fNT!%ksV`DN46c0_O1AoTMX)LlbcBOhE1G%GwmU$G>L@;)Be<&y*`D^w5;}` zXM*bPnUXd)8JR;$m0-w3)&B8eKFDf2Ez3#4v~V%5hyNpqA`{*8h8z8C)4Ye( z`{-KY5cysSYI^txi+{BR`0Lv}?0gLJv9#D=oTXUM3vqX1b-BB?bI6J#vEaf#u1BIn ze>)|!#|^3&RPo%_7EUhGhtb@LGH3KT#PD~{KPwN#XVXP?BuzuAri5{;`A5)+PB^6E zmHWIvs=XM;#1lms!`8f!(B%d@WaYHv*Fr+mP+ z*;wEc*Rx|tC#3Oh!Lw7~JcHf}lz=oujhhY5hTce5aD9l^9?J6w538`y+C=34Tj_*% zoraLC*-(X!lo-NQk@Vbq5W)B6{*if1{z#Tq|uq>~KCy(GkCFmY?5INHy#e zW72iMty~gb(F;N**uiy4NvC0T(d9gMgPGN-cS+DSk%!yMOk4<3jgOLL#c#oU;JLG@ zr&&=mZD{kfw})t^@nWU_Jfx*YAwRjfjFu+GH;Kn(51ftjO)#wrsnn)^ZCadufhfv= zL!g6zfWUy*;an&OB|-}oe*fC}4&?7JHg$5bG_zzdws$h6cktwk?SSiJLS1=Gm9YZUJlu1`@_0wXG+W*4W)L>oMpPvqkUCe8~taJTR>w89+1fuMPMLsHK_ zkZhC3J<%yeCFhdUk4(~SS9@!=&qqwC1+x>PA$J(p+w@+GjJQ%$Cs?Zr}*0R=+` z|6g4yGwuyfA^`zGQUw8_{O;0!w!(n_*!zDwNXN{`#6{12cU+en3(K;=jnah{=j{6V7}v9(SNnVfZqR!=VI?* zU}NfLYV&{lFHsdSezJelSib}9zo`GA6P^CQbTSwiSlU^-7#MsH?*A?CZ z{{sN{-vG8omUjPFKlq_h@%Vy2sq zyVmNi>Rna)mptSTOfWDoSTIMt8`Vm)!KhSnFfe3wFtGnNFf(ftS91$@Ms_9^CJrWZ z8#i}G8%IkgW>F1w8D&*9CU9B#U5s=&Tu%Y%m-dU+SQ(Ay+ z0=O4|lK2ni+rt-GWvuY_rU0K-R@G5mL(4;BbBE_Hm#iVZ+DK(>&__0cMpfBUcnp(k zxn@<&Y+@p@V4$n7>w7=#-sWhD>>WUVTf2PAmhh~M{(a;AwT2~LSIUb{i-}J-;B{w6 zdMq(d;1}s0`^Wr|GIP-9*JCVkarRa$5QlqV2gS+AplGStbjQkehi|2lt1&=JM=wHp zc{-mkUw{`9K5Y%uHI}j_`%J&%UbeXKh7Om_pF;5Qy6_{6H98M#k|Uc%1n!%`bO*)a zu7^l^_Nru+KQWxllGvLbLb%97v+vMp5euK(Ci{S}X_LbqTsZpkS$d5wASOeg(}k>O(A-f*sL7aEU3AV5e|)P~A=vF(|Rm z@AY2RH148FyR^{;OvFla)ni1%y;pO`i+YdJPD6Vt;;`sPfqHM$ZH^AzUM1y~X~Ldm zju7u#Alo(;-*fS4yM|qSh?Pt zZ|Q2LUu*f@k$zOqYOqWGx0Tv@6_Lp-d=|%hFJ#b|8#~FK_7!~(G;#{_1jW5Z8O)D% zkuy5=)MJ`qSE86(zBFu43w690jT9T4-P$FlRwfjYiNxC&#~TJ{f~kOFmRZlfy?$Oo z!RC0ijaI3#469io{GQ%M?aHa-p4ctY+*jQW$5IQ$;huMFZMI$k740*RvJ786KZ~eM zYqg)cjxEuK`1#l^&N2?kZz4$byA{w3LA45Fmohp%IlUgme0sITKt4u326aSpZmRP3 zxEz<#ZmE@;IQOjOG6J5zkfr`lWp_CiJ|n}1SW4OFX_~Z@WpOppZlryKwf&X>oCTV) z$fo|(<~0K|8g+6?RKyBm7Ntm6(8FiKALku)r)8p6M7eo_Akfp(Ye>I8_5%vibs&86G=f-XO(Y7)p?FYS-uHxdniO3>%vKW zdT_i;K)UFWphliNRZEs(Ar~jMg3+AFW{*}yumLoh7X@@74SF-Uy#5P=r_hAGu-eQk z3x`v4!mT}ydh!El+Ea^c>>mq0JA6U|;I3I5!nmq41Ps&>ZcO(14qLbw6!+vH6i`$C zCLvL|%z*Mi%EK|W>?RWgZ)xwY!ibgL9M9BZH$FbEX<)`b?hM2VBhQNk=uMBSvw^uH+?Y_WSpwFhY-O>*P*H<9v z^ZU33&M}eVAZV=pMSQMo6qITqa;35^XTstQ#j=pxa}Rn2#TuG**!8( zw;Z)7oA6>)*4V<^3ki*P@)*&|ToHGTaYHhEOgogzgaaSZQRJaDKZ_)(C|k04V)D9j zAA07Gy-CU&^tWO;A~p^(5rcv2KuoPzDfccvvoD4qo^?;z55hh#ga>1~=}cLKh?f2O zTeB~SH!$HOpw})aQB~YVXCx0rTlV|XG=O-m@Hw1JcqdpmXWgrrl-_17l|XdS$%R<` z5h7MdJ>45JZ_=2^X{)I$)-ldg2?4@<8=m(jg?{0PAXAKvI^n-#N2Fb9sIxbIDDzIa zp`WNc)pUBjtpmxwrgOdoA^ZyG2If60&N2*^zeLbGqF`dWUTifKhY%8MT8?%6412$d zXV?{XyEHj%7Tl64$s5I`P*0R?;J%-hlo#GI`TB2^ZDzWisTeI9TAt_AQrf_RukKA5 zSN9l_8p-}cW>W`HB{;SKz$bHl9GViAnTvSL&x>lpmSn?m)+(4$II2{PMG2ZE;ZMd(ieD2;c zmjILj4Hrb3L;Uc+jtX%0vT!qm&BIpJcVrt$n`PtTy5xvIznrndklr%8&y)q6+(#JtA^4Z!SS zUS1~}*PuSWtq@SthouFH{hhze#Kh*{EgY7Yi9UyD2_;aqd}$=(gvvfVUj!a78K4FBuj<5ARshfeIDQ=|=`!kdHOtqpINpNrCEtO#=85;t^ z_sJD%V-bBY4PKSi+t9od6WX+`i#%M38P-~fTJ2meD;rlF%ZXNc{q47AmD*+G+?bYA zZ`Z`*p^xUHFd?`JdEwu6lm-LGMdQCWqy~_<}U9Fec1}DP<+a5<7cm*uBF=ci$uX zRn$aHNwTr+z{6I51;XhYdn~OxM-U#`ymPhe5ZH^EooZm0(2tPSh=@D_gTgJW)pjjU z_8WE*;@k-YC6uVN5^B_P1tJ3zYrbNF2Wa*~*Xc}C7*Kntp}nc=W$xS~##;vI zwpBqlW$bSvtHC~NTjN_92kVTmK5_?p5%-6s3re3(`%Fnp3h^l5(t#>{THBr;{hc^4dWJo@@J^5ah=5p| z)! z$GyeF69$0a0wtLF#+s{Z#^2A6ex>w17PouK-<8yWEZ_> zJ{?Sh&(^ClLBzFT?GA!XIAV%!Oc2v+mFec>-9N<>xrU|Pj6|9sA z+Cdl>s6TLDG(hP0%zos27qln183nnEjl@?y!@j~olE>98(3ka94KXR|#yOner?4JK z%Y3Ye5Erx6i9UZ>;HXq_g`{X89EszajNLCU#k2U zTE)E*rz5Tyw(VgzCOOr#j=*Yzq(o#ELTMOt-C40Pc|3wY)dCfIOoU+9RAf9ZDfDKu{vqje_RT4{LHeDIx9!{Q_oBkAF3YQBVUtz<+x>jrdtba4 zH6JN8=N!*^DsDQAjg>|YMXPJ|bYr+vPh?#g^fWqhBGq>lJW`(%*SsFBk^NFlQyv(4 z>v~-AHh=Y|#|Es(R2bGtr?$#I=K=7Iv-zxU5vOTOWDb zRCmu0AM^1Xh}e?laPG50U3ZFZ@pD;U#My;`6g+2Uinw^%+dsqfqmHi;CyVc%n1&^Y z)hYQDM5t~LOU)HJElv$6|LlgdRTVtb;x$fD@664Vwfgi4QJKmpO-@ahZD$1e`@ftY zKZVT0@I0qEkhYo38%m!gCJ^W5?(c>2N#6oes8LV^UvIzoZwD$8_!X_Mu8#qs-LJP# z^Wr{saZH;{tmUFA;w9w8s%l{oaUH6%&C|Np~+kb_#hiA z=NHQ?a1YSnBbINQQA=WpxI!y!Rz&_eaM@1wWmu<5L;nnilte;T&hzhs0YIIuS`@9r zCtE2~HN%tZadkVLcG~Pu=i-o(t6)hK5b0;gJEdYF{3wDgkZU9SJiXx!n-V$`LIW|O zNbdc3fzG3`$81qg@HA2JK)p?2LWA1EN}!}DLhri0TloprSB79Ws#s7!-+~_7b06K4 zxb*Q~9KuX;r=*jyk+8PopkzU*G3Z4`MhENV(4whp4?T8Vf*p=4;2`{I5)A(lm^i1D z0F1rkThaWxMc>yunRs6%30e#_fFi31wz>Egn+gMC;K={|g1d)aI5p3A$t&XG3j> zN7Vm5*%R3X?R|fakg@$(uFRo_-M4cVT(|s~?hrZT%Uzbg?P$zaX!awqCkt<};opb~ ztX1Vlh(%Dvc)9zHS6Vsrh@gS571PqJc)R+ooAwolaefjE2@AEQP*HC}yt{FB$(1mi)+{_8+veeZ1~4K>ft z=BF7{c!Xby47s$M<&CM-NUJqeBV3h(gmZ~JZ2R1|SQy0`#wcW1VG8%Ax$X;wj9A8> zI7RlhpUzgFA~B$CYD;k~O)D*%7w&^zkH!EsW5GTWgucD=$Ir?cpO1AmVS;q(i z5+m#}H7AZi!@A7j{4&8wEKw0|fFX%N)>m%Enl}DF+dYzPxT@{anU$FFol-&%DaycO zvvoL!;Z+dtK5H$aN-)A66boK#RRrGA;yd5`9UU4^^Jx_j^`V8ZhTvnp(bgb2M;4&{ z?cBN4(s18rxCBRhcCdfVsRzZ@{DnqV(d~b4Q_LjM9!=h^E+~LJAFB9(pm%|iBH#^? zep)PAkV?mpQE(xlZh30(XP`2Bd`ql>xpHJjTI;=~cadzzftDb_kO_W<(PjvQ@Gb2k zyZ&UNAfJsytb5v*L!WT)GSG`q#1^B9RX7jH)qJBh;$t+kw&qzc4q~VVa^|>V>^#Ng z&6`6c^F}*4Se=IEbgOc#YHQP_kh%CjI0H-T)NAQ7iIGrt-1h|_{*18OU9g0enl7;Y z7R+=RMMy!^X-d=-Teew8`USpqTmm=q)otg|mwW_8Inj=MjH%@#^H*N#!{<8b*Xi&` zCc7l}`A=`ioLz^CbGhT1lnoJOl{Ra4a?@T!-UPfpcyjr3IX9~Z8)nu&=v0w5mK3A- z+I-h2O__yWh3FNrs{V%t6#m1Vs~X&DIW%}jFcPRY-9olG)rRGor@PY z1>3+TR@Ch#^qlhj0_1S2>pC^O-v}5{V7N>1rxasI453XH`lsFh7!j`*hI@Z&)8b?G zY$b8ZtjF^S4gJlXmO|MeFeqP(i)hFwF(F(LQ%<^)+tyWv3o!g0vn6sTx! zS?T@TulTd9siC4Ex98ehO2055nyJ-!hf zBaxGwxx6B;{Zno|6zicALXdF`z8zXktwge~f;s_!y4dYyYaW;75kUe;Beis8(WbHyD7W z(9hV6JPv!S>nLxCF=Q_TBZXf!m7#Lm;{UGP!`}$Q-%&%B!L+k1B>eAx!ClC`M4*&b z@o_f4e$jFSYQRX)r zGhpM@4Ry>%i7s(NMG^38a|jz@R#1}>DQ|^l_j$NK7`kA9${e0Jp&0%}_)324kMIRa zKCC~L%Vf$f2rp#1i?XwEVQiv*>XY0O{@1QGqz?ec77IHJ0PkaatoxbUcJo%0%Pt*s zR)O}YKtRXgVz(HWD0z3lt1p_Hb%4lo-v0BvJ_-MEvHrxr00FM)>R(UGt;OoApYgy- zgSFr7T~1z}kk9Awhcrq=j`-X?n3Q|q=hsF`UDH=)PB#VvKc(I$ zsf#-eI_Ga@p=S=x`RBJjjeie}m>u3mEqmy)OM7AB%Xj=Kex*v)hY-zaRK+zRNJJ zob7Lo5mb6w?wYn&Y~u!*c`?8g=!*|*vcIB|lCb`=xzo2tt0<HS|awv91UY}r3p_iP2nw#LfI>mNX(#Xb>sd&J)P=~Mm?Qqu}5L%cD!wWR6Y>a3fqFKDRYUou#_KakF{ zIO4EhYfSWaMXyERo&rII`Tn?cAe5Mn17?7kDY<9ASQ&evN6knIxr?l}Zu^gw+_6PRBon z(Rq*1?zS4YN^bmO3*5tj(IJ>CZ!E6!ydKOc%?o~dl`HwR>ND2}fEmwWM)`#mh9*x$ z8ZcC$&#vD~(yR9*PLjss3-(JVfO=J%o>%r2VAd(6JV-3e zCluiQzVFquI>R38A|Q}NA7hI3vb}K_6S=dz=6BEC$$*9VekRNt)2b=1$R0OIknL&) zS$``0trCMm8yCJa(y^W$@Q|yLocxh2O7YvBhY? zTeG;9|DCGVeqMvX;tkSKu@8 zW^8PUTW^hJpeP614d8wMqxxU@wCcqC#ix3B{*R+>%cD9$0&d)bzUID{P>VCMD6Q#& zzLDsr=lUi+$hwVkPvFl0Ozg;}Cr4^g*Dj+1H?Eo&7yY=8shAJ?M_IJMw%em(OYL-s z`7!{wgfP=@ag}GHwX07aQ!)o+Ij*&9Aan{?dx)idCChNiStXnUhVD(2Q5-QP3E)MZ zY=Ju(Lm+bx1Ag?7rD=_p(VoUc#_l8$uXVloDNp9sABfcRW4i(xd^iB{j*LJU zC-?y6wv>z3d7vMxW4AquX%`;wI7=zU6QV=OC~G6`ePzXF_L%$9hxnT?CuK(lDcYby zCd!#qfz8xhf&PT^iWL7+WL~YJ9QwJoRNcFl2dT1o!<6ozPs87M)@#0qlaL)-V10JP z%Wfm3oCQM#!yUULO9yZ*uQ_-Wyqjp0-A^v~%*m|lQrIp+Z38auvL#If(U&DY{czb` zsF2a^&5h#ZLEN6bhE=y@)wFRWLNP!gCcWr^`rS=1fe~&%T|Y>l3}DDZ!s`Nj=v71} z>dx}2)_nE_0gZhA(A@ZbM;6VwdF%62Q}jWV!D-c7%^!wt_nuJRC$7d^9IU?4Wlv}5 zadV8FobJ3KH^z2^^4b(t?~{rynteqQFEn{o>5?I_U#@b1+43a^PAhC@@~*ao@%T8{ zZDc*$nkXv~=Mf5TILtjJA+}+N^{dOUKPL>1-lQF1M>UX>hxZWxRdp8hRwK zuGdD)h?%0*2{R{uJhw-?m0Jx7ZmbF5kmHm@=6I9xHnJRmB#)Wrc36c5yjd8z%93^F zK-2Vy496~fLP=K^Pm3}o%PBlQJRJ`K<)jC9H78j1=c%hTg};@OvCTGSjuz3taRLYf z`USM?@;F1_kO?V+B8!o{wigeFr*IV3e`!&C4*7i)W)(FZ_@OaiLp1S!qEmGHX=&p( ztWDla#o@#p&4rS-jnLw(!kspV`tp$InqQhVVbM3_ij!X;Wrd)f1wuDF=S)O}x zEYtjY5x?LB4{$@Vz1y8+h7k+zq@RvK%I?%!l@mo2X2j!gb!zfY@JtcSlzrj9T#rT~ zw@bDskhmrd%Fj$5SeFpNd?tc3IJBgdS~ntxMnqaut(mv&?Lyv?%6AlcJH!{+VO^0G z58qbuh6foe?rS` zZYKu=%PX12sdO%;2l=Z0IePiRjp`5>HXrH#FrSGt*|esd@qTqu5ai39{cmVDwJ)Kp zXn7#_H8j%P<>h4bS^STV5}+W5p608o|8uZD@7-g+S}s--Unw|#?q}LG@tXRa;&>D_ z3Buogdfv#x*f6UXw_Q+Fwg>$7qR9JOj8UkrRUFv7uu+;z=M#VjU?$oQC=Pt9bQ0C7 z`fsuew<#sYNjO}6-L5nYt9(}P_v-1DA*}y>zjRm6BxKmoR>qaxt6mMa=EdHPyz}zN znsyFNzJFjQx{es~0Swo9J?~-fe98T}Jk;*Y->k~+qO>=4)>4$wxnaB?ndmShtLTgU ztKQp8UdVB=Qs2=j0CGv3AbM^6M4auyGP@YttpO8C0L*BK3%0A_-uQ2C75bZ}x=BDA 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 literal 0 HcmV?d00001 diff --git a/venv/share/python-wheels/contextlib2-0.6.0-py2.py3-none-any.whl b/venv/share/python-wheels/contextlib2-0.6.0-py2.py3-none-any.whl new file mode 100644 index 0000000000000000000000000000000000000000..5d08a03a6ce658e25d62fa7d96a631da53faef14 GIT binary patch literal 17188 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%0D(-|d4ev*;#QfHo;5)Q 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 QTvUN}@a=;gcQUCw| literal 0 HcmV?d00001 diff --git a/venv/share/python-wheels/distro-1.4.0-py2.py3-none-any.whl b/venv/share/python-wheels/distro-1.4.0-py2.py3-none-any.whl new file mode 100644 index 0000000000000000000000000000000000000000..e94a3a498b11426479171ecac558e7eaa2b9ee40 GIT binary patch literal 23898 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 P&oKYvEAJToXZC*p%F?U3 literal 0 HcmV?d00001 diff --git a/venv/share/python-wheels/html5lib-1.0.1-py2.py3-none-any.whl b/venv/share/python-wheels/html5lib-1.0.1-py2.py3-none-any.whl new file mode 100644 index 0000000000000000000000000000000000000000..f56e2979af697043882883ee1af06b30bb6edf83 GIT binary patch literal 120020 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

d;h|Tyf2BJx$F58r)qn+s_Wb7PG~VS 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 literal 0 HcmV?d00001 diff --git a/venv/share/python-wheels/lockfile-0.12.2-py2.py3-none-any.whl b/venv/share/python-wheels/lockfile-0.12.2-py2.py3-none-any.whl new file mode 100644 index 0000000000000000000000000000000000000000..4d2a1c63aaf03c39583a76ca58a604b198d2ed89 GIT binary patch literal 21972 zcmagFQ;;Z8lQr75ZQHhO+qP}ncK2!Pv~AnAZJYm@xberGZzAs8h{}hmhn@Q&SLVvh zRSMF;ASeI;01yCnnAb`b#sd*4!~g(rDgXea|GwJT8(W)M+L+QZ&@nR6G0~Y=I=j$X z+L_tY3#zI}$SWz+xp=t5`pCv_adqtY`Guyv4p{VW-|&rsVF5Suf3|JA$+wQqaApHa z8%fgmDv*^_)@U6QjnfGxmD6ootCK3rTSXM0lMFl z;wPfKKYSBaMDuTL@NlVTRvy;WH9yohw!7`HN$OE64_8$Ce`Z6gR+c`6M$tKysZ~bJ z#K+_F`Z;+yee_Z8Zj2O5-rnnMX_ReR;hvUKf2`lVRWZbBiMdm$({b_pzHJYRkH+Wm zC=l*4f6g7s)BAsYKStvhWp75mqO;F$!`tiY7A`g#ZJS$db1he})%&VzYKMt0P5r_B z!@~&-mAd-VIhwpG`Aog-Qo1nzjs%&_os9kYHV+cQ7@3DU!II4&0QpN}v<+{1+l?na zb6LE?9Un?$hVMZQ#9!#D)_Y*TfQm(InZ1wOu)$&j$RGLjEWS$R8#^X7d$!H46spC&d|_7|@hOx`!VII!yGR$0y^@kJ!9jnORc?M*P$!~$CBX5|uetJCC7$67R3^(u53v8JGc&=i#wB$(7+f;_ILV!ADL6=*z$ukV z$`Qqo6JFE}S1OvDsS0M4YO*EzPW2*P3mv?`c>GP2-8Bsu_M~qS!;D++ZXYKuZ)2?T zdW+a-y7>$rR(DUmM#W@Ocl0JkEF zF0tjR7?;eYQf!Va;1Zvw(%T$U&*33GRJrW4R5eP{(wM49XTsir>OM1H)_gTdI3pi& zldAq{)fy=|GJF{!(-PQAu%T1_&$ITLlTtx*yxctApP#3vx4=Fhvyc@uRF#u&|^vtK;WQ<7*W}0+f1QCpzIR^ps#Au*KzUk zrMjdKVy<>6rPmohP-ZqRinOR{jj?pi)?;IHYP!bUV-ByVez@I;fI9-2g2gHbhsqFX zE2&Hfc7pf}&jtt$7<9o@V*Be)jX-F?9~GgEp*HfRR$b@l^VHdtR+~D0fI2b+z22WU zud{T7=+LUGSuoEP^}J%ucur&%Wpt>V!KkL9yDt83Khb)|?Uq5R2Hq&#QU?jCDrTH+ z+lsck8(;@%TNM(*FyLH@mf&ae=MXn6M}8~mSditHz*m>h6F=6Z$R0IlnmW>6b6niD z`_ZVK`35u91m|nvjMwBBb)T$mQm6g6WM1il^PFm7i8Ht4hb=aDrL#7G+(%m;Wo9F$ zrQ`05@~WGdyMe*6_O8R~8Oy>>QO>Y>kEsVz8IXX(nz9^}Ca2*9<)w?JPjv2=E`!h9 z(boxi13u;qhxi8mhC<+w?Jz0j%Vi#Ar#3}E_%klad;Vx=1yBHV*B!|VK#`K)Syg+y znEm7SJlbu%B9%q0RQl4Ol%+uzM!xu~1<#>G{M!NiIcx5Xgw&R+DcFJw_Kx@}k3i9U zDrp|Tc@qYB_L~i*(RMLza?n5~TTqf*m}tg6X%*^t=V7 z$)?h3t!xRJ8qT=l_^`?y>gadPSxb=_vhcvR1p$P#+?lFK4uC|M)a`1xX?7KgrkQ1S zI@MS$=be*CiR*>M5RT<7A%CA1<>%isxcaW;EvLI2$Y@RLnxE%VlUo4-F7J$JS9WO< z>WTh&W>UE)i?eIK2b{LznUq4SCB_D-1qf6ZiuI+xkd%-LxV5rG;?-ZzWLH?kQv}C`k^t}B*S-dCp ztvkn48{~#kILt@iliGlRnZJc4S8VNI{PR2I_9#@LAW;HE7tFK57Z&g#%M>8Y3il6(VR%Rw;=CT^OR0~hx*i?h4-Wp2Rcu&N`cXW&IG zjPFx+je;gxxF)f!T$MkO`#mp#87yY~WAow|{3zh(Mx+%ai_FX&A$PXtUA>RYml5Mt z#YqNM{STXc<fbqh98SK8Fwn6H@$ z@N>tZ<=`Vyi^&nnWbkwiEx3xXAHbLooTf62z<=6;^=vH6%ZUBo5|{;F5hNTQZNeoX zL>{1i#GOH($sdzz_VJi&#ON8eOYv_%)n*MV@|Sm?M>N5x`An1QH`km~_^VM;AC@7=&LYx z$1kTYX%Cv8GnQsL)Xd!gjc#Kj+o|_97F(ge<9zdb#V*c3!KRs$3U0Nz53%tz7!HNm zXG+PGjla1xjj~#Upur z-N5g$8k}kL_Gh;`vT!3ml@Q3H=^l1eVB!EkylN2v#C|eK*Y9n7pegI<7Of+9O{M}U zu$X!j$MM+KEnI#e;tuJeKAb>ImeT59jMt+}hz|4n`bWjQUi;Zq*eOD433)3d{I{XU zcxv}u7IdNe+_E28KX`4huSb4dgoa})pCR5LfQe&j=BZ12D+lRhwPI|Kv6310#U(zM z1#zEsytkh-&58#&$L<61q+(}i!DXinW}S{Q662l@B}LTwdeNXiA&4GSOPC@9O@u~0 z^T{Q&2T9r*{J;4Jgo@|JO|M`lDWD5GYyQk~qb137B^XX`lIaV+MmeVV5@M8$E{s?( zXJxX9yjW}vGBqs7{1N8wTog9jcYal(jzI82HwvuyKs}83u#D&T<5K5c@j(8bJBka_ zF-w{nVp$sVrEa!!c|tJ=i(w{AhQkZ1RUvO++9}`tIT0NxuQ!;%!}I^WI|`h!8t0fB z&kcV9sJRB~#^sqt2lEqgNsN@K%2)9z%oH^r2aTW;U7s5Z?krX6){vp$(G|3?-0-&$ zUSNzo=bMe55OKGx59)`6*7_uTH)%+Igw7XfZ|V!Wy#1Hl6$g)p2<*$dZ5AtE?jL$+M4M@1(a)}R?JVde0Q14;Fwt~$!+Cys`(CYwQnkMN+a8*20zY?8!QJ%;gM zA)dptmh3R1ZY-auG!8&dzooe{GnMQO_M-|>_egyW-&m?5tg! zU5)o_u_H1JJ#az@bllsjm@W~5t!beCWElWSa^eWn!lrtE?NJC7#?L?QOpn#`e*vsf zAzN*v0>t=(CJEN88kox;>Lu%dSjCHbLDiiFyKSHw6y#`gd$n&lukGI&b`gSiA)yTD(##d zJpRG7#bZj6LchxlcG@ny!OCTP5oYFpCE++Vmc_u-*un|Xi8#7~nJBt_q8k#yS0Uw+ z5g@xcC^3=gFg?*FP234(s?2|;#H^nr-=3W=ZSm~oBQuhao0yy`-AecO@p(BrdJ3Ea z=Xg%FC2TdE(-S|9kHgQ+-P;Z362G}mCWnXTeY^SQzUeQILkmF(ISF1tW6A<^ry-m|G|{ z#n?xL3R}8qL@18NV+*dZTo!1uWwV;-O}9u92g3;k7KKHU&-3X8zXv^8F)dt!N-~!x zYlI@!X6v#)>9E|J%0(w6Rzwxa$J0rdwogHY1}TKdmukiRI=SWyndCd=L;RtG7u^MU z0n4MXL1|Wrb2C(QMYu_(Lj>JKjUy!~MC!b`UB&_EErqrok(CU_)Jh`8tw4#$N=peN<LsfP*m^bm+te-cS&~_*uEQ*XUcW zWwoqL>fWA-_`6EcpM_vuP@?hx%X5XH=@}u|{v~`TjZpP(FttkhwiW48Sw2KhppIa8 z^noG@SIFNtLTiEht`X(q6+>lvwqi2W?rsl1#BSBJEKnf2R_D}-p9{J%CWN|J7@gna zU4fmS-QTZaA|{ZfiX3W)J!=QvHM7sDc7X$~+$HIo_WEp@MsETeqR?hb?)3=2Y9(&y zXlNzmm)juBl8V7cXjLrrsOCo5o0VU!)bAMNv*Q3@2+&QL@>)aum7O%}3P>%a9sNkf zt(X#q4#h#E&_5zSV8$2Cg_oaI2jjq*3!uykiFqvz;I3563j3;SyYIuP2zlO?IL4r% zVcy9S#Ny6o*G6K)Ef%2lkd?L~4#mR@c;1>n??CU3Zes^d&B={^SZT(+WX-HikWPG)vrV>7+lOgjX(5it zSW>Iqq#Fy zyaK|WY6WmG5LrG^_?C2HLP0kM{R?_h_-_sE`}>j}IIzpdb;b?BVU+twN&%y@HCczC z6k%?^s!bz`kwYG2^IxnKc|H(hJKlZlZ0k?{P|CpQfbpRYLPdKZt^%_T&x83`yRa#z zVth=q@eX@#qbba)_(xY|fx#(i^?kI;W)NtMByIi8&j&smEdKvbeya1KAv1n_kFNs1v}1-{?YW_L6m3HX6CpsB2zUn9pz#CpD(NJ;`l2Ht zo(YGkdD@dg8n<=V)ee(I6C#V2ISb5Hd#BXrqBXX#;8-j2r}_KJn&X7L{S=coX9ASO z8EJ28eiEG1rNpwLp+S{Q!G|v>oo8dSD zoeZPd5U(b*WVr^b0JwQn3_1PXW$oIVbO=g1-UfGsqV6e?B`x;pd6l4WGBljQEXsa{ z;{lwrV_SYEbyStSE+DViYT-g`)C0pAhuI57EPW>BZ2n+L&zOir7H(-qGJ>VSbp_v$ zQQ%&HR35G5bD&G&Gt{x7%5HQDoLlu2v*VEbsryDty6(Y5#IsMaD1_FraDJV?_1eIQ zu+@N+Q?{267fN(y&84F3}YT z|JT&P*4cYTL?1c@}9 ztG5;yxQCIp2msYDXS|d=XGfqO;QS!G@!-KA2B#m)%t z=|Uvcjk#>G?5^B+J7`x3zOR7SYQXKQfsixRNZV^Q_ETkjIUswmbcV(5P9|n{S&TgH z{L~GI$Eec*9X#F-Z=J=OuYtdb`az1Gdc$`b3Kgc@aKKm(gEqQ<<>=dV`yohl(l^47 zLf&iI%j%-^m`ec&p_Ys!$ecI1e=Bye)U=QgJy?Br-2k z+mZeAju8Jir@2kJeiWq!#AQz4_Q>a5&NFjtSZ zR4k6x3x4sUxBHwrg1MRdFdS!XIA^s9SdR;}$3FSckPVkj-OV?qD{tNg{mXS0-Z!^7 zd3k)EUq_$f@L@T^vv&YuE`DF%>&fAx@b@6+!X9fOdg|5<-x)bw$TZxf+Fyi@E)+E`)dU;OC5p2vO7J314NDF}^P@}NfXIEfd~3ipWx>L_*RZcpzRKk7PeoiNdQAp9|3o9o5)>7M@R7`&x;b2dH~OjONOyuF!AsR`ypyyxcWZNd zQVW(YT%8x+Q;@K#kD6r424UQ_vNIIQj;vq21308nh%cR=X~l4OBBviB87`N&pdQji zcL~Xvph;FWET@>n9r9LAA2bAnxXp4e^74N;v#F(;l)WoUo8Kl=P@pGW z5wnPCn^Pv4nhFXxB!C0V@syNh|K8DZthmYd^2ljMWV#m$Lw#ydPW2nU&T>{s&1^V- zVMEI@74sawexl1BQQDn$)wIqtANARwAEFzX@eH%Fgfy^v;EC_#vM{D)WTH0dLSU+| zn79IY#arkVV77tjnVUM{4kR=xC)2|mbzV)F+WDJ#efbRrI;0?hss#djn#mG__Eu%6 zvmvYm z9cyk*UQV81uFWHy1>jCBp*8=l`AiV^h78hTB{0Z}3gzg)Mna-THkRt~Oif3S`=G(@ z+Exr=!hJov6{%5obx%WgSQMAG74Iovc6Utgs=Zd5?YN@7w4_W-ANCG%=Yqp7uJz4d zj7q7o^G!fkTUy%yw!G1pj%{|yd~ z?v-igXh$BN1nMXw)R(RGgQ)QBrB&}c_6{0Ul#f$>&ZrhOVOi#w3G8eqW8m5o{$Ir? zjQkpytFIw+H&AMus-U{~N~BhjJ~g3hwxPuZ@mxq$$qR+w0vVR(%BVa+*jMQYKGOOM zw(fLb8FrLr`rMHP3+On`pQ&vNNQrY;lHRdP0Ei_-PcQJN`nf`Zi1kfcQ_iY|)jz)} z%57&=&@5RNS~#VJX_9>vdz^~fhJ4$uZz&r zeWsUrhUz;y#8JhwuM9`k)^)h{zN-(>ly5}o_BkuKv#-Is_hh;-2{0)sl-LL`N=Pnq`la!^UYzuS8QpUGg!upDYgp$feSrUu)I^O{Oot%hveqf zM^|oN?mVJIU=t-nW1jg(iz1Q+!;c6~Lxz3WIsQ;CTTtE6U9m+DTn`=YPDA6S&BaJ> zJDBnvFdVF9o<7!$XEx2tg`HmNcO6%Wk*4RtBC5;$h{*<<n51(HY0gca5NFxy4ZRz))fr6N4~PMYjFkDmiH|V3yOL1UOVQ4^UmVg z)@80qgxwZQOwcKb<_jR5u_px@gui*AjzVfZf z=Ph%u-VkoFh8%a$`o>=&N+zqmQc+Y+#my5$lP4umpH zMkX@U$E=rxSQi3w%H?HX&($R=9@QMM6^-jgRQtWEJ_a-HbA_z9%xFAoGsEuI>&ayd z$co4=XziJr_gB(t1BU@S@%q_)#Jta}^jeMuZ35($fWnTO;&?#4nZi>K7hMH1>0KV| z@b<3wZP}}+HH+pA>xTj){Uk!-3$6&iUD)Hup}OR?1Jp_PGB#KGn`6Q zU%mdX`ksjt*IvKjg|p5cI^5(Wy`ZI#>b2%`2fm16aQWA5XCD(_T9JkNR3w<6;|4~qQ}@v#>WGO$dk#;u#xM=ELSqs1T;mwms>7y* zj1X)1>61R6+ajII%m;bbS9#Eh(Tl@#JP0}K8TNlfkLYK&8TtA>7--o_lQd_4rl?_P zjvTr85-v@j79@(7k~us%+8=z&2={NRj!|vSQdX)8g5;9WjMt|R7Z3r_eQ|yJc+{=) zSOX#9a7q2ci(uWi77m6c(Ph>Y)JeVuy*~>w3mf*m5oyqX8o0lZNV>e$HL&VdC+@^z z(4!9L0%w=B#+$Vbft8(!kAfjr1HP4zz|mfFZG?Fajq;@?ox1%u`3US7p1X6*QoVa% zz9D({F@n)N+UzBUUruvNzQ!kRk){^~7xO}wp=tE}O07NCJyIPzl4aL;i?aaTObqyy zRnU!*X`W9Fa8)+hxqCs5XkzO%9_oOYOve~*SddP8yxGg}a^=qaTiQ+TiO9>E?Mr9r}CKCN~5je_HGP=H{Nxuk(Aicw0-yr&rfn%9h=u@)vT|ow*Bc`{j`_^$d)7 zZ{JvO4JPpOHB|HMted&xB^PIDu+4$HQHj}6Zg=vuxiGzB-C!>~-ga72)(cIc*27qu z&u*bY$Ijjtcu^QTa&_%knCaXsy9mv>4h574K!1@9qOD^7m(6<#-SM}SA zG8Hm6B{0sKmYfP~2_fg{>-?cu(wv7`Wi*!ZV2du0+4ac>dkBZDiTOE^hbWu>_Lx9< z6g51E!<>oHB|B_YnDb5ICT&3KbbhCz4JkmanrC(b8o_A?=zI*{0xN6e`Mc{hnUJ+& zb!A@q(rke_I?I-~HHFWQ!Z|BWuE0|QG4v~FIwR3xP+YwQ`Tv=hdQyF}I)6sfp{6!UBwzyy*Gu3|HB$-=X%p)K5Ub@{iqbAvP>OyQGSfXa zgVbC+zKrVmS&feS_9;Ii0MiS}GF!}3KZ}Fd?NX3p1ZgC{2ht+2yg&(02P261P|#7h z<&%|{5G+S>jrXiG6o%*9vU!=j99|x;1{`Sf5q`!Ce5o=jhWzxIDvkM<@7H#5tduE2 zaU7$`?4r1wANlB?qJ}sATGOr?D9u4A`Ft4?&fo)61j4}svz^p+if97W~*4bo?px2 z{eBByTgomyiTZ8avYfOKz2GC)WdjjyUUG^)dRl&clkS(@7Ps=!-38gMMcnH;!v9vm zA)#zI-XE9z_t1dZXRvExu)EM}B&Zc_q22e7`2Iim{J*!o-(`P(Nk86uzrJ>VUuu6} zZhv3!e_!PJf9Xx;3P--U_abk2Kr)qe+=GD7h@lr7pW>Id@nGLjrmPc zIm6+&m%T3himajmG>va}73 zIvd45lM4Yl7GGzz9a>Cyyr({8%s-y!pSZ-G-fY52*Z&qst6M7{6y{dDoAvr%|DcMvw~Ok_ee6R`5u&MN;$!1bXOLNtkR!h`1t6Ac&o+ zAF(xNMTeA{ry+DKWM{Yzg^PTKG>M5KV}WShL`JY)F_eaLqD+y_IguW<@{V=(8AnwS z>WvvMU#FfXyV%Yj=^=g0sBCCaYEa6Ia&!_jo~a)VvscQnoW$4&S9oIODpH;zk_O7+ z>cp<|U=j6#@ry)jjAuX&DbqT16hoQn8@&USG(M10QHfBRG%@c&BqT=yA^njWS{3%! z21NX2Z#B>So1t54TkP-6Qt(%4+NVcxNvbqO_S+ zWn1WFim!DEncTV2E zT`H*dOZU=Bw2i58L;ky;CWX&Gv2ct>hk7?(Y@Lfp@et2lU%u~m4O3uQWx4vX5Q6Di zgmVL8W_okB+7_lIh3`3hmEBAZmxGus?$Z(B%RzS8Bb~f5_ddNISaGv54)F9ur$(+Y zipw#+A@}-SZHq0w-*jJkW8urMidtUiI+*YKps0@FcW&)IS=&0gy5Iax=H=qIEqY6= zhc_YHEfgj~c#0UGa1^z6JJGZLK4ru3x5KBWX!14lN$_eCCxRZV+zrgp?_ql;9C4B=z<(IwVo?4v-I&`_Iv^-j#LoIL)Ah+GJa(@6&UL^Fj zQHi*?>q=Z$^%<%sS4O2gD^o1Ts6t=Hu!=amtb{{6H^U+bZ4z$^^v}< za9ye_x__pQdVKg?KhvMH_)@0A7I=9)QLzw|&^^<5RjqJ@jG30L4|z18ItJ&-`I2;a zxKy;%hF~k8hff7p_hee*p@kxBFeI;Nk3?oy&T!3@V`-JbyPp{G6EPHX@+Lv3N@B@! zQ!#g2j*cTB(mN>LkatHu`Lc0O3b5C{N~iKVu)90 z;vpqw&%eKI4mA= zmpg?%n^wi!^XFp05Lk0swWTTRY0&!B*LC(gf7v-t|~2*3(NGi0rwbLMfjdJ2Nrs~rT0mn7c)#}hS@0p z9P|q!YDbf$1Nr(Oj55qJWjWBpwJmgFk#rgbT367n66F8#UZjMKRN)8&6UtW`+_voY-4+8DuSAWAk*z zk!!RO!q2r4hm8A!8k)T812+}5uln;sZ5#yBq?gwt-ooW)OkU55-8vKNZ`o?dvb{(6 zJ9~@y^#l5!*(hyM7RvTtNu~dnkqG|RY@{SAEUzTuyEvXyD1ZRA=gkkzK?6Ew2v<(g zlrpA7pa+psU2Kvl>+^9Qy(lIVKicJUKl&%LmTYNwe*a>}jgZuu}ATDJJ_$HW#F=+CDvnxP)e8~gW=AfG6 zwtr*d!c*(2eE{SS?6W(ZmJ=1PZ(mh1%a?WR?p6O+< z-R_>K=sGHPz5J_bt;M3)Lkz8V7;BW@!?$4Em+)rg+xMXcyMN#Z;;v<1Sv@En%=B9j zt&ni-5|EUM>G8T5wqN%FSksY?CLfoP0zLOwZ^g68%VIf2nzxWc z&EVADLs-9(Tio~9S5f{m5v2*+wIY^dFwN%$Igi`}aUgOV)y=T-kFaH}N|f*Qn?7!3 zO@orovE*&B0ZaF6-v&|vvJ_^%Ugg|#NOH=P#WO%cuT+KaDYAfL0OHPEPif`IA}w1D z2#kNj{Jj|fJ+l+zl!lx<57I=p&(i}%k7+ou5^$91E@_Q?>v~D`L@z%YWu`!*4Wa$C z;Wn1-73^0otDKJ{J!iw^qn3M3myI7Tjz{ZgO{H)W45VkZmp$uKPob}e8unju5HUqJ zI%`TnmvkWR|SZ_zUl7}DN;TUW~s>Zp%5;QtKOzOqFP{eK~9_s{VE*HBfL5EYey zo|TZDo`;pDrJ9+VZB$}dV%~F-pO&VTq8X=eP?C@ur=g3a2d_|^W0+%Rn`d4)f|{76 zpMR!Vfu*38njV*FP@C}&xio}86lmYw<=5{W@9()K@!`kjLiAN{{O z(fzaky{J1FInh};+uQwBlbWT8r2l`er`({VAl1Uq+9V;Tx}c~qK@&$W^{n|JnbyzTL&%LEpyI&D7?t{EXb>l;rXMJkMEI zJJ=Hn0Kks~0N}q=^#AufdVPIMJ4+XReL4rvVJvI=&6bx=KhS-mRi~P2w?QzNew?aK z+rWR?zD@9#0tyhVLSwe1vm_Oq-%sxuLP|wHl9{Y%NKvH3@YCT(wLkUi?=h&ADbvrO z*4Iui&^09E7A#U!s#`Rsqz%t$(`%hkn4e6*%b)qbVSMXKMHZ~#76JmV^q6#sc%gvWO~%n1^~!ES0=N?^K<()v-;~ z8@C$X0Z)8c$r>IbH8fb^9sAm5sllz-nh-5Zm1b_F8T-u!GkO8(#8 zD-;f)E%idg-Pmnyl*~~!E88#_j7YVc6BDc$U8&6sfYXea`pJ+I%NTWXCWp-{Qo-VZ z$53i2I58MF(Ub@x-ob(vLBrsz&POn{RE5z$&U++$z{FrM^w{EK-sl97c}KG8)heo3 zO4OLDF;%U`eIfKV=Q|0QUF`Ir1Wc9ZaehSI+r+`jSA$9%A|kl9p|)*-+Kv7CVB$Me zpX8Caz@LZFD+}$zX-70#)r>iuxje5>1q2xhvB&QX&DCh0GbY_?SVX%6<(17u?zfT$ ztLe7N8YNW7XezJif*WjIoLU4<8fy;QeSamB%&+K6>~lbSy}xhJN3xODY|WmWsG9`8 z4JfV>>aKh&%--9K)c6dqZ5;r2)hgsL zA0s7QA+HWZDh^>;2H;2`R#LPKg4{<@>_>v$q@%UGI3`Z{q9dUCI1u_`Qhd*g!Z)z zd8`w^BfE=fQGQe+xa^?_nr1UORhFqJ>YVf+8YwDvVEpthad-)93GIeZ+tGEr&*zB? zCQl^)tvk?4u@J4$@<9!K9uSxcv=U)kIPtU+Y0eoC?0o2a+cOHYPGG-RU&w_nspU4) zg~{p#6)ZXo#P!j`i(7chY5Z#{Ah_&FD_B7)-MMg2rtT@_Ti)@ z04v;zWf(c|!l>q-OI!<1M2ZsIOhMWTgr(meQz3>T^xdsJHNw8IzM%>WD*?-j$#EkQ zhHjCZX^CzkJcr@Nj^Dx8^-k>m{o?>KaB9`(sNx{+?)xs8IpZ9%v@;W5_l*zA;BEpi z_baSsv8o}9Zx*6cWDmgo1G4l2dkt5&MHCekG$H zw}wfaK{G39>Ivs>NSk}QxbsdPj3ezx5=H52vNf)J$#BeQtvFUf&?NWqN)G4D*F+J84R;QOoCZRq!*_YB%rc z{i%&&-nqN9#P)2h3b_kMboI*6BjgYD9IZwhs$dtM%bpAJ zBY?F^a1a8sDyD3MrCyN>!%0F4;u>pa?rw4fH{HATZ=&h{p=?Luh9mBeJy-NT?BMT5 zimP{59Pd7xkCm{i)qh5S2I*jr(EbiooSMrns2IXpP69PPia4H#loNvz~!s*H8 z%z7zS2)F@D()>V8kD$4nE({0UV2Uu@kQ5rawDCp&6UC|v;nvJ}q^6TG&!= ze#$fVQ|$EzC<2L=j1JwczOp33vrXAg2n~HtoPFr<8)juMaIR3nb7YO2IL$V+>mhZwQe<|B)|W>T(Fg<&aItyUz?Gie(x3g^H=^O#!E(21TZVx&3f&1vSD^~=}KuaPp= zoOw!v`HL7=_dS!=?a+K=R^d=yb{`pI=;i>-iW>zi5r6Li^-KhXrQ~f=5%8P_=WqUR z#R)%`_<#gmJ7m*fY)v zxUs9Y!K~#k79;BdM?B@*oZpSt&)?>+LPw0+&zl)LLk3KWGR`hajgNzoOkmn1ma;Y}5u zYgzbpB##Ab1#I7M7_4xwJ+uil_I$0r$yD*VzxI- zH2SZJ%v}~AO98Qg(fXTc^a6;LOjUq|Osh8}1aEHKNuUu7o)ys}F-8eAXMmC|!Gc+M~H8@y?6=_fMnRV2vr^c@0_@Bec~TQQf{?8jmZ=2IwCxU zM+6FNCM0Svh&K+|&xTR=zE4{EyI(03Dd#yB6#fPc#`!x?v{#QM*PW7Jf#J`;cUpcG zwc0YHgf-LUiER$oAbD3N5T6AS(x|@s`^!f`@AIjXv@C#-pxziyZ@&WbkssOU)?Z&~ zm!}=Jd8^to^M`sP=!)3kQ4Ro>X{O2ls1fsQzbX-nWKLld;*xW0`$pS0Nomlf zN9(+<0vSfqQ)AG~Pk8I0zx+!a4hH=GVyw^MXg0P}+vpU)+AHlRMuZVR%!c3Kfi1>D63LeE z6F+a#FW`T60n|GW$Br4;6d!&_;s?&4NjIs{k%+1XukEPHONX`fU@hC1QRyziX)@&jxL_j7de2rJB)P<*n-I|uXerO+FJd; zqR@kqQ!_#5eEpz8X*NI0IUs^k4YUS<>Gg3L_FKG%Tj{u9gt>ujnuWBiNEpT}aaFR? ztqsJ`d_c8HTg#{LOyGj%3bQ#Nb-s-10Sp08wr%N}Y36`*NAPvnfg9_e7_)a71wpX= z{EA?liQd&5LleakXLHJn2fifJWZ7OAt^79;!^+d?NGha$)C{#6f{NkXCmH0_gsfr? z*Z_9b+gKfbzqBbUIs~E|W5r3M2DZMnmeoYI33Sd7=<<6tad6f=7f6Je58e&S3sS&r zgaSwc!7F$1DAF{oPOV^Ge<*?>dDP6Vzkq5wGMf|hwe`R!I%A&)qbuvMpF&Sw;9BMK z`ok)wFo&cDWEV8~DPpMO@TVu)lybkr(p24J0cJ zl0Rh~E4>@Bj}=|%`e-#`m{m%RJ=<>_sN(XDS5*b+O1E53E` z6|DwPA9t;t7iYd|ZLK+b8JKcyvrbCBR%jLS{!4)(fnM0SHqUG1ozd1o(k|C6qsZe% z+QjZ!R1It6in|CY3M&uSYLDb|x^Y%8P2TdT4?OKw_#>l{l!E5c9u7qA_9G$vyn=%} zP;CJ&>eb-sD*lKyEUCGlP`*l*U+4!}%nEslS`6Vx=mammX`&GV6@+tY!&q zW2v&Nk@xwC19h*BQDB17jHI^IwMo5rJw<2JzM>?mC<)d8$NpZdmi;<)$2oVC7a4`_ z{8mMSyLmkr2d8%cIbA+7Lwr{2o_bQX=2^`WRj4`~6BsT_*d#2rXF${Kc;Se%h)!|O zuW@4#il8?3r;mYWT3zj2H%v&bZIARsRKoC)hp~(5w9eFx7rc{fvP*;K9Bi;|r+?U- zl$*P{x~{joJ2VQ0KJKfNrSjxx+SDuVE)f2;YT!<++O6N5ya)pDN|4Ur52>LfWXSpP zKSBGj8jc_bixLm}mbA25QB>0ffb<$o4g~chRC}^6fh&^}#b-%~3!E8>kDNnrmVAwe zSwm)KCWhIb;L3zX!`&@L_c6l{wgGh%N`<7k5wbQfd&WQu404wxzp+_IF2$=hu#zSL z>Ym2iiu|vAz+S`HxpwsakNnGVZl7@j#IF7RMJc*_fDiIl6d3?yRqfXR$gp#&?yauK zsd%W>OO{UPQJ;2OkJM|L-pUZuMQ2aLa%Z++Zh|H&>m1_W1wVsY>YnDi<9j*ll5hf! zp*iXtD@-XP{8TE*Uj1K;f5Scn7H4L7G-&>>hR#lVeEdIQzCm#a$;JkYkkma*3tK7)WKt6HV&i3cz`=JVrp8eh%;?j-8Gn z1?#q|s~Y#2)mWdL+ElQ1E;$u9+Bnq7a#V1ZeqD5Xh-F@9r>x9&9&~N!!l?mx9yFEN1mlp!+I22#Si7`{|NDQ6H7dDrgK*y_BS0#STEN)m>VqS56gXS@XltY(Hs!17 z@Y_lOy2+km;je-*iDi+xu6B^}ETzRa-vSQ()c@Fm67V?DVnF}^OrQe*{Coc2VU2^O z$$!VG#--h18|sh!6Cnh6@S3jpxLNBkn{AL;gCsUVHVjg0Cn(fdlgRLpL}7aIfyX@l zBi#2UpMZW*Jd^x_Gn}NZ4QJ*#1R#+z5B}`;0I%EKC2(4~N?JU5Rl|C}dm9tRRegz! zb86SD30>i_R~@)Cx>ftigQMZP|L3TE&jOd5I#~XAi z@8TZQ7OY8@Lw}ipGUt8?v`#Aq(K^_q$C6Z>4%r+edif{_L=v&_m4Yw=FVsCoSA#h z?|kp)9PN_ZMNVc7A1ctHpOzonKGKR@pXiF z_L4(4b18cPZ1$YtX52C~l~}h8bkb*A#=~vLz@6^NWlb@zN5`M#7*e z;Xt3bB1efV;#}YYYyYgF;`!hgxR08z1acW|yaO~*WaN;lT{q4Y6{~JBaJEoDOHS3a z6yRq_rT3owN}Z)yR~I{)0vJMa8+2vQ4LfnUH}(Q!RYR6ImKm1p5(owkE-?0zh+mgt zQRUkQ7VWz8o=t-K8~7lEjA-g!Q)l->rVzQMcombu{1R{E`G98GYhsZ~3p(uZg9Wa) z&4`Er8~ftfxcQ#J!lTr!QOk|kxsY@WhrOOeJBZgf_aVN*q_xp;NH%^YUBmUYV|O!1 z0R(uYO};w%CXgjGv|Chb8_p|wF_M9y29T)T(I3q7#OAS7 zx|!sx-C#`1x$+OXm)4KBYSWpF@<*r%mei4-7MYwxSB}nKCrI%_biI$0GYMy>7I}h)P&wVMrGaPaU(9ec)-gQaW&H6~+#w--+MDURBhWi``*u zkExI=SCW}<_+FNTbK*jFLZ4ryKs@_PULynV|4e9u9)6o zkI-0pGP+Sjtj7WeS$h~;ZvmztLcC315KE-bFKD7V)iE)7-W+1I7zlssN=p?#G$1XH zZ~tr^Txcq6bx3y{+H%ciMkCT)GmsA>_k6R_y1Ql5`LmWm(6ghtHQRqSE0}S_W-BLJ ze9K3jxfPLdALiq2gd7uD?!eKOIV(1Yf1X|;n|{;Ct`FjZPGgW|%K*7pw|aa{tfQXu z1I_xCpO`}i2+z;EdQMLKAY?(ViZV>bwy6@5pPXtPO~A_WFJvYRtCo{lb+!;#0^e&q zJ~tm!)6n91qrBaf^XKf?k+t%LkYgSFc&XBq|GW$k=G!uTNk< zt%bgiO1WX$e2rt}<&Y#~HoIXG44lLKen&!wgc-F=u*8yYE1L@qhotM$4ZuKHQ_e7k5foL&w zg-hO-dl|V?P$@h#6*YbYVX7c#O}G|3G*0Mn2gk;z_B+=}Pm;0SK@jx{UKLuCW@9h$ z2rW-3OJWgO>1c-gz}Cpg(e|Moi_p!R8jdHdrBaDZ3rl=saD^SHQ|GQC8tjL{sF%fZ z--Cegys58q!ZOldg08!ll&oou8ZKL+7!0K^i}!~4!{%S3_qd_!ix5lu3U8Kf5XCdN z-f^G&yiGS#RTZqwc&ld=@;c|g?S{B^Yi=;DI+gn`UI}RGGTl9PC20cS5Cz^r|T5x~>fIkHQK=XS!;pAX#;cWI> zMX~ox$!SS~NGrwKccJk>4$o0+7@oM~5Y!kmhv@DZFaAX_X3#D?ql= zGI&7Hzy=N<7&h<4=_+W%aq3StzKbynOt{A=l&Qq*Udm|Y&6;DRrp%`S^ot)Y33TPw zB1Sa4rXr?w>2cJM0E~!Q3pQjkU$NxI1ZY=*6bC@hs820+P6GNEyz_8L9a(G6(Sp*v z7m^r4;WrW9GLa|F-}F~=f_B_ybe##5vX)&&&NahKX7vkMg=B~q}%jY z^(3K+mERr_U~uG0Zodd+{1S?rtOhJ0X4c_LGmAxURqPA?=JMotP8zLewYr4Qc2T;X zH+eY!c1XELEFG!^G;N9>9)nD3CY3zf)$Nc`+xGUNo$Yjwvy`$ln0G zjjvA=`qM;kr(H@wL`;gq;<*xY&U+u^tSU#4d0*_QMxu#0NI?+3`XNO{XGNlh!MMf^ zcyrPDDvRInDRs*=qbi}rS;E@(u6AhGBk;7dUXAw>K$FfXe_=;*Z^o!=ODGoFwT|PN z#hFB(pf=AV^iV+jnZ=`A(tYZww1`GW#f@U{{sV#`1}l~h5@$6vhjbN<25SC-6n0G< zn^z_RR&fr+Uc=h4Np{1*@Y5gjCeb=Fr`N#-1d=<--t#>ayL?dQlXv{_BibH&HsSfl zYcF=oCZQFPsyVfX;tj1o5HHvqLO9a4Ty4T;YR)xS^>h&>XnFj$BiRsd5w>ZO4G4J1 zLveIG3Na?=RuUiTP9~`)ufx`^Xp-=BZUAWuO3I4z4jn0OG5z6^4k=#|=e`f4M8ss@f4%qO zJA@V73dd-q{oq}n|75L@S>Ty`r8Z(%rV%}|CH4rx9@5}czyxLh%a!N%%m7?jg?)3+ zaO_Co`5%!?lPov}XJq9{YS_=YxByQ_H+;L|Ne;e3G3v?#h9lya1=e!%YJdQnB{2jl$MLWC7;W~ zc08&tTN&fqjI?*6yCBW#FT)W>V{{#fQ4CuJl&yeG91y)X=G zrho>w?D#$@&)2&C?y!LPeL@x4#qf_qdEdCnvXx&(n%4|22)LDBZzL_wZSG&UbmQ{7 zzI)*B1?u$S*77W&%uCA%1<#ksZ1C4+x)ZFP!L1?Zab%lUUtBBl=~`1~ZUpZ#KVcl#UcVzx;llJ$ou5%yXLehVTL!ClYqkdXcZz#`A4j^(qIvCp01MYAyN@Uwbe; z_SF91{M68Y)fZZ6bE=$`>e|3yECj5@unpz9>|i?esA$Q6dwN~(+ECn}|2>h61>?+$ z-zF!}+eGr--#XA&Hvb4E_3b8j$-PI)p{6wVvjQWL3P8VZOj6$aEQh}8UvpTCwMDq= zr25;CNY#ananHq`sao(fqMnD@5XHby)4vZF9Fp(Medew`Ups#l&MtD%LPCv=6V z_n*Ee*1C=!5PsZC9kQ0F>YKo!=_9>#enlPaJcxFJ= z9^>cJ3dbYPX3%v>;d%O<8bg!deZ%TvpXh5WZAeZ%BXS)EL5}0V3 zi}1o_Hb`~Gpw;ixI!p_DO5%&}mK zktP{@VK$Iw7j2QZ5L)qe^Rvn}aoxz&VzfpbA$A)vAy)JNjb|OdZ+Qt9@z1kWo=!#K zpmtbi?PXIafl_`zyHnkeLZ7QsoT?Yy)wu`ggBM7`&-4J^Pg;7as}kh8I~fnt!pt{V zOcE**r^s0ZFs5LN6`#v{Ij@^qtspR=7Iaop zxE{H=c_~GE8e^--ZZa+V_%P^+d(61@RX{4G0c_g%8wWYUj&XWZPQ}!L6uN{E zJAD}0G)P9ffAqmX6Tf?yBg0m%r+kf8FvC6^SaC{|^WNEh$-k&PRAKKIkDcS+c>mM)P-&=6)i2s4*T2#JYgnPe zP$j5eFo#<&>i@UiUrH1z57lz|#asSY-rt-jR4A(I^b5*+D{%ewlD~^js07qMP`?QC zqQ4PPx_(p&YTo{fA|U=71vPy~#h`|Pzc7muzhV9!4WdF&rvSeooC?1|{xKmy<)Ds) fzc@CkzjOXEE~+a5@BH~N!R`8QR|Nq68vu4L7LGKMp*>^So{e4OXZ!Fs?w+VS;qr;+>;R` zp}s$S6IaFvY;W>%Yh+d()ity}G&Xm-@3Kqj)2NJ8)&_iL!>Co2J%vTnJD00hMb9QA z5b*gsdpmy&Q0;AwmPp;+>uzh7Z&~A=mC<}`+`ZK>#%YUtP;1b03;4b53`vY7de0@L05EN%`#k^v0EbJgS80Zx(H5>0(SnqJJRI)evX=v$$ODs?4m zfk3CN{dA9|tVuo7?6{UKF1#Z{W%H!qe7-G!hB8Ivp-r-8GYUfe(i-m|nBDf`OUz!D ztnws;5t|cu(f|t-xvBRbIxM1LlUQXR;5BWs+5!ngeLYL8QTs)w^L9D0*V$H4uO7wP z7uj6Gn#XxAI^mt~a43gq^Q`={uZ{c^&Lw4m)#F>DPr%tJoc*h6BL*9g(C_nhCuJOa z(WF`0Xax|oP+xT$QFHB6-|?W>BePM{oC-fI0xeMOi@eFvqTZ_{yEKm9Gtc4YdiQ7E zM&o`iKJ8Gmi3^hPL%)m-(JM63d+M9>F*qj!nwIP$B5~K5U#QmCmy6_txIcDf23Afa z5Y$!edRkcOJD88SkXD?3IrWDbV68kiGt|G6X%Kx=cS+Bx3nuX3}{pbS;7;|AE+|#_I=>>;RVVEGjQ!9f2?GQYpR!u#o z9CpT!zTr+ocQ;eTidIXp!q}}{qHm)|5S&Q3iMGF{1;?54D`uQ^@828X!sBa>Q`u+} zA4|8G<;U*rYt*cqO74x>BFcT!?zAs8lN;{+K-XmM<5ki;b1O^t*6}fm+_Y4|)wXYq z(#Ot6Z*`QkOMVxGtKY2vrwyo;9s4J#)tl4jR?MwaTl~sR$4#pWYsx`h-VvMQRN5oH zQWNW%xmfn5T?*dVm%_AW za7L|8TArLhR@kf*?h<_XOyKjpv+lG^$O1n%kMHN_>FF(Kz!&`i0q)8l&f3>}bI$E) z(JD?YPfB5M6$A=@7M+?d0BHihUgC+cAhN5@Ip%DW*`~e7g~4z30nb`nKwpOhvxVj zTMX6Y2cop6R;idIGj1DfJiXUllUSH>Wk+BLup`Xq?DHMwFkvu`$-iK)>N3~y2?}L; zWDnwQ_Nisp89&hGwysKaXn&gH=v!^Z$LH1cOnAl}U(x*WdXa#31v7<8R1uFthfs?jY&G}id$`bbbeBQjy z(Gy|7sI6teK36vKiMQfAlUtV4qj80xnThSW2E6^m=$mv}1*;kQpz=r`CZ?&HbGh#* z+3jtDAO6{{loWx5;8wDNIA6GcykR}|Uron`s<;HXx`dhhu^~h8tV7q*mGPeE=BYo3 zLF+CsoUJ9iSdU=3ruf(J$>uJ7Hi$>=oi4P%r5>I%drNWDW_wpQXA8u0yzNc7!cW=iKr9*cFZq40{%AWhjhU_~1K20AXzp<{HvNU{Pib`#K)lJ;mY~7TMiy zbvCO7mt-=MMiFtu69p@%-=`&oh4&2Zfolb;nI1=SI=lQghc0l0eoiW|&9&KVH z@qarrtKO5x+qd2WP3C|e8sn9j3cAhD3#mhvWJ9sl%9@bcD^-k#!>rG-n9DJl9$R=0 z!5afDeV#9DT%?Rqj3JoQr)`JS_rBh}U{w$@*5!J13pTi-e9%N$aa>h--F~1h-IMt> zT;Qt@@jxpc6=3X3Z^FVZ+`>^PwRbV)|4zGq${VrCA@;ds*2}ot$jVP{lxnmUWq^g| zYF}32kxJjrYsf20lF}`g|2$Bp(mzq_zhmoaVv>zBHRC_H>&Pg`8?xl&;CkL$AZoGH zWy443${S{BSK#KC&{jlz(YZ&h_(7mF0W@Apoo%-8khkVitBY)UPgw^oYmi~7N1QcL zXj>Tt;aW0Lb@C}s*cmA(-4$(VXq7Wo<>&!A3jk?#A{h3*Tbd_^J$CSW)Lw?=b^LKP zisPFKUKL$PsvqI3`F|Ox=&W3Y!!nXl=fJHYILhWPjl^tV*@x$guZOJcuENbJuDo7Qy^hbz&;8Y_{jUCU)<<8os;QSxuWK5G`K-3E@0X*u;at#l{z zdtMtrZfi9xSe>IX{}5T!C({;Gy30}m@{*%1gypE~QLnO}v{qDjfLg*>UV<`M%?HO9BrpX~Auf!`DoK}ESh_;*>@IrxA6YIVCu&NP z4XpxC0sA#zl3~>~Ai$!+gj474(b$I|l=wVM#8$)!{k9A<$$z65*IF zBUdr`=GHRKY7c>ag_kdY%qjd9)0G@;0hywt^(gq$wEPqL2P?1~py&)A(Yt5mQQhR4_0&Chq+@$f3$X8Cp-oS1B2=12fKB zf8e^P2Q%QF{mAygXNz+^`r|4*5?A#M`34C>5?i-GQ`TQKL@%cuYj=X3!gL@Z`MDy5 z_pIx)^PFj3@|SD;J_uhrZk7&0ZpLuV`8Xpf{^>|cRDGZy9p)2~_(83dIV#9hc+9JS zLQ-dlw4*8DTi~y7$^3-b72FghOi_1T{u~c_vTRSH(aaXPfzWHTQ>q^kX6e}Cs3l8Q zCcEg1<@OMB)1qv?h(Py}i1~rbt1?X_qBn+dP~`{OQRIhJf`C7_2H&bD%J=+ne7LT8 z^7Jt4^0*&OtG(+Js$qC63sDL@et5kqMHBOG#oo`U*l0zg;VeFW!0+90(5&?Y=ln!& z#1o+I8oU>ecLoF8U(_`zO17pz)wd{9%whs8l3r|MemtbROu1K6mX=pf$kJ*vz*1z9 zDe8iME@o2H!>TcO5DG^7ljz;FDdiESK(w=EAo%k3zsp@|=wz7Cp`zDzsj?-cien{K zOGGYo+s$T7Y^rG;hRF&}9^WL0Oh5Xnt72jDcm#W@6)fZ!AI7GsPM^^>S$xfN1RoCa zIU;M>9y9vJ>WNzO5bW$*hC4G;*}?E2x(IEb%+KhJwPvowu^5EQ?hohIq9_-`F-N1D z$-W&U+1q6=!BAmI(&a312miD6inqr>Cfx$UxkaBI{<1kr;u7m&U^ z(z~42ncz>VGn?50r_0tqC+h;@b2i?-Z?oTr2(h{>qmqeET-mbw^}P47cqe2!QfkUJ zp7~VVbQlvO0Uv@?*XHg*d#jqjwDQ;8;K+eU*O~7~bxuV6YP3e`TRBZ(aOjcqmaWEq z`m!BqO_P3;X4CI#ki4w1+)se5(|~)EbB&nI>h8o*jr_hu1NsM}wie$PLWf#D^9>z1 z>qMNVhZJt$s|2l(15Ef@l!I}Lve;SKjb@pi8X-Kk1AtiAwR+EPp`6|J$kndAdw%$s zk7b9?oGguTml@)`Q*?u!%k(0`BJfJed1fMqiKV%X8>$<5d<8pMeEUQ{EJ~nC#w{yI zesfrAD%)jtsz;Wz8^&B!@Jxl(I7P8DH&fQ;)z43EEGa)ZHC?uy9^mWya(?_2G!Mb~ zoMuPVZZxkiah4EIkej=|7s4%ZbDu(ifWY^5^UZTJSP{=7XL)&bd>_*DcJnkZ;$7q|$0du*Htuda^&=GF1W`Hw;7!4p|}3w;$pj>~z(vXdOD)LV>&) znnZ`a$KkZgYJWNxgNQ^4O|$@CH(kad6%7Wo2(m!B9q;S(nk#gQ|BN5$haN#}5A+2* zkJ1*kRW;t-NXZTHCWRgeYzr-(jI;>3`{s597tmh@V>2pOP(ag)9MgLj)tj*N`JW#` zOmd|BA!a6I>cBwA1XH2aiHL{_)XAYjQq>%K?ED8f9GAs_NowK?1NBdslaGImx#eC_ z&)TBt@0(1xs}lQJ4ABE4t_ZZcP#m6_6^0vJCUDja)A$BguVUy}l_`_sNAd#h3PHg5 zTTJN&_4`I-BY594s&cYwq~gF{LXOtk>*`R8<};30SJvdm3qW43Iw51}n_SgRG!Mx=kOG7n4) zj55m0Z7^18<aTX%cPz^JNgxO$*p_TXy%E9c?jM^knoQit8qnadbd0zb2jA~MESeFqf;8wMznC8Zn=FJOt0kvu_Ph^RauVK&D z*~L0CKDWL|z!i^)m&uE+jBC$tSHAM>7>{O5DZ{&1=s~<1;OrHJ5HwMyZ+Jv%anOcH z?5jT~`AR9Kqz4klurNCrpD2{FoMA2&6vjVnv=iQP<~F9tr+z8fraNbyBeZaIkjE5k z726!xVG+!{Fy4kSNt;#5rNP8dPJstk~p0mWo%u?<5j z!QOt=nnjkNgg(d>yjUyoejvqlz5CkRHJ;{E$-?S_^P>$x$9N*Gfv}A%fcx6Gva6(F ze$24*jd<;#E6%9~#MESg!z*bIe6-7D5NeJlZ&w!-fSeCid;-%rfr;aA1xY+D7A=VX zL6MYoBBW@2YVf5cH+g(dsDZe&XMtPmyP%agPB}9=7e1_1Z^#}GY?IynZq9-Mp zjexCt+LuP2u=CK<3710`CXbOl56V@4r!wHCGqJSfTrUowt$t<8aYosBip`rh1y1IQ zaF4awn@@9?4)4<2c9l z1j*U8t2mcFu1VPtR8VTSbR{wFgXN0H>W3zgIhS^^c(7t%N7yNv_9n z^ABa^PKzUK;OLdF#fCSeml)x#2rDFBN^ff`K>6thM{fyU7g73l>ZgW&xmS7y`xJkb zH8oW92y_K|3BJ$@4VNN1k)142>kR zn>m`^9>=w9SKKpmp+PcSTr6~QG(Z?+ng!BY?Y%xv!){qSF#c<^KEK)9*rgdoCX3+i zuLl9?W1=etp!w%alu_jD3N}K14tmiSh*!Bvk|SHqjm8yl_(AjCO^h;hev&iN~a=JhSUda=$-WWvuVg_oc#z_16$o z`-8~uA;Ma?xd7fz9|@RN@_)5FiHI3|e@KR!j>89FKY3jH-$Vs}omK9@ls9%Ouc;$p zO-a98O4>Sk=3lGoR^??y7Xx7(3#kzX#X?S;~X zNo$*P+2c6ec<^`8uMquSfv(j-I@f}rW^0jm*6SRm%Lj5m_u=S`N<5rR&F!<8cs&GY znvhP=W&*o-eIDMrOSE2tev=G>mAv#v?lcuE&3NEJupfqO^{V9=I`jr1Np;gVBaTDg z>pIIDqV-wI07THs#**YNTRgv&d)OPH*gGollBhQ3g?RtHFPICt|6s@@hGp5b1@+%UF~>j--vjkCKi1*qwqL&&<+4ZwoK+w_%HmM7 zI@v7xCy3o1aOn!=W*)$Do_FA$*C%2>F4mv;7QjF?UAFYL-k7bv`4|qaG+6rF+~(xv z@q2w8e@Y;P=ZMVR0mNPXzrHt8BE}HzK`%r+*F*I+Y?{6^a(Yl`dB}9Wh@4z0k=cS7 z_@7zXmS3pYOns|QF`QgWb*s%}+y=%@5+7?J>Zmt#&@9tJ^OL<))+yCOHDoJOW+rFb z;-}^jXDHh3)GK<)WuD*r)mk3tP&+*hTKABpmiBCTj34uEZ&VRX2+SepN>-AwXeLV7 zia3@&2Co(l3p1YAd6~r_H4hY$nA}_pW_@D2crQb=v30yRhLh`P zxT;%UGLP$J$&F5Ll+XcZI67G~Qq9iJ!|hDk>%B>&M2>tVQt z=1kJ2s2NpIPT>vvsH6`W0YTnoc@%pGJe=FsQ%}j=mH%1TAy-tSK0#GQzv7+4ZfFy? zjP00LA)THMjxZvG2g>o1lH>T^)pn}9De(5pX+>hb7Y;{zYEwz`AGywQQBBKix_Dtn z&oUGDnz(+V&mL9Yn{m^!$+H;q-DDW1AD#6Ix3+>Zw0_`C=;pRGp<`mEG3`NQZmgWV z0)53_>=$IQh3%W4KII7_GOi%k#~O24OPt=V&b+?-1_v8fltj}8g*(e+jYWT}G1A=? zx)OwX;tgiJt)#8pLQbKs@5~0lZ~}^_O|Z4&$zDzf|GQaROn{bPk*`yd@=j>7w?NpR zN@CwK1Cv|8&w}%}=a%=D$4;R+UuW^2co*M$&n^I^7wk6*$CSfqY}x)DuIDMuUfP~5 zHzzMAPbk;+5#ADLH;%|g;MQU`m}gTKd8rBnbXApV?C)k`l4mxy+R1EPSFp#B;okao zEK=fqBZoDaac^y3Q*U@Qw~jU68Blg_Z2y{rc8A@Bl7oztZ0rEeE=u>J;~t*PO*Lkf z^!UXVkeeNyT_AhjSZvpMJ-{K&1A2OuJ^8KbE7#y2HICJU>>DiU0-MYoTz zPv=R5Fpbk2ps3|Xv8qYKCG~c1(kDvqu#9{JR`77g{|On@u8Oo)FxtOe8;9VYAZwT=%OV|JlD_kjwO`j1srMr_$2^x8Oh5V;;C`INHB6^i_VOzW^pb5H&vzM zyatBR6WGPZtA=RWAy99qF|{>Z%H-ev)_s(^#O*&UPaQVc-!^v{S#Bdwy2jSn^|lyV z(sIDAAJ<2c@_*sessqC}xANh63v1n$TXnoB)VLW<&0Qa!23tZ=TGIthBmQ;o)%BkM z%XYFo-lRc@n2}9)*3_czT{>9~Ocf7ynsF~^kiCgA(j)prUaW|dEg*YCV0ez< zd(d9OJl`~uV!MKrmnpJ-oc4v*@ZT%;KU=fdCQGSyi-4fTK596=X*L0lyYC|ki`wHW z_b(4#F=Ft^(&2Hhg5xDoDZ`ORMCW0n0i2uwXxDA%-k6@aVn^HMa8OV4*c6jTw~wQRRwfzR{@i5Qi0WlcE?c z2i_2!_~Q*ztWMj}ylHsaNF6;K{TG``M!aJ`Il1-t!dk2QHpfM!yaexEi=hPy?Rs?+F*n4Ls|weEKxg~{Cd1HpP8bm#j9FV_1wd%9N$2WUTq_LPgZ z`BxuE`yN{a<8G|i<4pNzci>KWgUpTCkChdx*<+4>UIf2*IVn4ma8Y^{l97%?vdqS& zvNR`bmqghA1m{&M%E6y&OI1B_08Lox!!*8p`QqXS0#{Y;B|< zPmqTvuwgg%mA(kx79F^W=L?y%$45gGyJ2nePCOPP z`e;6AZdrSxRmTWK#f9WJ1ZpktTNxPw{WaHCg!jm}Kzho#H(-mO(4O(RH^)59rw{fU zithk31l_a4L2?+j@K)mK_(#E&LZfn`h}48&9I8%5<_VfUyqT;&OwsvhBx1W{djgJq zQm_2X=z(bo7T`4zn9iypA>XzUF*G9BmTJkcZEF+so>;yk+t(?w$O7pMFL(I9k~jR9 z*6bFO469n}-#LLkRjk%)Lee%_dT~ezA51yA=D@G?`eVZ*^@$UCcAbv|EAY+aU;pw- z`f+lti|N1IRW0@&-cX}jIQq>;x}c^ru|}JgWHX*`4zhgQxwHQj?WXoc739nhq`!wo zn!7z548Dq6sLAeSrIFLTwRLg-*5`e=?N>|3sAJ0q#?9fTO%trC&dH5OQV_yq4bX5! z9L9uNytwTCL}t4|Z!Zddyhj^^Xj{Yr<^>GWoVuRwIqyw`I_``8-zy!2G^+lq>_Tmd z3$x)3S6_9=4?`-P)%(1;d!!5K{@yL!*3JNSVtiQq)7t)GZ6UzleXqq{Vqg7E?jme?V?8}1CV`l^uM-BpeJ+QIbHzP+i^ zpmI}#;%(?CsKJ*JbDq8~9!jJvcv)1(;;0U{>4R9@o_ukJamia)o|AZqvjuKX2vx?= zB7!+Bn3-I&!`DQ(-Xw4S{FOdi*sbh94pgt@otuO~blwHN7$>mA&KiCG?m0^#Vyj$R zU68pnUu22Nvg2z{<@cv_$%>aR^pZph`wE`PNOByK&}hTCrsBUNT5c}kkLfNoHAdXy zVlWsEMjIF=6$SwnC{-G0P;_IMd)(d@RPfoFKgHETSsu?_HLA2vpohFE7j{BHaG&(4 zawtOi8H7f{6Ps_V!#fQ8^RLD(wR)}6I^@1Boe8b*mQFqWgdG)~SwL!0N}M^uF%;tR zO1OMTZRi#L527aA^`-6$Msx0wEmrtEtHqc|YxYk?>HBldxm9T4N7?HVgRQUP0Wo!k z^c3CNNg@(Pa$~E8Kt{`vmJVtZP!lTmOVDmDb1E%a3)>+uo7H-%@*a3_szDYC^F0ou z^n3z=tlGtSovz2unE(=i`Gs_aJ@#pk)lvL*Ian!@EK0x=c?m>8u#~rp2~=V@_&CDq z$=X{Ojx(jsXU+v0)9Y=;qFg~9KaWon9<244Amat0Oa%>7Vdh+o*5b?WYo{bm+6=KI zp2>7>NkZNqVfmdYe1BO6KO9}fdjw=p>hy`PCSZf;-Lh(+lO`kc%Tt}56On+-F-ugBgUl$6`V}}%*ng2g30EW9Y&xMZixtpY&5p8dq zGC}gAnX~VM9;L33=m4sH$ylP3to&xf3h!B`pJsw->x$r#KWO!gY$VQ@pGo{3v-zq> zZ<54sS~BC$6oY|DmxfG5QqZ>DQMTgfSAT(yPVGA#ggq+LvYSJtB~a=f2#b3{(mvPa zEa#2eU)No`_pz8um@@OmlIY zp#o<%=BAPlzo1YcJ<;}ohQjJ@%W z{)=DRDz1G=1|2+dTy&8A5Tn=Sex*qE&W;_1-@c1pE*P{NDC|m*@YIeZ2R7eeM0e)c?NR z{=N|Wz9F+urSM z$S_=eF<%?d%|9PcU(dIXi~EBqj``Z4LHPL$jHS-OSp1tFrU75i_4Hf?{av7U7ga zG3;CT1LZjI2%L%@kJj2m1Z<6bg)#&+LO$ofQDK`REiaMj8;Yb+RlIfl4cH#O!IALQ zT#(q&h=tW*q$9Y$at{0bBm36?= zWTOUTawEdT5$LXU!ibAZ^fjiA2P6>xM=kMSFrReR3%CW=?$s^;gT2-1<$G@vzV$)T zgAviIY5zd9AoU_}yhraQ*ygW*#h8COjS z`i%v@K(~=LyTm>K`5}GWxO{j?dPv%wYHSKDfq4)et6$ovg4DzqPh@iSDoTMeiWb`P z>eRmba0%@n(-*1sIPYJ15eF-#TeZ;UQ9vV8Z`IozlPoxOox*fd2_$h*bqySp)z;i5dVP{9kx!a$>4NqC%=dBif%X zB<)E*cmZJ2QSl|h@%Z{YTpt~?+S*%PSJmp99m??vpj?Demik!Jkwq%+d$*V1j5&pp zWZB(aCTZ?cuw4u1XAz@4D{0YcrQ!k0rEFg8e=rt0Jyrg^CBR|H_liZ8s{Zk4mH|eaZ`WvsHz}HR5kY0YMrdRvm zOk2O#+vQERSNXO3)|e!pCN;Wvy1{Hv(K&fIbDPeJKJ%#B!{m~y)!+waP6OvOHypwI z8A+5 z@DMZu-%bB+7e&$a1^c05Vpm)HmRMn(lzyS<@BJF#aU0-EL62fqtAz=tXOv`Cxwvd9 z^Db^Sh5awhB$fr?!~MSVv3Sp)d;}w(N8sb3nX2!@HhOMn#7&#D%Ly5~(-q-&%$MJm z-`D#7pn54Q|V-B9e)BEN)@Q;-YR+22^^}yR&R1ENDd}C zz3{dD@r-KEa`_%_2QG&Yz}nI_KXA?hF*lccbIBpYEE`2;dqO7e_;4((%3EEX#$?3u z6Ulh9Z8qRarih{3V^On`xe^10CBj3^*_`><980-TCssMSir7hSLR3TD{z3cS*gG_T zEty$BrLw6`=Bkw0{sQy;uDzM@P3zZO_UkS2y`7$vNE7{fq$bB7b~P#C_aF2JndDgG z(CyXXf)^z*<&j9@DSh$i;zZ&PH!JFo-CY_eR3R2h9-NHU@hNE|3oUp*W{_`7T9uVQ z#FkHUexZW4`W(#Wlun2J?gGNweeWOtjx>Kd7Bg#Lh6Sd&C?8puhZeM+gp)C=WMNC+ zIp@65e$tlyqAr@Y1uGw)r(AhYvm$Hw%jbq^?NAv^u|xdYPJ$?6r#=*t^@bXI$=H~c zvY69W^Cog-&J{5jd0dfBpyd%m*AnF`N)<=>Yk(6cU8ZH$o7TY0gcp~7)dUfuth3Hl ztHl^-h~zD)V@CQHADXh5N<`GPkmc4sE}G$&Tj90gOTAkQ@xLIja-$kG8*2YcZ6~U4}blsd@EWHYxK5*`9C5)O+#T#c{wV-YnVw|- z9q)+^gk?EM^H3;gXIj>n+A^IOCo&2nQ~v%IPx!V@SSZ7{9J#t&1wCJlJ$IHJvhqUp zm_<5n-et;1y7iCf+Ky;$m|bE;7TB^)!(Z1sckhAtM5{YX?p`_@ZI`wnZFK01u->!8 zCze@8(GBOb3sy;cX4*38&Wh@;P{V+Kw&=*RZ7f`dl7|dH=-L8RJO+BffkVXSpG4; zRUBbkMgV(o%dH&k9336$6*Y&4$ebolPAA1#PyTk}_K;Ud8zRi=@LalNEsujWhABC? zRN_0M5X^Vt>_0%1Vu%@^{v-xwK|ok!>pC%0q;G;dBW4VL0yF|9+}$*HiQbM_P)gRi8(L7R8%+ z!iTZaw^p$sZBn)+w)bywQ4|dNy1vh7h&lU{E5{zVJ}H}GZaS>E#V=8(u4D|ev;9}m z4+C>_0`^iMHYAil!30;4k>dV_B_>C_Im0BC4F{<2Wt-z`H%LTzYYCB%9RZlc0U1_J zEI7`i89j~BvV%N@z{LLJYpg&hVmOJtb5G-Siu>zmzcUd(K{YhP6tj=4X5os2GV`yB z$y5Su`JD!y*nDm;7p!$lf7yd%&<_n_%YbsyWaM){NZ0Oom~wwcPPIg$j@|Mt>8a#f zPN8Z830TGNqa`&5Ld0P!^akTZ6FW&D{X3K{UAFOsx$hO}FlUl|{S!i%lAeCP-fj)P-tVt)12En`i`u8gX?g-U zQsth_7Q@>u9hj~rQ(hq%(yT=$o$PmuAH!>L5i^>}Y;Ptk)xj`jv_9TvZlyVVx{%t< zw5OnYX#)191Q21F_lwzhw+>p#If}>Mgau<8`h9wV3PyUICn)&5FfT<9#gB4IWcag` zGzQ!P6QPkIH8>YAtc=*)luPa-|GA9lm zu4=+!2~dI#UA}`eSw&1TNh*PMYt7L;nA`d8w(JT9Dol z$S)>KxS^Y%u+Z zBe+Fj0yN_UOV+6vNjnoPHwmU#ew8ph=>%6=@)<{H*X5FFv7y*NM^iiCYz-#&O zsl7u3NDtQw_xbTlM{h505%>37_xEzHJ)GFAxH54^aP>`SDRaPcQC74=l%~ku?7q~~ z1vE_t#|}F?aai*RW^)tKdxqj$ns-$`CqJM1gI@Do_Kdn5b=u;1;VPr17TFQhC?JaD zy(%(bF|v82->Zuv`2{!XUj70bOr8{!JX#GB6P037xM42R%tu3wc{Yy&6`AU9S;~!; z<`|QyFHmyP(ipR)bo0krK`B#DFhR`B-ilE0>eG>nZPIV=(*x zJ0+N&-$Uc`a~BQb&k&)A7FF=bZ+*n<>95`#V=frU0aB*L2_*K4%^PUV4x5e4sQifOjBCXPie=x#1Q33_x5s`if`s zY9CfFdx-<_M5;F8&dbVnd>svAD;+oJMsG>Jwp+tYIb3;}&4Vf0cvXP0Tmn^=d<^xx zEB+%q5WbY`0v{YA8n$6e7c4O~%|;@3f)0USyL~8Bv9BeXxpEOpND(}U*IvtbBc%tp z2lpe9QdvTTs?w&)*O)xaco)D1CHe?bpmEOZ{#{NF%PWxgK(Iq%L2Ji5}Sg2 zUM~+}eLJFehfh>9yHqgS`QAKi*`H#aw4qSdi&B7BF4;0k5&Yg#igP)ttxqR8iX85r zq}#N`xU887)Fj#v8wztTcH&{gC3sC5)Z!i~MheuFm{T!S3hZ)pNpb9lDnb0g8@8By z>*KT(6k7l_v`ziRBvQ>LI1Ek8d#LFe=wqA9R##$Vj!x$>#%6?2ZXCRXykh21&@si@ z6@s^4+vPnj{T5v z{ir1uQ)L(*-(*DwX_AOGU7A{d-m_5rfS)^UsP^DaGYVMEbr{pS1`uMQN&Asd+0Np!pW-R4>y5cB8EzP6!m+rWMSV;!8` z=!mpG%_cRA`%oaFC}}gEI<1jB#l7A&&b~#s+=|IR@T}(vCpC5}ruL7P1xdf9kwcr} z`!Zf+Fi>#b-esE~_5=OTNSrhYnV0#$WKtjq0D%9$MB>U~A_~f)ZVNIlMS`ec`+oi~ zoU94p=*|0Nh)7^UL2zP-R-ibke*pdd$yH2FM>lnSF8{V=4BWN!f2Ee7HAv+!c0`{k zO~BsP2CFwv!AJ9xn=mxwrWdur<_&-9z_FnIEh?+51bZ-F z+9Jz;@lc;-R>spaH$JLP&pkMg>;tnpi64xrvA&tGw89QW_4f%dXK43>^>C~6=F#|D z15z0q*njMW#2*IyoZ(JZDo1=!HhM~EpcNDb#o>~qd-i)oGx>F{Lx+7N8wCN2GTV)8 zLpxY=Z$O*npB5@hLgMoN<#&1tpHw^tv(!*=S)jWvdaLdhs_-H&{17sg-WVYaJen}PBf-}L zug?ixJ0d2Deqj{udmbP%6;+jbjTbn(qf6B17li+bwt?~`O@seXX8)hy{V! zg_)C-n^}O9p`)Iio@-WSTxQvKR+y2Ylct?uXi}Dxo}i_VVt}YrnrED6VP9ZbJcgc} zV_0~mU4^5hlb)H7ZBnMBqLw>>mXd8(rmSFHoSB-FS&^Hr4voSj5$*WDGE&cj9SzX` zSp@l?ko_-~xjHx+*qXVU+5Vrj>J*(kgQV>2De(WLjB2NC#o<4v`UL|3Q2sw<3SK~*n-5CBn z{@29_+5-{8DOdqN=BL@Xg2g(8e^fB94o7g>7`sB8{X@b-)d{=wabPB7^?U3Z+Goq+ z0{#|NFDM(kjFoyu)Z%$Z#WspN6LWU9o?YTM=hEPmI~)Oz#v=+((Gi@zrv~X1FHpV@ z8agB@Y617O8h&#W78IM!WnV6eg`?2X8}e&(WX&~;D<3ou6Bm%n_74N6wh>BFHtDiu zj4&2n>8Bcm!wBEO%EvB{WM@V$ye>+pWFv4vPQWg|Sq?A&3J4;PY382lhF|%o)xa6>=RoI6vROuGY zj2g`G&+hjAGUw~%9J z_sXzDwMgj&;ExeRSB1?Hv8$f)@9#YtPs2>(WYP!L2<@UVX6n{=Xf4XO9$Xse2N3|@2uuaH&QWvFyCZO_#FHe%wV&=8QeEexPkhGFsVrta}=((cW1T~K|ayYrb` z0Xk4~fL)8b^K_J8sIE3ILvv`!^pn&h@Hkv2PK+3`Y@*0gvf6J(A#rIpvs$Z<=bvZc z<@?J`m#;YfryD~58lHE;009#HfB}sEe|(z!zYW6lCXQaNmJarGESz+noa_edtaP?k z_HLeZ7WQuRE)LthUb@RGuLArbvBAvaY$QaAYAR@3FgqWyP zU^tRxR>|&rwW{hZTjnKJ9mS=E=1S&CWqst%R!9?e{%1Kp2K8&XG)rgS{sH`Z0sg#C zvpHv%+b(lluiMXV2K8FW)&y9l?Aa~->}A< zD*OEz3qSc~jxRy)v~Og&M~i2D7Bl|&#{AT`q+_LXMD5vM{3E`02LX|B8%WL(zh}`w zIltV$zCyePq;nWv5x*8B4Emq22OA;pzt%VG?<|wYzf@<{N4^ghEfc>gkKY|b@fW{x zUKhLuVg{p>0rscwtqQe0Oo{ci7kj@)H>`0dCty_(==7?e%fu`hQv(@TZa(0vGIYjv zp_h7`aceXlY2vOA@v!xNCQBhZwR;*2+s`AO$3x2cj9B-G@sfy-;D>9Y@V$PgZ|-ZL zO~nB^L+JOngZr!Z*QcxZ2S9hdcG_bqBHCl^Ee?3U+<;w@z^^)>V-oZg=sYyRpPu>E zdyWw8u_KUu6YiGy1cZTKW58Fnd+m`Q@OeK~AVCrEx|;~#s~O;*hhMO}1(En@SKtW~ zcneQ>wg&hz0FB%#0{r+A1^%>yCN2pC=9~h)27$g_d;r~lAO@O2#sioHd-re$1jK+2 zEjYgVThP8X03YqGppj>QA6-PjxkG@vAHl#JSlQ}5JD#3oF0)1lOr?~*|#Ae1oei)E-A2Y?v>&sohk1Ist61iaa4`X273&7hSyI{8- zZs1obu)~`&Fee<~|HB#Bn+|GefK>+g0Nqc3Ck$`~1n^@B&glS;6QB<4rURdQu?7nC zBOsoo0lg8x6`Z{Ry!8nN5XwRJS%6b{I0C;e{yUHs(ASr{<>kEqks$9H=-pf{(33Am zU{2hBOAzMw+@T21HURey@Q4T@z{_jmDwiGD0}cV8cSB1+|L$)9-Y<}Z7P0^?JK(po z9e_7FL}CEH;Fl}He!H?t;17!+UmcvHfeFYPLHdYN?S3)v+YIV}00r>*uN~kgqzv%5 z3-GUoHoPqW9I5I91Wdu^$It_R=K#Stus?-r zQB`Mlbz_s8zY^qyB|XFTBzE=D+5AWp0{SLjK^b z1%(Roy%+eaS0d-Wr2`YPEflg0d0E}P|%pKuAobQd0Dj0-xZ8L#XKjEbchFSGqD zb^moa`D*$e2HIH}2IdhaiJo>EH`9RA16zN3JUcU2fRBQuGco|B0qNZZrVQ=$j<&eD zIR*yCrOak=?1a-cKBuz)IwP5nhlR(({WR8!tXVUe zOfnBp<4i7#hhC0?N6=~GRFe{qNIC8zE0$;YU1+t^~N-gymk+AXBX z$|B1$k^&3t*TuIZ{`<0tmhHtz;rJEWr2RWKkVmsFdW6<-OXUOd5B4}D-SvU)r=}qD z(nLtwukN%X3(TUa&?(f*q(j9I${zEqQ@%p9F^q-(v9o+U;`>ScC()@Pdn1I0X9^WV zu5WaBbeolzADFoj_y?Mi32bTn?+~P^gt@zIAQYP##~w_USW~#IkjZ02g~*A|QqMic z>Qug>DK1M-Lzj_zKMSnBw#Oz2z|3LUN^y6q>Zv&2=PZzWm$-`qXFcTq2{X!H)sC_r zhv_e814+ktw$y(vO@gvt-u>b)LjLdOsnwIM%9f>wy-r@gyOyW7nap)hwNa_Hrn91y zMwblRYAiXCU4q&2s&P1{6~1zuRisD_nT_;BT!?_g*vrB1glFZui?C$$FRJvpFfK*t zVxfgg%s-B=y-%s`TDmV!{3e=8<)-G2AAQVmDlB{`$t%ov1l)P1c#x!t1ego$`_i87 zQ>ev1?V70kJx?Py_U*RkzHvaknktI^_`XP^*&j0emB&Utb{3IbpuKW_FV;O_@eKJq8OU<2$o{RI{Gl(LI?ASul(w7}YI&+D46st~pGw4ajO1g$5FAUz1&8Se7Sj12aO?%}UMfzV5#B`=2W zuB7`5@bDrR;QJ7Y#?Fe|VTJH^4vqhbQ_{|1WcJ4VhEe4BF*QTQuofuNK4BV!H;MJqh_3;aHc!7Dq4+8=wIM1&VJO!#{7W%rlAk3+>GXkT*g89pGmFr;gud1p*4} zd!UBOPYmr|rZg8L>+{&rf-|3vY1W++li7R5fuooadL0V?E`xysK+4vPid=JYolcHs z*LsTnkv(1%;>q}lKLNq^FYy4P)$oaRr#wdKqhen)B67+7@4s!Nk)Gmd725%QD_U!XX=4X_O z%_k9x)*Dpu!XfV6Op5hbZJ*G9Ir|r76orkK;<&RPX&stOiI;OyAdcON#IsN3V^Sy; z8&8Y?-R@0xwlQM8uKQeyrw_N_xBxXrAF*z$#wTr*inS+108#H73&>?f%o)JeE;7RD zMH6Lg`+|V7)%UUlQ0{n7dLQ?7l$dEfav7v81^Tobop?q!3Y6-mc6eb(&g>T{4k&bb zK}F#@2bCw-2VPdhodI+^t^pZ;?+J{7_OG>)ApTu0+`G*$uxm!CyAPwprxJ0zuiW^)UkoZPIulK&h#7FRD_J5LU zm%mDBD2%R>t;d5N!x-Wg5O<^F&ZIP7nb&`(>BXKg*xHr9l^Y&bs|QtS5bdrW>G}^Z zK^5|K%CwH3-MHo8+yFd#pC8=>+~5$A3-(>C#4~%rc68X%QDWxx4#)d=3NOI!Slk(5 zT8C=)6c0EMR$=f@na1vWScl+LRCvIO{e)4i!!M{s!Jl!N8b*2l7G8uKmJX~9R4Mp_ zE(>Kq$PEobuwF=%1d-3deEgrJcIyw*(je~Lig^1UsjovGj<7ym>AdgRm3pSzjfR}j zl)WaNC7`azQ}Tx{rc$m`^MK0(%pC4Y65I#q4&773dioSBP0<>3nJ5jyxds0Yfc4`HK)3g}EdI=LRF8RG zBkeVhA^5UE5=3{aU>rLA>hwZ`VmAbnp*8N39?%|otJVb2?Yc*!(4KezqcCqj(Npjz zAO8P>j-+)cb)#{2(5=rbJc0e*mfNF5Z@jACNC+?A2w_7XW+?8%!ihrfr zm?sUW)?Lyh_&-Hqd#{9|HTH5&67=a5_&-H2nqKA5@?SD9gC#)}bJXJ9hup6pV4e9Q zn|P-Aw&!G+HytR~Io|q1!SeE-*h}NB^a>NqPv&I^tdHb(r9siwHyUK?+w6_HfOfK! z1~(KeaGZAmbHc-Y&5=};6d>ao{uOeTXVxUhHhQZgV{(58H47Z>2xwqN!6F{JvWPi* zNPNDuxC>s=73=P~$EJgo! zRcOnHz;+u?ETBDXC^YU2TU$ONK5B4^ zCiaYisZhMz(~;*I;B#SdliaR4*&%RRLGiS8dBiT$-NU0xx-Nxv28!8!8W1F);4gs! zGlQbXpJ>;AY=T>(gyIPkmQX!?*sUGFcEb^$l0R`s$>iA`yhyg5&+gvh^ssqY z>q@;Y(x?;r=0Q{nMD$ifwR2ZI=Jm*?2>CesHUVkS1KbUdRKnP{u~g#;9750*gUKsD04f> z)F$4w&myox6giWZ#`=zrWa|stPLfE*&8@ZfQ5Vo*~=h;l~`Je6I5*MVULngQX2mtY=8U zUmWV)H`F+*he)G_qG+2CV0BCGNU2@23J>$$AexZd`x|DOqodH)GW#LjSpQPi5$?Ug zKD%KN@gB~Oc`XutMY!_^+$qf(H6p)krxrqMs&6VAMr-hY!N?#xI4ry~VR$0iwJLZb z%C$LEP=v1@^_mC*zi#Iyq8G%M8l{nJEzEZjfnTTd7+z4S(+=;90S+wO>4fO@#}^Oz zZW&&eY>fwAmu~GA85HO{hI1wjmr1`ykHD|jS%T0i*;#_PM7maj@FWOV@$oDWUYCAN z2BB5HGZ7Wk=BtJb^7m~)Y*p$c#YWM1JW`q&Eu|&KW7ZpgK%LZLeaY$r@QrA~UpCsQ~*(zOO;&~I1~Ky|*+Y(HbrO_(gwQ`v6BwzqSr9 zDBnqr=+){gfdUHh?MJ>tfFmYb!$ySF8WthWca;=Y=~ddbeRx3)nB@-VjbsY~j3hfE zjARW$t7vB-3aHrE3=LLknBuTXlfG424OVHd1Yb3@J8L*S$~7m1R`JeDgw~&(Xm6E1 z#Xa+YW5zjq56ArJOdKwgdhL(z*juGxjl&4vF4QUK_T}yw{wvv9I0C2 z2P=04&KW8kSoKXvls6$2P+>v>Dc5G;Uuu0T0B2wnP^2%Ae60@trPOy0<<6<#_4W1H z;@Dl>;pJ0KBO}TzNxZV|A@aox{pbj3>RvPR$>WW10np3)wkNm_?_33V9eit+Ii@C6 zo4mKoODKBvKHXO2>XDaF_DY7=hV(%x-B#vGIo(#`s*RWM`_;E}OiGUk`37oUjY7T; zge6mip(kZi2BL10`!XS%hqb@=R+-J6xoh+a`B)!a9+XWx}zEV3uf@h4sxc_GW?25%7gs-o1ek81RPyZ;YDPG;u5gSV#s~$O@C2!z&lqlJ*SP z1cx`^2LoJek1o7#7L+$jC=7_aIf;OQ&^Jpm3^cGjj#)YbU{2!S#?oLWau|v9Zdhzp zSQ633FxNCNKo46{|CZWM*uiSw(VPVzY|#{KuJ;>|V1FDlcjkqmewZR2Z>;)Zvpx7> zfE_kT;EfRWTZlIvZm>BI@-RmVFdeUO-oRT5IazPZTW1hLE&AK>|qD3EzVLAq8VXNb}xRuoU>N;`BkcCQ$aPC8)$ zNT-_!1rSnC_)|1jh~CERA%|kdn}>^La>-mXPxMnfREiSE?0Ey)RB{?5uXsaW)N@v2 z_tYpK+(Uhoa|8f7OcUW0&FVS3(#}z$3cvTzL*?W5R72$aa1ln=h5r}2B~fHtw5IjO6Dz;l#n2i?S&%vC(#ICjr5RF`6+7a*XP z<3!={N7PKxIYqQk+BrwGU+Rh^^n`vwfP(jXP7lQb*~G55>FYz{o)N%XJqJtjN-%VV zc0!B7BV82CFmWn*RRVZ!6$R2x5Jk!p**QJ`W)*kn7nlMLPe2cIUy-XY9{S3iBMd9Y-u*#=|zQZmQ48n~UwK zLrET-93H^oLM&g<5p*G;{rpvK&hT8bo673`GQt9f#o)!0=JnIY{y!#+t$T0_{w4c_ z0mNIz!L5;KxB~26cjDWw%RhxQH|-;A?DC9Q>w%`dfM^>ku!DgF$9cO;S{icvw_XV& z&;>7~qKG3@P0z37pqyR%SKWpQ)#60-Z$6^Ix+czez4s!RE?+CVUHCeD1awxz9tqro z#tA^N3h6y$GJOPU&H4_>nhum)*%8VlscgS(x*B~rVo|CdQ$76DpV~WUe}VaCr%5^L zzqE7I`H7~x2OXd-8@s=>ez8vZTnyT<{qxr{Ji6>hN%ocTuDt%jDYA+eA9PAzFhdA|KjO(2fPyv#(KOd+oOhHG31w8CbwD)<^0d}y4nuFcCEfn}L8>VY{odb} zbSHtRvz#K(kH%tjbNA_{&b^7^d`bFF$I_#fP4cwmc9o=gjhw}-Bc+|(CPgOOJnVg1 z4#=RQs~G5nl*6;78^@yX&q9^yfdSHIB@l1I9Gd02(?CGJ@8b-#P)R}}#KQ!wZuXzz zH!c@!PFL#y&N+7)&j=40v_9CS?m`59Be_p^ce{8?W-a^3F#9_WhRa8sS$Smh!zInbJ=e7zl3_Rt3DuKm!aY8*SI7!sp_*E zC5JNLMu<&loZx7j2qk>&gE!DXo16N3$l01PSgvJVzM8_+i&~k`(4`2k({VSn+cIT) zmqf?q{`C2}s-*UlHveZYw_c5%T4s5rXKlEceTIZfdeFbyubez9X5Yl5>9Z0<(`OWtqmX+_1g=^}(6H+;5nlTp|Hr<=m@%)|N!6Ecz zD%;^UGP`>)=Wq?%TIM0%<;tW)c9`QNFJ@=5!Iy?HNWL@fk?WxcO}@cP-0$Y9Cq;{m zL^<_ha_MG|MyuOR?AiCxa;?4zUp=T|PB}>83VkAp)FDI1flxk}?isnff0im5Zq|Qb zlh?q>yMgFh+Nt<}rnE<0?2zg42FO# zWV7_KRCu-H44w(ne;lNc^C?c8v5&XE91i`Z{IL(7i(<^Aoh9n9>ur(kkLjGd!>r!j znF1>LA%JC8qKBo8o3mrU-Rz1(!!o-7ua`gxgFV((n>)|!fKp4pa(lvo_%Wutk+;>b z>cU5t<`Zja8?<3uVvGwkCS^=vQ(#B-yLBp%h}Y^0;Kf zjs;i<$0bE|LzC<&^+(}KE7Eap<$M58K|BUpc=07Pu6i>u;^!<^HyV%Bh zE_K1^?uCN|8B>ksnXK#Eo7u9C5-v?3;$-ohesZYE-Cbc1<|^twLByZ|%Gn5^gN)sk zl_4O+zJFayVtRbBa{g}>D0^wQQR!Ucw@rf9-MhTr=jpi3aW}EzomCA{SH$$&XEB}b zWCis^d)zyCUQ9DXiD47(oEvBVhSTl5!zBg9IYy=Ca$?c!@)DBt01gg(uiSFMa=8#% zX#mYwu6RZ-#Edj=ie(I!d)9p;!Em3&buP^~jMD#-C@QBiSvXO?$O$|pvXeMNxH<(Ou}o1PVS5gq{nCroR7vW5V#rQ^Zk6 zJd{Cc+@N%G?aQDKUClYN6KeiaL(kwzW~ydK7G?YW<_6-8LXyw$_;pYaZIUrb0AjL= zn4RC=Reic|Vf?ybG@OC3R8f88PxJVnWP{-i;V$hX%CKO#i5nV}xZvn>VrKPGzo+5N zDogK?Z31EDgep?y5$*SzZ-eb0W6argyrQc+-dPZuHq;!+us+(M{B>v#j&0i}A3i}i z(I~xwAIw17cO53`s|NZ*R}G+QXi#AOQ4!Xy7lTR1`$@ti?>U~q_6|PdF(c?@;L)v; zE1G?a`VG)S-_@)A7Hzma%_O>Svcdpr6mTR$`}k8x*RUQe30)1ok{Qkztu8d!r``^rfi&hYnmB#$nm)9S@Rwun5AFsW$Y zkv@OS_i{+c3qVuuW2e<3!=S~AgVZcve^zbDg^0OcnPrr?Nxc}yop%SXq*J@Cuhg_|-w#A+!8J4ct&$>x?_>vG zhR|t=V<9gw`vg?^^iuoq7LURt+agqAxD5Dxc_0K@cZ%%~G*4*p%CI-epokU-(#b=4 zUf?Fu{Nx9|A;w>j&v6(0#=K*B{G!TqB$3}~pOYY~2;o0jX*=9F^1gZz=gS7j+NihY z#X#0$FokGA3MhH99~e@4^IFLy-J|lHf5{RiLC_L&Ax<$XzRDRU$~g!+Imr-o;X#DB z3q<2;Hd+n}6OO!pG?e~QUzjBC&p%69P)njv({3jorc01Y(fUqDDVNF)roj@SPl70r zqth-+4l>4s+I-Y_9|tKRP4`ugb^laIFajnS5v7%< z$}cD(%_ona6o~zo+Q%ZwDvME%mNj`?nFYgH* z*BvjunjVnvg;GqAKWwTjjYtdTh=uf|2c}Tbj(sn%rpo`7$B(?PLX*!NU#%2#!4!W{ zOJdUBLPJTee0mZb5229M`%VkwsPU$c0cgoMPA^dz{W&f;((!BgWnw1+9f@g=gqEn^ z7z&5J$cEnh0u)o^6XjSC$5)@QL8?DZDku)7%SxLDkZzAxP;A%8V9>U^DGrLn&_)No zc*QBB?~6kw1EpBqSo8SD^0rWv1u1E1V=P$X0W!+ve$Ld=P?xYg?Kx-+TdY(lAP*-N zf~IrrP+Ckceg1vHSD7ve()3F#JqaR^j!x?@iCP~$B0E?@f%upqLSw=mUo9GQ5tx_< zK~ausk5oo&Iq)~6l1fJ1cYrvaFvmFt>nriZJNlF4Gw!ohmaI@ZlhY;&FZ@#e$xfS& zNZY_dYuQMepWw^`$aX{VBv%}?l^pRGmWGoGou5qJxf)5QIj9u6#+nIfMvhZPOg3es zC5qb!swJ0hN|Dka@*7I7RK80}()KSoon>W#rbS7mJmV*O-dF z9#0`3-=#~=JH_1ohrL5)Fhmk5ZlK1xy__y}A9%(})l}eL(3(sO_Jw5HiEW=^%t89e zX4c~_nA?QU?I3fJgDvQjKI$u$+9yqn6<@o4>u$^)|1vi?scsFu-l&Q|?nyTv!iw;? zhEG)s`Z#0Dm5TH(|KwFe&o5s&)QUucpZ@$>rs}U6>BwJzO3`0#ydPd0r5^^KTmJ0Y zN;Ki&H<>A)c#@?1H7!;zc@IECP4d)4u@to;fkkLg^~mqG-vUJAW9UiSkOHkcQA()K zCA9`-?bXM2U^|6;u}VIv3`LoLc*i@WTBDTE!bWE~Nc+-)+OaR{mbO2WFvP=?XlSe` zzDwJQjy{cxe-{uH0(N#Y&1p*OxOUp|)E{n-h7o7i;gRN?+nxEcO( zb-Pd!iX}*#N?5mAVFQg%np9I7E|zij#MJ#|h)=5XYmr7KN~z%-t=2o$)5|$;*(Km1 zk|dTZ1a5GVSn|AlW;(mrM~QycN9`FsW@q3^aww{ z!M6%D6W@nTH=p`t*#~Q+4EusHOT$;>Ni4-o2kzgl)MDQoUN~F{%QwTAB^?6a2^5mo zjTX-QL2%*yKSj@?Hjh*^$%^FD$BZT+QtHjq)+m?Vc2Z?2B z=6GK^$wMWfGBMSiC%3#|9l|8GxjXvH%^@1Ag6v_0I1Zvo0h%ELQj;9s7&i7Mw(KCb zv3TFljpLyxAtZ2nLlsJ$E{$OJab>mpnNd=Q?RZC~kI{v$5Oy($<~u>jSkrFyP>#K3Mr# z#3SwiD0wuH(?JY}$=pviN<>QNhfesD)MAW*eU(>Kf_v{|L$2`rJI?0^L zo6(1&mYb}TnZ2ETD)(o0yZC6szcnn%7jEra`e$aE^7z4^%?26*%>|mBvcVIyC?=Au z{##k0kP3(Q=^|4Xx%l~^ps%B<{3Id{RQ0bJrtrapgk8aj|7H6$FYc-o_Bb1qAVxPO z7k=06cv`s^)B&>%*+_{7HbjPz;igluS0*N39ge!1_Rheo$I(JvCSBN|#VIlc3)P1Z z3?LG9L_-imDSDZ{uy7>vB!xB=CEah!CJ716)t@ ze_MBWU-pls`~S!rNlN^YaXsXWxUE^|fOKtQU9TE4R*=d0(~vKmp+d0`h{~5l6Mm6c zX;5CAd(bdv%hFD;It%J!I2c@YE88yV&c4S?e^*xRCGLK|zQQsrj!#syo3ChtO4KOo zFt$Z>7kZL7y0vpkHE52ojrCDK`MD1IccT+KF*A4OWxB2Prft_xPC)n6NW!F}nZ%>- z5p~e_ZvCG6yU(fRu)RJWjV;JiJb!}-kv?@&x<1_Os$s?YU{mf0v?l0^o)pC_{JzB# z_a|pYZCXV=65&#O4u3;3u3I#t=Ll6IfTOl2jz6hl-GFm0)OeMPrA`^k2hj^rDFa1N zovdjQ1kniv)tWm*2N0q?uEE99#s?ZXr34XZ{^BQ$2e>luX0;>0*Hek5rrh}IYC=3y zU28xW6z$&#dBKlr&S@ubjKBd;klflz^vyUN>X@^u@5Y(D{r>l}68)k} zuA&@DQXc_o=fSYYUdyZmqV5B_(O|e%fC*)qYlI>(G%_D=H81NJ$pJ#x7#tPyo!Fvo zT?5zi8**zoxm^v>!8&JfE=MYeKR;-3{(gJoP-qM%W?9v2I?2VwQdQ&lSJDB61nR}) zzq&PZ7yjw*D!8*|mafPk zC&~2Q$0NDo|9K(WQfQ=>S`vjJ04hCY08#gyoTP7zX2L#@4c#~s_SfGDXZdyLdfGNl z9E$?jP6iuFCk4{;nbtalUj>ew4y)<2N(gRpT%azUoYqY)U&OtSs@TjS9X-EQ`Fm9` zO4^ObXhPO7!l)Zn&-1JYT?!?5$6&W`#X7h6v5gs>dJ-=LW~<>$zm{Su=T_dn_HcMA zhgsb~aOR#hIMoOExccvIgK3#?#lI;IoGfHt0dpy=YXwJpYuzHs6+~I@MJ@q`AsjKp(-|kJfD(kZMfS;LWY0T zV-%{fQ}Q(=r$_$m<>3Fjvt%tVa|hLYSw!TYYa*}by!mW?ESLX93bomAUSZaxaP1GZ zK=G9<^IJG+}3L}BM5Cmj}@ zt_r!1kY`Wf#*JkC0)dF^ebU*B#Ty*4WrpyN9zLH=i0|Z*h!af*?r|Va$JRovz}+7-gtE|KJ;`GHK_^S1|5-YJ+7t- zqop1*lNhP5EjT`1YZ%0X((5wGL|M^Ou>#l3xr}bp>)O@%%+U;B8R1!(}oZa_E9v)Q)9>F zMAqUif+{G6utRCka$@#36DQ7{QXGRig?#xlp5Kl96R5HxSmVfHpAD3doZA(p# z2%_d%9WnhDT}H~8y)KC1n+t;zX@vU={}VJcc5lH3v6#I2GH6`)?+`S|^YepWC;aMV z6=s}BL!Ks(r=Y5L|KdYc!m~$Ea!^xitUYTz6!V=@9^nqbx4K{#-CJ{)OHAwD<=kWL z?)ha9#tv)jO2a6^U=^!S6r$PFS7kw>)cY&;R`9RJOL>a#hYAck%p>FX5z(B5eTG;O zL)5(-WQpJB_;%5Wehcm#I|X@sImNw$zJ5c`EoWbuFjKGLAA7JpWi-2T&wF1p>oN1i zrace~GkrQiNY6?{DQ`I)i*q;_?lI-tSU2)smi*YEz=G2=W9_$J!lNgaKc^aUFu61P zKe~q-t(9d2`d3o4Se2x-VHC=~GqgG`Cp(*bCcV=RVR0==v|U%JDCp__?;r7+J{nuE z3u<(0$*L`UZ^P8XKJqZ3O*!KMbLxC;y^uq&SVmv`L25S5<(TySOYgF|Aiob<``<6x zb0+T?vWBI*3pVtscB1}JYVDl|8@pLTsF%}@21BZOki=67)8loDl~^ozEo4*79~GeJ z82=?1{9d>cp<|G~C3x5XMNJXdr@W@H0L(aZ_3^{v3HGjEzt#K`nR0C4a7^# zjPs_k7Jg@Jnfv{-3nBopaT*oV|BUXjjhu3~lx*5WdeBec;L}|GXHe8ko7}fVdec$& zoxw>K?s&7MU-m+@0fJG{$Iq5epP5Y1>)=JohqnGSxT?6-($}gAnCWL8 z&o5oPTUE{8$q{@`vtyei$9Uk(BS-h3ne5m*BzO65k{JIAR}!dSnwiFd`%N5jpLNd> zZRw}T9Y`PSkUIY$f%uD8?pkR;BUu;?dCt9sk2a3cU>Gy4p?oQ549Qx3jHoJfpixAx z!#4L{(XTccoAVzjZ80WYoUIl&NLsf(#b!x$zacY9^@@L~>A4W4~KbhFIEfj$EJ2Xq5=#|RU3OFUQ2X3m%|lGEmCx@3+aan_?o@RRpv8yeHAI99R4AIDM_9@dezR zHS^kzrv6Hx{=C`l+YoR-?D+FS!n>0Br#4^RZ(;h3ObTxI#UiOvOb4-VbZC1F*k(b! zdqvv+C0*Yo=}0>_HshxswSocPAXL~|&B2?q7*|^(Q8X^o9yg-fYIr(mKhtcocbY{v zeNPXOgh0unrf`*wr9*}sskAPExzS|GY?@9zVo7u&FJSMV(o%@ zqx4e*FWx_dXu~BF-}z?3>Z`Se7TEQ?ty4(L`~S=tO=Wc5LhFm^V|0rrBxb^{YZEq) z4b^LH2s~ACBZ0}q_V{uZG9Lj$7_)l_^%eP3%kvpsqDHGK$NquSKmMq#ndN@OB8(~j z0n{AZN!Ikl@7K+l$sIDaPRvx1II+!b%qX(ei33OQy=FPqgbX$vWv$g7(9V(o%g)s|f|LtuUVUW=y5n#jn4MIGNb;bTPpgucZ$ z^`uP)M0|i2pT=p!bc0~7kq~;CQn4VK^OR-Jt8G?WzWA#*aMI$vz$1G*eZlpsnC`JeT6%3!|Q*kPmb{vPx5u;^Sa{+Er0@&$OyZW6{m4d*X21 z(6n*I?i*Ss5IU(_C>2-BLg>`|GW@<${=FSirSALe=L(w`;XSK4LtnO*<_Bp0;#7+F za4ABsS66fMaV7Cru}h=$I>esROS>QT>$}pG4S@6t_p*irN=A8PGiA#EI!30 zoqh0oVr5?J)_Jrqj4=~!^VZLQEa*qTjO@Td#-`xDYR0B2t2-}Gwqv8qR^jkfzgC-~ z@m^DHdM3q`>2pO-A!p3W` za6DWsJFK1LTZpT^1RMIc0{vZoUp>)#Su7Y_?Yc;Il$5E>V;<0UT%+#QAS7sAk_)HO z)L}BX&?{xInyPu=aOdEd%8B%p4LKCV9TDN8xXh74nW+-U5*LGLP8?X(qx-*- z)}rk#0YVK`bRvrz&&-L8+`0w_`8Zt_Jo*^oJ#ekGMeK=hMmf3#86d8-kR8qm-J`gb z#%268NTq{;!Z%g$uivK`egg8>3jvYgn16I;&qn6$?zy+6jszC0l{=mwa@fjVS0UCa zk(_$(emt80`Bf7xVgtqQ`5h1$W%bRol}ngN^cV#x9Gq_gJ#~IJSSWanWV7O7*A+-M zjP*rxaN7-4W#Qj@z0`AmXdTDgbq^&B7F004>64=GqGS{La89A>y(IXJds7#~`wkAi!RH~l73B5lv=G4!7P zEBUeXul*8p>7gKXE}vKhowZBzYZD{E?Bt`+FQM3Zf%ZX=Y4cowkx>3k6359B{fWtZ zfPJe1T}Ci*eiY@%wtBo&l)K_ogI71PTZKzRAFS1e#4_%28u+r${S_tPZqVkSm6Iun z)e%m`tNhuz53C6iI^qt6#aYapIH!rkRqoiCH$T1?O{$${N8fof59L}77Zk7gTdcin zMesS>@hUy8@ZCbyxA9Qa!;{nUKP2;F?3`G<-dz>`M@0?RD+a$lksoHtXdPzi-O=d3 zK25#O1MOZRe@@i+4l{vwd#^cQQ!6%)omI^sGlrD?D51Ezqj%UXe5H*tb(#nXzXvWz z%)0QlHX;*CaBrvL?W2(6pSr>xem7%*>M=%IV_1Xb$dw~5t zxYFH-{md*3pECcW59(V+EYQp>%73t0zg8T)AmI!-~K~9-bOBOlZ_5t3;0VQjCWlSJs-)}KpCVe6IR=#oQ>XW z_SwSey+rDBA6@y}3Kn!?QN-)7DP9|)_seZVTz}1@mnKek#4R8G&SG-iafBa>6LN#Q za*jWanM|e2mzN{tb~J;8*JDx}ZzMF_F+rN3-w#m|cKvT1%{tE_7RI4bEn;`eh0-_lLkM@=b&lYU7x z6v{BG69ZhoYh}t6cxUHZE-G+QUeIP##k4~mmlOJ*MSP&QRe>+Gsb*SX{4yx3aUJ*F zsj!EFt*Kj{yDT{C@EBYkK-bPlbJY|D^gzR;> zR{nBg8Kr)_r>fgg>RC&5c2yxjbL@d2D{ZWhsNN{(C|lMkHhM|>{I4ne zmPJ^z#r7O`?oZ*00e14tLbJ@}=GU%hjb>tMA;0Lhv1e|{OC!j-#7Sis#JmLm;nT{k zzg;bffo&-*JXesX3)gJ*t?5=<&)6!33X-u#TUeWGQOK9NCq~8_`Ge!wWx5>fiFvx$ zzw7ck&z$ip^-&MqoTdzY9JG@`brx=FxndR|&yRE91JpmeL~cR`57iFlW`~Zg;EyfA zD{`*<&;~3#Pp8!#8JYcYIoa;0K!1xmp+~;jS;9SF1Y5_!uH8*h8*I4U=4nZCli;CI zP$TmcKGN>XRMds_QduJniycWD)^jdlLHZbiT z(-(PencP8ofXlNiuCAugjR)o)Q2H9pk>)8F%WN!a?}L>FMhfqAHQ@)V`v(4q<({6B z^##-E2?3-wZ#T)KsskE{DBdl`i_6nfX`gaZ�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 WreC%X;pQn(48qG^m>{b_1qOI>gfV6 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 EfAWYk_W%F@ literal 0 HcmV?d00001 diff --git a/venv/share/python-wheels/pep517-0.8.2-py2.py3-none-any.whl b/venv/share/python-wheels/pep517-0.8.2-py2.py3-none-any.whl new file mode 100644 index 0000000000000000000000000000000000000000..9a41c2531755f2c65292bd62af636d08517778d8 GIT binary patch literal 26686 zcmaHRLzHO2wq)71ZQHi3TefZ6wySR0wr$(CZT9_>?tZ`5??DdE8SIReD^F{rhWgV$aIRPRl^YLB~XAY~kcgYhi0@M=z+V zA|bD&Oy}(G9OEq;x5d@5UW8?JD0oI>VU-C~YW77;oZl4VE!YkOhDa*)TRe!Yq(#_9NsgnR{BSLYLxW84KukPl}&_^8WBm zR362@wZX%so>6gFQ`h`Z-`MWD!zQUqtvp;_?f01lty)p?6cS12SgKYLITII$&+F^x z>G;t{xw|n^Bzb$Uy`@pQX^DGULjAFR_g2LaqbcS_rB27i@AI}jC_WmO%cDTJ%ltWa zC{OSA_5B!yUzoKS^@`3uzYTAvr&F-lXt-@=xy`j)&Q|ZE{zofRd}-=0?q42GV5pSU zpU%;wRmo@SZRe7O`FAA9Ebb)i&$oGyV8)1C)Cra>1_8)l8pCaPliO}Q@tMn_74EnY zB2#>KY9Rgs7q#94y9HD%VvDSO+=dMnYe4>puV?X9Dxb(So(>1L8tV$GmBVP;0;@|H z(-`*!2i&u5cBK$a?&S;H>hMpY91><29o|K{IPC5GnE@3mQ5e6tUaz-1NyFĦr+ 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

1tp;3{lr;Rx+*P*B%e4R2bVHtZE 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

f@GaF7t$vor#pW{{Fc8P-yihf!_Qn}Yhfgi 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

$T~JHC!0Jhp@iU9grz zv*_;($V&wvkufj`mIb7kJ#jkM4LHXGi6q^@=r8&*gpm7b z3;e@PQBgymU5wCNTXeKUGp$B808iY6LZ3lHP z&_HppT_Tvh;9M*O=40doe(%IAI*t1Qo47iWDt*np2z2+o#ZBuFC>2mEDE-@2} z9aiiOhyjnspG7+*nuCo+)?~pL9I#Y?9c^?&e!ikl&BzIX z^IytIR8p9fQG&cEQ^-}-{9RY8@Oy9hI*f@+VvnKHp4F}qi?8&FpNS>SJc#+y-@+Rr z@oG|gFHJ_292i%PNBuD4lPs)bYsBJmMYJp7^Gx*d^s&sM>>To)IGP9@(Te-YRR0(Q zUWhRE7tZ*-;Ar>yWEa1O$RwUVSh$ zn_w8hnvXUBdE7L!cP4@0wM(4PzhH_w{Q4xv4}K2nfOFQ*g0Qjf8%`36@%2 zOa2meYqGphmtWkSmm#Z4N~em|n4_e7wgJ}xHhPfM@-GoHnY#DA{nxKK_@2W)$3=c* zP!s!-Rhm{=r-G(bGWN1Qx-)+Nj4g3z5JHFFtho`47o7ok~#-dMymR) zy4QrK1F_FLj}|VFBlO2-Mz4Ack0vH;KM~4G#b!KHka2##WlH^8oDj z^X$0o{*=irD=Vt7>*=iGQ7a_wxv75_?B2H9^pLdrfEa^1F zuiB)t%*`1yad2{?t!Q~Aog4u_YbAGP(_rPdm}CNTQ(CrD-j_X6he|nsT|u78};yU z&d;d%#b^^kEb*+XXwVr{JcoC%rMkDT0o)(AC@UnhXgO+0ITp9rBx(Tgw+-vwT#3U= z=m0PbiPIyK_P);(Y%aG;E;H%+JQdTZnozaR&1f`(9ZFaJ9j~a}QxwdvxcI6| z9mk_}Qg1hO^w~3ng{HMq9~S4WA)zf7InH{c>kl<^)>$^%x_3x+>qaQlxvy=Aan%6) zyECEL|54w=j);22)XbEvCJ}s@I9wqy(E=GvgVLasv6R0`W{G`3gcGtfsuLUy+hx_} zo4C|xUM!aB)9M`@kk94)GBe>jT>IDM`Tgdu^Jb@q$M<7uFUQ88=)~z59G^ciXxTwh zks5P>I4O`9WG zm#7%mO|ge`X+6EK1D!Vlw5SnSiVS&S1t(7@r=Wd$E4Sh&eh}+tS{~^AHgT6cdw{?~ zGek%#PRT+Y_#|E4Fu2B;Pn3y6J^7Eqg(nUw#A_*SI@7;3zEN25QP=iW^e) zVpI;nrMDrzMznj;NRqT<5D8Y`&IMYURaEYGV$8MxY7z;tk=+e0d!A~c(G8O>M`I~! zgz`_PVS#=OGQ<69fUT-qOrodO803$_kQVXtLV!AKRY)L~LY|tTxAptEU?H&6#~`XM z_On_!nrhU#Bfq;}lx-gMr|JD%?-%0OXKl2*1sBCQYt5QR*7sNoWu!d>#&F=^L0vc# z1J3f`hGKRxg^C2J7QA~q5wTsh&*mAnRyQvf3llJAz}hv{NNFE%AH3LqW!5FUiv#?? z@pTEvlg+pf!dG&fDqeA>j*l}Yz(*og-6&ceWnp4?dcE1{{o&B->UDVvO;VutO*<-x z+wo)|;l{T}CW@ArnnZP(jNe~X5mOS19_okWEKi(C_uX>8)DTjZREb__h!arsf|tuG zdKGZ2eljT&%B&CqT`99ci9x3*38kD(hTc>ma0y>Szfsr^*_rRMwrMrPp3jIwqw<0V zha?6`F&IALfN-Tv!A%3%3t+PL_3}IHam~tt-I6F&(qz8!Tc$XMLcxK8346N*lwl1D zWwSEXwN1gb_UCu5IFInsh4#`y6K@-%9(2%TvMbqx)&Q8d>yu}Kypo(Tx3mNfZjLU{ z$uEGP;Ye=-4!*T#=rIjSKxlIU>m37Lj!Dy?8O{SJB1eOAXq@WA>s0}1lass=_8Vqz zkFiia%fG&;eh}1R@}|b>XMo>kYkb~YLHvz*tXtWD*`y;?B)|}#p|VIu`Dg%Ts{pvj zOA;T|8d1+jVF^qtCBQo`s^C8X3~pRf9oQHH`D`f@GP=wO$RFd_HEWrMMZf*I~q9TEj_L!DANya*S&4_ij`O|Usa3;LO0~x zt1EnV-A@xVamYBYF6(=jI%xarL96kZ-|m*mO%QjxK>Hi|4`MK!emQwXT5*3?Ydg12 zE9lTrH|h^783cFhW(~YcjCVPjC=T<-P&#nmz&i(v_1JOxX5mKIGD{^dhGX9lR5xiS z0;5R?R(f{7^t1!?RaJ{DW9JX;bJ2-g)B7PR*i=W{u023>9Sj+TJWE+b1noaC3*_hm zoRk@J@MB|C*fKI0Ah{(0V5(rc#ew%XjiEAVKM#dLq0AuM37lKke8HzMYtiEV_SVO9!0|q49E*0Z=LH=Idv)zx!&IiIe>WE9 zvtn>J2m``ijMWW34Y20r*Gs^x0D}n7q(kf-x*2%=7K9B^)0YSq%;@|HApTDJG7<=Q ze6XKsP^v8LhGU#%PUthoIbJL)QC$hwk-EjmOY5j}oGD2Nz)&WtGhTGLSN*J_wdq|E zhOZ6F)U-tXhAmY=pS*$K6~vo=Y$QEZdwH}SeK9@T`uAw)>&eO!#OuprG4L=Cu-<8t74GCNOjGm zu(>wpG)`l9u`{_9;PR1cUBy%36UQwP7h$`#=e)>s{E*Dq7%fOj0#}aO0(%=nSaFe2 zoRBx5KM9lpepReC`TSoSbWs4}SAvln4rGy_J7#Xe^w+wWm zT>;6~BXDXa6b?D+d1;_u@&v!NvN1GWMRW+K`)S(=TBv$OH

;p_)?2m=;|Cc!t|?w(ih-|8-5b>UZDW04 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

TU?^Y|i!I>iIF3xB+l@0HjQ%vHO0 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 literal 0 HcmV?d00001 diff --git a/venv/share/python-wheels/pkg_resources-0.0.0-py2.py3-none-any.whl b/venv/share/python-wheels/pkg_resources-0.0.0-py2.py3-none-any.whl new file mode 100644 index 0000000000000000000000000000000000000000..e066bc741edc8d6dfade490f18ec62ea7ffffc1f GIT binary patch literal 127312 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 aG)_=gLU=BO0092;vHE;wwEt{Zz<&W9Ieei2 literal 0 HcmV?d00001 diff --git a/venv/share/python-wheels/progress-1.5-py2.py3-none-any.whl b/venv/share/python-wheels/progress-1.5-py2.py3-none-any.whl new file mode 100644 index 0000000000000000000000000000000000000000..ec396717939731c24396ffbf5f5dec912b0e2147 GIT binary patch literal 17547 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 F{{U6inlu0a literal 0 HcmV?d00001 diff --git a/venv/share/python-wheels/retrying-1.3.3-py2.py3-none-any.whl b/venv/share/python-wheels/retrying-1.3.3-py2.py3-none-any.whl new file mode 100644 index 0000000000000000000000000000000000000000..48b9fc004da63c7ae3dac0749dafed6ba66cacda GIT binary patch literal 16358 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 literal 0 HcmV?d00001 diff --git a/venv/share/python-wheels/setuptools-44.0.0-py2.py3-none-any.whl b/venv/share/python-wheels/setuptools-44.0.0-py2.py3-none-any.whl new file mode 100644 index 0000000000000000000000000000000000000000..b352c67e0fc367c841b8dbb6f76f8788bf8effe6 GIT binary patch literal 477446 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
aWIfsh#V;nI8v;f3CNN51*q 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 literal 0 HcmV?d00001 diff --git a/venv/share/python-wheels/six-1.14.0-py2.py3-none-any.whl b/venv/share/python-wheels/six-1.14.0-py2.py3-none-any.whl new file mode 100644 index 0000000000000000000000000000000000000000..0e572b2e940857d726d5e3006096e74247c60dff GIT binary patch literal 20256 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 oikgX!$LIBP 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 literal 0 HcmV?d00001 diff --git a/venv/share/python-wheels/urllib3-1.25.8-py2.py3-none-any.whl b/venv/share/python-wheels/urllib3-1.25.8-py2.py3-none-any.whl new file mode 100644 index 0000000000000000000000000000000000000000..e0851877d07e201e15640b32bab46edabbafdfe6 GIT binary patch literal 127041 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 literal 0 HcmV?d00001 diff --git a/venv/share/python-wheels/webencodings-0.5.1-py2.py3-none-any.whl b/venv/share/python-wheels/webencodings-0.5.1-py2.py3-none-any.whl new file mode 100644 index 0000000000000000000000000000000000000000..4fd5bfeb72c76d85a4433f322423ddc499fb43ac GIT binary patch literal 20484 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 Q=va3PWLLyOnf`eD4?P}r4gdfE literal 0 HcmV?d00001 diff --git a/venv/share/python-wheels/wheel-0.34.2-py2.py3-none-any.whl b/venv/share/python-wheels/wheel-0.34.2-py2.py3-none-any.whl new file mode 100644 index 0000000000000000000000000000000000000000..2fcda361e67827f696f6255a1b2cb5f90443dc8c GIT binary patch literal 35611 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�f``%?xk`|lba~?R#7s-f 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 KGB8B7f_MO;o(lH> literal 0 HcmV?d00001 From 5a9c84d4e9626756357003fff9c09422243141fd Mon Sep 17 00:00:00 2001 From: GACB-Ar Date: Tue, 24 Aug 2021 16:24:41 -0300 Subject: [PATCH 02/11] first commit --- telebot/telegram.py | 28 +++++++--------------------- 1 file changed, 7 insertions(+), 21 deletions(-) diff --git a/telebot/telegram.py b/telebot/telegram.py index 9d6d302..109c86d 100644 --- a/telebot/telegram.py +++ b/telebot/telegram.py @@ -69,29 +69,15 @@ def get_updates(token): return rsp.json()["result"] - -def register_message(sql: SQL, data, tkn): - """ - Recibe un mensaje, lo guarda en la base y envia - un response. - {'chat': {'first_name': 'Xavier', - 'id': 44444, - 'last_name': 'Petit', - 'type': 'private', - 'username': 'xpetit' - }, - 'date': 1628087051, - 'from': {'first_name': 'Xavier', - 'id': 4444, - 'is_bot': False, - 'language_code': 'en', - 'last_name': 'Petit', - 'username': 'xpetit'}, - 'message_id': 15, - 'text': 'dame info'} - """ +def register_db(sql:SQL, data): msg = Message(sql) msg.add(data["chat"]["id"], data["message_id"], data["text"]) + +def send_txt(data, tkn): send_message( f"👋 Hola {data['chat']['first_name']}! en que te puedo ayudar?", data["chat"]["id"], tkn) + +def register_message(sql: SQL, data, tkn): + register_db(sql, data) + send_txt(data, tkn) \ No newline at end of file From dbb9e3692a39692546d4aad6c8eb6d3ce5acde35 Mon Sep 17 00:00:00 2001 From: javim24 Date: Tue, 24 Aug 2021 16:33:24 -0300 Subject: [PATCH 03/11] Refactorizacion de register_message --- .gitignore | 4 ++++ telebot/telegram.py | 2 +- 2 files changed, 5 insertions(+), 1 deletion(-) diff --git a/.gitignore b/.gitignore index acbcdc1..b7ff267 100644 --- a/.gitignore +++ b/.gitignore @@ -152,6 +152,10 @@ ipython_config.py # PEP 582; used by e.g. github.com/David-OConnor/pyflow __pypackages__/ + +.vscode/ + + # Celery stuff celerybeat-schedule celerybeat.pid diff --git a/telebot/telegram.py b/telebot/telegram.py index 109c86d..9e283d9 100644 --- a/telebot/telegram.py +++ b/telebot/telegram.py @@ -75,7 +75,7 @@ def register_db(sql:SQL, data): def send_txt(data, tkn): send_message( - f"👋 Hola {data['chat']['first_name']}! en que te puedo ayudar?", + f"👋 Hola amigo {data['chat']['first_name']}! en que te puedo ayudar?", data["chat"]["id"], tkn) def register_message(sql: SQL, data, tkn): From c42f05b373e61d753b42cc5c0498a3386106365f Mon Sep 17 00:00:00 2001 From: javim24 Date: Tue, 24 Aug 2021 16:36:19 -0300 Subject: [PATCH 04/11] asd --- venv/bin/Activate.ps1 | 241 - venv/bin/activate | 76 - venv/bin/activate.csh | 37 - venv/bin/activate.fish | 75 - venv/bin/easy_install | 8 - venv/bin/easy_install-3.8 | 8 - venv/bin/normalizer | 8 - venv/bin/pip | 8 - venv/bin/pip3 | 8 - venv/bin/pip3.8 | 8 - venv/bin/python | 1 - venv/bin/python3 | 1 - .../__pycache__/easy_install.cpython-38.pyc | Bin 281 -> 0 bytes .../certifi-2021.5.30.dist-info/INSTALLER | 1 - .../certifi-2021.5.30.dist-info/LICENSE | 21 - .../certifi-2021.5.30.dist-info/METADATA | 83 - .../certifi-2021.5.30.dist-info/RECORD | 13 - .../certifi-2021.5.30.dist-info/WHEEL | 6 - .../certifi-2021.5.30.dist-info/top_level.txt | 1 - .../site-packages/certifi/__init__.py | 3 - .../site-packages/certifi/__main__.py | 12 - .../__pycache__/__init__.cpython-38.pyc | Bin 227 -> 0 bytes .../__pycache__/__main__.cpython-38.pyc | Bin 392 -> 0 bytes .../certifi/__pycache__/core.cpython-38.pyc | Bin 1108 -> 0 bytes .../site-packages/certifi/cacert.pem | 4257 --------- .../python3.8/site-packages/certifi/core.py | 60 - .../INSTALLER | 1 - .../LICENSE | 21 - .../METADATA | 275 - .../charset_normalizer-2.0.3.dist-info/RECORD | 33 - .../charset_normalizer-2.0.3.dist-info/WHEEL | 5 - .../entry_points.txt | 3 - .../top_level.txt | 1 - .../charset_normalizer/__init__.py | 31 - .../__pycache__/__init__.cpython-38.pyc | Bin 1855 -> 0 bytes .../__pycache__/api.cpython-38.pyc | Bin 9516 -> 0 bytes .../__pycache__/cd.cpython-38.pyc | Bin 7134 -> 0 bytes .../__pycache__/constant.cpython-38.pyc | Bin 13110 -> 0 bytes .../__pycache__/legacy.cpython-38.pyc | Bin 1419 -> 0 bytes .../__pycache__/md.cpython-38.pyc | Bin 13350 -> 0 bytes .../__pycache__/models.cpython-38.pyc | Bin 12394 -> 0 bytes .../__pycache__/utils.cpython-38.pyc | Bin 6050 -> 0 bytes .../__pycache__/version.cpython-38.pyc | Bin 238 -> 0 bytes .../site-packages/charset_normalizer/api.py | 421 - .../charset_normalizer/assets/__init__.py | 52 - .../__pycache__/__init__.cpython-38.pyc | Bin 6042 -> 0 bytes .../site-packages/charset_normalizer/cd.py | 261 - .../charset_normalizer/cli/__init__.py | 0 .../cli/__pycache__/__init__.cpython-38.pyc | Bin 158 -> 0 bytes .../cli/__pycache__/normalizer.cpython-38.pyc | Bin 5765 -> 0 bytes .../charset_normalizer/cli/normalizer.py | 210 - .../charset_normalizer/constant.py | 343 - .../charset_normalizer/legacy.py | 38 - .../site-packages/charset_normalizer/md.py | 451 - .../charset_normalizer/models.py | 355 - .../site-packages/charset_normalizer/py.typed | 0 .../site-packages/charset_normalizer/utils.py | 248 - .../charset_normalizer/version.py | 6 - .../python3.8/site-packages/easy_install.py | 5 - .../idna-3.2.dist-info/INSTALLER | 1 - .../idna-3.2.dist-info/LICENSE.md | 29 - .../site-packages/idna-3.2.dist-info/METADATA | 225 - .../site-packages/idna-3.2.dist-info/RECORD | 23 - .../site-packages/idna-3.2.dist-info/WHEEL | 5 - .../idna-3.2.dist-info/top_level.txt | 1 - .../python3.8/site-packages/idna/__init__.py | 44 - .../idna/__pycache__/__init__.cpython-38.pyc | Bin 869 -> 0 bytes .../idna/__pycache__/codec.cpython-38.pyc | Bin 2830 -> 0 bytes .../idna/__pycache__/compat.cpython-38.pyc | Bin 636 -> 0 bytes .../idna/__pycache__/core.cpython-38.pyc | Bin 9126 -> 0 bytes .../idna/__pycache__/idnadata.cpython-38.pyc | Bin 22090 -> 0 bytes .../idna/__pycache__/intranges.cpython-38.pyc | Bin 1812 -> 0 bytes .../__pycache__/package_data.cpython-38.pyc | Bin 163 -> 0 bytes .../idna/__pycache__/uts46data.cpython-38.pyc | Bin 177435 -> 0 bytes .../lib/python3.8/site-packages/idna/codec.py | 117 - .../python3.8/site-packages/idna/compat.py | 16 - venv/lib/python3.8/site-packages/idna/core.py | 409 - .../python3.8/site-packages/idna/idnadata.py | 2050 ---- .../python3.8/site-packages/idna/intranges.py | 58 - .../site-packages/idna/package_data.py | 2 - .../lib/python3.8/site-packages/idna/py.typed | 0 .../python3.8/site-packages/idna/uts46data.py | 8438 ----------------- .../pip-20.0.2.dist-info/INSTALLER | 1 - .../pip-20.0.2.dist-info/LICENSE.txt | 20 - .../pip-20.0.2.dist-info/METADATA | 84 - .../site-packages/pip-20.0.2.dist-info/RECORD | 246 - .../site-packages/pip-20.0.2.dist-info/WHEEL | 6 - .../pip-20.0.2.dist-info/entry_points.txt | 5 - .../pip-20.0.2.dist-info/top_level.txt | 1 - .../python3.8/site-packages/pip/__init__.py | 18 - .../python3.8/site-packages/pip/__main__.py | 19 - .../pip/__pycache__/__init__.cpython-38.pyc | Bin 629 -> 0 bytes .../pip/__pycache__/__main__.cpython-38.pyc | Bin 422 -> 0 bytes .../site-packages/pip/_internal/__init__.py | 18 - .../__pycache__/__init__.cpython-38.pyc | Bin 678 -> 0 bytes .../__pycache__/build_env.cpython-38.pyc | Bin 7483 -> 0 bytes .../__pycache__/cache.cpython-38.pyc | Bin 8700 -> 0 bytes .../__pycache__/configuration.cpython-38.pyc | Bin 10645 -> 0 bytes .../__pycache__/exceptions.cpython-38.pyc | Bin 12482 -> 0 bytes .../__pycache__/legacy_resolve.cpython-38.pyc | Bin 9898 -> 0 bytes .../__pycache__/locations.cpython-38.pyc | Bin 4492 -> 0 bytes .../_internal/__pycache__/main.cpython-38.pyc | Bin 615 -> 0 bytes .../__pycache__/pep425tags.cpython-38.pyc | Bin 3584 -> 0 bytes .../__pycache__/pyproject.cpython-38.pyc | Bin 3732 -> 0 bytes .../self_outdated_check.cpython-38.pyc | Bin 5493 -> 0 bytes .../__pycache__/wheel_builder.cpython-38.pyc | Bin 6699 -> 0 bytes .../site-packages/pip/_internal/build_env.py | 221 - .../site-packages/pip/_internal/cache.py | 329 - .../pip/_internal/cli/__init__.py | 4 - .../cli/__pycache__/__init__.cpython-38.pyc | Bin 236 -> 0 bytes .../__pycache__/autocompletion.cpython-38.pyc | Bin 4953 -> 0 bytes .../__pycache__/base_command.cpython-38.pyc | Bin 5847 -> 0 bytes .../cli/__pycache__/cmdoptions.cpython-38.pyc | Bin 20328 -> 0 bytes .../command_context.cpython-38.pyc | Bin 1311 -> 0 bytes .../cli/__pycache__/main.cpython-38.pyc | Bin 1406 -> 0 bytes .../__pycache__/main_parser.cpython-38.pyc | Bin 2159 -> 0 bytes .../cli/__pycache__/parser.cpython-38.pyc | Bin 8977 -> 0 bytes .../__pycache__/req_command.cpython-38.pyc | Bin 8289 -> 0 bytes .../__pycache__/status_codes.cpython-38.pyc | Bin 365 -> 0 bytes .../pip/_internal/cli/autocompletion.py | 164 - .../pip/_internal/cli/base_command.py | 226 - .../pip/_internal/cli/cmdoptions.py | 957 -- .../pip/_internal/cli/command_context.py | 36 - .../site-packages/pip/_internal/cli/main.py | 75 - .../pip/_internal/cli/main_parser.py | 99 - .../site-packages/pip/_internal/cli/parser.py | 265 - .../pip/_internal/cli/req_command.py | 333 - .../pip/_internal/cli/status_codes.py | 8 - .../pip/_internal/commands/__init__.py | 114 - .../__pycache__/__init__.cpython-38.pyc | Bin 2852 -> 0 bytes .../commands/__pycache__/check.cpython-38.pyc | Bin 1312 -> 0 bytes .../__pycache__/completion.cpython-38.pyc | Bin 3013 -> 0 bytes .../__pycache__/configuration.cpython-38.pyc | Bin 6575 -> 0 bytes .../commands/__pycache__/debug.cpython-38.pyc | Bin 4089 -> 0 bytes .../__pycache__/download.cpython-38.pyc | Bin 3921 -> 0 bytes .../__pycache__/freeze.cpython-38.pyc | Bin 2929 -> 0 bytes .../commands/__pycache__/hash.cpython-38.pyc | Bin 1990 -> 0 bytes .../commands/__pycache__/help.cpython-38.pyc | Bin 1186 -> 0 bytes .../__pycache__/install.cpython-38.pyc | Bin 16661 -> 0 bytes .../commands/__pycache__/list.cpython-38.pyc | Bin 9042 -> 0 bytes .../__pycache__/search.cpython-38.pyc | Bin 4484 -> 0 bytes .../commands/__pycache__/show.cpython-38.pyc | Bin 6325 -> 0 bytes .../__pycache__/uninstall.cpython-38.pyc | Bin 2694 -> 0 bytes .../commands/__pycache__/wheel.cpython-38.pyc | Bin 5246 -> 0 bytes .../pip/_internal/commands/check.py | 45 - .../pip/_internal/commands/completion.py | 96 - .../pip/_internal/commands/configuration.py | 233 - .../pip/_internal/commands/debug.py | 142 - .../pip/_internal/commands/download.py | 147 - .../pip/_internal/commands/freeze.py | 103 - .../pip/_internal/commands/hash.py | 58 - .../pip/_internal/commands/help.py | 41 - .../pip/_internal/commands/install.py | 727 -- .../pip/_internal/commands/list.py | 315 - .../pip/_internal/commands/search.py | 145 - .../pip/_internal/commands/show.py | 180 - .../pip/_internal/commands/uninstall.py | 82 - .../pip/_internal/commands/wheel.py | 197 - .../pip/_internal/configuration.py | 422 - .../pip/_internal/distributions/__init__.py | 24 - .../__pycache__/__init__.cpython-38.pyc | Bin 812 -> 0 bytes .../__pycache__/base.cpython-38.pyc | Bin 1928 -> 0 bytes .../__pycache__/installed.cpython-38.pyc | Bin 1208 -> 0 bytes .../__pycache__/sdist.cpython-38.pyc | Bin 3471 -> 0 bytes .../__pycache__/wheel.cpython-38.pyc | Bin 1560 -> 0 bytes .../pip/_internal/distributions/base.py | 45 - .../pip/_internal/distributions/installed.py | 24 - .../pip/_internal/distributions/sdist.py | 104 - .../pip/_internal/distributions/wheel.py | 36 - .../site-packages/pip/_internal/exceptions.py | 308 - .../pip/_internal/index/__init__.py | 2 - .../index/__pycache__/__init__.cpython-38.pyc | Bin 190 -> 0 bytes .../__pycache__/collector.cpython-38.pyc | Bin 14156 -> 0 bytes .../__pycache__/package_finder.cpython-38.pyc | Bin 25749 -> 0 bytes .../pip/_internal/index/collector.py | 544 -- .../pip/_internal/index/package_finder.py | 1013 -- .../pip/_internal/legacy_resolve.py | 430 - .../site-packages/pip/_internal/locations.py | 194 - .../site-packages/pip/_internal/main.py | 16 - .../pip/_internal/models/__init__.py | 2 - .../__pycache__/__init__.cpython-38.pyc | Bin 224 -> 0 bytes .../__pycache__/candidate.cpython-38.pyc | Bin 1421 -> 0 bytes .../__pycache__/format_control.cpython-38.pyc | Bin 2416 -> 0 bytes .../models/__pycache__/index.cpython-38.pyc | Bin 1146 -> 0 bytes .../models/__pycache__/link.cpython-38.pyc | Bin 6659 -> 0 bytes .../models/__pycache__/scheme.cpython-38.pyc | Bin 862 -> 0 bytes .../__pycache__/search_scope.cpython-38.pyc | Bin 3253 -> 0 bytes .../selection_prefs.cpython-38.pyc | Bin 1596 -> 0 bytes .../__pycache__/target_python.cpython-38.pyc | Bin 3219 -> 0 bytes .../models/__pycache__/wheel.cpython-38.pyc | Bin 3182 -> 0 bytes .../pip/_internal/models/candidate.py | 36 - .../pip/_internal/models/format_control.py | 84 - .../pip/_internal/models/index.py | 31 - .../pip/_internal/models/link.py | 227 - .../pip/_internal/models/scheme.py | 25 - .../pip/_internal/models/search_scope.py | 114 - .../pip/_internal/models/selection_prefs.py | 47 - .../pip/_internal/models/target_python.py | 107 - .../pip/_internal/models/wheel.py | 78 - .../pip/_internal/network/__init__.py | 2 - .../__pycache__/__init__.cpython-38.pyc | Bin 212 -> 0 bytes .../network/__pycache__/auth.cpython-38.pyc | Bin 6978 -> 0 bytes .../network/__pycache__/cache.cpython-38.pyc | Bin 2691 -> 0 bytes .../__pycache__/download.cpython-38.pyc | Bin 4370 -> 0 bytes .../__pycache__/session.cpython-38.pyc | Bin 8851 -> 0 bytes .../network/__pycache__/utils.cpython-38.pyc | Bin 706 -> 0 bytes .../network/__pycache__/xmlrpc.cpython-38.pyc | Bin 1574 -> 0 bytes .../pip/_internal/network/auth.py | 298 - .../pip/_internal/network/cache.py | 81 - .../pip/_internal/network/download.py | 200 - .../pip/_internal/network/session.py | 405 - .../pip/_internal/network/utils.py | 48 - .../pip/_internal/network/xmlrpc.py | 44 - .../pip/_internal/operations/__init__.py | 0 .../__pycache__/__init__.cpython-38.pyc | Bin 160 -> 0 bytes .../__pycache__/check.cpython-38.pyc | Bin 3656 -> 0 bytes .../__pycache__/freeze.cpython-38.pyc | Bin 5803 -> 0 bytes .../__pycache__/prepare.cpython-38.pyc | Bin 11162 -> 0 bytes .../_internal/operations/build/__init__.py | 0 .../build/__pycache__/__init__.cpython-38.pyc | Bin 166 -> 0 bytes .../build/__pycache__/metadata.cpython-38.pyc | Bin 1208 -> 0 bytes .../metadata_legacy.cpython-38.pyc | Bin 3268 -> 0 bytes .../build/__pycache__/wheel.cpython-38.pyc | Bin 1306 -> 0 bytes .../__pycache__/wheel_legacy.cpython-38.pyc | Bin 2567 -> 0 bytes .../_internal/operations/build/metadata.py | 40 - .../operations/build/metadata_legacy.py | 122 - .../pip/_internal/operations/build/wheel.py | 46 - .../operations/build/wheel_legacy.py | 115 - .../pip/_internal/operations/check.py | 163 - .../pip/_internal/operations/freeze.py | 265 - .../_internal/operations/install/__init__.py | 2 - .../__pycache__/__init__.cpython-38.pyc | Bin 224 -> 0 bytes .../editable_legacy.cpython-38.pyc | Bin 1302 -> 0 bytes .../install/__pycache__/legacy.cpython-38.pyc | Bin 3048 -> 0 bytes .../install/__pycache__/wheel.cpython-38.pyc | Bin 14582 -> 0 bytes .../operations/install/editable_legacy.py | 52 - .../_internal/operations/install/legacy.py | 129 - .../pip/_internal/operations/install/wheel.py | 615 -- .../pip/_internal/operations/prepare.py | 591 -- .../site-packages/pip/_internal/pep425tags.py | 167 - .../site-packages/pip/_internal/pyproject.py | 196 - .../pip/_internal/req/__init__.py | 92 - .../req/__pycache__/__init__.cpython-38.pyc | Bin 2194 -> 0 bytes .../__pycache__/constructors.cpython-38.pyc | Bin 10363 -> 0 bytes .../req/__pycache__/req_file.cpython-38.pyc | Bin 12702 -> 0 bytes .../__pycache__/req_install.cpython-38.pyc | Bin 21338 -> 0 bytes .../req/__pycache__/req_set.cpython-38.pyc | Bin 6021 -> 0 bytes .../__pycache__/req_tracker.cpython-38.pyc | Bin 4041 -> 0 bytes .../__pycache__/req_uninstall.cpython-38.pyc | Bin 17427 -> 0 bytes .../pip/_internal/req/constructors.py | 436 - .../pip/_internal/req/req_file.py | 546 -- .../pip/_internal/req/req_install.py | 830 -- .../pip/_internal/req/req_set.py | 209 - .../pip/_internal/req/req_tracker.py | 150 - .../pip/_internal/req/req_uninstall.py | 644 -- .../pip/_internal/self_outdated_check.py | 242 - .../pip/_internal/utils/__init__.py | 0 .../utils/__pycache__/__init__.cpython-38.pyc | Bin 155 -> 0 bytes .../utils/__pycache__/appdirs.cpython-38.pyc | Bin 1351 -> 0 bytes .../utils/__pycache__/compat.cpython-38.pyc | Bin 6120 -> 0 bytes .../__pycache__/deprecation.cpython-38.pyc | Bin 2826 -> 0 bytes .../__pycache__/distutils_args.cpython-38.pyc | Bin 1139 -> 0 bytes .../utils/__pycache__/encoding.cpython-38.pyc | Bin 1247 -> 0 bytes .../__pycache__/entrypoints.cpython-38.pyc | Bin 1299 -> 0 bytes .../__pycache__/filesystem.cpython-38.pyc | Bin 4035 -> 0 bytes .../__pycache__/filetypes.cpython-38.pyc | Bin 556 -> 0 bytes .../utils/__pycache__/glibc.cpython-38.pyc | Bin 1708 -> 0 bytes .../utils/__pycache__/hashes.cpython-38.pyc | Bin 4144 -> 0 bytes .../inject_securetransport.cpython-38.pyc | Bin 932 -> 0 bytes .../utils/__pycache__/logging.cpython-38.pyc | Bin 9159 -> 0 bytes .../__pycache__/marker_files.cpython-38.pyc | Bin 928 -> 0 bytes .../utils/__pycache__/misc.cpython-38.pyc | Bin 23778 -> 0 bytes .../utils/__pycache__/models.cpython-38.pyc | Bin 1924 -> 0 bytes .../__pycache__/packaging.cpython-38.pyc | Bin 2608 -> 0 bytes .../__pycache__/pkg_resources.cpython-38.pyc | Bin 1822 -> 0 bytes .../setuptools_build.cpython-38.pyc | Bin 2927 -> 0 bytes .../__pycache__/subprocess.cpython-38.pyc | Bin 5598 -> 0 bytes .../utils/__pycache__/temp_dir.cpython-38.pyc | Bin 6711 -> 0 bytes .../utils/__pycache__/typing.cpython-38.pyc | Bin 1437 -> 0 bytes .../utils/__pycache__/ui.cpython-38.pyc | Bin 11802 -> 0 bytes .../__pycache__/unpacking.cpython-38.pyc | Bin 6075 -> 0 bytes .../utils/__pycache__/urls.cpython-38.pyc | Bin 1465 -> 0 bytes .../__pycache__/virtualenv.cpython-38.pyc | Bin 3280 -> 0 bytes .../utils/__pycache__/wheel.cpython-38.pyc | Bin 6325 -> 0 bytes .../pip/_internal/utils/appdirs.py | 44 - .../pip/_internal/utils/compat.py | 269 - .../pip/_internal/utils/deprecation.py | 104 - .../pip/_internal/utils/distutils_args.py | 48 - .../pip/_internal/utils/encoding.py | 42 - .../pip/_internal/utils/entrypoints.py | 31 - .../pip/_internal/utils/filesystem.py | 171 - .../pip/_internal/utils/filetypes.py | 16 - .../pip/_internal/utils/glibc.py | 98 - .../pip/_internal/utils/hashes.py | 131 - .../_internal/utils/inject_securetransport.py | 36 - .../pip/_internal/utils/logging.py | 398 - .../pip/_internal/utils/marker_files.py | 25 - .../site-packages/pip/_internal/utils/misc.py | 904 -- .../pip/_internal/utils/models.py | 42 - .../pip/_internal/utils/packaging.py | 94 - .../pip/_internal/utils/pkg_resources.py | 44 - .../pip/_internal/utils/setuptools_build.py | 181 - .../pip/_internal/utils/subprocess.py | 278 - .../pip/_internal/utils/temp_dir.py | 250 - .../pip/_internal/utils/typing.py | 38 - .../site-packages/pip/_internal/utils/ui.py | 428 - .../pip/_internal/utils/unpacking.py | 272 - .../site-packages/pip/_internal/utils/urls.py | 54 - .../pip/_internal/utils/virtualenv.py | 115 - .../pip/_internal/utils/wheel.py | 225 - .../pip/_internal/vcs/__init__.py | 15 - .../vcs/__pycache__/__init__.cpython-38.pyc | Bin 448 -> 0 bytes .../vcs/__pycache__/bazaar.cpython-38.pyc | Bin 3747 -> 0 bytes .../vcs/__pycache__/git.cpython-38.pyc | Bin 9559 -> 0 bytes .../vcs/__pycache__/mercurial.cpython-38.pyc | Bin 4888 -> 0 bytes .../vcs/__pycache__/subversion.cpython-38.pyc | Bin 8487 -> 0 bytes .../__pycache__/versioncontrol.cpython-38.pyc | Bin 19216 -> 0 bytes .../site-packages/pip/_internal/vcs/bazaar.py | 120 - .../site-packages/pip/_internal/vcs/git.py | 395 - .../pip/_internal/vcs/mercurial.py | 155 - .../pip/_internal/vcs/subversion.py | 333 - .../pip/_internal/vcs/versioncontrol.py | 700 -- .../pip/_internal/wheel_builder.py | 305 - .../site-packages/pip/_vendor/__init__.py | 119 - .../__pycache__/__init__.cpython-38.pyc | Bin 3037 -> 0 bytes .../pkg_resources-0.0.0.dist-info/AUTHORS.txt | 562 -- .../pkg_resources-0.0.0.dist-info/INSTALLER | 1 - .../pkg_resources-0.0.0.dist-info/LICENSE.txt | 20 - .../pkg_resources-0.0.0.dist-info/METADATA | 13 - .../pkg_resources-0.0.0.dist-info/RECORD | 38 - .../pkg_resources-0.0.0.dist-info/WHEEL | 6 - .../site-packages/pkg_resources/__init__.py | 3296 ------- .../__pycache__/__init__.cpython-38.pyc | Bin 100356 -> 0 bytes .../__pycache__/py31compat.cpython-38.pyc | Bin 600 -> 0 bytes .../pkg_resources/_vendor/__init__.py | 0 .../__pycache__/__init__.cpython-38.pyc | Bin 157 -> 0 bytes .../__pycache__/appdirs.cpython-38.pyc | Bin 20510 -> 0 bytes .../__pycache__/pyparsing.cpython-38.pyc | Bin 201634 -> 0 bytes .../_vendor/__pycache__/six.cpython-38.pyc | Bin 24430 -> 0 bytes .../pkg_resources/_vendor/appdirs.py | 608 -- .../_vendor/packaging/__about__.py | 21 - .../_vendor/packaging/__init__.py | 14 - .../__pycache__/__about__.cpython-38.pyc | Bin 707 -> 0 bytes .../__pycache__/__init__.cpython-38.pyc | Bin 545 -> 0 bytes .../__pycache__/_compat.cpython-38.pyc | Bin 981 -> 0 bytes .../__pycache__/_structures.cpython-38.pyc | Bin 2763 -> 0 bytes .../__pycache__/markers.cpython-38.pyc | Bin 8919 -> 0 bytes .../__pycache__/requirements.cpython-38.pyc | Bin 3878 -> 0 bytes .../__pycache__/specifiers.cpython-38.pyc | Bin 19787 -> 0 bytes .../__pycache__/utils.cpython-38.pyc | Bin 466 -> 0 bytes .../__pycache__/version.cpython-38.pyc | Bin 10634 -> 0 bytes .../_vendor/packaging/_compat.py | 30 - .../_vendor/packaging/_structures.py | 68 - .../_vendor/packaging/markers.py | 301 - .../_vendor/packaging/requirements.py | 127 - .../_vendor/packaging/specifiers.py | 774 -- .../pkg_resources/_vendor/packaging/utils.py | 14 - .../_vendor/packaging/version.py | 393 - .../pkg_resources/_vendor/pyparsing.py | 5742 ----------- .../pkg_resources/_vendor/six.py | 868 -- .../pkg_resources/extern/__init__.py | 73 - .../__pycache__/__init__.cpython-38.pyc | Bin 2406 -> 0 bytes .../site-packages/pkg_resources/py31compat.py | 23 - .../requests-2.26.0.dist-info/INSTALLER | 1 - .../requests-2.26.0.dist-info/LICENSE | 175 - .../requests-2.26.0.dist-info/METADATA | 120 - .../requests-2.26.0.dist-info/RECORD | 42 - .../requests-2.26.0.dist-info/WHEEL | 6 - .../requests-2.26.0.dist-info/top_level.txt | 1 - .../site-packages/requests/__init__.py | 152 - .../__pycache__/__init__.cpython-38.pyc | Bin 3850 -> 0 bytes .../__pycache__/__version__.cpython-38.pyc | Bin 507 -> 0 bytes .../_internal_utils.cpython-38.pyc | Bin 1272 -> 0 bytes .../__pycache__/adapters.cpython-38.pyc | Bin 16863 -> 0 bytes .../requests/__pycache__/api.cpython-38.pyc | Bin 6647 -> 0 bytes .../requests/__pycache__/auth.cpython-38.pyc | Bin 8291 -> 0 bytes .../requests/__pycache__/certs.cpython-38.pyc | Bin 573 -> 0 bytes .../__pycache__/compat.cpython-38.pyc | Bin 1667 -> 0 bytes .../__pycache__/cookies.cpython-38.pyc | Bin 18786 -> 0 bytes .../__pycache__/exceptions.cpython-38.pyc | Bin 5341 -> 0 bytes .../requests/__pycache__/help.cpython-38.pyc | Bin 2845 -> 0 bytes .../requests/__pycache__/hooks.cpython-38.pyc | Bin 944 -> 0 bytes .../__pycache__/models.cpython-38.pyc | Bin 24428 -> 0 bytes .../__pycache__/packages.cpython-38.pyc | Bin 651 -> 0 bytes .../__pycache__/sessions.cpython-38.pyc | Bin 19887 -> 0 bytes .../__pycache__/status_codes.cpython-38.pyc | Bin 4199 -> 0 bytes .../__pycache__/structures.cpython-38.pyc | Bin 4412 -> 0 bytes .../requests/__pycache__/utils.cpython-38.pyc | Bin 23213 -> 0 bytes .../site-packages/requests/__version__.py | 14 - .../site-packages/requests/_internal_utils.py | 42 - .../site-packages/requests/adapters.py | 533 -- .../python3.8/site-packages/requests/api.py | 159 - .../python3.8/site-packages/requests/auth.py | 305 - .../python3.8/site-packages/requests/certs.py | 18 - .../site-packages/requests/compat.py | 75 - .../site-packages/requests/cookies.py | 549 -- .../site-packages/requests/exceptions.py | 127 - .../python3.8/site-packages/requests/help.py | 135 - .../python3.8/site-packages/requests/hooks.py | 34 - .../site-packages/requests/models.py | 966 -- .../site-packages/requests/packages.py | 26 - .../site-packages/requests/sessions.py | 781 -- .../site-packages/requests/status_codes.py | 123 - .../site-packages/requests/structures.py | 105 - .../python3.8/site-packages/requests/utils.py | 1013 -- .../setuptools-44.0.0.dist-info/AUTHORS.txt | 562 -- .../setuptools-44.0.0.dist-info/INSTALLER | 1 - .../setuptools-44.0.0.dist-info/LICENSE.txt | 20 - .../setuptools-44.0.0.dist-info/METADATA | 82 - .../setuptools-44.0.0.dist-info/RECORD | 163 - .../setuptools-44.0.0.dist-info/WHEEL | 6 - .../dependency_links.txt | 2 - .../entry_points.txt | 68 - .../setuptools-44.0.0.dist-info/top_level.txt | 3 - .../setuptools-44.0.0.dist-info/zip-safe | 1 - .../site-packages/setuptools/__init__.py | 228 - .../__pycache__/__init__.cpython-38.pyc | Bin 7768 -> 0 bytes .../_deprecation_warning.cpython-38.pyc | Bin 516 -> 0 bytes .../__pycache__/_imp.cpython-38.pyc | Bin 1890 -> 0 bytes .../__pycache__/archive_util.cpython-38.pyc | Bin 5128 -> 0 bytes .../__pycache__/build_meta.cpython-38.pyc | Bin 8495 -> 0 bytes .../__pycache__/config.cpython-38.pyc | Bin 17896 -> 0 bytes .../__pycache__/dep_util.cpython-38.pyc | Bin 819 -> 0 bytes .../__pycache__/depends.cpython-38.pyc | Bin 5216 -> 0 bytes .../__pycache__/dist.cpython-38.pyc | Bin 42326 -> 0 bytes .../__pycache__/errors.cpython-38.pyc | Bin 816 -> 0 bytes .../__pycache__/extension.cpython-38.pyc | Bin 1961 -> 0 bytes .../__pycache__/glob.cpython-38.pyc | Bin 3733 -> 0 bytes .../__pycache__/installer.cpython-38.pyc | Bin 4102 -> 0 bytes .../__pycache__/launch.cpython-38.pyc | Bin 824 -> 0 bytes .../__pycache__/lib2to3_ex.cpython-38.pyc | Bin 2411 -> 0 bytes .../__pycache__/monkey.cpython-38.pyc | Bin 4644 -> 0 bytes .../__pycache__/msvc.cpython-38.pyc | Bin 39631 -> 0 bytes .../__pycache__/namespaces.cpython-38.pyc | Bin 3616 -> 0 bytes .../__pycache__/package_index.cpython-38.pyc | Bin 32970 -> 0 bytes .../__pycache__/py27compat.cpython-38.pyc | Bin 1749 -> 0 bytes .../__pycache__/py31compat.cpython-38.pyc | Bin 1191 -> 0 bytes .../__pycache__/py33compat.cpython-38.pyc | Bin 1408 -> 0 bytes .../__pycache__/py34compat.cpython-38.pyc | Bin 450 -> 0 bytes .../__pycache__/sandbox.cpython-38.pyc | Bin 15536 -> 0 bytes .../__pycache__/site-patch.cpython-38.pyc | Bin 1474 -> 0 bytes .../__pycache__/ssl_support.cpython-38.pyc | Bin 6855 -> 0 bytes .../__pycache__/unicode_utils.cpython-38.pyc | Bin 1151 -> 0 bytes .../__pycache__/version.cpython-38.pyc | Bin 292 -> 0 bytes .../__pycache__/wheel.cpython-38.pyc | Bin 7383 -> 0 bytes .../windows_support.cpython-38.pyc | Bin 989 -> 0 bytes .../setuptools/_deprecation_warning.py | 7 - .../site-packages/setuptools/_imp.py | 73 - .../setuptools/_vendor/__init__.py | 0 .../__pycache__/__init__.cpython-38.pyc | Bin 154 -> 0 bytes .../__pycache__/ordered_set.cpython-38.pyc | Bin 16412 -> 0 bytes .../__pycache__/pyparsing.cpython-38.pyc | Bin 201631 -> 0 bytes .../_vendor/__pycache__/six.cpython-38.pyc | Bin 24427 -> 0 bytes .../setuptools/_vendor/ordered_set.py | 488 - .../setuptools/_vendor/packaging/__about__.py | 27 - .../setuptools/_vendor/packaging/__init__.py | 26 - .../__pycache__/__about__.cpython-38.pyc | Bin 704 -> 0 bytes .../__pycache__/__init__.cpython-38.pyc | Bin 542 -> 0 bytes .../__pycache__/_compat.cpython-38.pyc | Bin 978 -> 0 bytes .../__pycache__/_structures.cpython-38.pyc | Bin 2760 -> 0 bytes .../__pycache__/markers.cpython-38.pyc | Bin 8927 -> 0 bytes .../__pycache__/requirements.cpython-38.pyc | Bin 3995 -> 0 bytes .../__pycache__/specifiers.cpython-38.pyc | Bin 19734 -> 0 bytes .../packaging/__pycache__/tags.cpython-38.pyc | Bin 10811 -> 0 bytes .../__pycache__/utils.cpython-38.pyc | Bin 1435 -> 0 bytes .../__pycache__/version.cpython-38.pyc | Bin 12065 -> 0 bytes .../setuptools/_vendor/packaging/_compat.py | 31 - .../_vendor/packaging/_structures.py | 68 - .../setuptools/_vendor/packaging/markers.py | 296 - .../_vendor/packaging/requirements.py | 138 - .../_vendor/packaging/specifiers.py | 749 -- .../setuptools/_vendor/packaging/tags.py | 404 - .../setuptools/_vendor/packaging/utils.py | 57 - .../setuptools/_vendor/packaging/version.py | 420 - .../setuptools/_vendor/pyparsing.py | 5742 ----------- .../site-packages/setuptools/_vendor/six.py | 868 -- .../site-packages/setuptools/archive_util.py | 173 - .../site-packages/setuptools/build_meta.py | 257 - .../site-packages/setuptools/cli-32.exe | Bin 65536 -> 0 bytes .../site-packages/setuptools/cli-64.exe | Bin 74752 -> 0 bytes .../site-packages/setuptools/cli.exe | Bin 65536 -> 0 bytes .../setuptools/command/__init__.py | 17 - .../__pycache__/__init__.cpython-38.pyc | Bin 712 -> 0 bytes .../command/__pycache__/alias.cpython-38.pyc | Bin 2392 -> 0 bytes .../__pycache__/bdist_egg.cpython-38.pyc | Bin 14182 -> 0 bytes .../__pycache__/bdist_rpm.cpython-38.pyc | Bin 1784 -> 0 bytes .../__pycache__/bdist_wininst.cpython-38.pyc | Bin 954 -> 0 bytes .../__pycache__/build_clib.cpython-38.pyc | Bin 2437 -> 0 bytes .../__pycache__/build_ext.cpython-38.pyc | Bin 9895 -> 0 bytes .../__pycache__/build_py.cpython-38.pyc | Bin 8641 -> 0 bytes .../__pycache__/develop.cpython-38.pyc | Bin 6501 -> 0 bytes .../__pycache__/dist_info.cpython-38.pyc | Bin 1361 -> 0 bytes .../__pycache__/easy_install.cpython-38.pyc | Bin 66694 -> 0 bytes .../__pycache__/egg_info.cpython-38.pyc | Bin 21773 -> 0 bytes .../__pycache__/install.cpython-38.pyc | Bin 4016 -> 0 bytes .../install_egg_info.cpython-38.pyc | Bin 2900 -> 0 bytes .../__pycache__/install_lib.cpython-38.pyc | Bin 5083 -> 0 bytes .../install_scripts.cpython-38.pyc | Bin 2273 -> 0 bytes .../__pycache__/py36compat.cpython-38.pyc | Bin 4610 -> 0 bytes .../__pycache__/register.cpython-38.pyc | Bin 811 -> 0 bytes .../command/__pycache__/rotate.cpython-38.pyc | Bin 2520 -> 0 bytes .../__pycache__/saveopts.cpython-38.pyc | Bin 889 -> 0 bytes .../command/__pycache__/sdist.cpython-38.pyc | Bin 7859 -> 0 bytes .../command/__pycache__/setopt.cpython-38.pyc | Bin 4537 -> 0 bytes .../command/__pycache__/test.cpython-38.pyc | Bin 8475 -> 0 bytes .../command/__pycache__/upload.cpython-38.pyc | Bin 784 -> 0 bytes .../__pycache__/upload_docs.cpython-38.pyc | Bin 6140 -> 0 bytes .../site-packages/setuptools/command/alias.py | 80 - .../setuptools/command/bdist_egg.py | 502 - .../setuptools/command/bdist_rpm.py | 43 - .../setuptools/command/bdist_wininst.py | 21 - .../setuptools/command/build_clib.py | 98 - .../setuptools/command/build_ext.py | 327 - .../setuptools/command/build_py.py | 270 - .../setuptools/command/develop.py | 221 - .../setuptools/command/dist_info.py | 36 - .../setuptools/command/easy_install.py | 2402 ----- .../setuptools/command/egg_info.py | 717 -- .../setuptools/command/install.py | 125 - .../setuptools/command/install_egg_info.py | 82 - .../setuptools/command/install_lib.py | 147 - .../setuptools/command/install_scripts.py | 65 - .../setuptools/command/launcher manifest.xml | 15 - .../setuptools/command/py36compat.py | 136 - .../setuptools/command/register.py | 18 - .../setuptools/command/rotate.py | 66 - .../setuptools/command/saveopts.py | 22 - .../site-packages/setuptools/command/sdist.py | 252 - .../setuptools/command/setopt.py | 149 - .../site-packages/setuptools/command/test.py | 279 - .../setuptools/command/upload.py | 17 - .../setuptools/command/upload_docs.py | 206 - .../site-packages/setuptools/config.py | 659 -- .../site-packages/setuptools/dep_util.py | 23 - .../site-packages/setuptools/depends.py | 176 - .../site-packages/setuptools/dist.py | 1274 --- .../site-packages/setuptools/errors.py | 16 - .../site-packages/setuptools/extension.py | 57 - .../setuptools/extern/__init__.py | 73 - .../__pycache__/__init__.cpython-38.pyc | Bin 2420 -> 0 bytes .../site-packages/setuptools/glob.py | 174 - .../site-packages/setuptools/gui-32.exe | Bin 65536 -> 0 bytes .../site-packages/setuptools/gui-64.exe | Bin 75264 -> 0 bytes .../site-packages/setuptools/gui.exe | Bin 65536 -> 0 bytes .../site-packages/setuptools/installer.py | 150 - .../site-packages/setuptools/launch.py | 35 - .../site-packages/setuptools/lib2to3_ex.py | 62 - .../site-packages/setuptools/monkey.py | 179 - .../site-packages/setuptools/msvc.py | 1679 ---- .../site-packages/setuptools/namespaces.py | 107 - .../site-packages/setuptools/package_index.py | 1136 --- .../site-packages/setuptools/py27compat.py | 60 - .../site-packages/setuptools/py31compat.py | 32 - .../site-packages/setuptools/py33compat.py | 59 - .../site-packages/setuptools/py34compat.py | 13 - .../site-packages/setuptools/sandbox.py | 491 - .../setuptools/script (dev).tmpl | 6 - .../site-packages/setuptools/script.tmpl | 3 - .../site-packages/setuptools/site-patch.py | 74 - .../site-packages/setuptools/ssl_support.py | 260 - .../site-packages/setuptools/unicode_utils.py | 44 - .../site-packages/setuptools/version.py | 6 - .../site-packages/setuptools/wheel.py | 220 - .../setuptools/windows_support.py | 29 - .../urllib3-1.26.6.dist-info/INSTALLER | 1 - .../urllib3-1.26.6.dist-info/LICENSE.txt | 21 - .../urllib3-1.26.6.dist-info/METADATA | 1388 --- .../urllib3-1.26.6.dist-info/RECORD | 84 - .../urllib3-1.26.6.dist-info/WHEEL | 6 - .../urllib3-1.26.6.dist-info/top_level.txt | 1 - .../site-packages/urllib3/__init__.py | 85 - .../__pycache__/__init__.cpython-38.pyc | Bin 2141 -> 0 bytes .../__pycache__/_collections.cpython-38.pyc | Bin 10654 -> 0 bytes .../__pycache__/_version.cpython-38.pyc | Bin 165 -> 0 bytes .../__pycache__/connection.cpython-38.pyc | Bin 13332 -> 0 bytes .../__pycache__/connectionpool.cpython-38.pyc | Bin 24404 -> 0 bytes .../__pycache__/exceptions.cpython-38.pyc | Bin 11598 -> 0 bytes .../urllib3/__pycache__/fields.cpython-38.pyc | Bin 8135 -> 0 bytes .../__pycache__/filepost.cpython-38.pyc | Bin 2722 -> 0 bytes .../__pycache__/poolmanager.cpython-38.pyc | Bin 15080 -> 0 bytes .../__pycache__/request.cpython-38.pyc | Bin 5578 -> 0 bytes .../__pycache__/response.cpython-38.pyc | Bin 20678 -> 0 bytes .../site-packages/urllib3/_collections.py | 337 - .../site-packages/urllib3/_version.py | 2 - .../site-packages/urllib3/connection.py | 539 -- .../site-packages/urllib3/connectionpool.py | 1067 --- .../site-packages/urllib3/contrib/__init__.py | 0 .../__pycache__/__init__.cpython-38.pyc | Bin 151 -> 0 bytes .../_appengine_environ.cpython-38.pyc | Bin 1375 -> 0 bytes .../__pycache__/appengine.cpython-38.pyc | Bin 8200 -> 0 bytes .../__pycache__/ntlmpool.cpython-38.pyc | Bin 3594 -> 0 bytes .../__pycache__/pyopenssl.cpython-38.pyc | Bin 15528 -> 0 bytes .../securetransport.cpython-38.pyc | Bin 21573 -> 0 bytes .../contrib/__pycache__/socks.cpython-38.pyc | Bin 5589 -> 0 bytes .../urllib3/contrib/_appengine_environ.py | 36 - .../contrib/_securetransport/__init__.py | 0 .../__pycache__/__init__.cpython-38.pyc | Bin 168 -> 0 bytes .../__pycache__/bindings.cpython-38.pyc | Bin 10689 -> 0 bytes .../__pycache__/low_level.cpython-38.pyc | Bin 9056 -> 0 bytes .../contrib/_securetransport/bindings.py | 519 - .../contrib/_securetransport/low_level.py | 396 - .../urllib3/contrib/appengine.py | 314 - .../site-packages/urllib3/contrib/ntlmpool.py | 130 - .../urllib3/contrib/pyopenssl.py | 511 - .../urllib3/contrib/securetransport.py | 922 -- .../site-packages/urllib3/contrib/socks.py | 216 - .../site-packages/urllib3/exceptions.py | 323 - .../python3.8/site-packages/urllib3/fields.py | 274 - .../site-packages/urllib3/filepost.py | 98 - .../urllib3/packages/__init__.py | 5 - .../__pycache__/__init__.cpython-38.pyc | Bin 265 -> 0 bytes .../packages/__pycache__/six.cpython-38.pyc | Bin 27547 -> 0 bytes .../urllib3/packages/backports/__init__.py | 0 .../__pycache__/__init__.cpython-38.pyc | Bin 162 -> 0 bytes .../__pycache__/makefile.cpython-38.pyc | Bin 1266 -> 0 bytes .../urllib3/packages/backports/makefile.py | 51 - .../site-packages/urllib3/packages/six.py | 1077 --- .../packages/ssl_match_hostname/__init__.py | 24 - .../__pycache__/__init__.cpython-38.pyc | Bin 528 -> 0 bytes .../_implementation.cpython-38.pyc | Bin 3263 -> 0 bytes .../ssl_match_hostname/_implementation.py | 160 - .../site-packages/urllib3/poolmanager.py | 536 -- .../site-packages/urllib3/request.py | 170 - .../site-packages/urllib3/response.py | 821 -- .../site-packages/urllib3/util/__init__.py | 49 - .../util/__pycache__/__init__.cpython-38.pyc | Bin 1061 -> 0 bytes .../__pycache__/connection.cpython-38.pyc | Bin 3407 -> 0 bytes .../util/__pycache__/proxy.cpython-38.pyc | Bin 1305 -> 0 bytes .../util/__pycache__/queue.cpython-38.pyc | Bin 1016 -> 0 bytes .../util/__pycache__/request.cpython-38.pyc | Bin 3410 -> 0 bytes .../util/__pycache__/response.cpython-38.pyc | Bin 2309 -> 0 bytes .../util/__pycache__/retry.cpython-38.pyc | Bin 15804 -> 0 bytes .../util/__pycache__/ssl_.cpython-38.pyc | Bin 11336 -> 0 bytes .../__pycache__/ssltransport.cpython-38.pyc | Bin 7406 -> 0 bytes .../util/__pycache__/timeout.cpython-38.pyc | Bin 8903 -> 0 bytes .../util/__pycache__/url.cpython-38.pyc | Bin 10706 -> 0 bytes .../util/__pycache__/wait.cpython-38.pyc | Bin 3063 -> 0 bytes .../site-packages/urllib3/util/connection.py | 150 - .../site-packages/urllib3/util/proxy.py | 56 - .../site-packages/urllib3/util/queue.py | 22 - .../site-packages/urllib3/util/request.py | 143 - .../site-packages/urllib3/util/response.py | 107 - .../site-packages/urllib3/util/retry.py | 602 -- .../site-packages/urllib3/util/ssl_.py | 495 - .../urllib3/util/ssltransport.py | 221 - .../site-packages/urllib3/util/timeout.py | 268 - .../site-packages/urllib3/util/url.py | 432 - .../site-packages/urllib3/util/wait.py | 153 - venv/lib64 | 1 - venv/pyvenv.cfg | 3 - .../CacheControl-0.12.6-py2.py3-none-any.whl | Bin 28023 -> 0 bytes .../appdirs-1.4.3-py2.py3-none-any.whl | Bin 18776 -> 0 bytes .../certifi-2019.11.28-py2.py3-none-any.whl | Bin 164552 -> 0 bytes .../chardet-3.0.4-py2.py3-none-any.whl | Bin 141487 -> 0 bytes .../colorama-0.4.3-py2.py3-none-any.whl | Bin 25094 -> 0 bytes .../contextlib2-0.6.0-py2.py3-none-any.whl | Bin 17188 -> 0 bytes .../distlib-0.3.0-py2.py3-none-any.whl | Bin 152027 -> 0 bytes .../distro-1.4.0-py2.py3-none-any.whl | Bin 23898 -> 0 bytes .../html5lib-1.0.1-py2.py3-none-any.whl | Bin 120020 -> 0 bytes .../idna-2.8-py2.py3-none-any.whl | Bin 66836 -> 0 bytes .../ipaddr-2.2.0-py2.py3-none-any.whl | Bin 24287 -> 0 bytes .../lockfile-0.12.2-py2.py3-none-any.whl | Bin 21972 -> 0 bytes .../msgpack-0.6.2-py2.py3-none-any.whl | Bin 92927 -> 0 bytes .../packaging-20.3-py2.py3-none-any.whl | Bin 42242 -> 0 bytes .../pep517-0.8.2-py2.py3-none-any.whl | Bin 26686 -> 0 bytes .../pip-20.0.2-py2.py3-none-any.whl | Bin 262434 -> 0 bytes .../pkg_resources-0.0.0-py2.py3-none-any.whl | Bin 127312 -> 0 bytes .../progress-1.5-py2.py3-none-any.whl | Bin 17547 -> 0 bytes .../pyparsing-2.4.6-py2.py3-none-any.whl | Bin 77093 -> 0 bytes .../requests-2.22.0-py2.py3-none-any.whl | Bin 67470 -> 0 bytes .../retrying-1.3.3-py2.py3-none-any.whl | Bin 16358 -> 0 bytes .../setuptools-44.0.0-py2.py3-none-any.whl | Bin 477446 -> 0 bytes .../six-1.14.0-py2.py3-none-any.whl | Bin 20256 -> 0 bytes .../toml-0.10.0-py2.py3-none-any.whl | Bin 24106 -> 0 bytes .../urllib3-1.25.8-py2.py3-none-any.whl | Bin 127041 -> 0 bytes .../webencodings-0.5.1-py2.py3-none-any.whl | Bin 20484 -> 0 bytes .../wheel-0.34.2-py2.py3-none-any.whl | Bin 35611 -> 0 bytes 677 files changed, 97677 deletions(-) delete mode 100644 venv/bin/Activate.ps1 delete mode 100644 venv/bin/activate delete mode 100644 venv/bin/activate.csh delete mode 100644 venv/bin/activate.fish delete mode 100755 venv/bin/easy_install delete mode 100755 venv/bin/easy_install-3.8 delete mode 100755 venv/bin/normalizer delete mode 100755 venv/bin/pip delete mode 100755 venv/bin/pip3 delete mode 100755 venv/bin/pip3.8 delete mode 120000 venv/bin/python delete mode 120000 venv/bin/python3 delete mode 100644 venv/lib/python3.8/site-packages/__pycache__/easy_install.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/certifi-2021.5.30.dist-info/INSTALLER delete mode 100644 venv/lib/python3.8/site-packages/certifi-2021.5.30.dist-info/LICENSE delete mode 100644 venv/lib/python3.8/site-packages/certifi-2021.5.30.dist-info/METADATA delete mode 100644 venv/lib/python3.8/site-packages/certifi-2021.5.30.dist-info/RECORD delete mode 100644 venv/lib/python3.8/site-packages/certifi-2021.5.30.dist-info/WHEEL delete mode 100644 venv/lib/python3.8/site-packages/certifi-2021.5.30.dist-info/top_level.txt delete mode 100644 venv/lib/python3.8/site-packages/certifi/__init__.py delete mode 100644 venv/lib/python3.8/site-packages/certifi/__main__.py delete mode 100644 venv/lib/python3.8/site-packages/certifi/__pycache__/__init__.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/certifi/__pycache__/__main__.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/certifi/__pycache__/core.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/certifi/cacert.pem delete mode 100644 venv/lib/python3.8/site-packages/certifi/core.py delete mode 100644 venv/lib/python3.8/site-packages/charset_normalizer-2.0.3.dist-info/INSTALLER delete mode 100644 venv/lib/python3.8/site-packages/charset_normalizer-2.0.3.dist-info/LICENSE delete mode 100644 venv/lib/python3.8/site-packages/charset_normalizer-2.0.3.dist-info/METADATA delete mode 100644 venv/lib/python3.8/site-packages/charset_normalizer-2.0.3.dist-info/RECORD delete mode 100644 venv/lib/python3.8/site-packages/charset_normalizer-2.0.3.dist-info/WHEEL delete mode 100644 venv/lib/python3.8/site-packages/charset_normalizer-2.0.3.dist-info/entry_points.txt delete mode 100644 venv/lib/python3.8/site-packages/charset_normalizer-2.0.3.dist-info/top_level.txt delete mode 100644 venv/lib/python3.8/site-packages/charset_normalizer/__init__.py delete mode 100644 venv/lib/python3.8/site-packages/charset_normalizer/__pycache__/__init__.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/charset_normalizer/__pycache__/api.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/charset_normalizer/__pycache__/cd.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/charset_normalizer/__pycache__/constant.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/charset_normalizer/__pycache__/legacy.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/charset_normalizer/__pycache__/md.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/charset_normalizer/__pycache__/models.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/charset_normalizer/__pycache__/utils.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/charset_normalizer/__pycache__/version.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/charset_normalizer/api.py delete mode 100644 venv/lib/python3.8/site-packages/charset_normalizer/assets/__init__.py delete mode 100644 venv/lib/python3.8/site-packages/charset_normalizer/assets/__pycache__/__init__.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/charset_normalizer/cd.py delete mode 100644 venv/lib/python3.8/site-packages/charset_normalizer/cli/__init__.py delete mode 100644 venv/lib/python3.8/site-packages/charset_normalizer/cli/__pycache__/__init__.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/charset_normalizer/cli/__pycache__/normalizer.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/charset_normalizer/cli/normalizer.py delete mode 100644 venv/lib/python3.8/site-packages/charset_normalizer/constant.py delete mode 100644 venv/lib/python3.8/site-packages/charset_normalizer/legacy.py delete mode 100644 venv/lib/python3.8/site-packages/charset_normalizer/md.py delete mode 100644 venv/lib/python3.8/site-packages/charset_normalizer/models.py delete mode 100644 venv/lib/python3.8/site-packages/charset_normalizer/py.typed delete mode 100644 venv/lib/python3.8/site-packages/charset_normalizer/utils.py delete mode 100644 venv/lib/python3.8/site-packages/charset_normalizer/version.py delete mode 100644 venv/lib/python3.8/site-packages/easy_install.py delete mode 100644 venv/lib/python3.8/site-packages/idna-3.2.dist-info/INSTALLER delete mode 100644 venv/lib/python3.8/site-packages/idna-3.2.dist-info/LICENSE.md delete mode 100644 venv/lib/python3.8/site-packages/idna-3.2.dist-info/METADATA delete mode 100644 venv/lib/python3.8/site-packages/idna-3.2.dist-info/RECORD delete mode 100644 venv/lib/python3.8/site-packages/idna-3.2.dist-info/WHEEL delete mode 100644 venv/lib/python3.8/site-packages/idna-3.2.dist-info/top_level.txt delete mode 100644 venv/lib/python3.8/site-packages/idna/__init__.py delete mode 100644 venv/lib/python3.8/site-packages/idna/__pycache__/__init__.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/idna/__pycache__/codec.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/idna/__pycache__/compat.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/idna/__pycache__/core.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/idna/__pycache__/idnadata.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/idna/__pycache__/intranges.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/idna/__pycache__/package_data.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/idna/__pycache__/uts46data.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/idna/codec.py delete mode 100644 venv/lib/python3.8/site-packages/idna/compat.py delete mode 100644 venv/lib/python3.8/site-packages/idna/core.py delete mode 100644 venv/lib/python3.8/site-packages/idna/idnadata.py delete mode 100644 venv/lib/python3.8/site-packages/idna/intranges.py delete mode 100644 venv/lib/python3.8/site-packages/idna/package_data.py delete mode 100644 venv/lib/python3.8/site-packages/idna/py.typed delete mode 100644 venv/lib/python3.8/site-packages/idna/uts46data.py delete mode 100644 venv/lib/python3.8/site-packages/pip-20.0.2.dist-info/INSTALLER delete mode 100644 venv/lib/python3.8/site-packages/pip-20.0.2.dist-info/LICENSE.txt delete mode 100644 venv/lib/python3.8/site-packages/pip-20.0.2.dist-info/METADATA delete mode 100644 venv/lib/python3.8/site-packages/pip-20.0.2.dist-info/RECORD delete mode 100644 venv/lib/python3.8/site-packages/pip-20.0.2.dist-info/WHEEL delete mode 100644 venv/lib/python3.8/site-packages/pip-20.0.2.dist-info/entry_points.txt delete mode 100644 venv/lib/python3.8/site-packages/pip-20.0.2.dist-info/top_level.txt delete mode 100644 venv/lib/python3.8/site-packages/pip/__init__.py delete mode 100644 venv/lib/python3.8/site-packages/pip/__main__.py delete mode 100644 venv/lib/python3.8/site-packages/pip/__pycache__/__init__.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/__pycache__/__main__.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/__init__.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/__pycache__/__init__.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/__pycache__/build_env.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/__pycache__/cache.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/__pycache__/configuration.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/__pycache__/exceptions.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/__pycache__/legacy_resolve.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/__pycache__/locations.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/__pycache__/main.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/__pycache__/pep425tags.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/__pycache__/pyproject.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/__pycache__/self_outdated_check.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/__pycache__/wheel_builder.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/build_env.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/cache.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/cli/__init__.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/cli/__pycache__/__init__.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/cli/__pycache__/autocompletion.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/cli/__pycache__/base_command.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/cli/__pycache__/cmdoptions.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/cli/__pycache__/command_context.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/cli/__pycache__/main.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/cli/__pycache__/main_parser.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/cli/__pycache__/parser.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/cli/__pycache__/req_command.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/cli/__pycache__/status_codes.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/cli/autocompletion.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/cli/base_command.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/cli/cmdoptions.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/cli/command_context.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/cli/main.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/cli/main_parser.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/cli/parser.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/cli/req_command.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/cli/status_codes.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/commands/__init__.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/__init__.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/check.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/completion.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/configuration.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/debug.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/download.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/freeze.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/hash.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/help.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/install.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/list.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/search.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/show.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/uninstall.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/wheel.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/commands/check.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/commands/completion.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/commands/configuration.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/commands/debug.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/commands/download.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/commands/freeze.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/commands/hash.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/commands/help.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/commands/install.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/commands/list.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/commands/search.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/commands/show.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/commands/uninstall.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/commands/wheel.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/configuration.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/distributions/__init__.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/distributions/__pycache__/__init__.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/distributions/__pycache__/base.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/distributions/__pycache__/installed.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/distributions/__pycache__/sdist.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/distributions/__pycache__/wheel.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/distributions/base.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/distributions/installed.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/distributions/sdist.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/distributions/wheel.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/exceptions.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/index/__init__.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/index/__pycache__/__init__.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/index/__pycache__/collector.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/index/__pycache__/package_finder.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/index/collector.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/index/package_finder.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/legacy_resolve.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/locations.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/main.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/models/__init__.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/models/__pycache__/__init__.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/models/__pycache__/candidate.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/models/__pycache__/format_control.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/models/__pycache__/index.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/models/__pycache__/link.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/models/__pycache__/scheme.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/models/__pycache__/search_scope.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/models/__pycache__/selection_prefs.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/models/__pycache__/target_python.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/models/__pycache__/wheel.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/models/candidate.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/models/format_control.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/models/index.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/models/link.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/models/scheme.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/models/search_scope.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/models/selection_prefs.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/models/target_python.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/models/wheel.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/network/__init__.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/network/__pycache__/__init__.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/network/__pycache__/auth.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/network/__pycache__/cache.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/network/__pycache__/download.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/network/__pycache__/session.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/network/__pycache__/utils.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/network/__pycache__/xmlrpc.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/network/auth.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/network/cache.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/network/download.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/network/session.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/network/utils.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/network/xmlrpc.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/operations/__init__.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/operations/__pycache__/__init__.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/operations/__pycache__/check.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/operations/__pycache__/freeze.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/operations/__pycache__/prepare.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/operations/build/__init__.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/operations/build/__pycache__/__init__.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/operations/build/__pycache__/metadata.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/operations/build/__pycache__/metadata_legacy.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/operations/build/__pycache__/wheel.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/operations/build/__pycache__/wheel_legacy.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/operations/build/metadata.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/operations/build/metadata_legacy.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/operations/build/wheel.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/operations/build/wheel_legacy.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/operations/check.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/operations/freeze.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/operations/install/__init__.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/operations/install/__pycache__/__init__.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/operations/install/__pycache__/editable_legacy.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/operations/install/__pycache__/legacy.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/operations/install/__pycache__/wheel.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/operations/install/editable_legacy.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/operations/install/legacy.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/operations/install/wheel.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/operations/prepare.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/pep425tags.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/pyproject.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/req/__init__.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/req/__pycache__/__init__.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/req/__pycache__/constructors.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/req/__pycache__/req_file.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/req/__pycache__/req_install.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/req/__pycache__/req_set.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/req/__pycache__/req_tracker.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/req/__pycache__/req_uninstall.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/req/constructors.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/req/req_file.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/req/req_install.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/req/req_set.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/req/req_tracker.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/req/req_uninstall.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/self_outdated_check.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/__init__.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/__init__.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/appdirs.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/compat.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/deprecation.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/distutils_args.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/encoding.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/entrypoints.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/filesystem.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/filetypes.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/glibc.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/hashes.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/inject_securetransport.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/logging.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/marker_files.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/misc.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/models.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/packaging.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/pkg_resources.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/setuptools_build.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/subprocess.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/temp_dir.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/typing.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/ui.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/unpacking.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/urls.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/virtualenv.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/wheel.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/appdirs.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/compat.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/deprecation.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/distutils_args.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/encoding.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/entrypoints.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/filesystem.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/filetypes.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/glibc.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/hashes.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/inject_securetransport.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/logging.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/marker_files.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/misc.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/models.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/packaging.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/pkg_resources.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/setuptools_build.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/subprocess.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/temp_dir.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/typing.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/ui.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/unpacking.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/urls.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/virtualenv.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/utils/wheel.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/vcs/__init__.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/vcs/__pycache__/__init__.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/vcs/__pycache__/bazaar.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/vcs/__pycache__/git.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/vcs/__pycache__/mercurial.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/vcs/__pycache__/subversion.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/vcs/__pycache__/versioncontrol.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/vcs/bazaar.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/vcs/git.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/vcs/mercurial.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/vcs/subversion.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/vcs/versioncontrol.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_internal/wheel_builder.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_vendor/__init__.py delete mode 100644 venv/lib/python3.8/site-packages/pip/_vendor/__pycache__/__init__.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pkg_resources-0.0.0.dist-info/AUTHORS.txt delete mode 100644 venv/lib/python3.8/site-packages/pkg_resources-0.0.0.dist-info/INSTALLER delete mode 100644 venv/lib/python3.8/site-packages/pkg_resources-0.0.0.dist-info/LICENSE.txt delete mode 100644 venv/lib/python3.8/site-packages/pkg_resources-0.0.0.dist-info/METADATA delete mode 100644 venv/lib/python3.8/site-packages/pkg_resources-0.0.0.dist-info/RECORD delete mode 100644 venv/lib/python3.8/site-packages/pkg_resources-0.0.0.dist-info/WHEEL delete mode 100644 venv/lib/python3.8/site-packages/pkg_resources/__init__.py delete mode 100644 venv/lib/python3.8/site-packages/pkg_resources/__pycache__/__init__.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pkg_resources/__pycache__/py31compat.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pkg_resources/_vendor/__init__.py delete mode 100644 venv/lib/python3.8/site-packages/pkg_resources/_vendor/__pycache__/__init__.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pkg_resources/_vendor/__pycache__/appdirs.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pkg_resources/_vendor/__pycache__/pyparsing.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pkg_resources/_vendor/__pycache__/six.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pkg_resources/_vendor/appdirs.py delete mode 100644 venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__about__.py delete mode 100644 venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__init__.py delete mode 100644 venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/__about__.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/__init__.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/_compat.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/_structures.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/markers.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/requirements.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/specifiers.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/utils.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/version.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/_compat.py delete mode 100644 venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/_structures.py delete mode 100644 venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/markers.py delete mode 100644 venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/requirements.py delete mode 100644 venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/specifiers.py delete mode 100644 venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/utils.py delete mode 100644 venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/version.py delete mode 100644 venv/lib/python3.8/site-packages/pkg_resources/_vendor/pyparsing.py delete mode 100644 venv/lib/python3.8/site-packages/pkg_resources/_vendor/six.py delete mode 100644 venv/lib/python3.8/site-packages/pkg_resources/extern/__init__.py delete mode 100644 venv/lib/python3.8/site-packages/pkg_resources/extern/__pycache__/__init__.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/pkg_resources/py31compat.py delete mode 100644 venv/lib/python3.8/site-packages/requests-2.26.0.dist-info/INSTALLER delete mode 100644 venv/lib/python3.8/site-packages/requests-2.26.0.dist-info/LICENSE delete mode 100644 venv/lib/python3.8/site-packages/requests-2.26.0.dist-info/METADATA delete mode 100644 venv/lib/python3.8/site-packages/requests-2.26.0.dist-info/RECORD delete mode 100644 venv/lib/python3.8/site-packages/requests-2.26.0.dist-info/WHEEL delete mode 100644 venv/lib/python3.8/site-packages/requests-2.26.0.dist-info/top_level.txt delete mode 100644 venv/lib/python3.8/site-packages/requests/__init__.py delete mode 100644 venv/lib/python3.8/site-packages/requests/__pycache__/__init__.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/requests/__pycache__/__version__.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/requests/__pycache__/_internal_utils.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/requests/__pycache__/adapters.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/requests/__pycache__/api.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/requests/__pycache__/auth.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/requests/__pycache__/certs.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/requests/__pycache__/compat.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/requests/__pycache__/cookies.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/requests/__pycache__/exceptions.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/requests/__pycache__/help.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/requests/__pycache__/hooks.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/requests/__pycache__/models.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/requests/__pycache__/packages.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/requests/__pycache__/sessions.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/requests/__pycache__/status_codes.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/requests/__pycache__/structures.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/requests/__pycache__/utils.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/requests/__version__.py delete mode 100644 venv/lib/python3.8/site-packages/requests/_internal_utils.py delete mode 100644 venv/lib/python3.8/site-packages/requests/adapters.py delete mode 100644 venv/lib/python3.8/site-packages/requests/api.py delete mode 100644 venv/lib/python3.8/site-packages/requests/auth.py delete mode 100644 venv/lib/python3.8/site-packages/requests/certs.py delete mode 100644 venv/lib/python3.8/site-packages/requests/compat.py delete mode 100644 venv/lib/python3.8/site-packages/requests/cookies.py delete mode 100644 venv/lib/python3.8/site-packages/requests/exceptions.py delete mode 100644 venv/lib/python3.8/site-packages/requests/help.py delete mode 100644 venv/lib/python3.8/site-packages/requests/hooks.py delete mode 100644 venv/lib/python3.8/site-packages/requests/models.py delete mode 100644 venv/lib/python3.8/site-packages/requests/packages.py delete mode 100644 venv/lib/python3.8/site-packages/requests/sessions.py delete mode 100644 venv/lib/python3.8/site-packages/requests/status_codes.py delete mode 100644 venv/lib/python3.8/site-packages/requests/structures.py delete mode 100644 venv/lib/python3.8/site-packages/requests/utils.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/AUTHORS.txt delete mode 100644 venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/INSTALLER delete mode 100644 venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/LICENSE.txt delete mode 100644 venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/METADATA delete mode 100644 venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/RECORD delete mode 100644 venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/WHEEL delete mode 100644 venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/dependency_links.txt delete mode 100644 venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/entry_points.txt delete mode 100644 venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/top_level.txt delete mode 100644 venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/zip-safe delete mode 100644 venv/lib/python3.8/site-packages/setuptools/__init__.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/__pycache__/__init__.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/__pycache__/_deprecation_warning.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/__pycache__/_imp.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/__pycache__/archive_util.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/__pycache__/build_meta.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/__pycache__/config.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/__pycache__/dep_util.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/__pycache__/depends.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/__pycache__/dist.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/__pycache__/errors.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/__pycache__/extension.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/__pycache__/glob.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/__pycache__/installer.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/__pycache__/launch.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/__pycache__/lib2to3_ex.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/__pycache__/monkey.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/__pycache__/msvc.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/__pycache__/namespaces.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/__pycache__/package_index.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/__pycache__/py27compat.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/__pycache__/py31compat.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/__pycache__/py33compat.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/__pycache__/py34compat.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/__pycache__/sandbox.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/__pycache__/site-patch.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/__pycache__/ssl_support.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/__pycache__/unicode_utils.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/__pycache__/version.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/__pycache__/wheel.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/__pycache__/windows_support.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/_deprecation_warning.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/_imp.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/_vendor/__init__.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/_vendor/__pycache__/__init__.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/_vendor/__pycache__/ordered_set.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/_vendor/__pycache__/pyparsing.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/_vendor/__pycache__/six.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/_vendor/ordered_set.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__about__.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__init__.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/__about__.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/__init__.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/_compat.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/_structures.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/markers.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/requirements.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/specifiers.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/tags.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/utils.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/version.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/_compat.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/_structures.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/markers.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/requirements.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/specifiers.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/tags.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/utils.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/version.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/_vendor/pyparsing.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/_vendor/six.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/archive_util.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/build_meta.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/cli-32.exe delete mode 100644 venv/lib/python3.8/site-packages/setuptools/cli-64.exe delete mode 100644 venv/lib/python3.8/site-packages/setuptools/cli.exe delete mode 100644 venv/lib/python3.8/site-packages/setuptools/command/__init__.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/command/__pycache__/__init__.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/command/__pycache__/alias.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/command/__pycache__/bdist_egg.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/command/__pycache__/bdist_rpm.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/command/__pycache__/bdist_wininst.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/command/__pycache__/build_clib.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/command/__pycache__/build_ext.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/command/__pycache__/build_py.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/command/__pycache__/develop.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/command/__pycache__/dist_info.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/command/__pycache__/easy_install.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/command/__pycache__/egg_info.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/command/__pycache__/install.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/command/__pycache__/install_egg_info.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/command/__pycache__/install_lib.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/command/__pycache__/install_scripts.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/command/__pycache__/py36compat.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/command/__pycache__/register.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/command/__pycache__/rotate.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/command/__pycache__/saveopts.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/command/__pycache__/sdist.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/command/__pycache__/setopt.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/command/__pycache__/test.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/command/__pycache__/upload.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/command/__pycache__/upload_docs.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/command/alias.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/command/bdist_egg.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/command/bdist_rpm.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/command/bdist_wininst.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/command/build_clib.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/command/build_ext.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/command/build_py.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/command/develop.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/command/dist_info.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/command/easy_install.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/command/egg_info.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/command/install.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/command/install_egg_info.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/command/install_lib.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/command/install_scripts.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/command/launcher manifest.xml delete mode 100644 venv/lib/python3.8/site-packages/setuptools/command/py36compat.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/command/register.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/command/rotate.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/command/saveopts.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/command/sdist.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/command/setopt.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/command/test.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/command/upload.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/command/upload_docs.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/config.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/dep_util.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/depends.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/dist.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/errors.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/extension.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/extern/__init__.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/extern/__pycache__/__init__.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/setuptools/glob.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/gui-32.exe delete mode 100644 venv/lib/python3.8/site-packages/setuptools/gui-64.exe delete mode 100644 venv/lib/python3.8/site-packages/setuptools/gui.exe delete mode 100644 venv/lib/python3.8/site-packages/setuptools/installer.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/launch.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/lib2to3_ex.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/monkey.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/msvc.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/namespaces.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/package_index.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/py27compat.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/py31compat.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/py33compat.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/py34compat.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/sandbox.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/script (dev).tmpl delete mode 100644 venv/lib/python3.8/site-packages/setuptools/script.tmpl delete mode 100644 venv/lib/python3.8/site-packages/setuptools/site-patch.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/ssl_support.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/unicode_utils.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/version.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/wheel.py delete mode 100644 venv/lib/python3.8/site-packages/setuptools/windows_support.py delete mode 100644 venv/lib/python3.8/site-packages/urllib3-1.26.6.dist-info/INSTALLER delete mode 100644 venv/lib/python3.8/site-packages/urllib3-1.26.6.dist-info/LICENSE.txt delete mode 100644 venv/lib/python3.8/site-packages/urllib3-1.26.6.dist-info/METADATA delete mode 100644 venv/lib/python3.8/site-packages/urllib3-1.26.6.dist-info/RECORD delete mode 100644 venv/lib/python3.8/site-packages/urllib3-1.26.6.dist-info/WHEEL delete mode 100644 venv/lib/python3.8/site-packages/urllib3-1.26.6.dist-info/top_level.txt delete mode 100644 venv/lib/python3.8/site-packages/urllib3/__init__.py delete mode 100644 venv/lib/python3.8/site-packages/urllib3/__pycache__/__init__.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/urllib3/__pycache__/_collections.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/urllib3/__pycache__/_version.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/urllib3/__pycache__/connection.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/urllib3/__pycache__/connectionpool.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/urllib3/__pycache__/exceptions.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/urllib3/__pycache__/fields.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/urllib3/__pycache__/filepost.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/urllib3/__pycache__/poolmanager.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/urllib3/__pycache__/request.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/urllib3/__pycache__/response.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/urllib3/_collections.py delete mode 100644 venv/lib/python3.8/site-packages/urllib3/_version.py delete mode 100644 venv/lib/python3.8/site-packages/urllib3/connection.py delete mode 100644 venv/lib/python3.8/site-packages/urllib3/connectionpool.py delete mode 100644 venv/lib/python3.8/site-packages/urllib3/contrib/__init__.py delete mode 100644 venv/lib/python3.8/site-packages/urllib3/contrib/__pycache__/__init__.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/urllib3/contrib/__pycache__/_appengine_environ.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/urllib3/contrib/__pycache__/appengine.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/urllib3/contrib/__pycache__/ntlmpool.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/urllib3/contrib/__pycache__/pyopenssl.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/urllib3/contrib/__pycache__/securetransport.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/urllib3/contrib/__pycache__/socks.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/urllib3/contrib/_appengine_environ.py delete mode 100644 venv/lib/python3.8/site-packages/urllib3/contrib/_securetransport/__init__.py delete mode 100644 venv/lib/python3.8/site-packages/urllib3/contrib/_securetransport/__pycache__/__init__.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/urllib3/contrib/_securetransport/__pycache__/bindings.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/urllib3/contrib/_securetransport/__pycache__/low_level.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/urllib3/contrib/_securetransport/bindings.py delete mode 100644 venv/lib/python3.8/site-packages/urllib3/contrib/_securetransport/low_level.py delete mode 100644 venv/lib/python3.8/site-packages/urllib3/contrib/appengine.py delete mode 100644 venv/lib/python3.8/site-packages/urllib3/contrib/ntlmpool.py delete mode 100644 venv/lib/python3.8/site-packages/urllib3/contrib/pyopenssl.py delete mode 100644 venv/lib/python3.8/site-packages/urllib3/contrib/securetransport.py delete mode 100644 venv/lib/python3.8/site-packages/urllib3/contrib/socks.py delete mode 100644 venv/lib/python3.8/site-packages/urllib3/exceptions.py delete mode 100644 venv/lib/python3.8/site-packages/urllib3/fields.py delete mode 100644 venv/lib/python3.8/site-packages/urllib3/filepost.py delete mode 100644 venv/lib/python3.8/site-packages/urllib3/packages/__init__.py delete mode 100644 venv/lib/python3.8/site-packages/urllib3/packages/__pycache__/__init__.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/urllib3/packages/__pycache__/six.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/urllib3/packages/backports/__init__.py delete mode 100644 venv/lib/python3.8/site-packages/urllib3/packages/backports/__pycache__/__init__.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/urllib3/packages/backports/__pycache__/makefile.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/urllib3/packages/backports/makefile.py delete mode 100644 venv/lib/python3.8/site-packages/urllib3/packages/six.py delete mode 100644 venv/lib/python3.8/site-packages/urllib3/packages/ssl_match_hostname/__init__.py delete mode 100644 venv/lib/python3.8/site-packages/urllib3/packages/ssl_match_hostname/__pycache__/__init__.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/urllib3/packages/ssl_match_hostname/__pycache__/_implementation.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/urllib3/packages/ssl_match_hostname/_implementation.py delete mode 100644 venv/lib/python3.8/site-packages/urllib3/poolmanager.py delete mode 100644 venv/lib/python3.8/site-packages/urllib3/request.py delete mode 100644 venv/lib/python3.8/site-packages/urllib3/response.py delete mode 100644 venv/lib/python3.8/site-packages/urllib3/util/__init__.py delete mode 100644 venv/lib/python3.8/site-packages/urllib3/util/__pycache__/__init__.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/urllib3/util/__pycache__/connection.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/urllib3/util/__pycache__/proxy.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/urllib3/util/__pycache__/queue.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/urllib3/util/__pycache__/request.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/urllib3/util/__pycache__/response.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/urllib3/util/__pycache__/retry.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/urllib3/util/__pycache__/ssl_.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/urllib3/util/__pycache__/ssltransport.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/urllib3/util/__pycache__/timeout.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/urllib3/util/__pycache__/url.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/urllib3/util/__pycache__/wait.cpython-38.pyc delete mode 100644 venv/lib/python3.8/site-packages/urllib3/util/connection.py delete mode 100644 venv/lib/python3.8/site-packages/urllib3/util/proxy.py delete mode 100644 venv/lib/python3.8/site-packages/urllib3/util/queue.py delete mode 100644 venv/lib/python3.8/site-packages/urllib3/util/request.py delete mode 100644 venv/lib/python3.8/site-packages/urllib3/util/response.py delete mode 100644 venv/lib/python3.8/site-packages/urllib3/util/retry.py delete mode 100644 venv/lib/python3.8/site-packages/urllib3/util/ssl_.py delete mode 100644 venv/lib/python3.8/site-packages/urllib3/util/ssltransport.py delete mode 100644 venv/lib/python3.8/site-packages/urllib3/util/timeout.py delete mode 100644 venv/lib/python3.8/site-packages/urllib3/util/url.py delete mode 100644 venv/lib/python3.8/site-packages/urllib3/util/wait.py delete mode 120000 venv/lib64 delete mode 100644 venv/pyvenv.cfg delete mode 100644 venv/share/python-wheels/CacheControl-0.12.6-py2.py3-none-any.whl delete mode 100644 venv/share/python-wheels/appdirs-1.4.3-py2.py3-none-any.whl delete mode 100644 venv/share/python-wheels/certifi-2019.11.28-py2.py3-none-any.whl delete mode 100644 venv/share/python-wheels/chardet-3.0.4-py2.py3-none-any.whl delete mode 100644 venv/share/python-wheels/colorama-0.4.3-py2.py3-none-any.whl delete mode 100644 venv/share/python-wheels/contextlib2-0.6.0-py2.py3-none-any.whl delete mode 100644 venv/share/python-wheels/distlib-0.3.0-py2.py3-none-any.whl delete mode 100644 venv/share/python-wheels/distro-1.4.0-py2.py3-none-any.whl delete mode 100644 venv/share/python-wheels/html5lib-1.0.1-py2.py3-none-any.whl delete mode 100644 venv/share/python-wheels/idna-2.8-py2.py3-none-any.whl delete mode 100644 venv/share/python-wheels/ipaddr-2.2.0-py2.py3-none-any.whl delete mode 100644 venv/share/python-wheels/lockfile-0.12.2-py2.py3-none-any.whl delete mode 100644 venv/share/python-wheels/msgpack-0.6.2-py2.py3-none-any.whl delete mode 100644 venv/share/python-wheels/packaging-20.3-py2.py3-none-any.whl delete mode 100644 venv/share/python-wheels/pep517-0.8.2-py2.py3-none-any.whl delete mode 100644 venv/share/python-wheels/pip-20.0.2-py2.py3-none-any.whl delete mode 100644 venv/share/python-wheels/pkg_resources-0.0.0-py2.py3-none-any.whl delete mode 100644 venv/share/python-wheels/progress-1.5-py2.py3-none-any.whl delete mode 100644 venv/share/python-wheels/pyparsing-2.4.6-py2.py3-none-any.whl delete mode 100644 venv/share/python-wheels/requests-2.22.0-py2.py3-none-any.whl delete mode 100644 venv/share/python-wheels/retrying-1.3.3-py2.py3-none-any.whl delete mode 100644 venv/share/python-wheels/setuptools-44.0.0-py2.py3-none-any.whl delete mode 100644 venv/share/python-wheels/six-1.14.0-py2.py3-none-any.whl delete mode 100644 venv/share/python-wheels/toml-0.10.0-py2.py3-none-any.whl delete mode 100644 venv/share/python-wheels/urllib3-1.25.8-py2.py3-none-any.whl delete mode 100644 venv/share/python-wheels/webencodings-0.5.1-py2.py3-none-any.whl delete mode 100644 venv/share/python-wheels/wheel-0.34.2-py2.py3-none-any.whl diff --git a/venv/bin/Activate.ps1 b/venv/bin/Activate.ps1 deleted file mode 100644 index 2fb3852..0000000 --- a/venv/bin/Activate.ps1 +++ /dev/null @@ -1,241 +0,0 @@ -<# -.Synopsis -Activate a Python virtual environment for the current PowerShell session. - -.Description -Pushes the python executable for a virtual environment to the front of the -$Env:PATH environment variable and sets the prompt to signify that you are -in a Python virtual environment. Makes use of the command line switches as -well as the `pyvenv.cfg` file values present in the virtual environment. - -.Parameter VenvDir -Path to the directory that contains the virtual environment to activate. The -default value for this is the parent of the directory that the Activate.ps1 -script is located within. - -.Parameter Prompt -The prompt prefix to display when this virtual environment is activated. By -default, this prompt is the name of the virtual environment folder (VenvDir) -surrounded by parentheses and followed by a single space (ie. '(.venv) '). - -.Example -Activate.ps1 -Activates the Python virtual environment that contains the Activate.ps1 script. - -.Example -Activate.ps1 -Verbose -Activates the Python virtual environment that contains the Activate.ps1 script, -and shows extra information about the activation as it executes. - -.Example -Activate.ps1 -VenvDir C:\Users\MyUser\Common\.venv -Activates the Python virtual environment located in the specified location. - -.Example -Activate.ps1 -Prompt "MyPython" -Activates the Python virtual environment that contains the Activate.ps1 script, -and prefixes the current prompt with the specified string (surrounded in -parentheses) while the virtual environment is active. - -.Notes -On Windows, it may be required to enable this Activate.ps1 script by setting the -execution policy for the user. You can do this by issuing the following PowerShell -command: - -PS C:\> Set-ExecutionPolicy -ExecutionPolicy RemoteSigned -Scope CurrentUser - -For more information on Execution Policies: -https://go.microsoft.com/fwlink/?LinkID=135170 - -#> -Param( - [Parameter(Mandatory = $false)] - [String] - $VenvDir, - [Parameter(Mandatory = $false)] - [String] - $Prompt -) - -<# Function declarations --------------------------------------------------- #> - -<# -.Synopsis -Remove all shell session elements added by the Activate script, including the -addition of the virtual environment's Python executable from the beginning of -the PATH variable. - -.Parameter NonDestructive -If present, do not remove this function from the global namespace for the -session. - -#> -function global:deactivate ([switch]$NonDestructive) { - # Revert to original values - - # The prior prompt: - if (Test-Path -Path Function:_OLD_VIRTUAL_PROMPT) { - Copy-Item -Path Function:_OLD_VIRTUAL_PROMPT -Destination Function:prompt - Remove-Item -Path Function:_OLD_VIRTUAL_PROMPT - } - - # The prior PYTHONHOME: - if (Test-Path -Path Env:_OLD_VIRTUAL_PYTHONHOME) { - Copy-Item -Path Env:_OLD_VIRTUAL_PYTHONHOME -Destination Env:PYTHONHOME - Remove-Item -Path Env:_OLD_VIRTUAL_PYTHONHOME - } - - # The prior PATH: - if (Test-Path -Path Env:_OLD_VIRTUAL_PATH) { - Copy-Item -Path Env:_OLD_VIRTUAL_PATH -Destination Env:PATH - Remove-Item -Path Env:_OLD_VIRTUAL_PATH - } - - # Just remove the VIRTUAL_ENV altogether: - if (Test-Path -Path Env:VIRTUAL_ENV) { - Remove-Item -Path env:VIRTUAL_ENV - } - - # 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 - } - - # Leave deactivate function in the global namespace if requested: - if (-not $NonDestructive) { - Remove-Item -Path function:deactivate - } -} - -<# -.Description -Get-PyVenvConfig parses the values from the pyvenv.cfg file located in the -given folder, and returns them in a map. - -For each line in the pyvenv.cfg file, if that line can be parsed into exactly -two strings separated by `=` (with any amount of whitespace surrounding the =) -then it is considered a `key = value` line. The left hand string is the key, -the right hand is the value. - -If the value starts with a `'` or a `"` then the first and last character is -stripped from the value before being captured. - -.Parameter ConfigDir -Path to the directory that contains the `pyvenv.cfg` file. -#> -function Get-PyVenvConfig( - [String] - $ConfigDir -) { - Write-Verbose "Given ConfigDir=$ConfigDir, obtain values in pyvenv.cfg" - - # Ensure the file exists, and issue a warning if it doesn't (but still allow the function to continue). - $pyvenvConfigPath = Join-Path -Resolve -Path $ConfigDir -ChildPath 'pyvenv.cfg' -ErrorAction Continue - - # An empty map will be returned if no config file is found. - $pyvenvConfig = @{ } - - if ($pyvenvConfigPath) { - - Write-Verbose "File exists, parse `key = value` lines" - $pyvenvConfigContent = Get-Content -Path $pyvenvConfigPath - - $pyvenvConfigContent | ForEach-Object { - $keyval = $PSItem -split "\s*=\s*", 2 - if ($keyval[0] -and $keyval[1]) { - $val = $keyval[1] - - # Remove extraneous quotations around a string value. - if ("'""".Contains($val.Substring(0, 1))) { - $val = $val.Substring(1, $val.Length - 2) - } - - $pyvenvConfig[$keyval[0]] = $val - Write-Verbose "Adding Key: '$($keyval[0])'='$val'" - } - } - } - return $pyvenvConfig -} - - -<# Begin Activate script --------------------------------------------------- #> - -# Determine the containing directory of this script -$VenvExecPath = Split-Path -Parent $MyInvocation.MyCommand.Definition -$VenvExecDir = Get-Item -Path $VenvExecPath - -Write-Verbose "Activation script is located in path: '$VenvExecPath'" -Write-Verbose "VenvExecDir Fullname: '$($VenvExecDir.FullName)" -Write-Verbose "VenvExecDir Name: '$($VenvExecDir.Name)" - -# Set values required in priority: CmdLine, ConfigFile, Default -# First, get the location of the virtual environment, it might not be -# VenvExecDir if specified on the command line. -if ($VenvDir) { - Write-Verbose "VenvDir given as parameter, using '$VenvDir' to determine values" -} -else { - Write-Verbose "VenvDir not given as a parameter, using parent directory name as VenvDir." - $VenvDir = $VenvExecDir.Parent.FullName.TrimEnd("\\/") - Write-Verbose "VenvDir=$VenvDir" -} - -# Next, read the `pyvenv.cfg` file to determine any required value such -# as `prompt`. -$pyvenvCfg = Get-PyVenvConfig -ConfigDir $VenvDir - -# Next, set the prompt from the command line, or the config file, or -# just use the name of the virtual environment folder. -if ($Prompt) { - Write-Verbose "Prompt specified as argument, using '$Prompt'" -} -else { - Write-Verbose "Prompt not specified as argument to script, checking pyvenv.cfg value" - if ($pyvenvCfg -and $pyvenvCfg['prompt']) { - Write-Verbose " Setting based on value in pyvenv.cfg='$($pyvenvCfg['prompt'])'" - $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 " Got leaf-name of $VenvDir='$(Split-Path -Path $venvDir -Leaf)'" - $Prompt = Split-Path -Path $venvDir -Leaf - } -} - -Write-Verbose "Prompt = '$Prompt'" -Write-Verbose "VenvDir='$VenvDir'" - -# Deactivate any currently active virtual environment, but leave the -# deactivate function in place. -deactivate -nondestructive - -# Now set the environment variable VIRTUAL_ENV, used by many tools to determine -# that there is an activated venv. -$env:VIRTUAL_ENV = $VenvDir - -if (-not $Env:VIRTUAL_ENV_DISABLE_PROMPT) { - - Write-Verbose "Setting prompt to '$Prompt'" - - # Set the prompt to include the env name - # Make sure _OLD_VIRTUAL_PROMPT is global - function global:_OLD_VIRTUAL_PROMPT { "" } - Copy-Item -Path function:prompt -Destination function:_OLD_VIRTUAL_PROMPT - New-Variable -Name _PYTHON_VENV_PROMPT_PREFIX -Description "Python virtual environment prompt prefix" -Scope Global -Option ReadOnly -Visibility Public -Value $Prompt - - function global:prompt { - Write-Host -NoNewline -ForegroundColor Green "($_PYTHON_VENV_PROMPT_PREFIX) " - _OLD_VIRTUAL_PROMPT - } -} - -# Clear PYTHONHOME -if (Test-Path -Path Env:PYTHONHOME) { - Copy-Item -Path Env:PYTHONHOME -Destination Env:_OLD_VIRTUAL_PYTHONHOME - Remove-Item -Path Env:PYTHONHOME -} - -# Add the venv to the PATH -Copy-Item -Path Env:PATH -Destination Env:_OLD_VIRTUAL_PATH -$Env:PATH = "$VenvExecDir$([System.IO.Path]::PathSeparator)$Env:PATH" diff --git a/venv/bin/activate b/venv/bin/activate deleted file mode 100644 index c161d2a..0000000 --- a/venv/bin/activate +++ /dev/null @@ -1,76 +0,0 @@ -# This file must be used with "source bin/activate" *from bash* -# you cannot run it directly - -deactivate () { - # reset old environment variables - if [ -n "${_OLD_VIRTUAL_PATH:-}" ] ; then - PATH="${_OLD_VIRTUAL_PATH:-}" - export PATH - unset _OLD_VIRTUAL_PATH - fi - if [ -n "${_OLD_VIRTUAL_PYTHONHOME:-}" ] ; then - PYTHONHOME="${_OLD_VIRTUAL_PYTHONHOME:-}" - export PYTHONHOME - unset _OLD_VIRTUAL_PYTHONHOME - fi - - # This should detect bash and zsh, which have a hash command that must - # be called to get it to forget past commands. Without forgetting - # past commands the $PATH changes we made may not be respected - if [ -n "${BASH:-}" -o -n "${ZSH_VERSION:-}" ] ; then - hash -r - fi - - if [ -n "${_OLD_VIRTUAL_PS1:-}" ] ; then - PS1="${_OLD_VIRTUAL_PS1:-}" - export PS1 - unset _OLD_VIRTUAL_PS1 - fi - - unset VIRTUAL_ENV - if [ ! "${1:-}" = "nondestructive" ] ; then - # Self destruct! - unset -f deactivate - fi -} - -# unset irrelevant variables -deactivate nondestructive - -VIRTUAL_ENV="/home/angel/Documents/workspace/telebot/venv" -export VIRTUAL_ENV - -_OLD_VIRTUAL_PATH="$PATH" -PATH="$VIRTUAL_ENV/bin:$PATH" -export PATH - -# unset PYTHONHOME if set -# this will fail if PYTHONHOME is set to the empty string (which is bad anyway) -# could use `if (set -u; : $PYTHONHOME) ;` in bash -if [ -n "${PYTHONHOME:-}" ] ; then - _OLD_VIRTUAL_PYTHONHOME="${PYTHONHOME:-}" - unset PYTHONHOME -fi - -if [ -z "${VIRTUAL_ENV_DISABLE_PROMPT:-}" ] ; then - _OLD_VIRTUAL_PS1="${PS1:-}" - if [ "x(venv) " != x ] ; then - PS1="(venv) ${PS1:-}" - else - if [ "`basename \"$VIRTUAL_ENV\"`" = "__" ] ; then - # special case for Aspen magic directories - # see https://aspen.io/ - PS1="[`basename \`dirname \"$VIRTUAL_ENV\"\``] $PS1" - else - PS1="(`basename \"$VIRTUAL_ENV\"`)$PS1" - fi - fi - export PS1 -fi - -# This should detect bash and zsh, which have a hash command that must -# be called to get it to forget past commands. Without forgetting -# past commands the $PATH changes we made may not be respected -if [ -n "${BASH:-}" -o -n "${ZSH_VERSION:-}" ] ; then - hash -r -fi diff --git a/venv/bin/activate.csh b/venv/bin/activate.csh deleted file mode 100644 index 420f69c..0000000 --- a/venv/bin/activate.csh +++ /dev/null @@ -1,37 +0,0 @@ -# This file must be used with "source bin/activate.csh" *from csh*. -# You cannot run it directly. -# Created by Davide Di Blasi . -# Ported to Python 3.3 venv by Andrew Svetlov - -alias deactivate 'test $?_OLD_VIRTUAL_PATH != 0 && setenv PATH "$_OLD_VIRTUAL_PATH" && unset _OLD_VIRTUAL_PATH; rehash; test $?_OLD_VIRTUAL_PROMPT != 0 && set prompt="$_OLD_VIRTUAL_PROMPT" && unset _OLD_VIRTUAL_PROMPT; unsetenv VIRTUAL_ENV; test "\!:*" != "nondestructive" && unalias deactivate' - -# Unset irrelevant variables. -deactivate nondestructive - -setenv VIRTUAL_ENV "/home/angel/Documents/workspace/telebot/venv" - -set _OLD_VIRTUAL_PATH="$PATH" -setenv PATH "$VIRTUAL_ENV/bin:$PATH" - - -set _OLD_VIRTUAL_PROMPT="$prompt" - -if (! "$?VIRTUAL_ENV_DISABLE_PROMPT") then - if ("venv" != "") then - set env_name = "venv" - else - if (`basename "VIRTUAL_ENV"` == "__") then - # special case for Aspen magic directories - # see https://aspen.io/ - set env_name = `basename \`dirname "$VIRTUAL_ENV"\`` - else - set env_name = `basename "$VIRTUAL_ENV"` - endif - endif - set prompt = "[$env_name] $prompt" - unset env_name -endif - -alias pydoc python -m pydoc - -rehash diff --git a/venv/bin/activate.fish b/venv/bin/activate.fish deleted file mode 100644 index d99efba..0000000 --- a/venv/bin/activate.fish +++ /dev/null @@ -1,75 +0,0 @@ -# This file must be used with ". bin/activate.fish" *from fish* (http://fishshell.org) -# you cannot run it directly - -function deactivate -d "Exit virtualenv and return to normal shell environment" - # reset old environment variables - if test -n "$_OLD_VIRTUAL_PATH" - set -gx PATH $_OLD_VIRTUAL_PATH - set -e _OLD_VIRTUAL_PATH - end - if test -n "$_OLD_VIRTUAL_PYTHONHOME" - set -gx PYTHONHOME $_OLD_VIRTUAL_PYTHONHOME - set -e _OLD_VIRTUAL_PYTHONHOME - end - - if test -n "$_OLD_FISH_PROMPT_OVERRIDE" - functions -e fish_prompt - set -e _OLD_FISH_PROMPT_OVERRIDE - functions -c _old_fish_prompt fish_prompt - functions -e _old_fish_prompt - end - - set -e VIRTUAL_ENV - if test "$argv[1]" != "nondestructive" - # Self destruct! - functions -e deactivate - end -end - -# unset irrelevant variables -deactivate nondestructive - -set -gx VIRTUAL_ENV "/home/angel/Documents/workspace/telebot/venv" - -set -gx _OLD_VIRTUAL_PATH $PATH -set -gx PATH "$VIRTUAL_ENV/bin" $PATH - -# unset PYTHONHOME if set -if set -q PYTHONHOME - set -gx _OLD_VIRTUAL_PYTHONHOME $PYTHONHOME - set -e PYTHONHOME -end - -if test -z "$VIRTUAL_ENV_DISABLE_PROMPT" - # fish uses a function instead of an env var to generate the prompt. - - # save the current fish_prompt function as the function _old_fish_prompt - functions -c fish_prompt _old_fish_prompt - - # with the original prompt function renamed, we can override with our own. - function fish_prompt - # Save the return status of the last command - set -l old_status $status - - # Prompt override? - if test -n "(venv) " - printf "%s%s" "(venv) " (set_color normal) - else - # ...Otherwise, prepend env - set -l _checkbase (basename "$VIRTUAL_ENV") - if test $_checkbase = "__" - # special case for Aspen magic directories - # see https://aspen.io/ - printf "%s[%s]%s " (set_color -b blue white) (basename (dirname "$VIRTUAL_ENV")) (set_color normal) - else - printf "%s(%s)%s" (set_color -b blue white) (basename "$VIRTUAL_ENV") (set_color normal) - end - end - - # Restore the return status of the previous command. - echo "exit $old_status" | . - _old_fish_prompt - end - - set -gx _OLD_FISH_PROMPT_OVERRIDE "$VIRTUAL_ENV" -end diff --git a/venv/bin/easy_install b/venv/bin/easy_install deleted file mode 100755 index 6fb8da2..0000000 --- a/venv/bin/easy_install +++ /dev/null @@ -1,8 +0,0 @@ -#!/home/angel/Documents/workspace/telebot/venv/bin/python3 -# -*- coding: utf-8 -*- -import re -import sys -from setuptools.command.easy_install import main -if __name__ == '__main__': - sys.argv[0] = re.sub(r'(-script\.pyw|\.exe)?$', '', sys.argv[0]) - sys.exit(main()) diff --git a/venv/bin/easy_install-3.8 b/venv/bin/easy_install-3.8 deleted file mode 100755 index 6fb8da2..0000000 --- a/venv/bin/easy_install-3.8 +++ /dev/null @@ -1,8 +0,0 @@ -#!/home/angel/Documents/workspace/telebot/venv/bin/python3 -# -*- coding: utf-8 -*- -import re -import sys -from setuptools.command.easy_install import main -if __name__ == '__main__': - sys.argv[0] = re.sub(r'(-script\.pyw|\.exe)?$', '', sys.argv[0]) - sys.exit(main()) diff --git a/venv/bin/normalizer b/venv/bin/normalizer deleted file mode 100755 index 1ad3ed6..0000000 --- a/venv/bin/normalizer +++ /dev/null @@ -1,8 +0,0 @@ -#!/home/angel/Documents/workspace/telebot/venv/bin/python3 -# -*- coding: utf-8 -*- -import re -import sys -from charset_normalizer.cli.normalizer import cli_detect -if __name__ == '__main__': - sys.argv[0] = re.sub(r'(-script\.pyw|\.exe)?$', '', sys.argv[0]) - sys.exit(cli_detect()) diff --git a/venv/bin/pip b/venv/bin/pip deleted file mode 100755 index 746b9dd..0000000 --- a/venv/bin/pip +++ /dev/null @@ -1,8 +0,0 @@ -#!/home/angel/Documents/workspace/telebot/venv/bin/python3 -# -*- coding: utf-8 -*- -import re -import sys -from pip._internal.cli.main import main -if __name__ == '__main__': - sys.argv[0] = re.sub(r'(-script\.pyw|\.exe)?$', '', sys.argv[0]) - sys.exit(main()) diff --git a/venv/bin/pip3 b/venv/bin/pip3 deleted file mode 100755 index 746b9dd..0000000 --- a/venv/bin/pip3 +++ /dev/null @@ -1,8 +0,0 @@ -#!/home/angel/Documents/workspace/telebot/venv/bin/python3 -# -*- coding: utf-8 -*- -import re -import sys -from pip._internal.cli.main import main -if __name__ == '__main__': - sys.argv[0] = re.sub(r'(-script\.pyw|\.exe)?$', '', sys.argv[0]) - sys.exit(main()) diff --git a/venv/bin/pip3.8 b/venv/bin/pip3.8 deleted file mode 100755 index 746b9dd..0000000 --- a/venv/bin/pip3.8 +++ /dev/null @@ -1,8 +0,0 @@ -#!/home/angel/Documents/workspace/telebot/venv/bin/python3 -# -*- coding: utf-8 -*- -import re -import sys -from pip._internal.cli.main import main -if __name__ == '__main__': - sys.argv[0] = re.sub(r'(-script\.pyw|\.exe)?$', '', sys.argv[0]) - sys.exit(main()) diff --git a/venv/bin/python b/venv/bin/python deleted file mode 120000 index b8a0adb..0000000 --- a/venv/bin/python +++ /dev/null @@ -1 +0,0 @@ -python3 \ No newline at end of file diff --git a/venv/bin/python3 b/venv/bin/python3 deleted file mode 120000 index ae65fda..0000000 --- a/venv/bin/python3 +++ /dev/null @@ -1 +0,0 @@ -/usr/bin/python3 \ No newline at end of file diff --git a/venv/lib/python3.8/site-packages/__pycache__/easy_install.cpython-38.pyc b/venv/lib/python3.8/site-packages/__pycache__/easy_install.cpython-38.pyc deleted file mode 100644 index 9756c319f6a1b1919071a2ac30a7eba8b0e11675..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 281 zcmYj}y-veG5QOi?5DSqfKmrRXg$vtM&>%!ZK|=weakD!4Hj2sp#b+xD1r1NbE4iiO z6{uJPMMjz#jkNnc&*w*sbalB`ukqy^FmvCTqO4%IPr$u&Q+cUxZ^hACqZ5>> import certifi - - >>> certifi.where() - '/usr/local/lib/python3.7/site-packages/certifi/cacert.pem' - -Or from the command line:: - - $ python -m certifi - /usr/local/lib/python3.7/site-packages/certifi/cacert.pem - -Enjoy! - -1024-bit Root Certificates -~~~~~~~~~~~~~~~~~~~~~~~~~~ - -Browsers and certificate authorities have concluded that 1024-bit keys are -unacceptably weak for certificates, particularly root certificates. For this -reason, Mozilla has removed any weak (i.e. 1024-bit key) certificate from its -bundle, replacing it with an equivalent strong (i.e. 2048-bit or greater key) -certificate from the same CA. Because Mozilla removed these certificates from -its bundle, ``certifi`` removed them as well. - -In previous versions, ``certifi`` provided the ``certifi.old_where()`` function -to intentionally re-add the 1024-bit roots back into your bundle. This was not -recommended in production and therefore was removed at the end of 2018. - -.. _`Certifi`: https://certifiio.readthedocs.io/en/latest/ -.. _`Requests`: https://requests.readthedocs.io/en/master/ - -Addition/Removal of Certificates --------------------------------- - -Certifi does not support any addition/removal or other modification of the -CA trust store content. This project is intended to provide a reliable and -highly portable root of trust to python deployments. Look to upstream projects -for methods to use alternate trust. - - diff --git a/venv/lib/python3.8/site-packages/certifi-2021.5.30.dist-info/RECORD b/venv/lib/python3.8/site-packages/certifi-2021.5.30.dist-info/RECORD deleted file mode 100644 index f2d2621..0000000 --- a/venv/lib/python3.8/site-packages/certifi-2021.5.30.dist-info/RECORD +++ /dev/null @@ -1,13 +0,0 @@ -certifi-2021.5.30.dist-info/INSTALLER,sha256=zuuue4knoyJ-UwPPXg8fezS7VCrXJQrAP7zeNuwvFQg,4 -certifi-2021.5.30.dist-info/LICENSE,sha256=vp2C82ES-Hp_HXTs1Ih-FGe7roh4qEAEoAEXseR1o-I,1049 -certifi-2021.5.30.dist-info/METADATA,sha256=RDzuah_IZxjVhKootR1Ha1BrDovPSA-xF-rcaD90PTo,2994 -certifi-2021.5.30.dist-info/RECORD,, -certifi-2021.5.30.dist-info/WHEEL,sha256=ADKeyaGyKF5DwBNE0sRE5pvW-bSkFMJfBuhzZ3rceP4,110 -certifi-2021.5.30.dist-info/top_level.txt,sha256=KMu4vUCfsjLrkPbSNdgdekS-pVJzBAJFO__nI8NF6-U,8 -certifi/__init__.py,sha256=-b78tXibbl0qtgCzv9tc9v6ozwcNX915lT9Tf4a9lds,62 -certifi/__main__.py,sha256=xBBoj905TUWBLRGANOcf7oi6e-3dMP4cEoG9OyMs11g,243 -certifi/__pycache__/__init__.cpython-38.pyc,, -certifi/__pycache__/__main__.cpython-38.pyc,, -certifi/__pycache__/core.cpython-38.pyc,, -certifi/cacert.pem,sha256=3i-hfE2K5o3CBKG2tYt6ehJWk2fP64o6Th83fHPoPp4,259465 -certifi/core.py,sha256=V0uyxKOYdz6ulDSusclrLmjbPgOXsD0BnEf0SQ7OnoE,2303 diff --git a/venv/lib/python3.8/site-packages/certifi-2021.5.30.dist-info/WHEEL b/venv/lib/python3.8/site-packages/certifi-2021.5.30.dist-info/WHEEL deleted file mode 100644 index 6d38aa0..0000000 --- a/venv/lib/python3.8/site-packages/certifi-2021.5.30.dist-info/WHEEL +++ /dev/null @@ -1,6 +0,0 @@ -Wheel-Version: 1.0 -Generator: bdist_wheel (0.35.1) -Root-Is-Purelib: true -Tag: py2-none-any -Tag: py3-none-any - diff --git a/venv/lib/python3.8/site-packages/certifi-2021.5.30.dist-info/top_level.txt b/venv/lib/python3.8/site-packages/certifi-2021.5.30.dist-info/top_level.txt deleted file mode 100644 index 963eac5..0000000 --- a/venv/lib/python3.8/site-packages/certifi-2021.5.30.dist-info/top_level.txt +++ /dev/null @@ -1 +0,0 @@ -certifi diff --git a/venv/lib/python3.8/site-packages/certifi/__init__.py b/venv/lib/python3.8/site-packages/certifi/__init__.py deleted file mode 100644 index eebdf88..0000000 --- a/venv/lib/python3.8/site-packages/certifi/__init__.py +++ /dev/null @@ -1,3 +0,0 @@ -from .core import contents, where - -__version__ = "2021.05.30" diff --git a/venv/lib/python3.8/site-packages/certifi/__main__.py b/venv/lib/python3.8/site-packages/certifi/__main__.py deleted file mode 100644 index 8945b5d..0000000 --- a/venv/lib/python3.8/site-packages/certifi/__main__.py +++ /dev/null @@ -1,12 +0,0 @@ -import argparse - -from certifi import contents, where - -parser = argparse.ArgumentParser() -parser.add_argument("-c", "--contents", action="store_true") -args = parser.parse_args() - -if args.contents: - print(contents()) -else: - print(where()) diff --git a/venv/lib/python3.8/site-packages/certifi/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/certifi/__pycache__/__init__.cpython-38.pyc deleted file mode 100644 index 651c23a00a4338214cb90471edd0549eaaf831b1..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 227 zcmWIL<>g`kf^tjML^~k;7{oyaOhAqU5En}Ti4=wu#vF!R#wf;IrYI&xh7_hK<`m{& z22GZij6i8krdu4z`FSO&c_qcSSj#g~i&Cq&j0}tn^$bk)j1BxWS#Gf;=NF|GfebBT z1`@ZpWHa^HWN5Qtd#_DF#_1zytszC^lmN diff --git a/venv/lib/python3.8/site-packages/certifi/__pycache__/__main__.cpython-38.pyc b/venv/lib/python3.8/site-packages/certifi/__pycache__/__main__.cpython-38.pyc deleted file mode 100644 index c6f65d2324d5a0b8debf4720bd5b89a6156b7338..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 392 zcmYk0u};G<5Qc51PEFKSeF=sPAxMA(5<;*tR7eO3Wr?i#C@HaHIgTp2cIF+*$SZke zVrFB)4hV6Q|GWF|{MmQYX@Y#L&-VGJ&+no6AJjLO{&e?V1QNJGMaZPVk`zQnMT8Nc z-RKn+6zD1zkr)Xo;+Npl-PrpK*ov5I*aNafTa1xPd>#GN0^g!^{Nd?nkrKzMR#{NC zb9DU(1~w$CHc6KK*-2+x1En=Rq}av0vURJ{#4&D`nwt*XxB_GAhuRR&G?5oKyE4mO zdhAWuFfJZ8jhk>GN`G;fxnyud-?`DCRGV7aH)Li373AwUw^HZ2)>*GKubx0;{-e-j t>%-H&J&{NG@AG+CN?xn7JkZaMoy%7A4P0Q)=mLn5IbnE?8Hw?Pd;|FiYoGuC diff --git a/venv/lib/python3.8/site-packages/certifi/__pycache__/core.cpython-38.pyc b/venv/lib/python3.8/site-packages/certifi/__pycache__/core.cpython-38.pyc deleted file mode 100644 index 67ac3bb65b9f8152b00eae69c4616c10b8b8a0ae..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1108 zcmZuv&2G~`5Z+zeiQ^uh587UumzLc!geI)=p?aOf-|39q-Qf&CI)Y+aoA@PaZ_STta@B;IiNud4XDR zG@J|xr<|p9NcZofXQgan4eg0DbSU90s-f1o&7EU1bhk+M&?cg>>%n_U%#XKtox8_$ z=jsF3he~`_ zu}NGO3xghNaSx5cF6_E+S5ec6BNj1bDRyel$PtY&iwvy3uFn~qdlwJ_N4LV>dT(QM z5WZd?ywvWtP+?iTxj63)K4_~@pc`R`Fa?C+8G$C&EzS9AS55M6p5!ajERW({!B_Ui zLZmButBT({}b7K1kW+KGxdNn%5AAvQW@B}&4p z=qRG-5sv+Uadu*TyK!h8Sf^}8wg@9@C^`m2V#)hnZP0)&~c_z;Q5H07F;Tc>-B95!wyIQId)<)b@@{vVdwj`WKGr+#2c} zPK*781QWzOUm{sT2Nwnxg?tB+sgmJ-6^;aUG3aa~Y${%%(PL-CA=3.5.0 -Description-Content-Type: text/markdown -Provides-Extra: unicode_backport -Requires-Dist: unicodedata2 ; extra == 'unicode_backport' - - -

Charset Detection, for Everyone 👋

- -

- The Real First Universal Charset Detector
- - - - - - - - Code Quality Badge - - - - - - Documentation Status - - - Download Count Total - -

- -> A library that helps you read text from an unknown charset encoding.
Motivated by `chardet`, -> I'm trying to resolve the issue by taking a new approach. -> All IANA character set names for which the Python core library provides codecs are supported. - -

- >>>>> 👉 Try Me Online Now, Then Adopt Me 👈 <<<<< -

- -This project offers you an alternative to **Universal Charset Encoding Detector**, also known as **Chardet**. - -| Feature | [Chardet](https://github.com/chardet/chardet) | Charset Normalizer | [cChardet](https://github.com/PyYoshi/cChardet) | -| ------------- | :-------------: | :------------------: | :------------------: | -| `Fast` | ❌
| ✅
| ✅
| -| `Universal**` | ❌ | ✅ | ❌ | -| `Reliable` **without** distinguishable standards | ❌ | ✅ | ✅ | -| `Reliable` **with** distinguishable standards | ✅ | ✅ | ✅ | -| `Free & Open` | ✅ | ✅ | ✅ | -| `License` | LGPL-2.1 | MIT | MPL-1.1 -| `Native Python` | ✅ | ✅ | ❌ | -| `Detect spoken language` | ❌ | ✅ | N/A | -| `Supported Encoding` | 30 | :tada: [93](https://charset-normalizer.readthedocs.io/en/latest/support.html) | 40 - -

-Reading Normalized TextCat Reading Text - -*\*\* : They are clearly using specific code for a specific encoding even if covering most of used one*
- -## ⚡ Performance - -This package offer better performance than its counterpart Chardet. Here are some numbers. - -| Package | Accuracy | Mean per file (ns) | File per sec (est) | -| ------------- | :-------------: | :------------------: | :------------------: | -| [chardet](https://github.com/chardet/chardet) | 93.0 % | 67 ms | 15.38 file/sec | -| charset-normalizer | **95.0 %** | **37 ms** | 27.77 file/sec | - -| Package | 99th percentile | 95th percentile | 50th percentile | -| ------------- | :-------------: | :------------------: | :------------------: | -| [chardet](https://github.com/chardet/chardet) | 424 ms | 234 ms | 26 ms | -| charset-normalizer | 335 ms | 186 ms | 17 ms | - -Chardet's performance on larger file (1MB+) are very poor. Expect huge difference on large payload. - -> Stats are generated using 400+ files using default parameters. More details on used files, see GHA workflows. -> And yes, these results might change at any time. The dataset can be updated to include more files. - -[cchardet](https://github.com/PyYoshi/cChardet) is a non-native (cpp binding) faster alternative. If speed is the most important factor, -you should try it. - -## Your support - -Please ⭐ this repository if this project helped you! - -## ✨ Installation - -Using PyPi for latest stable -```sh -pip install charset-normalizer -``` -Or directly from dev-master for latest preview -```sh -pip install git+https://github.com/Ousret/charset_normalizer.git -``` - -If you want a more up-to-date `unicodedata` than the one available in your Python setup. -```sh -pip install charset-normalizer[unicode_backport] -``` - -## 🚀 Basic Usage - -### CLI -This package comes with a CLI. - -``` -usage: normalizer [-h] [-v] [-a] [-n] [-m] [-r] [-f] [-t THRESHOLD] - file [file ...] - -The Real First Universal Charset Detector. Discover originating encoding used -on text file. Normalize text to unicode. - -positional arguments: - files File(s) to be analysed - -optional arguments: - -h, --help show this help message and exit - -v, --verbose Display complementary information about file if any. - Stdout will contain logs about the detection process. - -a, --with-alternative - Output complementary possibilities if any. Top-level - JSON WILL be a list. - -n, --normalize Permit to normalize input file. If not set, program - does not write anything. - -m, --minimal Only output the charset detected to STDOUT. Disabling - JSON output. - -r, --replace Replace file when trying to normalize it instead of - creating a new one. - -f, --force Replace file without asking if you are sure, use this - flag with caution. - -t THRESHOLD, --threshold THRESHOLD - Define a custom maximum amount of chaos allowed in - decoded content. 0. <= chaos <= 1. - --version Show version information and exit. -``` - -```bash -normalizer ./data/sample.1.fr.srt -``` - -:tada: Since version 1.4.0 the CLI produce easily usable stdout result in JSON format. - -```json -{ - "path": "/home/default/projects/charset_normalizer/data/sample.1.fr.srt", - "encoding": "cp1252", - "encoding_aliases": [ - "1252", - "windows_1252" - ], - "alternative_encodings": [ - "cp1254", - "cp1256", - "cp1258", - "iso8859_14", - "iso8859_15", - "iso8859_16", - "iso8859_3", - "iso8859_9", - "latin_1", - "mbcs" - ], - "language": "French", - "alphabets": [ - "Basic Latin", - "Latin-1 Supplement" - ], - "has_sig_or_bom": false, - "chaos": 0.149, - "coherence": 97.152, - "unicode_path": null, - "is_preferred": true -} -``` - -### Python -*Just print out normalized text* -```python -from charset_normalizer import from_path - -results = from_path('./my_subtitle.srt') - -print(str(results.best())) -``` - -*Normalize any text file* -```python -from charset_normalizer import normalize -try: - normalize('./my_subtitle.srt') # should write to disk my_subtitle-***.srt -except IOError as e: - print('Sadly, we are unable to perform charset normalization.', str(e)) -``` - -*Upgrade your code without effort* -```python -from charset_normalizer import detect -``` - -The above code will behave the same as **chardet**. We ensure that we offer the best (reasonable) BC result possible. - -See the docs for advanced usage : [readthedocs.io](https://charset-normalizer.readthedocs.io/en/latest/) - -## 😇 Why - -When I started using Chardet, I noticed that it was not suited to my expectations, and I wanted to propose a -reliable alternative using a completely different method. Also! I never back down on a good challenge ! - -I **don't care** about the **originating charset** encoding, because **two different tables** can -produce **two identical files.** -What I want is to get readable text, the best I can. - -In a way, **I'm brute forcing text decoding.** How cool is that ? 😎 - -Don't confuse package **ftfy** with charset-normalizer or chardet. ftfy goal is to repair unicode string whereas charset-normalizer to convert raw file in unknown encoding to unicode. - -## 🍰 How - - - Discard all charset encoding table that could not fit the binary content. - - Measure chaos, or the mess once opened (by chunks) with a corresponding charset encoding. - - Extract matches with the lowest mess detected. - - Finally, if there is too much match left, we measure coherence. - -**Wait a minute**, what is chaos/mess and coherence according to **YOU ?** - -*Chaos :* I opened hundred of text files, **written by humans**, with the wrong encoding table. **I observed**, then -**I established** some ground rules about **what is obvious** when **it seems like** a mess. - I know that my interpretation of what is chaotic is very subjective, feel free to contribute in order to - improve or rewrite it. - -*Coherence :* For each language there is on earth, we have computed ranked letter appearance occurrences (the best we can). So I thought -that intel is worth something here. So I use those records against decoded text to check if I can detect intelligent design. - -## ⚡ Known limitations - - - Language detection is unreliable when text contains two or more languages sharing identical letters. (eg. HTML (english tags) + Turkish content (Sharing Latin characters)) - - Every charset detector heavily depends on sufficient content. In common cases, do not bother run detection on very tiny content. - -## 👤 Contributing - -Contributions, issues and feature requests are very much welcome.
-Feel free to check [issues page](https://github.com/ousret/charset_normalizer/issues) if you want to contribute. - -## 📝 License - -Copyright © 2019 [Ahmed TAHRI @Ousret](https://github.com/Ousret).
-This project is [MIT](https://github.com/Ousret/charset_normalizer/blob/master/LICENSE) licensed. - -Characters frequencies used in this project © 2012 [Denny Vrandečić](http://denny.vrandecic.de) - - diff --git a/venv/lib/python3.8/site-packages/charset_normalizer-2.0.3.dist-info/RECORD b/venv/lib/python3.8/site-packages/charset_normalizer-2.0.3.dist-info/RECORD deleted file mode 100644 index 7cc9928..0000000 --- a/venv/lib/python3.8/site-packages/charset_normalizer-2.0.3.dist-info/RECORD +++ /dev/null @@ -1,33 +0,0 @@ -../../../bin/normalizer,sha256=73BGDYHJdrSug4_ba5piGJQZJXD6k9x8QQnzrq7ldtI,284 -charset_normalizer-2.0.3.dist-info/INSTALLER,sha256=zuuue4knoyJ-UwPPXg8fezS7VCrXJQrAP7zeNuwvFQg,4 -charset_normalizer-2.0.3.dist-info/LICENSE,sha256=6zGgxaT7Cbik4yBV0lweX5w1iidS_vPNcgIT0cz-4kE,1070 -charset_normalizer-2.0.3.dist-info/METADATA,sha256=RZIpCo9OAmNF71ZG8QWXqf6AbVu68_-PYP4MZKp_wnw,11716 -charset_normalizer-2.0.3.dist-info/RECORD,, -charset_normalizer-2.0.3.dist-info/WHEEL,sha256=OqRkF0eY5GHssMorFjlbTIq072vpHpF60fIQA6lS9xA,92 -charset_normalizer-2.0.3.dist-info/entry_points.txt,sha256=5AJq_EPtGGUwJPgQLnBZfbVr-FYCIwT0xP7dIEZO3NI,77 -charset_normalizer-2.0.3.dist-info/top_level.txt,sha256=7ASyzePr8_xuZWJsnqJjIBtyV8vhEo0wBCv1MPRRi3Q,19 -charset_normalizer/__init__.py,sha256=i8FSr9cSFIrh16O8h7com8LKtd9nsLY8wiEhSpk1_aY,1673 -charset_normalizer/__pycache__/__init__.cpython-38.pyc,, -charset_normalizer/__pycache__/api.cpython-38.pyc,, -charset_normalizer/__pycache__/cd.cpython-38.pyc,, -charset_normalizer/__pycache__/constant.cpython-38.pyc,, -charset_normalizer/__pycache__/legacy.cpython-38.pyc,, -charset_normalizer/__pycache__/md.cpython-38.pyc,, -charset_normalizer/__pycache__/models.cpython-38.pyc,, -charset_normalizer/__pycache__/utils.cpython-38.pyc,, -charset_normalizer/__pycache__/version.cpython-38.pyc,, -charset_normalizer/api.py,sha256=Ca_7jRyYMRWktz_Vlc0C7QvNjSJ3-a1wlaaGLLX9-2E,15319 -charset_normalizer/assets/__init__.py,sha256=JTs2XX9qbYSBhS4EEI93IqEOnzzrHhVmX1gp2vKjZdE,6938 -charset_normalizer/assets/__pycache__/__init__.cpython-38.pyc,, -charset_normalizer/cd.py,sha256=_HLe1wgJAifJPl4dlBctjK5yIvH0ja67jePw36OrrhI,9223 -charset_normalizer/cli/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -charset_normalizer/cli/__pycache__/__init__.cpython-38.pyc,, -charset_normalizer/cli/__pycache__/normalizer.cpython-38.pyc,, -charset_normalizer/cli/normalizer.py,sha256=qG1z783dgpUfllxLIkyLFfSsz1QKMh2T2VlHMr8Cvjg,7773 -charset_normalizer/constant.py,sha256=YA8r7rNGeuLlnqWLs2MISs1mFLmaralG99HNevHuUuo,18390 -charset_normalizer/legacy.py,sha256=L3Qn-DSLjRQoYPtDIzkXcqO0mnFIjOl0p6-gAzYUY54,1640 -charset_normalizer/md.py,sha256=QV0YU1ciDm3VSMrlabl9bXIHxOt7C5-uiLQpJZiJ-4A,14662 -charset_normalizer/models.py,sha256=ZYcD6qEsX00SHUJ7XwPScxESWLNIYpDw1JZ0JKQU2EU,12391 -charset_normalizer/py.typed,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -charset_normalizer/utils.py,sha256=m8EVpWxu3RRORZYqxdFxWSK1osS22oIGP9wACVRl6Mk,7239 -charset_normalizer/version.py,sha256=Ejou22hb6JfMu7pp3axnqZP-xGcsS0KsJVRe5yRrvOQ,79 diff --git a/venv/lib/python3.8/site-packages/charset_normalizer-2.0.3.dist-info/WHEEL b/venv/lib/python3.8/site-packages/charset_normalizer-2.0.3.dist-info/WHEEL deleted file mode 100644 index 385faab..0000000 --- a/venv/lib/python3.8/site-packages/charset_normalizer-2.0.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/venv/lib/python3.8/site-packages/charset_normalizer-2.0.3.dist-info/entry_points.txt b/venv/lib/python3.8/site-packages/charset_normalizer-2.0.3.dist-info/entry_points.txt deleted file mode 100644 index a67f60b..0000000 --- a/venv/lib/python3.8/site-packages/charset_normalizer-2.0.3.dist-info/entry_points.txt +++ /dev/null @@ -1,3 +0,0 @@ -[console_scripts] -normalizer = charset_normalizer.cli.normalizer:cli_detect - diff --git a/venv/lib/python3.8/site-packages/charset_normalizer-2.0.3.dist-info/top_level.txt b/venv/lib/python3.8/site-packages/charset_normalizer-2.0.3.dist-info/top_level.txt deleted file mode 100644 index 66958f0..0000000 --- a/venv/lib/python3.8/site-packages/charset_normalizer-2.0.3.dist-info/top_level.txt +++ /dev/null @@ -1 +0,0 @@ -charset_normalizer diff --git a/venv/lib/python3.8/site-packages/charset_normalizer/__init__.py b/venv/lib/python3.8/site-packages/charset_normalizer/__init__.py deleted file mode 100644 index f14a90b..0000000 --- a/venv/lib/python3.8/site-packages/charset_normalizer/__init__.py +++ /dev/null @@ -1,31 +0,0 @@ -""" -Charset-Normalizer -~~~~~~~~~~~~~~ -The Real First Universal Charset Detector. -A library that helps you read text from an unknown charset encoding. -Motivated by chardet, This package is trying to resolve the issue by taking a new approach. -All IANA character set names for which the Python core library provides codecs are supported. - -Basic usage: - >>> from charset_normalizer import from_bytes - >>> results = from_bytes('Bсеки човек има право на образование. Oбразованието трябва да бъде безплатно, поне що се отнася до началното и основното образование.'.encode('utf_8')) - >>> "utf_8" in results - True - >>> best_result = results.best() - >>> str(best_result) - 'Bсеки човек има право на образование. Oбразованието трябва да бъде безплатно, поне що се отнася до началното и основното образование.' - -Others methods and usages are available - see the full documentation -at . -:copyright: (c) 2021 by Ahmed TAHRI -:license: MIT, see LICENSE for more details. -""" -from charset_normalizer.api import from_fp, from_path, from_bytes, normalize -from charset_normalizer.legacy import detect -from charset_normalizer.version import __version__, VERSION -from charset_normalizer.models import CharsetMatch, CharsetMatches - -# Backward-compatible v1 imports -from charset_normalizer.models import CharsetNormalizerMatch -import charset_normalizer.api as CharsetDetector -CharsetNormalizerMatches = CharsetDetector diff --git a/venv/lib/python3.8/site-packages/charset_normalizer/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/charset_normalizer/__pycache__/__init__.cpython-38.pyc deleted file mode 100644 index 2a5b6111577c49fb102d90c6ce4cda021f3a3389..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1855 zcmd^APj4GV6kq>I9B-U71ZqA3D|!6>zu$X1@9op2CDXv?*+=h_ zm-B}4yJBuXWn@0ZpYZYU4BPNZUO6a*WxE_!>`GX*tKpnIS5opyFdx?Jnx?D4LRh!! zp=q0%p9>blhTRC4>?O_5Bfo4fYr2Ncu=H z0sDq>^V@$sX5Xi$qzJgV~<6Lmbn{Cc1$GoU@+2ZkID_``%FMW+#_;G z0ZGY6Xbm#P*dh*&DW+5kky7O+$&peMi0BEBB;he}eFPW;u+!~zbzI^~$^naqh=f$Y zFy?ULGuPLlz8XnCMtm`+H&tPnW9FeLVx_JCf;y2VNz4(hWtxwPU@oKrF?LJ<*xK5f z6g;iciEg?KEL3heeifad~Ck>>4k8kPL*B^ zy~&?vW0YM%cB%NQ>`Y5uYs)bTFS2tB_GXFm7wDG1$e-u0vNMc+DVTOEyN^%j{|c6Jp>?ROT<0Ga|#BS~<>7^H(au1PWpuqa!-$G>9IlQ^jMZ8|iGg zYnHwfbbT$AL+9aIvw7X2`&w`xSfpOQYL?RUc}lM>22@CAqQgE;jVvWyzlkCwU%zFi z<^RVvo8}&l4i^woyzw61>d2ei;mHLj$AkrB5Kw60uuSG`nBpLLv73f8l0>pNGI8D? z`BEmL({3L!>8AtBjl=d{Dmazxw+CR$GCOXZj5s^=We3*XCOp`D@PQiMt{>v`_q$*0 z@0gu{xik{A1G_u@4GrMSohRG9gKa&pp&CzI5C~CN<{!8~jb^o|sV(CSlcKJPgh;^0vhYL0_#avXd0?G9KZVO%YLUQq{bV}sA(VZS@WHlT;Z9dZ1A81{QJ^i$xx zrlKtTSCkOs?8L5vFU&N!RAQ1b`w213%Zr_^<{#6wfKNx&j`Ksg3Puem}+6hZq zX{6RO^;#!Br9q22$tEEmZq9i1ZO35|la6C0qhjF^f=UCrRl;yW#jLL0D>X_hrIktp G|NjD+5CE+J diff --git a/venv/lib/python3.8/site-packages/charset_normalizer/__pycache__/api.cpython-38.pyc b/venv/lib/python3.8/site-packages/charset_normalizer/__pycache__/api.cpython-38.pyc deleted file mode 100644 index da9c8029902708c8d592561327b174a5ffc73a1d..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 9516 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 z RR~FY+R$p6rY31cA`!A%xU335d diff --git a/venv/lib/python3.8/site-packages/charset_normalizer/__pycache__/constant.cpython-38.pyc b/venv/lib/python3.8/site-packages/charset_normalizer/__pycache__/constant.cpython-38.pyc deleted file mode 100644 index 0d440206f1c1ddfb159ee9d5e943de8917464f20..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 13110 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 F`+syE&cy%# diff --git a/venv/lib/python3.8/site-packages/charset_normalizer/__pycache__/legacy.cpython-38.pyc b/venv/lib/python3.8/site-packages/charset_normalizer/__pycache__/legacy.cpython-38.pyc deleted file mode 100644 index 449cb297c2095323f15b020338d9f2c5fefc442b..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1419 zcmZuxPj4eN6t_KpGRdYZ?P^tRfrBqdM51YhR${66t2PoyC`H}$GMC61JIQQj?7{Xl z&604Se2hJGk4St3PJ9esIdS8Rgy4CSWh;TDd47J+e((2we&fr%y$*tL{n5K@9wYRd zU)&unSbPqj8G+!4;{ug9#n|hlAZ3sSjUE(X8KqGfr*YXzTNsH%M4~NX(E{0-k^^*r zyyW3a!XqC47^e4l>lx}Lze8ly!>%*csvJ*NRv1|ApMLqp#o1sqK0Uv<7(Dyte0Vk( zo(_6}3(xY*y5zjFxst4K(WL~XM_l61j*ZnW*230WX4r?`jR-;!0~Npqcyt0uka220dM^`M1Nq3w{DP){e0Vcg*JGNIa##z*K7Pdk%W^C*;(db zY4cza=tcuyxCwT??|B5?&STV^2zS=oHR17s=v(mJ14(%6Lj>`N?JipS=QWYB?XH2l zb+8V3@-hI{+U!>-u0vsDbEdhlv=B3vt!OFiT=B+pCalOTwR1s*%oNY%jH+p~p5<3U zQcoBK!obm|Us-DAsxCO42wEy*ixr))Y_Wv!hnXrXX7foQ`c3G;>v)otf-du-pe3`} zoSyE`sHLP!om-!CITun~2~8_yOcR5?H&m7?`36@Lr&G=er%#sw2q>HrMANc*?LVf|*4 zz7Lk4kbVr)pPwArvO22r>adm-w3*fFaMj{lB>4o*myJjCzd{cs;A!9z?i`AfeAdxpJky8qv>eOBd7 zRq5ORjE3+P^2-L(mUExWK#^HtCu|?}!7xDfzfmye`D2 O{&6z?a2I#+qu?L*Yny2R diff --git a/venv/lib/python3.8/site-packages/charset_normalizer/__pycache__/md.cpython-38.pyc b/venv/lib/python3.8/site-packages/charset_normalizer/__pycache__/md.cpython-38.pyc deleted file mode 100644 index cda1d7f595961c34a1d9b7d17e60ef57f647b6cd..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 13350 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 diff --git a/venv/lib/python3.8/site-packages/charset_normalizer/__pycache__/models.cpython-38.pyc b/venv/lib/python3.8/site-packages/charset_normalizer/__pycache__/models.cpython-38.pyc deleted file mode 100644 index ace03a4cbb98b0a3ce45eb4f3bb7133abb4552ed..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 12394 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 diff --git a/venv/lib/python3.8/site-packages/charset_normalizer/__pycache__/utils.cpython-38.pyc b/venv/lib/python3.8/site-packages/charset_normalizer/__pycache__/utils.cpython-38.pyc deleted file mode 100644 index 5d32466ffd874254e1e2283654d79bc812da5bf5..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6050 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 diff --git a/venv/lib/python3.8/site-packages/charset_normalizer/__pycache__/version.cpython-38.pyc b/venv/lib/python3.8/site-packages/charset_normalizer/__pycache__/version.cpython-38.pyc deleted file mode 100644 index 51cdc8a6025b9de9f0b977708a413316c8bff043..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 238 zcmWIL<>g`kf(lF3M1LUt7{oya%s`F<5EqL9i4=w?h7`sq##F`yOestY8Kam}n1dNK zS*irMTq_Fli&GWKQj3Z+^Ygf>SdH`y^o(yY>iKE1++vT9PsvY?kH5to9}iUl2KczG$)s7M5b`~JP!otD`0AkZW AVE_OC diff --git a/venv/lib/python3.8/site-packages/charset_normalizer/api.py b/venv/lib/python3.8/site-packages/charset_normalizer/api.py deleted file mode 100644 index 7ad912c..0000000 --- a/venv/lib/python3.8/site-packages/charset_normalizer/api.py +++ /dev/null @@ -1,421 +0,0 @@ -from os.path import splitext, basename -from typing import List, BinaryIO, Optional, Set, Union - -try: - from os import PathLike -except ImportError: - PathLike = Union[str, 'os.PathLike[str]'] # type: ignore - -from charset_normalizer.constant import TOO_SMALL_SEQUENCE, TOO_BIG_SEQUENCE, IANA_SUPPORTED -from charset_normalizer.md import mess_ratio -from charset_normalizer.models import CharsetMatches, CharsetMatch -from warnings import warn -import logging - -from charset_normalizer.utils import any_specified_encoding, is_multi_byte_encoding, identify_sig_or_bom, \ - should_strip_sig_or_bom, is_cp_similar, iana_name -from charset_normalizer.cd import coherence_ratio, encoding_languages, mb_encoding_languages, merge_coherence_ratios - -logger = logging.getLogger("charset_normalizer") -logger.setLevel(logging.DEBUG) - -handler = logging.StreamHandler() -handler.setFormatter(logging.Formatter('%(asctime)s | %(levelname)s | %(message)s')) -logger.addHandler(handler) - - -def from_bytes( - sequences: bytes, - steps: int = 5, - chunk_size: int = 512, - threshold: float = 0.2, - cp_isolation: List[str] = None, - cp_exclusion: List[str] = None, - preemptive_behaviour: bool = True, - explain: bool = False -) -> CharsetMatches: - """ - Given a raw bytes sequence, return the best possibles charset usable to render str objects. - If there is no results, it is a strong indicator that the source is binary/not text. - By default, the process will extract 5 blocs of 512o each to assess the mess and coherence of a given sequence. - And will give up a particular code page after 20% of measured mess. Those criteria are customizable at will. - - The preemptive behavior DOES NOT replace the traditional detection workflow, it prioritize a particular code page - but never take it for granted. Can improve the performance. - - You may want to focus your attention to some code page or/and not others, use cp_isolation and cp_exclusion for that - purpose. - - This function will strip the SIG in the payload/sequence every time except on UTF-16, UTF-32. - """ - - if not explain: - logger.setLevel(logging.CRITICAL) - else: - logger.setLevel(logging.INFO) - - length = len(sequences) # type: int - - if length == 0: - logger.warning("Given content is empty, stopping the process very early, returning empty utf_8 str match") - return CharsetMatches( - [ - CharsetMatch( - sequences, - "utf_8", - 0., - False, - [], - "" - ) - ] - ) - - if cp_isolation is not None: - logger.warning('cp_isolation is set. use this flag for debugging purpose. ' - 'limited list of encoding allowed : %s.', - ', '.join(cp_isolation)) - cp_isolation = [iana_name(cp, False) for cp in cp_isolation] - else: - cp_isolation = [] - - if cp_exclusion is not None: - logger.warning( - 'cp_exclusion is set. use this flag for debugging purpose. ' - 'limited list of encoding excluded : %s.', - ', '.join(cp_exclusion)) - cp_exclusion = [iana_name(cp, False) for cp in cp_exclusion] - else: - cp_exclusion = [] - - if length <= (chunk_size * steps): - logger.warning( - 'override steps (%i) and chunk_size (%i) as content does not fit (%i byte(s) given) parameters.', - steps, chunk_size, length) - steps = 1 - chunk_size = length - - if steps > 1 and length / steps < chunk_size: - chunk_size = int(length / steps) - - is_too_small_sequence = len(sequences) < TOO_SMALL_SEQUENCE # type: bool - is_too_large_sequence = len(sequences) >= TOO_BIG_SEQUENCE # type: bool - - if is_too_small_sequence: - warn('Trying to detect encoding from a tiny portion of ({}) byte(s).'.format(length)) - - prioritized_encodings = [] # type: List[str] - - specified_encoding = any_specified_encoding(sequences) if preemptive_behaviour is True else None # type: Optional[str] - - if specified_encoding is not None: - prioritized_encodings.append(specified_encoding) - logger.info('Detected declarative mark in sequence. Priority +1 given for %s.', specified_encoding) - - tested = set() # type: Set[str] - tested_but_hard_failure = [] # type: List[str] - tested_but_soft_failure = [] # type: List[str] - - fallback_ascii = None # type: Optional[CharsetMatch] - fallback_u8 = None # type: Optional[CharsetMatch] - - single_byte_hard_failure_count = 0 # type: int - single_byte_soft_failure_count = 0 # type: int - - results = CharsetMatches() # type: CharsetMatches - - sig_encoding, sig_payload = identify_sig_or_bom(sequences) - - if sig_encoding is not None: - prioritized_encodings.append(sig_encoding) - logger.info('Detected a SIG or BOM mark on first %i byte(s). Priority +1 given for %s.', len(sig_payload), sig_encoding) - - prioritized_encodings.append("ascii") - - if "utf_8" not in prioritized_encodings: - prioritized_encodings.append("utf_8") - - for encoding_iana in prioritized_encodings+IANA_SUPPORTED: - - if cp_isolation and encoding_iana not in cp_isolation: - continue - - if cp_exclusion and encoding_iana in cp_exclusion: - continue - - if encoding_iana in tested: - continue - - tested.add(encoding_iana) - - decoded_payload = None # type: Optional[str] - bom_or_sig_available = sig_encoding == encoding_iana # type: bool - strip_sig_or_bom = bom_or_sig_available and should_strip_sig_or_bom(encoding_iana) # type: bool - - if encoding_iana in {"utf_16", "utf_32"} and bom_or_sig_available is False: - logger.info("Encoding %s wont be tested as-is because it require a BOM. Will try some sub-encoder LE/BE.", encoding_iana) - continue - - try: - is_multi_byte_decoder = is_multi_byte_encoding(encoding_iana) # type: bool - except (ModuleNotFoundError, ImportError): - logger.debug("Encoding %s does not provide an IncrementalDecoder", encoding_iana) - continue - - try: - if is_too_large_sequence and is_multi_byte_decoder is False: - str( - sequences[:int(50e4)] if strip_sig_or_bom is False else sequences[len(sig_payload):int(50e4)], - encoding=encoding_iana - ) - else: - decoded_payload = str( - sequences if strip_sig_or_bom is False else sequences[len(sig_payload):], - encoding=encoding_iana - ) - except UnicodeDecodeError as e: - logger.warning('Code page %s does not fit given bytes sequence at ALL. %s', encoding_iana, str(e)) - tested_but_hard_failure.append(encoding_iana) - if not is_multi_byte_decoder: - single_byte_hard_failure_count += 1 - continue - except LookupError: - tested_but_hard_failure.append(encoding_iana) - if not is_multi_byte_decoder: - single_byte_hard_failure_count += 1 - continue - - similar_soft_failure_test = False # type: bool - - for encoding_soft_failed in tested_but_soft_failure: - if is_cp_similar(encoding_iana, encoding_soft_failed): - similar_soft_failure_test = True - break - - if similar_soft_failure_test: - logger.warning("%s is deemed too similar to code page %s and was consider unsuited already. Continuing!", encoding_iana, encoding_soft_failed) - continue - - r_ = range( - 0 if bom_or_sig_available is False else len(sig_payload), - length, - int(length / steps) - ) - - multi_byte_bonus = is_multi_byte_decoder and decoded_payload is not None and len(decoded_payload) < length # type: bool - - if multi_byte_bonus: - logger.info('Code page %s is a multi byte encoding table and it appear that at least one character was encoded using n-bytes. Should not be a coincidence. Priority +1 given.', encoding_iana) - - max_chunk_gave_up = int(len(r_) / 4) # type: int - - if max_chunk_gave_up < 2: - max_chunk_gave_up = 2 - - early_stop_count = 0 # type: int - - md_chunks = [] # type: List[str] - md_ratios = [] - - for i in r_: - cut_sequence = sequences[i:i + chunk_size] - - if bom_or_sig_available and strip_sig_or_bom is False: - cut_sequence = sig_payload+cut_sequence - - chunk = cut_sequence.decode(encoding_iana, errors="ignore") # type: str - - md_chunks.append(chunk) - - md_ratios.append( - mess_ratio( - chunk, - threshold - ) - ) - - if md_ratios[-1] >= threshold: - early_stop_count += 1 - - if (early_stop_count >= max_chunk_gave_up) or (bom_or_sig_available and strip_sig_or_bom is False): - break - - if md_ratios: - mean_mess_ratio = sum(md_ratios) / len(md_ratios) # type: float - else: - mean_mess_ratio = 0. - - if mean_mess_ratio >= threshold or early_stop_count >= max_chunk_gave_up: - tested_but_soft_failure.append(encoding_iana) - if not is_multi_byte_decoder: - single_byte_soft_failure_count += 1 - logger.warning('%s was excluded because of initial chaos probing. Gave up %i time(s). ' - 'Computed mean chaos is %f %%.', - encoding_iana, - early_stop_count, - round(mean_mess_ratio * 100, ndigits=3)) - # Preparing those fallbacks in case we got nothing. - if encoding_iana in ["ascii", "utf_8"]: - fallback_entry = CharsetMatch( - sequences, - encoding_iana, - threshold, - False, - [], - decoded_payload - ) - if encoding_iana == "ascii": - fallback_ascii = fallback_entry - else: - fallback_u8 = fallback_entry - continue - - logger.info( - '%s passed initial chaos probing. Mean measured chaos is %f %%', - encoding_iana, - round(mean_mess_ratio * 100, ndigits=3) - ) - - if not is_multi_byte_decoder: - target_languages = encoding_languages(encoding_iana) # type: List[str] - else: - target_languages = mb_encoding_languages(encoding_iana) - - if target_languages: - logger.info("{} should target any language(s) of {}".format(encoding_iana, str(target_languages))) - - cd_ratios = [] - - for chunk in md_chunks: - chunk_languages = coherence_ratio(chunk, 0.1, ",".join(target_languages) if target_languages else None) - - cd_ratios.append( - chunk_languages - ) - - cd_ratios_merged = merge_coherence_ratios(cd_ratios) - - if cd_ratios_merged: - logger.info("We detected language {} using {}".format(cd_ratios_merged, encoding_iana)) - - results.append( - CharsetMatch( - sequences, - encoding_iana, - mean_mess_ratio, - bom_or_sig_available, - cd_ratios_merged, - decoded_payload - ) - ) - - if encoding_iana in [specified_encoding, "ascii", "utf_8"] and mean_mess_ratio < 0.1: - logger.info("%s is most likely the one. Stopping the process.", encoding_iana) - return CharsetMatches( - [results[encoding_iana]] - ) - - if encoding_iana == sig_encoding: - logger.info( - "%s is most likely the one as we detected a BOM or SIG within the beginning of the sequence.", - encoding_iana - ) - return CharsetMatches( - [results[encoding_iana]] - ) - - if results[-1].languages: - logger.info( - "Using %s code page we detected the following languages: %s", - encoding_iana, - results[-1]._languages - ) - - if len(results) == 0: - if fallback_u8 or fallback_ascii: - logger.warning("Nothing got out of the detection process. Using ASCII/UTF-8 fallback.") - - if (fallback_u8 and fallback_ascii is None) or (fallback_u8 and fallback_u8.fingerprint != fallback_ascii.fingerprint): - logger.warning("utf_8 will be used as a fallback match") - results.append(fallback_u8) - elif fallback_ascii: - logger.warning("ascii will be used as a fallback match") - results.append(fallback_ascii) - - return results - - -def from_fp( - fp: BinaryIO, - steps: int = 5, - chunk_size: int = 512, - threshold: float = 0.20, - cp_isolation: List[str] = None, - cp_exclusion: List[str] = None, - preemptive_behaviour: bool = True, - explain: bool = False -) -> CharsetMatches: - """ - Same thing than the function from_bytes but using a file pointer that is already ready. - Will not close the file pointer. - """ - return from_bytes( - fp.read(), - steps, - chunk_size, - threshold, - cp_isolation, - cp_exclusion, - preemptive_behaviour, - explain - ) - - -def from_path( - path: PathLike, - steps: int = 5, - chunk_size: int = 512, - threshold: float = 0.20, - cp_isolation: List[str] = None, - cp_exclusion: List[str] = None, - preemptive_behaviour: bool = True, - explain: bool = False -) -> CharsetMatches: - """ - Same thing than the function from_bytes but with one extra step. Opening and reading given file path in binary mode. - Can raise IOError. - """ - with open(path, 'rb') as fp: - return from_fp(fp, steps, chunk_size, threshold, cp_isolation, cp_exclusion, preemptive_behaviour, explain) - - -def normalize(path: PathLike, steps: int = 5, chunk_size: int = 512, threshold: float = 0.20, cp_isolation: List[str] = None, cp_exclusion: List[str] = None, preemptive_behaviour: bool = True) -> CharsetMatch: - """ - Take a (text-based) file path and try to create another file next to it, this time using UTF-8. - """ - results = from_path( - path, - steps, - chunk_size, - threshold, - cp_isolation, - cp_exclusion, - preemptive_behaviour - ) - - filename = basename(path) - target_extensions = list(splitext(filename)) - - if len(results) == 0: - raise IOError('Unable to normalize "{}", no encoding charset seems to fit.'.format(filename)) - - result = results.best() - - target_extensions[0] += '-' + result.encoding # type: ignore - - with open('{}'.format(path.replace(filename, ''.join(target_extensions))), 'wb') as fp: - fp.write( - result.output() # type: ignore - ) - - return result # type: ignore diff --git a/venv/lib/python3.8/site-packages/charset_normalizer/assets/__init__.py b/venv/lib/python3.8/site-packages/charset_normalizer/assets/__init__.py deleted file mode 100644 index 2d93773..0000000 --- a/venv/lib/python3.8/site-packages/charset_normalizer/assets/__init__.py +++ /dev/null @@ -1,52 +0,0 @@ -""" -This submodule purpose is to load attached JSON asset. -Will be loaded once per package import / python init. - -The file 'frequencies.json' is mandatory for language/coherence detection. Not having it will weaker considerably -the core detection. -""" -from collections import OrderedDict - - -FREQUENCIES = OrderedDict( - [ - ('English', ['e', 'a', 't', 'i', 'o', 'n', 's', 'r', 'h', 'l', 'd', 'c', 'u', 'm', 'f', 'p', 'g', 'w', 'y', 'b', 'v', 'k', 'x', 'j', 'z', 'q']), - ('German', ['e', 'n', 'i', 'r', 's', 't', 'a', 'd', 'h', 'u', 'l', 'g', 'o', 'c', 'm', 'b', 'f', 'k', 'w', 'z', 'p', 'v', 'ü', 'ä', 'ö', 'j']), - ('French', ['e', 'a', 's', 'n', 'i', 't', 'r', 'l', 'u', 'o', 'd', 'c', 'p', 'm', 'é', 'v', 'g', 'f', 'b', 'h', 'q', 'à', 'x', 'è', 'y', 'j']), - ('Dutch', ['e', 'n', 'a', 'i', 'r', 't', 'o', 'd', 's', 'l', 'g', 'h', 'v', 'm', 'u', 'k', 'c', 'p', 'b', 'w', 'j', 'z', 'f', 'y', 'x', 'ë']), - ('Italian', ['e', 'i', 'a', 'o', 'n', 'l', 't', 'r', 's', 'c', 'd', 'u', 'p', 'm', 'g', 'v', 'f', 'b', 'z', 'h', 'q', 'è', 'à', 'k', 'y', 'ò']), - ('Polish', ['a', 'i', 'o', 'e', 'n', 'r', 'z', 'w', 's', 'c', 't', 'k', 'y', 'd', 'p', 'm', 'u', 'l', 'j', 'ł', 'g', 'b', 'h', 'ą', 'ę', 'ó']), - ('Spanish', ['e', 'a', 'o', 'n', 's', 'r', 'i', 'l', 'd', 't', 'c', 'u', 'm', 'p', 'b', 'g', 'v', 'f', 'y', 'ó', 'h', 'q', 'í', 'j', 'z', 'á']), - ('Russian', ['о', 'а', 'е', 'и', 'н', 'с', 'т', 'р', 'в', 'л', 'к', 'м', 'д', 'п', 'у', 'г', 'я', 'ы', 'з', 'б', 'й', 'ь', 'ч', 'х', 'ж', 'ц']), - ('Japanese', ['の', 'に', 'る', 'た', 'は', 'ー', 'と', 'し', 'を', 'で', 'て', 'が', 'い', 'ン', 'れ', 'な', '年', 'ス', 'っ', 'ル', 'か', 'ら', 'あ', 'さ', 'も', 'り']), - ('Portuguese', ['a', 'e', 'o', 's', 'i', 'r', 'd', 'n', 't', 'm', 'u', 'c', 'l', 'p', 'g', 'v', 'b', 'f', 'h', 'ã', 'q', 'é', 'ç', 'á', 'z', 'í']), - ('Swedish', ['e', 'a', 'n', 'r', 't', 's', 'i', 'l', 'd', 'o', 'm', 'k', 'g', 'v', 'h', 'f', 'u', 'p', 'ä', 'c', 'b', 'ö', 'å', 'y', 'j', 'x']), - ('Chinese', ['的', '一', '是', '不', '了', '在', '人', '有', '我', '他', '这', '个', '们', '中', '来', '上', '大', '为', '和', '国', '地', '到', '以', '说', '时', '要', '就', '出', '会']), - ('Ukrainian', ['о', 'а', 'н', 'і', 'и', 'р', 'в', 'т', 'е', 'с', 'к', 'л', 'у', 'д', 'м', 'п', 'з', 'я', 'ь', 'б', 'г', 'й', 'ч', 'х', 'ц', 'ї']), - ('Norwegian', ['e', 'r', 'n', 't', 'a', 's', 'i', 'o', 'l', 'd', 'g', 'k', 'm', 'v', 'f', 'p', 'u', 'b', 'h', 'å', 'y', 'j', 'ø', 'c', 'æ', 'w']), - ('Finnish', ['a', 'i', 'n', 't', 'e', 's', 'l', 'o', 'u', 'k', 'ä', 'm', 'r', 'v', 'j', 'h', 'p', 'y', 'd', 'ö', 'g', 'c', 'b', 'f', 'w', 'z']), - ('Vietnamese', ['n', 'h', 't', 'i', 'c', 'g', 'a', 'o', 'u', 'm', 'l', 'r', 'à', 'đ', 's', 'e', 'v', 'p', 'b', 'y', 'ư', 'd', 'á', 'k', 'ộ', 'ế']), - ('Czech', ['o', 'e', 'a', 'n', 't', 's', 'i', 'l', 'v', 'r', 'k', 'd', 'u', 'm', 'p', 'í', 'c', 'h', 'z', 'á', 'y', 'j', 'b', 'ě', 'é', 'ř']), - ('Hungarian', ['e', 'a', 't', 'l', 's', 'n', 'k', 'r', 'i', 'o', 'z', 'á', 'é', 'g', 'm', 'b', 'y', 'v', 'd', 'h', 'u', 'p', 'j', 'ö', 'f', 'c']), - ('Korean', ['이', '다', '에', '의', '는', '로', '하', '을', '가', '고', '지', '서', '한', '은', '기', '으', '년', '대', '사', '시', '를', '리', '도', '인', '스', '일']), - ('Indonesian', ['a', 'n', 'e', 'i', 'r', 't', 'u', 's', 'd', 'k', 'm', 'l', 'g', 'p', 'b', 'o', 'h', 'y', 'j', 'c', 'w', 'f', 'v', 'z', 'x', 'q']), - ('Turkish', ['a', 'e', 'i', 'n', 'r', 'l', 'ı', 'k', 'd', 't', 's', 'm', 'y', 'u', 'o', 'b', 'ü', 'ş', 'v', 'g', 'z', 'h', 'c', 'p', 'ç', 'ğ']), - ('Romanian', ['e', 'i', 'a', 'r', 'n', 't', 'u', 'l', 'o', 'c', 's', 'd', 'p', 'm', 'ă', 'f', 'v', 'î', 'g', 'b', 'ș', 'ț', 'z', 'h', 'â', 'j']), - ('Farsi', ['ا', 'ی', 'ر', 'د', 'ن', 'ه', 'و', 'م', 'ت', 'ب', 'س', 'ل', 'ک', 'ش', 'ز', 'ف', 'گ', 'ع', 'خ', 'ق', 'ج', 'آ', 'پ', 'ح', 'ط', 'ص']), - ('Arabic', ['ا', 'ل', 'ي', 'م', 'و', 'ن', 'ر', 'ت', 'ب', 'ة', 'ع', 'د', 'س', 'ف', 'ه', 'ك', 'ق', 'أ', 'ح', 'ج', 'ش', 'ط', 'ص', 'ى', 'خ', 'إ']), - ('Danish', ['e', 'r', 'n', 't', 'a', 'i', 's', 'd', 'l', 'o', 'g', 'm', 'k', 'f', 'v', 'u', 'b', 'h', 'p', 'å', 'y', 'ø', 'æ', 'c', 'j', 'w']), - ('Serbian', ['а', 'и', 'о', 'е', 'н', 'р', 'с', 'у', 'т', 'к', 'ј', 'в', 'д', 'м', 'п', 'л', 'г', 'з', 'б', 'a', 'i', 'e', 'o', 'n', 'ц', 'ш']), - ('Lithuanian', ['i', 'a', 's', 'o', 'r', 'e', 't', 'n', 'u', 'k', 'm', 'l', 'p', 'v', 'd', 'j', 'g', 'ė', 'b', 'y', 'ų', 'š', 'ž', 'c', 'ą', 'į']), - ('Slovene', ['e', 'a', 'i', 'o', 'n', 'r', 's', 'l', 't', 'j', 'v', 'k', 'd', 'p', 'm', 'u', 'z', 'b', 'g', 'h', 'č', 'c', 'š', 'ž', 'f', 'y']), - ('Slovak', ['o', 'a', 'e', 'n', 'i', 'r', 'v', 't', 's', 'l', 'k', 'd', 'm', 'p', 'u', 'c', 'h', 'j', 'b', 'z', 'á', 'y', 'ý', 'í', 'č', 'é']), - ('Hebrew', ['י', 'ו', 'ה', 'ל', 'ר', 'ב', 'ת', 'מ', 'א', 'ש', 'נ', 'ע', 'ם', 'ד', 'ק', 'ח', 'פ', 'ס', 'כ', 'ג', 'ט', 'צ', 'ן', 'ז', 'ך']), - ('Bulgarian', ['а', 'и', 'о', 'е', 'н', 'т', 'р', 'с', 'в', 'л', 'к', 'д', 'п', 'м', 'з', 'г', 'я', 'ъ', 'у', 'б', 'ч', 'ц', 'й', 'ж', 'щ', 'х']), - ('Croatian', ['a', 'i', 'o', 'e', 'n', 'r', 'j', 's', 't', 'u', 'k', 'l', 'v', 'd', 'm', 'p', 'g', 'z', 'b', 'c', 'č', 'h', 'š', 'ž', 'ć', 'f']), - ('Hindi', ['क', 'र', 'स', 'न', 'त', 'म', 'ह', 'प', 'य', 'ल', 'व', 'ज', 'द', 'ग', 'ब', 'श', 'ट', 'अ', 'ए', 'थ', 'भ', 'ड', 'च', 'ध', 'ष', 'इ']), - ('Estonian', ['a', 'i', 'e', 's', 't', 'l', 'u', 'n', 'o', 'k', 'r', 'd', 'm', 'v', 'g', 'p', 'j', 'h', 'ä', 'b', 'õ', 'ü', 'f', 'c', 'ö', 'y']), - ('Simple English', ['e', 'a', 't', 'i', 'o', 'n', 's', 'r', 'h', 'l', 'd', 'c', 'm', 'u', 'f', 'p', 'g', 'w', 'b', 'y', 'v', 'k', 'j', 'x', 'z', 'q']), - ('Thai', ['า', 'น', 'ร', 'อ', 'ก', 'เ', 'ง', 'ม', 'ย', 'ล', 'ว', 'ด', 'ท', 'ส', 'ต', 'ะ', 'ป', 'บ', 'ค', 'ห', 'แ', 'จ', 'พ', 'ช', 'ข', 'ใ']), - ('Greek', ['α', 'τ', 'ο', 'ι', 'ε', 'ν', 'ρ', 'σ', 'κ', 'η', 'π', 'ς', 'υ', 'μ', 'λ', 'ί', 'ό', 'ά', 'γ', 'έ', 'δ', 'ή', 'ω', 'χ', 'θ', 'ύ']), - ('Tamil', ['க', 'த', 'ப', 'ட', 'ர', 'ம', 'ல', 'ன', 'வ', 'ற', 'ய', 'ள', 'ச', 'ந', 'இ', 'ண', 'அ', 'ஆ', 'ழ', 'ங', 'எ', 'உ', 'ஒ', 'ஸ']), - ('Classical Chinese', ['之', '年', '為', '也', '以', '一', '人', '其', '者', '國', '有', '二', '十', '於', '曰', '三', '不', '大', '而', '子', '中', '五', '四'])] -) diff --git a/venv/lib/python3.8/site-packages/charset_normalizer/assets/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/charset_normalizer/assets/__pycache__/__init__.cpython-38.pyc deleted file mode 100644 index 8a10fe2976f6f87e466cd70b8d0d2d76d65d8b47..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6042 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 BN-F>W diff --git a/venv/lib/python3.8/site-packages/charset_normalizer/cd.py b/venv/lib/python3.8/site-packages/charset_normalizer/cd.py deleted file mode 100644 index c4fc1ba..0000000 --- a/venv/lib/python3.8/site-packages/charset_normalizer/cd.py +++ /dev/null @@ -1,261 +0,0 @@ -from codecs import IncrementalDecoder -from functools import lru_cache -from typing import List, Set, Optional, Tuple, Dict -import importlib - -from charset_normalizer.models import CoherenceMatches -from charset_normalizer.utils import unicode_range, is_unicode_range_secondary, is_multi_byte_encoding -from charset_normalizer.md import is_suspiciously_successive_range -from charset_normalizer.assets import FREQUENCIES -from collections import Counter - - -def encoding_unicode_range(iana_name: str) -> List[str]: - """ - Return associated unicode ranges in a single byte code page. - """ - if is_multi_byte_encoding(iana_name): - raise IOError("Function not supported on multi-byte code page") - - decoder = importlib.import_module('encodings.{}'.format(iana_name)).IncrementalDecoder # type: ignore - - p = decoder(errors="ignore") # type: IncrementalDecoder - seen_ranges = set() # type: Set[str] - - for i in range(48, 255): - chunk = p.decode( - bytes([i]) - ) # type: str - - if chunk: - character_range = unicode_range(chunk) # type: Optional[str] - - if character_range is None: - continue - - if is_unicode_range_secondary(character_range) is False: - seen_ranges.add(character_range) - - return sorted(list(seen_ranges)) - - -def unicode_range_languages(primary_range: str) -> List[str]: - """ - Return inferred languages used with a unicode range. - """ - languages = [] # type: List[str] - - for language, characters in FREQUENCIES.items(): - for character in characters: - if unicode_range(character) == primary_range: - languages.append(language) - break - - return languages - - -@lru_cache() -def encoding_languages(iana_name: str) -> List[str]: - """ - Single-byte encoding language association. Some code page are heavily linked to particular language(s). - This function does the correspondence. - """ - unicode_ranges = encoding_unicode_range(iana_name) # type: List[str] - primary_range = None # type: Optional[str] - - for specified_range in unicode_ranges: - if "Latin" not in specified_range: - primary_range = specified_range - break - - if primary_range is None: - return ["Latin Based"] - - return unicode_range_languages(primary_range) - - -def mb_encoding_languages(iana_name: str) -> List[str]: - """ - Multi-byte encoding language association. Some code page are heavily linked to particular language(s). - This function does the correspondence. - """ - if iana_name.startswith("shift_") or iana_name.startswith("iso2022_jp") or iana_name.startswith("euc_j") or iana_name in {"cp932"}: - return ["Japanese"] - if iana_name.startswith("gb") or iana_name in {"big5", "cp950", "big5hkscs"}: - return ["Chinese", "Classical Chinese"] - if iana_name.startswith("iso2022_kr") or iana_name in {"johab", "cp949", "euc_kr"}: - return ["Korean"] - - return [] - - -def alphabet_languages(characters: List[str]) -> List[str]: - """ - Return associated languages associated to given characters. - """ - languages = [] # type: List[str] - - for language, language_characters in FREQUENCIES.items(): - character_match_count = 0 # type: int - character_count = len(language_characters) # type: int - - for character in language_characters: - if character in characters: - character_match_count += 1 - - if character_match_count / character_count >= 0.2: - languages.append(language) - - return languages - - -def characters_popularity_compare(language: str, ordered_characters: List[str]) -> float: - """ - Determine if a ordered characters list (by occurrence from most appearance to rarest) match a particular language. - The result is a ratio between 0. (absolutely no correspondence) and 1. (near perfect fit). - Beware that is function is not strict on the match in order to ease the detection. (Meaning close match is 1.) - """ - if language not in FREQUENCIES: - raise ValueError("{} not available".format(language)) - - character_approved_count = 0 # type: int - - for character in ordered_characters: - if character not in FREQUENCIES[language]: - continue - - characters_before_source = FREQUENCIES[language][0:FREQUENCIES[language].index(character)] # type: List[str] - characters_after_source = FREQUENCIES[language][FREQUENCIES[language].index(character):] # type: List[str] - - characters_before = ordered_characters[0:ordered_characters.index(character)] # type: List[str] - characters_after = ordered_characters[ordered_characters.index(character):] # type: List[str] - - before_match_count = [e in characters_before for e in characters_before_source].count(True) # type: int - after_match_count = [e in characters_after for e in characters_after_source].count(True) # type: int - - if len(characters_before_source) == 0 and before_match_count <= 4: - character_approved_count += 1 - continue - - if len(characters_after_source) == 0 and after_match_count <= 4: - character_approved_count += 1 - continue - - if before_match_count / len(characters_before_source) >= 0.4 or after_match_count / len(characters_after_source) >= 0.4: - character_approved_count += 1 - continue - - return character_approved_count / len(ordered_characters) - - -def alpha_unicode_split(decoded_sequence: str) -> List[str]: - """ - Given a decoded text sequence, return a list of str. Unicode range / alphabet separation. - Ex. a text containing English/Latin with a bit a Hebrew will return two items in the resulting list; - One containing the latin letters and the other hebrew. - """ - layers = {} # type: Dict[str, str] - - for character in decoded_sequence: - if character.isalpha() is False: - continue - - character_range = unicode_range(character) # type: str - - layer_target_range = None # type: Optional[str] - - for discovered_range in layers: - if is_suspiciously_successive_range(discovered_range, character_range) is False: - layer_target_range = discovered_range - break - - if layer_target_range is None: - layer_target_range = character_range - - if layer_target_range not in layers: - layers[layer_target_range] = character.lower() - continue - - layers[layer_target_range] += character.lower() - - return list(layers.values()) - - -def merge_coherence_ratios(results: List[CoherenceMatches]) -> CoherenceMatches: - """ - This function merge results previously given by the function coherence_ratio. - The return type is the same as coherence_ratio. - """ - per_language_ratios = {} # type: Dict[str, List[float]] - merge = [] # type: CoherenceMatches - - for result in results: - for sub_result in result: - language, ratio = sub_result - if language not in per_language_ratios: - per_language_ratios[language] = [ratio] - continue - per_language_ratios[language].append( - ratio - ) - - for language in per_language_ratios: - merge.append( - ( - language, - round( - sum( - per_language_ratios[language] - ) / len(per_language_ratios[language]), - 4 - ) - ) - ) - - return sorted(merge, key=lambda x: x[1], reverse=True) - - -@lru_cache(maxsize=2048) -def coherence_ratio(decoded_sequence: str, threshold: float = 0.1, lg_inclusion: Optional[str] = None) -> CoherenceMatches: - """ - Detect ANY language that can be identified in given sequence. The sequence will be analysed by layers. - A layer = Character extraction by alphabets/ranges. - """ - - results = [] # type: List[Tuple[str, float]] - - sufficient_match_count = 0 # type: int - - if lg_inclusion is not None: - lg_inclusion = lg_inclusion.split(",") - - if lg_inclusion is not None and "Latin Based" in lg_inclusion: - lg_inclusion.remove("Latin Based") - - for layer in alpha_unicode_split(decoded_sequence): - sequence_frequencies = Counter(layer) # type: Counter - most_common = sequence_frequencies.most_common() - - character_count = sum([o for c, o in most_common]) # type: int - - if character_count <= 32: - continue - - popular_character_ordered = [c for c, o in most_common] # type: List[str] - - for language in lg_inclusion or alphabet_languages(popular_character_ordered): - ratio = characters_popularity_compare(language, popular_character_ordered) # type: float - - if ratio < threshold: - continue - elif ratio >= 0.8: - sufficient_match_count += 1 - - results.append( - (language, round(ratio, 4)) - ) - - if sufficient_match_count >= 3: - break - - return sorted(results, key=lambda x: x[1], reverse=True) diff --git a/venv/lib/python3.8/site-packages/charset_normalizer/cli/__init__.py b/venv/lib/python3.8/site-packages/charset_normalizer/cli/__init__.py deleted file mode 100644 index e69de29..0000000 diff --git a/venv/lib/python3.8/site-packages/charset_normalizer/cli/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/charset_normalizer/cli/__pycache__/__init__.cpython-38.pyc deleted file mode 100644 index 023eb07522e7672c786b227373d29ec05eb860ac..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 158 zcmWIL<>g`kf(lF3L=gQLL?8o3AjbiSi&=m~3PUi1CZpd%JwC diff --git a/venv/lib/python3.8/site-packages/charset_normalizer/cli/__pycache__/normalizer.cpython-38.pyc b/venv/lib/python3.8/site-packages/charset_normalizer/cli/__pycache__/normalizer.cpython-38.pyc deleted file mode 100644 index 2c0780cd98a389a9141e33277fb59e9568102d0c..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 5765 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. - It must be "yes" (the default), "no" or None (meaning - an answer is required of the user). - - The "answer" return value is True for "yes" or False for "no". - - Credit goes to (c) https://stackoverflow.com/questions/3041986/apt-command-line-interface-like-yes-no-input - """ - valid = {"yes": True, "y": True, "ye": True, - "no": False, "n": False} - if default is None: - prompt = " [y/n] " - elif default == "yes": - prompt = " [Y/n] " - elif default == "no": - prompt = " [y/N] " - else: - raise ValueError("invalid default answer: '%s'" % default) - - while True: - sys.stdout.write(question + prompt) - choice = input().lower() - if default is not None and choice == '': - return valid[default] - elif choice in valid: - return valid[choice] - else: - sys.stdout.write("Please respond with 'yes' or 'no' " - "(or 'y' or 'n').\n") - - -def cli_detect(argv=None): - """ - CLI assistant using ARGV and ArgumentParser - :param argv: - :return: 0 if everything is fine, anything else equal trouble - """ - parser = argparse.ArgumentParser( - description="The Real First Universal Charset Detector. " - "Discover originating encoding used on text file. " - "Normalize text to unicode." - ) - - parser.add_argument('files', type=argparse.FileType('rb'), nargs='+', help='File(s) to be analysed') - parser.add_argument('-v', '--verbose', action="store_true", default=False, dest='verbose', - help='Display complementary information about file if any. Stdout will contain logs about the detection process.') - parser.add_argument('-a', '--with-alternative', action="store_true", default=False, dest='alternatives', - help='Output complementary possibilities if any. Top-level JSON WILL be a list.') - parser.add_argument('-n', '--normalize', action="store_true", default=False, dest='normalize', - help='Permit to normalize input file. If not set, program does not write anything.') - parser.add_argument('-m', '--minimal', action="store_true", default=False, dest='minimal', - help='Only output the charset detected to STDOUT. Disabling JSON output.') - parser.add_argument('-r', '--replace', action="store_true", default=False, dest='replace', - help='Replace file when trying to normalize it instead of creating a new one.') - parser.add_argument('-f', '--force', action="store_true", default=False, dest='force', - help='Replace file without asking if you are sure, use this flag with caution.') - parser.add_argument('-t', '--threshold', action="store", default=0.1, type=float, dest='threshold', - help="Define a custom maximum amount of chaos allowed in decoded content. 0. <= chaos <= 1.") - parser.add_argument( - "--version", - action="version", - version="Charset-Normalizer {} - Python {}".format(__version__, python_version()), - help="Show version information and exit." - ) - - args = parser.parse_args(argv) - - if args.replace is True and args.normalize is False: - print('Use --replace in addition of --normalize only.', file=sys.stderr) - return 1 - - if args.force is True and args.replace is False: - print('Use --force in addition of --replace only.', file=sys.stderr) - return 1 - - if args.threshold < 0. or args.threshold > 1.: - print('--threshold VALUE should be between 0. AND 1.', file=sys.stderr) - return 1 - - for my_file in args.files: - - matches = from_fp( - my_file, - threshold=args.threshold, - explain=args.verbose - ) - - if len(matches) == 0: - print('Unable to identify originating encoding for "{}". {}'.format(my_file.name, 'Maybe try increasing maximum amount of chaos.' if args.threshold < 1. else ''), file=sys.stderr) - if my_file.closed is False: - my_file.close() - continue - - x_ = [] - - r_ = matches.best() - p_ = r_.first() - - x_.append( - CliDetectionResult( - abspath(my_file.name), - p_.encoding, - p_.encoding_aliases, - [cp for cp in p_.could_be_from_charset if cp != p_.encoding], - p_.language, - p_.alphabets, - p_.bom, - p_.percent_chaos, - p_.percent_coherence, - None, - True - ) - ) - - if len(matches) > 1 and args.alternatives: - for el in matches: - if el != p_: - x_.append( - CliDetectionResult( - abspath(my_file.name), - el.encoding, - el.encoding_aliases, - [cp for cp in el.could_be_from_charset if cp != el.encoding], - el.language, - el.alphabets, - el.bom, - el.percent_chaos, - el.percent_coherence, - None, - False - ) - ) - - if args.normalize is True: - - if p_.encoding.startswith('utf') is True: - print('"{}" file does not need to be normalized, as it already came from unicode.'.format(my_file.name), file=sys.stderr) - if my_file.closed is False: - my_file.close() - continue - - o_ = my_file.name.split('.') # type: list[str] - - if args.replace is False: - o_.insert(-1, p_.encoding) - if my_file.closed is False: - my_file.close() - else: - if args.force is False and query_yes_no( - 'Are you sure to normalize "{}" by replacing it ?'.format(my_file.name), 'no') is False: - if my_file.closed is False: - my_file.close() - continue - - try: - x_[0].unicode_path = './{}'.format('.'.join(o_)) - - with open(x_[0].unicode_path, 'w', encoding='utf-8') as fp: - fp.write( - str(p_) - ) - except IOError as e: - print(str(e), file=sys.stderr) - if my_file.closed is False: - my_file.close() - return 2 - - if my_file.closed is False: - my_file.close() - - if args.minimal is False: - print( - dumps( - [ - el.__dict__ for el in x_ - ] if args.alternatives else x_[0].__dict__, - ensure_ascii=True, - indent=4 - ) - ) - else: - print( - ', '.join( - [ - el.encoding for el in x_ - ] - ) - ) - - return 0 - - -if __name__ == '__main__': - cli_detect() diff --git a/venv/lib/python3.8/site-packages/charset_normalizer/constant.py b/venv/lib/python3.8/site-packages/charset_normalizer/constant.py deleted file mode 100644 index c9c9655..0000000 --- a/venv/lib/python3.8/site-packages/charset_normalizer/constant.py +++ /dev/null @@ -1,343 +0,0 @@ -from codecs import BOM_UTF8, BOM_UTF16_BE, BOM_UTF16_LE, BOM_UTF32_BE, BOM_UTF32_LE -from typing import Dict, List, Union -from encodings.aliases import aliases -from re import compile as re_compile, IGNORECASE -from collections import OrderedDict - -# Contain for each eligible encoding a list of/item bytes SIG/BOM -ENCODING_MARKS = OrderedDict([ - ('utf_8', BOM_UTF8), - ('utf_7', [ - b'\x2b\x2f\x76\x38', - b'\x2b\x2f\x76\x39', - b'\x2b\x2f\x76\x2b', - b'\x2b\x2f\x76\x2f', - b'\x2b\x2f\x76\x38\x2d' - ]), - ('gb18030', b'\x84\x31\x95\x33'), - ('utf_32', [ - BOM_UTF32_BE, - BOM_UTF32_LE - ]), - ('utf_16', [ - BOM_UTF16_BE, - BOM_UTF16_LE - ]), -]) # type: Dict[str, Union[bytes, List[bytes]]] - -TOO_SMALL_SEQUENCE = 32 # type: int -TOO_BIG_SEQUENCE = int(10e6) # type: int - -UTF8_MAXIMAL_ALLOCATION = 1112064 # type: int - -UNICODE_RANGES_COMBINED = {'Control character': range(0, 31+1), 'Basic Latin': range(32, 127+1), 'Latin-1 Supplement': range(128, 255+1), 'Latin Extended-A': range(256, 383+1), 'Latin Extended-B': range(384, 591+1), 'IPA Extensions': range(592, 687+1), 'Spacing Modifier Letters': range(688, 767+1), 'Combining Diacritical Marks': range(768, 879+1), 'Greek and Coptic': range(880, 1023+1), 'Cyrillic': range(1024, 1279+1), 'Cyrillic Supplement': range(1280, 1327+1), 'Armenian': range(1328, 1423+1), 'Hebrew': range(1424, 1535+1), 'Arabic': range(1536, 1791+1), 'Syriac': range(1792, 1871+1), 'Arabic Supplement': range(1872, 1919+1), 'Thaana': range(1920, 1983+1), 'NKo': range(1984, 2047+1), 'Samaritan': range(2048, 2111+1), 'Mandaic': range(2112, 2143+1), 'Syriac Supplement': range(2144, 2159+1), 'Arabic Extended-A': range(2208, 2303+1), 'Devanagari': range(2304, 2431+1), 'Bengali': range(2432, 2559+1), 'Gurmukhi': range(2560, 2687+1), 'Gujarati': range(2688, 2815+1), 'Oriya': range(2816, 2943+1), 'Tamil': range(2944, 3071+1), 'Telugu': range(3072, 3199+1), 'Kannada': range(3200, 3327+1), 'Malayalam': range(3328, 3455+1), 'Sinhala': range(3456, 3583+1), 'Thai': range(3584, 3711+1), 'Lao': range(3712, 3839+1), 'Tibetan': range(3840, 4095+1), 'Myanmar': range(4096, 4255+1), 'Georgian': range(4256, 4351+1), 'Hangul Jamo': range(4352, 4607+1), 'Ethiopic': range(4608, 4991+1), 'Ethiopic Supplement': range(4992, 5023+1), 'Cherokee': range(5024, 5119+1), 'Unified Canadian Aboriginal Syllabics': range(5120, 5759+1), 'Ogham': range(5760, 5791+1), 'Runic': range(5792, 5887+1), 'Tagalog': range(5888, 5919+1), 'Hanunoo': range(5920, 5951+1), 'Buhid': range(5952, 5983+1), 'Tagbanwa': range(5984, 6015+1), 'Khmer': range(6016, 6143+1), 'Mongolian': range(6144, 6319+1), 'Unified Canadian Aboriginal Syllabics Extended': range(6320, 6399+1), 'Limbu': range(6400, 6479+1), 'Tai Le': range(6480, 6527+1), 'New Tai Lue': range(6528, 6623+1), 'Khmer Symbols': range(6624, 6655+1), 'Buginese': range(6656, 6687+1), 'Tai Tham': range(6688, 6831+1), 'Combining Diacritical Marks Extended': range(6832, 6911+1), 'Balinese': range(6912, 7039+1), 'Sundanese': range(7040, 7103+1), 'Batak': range(7104, 7167+1), 'Lepcha': range(7168, 7247+1), 'Ol Chiki': range(7248, 7295+1), 'Cyrillic Extended C': range(7296, 7311+1), 'Sundanese Supplement': range(7360, 7375+1), 'Vedic Extensions': range(7376, 7423+1), 'Phonetic Extensions': range(7424, 7551+1), 'Phonetic Extensions Supplement': range(7552, 7615+1), 'Combining Diacritical Marks Supplement': range(7616, 7679+1), 'Latin Extended Additional': range(7680, 7935+1), 'Greek Extended': range(7936, 8191+1), 'General Punctuation': range(8192, 8303+1), 'Superscripts and Subscripts': range(8304, 8351+1), 'Currency Symbols': range(8352, 8399+1), 'Combining Diacritical Marks for Symbols': range(8400, 8447+1), 'Letterlike Symbols': range(8448, 8527+1), 'Number Forms': range(8528, 8591+1), 'Arrows': range(8592, 8703+1), 'Mathematical Operators': range(8704, 8959+1), 'Miscellaneous Technical': range(8960, 9215+1), 'Control Pictures': range(9216, 9279+1), 'Optical Character Recognition': range(9280, 9311+1), 'Enclosed Alphanumerics': range(9312, 9471+1), 'Box Drawing': range(9472, 9599+1), 'Block Elements': range(9600, 9631+1), 'Geometric Shapes': range(9632, 9727+1), 'Miscellaneous Symbols': range(9728, 9983+1), 'Dingbats': range(9984, 10175+1), 'Miscellaneous Mathematical Symbols-A': range(10176, 10223+1), 'Supplemental Arrows-A': range(10224, 10239+1), 'Braille Patterns': range(10240, 10495+1), 'Supplemental Arrows-B': range(10496, 10623+1), 'Miscellaneous Mathematical Symbols-B': range(10624, 10751+1), 'Supplemental Mathematical Operators': range(10752, 11007+1), 'Miscellaneous Symbols and Arrows': range(11008, 11263+1), 'Glagolitic': range(11264, 11359+1), 'Latin Extended-C': range(11360, 11391+1), 'Coptic': range(11392, 11519+1), 'Georgian Supplement': range(11520, 11567+1), 'Tifinagh': range(11568, 11647+1), 'Ethiopic Extended': range(11648, 11743+1), 'Cyrillic Extended-A': range(11744, 11775+1), 'Supplemental Punctuation': range(11776, 11903+1), 'CJK Radicals Supplement': range(11904, 12031+1), 'Kangxi Radicals': range(12032, 12255+1), 'Ideographic Description Characters': range(12272, 12287+1), 'CJK Symbols and Punctuation': range(12288, 12351+1), 'Hiragana': range(12352, 12447+1), 'Katakana': range(12448, 12543+1), 'Bopomofo': range(12544, 12591+1), 'Hangul Compatibility Jamo': range(12592, 12687+1), 'Kanbun': range(12688, 12703+1), 'Bopomofo Extended': range(12704, 12735+1), 'CJK Strokes': range(12736, 12783+1), 'Katakana Phonetic Extensions': range(12784, 12799+1), 'Enclosed CJK Letters and Months': range(12800, 13055+1), 'CJK Compatibility': range(13056, 13311+1), 'CJK Unified Ideographs Extension A': range(13312, 19903+1), 'Yijing Hexagram Symbols': range(19904, 19967+1), 'CJK Unified Ideographs': range(19968, 40959+1), 'Yi Syllables': range(40960, 42127+1), 'Yi Radicals': range(42128, 42191+1), 'Lisu': range(42192, 42239+1), 'Vai': range(42240, 42559+1), 'Cyrillic Extended-B': range(42560, 42655+1), 'Bamum': range(42656, 42751+1), 'Modifier Tone Letters': range(42752, 42783+1), 'Latin Extended-D': range(42784, 43007+1), 'Syloti Nagri': range(43008, 43055+1), 'Common Indic Number Forms': range(43056, 43071+1), 'Phags-pa': range(43072, 43135+1), 'Saurashtra': range(43136, 43231+1), 'Devanagari Extended': range(43232, 43263+1), 'Kayah Li': range(43264, 43311+1), 'Rejang': range(43312, 43359+1), 'Hangul Jamo Extended-A': range(43360, 43391+1), 'Javanese': range(43392, 43487+1), 'Myanmar Extended-B': range(43488, 43519+1), 'Cham': range(43520, 43615+1), 'Myanmar Extended-A': range(43616, 43647+1), 'Tai Viet': range(43648, 43743+1), 'Meetei Mayek Extensions': range(43744, 43775+1), 'Ethiopic Extended-A': range(43776, 43823+1), 'Latin Extended-E': range(43824, 43887+1), 'Cherokee Supplement': range(43888, 43967+1), 'Meetei Mayek': range(43968, 44031+1), 'Hangul Syllables': range(44032, 55215+1), 'Hangul Jamo Extended-B': range(55216, 55295+1), 'High Surrogates': range(55296, 56191+1), 'High Private Use Surrogates': range(56192, 56319+1), 'Low Surrogates': range(56320, 57343+1), 'Private Use Area': range(57344, 63743+1), 'CJK Compatibility Ideographs': range(63744, 64255+1), 'Alphabetic Presentation Forms': range(64256, 64335+1), 'Arabic Presentation Forms-A': range(64336, 65023+1), 'Variation Selectors': range(65024, 65039+1), 'Vertical Forms': range(65040, 65055+1), 'Combining Half Marks': range(65056, 65071+1), 'CJK Compatibility Forms': range(65072, 65103+1), 'Small Form Variants': range(65104, 65135+1), 'Arabic Presentation Forms-B': range(65136, 65279+1), 'Halfwidth and Fullwidth Forms': range(65280, 65519+1), 'Specials': range(65520, 65535+1), 'Linear B Syllabary': range(65536, 65663+1), 'Linear B Ideograms': range(65664, 65791+1), 'Aegean Numbers': range(65792, 65855+1), 'Ancient Greek Numbers': range(65856, 65935+1), 'Ancient Symbols': range(65936, 65999+1), 'Phaistos Disc': range(66000, 66047+1), 'Lycian': range(66176, 66207+1), 'Carian': range(66208, 66271+1), 'Coptic Epact Numbers': range(66272, 66303+1), 'Old Italic': range(66304, 66351+1), 'Gothic': range(66352, 66383+1), 'Old Permic': range(66384, 66431+1), 'Ugaritic': range(66432, 66463+1), 'Old Persian': range(66464, 66527+1), 'Deseret': range(66560, 66639+1), 'Shavian': range(66640, 66687+1), 'Osmanya': range(66688, 66735+1), 'Osage': range(66736, 66815+1), 'Elbasan': range(66816, 66863+1), 'Caucasian Albanian': range(66864, 66927+1), 'Linear A': range(67072, 67455+1), 'Cypriot Syllabary': range(67584, 67647+1), 'Imperial Aramaic': range(67648, 67679+1), 'Palmyrene': range(67680, 67711+1), 'Nabataean': range(67712, 67759+1), 'Hatran': range(67808, 67839+1), 'Phoenician': range(67840, 67871+1), 'Lydian': range(67872, 67903+1), 'Meroitic Hieroglyphs': range(67968, 67999+1), 'Meroitic Cursive': range(68000, 68095+1), 'Kharoshthi': range(68096, 68191+1), 'Old South Arabian': range(68192, 68223+1), 'Old North Arabian': range(68224, 68255+1), 'Manichaean': range(68288, 68351+1), 'Avestan': range(68352, 68415+1), 'Inscriptional Parthian': range(68416, 68447+1), 'Inscriptional Pahlavi': range(68448, 68479+1), 'Psalter Pahlavi': range(68480, 68527+1), 'Old Turkic': range(68608, 68687+1), 'Old Hungarian': range(68736, 68863+1), 'Rumi Numeral Symbols': range(69216, 69247+1), 'Brahmi': range(69632, 69759+1), 'Kaithi': range(69760, 69839+1), 'Sora Sompeng': range(69840, 69887+1), 'Chakma': range(69888, 69967+1), 'Mahajani': range(69968, 70015+1), 'Sharada': range(70016, 70111+1), 'Sinhala Archaic Numbers': range(70112, 70143+1), 'Khojki': range(70144, 70223+1), 'Multani': range(70272, 70319+1), 'Khudawadi': range(70320, 70399+1), 'Grantha': range(70400, 70527+1), 'Newa': range(70656, 70783+1), 'Tirhuta': range(70784, 70879+1), 'Siddham': range(71040, 71167+1), 'Modi': range(71168, 71263+1), 'Mongolian Supplement': range(71264, 71295+1), 'Takri': range(71296, 71375+1), 'Ahom': range(71424, 71487+1), 'Warang Citi': range(71840, 71935+1), 'Zanabazar Square': range(72192, 72271+1), 'Soyombo': range(72272, 72367+1), 'Pau Cin Hau': range(72384, 72447+1), 'Bhaiksuki': range(72704, 72815+1), 'Marchen': range(72816, 72895+1), 'Masaram Gondi': range(72960, 73055+1), 'Cuneiform': range(73728, 74751+1), 'Cuneiform Numbers and Punctuation': range(74752, 74879+1), 'Early Dynastic Cuneiform': range(74880, 75087+1), 'Egyptian Hieroglyphs': range(77824, 78895+1), 'Anatolian Hieroglyphs': range(82944, 83583+1), 'Bamum Supplement': range(92160, 92735+1), 'Mro': range(92736, 92783+1), 'Bassa Vah': range(92880, 92927+1), 'Pahawh Hmong': range(92928, 93071+1), 'Miao': range(93952, 94111+1), 'Ideographic Symbols and Punctuation': range(94176, 94207+1), 'Tangut': range(94208, 100351+1), 'Tangut Components': range(100352, 101119+1), 'Kana Supplement': range(110592, 110847+1), 'Kana Extended-A': range(110848, 110895+1), 'Nushu': range(110960, 111359+1), 'Duployan': range(113664, 113823+1), 'Shorthand Format Controls': range(113824, 113839+1), 'Byzantine Musical Symbols': range(118784, 119039+1), 'Musical Symbols': range(119040, 119295+1), 'Ancient Greek Musical Notation': range(119296, 119375+1), 'Tai Xuan Jing Symbols': range(119552, 119647+1), 'Counting Rod Numerals': range(119648, 119679+1), 'Mathematical Alphanumeric Symbols': range(119808, 120831+1), 'Sutton SignWriting': range(120832, 121519+1), 'Glagolitic Supplement': range(122880, 122927+1), 'Mende Kikakui': range(124928, 125151+1), 'Adlam': range(125184, 125279+1), 'Arabic Mathematical Alphabetic Symbols': range(126464, 126719+1), 'Mahjong Tiles': range(126976, 127023+1), 'Domino Tiles': range(127024, 127135+1), 'Playing Cards': range(127136, 127231+1), 'Enclosed Alphanumeric Supplement': range(127232, 127487+1), 'Enclosed Ideographic Supplement': range(127488, 127743+1), 'Miscellaneous Symbols and Pictographs': range(127744, 128511+1), 'Emoticons range(Emoji)': range(128512, 128591+1), 'Ornamental Dingbats': range(128592, 128639+1), 'Transport and Map Symbols': range(128640, 128767+1), 'Alchemical Symbols': range(128768, 128895+1), 'Geometric Shapes Extended': range(128896, 129023+1), 'Supplemental Arrows-C': range(129024, 129279+1), 'Supplemental Symbols and Pictographs': range(129280, 129535+1), 'CJK Unified Ideographs Extension B': range(131072, 173791+1), 'CJK Unified Ideographs Extension C': range(173824, 177983+1), 'CJK Unified Ideographs Extension D': range(177984, 178207+1), 'CJK Unified Ideographs Extension E': range(178208, 183983+1), 'CJK Unified Ideographs Extension F': range(183984, 191471+1), 'CJK Compatibility Ideographs Supplement': range(194560, 195103+1), 'Tags': range(917504, 917631+1), 'Variation Selectors Supplement': range(917760, 917999+1)} # type: Dict[str, range] - -UNICODE_SECONDARY_RANGE_KEYWORD = [ - 'Supplement', - 'Extended', - 'Extensions', - 'Modifier', - 'Marks', - 'Punctuation', - 'Symbols', - 'Forms', - 'Operators', - 'Miscellaneous', - 'Drawing', - 'Block', - 'Shapes', - 'Supplemental', - 'Tags' -] # type: List[str] - -RE_POSSIBLE_ENCODING_INDICATION = re_compile( - r'(?:(?:encoding)|(?:charset)|(?:coding))(?:[\:= ]{1,10})(?:[\"\']?)([a-zA-Z0-9\-_]+)(?:[\"\']?)', - IGNORECASE -) - -IANA_SUPPORTED = sorted( - filter( - lambda x: x.endswith("_codec") is False and x not in {"rot_13", "tactis", "mbcs"}, - list(set(aliases.values())) - ) -) # type: List[str] - -IANA_SUPPORTED_COUNT = len(IANA_SUPPORTED) # type: int - -# pre-computed code page that are similar using the function cp_similarity. -IANA_SUPPORTED_SIMILAR = { - "cp037": [ - "cp1026", - "cp1140", - "cp273", - "cp500" - ], - "cp1026": [ - "cp037", - "cp1140", - "cp273", - "cp500" - ], - "cp1125": [ - "cp866" - ], - "cp1140": [ - "cp037", - "cp1026", - "cp273", - "cp500" - ], - "cp1250": [ - "iso8859_2" - ], - "cp1251": [ - "kz1048", - "ptcp154" - ], - "cp1252": [ - "cp1258", - "iso8859_15", - "iso8859_9", - "latin_1" - ], - "cp1253": [ - "iso8859_7" - ], - "cp1254": [ - "cp1258", - "iso8859_15", - "iso8859_9", - "latin_1" - ], - "cp1257": [ - "iso8859_13" - ], - "cp1258": [ - "cp1252", - "cp1254", - "iso8859_9", - "latin_1" - ], - "cp273": [ - "cp037", - "cp1026", - "cp1140", - "cp500" - ], - "cp437": [ - "cp850", - "cp858", - "cp860", - "cp861", - "cp862", - "cp863", - "cp865" - ], - "cp500": [ - "cp037", - "cp1026", - "cp1140", - "cp273" - ], - "cp850": [ - "cp437", - "cp857", - "cp858", - "cp865" - ], - "cp857": [ - "cp850", - "cp858", - "cp865" - ], - "cp858": [ - "cp437", - "cp850", - "cp857", - "cp865" - ], - "cp860": [ - "cp437", - "cp861", - "cp862", - "cp863", - "cp865" - ], - "cp861": [ - "cp437", - "cp860", - "cp862", - "cp863", - "cp865" - ], - "cp862": [ - "cp437", - "cp860", - "cp861", - "cp863", - "cp865" - ], - "cp863": [ - "cp437", - "cp860", - "cp861", - "cp862", - "cp865" - ], - "cp865": [ - "cp437", - "cp850", - "cp857", - "cp858", - "cp860", - "cp861", - "cp862", - "cp863" - ], - "cp866": [ - "cp1125" - ], - "iso8859_10": [ - "iso8859_14", - "iso8859_15", - "iso8859_4", - "iso8859_9", - "latin_1" - ], - "iso8859_11": [ - "tis_620" - ], - "iso8859_13": [ - "cp1257" - ], - "iso8859_14": [ - "iso8859_10", - "iso8859_15", - "iso8859_16", - "iso8859_3", - "iso8859_9", - "latin_1" - ], - "iso8859_15": [ - "cp1252", - "cp1254", - "iso8859_10", - "iso8859_14", - "iso8859_16", - "iso8859_3", - "iso8859_9", - "latin_1" - ], - "iso8859_16": [ - "iso8859_14", - "iso8859_15", - "iso8859_2", - "iso8859_3", - "iso8859_9", - "latin_1" - ], - "iso8859_2": [ - "cp1250", - "iso8859_16", - "iso8859_4" - ], - "iso8859_3": [ - "iso8859_14", - "iso8859_15", - "iso8859_16", - "iso8859_9", - "latin_1" - ], - "iso8859_4": [ - "iso8859_10", - "iso8859_2", - "iso8859_9", - "latin_1" - ], - "iso8859_7": [ - "cp1253" - ], - "iso8859_9": [ - "cp1252", - "cp1254", - "cp1258", - "iso8859_10", - "iso8859_14", - "iso8859_15", - "iso8859_16", - "iso8859_3", - "iso8859_4", - "latin_1" - ], - "kz1048": [ - "cp1251", - "ptcp154" - ], - "latin_1": [ - "cp1252", - "cp1254", - "cp1258", - "iso8859_10", - "iso8859_14", - "iso8859_15", - "iso8859_16", - "iso8859_3", - "iso8859_4", - "iso8859_9" - ], - "mac_iceland": [ - "mac_roman", - "mac_turkish" - ], - "mac_roman": [ - "mac_iceland", - "mac_turkish" - ], - "mac_turkish": [ - "mac_iceland", - "mac_roman" - ], - "ptcp154": [ - "cp1251", - "kz1048" - ], - "tis_620": [ - "iso8859_11" - ] -} # type: Dict[str, List[str]] - - -CHARDET_CORRESPONDENCE = { - 'iso2022_kr': 'ISO-2022-KR', - 'iso2022_jp': 'ISO-2022-JP', - 'euc_kr': 'EUC-KR', - 'tis_620': 'TIS-620', - 'utf_32': 'UTF-32', - 'euc_jp': 'EUC-JP', - 'koi8_r': 'KOI8-R', - 'iso8859_1': 'ISO-8859-1', - 'iso8859_2': 'ISO-8859-2', - 'iso8859_5': 'ISO-8859-5', - 'iso8859_6': 'ISO-8859-6', - 'iso8859_7': 'ISO-8859-7', - 'iso8859_8': 'ISO-8859-8', - 'utf_16': 'UTF-16', - 'cp855': 'IBM855', - 'mac_cyrillic': 'MacCyrillic', - 'gb2312': 'GB2312', - 'gb18030': 'GB18030', - 'cp932': 'CP932', - 'cp866': 'IBM866', - 'utf_8': 'utf-8', - 'utf_8_sig': 'UTF-8-SIG', - 'shift_jis': 'SHIFT_JIS', - 'big5': 'Big5', - 'cp1250': 'windows-1250', - 'cp1251': 'windows-1251', - 'cp1252': 'Windows-1252', - 'cp1253': 'windows-1253', - 'cp1255': 'windows-1255', - 'cp1256': 'windows-1256', - 'cp1254': 'Windows-1254', - 'cp949': 'CP949' -} # type: Dict[str, str] diff --git a/venv/lib/python3.8/site-packages/charset_normalizer/legacy.py b/venv/lib/python3.8/site-packages/charset_normalizer/legacy.py deleted file mode 100644 index 7b28cb4..0000000 --- a/venv/lib/python3.8/site-packages/charset_normalizer/legacy.py +++ /dev/null @@ -1,38 +0,0 @@ -from charset_normalizer.api import from_bytes -from charset_normalizer.constant import CHARDET_CORRESPONDENCE -from typing import Dict, Optional, Union - - -def detect(byte_str: bytes) -> Dict[str, Optional[Union[str, float]]]: - """ - chardet legacy method - Detect the encoding of the given byte string. It should be mostly backward-compatible. - Encoding name will match Chardet own writing whenever possible. (Not on encoding name unsupported by it) - This function is deprecated and should be used to migrate your project easily, consult the documentation for - further information. Not planned for removal. - - :param byte_str: The byte sequence to examine. - """ - if not isinstance(byte_str, (bytearray, bytes)): - raise TypeError('Expected object of type bytes or bytearray, got: ' - '{0}'.format(type(byte_str))) - - if isinstance(byte_str, bytearray): - byte_str = bytes(byte_str) - - r = from_bytes(byte_str).best() - - encoding = r.encoding if r is not None else None - language = r.language if r is not None and r.language != 'Unknown' else '' - confidence = 1. - r.chaos if r is not None else None - - # Note: CharsetNormalizer does not return 'UTF-8-SIG' as the sig get stripped in the detection/normalization process - # but chardet does return 'utf-8-sig' and it is a valid codec name. - if r is not None and encoding == 'utf_8' and r.bom: - encoding += '_sig' - - return { - 'encoding': encoding if encoding not in CHARDET_CORRESPONDENCE else CHARDET_CORRESPONDENCE[encoding], - 'language': language, - 'confidence': confidence - } diff --git a/venv/lib/python3.8/site-packages/charset_normalizer/md.py b/venv/lib/python3.8/site-packages/charset_normalizer/md.py deleted file mode 100644 index 4f9c714..0000000 --- a/venv/lib/python3.8/site-packages/charset_normalizer/md.py +++ /dev/null @@ -1,451 +0,0 @@ -from functools import lru_cache -from typing import Optional, List - -from charset_normalizer.constant import UNICODE_SECONDARY_RANGE_KEYWORD -from charset_normalizer.utils import is_punctuation, is_symbol, unicode_range, is_accentuated, is_latin, \ - remove_accent, is_separator, is_cjk - - -class MessDetectorPlugin: - """ - Base abstract class used for mess detection plugins. - All detectors MUST extend and implement given methods. - """ - - def eligible(self, character: str) -> bool: - """ - Determine if given character should be fed in. - """ - raise NotImplementedError # pragma: nocover - - def feed(self, character: str) -> None: - """ - The main routine to be executed upon character. - Insert the logic in witch the text would be considered chaotic. - """ - raise NotImplementedError # pragma: nocover - - def reset(self) -> None: - """ - Permit to reset the plugin to the initial state. - """ - raise NotImplementedError # pragma: nocover - - @property - def ratio(self) -> float: - """ - Compute the chaos ratio based on what your feed() has seen. - Must NOT be lower than 0.; No restriction gt 0. - """ - raise NotImplementedError # pragma: nocover - - -class TooManySymbolOrPunctuationPlugin(MessDetectorPlugin): - - def __init__(self): - self._punctuation_count = 0 # type: int - self._symbol_count = 0 # type: int - self._character_count = 0 # type: int - - self._last_printable_char = None # type: Optional[str] - self._frenzy_symbol_in_word = False # type: bool - - def eligible(self, character: str) -> bool: - return character.isprintable() - - def feed(self, character: str) -> None: - self._character_count += 1 - - if character != self._last_printable_char and character not in ["<", ">", "=", ":", "/", "&", ";", "{", "}", "[", "]"]: - if is_punctuation(character): - self._punctuation_count += 1 - elif character.isdigit() is False and is_symbol(character): - self._symbol_count += 2 - - self._last_printable_char = character - - def reset(self) -> None: - self._punctuation_count = 0 - self._character_count = 0 - self._symbol_count = 0 - - @property - def ratio(self) -> float: - if self._character_count == 0: - return 0. - - ratio_of_punctuation = (self._punctuation_count + self._symbol_count) / self._character_count # type: float - - return ratio_of_punctuation if ratio_of_punctuation >= 0.3 else 0. - - -class TooManyAccentuatedPlugin(MessDetectorPlugin): - - def __init__(self): - self._character_count = 0 # type: int - self._accentuated_count = 0 # type: int - - def eligible(self, character: str) -> bool: - return character.isalpha() - - def feed(self, character: str) -> None: - self._character_count += 1 - - if is_accentuated(character): - self._accentuated_count += 1 - - def reset(self) -> None: - self._character_count = 0 - self._accentuated_count = 0 - - @property - def ratio(self) -> float: - if self._character_count == 0: - return 0. - ratio_of_accentuation = self._accentuated_count / self._character_count # type: float - return ratio_of_accentuation if ratio_of_accentuation >= 0.35 else 0. - - -class UnprintablePlugin(MessDetectorPlugin): - - def __init__(self): - self._unprintable_count = 0 # type: int - self._character_count = 0 # type: int - - def eligible(self, character: str) -> bool: - return True - - def feed(self, character: str) -> None: - if character not in {'\n', '\t', '\r'} and character.isprintable() is False: - self._unprintable_count += 1 - self._character_count += 1 - - def reset(self) -> None: - self._unprintable_count = 0 - - @property - def ratio(self) -> float: - if self._character_count == 0: - return 0. - - return (self._unprintable_count * 8) / self._character_count - - -class SuspiciousDuplicateAccentPlugin(MessDetectorPlugin): - - def __init__(self): - self._successive_count = 0 # type: int - self._character_count = 0 # type: int - - self._last_latin_character = None # type: Optional[str] - - def eligible(self, character: str) -> bool: - return is_latin(character) - - def feed(self, character: str) -> None: - if self._last_latin_character is not None: - if is_accentuated(character) and is_accentuated(self._last_latin_character): - if remove_accent(character) == remove_accent(self._last_latin_character): - self._successive_count += 1 - self._last_latin_character = character - - def reset(self) -> None: - self._successive_count = 0 - self._character_count = 0 - self._last_latin_character = None - - @property - def ratio(self) -> float: - if self._character_count == 0: - return 0. - - return (self._successive_count * 2) / self._character_count - - -class SuspiciousRange(MessDetectorPlugin): - - def __init__(self): - self._suspicious_successive_range_count = 0 # type: int - self._character_count = 0 # type: int - self._last_printable_seen = None # type: Optional[str] - - def eligible(self, character: str) -> bool: - return character.isprintable() - - def feed(self, character: str) -> None: - self._character_count += 1 - - if self._last_printable_seen is None: - self._last_printable_seen = character - return - - if character.isspace() or is_punctuation(character): - self._last_printable_seen = None - return - - unicode_range_a = unicode_range(self._last_printable_seen) # type: Optional[str] - unicode_range_b = unicode_range(character) # type: Optional[str] - - if is_suspiciously_successive_range(unicode_range_a, unicode_range_b): - self._suspicious_successive_range_count += 1 - - self._last_printable_seen = character - - def reset(self) -> None: - self._character_count = 0 - self._suspicious_successive_range_count = 0 - self._last_printable_seen = None - - @property - def ratio(self) -> float: - if self._character_count == 0: - return 0. - - ratio_of_suspicious_range_usage = (self._suspicious_successive_range_count * 2) / self._character_count # type: float - - if ratio_of_suspicious_range_usage < 0.1: - return 0. - - return ratio_of_suspicious_range_usage - - -class SuperWeirdWordPlugin(MessDetectorPlugin): - - def __init__(self): - self._word_count = 0 # type: int - self._bad_word_count = 0 # type: int - self._is_current_word_bad = False # type: bool - - self._character_count = 0 # type: int - self._bad_character_count = 0 # type: int - - self._buffer = "" # type: str - self._buffer_accent_count = 0 # type: int - - def eligible(self, character: str) -> bool: - return True - - def feed(self, character: str) -> None: - if character.isalpha(): - self._buffer = "".join([self._buffer, character]) - if is_accentuated(character): - self._buffer_accent_count += 1 - return - if not self._buffer: - return - if (character.isspace() or is_punctuation(character) or is_separator(character)) and self._buffer: - self._word_count += 1 - buffer_length = len(self._buffer) # type: int - - self._character_count += buffer_length - - if buffer_length >= 4 and self._buffer_accent_count / buffer_length >= 0.3: - self._is_current_word_bad = True - - if self._is_current_word_bad: - self._bad_word_count += 1 - self._bad_character_count += len(self._buffer) - self._is_current_word_bad = False - - self._buffer = "" - self._buffer_accent_count = 0 - elif character not in {"<", ">", "-", "="} and character.isdigit() is False and is_symbol(character): - self._is_current_word_bad = True - self._buffer += character - - def reset(self) -> None: - self._buffer = "" - self._is_current_word_bad = False - self._bad_word_count = 0 - self._word_count = 0 - self._character_count = 0 - self._bad_character_count = 0 - - @property - def ratio(self) -> float: - if self._word_count <= 16: - return 0. - - return self._bad_character_count / self._character_count - - -class CjkInvalidStopPlugin(MessDetectorPlugin): - """ - GB(Chinese) based encoding often render the stop incorrectly when the content does not fit and can be easily detected. - Searching for the overuse of '丅' and '丄'. - """ - - def __init__(self): - self._wrong_stop_count = 0 # type: int - self._cjk_character_count = 0 # type: int - - def eligible(self, character: str) -> bool: - return True - - def feed(self, character: str) -> None: - if character in ["丅", "丄"]: - self._wrong_stop_count += 1 - return - if is_cjk(character): - self._cjk_character_count += 1 - - def reset(self) -> None: - self._wrong_stop_count = 0 - self._cjk_character_count = 0 - - @property - def ratio(self) -> float: - if self._cjk_character_count < 16: - return 0. - return self._wrong_stop_count / self._cjk_character_count - - -class ArchaicUpperLowerPlugin(MessDetectorPlugin): - - def __init__(self): - self._buf = False # type: bool - - self._character_count_since_last_sep = 0 # type: int - - self._successive_upper_lower_count = 0 # type: int - self._successive_upper_lower_count_final = 0 # type: int - - self._character_count = 0 # type: int - - self._last_alpha_seen = None # type: Optional[str] - - def eligible(self, character: str) -> bool: - return character.isspace() or character.isalpha() - - def feed(self, character: str) -> None: - if is_separator(character): - if self._character_count_since_last_sep < 24: - self._successive_upper_lower_count_final += self._successive_upper_lower_count - self._successive_upper_lower_count = 0 - self._character_count_since_last_sep = 0 - - if self._last_alpha_seen is not None: - if (character.isupper() and self._last_alpha_seen.islower()) or (character.islower() and self._last_alpha_seen.isupper()): - if self._buf is True: - self._successive_upper_lower_count += 1 - else: - self._buf = True - else: - self._buf = False - - self._character_count += 1 - self._last_alpha_seen = character - - def reset(self) -> None: - self._character_count = 0 - self._character_count_since_last_sep = 0 - self._successive_upper_lower_count = 0 - self._successive_upper_lower_count_final = 0 - self._last_alpha_seen = None - - @property - def ratio(self) -> float: - if self._character_count == 0: - return 0. - - return (self._successive_upper_lower_count_final * 2) / self._character_count - - -def is_suspiciously_successive_range(unicode_range_a: Optional[str], unicode_range_b: Optional[str]) -> bool: - """ - Determine if two Unicode range seen next to each other can be considered as suspicious. - """ - if unicode_range_a is None or unicode_range_b is None: - return True - - if unicode_range_a == unicode_range_b: - return False - - if "Latin" in unicode_range_a and "Latin" in unicode_range_b: - return False - - if "Emoticons" in unicode_range_a or "Emoticons" in unicode_range_b: - return False - - keywords_range_a, keywords_range_b = unicode_range_a.split(" "), unicode_range_b.split(" ") - - for el in keywords_range_a: - if el in UNICODE_SECONDARY_RANGE_KEYWORD: - continue - if el in keywords_range_b: - return False - - # Japanese Exception - if unicode_range_a in ['Katakana', 'Hiragana'] and unicode_range_b in ['Katakana', 'Hiragana']: - return False - - if unicode_range_a in ['Katakana', 'Hiragana'] or unicode_range_b in ['Katakana', 'Hiragana']: - if "CJK" in unicode_range_a or "CJK" in unicode_range_b: - return False - - if "Hangul" in unicode_range_a or "Hangul" in unicode_range_b: - if "CJK" in unicode_range_a or "CJK" in unicode_range_b: - return False - if unicode_range_a == "Basic Latin" or unicode_range_b == "Basic Latin": - return False - - # Chinese/Japanese use dedicated range for punctuation and/or separators. - if ('CJK' in unicode_range_a or 'CJK' in unicode_range_b) or (unicode_range_a in ['Katakana', 'Hiragana'] and unicode_range_b in ['Katakana', 'Hiragana']): - if 'Punctuation' in unicode_range_a or 'Punctuation' in unicode_range_b: - return False - if 'Forms' in unicode_range_a or 'Forms' in unicode_range_b: - return False - - return True - - -@lru_cache(maxsize=2048) -def mess_ratio(decoded_sequence: str, maximum_threshold: float = 0.2, debug: bool = False) -> float: - """ - Compute a mess ratio given a decoded bytes sequence. The maximum threshold does stop the computation earlier. - """ - detectors = [] # type: List[MessDetectorPlugin] - - for md_class in MessDetectorPlugin.__subclasses__(): - detectors.append( - md_class() - ) - - length = len(decoded_sequence) # type: int - - mean_mess_ratio = 0. # type: float - - if length < 512: - intermediary_mean_mess_ratio_calc = 32 # type: int - elif length <= 1024: - intermediary_mean_mess_ratio_calc = 64 - else: - intermediary_mean_mess_ratio_calc = 128 - - for character, index in zip(decoded_sequence, range(0, length)): - for detector in detectors: - if detector.eligible(character): - detector.feed(character) - - if (index > 0 and index % intermediary_mean_mess_ratio_calc == 0) or index == length-1: - mean_mess_ratio = sum( - [ - dt.ratio for dt in detectors - ] - ) - - if mean_mess_ratio >= maximum_threshold: - break - - if debug: - for dt in detectors: # pragma: nocover - print( - dt.__class__, - dt.ratio - ) - - return round( - mean_mess_ratio, - 3 - ) - diff --git a/venv/lib/python3.8/site-packages/charset_normalizer/models.py b/venv/lib/python3.8/site-packages/charset_normalizer/models.py deleted file mode 100644 index 2bf75a4..0000000 --- a/venv/lib/python3.8/site-packages/charset_normalizer/models.py +++ /dev/null @@ -1,355 +0,0 @@ -import warnings -from encodings.aliases import aliases -from hashlib import sha256 -from json import dumps -from typing import Optional, List, Tuple, Set -from collections import Counter -from re import sub, compile as re_compile - -from charset_normalizer.constant import TOO_BIG_SEQUENCE -from charset_normalizer.md import mess_ratio -from charset_normalizer.utils import iana_name, is_multi_byte_encoding, unicode_range - - -class CharsetMatch: - def __init__( - self, - payload: bytes, - guessed_encoding: str, - mean_mess_ratio: float, - has_sig_or_bom: bool, - languages: "CoherenceMatches", - decoded_payload: Optional[str] = None - ): - self._payload = payload # type: bytes - - self._encoding = guessed_encoding # type: str - self._mean_mess_ratio = mean_mess_ratio # type: float - self._languages = languages # type: CoherenceMatches - self._has_sig_or_bom = has_sig_or_bom # type: bool - self._unicode_ranges = None # type: Optional[List[str]] - - self._leaves = [] # type: List[CharsetMatch] - self._mean_coherence_ratio = 0. # type: float - - self._output_payload = None # type: Optional[bytes] - self._output_encoding = None # type: Optional[str] - - self._string = decoded_payload # type: Optional[str] - - def __eq__(self, other) -> bool: - if not isinstance(other, CharsetMatch): - raise TypeError('__eq__ cannot be invoked on {} and {}.'.format(str(other.__class__), str(self.__class__))) - return self.encoding == other.encoding and self.fingerprint == other.fingerprint - - def __lt__(self, other) -> bool: - """ - Implemented to make sorted available upon CharsetMatches items. - """ - if not isinstance(other, CharsetMatch): - raise ValueError - - chaos_difference = abs(self.chaos - other.chaos) # type: float - - # Bellow 1% difference --> Use Coherence - if chaos_difference < 0.01: - return self.coherence > other.coherence - - return self.chaos < other.chaos - - @property - def chaos_secondary_pass(self) -> float: - """ - Check once again chaos in decoded text, except this time, with full content. - Use with caution, this can be very slow. - Notice: Will be removed in 3.0 - """ - warnings.warn("chaos_secondary_pass is deprecated and will be removed in 3.0", DeprecationWarning) - return mess_ratio( - str(self), - 1. - ) - - @property - def coherence_non_latin(self) -> float: - """ - Coherence ratio on the first non-latin language detected if ANY. - Notice: Will be removed in 3.0 - """ - warnings.warn("coherence_non_latin is deprecated and will be removed in 3.0", DeprecationWarning) - return 0. - - @property - def w_counter(self) -> Counter: - """ - Word counter instance on decoded text. - Notice: Will be removed in 3.0 - """ - warnings.warn("w_counter is deprecated and will be removed in 3.0", DeprecationWarning) - not_printable_pattern = re_compile(r'[0-9\W\n\r\t]+') - string_printable_only = sub(not_printable_pattern, ' ', str(self).lower()) - - return Counter(string_printable_only.split()) - - def __str__(self) -> str: - # Lazy Str Loading - if self._string is None: - self._string = str(self._payload, self._encoding, "strict") - return self._string - - def __repr__(self) -> str: - return "".format(self.encoding, self.fingerprint) - - def add_submatch(self, other: "CharsetMatch") -> None: - if not isinstance(other, CharsetMatch) or other == self: - raise ValueError("Unable to add instance <{}> as a submatch of a CharsetMatch".format(other.__class__)) - - other._string = None # Unload RAM usage; dirty trick. - self._leaves.append(other) - - @property - def encoding(self) -> str: - return self._encoding - - @property - def encoding_aliases(self) -> List[str]: - """ - Encoding name are known by many name, using this could help when searching for IBM855 when it's listed as CP855. - """ - also_known_as = [] # type: List[str] - for u, p in aliases.items(): - if self.encoding == u: - also_known_as.append(p) - elif self.encoding == p: - also_known_as.append(u) - return also_known_as - - @property - def bom(self) -> bool: - return self._has_sig_or_bom - - @property - def byte_order_mark(self) -> bool: - return self._has_sig_or_bom - - @property - def languages(self) -> List[str]: - """ - Return the complete list of possible languages found in decoded sequence. - Usually not really useful. Returned list may be empty even if 'language' property return something != 'Unknown'. - """ - return [e[0] for e in self._languages] - - @property - def language(self) -> str: - """ - Most probable language found in decoded sequence. If none were detected or inferred, the property will return - "Unknown". - """ - if not self._languages: - # Trying to infer the language based on the given encoding - # Its either English or we should not pronounce ourselves in certain cases. - if "ascii" in self.could_be_from_charset: - return "English" - - # doing it there to avoid circular import - from charset_normalizer.cd import mb_encoding_languages, encoding_languages - - languages = mb_encoding_languages(self.encoding) if is_multi_byte_encoding(self.encoding) else encoding_languages(self.encoding) - - if len(languages) == 0 or "Latin Based" in languages: - return "Unknown" - - return languages[0] - - return self._languages[0][0] - - @property - def chaos(self) -> float: - return self._mean_mess_ratio - - @property - def coherence(self) -> float: - if not self._languages: - return 0. - return self._languages[0][1] - - @property - def percent_chaos(self) -> float: - return round(self.chaos * 100, ndigits=3) - - @property - def percent_coherence(self) -> float: - return round(self.coherence * 100, ndigits=3) - - @property - def raw(self) -> bytes: - """ - Original untouched bytes. - """ - return self._payload - - @property - def submatch(self) -> List["CharsetMatch"]: - return self._leaves - - @property - def has_submatch(self) -> bool: - return len(self._leaves) > 0 - - @property - def alphabets(self) -> List[str]: - if self._unicode_ranges is not None: - return self._unicode_ranges - detected_ranges = set() # type: Set[str] - for character in str(self): - detected_ranges.add( - unicode_range(character) - ) - self._unicode_ranges = sorted(list(detected_ranges)) - return self._unicode_ranges - - @property - def could_be_from_charset(self) -> List[str]: - """ - The complete list of encoding that output the exact SAME str result and therefore could be the originating - encoding. - This list does include the encoding available in property 'encoding'. - """ - return [self._encoding] + [m.encoding for m in self._leaves] - - def first(self) -> "CharsetMatch": - """ - Kept for BC reasons. Will be removed in 3.0. - """ - return self - - def best(self) -> "CharsetMatch": - """ - Kept for BC reasons. Will be removed in 3.0. - """ - return self - - def output(self, encoding: str = "utf_8") -> bytes: - """ - Method to get re-encoded bytes payload using given target encoding. Default to UTF-8. - Any errors will be simply ignored by the encoder NOT replaced. - """ - if self._output_encoding is None or self._output_encoding != encoding: - self._output_encoding = encoding - self._output_payload = str(self).encode(encoding, "replace") - - return self._output_payload # type: ignore - - @property - def fingerprint(self) -> str: - """ - Retrieve the unique SHA256 computed using the transformed (re-encoded) payload. Not the original one. - """ - return sha256(self.output()).hexdigest() - - -class CharsetMatches: - """ - Container with every CharsetMatch items ordered by default from most probable to the less one. - Act like a list(iterable) but does not implements all related methods. - """ - def __init__(self, results: List[CharsetMatch] = None): - self._results = sorted(results) if results else [] # type: List[CharsetMatch] - - def __iter__(self): - for result in self._results: - yield result - - def __getitem__(self, item) -> CharsetMatch: - """ - Retrieve a single item either by its position or encoding name (alias may be used here). - Raise KeyError upon invalid index or encoding not present in results. - """ - if isinstance(item, int): - return self._results[item] - if isinstance(item, str): - item = iana_name(item, False) - for result in self._results: - if item in result.could_be_from_charset: - return result - raise KeyError - - def __len__(self) -> int: - return len(self._results) - - def append(self, item: CharsetMatch) -> None: - """ - Insert a single match. Will be inserted accordingly to preserve sort. - Can be inserted as a submatch. - """ - if not isinstance(item, CharsetMatch): - raise ValueError("Cannot append instance '{}' to CharsetMatches".format(str(item.__class__))) - # We should disable the submatch factoring when the input file is too heavy (conserve RAM usage) - if len(item.raw) <= TOO_BIG_SEQUENCE: - for match in self._results: - if match.fingerprint == item.fingerprint: - match.add_submatch(item) - return - self._results.append(item) - self._results = sorted(self._results) - - def best(self) -> Optional["CharsetMatch"]: - """ - Simply return the first match. Strict equivalent to matches[0]. - """ - if not self._results: - return None - return self._results[0] - - def first(self) -> Optional["CharsetMatch"]: - """ - Redundant method, call the method best(). Kept for BC reasons. - """ - return self.best() - - -CoherenceMatch = Tuple[str, float] -CoherenceMatches = List[CoherenceMatch] - - -class CliDetectionResult: - - def __init__(self, path: str, encoding: str, encoding_aliases: List[str], alternative_encodings: List[str], language: str, alphabets: List[str], has_sig_or_bom: bool, chaos: float, coherence: float, unicode_path: Optional[str], is_preferred: bool): - self.path = path # type: str - self.unicode_path = unicode_path # type: Optional[str] - self.encoding = encoding # type: str - self.encoding_aliases = encoding_aliases # type: List[str] - self.alternative_encodings = alternative_encodings # type: List[str] - self.language = language # type: str - self.alphabets = alphabets # type: List[str] - self.has_sig_or_bom = has_sig_or_bom # type: bool - self.chaos = chaos # type: float - self.coherence = coherence # type: float - self.is_preferred = is_preferred # type: bool - - @property - def __dict__(self): - return { - 'path': self.path, - 'encoding': self.encoding, - 'encoding_aliases': self.encoding_aliases, - 'alternative_encodings': self.alternative_encodings, - 'language': self.language, - 'alphabets': self.alphabets, - 'has_sig_or_bom': self.has_sig_or_bom, - 'chaos': self.chaos, - 'coherence': self.coherence, - 'unicode_path': self.unicode_path, - 'is_preferred': self.is_preferred - } - - def to_json(self) -> str: - return dumps( - self.__dict__, - ensure_ascii=True, - indent=4 - ) - - -CharsetNormalizerMatch = CharsetMatch diff --git a/venv/lib/python3.8/site-packages/charset_normalizer/py.typed b/venv/lib/python3.8/site-packages/charset_normalizer/py.typed deleted file mode 100644 index e69de29..0000000 diff --git a/venv/lib/python3.8/site-packages/charset_normalizer/utils.py b/venv/lib/python3.8/site-packages/charset_normalizer/utils.py deleted file mode 100644 index db59739..0000000 --- a/venv/lib/python3.8/site-packages/charset_normalizer/utils.py +++ /dev/null @@ -1,248 +0,0 @@ -try: - import unicodedata2 as unicodedata -except ImportError: - import unicodedata - -from codecs import IncrementalDecoder -from re import findall -from typing import Optional, Tuple, Union, List, Set -import importlib -from _multibytecodec import MultibyteIncrementalDecoder # type: ignore - -from encodings.aliases import aliases -from functools import lru_cache - -from charset_normalizer.constant import UNICODE_RANGES_COMBINED, UNICODE_SECONDARY_RANGE_KEYWORD, \ - RE_POSSIBLE_ENCODING_INDICATION, ENCODING_MARKS, UTF8_MAXIMAL_ALLOCATION, IANA_SUPPORTED_SIMILAR - - -@lru_cache(maxsize=UTF8_MAXIMAL_ALLOCATION) -def is_accentuated(character: str) -> bool: - try: - description = unicodedata.name(character) # type: str - except ValueError: - return False - return "WITH GRAVE" in description or "WITH ACUTE" in description or "WITH CEDILLA" in description - - -@lru_cache(maxsize=UTF8_MAXIMAL_ALLOCATION) -def remove_accent(character: str) -> str: - decomposed = unicodedata.decomposition(character) # type: str - if not decomposed: - return character - - codes = decomposed.split(" ") # type: List[str] - - return chr( - int( - codes[0], - 16 - ) - ) - - -@lru_cache(maxsize=UTF8_MAXIMAL_ALLOCATION) -def unicode_range(character: str) -> Optional[str]: - """ - Retrieve the Unicode range official name from a single character. - """ - character_ord = ord(character) # type: int - - for range_name, ord_range in UNICODE_RANGES_COMBINED.items(): - if character_ord in ord_range: - return range_name - - return None - - -@lru_cache(maxsize=UTF8_MAXIMAL_ALLOCATION) -def is_latin(character: str) -> bool: - try: - description = unicodedata.name(character) # type: str - except ValueError: - return False - return "LATIN" in description - - -@lru_cache(maxsize=UTF8_MAXIMAL_ALLOCATION) -def is_punctuation(character: str) -> bool: - character_category = unicodedata.category(character) # type: str - - if "P" in character_category: - return True - - character_range = unicode_range(character) # type: Optional[str] - - if character_range is None: - return False - - return "Punctuation" in character_range - - -@lru_cache(maxsize=UTF8_MAXIMAL_ALLOCATION) -def is_symbol(character: str) -> bool: - character_category = unicodedata.category(character) # type: str - - if "S" in character_category or "N" in character_category: - return True - - character_range = unicode_range(character) # type: Optional[str] - - if character_range is None: - return False - - return "Forms" in character_range - - -@lru_cache(maxsize=UTF8_MAXIMAL_ALLOCATION) -def is_separator(character: str) -> bool: - if character.isspace() or character in ["|", "+"]: - return True - - character_category = unicodedata.category(character) # type: str - - return "Z" in character_category - - -def is_private_use_only(character: str) -> bool: - character_category = unicodedata.category(character) # type: str - - return "Co" == character_category - - -def is_cjk(character: str) -> bool: - try: - character_name = unicodedata.name(character) - except ValueError: - return False - - return "CJK" in character_name - - -@lru_cache(maxsize=len(UNICODE_RANGES_COMBINED)) -def is_unicode_range_secondary(range_name: str) -> bool: - for keyword in UNICODE_SECONDARY_RANGE_KEYWORD: - if keyword in range_name: - return True - - return False - - -def any_specified_encoding(sequence: bytes, search_zone: int = 4096) -> Optional[str]: - """ - Extract using ASCII-only decoder any specified encoding in the first n-bytes. - """ - if not isinstance(sequence, bytes): - raise TypeError - - seq_len = len(sequence) # type: int - - results = findall( - RE_POSSIBLE_ENCODING_INDICATION, - sequence[:seq_len if seq_len <= search_zone else search_zone].decode('ascii', errors='ignore') - ) # type: List[str] - - if len(results) == 0: - return None - - for specified_encoding in results: - specified_encoding = specified_encoding.lower().replace('-', '_') - - for encoding_alias, encoding_iana in aliases.items(): - if encoding_alias == specified_encoding: - return encoding_iana - if encoding_iana == specified_encoding: - return encoding_iana - - return None - - -@lru_cache(maxsize=128) -def is_multi_byte_encoding(name: str) -> bool: - """ - Verify is a specific encoding is a multi byte one based on it IANA name - """ - return name in {"utf_8", "utf_8_sig", "utf_16", "utf_16_be", "utf_16_le", "utf_32", "utf_32_le", "utf_32_be", "utf_7"} or issubclass( - importlib.import_module('encodings.{}'.format(name)).IncrementalDecoder, # type: ignore - MultibyteIncrementalDecoder - ) - - -def identify_sig_or_bom(sequence: bytes) -> Tuple[Optional[str], bytes]: - """ - Identify and extract SIG/BOM in given sequence. - """ - - for iana_encoding in ENCODING_MARKS: - marks = ENCODING_MARKS[iana_encoding] # type: Union[bytes, List[bytes]] - - if isinstance(marks, bytes): - marks = [marks] - - for mark in marks: - if sequence.startswith(mark): - return iana_encoding, mark - - return None, b"" - - -def should_strip_sig_or_bom(iana_encoding: str) -> bool: - return iana_encoding not in {"utf_16", "utf_32"} - - -def iana_name(cp_name: str, strict: bool = True) -> str: - cp_name = cp_name.lower().replace('-', '_') - - for encoding_alias, encoding_iana in aliases.items(): - if cp_name == encoding_alias or cp_name == encoding_iana: - return encoding_iana - - if strict: - raise ValueError("Unable to retrieve IANA for '{}'".format(cp_name)) - - return cp_name - - -def range_scan(decoded_sequence: str) -> List[str]: - ranges = set() # type: Set[str] - - for character in decoded_sequence: - character_range = unicode_range(character) # type: Optional[str] - - if character_range is None: - continue - - ranges.add( - character_range - ) - - return list(ranges) - - -def cp_similarity(iana_name_a: str, iana_name_b: str) -> float: - - if is_multi_byte_encoding(iana_name_a) or is_multi_byte_encoding(iana_name_b): - return 0. - - decoder_a = importlib.import_module('encodings.{}'.format(iana_name_a)).IncrementalDecoder # type: ignore - decoder_b = importlib.import_module('encodings.{}'.format(iana_name_b)).IncrementalDecoder # type: ignore - - id_a = decoder_a(errors="ignore") # type: IncrementalDecoder - id_b = decoder_b(errors="ignore") # type: IncrementalDecoder - - character_match_count = 0 # type: int - - for i in range(0, 255): - to_be_decoded = bytes([i]) # type: bytes - if id_a.decode(to_be_decoded) == id_b.decode(to_be_decoded): - character_match_count += 1 - - return character_match_count / 254 - - -def is_cp_similar(iana_name_a: str, iana_name_b: str) -> bool: - """ - Determine if two code page are at least 80% similar. IANA_SUPPORTED_SIMILAR dict was generated using - the function cp_similarity. - """ - return iana_name_a in IANA_SUPPORTED_SIMILAR and iana_name_b in IANA_SUPPORTED_SIMILAR[iana_name_a] diff --git a/venv/lib/python3.8/site-packages/charset_normalizer/version.py b/venv/lib/python3.8/site-packages/charset_normalizer/version.py deleted file mode 100644 index 12f4b34..0000000 --- a/venv/lib/python3.8/site-packages/charset_normalizer/version.py +++ /dev/null @@ -1,6 +0,0 @@ -""" -Expose version -""" - -__version__ = "2.0.3" -VERSION = __version__.split('.') diff --git a/venv/lib/python3.8/site-packages/easy_install.py b/venv/lib/python3.8/site-packages/easy_install.py deleted file mode 100644 index d87e984..0000000 --- a/venv/lib/python3.8/site-packages/easy_install.py +++ /dev/null @@ -1,5 +0,0 @@ -"""Run the EasyInstall command""" - -if __name__ == '__main__': - from setuptools.command.easy_install import main - main() diff --git a/venv/lib/python3.8/site-packages/idna-3.2.dist-info/INSTALLER b/venv/lib/python3.8/site-packages/idna-3.2.dist-info/INSTALLER deleted file mode 100644 index a1b589e..0000000 --- a/venv/lib/python3.8/site-packages/idna-3.2.dist-info/INSTALLER +++ /dev/null @@ -1 +0,0 @@ -pip diff --git a/venv/lib/python3.8/site-packages/idna-3.2.dist-info/LICENSE.md b/venv/lib/python3.8/site-packages/idna-3.2.dist-info/LICENSE.md deleted file mode 100644 index b6f8732..0000000 --- a/venv/lib/python3.8/site-packages/idna-3.2.dist-info/LICENSE.md +++ /dev/null @@ -1,29 +0,0 @@ -BSD 3-Clause License - -Copyright (c) 2013-2021, Kim Davies -All rights reserved. - -Redistribution and use in source and binary forms, with or without -modification, are permitted provided that the following conditions are met: - -1. Redistributions of source code must retain the above copyright notice, this - list of conditions and the following disclaimer. - -2. Redistributions in binary form must reproduce the above copyright notice, - this list of conditions and the following disclaimer in the documentation - and/or other materials provided with the distribution. - -3. Neither the name of the copyright holder nor the names of its - contributors may be used to endorse or promote products derived from - this software without specific prior written permission. - -THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" -AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE -IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE -DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE -FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL -DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR -SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER -CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, -OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE -OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. diff --git a/venv/lib/python3.8/site-packages/idna-3.2.dist-info/METADATA b/venv/lib/python3.8/site-packages/idna-3.2.dist-info/METADATA deleted file mode 100644 index 808eebb..0000000 --- a/venv/lib/python3.8/site-packages/idna-3.2.dist-info/METADATA +++ /dev/null @@ -1,225 +0,0 @@ -Metadata-Version: 2.1 -Name: idna -Version: 3.2 -Summary: Internationalized Domain Names in Applications (IDNA) -Home-page: https://github.com/kjd/idna -Author: Kim Davies -Author-email: kim@cynosure.com.au -License: BSD-3-Clause -Platform: UNKNOWN -Classifier: Development Status :: 5 - Production/Stable -Classifier: Intended Audience :: Developers -Classifier: Intended Audience :: System Administrators -Classifier: License :: OSI Approved :: BSD License -Classifier: Operating System :: OS Independent -Classifier: Programming Language :: Python -Classifier: Programming Language :: Python :: 3 -Classifier: Programming Language :: Python :: 3 :: Only -Classifier: Programming Language :: Python :: 3.5 -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 -Classifier: Topic :: Internet :: Name Service (DNS) -Classifier: Topic :: Software Development :: Libraries :: Python Modules -Classifier: Topic :: Utilities -Requires-Python: >=3.5 - -Internationalized Domain Names in Applications (IDNA) -===================================================== - -Support for the Internationalised Domain Names in Applications -(IDNA) protocol as specified in `RFC 5891 `_. -This is the latest version of the protocol and is sometimes referred to as -“IDNA 2008”. - -This library also provides support for Unicode Technical Standard 46, -`Unicode IDNA Compatibility Processing `_. - -This acts as a suitable replacement for the “encodings.idna” module that -comes with the Python standard library, but which only supports the -old, deprecated IDNA specification (`RFC 3490 `_). - -Basic functions are simply executed: - -.. code-block:: pycon - - >>> import idna - >>> idna.encode('ドメイン.テスト') - b'xn--eckwd4c7c.xn--zckzah' - >>> print(idna.decode('xn--eckwd4c7c.xn--zckzah')) - ドメイン.テスト - -Packages --------- - -The latest tagged release version is published in the PyPI repository: - -.. image:: https://badge.fury.io/py/idna.svg - :target: https://badge.fury.io/py/idna - - -Installation ------------- - -To install this library, you can use pip: - -.. code-block:: bash - - $ pip install idna - -Alternatively, you can install the package using the bundled setup script: - -.. code-block:: bash - - $ python setup.py install - -This library works with Python 3.4 or later. Earlier versions of this -library support Python 2 - use "idna<3" in your requirements file if -you need this library for a Python 2 application. - - -Usage ------ - -For typical usage, the ``encode`` and ``decode`` functions will take a domain -name argument and perform a conversion to A-labels or U-labels respectively. - -.. code-block:: pycon - - >>> import idna - >>> idna.encode('ドメイン.テスト') - b'xn--eckwd4c7c.xn--zckzah' - >>> print(idna.decode('xn--eckwd4c7c.xn--zckzah')) - ドメイン.テスト - -You may use the codec encoding and decoding methods using the -``idna.codec`` module: - -.. code-block:: pycon - - >>> import idna.codec - >>> print('домена.испытание'.encode('idna')) - b'xn--80ahd1agd.xn--80akhbyknj4f' - >>> print(b'xn--80ahd1agd.xn--80akhbyknj4f'.decode('idna')) - домена.испытание - -Conversions can be applied at a per-label basis using the ``ulabel`` or ``alabel`` -functions if necessary: - -.. code-block:: pycon - - >>> idna.alabel('测试') - b'xn--0zwm56d' - -Compatibility Mapping (UTS #46) -+++++++++++++++++++++++++++++++ - -As described in `RFC 5895 `_, the IDNA -specification does not normalize input from different potential ways a user -may input a domain name. This functionality, known as a “mapping”, is -considered by the specification to be a local user-interface issue distinct -from IDNA conversion functionality. - -This library provides one such mapping, that was developed by the Unicode -Consortium. Known as `Unicode IDNA Compatibility Processing `_, -it provides for both a regular mapping for typical applications, as well as -a transitional mapping to help migrate from older IDNA 2003 applications. - -For example, “Königsgäßchen” is not a permissible label as *LATIN CAPITAL -LETTER K* is not allowed (nor are capital letters in general). UTS 46 will -convert this into lower case prior to applying the IDNA conversion. - -.. code-block:: pycon - - >>> import idna - >>> idna.encode('Königsgäßchen') - ... - idna.core.InvalidCodepoint: Codepoint U+004B at position 1 of 'Königsgäßchen' not allowed - >>> idna.encode('Königsgäßchen', uts46=True) - b'xn--knigsgchen-b4a3dun' - >>> print(idna.decode('xn--knigsgchen-b4a3dun')) - königsgäßchen - -Transitional processing provides conversions to help transition from the older -2003 standard to the current standard. For example, in the original IDNA -specification, the *LATIN SMALL LETTER SHARP S* (ß) was converted into two -*LATIN SMALL LETTER S* (ss), whereas in the current IDNA specification this -conversion is not performed. - -.. code-block:: pycon - - >>> idna.encode('Königsgäßchen', uts46=True, transitional=True) - 'xn--knigsgsschen-lcb0w' - -Implementors should use transitional processing with caution, only in rare -cases where conversion from legacy labels to current labels must be performed -(i.e. IDNA implementations that pre-date 2008). For typical applications -that just need to convert labels, transitional processing is unlikely to be -beneficial and could produce unexpected incompatible results. - -``encodings.idna`` Compatibility -++++++++++++++++++++++++++++++++ - -Function calls from the Python built-in ``encodings.idna`` module are -mapped to their IDNA 2008 equivalents using the ``idna.compat`` module. -Simply substitute the ``import`` clause in your code to refer to the -new module name. - -Exceptions ----------- - -All errors raised during the conversion following the specification should -raise an exception derived from the ``idna.IDNAError`` base class. - -More specific exceptions that may be generated as ``idna.IDNABidiError`` -when the error reflects an illegal combination of left-to-right and -right-to-left characters in a label; ``idna.InvalidCodepoint`` when -a specific codepoint is an illegal character in an IDN label (i.e. -INVALID); and ``idna.InvalidCodepointContext`` when the codepoint is -illegal based on its positional context (i.e. it is CONTEXTO or CONTEXTJ -but the contextual requirements are not satisfied.) - -Building and Diagnostics ------------------------- - -The IDNA and UTS 46 functionality relies upon pre-calculated lookup -tables for performance. These tables are derived from computing against -eligibility criteria in the respective standards. These tables are -computed using the command-line script ``tools/idna-data``. - -This tool will fetch relevant codepoint data from the Unicode repository -and perform the required calculations to identify eligibility. There are -three main modes: - -* ``idna-data make-libdata``. Generates ``idnadata.py`` and ``uts46data.py``, - the pre-calculated lookup tables using for IDNA and UTS 46 conversions. Implementors - who wish to track this library against a different Unicode version may use this tool - to manually generate a different version of the ``idnadata.py`` and ``uts46data.py`` - files. - -* ``idna-data make-table``. Generate a table of the IDNA disposition - (e.g. PVALID, CONTEXTJ, CONTEXTO) in the format found in Appendix B.1 of RFC - 5892 and the pre-computed tables published by `IANA `_. - -* ``idna-data U+0061``. Prints debugging output on the various properties - associated with an individual Unicode codepoint (in this case, U+0061), that are - used to assess the IDNA and UTS 46 status of a codepoint. This is helpful in debugging - or analysis. - -The tool accepts a number of arguments, described using ``idna-data -h``. Most notably, -the ``--version`` argument allows the specification of the version of Unicode to use -in computing the table data. For example, ``idna-data --version 9.0.0 make-libdata`` -will generate library data against Unicode 9.0.0. - - -Testing -------- - -The library has a test suite based on each rule of the IDNA specification, as -well as tests that are provided as part of the Unicode Technical Standard 46, -`Unicode IDNA Compatibility Processing `_. - - diff --git a/venv/lib/python3.8/site-packages/idna-3.2.dist-info/RECORD b/venv/lib/python3.8/site-packages/idna-3.2.dist-info/RECORD deleted file mode 100644 index 9605bcd..0000000 --- a/venv/lib/python3.8/site-packages/idna-3.2.dist-info/RECORD +++ /dev/null @@ -1,23 +0,0 @@ -idna-3.2.dist-info/INSTALLER,sha256=zuuue4knoyJ-UwPPXg8fezS7VCrXJQrAP7zeNuwvFQg,4 -idna-3.2.dist-info/LICENSE.md,sha256=otbk2UC9JNvnuWRc3hmpeSzFHbeuDVrNMBrIYMqj6DY,1523 -idna-3.2.dist-info/METADATA,sha256=L6eIrqdmpRK2oKwBFd8CcID4FQ8h2SYKf2fg7KEQLG0,8638 -idna-3.2.dist-info/RECORD,, -idna-3.2.dist-info/WHEEL,sha256=OqRkF0eY5GHssMorFjlbTIq072vpHpF60fIQA6lS9xA,92 -idna-3.2.dist-info/top_level.txt,sha256=jSag9sEDqvSPftxOQy-ABfGV_RSy7oFh4zZJpODV8k0,5 -idna/__init__.py,sha256=KJQN1eQBr8iIK5SKrJ47lXvxG0BJ7Lm38W4zT0v_8lk,849 -idna/__pycache__/__init__.cpython-38.pyc,, -idna/__pycache__/codec.cpython-38.pyc,, -idna/__pycache__/compat.cpython-38.pyc,, -idna/__pycache__/core.cpython-38.pyc,, -idna/__pycache__/idnadata.cpython-38.pyc,, -idna/__pycache__/intranges.cpython-38.pyc,, -idna/__pycache__/package_data.cpython-38.pyc,, -idna/__pycache__/uts46data.cpython-38.pyc,, -idna/codec.py,sha256=QsPFD3Je8gN17rfs14e7zTGRWlnL7bNf2ZqcHTRVYHs,3453 -idna/compat.py,sha256=5A9xR04puRHCsyjBNewZlVSiarth7K1bZqyEOeob1fA,360 -idna/core.py,sha256=icq2P13S6JMjoXgKhhd6ihhby7QsnZlNfniH6fLyf6U,12826 -idna/idnadata.py,sha256=cl4x9RLdw1ZMtEEbvKwAsX-Id3AdIjO5U3HaoKM6VGs,42350 -idna/intranges.py,sha256=EqgXwyATAn-CTACInqH9tYsYAitGB2VcQ50RZt_Cpjs,1933 -idna/package_data.py,sha256=_028B4fvadRIaXMwMYjhuQPP3AxTIt1IRE7X6RDR4Mk,21 -idna/py.typed,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -idna/uts46data.py,sha256=DGzwDQv8JijY17I_7ondo3stjFjNnjvVAbA-z0k1XOE,201849 diff --git a/venv/lib/python3.8/site-packages/idna-3.2.dist-info/WHEEL b/venv/lib/python3.8/site-packages/idna-3.2.dist-info/WHEEL deleted file mode 100644 index 385faab..0000000 --- a/venv/lib/python3.8/site-packages/idna-3.2.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/venv/lib/python3.8/site-packages/idna-3.2.dist-info/top_level.txt b/venv/lib/python3.8/site-packages/idna-3.2.dist-info/top_level.txt deleted file mode 100644 index c40472e..0000000 --- a/venv/lib/python3.8/site-packages/idna-3.2.dist-info/top_level.txt +++ /dev/null @@ -1 +0,0 @@ -idna diff --git a/venv/lib/python3.8/site-packages/idna/__init__.py b/venv/lib/python3.8/site-packages/idna/__init__.py deleted file mode 100644 index a40eeaf..0000000 --- a/venv/lib/python3.8/site-packages/idna/__init__.py +++ /dev/null @@ -1,44 +0,0 @@ -from .package_data import __version__ -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/venv/lib/python3.8/site-packages/idna/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/idna/__pycache__/__init__.cpython-38.pyc deleted file mode 100644 index 5de0dce5b82921314e2ced0ae949dfe9bf8f5911..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 869 zcmbu7%Z}496o!*t(xypzNqQNvXHkh#jRZ(Y2mu3&*^EGljW?E?<4HY@o#3Ry%!}|2 zypp%9SnvX@@JSFtvp`5V%9nHgB*(w)^C5~xjvY5o@3VJZ$N7rMpChr!3wu|eEx-Xc zcce>P7voOekzLZ2J<^kX(w83bBChAw)2S2~1%IF(fdD1uV0KtYG!tS)Y7! zt+};p0!pvBu0)|IUB@Ome|_=tl>qTZ>p~kJ(>9!*t811EI4gjcg;2Fw-Br#CRr8zL zcr0f-o|{p+=jnm&Y&kP&`z6|qnb{?3 zrZQeN<(N>~9=4-{Nz86rktx9GXW#rnjAB})%1 z;}lrUbjPZumlm4;*VKQV)%d^H*?2SqN?D#$`o+=r&>G^$>9&^TwiM;&sL&#Z&8I!* w`R4NRN0DY%^;UplTT1abDScSpn&C59z%l2~vC*mr7NPrg9(FtKKV08`0t&U=qW}N^ diff --git a/venv/lib/python3.8/site-packages/idna/__pycache__/codec.cpython-38.pyc b/venv/lib/python3.8/site-packages/idna/__pycache__/codec.cpython-38.pyc deleted file mode 100644 index d68bf6a4b7d5df53a33ab7f77c4f70198587d8c7..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2830 zcmds3Pj4JG6t_K|KfBr8q}#NmrE1e44qM2E3;!gFQkn|&vPhJIG^iR)*4}i|nc1nw ztI{$nRZXw(8Ioged;s_&zV_5p51i-)-t#owqzOWRxZsta{eJfN+0VcCytmrzCV}$Z z$8X2eHX%<@Iapj!)}WR@fe=K{lw>rd84FqFgigjop1Gk*iD1G>z0k9*ANtVpG{_oZ zBWs3DN~FItC)`~cwmv7q6aEt-eCchqx1F#JNFW-3Gyv%UG7m^o%mFe7$O0fI0BMOf zAZ^(Oth>#_E?^xo57@lLP6BpPEQk|NNVq7Ro21u$Mq%4M*LX4?j)gRykaZiU@rF!| zH>umkjrGCR>q?E)Gx&fEdd#?AO^Q^S;EO^h<2+6$Eg1N=|Mb!0=Rg1W{FmL^L!5cA zIH0USEtfz@5>i1zCeRbk6B;^jMlM|FapA$<8pgc_TN)a#)G8V3A%4DJu+O1hgIe}M zR7}vjjykQu(L1zayL6jArWGwO;6XL3K-Uh+5rf6~K+VBdFD~B7%Slm;m6l>j;`x^D z#JNb5d~<2}`{{Cz{R-2F@{lA+lT$)fn63kS6bq+fOZ(C zoIPw=Z}jVn`Y)WJ@B;UkIdodp0Z^g4)jWy?6nL&$oWdTCBJ?Lat|>L>QS0*k#x+3{ z<#8sX$TXuU8;ePb{Z0 zl%}OsoM3q2g2q#_oTM7UCwT}<+c{yg1|taj*O+EH(Z*ynk}9gB;360(-vdEjg-Me_ zu+X5c%tH;s2arxJoepi$hnJ3CcmMF(0|@swU}bd{#W@t0Q5?s^H(}rc)DoE%P=)%x zX5qTc#Q!rEs`KEQ-T{UwyhF8w;t~psu{zT%WA7~#GnZr3&qz=wmaBmMT@tV(BzWoV zS0va^T1QCm?%^HHlF>Ubu!ehiNdnZ5kN^YBPQqL}OGWS^G1I!Km5j4*RHCIC>^ZN~ zZ{~)X(G^%`1M0p})c=XmFJ&yisKTf8fWK#kR$*Xtz!2(33^f3}hLe^+XtG5G)ohz= zIaWd<)1LNqAlMH+oY)x{j!$3DHyqRbEZLiGGRwwwsH;O*eLKpuAV+}9?pv4bYkLA+@=IWoA5fQ2U{?y#Qa7aP8s#! z$Lim2>LWmVrwkvC)q&&GNzyVK|3Ih@Ko|zO)YA_NNQDaDFon)D{&1WXNh<5Gz}=d2 zpV^cr#nF^y_kZk!mvnypY`DK;4;Xw>Kfs?NLG3$v9#UpN7g&>ZPj{EQ%Zq%G{{frw BPA32W diff --git a/venv/lib/python3.8/site-packages/idna/__pycache__/compat.cpython-38.pyc b/venv/lib/python3.8/site-packages/idna/__pycache__/compat.cpython-38.pyc deleted file mode 100644 index 4150f4b755424765d43c603e0285363e356a2a1a..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 636 zcma)3%}yIJ5VkkF8wZ*S#0%_&L#n2WkdRslAtKj zlCPY21y0NaMT(FrbtKP^$DZ$-nah5Ei=o{9*e|a+W6u<9N`%2Fp7t0OFyM+!-z`TQ zK}SVRXVz)rS>e}dv zl4~KKfY0!>0+na??2%8{k{4JYmAWz@mpmk@{3+FvIcnlH&wXQaTifAW+p_v2VR&;b zr5gS^`de35zkObVF7wJXw)EfZB6O!_G&viO6T%@t7P(KT|BsAI@hQ;(Npu_$T@iU# z+Zcx4)L?s*?qRsb_>BI)F^GZ3Nk8%j4h$z36?b39=fx;HJUIBCfst*djnC%3R&^^g zT{hA>X*27LHf239YoHd%*?Yi9{^oH#^{fqW}N^ diff --git a/venv/lib/python3.8/site-packages/idna/__pycache__/core.cpython-38.pyc b/venv/lib/python3.8/site-packages/idna/__pycache__/core.cpython-38.pyc deleted file mode 100644 index 6bdcabbd5b0173ca374c87aa51ff3c34172501fb..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 9126 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 diff --git a/venv/lib/python3.8/site-packages/idna/__pycache__/package_data.cpython-38.pyc b/venv/lib/python3.8/site-packages/idna/__pycache__/package_data.cpython-38.pyc deleted file mode 100644 index 210ed9c6d5f1f0675270db426e965b108f2f5d00..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 163 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 HV*mYrqtaTi diff --git a/venv/lib/python3.8/site-packages/idna/codec.py b/venv/lib/python3.8/site-packages/idna/codec.py deleted file mode 100644 index 080f22a..0000000 --- a/venv/lib/python3.8/site-packages/idna/codec.py +++ /dev/null @@ -1,117 +0,0 @@ -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'): - # type: (str, str) -> Tuple[bytes, int] - if errors != 'strict': - raise IDNAError('Unsupported error handling \"{}\"'.format(errors)) - - if not data: - return b"", 0 - - return encode(data), len(data) - - def decode(self, data, errors='strict'): - # type: (bytes, str) -> Tuple[str, int] - if errors != 'strict': - raise IDNAError('Unsupported error handling \"{}\"'.format(errors)) - - if not data: - return '', 0 - - return decode(data), len(data) - -class IncrementalEncoder(codecs.BufferedIncrementalEncoder): - def _buffer_encode(self, data, errors, final): # type: ignore - # type: (str, str, bool) -> Tuple[str, int] - if errors != 'strict': - raise IDNAError('Unsupported error handling \"{}\"'.format(errors)) - - if not data: - return "", 0 - - labels = _unicode_dots_re.split(data) - trailing_dot = '' - if labels: - if not labels[-1]: - trailing_dot = '.' - del labels[-1] - elif not final: - # Keep potentially unfinished label until the next call - del labels[-1] - if labels: - trailing_dot = '.' - - result = [] - size = 0 - for label in labels: - result.append(alabel(label)) - if size: - size += 1 - size += len(label) - - # Join with U+002E - result_str = '.'.join(result) + trailing_dot # type: ignore - size += len(trailing_dot) - return result_str, size - -class IncrementalDecoder(codecs.BufferedIncrementalDecoder): - def _buffer_decode(self, data, errors, final): # type: ignore - # type: (str, str, bool) -> Tuple[str, int] - if errors != 'strict': - raise IDNAError('Unsupported error handling \"{}\"'.format(errors)) - - if not data: - return ('', 0) - - labels = _unicode_dots_re.split(data) - trailing_dot = '' - if labels: - if not labels[-1]: - trailing_dot = '.' - del labels[-1] - elif not final: - # Keep potentially unfinished label until the next call - del labels[-1] - if labels: - trailing_dot = '.' - - result = [] - size = 0 - for label in labels: - result.append(ulabel(label)) - if size: - size += 1 - size += len(label) - - result_str = '.'.join(result) + trailing_dot - size += len(trailing_dot) - return (result_str, size) - - -class StreamWriter(Codec, codecs.StreamWriter): - pass - - -class StreamReader(Codec, codecs.StreamReader): - pass - - -def getregentry(): - # type: () -> codecs.CodecInfo - # Compatibility as a search_function for codecs.register() - return codecs.CodecInfo( - name='idna', - encode=Codec().encode, # type: ignore - decode=Codec().decode, # type: ignore - incrementalencoder=IncrementalEncoder, - incrementaldecoder=IncrementalDecoder, - streamwriter=StreamWriter, - streamreader=StreamReader, - ) diff --git a/venv/lib/python3.8/site-packages/idna/compat.py b/venv/lib/python3.8/site-packages/idna/compat.py deleted file mode 100644 index dc896c7..0000000 --- a/venv/lib/python3.8/site-packages/idna/compat.py +++ /dev/null @@ -1,16 +0,0 @@ -from .core import * -from .codec import * -from typing import Any, Union - -def ToASCII(label): - # type: (str) -> bytes - return encode(label) - -def ToUnicode(label): - # type: (Union[bytes, bytearray]) -> str - return decode(label) - -def nameprep(s): - # type: (Any) -> None - raise NotImplementedError('IDNA 2008 does not utilise nameprep protocol') - diff --git a/venv/lib/python3.8/site-packages/idna/core.py b/venv/lib/python3.8/site-packages/idna/core.py deleted file mode 100644 index d605129..0000000 --- a/venv/lib/python3.8/site-packages/idna/core.py +++ /dev/null @@ -1,409 +0,0 @@ -from . import idnadata -import bisect -import unicodedata -import re -from typing import Union, Optional -from .intranges import intranges_contain - -_virama_combining_class = 9 -_alabel_prefix = b'xn--' -_unicode_dots_re = re.compile('[\u002e\u3002\uff0e\uff61]') - -class IDNAError(UnicodeError): - """ Base exception for all IDNA-encoding related problems """ - pass - - -class IDNABidiError(IDNAError): - """ Exception when bidirectional requirements are not satisfied """ - pass - - -class InvalidCodepoint(IDNAError): - """ Exception when a disallowed or unallocated codepoint is used """ - pass - - -class InvalidCodepointContext(IDNAError): - """ Exception when the codepoint is not valid in the context it is used """ - pass - - -def _combining_class(cp): - # type: (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): - # type: (str, str) -> bool - return intranges_contain(ord(cp), idnadata.scripts[script]) - -def _punycode(s): - # type: (str) -> bytes - return s.encode('punycode') - -def _unot(s): - # type: (int) -> str - return 'U+{:04X}'.format(s) - - -def valid_label_length(label): - # type: (Union[bytes, str]) -> bool - if len(label) > 63: - return False - return True - - -def valid_string_length(label, trailing_dot): - # type: (Union[bytes, str], bool) -> bool - if len(label) > (254 if trailing_dot else 253): - return False - return True - - -def check_bidi(label, check_ltr=False): - # type: (str, bool) -> bool - # Bidi rules should only be applied if string contains RTL characters - bidi_label = False - for (idx, cp) in enumerate(label, 1): - direction = unicodedata.bidirectional(cp) - if direction == '': - # String likely comes from a newer version of Unicode - raise IDNABidiError('Unknown directionality in label {} at position {}'.format(repr(label), idx)) - if direction in ['R', 'AL', 'AN']: - bidi_label = True - if not bidi_label and not check_ltr: - return True - - # Bidi rule 1 - direction = unicodedata.bidirectional(label[0]) - if direction in ['R', 'AL']: - rtl = True - elif direction == 'L': - rtl = False - else: - raise IDNABidiError('First codepoint in label {} must be directionality L, R or AL'.format(repr(label))) - - valid_ending = False - number_type = None # type: Optional[str] - for (idx, cp) in enumerate(label, 1): - direction = unicodedata.bidirectional(cp) - - if rtl: - # Bidi rule 2 - if not direction in ['R', 'AL', 'AN', 'EN', 'ES', 'CS', 'ET', 'ON', 'BN', 'NSM']: - raise IDNABidiError('Invalid direction for codepoint at position {} in a right-to-left label'.format(idx)) - # Bidi rule 3 - if direction in ['R', 'AL', 'EN', 'AN']: - valid_ending = True - elif direction != 'NSM': - valid_ending = False - # Bidi rule 4 - if direction in ['AN', 'EN']: - if not number_type: - number_type = direction - else: - if number_type != direction: - raise IDNABidiError('Can not mix numeral types in a right-to-left label') - else: - # Bidi rule 5 - if not direction in ['L', 'EN', 'ES', 'CS', 'ET', 'ON', 'BN', 'NSM']: - raise IDNABidiError('Invalid direction for codepoint at position {} in a left-to-right label'.format(idx)) - # Bidi rule 6 - if direction in ['L', 'EN']: - valid_ending = True - elif direction != 'NSM': - valid_ending = False - - if not valid_ending: - raise IDNABidiError('Label ends with illegal codepoint directionality') - - return True - - -def check_initial_combiner(label): - # type: (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): - # type: (str) -> bool - if label[2:4] == '--': - raise IDNAError('Label has disallowed hyphens in 3rd and 4th position') - if label[0] == '-' or label[-1] == '-': - raise IDNAError('Label must not start or end with a hyphen') - return True - - -def check_nfc(label): - # type: (str) -> None - if unicodedata.normalize('NFC', label) != label: - raise IDNAError('Label must be in Normalization Form C') - - -def valid_contextj(label, pos): - # type: (str, int) -> bool - cp_value = ord(label[pos]) - - if cp_value == 0x200c: - - if pos > 0: - if _combining_class(ord(label[pos - 1])) == _virama_combining_class: - return True - - ok = False - for i in range(pos-1, -1, -1): - joining_type = idnadata.joining_types.get(ord(label[i])) - if joining_type == ord('T'): - continue - if joining_type in [ord('L'), ord('D')]: - ok = True - break - - if not ok: - return False - - ok = False - for i in range(pos+1, len(label)): - joining_type = idnadata.joining_types.get(ord(label[i])) - if joining_type == ord('T'): - continue - if joining_type in [ord('R'), ord('D')]: - ok = True - break - return ok - - if cp_value == 0x200d: - - if pos > 0: - if _combining_class(ord(label[pos - 1])) == _virama_combining_class: - return True - return False - - else: - - return False - - -def valid_contexto(label, pos, exception=False): - # type: (str, int, bool) -> bool - cp_value = ord(label[pos]) - - if cp_value == 0x00b7: - if 0 < pos < len(label)-1: - if ord(label[pos - 1]) == 0x006c and ord(label[pos + 1]) == 0x006c: - return True - return False - - elif cp_value == 0x0375: - if pos < len(label)-1 and len(label) > 1: - return _is_script(label[pos + 1], 'Greek') - return False - - elif cp_value == 0x05f3 or cp_value == 0x05f4: - if pos > 0: - return _is_script(label[pos - 1], 'Hebrew') - return False - - elif cp_value == 0x30fb: - for cp in label: - if cp == '\u30fb': - continue - if _is_script(cp, 'Hiragana') or _is_script(cp, 'Katakana') or _is_script(cp, 'Han'): - return True - return False - - elif 0x660 <= cp_value <= 0x669: - for cp in label: - if 0x6f0 <= ord(cp) <= 0x06f9: - return False - return True - - elif 0x6f0 <= cp_value <= 0x6f9: - for cp in label: - if 0x660 <= ord(cp) <= 0x0669: - return False - return True - - return False - - -def check_label(label): - # type: (Union[str, bytes, bytearray]) -> None - if isinstance(label, (bytes, bytearray)): - label = label.decode('utf-8') - if len(label) == 0: - raise IDNAError('Empty Label') - - check_nfc(label) - check_hyphen_ok(label) - check_initial_combiner(label) - - for (pos, cp) in enumerate(label): - cp_value = ord(cp) - if intranges_contain(cp_value, idnadata.codepoint_classes['PVALID']): - continue - elif intranges_contain(cp_value, idnadata.codepoint_classes['CONTEXTJ']): - try: - if not valid_contextj(label, pos): - raise InvalidCodepointContext('Joiner {} not allowed at position {} in {}'.format( - _unot(cp_value), pos+1, repr(label))) - except ValueError: - raise IDNAError('Unknown codepoint adjacent to joiner {} at position {} in {}'.format( - _unot(cp_value), pos+1, repr(label))) - elif intranges_contain(cp_value, idnadata.codepoint_classes['CONTEXTO']): - if not valid_contexto(label, pos): - raise InvalidCodepointContext('Codepoint {} not allowed at position {} in {}'.format(_unot(cp_value), pos+1, repr(label))) - else: - raise InvalidCodepoint('Codepoint {} at position {} of {} not allowed'.format(_unot(cp_value), pos+1, repr(label))) - - check_bidi(label) - - -def alabel(label): - # type: (str) -> bytes - try: - label_bytes = label.encode('ascii') - ulabel(label_bytes) - if not valid_label_length(label_bytes): - raise IDNAError('Label too long') - return label_bytes - except UnicodeEncodeError: - pass - - if not label: - raise IDNAError('No Input') - - label = str(label) - check_label(label) - label_bytes = _punycode(label) - label_bytes = _alabel_prefix + label_bytes - - if not valid_label_length(label_bytes): - raise IDNAError('Label too long') - - return label_bytes - - -def ulabel(label): - # type: (Union[str, bytes, bytearray]) -> str - if not isinstance(label, (bytes, bytearray)): - try: - label_bytes = label.encode('ascii') - except UnicodeEncodeError: - check_label(label) - return label - else: - label_bytes = 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_bytes.decode('ascii')[-1] == '-': - raise IDNAError('A-label must not end with a hyphen') - else: - check_label(label_bytes) - return label_bytes.decode('ascii') - - label = label_bytes.decode('punycode') - check_label(label) - return label - - -def uts46_remap(domain, std3_rules=True, transitional=False): - # type: (str, bool, bool) -> str - """Re-map the characters in the string according to UTS46 processing.""" - from .uts46data import uts46data - output = '' - - 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 = 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)): - output += char - elif replacement is not None and (status == 'M' or - (status == '3' and not std3_rules) or - (status == 'D' and transitional)): - output += replacement - elif status != 'I': - raise IndexError() - 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): - # type: (Union[str, bytes, bytearray], bool, bool, bool, bool) -> bytes - if isinstance(s, (bytes, bytearray)): - s = s.decode('ascii') - if uts46: - s = uts46_remap(s, std3_rules, transitional) - trailing_dot = False - result = [] - if strict: - labels = s.split('.') - else: - labels = _unicode_dots_re.split(s) - if not labels or labels == ['']: - raise IDNAError('Empty domain') - if labels[-1] == '': - del labels[-1] - trailing_dot = True - for label in labels: - s = alabel(label) - if s: - result.append(s) - else: - raise IDNAError('Empty label') - if trailing_dot: - result.append(b'') - s = b'.'.join(result) - if not valid_string_length(s, trailing_dot): - raise IDNAError('Domain too long') - return s - - -def decode(s, strict=False, uts46=False, std3_rules=False): - # type: (Union[str, bytes, bytearray], bool, bool, bool) -> str - if isinstance(s, (bytes, bytearray)): - s = s.decode('ascii') - if uts46: - s = uts46_remap(s, std3_rules, False) - trailing_dot = False - result = [] - if not strict: - labels = _unicode_dots_re.split(s) - else: - labels = s.split('.') - if not labels or labels == ['']: - raise IDNAError('Empty domain') - if not labels[-1]: - del labels[-1] - trailing_dot = True - for label in labels: - s = ulabel(label) - if s: - result.append(s) - else: - raise IDNAError('Empty label') - if trailing_dot: - result.append('') - return '.'.join(result) diff --git a/venv/lib/python3.8/site-packages/idna/idnadata.py b/venv/lib/python3.8/site-packages/idna/idnadata.py deleted file mode 100644 index b86a3e0..0000000 --- a/venv/lib/python3.8/site-packages/idna/idnadata.py +++ /dev/null @@ -1,2050 +0,0 @@ -# This file is automatically generated by tools/idna-data - -__version__ = '13.0.0' -scripts = { - 'Greek': ( - 0x37000000374, - 0x37500000378, - 0x37a0000037e, - 0x37f00000380, - 0x38400000385, - 0x38600000387, - 0x3880000038b, - 0x38c0000038d, - 0x38e000003a2, - 0x3a3000003e2, - 0x3f000000400, - 0x1d2600001d2b, - 0x1d5d00001d62, - 0x1d6600001d6b, - 0x1dbf00001dc0, - 0x1f0000001f16, - 0x1f1800001f1e, - 0x1f2000001f46, - 0x1f4800001f4e, - 0x1f5000001f58, - 0x1f5900001f5a, - 0x1f5b00001f5c, - 0x1f5d00001f5e, - 0x1f5f00001f7e, - 0x1f8000001fb5, - 0x1fb600001fc5, - 0x1fc600001fd4, - 0x1fd600001fdc, - 0x1fdd00001ff0, - 0x1ff200001ff5, - 0x1ff600001fff, - 0x212600002127, - 0xab650000ab66, - 0x101400001018f, - 0x101a0000101a1, - 0x1d2000001d246, - ), - 'Han': ( - 0x2e8000002e9a, - 0x2e9b00002ef4, - 0x2f0000002fd6, - 0x300500003006, - 0x300700003008, - 0x30210000302a, - 0x30380000303c, - 0x340000004dc0, - 0x4e0000009ffd, - 0xf9000000fa6e, - 0xfa700000fada, - 0x16ff000016ff2, - 0x200000002a6de, - 0x2a7000002b735, - 0x2b7400002b81e, - 0x2b8200002cea2, - 0x2ceb00002ebe1, - 0x2f8000002fa1e, - 0x300000003134b, - ), - 'Hebrew': ( - 0x591000005c8, - 0x5d0000005eb, - 0x5ef000005f5, - 0xfb1d0000fb37, - 0xfb380000fb3d, - 0xfb3e0000fb3f, - 0xfb400000fb42, - 0xfb430000fb45, - 0xfb460000fb50, - ), - 'Hiragana': ( - 0x304100003097, - 0x309d000030a0, - 0x1b0010001b11f, - 0x1b1500001b153, - 0x1f2000001f201, - ), - 'Katakana': ( - 0x30a1000030fb, - 0x30fd00003100, - 0x31f000003200, - 0x32d0000032ff, - 0x330000003358, - 0xff660000ff70, - 0xff710000ff9e, - 0x1b0000001b001, - 0x1b1640001b168, - ), -} -joining_types = { - 0x600: 85, - 0x601: 85, - 0x602: 85, - 0x603: 85, - 0x604: 85, - 0x605: 85, - 0x608: 85, - 0x60b: 85, - 0x620: 68, - 0x621: 85, - 0x622: 82, - 0x623: 82, - 0x624: 82, - 0x625: 82, - 0x626: 68, - 0x627: 82, - 0x628: 68, - 0x629: 82, - 0x62a: 68, - 0x62b: 68, - 0x62c: 68, - 0x62d: 68, - 0x62e: 68, - 0x62f: 82, - 0x630: 82, - 0x631: 82, - 0x632: 82, - 0x633: 68, - 0x634: 68, - 0x635: 68, - 0x636: 68, - 0x637: 68, - 0x638: 68, - 0x639: 68, - 0x63a: 68, - 0x63b: 68, - 0x63c: 68, - 0x63d: 68, - 0x63e: 68, - 0x63f: 68, - 0x640: 67, - 0x641: 68, - 0x642: 68, - 0x643: 68, - 0x644: 68, - 0x645: 68, - 0x646: 68, - 0x647: 68, - 0x648: 82, - 0x649: 68, - 0x64a: 68, - 0x66e: 68, - 0x66f: 68, - 0x671: 82, - 0x672: 82, - 0x673: 82, - 0x674: 85, - 0x675: 82, - 0x676: 82, - 0x677: 82, - 0x678: 68, - 0x679: 68, - 0x67a: 68, - 0x67b: 68, - 0x67c: 68, - 0x67d: 68, - 0x67e: 68, - 0x67f: 68, - 0x680: 68, - 0x681: 68, - 0x682: 68, - 0x683: 68, - 0x684: 68, - 0x685: 68, - 0x686: 68, - 0x687: 68, - 0x688: 82, - 0x689: 82, - 0x68a: 82, - 0x68b: 82, - 0x68c: 82, - 0x68d: 82, - 0x68e: 82, - 0x68f: 82, - 0x690: 82, - 0x691: 82, - 0x692: 82, - 0x693: 82, - 0x694: 82, - 0x695: 82, - 0x696: 82, - 0x697: 82, - 0x698: 82, - 0x699: 82, - 0x69a: 68, - 0x69b: 68, - 0x69c: 68, - 0x69d: 68, - 0x69e: 68, - 0x69f: 68, - 0x6a0: 68, - 0x6a1: 68, - 0x6a2: 68, - 0x6a3: 68, - 0x6a4: 68, - 0x6a5: 68, - 0x6a6: 68, - 0x6a7: 68, - 0x6a8: 68, - 0x6a9: 68, - 0x6aa: 68, - 0x6ab: 68, - 0x6ac: 68, - 0x6ad: 68, - 0x6ae: 68, - 0x6af: 68, - 0x6b0: 68, - 0x6b1: 68, - 0x6b2: 68, - 0x6b3: 68, - 0x6b4: 68, - 0x6b5: 68, - 0x6b6: 68, - 0x6b7: 68, - 0x6b8: 68, - 0x6b9: 68, - 0x6ba: 68, - 0x6bb: 68, - 0x6bc: 68, - 0x6bd: 68, - 0x6be: 68, - 0x6bf: 68, - 0x6c0: 82, - 0x6c1: 68, - 0x6c2: 68, - 0x6c3: 82, - 0x6c4: 82, - 0x6c5: 82, - 0x6c6: 82, - 0x6c7: 82, - 0x6c8: 82, - 0x6c9: 82, - 0x6ca: 82, - 0x6cb: 82, - 0x6cc: 68, - 0x6cd: 82, - 0x6ce: 68, - 0x6cf: 82, - 0x6d0: 68, - 0x6d1: 68, - 0x6d2: 82, - 0x6d3: 82, - 0x6d5: 82, - 0x6dd: 85, - 0x6ee: 82, - 0x6ef: 82, - 0x6fa: 68, - 0x6fb: 68, - 0x6fc: 68, - 0x6ff: 68, - 0x70f: 84, - 0x710: 82, - 0x712: 68, - 0x713: 68, - 0x714: 68, - 0x715: 82, - 0x716: 82, - 0x717: 82, - 0x718: 82, - 0x719: 82, - 0x71a: 68, - 0x71b: 68, - 0x71c: 68, - 0x71d: 68, - 0x71e: 82, - 0x71f: 68, - 0x720: 68, - 0x721: 68, - 0x722: 68, - 0x723: 68, - 0x724: 68, - 0x725: 68, - 0x726: 68, - 0x727: 68, - 0x728: 82, - 0x729: 68, - 0x72a: 82, - 0x72b: 68, - 0x72c: 82, - 0x72d: 68, - 0x72e: 68, - 0x72f: 82, - 0x74d: 82, - 0x74e: 68, - 0x74f: 68, - 0x750: 68, - 0x751: 68, - 0x752: 68, - 0x753: 68, - 0x754: 68, - 0x755: 68, - 0x756: 68, - 0x757: 68, - 0x758: 68, - 0x759: 82, - 0x75a: 82, - 0x75b: 82, - 0x75c: 68, - 0x75d: 68, - 0x75e: 68, - 0x75f: 68, - 0x760: 68, - 0x761: 68, - 0x762: 68, - 0x763: 68, - 0x764: 68, - 0x765: 68, - 0x766: 68, - 0x767: 68, - 0x768: 68, - 0x769: 68, - 0x76a: 68, - 0x76b: 82, - 0x76c: 82, - 0x76d: 68, - 0x76e: 68, - 0x76f: 68, - 0x770: 68, - 0x771: 82, - 0x772: 68, - 0x773: 82, - 0x774: 82, - 0x775: 68, - 0x776: 68, - 0x777: 68, - 0x778: 82, - 0x779: 82, - 0x77a: 68, - 0x77b: 68, - 0x77c: 68, - 0x77d: 68, - 0x77e: 68, - 0x77f: 68, - 0x7ca: 68, - 0x7cb: 68, - 0x7cc: 68, - 0x7cd: 68, - 0x7ce: 68, - 0x7cf: 68, - 0x7d0: 68, - 0x7d1: 68, - 0x7d2: 68, - 0x7d3: 68, - 0x7d4: 68, - 0x7d5: 68, - 0x7d6: 68, - 0x7d7: 68, - 0x7d8: 68, - 0x7d9: 68, - 0x7da: 68, - 0x7db: 68, - 0x7dc: 68, - 0x7dd: 68, - 0x7de: 68, - 0x7df: 68, - 0x7e0: 68, - 0x7e1: 68, - 0x7e2: 68, - 0x7e3: 68, - 0x7e4: 68, - 0x7e5: 68, - 0x7e6: 68, - 0x7e7: 68, - 0x7e8: 68, - 0x7e9: 68, - 0x7ea: 68, - 0x7fa: 67, - 0x840: 82, - 0x841: 68, - 0x842: 68, - 0x843: 68, - 0x844: 68, - 0x845: 68, - 0x846: 82, - 0x847: 82, - 0x848: 68, - 0x849: 82, - 0x84a: 68, - 0x84b: 68, - 0x84c: 68, - 0x84d: 68, - 0x84e: 68, - 0x84f: 68, - 0x850: 68, - 0x851: 68, - 0x852: 68, - 0x853: 68, - 0x854: 82, - 0x855: 68, - 0x856: 82, - 0x857: 82, - 0x858: 82, - 0x860: 68, - 0x861: 85, - 0x862: 68, - 0x863: 68, - 0x864: 68, - 0x865: 68, - 0x866: 85, - 0x867: 82, - 0x868: 68, - 0x869: 82, - 0x86a: 82, - 0x8a0: 68, - 0x8a1: 68, - 0x8a2: 68, - 0x8a3: 68, - 0x8a4: 68, - 0x8a5: 68, - 0x8a6: 68, - 0x8a7: 68, - 0x8a8: 68, - 0x8a9: 68, - 0x8aa: 82, - 0x8ab: 82, - 0x8ac: 82, - 0x8ad: 85, - 0x8ae: 82, - 0x8af: 68, - 0x8b0: 68, - 0x8b1: 82, - 0x8b2: 82, - 0x8b3: 68, - 0x8b4: 68, - 0x8b6: 68, - 0x8b7: 68, - 0x8b8: 68, - 0x8b9: 82, - 0x8ba: 68, - 0x8bb: 68, - 0x8bc: 68, - 0x8bd: 68, - 0x8be: 68, - 0x8bf: 68, - 0x8c0: 68, - 0x8c1: 68, - 0x8c2: 68, - 0x8c3: 68, - 0x8c4: 68, - 0x8c5: 68, - 0x8c6: 68, - 0x8c7: 68, - 0x8e2: 85, - 0x1806: 85, - 0x1807: 68, - 0x180a: 67, - 0x180e: 85, - 0x1820: 68, - 0x1821: 68, - 0x1822: 68, - 0x1823: 68, - 0x1824: 68, - 0x1825: 68, - 0x1826: 68, - 0x1827: 68, - 0x1828: 68, - 0x1829: 68, - 0x182a: 68, - 0x182b: 68, - 0x182c: 68, - 0x182d: 68, - 0x182e: 68, - 0x182f: 68, - 0x1830: 68, - 0x1831: 68, - 0x1832: 68, - 0x1833: 68, - 0x1834: 68, - 0x1835: 68, - 0x1836: 68, - 0x1837: 68, - 0x1838: 68, - 0x1839: 68, - 0x183a: 68, - 0x183b: 68, - 0x183c: 68, - 0x183d: 68, - 0x183e: 68, - 0x183f: 68, - 0x1840: 68, - 0x1841: 68, - 0x1842: 68, - 0x1843: 68, - 0x1844: 68, - 0x1845: 68, - 0x1846: 68, - 0x1847: 68, - 0x1848: 68, - 0x1849: 68, - 0x184a: 68, - 0x184b: 68, - 0x184c: 68, - 0x184d: 68, - 0x184e: 68, - 0x184f: 68, - 0x1850: 68, - 0x1851: 68, - 0x1852: 68, - 0x1853: 68, - 0x1854: 68, - 0x1855: 68, - 0x1856: 68, - 0x1857: 68, - 0x1858: 68, - 0x1859: 68, - 0x185a: 68, - 0x185b: 68, - 0x185c: 68, - 0x185d: 68, - 0x185e: 68, - 0x185f: 68, - 0x1860: 68, - 0x1861: 68, - 0x1862: 68, - 0x1863: 68, - 0x1864: 68, - 0x1865: 68, - 0x1866: 68, - 0x1867: 68, - 0x1868: 68, - 0x1869: 68, - 0x186a: 68, - 0x186b: 68, - 0x186c: 68, - 0x186d: 68, - 0x186e: 68, - 0x186f: 68, - 0x1870: 68, - 0x1871: 68, - 0x1872: 68, - 0x1873: 68, - 0x1874: 68, - 0x1875: 68, - 0x1876: 68, - 0x1877: 68, - 0x1878: 68, - 0x1880: 85, - 0x1881: 85, - 0x1882: 85, - 0x1883: 85, - 0x1884: 85, - 0x1885: 84, - 0x1886: 84, - 0x1887: 68, - 0x1888: 68, - 0x1889: 68, - 0x188a: 68, - 0x188b: 68, - 0x188c: 68, - 0x188d: 68, - 0x188e: 68, - 0x188f: 68, - 0x1890: 68, - 0x1891: 68, - 0x1892: 68, - 0x1893: 68, - 0x1894: 68, - 0x1895: 68, - 0x1896: 68, - 0x1897: 68, - 0x1898: 68, - 0x1899: 68, - 0x189a: 68, - 0x189b: 68, - 0x189c: 68, - 0x189d: 68, - 0x189e: 68, - 0x189f: 68, - 0x18a0: 68, - 0x18a1: 68, - 0x18a2: 68, - 0x18a3: 68, - 0x18a4: 68, - 0x18a5: 68, - 0x18a6: 68, - 0x18a7: 68, - 0x18a8: 68, - 0x18aa: 68, - 0x200c: 85, - 0x200d: 67, - 0x202f: 85, - 0x2066: 85, - 0x2067: 85, - 0x2068: 85, - 0x2069: 85, - 0xa840: 68, - 0xa841: 68, - 0xa842: 68, - 0xa843: 68, - 0xa844: 68, - 0xa845: 68, - 0xa846: 68, - 0xa847: 68, - 0xa848: 68, - 0xa849: 68, - 0xa84a: 68, - 0xa84b: 68, - 0xa84c: 68, - 0xa84d: 68, - 0xa84e: 68, - 0xa84f: 68, - 0xa850: 68, - 0xa851: 68, - 0xa852: 68, - 0xa853: 68, - 0xa854: 68, - 0xa855: 68, - 0xa856: 68, - 0xa857: 68, - 0xa858: 68, - 0xa859: 68, - 0xa85a: 68, - 0xa85b: 68, - 0xa85c: 68, - 0xa85d: 68, - 0xa85e: 68, - 0xa85f: 68, - 0xa860: 68, - 0xa861: 68, - 0xa862: 68, - 0xa863: 68, - 0xa864: 68, - 0xa865: 68, - 0xa866: 68, - 0xa867: 68, - 0xa868: 68, - 0xa869: 68, - 0xa86a: 68, - 0xa86b: 68, - 0xa86c: 68, - 0xa86d: 68, - 0xa86e: 68, - 0xa86f: 68, - 0xa870: 68, - 0xa871: 68, - 0xa872: 76, - 0xa873: 85, - 0x10ac0: 68, - 0x10ac1: 68, - 0x10ac2: 68, - 0x10ac3: 68, - 0x10ac4: 68, - 0x10ac5: 82, - 0x10ac6: 85, - 0x10ac7: 82, - 0x10ac8: 85, - 0x10ac9: 82, - 0x10aca: 82, - 0x10acb: 85, - 0x10acc: 85, - 0x10acd: 76, - 0x10ace: 82, - 0x10acf: 82, - 0x10ad0: 82, - 0x10ad1: 82, - 0x10ad2: 82, - 0x10ad3: 68, - 0x10ad4: 68, - 0x10ad5: 68, - 0x10ad6: 68, - 0x10ad7: 76, - 0x10ad8: 68, - 0x10ad9: 68, - 0x10ada: 68, - 0x10adb: 68, - 0x10adc: 68, - 0x10add: 82, - 0x10ade: 68, - 0x10adf: 68, - 0x10ae0: 68, - 0x10ae1: 82, - 0x10ae2: 85, - 0x10ae3: 85, - 0x10ae4: 82, - 0x10aeb: 68, - 0x10aec: 68, - 0x10aed: 68, - 0x10aee: 68, - 0x10aef: 82, - 0x10b80: 68, - 0x10b81: 82, - 0x10b82: 68, - 0x10b83: 82, - 0x10b84: 82, - 0x10b85: 82, - 0x10b86: 68, - 0x10b87: 68, - 0x10b88: 68, - 0x10b89: 82, - 0x10b8a: 68, - 0x10b8b: 68, - 0x10b8c: 82, - 0x10b8d: 68, - 0x10b8e: 82, - 0x10b8f: 82, - 0x10b90: 68, - 0x10b91: 82, - 0x10ba9: 82, - 0x10baa: 82, - 0x10bab: 82, - 0x10bac: 82, - 0x10bad: 68, - 0x10bae: 68, - 0x10baf: 85, - 0x10d00: 76, - 0x10d01: 68, - 0x10d02: 68, - 0x10d03: 68, - 0x10d04: 68, - 0x10d05: 68, - 0x10d06: 68, - 0x10d07: 68, - 0x10d08: 68, - 0x10d09: 68, - 0x10d0a: 68, - 0x10d0b: 68, - 0x10d0c: 68, - 0x10d0d: 68, - 0x10d0e: 68, - 0x10d0f: 68, - 0x10d10: 68, - 0x10d11: 68, - 0x10d12: 68, - 0x10d13: 68, - 0x10d14: 68, - 0x10d15: 68, - 0x10d16: 68, - 0x10d17: 68, - 0x10d18: 68, - 0x10d19: 68, - 0x10d1a: 68, - 0x10d1b: 68, - 0x10d1c: 68, - 0x10d1d: 68, - 0x10d1e: 68, - 0x10d1f: 68, - 0x10d20: 68, - 0x10d21: 68, - 0x10d22: 82, - 0x10d23: 68, - 0x10f30: 68, - 0x10f31: 68, - 0x10f32: 68, - 0x10f33: 82, - 0x10f34: 68, - 0x10f35: 68, - 0x10f36: 68, - 0x10f37: 68, - 0x10f38: 68, - 0x10f39: 68, - 0x10f3a: 68, - 0x10f3b: 68, - 0x10f3c: 68, - 0x10f3d: 68, - 0x10f3e: 68, - 0x10f3f: 68, - 0x10f40: 68, - 0x10f41: 68, - 0x10f42: 68, - 0x10f43: 68, - 0x10f44: 68, - 0x10f45: 85, - 0x10f51: 68, - 0x10f52: 68, - 0x10f53: 68, - 0x10f54: 82, - 0x10fb0: 68, - 0x10fb1: 85, - 0x10fb2: 68, - 0x10fb3: 68, - 0x10fb4: 82, - 0x10fb5: 82, - 0x10fb6: 82, - 0x10fb7: 85, - 0x10fb8: 68, - 0x10fb9: 82, - 0x10fba: 82, - 0x10fbb: 68, - 0x10fbc: 68, - 0x10fbd: 82, - 0x10fbe: 68, - 0x10fbf: 68, - 0x10fc0: 85, - 0x10fc1: 68, - 0x10fc2: 82, - 0x10fc3: 82, - 0x10fc4: 68, - 0x10fc5: 85, - 0x10fc6: 85, - 0x10fc7: 85, - 0x10fc8: 85, - 0x10fc9: 82, - 0x10fca: 68, - 0x10fcb: 76, - 0x110bd: 85, - 0x110cd: 85, - 0x1e900: 68, - 0x1e901: 68, - 0x1e902: 68, - 0x1e903: 68, - 0x1e904: 68, - 0x1e905: 68, - 0x1e906: 68, - 0x1e907: 68, - 0x1e908: 68, - 0x1e909: 68, - 0x1e90a: 68, - 0x1e90b: 68, - 0x1e90c: 68, - 0x1e90d: 68, - 0x1e90e: 68, - 0x1e90f: 68, - 0x1e910: 68, - 0x1e911: 68, - 0x1e912: 68, - 0x1e913: 68, - 0x1e914: 68, - 0x1e915: 68, - 0x1e916: 68, - 0x1e917: 68, - 0x1e918: 68, - 0x1e919: 68, - 0x1e91a: 68, - 0x1e91b: 68, - 0x1e91c: 68, - 0x1e91d: 68, - 0x1e91e: 68, - 0x1e91f: 68, - 0x1e920: 68, - 0x1e921: 68, - 0x1e922: 68, - 0x1e923: 68, - 0x1e924: 68, - 0x1e925: 68, - 0x1e926: 68, - 0x1e927: 68, - 0x1e928: 68, - 0x1e929: 68, - 0x1e92a: 68, - 0x1e92b: 68, - 0x1e92c: 68, - 0x1e92d: 68, - 0x1e92e: 68, - 0x1e92f: 68, - 0x1e930: 68, - 0x1e931: 68, - 0x1e932: 68, - 0x1e933: 68, - 0x1e934: 68, - 0x1e935: 68, - 0x1e936: 68, - 0x1e937: 68, - 0x1e938: 68, - 0x1e939: 68, - 0x1e93a: 68, - 0x1e93b: 68, - 0x1e93c: 68, - 0x1e93d: 68, - 0x1e93e: 68, - 0x1e93f: 68, - 0x1e940: 68, - 0x1e941: 68, - 0x1e942: 68, - 0x1e943: 68, - 0x1e94b: 84, -} -codepoint_classes = { - 'PVALID': ( - 0x2d0000002e, - 0x300000003a, - 0x610000007b, - 0xdf000000f7, - 0xf800000100, - 0x10100000102, - 0x10300000104, - 0x10500000106, - 0x10700000108, - 0x1090000010a, - 0x10b0000010c, - 0x10d0000010e, - 0x10f00000110, - 0x11100000112, - 0x11300000114, - 0x11500000116, - 0x11700000118, - 0x1190000011a, - 0x11b0000011c, - 0x11d0000011e, - 0x11f00000120, - 0x12100000122, - 0x12300000124, - 0x12500000126, - 0x12700000128, - 0x1290000012a, - 0x12b0000012c, - 0x12d0000012e, - 0x12f00000130, - 0x13100000132, - 0x13500000136, - 0x13700000139, - 0x13a0000013b, - 0x13c0000013d, - 0x13e0000013f, - 0x14200000143, - 0x14400000145, - 0x14600000147, - 0x14800000149, - 0x14b0000014c, - 0x14d0000014e, - 0x14f00000150, - 0x15100000152, - 0x15300000154, - 0x15500000156, - 0x15700000158, - 0x1590000015a, - 0x15b0000015c, - 0x15d0000015e, - 0x15f00000160, - 0x16100000162, - 0x16300000164, - 0x16500000166, - 0x16700000168, - 0x1690000016a, - 0x16b0000016c, - 0x16d0000016e, - 0x16f00000170, - 0x17100000172, - 0x17300000174, - 0x17500000176, - 0x17700000178, - 0x17a0000017b, - 0x17c0000017d, - 0x17e0000017f, - 0x18000000181, - 0x18300000184, - 0x18500000186, - 0x18800000189, - 0x18c0000018e, - 0x19200000193, - 0x19500000196, - 0x1990000019c, - 0x19e0000019f, - 0x1a1000001a2, - 0x1a3000001a4, - 0x1a5000001a6, - 0x1a8000001a9, - 0x1aa000001ac, - 0x1ad000001ae, - 0x1b0000001b1, - 0x1b4000001b5, - 0x1b6000001b7, - 0x1b9000001bc, - 0x1bd000001c4, - 0x1ce000001cf, - 0x1d0000001d1, - 0x1d2000001d3, - 0x1d4000001d5, - 0x1d6000001d7, - 0x1d8000001d9, - 0x1da000001db, - 0x1dc000001de, - 0x1df000001e0, - 0x1e1000001e2, - 0x1e3000001e4, - 0x1e5000001e6, - 0x1e7000001e8, - 0x1e9000001ea, - 0x1eb000001ec, - 0x1ed000001ee, - 0x1ef000001f1, - 0x1f5000001f6, - 0x1f9000001fa, - 0x1fb000001fc, - 0x1fd000001fe, - 0x1ff00000200, - 0x20100000202, - 0x20300000204, - 0x20500000206, - 0x20700000208, - 0x2090000020a, - 0x20b0000020c, - 0x20d0000020e, - 0x20f00000210, - 0x21100000212, - 0x21300000214, - 0x21500000216, - 0x21700000218, - 0x2190000021a, - 0x21b0000021c, - 0x21d0000021e, - 0x21f00000220, - 0x22100000222, - 0x22300000224, - 0x22500000226, - 0x22700000228, - 0x2290000022a, - 0x22b0000022c, - 0x22d0000022e, - 0x22f00000230, - 0x23100000232, - 0x2330000023a, - 0x23c0000023d, - 0x23f00000241, - 0x24200000243, - 0x24700000248, - 0x2490000024a, - 0x24b0000024c, - 0x24d0000024e, - 0x24f000002b0, - 0x2b9000002c2, - 0x2c6000002d2, - 0x2ec000002ed, - 0x2ee000002ef, - 0x30000000340, - 0x34200000343, - 0x3460000034f, - 0x35000000370, - 0x37100000372, - 0x37300000374, - 0x37700000378, - 0x37b0000037e, - 0x39000000391, - 0x3ac000003cf, - 0x3d7000003d8, - 0x3d9000003da, - 0x3db000003dc, - 0x3dd000003de, - 0x3df000003e0, - 0x3e1000003e2, - 0x3e3000003e4, - 0x3e5000003e6, - 0x3e7000003e8, - 0x3e9000003ea, - 0x3eb000003ec, - 0x3ed000003ee, - 0x3ef000003f0, - 0x3f3000003f4, - 0x3f8000003f9, - 0x3fb000003fd, - 0x43000000460, - 0x46100000462, - 0x46300000464, - 0x46500000466, - 0x46700000468, - 0x4690000046a, - 0x46b0000046c, - 0x46d0000046e, - 0x46f00000470, - 0x47100000472, - 0x47300000474, - 0x47500000476, - 0x47700000478, - 0x4790000047a, - 0x47b0000047c, - 0x47d0000047e, - 0x47f00000480, - 0x48100000482, - 0x48300000488, - 0x48b0000048c, - 0x48d0000048e, - 0x48f00000490, - 0x49100000492, - 0x49300000494, - 0x49500000496, - 0x49700000498, - 0x4990000049a, - 0x49b0000049c, - 0x49d0000049e, - 0x49f000004a0, - 0x4a1000004a2, - 0x4a3000004a4, - 0x4a5000004a6, - 0x4a7000004a8, - 0x4a9000004aa, - 0x4ab000004ac, - 0x4ad000004ae, - 0x4af000004b0, - 0x4b1000004b2, - 0x4b3000004b4, - 0x4b5000004b6, - 0x4b7000004b8, - 0x4b9000004ba, - 0x4bb000004bc, - 0x4bd000004be, - 0x4bf000004c0, - 0x4c2000004c3, - 0x4c4000004c5, - 0x4c6000004c7, - 0x4c8000004c9, - 0x4ca000004cb, - 0x4cc000004cd, - 0x4ce000004d0, - 0x4d1000004d2, - 0x4d3000004d4, - 0x4d5000004d6, - 0x4d7000004d8, - 0x4d9000004da, - 0x4db000004dc, - 0x4dd000004de, - 0x4df000004e0, - 0x4e1000004e2, - 0x4e3000004e4, - 0x4e5000004e6, - 0x4e7000004e8, - 0x4e9000004ea, - 0x4eb000004ec, - 0x4ed000004ee, - 0x4ef000004f0, - 0x4f1000004f2, - 0x4f3000004f4, - 0x4f5000004f6, - 0x4f7000004f8, - 0x4f9000004fa, - 0x4fb000004fc, - 0x4fd000004fe, - 0x4ff00000500, - 0x50100000502, - 0x50300000504, - 0x50500000506, - 0x50700000508, - 0x5090000050a, - 0x50b0000050c, - 0x50d0000050e, - 0x50f00000510, - 0x51100000512, - 0x51300000514, - 0x51500000516, - 0x51700000518, - 0x5190000051a, - 0x51b0000051c, - 0x51d0000051e, - 0x51f00000520, - 0x52100000522, - 0x52300000524, - 0x52500000526, - 0x52700000528, - 0x5290000052a, - 0x52b0000052c, - 0x52d0000052e, - 0x52f00000530, - 0x5590000055a, - 0x56000000587, - 0x58800000589, - 0x591000005be, - 0x5bf000005c0, - 0x5c1000005c3, - 0x5c4000005c6, - 0x5c7000005c8, - 0x5d0000005eb, - 0x5ef000005f3, - 0x6100000061b, - 0x62000000640, - 0x64100000660, - 0x66e00000675, - 0x679000006d4, - 0x6d5000006dd, - 0x6df000006e9, - 0x6ea000006f0, - 0x6fa00000700, - 0x7100000074b, - 0x74d000007b2, - 0x7c0000007f6, - 0x7fd000007fe, - 0x8000000082e, - 0x8400000085c, - 0x8600000086b, - 0x8a0000008b5, - 0x8b6000008c8, - 0x8d3000008e2, - 0x8e300000958, - 0x96000000964, - 0x96600000970, - 0x97100000984, - 0x9850000098d, - 0x98f00000991, - 0x993000009a9, - 0x9aa000009b1, - 0x9b2000009b3, - 0x9b6000009ba, - 0x9bc000009c5, - 0x9c7000009c9, - 0x9cb000009cf, - 0x9d7000009d8, - 0x9e0000009e4, - 0x9e6000009f2, - 0x9fc000009fd, - 0x9fe000009ff, - 0xa0100000a04, - 0xa0500000a0b, - 0xa0f00000a11, - 0xa1300000a29, - 0xa2a00000a31, - 0xa3200000a33, - 0xa3500000a36, - 0xa3800000a3a, - 0xa3c00000a3d, - 0xa3e00000a43, - 0xa4700000a49, - 0xa4b00000a4e, - 0xa5100000a52, - 0xa5c00000a5d, - 0xa6600000a76, - 0xa8100000a84, - 0xa8500000a8e, - 0xa8f00000a92, - 0xa9300000aa9, - 0xaaa00000ab1, - 0xab200000ab4, - 0xab500000aba, - 0xabc00000ac6, - 0xac700000aca, - 0xacb00000ace, - 0xad000000ad1, - 0xae000000ae4, - 0xae600000af0, - 0xaf900000b00, - 0xb0100000b04, - 0xb0500000b0d, - 0xb0f00000b11, - 0xb1300000b29, - 0xb2a00000b31, - 0xb3200000b34, - 0xb3500000b3a, - 0xb3c00000b45, - 0xb4700000b49, - 0xb4b00000b4e, - 0xb5500000b58, - 0xb5f00000b64, - 0xb6600000b70, - 0xb7100000b72, - 0xb8200000b84, - 0xb8500000b8b, - 0xb8e00000b91, - 0xb9200000b96, - 0xb9900000b9b, - 0xb9c00000b9d, - 0xb9e00000ba0, - 0xba300000ba5, - 0xba800000bab, - 0xbae00000bba, - 0xbbe00000bc3, - 0xbc600000bc9, - 0xbca00000bce, - 0xbd000000bd1, - 0xbd700000bd8, - 0xbe600000bf0, - 0xc0000000c0d, - 0xc0e00000c11, - 0xc1200000c29, - 0xc2a00000c3a, - 0xc3d00000c45, - 0xc4600000c49, - 0xc4a00000c4e, - 0xc5500000c57, - 0xc5800000c5b, - 0xc6000000c64, - 0xc6600000c70, - 0xc8000000c84, - 0xc8500000c8d, - 0xc8e00000c91, - 0xc9200000ca9, - 0xcaa00000cb4, - 0xcb500000cba, - 0xcbc00000cc5, - 0xcc600000cc9, - 0xcca00000cce, - 0xcd500000cd7, - 0xcde00000cdf, - 0xce000000ce4, - 0xce600000cf0, - 0xcf100000cf3, - 0xd0000000d0d, - 0xd0e00000d11, - 0xd1200000d45, - 0xd4600000d49, - 0xd4a00000d4f, - 0xd5400000d58, - 0xd5f00000d64, - 0xd6600000d70, - 0xd7a00000d80, - 0xd8100000d84, - 0xd8500000d97, - 0xd9a00000db2, - 0xdb300000dbc, - 0xdbd00000dbe, - 0xdc000000dc7, - 0xdca00000dcb, - 0xdcf00000dd5, - 0xdd600000dd7, - 0xdd800000de0, - 0xde600000df0, - 0xdf200000df4, - 0xe0100000e33, - 0xe3400000e3b, - 0xe4000000e4f, - 0xe5000000e5a, - 0xe8100000e83, - 0xe8400000e85, - 0xe8600000e8b, - 0xe8c00000ea4, - 0xea500000ea6, - 0xea700000eb3, - 0xeb400000ebe, - 0xec000000ec5, - 0xec600000ec7, - 0xec800000ece, - 0xed000000eda, - 0xede00000ee0, - 0xf0000000f01, - 0xf0b00000f0c, - 0xf1800000f1a, - 0xf2000000f2a, - 0xf3500000f36, - 0xf3700000f38, - 0xf3900000f3a, - 0xf3e00000f43, - 0xf4400000f48, - 0xf4900000f4d, - 0xf4e00000f52, - 0xf5300000f57, - 0xf5800000f5c, - 0xf5d00000f69, - 0xf6a00000f6d, - 0xf7100000f73, - 0xf7400000f75, - 0xf7a00000f81, - 0xf8200000f85, - 0xf8600000f93, - 0xf9400000f98, - 0xf9900000f9d, - 0xf9e00000fa2, - 0xfa300000fa7, - 0xfa800000fac, - 0xfad00000fb9, - 0xfba00000fbd, - 0xfc600000fc7, - 0x10000000104a, - 0x10500000109e, - 0x10d0000010fb, - 0x10fd00001100, - 0x120000001249, - 0x124a0000124e, - 0x125000001257, - 0x125800001259, - 0x125a0000125e, - 0x126000001289, - 0x128a0000128e, - 0x1290000012b1, - 0x12b2000012b6, - 0x12b8000012bf, - 0x12c0000012c1, - 0x12c2000012c6, - 0x12c8000012d7, - 0x12d800001311, - 0x131200001316, - 0x13180000135b, - 0x135d00001360, - 0x138000001390, - 0x13a0000013f6, - 0x14010000166d, - 0x166f00001680, - 0x16810000169b, - 0x16a0000016eb, - 0x16f1000016f9, - 0x17000000170d, - 0x170e00001715, - 0x172000001735, - 0x174000001754, - 0x17600000176d, - 0x176e00001771, - 0x177200001774, - 0x1780000017b4, - 0x17b6000017d4, - 0x17d7000017d8, - 0x17dc000017de, - 0x17e0000017ea, - 0x18100000181a, - 0x182000001879, - 0x1880000018ab, - 0x18b0000018f6, - 0x19000000191f, - 0x19200000192c, - 0x19300000193c, - 0x19460000196e, - 0x197000001975, - 0x1980000019ac, - 0x19b0000019ca, - 0x19d0000019da, - 0x1a0000001a1c, - 0x1a2000001a5f, - 0x1a6000001a7d, - 0x1a7f00001a8a, - 0x1a9000001a9a, - 0x1aa700001aa8, - 0x1ab000001abe, - 0x1abf00001ac1, - 0x1b0000001b4c, - 0x1b5000001b5a, - 0x1b6b00001b74, - 0x1b8000001bf4, - 0x1c0000001c38, - 0x1c4000001c4a, - 0x1c4d00001c7e, - 0x1cd000001cd3, - 0x1cd400001cfb, - 0x1d0000001d2c, - 0x1d2f00001d30, - 0x1d3b00001d3c, - 0x1d4e00001d4f, - 0x1d6b00001d78, - 0x1d7900001d9b, - 0x1dc000001dfa, - 0x1dfb00001e00, - 0x1e0100001e02, - 0x1e0300001e04, - 0x1e0500001e06, - 0x1e0700001e08, - 0x1e0900001e0a, - 0x1e0b00001e0c, - 0x1e0d00001e0e, - 0x1e0f00001e10, - 0x1e1100001e12, - 0x1e1300001e14, - 0x1e1500001e16, - 0x1e1700001e18, - 0x1e1900001e1a, - 0x1e1b00001e1c, - 0x1e1d00001e1e, - 0x1e1f00001e20, - 0x1e2100001e22, - 0x1e2300001e24, - 0x1e2500001e26, - 0x1e2700001e28, - 0x1e2900001e2a, - 0x1e2b00001e2c, - 0x1e2d00001e2e, - 0x1e2f00001e30, - 0x1e3100001e32, - 0x1e3300001e34, - 0x1e3500001e36, - 0x1e3700001e38, - 0x1e3900001e3a, - 0x1e3b00001e3c, - 0x1e3d00001e3e, - 0x1e3f00001e40, - 0x1e4100001e42, - 0x1e4300001e44, - 0x1e4500001e46, - 0x1e4700001e48, - 0x1e4900001e4a, - 0x1e4b00001e4c, - 0x1e4d00001e4e, - 0x1e4f00001e50, - 0x1e5100001e52, - 0x1e5300001e54, - 0x1e5500001e56, - 0x1e5700001e58, - 0x1e5900001e5a, - 0x1e5b00001e5c, - 0x1e5d00001e5e, - 0x1e5f00001e60, - 0x1e6100001e62, - 0x1e6300001e64, - 0x1e6500001e66, - 0x1e6700001e68, - 0x1e6900001e6a, - 0x1e6b00001e6c, - 0x1e6d00001e6e, - 0x1e6f00001e70, - 0x1e7100001e72, - 0x1e7300001e74, - 0x1e7500001e76, - 0x1e7700001e78, - 0x1e7900001e7a, - 0x1e7b00001e7c, - 0x1e7d00001e7e, - 0x1e7f00001e80, - 0x1e8100001e82, - 0x1e8300001e84, - 0x1e8500001e86, - 0x1e8700001e88, - 0x1e8900001e8a, - 0x1e8b00001e8c, - 0x1e8d00001e8e, - 0x1e8f00001e90, - 0x1e9100001e92, - 0x1e9300001e94, - 0x1e9500001e9a, - 0x1e9c00001e9e, - 0x1e9f00001ea0, - 0x1ea100001ea2, - 0x1ea300001ea4, - 0x1ea500001ea6, - 0x1ea700001ea8, - 0x1ea900001eaa, - 0x1eab00001eac, - 0x1ead00001eae, - 0x1eaf00001eb0, - 0x1eb100001eb2, - 0x1eb300001eb4, - 0x1eb500001eb6, - 0x1eb700001eb8, - 0x1eb900001eba, - 0x1ebb00001ebc, - 0x1ebd00001ebe, - 0x1ebf00001ec0, - 0x1ec100001ec2, - 0x1ec300001ec4, - 0x1ec500001ec6, - 0x1ec700001ec8, - 0x1ec900001eca, - 0x1ecb00001ecc, - 0x1ecd00001ece, - 0x1ecf00001ed0, - 0x1ed100001ed2, - 0x1ed300001ed4, - 0x1ed500001ed6, - 0x1ed700001ed8, - 0x1ed900001eda, - 0x1edb00001edc, - 0x1edd00001ede, - 0x1edf00001ee0, - 0x1ee100001ee2, - 0x1ee300001ee4, - 0x1ee500001ee6, - 0x1ee700001ee8, - 0x1ee900001eea, - 0x1eeb00001eec, - 0x1eed00001eee, - 0x1eef00001ef0, - 0x1ef100001ef2, - 0x1ef300001ef4, - 0x1ef500001ef6, - 0x1ef700001ef8, - 0x1ef900001efa, - 0x1efb00001efc, - 0x1efd00001efe, - 0x1eff00001f08, - 0x1f1000001f16, - 0x1f2000001f28, - 0x1f3000001f38, - 0x1f4000001f46, - 0x1f5000001f58, - 0x1f6000001f68, - 0x1f7000001f71, - 0x1f7200001f73, - 0x1f7400001f75, - 0x1f7600001f77, - 0x1f7800001f79, - 0x1f7a00001f7b, - 0x1f7c00001f7d, - 0x1fb000001fb2, - 0x1fb600001fb7, - 0x1fc600001fc7, - 0x1fd000001fd3, - 0x1fd600001fd8, - 0x1fe000001fe3, - 0x1fe400001fe8, - 0x1ff600001ff7, - 0x214e0000214f, - 0x218400002185, - 0x2c3000002c5f, - 0x2c6100002c62, - 0x2c6500002c67, - 0x2c6800002c69, - 0x2c6a00002c6b, - 0x2c6c00002c6d, - 0x2c7100002c72, - 0x2c7300002c75, - 0x2c7600002c7c, - 0x2c8100002c82, - 0x2c8300002c84, - 0x2c8500002c86, - 0x2c8700002c88, - 0x2c8900002c8a, - 0x2c8b00002c8c, - 0x2c8d00002c8e, - 0x2c8f00002c90, - 0x2c9100002c92, - 0x2c9300002c94, - 0x2c9500002c96, - 0x2c9700002c98, - 0x2c9900002c9a, - 0x2c9b00002c9c, - 0x2c9d00002c9e, - 0x2c9f00002ca0, - 0x2ca100002ca2, - 0x2ca300002ca4, - 0x2ca500002ca6, - 0x2ca700002ca8, - 0x2ca900002caa, - 0x2cab00002cac, - 0x2cad00002cae, - 0x2caf00002cb0, - 0x2cb100002cb2, - 0x2cb300002cb4, - 0x2cb500002cb6, - 0x2cb700002cb8, - 0x2cb900002cba, - 0x2cbb00002cbc, - 0x2cbd00002cbe, - 0x2cbf00002cc0, - 0x2cc100002cc2, - 0x2cc300002cc4, - 0x2cc500002cc6, - 0x2cc700002cc8, - 0x2cc900002cca, - 0x2ccb00002ccc, - 0x2ccd00002cce, - 0x2ccf00002cd0, - 0x2cd100002cd2, - 0x2cd300002cd4, - 0x2cd500002cd6, - 0x2cd700002cd8, - 0x2cd900002cda, - 0x2cdb00002cdc, - 0x2cdd00002cde, - 0x2cdf00002ce0, - 0x2ce100002ce2, - 0x2ce300002ce5, - 0x2cec00002ced, - 0x2cee00002cf2, - 0x2cf300002cf4, - 0x2d0000002d26, - 0x2d2700002d28, - 0x2d2d00002d2e, - 0x2d3000002d68, - 0x2d7f00002d97, - 0x2da000002da7, - 0x2da800002daf, - 0x2db000002db7, - 0x2db800002dbf, - 0x2dc000002dc7, - 0x2dc800002dcf, - 0x2dd000002dd7, - 0x2dd800002ddf, - 0x2de000002e00, - 0x2e2f00002e30, - 0x300500003008, - 0x302a0000302e, - 0x303c0000303d, - 0x304100003097, - 0x30990000309b, - 0x309d0000309f, - 0x30a1000030fb, - 0x30fc000030ff, - 0x310500003130, - 0x31a0000031c0, - 0x31f000003200, - 0x340000004dc0, - 0x4e0000009ffd, - 0xa0000000a48d, - 0xa4d00000a4fe, - 0xa5000000a60d, - 0xa6100000a62c, - 0xa6410000a642, - 0xa6430000a644, - 0xa6450000a646, - 0xa6470000a648, - 0xa6490000a64a, - 0xa64b0000a64c, - 0xa64d0000a64e, - 0xa64f0000a650, - 0xa6510000a652, - 0xa6530000a654, - 0xa6550000a656, - 0xa6570000a658, - 0xa6590000a65a, - 0xa65b0000a65c, - 0xa65d0000a65e, - 0xa65f0000a660, - 0xa6610000a662, - 0xa6630000a664, - 0xa6650000a666, - 0xa6670000a668, - 0xa6690000a66a, - 0xa66b0000a66c, - 0xa66d0000a670, - 0xa6740000a67e, - 0xa67f0000a680, - 0xa6810000a682, - 0xa6830000a684, - 0xa6850000a686, - 0xa6870000a688, - 0xa6890000a68a, - 0xa68b0000a68c, - 0xa68d0000a68e, - 0xa68f0000a690, - 0xa6910000a692, - 0xa6930000a694, - 0xa6950000a696, - 0xa6970000a698, - 0xa6990000a69a, - 0xa69b0000a69c, - 0xa69e0000a6e6, - 0xa6f00000a6f2, - 0xa7170000a720, - 0xa7230000a724, - 0xa7250000a726, - 0xa7270000a728, - 0xa7290000a72a, - 0xa72b0000a72c, - 0xa72d0000a72e, - 0xa72f0000a732, - 0xa7330000a734, - 0xa7350000a736, - 0xa7370000a738, - 0xa7390000a73a, - 0xa73b0000a73c, - 0xa73d0000a73e, - 0xa73f0000a740, - 0xa7410000a742, - 0xa7430000a744, - 0xa7450000a746, - 0xa7470000a748, - 0xa7490000a74a, - 0xa74b0000a74c, - 0xa74d0000a74e, - 0xa74f0000a750, - 0xa7510000a752, - 0xa7530000a754, - 0xa7550000a756, - 0xa7570000a758, - 0xa7590000a75a, - 0xa75b0000a75c, - 0xa75d0000a75e, - 0xa75f0000a760, - 0xa7610000a762, - 0xa7630000a764, - 0xa7650000a766, - 0xa7670000a768, - 0xa7690000a76a, - 0xa76b0000a76c, - 0xa76d0000a76e, - 0xa76f0000a770, - 0xa7710000a779, - 0xa77a0000a77b, - 0xa77c0000a77d, - 0xa77f0000a780, - 0xa7810000a782, - 0xa7830000a784, - 0xa7850000a786, - 0xa7870000a789, - 0xa78c0000a78d, - 0xa78e0000a790, - 0xa7910000a792, - 0xa7930000a796, - 0xa7970000a798, - 0xa7990000a79a, - 0xa79b0000a79c, - 0xa79d0000a79e, - 0xa79f0000a7a0, - 0xa7a10000a7a2, - 0xa7a30000a7a4, - 0xa7a50000a7a6, - 0xa7a70000a7a8, - 0xa7a90000a7aa, - 0xa7af0000a7b0, - 0xa7b50000a7b6, - 0xa7b70000a7b8, - 0xa7b90000a7ba, - 0xa7bb0000a7bc, - 0xa7bd0000a7be, - 0xa7bf0000a7c0, - 0xa7c30000a7c4, - 0xa7c80000a7c9, - 0xa7ca0000a7cb, - 0xa7f60000a7f8, - 0xa7fa0000a828, - 0xa82c0000a82d, - 0xa8400000a874, - 0xa8800000a8c6, - 0xa8d00000a8da, - 0xa8e00000a8f8, - 0xa8fb0000a8fc, - 0xa8fd0000a92e, - 0xa9300000a954, - 0xa9800000a9c1, - 0xa9cf0000a9da, - 0xa9e00000a9ff, - 0xaa000000aa37, - 0xaa400000aa4e, - 0xaa500000aa5a, - 0xaa600000aa77, - 0xaa7a0000aac3, - 0xaadb0000aade, - 0xaae00000aaf0, - 0xaaf20000aaf7, - 0xab010000ab07, - 0xab090000ab0f, - 0xab110000ab17, - 0xab200000ab27, - 0xab280000ab2f, - 0xab300000ab5b, - 0xab600000ab6a, - 0xabc00000abeb, - 0xabec0000abee, - 0xabf00000abfa, - 0xac000000d7a4, - 0xfa0e0000fa10, - 0xfa110000fa12, - 0xfa130000fa15, - 0xfa1f0000fa20, - 0xfa210000fa22, - 0xfa230000fa25, - 0xfa270000fa2a, - 0xfb1e0000fb1f, - 0xfe200000fe30, - 0xfe730000fe74, - 0x100000001000c, - 0x1000d00010027, - 0x100280001003b, - 0x1003c0001003e, - 0x1003f0001004e, - 0x100500001005e, - 0x10080000100fb, - 0x101fd000101fe, - 0x102800001029d, - 0x102a0000102d1, - 0x102e0000102e1, - 0x1030000010320, - 0x1032d00010341, - 0x103420001034a, - 0x103500001037b, - 0x103800001039e, - 0x103a0000103c4, - 0x103c8000103d0, - 0x104280001049e, - 0x104a0000104aa, - 0x104d8000104fc, - 0x1050000010528, - 0x1053000010564, - 0x1060000010737, - 0x1074000010756, - 0x1076000010768, - 0x1080000010806, - 0x1080800010809, - 0x1080a00010836, - 0x1083700010839, - 0x1083c0001083d, - 0x1083f00010856, - 0x1086000010877, - 0x108800001089f, - 0x108e0000108f3, - 0x108f4000108f6, - 0x1090000010916, - 0x109200001093a, - 0x10980000109b8, - 0x109be000109c0, - 0x10a0000010a04, - 0x10a0500010a07, - 0x10a0c00010a14, - 0x10a1500010a18, - 0x10a1900010a36, - 0x10a3800010a3b, - 0x10a3f00010a40, - 0x10a6000010a7d, - 0x10a8000010a9d, - 0x10ac000010ac8, - 0x10ac900010ae7, - 0x10b0000010b36, - 0x10b4000010b56, - 0x10b6000010b73, - 0x10b8000010b92, - 0x10c0000010c49, - 0x10cc000010cf3, - 0x10d0000010d28, - 0x10d3000010d3a, - 0x10e8000010eaa, - 0x10eab00010ead, - 0x10eb000010eb2, - 0x10f0000010f1d, - 0x10f2700010f28, - 0x10f3000010f51, - 0x10fb000010fc5, - 0x10fe000010ff7, - 0x1100000011047, - 0x1106600011070, - 0x1107f000110bb, - 0x110d0000110e9, - 0x110f0000110fa, - 0x1110000011135, - 0x1113600011140, - 0x1114400011148, - 0x1115000011174, - 0x1117600011177, - 0x11180000111c5, - 0x111c9000111cd, - 0x111ce000111db, - 0x111dc000111dd, - 0x1120000011212, - 0x1121300011238, - 0x1123e0001123f, - 0x1128000011287, - 0x1128800011289, - 0x1128a0001128e, - 0x1128f0001129e, - 0x1129f000112a9, - 0x112b0000112eb, - 0x112f0000112fa, - 0x1130000011304, - 0x113050001130d, - 0x1130f00011311, - 0x1131300011329, - 0x1132a00011331, - 0x1133200011334, - 0x113350001133a, - 0x1133b00011345, - 0x1134700011349, - 0x1134b0001134e, - 0x1135000011351, - 0x1135700011358, - 0x1135d00011364, - 0x113660001136d, - 0x1137000011375, - 0x114000001144b, - 0x114500001145a, - 0x1145e00011462, - 0x11480000114c6, - 0x114c7000114c8, - 0x114d0000114da, - 0x11580000115b6, - 0x115b8000115c1, - 0x115d8000115de, - 0x1160000011641, - 0x1164400011645, - 0x116500001165a, - 0x11680000116b9, - 0x116c0000116ca, - 0x117000001171b, - 0x1171d0001172c, - 0x117300001173a, - 0x118000001183b, - 0x118c0000118ea, - 0x118ff00011907, - 0x119090001190a, - 0x1190c00011914, - 0x1191500011917, - 0x1191800011936, - 0x1193700011939, - 0x1193b00011944, - 0x119500001195a, - 0x119a0000119a8, - 0x119aa000119d8, - 0x119da000119e2, - 0x119e3000119e5, - 0x11a0000011a3f, - 0x11a4700011a48, - 0x11a5000011a9a, - 0x11a9d00011a9e, - 0x11ac000011af9, - 0x11c0000011c09, - 0x11c0a00011c37, - 0x11c3800011c41, - 0x11c5000011c5a, - 0x11c7200011c90, - 0x11c9200011ca8, - 0x11ca900011cb7, - 0x11d0000011d07, - 0x11d0800011d0a, - 0x11d0b00011d37, - 0x11d3a00011d3b, - 0x11d3c00011d3e, - 0x11d3f00011d48, - 0x11d5000011d5a, - 0x11d6000011d66, - 0x11d6700011d69, - 0x11d6a00011d8f, - 0x11d9000011d92, - 0x11d9300011d99, - 0x11da000011daa, - 0x11ee000011ef7, - 0x11fb000011fb1, - 0x120000001239a, - 0x1248000012544, - 0x130000001342f, - 0x1440000014647, - 0x1680000016a39, - 0x16a4000016a5f, - 0x16a6000016a6a, - 0x16ad000016aee, - 0x16af000016af5, - 0x16b0000016b37, - 0x16b4000016b44, - 0x16b5000016b5a, - 0x16b6300016b78, - 0x16b7d00016b90, - 0x16e6000016e80, - 0x16f0000016f4b, - 0x16f4f00016f88, - 0x16f8f00016fa0, - 0x16fe000016fe2, - 0x16fe300016fe5, - 0x16ff000016ff2, - 0x17000000187f8, - 0x1880000018cd6, - 0x18d0000018d09, - 0x1b0000001b11f, - 0x1b1500001b153, - 0x1b1640001b168, - 0x1b1700001b2fc, - 0x1bc000001bc6b, - 0x1bc700001bc7d, - 0x1bc800001bc89, - 0x1bc900001bc9a, - 0x1bc9d0001bc9f, - 0x1da000001da37, - 0x1da3b0001da6d, - 0x1da750001da76, - 0x1da840001da85, - 0x1da9b0001daa0, - 0x1daa10001dab0, - 0x1e0000001e007, - 0x1e0080001e019, - 0x1e01b0001e022, - 0x1e0230001e025, - 0x1e0260001e02b, - 0x1e1000001e12d, - 0x1e1300001e13e, - 0x1e1400001e14a, - 0x1e14e0001e14f, - 0x1e2c00001e2fa, - 0x1e8000001e8c5, - 0x1e8d00001e8d7, - 0x1e9220001e94c, - 0x1e9500001e95a, - 0x1fbf00001fbfa, - 0x200000002a6de, - 0x2a7000002b735, - 0x2b7400002b81e, - 0x2b8200002cea2, - 0x2ceb00002ebe1, - 0x300000003134b, - ), - 'CONTEXTJ': ( - 0x200c0000200e, - ), - 'CONTEXTO': ( - 0xb7000000b8, - 0x37500000376, - 0x5f3000005f5, - 0x6600000066a, - 0x6f0000006fa, - 0x30fb000030fc, - ), -} diff --git a/venv/lib/python3.8/site-packages/idna/intranges.py b/venv/lib/python3.8/site-packages/idna/intranges.py deleted file mode 100644 index ee364a9..0000000 --- a/venv/lib/python3.8/site-packages/idna/intranges.py +++ /dev/null @@ -1,58 +0,0 @@ -""" -Given a list of integers, made up of (hopefully) a small number of long runs -of consecutive integers, compute a representation of the form -((start1, end1), (start2, end2) ...). Then answer the question "was x present -in the original list?" in time O(log(# runs)). -""" - -import bisect -from typing import List, Tuple - -def intranges_from_list(list_): - # type: (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. - - Ranges are encoded as single integers (start << 32 | end), not as tuples. - """ - - sorted_list = sorted(list_) - ranges = [] - last_write = -1 - for i in range(len(sorted_list)): - if i+1 < len(sorted_list): - if sorted_list[i] == sorted_list[i+1]-1: - continue - current_range = sorted_list[last_write+1:i+1] - ranges.append(_encode_range(current_range[0], current_range[-1] + 1)) - last_write = i - - return tuple(ranges) - -def _encode_range(start, end): - # type: (int, int) -> int - return (start << 32) | end - -def _decode_range(r): - # type: (int) -> Tuple[int, int] - return (r >> 32), (r & ((1 << 32) - 1)) - - -def intranges_contain(int_, ranges): - # type: (int, 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_) - # we could be immediately ahead of a tuple (start, end) - # with start < int_ <= end - if pos > 0: - left, right = _decode_range(ranges[pos-1]) - if left <= int_ < right: - return True - # or we could be immediately behind a tuple (int_, end) - if pos < len(ranges): - left, _ = _decode_range(ranges[pos]) - if left == int_: - return True - return False diff --git a/venv/lib/python3.8/site-packages/idna/package_data.py b/venv/lib/python3.8/site-packages/idna/package_data.py deleted file mode 100644 index e096d1d..0000000 --- a/venv/lib/python3.8/site-packages/idna/package_data.py +++ /dev/null @@ -1,2 +0,0 @@ -__version__ = '3.2' - diff --git a/venv/lib/python3.8/site-packages/idna/py.typed b/venv/lib/python3.8/site-packages/idna/py.typed deleted file mode 100644 index e69de29..0000000 diff --git a/venv/lib/python3.8/site-packages/idna/uts46data.py b/venv/lib/python3.8/site-packages/idna/uts46data.py deleted file mode 100644 index f382ce3..0000000 --- a/venv/lib/python3.8/site-packages/idna/uts46data.py +++ /dev/null @@ -1,8438 +0,0 @@ -# This file is automatically generated by tools/idna-data - -from typing import List, Tuple, Union - -"""IDNA Mapping Table from UTS46.""" - - -__version__ = '13.0.0' -def _seg_0(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0x0, '3'), - (0x1, '3'), - (0x2, '3'), - (0x3, '3'), - (0x4, '3'), - (0x5, '3'), - (0x6, '3'), - (0x7, '3'), - (0x8, '3'), - (0x9, '3'), - (0xA, '3'), - (0xB, '3'), - (0xC, '3'), - (0xD, '3'), - (0xE, '3'), - (0xF, '3'), - (0x10, '3'), - (0x11, '3'), - (0x12, '3'), - (0x13, '3'), - (0x14, '3'), - (0x15, '3'), - (0x16, '3'), - (0x17, '3'), - (0x18, '3'), - (0x19, '3'), - (0x1A, '3'), - (0x1B, '3'), - (0x1C, '3'), - (0x1D, '3'), - (0x1E, '3'), - (0x1F, '3'), - (0x20, '3'), - (0x21, '3'), - (0x22, '3'), - (0x23, '3'), - (0x24, '3'), - (0x25, '3'), - (0x26, '3'), - (0x27, '3'), - (0x28, '3'), - (0x29, '3'), - (0x2A, '3'), - (0x2B, '3'), - (0x2C, '3'), - (0x2D, 'V'), - (0x2E, 'V'), - (0x2F, '3'), - (0x30, 'V'), - (0x31, 'V'), - (0x32, 'V'), - (0x33, 'V'), - (0x34, 'V'), - (0x35, 'V'), - (0x36, 'V'), - (0x37, 'V'), - (0x38, 'V'), - (0x39, 'V'), - (0x3A, '3'), - (0x3B, '3'), - (0x3C, '3'), - (0x3D, '3'), - (0x3E, '3'), - (0x3F, '3'), - (0x40, '3'), - (0x41, 'M', 'a'), - (0x42, 'M', 'b'), - (0x43, 'M', 'c'), - (0x44, 'M', 'd'), - (0x45, 'M', 'e'), - (0x46, 'M', 'f'), - (0x47, 'M', 'g'), - (0x48, 'M', 'h'), - (0x49, 'M', 'i'), - (0x4A, 'M', 'j'), - (0x4B, 'M', 'k'), - (0x4C, 'M', 'l'), - (0x4D, 'M', 'm'), - (0x4E, 'M', 'n'), - (0x4F, 'M', 'o'), - (0x50, 'M', 'p'), - (0x51, 'M', 'q'), - (0x52, 'M', 'r'), - (0x53, 'M', 's'), - (0x54, 'M', 't'), - (0x55, 'M', 'u'), - (0x56, 'M', 'v'), - (0x57, 'M', 'w'), - (0x58, 'M', 'x'), - (0x59, 'M', 'y'), - (0x5A, 'M', 'z'), - (0x5B, '3'), - (0x5C, '3'), - (0x5D, '3'), - (0x5E, '3'), - (0x5F, '3'), - (0x60, '3'), - (0x61, 'V'), - (0x62, 'V'), - (0x63, 'V'), - ] - -def _seg_1(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0x64, 'V'), - (0x65, 'V'), - (0x66, 'V'), - (0x67, 'V'), - (0x68, 'V'), - (0x69, 'V'), - (0x6A, 'V'), - (0x6B, 'V'), - (0x6C, 'V'), - (0x6D, 'V'), - (0x6E, 'V'), - (0x6F, 'V'), - (0x70, 'V'), - (0x71, 'V'), - (0x72, 'V'), - (0x73, 'V'), - (0x74, 'V'), - (0x75, 'V'), - (0x76, 'V'), - (0x77, 'V'), - (0x78, 'V'), - (0x79, 'V'), - (0x7A, 'V'), - (0x7B, '3'), - (0x7C, '3'), - (0x7D, '3'), - (0x7E, '3'), - (0x7F, '3'), - (0x80, 'X'), - (0x81, 'X'), - (0x82, 'X'), - (0x83, 'X'), - (0x84, 'X'), - (0x85, 'X'), - (0x86, 'X'), - (0x87, 'X'), - (0x88, 'X'), - (0x89, 'X'), - (0x8A, 'X'), - (0x8B, 'X'), - (0x8C, 'X'), - (0x8D, 'X'), - (0x8E, 'X'), - (0x8F, 'X'), - (0x90, 'X'), - (0x91, 'X'), - (0x92, 'X'), - (0x93, 'X'), - (0x94, 'X'), - (0x95, 'X'), - (0x96, 'X'), - (0x97, 'X'), - (0x98, 'X'), - (0x99, 'X'), - (0x9A, 'X'), - (0x9B, 'X'), - (0x9C, 'X'), - (0x9D, 'X'), - (0x9E, 'X'), - (0x9F, 'X'), - (0xA0, '3', ' '), - (0xA1, 'V'), - (0xA2, 'V'), - (0xA3, 'V'), - (0xA4, 'V'), - (0xA5, 'V'), - (0xA6, 'V'), - (0xA7, 'V'), - (0xA8, '3', ' ̈'), - (0xA9, 'V'), - (0xAA, 'M', 'a'), - (0xAB, 'V'), - (0xAC, 'V'), - (0xAD, 'I'), - (0xAE, 'V'), - (0xAF, '3', ' ̄'), - (0xB0, 'V'), - (0xB1, 'V'), - (0xB2, 'M', '2'), - (0xB3, 'M', '3'), - (0xB4, '3', ' ́'), - (0xB5, 'M', 'μ'), - (0xB6, 'V'), - (0xB7, 'V'), - (0xB8, '3', ' ̧'), - (0xB9, 'M', '1'), - (0xBA, 'M', 'o'), - (0xBB, 'V'), - (0xBC, 'M', '1⁄4'), - (0xBD, 'M', '1⁄2'), - (0xBE, 'M', '3⁄4'), - (0xBF, 'V'), - (0xC0, 'M', 'à'), - (0xC1, 'M', 'á'), - (0xC2, 'M', 'â'), - (0xC3, 'M', 'ã'), - (0xC4, 'M', 'ä'), - (0xC5, 'M', 'å'), - (0xC6, 'M', 'æ'), - (0xC7, 'M', 'ç'), - ] - -def _seg_2(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0xC8, 'M', 'è'), - (0xC9, 'M', 'é'), - (0xCA, 'M', 'ê'), - (0xCB, 'M', 'ë'), - (0xCC, 'M', 'ì'), - (0xCD, 'M', 'í'), - (0xCE, 'M', 'î'), - (0xCF, 'M', 'ï'), - (0xD0, 'M', 'ð'), - (0xD1, 'M', 'ñ'), - (0xD2, 'M', 'ò'), - (0xD3, 'M', 'ó'), - (0xD4, 'M', 'ô'), - (0xD5, 'M', 'õ'), - (0xD6, 'M', 'ö'), - (0xD7, 'V'), - (0xD8, 'M', 'ø'), - (0xD9, 'M', 'ù'), - (0xDA, 'M', 'ú'), - (0xDB, 'M', 'û'), - (0xDC, 'M', 'ü'), - (0xDD, 'M', 'ý'), - (0xDE, 'M', 'þ'), - (0xDF, 'D', 'ss'), - (0xE0, 'V'), - (0xE1, 'V'), - (0xE2, 'V'), - (0xE3, 'V'), - (0xE4, 'V'), - (0xE5, 'V'), - (0xE6, 'V'), - (0xE7, 'V'), - (0xE8, 'V'), - (0xE9, 'V'), - (0xEA, 'V'), - (0xEB, 'V'), - (0xEC, 'V'), - (0xED, 'V'), - (0xEE, 'V'), - (0xEF, 'V'), - (0xF0, 'V'), - (0xF1, 'V'), - (0xF2, 'V'), - (0xF3, 'V'), - (0xF4, 'V'), - (0xF5, 'V'), - (0xF6, 'V'), - (0xF7, 'V'), - (0xF8, 'V'), - (0xF9, 'V'), - (0xFA, 'V'), - (0xFB, 'V'), - (0xFC, 'V'), - (0xFD, 'V'), - (0xFE, 'V'), - (0xFF, 'V'), - (0x100, 'M', 'ā'), - (0x101, 'V'), - (0x102, 'M', 'ă'), - (0x103, 'V'), - (0x104, 'M', 'ą'), - (0x105, 'V'), - (0x106, 'M', 'ć'), - (0x107, 'V'), - (0x108, 'M', 'ĉ'), - (0x109, 'V'), - (0x10A, 'M', 'ċ'), - (0x10B, 'V'), - (0x10C, 'M', 'č'), - (0x10D, 'V'), - (0x10E, 'M', 'ď'), - (0x10F, 'V'), - (0x110, 'M', 'đ'), - (0x111, 'V'), - (0x112, 'M', 'ē'), - (0x113, 'V'), - (0x114, 'M', 'ĕ'), - (0x115, 'V'), - (0x116, 'M', 'ė'), - (0x117, 'V'), - (0x118, 'M', 'ę'), - (0x119, 'V'), - (0x11A, 'M', 'ě'), - (0x11B, 'V'), - (0x11C, 'M', 'ĝ'), - (0x11D, 'V'), - (0x11E, 'M', 'ğ'), - (0x11F, 'V'), - (0x120, 'M', 'ġ'), - (0x121, 'V'), - (0x122, 'M', 'ģ'), - (0x123, 'V'), - (0x124, 'M', 'ĥ'), - (0x125, 'V'), - (0x126, 'M', 'ħ'), - (0x127, 'V'), - (0x128, 'M', 'ĩ'), - (0x129, 'V'), - (0x12A, 'M', 'ī'), - (0x12B, 'V'), - ] - -def _seg_3(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0x12C, 'M', 'ĭ'), - (0x12D, 'V'), - (0x12E, 'M', 'į'), - (0x12F, 'V'), - (0x130, 'M', 'i̇'), - (0x131, 'V'), - (0x132, 'M', 'ij'), - (0x134, 'M', 'ĵ'), - (0x135, 'V'), - (0x136, 'M', 'ķ'), - (0x137, 'V'), - (0x139, 'M', 'ĺ'), - (0x13A, 'V'), - (0x13B, 'M', 'ļ'), - (0x13C, 'V'), - (0x13D, 'M', 'ľ'), - (0x13E, 'V'), - (0x13F, 'M', 'l·'), - (0x141, 'M', 'ł'), - (0x142, 'V'), - (0x143, 'M', 'ń'), - (0x144, 'V'), - (0x145, 'M', 'ņ'), - (0x146, 'V'), - (0x147, 'M', 'ň'), - (0x148, 'V'), - (0x149, 'M', 'ʼn'), - (0x14A, 'M', 'ŋ'), - (0x14B, 'V'), - (0x14C, 'M', 'ō'), - (0x14D, 'V'), - (0x14E, 'M', 'ŏ'), - (0x14F, 'V'), - (0x150, 'M', 'ő'), - (0x151, 'V'), - (0x152, 'M', 'œ'), - (0x153, 'V'), - (0x154, 'M', 'ŕ'), - (0x155, 'V'), - (0x156, 'M', 'ŗ'), - (0x157, 'V'), - (0x158, 'M', 'ř'), - (0x159, 'V'), - (0x15A, 'M', 'ś'), - (0x15B, 'V'), - (0x15C, 'M', 'ŝ'), - (0x15D, 'V'), - (0x15E, 'M', 'ş'), - (0x15F, 'V'), - (0x160, 'M', 'š'), - (0x161, 'V'), - (0x162, 'M', 'ţ'), - (0x163, 'V'), - (0x164, 'M', 'ť'), - (0x165, 'V'), - (0x166, 'M', 'ŧ'), - (0x167, 'V'), - (0x168, 'M', 'ũ'), - (0x169, 'V'), - (0x16A, 'M', 'ū'), - (0x16B, 'V'), - (0x16C, 'M', 'ŭ'), - (0x16D, 'V'), - (0x16E, 'M', 'ů'), - (0x16F, 'V'), - (0x170, 'M', 'ű'), - (0x171, 'V'), - (0x172, 'M', 'ų'), - (0x173, 'V'), - (0x174, 'M', 'ŵ'), - (0x175, 'V'), - (0x176, 'M', 'ŷ'), - (0x177, 'V'), - (0x178, 'M', 'ÿ'), - (0x179, 'M', 'ź'), - (0x17A, 'V'), - (0x17B, 'M', 'ż'), - (0x17C, 'V'), - (0x17D, 'M', 'ž'), - (0x17E, 'V'), - (0x17F, 'M', 's'), - (0x180, 'V'), - (0x181, 'M', 'ɓ'), - (0x182, 'M', 'ƃ'), - (0x183, 'V'), - (0x184, 'M', 'ƅ'), - (0x185, 'V'), - (0x186, 'M', 'ɔ'), - (0x187, 'M', 'ƈ'), - (0x188, 'V'), - (0x189, 'M', 'ɖ'), - (0x18A, 'M', 'ɗ'), - (0x18B, 'M', 'ƌ'), - (0x18C, 'V'), - (0x18E, 'M', 'ǝ'), - (0x18F, 'M', 'ə'), - (0x190, 'M', 'ɛ'), - (0x191, 'M', 'ƒ'), - (0x192, 'V'), - (0x193, 'M', 'ɠ'), - ] - -def _seg_4(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0x194, 'M', 'ɣ'), - (0x195, 'V'), - (0x196, 'M', 'ɩ'), - (0x197, 'M', 'ɨ'), - (0x198, 'M', 'ƙ'), - (0x199, 'V'), - (0x19C, 'M', 'ɯ'), - (0x19D, 'M', 'ɲ'), - (0x19E, 'V'), - (0x19F, 'M', 'ɵ'), - (0x1A0, 'M', 'ơ'), - (0x1A1, 'V'), - (0x1A2, 'M', 'ƣ'), - (0x1A3, 'V'), - (0x1A4, 'M', 'ƥ'), - (0x1A5, 'V'), - (0x1A6, 'M', 'ʀ'), - (0x1A7, 'M', 'ƨ'), - (0x1A8, 'V'), - (0x1A9, 'M', 'ʃ'), - (0x1AA, 'V'), - (0x1AC, 'M', 'ƭ'), - (0x1AD, 'V'), - (0x1AE, 'M', 'ʈ'), - (0x1AF, 'M', 'ư'), - (0x1B0, 'V'), - (0x1B1, 'M', 'ʊ'), - (0x1B2, 'M', 'ʋ'), - (0x1B3, 'M', 'ƴ'), - (0x1B4, 'V'), - (0x1B5, 'M', 'ƶ'), - (0x1B6, 'V'), - (0x1B7, 'M', 'ʒ'), - (0x1B8, 'M', 'ƹ'), - (0x1B9, 'V'), - (0x1BC, 'M', 'ƽ'), - (0x1BD, 'V'), - (0x1C4, 'M', 'dž'), - (0x1C7, 'M', 'lj'), - (0x1CA, 'M', 'nj'), - (0x1CD, 'M', 'ǎ'), - (0x1CE, 'V'), - (0x1CF, 'M', 'ǐ'), - (0x1D0, 'V'), - (0x1D1, 'M', 'ǒ'), - (0x1D2, 'V'), - (0x1D3, 'M', 'ǔ'), - (0x1D4, 'V'), - (0x1D5, 'M', 'ǖ'), - (0x1D6, 'V'), - (0x1D7, 'M', 'ǘ'), - (0x1D8, 'V'), - (0x1D9, 'M', 'ǚ'), - (0x1DA, 'V'), - (0x1DB, 'M', 'ǜ'), - (0x1DC, 'V'), - (0x1DE, 'M', 'ǟ'), - (0x1DF, 'V'), - (0x1E0, 'M', 'ǡ'), - (0x1E1, 'V'), - (0x1E2, 'M', 'ǣ'), - (0x1E3, 'V'), - (0x1E4, 'M', 'ǥ'), - (0x1E5, 'V'), - (0x1E6, 'M', 'ǧ'), - (0x1E7, 'V'), - (0x1E8, 'M', 'ǩ'), - (0x1E9, 'V'), - (0x1EA, 'M', 'ǫ'), - (0x1EB, 'V'), - (0x1EC, 'M', 'ǭ'), - (0x1ED, 'V'), - (0x1EE, 'M', 'ǯ'), - (0x1EF, 'V'), - (0x1F1, 'M', 'dz'), - (0x1F4, 'M', 'ǵ'), - (0x1F5, 'V'), - (0x1F6, 'M', 'ƕ'), - (0x1F7, 'M', 'ƿ'), - (0x1F8, 'M', 'ǹ'), - (0x1F9, 'V'), - (0x1FA, 'M', 'ǻ'), - (0x1FB, 'V'), - (0x1FC, 'M', 'ǽ'), - (0x1FD, 'V'), - (0x1FE, 'M', 'ǿ'), - (0x1FF, 'V'), - (0x200, 'M', 'ȁ'), - (0x201, 'V'), - (0x202, 'M', 'ȃ'), - (0x203, 'V'), - (0x204, 'M', 'ȅ'), - (0x205, 'V'), - (0x206, 'M', 'ȇ'), - (0x207, 'V'), - (0x208, 'M', 'ȉ'), - (0x209, 'V'), - (0x20A, 'M', 'ȋ'), - (0x20B, 'V'), - (0x20C, 'M', 'ȍ'), - ] - -def _seg_5(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0x20D, 'V'), - (0x20E, 'M', 'ȏ'), - (0x20F, 'V'), - (0x210, 'M', 'ȑ'), - (0x211, 'V'), - (0x212, 'M', 'ȓ'), - (0x213, 'V'), - (0x214, 'M', 'ȕ'), - (0x215, 'V'), - (0x216, 'M', 'ȗ'), - (0x217, 'V'), - (0x218, 'M', 'ș'), - (0x219, 'V'), - (0x21A, 'M', 'ț'), - (0x21B, 'V'), - (0x21C, 'M', 'ȝ'), - (0x21D, 'V'), - (0x21E, 'M', 'ȟ'), - (0x21F, 'V'), - (0x220, 'M', 'ƞ'), - (0x221, 'V'), - (0x222, 'M', 'ȣ'), - (0x223, 'V'), - (0x224, 'M', 'ȥ'), - (0x225, 'V'), - (0x226, 'M', 'ȧ'), - (0x227, 'V'), - (0x228, 'M', 'ȩ'), - (0x229, 'V'), - (0x22A, 'M', 'ȫ'), - (0x22B, 'V'), - (0x22C, 'M', 'ȭ'), - (0x22D, 'V'), - (0x22E, 'M', 'ȯ'), - (0x22F, 'V'), - (0x230, 'M', 'ȱ'), - (0x231, 'V'), - (0x232, 'M', 'ȳ'), - (0x233, 'V'), - (0x23A, 'M', 'ⱥ'), - (0x23B, 'M', 'ȼ'), - (0x23C, 'V'), - (0x23D, 'M', 'ƚ'), - (0x23E, 'M', 'ⱦ'), - (0x23F, 'V'), - (0x241, 'M', 'ɂ'), - (0x242, 'V'), - (0x243, 'M', 'ƀ'), - (0x244, 'M', 'ʉ'), - (0x245, 'M', 'ʌ'), - (0x246, 'M', 'ɇ'), - (0x247, 'V'), - (0x248, 'M', 'ɉ'), - (0x249, 'V'), - (0x24A, 'M', 'ɋ'), - (0x24B, 'V'), - (0x24C, 'M', 'ɍ'), - (0x24D, 'V'), - (0x24E, 'M', 'ɏ'), - (0x24F, 'V'), - (0x2B0, 'M', 'h'), - (0x2B1, 'M', 'ɦ'), - (0x2B2, 'M', 'j'), - (0x2B3, 'M', 'r'), - (0x2B4, 'M', 'ɹ'), - (0x2B5, 'M', 'ɻ'), - (0x2B6, 'M', 'ʁ'), - (0x2B7, 'M', 'w'), - (0x2B8, 'M', 'y'), - (0x2B9, 'V'), - (0x2D8, '3', ' ̆'), - (0x2D9, '3', ' ̇'), - (0x2DA, '3', ' ̊'), - (0x2DB, '3', ' ̨'), - (0x2DC, '3', ' ̃'), - (0x2DD, '3', ' ̋'), - (0x2DE, 'V'), - (0x2E0, 'M', 'ɣ'), - (0x2E1, 'M', 'l'), - (0x2E2, 'M', 's'), - (0x2E3, 'M', 'x'), - (0x2E4, 'M', 'ʕ'), - (0x2E5, 'V'), - (0x340, 'M', '̀'), - (0x341, 'M', '́'), - (0x342, 'V'), - (0x343, 'M', '̓'), - (0x344, 'M', '̈́'), - (0x345, 'M', 'ι'), - (0x346, 'V'), - (0x34F, 'I'), - (0x350, 'V'), - (0x370, 'M', 'ͱ'), - (0x371, 'V'), - (0x372, 'M', 'ͳ'), - (0x373, 'V'), - (0x374, 'M', 'ʹ'), - (0x375, 'V'), - (0x376, 'M', 'ͷ'), - (0x377, 'V'), - ] - -def _seg_6(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0x378, 'X'), - (0x37A, '3', ' ι'), - (0x37B, 'V'), - (0x37E, '3', ';'), - (0x37F, 'M', 'ϳ'), - (0x380, 'X'), - (0x384, '3', ' ́'), - (0x385, '3', ' ̈́'), - (0x386, 'M', 'ά'), - (0x387, 'M', '·'), - (0x388, 'M', 'έ'), - (0x389, 'M', 'ή'), - (0x38A, 'M', 'ί'), - (0x38B, 'X'), - (0x38C, 'M', 'ό'), - (0x38D, 'X'), - (0x38E, 'M', 'ύ'), - (0x38F, 'M', 'ώ'), - (0x390, 'V'), - (0x391, 'M', 'α'), - (0x392, 'M', 'β'), - (0x393, 'M', 'γ'), - (0x394, 'M', 'δ'), - (0x395, 'M', 'ε'), - (0x396, 'M', 'ζ'), - (0x397, 'M', 'η'), - (0x398, 'M', 'θ'), - (0x399, 'M', 'ι'), - (0x39A, 'M', 'κ'), - (0x39B, 'M', 'λ'), - (0x39C, 'M', 'μ'), - (0x39D, 'M', 'ν'), - (0x39E, 'M', 'ξ'), - (0x39F, 'M', 'ο'), - (0x3A0, 'M', 'π'), - (0x3A1, 'M', 'ρ'), - (0x3A2, 'X'), - (0x3A3, 'M', 'σ'), - (0x3A4, 'M', 'τ'), - (0x3A5, 'M', 'υ'), - (0x3A6, 'M', 'φ'), - (0x3A7, 'M', 'χ'), - (0x3A8, 'M', 'ψ'), - (0x3A9, 'M', 'ω'), - (0x3AA, 'M', 'ϊ'), - (0x3AB, 'M', 'ϋ'), - (0x3AC, 'V'), - (0x3C2, 'D', 'σ'), - (0x3C3, 'V'), - (0x3CF, 'M', 'ϗ'), - (0x3D0, 'M', 'β'), - (0x3D1, 'M', 'θ'), - (0x3D2, 'M', 'υ'), - (0x3D3, 'M', 'ύ'), - (0x3D4, 'M', 'ϋ'), - (0x3D5, 'M', 'φ'), - (0x3D6, 'M', 'π'), - (0x3D7, 'V'), - (0x3D8, 'M', 'ϙ'), - (0x3D9, 'V'), - (0x3DA, 'M', 'ϛ'), - (0x3DB, 'V'), - (0x3DC, 'M', 'ϝ'), - (0x3DD, 'V'), - (0x3DE, 'M', 'ϟ'), - (0x3DF, 'V'), - (0x3E0, 'M', 'ϡ'), - (0x3E1, 'V'), - (0x3E2, 'M', 'ϣ'), - (0x3E3, 'V'), - (0x3E4, 'M', 'ϥ'), - (0x3E5, 'V'), - (0x3E6, 'M', 'ϧ'), - (0x3E7, 'V'), - (0x3E8, 'M', 'ϩ'), - (0x3E9, 'V'), - (0x3EA, 'M', 'ϫ'), - (0x3EB, 'V'), - (0x3EC, 'M', 'ϭ'), - (0x3ED, 'V'), - (0x3EE, 'M', 'ϯ'), - (0x3EF, 'V'), - (0x3F0, 'M', 'κ'), - (0x3F1, 'M', 'ρ'), - (0x3F2, 'M', 'σ'), - (0x3F3, 'V'), - (0x3F4, 'M', 'θ'), - (0x3F5, 'M', 'ε'), - (0x3F6, 'V'), - (0x3F7, 'M', 'ϸ'), - (0x3F8, 'V'), - (0x3F9, 'M', 'σ'), - (0x3FA, 'M', 'ϻ'), - (0x3FB, 'V'), - (0x3FD, 'M', 'ͻ'), - (0x3FE, 'M', 'ͼ'), - (0x3FF, 'M', 'ͽ'), - (0x400, 'M', 'ѐ'), - (0x401, 'M', 'ё'), - (0x402, 'M', 'ђ'), - ] - -def _seg_7(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0x403, 'M', 'ѓ'), - (0x404, 'M', 'є'), - (0x405, 'M', 'ѕ'), - (0x406, 'M', 'і'), - (0x407, 'M', 'ї'), - (0x408, 'M', 'ј'), - (0x409, 'M', 'љ'), - (0x40A, 'M', 'њ'), - (0x40B, 'M', 'ћ'), - (0x40C, 'M', 'ќ'), - (0x40D, 'M', 'ѝ'), - (0x40E, 'M', 'ў'), - (0x40F, 'M', 'џ'), - (0x410, 'M', 'а'), - (0x411, 'M', 'б'), - (0x412, 'M', 'в'), - (0x413, 'M', 'г'), - (0x414, 'M', 'д'), - (0x415, 'M', 'е'), - (0x416, 'M', 'ж'), - (0x417, 'M', 'з'), - (0x418, 'M', 'и'), - (0x419, 'M', 'й'), - (0x41A, 'M', 'к'), - (0x41B, 'M', 'л'), - (0x41C, 'M', 'м'), - (0x41D, 'M', 'н'), - (0x41E, 'M', 'о'), - (0x41F, 'M', 'п'), - (0x420, 'M', 'р'), - (0x421, 'M', 'с'), - (0x422, 'M', 'т'), - (0x423, 'M', 'у'), - (0x424, 'M', 'ф'), - (0x425, 'M', 'х'), - (0x426, 'M', 'ц'), - (0x427, 'M', 'ч'), - (0x428, 'M', 'ш'), - (0x429, 'M', 'щ'), - (0x42A, 'M', 'ъ'), - (0x42B, 'M', 'ы'), - (0x42C, 'M', 'ь'), - (0x42D, 'M', 'э'), - (0x42E, 'M', 'ю'), - (0x42F, 'M', 'я'), - (0x430, 'V'), - (0x460, 'M', 'ѡ'), - (0x461, 'V'), - (0x462, 'M', 'ѣ'), - (0x463, 'V'), - (0x464, 'M', 'ѥ'), - (0x465, 'V'), - (0x466, 'M', 'ѧ'), - (0x467, 'V'), - (0x468, 'M', 'ѩ'), - (0x469, 'V'), - (0x46A, 'M', 'ѫ'), - (0x46B, 'V'), - (0x46C, 'M', 'ѭ'), - (0x46D, 'V'), - (0x46E, 'M', 'ѯ'), - (0x46F, 'V'), - (0x470, 'M', 'ѱ'), - (0x471, 'V'), - (0x472, 'M', 'ѳ'), - (0x473, 'V'), - (0x474, 'M', 'ѵ'), - (0x475, 'V'), - (0x476, 'M', 'ѷ'), - (0x477, 'V'), - (0x478, 'M', 'ѹ'), - (0x479, 'V'), - (0x47A, 'M', 'ѻ'), - (0x47B, 'V'), - (0x47C, 'M', 'ѽ'), - (0x47D, 'V'), - (0x47E, 'M', 'ѿ'), - (0x47F, 'V'), - (0x480, 'M', 'ҁ'), - (0x481, 'V'), - (0x48A, 'M', 'ҋ'), - (0x48B, 'V'), - (0x48C, 'M', 'ҍ'), - (0x48D, 'V'), - (0x48E, 'M', 'ҏ'), - (0x48F, 'V'), - (0x490, 'M', 'ґ'), - (0x491, 'V'), - (0x492, 'M', 'ғ'), - (0x493, 'V'), - (0x494, 'M', 'ҕ'), - (0x495, 'V'), - (0x496, 'M', 'җ'), - (0x497, 'V'), - (0x498, 'M', 'ҙ'), - (0x499, 'V'), - (0x49A, 'M', 'қ'), - (0x49B, 'V'), - (0x49C, 'M', 'ҝ'), - (0x49D, 'V'), - ] - -def _seg_8(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0x49E, 'M', 'ҟ'), - (0x49F, 'V'), - (0x4A0, 'M', 'ҡ'), - (0x4A1, 'V'), - (0x4A2, 'M', 'ң'), - (0x4A3, 'V'), - (0x4A4, 'M', 'ҥ'), - (0x4A5, 'V'), - (0x4A6, 'M', 'ҧ'), - (0x4A7, 'V'), - (0x4A8, 'M', 'ҩ'), - (0x4A9, 'V'), - (0x4AA, 'M', 'ҫ'), - (0x4AB, 'V'), - (0x4AC, 'M', 'ҭ'), - (0x4AD, 'V'), - (0x4AE, 'M', 'ү'), - (0x4AF, 'V'), - (0x4B0, 'M', 'ұ'), - (0x4B1, 'V'), - (0x4B2, 'M', 'ҳ'), - (0x4B3, 'V'), - (0x4B4, 'M', 'ҵ'), - (0x4B5, 'V'), - (0x4B6, 'M', 'ҷ'), - (0x4B7, 'V'), - (0x4B8, 'M', 'ҹ'), - (0x4B9, 'V'), - (0x4BA, 'M', 'һ'), - (0x4BB, 'V'), - (0x4BC, 'M', 'ҽ'), - (0x4BD, 'V'), - (0x4BE, 'M', 'ҿ'), - (0x4BF, 'V'), - (0x4C0, 'X'), - (0x4C1, 'M', 'ӂ'), - (0x4C2, 'V'), - (0x4C3, 'M', 'ӄ'), - (0x4C4, 'V'), - (0x4C5, 'M', 'ӆ'), - (0x4C6, 'V'), - (0x4C7, 'M', 'ӈ'), - (0x4C8, 'V'), - (0x4C9, 'M', 'ӊ'), - (0x4CA, 'V'), - (0x4CB, 'M', 'ӌ'), - (0x4CC, 'V'), - (0x4CD, 'M', 'ӎ'), - (0x4CE, 'V'), - (0x4D0, 'M', 'ӑ'), - (0x4D1, 'V'), - (0x4D2, 'M', 'ӓ'), - (0x4D3, 'V'), - (0x4D4, 'M', 'ӕ'), - (0x4D5, 'V'), - (0x4D6, 'M', 'ӗ'), - (0x4D7, 'V'), - (0x4D8, 'M', 'ә'), - (0x4D9, 'V'), - (0x4DA, 'M', 'ӛ'), - (0x4DB, 'V'), - (0x4DC, 'M', 'ӝ'), - (0x4DD, 'V'), - (0x4DE, 'M', 'ӟ'), - (0x4DF, 'V'), - (0x4E0, 'M', 'ӡ'), - (0x4E1, 'V'), - (0x4E2, 'M', 'ӣ'), - (0x4E3, 'V'), - (0x4E4, 'M', 'ӥ'), - (0x4E5, 'V'), - (0x4E6, 'M', 'ӧ'), - (0x4E7, 'V'), - (0x4E8, 'M', 'ө'), - (0x4E9, 'V'), - (0x4EA, 'M', 'ӫ'), - (0x4EB, 'V'), - (0x4EC, 'M', 'ӭ'), - (0x4ED, 'V'), - (0x4EE, 'M', 'ӯ'), - (0x4EF, 'V'), - (0x4F0, 'M', 'ӱ'), - (0x4F1, 'V'), - (0x4F2, 'M', 'ӳ'), - (0x4F3, 'V'), - (0x4F4, 'M', 'ӵ'), - (0x4F5, 'V'), - (0x4F6, 'M', 'ӷ'), - (0x4F7, 'V'), - (0x4F8, 'M', 'ӹ'), - (0x4F9, 'V'), - (0x4FA, 'M', 'ӻ'), - (0x4FB, 'V'), - (0x4FC, 'M', 'ӽ'), - (0x4FD, 'V'), - (0x4FE, 'M', 'ӿ'), - (0x4FF, 'V'), - (0x500, 'M', 'ԁ'), - (0x501, 'V'), - (0x502, 'M', 'ԃ'), - ] - -def _seg_9(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0x503, 'V'), - (0x504, 'M', 'ԅ'), - (0x505, 'V'), - (0x506, 'M', 'ԇ'), - (0x507, 'V'), - (0x508, 'M', 'ԉ'), - (0x509, 'V'), - (0x50A, 'M', 'ԋ'), - (0x50B, 'V'), - (0x50C, 'M', 'ԍ'), - (0x50D, 'V'), - (0x50E, 'M', 'ԏ'), - (0x50F, 'V'), - (0x510, 'M', 'ԑ'), - (0x511, 'V'), - (0x512, 'M', 'ԓ'), - (0x513, 'V'), - (0x514, 'M', 'ԕ'), - (0x515, 'V'), - (0x516, 'M', 'ԗ'), - (0x517, 'V'), - (0x518, 'M', 'ԙ'), - (0x519, 'V'), - (0x51A, 'M', 'ԛ'), - (0x51B, 'V'), - (0x51C, 'M', 'ԝ'), - (0x51D, 'V'), - (0x51E, 'M', 'ԟ'), - (0x51F, 'V'), - (0x520, 'M', 'ԡ'), - (0x521, 'V'), - (0x522, 'M', 'ԣ'), - (0x523, 'V'), - (0x524, 'M', 'ԥ'), - (0x525, 'V'), - (0x526, 'M', 'ԧ'), - (0x527, 'V'), - (0x528, 'M', 'ԩ'), - (0x529, 'V'), - (0x52A, 'M', 'ԫ'), - (0x52B, 'V'), - (0x52C, 'M', 'ԭ'), - (0x52D, 'V'), - (0x52E, 'M', 'ԯ'), - (0x52F, 'V'), - (0x530, 'X'), - (0x531, 'M', 'ա'), - (0x532, 'M', 'բ'), - (0x533, 'M', 'գ'), - (0x534, 'M', 'դ'), - (0x535, 'M', 'ե'), - (0x536, 'M', 'զ'), - (0x537, 'M', 'է'), - (0x538, 'M', 'ը'), - (0x539, 'M', 'թ'), - (0x53A, 'M', 'ժ'), - (0x53B, 'M', 'ի'), - (0x53C, 'M', 'լ'), - (0x53D, 'M', 'խ'), - (0x53E, 'M', 'ծ'), - (0x53F, 'M', 'կ'), - (0x540, 'M', 'հ'), - (0x541, 'M', 'ձ'), - (0x542, 'M', 'ղ'), - (0x543, 'M', 'ճ'), - (0x544, 'M', 'մ'), - (0x545, 'M', 'յ'), - (0x546, 'M', 'ն'), - (0x547, 'M', 'շ'), - (0x548, 'M', 'ո'), - (0x549, 'M', 'չ'), - (0x54A, 'M', 'պ'), - (0x54B, 'M', 'ջ'), - (0x54C, 'M', 'ռ'), - (0x54D, 'M', 'ս'), - (0x54E, 'M', 'վ'), - (0x54F, 'M', 'տ'), - (0x550, 'M', 'ր'), - (0x551, 'M', 'ց'), - (0x552, 'M', 'ւ'), - (0x553, 'M', 'փ'), - (0x554, 'M', 'ք'), - (0x555, 'M', 'օ'), - (0x556, 'M', 'ֆ'), - (0x557, 'X'), - (0x559, 'V'), - (0x587, 'M', 'եւ'), - (0x588, 'V'), - (0x58B, 'X'), - (0x58D, 'V'), - (0x590, 'X'), - (0x591, 'V'), - (0x5C8, 'X'), - (0x5D0, 'V'), - (0x5EB, 'X'), - (0x5EF, 'V'), - (0x5F5, 'X'), - (0x606, 'V'), - (0x61C, 'X'), - (0x61E, 'V'), - ] - -def _seg_10(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0x675, 'M', 'اٴ'), - (0x676, 'M', 'وٴ'), - (0x677, 'M', 'ۇٴ'), - (0x678, 'M', 'يٴ'), - (0x679, 'V'), - (0x6DD, 'X'), - (0x6DE, 'V'), - (0x70E, 'X'), - (0x710, 'V'), - (0x74B, 'X'), - (0x74D, 'V'), - (0x7B2, 'X'), - (0x7C0, 'V'), - (0x7FB, 'X'), - (0x7FD, 'V'), - (0x82E, 'X'), - (0x830, 'V'), - (0x83F, 'X'), - (0x840, 'V'), - (0x85C, 'X'), - (0x85E, 'V'), - (0x85F, 'X'), - (0x860, 'V'), - (0x86B, 'X'), - (0x8A0, 'V'), - (0x8B5, 'X'), - (0x8B6, 'V'), - (0x8C8, 'X'), - (0x8D3, 'V'), - (0x8E2, 'X'), - (0x8E3, 'V'), - (0x958, 'M', 'क़'), - (0x959, 'M', 'ख़'), - (0x95A, 'M', 'ग़'), - (0x95B, 'M', 'ज़'), - (0x95C, 'M', 'ड़'), - (0x95D, 'M', 'ढ़'), - (0x95E, 'M', 'फ़'), - (0x95F, 'M', 'य़'), - (0x960, 'V'), - (0x984, 'X'), - (0x985, 'V'), - (0x98D, 'X'), - (0x98F, 'V'), - (0x991, 'X'), - (0x993, 'V'), - (0x9A9, 'X'), - (0x9AA, 'V'), - (0x9B1, 'X'), - (0x9B2, 'V'), - (0x9B3, 'X'), - (0x9B6, 'V'), - (0x9BA, 'X'), - (0x9BC, 'V'), - (0x9C5, 'X'), - (0x9C7, 'V'), - (0x9C9, 'X'), - (0x9CB, 'V'), - (0x9CF, 'X'), - (0x9D7, 'V'), - (0x9D8, 'X'), - (0x9DC, 'M', 'ড়'), - (0x9DD, 'M', 'ঢ়'), - (0x9DE, 'X'), - (0x9DF, 'M', 'য়'), - (0x9E0, 'V'), - (0x9E4, 'X'), - (0x9E6, 'V'), - (0x9FF, 'X'), - (0xA01, 'V'), - (0xA04, 'X'), - (0xA05, 'V'), - (0xA0B, 'X'), - (0xA0F, 'V'), - (0xA11, 'X'), - (0xA13, 'V'), - (0xA29, 'X'), - (0xA2A, 'V'), - (0xA31, 'X'), - (0xA32, 'V'), - (0xA33, 'M', 'ਲ਼'), - (0xA34, 'X'), - (0xA35, 'V'), - (0xA36, 'M', 'ਸ਼'), - (0xA37, 'X'), - (0xA38, 'V'), - (0xA3A, 'X'), - (0xA3C, 'V'), - (0xA3D, 'X'), - (0xA3E, 'V'), - (0xA43, 'X'), - (0xA47, 'V'), - (0xA49, 'X'), - (0xA4B, 'V'), - (0xA4E, 'X'), - (0xA51, 'V'), - (0xA52, 'X'), - (0xA59, 'M', 'ਖ਼'), - (0xA5A, 'M', 'ਗ਼'), - (0xA5B, 'M', 'ਜ਼'), - ] - -def _seg_11(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0xA5C, 'V'), - (0xA5D, 'X'), - (0xA5E, 'M', 'ਫ਼'), - (0xA5F, 'X'), - (0xA66, 'V'), - (0xA77, 'X'), - (0xA81, 'V'), - (0xA84, 'X'), - (0xA85, 'V'), - (0xA8E, 'X'), - (0xA8F, 'V'), - (0xA92, 'X'), - (0xA93, 'V'), - (0xAA9, 'X'), - (0xAAA, 'V'), - (0xAB1, 'X'), - (0xAB2, 'V'), - (0xAB4, 'X'), - (0xAB5, 'V'), - (0xABA, 'X'), - (0xABC, 'V'), - (0xAC6, 'X'), - (0xAC7, 'V'), - (0xACA, 'X'), - (0xACB, 'V'), - (0xACE, 'X'), - (0xAD0, 'V'), - (0xAD1, 'X'), - (0xAE0, 'V'), - (0xAE4, 'X'), - (0xAE6, 'V'), - (0xAF2, 'X'), - (0xAF9, 'V'), - (0xB00, 'X'), - (0xB01, 'V'), - (0xB04, 'X'), - (0xB05, 'V'), - (0xB0D, 'X'), - (0xB0F, 'V'), - (0xB11, 'X'), - (0xB13, 'V'), - (0xB29, 'X'), - (0xB2A, 'V'), - (0xB31, 'X'), - (0xB32, 'V'), - (0xB34, 'X'), - (0xB35, 'V'), - (0xB3A, 'X'), - (0xB3C, 'V'), - (0xB45, 'X'), - (0xB47, 'V'), - (0xB49, 'X'), - (0xB4B, 'V'), - (0xB4E, 'X'), - (0xB55, 'V'), - (0xB58, 'X'), - (0xB5C, 'M', 'ଡ଼'), - (0xB5D, 'M', 'ଢ଼'), - (0xB5E, 'X'), - (0xB5F, 'V'), - (0xB64, 'X'), - (0xB66, 'V'), - (0xB78, 'X'), - (0xB82, 'V'), - (0xB84, 'X'), - (0xB85, 'V'), - (0xB8B, 'X'), - (0xB8E, 'V'), - (0xB91, 'X'), - (0xB92, 'V'), - (0xB96, 'X'), - (0xB99, 'V'), - (0xB9B, 'X'), - (0xB9C, 'V'), - (0xB9D, 'X'), - (0xB9E, 'V'), - (0xBA0, 'X'), - (0xBA3, 'V'), - (0xBA5, 'X'), - (0xBA8, 'V'), - (0xBAB, 'X'), - (0xBAE, 'V'), - (0xBBA, 'X'), - (0xBBE, 'V'), - (0xBC3, 'X'), - (0xBC6, 'V'), - (0xBC9, 'X'), - (0xBCA, 'V'), - (0xBCE, 'X'), - (0xBD0, 'V'), - (0xBD1, 'X'), - (0xBD7, 'V'), - (0xBD8, 'X'), - (0xBE6, 'V'), - (0xBFB, 'X'), - (0xC00, 'V'), - (0xC0D, 'X'), - (0xC0E, 'V'), - (0xC11, 'X'), - (0xC12, 'V'), - ] - -def _seg_12(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0xC29, 'X'), - (0xC2A, 'V'), - (0xC3A, 'X'), - (0xC3D, 'V'), - (0xC45, 'X'), - (0xC46, 'V'), - (0xC49, 'X'), - (0xC4A, 'V'), - (0xC4E, 'X'), - (0xC55, 'V'), - (0xC57, 'X'), - (0xC58, 'V'), - (0xC5B, 'X'), - (0xC60, 'V'), - (0xC64, 'X'), - (0xC66, 'V'), - (0xC70, 'X'), - (0xC77, 'V'), - (0xC8D, 'X'), - (0xC8E, 'V'), - (0xC91, 'X'), - (0xC92, 'V'), - (0xCA9, 'X'), - (0xCAA, 'V'), - (0xCB4, 'X'), - (0xCB5, 'V'), - (0xCBA, 'X'), - (0xCBC, 'V'), - (0xCC5, 'X'), - (0xCC6, 'V'), - (0xCC9, 'X'), - (0xCCA, 'V'), - (0xCCE, 'X'), - (0xCD5, 'V'), - (0xCD7, 'X'), - (0xCDE, 'V'), - (0xCDF, 'X'), - (0xCE0, 'V'), - (0xCE4, 'X'), - (0xCE6, 'V'), - (0xCF0, 'X'), - (0xCF1, 'V'), - (0xCF3, 'X'), - (0xD00, 'V'), - (0xD0D, 'X'), - (0xD0E, 'V'), - (0xD11, 'X'), - (0xD12, 'V'), - (0xD45, 'X'), - (0xD46, 'V'), - (0xD49, 'X'), - (0xD4A, 'V'), - (0xD50, 'X'), - (0xD54, 'V'), - (0xD64, 'X'), - (0xD66, 'V'), - (0xD80, 'X'), - (0xD81, 'V'), - (0xD84, 'X'), - (0xD85, 'V'), - (0xD97, 'X'), - (0xD9A, 'V'), - (0xDB2, 'X'), - (0xDB3, 'V'), - (0xDBC, 'X'), - (0xDBD, 'V'), - (0xDBE, 'X'), - (0xDC0, 'V'), - (0xDC7, 'X'), - (0xDCA, 'V'), - (0xDCB, 'X'), - (0xDCF, 'V'), - (0xDD5, 'X'), - (0xDD6, 'V'), - (0xDD7, 'X'), - (0xDD8, 'V'), - (0xDE0, 'X'), - (0xDE6, 'V'), - (0xDF0, 'X'), - (0xDF2, 'V'), - (0xDF5, 'X'), - (0xE01, 'V'), - (0xE33, 'M', 'ํา'), - (0xE34, 'V'), - (0xE3B, 'X'), - (0xE3F, 'V'), - (0xE5C, 'X'), - (0xE81, 'V'), - (0xE83, 'X'), - (0xE84, 'V'), - (0xE85, 'X'), - (0xE86, 'V'), - (0xE8B, 'X'), - (0xE8C, 'V'), - (0xEA4, 'X'), - (0xEA5, 'V'), - (0xEA6, 'X'), - (0xEA7, 'V'), - (0xEB3, 'M', 'ໍາ'), - (0xEB4, 'V'), - ] - -def _seg_13(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0xEBE, 'X'), - (0xEC0, 'V'), - (0xEC5, 'X'), - (0xEC6, 'V'), - (0xEC7, 'X'), - (0xEC8, 'V'), - (0xECE, 'X'), - (0xED0, 'V'), - (0xEDA, 'X'), - (0xEDC, 'M', 'ຫນ'), - (0xEDD, 'M', 'ຫມ'), - (0xEDE, 'V'), - (0xEE0, 'X'), - (0xF00, 'V'), - (0xF0C, 'M', '་'), - (0xF0D, 'V'), - (0xF43, 'M', 'གྷ'), - (0xF44, 'V'), - (0xF48, 'X'), - (0xF49, 'V'), - (0xF4D, 'M', 'ཌྷ'), - (0xF4E, 'V'), - (0xF52, 'M', 'དྷ'), - (0xF53, 'V'), - (0xF57, 'M', 'བྷ'), - (0xF58, 'V'), - (0xF5C, 'M', 'ཛྷ'), - (0xF5D, 'V'), - (0xF69, 'M', 'ཀྵ'), - (0xF6A, 'V'), - (0xF6D, 'X'), - (0xF71, 'V'), - (0xF73, 'M', 'ཱི'), - (0xF74, 'V'), - (0xF75, 'M', 'ཱུ'), - (0xF76, 'M', 'ྲྀ'), - (0xF77, 'M', 'ྲཱྀ'), - (0xF78, 'M', 'ླྀ'), - (0xF79, 'M', 'ླཱྀ'), - (0xF7A, 'V'), - (0xF81, 'M', 'ཱྀ'), - (0xF82, 'V'), - (0xF93, 'M', 'ྒྷ'), - (0xF94, 'V'), - (0xF98, 'X'), - (0xF99, 'V'), - (0xF9D, 'M', 'ྜྷ'), - (0xF9E, 'V'), - (0xFA2, 'M', 'ྡྷ'), - (0xFA3, 'V'), - (0xFA7, 'M', 'ྦྷ'), - (0xFA8, 'V'), - (0xFAC, 'M', 'ྫྷ'), - (0xFAD, 'V'), - (0xFB9, 'M', 'ྐྵ'), - (0xFBA, 'V'), - (0xFBD, 'X'), - (0xFBE, 'V'), - (0xFCD, 'X'), - (0xFCE, 'V'), - (0xFDB, 'X'), - (0x1000, 'V'), - (0x10A0, 'X'), - (0x10C7, 'M', 'ⴧ'), - (0x10C8, 'X'), - (0x10CD, 'M', 'ⴭ'), - (0x10CE, 'X'), - (0x10D0, 'V'), - (0x10FC, 'M', 'ნ'), - (0x10FD, 'V'), - (0x115F, 'X'), - (0x1161, 'V'), - (0x1249, 'X'), - (0x124A, 'V'), - (0x124E, 'X'), - (0x1250, 'V'), - (0x1257, 'X'), - (0x1258, 'V'), - (0x1259, 'X'), - (0x125A, 'V'), - (0x125E, 'X'), - (0x1260, 'V'), - (0x1289, 'X'), - (0x128A, 'V'), - (0x128E, 'X'), - (0x1290, 'V'), - (0x12B1, 'X'), - (0x12B2, 'V'), - (0x12B6, 'X'), - (0x12B8, 'V'), - (0x12BF, 'X'), - (0x12C0, 'V'), - (0x12C1, 'X'), - (0x12C2, 'V'), - (0x12C6, 'X'), - (0x12C8, 'V'), - (0x12D7, 'X'), - (0x12D8, 'V'), - (0x1311, 'X'), - (0x1312, 'V'), - ] - -def _seg_14(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0x1316, 'X'), - (0x1318, 'V'), - (0x135B, 'X'), - (0x135D, 'V'), - (0x137D, 'X'), - (0x1380, 'V'), - (0x139A, 'X'), - (0x13A0, 'V'), - (0x13F6, 'X'), - (0x13F8, 'M', 'Ᏸ'), - (0x13F9, 'M', 'Ᏹ'), - (0x13FA, 'M', 'Ᏺ'), - (0x13FB, 'M', 'Ᏻ'), - (0x13FC, 'M', 'Ᏼ'), - (0x13FD, 'M', 'Ᏽ'), - (0x13FE, 'X'), - (0x1400, 'V'), - (0x1680, 'X'), - (0x1681, 'V'), - (0x169D, 'X'), - (0x16A0, 'V'), - (0x16F9, 'X'), - (0x1700, 'V'), - (0x170D, 'X'), - (0x170E, 'V'), - (0x1715, 'X'), - (0x1720, 'V'), - (0x1737, 'X'), - (0x1740, 'V'), - (0x1754, 'X'), - (0x1760, 'V'), - (0x176D, 'X'), - (0x176E, 'V'), - (0x1771, 'X'), - (0x1772, 'V'), - (0x1774, 'X'), - (0x1780, 'V'), - (0x17B4, 'X'), - (0x17B6, 'V'), - (0x17DE, 'X'), - (0x17E0, 'V'), - (0x17EA, 'X'), - (0x17F0, 'V'), - (0x17FA, 'X'), - (0x1800, 'V'), - (0x1806, 'X'), - (0x1807, 'V'), - (0x180B, 'I'), - (0x180E, 'X'), - (0x1810, 'V'), - (0x181A, 'X'), - (0x1820, 'V'), - (0x1879, 'X'), - (0x1880, 'V'), - (0x18AB, 'X'), - (0x18B0, 'V'), - (0x18F6, 'X'), - (0x1900, 'V'), - (0x191F, 'X'), - (0x1920, 'V'), - (0x192C, 'X'), - (0x1930, 'V'), - (0x193C, 'X'), - (0x1940, 'V'), - (0x1941, 'X'), - (0x1944, 'V'), - (0x196E, 'X'), - (0x1970, 'V'), - (0x1975, 'X'), - (0x1980, 'V'), - (0x19AC, 'X'), - (0x19B0, 'V'), - (0x19CA, 'X'), - (0x19D0, 'V'), - (0x19DB, 'X'), - (0x19DE, 'V'), - (0x1A1C, 'X'), - (0x1A1E, 'V'), - (0x1A5F, 'X'), - (0x1A60, 'V'), - (0x1A7D, 'X'), - (0x1A7F, 'V'), - (0x1A8A, 'X'), - (0x1A90, 'V'), - (0x1A9A, 'X'), - (0x1AA0, 'V'), - (0x1AAE, 'X'), - (0x1AB0, 'V'), - (0x1AC1, 'X'), - (0x1B00, 'V'), - (0x1B4C, 'X'), - (0x1B50, 'V'), - (0x1B7D, 'X'), - (0x1B80, 'V'), - (0x1BF4, 'X'), - (0x1BFC, 'V'), - (0x1C38, 'X'), - (0x1C3B, 'V'), - (0x1C4A, 'X'), - (0x1C4D, 'V'), - ] - -def _seg_15(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0x1C80, 'M', 'в'), - (0x1C81, 'M', 'д'), - (0x1C82, 'M', 'о'), - (0x1C83, 'M', 'с'), - (0x1C84, 'M', 'т'), - (0x1C86, 'M', 'ъ'), - (0x1C87, 'M', 'ѣ'), - (0x1C88, 'M', 'ꙋ'), - (0x1C89, 'X'), - (0x1C90, 'M', 'ა'), - (0x1C91, 'M', 'ბ'), - (0x1C92, 'M', 'გ'), - (0x1C93, 'M', 'დ'), - (0x1C94, 'M', 'ე'), - (0x1C95, 'M', 'ვ'), - (0x1C96, 'M', 'ზ'), - (0x1C97, 'M', 'თ'), - (0x1C98, 'M', 'ი'), - (0x1C99, 'M', 'კ'), - (0x1C9A, 'M', 'ლ'), - (0x1C9B, 'M', 'მ'), - (0x1C9C, 'M', 'ნ'), - (0x1C9D, 'M', 'ო'), - (0x1C9E, 'M', 'პ'), - (0x1C9F, 'M', 'ჟ'), - (0x1CA0, 'M', 'რ'), - (0x1CA1, 'M', 'ს'), - (0x1CA2, 'M', 'ტ'), - (0x1CA3, 'M', 'უ'), - (0x1CA4, 'M', 'ფ'), - (0x1CA5, 'M', 'ქ'), - (0x1CA6, 'M', 'ღ'), - (0x1CA7, 'M', 'ყ'), - (0x1CA8, 'M', 'შ'), - (0x1CA9, 'M', 'ჩ'), - (0x1CAA, 'M', 'ც'), - (0x1CAB, 'M', 'ძ'), - (0x1CAC, 'M', 'წ'), - (0x1CAD, 'M', 'ჭ'), - (0x1CAE, 'M', 'ხ'), - (0x1CAF, 'M', 'ჯ'), - (0x1CB0, 'M', 'ჰ'), - (0x1CB1, 'M', 'ჱ'), - (0x1CB2, 'M', 'ჲ'), - (0x1CB3, 'M', 'ჳ'), - (0x1CB4, 'M', 'ჴ'), - (0x1CB5, 'M', 'ჵ'), - (0x1CB6, 'M', 'ჶ'), - (0x1CB7, 'M', 'ჷ'), - (0x1CB8, 'M', 'ჸ'), - (0x1CB9, 'M', 'ჹ'), - (0x1CBA, 'M', 'ჺ'), - (0x1CBB, 'X'), - (0x1CBD, 'M', 'ჽ'), - (0x1CBE, 'M', 'ჾ'), - (0x1CBF, 'M', 'ჿ'), - (0x1CC0, 'V'), - (0x1CC8, 'X'), - (0x1CD0, 'V'), - (0x1CFB, 'X'), - (0x1D00, 'V'), - (0x1D2C, 'M', 'a'), - (0x1D2D, 'M', 'æ'), - (0x1D2E, 'M', 'b'), - (0x1D2F, 'V'), - (0x1D30, 'M', 'd'), - (0x1D31, 'M', 'e'), - (0x1D32, 'M', 'ǝ'), - (0x1D33, 'M', 'g'), - (0x1D34, 'M', 'h'), - (0x1D35, 'M', 'i'), - (0x1D36, 'M', 'j'), - (0x1D37, 'M', 'k'), - (0x1D38, 'M', 'l'), - (0x1D39, 'M', 'm'), - (0x1D3A, 'M', 'n'), - (0x1D3B, 'V'), - (0x1D3C, 'M', 'o'), - (0x1D3D, 'M', 'ȣ'), - (0x1D3E, 'M', 'p'), - (0x1D3F, 'M', 'r'), - (0x1D40, 'M', 't'), - (0x1D41, 'M', 'u'), - (0x1D42, 'M', 'w'), - (0x1D43, 'M', 'a'), - (0x1D44, 'M', 'ɐ'), - (0x1D45, 'M', 'ɑ'), - (0x1D46, 'M', 'ᴂ'), - (0x1D47, 'M', 'b'), - (0x1D48, 'M', 'd'), - (0x1D49, 'M', 'e'), - (0x1D4A, 'M', 'ə'), - (0x1D4B, 'M', 'ɛ'), - (0x1D4C, 'M', 'ɜ'), - (0x1D4D, 'M', 'g'), - (0x1D4E, 'V'), - (0x1D4F, 'M', 'k'), - (0x1D50, 'M', 'm'), - (0x1D51, 'M', 'ŋ'), - (0x1D52, 'M', 'o'), - ] - -def _seg_16(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0x1D53, 'M', 'ɔ'), - (0x1D54, 'M', 'ᴖ'), - (0x1D55, 'M', 'ᴗ'), - (0x1D56, 'M', 'p'), - (0x1D57, 'M', 't'), - (0x1D58, 'M', 'u'), - (0x1D59, 'M', 'ᴝ'), - (0x1D5A, 'M', 'ɯ'), - (0x1D5B, 'M', 'v'), - (0x1D5C, 'M', 'ᴥ'), - (0x1D5D, 'M', 'β'), - (0x1D5E, 'M', 'γ'), - (0x1D5F, 'M', 'δ'), - (0x1D60, 'M', 'φ'), - (0x1D61, 'M', 'χ'), - (0x1D62, 'M', 'i'), - (0x1D63, 'M', 'r'), - (0x1D64, 'M', 'u'), - (0x1D65, 'M', 'v'), - (0x1D66, 'M', 'β'), - (0x1D67, 'M', 'γ'), - (0x1D68, 'M', 'ρ'), - (0x1D69, 'M', 'φ'), - (0x1D6A, 'M', 'χ'), - (0x1D6B, 'V'), - (0x1D78, 'M', 'н'), - (0x1D79, 'V'), - (0x1D9B, 'M', 'ɒ'), - (0x1D9C, 'M', 'c'), - (0x1D9D, 'M', 'ɕ'), - (0x1D9E, 'M', 'ð'), - (0x1D9F, 'M', 'ɜ'), - (0x1DA0, 'M', 'f'), - (0x1DA1, 'M', 'ɟ'), - (0x1DA2, 'M', 'ɡ'), - (0x1DA3, 'M', 'ɥ'), - (0x1DA4, 'M', 'ɨ'), - (0x1DA5, 'M', 'ɩ'), - (0x1DA6, 'M', 'ɪ'), - (0x1DA7, 'M', 'ᵻ'), - (0x1DA8, 'M', 'ʝ'), - (0x1DA9, 'M', 'ɭ'), - (0x1DAA, 'M', 'ᶅ'), - (0x1DAB, 'M', 'ʟ'), - (0x1DAC, 'M', 'ɱ'), - (0x1DAD, 'M', 'ɰ'), - (0x1DAE, 'M', 'ɲ'), - (0x1DAF, 'M', 'ɳ'), - (0x1DB0, 'M', 'ɴ'), - (0x1DB1, 'M', 'ɵ'), - (0x1DB2, 'M', 'ɸ'), - (0x1DB3, 'M', 'ʂ'), - (0x1DB4, 'M', 'ʃ'), - (0x1DB5, 'M', 'ƫ'), - (0x1DB6, 'M', 'ʉ'), - (0x1DB7, 'M', 'ʊ'), - (0x1DB8, 'M', 'ᴜ'), - (0x1DB9, 'M', 'ʋ'), - (0x1DBA, 'M', 'ʌ'), - (0x1DBB, 'M', 'z'), - (0x1DBC, 'M', 'ʐ'), - (0x1DBD, 'M', 'ʑ'), - (0x1DBE, 'M', 'ʒ'), - (0x1DBF, 'M', 'θ'), - (0x1DC0, 'V'), - (0x1DFA, 'X'), - (0x1DFB, 'V'), - (0x1E00, 'M', 'ḁ'), - (0x1E01, 'V'), - (0x1E02, 'M', 'ḃ'), - (0x1E03, 'V'), - (0x1E04, 'M', 'ḅ'), - (0x1E05, 'V'), - (0x1E06, 'M', 'ḇ'), - (0x1E07, 'V'), - (0x1E08, 'M', 'ḉ'), - (0x1E09, 'V'), - (0x1E0A, 'M', 'ḋ'), - (0x1E0B, 'V'), - (0x1E0C, 'M', 'ḍ'), - (0x1E0D, 'V'), - (0x1E0E, 'M', 'ḏ'), - (0x1E0F, 'V'), - (0x1E10, 'M', 'ḑ'), - (0x1E11, 'V'), - (0x1E12, 'M', 'ḓ'), - (0x1E13, 'V'), - (0x1E14, 'M', 'ḕ'), - (0x1E15, 'V'), - (0x1E16, 'M', 'ḗ'), - (0x1E17, 'V'), - (0x1E18, 'M', 'ḙ'), - (0x1E19, 'V'), - (0x1E1A, 'M', 'ḛ'), - (0x1E1B, 'V'), - (0x1E1C, 'M', 'ḝ'), - (0x1E1D, 'V'), - (0x1E1E, 'M', 'ḟ'), - (0x1E1F, 'V'), - (0x1E20, 'M', 'ḡ'), - ] - -def _seg_17(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0x1E21, 'V'), - (0x1E22, 'M', 'ḣ'), - (0x1E23, 'V'), - (0x1E24, 'M', 'ḥ'), - (0x1E25, 'V'), - (0x1E26, 'M', 'ḧ'), - (0x1E27, 'V'), - (0x1E28, 'M', 'ḩ'), - (0x1E29, 'V'), - (0x1E2A, 'M', 'ḫ'), - (0x1E2B, 'V'), - (0x1E2C, 'M', 'ḭ'), - (0x1E2D, 'V'), - (0x1E2E, 'M', 'ḯ'), - (0x1E2F, 'V'), - (0x1E30, 'M', 'ḱ'), - (0x1E31, 'V'), - (0x1E32, 'M', 'ḳ'), - (0x1E33, 'V'), - (0x1E34, 'M', 'ḵ'), - (0x1E35, 'V'), - (0x1E36, 'M', 'ḷ'), - (0x1E37, 'V'), - (0x1E38, 'M', 'ḹ'), - (0x1E39, 'V'), - (0x1E3A, 'M', 'ḻ'), - (0x1E3B, 'V'), - (0x1E3C, 'M', 'ḽ'), - (0x1E3D, 'V'), - (0x1E3E, 'M', 'ḿ'), - (0x1E3F, 'V'), - (0x1E40, 'M', 'ṁ'), - (0x1E41, 'V'), - (0x1E42, 'M', 'ṃ'), - (0x1E43, 'V'), - (0x1E44, 'M', 'ṅ'), - (0x1E45, 'V'), - (0x1E46, 'M', 'ṇ'), - (0x1E47, 'V'), - (0x1E48, 'M', 'ṉ'), - (0x1E49, 'V'), - (0x1E4A, 'M', 'ṋ'), - (0x1E4B, 'V'), - (0x1E4C, 'M', 'ṍ'), - (0x1E4D, 'V'), - (0x1E4E, 'M', 'ṏ'), - (0x1E4F, 'V'), - (0x1E50, 'M', 'ṑ'), - (0x1E51, 'V'), - (0x1E52, 'M', 'ṓ'), - (0x1E53, 'V'), - (0x1E54, 'M', 'ṕ'), - (0x1E55, 'V'), - (0x1E56, 'M', 'ṗ'), - (0x1E57, 'V'), - (0x1E58, 'M', 'ṙ'), - (0x1E59, 'V'), - (0x1E5A, 'M', 'ṛ'), - (0x1E5B, 'V'), - (0x1E5C, 'M', 'ṝ'), - (0x1E5D, 'V'), - (0x1E5E, 'M', 'ṟ'), - (0x1E5F, 'V'), - (0x1E60, 'M', 'ṡ'), - (0x1E61, 'V'), - (0x1E62, 'M', 'ṣ'), - (0x1E63, 'V'), - (0x1E64, 'M', 'ṥ'), - (0x1E65, 'V'), - (0x1E66, 'M', 'ṧ'), - (0x1E67, 'V'), - (0x1E68, 'M', 'ṩ'), - (0x1E69, 'V'), - (0x1E6A, 'M', 'ṫ'), - (0x1E6B, 'V'), - (0x1E6C, 'M', 'ṭ'), - (0x1E6D, 'V'), - (0x1E6E, 'M', 'ṯ'), - (0x1E6F, 'V'), - (0x1E70, 'M', 'ṱ'), - (0x1E71, 'V'), - (0x1E72, 'M', 'ṳ'), - (0x1E73, 'V'), - (0x1E74, 'M', 'ṵ'), - (0x1E75, 'V'), - (0x1E76, 'M', 'ṷ'), - (0x1E77, 'V'), - (0x1E78, 'M', 'ṹ'), - (0x1E79, 'V'), - (0x1E7A, 'M', 'ṻ'), - (0x1E7B, 'V'), - (0x1E7C, 'M', 'ṽ'), - (0x1E7D, 'V'), - (0x1E7E, 'M', 'ṿ'), - (0x1E7F, 'V'), - (0x1E80, 'M', 'ẁ'), - (0x1E81, 'V'), - (0x1E82, 'M', 'ẃ'), - (0x1E83, 'V'), - (0x1E84, 'M', 'ẅ'), - ] - -def _seg_18(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0x1E85, 'V'), - (0x1E86, 'M', 'ẇ'), - (0x1E87, 'V'), - (0x1E88, 'M', 'ẉ'), - (0x1E89, 'V'), - (0x1E8A, 'M', 'ẋ'), - (0x1E8B, 'V'), - (0x1E8C, 'M', 'ẍ'), - (0x1E8D, 'V'), - (0x1E8E, 'M', 'ẏ'), - (0x1E8F, 'V'), - (0x1E90, 'M', 'ẑ'), - (0x1E91, 'V'), - (0x1E92, 'M', 'ẓ'), - (0x1E93, 'V'), - (0x1E94, 'M', 'ẕ'), - (0x1E95, 'V'), - (0x1E9A, 'M', 'aʾ'), - (0x1E9B, 'M', 'ṡ'), - (0x1E9C, 'V'), - (0x1E9E, 'M', 'ss'), - (0x1E9F, 'V'), - (0x1EA0, 'M', 'ạ'), - (0x1EA1, 'V'), - (0x1EA2, 'M', 'ả'), - (0x1EA3, 'V'), - (0x1EA4, 'M', 'ấ'), - (0x1EA5, 'V'), - (0x1EA6, 'M', 'ầ'), - (0x1EA7, 'V'), - (0x1EA8, 'M', 'ẩ'), - (0x1EA9, 'V'), - (0x1EAA, 'M', 'ẫ'), - (0x1EAB, 'V'), - (0x1EAC, 'M', 'ậ'), - (0x1EAD, 'V'), - (0x1EAE, 'M', 'ắ'), - (0x1EAF, 'V'), - (0x1EB0, 'M', 'ằ'), - (0x1EB1, 'V'), - (0x1EB2, 'M', 'ẳ'), - (0x1EB3, 'V'), - (0x1EB4, 'M', 'ẵ'), - (0x1EB5, 'V'), - (0x1EB6, 'M', 'ặ'), - (0x1EB7, 'V'), - (0x1EB8, 'M', 'ẹ'), - (0x1EB9, 'V'), - (0x1EBA, 'M', 'ẻ'), - (0x1EBB, 'V'), - (0x1EBC, 'M', 'ẽ'), - (0x1EBD, 'V'), - (0x1EBE, 'M', 'ế'), - (0x1EBF, 'V'), - (0x1EC0, 'M', 'ề'), - (0x1EC1, 'V'), - (0x1EC2, 'M', 'ể'), - (0x1EC3, 'V'), - (0x1EC4, 'M', 'ễ'), - (0x1EC5, 'V'), - (0x1EC6, 'M', 'ệ'), - (0x1EC7, 'V'), - (0x1EC8, 'M', 'ỉ'), - (0x1EC9, 'V'), - (0x1ECA, 'M', 'ị'), - (0x1ECB, 'V'), - (0x1ECC, 'M', 'ọ'), - (0x1ECD, 'V'), - (0x1ECE, 'M', 'ỏ'), - (0x1ECF, 'V'), - (0x1ED0, 'M', 'ố'), - (0x1ED1, 'V'), - (0x1ED2, 'M', 'ồ'), - (0x1ED3, 'V'), - (0x1ED4, 'M', 'ổ'), - (0x1ED5, 'V'), - (0x1ED6, 'M', 'ỗ'), - (0x1ED7, 'V'), - (0x1ED8, 'M', 'ộ'), - (0x1ED9, 'V'), - (0x1EDA, 'M', 'ớ'), - (0x1EDB, 'V'), - (0x1EDC, 'M', 'ờ'), - (0x1EDD, 'V'), - (0x1EDE, 'M', 'ở'), - (0x1EDF, 'V'), - (0x1EE0, 'M', 'ỡ'), - (0x1EE1, 'V'), - (0x1EE2, 'M', 'ợ'), - (0x1EE3, 'V'), - (0x1EE4, 'M', 'ụ'), - (0x1EE5, 'V'), - (0x1EE6, 'M', 'ủ'), - (0x1EE7, 'V'), - (0x1EE8, 'M', 'ứ'), - (0x1EE9, 'V'), - (0x1EEA, 'M', 'ừ'), - (0x1EEB, 'V'), - (0x1EEC, 'M', 'ử'), - (0x1EED, 'V'), - ] - -def _seg_19(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0x1EEE, 'M', 'ữ'), - (0x1EEF, 'V'), - (0x1EF0, 'M', 'ự'), - (0x1EF1, 'V'), - (0x1EF2, 'M', 'ỳ'), - (0x1EF3, 'V'), - (0x1EF4, 'M', 'ỵ'), - (0x1EF5, 'V'), - (0x1EF6, 'M', 'ỷ'), - (0x1EF7, 'V'), - (0x1EF8, 'M', 'ỹ'), - (0x1EF9, 'V'), - (0x1EFA, 'M', 'ỻ'), - (0x1EFB, 'V'), - (0x1EFC, 'M', 'ỽ'), - (0x1EFD, 'V'), - (0x1EFE, 'M', 'ỿ'), - (0x1EFF, 'V'), - (0x1F08, 'M', 'ἀ'), - (0x1F09, 'M', 'ἁ'), - (0x1F0A, 'M', 'ἂ'), - (0x1F0B, 'M', 'ἃ'), - (0x1F0C, 'M', 'ἄ'), - (0x1F0D, 'M', 'ἅ'), - (0x1F0E, 'M', 'ἆ'), - (0x1F0F, 'M', 'ἇ'), - (0x1F10, 'V'), - (0x1F16, 'X'), - (0x1F18, 'M', 'ἐ'), - (0x1F19, 'M', 'ἑ'), - (0x1F1A, 'M', 'ἒ'), - (0x1F1B, 'M', 'ἓ'), - (0x1F1C, 'M', 'ἔ'), - (0x1F1D, 'M', 'ἕ'), - (0x1F1E, 'X'), - (0x1F20, 'V'), - (0x1F28, 'M', 'ἠ'), - (0x1F29, 'M', 'ἡ'), - (0x1F2A, 'M', 'ἢ'), - (0x1F2B, 'M', 'ἣ'), - (0x1F2C, 'M', 'ἤ'), - (0x1F2D, 'M', 'ἥ'), - (0x1F2E, 'M', 'ἦ'), - (0x1F2F, 'M', 'ἧ'), - (0x1F30, 'V'), - (0x1F38, 'M', 'ἰ'), - (0x1F39, 'M', 'ἱ'), - (0x1F3A, 'M', 'ἲ'), - (0x1F3B, 'M', 'ἳ'), - (0x1F3C, 'M', 'ἴ'), - (0x1F3D, 'M', 'ἵ'), - (0x1F3E, 'M', 'ἶ'), - (0x1F3F, 'M', 'ἷ'), - (0x1F40, 'V'), - (0x1F46, 'X'), - (0x1F48, 'M', 'ὀ'), - (0x1F49, 'M', 'ὁ'), - (0x1F4A, 'M', 'ὂ'), - (0x1F4B, 'M', 'ὃ'), - (0x1F4C, 'M', 'ὄ'), - (0x1F4D, 'M', 'ὅ'), - (0x1F4E, 'X'), - (0x1F50, 'V'), - (0x1F58, 'X'), - (0x1F59, 'M', 'ὑ'), - (0x1F5A, 'X'), - (0x1F5B, 'M', 'ὓ'), - (0x1F5C, 'X'), - (0x1F5D, 'M', 'ὕ'), - (0x1F5E, 'X'), - (0x1F5F, 'M', 'ὗ'), - (0x1F60, 'V'), - (0x1F68, 'M', 'ὠ'), - (0x1F69, 'M', 'ὡ'), - (0x1F6A, 'M', 'ὢ'), - (0x1F6B, 'M', 'ὣ'), - (0x1F6C, 'M', 'ὤ'), - (0x1F6D, 'M', 'ὥ'), - (0x1F6E, 'M', 'ὦ'), - (0x1F6F, 'M', 'ὧ'), - (0x1F70, 'V'), - (0x1F71, 'M', 'ά'), - (0x1F72, 'V'), - (0x1F73, 'M', 'έ'), - (0x1F74, 'V'), - (0x1F75, 'M', 'ή'), - (0x1F76, 'V'), - (0x1F77, 'M', 'ί'), - (0x1F78, 'V'), - (0x1F79, 'M', 'ό'), - (0x1F7A, 'V'), - (0x1F7B, 'M', 'ύ'), - (0x1F7C, 'V'), - (0x1F7D, 'M', 'ώ'), - (0x1F7E, 'X'), - (0x1F80, 'M', 'ἀι'), - (0x1F81, 'M', 'ἁι'), - (0x1F82, 'M', 'ἂι'), - (0x1F83, 'M', 'ἃι'), - (0x1F84, 'M', 'ἄι'), - ] - -def _seg_20(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0x1F85, 'M', 'ἅι'), - (0x1F86, 'M', 'ἆι'), - (0x1F87, 'M', 'ἇι'), - (0x1F88, 'M', 'ἀι'), - (0x1F89, 'M', 'ἁι'), - (0x1F8A, 'M', 'ἂι'), - (0x1F8B, 'M', 'ἃι'), - (0x1F8C, 'M', 'ἄι'), - (0x1F8D, 'M', 'ἅι'), - (0x1F8E, 'M', 'ἆι'), - (0x1F8F, 'M', 'ἇι'), - (0x1F90, 'M', 'ἠι'), - (0x1F91, 'M', 'ἡι'), - (0x1F92, 'M', 'ἢι'), - (0x1F93, 'M', 'ἣι'), - (0x1F94, 'M', 'ἤι'), - (0x1F95, 'M', 'ἥι'), - (0x1F96, 'M', 'ἦι'), - (0x1F97, 'M', 'ἧι'), - (0x1F98, 'M', 'ἠι'), - (0x1F99, 'M', 'ἡι'), - (0x1F9A, 'M', 'ἢι'), - (0x1F9B, 'M', 'ἣι'), - (0x1F9C, 'M', 'ἤι'), - (0x1F9D, 'M', 'ἥι'), - (0x1F9E, 'M', 'ἦι'), - (0x1F9F, 'M', 'ἧι'), - (0x1FA0, 'M', 'ὠι'), - (0x1FA1, 'M', 'ὡι'), - (0x1FA2, 'M', 'ὢι'), - (0x1FA3, 'M', 'ὣι'), - (0x1FA4, 'M', 'ὤι'), - (0x1FA5, 'M', 'ὥι'), - (0x1FA6, 'M', 'ὦι'), - (0x1FA7, 'M', 'ὧι'), - (0x1FA8, 'M', 'ὠι'), - (0x1FA9, 'M', 'ὡι'), - (0x1FAA, 'M', 'ὢι'), - (0x1FAB, 'M', 'ὣι'), - (0x1FAC, 'M', 'ὤι'), - (0x1FAD, 'M', 'ὥι'), - (0x1FAE, 'M', 'ὦι'), - (0x1FAF, 'M', 'ὧι'), - (0x1FB0, 'V'), - (0x1FB2, 'M', 'ὰι'), - (0x1FB3, 'M', 'αι'), - (0x1FB4, 'M', 'άι'), - (0x1FB5, 'X'), - (0x1FB6, 'V'), - (0x1FB7, 'M', 'ᾶι'), - (0x1FB8, 'M', 'ᾰ'), - (0x1FB9, 'M', 'ᾱ'), - (0x1FBA, 'M', 'ὰ'), - (0x1FBB, 'M', 'ά'), - (0x1FBC, 'M', 'αι'), - (0x1FBD, '3', ' ̓'), - (0x1FBE, 'M', 'ι'), - (0x1FBF, '3', ' ̓'), - (0x1FC0, '3', ' ͂'), - (0x1FC1, '3', ' ̈͂'), - (0x1FC2, 'M', 'ὴι'), - (0x1FC3, 'M', 'ηι'), - (0x1FC4, 'M', 'ήι'), - (0x1FC5, 'X'), - (0x1FC6, 'V'), - (0x1FC7, 'M', 'ῆι'), - (0x1FC8, 'M', 'ὲ'), - (0x1FC9, 'M', 'έ'), - (0x1FCA, 'M', 'ὴ'), - (0x1FCB, 'M', 'ή'), - (0x1FCC, 'M', 'ηι'), - (0x1FCD, '3', ' ̓̀'), - (0x1FCE, '3', ' ̓́'), - (0x1FCF, '3', ' ̓͂'), - (0x1FD0, 'V'), - (0x1FD3, 'M', 'ΐ'), - (0x1FD4, 'X'), - (0x1FD6, 'V'), - (0x1FD8, 'M', 'ῐ'), - (0x1FD9, 'M', 'ῑ'), - (0x1FDA, 'M', 'ὶ'), - (0x1FDB, 'M', 'ί'), - (0x1FDC, 'X'), - (0x1FDD, '3', ' ̔̀'), - (0x1FDE, '3', ' ̔́'), - (0x1FDF, '3', ' ̔͂'), - (0x1FE0, 'V'), - (0x1FE3, 'M', 'ΰ'), - (0x1FE4, 'V'), - (0x1FE8, 'M', 'ῠ'), - (0x1FE9, 'M', 'ῡ'), - (0x1FEA, 'M', 'ὺ'), - (0x1FEB, 'M', 'ύ'), - (0x1FEC, 'M', 'ῥ'), - (0x1FED, '3', ' ̈̀'), - (0x1FEE, '3', ' ̈́'), - (0x1FEF, '3', '`'), - (0x1FF0, 'X'), - (0x1FF2, 'M', 'ὼι'), - (0x1FF3, 'M', 'ωι'), - ] - -def _seg_21(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0x1FF4, 'M', 'ώι'), - (0x1FF5, 'X'), - (0x1FF6, 'V'), - (0x1FF7, 'M', 'ῶι'), - (0x1FF8, 'M', 'ὸ'), - (0x1FF9, 'M', 'ό'), - (0x1FFA, 'M', 'ὼ'), - (0x1FFB, 'M', 'ώ'), - (0x1FFC, 'M', 'ωι'), - (0x1FFD, '3', ' ́'), - (0x1FFE, '3', ' ̔'), - (0x1FFF, 'X'), - (0x2000, '3', ' '), - (0x200B, 'I'), - (0x200C, 'D', ''), - (0x200E, 'X'), - (0x2010, 'V'), - (0x2011, 'M', '‐'), - (0x2012, 'V'), - (0x2017, '3', ' ̳'), - (0x2018, 'V'), - (0x2024, 'X'), - (0x2027, 'V'), - (0x2028, 'X'), - (0x202F, '3', ' '), - (0x2030, 'V'), - (0x2033, 'M', '′′'), - (0x2034, 'M', '′′′'), - (0x2035, 'V'), - (0x2036, 'M', '‵‵'), - (0x2037, 'M', '‵‵‵'), - (0x2038, 'V'), - (0x203C, '3', '!!'), - (0x203D, 'V'), - (0x203E, '3', ' ̅'), - (0x203F, 'V'), - (0x2047, '3', '??'), - (0x2048, '3', '?!'), - (0x2049, '3', '!?'), - (0x204A, 'V'), - (0x2057, 'M', '′′′′'), - (0x2058, 'V'), - (0x205F, '3', ' '), - (0x2060, 'I'), - (0x2061, 'X'), - (0x2064, 'I'), - (0x2065, 'X'), - (0x2070, 'M', '0'), - (0x2071, 'M', 'i'), - (0x2072, 'X'), - (0x2074, 'M', '4'), - (0x2075, 'M', '5'), - (0x2076, 'M', '6'), - (0x2077, 'M', '7'), - (0x2078, 'M', '8'), - (0x2079, 'M', '9'), - (0x207A, '3', '+'), - (0x207B, 'M', '−'), - (0x207C, '3', '='), - (0x207D, '3', '('), - (0x207E, '3', ')'), - (0x207F, 'M', 'n'), - (0x2080, 'M', '0'), - (0x2081, 'M', '1'), - (0x2082, 'M', '2'), - (0x2083, 'M', '3'), - (0x2084, 'M', '4'), - (0x2085, 'M', '5'), - (0x2086, 'M', '6'), - (0x2087, 'M', '7'), - (0x2088, 'M', '8'), - (0x2089, 'M', '9'), - (0x208A, '3', '+'), - (0x208B, 'M', '−'), - (0x208C, '3', '='), - (0x208D, '3', '('), - (0x208E, '3', ')'), - (0x208F, 'X'), - (0x2090, 'M', 'a'), - (0x2091, 'M', 'e'), - (0x2092, 'M', 'o'), - (0x2093, 'M', 'x'), - (0x2094, 'M', 'ə'), - (0x2095, 'M', 'h'), - (0x2096, 'M', 'k'), - (0x2097, 'M', 'l'), - (0x2098, 'M', 'm'), - (0x2099, 'M', 'n'), - (0x209A, 'M', 'p'), - (0x209B, 'M', 's'), - (0x209C, 'M', 't'), - (0x209D, 'X'), - (0x20A0, 'V'), - (0x20A8, 'M', 'rs'), - (0x20A9, 'V'), - (0x20C0, 'X'), - (0x20D0, 'V'), - (0x20F1, 'X'), - (0x2100, '3', 'a/c'), - (0x2101, '3', 'a/s'), - ] - -def _seg_22(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0x2102, 'M', 'c'), - (0x2103, 'M', '°c'), - (0x2104, 'V'), - (0x2105, '3', 'c/o'), - (0x2106, '3', 'c/u'), - (0x2107, 'M', 'ɛ'), - (0x2108, 'V'), - (0x2109, 'M', '°f'), - (0x210A, 'M', 'g'), - (0x210B, 'M', 'h'), - (0x210F, 'M', 'ħ'), - (0x2110, 'M', 'i'), - (0x2112, 'M', 'l'), - (0x2114, 'V'), - (0x2115, 'M', 'n'), - (0x2116, 'M', 'no'), - (0x2117, 'V'), - (0x2119, 'M', 'p'), - (0x211A, 'M', 'q'), - (0x211B, 'M', 'r'), - (0x211E, 'V'), - (0x2120, 'M', 'sm'), - (0x2121, 'M', 'tel'), - (0x2122, 'M', 'tm'), - (0x2123, 'V'), - (0x2124, 'M', 'z'), - (0x2125, 'V'), - (0x2126, 'M', 'ω'), - (0x2127, 'V'), - (0x2128, 'M', 'z'), - (0x2129, 'V'), - (0x212A, 'M', 'k'), - (0x212B, 'M', 'å'), - (0x212C, 'M', 'b'), - (0x212D, 'M', 'c'), - (0x212E, 'V'), - (0x212F, 'M', 'e'), - (0x2131, 'M', 'f'), - (0x2132, 'X'), - (0x2133, 'M', 'm'), - (0x2134, 'M', 'o'), - (0x2135, 'M', 'א'), - (0x2136, 'M', 'ב'), - (0x2137, 'M', 'ג'), - (0x2138, 'M', 'ד'), - (0x2139, 'M', 'i'), - (0x213A, 'V'), - (0x213B, 'M', 'fax'), - (0x213C, 'M', 'π'), - (0x213D, 'M', 'γ'), - (0x213F, 'M', 'π'), - (0x2140, 'M', '∑'), - (0x2141, 'V'), - (0x2145, 'M', 'd'), - (0x2147, 'M', 'e'), - (0x2148, 'M', 'i'), - (0x2149, 'M', 'j'), - (0x214A, 'V'), - (0x2150, 'M', '1⁄7'), - (0x2151, 'M', '1⁄9'), - (0x2152, 'M', '1⁄10'), - (0x2153, 'M', '1⁄3'), - (0x2154, 'M', '2⁄3'), - (0x2155, 'M', '1⁄5'), - (0x2156, 'M', '2⁄5'), - (0x2157, 'M', '3⁄5'), - (0x2158, 'M', '4⁄5'), - (0x2159, 'M', '1⁄6'), - (0x215A, 'M', '5⁄6'), - (0x215B, 'M', '1⁄8'), - (0x215C, 'M', '3⁄8'), - (0x215D, 'M', '5⁄8'), - (0x215E, 'M', '7⁄8'), - (0x215F, 'M', '1⁄'), - (0x2160, 'M', 'i'), - (0x2161, 'M', 'ii'), - (0x2162, 'M', 'iii'), - (0x2163, 'M', 'iv'), - (0x2164, 'M', 'v'), - (0x2165, 'M', 'vi'), - (0x2166, 'M', 'vii'), - (0x2167, 'M', 'viii'), - (0x2168, 'M', 'ix'), - (0x2169, 'M', 'x'), - (0x216A, 'M', 'xi'), - (0x216B, 'M', 'xii'), - (0x216C, 'M', 'l'), - (0x216D, 'M', 'c'), - (0x216E, 'M', 'd'), - (0x216F, 'M', 'm'), - (0x2170, 'M', 'i'), - (0x2171, 'M', 'ii'), - (0x2172, 'M', 'iii'), - (0x2173, 'M', 'iv'), - (0x2174, 'M', 'v'), - (0x2175, 'M', 'vi'), - (0x2176, 'M', 'vii'), - (0x2177, 'M', 'viii'), - (0x2178, 'M', 'ix'), - (0x2179, 'M', 'x'), - ] - -def _seg_23(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0x217A, 'M', 'xi'), - (0x217B, 'M', 'xii'), - (0x217C, 'M', 'l'), - (0x217D, 'M', 'c'), - (0x217E, 'M', 'd'), - (0x217F, 'M', 'm'), - (0x2180, 'V'), - (0x2183, 'X'), - (0x2184, 'V'), - (0x2189, 'M', '0⁄3'), - (0x218A, 'V'), - (0x218C, 'X'), - (0x2190, 'V'), - (0x222C, 'M', '∫∫'), - (0x222D, 'M', '∫∫∫'), - (0x222E, 'V'), - (0x222F, 'M', '∮∮'), - (0x2230, 'M', '∮∮∮'), - (0x2231, 'V'), - (0x2260, '3'), - (0x2261, 'V'), - (0x226E, '3'), - (0x2270, 'V'), - (0x2329, 'M', '〈'), - (0x232A, 'M', '〉'), - (0x232B, 'V'), - (0x2427, 'X'), - (0x2440, 'V'), - (0x244B, 'X'), - (0x2460, 'M', '1'), - (0x2461, 'M', '2'), - (0x2462, 'M', '3'), - (0x2463, 'M', '4'), - (0x2464, 'M', '5'), - (0x2465, 'M', '6'), - (0x2466, 'M', '7'), - (0x2467, 'M', '8'), - (0x2468, 'M', '9'), - (0x2469, 'M', '10'), - (0x246A, 'M', '11'), - (0x246B, 'M', '12'), - (0x246C, 'M', '13'), - (0x246D, 'M', '14'), - (0x246E, 'M', '15'), - (0x246F, 'M', '16'), - (0x2470, 'M', '17'), - (0x2471, 'M', '18'), - (0x2472, 'M', '19'), - (0x2473, 'M', '20'), - (0x2474, '3', '(1)'), - (0x2475, '3', '(2)'), - (0x2476, '3', '(3)'), - (0x2477, '3', '(4)'), - (0x2478, '3', '(5)'), - (0x2479, '3', '(6)'), - (0x247A, '3', '(7)'), - (0x247B, '3', '(8)'), - (0x247C, '3', '(9)'), - (0x247D, '3', '(10)'), - (0x247E, '3', '(11)'), - (0x247F, '3', '(12)'), - (0x2480, '3', '(13)'), - (0x2481, '3', '(14)'), - (0x2482, '3', '(15)'), - (0x2483, '3', '(16)'), - (0x2484, '3', '(17)'), - (0x2485, '3', '(18)'), - (0x2486, '3', '(19)'), - (0x2487, '3', '(20)'), - (0x2488, 'X'), - (0x249C, '3', '(a)'), - (0x249D, '3', '(b)'), - (0x249E, '3', '(c)'), - (0x249F, '3', '(d)'), - (0x24A0, '3', '(e)'), - (0x24A1, '3', '(f)'), - (0x24A2, '3', '(g)'), - (0x24A3, '3', '(h)'), - (0x24A4, '3', '(i)'), - (0x24A5, '3', '(j)'), - (0x24A6, '3', '(k)'), - (0x24A7, '3', '(l)'), - (0x24A8, '3', '(m)'), - (0x24A9, '3', '(n)'), - (0x24AA, '3', '(o)'), - (0x24AB, '3', '(p)'), - (0x24AC, '3', '(q)'), - (0x24AD, '3', '(r)'), - (0x24AE, '3', '(s)'), - (0x24AF, '3', '(t)'), - (0x24B0, '3', '(u)'), - (0x24B1, '3', '(v)'), - (0x24B2, '3', '(w)'), - (0x24B3, '3', '(x)'), - (0x24B4, '3', '(y)'), - (0x24B5, '3', '(z)'), - (0x24B6, 'M', 'a'), - (0x24B7, 'M', 'b'), - (0x24B8, 'M', 'c'), - (0x24B9, 'M', 'd'), - ] - -def _seg_24(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0x24BA, 'M', 'e'), - (0x24BB, 'M', 'f'), - (0x24BC, 'M', 'g'), - (0x24BD, 'M', 'h'), - (0x24BE, 'M', 'i'), - (0x24BF, 'M', 'j'), - (0x24C0, 'M', 'k'), - (0x24C1, 'M', 'l'), - (0x24C2, 'M', 'm'), - (0x24C3, 'M', 'n'), - (0x24C4, 'M', 'o'), - (0x24C5, 'M', 'p'), - (0x24C6, 'M', 'q'), - (0x24C7, 'M', 'r'), - (0x24C8, 'M', 's'), - (0x24C9, 'M', 't'), - (0x24CA, 'M', 'u'), - (0x24CB, 'M', 'v'), - (0x24CC, 'M', 'w'), - (0x24CD, 'M', 'x'), - (0x24CE, 'M', 'y'), - (0x24CF, 'M', 'z'), - (0x24D0, 'M', 'a'), - (0x24D1, 'M', 'b'), - (0x24D2, 'M', 'c'), - (0x24D3, 'M', 'd'), - (0x24D4, 'M', 'e'), - (0x24D5, 'M', 'f'), - (0x24D6, 'M', 'g'), - (0x24D7, 'M', 'h'), - (0x24D8, 'M', 'i'), - (0x24D9, 'M', 'j'), - (0x24DA, 'M', 'k'), - (0x24DB, 'M', 'l'), - (0x24DC, 'M', 'm'), - (0x24DD, 'M', 'n'), - (0x24DE, 'M', 'o'), - (0x24DF, 'M', 'p'), - (0x24E0, 'M', 'q'), - (0x24E1, 'M', 'r'), - (0x24E2, 'M', 's'), - (0x24E3, 'M', 't'), - (0x24E4, 'M', 'u'), - (0x24E5, 'M', 'v'), - (0x24E6, 'M', 'w'), - (0x24E7, 'M', 'x'), - (0x24E8, 'M', 'y'), - (0x24E9, 'M', 'z'), - (0x24EA, 'M', '0'), - (0x24EB, 'V'), - (0x2A0C, 'M', '∫∫∫∫'), - (0x2A0D, 'V'), - (0x2A74, '3', '::='), - (0x2A75, '3', '=='), - (0x2A76, '3', '==='), - (0x2A77, 'V'), - (0x2ADC, 'M', '⫝̸'), - (0x2ADD, 'V'), - (0x2B74, 'X'), - (0x2B76, 'V'), - (0x2B96, 'X'), - (0x2B97, 'V'), - (0x2C00, 'M', 'ⰰ'), - (0x2C01, 'M', 'ⰱ'), - (0x2C02, 'M', 'ⰲ'), - (0x2C03, 'M', 'ⰳ'), - (0x2C04, 'M', 'ⰴ'), - (0x2C05, 'M', 'ⰵ'), - (0x2C06, 'M', 'ⰶ'), - (0x2C07, 'M', 'ⰷ'), - (0x2C08, 'M', 'ⰸ'), - (0x2C09, 'M', 'ⰹ'), - (0x2C0A, 'M', 'ⰺ'), - (0x2C0B, 'M', 'ⰻ'), - (0x2C0C, 'M', 'ⰼ'), - (0x2C0D, 'M', 'ⰽ'), - (0x2C0E, 'M', 'ⰾ'), - (0x2C0F, 'M', 'ⰿ'), - (0x2C10, 'M', 'ⱀ'), - (0x2C11, 'M', 'ⱁ'), - (0x2C12, 'M', 'ⱂ'), - (0x2C13, 'M', 'ⱃ'), - (0x2C14, 'M', 'ⱄ'), - (0x2C15, 'M', 'ⱅ'), - (0x2C16, 'M', 'ⱆ'), - (0x2C17, 'M', 'ⱇ'), - (0x2C18, 'M', 'ⱈ'), - (0x2C19, 'M', 'ⱉ'), - (0x2C1A, 'M', 'ⱊ'), - (0x2C1B, 'M', 'ⱋ'), - (0x2C1C, 'M', 'ⱌ'), - (0x2C1D, 'M', 'ⱍ'), - (0x2C1E, 'M', 'ⱎ'), - (0x2C1F, 'M', 'ⱏ'), - (0x2C20, 'M', 'ⱐ'), - (0x2C21, 'M', 'ⱑ'), - (0x2C22, 'M', 'ⱒ'), - (0x2C23, 'M', 'ⱓ'), - (0x2C24, 'M', 'ⱔ'), - (0x2C25, 'M', 'ⱕ'), - ] - -def _seg_25(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0x2C26, 'M', 'ⱖ'), - (0x2C27, 'M', 'ⱗ'), - (0x2C28, 'M', 'ⱘ'), - (0x2C29, 'M', 'ⱙ'), - (0x2C2A, 'M', 'ⱚ'), - (0x2C2B, 'M', 'ⱛ'), - (0x2C2C, 'M', 'ⱜ'), - (0x2C2D, 'M', 'ⱝ'), - (0x2C2E, 'M', 'ⱞ'), - (0x2C2F, 'X'), - (0x2C30, 'V'), - (0x2C5F, 'X'), - (0x2C60, 'M', 'ⱡ'), - (0x2C61, 'V'), - (0x2C62, 'M', 'ɫ'), - (0x2C63, 'M', 'ᵽ'), - (0x2C64, 'M', 'ɽ'), - (0x2C65, 'V'), - (0x2C67, 'M', 'ⱨ'), - (0x2C68, 'V'), - (0x2C69, 'M', 'ⱪ'), - (0x2C6A, 'V'), - (0x2C6B, 'M', 'ⱬ'), - (0x2C6C, 'V'), - (0x2C6D, 'M', 'ɑ'), - (0x2C6E, 'M', 'ɱ'), - (0x2C6F, 'M', 'ɐ'), - (0x2C70, 'M', 'ɒ'), - (0x2C71, 'V'), - (0x2C72, 'M', 'ⱳ'), - (0x2C73, 'V'), - (0x2C75, 'M', 'ⱶ'), - (0x2C76, 'V'), - (0x2C7C, 'M', 'j'), - (0x2C7D, 'M', 'v'), - (0x2C7E, 'M', 'ȿ'), - (0x2C7F, 'M', 'ɀ'), - (0x2C80, 'M', 'ⲁ'), - (0x2C81, 'V'), - (0x2C82, 'M', 'ⲃ'), - (0x2C83, 'V'), - (0x2C84, 'M', 'ⲅ'), - (0x2C85, 'V'), - (0x2C86, 'M', 'ⲇ'), - (0x2C87, 'V'), - (0x2C88, 'M', 'ⲉ'), - (0x2C89, 'V'), - (0x2C8A, 'M', 'ⲋ'), - (0x2C8B, 'V'), - (0x2C8C, 'M', 'ⲍ'), - (0x2C8D, 'V'), - (0x2C8E, 'M', 'ⲏ'), - (0x2C8F, 'V'), - (0x2C90, 'M', 'ⲑ'), - (0x2C91, 'V'), - (0x2C92, 'M', 'ⲓ'), - (0x2C93, 'V'), - (0x2C94, 'M', 'ⲕ'), - (0x2C95, 'V'), - (0x2C96, 'M', 'ⲗ'), - (0x2C97, 'V'), - (0x2C98, 'M', 'ⲙ'), - (0x2C99, 'V'), - (0x2C9A, 'M', 'ⲛ'), - (0x2C9B, 'V'), - (0x2C9C, 'M', 'ⲝ'), - (0x2C9D, 'V'), - (0x2C9E, 'M', 'ⲟ'), - (0x2C9F, 'V'), - (0x2CA0, 'M', 'ⲡ'), - (0x2CA1, 'V'), - (0x2CA2, 'M', 'ⲣ'), - (0x2CA3, 'V'), - (0x2CA4, 'M', 'ⲥ'), - (0x2CA5, 'V'), - (0x2CA6, 'M', 'ⲧ'), - (0x2CA7, 'V'), - (0x2CA8, 'M', 'ⲩ'), - (0x2CA9, 'V'), - (0x2CAA, 'M', 'ⲫ'), - (0x2CAB, 'V'), - (0x2CAC, 'M', 'ⲭ'), - (0x2CAD, 'V'), - (0x2CAE, 'M', 'ⲯ'), - (0x2CAF, 'V'), - (0x2CB0, 'M', 'ⲱ'), - (0x2CB1, 'V'), - (0x2CB2, 'M', 'ⲳ'), - (0x2CB3, 'V'), - (0x2CB4, 'M', 'ⲵ'), - (0x2CB5, 'V'), - (0x2CB6, 'M', 'ⲷ'), - (0x2CB7, 'V'), - (0x2CB8, 'M', 'ⲹ'), - (0x2CB9, 'V'), - (0x2CBA, 'M', 'ⲻ'), - (0x2CBB, 'V'), - (0x2CBC, 'M', 'ⲽ'), - (0x2CBD, 'V'), - (0x2CBE, 'M', 'ⲿ'), - ] - -def _seg_26(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0x2CBF, 'V'), - (0x2CC0, 'M', 'ⳁ'), - (0x2CC1, 'V'), - (0x2CC2, 'M', 'ⳃ'), - (0x2CC3, 'V'), - (0x2CC4, 'M', 'ⳅ'), - (0x2CC5, 'V'), - (0x2CC6, 'M', 'ⳇ'), - (0x2CC7, 'V'), - (0x2CC8, 'M', 'ⳉ'), - (0x2CC9, 'V'), - (0x2CCA, 'M', 'ⳋ'), - (0x2CCB, 'V'), - (0x2CCC, 'M', 'ⳍ'), - (0x2CCD, 'V'), - (0x2CCE, 'M', 'ⳏ'), - (0x2CCF, 'V'), - (0x2CD0, 'M', 'ⳑ'), - (0x2CD1, 'V'), - (0x2CD2, 'M', 'ⳓ'), - (0x2CD3, 'V'), - (0x2CD4, 'M', 'ⳕ'), - (0x2CD5, 'V'), - (0x2CD6, 'M', 'ⳗ'), - (0x2CD7, 'V'), - (0x2CD8, 'M', 'ⳙ'), - (0x2CD9, 'V'), - (0x2CDA, 'M', 'ⳛ'), - (0x2CDB, 'V'), - (0x2CDC, 'M', 'ⳝ'), - (0x2CDD, 'V'), - (0x2CDE, 'M', 'ⳟ'), - (0x2CDF, 'V'), - (0x2CE0, 'M', 'ⳡ'), - (0x2CE1, 'V'), - (0x2CE2, 'M', 'ⳣ'), - (0x2CE3, 'V'), - (0x2CEB, 'M', 'ⳬ'), - (0x2CEC, 'V'), - (0x2CED, 'M', 'ⳮ'), - (0x2CEE, 'V'), - (0x2CF2, 'M', 'ⳳ'), - (0x2CF3, 'V'), - (0x2CF4, 'X'), - (0x2CF9, 'V'), - (0x2D26, 'X'), - (0x2D27, 'V'), - (0x2D28, 'X'), - (0x2D2D, 'V'), - (0x2D2E, 'X'), - (0x2D30, 'V'), - (0x2D68, 'X'), - (0x2D6F, 'M', 'ⵡ'), - (0x2D70, 'V'), - (0x2D71, 'X'), - (0x2D7F, 'V'), - (0x2D97, 'X'), - (0x2DA0, 'V'), - (0x2DA7, 'X'), - (0x2DA8, 'V'), - (0x2DAF, 'X'), - (0x2DB0, 'V'), - (0x2DB7, 'X'), - (0x2DB8, 'V'), - (0x2DBF, 'X'), - (0x2DC0, 'V'), - (0x2DC7, 'X'), - (0x2DC8, 'V'), - (0x2DCF, 'X'), - (0x2DD0, 'V'), - (0x2DD7, 'X'), - (0x2DD8, 'V'), - (0x2DDF, 'X'), - (0x2DE0, 'V'), - (0x2E53, 'X'), - (0x2E80, 'V'), - (0x2E9A, 'X'), - (0x2E9B, 'V'), - (0x2E9F, 'M', '母'), - (0x2EA0, 'V'), - (0x2EF3, 'M', '龟'), - (0x2EF4, 'X'), - (0x2F00, 'M', '一'), - (0x2F01, 'M', '丨'), - (0x2F02, 'M', '丶'), - (0x2F03, 'M', '丿'), - (0x2F04, 'M', '乙'), - (0x2F05, 'M', '亅'), - (0x2F06, 'M', '二'), - (0x2F07, 'M', '亠'), - (0x2F08, 'M', '人'), - (0x2F09, 'M', '儿'), - (0x2F0A, 'M', '入'), - (0x2F0B, 'M', '八'), - (0x2F0C, 'M', '冂'), - (0x2F0D, 'M', '冖'), - (0x2F0E, 'M', '冫'), - (0x2F0F, 'M', '几'), - (0x2F10, 'M', '凵'), - (0x2F11, 'M', '刀'), - ] - -def _seg_27(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0x2F12, 'M', '力'), - (0x2F13, 'M', '勹'), - (0x2F14, 'M', '匕'), - (0x2F15, 'M', '匚'), - (0x2F16, 'M', '匸'), - (0x2F17, 'M', '十'), - (0x2F18, 'M', '卜'), - (0x2F19, 'M', '卩'), - (0x2F1A, 'M', '厂'), - (0x2F1B, 'M', '厶'), - (0x2F1C, 'M', '又'), - (0x2F1D, 'M', '口'), - (0x2F1E, 'M', '囗'), - (0x2F1F, 'M', '土'), - (0x2F20, 'M', '士'), - (0x2F21, 'M', '夂'), - (0x2F22, 'M', '夊'), - (0x2F23, 'M', '夕'), - (0x2F24, 'M', '大'), - (0x2F25, 'M', '女'), - (0x2F26, 'M', '子'), - (0x2F27, 'M', '宀'), - (0x2F28, 'M', '寸'), - (0x2F29, 'M', '小'), - (0x2F2A, 'M', '尢'), - (0x2F2B, 'M', '尸'), - (0x2F2C, 'M', '屮'), - (0x2F2D, 'M', '山'), - (0x2F2E, 'M', '巛'), - (0x2F2F, 'M', '工'), - (0x2F30, 'M', '己'), - (0x2F31, 'M', '巾'), - (0x2F32, 'M', '干'), - (0x2F33, 'M', '幺'), - (0x2F34, 'M', '广'), - (0x2F35, 'M', '廴'), - (0x2F36, 'M', '廾'), - (0x2F37, 'M', '弋'), - (0x2F38, 'M', '弓'), - (0x2F39, 'M', '彐'), - (0x2F3A, 'M', '彡'), - (0x2F3B, 'M', '彳'), - (0x2F3C, 'M', '心'), - (0x2F3D, 'M', '戈'), - (0x2F3E, 'M', '戶'), - (0x2F3F, 'M', '手'), - (0x2F40, 'M', '支'), - (0x2F41, 'M', '攴'), - (0x2F42, 'M', '文'), - (0x2F43, 'M', '斗'), - (0x2F44, 'M', '斤'), - (0x2F45, 'M', '方'), - (0x2F46, 'M', '无'), - (0x2F47, 'M', '日'), - (0x2F48, 'M', '曰'), - (0x2F49, 'M', '月'), - (0x2F4A, 'M', '木'), - (0x2F4B, 'M', '欠'), - (0x2F4C, 'M', '止'), - (0x2F4D, 'M', '歹'), - (0x2F4E, 'M', '殳'), - (0x2F4F, 'M', '毋'), - (0x2F50, 'M', '比'), - (0x2F51, 'M', '毛'), - (0x2F52, 'M', '氏'), - (0x2F53, 'M', '气'), - (0x2F54, 'M', '水'), - (0x2F55, 'M', '火'), - (0x2F56, 'M', '爪'), - (0x2F57, 'M', '父'), - (0x2F58, 'M', '爻'), - (0x2F59, 'M', '爿'), - (0x2F5A, 'M', '片'), - (0x2F5B, 'M', '牙'), - (0x2F5C, 'M', '牛'), - (0x2F5D, 'M', '犬'), - (0x2F5E, 'M', '玄'), - (0x2F5F, 'M', '玉'), - (0x2F60, 'M', '瓜'), - (0x2F61, 'M', '瓦'), - (0x2F62, 'M', '甘'), - (0x2F63, 'M', '生'), - (0x2F64, 'M', '用'), - (0x2F65, 'M', '田'), - (0x2F66, 'M', '疋'), - (0x2F67, 'M', '疒'), - (0x2F68, 'M', '癶'), - (0x2F69, 'M', '白'), - (0x2F6A, 'M', '皮'), - (0x2F6B, 'M', '皿'), - (0x2F6C, 'M', '目'), - (0x2F6D, 'M', '矛'), - (0x2F6E, 'M', '矢'), - (0x2F6F, 'M', '石'), - (0x2F70, 'M', '示'), - (0x2F71, 'M', '禸'), - (0x2F72, 'M', '禾'), - (0x2F73, 'M', '穴'), - (0x2F74, 'M', '立'), - (0x2F75, 'M', '竹'), - ] - -def _seg_28(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0x2F76, 'M', '米'), - (0x2F77, 'M', '糸'), - (0x2F78, 'M', '缶'), - (0x2F79, 'M', '网'), - (0x2F7A, 'M', '羊'), - (0x2F7B, 'M', '羽'), - (0x2F7C, 'M', '老'), - (0x2F7D, 'M', '而'), - (0x2F7E, 'M', '耒'), - (0x2F7F, 'M', '耳'), - (0x2F80, 'M', '聿'), - (0x2F81, 'M', '肉'), - (0x2F82, 'M', '臣'), - (0x2F83, 'M', '自'), - (0x2F84, 'M', '至'), - (0x2F85, 'M', '臼'), - (0x2F86, 'M', '舌'), - (0x2F87, 'M', '舛'), - (0x2F88, 'M', '舟'), - (0x2F89, 'M', '艮'), - (0x2F8A, 'M', '色'), - (0x2F8B, 'M', '艸'), - (0x2F8C, 'M', '虍'), - (0x2F8D, 'M', '虫'), - (0x2F8E, 'M', '血'), - (0x2F8F, 'M', '行'), - (0x2F90, 'M', '衣'), - (0x2F91, 'M', '襾'), - (0x2F92, 'M', '見'), - (0x2F93, 'M', '角'), - (0x2F94, 'M', '言'), - (0x2F95, 'M', '谷'), - (0x2F96, 'M', '豆'), - (0x2F97, 'M', '豕'), - (0x2F98, 'M', '豸'), - (0x2F99, 'M', '貝'), - (0x2F9A, 'M', '赤'), - (0x2F9B, 'M', '走'), - (0x2F9C, 'M', '足'), - (0x2F9D, 'M', '身'), - (0x2F9E, 'M', '車'), - (0x2F9F, 'M', '辛'), - (0x2FA0, 'M', '辰'), - (0x2FA1, 'M', '辵'), - (0x2FA2, 'M', '邑'), - (0x2FA3, 'M', '酉'), - (0x2FA4, 'M', '釆'), - (0x2FA5, 'M', '里'), - (0x2FA6, 'M', '金'), - (0x2FA7, 'M', '長'), - (0x2FA8, 'M', '門'), - (0x2FA9, 'M', '阜'), - (0x2FAA, 'M', '隶'), - (0x2FAB, 'M', '隹'), - (0x2FAC, 'M', '雨'), - (0x2FAD, 'M', '靑'), - (0x2FAE, 'M', '非'), - (0x2FAF, 'M', '面'), - (0x2FB0, 'M', '革'), - (0x2FB1, 'M', '韋'), - (0x2FB2, 'M', '韭'), - (0x2FB3, 'M', '音'), - (0x2FB4, 'M', '頁'), - (0x2FB5, 'M', '風'), - (0x2FB6, 'M', '飛'), - (0x2FB7, 'M', '食'), - (0x2FB8, 'M', '首'), - (0x2FB9, 'M', '香'), - (0x2FBA, 'M', '馬'), - (0x2FBB, 'M', '骨'), - (0x2FBC, 'M', '高'), - (0x2FBD, 'M', '髟'), - (0x2FBE, 'M', '鬥'), - (0x2FBF, 'M', '鬯'), - (0x2FC0, 'M', '鬲'), - (0x2FC1, 'M', '鬼'), - (0x2FC2, 'M', '魚'), - (0x2FC3, 'M', '鳥'), - (0x2FC4, 'M', '鹵'), - (0x2FC5, 'M', '鹿'), - (0x2FC6, 'M', '麥'), - (0x2FC7, 'M', '麻'), - (0x2FC8, 'M', '黃'), - (0x2FC9, 'M', '黍'), - (0x2FCA, 'M', '黑'), - (0x2FCB, 'M', '黹'), - (0x2FCC, 'M', '黽'), - (0x2FCD, 'M', '鼎'), - (0x2FCE, 'M', '鼓'), - (0x2FCF, 'M', '鼠'), - (0x2FD0, 'M', '鼻'), - (0x2FD1, 'M', '齊'), - (0x2FD2, 'M', '齒'), - (0x2FD3, 'M', '龍'), - (0x2FD4, 'M', '龜'), - (0x2FD5, 'M', '龠'), - (0x2FD6, 'X'), - (0x3000, '3', ' '), - (0x3001, 'V'), - (0x3002, 'M', '.'), - ] - -def _seg_29(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0x3003, 'V'), - (0x3036, 'M', '〒'), - (0x3037, 'V'), - (0x3038, 'M', '十'), - (0x3039, 'M', '卄'), - (0x303A, 'M', '卅'), - (0x303B, 'V'), - (0x3040, 'X'), - (0x3041, 'V'), - (0x3097, 'X'), - (0x3099, 'V'), - (0x309B, '3', ' ゙'), - (0x309C, '3', ' ゚'), - (0x309D, 'V'), - (0x309F, 'M', 'より'), - (0x30A0, 'V'), - (0x30FF, 'M', 'コト'), - (0x3100, 'X'), - (0x3105, 'V'), - (0x3130, 'X'), - (0x3131, 'M', 'ᄀ'), - (0x3132, 'M', 'ᄁ'), - (0x3133, 'M', 'ᆪ'), - (0x3134, 'M', 'ᄂ'), - (0x3135, 'M', 'ᆬ'), - (0x3136, 'M', 'ᆭ'), - (0x3137, 'M', 'ᄃ'), - (0x3138, 'M', 'ᄄ'), - (0x3139, 'M', 'ᄅ'), - (0x313A, 'M', 'ᆰ'), - (0x313B, 'M', 'ᆱ'), - (0x313C, 'M', 'ᆲ'), - (0x313D, 'M', 'ᆳ'), - (0x313E, 'M', 'ᆴ'), - (0x313F, 'M', 'ᆵ'), - (0x3140, 'M', 'ᄚ'), - (0x3141, 'M', 'ᄆ'), - (0x3142, 'M', 'ᄇ'), - (0x3143, 'M', 'ᄈ'), - (0x3144, 'M', 'ᄡ'), - (0x3145, 'M', 'ᄉ'), - (0x3146, 'M', 'ᄊ'), - (0x3147, 'M', 'ᄋ'), - (0x3148, 'M', 'ᄌ'), - (0x3149, 'M', 'ᄍ'), - (0x314A, 'M', 'ᄎ'), - (0x314B, 'M', 'ᄏ'), - (0x314C, 'M', 'ᄐ'), - (0x314D, 'M', 'ᄑ'), - (0x314E, 'M', 'ᄒ'), - (0x314F, 'M', 'ᅡ'), - (0x3150, 'M', 'ᅢ'), - (0x3151, 'M', 'ᅣ'), - (0x3152, 'M', 'ᅤ'), - (0x3153, 'M', 'ᅥ'), - (0x3154, 'M', 'ᅦ'), - (0x3155, 'M', 'ᅧ'), - (0x3156, 'M', 'ᅨ'), - (0x3157, 'M', 'ᅩ'), - (0x3158, 'M', 'ᅪ'), - (0x3159, 'M', 'ᅫ'), - (0x315A, 'M', 'ᅬ'), - (0x315B, 'M', 'ᅭ'), - (0x315C, 'M', 'ᅮ'), - (0x315D, 'M', 'ᅯ'), - (0x315E, 'M', 'ᅰ'), - (0x315F, 'M', 'ᅱ'), - (0x3160, 'M', 'ᅲ'), - (0x3161, 'M', 'ᅳ'), - (0x3162, 'M', 'ᅴ'), - (0x3163, 'M', 'ᅵ'), - (0x3164, 'X'), - (0x3165, 'M', 'ᄔ'), - (0x3166, 'M', 'ᄕ'), - (0x3167, 'M', 'ᇇ'), - (0x3168, 'M', 'ᇈ'), - (0x3169, 'M', 'ᇌ'), - (0x316A, 'M', 'ᇎ'), - (0x316B, 'M', 'ᇓ'), - (0x316C, 'M', 'ᇗ'), - (0x316D, 'M', 'ᇙ'), - (0x316E, 'M', 'ᄜ'), - (0x316F, 'M', 'ᇝ'), - (0x3170, 'M', 'ᇟ'), - (0x3171, 'M', 'ᄝ'), - (0x3172, 'M', 'ᄞ'), - (0x3173, 'M', 'ᄠ'), - (0x3174, 'M', 'ᄢ'), - (0x3175, 'M', 'ᄣ'), - (0x3176, 'M', 'ᄧ'), - (0x3177, 'M', 'ᄩ'), - (0x3178, 'M', 'ᄫ'), - (0x3179, 'M', 'ᄬ'), - (0x317A, 'M', 'ᄭ'), - (0x317B, 'M', 'ᄮ'), - (0x317C, 'M', 'ᄯ'), - (0x317D, 'M', 'ᄲ'), - (0x317E, 'M', 'ᄶ'), - (0x317F, 'M', 'ᅀ'), - (0x3180, 'M', 'ᅇ'), - ] - -def _seg_30(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0x3181, 'M', 'ᅌ'), - (0x3182, 'M', 'ᇱ'), - (0x3183, 'M', 'ᇲ'), - (0x3184, 'M', 'ᅗ'), - (0x3185, 'M', 'ᅘ'), - (0x3186, 'M', 'ᅙ'), - (0x3187, 'M', 'ᆄ'), - (0x3188, 'M', 'ᆅ'), - (0x3189, 'M', 'ᆈ'), - (0x318A, 'M', 'ᆑ'), - (0x318B, 'M', 'ᆒ'), - (0x318C, 'M', 'ᆔ'), - (0x318D, 'M', 'ᆞ'), - (0x318E, 'M', 'ᆡ'), - (0x318F, 'X'), - (0x3190, 'V'), - (0x3192, 'M', '一'), - (0x3193, 'M', '二'), - (0x3194, 'M', '三'), - (0x3195, 'M', '四'), - (0x3196, 'M', '上'), - (0x3197, 'M', '中'), - (0x3198, 'M', '下'), - (0x3199, 'M', '甲'), - (0x319A, 'M', '乙'), - (0x319B, 'M', '丙'), - (0x319C, 'M', '丁'), - (0x319D, 'M', '天'), - (0x319E, 'M', '地'), - (0x319F, 'M', '人'), - (0x31A0, 'V'), - (0x31E4, 'X'), - (0x31F0, 'V'), - (0x3200, '3', '(ᄀ)'), - (0x3201, '3', '(ᄂ)'), - (0x3202, '3', '(ᄃ)'), - (0x3203, '3', '(ᄅ)'), - (0x3204, '3', '(ᄆ)'), - (0x3205, '3', '(ᄇ)'), - (0x3206, '3', '(ᄉ)'), - (0x3207, '3', '(ᄋ)'), - (0x3208, '3', '(ᄌ)'), - (0x3209, '3', '(ᄎ)'), - (0x320A, '3', '(ᄏ)'), - (0x320B, '3', '(ᄐ)'), - (0x320C, '3', '(ᄑ)'), - (0x320D, '3', '(ᄒ)'), - (0x320E, '3', '(가)'), - (0x320F, '3', '(나)'), - (0x3210, '3', '(다)'), - (0x3211, '3', '(라)'), - (0x3212, '3', '(마)'), - (0x3213, '3', '(바)'), - (0x3214, '3', '(사)'), - (0x3215, '3', '(아)'), - (0x3216, '3', '(자)'), - (0x3217, '3', '(차)'), - (0x3218, '3', '(카)'), - (0x3219, '3', '(타)'), - (0x321A, '3', '(파)'), - (0x321B, '3', '(하)'), - (0x321C, '3', '(주)'), - (0x321D, '3', '(오전)'), - (0x321E, '3', '(오후)'), - (0x321F, 'X'), - (0x3220, '3', '(一)'), - (0x3221, '3', '(二)'), - (0x3222, '3', '(三)'), - (0x3223, '3', '(四)'), - (0x3224, '3', '(五)'), - (0x3225, '3', '(六)'), - (0x3226, '3', '(七)'), - (0x3227, '3', '(八)'), - (0x3228, '3', '(九)'), - (0x3229, '3', '(十)'), - (0x322A, '3', '(月)'), - (0x322B, '3', '(火)'), - (0x322C, '3', '(水)'), - (0x322D, '3', '(木)'), - (0x322E, '3', '(金)'), - (0x322F, '3', '(土)'), - (0x3230, '3', '(日)'), - (0x3231, '3', '(株)'), - (0x3232, '3', '(有)'), - (0x3233, '3', '(社)'), - (0x3234, '3', '(名)'), - (0x3235, '3', '(特)'), - (0x3236, '3', '(財)'), - (0x3237, '3', '(祝)'), - (0x3238, '3', '(労)'), - (0x3239, '3', '(代)'), - (0x323A, '3', '(呼)'), - (0x323B, '3', '(学)'), - (0x323C, '3', '(監)'), - (0x323D, '3', '(企)'), - (0x323E, '3', '(資)'), - (0x323F, '3', '(協)'), - (0x3240, '3', '(祭)'), - (0x3241, '3', '(休)'), - (0x3242, '3', '(自)'), - ] - -def _seg_31(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0x3243, '3', '(至)'), - (0x3244, 'M', '問'), - (0x3245, 'M', '幼'), - (0x3246, 'M', '文'), - (0x3247, 'M', '箏'), - (0x3248, 'V'), - (0x3250, 'M', 'pte'), - (0x3251, 'M', '21'), - (0x3252, 'M', '22'), - (0x3253, 'M', '23'), - (0x3254, 'M', '24'), - (0x3255, 'M', '25'), - (0x3256, 'M', '26'), - (0x3257, 'M', '27'), - (0x3258, 'M', '28'), - (0x3259, 'M', '29'), - (0x325A, 'M', '30'), - (0x325B, 'M', '31'), - (0x325C, 'M', '32'), - (0x325D, 'M', '33'), - (0x325E, 'M', '34'), - (0x325F, 'M', '35'), - (0x3260, 'M', 'ᄀ'), - (0x3261, 'M', 'ᄂ'), - (0x3262, 'M', 'ᄃ'), - (0x3263, 'M', 'ᄅ'), - (0x3264, 'M', 'ᄆ'), - (0x3265, 'M', 'ᄇ'), - (0x3266, 'M', 'ᄉ'), - (0x3267, 'M', 'ᄋ'), - (0x3268, 'M', 'ᄌ'), - (0x3269, 'M', 'ᄎ'), - (0x326A, 'M', 'ᄏ'), - (0x326B, 'M', 'ᄐ'), - (0x326C, 'M', 'ᄑ'), - (0x326D, 'M', 'ᄒ'), - (0x326E, 'M', '가'), - (0x326F, 'M', '나'), - (0x3270, 'M', '다'), - (0x3271, 'M', '라'), - (0x3272, 'M', '마'), - (0x3273, 'M', '바'), - (0x3274, 'M', '사'), - (0x3275, 'M', '아'), - (0x3276, 'M', '자'), - (0x3277, 'M', '차'), - (0x3278, 'M', '카'), - (0x3279, 'M', '타'), - (0x327A, 'M', '파'), - (0x327B, 'M', '하'), - (0x327C, 'M', '참고'), - (0x327D, 'M', '주의'), - (0x327E, 'M', '우'), - (0x327F, 'V'), - (0x3280, 'M', '一'), - (0x3281, 'M', '二'), - (0x3282, 'M', '三'), - (0x3283, 'M', '四'), - (0x3284, 'M', '五'), - (0x3285, 'M', '六'), - (0x3286, 'M', '七'), - (0x3287, 'M', '八'), - (0x3288, 'M', '九'), - (0x3289, 'M', '十'), - (0x328A, 'M', '月'), - (0x328B, 'M', '火'), - (0x328C, 'M', '水'), - (0x328D, 'M', '木'), - (0x328E, 'M', '金'), - (0x328F, 'M', '土'), - (0x3290, 'M', '日'), - (0x3291, 'M', '株'), - (0x3292, 'M', '有'), - (0x3293, 'M', '社'), - (0x3294, 'M', '名'), - (0x3295, 'M', '特'), - (0x3296, 'M', '財'), - (0x3297, 'M', '祝'), - (0x3298, 'M', '労'), - (0x3299, 'M', '秘'), - (0x329A, 'M', '男'), - (0x329B, 'M', '女'), - (0x329C, 'M', '適'), - (0x329D, 'M', '優'), - (0x329E, 'M', '印'), - (0x329F, 'M', '注'), - (0x32A0, 'M', '項'), - (0x32A1, 'M', '休'), - (0x32A2, 'M', '写'), - (0x32A3, 'M', '正'), - (0x32A4, 'M', '上'), - (0x32A5, 'M', '中'), - (0x32A6, 'M', '下'), - (0x32A7, 'M', '左'), - (0x32A8, 'M', '右'), - (0x32A9, 'M', '医'), - (0x32AA, 'M', '宗'), - (0x32AB, 'M', '学'), - (0x32AC, 'M', '監'), - (0x32AD, 'M', '企'), - ] - -def _seg_32(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0x32AE, 'M', '資'), - (0x32AF, 'M', '協'), - (0x32B0, 'M', '夜'), - (0x32B1, 'M', '36'), - (0x32B2, 'M', '37'), - (0x32B3, 'M', '38'), - (0x32B4, 'M', '39'), - (0x32B5, 'M', '40'), - (0x32B6, 'M', '41'), - (0x32B7, 'M', '42'), - (0x32B8, 'M', '43'), - (0x32B9, 'M', '44'), - (0x32BA, 'M', '45'), - (0x32BB, 'M', '46'), - (0x32BC, 'M', '47'), - (0x32BD, 'M', '48'), - (0x32BE, 'M', '49'), - (0x32BF, 'M', '50'), - (0x32C0, 'M', '1月'), - (0x32C1, 'M', '2月'), - (0x32C2, 'M', '3月'), - (0x32C3, 'M', '4月'), - (0x32C4, 'M', '5月'), - (0x32C5, 'M', '6月'), - (0x32C6, 'M', '7月'), - (0x32C7, 'M', '8月'), - (0x32C8, 'M', '9月'), - (0x32C9, 'M', '10月'), - (0x32CA, 'M', '11月'), - (0x32CB, 'M', '12月'), - (0x32CC, 'M', 'hg'), - (0x32CD, 'M', 'erg'), - (0x32CE, 'M', 'ev'), - (0x32CF, 'M', 'ltd'), - (0x32D0, 'M', 'ア'), - (0x32D1, 'M', 'イ'), - (0x32D2, 'M', 'ウ'), - (0x32D3, 'M', 'エ'), - (0x32D4, 'M', 'オ'), - (0x32D5, 'M', 'カ'), - (0x32D6, 'M', 'キ'), - (0x32D7, 'M', 'ク'), - (0x32D8, 'M', 'ケ'), - (0x32D9, 'M', 'コ'), - (0x32DA, 'M', 'サ'), - (0x32DB, 'M', 'シ'), - (0x32DC, 'M', 'ス'), - (0x32DD, 'M', 'セ'), - (0x32DE, 'M', 'ソ'), - (0x32DF, 'M', 'タ'), - (0x32E0, 'M', 'チ'), - (0x32E1, 'M', 'ツ'), - (0x32E2, 'M', 'テ'), - (0x32E3, 'M', 'ト'), - (0x32E4, 'M', 'ナ'), - (0x32E5, 'M', 'ニ'), - (0x32E6, 'M', 'ヌ'), - (0x32E7, 'M', 'ネ'), - (0x32E8, 'M', 'ノ'), - (0x32E9, 'M', 'ハ'), - (0x32EA, 'M', 'ヒ'), - (0x32EB, 'M', 'フ'), - (0x32EC, 'M', 'ヘ'), - (0x32ED, 'M', 'ホ'), - (0x32EE, 'M', 'マ'), - (0x32EF, 'M', 'ミ'), - (0x32F0, 'M', 'ム'), - (0x32F1, 'M', 'メ'), - (0x32F2, 'M', 'モ'), - (0x32F3, 'M', 'ヤ'), - (0x32F4, 'M', 'ユ'), - (0x32F5, 'M', 'ヨ'), - (0x32F6, 'M', 'ラ'), - (0x32F7, 'M', 'リ'), - (0x32F8, 'M', 'ル'), - (0x32F9, 'M', 'レ'), - (0x32FA, 'M', 'ロ'), - (0x32FB, 'M', 'ワ'), - (0x32FC, 'M', 'ヰ'), - (0x32FD, 'M', 'ヱ'), - (0x32FE, 'M', 'ヲ'), - (0x32FF, 'M', '令和'), - (0x3300, 'M', 'アパート'), - (0x3301, 'M', 'アルファ'), - (0x3302, 'M', 'アンペア'), - (0x3303, 'M', 'アール'), - (0x3304, 'M', 'イニング'), - (0x3305, 'M', 'インチ'), - (0x3306, 'M', 'ウォン'), - (0x3307, 'M', 'エスクード'), - (0x3308, 'M', 'エーカー'), - (0x3309, 'M', 'オンス'), - (0x330A, 'M', 'オーム'), - (0x330B, 'M', 'カイリ'), - (0x330C, 'M', 'カラット'), - (0x330D, 'M', 'カロリー'), - (0x330E, 'M', 'ガロン'), - (0x330F, 'M', 'ガンマ'), - (0x3310, 'M', 'ギガ'), - (0x3311, 'M', 'ギニー'), - ] - -def _seg_33(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0x3312, 'M', 'キュリー'), - (0x3313, 'M', 'ギルダー'), - (0x3314, 'M', 'キロ'), - (0x3315, 'M', 'キログラム'), - (0x3316, 'M', 'キロメートル'), - (0x3317, 'M', 'キロワット'), - (0x3318, 'M', 'グラム'), - (0x3319, 'M', 'グラムトン'), - (0x331A, 'M', 'クルゼイロ'), - (0x331B, 'M', 'クローネ'), - (0x331C, 'M', 'ケース'), - (0x331D, 'M', 'コルナ'), - (0x331E, 'M', 'コーポ'), - (0x331F, 'M', 'サイクル'), - (0x3320, 'M', 'サンチーム'), - (0x3321, 'M', 'シリング'), - (0x3322, 'M', 'センチ'), - (0x3323, 'M', 'セント'), - (0x3324, 'M', 'ダース'), - (0x3325, 'M', 'デシ'), - (0x3326, 'M', 'ドル'), - (0x3327, 'M', 'トン'), - (0x3328, 'M', 'ナノ'), - (0x3329, 'M', 'ノット'), - (0x332A, 'M', 'ハイツ'), - (0x332B, 'M', 'パーセント'), - (0x332C, 'M', 'パーツ'), - (0x332D, 'M', 'バーレル'), - (0x332E, 'M', 'ピアストル'), - (0x332F, 'M', 'ピクル'), - (0x3330, 'M', 'ピコ'), - (0x3331, 'M', 'ビル'), - (0x3332, 'M', 'ファラッド'), - (0x3333, 'M', 'フィート'), - (0x3334, 'M', 'ブッシェル'), - (0x3335, 'M', 'フラン'), - (0x3336, 'M', 'ヘクタール'), - (0x3337, 'M', 'ペソ'), - (0x3338, 'M', 'ペニヒ'), - (0x3339, 'M', 'ヘルツ'), - (0x333A, 'M', 'ペンス'), - (0x333B, 'M', 'ページ'), - (0x333C, 'M', 'ベータ'), - (0x333D, 'M', 'ポイント'), - (0x333E, 'M', 'ボルト'), - (0x333F, 'M', 'ホン'), - (0x3340, 'M', 'ポンド'), - (0x3341, 'M', 'ホール'), - (0x3342, 'M', 'ホーン'), - (0x3343, 'M', 'マイクロ'), - (0x3344, 'M', 'マイル'), - (0x3345, 'M', 'マッハ'), - (0x3346, 'M', 'マルク'), - (0x3347, 'M', 'マンション'), - (0x3348, 'M', 'ミクロン'), - (0x3349, 'M', 'ミリ'), - (0x334A, 'M', 'ミリバール'), - (0x334B, 'M', 'メガ'), - (0x334C, 'M', 'メガトン'), - (0x334D, 'M', 'メートル'), - (0x334E, 'M', 'ヤード'), - (0x334F, 'M', 'ヤール'), - (0x3350, 'M', 'ユアン'), - (0x3351, 'M', 'リットル'), - (0x3352, 'M', 'リラ'), - (0x3353, 'M', 'ルピー'), - (0x3354, 'M', 'ルーブル'), - (0x3355, 'M', 'レム'), - (0x3356, 'M', 'レントゲン'), - (0x3357, 'M', 'ワット'), - (0x3358, 'M', '0点'), - (0x3359, 'M', '1点'), - (0x335A, 'M', '2点'), - (0x335B, 'M', '3点'), - (0x335C, 'M', '4点'), - (0x335D, 'M', '5点'), - (0x335E, 'M', '6点'), - (0x335F, 'M', '7点'), - (0x3360, 'M', '8点'), - (0x3361, 'M', '9点'), - (0x3362, 'M', '10点'), - (0x3363, 'M', '11点'), - (0x3364, 'M', '12点'), - (0x3365, 'M', '13点'), - (0x3366, 'M', '14点'), - (0x3367, 'M', '15点'), - (0x3368, 'M', '16点'), - (0x3369, 'M', '17点'), - (0x336A, 'M', '18点'), - (0x336B, 'M', '19点'), - (0x336C, 'M', '20点'), - (0x336D, 'M', '21点'), - (0x336E, 'M', '22点'), - (0x336F, 'M', '23点'), - (0x3370, 'M', '24点'), - (0x3371, 'M', 'hpa'), - (0x3372, 'M', 'da'), - (0x3373, 'M', 'au'), - (0x3374, 'M', 'bar'), - (0x3375, 'M', 'ov'), - ] - -def _seg_34(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0x3376, 'M', 'pc'), - (0x3377, 'M', 'dm'), - (0x3378, 'M', 'dm2'), - (0x3379, 'M', 'dm3'), - (0x337A, 'M', 'iu'), - (0x337B, 'M', '平成'), - (0x337C, 'M', '昭和'), - (0x337D, 'M', '大正'), - (0x337E, 'M', '明治'), - (0x337F, 'M', '株式会社'), - (0x3380, 'M', 'pa'), - (0x3381, 'M', 'na'), - (0x3382, 'M', 'μa'), - (0x3383, 'M', 'ma'), - (0x3384, 'M', 'ka'), - (0x3385, 'M', 'kb'), - (0x3386, 'M', 'mb'), - (0x3387, 'M', 'gb'), - (0x3388, 'M', 'cal'), - (0x3389, 'M', 'kcal'), - (0x338A, 'M', 'pf'), - (0x338B, 'M', 'nf'), - (0x338C, 'M', 'μf'), - (0x338D, 'M', 'μg'), - (0x338E, 'M', 'mg'), - (0x338F, 'M', 'kg'), - (0x3390, 'M', 'hz'), - (0x3391, 'M', 'khz'), - (0x3392, 'M', 'mhz'), - (0x3393, 'M', 'ghz'), - (0x3394, 'M', 'thz'), - (0x3395, 'M', 'μl'), - (0x3396, 'M', 'ml'), - (0x3397, 'M', 'dl'), - (0x3398, 'M', 'kl'), - (0x3399, 'M', 'fm'), - (0x339A, 'M', 'nm'), - (0x339B, 'M', 'μm'), - (0x339C, 'M', 'mm'), - (0x339D, 'M', 'cm'), - (0x339E, 'M', 'km'), - (0x339F, 'M', 'mm2'), - (0x33A0, 'M', 'cm2'), - (0x33A1, 'M', 'm2'), - (0x33A2, 'M', 'km2'), - (0x33A3, 'M', 'mm3'), - (0x33A4, 'M', 'cm3'), - (0x33A5, 'M', 'm3'), - (0x33A6, 'M', 'km3'), - (0x33A7, 'M', 'm∕s'), - (0x33A8, 'M', 'm∕s2'), - (0x33A9, 'M', 'pa'), - (0x33AA, 'M', 'kpa'), - (0x33AB, 'M', 'mpa'), - (0x33AC, 'M', 'gpa'), - (0x33AD, 'M', 'rad'), - (0x33AE, 'M', 'rad∕s'), - (0x33AF, 'M', 'rad∕s2'), - (0x33B0, 'M', 'ps'), - (0x33B1, 'M', 'ns'), - (0x33B2, 'M', 'μs'), - (0x33B3, 'M', 'ms'), - (0x33B4, 'M', 'pv'), - (0x33B5, 'M', 'nv'), - (0x33B6, 'M', 'μv'), - (0x33B7, 'M', 'mv'), - (0x33B8, 'M', 'kv'), - (0x33B9, 'M', 'mv'), - (0x33BA, 'M', 'pw'), - (0x33BB, 'M', 'nw'), - (0x33BC, 'M', 'μw'), - (0x33BD, 'M', 'mw'), - (0x33BE, 'M', 'kw'), - (0x33BF, 'M', 'mw'), - (0x33C0, 'M', 'kω'), - (0x33C1, 'M', 'mω'), - (0x33C2, 'X'), - (0x33C3, 'M', 'bq'), - (0x33C4, 'M', 'cc'), - (0x33C5, 'M', 'cd'), - (0x33C6, 'M', 'c∕kg'), - (0x33C7, 'X'), - (0x33C8, 'M', 'db'), - (0x33C9, 'M', 'gy'), - (0x33CA, 'M', 'ha'), - (0x33CB, 'M', 'hp'), - (0x33CC, 'M', 'in'), - (0x33CD, 'M', 'kk'), - (0x33CE, 'M', 'km'), - (0x33CF, 'M', 'kt'), - (0x33D0, 'M', 'lm'), - (0x33D1, 'M', 'ln'), - (0x33D2, 'M', 'log'), - (0x33D3, 'M', 'lx'), - (0x33D4, 'M', 'mb'), - (0x33D5, 'M', 'mil'), - (0x33D6, 'M', 'mol'), - (0x33D7, 'M', 'ph'), - (0x33D8, 'X'), - (0x33D9, 'M', 'ppm'), - ] - -def _seg_35(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0x33DA, 'M', 'pr'), - (0x33DB, 'M', 'sr'), - (0x33DC, 'M', 'sv'), - (0x33DD, 'M', 'wb'), - (0x33DE, 'M', 'v∕m'), - (0x33DF, 'M', 'a∕m'), - (0x33E0, 'M', '1日'), - (0x33E1, 'M', '2日'), - (0x33E2, 'M', '3日'), - (0x33E3, 'M', '4日'), - (0x33E4, 'M', '5日'), - (0x33E5, 'M', '6日'), - (0x33E6, 'M', '7日'), - (0x33E7, 'M', '8日'), - (0x33E8, 'M', '9日'), - (0x33E9, 'M', '10日'), - (0x33EA, 'M', '11日'), - (0x33EB, 'M', '12日'), - (0x33EC, 'M', '13日'), - (0x33ED, 'M', '14日'), - (0x33EE, 'M', '15日'), - (0x33EF, 'M', '16日'), - (0x33F0, 'M', '17日'), - (0x33F1, 'M', '18日'), - (0x33F2, 'M', '19日'), - (0x33F3, 'M', '20日'), - (0x33F4, 'M', '21日'), - (0x33F5, 'M', '22日'), - (0x33F6, 'M', '23日'), - (0x33F7, 'M', '24日'), - (0x33F8, 'M', '25日'), - (0x33F9, 'M', '26日'), - (0x33FA, 'M', '27日'), - (0x33FB, 'M', '28日'), - (0x33FC, 'M', '29日'), - (0x33FD, 'M', '30日'), - (0x33FE, 'M', '31日'), - (0x33FF, 'M', 'gal'), - (0x3400, 'V'), - (0x9FFD, 'X'), - (0xA000, 'V'), - (0xA48D, 'X'), - (0xA490, 'V'), - (0xA4C7, 'X'), - (0xA4D0, 'V'), - (0xA62C, 'X'), - (0xA640, 'M', 'ꙁ'), - (0xA641, 'V'), - (0xA642, 'M', 'ꙃ'), - (0xA643, 'V'), - (0xA644, 'M', 'ꙅ'), - (0xA645, 'V'), - (0xA646, 'M', 'ꙇ'), - (0xA647, 'V'), - (0xA648, 'M', 'ꙉ'), - (0xA649, 'V'), - (0xA64A, 'M', 'ꙋ'), - (0xA64B, 'V'), - (0xA64C, 'M', 'ꙍ'), - (0xA64D, 'V'), - (0xA64E, 'M', 'ꙏ'), - (0xA64F, 'V'), - (0xA650, 'M', 'ꙑ'), - (0xA651, 'V'), - (0xA652, 'M', 'ꙓ'), - (0xA653, 'V'), - (0xA654, 'M', 'ꙕ'), - (0xA655, 'V'), - (0xA656, 'M', 'ꙗ'), - (0xA657, 'V'), - (0xA658, 'M', 'ꙙ'), - (0xA659, 'V'), - (0xA65A, 'M', 'ꙛ'), - (0xA65B, 'V'), - (0xA65C, 'M', 'ꙝ'), - (0xA65D, 'V'), - (0xA65E, 'M', 'ꙟ'), - (0xA65F, 'V'), - (0xA660, 'M', 'ꙡ'), - (0xA661, 'V'), - (0xA662, 'M', 'ꙣ'), - (0xA663, 'V'), - (0xA664, 'M', 'ꙥ'), - (0xA665, 'V'), - (0xA666, 'M', 'ꙧ'), - (0xA667, 'V'), - (0xA668, 'M', 'ꙩ'), - (0xA669, 'V'), - (0xA66A, 'M', 'ꙫ'), - (0xA66B, 'V'), - (0xA66C, 'M', 'ꙭ'), - (0xA66D, 'V'), - (0xA680, 'M', 'ꚁ'), - (0xA681, 'V'), - (0xA682, 'M', 'ꚃ'), - (0xA683, 'V'), - (0xA684, 'M', 'ꚅ'), - (0xA685, 'V'), - (0xA686, 'M', 'ꚇ'), - (0xA687, 'V'), - ] - -def _seg_36(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0xA688, 'M', 'ꚉ'), - (0xA689, 'V'), - (0xA68A, 'M', 'ꚋ'), - (0xA68B, 'V'), - (0xA68C, 'M', 'ꚍ'), - (0xA68D, 'V'), - (0xA68E, 'M', 'ꚏ'), - (0xA68F, 'V'), - (0xA690, 'M', 'ꚑ'), - (0xA691, 'V'), - (0xA692, 'M', 'ꚓ'), - (0xA693, 'V'), - (0xA694, 'M', 'ꚕ'), - (0xA695, 'V'), - (0xA696, 'M', 'ꚗ'), - (0xA697, 'V'), - (0xA698, 'M', 'ꚙ'), - (0xA699, 'V'), - (0xA69A, 'M', 'ꚛ'), - (0xA69B, 'V'), - (0xA69C, 'M', 'ъ'), - (0xA69D, 'M', 'ь'), - (0xA69E, 'V'), - (0xA6F8, 'X'), - (0xA700, 'V'), - (0xA722, 'M', 'ꜣ'), - (0xA723, 'V'), - (0xA724, 'M', 'ꜥ'), - (0xA725, 'V'), - (0xA726, 'M', 'ꜧ'), - (0xA727, 'V'), - (0xA728, 'M', 'ꜩ'), - (0xA729, 'V'), - (0xA72A, 'M', 'ꜫ'), - (0xA72B, 'V'), - (0xA72C, 'M', 'ꜭ'), - (0xA72D, 'V'), - (0xA72E, 'M', 'ꜯ'), - (0xA72F, 'V'), - (0xA732, 'M', 'ꜳ'), - (0xA733, 'V'), - (0xA734, 'M', 'ꜵ'), - (0xA735, 'V'), - (0xA736, 'M', 'ꜷ'), - (0xA737, 'V'), - (0xA738, 'M', 'ꜹ'), - (0xA739, 'V'), - (0xA73A, 'M', 'ꜻ'), - (0xA73B, 'V'), - (0xA73C, 'M', 'ꜽ'), - (0xA73D, 'V'), - (0xA73E, 'M', 'ꜿ'), - (0xA73F, 'V'), - (0xA740, 'M', 'ꝁ'), - (0xA741, 'V'), - (0xA742, 'M', 'ꝃ'), - (0xA743, 'V'), - (0xA744, 'M', 'ꝅ'), - (0xA745, 'V'), - (0xA746, 'M', 'ꝇ'), - (0xA747, 'V'), - (0xA748, 'M', 'ꝉ'), - (0xA749, 'V'), - (0xA74A, 'M', 'ꝋ'), - (0xA74B, 'V'), - (0xA74C, 'M', 'ꝍ'), - (0xA74D, 'V'), - (0xA74E, 'M', 'ꝏ'), - (0xA74F, 'V'), - (0xA750, 'M', 'ꝑ'), - (0xA751, 'V'), - (0xA752, 'M', 'ꝓ'), - (0xA753, 'V'), - (0xA754, 'M', 'ꝕ'), - (0xA755, 'V'), - (0xA756, 'M', 'ꝗ'), - (0xA757, 'V'), - (0xA758, 'M', 'ꝙ'), - (0xA759, 'V'), - (0xA75A, 'M', 'ꝛ'), - (0xA75B, 'V'), - (0xA75C, 'M', 'ꝝ'), - (0xA75D, 'V'), - (0xA75E, 'M', 'ꝟ'), - (0xA75F, 'V'), - (0xA760, 'M', 'ꝡ'), - (0xA761, 'V'), - (0xA762, 'M', 'ꝣ'), - (0xA763, 'V'), - (0xA764, 'M', 'ꝥ'), - (0xA765, 'V'), - (0xA766, 'M', 'ꝧ'), - (0xA767, 'V'), - (0xA768, 'M', 'ꝩ'), - (0xA769, 'V'), - (0xA76A, 'M', 'ꝫ'), - (0xA76B, 'V'), - (0xA76C, 'M', 'ꝭ'), - (0xA76D, 'V'), - (0xA76E, 'M', 'ꝯ'), - ] - -def _seg_37(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0xA76F, 'V'), - (0xA770, 'M', 'ꝯ'), - (0xA771, 'V'), - (0xA779, 'M', 'ꝺ'), - (0xA77A, 'V'), - (0xA77B, 'M', 'ꝼ'), - (0xA77C, 'V'), - (0xA77D, 'M', 'ᵹ'), - (0xA77E, 'M', 'ꝿ'), - (0xA77F, 'V'), - (0xA780, 'M', 'ꞁ'), - (0xA781, 'V'), - (0xA782, 'M', 'ꞃ'), - (0xA783, 'V'), - (0xA784, 'M', 'ꞅ'), - (0xA785, 'V'), - (0xA786, 'M', 'ꞇ'), - (0xA787, 'V'), - (0xA78B, 'M', 'ꞌ'), - (0xA78C, 'V'), - (0xA78D, 'M', 'ɥ'), - (0xA78E, 'V'), - (0xA790, 'M', 'ꞑ'), - (0xA791, 'V'), - (0xA792, 'M', 'ꞓ'), - (0xA793, 'V'), - (0xA796, 'M', 'ꞗ'), - (0xA797, 'V'), - (0xA798, 'M', 'ꞙ'), - (0xA799, 'V'), - (0xA79A, 'M', 'ꞛ'), - (0xA79B, 'V'), - (0xA79C, 'M', 'ꞝ'), - (0xA79D, 'V'), - (0xA79E, 'M', 'ꞟ'), - (0xA79F, 'V'), - (0xA7A0, 'M', 'ꞡ'), - (0xA7A1, 'V'), - (0xA7A2, 'M', 'ꞣ'), - (0xA7A3, 'V'), - (0xA7A4, 'M', 'ꞥ'), - (0xA7A5, 'V'), - (0xA7A6, 'M', 'ꞧ'), - (0xA7A7, 'V'), - (0xA7A8, 'M', 'ꞩ'), - (0xA7A9, 'V'), - (0xA7AA, 'M', 'ɦ'), - (0xA7AB, 'M', 'ɜ'), - (0xA7AC, 'M', 'ɡ'), - (0xA7AD, 'M', 'ɬ'), - (0xA7AE, 'M', 'ɪ'), - (0xA7AF, 'V'), - (0xA7B0, 'M', 'ʞ'), - (0xA7B1, 'M', 'ʇ'), - (0xA7B2, 'M', 'ʝ'), - (0xA7B3, 'M', 'ꭓ'), - (0xA7B4, 'M', 'ꞵ'), - (0xA7B5, 'V'), - (0xA7B6, 'M', 'ꞷ'), - (0xA7B7, 'V'), - (0xA7B8, 'M', 'ꞹ'), - (0xA7B9, 'V'), - (0xA7BA, 'M', 'ꞻ'), - (0xA7BB, 'V'), - (0xA7BC, 'M', 'ꞽ'), - (0xA7BD, 'V'), - (0xA7BE, 'M', 'ꞿ'), - (0xA7BF, 'V'), - (0xA7C0, 'X'), - (0xA7C2, 'M', 'ꟃ'), - (0xA7C3, 'V'), - (0xA7C4, 'M', 'ꞔ'), - (0xA7C5, 'M', 'ʂ'), - (0xA7C6, 'M', 'ᶎ'), - (0xA7C7, 'M', 'ꟈ'), - (0xA7C8, 'V'), - (0xA7C9, 'M', 'ꟊ'), - (0xA7CA, 'V'), - (0xA7CB, 'X'), - (0xA7F5, 'M', 'ꟶ'), - (0xA7F6, 'V'), - (0xA7F8, 'M', 'ħ'), - (0xA7F9, 'M', 'œ'), - (0xA7FA, 'V'), - (0xA82D, 'X'), - (0xA830, 'V'), - (0xA83A, 'X'), - (0xA840, 'V'), - (0xA878, 'X'), - (0xA880, 'V'), - (0xA8C6, 'X'), - (0xA8CE, 'V'), - (0xA8DA, 'X'), - (0xA8E0, 'V'), - (0xA954, 'X'), - (0xA95F, 'V'), - (0xA97D, 'X'), - (0xA980, 'V'), - (0xA9CE, 'X'), - (0xA9CF, 'V'), - ] - -def _seg_38(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0xA9DA, 'X'), - (0xA9DE, 'V'), - (0xA9FF, 'X'), - (0xAA00, 'V'), - (0xAA37, 'X'), - (0xAA40, 'V'), - (0xAA4E, 'X'), - (0xAA50, 'V'), - (0xAA5A, 'X'), - (0xAA5C, 'V'), - (0xAAC3, 'X'), - (0xAADB, 'V'), - (0xAAF7, 'X'), - (0xAB01, 'V'), - (0xAB07, 'X'), - (0xAB09, 'V'), - (0xAB0F, 'X'), - (0xAB11, 'V'), - (0xAB17, 'X'), - (0xAB20, 'V'), - (0xAB27, 'X'), - (0xAB28, 'V'), - (0xAB2F, 'X'), - (0xAB30, 'V'), - (0xAB5C, 'M', 'ꜧ'), - (0xAB5D, 'M', 'ꬷ'), - (0xAB5E, 'M', 'ɫ'), - (0xAB5F, 'M', 'ꭒ'), - (0xAB60, 'V'), - (0xAB69, 'M', 'ʍ'), - (0xAB6A, 'V'), - (0xAB6C, 'X'), - (0xAB70, 'M', 'Ꭰ'), - (0xAB71, 'M', 'Ꭱ'), - (0xAB72, 'M', 'Ꭲ'), - (0xAB73, 'M', 'Ꭳ'), - (0xAB74, 'M', 'Ꭴ'), - (0xAB75, 'M', 'Ꭵ'), - (0xAB76, 'M', 'Ꭶ'), - (0xAB77, 'M', 'Ꭷ'), - (0xAB78, 'M', 'Ꭸ'), - (0xAB79, 'M', 'Ꭹ'), - (0xAB7A, 'M', 'Ꭺ'), - (0xAB7B, 'M', 'Ꭻ'), - (0xAB7C, 'M', 'Ꭼ'), - (0xAB7D, 'M', 'Ꭽ'), - (0xAB7E, 'M', 'Ꭾ'), - (0xAB7F, 'M', 'Ꭿ'), - (0xAB80, 'M', 'Ꮀ'), - (0xAB81, 'M', 'Ꮁ'), - (0xAB82, 'M', 'Ꮂ'), - (0xAB83, 'M', 'Ꮃ'), - (0xAB84, 'M', 'Ꮄ'), - (0xAB85, 'M', 'Ꮅ'), - (0xAB86, 'M', 'Ꮆ'), - (0xAB87, 'M', 'Ꮇ'), - (0xAB88, 'M', 'Ꮈ'), - (0xAB89, 'M', 'Ꮉ'), - (0xAB8A, 'M', 'Ꮊ'), - (0xAB8B, 'M', 'Ꮋ'), - (0xAB8C, 'M', 'Ꮌ'), - (0xAB8D, 'M', 'Ꮍ'), - (0xAB8E, 'M', 'Ꮎ'), - (0xAB8F, 'M', 'Ꮏ'), - (0xAB90, 'M', 'Ꮐ'), - (0xAB91, 'M', 'Ꮑ'), - (0xAB92, 'M', 'Ꮒ'), - (0xAB93, 'M', 'Ꮓ'), - (0xAB94, 'M', 'Ꮔ'), - (0xAB95, 'M', 'Ꮕ'), - (0xAB96, 'M', 'Ꮖ'), - (0xAB97, 'M', 'Ꮗ'), - (0xAB98, 'M', 'Ꮘ'), - (0xAB99, 'M', 'Ꮙ'), - (0xAB9A, 'M', 'Ꮚ'), - (0xAB9B, 'M', 'Ꮛ'), - (0xAB9C, 'M', 'Ꮜ'), - (0xAB9D, 'M', 'Ꮝ'), - (0xAB9E, 'M', 'Ꮞ'), - (0xAB9F, 'M', 'Ꮟ'), - (0xABA0, 'M', 'Ꮠ'), - (0xABA1, 'M', 'Ꮡ'), - (0xABA2, 'M', 'Ꮢ'), - (0xABA3, 'M', 'Ꮣ'), - (0xABA4, 'M', 'Ꮤ'), - (0xABA5, 'M', 'Ꮥ'), - (0xABA6, 'M', 'Ꮦ'), - (0xABA7, 'M', 'Ꮧ'), - (0xABA8, 'M', 'Ꮨ'), - (0xABA9, 'M', 'Ꮩ'), - (0xABAA, 'M', 'Ꮪ'), - (0xABAB, 'M', 'Ꮫ'), - (0xABAC, 'M', 'Ꮬ'), - (0xABAD, 'M', 'Ꮭ'), - (0xABAE, 'M', 'Ꮮ'), - (0xABAF, 'M', 'Ꮯ'), - (0xABB0, 'M', 'Ꮰ'), - (0xABB1, 'M', 'Ꮱ'), - (0xABB2, 'M', 'Ꮲ'), - (0xABB3, 'M', 'Ꮳ'), - ] - -def _seg_39(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0xABB4, 'M', 'Ꮴ'), - (0xABB5, 'M', 'Ꮵ'), - (0xABB6, 'M', 'Ꮶ'), - (0xABB7, 'M', 'Ꮷ'), - (0xABB8, 'M', 'Ꮸ'), - (0xABB9, 'M', 'Ꮹ'), - (0xABBA, 'M', 'Ꮺ'), - (0xABBB, 'M', 'Ꮻ'), - (0xABBC, 'M', 'Ꮼ'), - (0xABBD, 'M', 'Ꮽ'), - (0xABBE, 'M', 'Ꮾ'), - (0xABBF, 'M', 'Ꮿ'), - (0xABC0, 'V'), - (0xABEE, 'X'), - (0xABF0, 'V'), - (0xABFA, 'X'), - (0xAC00, 'V'), - (0xD7A4, 'X'), - (0xD7B0, 'V'), - (0xD7C7, 'X'), - (0xD7CB, 'V'), - (0xD7FC, 'X'), - (0xF900, 'M', '豈'), - (0xF901, 'M', '更'), - (0xF902, 'M', '車'), - (0xF903, 'M', '賈'), - (0xF904, 'M', '滑'), - (0xF905, 'M', '串'), - (0xF906, 'M', '句'), - (0xF907, 'M', '龜'), - (0xF909, 'M', '契'), - (0xF90A, 'M', '金'), - (0xF90B, 'M', '喇'), - (0xF90C, 'M', '奈'), - (0xF90D, 'M', '懶'), - (0xF90E, 'M', '癩'), - (0xF90F, 'M', '羅'), - (0xF910, 'M', '蘿'), - (0xF911, 'M', '螺'), - (0xF912, 'M', '裸'), - (0xF913, 'M', '邏'), - (0xF914, 'M', '樂'), - (0xF915, 'M', '洛'), - (0xF916, 'M', '烙'), - (0xF917, 'M', '珞'), - (0xF918, 'M', '落'), - (0xF919, 'M', '酪'), - (0xF91A, 'M', '駱'), - (0xF91B, 'M', '亂'), - (0xF91C, 'M', '卵'), - (0xF91D, 'M', '欄'), - (0xF91E, 'M', '爛'), - (0xF91F, 'M', '蘭'), - (0xF920, 'M', '鸞'), - (0xF921, 'M', '嵐'), - (0xF922, 'M', '濫'), - (0xF923, 'M', '藍'), - (0xF924, 'M', '襤'), - (0xF925, 'M', '拉'), - (0xF926, 'M', '臘'), - (0xF927, 'M', '蠟'), - (0xF928, 'M', '廊'), - (0xF929, 'M', '朗'), - (0xF92A, 'M', '浪'), - (0xF92B, 'M', '狼'), - (0xF92C, 'M', '郎'), - (0xF92D, 'M', '來'), - (0xF92E, 'M', '冷'), - (0xF92F, 'M', '勞'), - (0xF930, 'M', '擄'), - (0xF931, 'M', '櫓'), - (0xF932, 'M', '爐'), - (0xF933, 'M', '盧'), - (0xF934, 'M', '老'), - (0xF935, 'M', '蘆'), - (0xF936, 'M', '虜'), - (0xF937, 'M', '路'), - (0xF938, 'M', '露'), - (0xF939, 'M', '魯'), - (0xF93A, 'M', '鷺'), - (0xF93B, 'M', '碌'), - (0xF93C, 'M', '祿'), - (0xF93D, 'M', '綠'), - (0xF93E, 'M', '菉'), - (0xF93F, 'M', '錄'), - (0xF940, 'M', '鹿'), - (0xF941, 'M', '論'), - (0xF942, 'M', '壟'), - (0xF943, 'M', '弄'), - (0xF944, 'M', '籠'), - (0xF945, 'M', '聾'), - (0xF946, 'M', '牢'), - (0xF947, 'M', '磊'), - (0xF948, 'M', '賂'), - (0xF949, 'M', '雷'), - (0xF94A, 'M', '壘'), - (0xF94B, 'M', '屢'), - (0xF94C, 'M', '樓'), - (0xF94D, 'M', '淚'), - (0xF94E, 'M', '漏'), - ] - -def _seg_40(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0xF94F, 'M', '累'), - (0xF950, 'M', '縷'), - (0xF951, 'M', '陋'), - (0xF952, 'M', '勒'), - (0xF953, 'M', '肋'), - (0xF954, 'M', '凜'), - (0xF955, 'M', '凌'), - (0xF956, 'M', '稜'), - (0xF957, 'M', '綾'), - (0xF958, 'M', '菱'), - (0xF959, 'M', '陵'), - (0xF95A, 'M', '讀'), - (0xF95B, 'M', '拏'), - (0xF95C, 'M', '樂'), - (0xF95D, 'M', '諾'), - (0xF95E, 'M', '丹'), - (0xF95F, 'M', '寧'), - (0xF960, 'M', '怒'), - (0xF961, 'M', '率'), - (0xF962, 'M', '異'), - (0xF963, 'M', '北'), - (0xF964, 'M', '磻'), - (0xF965, 'M', '便'), - (0xF966, 'M', '復'), - (0xF967, 'M', '不'), - (0xF968, 'M', '泌'), - (0xF969, 'M', '數'), - (0xF96A, 'M', '索'), - (0xF96B, 'M', '參'), - (0xF96C, 'M', '塞'), - (0xF96D, 'M', '省'), - (0xF96E, 'M', '葉'), - (0xF96F, 'M', '說'), - (0xF970, 'M', '殺'), - (0xF971, 'M', '辰'), - (0xF972, 'M', '沈'), - (0xF973, 'M', '拾'), - (0xF974, 'M', '若'), - (0xF975, 'M', '掠'), - (0xF976, 'M', '略'), - (0xF977, 'M', '亮'), - (0xF978, 'M', '兩'), - (0xF979, 'M', '凉'), - (0xF97A, 'M', '梁'), - (0xF97B, 'M', '糧'), - (0xF97C, 'M', '良'), - (0xF97D, 'M', '諒'), - (0xF97E, 'M', '量'), - (0xF97F, 'M', '勵'), - (0xF980, 'M', '呂'), - (0xF981, 'M', '女'), - (0xF982, 'M', '廬'), - (0xF983, 'M', '旅'), - (0xF984, 'M', '濾'), - (0xF985, 'M', '礪'), - (0xF986, 'M', '閭'), - (0xF987, 'M', '驪'), - (0xF988, 'M', '麗'), - (0xF989, 'M', '黎'), - (0xF98A, 'M', '力'), - (0xF98B, 'M', '曆'), - (0xF98C, 'M', '歷'), - (0xF98D, 'M', '轢'), - (0xF98E, 'M', '年'), - (0xF98F, 'M', '憐'), - (0xF990, 'M', '戀'), - (0xF991, 'M', '撚'), - (0xF992, 'M', '漣'), - (0xF993, 'M', '煉'), - (0xF994, 'M', '璉'), - (0xF995, 'M', '秊'), - (0xF996, 'M', '練'), - (0xF997, 'M', '聯'), - (0xF998, 'M', '輦'), - (0xF999, 'M', '蓮'), - (0xF99A, 'M', '連'), - (0xF99B, 'M', '鍊'), - (0xF99C, 'M', '列'), - (0xF99D, 'M', '劣'), - (0xF99E, 'M', '咽'), - (0xF99F, 'M', '烈'), - (0xF9A0, 'M', '裂'), - (0xF9A1, 'M', '說'), - (0xF9A2, 'M', '廉'), - (0xF9A3, 'M', '念'), - (0xF9A4, 'M', '捻'), - (0xF9A5, 'M', '殮'), - (0xF9A6, 'M', '簾'), - (0xF9A7, 'M', '獵'), - (0xF9A8, 'M', '令'), - (0xF9A9, 'M', '囹'), - (0xF9AA, 'M', '寧'), - (0xF9AB, 'M', '嶺'), - (0xF9AC, 'M', '怜'), - (0xF9AD, 'M', '玲'), - (0xF9AE, 'M', '瑩'), - (0xF9AF, 'M', '羚'), - (0xF9B0, 'M', '聆'), - (0xF9B1, 'M', '鈴'), - (0xF9B2, 'M', '零'), - ] - -def _seg_41(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0xF9B3, 'M', '靈'), - (0xF9B4, 'M', '領'), - (0xF9B5, 'M', '例'), - (0xF9B6, 'M', '禮'), - (0xF9B7, 'M', '醴'), - (0xF9B8, 'M', '隸'), - (0xF9B9, 'M', '惡'), - (0xF9BA, 'M', '了'), - (0xF9BB, 'M', '僚'), - (0xF9BC, 'M', '寮'), - (0xF9BD, 'M', '尿'), - (0xF9BE, 'M', '料'), - (0xF9BF, 'M', '樂'), - (0xF9C0, 'M', '燎'), - (0xF9C1, 'M', '療'), - (0xF9C2, 'M', '蓼'), - (0xF9C3, 'M', '遼'), - (0xF9C4, 'M', '龍'), - (0xF9C5, 'M', '暈'), - (0xF9C6, 'M', '阮'), - (0xF9C7, 'M', '劉'), - (0xF9C8, 'M', '杻'), - (0xF9C9, 'M', '柳'), - (0xF9CA, 'M', '流'), - (0xF9CB, 'M', '溜'), - (0xF9CC, 'M', '琉'), - (0xF9CD, 'M', '留'), - (0xF9CE, 'M', '硫'), - (0xF9CF, 'M', '紐'), - (0xF9D0, 'M', '類'), - (0xF9D1, 'M', '六'), - (0xF9D2, 'M', '戮'), - (0xF9D3, 'M', '陸'), - (0xF9D4, 'M', '倫'), - (0xF9D5, 'M', '崙'), - (0xF9D6, 'M', '淪'), - (0xF9D7, 'M', '輪'), - (0xF9D8, 'M', '律'), - (0xF9D9, 'M', '慄'), - (0xF9DA, 'M', '栗'), - (0xF9DB, 'M', '率'), - (0xF9DC, 'M', '隆'), - (0xF9DD, 'M', '利'), - (0xF9DE, 'M', '吏'), - (0xF9DF, 'M', '履'), - (0xF9E0, 'M', '易'), - (0xF9E1, 'M', '李'), - (0xF9E2, 'M', '梨'), - (0xF9E3, 'M', '泥'), - (0xF9E4, 'M', '理'), - (0xF9E5, 'M', '痢'), - (0xF9E6, 'M', '罹'), - (0xF9E7, 'M', '裏'), - (0xF9E8, 'M', '裡'), - (0xF9E9, 'M', '里'), - (0xF9EA, 'M', '離'), - (0xF9EB, 'M', '匿'), - (0xF9EC, 'M', '溺'), - (0xF9ED, 'M', '吝'), - (0xF9EE, 'M', '燐'), - (0xF9EF, 'M', '璘'), - (0xF9F0, 'M', '藺'), - (0xF9F1, 'M', '隣'), - (0xF9F2, 'M', '鱗'), - (0xF9F3, 'M', '麟'), - (0xF9F4, 'M', '林'), - (0xF9F5, 'M', '淋'), - (0xF9F6, 'M', '臨'), - (0xF9F7, 'M', '立'), - (0xF9F8, 'M', '笠'), - (0xF9F9, 'M', '粒'), - (0xF9FA, 'M', '狀'), - (0xF9FB, 'M', '炙'), - (0xF9FC, 'M', '識'), - (0xF9FD, 'M', '什'), - (0xF9FE, 'M', '茶'), - (0xF9FF, 'M', '刺'), - (0xFA00, 'M', '切'), - (0xFA01, 'M', '度'), - (0xFA02, 'M', '拓'), - (0xFA03, 'M', '糖'), - (0xFA04, 'M', '宅'), - (0xFA05, 'M', '洞'), - (0xFA06, 'M', '暴'), - (0xFA07, 'M', '輻'), - (0xFA08, 'M', '行'), - (0xFA09, 'M', '降'), - (0xFA0A, 'M', '見'), - (0xFA0B, 'M', '廓'), - (0xFA0C, 'M', '兀'), - (0xFA0D, 'M', '嗀'), - (0xFA0E, 'V'), - (0xFA10, 'M', '塚'), - (0xFA11, 'V'), - (0xFA12, 'M', '晴'), - (0xFA13, 'V'), - (0xFA15, 'M', '凞'), - (0xFA16, 'M', '猪'), - (0xFA17, 'M', '益'), - (0xFA18, 'M', '礼'), - ] - -def _seg_42(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0xFA19, 'M', '神'), - (0xFA1A, 'M', '祥'), - (0xFA1B, 'M', '福'), - (0xFA1C, 'M', '靖'), - (0xFA1D, 'M', '精'), - (0xFA1E, 'M', '羽'), - (0xFA1F, 'V'), - (0xFA20, 'M', '蘒'), - (0xFA21, 'V'), - (0xFA22, 'M', '諸'), - (0xFA23, 'V'), - (0xFA25, 'M', '逸'), - (0xFA26, 'M', '都'), - (0xFA27, 'V'), - (0xFA2A, 'M', '飯'), - (0xFA2B, 'M', '飼'), - (0xFA2C, 'M', '館'), - (0xFA2D, 'M', '鶴'), - (0xFA2E, 'M', '郞'), - (0xFA2F, 'M', '隷'), - (0xFA30, 'M', '侮'), - (0xFA31, 'M', '僧'), - (0xFA32, 'M', '免'), - (0xFA33, 'M', '勉'), - (0xFA34, 'M', '勤'), - (0xFA35, 'M', '卑'), - (0xFA36, 'M', '喝'), - (0xFA37, 'M', '嘆'), - (0xFA38, 'M', '器'), - (0xFA39, 'M', '塀'), - (0xFA3A, 'M', '墨'), - (0xFA3B, 'M', '層'), - (0xFA3C, 'M', '屮'), - (0xFA3D, 'M', '悔'), - (0xFA3E, 'M', '慨'), - (0xFA3F, 'M', '憎'), - (0xFA40, 'M', '懲'), - (0xFA41, 'M', '敏'), - (0xFA42, 'M', '既'), - (0xFA43, 'M', '暑'), - (0xFA44, 'M', '梅'), - (0xFA45, 'M', '海'), - (0xFA46, 'M', '渚'), - (0xFA47, 'M', '漢'), - (0xFA48, 'M', '煮'), - (0xFA49, 'M', '爫'), - (0xFA4A, 'M', '琢'), - (0xFA4B, 'M', '碑'), - (0xFA4C, 'M', '社'), - (0xFA4D, 'M', '祉'), - (0xFA4E, 'M', '祈'), - (0xFA4F, 'M', '祐'), - (0xFA50, 'M', '祖'), - (0xFA51, 'M', '祝'), - (0xFA52, 'M', '禍'), - (0xFA53, 'M', '禎'), - (0xFA54, 'M', '穀'), - (0xFA55, 'M', '突'), - (0xFA56, 'M', '節'), - (0xFA57, 'M', '練'), - (0xFA58, 'M', '縉'), - (0xFA59, 'M', '繁'), - (0xFA5A, 'M', '署'), - (0xFA5B, 'M', '者'), - (0xFA5C, 'M', '臭'), - (0xFA5D, 'M', '艹'), - (0xFA5F, 'M', '著'), - (0xFA60, 'M', '褐'), - (0xFA61, 'M', '視'), - (0xFA62, 'M', '謁'), - (0xFA63, 'M', '謹'), - (0xFA64, 'M', '賓'), - (0xFA65, 'M', '贈'), - (0xFA66, 'M', '辶'), - (0xFA67, 'M', '逸'), - (0xFA68, 'M', '難'), - (0xFA69, 'M', '響'), - (0xFA6A, 'M', '頻'), - (0xFA6B, 'M', '恵'), - (0xFA6C, 'M', '𤋮'), - (0xFA6D, 'M', '舘'), - (0xFA6E, 'X'), - (0xFA70, 'M', '並'), - (0xFA71, 'M', '况'), - (0xFA72, 'M', '全'), - (0xFA73, 'M', '侀'), - (0xFA74, 'M', '充'), - (0xFA75, 'M', '冀'), - (0xFA76, 'M', '勇'), - (0xFA77, 'M', '勺'), - (0xFA78, 'M', '喝'), - (0xFA79, 'M', '啕'), - (0xFA7A, 'M', '喙'), - (0xFA7B, 'M', '嗢'), - (0xFA7C, 'M', '塚'), - (0xFA7D, 'M', '墳'), - (0xFA7E, 'M', '奄'), - (0xFA7F, 'M', '奔'), - (0xFA80, 'M', '婢'), - (0xFA81, 'M', '嬨'), - ] - -def _seg_43(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0xFA82, 'M', '廒'), - (0xFA83, 'M', '廙'), - (0xFA84, 'M', '彩'), - (0xFA85, 'M', '徭'), - (0xFA86, 'M', '惘'), - (0xFA87, 'M', '慎'), - (0xFA88, 'M', '愈'), - (0xFA89, 'M', '憎'), - (0xFA8A, 'M', '慠'), - (0xFA8B, 'M', '懲'), - (0xFA8C, 'M', '戴'), - (0xFA8D, 'M', '揄'), - (0xFA8E, 'M', '搜'), - (0xFA8F, 'M', '摒'), - (0xFA90, 'M', '敖'), - (0xFA91, 'M', '晴'), - (0xFA92, 'M', '朗'), - (0xFA93, 'M', '望'), - (0xFA94, 'M', '杖'), - (0xFA95, 'M', '歹'), - (0xFA96, 'M', '殺'), - (0xFA97, 'M', '流'), - (0xFA98, 'M', '滛'), - (0xFA99, 'M', '滋'), - (0xFA9A, 'M', '漢'), - (0xFA9B, 'M', '瀞'), - (0xFA9C, 'M', '煮'), - (0xFA9D, 'M', '瞧'), - (0xFA9E, 'M', '爵'), - (0xFA9F, 'M', '犯'), - (0xFAA0, 'M', '猪'), - (0xFAA1, 'M', '瑱'), - (0xFAA2, 'M', '甆'), - (0xFAA3, 'M', '画'), - (0xFAA4, 'M', '瘝'), - (0xFAA5, 'M', '瘟'), - (0xFAA6, 'M', '益'), - (0xFAA7, 'M', '盛'), - (0xFAA8, 'M', '直'), - (0xFAA9, 'M', '睊'), - (0xFAAA, 'M', '着'), - (0xFAAB, 'M', '磌'), - (0xFAAC, 'M', '窱'), - (0xFAAD, 'M', '節'), - (0xFAAE, 'M', '类'), - (0xFAAF, 'M', '絛'), - (0xFAB0, 'M', '練'), - (0xFAB1, 'M', '缾'), - (0xFAB2, 'M', '者'), - (0xFAB3, 'M', '荒'), - (0xFAB4, 'M', '華'), - (0xFAB5, 'M', '蝹'), - (0xFAB6, 'M', '襁'), - (0xFAB7, 'M', '覆'), - (0xFAB8, 'M', '視'), - (0xFAB9, 'M', '調'), - (0xFABA, 'M', '諸'), - (0xFABB, 'M', '請'), - (0xFABC, 'M', '謁'), - (0xFABD, 'M', '諾'), - (0xFABE, 'M', '諭'), - (0xFABF, 'M', '謹'), - (0xFAC0, 'M', '變'), - (0xFAC1, 'M', '贈'), - (0xFAC2, 'M', '輸'), - (0xFAC3, 'M', '遲'), - (0xFAC4, 'M', '醙'), - (0xFAC5, 'M', '鉶'), - (0xFAC6, 'M', '陼'), - (0xFAC7, 'M', '難'), - (0xFAC8, 'M', '靖'), - (0xFAC9, 'M', '韛'), - (0xFACA, 'M', '響'), - (0xFACB, 'M', '頋'), - (0xFACC, 'M', '頻'), - (0xFACD, 'M', '鬒'), - (0xFACE, 'M', '龜'), - (0xFACF, 'M', '𢡊'), - (0xFAD0, 'M', '𢡄'), - (0xFAD1, 'M', '𣏕'), - (0xFAD2, 'M', '㮝'), - (0xFAD3, 'M', '䀘'), - (0xFAD4, 'M', '䀹'), - (0xFAD5, 'M', '𥉉'), - (0xFAD6, 'M', '𥳐'), - (0xFAD7, 'M', '𧻓'), - (0xFAD8, 'M', '齃'), - (0xFAD9, 'M', '龎'), - (0xFADA, 'X'), - (0xFB00, 'M', 'ff'), - (0xFB01, 'M', 'fi'), - (0xFB02, 'M', 'fl'), - (0xFB03, 'M', 'ffi'), - (0xFB04, 'M', 'ffl'), - (0xFB05, 'M', 'st'), - (0xFB07, 'X'), - (0xFB13, 'M', 'մն'), - (0xFB14, 'M', 'մե'), - (0xFB15, 'M', 'մի'), - (0xFB16, 'M', 'վն'), - ] - -def _seg_44(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0xFB17, 'M', 'մխ'), - (0xFB18, 'X'), - (0xFB1D, 'M', 'יִ'), - (0xFB1E, 'V'), - (0xFB1F, 'M', 'ײַ'), - (0xFB20, 'M', 'ע'), - (0xFB21, 'M', 'א'), - (0xFB22, 'M', 'ד'), - (0xFB23, 'M', 'ה'), - (0xFB24, 'M', 'כ'), - (0xFB25, 'M', 'ל'), - (0xFB26, 'M', 'ם'), - (0xFB27, 'M', 'ר'), - (0xFB28, 'M', 'ת'), - (0xFB29, '3', '+'), - (0xFB2A, 'M', 'שׁ'), - (0xFB2B, 'M', 'שׂ'), - (0xFB2C, 'M', 'שּׁ'), - (0xFB2D, 'M', 'שּׂ'), - (0xFB2E, 'M', 'אַ'), - (0xFB2F, 'M', 'אָ'), - (0xFB30, 'M', 'אּ'), - (0xFB31, 'M', 'בּ'), - (0xFB32, 'M', 'גּ'), - (0xFB33, 'M', 'דּ'), - (0xFB34, 'M', 'הּ'), - (0xFB35, 'M', 'וּ'), - (0xFB36, 'M', 'זּ'), - (0xFB37, 'X'), - (0xFB38, 'M', 'טּ'), - (0xFB39, 'M', 'יּ'), - (0xFB3A, 'M', 'ךּ'), - (0xFB3B, 'M', 'כּ'), - (0xFB3C, 'M', 'לּ'), - (0xFB3D, 'X'), - (0xFB3E, 'M', 'מּ'), - (0xFB3F, 'X'), - (0xFB40, 'M', 'נּ'), - (0xFB41, 'M', 'סּ'), - (0xFB42, 'X'), - (0xFB43, 'M', 'ףּ'), - (0xFB44, 'M', 'פּ'), - (0xFB45, 'X'), - (0xFB46, 'M', 'צּ'), - (0xFB47, 'M', 'קּ'), - (0xFB48, 'M', 'רּ'), - (0xFB49, 'M', 'שּ'), - (0xFB4A, 'M', 'תּ'), - (0xFB4B, 'M', 'וֹ'), - (0xFB4C, 'M', 'בֿ'), - (0xFB4D, 'M', 'כֿ'), - (0xFB4E, 'M', 'פֿ'), - (0xFB4F, 'M', 'אל'), - (0xFB50, 'M', 'ٱ'), - (0xFB52, 'M', 'ٻ'), - (0xFB56, 'M', 'پ'), - (0xFB5A, 'M', 'ڀ'), - (0xFB5E, 'M', 'ٺ'), - (0xFB62, 'M', 'ٿ'), - (0xFB66, 'M', 'ٹ'), - (0xFB6A, 'M', 'ڤ'), - (0xFB6E, 'M', 'ڦ'), - (0xFB72, 'M', 'ڄ'), - (0xFB76, 'M', 'ڃ'), - (0xFB7A, 'M', 'چ'), - (0xFB7E, 'M', 'ڇ'), - (0xFB82, 'M', 'ڍ'), - (0xFB84, 'M', 'ڌ'), - (0xFB86, 'M', 'ڎ'), - (0xFB88, 'M', 'ڈ'), - (0xFB8A, 'M', 'ژ'), - (0xFB8C, 'M', 'ڑ'), - (0xFB8E, 'M', 'ک'), - (0xFB92, 'M', 'گ'), - (0xFB96, 'M', 'ڳ'), - (0xFB9A, 'M', 'ڱ'), - (0xFB9E, 'M', 'ں'), - (0xFBA0, 'M', 'ڻ'), - (0xFBA4, 'M', 'ۀ'), - (0xFBA6, 'M', 'ہ'), - (0xFBAA, 'M', 'ھ'), - (0xFBAE, 'M', 'ے'), - (0xFBB0, 'M', 'ۓ'), - (0xFBB2, 'V'), - (0xFBC2, 'X'), - (0xFBD3, 'M', 'ڭ'), - (0xFBD7, 'M', 'ۇ'), - (0xFBD9, 'M', 'ۆ'), - (0xFBDB, 'M', 'ۈ'), - (0xFBDD, 'M', 'ۇٴ'), - (0xFBDE, 'M', 'ۋ'), - (0xFBE0, 'M', 'ۅ'), - (0xFBE2, 'M', 'ۉ'), - (0xFBE4, 'M', 'ې'), - (0xFBE8, 'M', 'ى'), - (0xFBEA, 'M', 'ئا'), - (0xFBEC, 'M', 'ئە'), - (0xFBEE, 'M', 'ئو'), - (0xFBF0, 'M', 'ئۇ'), - (0xFBF2, 'M', 'ئۆ'), - ] - -def _seg_45(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0xFBF4, 'M', 'ئۈ'), - (0xFBF6, 'M', 'ئې'), - (0xFBF9, 'M', 'ئى'), - (0xFBFC, 'M', 'ی'), - (0xFC00, 'M', 'ئج'), - (0xFC01, 'M', 'ئح'), - (0xFC02, 'M', 'ئم'), - (0xFC03, 'M', 'ئى'), - (0xFC04, 'M', 'ئي'), - (0xFC05, 'M', 'بج'), - (0xFC06, 'M', 'بح'), - (0xFC07, 'M', 'بخ'), - (0xFC08, 'M', 'بم'), - (0xFC09, 'M', 'بى'), - (0xFC0A, 'M', 'بي'), - (0xFC0B, 'M', 'تج'), - (0xFC0C, 'M', 'تح'), - (0xFC0D, 'M', 'تخ'), - (0xFC0E, 'M', 'تم'), - (0xFC0F, 'M', 'تى'), - (0xFC10, 'M', 'تي'), - (0xFC11, 'M', 'ثج'), - (0xFC12, 'M', 'ثم'), - (0xFC13, 'M', 'ثى'), - (0xFC14, 'M', 'ثي'), - (0xFC15, 'M', 'جح'), - (0xFC16, 'M', 'جم'), - (0xFC17, 'M', 'حج'), - (0xFC18, 'M', 'حم'), - (0xFC19, 'M', 'خج'), - (0xFC1A, 'M', 'خح'), - (0xFC1B, 'M', 'خم'), - (0xFC1C, 'M', 'سج'), - (0xFC1D, 'M', 'سح'), - (0xFC1E, 'M', 'سخ'), - (0xFC1F, 'M', 'سم'), - (0xFC20, 'M', 'صح'), - (0xFC21, 'M', 'صم'), - (0xFC22, 'M', 'ضج'), - (0xFC23, 'M', 'ضح'), - (0xFC24, 'M', 'ضخ'), - (0xFC25, 'M', 'ضم'), - (0xFC26, 'M', 'طح'), - (0xFC27, 'M', 'طم'), - (0xFC28, 'M', 'ظم'), - (0xFC29, 'M', 'عج'), - (0xFC2A, 'M', 'عم'), - (0xFC2B, 'M', 'غج'), - (0xFC2C, 'M', 'غم'), - (0xFC2D, 'M', 'فج'), - (0xFC2E, 'M', 'فح'), - (0xFC2F, 'M', 'فخ'), - (0xFC30, 'M', 'فم'), - (0xFC31, 'M', 'فى'), - (0xFC32, 'M', 'في'), - (0xFC33, 'M', 'قح'), - (0xFC34, 'M', 'قم'), - (0xFC35, 'M', 'قى'), - (0xFC36, 'M', 'قي'), - (0xFC37, 'M', 'كا'), - (0xFC38, 'M', 'كج'), - (0xFC39, 'M', 'كح'), - (0xFC3A, 'M', 'كخ'), - (0xFC3B, 'M', 'كل'), - (0xFC3C, 'M', 'كم'), - (0xFC3D, 'M', 'كى'), - (0xFC3E, 'M', 'كي'), - (0xFC3F, 'M', 'لج'), - (0xFC40, 'M', 'لح'), - (0xFC41, 'M', 'لخ'), - (0xFC42, 'M', 'لم'), - (0xFC43, 'M', 'لى'), - (0xFC44, 'M', 'لي'), - (0xFC45, 'M', 'مج'), - (0xFC46, 'M', 'مح'), - (0xFC47, 'M', 'مخ'), - (0xFC48, 'M', 'مم'), - (0xFC49, 'M', 'مى'), - (0xFC4A, 'M', 'مي'), - (0xFC4B, 'M', 'نج'), - (0xFC4C, 'M', 'نح'), - (0xFC4D, 'M', 'نخ'), - (0xFC4E, 'M', 'نم'), - (0xFC4F, 'M', 'نى'), - (0xFC50, 'M', 'ني'), - (0xFC51, 'M', 'هج'), - (0xFC52, 'M', 'هم'), - (0xFC53, 'M', 'هى'), - (0xFC54, 'M', 'هي'), - (0xFC55, 'M', 'يج'), - (0xFC56, 'M', 'يح'), - (0xFC57, 'M', 'يخ'), - (0xFC58, 'M', 'يم'), - (0xFC59, 'M', 'يى'), - (0xFC5A, 'M', 'يي'), - (0xFC5B, 'M', 'ذٰ'), - (0xFC5C, 'M', 'رٰ'), - (0xFC5D, 'M', 'ىٰ'), - (0xFC5E, '3', ' ٌّ'), - (0xFC5F, '3', ' ٍّ'), - ] - -def _seg_46(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0xFC60, '3', ' َّ'), - (0xFC61, '3', ' ُّ'), - (0xFC62, '3', ' ِّ'), - (0xFC63, '3', ' ّٰ'), - (0xFC64, 'M', 'ئر'), - (0xFC65, 'M', 'ئز'), - (0xFC66, 'M', 'ئم'), - (0xFC67, 'M', 'ئن'), - (0xFC68, 'M', 'ئى'), - (0xFC69, 'M', 'ئي'), - (0xFC6A, 'M', 'بر'), - (0xFC6B, 'M', 'بز'), - (0xFC6C, 'M', 'بم'), - (0xFC6D, 'M', 'بن'), - (0xFC6E, 'M', 'بى'), - (0xFC6F, 'M', 'بي'), - (0xFC70, 'M', 'تر'), - (0xFC71, 'M', 'تز'), - (0xFC72, 'M', 'تم'), - (0xFC73, 'M', 'تن'), - (0xFC74, 'M', 'تى'), - (0xFC75, 'M', 'تي'), - (0xFC76, 'M', 'ثر'), - (0xFC77, 'M', 'ثز'), - (0xFC78, 'M', 'ثم'), - (0xFC79, 'M', 'ثن'), - (0xFC7A, 'M', 'ثى'), - (0xFC7B, 'M', 'ثي'), - (0xFC7C, 'M', 'فى'), - (0xFC7D, 'M', 'في'), - (0xFC7E, 'M', 'قى'), - (0xFC7F, 'M', 'قي'), - (0xFC80, 'M', 'كا'), - (0xFC81, 'M', 'كل'), - (0xFC82, 'M', 'كم'), - (0xFC83, 'M', 'كى'), - (0xFC84, 'M', 'كي'), - (0xFC85, 'M', 'لم'), - (0xFC86, 'M', 'لى'), - (0xFC87, 'M', 'لي'), - (0xFC88, 'M', 'ما'), - (0xFC89, 'M', 'مم'), - (0xFC8A, 'M', 'نر'), - (0xFC8B, 'M', 'نز'), - (0xFC8C, 'M', 'نم'), - (0xFC8D, 'M', 'نن'), - (0xFC8E, 'M', 'نى'), - (0xFC8F, 'M', 'ني'), - (0xFC90, 'M', 'ىٰ'), - (0xFC91, 'M', 'ير'), - (0xFC92, 'M', 'يز'), - (0xFC93, 'M', 'يم'), - (0xFC94, 'M', 'ين'), - (0xFC95, 'M', 'يى'), - (0xFC96, 'M', 'يي'), - (0xFC97, 'M', 'ئج'), - (0xFC98, 'M', 'ئح'), - (0xFC99, 'M', 'ئخ'), - (0xFC9A, 'M', 'ئم'), - (0xFC9B, 'M', 'ئه'), - (0xFC9C, 'M', 'بج'), - (0xFC9D, 'M', 'بح'), - (0xFC9E, 'M', 'بخ'), - (0xFC9F, 'M', 'بم'), - (0xFCA0, 'M', 'به'), - (0xFCA1, 'M', 'تج'), - (0xFCA2, 'M', 'تح'), - (0xFCA3, 'M', 'تخ'), - (0xFCA4, 'M', 'تم'), - (0xFCA5, 'M', 'ته'), - (0xFCA6, 'M', 'ثم'), - (0xFCA7, 'M', 'جح'), - (0xFCA8, 'M', 'جم'), - (0xFCA9, 'M', 'حج'), - (0xFCAA, 'M', 'حم'), - (0xFCAB, 'M', 'خج'), - (0xFCAC, 'M', 'خم'), - (0xFCAD, 'M', 'سج'), - (0xFCAE, 'M', 'سح'), - (0xFCAF, 'M', 'سخ'), - (0xFCB0, 'M', 'سم'), - (0xFCB1, 'M', 'صح'), - (0xFCB2, 'M', 'صخ'), - (0xFCB3, 'M', 'صم'), - (0xFCB4, 'M', 'ضج'), - (0xFCB5, 'M', 'ضح'), - (0xFCB6, 'M', 'ضخ'), - (0xFCB7, 'M', 'ضم'), - (0xFCB8, 'M', 'طح'), - (0xFCB9, 'M', 'ظم'), - (0xFCBA, 'M', 'عج'), - (0xFCBB, 'M', 'عم'), - (0xFCBC, 'M', 'غج'), - (0xFCBD, 'M', 'غم'), - (0xFCBE, 'M', 'فج'), - (0xFCBF, 'M', 'فح'), - (0xFCC0, 'M', 'فخ'), - (0xFCC1, 'M', 'فم'), - (0xFCC2, 'M', 'قح'), - (0xFCC3, 'M', 'قم'), - ] - -def _seg_47(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0xFCC4, 'M', 'كج'), - (0xFCC5, 'M', 'كح'), - (0xFCC6, 'M', 'كخ'), - (0xFCC7, 'M', 'كل'), - (0xFCC8, 'M', 'كم'), - (0xFCC9, 'M', 'لج'), - (0xFCCA, 'M', 'لح'), - (0xFCCB, 'M', 'لخ'), - (0xFCCC, 'M', 'لم'), - (0xFCCD, 'M', 'له'), - (0xFCCE, 'M', 'مج'), - (0xFCCF, 'M', 'مح'), - (0xFCD0, 'M', 'مخ'), - (0xFCD1, 'M', 'مم'), - (0xFCD2, 'M', 'نج'), - (0xFCD3, 'M', 'نح'), - (0xFCD4, 'M', 'نخ'), - (0xFCD5, 'M', 'نم'), - (0xFCD6, 'M', 'نه'), - (0xFCD7, 'M', 'هج'), - (0xFCD8, 'M', 'هم'), - (0xFCD9, 'M', 'هٰ'), - (0xFCDA, 'M', 'يج'), - (0xFCDB, 'M', 'يح'), - (0xFCDC, 'M', 'يخ'), - (0xFCDD, 'M', 'يم'), - (0xFCDE, 'M', 'يه'), - (0xFCDF, 'M', 'ئم'), - (0xFCE0, 'M', 'ئه'), - (0xFCE1, 'M', 'بم'), - (0xFCE2, 'M', 'به'), - (0xFCE3, 'M', 'تم'), - (0xFCE4, 'M', 'ته'), - (0xFCE5, 'M', 'ثم'), - (0xFCE6, 'M', 'ثه'), - (0xFCE7, 'M', 'سم'), - (0xFCE8, 'M', 'سه'), - (0xFCE9, 'M', 'شم'), - (0xFCEA, 'M', 'شه'), - (0xFCEB, 'M', 'كل'), - (0xFCEC, 'M', 'كم'), - (0xFCED, 'M', 'لم'), - (0xFCEE, 'M', 'نم'), - (0xFCEF, 'M', 'نه'), - (0xFCF0, 'M', 'يم'), - (0xFCF1, 'M', 'يه'), - (0xFCF2, 'M', 'ـَّ'), - (0xFCF3, 'M', 'ـُّ'), - (0xFCF4, 'M', 'ـِّ'), - (0xFCF5, 'M', 'طى'), - (0xFCF6, 'M', 'طي'), - (0xFCF7, 'M', 'عى'), - (0xFCF8, 'M', 'عي'), - (0xFCF9, 'M', 'غى'), - (0xFCFA, 'M', 'غي'), - (0xFCFB, 'M', 'سى'), - (0xFCFC, 'M', 'سي'), - (0xFCFD, 'M', 'شى'), - (0xFCFE, 'M', 'شي'), - (0xFCFF, 'M', 'حى'), - (0xFD00, 'M', 'حي'), - (0xFD01, 'M', 'جى'), - (0xFD02, 'M', 'جي'), - (0xFD03, 'M', 'خى'), - (0xFD04, 'M', 'خي'), - (0xFD05, 'M', 'صى'), - (0xFD06, 'M', 'صي'), - (0xFD07, 'M', 'ضى'), - (0xFD08, 'M', 'ضي'), - (0xFD09, 'M', 'شج'), - (0xFD0A, 'M', 'شح'), - (0xFD0B, 'M', 'شخ'), - (0xFD0C, 'M', 'شم'), - (0xFD0D, 'M', 'شر'), - (0xFD0E, 'M', 'سر'), - (0xFD0F, 'M', 'صر'), - (0xFD10, 'M', 'ضر'), - (0xFD11, 'M', 'طى'), - (0xFD12, 'M', 'طي'), - (0xFD13, 'M', 'عى'), - (0xFD14, 'M', 'عي'), - (0xFD15, 'M', 'غى'), - (0xFD16, 'M', 'غي'), - (0xFD17, 'M', 'سى'), - (0xFD18, 'M', 'سي'), - (0xFD19, 'M', 'شى'), - (0xFD1A, 'M', 'شي'), - (0xFD1B, 'M', 'حى'), - (0xFD1C, 'M', 'حي'), - (0xFD1D, 'M', 'جى'), - (0xFD1E, 'M', 'جي'), - (0xFD1F, 'M', 'خى'), - (0xFD20, 'M', 'خي'), - (0xFD21, 'M', 'صى'), - (0xFD22, 'M', 'صي'), - (0xFD23, 'M', 'ضى'), - (0xFD24, 'M', 'ضي'), - (0xFD25, 'M', 'شج'), - (0xFD26, 'M', 'شح'), - (0xFD27, 'M', 'شخ'), - ] - -def _seg_48(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0xFD28, 'M', 'شم'), - (0xFD29, 'M', 'شر'), - (0xFD2A, 'M', 'سر'), - (0xFD2B, 'M', 'صر'), - (0xFD2C, 'M', 'ضر'), - (0xFD2D, 'M', 'شج'), - (0xFD2E, 'M', 'شح'), - (0xFD2F, 'M', 'شخ'), - (0xFD30, 'M', 'شم'), - (0xFD31, 'M', 'سه'), - (0xFD32, 'M', 'شه'), - (0xFD33, 'M', 'طم'), - (0xFD34, 'M', 'سج'), - (0xFD35, 'M', 'سح'), - (0xFD36, 'M', 'سخ'), - (0xFD37, 'M', 'شج'), - (0xFD38, 'M', 'شح'), - (0xFD39, 'M', 'شخ'), - (0xFD3A, 'M', 'طم'), - (0xFD3B, 'M', 'ظم'), - (0xFD3C, 'M', 'اً'), - (0xFD3E, 'V'), - (0xFD40, 'X'), - (0xFD50, 'M', 'تجم'), - (0xFD51, 'M', 'تحج'), - (0xFD53, 'M', 'تحم'), - (0xFD54, 'M', 'تخم'), - (0xFD55, 'M', 'تمج'), - (0xFD56, 'M', 'تمح'), - (0xFD57, 'M', 'تمخ'), - (0xFD58, 'M', 'جمح'), - (0xFD5A, 'M', 'حمي'), - (0xFD5B, 'M', 'حمى'), - (0xFD5C, 'M', 'سحج'), - (0xFD5D, 'M', 'سجح'), - (0xFD5E, 'M', 'سجى'), - (0xFD5F, 'M', 'سمح'), - (0xFD61, 'M', 'سمج'), - (0xFD62, 'M', 'سمم'), - (0xFD64, 'M', 'صحح'), - (0xFD66, 'M', 'صمم'), - (0xFD67, 'M', 'شحم'), - (0xFD69, 'M', 'شجي'), - (0xFD6A, 'M', 'شمخ'), - (0xFD6C, 'M', 'شمم'), - (0xFD6E, 'M', 'ضحى'), - (0xFD6F, 'M', 'ضخم'), - (0xFD71, 'M', 'طمح'), - (0xFD73, 'M', 'طمم'), - (0xFD74, 'M', 'طمي'), - (0xFD75, 'M', 'عجم'), - (0xFD76, 'M', 'عمم'), - (0xFD78, 'M', 'عمى'), - (0xFD79, 'M', 'غمم'), - (0xFD7A, 'M', 'غمي'), - (0xFD7B, 'M', 'غمى'), - (0xFD7C, 'M', 'فخم'), - (0xFD7E, 'M', 'قمح'), - (0xFD7F, 'M', 'قمم'), - (0xFD80, 'M', 'لحم'), - (0xFD81, 'M', 'لحي'), - (0xFD82, 'M', 'لحى'), - (0xFD83, 'M', 'لجج'), - (0xFD85, 'M', 'لخم'), - (0xFD87, 'M', 'لمح'), - (0xFD89, 'M', 'محج'), - (0xFD8A, 'M', 'محم'), - (0xFD8B, 'M', 'محي'), - (0xFD8C, 'M', 'مجح'), - (0xFD8D, 'M', 'مجم'), - (0xFD8E, 'M', 'مخج'), - (0xFD8F, 'M', 'مخم'), - (0xFD90, 'X'), - (0xFD92, 'M', 'مجخ'), - (0xFD93, 'M', 'همج'), - (0xFD94, 'M', 'همم'), - (0xFD95, 'M', 'نحم'), - (0xFD96, 'M', 'نحى'), - (0xFD97, 'M', 'نجم'), - (0xFD99, 'M', 'نجى'), - (0xFD9A, 'M', 'نمي'), - (0xFD9B, 'M', 'نمى'), - (0xFD9C, 'M', 'يمم'), - (0xFD9E, 'M', 'بخي'), - (0xFD9F, 'M', 'تجي'), - (0xFDA0, 'M', 'تجى'), - (0xFDA1, 'M', 'تخي'), - (0xFDA2, 'M', 'تخى'), - (0xFDA3, 'M', 'تمي'), - (0xFDA4, 'M', 'تمى'), - (0xFDA5, 'M', 'جمي'), - (0xFDA6, 'M', 'جحى'), - (0xFDA7, 'M', 'جمى'), - (0xFDA8, 'M', 'سخى'), - (0xFDA9, 'M', 'صحي'), - (0xFDAA, 'M', 'شحي'), - (0xFDAB, 'M', 'ضحي'), - (0xFDAC, 'M', 'لجي'), - (0xFDAD, 'M', 'لمي'), - (0xFDAE, 'M', 'يحي'), - ] - -def _seg_49(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0xFDAF, 'M', 'يجي'), - (0xFDB0, 'M', 'يمي'), - (0xFDB1, 'M', 'ممي'), - (0xFDB2, 'M', 'قمي'), - (0xFDB3, 'M', 'نحي'), - (0xFDB4, 'M', 'قمح'), - (0xFDB5, 'M', 'لحم'), - (0xFDB6, 'M', 'عمي'), - (0xFDB7, 'M', 'كمي'), - (0xFDB8, 'M', 'نجح'), - (0xFDB9, 'M', 'مخي'), - (0xFDBA, 'M', 'لجم'), - (0xFDBB, 'M', 'كمم'), - (0xFDBC, 'M', 'لجم'), - (0xFDBD, 'M', 'نجح'), - (0xFDBE, 'M', 'جحي'), - (0xFDBF, 'M', 'حجي'), - (0xFDC0, 'M', 'مجي'), - (0xFDC1, 'M', 'فمي'), - (0xFDC2, 'M', 'بحي'), - (0xFDC3, 'M', 'كمم'), - (0xFDC4, 'M', 'عجم'), - (0xFDC5, 'M', 'صمم'), - (0xFDC6, 'M', 'سخي'), - (0xFDC7, 'M', 'نجي'), - (0xFDC8, 'X'), - (0xFDF0, 'M', 'صلے'), - (0xFDF1, 'M', 'قلے'), - (0xFDF2, 'M', 'الله'), - (0xFDF3, 'M', 'اكبر'), - (0xFDF4, 'M', 'محمد'), - (0xFDF5, 'M', 'صلعم'), - (0xFDF6, 'M', 'رسول'), - (0xFDF7, 'M', 'عليه'), - (0xFDF8, 'M', 'وسلم'), - (0xFDF9, 'M', 'صلى'), - (0xFDFA, '3', 'صلى الله عليه وسلم'), - (0xFDFB, '3', 'جل جلاله'), - (0xFDFC, 'M', 'ریال'), - (0xFDFD, 'V'), - (0xFDFE, 'X'), - (0xFE00, 'I'), - (0xFE10, '3', ','), - (0xFE11, 'M', '、'), - (0xFE12, 'X'), - (0xFE13, '3', ':'), - (0xFE14, '3', ';'), - (0xFE15, '3', '!'), - (0xFE16, '3', '?'), - (0xFE17, 'M', '〖'), - (0xFE18, 'M', '〗'), - (0xFE19, 'X'), - (0xFE20, 'V'), - (0xFE30, 'X'), - (0xFE31, 'M', '—'), - (0xFE32, 'M', '–'), - (0xFE33, '3', '_'), - (0xFE35, '3', '('), - (0xFE36, '3', ')'), - (0xFE37, '3', '{'), - (0xFE38, '3', '}'), - (0xFE39, 'M', '〔'), - (0xFE3A, 'M', '〕'), - (0xFE3B, 'M', '【'), - (0xFE3C, 'M', '】'), - (0xFE3D, 'M', '《'), - (0xFE3E, 'M', '》'), - (0xFE3F, 'M', '〈'), - (0xFE40, 'M', '〉'), - (0xFE41, 'M', '「'), - (0xFE42, 'M', '」'), - (0xFE43, 'M', '『'), - (0xFE44, 'M', '』'), - (0xFE45, 'V'), - (0xFE47, '3', '['), - (0xFE48, '3', ']'), - (0xFE49, '3', ' ̅'), - (0xFE4D, '3', '_'), - (0xFE50, '3', ','), - (0xFE51, 'M', '、'), - (0xFE52, 'X'), - (0xFE54, '3', ';'), - (0xFE55, '3', ':'), - (0xFE56, '3', '?'), - (0xFE57, '3', '!'), - (0xFE58, 'M', '—'), - (0xFE59, '3', '('), - (0xFE5A, '3', ')'), - (0xFE5B, '3', '{'), - (0xFE5C, '3', '}'), - (0xFE5D, 'M', '〔'), - (0xFE5E, 'M', '〕'), - (0xFE5F, '3', '#'), - (0xFE60, '3', '&'), - (0xFE61, '3', '*'), - (0xFE62, '3', '+'), - (0xFE63, 'M', '-'), - (0xFE64, '3', '<'), - (0xFE65, '3', '>'), - (0xFE66, '3', '='), - ] - -def _seg_50(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0xFE67, 'X'), - (0xFE68, '3', '\\'), - (0xFE69, '3', '$'), - (0xFE6A, '3', '%'), - (0xFE6B, '3', '@'), - (0xFE6C, 'X'), - (0xFE70, '3', ' ً'), - (0xFE71, 'M', 'ـً'), - (0xFE72, '3', ' ٌ'), - (0xFE73, 'V'), - (0xFE74, '3', ' ٍ'), - (0xFE75, 'X'), - (0xFE76, '3', ' َ'), - (0xFE77, 'M', 'ـَ'), - (0xFE78, '3', ' ُ'), - (0xFE79, 'M', 'ـُ'), - (0xFE7A, '3', ' ِ'), - (0xFE7B, 'M', 'ـِ'), - (0xFE7C, '3', ' ّ'), - (0xFE7D, 'M', 'ـّ'), - (0xFE7E, '3', ' ْ'), - (0xFE7F, 'M', 'ـْ'), - (0xFE80, 'M', 'ء'), - (0xFE81, 'M', 'آ'), - (0xFE83, 'M', 'أ'), - (0xFE85, 'M', 'ؤ'), - (0xFE87, 'M', 'إ'), - (0xFE89, 'M', 'ئ'), - (0xFE8D, 'M', 'ا'), - (0xFE8F, 'M', 'ب'), - (0xFE93, 'M', 'ة'), - (0xFE95, 'M', 'ت'), - (0xFE99, 'M', 'ث'), - (0xFE9D, 'M', 'ج'), - (0xFEA1, 'M', 'ح'), - (0xFEA5, 'M', 'خ'), - (0xFEA9, 'M', 'د'), - (0xFEAB, 'M', 'ذ'), - (0xFEAD, 'M', 'ر'), - (0xFEAF, 'M', 'ز'), - (0xFEB1, 'M', 'س'), - (0xFEB5, 'M', 'ش'), - (0xFEB9, 'M', 'ص'), - (0xFEBD, 'M', 'ض'), - (0xFEC1, 'M', 'ط'), - (0xFEC5, 'M', 'ظ'), - (0xFEC9, 'M', 'ع'), - (0xFECD, 'M', 'غ'), - (0xFED1, 'M', 'ف'), - (0xFED5, 'M', 'ق'), - (0xFED9, 'M', 'ك'), - (0xFEDD, 'M', 'ل'), - (0xFEE1, 'M', 'م'), - (0xFEE5, 'M', 'ن'), - (0xFEE9, 'M', 'ه'), - (0xFEED, 'M', 'و'), - (0xFEEF, 'M', 'ى'), - (0xFEF1, 'M', 'ي'), - (0xFEF5, 'M', 'لآ'), - (0xFEF7, 'M', 'لأ'), - (0xFEF9, 'M', 'لإ'), - (0xFEFB, 'M', 'لا'), - (0xFEFD, 'X'), - (0xFEFF, 'I'), - (0xFF00, 'X'), - (0xFF01, '3', '!'), - (0xFF02, '3', '"'), - (0xFF03, '3', '#'), - (0xFF04, '3', '$'), - (0xFF05, '3', '%'), - (0xFF06, '3', '&'), - (0xFF07, '3', '\''), - (0xFF08, '3', '('), - (0xFF09, '3', ')'), - (0xFF0A, '3', '*'), - (0xFF0B, '3', '+'), - (0xFF0C, '3', ','), - (0xFF0D, 'M', '-'), - (0xFF0E, 'M', '.'), - (0xFF0F, '3', '/'), - (0xFF10, 'M', '0'), - (0xFF11, 'M', '1'), - (0xFF12, 'M', '2'), - (0xFF13, 'M', '3'), - (0xFF14, 'M', '4'), - (0xFF15, 'M', '5'), - (0xFF16, 'M', '6'), - (0xFF17, 'M', '7'), - (0xFF18, 'M', '8'), - (0xFF19, 'M', '9'), - (0xFF1A, '3', ':'), - (0xFF1B, '3', ';'), - (0xFF1C, '3', '<'), - (0xFF1D, '3', '='), - (0xFF1E, '3', '>'), - (0xFF1F, '3', '?'), - (0xFF20, '3', '@'), - (0xFF21, 'M', 'a'), - (0xFF22, 'M', 'b'), - (0xFF23, 'M', 'c'), - ] - -def _seg_51(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0xFF24, 'M', 'd'), - (0xFF25, 'M', 'e'), - (0xFF26, 'M', 'f'), - (0xFF27, 'M', 'g'), - (0xFF28, 'M', 'h'), - (0xFF29, 'M', 'i'), - (0xFF2A, 'M', 'j'), - (0xFF2B, 'M', 'k'), - (0xFF2C, 'M', 'l'), - (0xFF2D, 'M', 'm'), - (0xFF2E, 'M', 'n'), - (0xFF2F, 'M', 'o'), - (0xFF30, 'M', 'p'), - (0xFF31, 'M', 'q'), - (0xFF32, 'M', 'r'), - (0xFF33, 'M', 's'), - (0xFF34, 'M', 't'), - (0xFF35, 'M', 'u'), - (0xFF36, 'M', 'v'), - (0xFF37, 'M', 'w'), - (0xFF38, 'M', 'x'), - (0xFF39, 'M', 'y'), - (0xFF3A, 'M', 'z'), - (0xFF3B, '3', '['), - (0xFF3C, '3', '\\'), - (0xFF3D, '3', ']'), - (0xFF3E, '3', '^'), - (0xFF3F, '3', '_'), - (0xFF40, '3', '`'), - (0xFF41, 'M', 'a'), - (0xFF42, 'M', 'b'), - (0xFF43, 'M', 'c'), - (0xFF44, 'M', 'd'), - (0xFF45, 'M', 'e'), - (0xFF46, 'M', 'f'), - (0xFF47, 'M', 'g'), - (0xFF48, 'M', 'h'), - (0xFF49, 'M', 'i'), - (0xFF4A, 'M', 'j'), - (0xFF4B, 'M', 'k'), - (0xFF4C, 'M', 'l'), - (0xFF4D, 'M', 'm'), - (0xFF4E, 'M', 'n'), - (0xFF4F, 'M', 'o'), - (0xFF50, 'M', 'p'), - (0xFF51, 'M', 'q'), - (0xFF52, 'M', 'r'), - (0xFF53, 'M', 's'), - (0xFF54, 'M', 't'), - (0xFF55, 'M', 'u'), - (0xFF56, 'M', 'v'), - (0xFF57, 'M', 'w'), - (0xFF58, 'M', 'x'), - (0xFF59, 'M', 'y'), - (0xFF5A, 'M', 'z'), - (0xFF5B, '3', '{'), - (0xFF5C, '3', '|'), - (0xFF5D, '3', '}'), - (0xFF5E, '3', '~'), - (0xFF5F, 'M', '⦅'), - (0xFF60, 'M', '⦆'), - (0xFF61, 'M', '.'), - (0xFF62, 'M', '「'), - (0xFF63, 'M', '」'), - (0xFF64, 'M', '、'), - (0xFF65, 'M', '・'), - (0xFF66, 'M', 'ヲ'), - (0xFF67, 'M', 'ァ'), - (0xFF68, 'M', 'ィ'), - (0xFF69, 'M', 'ゥ'), - (0xFF6A, 'M', 'ェ'), - (0xFF6B, 'M', 'ォ'), - (0xFF6C, 'M', 'ャ'), - (0xFF6D, 'M', 'ュ'), - (0xFF6E, 'M', 'ョ'), - (0xFF6F, 'M', 'ッ'), - (0xFF70, 'M', 'ー'), - (0xFF71, 'M', 'ア'), - (0xFF72, 'M', 'イ'), - (0xFF73, 'M', 'ウ'), - (0xFF74, 'M', 'エ'), - (0xFF75, 'M', 'オ'), - (0xFF76, 'M', 'カ'), - (0xFF77, 'M', 'キ'), - (0xFF78, 'M', 'ク'), - (0xFF79, 'M', 'ケ'), - (0xFF7A, 'M', 'コ'), - (0xFF7B, 'M', 'サ'), - (0xFF7C, 'M', 'シ'), - (0xFF7D, 'M', 'ス'), - (0xFF7E, 'M', 'セ'), - (0xFF7F, 'M', 'ソ'), - (0xFF80, 'M', 'タ'), - (0xFF81, 'M', 'チ'), - (0xFF82, 'M', 'ツ'), - (0xFF83, 'M', 'テ'), - (0xFF84, 'M', 'ト'), - (0xFF85, 'M', 'ナ'), - (0xFF86, 'M', 'ニ'), - (0xFF87, 'M', 'ヌ'), - ] - -def _seg_52(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0xFF88, 'M', 'ネ'), - (0xFF89, 'M', 'ノ'), - (0xFF8A, 'M', 'ハ'), - (0xFF8B, 'M', 'ヒ'), - (0xFF8C, 'M', 'フ'), - (0xFF8D, 'M', 'ヘ'), - (0xFF8E, 'M', 'ホ'), - (0xFF8F, 'M', 'マ'), - (0xFF90, 'M', 'ミ'), - (0xFF91, 'M', 'ム'), - (0xFF92, 'M', 'メ'), - (0xFF93, 'M', 'モ'), - (0xFF94, 'M', 'ヤ'), - (0xFF95, 'M', 'ユ'), - (0xFF96, 'M', 'ヨ'), - (0xFF97, 'M', 'ラ'), - (0xFF98, 'M', 'リ'), - (0xFF99, 'M', 'ル'), - (0xFF9A, 'M', 'レ'), - (0xFF9B, 'M', 'ロ'), - (0xFF9C, 'M', 'ワ'), - (0xFF9D, 'M', 'ン'), - (0xFF9E, 'M', '゙'), - (0xFF9F, 'M', '゚'), - (0xFFA0, 'X'), - (0xFFA1, 'M', 'ᄀ'), - (0xFFA2, 'M', 'ᄁ'), - (0xFFA3, 'M', 'ᆪ'), - (0xFFA4, 'M', 'ᄂ'), - (0xFFA5, 'M', 'ᆬ'), - (0xFFA6, 'M', 'ᆭ'), - (0xFFA7, 'M', 'ᄃ'), - (0xFFA8, 'M', 'ᄄ'), - (0xFFA9, 'M', 'ᄅ'), - (0xFFAA, 'M', 'ᆰ'), - (0xFFAB, 'M', 'ᆱ'), - (0xFFAC, 'M', 'ᆲ'), - (0xFFAD, 'M', 'ᆳ'), - (0xFFAE, 'M', 'ᆴ'), - (0xFFAF, 'M', 'ᆵ'), - (0xFFB0, 'M', 'ᄚ'), - (0xFFB1, 'M', 'ᄆ'), - (0xFFB2, 'M', 'ᄇ'), - (0xFFB3, 'M', 'ᄈ'), - (0xFFB4, 'M', 'ᄡ'), - (0xFFB5, 'M', 'ᄉ'), - (0xFFB6, 'M', 'ᄊ'), - (0xFFB7, 'M', 'ᄋ'), - (0xFFB8, 'M', 'ᄌ'), - (0xFFB9, 'M', 'ᄍ'), - (0xFFBA, 'M', 'ᄎ'), - (0xFFBB, 'M', 'ᄏ'), - (0xFFBC, 'M', 'ᄐ'), - (0xFFBD, 'M', 'ᄑ'), - (0xFFBE, 'M', 'ᄒ'), - (0xFFBF, 'X'), - (0xFFC2, 'M', 'ᅡ'), - (0xFFC3, 'M', 'ᅢ'), - (0xFFC4, 'M', 'ᅣ'), - (0xFFC5, 'M', 'ᅤ'), - (0xFFC6, 'M', 'ᅥ'), - (0xFFC7, 'M', 'ᅦ'), - (0xFFC8, 'X'), - (0xFFCA, 'M', 'ᅧ'), - (0xFFCB, 'M', 'ᅨ'), - (0xFFCC, 'M', 'ᅩ'), - (0xFFCD, 'M', 'ᅪ'), - (0xFFCE, 'M', 'ᅫ'), - (0xFFCF, 'M', 'ᅬ'), - (0xFFD0, 'X'), - (0xFFD2, 'M', 'ᅭ'), - (0xFFD3, 'M', 'ᅮ'), - (0xFFD4, 'M', 'ᅯ'), - (0xFFD5, 'M', 'ᅰ'), - (0xFFD6, 'M', 'ᅱ'), - (0xFFD7, 'M', 'ᅲ'), - (0xFFD8, 'X'), - (0xFFDA, 'M', 'ᅳ'), - (0xFFDB, 'M', 'ᅴ'), - (0xFFDC, 'M', 'ᅵ'), - (0xFFDD, 'X'), - (0xFFE0, 'M', '¢'), - (0xFFE1, 'M', '£'), - (0xFFE2, 'M', '¬'), - (0xFFE3, '3', ' ̄'), - (0xFFE4, 'M', '¦'), - (0xFFE5, 'M', '¥'), - (0xFFE6, 'M', '₩'), - (0xFFE7, 'X'), - (0xFFE8, 'M', '│'), - (0xFFE9, 'M', '←'), - (0xFFEA, 'M', '↑'), - (0xFFEB, 'M', '→'), - (0xFFEC, 'M', '↓'), - (0xFFED, 'M', '■'), - (0xFFEE, 'M', '○'), - (0xFFEF, 'X'), - (0x10000, 'V'), - (0x1000C, 'X'), - (0x1000D, 'V'), - ] - -def _seg_53(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0x10027, 'X'), - (0x10028, 'V'), - (0x1003B, 'X'), - (0x1003C, 'V'), - (0x1003E, 'X'), - (0x1003F, 'V'), - (0x1004E, 'X'), - (0x10050, 'V'), - (0x1005E, 'X'), - (0x10080, 'V'), - (0x100FB, 'X'), - (0x10100, 'V'), - (0x10103, 'X'), - (0x10107, 'V'), - (0x10134, 'X'), - (0x10137, 'V'), - (0x1018F, 'X'), - (0x10190, 'V'), - (0x1019D, 'X'), - (0x101A0, 'V'), - (0x101A1, 'X'), - (0x101D0, 'V'), - (0x101FE, 'X'), - (0x10280, 'V'), - (0x1029D, 'X'), - (0x102A0, 'V'), - (0x102D1, 'X'), - (0x102E0, 'V'), - (0x102FC, 'X'), - (0x10300, 'V'), - (0x10324, 'X'), - (0x1032D, 'V'), - (0x1034B, 'X'), - (0x10350, 'V'), - (0x1037B, 'X'), - (0x10380, 'V'), - (0x1039E, 'X'), - (0x1039F, 'V'), - (0x103C4, 'X'), - (0x103C8, 'V'), - (0x103D6, 'X'), - (0x10400, 'M', '𐐨'), - (0x10401, 'M', '𐐩'), - (0x10402, 'M', '𐐪'), - (0x10403, 'M', '𐐫'), - (0x10404, 'M', '𐐬'), - (0x10405, 'M', '𐐭'), - (0x10406, 'M', '𐐮'), - (0x10407, 'M', '𐐯'), - (0x10408, 'M', '𐐰'), - (0x10409, 'M', '𐐱'), - (0x1040A, 'M', '𐐲'), - (0x1040B, 'M', '𐐳'), - (0x1040C, 'M', '𐐴'), - (0x1040D, 'M', '𐐵'), - (0x1040E, 'M', '𐐶'), - (0x1040F, 'M', '𐐷'), - (0x10410, 'M', '𐐸'), - (0x10411, 'M', '𐐹'), - (0x10412, 'M', '𐐺'), - (0x10413, 'M', '𐐻'), - (0x10414, 'M', '𐐼'), - (0x10415, 'M', '𐐽'), - (0x10416, 'M', '𐐾'), - (0x10417, 'M', '𐐿'), - (0x10418, 'M', '𐑀'), - (0x10419, 'M', '𐑁'), - (0x1041A, 'M', '𐑂'), - (0x1041B, 'M', '𐑃'), - (0x1041C, 'M', '𐑄'), - (0x1041D, 'M', '𐑅'), - (0x1041E, 'M', '𐑆'), - (0x1041F, 'M', '𐑇'), - (0x10420, 'M', '𐑈'), - (0x10421, 'M', '𐑉'), - (0x10422, 'M', '𐑊'), - (0x10423, 'M', '𐑋'), - (0x10424, 'M', '𐑌'), - (0x10425, 'M', '𐑍'), - (0x10426, 'M', '𐑎'), - (0x10427, 'M', '𐑏'), - (0x10428, 'V'), - (0x1049E, 'X'), - (0x104A0, 'V'), - (0x104AA, 'X'), - (0x104B0, 'M', '𐓘'), - (0x104B1, 'M', '𐓙'), - (0x104B2, 'M', '𐓚'), - (0x104B3, 'M', '𐓛'), - (0x104B4, 'M', '𐓜'), - (0x104B5, 'M', '𐓝'), - (0x104B6, 'M', '𐓞'), - (0x104B7, 'M', '𐓟'), - (0x104B8, 'M', '𐓠'), - (0x104B9, 'M', '𐓡'), - (0x104BA, 'M', '𐓢'), - (0x104BB, 'M', '𐓣'), - (0x104BC, 'M', '𐓤'), - (0x104BD, 'M', '𐓥'), - (0x104BE, 'M', '𐓦'), - ] - -def _seg_54(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0x104BF, 'M', '𐓧'), - (0x104C0, 'M', '𐓨'), - (0x104C1, 'M', '𐓩'), - (0x104C2, 'M', '𐓪'), - (0x104C3, 'M', '𐓫'), - (0x104C4, 'M', '𐓬'), - (0x104C5, 'M', '𐓭'), - (0x104C6, 'M', '𐓮'), - (0x104C7, 'M', '𐓯'), - (0x104C8, 'M', '𐓰'), - (0x104C9, 'M', '𐓱'), - (0x104CA, 'M', '𐓲'), - (0x104CB, 'M', '𐓳'), - (0x104CC, 'M', '𐓴'), - (0x104CD, 'M', '𐓵'), - (0x104CE, 'M', '𐓶'), - (0x104CF, 'M', '𐓷'), - (0x104D0, 'M', '𐓸'), - (0x104D1, 'M', '𐓹'), - (0x104D2, 'M', '𐓺'), - (0x104D3, 'M', '𐓻'), - (0x104D4, 'X'), - (0x104D8, 'V'), - (0x104FC, 'X'), - (0x10500, 'V'), - (0x10528, 'X'), - (0x10530, 'V'), - (0x10564, 'X'), - (0x1056F, 'V'), - (0x10570, 'X'), - (0x10600, 'V'), - (0x10737, 'X'), - (0x10740, 'V'), - (0x10756, 'X'), - (0x10760, 'V'), - (0x10768, 'X'), - (0x10800, 'V'), - (0x10806, 'X'), - (0x10808, 'V'), - (0x10809, 'X'), - (0x1080A, 'V'), - (0x10836, 'X'), - (0x10837, 'V'), - (0x10839, 'X'), - (0x1083C, 'V'), - (0x1083D, 'X'), - (0x1083F, 'V'), - (0x10856, 'X'), - (0x10857, 'V'), - (0x1089F, 'X'), - (0x108A7, 'V'), - (0x108B0, 'X'), - (0x108E0, 'V'), - (0x108F3, 'X'), - (0x108F4, 'V'), - (0x108F6, 'X'), - (0x108FB, 'V'), - (0x1091C, 'X'), - (0x1091F, 'V'), - (0x1093A, 'X'), - (0x1093F, 'V'), - (0x10940, 'X'), - (0x10980, 'V'), - (0x109B8, 'X'), - (0x109BC, 'V'), - (0x109D0, 'X'), - (0x109D2, 'V'), - (0x10A04, 'X'), - (0x10A05, 'V'), - (0x10A07, 'X'), - (0x10A0C, 'V'), - (0x10A14, 'X'), - (0x10A15, 'V'), - (0x10A18, 'X'), - (0x10A19, 'V'), - (0x10A36, 'X'), - (0x10A38, 'V'), - (0x10A3B, 'X'), - (0x10A3F, 'V'), - (0x10A49, 'X'), - (0x10A50, 'V'), - (0x10A59, 'X'), - (0x10A60, 'V'), - (0x10AA0, 'X'), - (0x10AC0, 'V'), - (0x10AE7, 'X'), - (0x10AEB, 'V'), - (0x10AF7, 'X'), - (0x10B00, 'V'), - (0x10B36, 'X'), - (0x10B39, 'V'), - (0x10B56, 'X'), - (0x10B58, 'V'), - (0x10B73, 'X'), - (0x10B78, 'V'), - (0x10B92, 'X'), - (0x10B99, 'V'), - (0x10B9D, 'X'), - (0x10BA9, 'V'), - (0x10BB0, 'X'), - ] - -def _seg_55(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0x10C00, 'V'), - (0x10C49, 'X'), - (0x10C80, 'M', '𐳀'), - (0x10C81, 'M', '𐳁'), - (0x10C82, 'M', '𐳂'), - (0x10C83, 'M', '𐳃'), - (0x10C84, 'M', '𐳄'), - (0x10C85, 'M', '𐳅'), - (0x10C86, 'M', '𐳆'), - (0x10C87, 'M', '𐳇'), - (0x10C88, 'M', '𐳈'), - (0x10C89, 'M', '𐳉'), - (0x10C8A, 'M', '𐳊'), - (0x10C8B, 'M', '𐳋'), - (0x10C8C, 'M', '𐳌'), - (0x10C8D, 'M', '𐳍'), - (0x10C8E, 'M', '𐳎'), - (0x10C8F, 'M', '𐳏'), - (0x10C90, 'M', '𐳐'), - (0x10C91, 'M', '𐳑'), - (0x10C92, 'M', '𐳒'), - (0x10C93, 'M', '𐳓'), - (0x10C94, 'M', '𐳔'), - (0x10C95, 'M', '𐳕'), - (0x10C96, 'M', '𐳖'), - (0x10C97, 'M', '𐳗'), - (0x10C98, 'M', '𐳘'), - (0x10C99, 'M', '𐳙'), - (0x10C9A, 'M', '𐳚'), - (0x10C9B, 'M', '𐳛'), - (0x10C9C, 'M', '𐳜'), - (0x10C9D, 'M', '𐳝'), - (0x10C9E, 'M', '𐳞'), - (0x10C9F, 'M', '𐳟'), - (0x10CA0, 'M', '𐳠'), - (0x10CA1, 'M', '𐳡'), - (0x10CA2, 'M', '𐳢'), - (0x10CA3, 'M', '𐳣'), - (0x10CA4, 'M', '𐳤'), - (0x10CA5, 'M', '𐳥'), - (0x10CA6, 'M', '𐳦'), - (0x10CA7, 'M', '𐳧'), - (0x10CA8, 'M', '𐳨'), - (0x10CA9, 'M', '𐳩'), - (0x10CAA, 'M', '𐳪'), - (0x10CAB, 'M', '𐳫'), - (0x10CAC, 'M', '𐳬'), - (0x10CAD, 'M', '𐳭'), - (0x10CAE, 'M', '𐳮'), - (0x10CAF, 'M', '𐳯'), - (0x10CB0, 'M', '𐳰'), - (0x10CB1, 'M', '𐳱'), - (0x10CB2, 'M', '𐳲'), - (0x10CB3, 'X'), - (0x10CC0, 'V'), - (0x10CF3, 'X'), - (0x10CFA, 'V'), - (0x10D28, 'X'), - (0x10D30, 'V'), - (0x10D3A, 'X'), - (0x10E60, 'V'), - (0x10E7F, 'X'), - (0x10E80, 'V'), - (0x10EAA, 'X'), - (0x10EAB, 'V'), - (0x10EAE, 'X'), - (0x10EB0, 'V'), - (0x10EB2, 'X'), - (0x10F00, 'V'), - (0x10F28, 'X'), - (0x10F30, 'V'), - (0x10F5A, 'X'), - (0x10FB0, 'V'), - (0x10FCC, 'X'), - (0x10FE0, 'V'), - (0x10FF7, 'X'), - (0x11000, 'V'), - (0x1104E, 'X'), - (0x11052, 'V'), - (0x11070, 'X'), - (0x1107F, 'V'), - (0x110BD, 'X'), - (0x110BE, 'V'), - (0x110C2, 'X'), - (0x110D0, 'V'), - (0x110E9, 'X'), - (0x110F0, 'V'), - (0x110FA, 'X'), - (0x11100, 'V'), - (0x11135, 'X'), - (0x11136, 'V'), - (0x11148, 'X'), - (0x11150, 'V'), - (0x11177, 'X'), - (0x11180, 'V'), - (0x111E0, 'X'), - (0x111E1, 'V'), - (0x111F5, 'X'), - (0x11200, 'V'), - (0x11212, 'X'), - ] - -def _seg_56(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0x11213, 'V'), - (0x1123F, 'X'), - (0x11280, 'V'), - (0x11287, 'X'), - (0x11288, 'V'), - (0x11289, 'X'), - (0x1128A, 'V'), - (0x1128E, 'X'), - (0x1128F, 'V'), - (0x1129E, 'X'), - (0x1129F, 'V'), - (0x112AA, 'X'), - (0x112B0, 'V'), - (0x112EB, 'X'), - (0x112F0, 'V'), - (0x112FA, 'X'), - (0x11300, 'V'), - (0x11304, 'X'), - (0x11305, 'V'), - (0x1130D, 'X'), - (0x1130F, 'V'), - (0x11311, 'X'), - (0x11313, 'V'), - (0x11329, 'X'), - (0x1132A, 'V'), - (0x11331, 'X'), - (0x11332, 'V'), - (0x11334, 'X'), - (0x11335, 'V'), - (0x1133A, 'X'), - (0x1133B, 'V'), - (0x11345, 'X'), - (0x11347, 'V'), - (0x11349, 'X'), - (0x1134B, 'V'), - (0x1134E, 'X'), - (0x11350, 'V'), - (0x11351, 'X'), - (0x11357, 'V'), - (0x11358, 'X'), - (0x1135D, 'V'), - (0x11364, 'X'), - (0x11366, 'V'), - (0x1136D, 'X'), - (0x11370, 'V'), - (0x11375, 'X'), - (0x11400, 'V'), - (0x1145C, 'X'), - (0x1145D, 'V'), - (0x11462, 'X'), - (0x11480, 'V'), - (0x114C8, 'X'), - (0x114D0, 'V'), - (0x114DA, 'X'), - (0x11580, 'V'), - (0x115B6, 'X'), - (0x115B8, 'V'), - (0x115DE, 'X'), - (0x11600, 'V'), - (0x11645, 'X'), - (0x11650, 'V'), - (0x1165A, 'X'), - (0x11660, 'V'), - (0x1166D, 'X'), - (0x11680, 'V'), - (0x116B9, 'X'), - (0x116C0, 'V'), - (0x116CA, 'X'), - (0x11700, 'V'), - (0x1171B, 'X'), - (0x1171D, 'V'), - (0x1172C, 'X'), - (0x11730, 'V'), - (0x11740, 'X'), - (0x11800, 'V'), - (0x1183C, 'X'), - (0x118A0, 'M', '𑣀'), - (0x118A1, 'M', '𑣁'), - (0x118A2, 'M', '𑣂'), - (0x118A3, 'M', '𑣃'), - (0x118A4, 'M', '𑣄'), - (0x118A5, 'M', '𑣅'), - (0x118A6, 'M', '𑣆'), - (0x118A7, 'M', '𑣇'), - (0x118A8, 'M', '𑣈'), - (0x118A9, 'M', '𑣉'), - (0x118AA, 'M', '𑣊'), - (0x118AB, 'M', '𑣋'), - (0x118AC, 'M', '𑣌'), - (0x118AD, 'M', '𑣍'), - (0x118AE, 'M', '𑣎'), - (0x118AF, 'M', '𑣏'), - (0x118B0, 'M', '𑣐'), - (0x118B1, 'M', '𑣑'), - (0x118B2, 'M', '𑣒'), - (0x118B3, 'M', '𑣓'), - (0x118B4, 'M', '𑣔'), - (0x118B5, 'M', '𑣕'), - (0x118B6, 'M', '𑣖'), - (0x118B7, 'M', '𑣗'), - ] - -def _seg_57(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0x118B8, 'M', '𑣘'), - (0x118B9, 'M', '𑣙'), - (0x118BA, 'M', '𑣚'), - (0x118BB, 'M', '𑣛'), - (0x118BC, 'M', '𑣜'), - (0x118BD, 'M', '𑣝'), - (0x118BE, 'M', '𑣞'), - (0x118BF, 'M', '𑣟'), - (0x118C0, 'V'), - (0x118F3, 'X'), - (0x118FF, 'V'), - (0x11907, 'X'), - (0x11909, 'V'), - (0x1190A, 'X'), - (0x1190C, 'V'), - (0x11914, 'X'), - (0x11915, 'V'), - (0x11917, 'X'), - (0x11918, 'V'), - (0x11936, 'X'), - (0x11937, 'V'), - (0x11939, 'X'), - (0x1193B, 'V'), - (0x11947, 'X'), - (0x11950, 'V'), - (0x1195A, 'X'), - (0x119A0, 'V'), - (0x119A8, 'X'), - (0x119AA, 'V'), - (0x119D8, 'X'), - (0x119DA, 'V'), - (0x119E5, 'X'), - (0x11A00, 'V'), - (0x11A48, 'X'), - (0x11A50, 'V'), - (0x11AA3, 'X'), - (0x11AC0, 'V'), - (0x11AF9, 'X'), - (0x11C00, 'V'), - (0x11C09, 'X'), - (0x11C0A, 'V'), - (0x11C37, 'X'), - (0x11C38, 'V'), - (0x11C46, 'X'), - (0x11C50, 'V'), - (0x11C6D, 'X'), - (0x11C70, 'V'), - (0x11C90, 'X'), - (0x11C92, 'V'), - (0x11CA8, 'X'), - (0x11CA9, 'V'), - (0x11CB7, 'X'), - (0x11D00, 'V'), - (0x11D07, 'X'), - (0x11D08, 'V'), - (0x11D0A, 'X'), - (0x11D0B, 'V'), - (0x11D37, 'X'), - (0x11D3A, 'V'), - (0x11D3B, 'X'), - (0x11D3C, 'V'), - (0x11D3E, 'X'), - (0x11D3F, 'V'), - (0x11D48, 'X'), - (0x11D50, 'V'), - (0x11D5A, 'X'), - (0x11D60, 'V'), - (0x11D66, 'X'), - (0x11D67, 'V'), - (0x11D69, 'X'), - (0x11D6A, 'V'), - (0x11D8F, 'X'), - (0x11D90, 'V'), - (0x11D92, 'X'), - (0x11D93, 'V'), - (0x11D99, 'X'), - (0x11DA0, 'V'), - (0x11DAA, 'X'), - (0x11EE0, 'V'), - (0x11EF9, 'X'), - (0x11FB0, 'V'), - (0x11FB1, 'X'), - (0x11FC0, 'V'), - (0x11FF2, 'X'), - (0x11FFF, 'V'), - (0x1239A, 'X'), - (0x12400, 'V'), - (0x1246F, 'X'), - (0x12470, 'V'), - (0x12475, 'X'), - (0x12480, 'V'), - (0x12544, 'X'), - (0x13000, 'V'), - (0x1342F, 'X'), - (0x14400, 'V'), - (0x14647, 'X'), - (0x16800, 'V'), - (0x16A39, 'X'), - (0x16A40, 'V'), - (0x16A5F, 'X'), - ] - -def _seg_58(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0x16A60, 'V'), - (0x16A6A, 'X'), - (0x16A6E, 'V'), - (0x16A70, 'X'), - (0x16AD0, 'V'), - (0x16AEE, 'X'), - (0x16AF0, 'V'), - (0x16AF6, 'X'), - (0x16B00, 'V'), - (0x16B46, 'X'), - (0x16B50, 'V'), - (0x16B5A, 'X'), - (0x16B5B, 'V'), - (0x16B62, 'X'), - (0x16B63, 'V'), - (0x16B78, 'X'), - (0x16B7D, 'V'), - (0x16B90, 'X'), - (0x16E40, 'M', '𖹠'), - (0x16E41, 'M', '𖹡'), - (0x16E42, 'M', '𖹢'), - (0x16E43, 'M', '𖹣'), - (0x16E44, 'M', '𖹤'), - (0x16E45, 'M', '𖹥'), - (0x16E46, 'M', '𖹦'), - (0x16E47, 'M', '𖹧'), - (0x16E48, 'M', '𖹨'), - (0x16E49, 'M', '𖹩'), - (0x16E4A, 'M', '𖹪'), - (0x16E4B, 'M', '𖹫'), - (0x16E4C, 'M', '𖹬'), - (0x16E4D, 'M', '𖹭'), - (0x16E4E, 'M', '𖹮'), - (0x16E4F, 'M', '𖹯'), - (0x16E50, 'M', '𖹰'), - (0x16E51, 'M', '𖹱'), - (0x16E52, 'M', '𖹲'), - (0x16E53, 'M', '𖹳'), - (0x16E54, 'M', '𖹴'), - (0x16E55, 'M', '𖹵'), - (0x16E56, 'M', '𖹶'), - (0x16E57, 'M', '𖹷'), - (0x16E58, 'M', '𖹸'), - (0x16E59, 'M', '𖹹'), - (0x16E5A, 'M', '𖹺'), - (0x16E5B, 'M', '𖹻'), - (0x16E5C, 'M', '𖹼'), - (0x16E5D, 'M', '𖹽'), - (0x16E5E, 'M', '𖹾'), - (0x16E5F, 'M', '𖹿'), - (0x16E60, 'V'), - (0x16E9B, 'X'), - (0x16F00, 'V'), - (0x16F4B, 'X'), - (0x16F4F, 'V'), - (0x16F88, 'X'), - (0x16F8F, 'V'), - (0x16FA0, 'X'), - (0x16FE0, 'V'), - (0x16FE5, 'X'), - (0x16FF0, 'V'), - (0x16FF2, 'X'), - (0x17000, 'V'), - (0x187F8, 'X'), - (0x18800, 'V'), - (0x18CD6, 'X'), - (0x18D00, 'V'), - (0x18D09, 'X'), - (0x1B000, 'V'), - (0x1B11F, 'X'), - (0x1B150, 'V'), - (0x1B153, 'X'), - (0x1B164, 'V'), - (0x1B168, 'X'), - (0x1B170, 'V'), - (0x1B2FC, 'X'), - (0x1BC00, 'V'), - (0x1BC6B, 'X'), - (0x1BC70, 'V'), - (0x1BC7D, 'X'), - (0x1BC80, 'V'), - (0x1BC89, 'X'), - (0x1BC90, 'V'), - (0x1BC9A, 'X'), - (0x1BC9C, 'V'), - (0x1BCA0, 'I'), - (0x1BCA4, 'X'), - (0x1D000, 'V'), - (0x1D0F6, 'X'), - (0x1D100, 'V'), - (0x1D127, 'X'), - (0x1D129, 'V'), - (0x1D15E, 'M', '𝅗𝅥'), - (0x1D15F, 'M', '𝅘𝅥'), - (0x1D160, 'M', '𝅘𝅥𝅮'), - (0x1D161, 'M', '𝅘𝅥𝅯'), - (0x1D162, 'M', '𝅘𝅥𝅰'), - (0x1D163, 'M', '𝅘𝅥𝅱'), - (0x1D164, 'M', '𝅘𝅥𝅲'), - (0x1D165, 'V'), - ] - -def _seg_59(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0x1D173, 'X'), - (0x1D17B, 'V'), - (0x1D1BB, 'M', '𝆹𝅥'), - (0x1D1BC, 'M', '𝆺𝅥'), - (0x1D1BD, 'M', '𝆹𝅥𝅮'), - (0x1D1BE, 'M', '𝆺𝅥𝅮'), - (0x1D1BF, 'M', '𝆹𝅥𝅯'), - (0x1D1C0, 'M', '𝆺𝅥𝅯'), - (0x1D1C1, 'V'), - (0x1D1E9, 'X'), - (0x1D200, 'V'), - (0x1D246, 'X'), - (0x1D2E0, 'V'), - (0x1D2F4, 'X'), - (0x1D300, 'V'), - (0x1D357, 'X'), - (0x1D360, 'V'), - (0x1D379, 'X'), - (0x1D400, 'M', 'a'), - (0x1D401, 'M', 'b'), - (0x1D402, 'M', 'c'), - (0x1D403, 'M', 'd'), - (0x1D404, 'M', 'e'), - (0x1D405, 'M', 'f'), - (0x1D406, 'M', 'g'), - (0x1D407, 'M', 'h'), - (0x1D408, 'M', 'i'), - (0x1D409, 'M', 'j'), - (0x1D40A, 'M', 'k'), - (0x1D40B, 'M', 'l'), - (0x1D40C, 'M', 'm'), - (0x1D40D, 'M', 'n'), - (0x1D40E, 'M', 'o'), - (0x1D40F, 'M', 'p'), - (0x1D410, 'M', 'q'), - (0x1D411, 'M', 'r'), - (0x1D412, 'M', 's'), - (0x1D413, 'M', 't'), - (0x1D414, 'M', 'u'), - (0x1D415, 'M', 'v'), - (0x1D416, 'M', 'w'), - (0x1D417, 'M', 'x'), - (0x1D418, 'M', 'y'), - (0x1D419, 'M', 'z'), - (0x1D41A, 'M', 'a'), - (0x1D41B, 'M', 'b'), - (0x1D41C, 'M', 'c'), - (0x1D41D, 'M', 'd'), - (0x1D41E, 'M', 'e'), - (0x1D41F, 'M', 'f'), - (0x1D420, 'M', 'g'), - (0x1D421, 'M', 'h'), - (0x1D422, 'M', 'i'), - (0x1D423, 'M', 'j'), - (0x1D424, 'M', 'k'), - (0x1D425, 'M', 'l'), - (0x1D426, 'M', 'm'), - (0x1D427, 'M', 'n'), - (0x1D428, 'M', 'o'), - (0x1D429, 'M', 'p'), - (0x1D42A, 'M', 'q'), - (0x1D42B, 'M', 'r'), - (0x1D42C, 'M', 's'), - (0x1D42D, 'M', 't'), - (0x1D42E, 'M', 'u'), - (0x1D42F, 'M', 'v'), - (0x1D430, 'M', 'w'), - (0x1D431, 'M', 'x'), - (0x1D432, 'M', 'y'), - (0x1D433, 'M', 'z'), - (0x1D434, 'M', 'a'), - (0x1D435, 'M', 'b'), - (0x1D436, 'M', 'c'), - (0x1D437, 'M', 'd'), - (0x1D438, 'M', 'e'), - (0x1D439, 'M', 'f'), - (0x1D43A, 'M', 'g'), - (0x1D43B, 'M', 'h'), - (0x1D43C, 'M', 'i'), - (0x1D43D, 'M', 'j'), - (0x1D43E, 'M', 'k'), - (0x1D43F, 'M', 'l'), - (0x1D440, 'M', 'm'), - (0x1D441, 'M', 'n'), - (0x1D442, 'M', 'o'), - (0x1D443, 'M', 'p'), - (0x1D444, 'M', 'q'), - (0x1D445, 'M', 'r'), - (0x1D446, 'M', 's'), - (0x1D447, 'M', 't'), - (0x1D448, 'M', 'u'), - (0x1D449, 'M', 'v'), - (0x1D44A, 'M', 'w'), - (0x1D44B, 'M', 'x'), - (0x1D44C, 'M', 'y'), - (0x1D44D, 'M', 'z'), - (0x1D44E, 'M', 'a'), - (0x1D44F, 'M', 'b'), - (0x1D450, 'M', 'c'), - (0x1D451, 'M', 'd'), - ] - -def _seg_60(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0x1D452, 'M', 'e'), - (0x1D453, 'M', 'f'), - (0x1D454, 'M', 'g'), - (0x1D455, 'X'), - (0x1D456, 'M', 'i'), - (0x1D457, 'M', 'j'), - (0x1D458, 'M', 'k'), - (0x1D459, 'M', 'l'), - (0x1D45A, 'M', 'm'), - (0x1D45B, 'M', 'n'), - (0x1D45C, 'M', 'o'), - (0x1D45D, 'M', 'p'), - (0x1D45E, 'M', 'q'), - (0x1D45F, 'M', 'r'), - (0x1D460, 'M', 's'), - (0x1D461, 'M', 't'), - (0x1D462, 'M', 'u'), - (0x1D463, 'M', 'v'), - (0x1D464, 'M', 'w'), - (0x1D465, 'M', 'x'), - (0x1D466, 'M', 'y'), - (0x1D467, 'M', 'z'), - (0x1D468, 'M', 'a'), - (0x1D469, 'M', 'b'), - (0x1D46A, 'M', 'c'), - (0x1D46B, 'M', 'd'), - (0x1D46C, 'M', 'e'), - (0x1D46D, 'M', 'f'), - (0x1D46E, 'M', 'g'), - (0x1D46F, 'M', 'h'), - (0x1D470, 'M', 'i'), - (0x1D471, 'M', 'j'), - (0x1D472, 'M', 'k'), - (0x1D473, 'M', 'l'), - (0x1D474, 'M', 'm'), - (0x1D475, 'M', 'n'), - (0x1D476, 'M', 'o'), - (0x1D477, 'M', 'p'), - (0x1D478, 'M', 'q'), - (0x1D479, 'M', 'r'), - (0x1D47A, 'M', 's'), - (0x1D47B, 'M', 't'), - (0x1D47C, 'M', 'u'), - (0x1D47D, 'M', 'v'), - (0x1D47E, 'M', 'w'), - (0x1D47F, 'M', 'x'), - (0x1D480, 'M', 'y'), - (0x1D481, 'M', 'z'), - (0x1D482, 'M', 'a'), - (0x1D483, 'M', 'b'), - (0x1D484, 'M', 'c'), - (0x1D485, 'M', 'd'), - (0x1D486, 'M', 'e'), - (0x1D487, 'M', 'f'), - (0x1D488, 'M', 'g'), - (0x1D489, 'M', 'h'), - (0x1D48A, 'M', 'i'), - (0x1D48B, 'M', 'j'), - (0x1D48C, 'M', 'k'), - (0x1D48D, 'M', 'l'), - (0x1D48E, 'M', 'm'), - (0x1D48F, 'M', 'n'), - (0x1D490, 'M', 'o'), - (0x1D491, 'M', 'p'), - (0x1D492, 'M', 'q'), - (0x1D493, 'M', 'r'), - (0x1D494, 'M', 's'), - (0x1D495, 'M', 't'), - (0x1D496, 'M', 'u'), - (0x1D497, 'M', 'v'), - (0x1D498, 'M', 'w'), - (0x1D499, 'M', 'x'), - (0x1D49A, 'M', 'y'), - (0x1D49B, 'M', 'z'), - (0x1D49C, 'M', 'a'), - (0x1D49D, 'X'), - (0x1D49E, 'M', 'c'), - (0x1D49F, 'M', 'd'), - (0x1D4A0, 'X'), - (0x1D4A2, 'M', 'g'), - (0x1D4A3, 'X'), - (0x1D4A5, 'M', 'j'), - (0x1D4A6, 'M', 'k'), - (0x1D4A7, 'X'), - (0x1D4A9, 'M', 'n'), - (0x1D4AA, 'M', 'o'), - (0x1D4AB, 'M', 'p'), - (0x1D4AC, 'M', 'q'), - (0x1D4AD, 'X'), - (0x1D4AE, 'M', 's'), - (0x1D4AF, 'M', 't'), - (0x1D4B0, 'M', 'u'), - (0x1D4B1, 'M', 'v'), - (0x1D4B2, 'M', 'w'), - (0x1D4B3, 'M', 'x'), - (0x1D4B4, 'M', 'y'), - (0x1D4B5, 'M', 'z'), - (0x1D4B6, 'M', 'a'), - (0x1D4B7, 'M', 'b'), - (0x1D4B8, 'M', 'c'), - ] - -def _seg_61(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0x1D4B9, 'M', 'd'), - (0x1D4BA, 'X'), - (0x1D4BB, 'M', 'f'), - (0x1D4BC, 'X'), - (0x1D4BD, 'M', 'h'), - (0x1D4BE, 'M', 'i'), - (0x1D4BF, 'M', 'j'), - (0x1D4C0, 'M', 'k'), - (0x1D4C1, 'M', 'l'), - (0x1D4C2, 'M', 'm'), - (0x1D4C3, 'M', 'n'), - (0x1D4C4, 'X'), - (0x1D4C5, 'M', 'p'), - (0x1D4C6, 'M', 'q'), - (0x1D4C7, 'M', 'r'), - (0x1D4C8, 'M', 's'), - (0x1D4C9, 'M', 't'), - (0x1D4CA, 'M', 'u'), - (0x1D4CB, 'M', 'v'), - (0x1D4CC, 'M', 'w'), - (0x1D4CD, 'M', 'x'), - (0x1D4CE, 'M', 'y'), - (0x1D4CF, 'M', 'z'), - (0x1D4D0, 'M', 'a'), - (0x1D4D1, 'M', 'b'), - (0x1D4D2, 'M', 'c'), - (0x1D4D3, 'M', 'd'), - (0x1D4D4, 'M', 'e'), - (0x1D4D5, 'M', 'f'), - (0x1D4D6, 'M', 'g'), - (0x1D4D7, 'M', 'h'), - (0x1D4D8, 'M', 'i'), - (0x1D4D9, 'M', 'j'), - (0x1D4DA, 'M', 'k'), - (0x1D4DB, 'M', 'l'), - (0x1D4DC, 'M', 'm'), - (0x1D4DD, 'M', 'n'), - (0x1D4DE, 'M', 'o'), - (0x1D4DF, 'M', 'p'), - (0x1D4E0, 'M', 'q'), - (0x1D4E1, 'M', 'r'), - (0x1D4E2, 'M', 's'), - (0x1D4E3, 'M', 't'), - (0x1D4E4, 'M', 'u'), - (0x1D4E5, 'M', 'v'), - (0x1D4E6, 'M', 'w'), - (0x1D4E7, 'M', 'x'), - (0x1D4E8, 'M', 'y'), - (0x1D4E9, 'M', 'z'), - (0x1D4EA, 'M', 'a'), - (0x1D4EB, 'M', 'b'), - (0x1D4EC, 'M', 'c'), - (0x1D4ED, 'M', 'd'), - (0x1D4EE, 'M', 'e'), - (0x1D4EF, 'M', 'f'), - (0x1D4F0, 'M', 'g'), - (0x1D4F1, 'M', 'h'), - (0x1D4F2, 'M', 'i'), - (0x1D4F3, 'M', 'j'), - (0x1D4F4, 'M', 'k'), - (0x1D4F5, 'M', 'l'), - (0x1D4F6, 'M', 'm'), - (0x1D4F7, 'M', 'n'), - (0x1D4F8, 'M', 'o'), - (0x1D4F9, 'M', 'p'), - (0x1D4FA, 'M', 'q'), - (0x1D4FB, 'M', 'r'), - (0x1D4FC, 'M', 's'), - (0x1D4FD, 'M', 't'), - (0x1D4FE, 'M', 'u'), - (0x1D4FF, 'M', 'v'), - (0x1D500, 'M', 'w'), - (0x1D501, 'M', 'x'), - (0x1D502, 'M', 'y'), - (0x1D503, 'M', 'z'), - (0x1D504, 'M', 'a'), - (0x1D505, 'M', 'b'), - (0x1D506, 'X'), - (0x1D507, 'M', 'd'), - (0x1D508, 'M', 'e'), - (0x1D509, 'M', 'f'), - (0x1D50A, 'M', 'g'), - (0x1D50B, 'X'), - (0x1D50D, 'M', 'j'), - (0x1D50E, 'M', 'k'), - (0x1D50F, 'M', 'l'), - (0x1D510, 'M', 'm'), - (0x1D511, 'M', 'n'), - (0x1D512, 'M', 'o'), - (0x1D513, 'M', 'p'), - (0x1D514, 'M', 'q'), - (0x1D515, 'X'), - (0x1D516, 'M', 's'), - (0x1D517, 'M', 't'), - (0x1D518, 'M', 'u'), - (0x1D519, 'M', 'v'), - (0x1D51A, 'M', 'w'), - (0x1D51B, 'M', 'x'), - (0x1D51C, 'M', 'y'), - (0x1D51D, 'X'), - ] - -def _seg_62(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0x1D51E, 'M', 'a'), - (0x1D51F, 'M', 'b'), - (0x1D520, 'M', 'c'), - (0x1D521, 'M', 'd'), - (0x1D522, 'M', 'e'), - (0x1D523, 'M', 'f'), - (0x1D524, 'M', 'g'), - (0x1D525, 'M', 'h'), - (0x1D526, 'M', 'i'), - (0x1D527, 'M', 'j'), - (0x1D528, 'M', 'k'), - (0x1D529, 'M', 'l'), - (0x1D52A, 'M', 'm'), - (0x1D52B, 'M', 'n'), - (0x1D52C, 'M', 'o'), - (0x1D52D, 'M', 'p'), - (0x1D52E, 'M', 'q'), - (0x1D52F, 'M', 'r'), - (0x1D530, 'M', 's'), - (0x1D531, 'M', 't'), - (0x1D532, 'M', 'u'), - (0x1D533, 'M', 'v'), - (0x1D534, 'M', 'w'), - (0x1D535, 'M', 'x'), - (0x1D536, 'M', 'y'), - (0x1D537, 'M', 'z'), - (0x1D538, 'M', 'a'), - (0x1D539, 'M', 'b'), - (0x1D53A, 'X'), - (0x1D53B, 'M', 'd'), - (0x1D53C, 'M', 'e'), - (0x1D53D, 'M', 'f'), - (0x1D53E, 'M', 'g'), - (0x1D53F, 'X'), - (0x1D540, 'M', 'i'), - (0x1D541, 'M', 'j'), - (0x1D542, 'M', 'k'), - (0x1D543, 'M', 'l'), - (0x1D544, 'M', 'm'), - (0x1D545, 'X'), - (0x1D546, 'M', 'o'), - (0x1D547, 'X'), - (0x1D54A, 'M', 's'), - (0x1D54B, 'M', 't'), - (0x1D54C, 'M', 'u'), - (0x1D54D, 'M', 'v'), - (0x1D54E, 'M', 'w'), - (0x1D54F, 'M', 'x'), - (0x1D550, 'M', 'y'), - (0x1D551, 'X'), - (0x1D552, 'M', 'a'), - (0x1D553, 'M', 'b'), - (0x1D554, 'M', 'c'), - (0x1D555, 'M', 'd'), - (0x1D556, 'M', 'e'), - (0x1D557, 'M', 'f'), - (0x1D558, 'M', 'g'), - (0x1D559, 'M', 'h'), - (0x1D55A, 'M', 'i'), - (0x1D55B, 'M', 'j'), - (0x1D55C, 'M', 'k'), - (0x1D55D, 'M', 'l'), - (0x1D55E, 'M', 'm'), - (0x1D55F, 'M', 'n'), - (0x1D560, 'M', 'o'), - (0x1D561, 'M', 'p'), - (0x1D562, 'M', 'q'), - (0x1D563, 'M', 'r'), - (0x1D564, 'M', 's'), - (0x1D565, 'M', 't'), - (0x1D566, 'M', 'u'), - (0x1D567, 'M', 'v'), - (0x1D568, 'M', 'w'), - (0x1D569, 'M', 'x'), - (0x1D56A, 'M', 'y'), - (0x1D56B, 'M', 'z'), - (0x1D56C, 'M', 'a'), - (0x1D56D, 'M', 'b'), - (0x1D56E, 'M', 'c'), - (0x1D56F, 'M', 'd'), - (0x1D570, 'M', 'e'), - (0x1D571, 'M', 'f'), - (0x1D572, 'M', 'g'), - (0x1D573, 'M', 'h'), - (0x1D574, 'M', 'i'), - (0x1D575, 'M', 'j'), - (0x1D576, 'M', 'k'), - (0x1D577, 'M', 'l'), - (0x1D578, 'M', 'm'), - (0x1D579, 'M', 'n'), - (0x1D57A, 'M', 'o'), - (0x1D57B, 'M', 'p'), - (0x1D57C, 'M', 'q'), - (0x1D57D, 'M', 'r'), - (0x1D57E, 'M', 's'), - (0x1D57F, 'M', 't'), - (0x1D580, 'M', 'u'), - (0x1D581, 'M', 'v'), - (0x1D582, 'M', 'w'), - (0x1D583, 'M', 'x'), - ] - -def _seg_63(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0x1D584, 'M', 'y'), - (0x1D585, 'M', 'z'), - (0x1D586, 'M', 'a'), - (0x1D587, 'M', 'b'), - (0x1D588, 'M', 'c'), - (0x1D589, 'M', 'd'), - (0x1D58A, 'M', 'e'), - (0x1D58B, 'M', 'f'), - (0x1D58C, 'M', 'g'), - (0x1D58D, 'M', 'h'), - (0x1D58E, 'M', 'i'), - (0x1D58F, 'M', 'j'), - (0x1D590, 'M', 'k'), - (0x1D591, 'M', 'l'), - (0x1D592, 'M', 'm'), - (0x1D593, 'M', 'n'), - (0x1D594, 'M', 'o'), - (0x1D595, 'M', 'p'), - (0x1D596, 'M', 'q'), - (0x1D597, 'M', 'r'), - (0x1D598, 'M', 's'), - (0x1D599, 'M', 't'), - (0x1D59A, 'M', 'u'), - (0x1D59B, 'M', 'v'), - (0x1D59C, 'M', 'w'), - (0x1D59D, 'M', 'x'), - (0x1D59E, 'M', 'y'), - (0x1D59F, 'M', 'z'), - (0x1D5A0, 'M', 'a'), - (0x1D5A1, 'M', 'b'), - (0x1D5A2, 'M', 'c'), - (0x1D5A3, 'M', 'd'), - (0x1D5A4, 'M', 'e'), - (0x1D5A5, 'M', 'f'), - (0x1D5A6, 'M', 'g'), - (0x1D5A7, 'M', 'h'), - (0x1D5A8, 'M', 'i'), - (0x1D5A9, 'M', 'j'), - (0x1D5AA, 'M', 'k'), - (0x1D5AB, 'M', 'l'), - (0x1D5AC, 'M', 'm'), - (0x1D5AD, 'M', 'n'), - (0x1D5AE, 'M', 'o'), - (0x1D5AF, 'M', 'p'), - (0x1D5B0, 'M', 'q'), - (0x1D5B1, 'M', 'r'), - (0x1D5B2, 'M', 's'), - (0x1D5B3, 'M', 't'), - (0x1D5B4, 'M', 'u'), - (0x1D5B5, 'M', 'v'), - (0x1D5B6, 'M', 'w'), - (0x1D5B7, 'M', 'x'), - (0x1D5B8, 'M', 'y'), - (0x1D5B9, 'M', 'z'), - (0x1D5BA, 'M', 'a'), - (0x1D5BB, 'M', 'b'), - (0x1D5BC, 'M', 'c'), - (0x1D5BD, 'M', 'd'), - (0x1D5BE, 'M', 'e'), - (0x1D5BF, 'M', 'f'), - (0x1D5C0, 'M', 'g'), - (0x1D5C1, 'M', 'h'), - (0x1D5C2, 'M', 'i'), - (0x1D5C3, 'M', 'j'), - (0x1D5C4, 'M', 'k'), - (0x1D5C5, 'M', 'l'), - (0x1D5C6, 'M', 'm'), - (0x1D5C7, 'M', 'n'), - (0x1D5C8, 'M', 'o'), - (0x1D5C9, 'M', 'p'), - (0x1D5CA, 'M', 'q'), - (0x1D5CB, 'M', 'r'), - (0x1D5CC, 'M', 's'), - (0x1D5CD, 'M', 't'), - (0x1D5CE, 'M', 'u'), - (0x1D5CF, 'M', 'v'), - (0x1D5D0, 'M', 'w'), - (0x1D5D1, 'M', 'x'), - (0x1D5D2, 'M', 'y'), - (0x1D5D3, 'M', 'z'), - (0x1D5D4, 'M', 'a'), - (0x1D5D5, 'M', 'b'), - (0x1D5D6, 'M', 'c'), - (0x1D5D7, 'M', 'd'), - (0x1D5D8, 'M', 'e'), - (0x1D5D9, 'M', 'f'), - (0x1D5DA, 'M', 'g'), - (0x1D5DB, 'M', 'h'), - (0x1D5DC, 'M', 'i'), - (0x1D5DD, 'M', 'j'), - (0x1D5DE, 'M', 'k'), - (0x1D5DF, 'M', 'l'), - (0x1D5E0, 'M', 'm'), - (0x1D5E1, 'M', 'n'), - (0x1D5E2, 'M', 'o'), - (0x1D5E3, 'M', 'p'), - (0x1D5E4, 'M', 'q'), - (0x1D5E5, 'M', 'r'), - (0x1D5E6, 'M', 's'), - (0x1D5E7, 'M', 't'), - ] - -def _seg_64(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0x1D5E8, 'M', 'u'), - (0x1D5E9, 'M', 'v'), - (0x1D5EA, 'M', 'w'), - (0x1D5EB, 'M', 'x'), - (0x1D5EC, 'M', 'y'), - (0x1D5ED, 'M', 'z'), - (0x1D5EE, 'M', 'a'), - (0x1D5EF, 'M', 'b'), - (0x1D5F0, 'M', 'c'), - (0x1D5F1, 'M', 'd'), - (0x1D5F2, 'M', 'e'), - (0x1D5F3, 'M', 'f'), - (0x1D5F4, 'M', 'g'), - (0x1D5F5, 'M', 'h'), - (0x1D5F6, 'M', 'i'), - (0x1D5F7, 'M', 'j'), - (0x1D5F8, 'M', 'k'), - (0x1D5F9, 'M', 'l'), - (0x1D5FA, 'M', 'm'), - (0x1D5FB, 'M', 'n'), - (0x1D5FC, 'M', 'o'), - (0x1D5FD, 'M', 'p'), - (0x1D5FE, 'M', 'q'), - (0x1D5FF, 'M', 'r'), - (0x1D600, 'M', 's'), - (0x1D601, 'M', 't'), - (0x1D602, 'M', 'u'), - (0x1D603, 'M', 'v'), - (0x1D604, 'M', 'w'), - (0x1D605, 'M', 'x'), - (0x1D606, 'M', 'y'), - (0x1D607, 'M', 'z'), - (0x1D608, 'M', 'a'), - (0x1D609, 'M', 'b'), - (0x1D60A, 'M', 'c'), - (0x1D60B, 'M', 'd'), - (0x1D60C, 'M', 'e'), - (0x1D60D, 'M', 'f'), - (0x1D60E, 'M', 'g'), - (0x1D60F, 'M', 'h'), - (0x1D610, 'M', 'i'), - (0x1D611, 'M', 'j'), - (0x1D612, 'M', 'k'), - (0x1D613, 'M', 'l'), - (0x1D614, 'M', 'm'), - (0x1D615, 'M', 'n'), - (0x1D616, 'M', 'o'), - (0x1D617, 'M', 'p'), - (0x1D618, 'M', 'q'), - (0x1D619, 'M', 'r'), - (0x1D61A, 'M', 's'), - (0x1D61B, 'M', 't'), - (0x1D61C, 'M', 'u'), - (0x1D61D, 'M', 'v'), - (0x1D61E, 'M', 'w'), - (0x1D61F, 'M', 'x'), - (0x1D620, 'M', 'y'), - (0x1D621, 'M', 'z'), - (0x1D622, 'M', 'a'), - (0x1D623, 'M', 'b'), - (0x1D624, 'M', 'c'), - (0x1D625, 'M', 'd'), - (0x1D626, 'M', 'e'), - (0x1D627, 'M', 'f'), - (0x1D628, 'M', 'g'), - (0x1D629, 'M', 'h'), - (0x1D62A, 'M', 'i'), - (0x1D62B, 'M', 'j'), - (0x1D62C, 'M', 'k'), - (0x1D62D, 'M', 'l'), - (0x1D62E, 'M', 'm'), - (0x1D62F, 'M', 'n'), - (0x1D630, 'M', 'o'), - (0x1D631, 'M', 'p'), - (0x1D632, 'M', 'q'), - (0x1D633, 'M', 'r'), - (0x1D634, 'M', 's'), - (0x1D635, 'M', 't'), - (0x1D636, 'M', 'u'), - (0x1D637, 'M', 'v'), - (0x1D638, 'M', 'w'), - (0x1D639, 'M', 'x'), - (0x1D63A, 'M', 'y'), - (0x1D63B, 'M', 'z'), - (0x1D63C, 'M', 'a'), - (0x1D63D, 'M', 'b'), - (0x1D63E, 'M', 'c'), - (0x1D63F, 'M', 'd'), - (0x1D640, 'M', 'e'), - (0x1D641, 'M', 'f'), - (0x1D642, 'M', 'g'), - (0x1D643, 'M', 'h'), - (0x1D644, 'M', 'i'), - (0x1D645, 'M', 'j'), - (0x1D646, 'M', 'k'), - (0x1D647, 'M', 'l'), - (0x1D648, 'M', 'm'), - (0x1D649, 'M', 'n'), - (0x1D64A, 'M', 'o'), - (0x1D64B, 'M', 'p'), - ] - -def _seg_65(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0x1D64C, 'M', 'q'), - (0x1D64D, 'M', 'r'), - (0x1D64E, 'M', 's'), - (0x1D64F, 'M', 't'), - (0x1D650, 'M', 'u'), - (0x1D651, 'M', 'v'), - (0x1D652, 'M', 'w'), - (0x1D653, 'M', 'x'), - (0x1D654, 'M', 'y'), - (0x1D655, 'M', 'z'), - (0x1D656, 'M', 'a'), - (0x1D657, 'M', 'b'), - (0x1D658, 'M', 'c'), - (0x1D659, 'M', 'd'), - (0x1D65A, 'M', 'e'), - (0x1D65B, 'M', 'f'), - (0x1D65C, 'M', 'g'), - (0x1D65D, 'M', 'h'), - (0x1D65E, 'M', 'i'), - (0x1D65F, 'M', 'j'), - (0x1D660, 'M', 'k'), - (0x1D661, 'M', 'l'), - (0x1D662, 'M', 'm'), - (0x1D663, 'M', 'n'), - (0x1D664, 'M', 'o'), - (0x1D665, 'M', 'p'), - (0x1D666, 'M', 'q'), - (0x1D667, 'M', 'r'), - (0x1D668, 'M', 's'), - (0x1D669, 'M', 't'), - (0x1D66A, 'M', 'u'), - (0x1D66B, 'M', 'v'), - (0x1D66C, 'M', 'w'), - (0x1D66D, 'M', 'x'), - (0x1D66E, 'M', 'y'), - (0x1D66F, 'M', 'z'), - (0x1D670, 'M', 'a'), - (0x1D671, 'M', 'b'), - (0x1D672, 'M', 'c'), - (0x1D673, 'M', 'd'), - (0x1D674, 'M', 'e'), - (0x1D675, 'M', 'f'), - (0x1D676, 'M', 'g'), - (0x1D677, 'M', 'h'), - (0x1D678, 'M', 'i'), - (0x1D679, 'M', 'j'), - (0x1D67A, 'M', 'k'), - (0x1D67B, 'M', 'l'), - (0x1D67C, 'M', 'm'), - (0x1D67D, 'M', 'n'), - (0x1D67E, 'M', 'o'), - (0x1D67F, 'M', 'p'), - (0x1D680, 'M', 'q'), - (0x1D681, 'M', 'r'), - (0x1D682, 'M', 's'), - (0x1D683, 'M', 't'), - (0x1D684, 'M', 'u'), - (0x1D685, 'M', 'v'), - (0x1D686, 'M', 'w'), - (0x1D687, 'M', 'x'), - (0x1D688, 'M', 'y'), - (0x1D689, 'M', 'z'), - (0x1D68A, 'M', 'a'), - (0x1D68B, 'M', 'b'), - (0x1D68C, 'M', 'c'), - (0x1D68D, 'M', 'd'), - (0x1D68E, 'M', 'e'), - (0x1D68F, 'M', 'f'), - (0x1D690, 'M', 'g'), - (0x1D691, 'M', 'h'), - (0x1D692, 'M', 'i'), - (0x1D693, 'M', 'j'), - (0x1D694, 'M', 'k'), - (0x1D695, 'M', 'l'), - (0x1D696, 'M', 'm'), - (0x1D697, 'M', 'n'), - (0x1D698, 'M', 'o'), - (0x1D699, 'M', 'p'), - (0x1D69A, 'M', 'q'), - (0x1D69B, 'M', 'r'), - (0x1D69C, 'M', 's'), - (0x1D69D, 'M', 't'), - (0x1D69E, 'M', 'u'), - (0x1D69F, 'M', 'v'), - (0x1D6A0, 'M', 'w'), - (0x1D6A1, 'M', 'x'), - (0x1D6A2, 'M', 'y'), - (0x1D6A3, 'M', 'z'), - (0x1D6A4, 'M', 'ı'), - (0x1D6A5, 'M', 'ȷ'), - (0x1D6A6, 'X'), - (0x1D6A8, 'M', 'α'), - (0x1D6A9, 'M', 'β'), - (0x1D6AA, 'M', 'γ'), - (0x1D6AB, 'M', 'δ'), - (0x1D6AC, 'M', 'ε'), - (0x1D6AD, 'M', 'ζ'), - (0x1D6AE, 'M', 'η'), - (0x1D6AF, 'M', 'θ'), - (0x1D6B0, 'M', 'ι'), - ] - -def _seg_66(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0x1D6B1, 'M', 'κ'), - (0x1D6B2, 'M', 'λ'), - (0x1D6B3, 'M', 'μ'), - (0x1D6B4, 'M', 'ν'), - (0x1D6B5, 'M', 'ξ'), - (0x1D6B6, 'M', 'ο'), - (0x1D6B7, 'M', 'π'), - (0x1D6B8, 'M', 'ρ'), - (0x1D6B9, 'M', 'θ'), - (0x1D6BA, 'M', 'σ'), - (0x1D6BB, 'M', 'τ'), - (0x1D6BC, 'M', 'υ'), - (0x1D6BD, 'M', 'φ'), - (0x1D6BE, 'M', 'χ'), - (0x1D6BF, 'M', 'ψ'), - (0x1D6C0, 'M', 'ω'), - (0x1D6C1, 'M', '∇'), - (0x1D6C2, 'M', 'α'), - (0x1D6C3, 'M', 'β'), - (0x1D6C4, 'M', 'γ'), - (0x1D6C5, 'M', 'δ'), - (0x1D6C6, 'M', 'ε'), - (0x1D6C7, 'M', 'ζ'), - (0x1D6C8, 'M', 'η'), - (0x1D6C9, 'M', 'θ'), - (0x1D6CA, 'M', 'ι'), - (0x1D6CB, 'M', 'κ'), - (0x1D6CC, 'M', 'λ'), - (0x1D6CD, 'M', 'μ'), - (0x1D6CE, 'M', 'ν'), - (0x1D6CF, 'M', 'ξ'), - (0x1D6D0, 'M', 'ο'), - (0x1D6D1, 'M', 'π'), - (0x1D6D2, 'M', 'ρ'), - (0x1D6D3, 'M', 'σ'), - (0x1D6D5, 'M', 'τ'), - (0x1D6D6, 'M', 'υ'), - (0x1D6D7, 'M', 'φ'), - (0x1D6D8, 'M', 'χ'), - (0x1D6D9, 'M', 'ψ'), - (0x1D6DA, 'M', 'ω'), - (0x1D6DB, 'M', '∂'), - (0x1D6DC, 'M', 'ε'), - (0x1D6DD, 'M', 'θ'), - (0x1D6DE, 'M', 'κ'), - (0x1D6DF, 'M', 'φ'), - (0x1D6E0, 'M', 'ρ'), - (0x1D6E1, 'M', 'π'), - (0x1D6E2, 'M', 'α'), - (0x1D6E3, 'M', 'β'), - (0x1D6E4, 'M', 'γ'), - (0x1D6E5, 'M', 'δ'), - (0x1D6E6, 'M', 'ε'), - (0x1D6E7, 'M', 'ζ'), - (0x1D6E8, 'M', 'η'), - (0x1D6E9, 'M', 'θ'), - (0x1D6EA, 'M', 'ι'), - (0x1D6EB, 'M', 'κ'), - (0x1D6EC, 'M', 'λ'), - (0x1D6ED, 'M', 'μ'), - (0x1D6EE, 'M', 'ν'), - (0x1D6EF, 'M', 'ξ'), - (0x1D6F0, 'M', 'ο'), - (0x1D6F1, 'M', 'π'), - (0x1D6F2, 'M', 'ρ'), - (0x1D6F3, 'M', 'θ'), - (0x1D6F4, 'M', 'σ'), - (0x1D6F5, 'M', 'τ'), - (0x1D6F6, 'M', 'υ'), - (0x1D6F7, 'M', 'φ'), - (0x1D6F8, 'M', 'χ'), - (0x1D6F9, 'M', 'ψ'), - (0x1D6FA, 'M', 'ω'), - (0x1D6FB, 'M', '∇'), - (0x1D6FC, 'M', 'α'), - (0x1D6FD, 'M', 'β'), - (0x1D6FE, 'M', 'γ'), - (0x1D6FF, 'M', 'δ'), - (0x1D700, 'M', 'ε'), - (0x1D701, 'M', 'ζ'), - (0x1D702, 'M', 'η'), - (0x1D703, 'M', 'θ'), - (0x1D704, 'M', 'ι'), - (0x1D705, 'M', 'κ'), - (0x1D706, 'M', 'λ'), - (0x1D707, 'M', 'μ'), - (0x1D708, 'M', 'ν'), - (0x1D709, 'M', 'ξ'), - (0x1D70A, 'M', 'ο'), - (0x1D70B, 'M', 'π'), - (0x1D70C, 'M', 'ρ'), - (0x1D70D, 'M', 'σ'), - (0x1D70F, 'M', 'τ'), - (0x1D710, 'M', 'υ'), - (0x1D711, 'M', 'φ'), - (0x1D712, 'M', 'χ'), - (0x1D713, 'M', 'ψ'), - (0x1D714, 'M', 'ω'), - (0x1D715, 'M', '∂'), - (0x1D716, 'M', 'ε'), - ] - -def _seg_67(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0x1D717, 'M', 'θ'), - (0x1D718, 'M', 'κ'), - (0x1D719, 'M', 'φ'), - (0x1D71A, 'M', 'ρ'), - (0x1D71B, 'M', 'π'), - (0x1D71C, 'M', 'α'), - (0x1D71D, 'M', 'β'), - (0x1D71E, 'M', 'γ'), - (0x1D71F, 'M', 'δ'), - (0x1D720, 'M', 'ε'), - (0x1D721, 'M', 'ζ'), - (0x1D722, 'M', 'η'), - (0x1D723, 'M', 'θ'), - (0x1D724, 'M', 'ι'), - (0x1D725, 'M', 'κ'), - (0x1D726, 'M', 'λ'), - (0x1D727, 'M', 'μ'), - (0x1D728, 'M', 'ν'), - (0x1D729, 'M', 'ξ'), - (0x1D72A, 'M', 'ο'), - (0x1D72B, 'M', 'π'), - (0x1D72C, 'M', 'ρ'), - (0x1D72D, 'M', 'θ'), - (0x1D72E, 'M', 'σ'), - (0x1D72F, 'M', 'τ'), - (0x1D730, 'M', 'υ'), - (0x1D731, 'M', 'φ'), - (0x1D732, 'M', 'χ'), - (0x1D733, 'M', 'ψ'), - (0x1D734, 'M', 'ω'), - (0x1D735, 'M', '∇'), - (0x1D736, 'M', 'α'), - (0x1D737, 'M', 'β'), - (0x1D738, 'M', 'γ'), - (0x1D739, 'M', 'δ'), - (0x1D73A, 'M', 'ε'), - (0x1D73B, 'M', 'ζ'), - (0x1D73C, 'M', 'η'), - (0x1D73D, 'M', 'θ'), - (0x1D73E, 'M', 'ι'), - (0x1D73F, 'M', 'κ'), - (0x1D740, 'M', 'λ'), - (0x1D741, 'M', 'μ'), - (0x1D742, 'M', 'ν'), - (0x1D743, 'M', 'ξ'), - (0x1D744, 'M', 'ο'), - (0x1D745, 'M', 'π'), - (0x1D746, 'M', 'ρ'), - (0x1D747, 'M', 'σ'), - (0x1D749, 'M', 'τ'), - (0x1D74A, 'M', 'υ'), - (0x1D74B, 'M', 'φ'), - (0x1D74C, 'M', 'χ'), - (0x1D74D, 'M', 'ψ'), - (0x1D74E, 'M', 'ω'), - (0x1D74F, 'M', '∂'), - (0x1D750, 'M', 'ε'), - (0x1D751, 'M', 'θ'), - (0x1D752, 'M', 'κ'), - (0x1D753, 'M', 'φ'), - (0x1D754, 'M', 'ρ'), - (0x1D755, 'M', 'π'), - (0x1D756, 'M', 'α'), - (0x1D757, 'M', 'β'), - (0x1D758, 'M', 'γ'), - (0x1D759, 'M', 'δ'), - (0x1D75A, 'M', 'ε'), - (0x1D75B, 'M', 'ζ'), - (0x1D75C, 'M', 'η'), - (0x1D75D, 'M', 'θ'), - (0x1D75E, 'M', 'ι'), - (0x1D75F, 'M', 'κ'), - (0x1D760, 'M', 'λ'), - (0x1D761, 'M', 'μ'), - (0x1D762, 'M', 'ν'), - (0x1D763, 'M', 'ξ'), - (0x1D764, 'M', 'ο'), - (0x1D765, 'M', 'π'), - (0x1D766, 'M', 'ρ'), - (0x1D767, 'M', 'θ'), - (0x1D768, 'M', 'σ'), - (0x1D769, 'M', 'τ'), - (0x1D76A, 'M', 'υ'), - (0x1D76B, 'M', 'φ'), - (0x1D76C, 'M', 'χ'), - (0x1D76D, 'M', 'ψ'), - (0x1D76E, 'M', 'ω'), - (0x1D76F, 'M', '∇'), - (0x1D770, 'M', 'α'), - (0x1D771, 'M', 'β'), - (0x1D772, 'M', 'γ'), - (0x1D773, 'M', 'δ'), - (0x1D774, 'M', 'ε'), - (0x1D775, 'M', 'ζ'), - (0x1D776, 'M', 'η'), - (0x1D777, 'M', 'θ'), - (0x1D778, 'M', 'ι'), - (0x1D779, 'M', 'κ'), - (0x1D77A, 'M', 'λ'), - (0x1D77B, 'M', 'μ'), - ] - -def _seg_68(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0x1D77C, 'M', 'ν'), - (0x1D77D, 'M', 'ξ'), - (0x1D77E, 'M', 'ο'), - (0x1D77F, 'M', 'π'), - (0x1D780, 'M', 'ρ'), - (0x1D781, 'M', 'σ'), - (0x1D783, 'M', 'τ'), - (0x1D784, 'M', 'υ'), - (0x1D785, 'M', 'φ'), - (0x1D786, 'M', 'χ'), - (0x1D787, 'M', 'ψ'), - (0x1D788, 'M', 'ω'), - (0x1D789, 'M', '∂'), - (0x1D78A, 'M', 'ε'), - (0x1D78B, 'M', 'θ'), - (0x1D78C, 'M', 'κ'), - (0x1D78D, 'M', 'φ'), - (0x1D78E, 'M', 'ρ'), - (0x1D78F, 'M', 'π'), - (0x1D790, 'M', 'α'), - (0x1D791, 'M', 'β'), - (0x1D792, 'M', 'γ'), - (0x1D793, 'M', 'δ'), - (0x1D794, 'M', 'ε'), - (0x1D795, 'M', 'ζ'), - (0x1D796, 'M', 'η'), - (0x1D797, 'M', 'θ'), - (0x1D798, 'M', 'ι'), - (0x1D799, 'M', 'κ'), - (0x1D79A, 'M', 'λ'), - (0x1D79B, 'M', 'μ'), - (0x1D79C, 'M', 'ν'), - (0x1D79D, 'M', 'ξ'), - (0x1D79E, 'M', 'ο'), - (0x1D79F, 'M', 'π'), - (0x1D7A0, 'M', 'ρ'), - (0x1D7A1, 'M', 'θ'), - (0x1D7A2, 'M', 'σ'), - (0x1D7A3, 'M', 'τ'), - (0x1D7A4, 'M', 'υ'), - (0x1D7A5, 'M', 'φ'), - (0x1D7A6, 'M', 'χ'), - (0x1D7A7, 'M', 'ψ'), - (0x1D7A8, 'M', 'ω'), - (0x1D7A9, 'M', '∇'), - (0x1D7AA, 'M', 'α'), - (0x1D7AB, 'M', 'β'), - (0x1D7AC, 'M', 'γ'), - (0x1D7AD, 'M', 'δ'), - (0x1D7AE, 'M', 'ε'), - (0x1D7AF, 'M', 'ζ'), - (0x1D7B0, 'M', 'η'), - (0x1D7B1, 'M', 'θ'), - (0x1D7B2, 'M', 'ι'), - (0x1D7B3, 'M', 'κ'), - (0x1D7B4, 'M', 'λ'), - (0x1D7B5, 'M', 'μ'), - (0x1D7B6, 'M', 'ν'), - (0x1D7B7, 'M', 'ξ'), - (0x1D7B8, 'M', 'ο'), - (0x1D7B9, 'M', 'π'), - (0x1D7BA, 'M', 'ρ'), - (0x1D7BB, 'M', 'σ'), - (0x1D7BD, 'M', 'τ'), - (0x1D7BE, 'M', 'υ'), - (0x1D7BF, 'M', 'φ'), - (0x1D7C0, 'M', 'χ'), - (0x1D7C1, 'M', 'ψ'), - (0x1D7C2, 'M', 'ω'), - (0x1D7C3, 'M', '∂'), - (0x1D7C4, 'M', 'ε'), - (0x1D7C5, 'M', 'θ'), - (0x1D7C6, 'M', 'κ'), - (0x1D7C7, 'M', 'φ'), - (0x1D7C8, 'M', 'ρ'), - (0x1D7C9, 'M', 'π'), - (0x1D7CA, 'M', 'ϝ'), - (0x1D7CC, 'X'), - (0x1D7CE, 'M', '0'), - (0x1D7CF, 'M', '1'), - (0x1D7D0, 'M', '2'), - (0x1D7D1, 'M', '3'), - (0x1D7D2, 'M', '4'), - (0x1D7D3, 'M', '5'), - (0x1D7D4, 'M', '6'), - (0x1D7D5, 'M', '7'), - (0x1D7D6, 'M', '8'), - (0x1D7D7, 'M', '9'), - (0x1D7D8, 'M', '0'), - (0x1D7D9, 'M', '1'), - (0x1D7DA, 'M', '2'), - (0x1D7DB, 'M', '3'), - (0x1D7DC, 'M', '4'), - (0x1D7DD, 'M', '5'), - (0x1D7DE, 'M', '6'), - (0x1D7DF, 'M', '7'), - (0x1D7E0, 'M', '8'), - (0x1D7E1, 'M', '9'), - (0x1D7E2, 'M', '0'), - (0x1D7E3, 'M', '1'), - ] - -def _seg_69(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0x1D7E4, 'M', '2'), - (0x1D7E5, 'M', '3'), - (0x1D7E6, 'M', '4'), - (0x1D7E7, 'M', '5'), - (0x1D7E8, 'M', '6'), - (0x1D7E9, 'M', '7'), - (0x1D7EA, 'M', '8'), - (0x1D7EB, 'M', '9'), - (0x1D7EC, 'M', '0'), - (0x1D7ED, 'M', '1'), - (0x1D7EE, 'M', '2'), - (0x1D7EF, 'M', '3'), - (0x1D7F0, 'M', '4'), - (0x1D7F1, 'M', '5'), - (0x1D7F2, 'M', '6'), - (0x1D7F3, 'M', '7'), - (0x1D7F4, 'M', '8'), - (0x1D7F5, 'M', '9'), - (0x1D7F6, 'M', '0'), - (0x1D7F7, 'M', '1'), - (0x1D7F8, 'M', '2'), - (0x1D7F9, 'M', '3'), - (0x1D7FA, 'M', '4'), - (0x1D7FB, 'M', '5'), - (0x1D7FC, 'M', '6'), - (0x1D7FD, 'M', '7'), - (0x1D7FE, 'M', '8'), - (0x1D7FF, 'M', '9'), - (0x1D800, 'V'), - (0x1DA8C, 'X'), - (0x1DA9B, 'V'), - (0x1DAA0, 'X'), - (0x1DAA1, 'V'), - (0x1DAB0, 'X'), - (0x1E000, 'V'), - (0x1E007, 'X'), - (0x1E008, 'V'), - (0x1E019, 'X'), - (0x1E01B, 'V'), - (0x1E022, 'X'), - (0x1E023, 'V'), - (0x1E025, 'X'), - (0x1E026, 'V'), - (0x1E02B, 'X'), - (0x1E100, 'V'), - (0x1E12D, 'X'), - (0x1E130, 'V'), - (0x1E13E, 'X'), - (0x1E140, 'V'), - (0x1E14A, 'X'), - (0x1E14E, 'V'), - (0x1E150, 'X'), - (0x1E2C0, 'V'), - (0x1E2FA, 'X'), - (0x1E2FF, 'V'), - (0x1E300, 'X'), - (0x1E800, 'V'), - (0x1E8C5, 'X'), - (0x1E8C7, 'V'), - (0x1E8D7, 'X'), - (0x1E900, 'M', '𞤢'), - (0x1E901, 'M', '𞤣'), - (0x1E902, 'M', '𞤤'), - (0x1E903, 'M', '𞤥'), - (0x1E904, 'M', '𞤦'), - (0x1E905, 'M', '𞤧'), - (0x1E906, 'M', '𞤨'), - (0x1E907, 'M', '𞤩'), - (0x1E908, 'M', '𞤪'), - (0x1E909, 'M', '𞤫'), - (0x1E90A, 'M', '𞤬'), - (0x1E90B, 'M', '𞤭'), - (0x1E90C, 'M', '𞤮'), - (0x1E90D, 'M', '𞤯'), - (0x1E90E, 'M', '𞤰'), - (0x1E90F, 'M', '𞤱'), - (0x1E910, 'M', '𞤲'), - (0x1E911, 'M', '𞤳'), - (0x1E912, 'M', '𞤴'), - (0x1E913, 'M', '𞤵'), - (0x1E914, 'M', '𞤶'), - (0x1E915, 'M', '𞤷'), - (0x1E916, 'M', '𞤸'), - (0x1E917, 'M', '𞤹'), - (0x1E918, 'M', '𞤺'), - (0x1E919, 'M', '𞤻'), - (0x1E91A, 'M', '𞤼'), - (0x1E91B, 'M', '𞤽'), - (0x1E91C, 'M', '𞤾'), - (0x1E91D, 'M', '𞤿'), - (0x1E91E, 'M', '𞥀'), - (0x1E91F, 'M', '𞥁'), - (0x1E920, 'M', '𞥂'), - (0x1E921, 'M', '𞥃'), - (0x1E922, 'V'), - (0x1E94C, 'X'), - (0x1E950, 'V'), - (0x1E95A, 'X'), - (0x1E95E, 'V'), - (0x1E960, 'X'), - ] - -def _seg_70(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0x1EC71, 'V'), - (0x1ECB5, 'X'), - (0x1ED01, 'V'), - (0x1ED3E, 'X'), - (0x1EE00, 'M', 'ا'), - (0x1EE01, 'M', 'ب'), - (0x1EE02, 'M', 'ج'), - (0x1EE03, 'M', 'د'), - (0x1EE04, 'X'), - (0x1EE05, 'M', 'و'), - (0x1EE06, 'M', 'ز'), - (0x1EE07, 'M', 'ح'), - (0x1EE08, 'M', 'ط'), - (0x1EE09, 'M', 'ي'), - (0x1EE0A, 'M', 'ك'), - (0x1EE0B, 'M', 'ل'), - (0x1EE0C, 'M', 'م'), - (0x1EE0D, 'M', 'ن'), - (0x1EE0E, 'M', 'س'), - (0x1EE0F, 'M', 'ع'), - (0x1EE10, 'M', 'ف'), - (0x1EE11, 'M', 'ص'), - (0x1EE12, 'M', 'ق'), - (0x1EE13, 'M', 'ر'), - (0x1EE14, 'M', 'ش'), - (0x1EE15, 'M', 'ت'), - (0x1EE16, 'M', 'ث'), - (0x1EE17, 'M', 'خ'), - (0x1EE18, 'M', 'ذ'), - (0x1EE19, 'M', 'ض'), - (0x1EE1A, 'M', 'ظ'), - (0x1EE1B, 'M', 'غ'), - (0x1EE1C, 'M', 'ٮ'), - (0x1EE1D, 'M', 'ں'), - (0x1EE1E, 'M', 'ڡ'), - (0x1EE1F, 'M', 'ٯ'), - (0x1EE20, 'X'), - (0x1EE21, 'M', 'ب'), - (0x1EE22, 'M', 'ج'), - (0x1EE23, 'X'), - (0x1EE24, 'M', 'ه'), - (0x1EE25, 'X'), - (0x1EE27, 'M', 'ح'), - (0x1EE28, 'X'), - (0x1EE29, 'M', 'ي'), - (0x1EE2A, 'M', 'ك'), - (0x1EE2B, 'M', 'ل'), - (0x1EE2C, 'M', 'م'), - (0x1EE2D, 'M', 'ن'), - (0x1EE2E, 'M', 'س'), - (0x1EE2F, 'M', 'ع'), - (0x1EE30, 'M', 'ف'), - (0x1EE31, 'M', 'ص'), - (0x1EE32, 'M', 'ق'), - (0x1EE33, 'X'), - (0x1EE34, 'M', 'ش'), - (0x1EE35, 'M', 'ت'), - (0x1EE36, 'M', 'ث'), - (0x1EE37, 'M', 'خ'), - (0x1EE38, 'X'), - (0x1EE39, 'M', 'ض'), - (0x1EE3A, 'X'), - (0x1EE3B, 'M', 'غ'), - (0x1EE3C, 'X'), - (0x1EE42, 'M', 'ج'), - (0x1EE43, 'X'), - (0x1EE47, 'M', 'ح'), - (0x1EE48, 'X'), - (0x1EE49, 'M', 'ي'), - (0x1EE4A, 'X'), - (0x1EE4B, 'M', 'ل'), - (0x1EE4C, 'X'), - (0x1EE4D, 'M', 'ن'), - (0x1EE4E, 'M', 'س'), - (0x1EE4F, 'M', 'ع'), - (0x1EE50, 'X'), - (0x1EE51, 'M', 'ص'), - (0x1EE52, 'M', 'ق'), - (0x1EE53, 'X'), - (0x1EE54, 'M', 'ش'), - (0x1EE55, 'X'), - (0x1EE57, 'M', 'خ'), - (0x1EE58, 'X'), - (0x1EE59, 'M', 'ض'), - (0x1EE5A, 'X'), - (0x1EE5B, 'M', 'غ'), - (0x1EE5C, 'X'), - (0x1EE5D, 'M', 'ں'), - (0x1EE5E, 'X'), - (0x1EE5F, 'M', 'ٯ'), - (0x1EE60, 'X'), - (0x1EE61, 'M', 'ب'), - (0x1EE62, 'M', 'ج'), - (0x1EE63, 'X'), - (0x1EE64, 'M', 'ه'), - (0x1EE65, 'X'), - (0x1EE67, 'M', 'ح'), - (0x1EE68, 'M', 'ط'), - (0x1EE69, 'M', 'ي'), - (0x1EE6A, 'M', 'ك'), - ] - -def _seg_71(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0x1EE6B, 'X'), - (0x1EE6C, 'M', 'م'), - (0x1EE6D, 'M', 'ن'), - (0x1EE6E, 'M', 'س'), - (0x1EE6F, 'M', 'ع'), - (0x1EE70, 'M', 'ف'), - (0x1EE71, 'M', 'ص'), - (0x1EE72, 'M', 'ق'), - (0x1EE73, 'X'), - (0x1EE74, 'M', 'ش'), - (0x1EE75, 'M', 'ت'), - (0x1EE76, 'M', 'ث'), - (0x1EE77, 'M', 'خ'), - (0x1EE78, 'X'), - (0x1EE79, 'M', 'ض'), - (0x1EE7A, 'M', 'ظ'), - (0x1EE7B, 'M', 'غ'), - (0x1EE7C, 'M', 'ٮ'), - (0x1EE7D, 'X'), - (0x1EE7E, 'M', 'ڡ'), - (0x1EE7F, 'X'), - (0x1EE80, 'M', 'ا'), - (0x1EE81, 'M', 'ب'), - (0x1EE82, 'M', 'ج'), - (0x1EE83, 'M', 'د'), - (0x1EE84, 'M', 'ه'), - (0x1EE85, 'M', 'و'), - (0x1EE86, 'M', 'ز'), - (0x1EE87, 'M', 'ح'), - (0x1EE88, 'M', 'ط'), - (0x1EE89, 'M', 'ي'), - (0x1EE8A, 'X'), - (0x1EE8B, 'M', 'ل'), - (0x1EE8C, 'M', 'م'), - (0x1EE8D, 'M', 'ن'), - (0x1EE8E, 'M', 'س'), - (0x1EE8F, 'M', 'ع'), - (0x1EE90, 'M', 'ف'), - (0x1EE91, 'M', 'ص'), - (0x1EE92, 'M', 'ق'), - (0x1EE93, 'M', 'ر'), - (0x1EE94, 'M', 'ش'), - (0x1EE95, 'M', 'ت'), - (0x1EE96, 'M', 'ث'), - (0x1EE97, 'M', 'خ'), - (0x1EE98, 'M', 'ذ'), - (0x1EE99, 'M', 'ض'), - (0x1EE9A, 'M', 'ظ'), - (0x1EE9B, 'M', 'غ'), - (0x1EE9C, 'X'), - (0x1EEA1, 'M', 'ب'), - (0x1EEA2, 'M', 'ج'), - (0x1EEA3, 'M', 'د'), - (0x1EEA4, 'X'), - (0x1EEA5, 'M', 'و'), - (0x1EEA6, 'M', 'ز'), - (0x1EEA7, 'M', 'ح'), - (0x1EEA8, 'M', 'ط'), - (0x1EEA9, 'M', 'ي'), - (0x1EEAA, 'X'), - (0x1EEAB, 'M', 'ل'), - (0x1EEAC, 'M', 'م'), - (0x1EEAD, 'M', 'ن'), - (0x1EEAE, 'M', 'س'), - (0x1EEAF, 'M', 'ع'), - (0x1EEB0, 'M', 'ف'), - (0x1EEB1, 'M', 'ص'), - (0x1EEB2, 'M', 'ق'), - (0x1EEB3, 'M', 'ر'), - (0x1EEB4, 'M', 'ش'), - (0x1EEB5, 'M', 'ت'), - (0x1EEB6, 'M', 'ث'), - (0x1EEB7, 'M', 'خ'), - (0x1EEB8, 'M', 'ذ'), - (0x1EEB9, 'M', 'ض'), - (0x1EEBA, 'M', 'ظ'), - (0x1EEBB, 'M', 'غ'), - (0x1EEBC, 'X'), - (0x1EEF0, 'V'), - (0x1EEF2, 'X'), - (0x1F000, 'V'), - (0x1F02C, 'X'), - (0x1F030, 'V'), - (0x1F094, 'X'), - (0x1F0A0, 'V'), - (0x1F0AF, 'X'), - (0x1F0B1, 'V'), - (0x1F0C0, 'X'), - (0x1F0C1, 'V'), - (0x1F0D0, 'X'), - (0x1F0D1, 'V'), - (0x1F0F6, 'X'), - (0x1F101, '3', '0,'), - (0x1F102, '3', '1,'), - (0x1F103, '3', '2,'), - (0x1F104, '3', '3,'), - (0x1F105, '3', '4,'), - (0x1F106, '3', '5,'), - (0x1F107, '3', '6,'), - (0x1F108, '3', '7,'), - ] - -def _seg_72(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0x1F109, '3', '8,'), - (0x1F10A, '3', '9,'), - (0x1F10B, 'V'), - (0x1F110, '3', '(a)'), - (0x1F111, '3', '(b)'), - (0x1F112, '3', '(c)'), - (0x1F113, '3', '(d)'), - (0x1F114, '3', '(e)'), - (0x1F115, '3', '(f)'), - (0x1F116, '3', '(g)'), - (0x1F117, '3', '(h)'), - (0x1F118, '3', '(i)'), - (0x1F119, '3', '(j)'), - (0x1F11A, '3', '(k)'), - (0x1F11B, '3', '(l)'), - (0x1F11C, '3', '(m)'), - (0x1F11D, '3', '(n)'), - (0x1F11E, '3', '(o)'), - (0x1F11F, '3', '(p)'), - (0x1F120, '3', '(q)'), - (0x1F121, '3', '(r)'), - (0x1F122, '3', '(s)'), - (0x1F123, '3', '(t)'), - (0x1F124, '3', '(u)'), - (0x1F125, '3', '(v)'), - (0x1F126, '3', '(w)'), - (0x1F127, '3', '(x)'), - (0x1F128, '3', '(y)'), - (0x1F129, '3', '(z)'), - (0x1F12A, 'M', '〔s〕'), - (0x1F12B, 'M', 'c'), - (0x1F12C, 'M', 'r'), - (0x1F12D, 'M', 'cd'), - (0x1F12E, 'M', 'wz'), - (0x1F12F, 'V'), - (0x1F130, 'M', 'a'), - (0x1F131, 'M', 'b'), - (0x1F132, 'M', 'c'), - (0x1F133, 'M', 'd'), - (0x1F134, 'M', 'e'), - (0x1F135, 'M', 'f'), - (0x1F136, 'M', 'g'), - (0x1F137, 'M', 'h'), - (0x1F138, 'M', 'i'), - (0x1F139, 'M', 'j'), - (0x1F13A, 'M', 'k'), - (0x1F13B, 'M', 'l'), - (0x1F13C, 'M', 'm'), - (0x1F13D, 'M', 'n'), - (0x1F13E, 'M', 'o'), - (0x1F13F, 'M', 'p'), - (0x1F140, 'M', 'q'), - (0x1F141, 'M', 'r'), - (0x1F142, 'M', 's'), - (0x1F143, 'M', 't'), - (0x1F144, 'M', 'u'), - (0x1F145, 'M', 'v'), - (0x1F146, 'M', 'w'), - (0x1F147, 'M', 'x'), - (0x1F148, 'M', 'y'), - (0x1F149, 'M', 'z'), - (0x1F14A, 'M', 'hv'), - (0x1F14B, 'M', 'mv'), - (0x1F14C, 'M', 'sd'), - (0x1F14D, 'M', 'ss'), - (0x1F14E, 'M', 'ppv'), - (0x1F14F, 'M', 'wc'), - (0x1F150, 'V'), - (0x1F16A, 'M', 'mc'), - (0x1F16B, 'M', 'md'), - (0x1F16C, 'M', 'mr'), - (0x1F16D, 'V'), - (0x1F190, 'M', 'dj'), - (0x1F191, 'V'), - (0x1F1AE, 'X'), - (0x1F1E6, 'V'), - (0x1F200, 'M', 'ほか'), - (0x1F201, 'M', 'ココ'), - (0x1F202, 'M', 'サ'), - (0x1F203, 'X'), - (0x1F210, 'M', '手'), - (0x1F211, 'M', '字'), - (0x1F212, 'M', '双'), - (0x1F213, 'M', 'デ'), - (0x1F214, 'M', '二'), - (0x1F215, 'M', '多'), - (0x1F216, 'M', '解'), - (0x1F217, 'M', '天'), - (0x1F218, 'M', '交'), - (0x1F219, 'M', '映'), - (0x1F21A, 'M', '無'), - (0x1F21B, 'M', '料'), - (0x1F21C, 'M', '前'), - (0x1F21D, 'M', '後'), - (0x1F21E, 'M', '再'), - (0x1F21F, 'M', '新'), - (0x1F220, 'M', '初'), - (0x1F221, 'M', '終'), - (0x1F222, 'M', '生'), - (0x1F223, 'M', '販'), - ] - -def _seg_73(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0x1F224, 'M', '声'), - (0x1F225, 'M', '吹'), - (0x1F226, 'M', '演'), - (0x1F227, 'M', '投'), - (0x1F228, 'M', '捕'), - (0x1F229, 'M', '一'), - (0x1F22A, 'M', '三'), - (0x1F22B, 'M', '遊'), - (0x1F22C, 'M', '左'), - (0x1F22D, 'M', '中'), - (0x1F22E, 'M', '右'), - (0x1F22F, 'M', '指'), - (0x1F230, 'M', '走'), - (0x1F231, 'M', '打'), - (0x1F232, 'M', '禁'), - (0x1F233, 'M', '空'), - (0x1F234, 'M', '合'), - (0x1F235, 'M', '満'), - (0x1F236, 'M', '有'), - (0x1F237, 'M', '月'), - (0x1F238, 'M', '申'), - (0x1F239, 'M', '割'), - (0x1F23A, 'M', '営'), - (0x1F23B, 'M', '配'), - (0x1F23C, 'X'), - (0x1F240, 'M', '〔本〕'), - (0x1F241, 'M', '〔三〕'), - (0x1F242, 'M', '〔二〕'), - (0x1F243, 'M', '〔安〕'), - (0x1F244, 'M', '〔点〕'), - (0x1F245, 'M', '〔打〕'), - (0x1F246, 'M', '〔盗〕'), - (0x1F247, 'M', '〔勝〕'), - (0x1F248, 'M', '〔敗〕'), - (0x1F249, 'X'), - (0x1F250, 'M', '得'), - (0x1F251, 'M', '可'), - (0x1F252, 'X'), - (0x1F260, 'V'), - (0x1F266, 'X'), - (0x1F300, 'V'), - (0x1F6D8, 'X'), - (0x1F6E0, 'V'), - (0x1F6ED, 'X'), - (0x1F6F0, 'V'), - (0x1F6FD, 'X'), - (0x1F700, 'V'), - (0x1F774, 'X'), - (0x1F780, 'V'), - (0x1F7D9, 'X'), - (0x1F7E0, 'V'), - (0x1F7EC, 'X'), - (0x1F800, 'V'), - (0x1F80C, 'X'), - (0x1F810, 'V'), - (0x1F848, 'X'), - (0x1F850, 'V'), - (0x1F85A, 'X'), - (0x1F860, 'V'), - (0x1F888, 'X'), - (0x1F890, 'V'), - (0x1F8AE, 'X'), - (0x1F8B0, 'V'), - (0x1F8B2, 'X'), - (0x1F900, 'V'), - (0x1F979, 'X'), - (0x1F97A, 'V'), - (0x1F9CC, 'X'), - (0x1F9CD, 'V'), - (0x1FA54, 'X'), - (0x1FA60, 'V'), - (0x1FA6E, 'X'), - (0x1FA70, 'V'), - (0x1FA75, 'X'), - (0x1FA78, 'V'), - (0x1FA7B, 'X'), - (0x1FA80, 'V'), - (0x1FA87, 'X'), - (0x1FA90, 'V'), - (0x1FAA9, 'X'), - (0x1FAB0, 'V'), - (0x1FAB7, 'X'), - (0x1FAC0, 'V'), - (0x1FAC3, 'X'), - (0x1FAD0, 'V'), - (0x1FAD7, 'X'), - (0x1FB00, 'V'), - (0x1FB93, 'X'), - (0x1FB94, 'V'), - (0x1FBCB, 'X'), - (0x1FBF0, 'M', '0'), - (0x1FBF1, 'M', '1'), - (0x1FBF2, 'M', '2'), - (0x1FBF3, 'M', '3'), - (0x1FBF4, 'M', '4'), - (0x1FBF5, 'M', '5'), - (0x1FBF6, 'M', '6'), - (0x1FBF7, 'M', '7'), - (0x1FBF8, 'M', '8'), - (0x1FBF9, 'M', '9'), - ] - -def _seg_74(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0x1FBFA, 'X'), - (0x20000, 'V'), - (0x2A6DE, 'X'), - (0x2A700, 'V'), - (0x2B735, 'X'), - (0x2B740, 'V'), - (0x2B81E, 'X'), - (0x2B820, 'V'), - (0x2CEA2, 'X'), - (0x2CEB0, 'V'), - (0x2EBE1, 'X'), - (0x2F800, 'M', '丽'), - (0x2F801, 'M', '丸'), - (0x2F802, 'M', '乁'), - (0x2F803, 'M', '𠄢'), - (0x2F804, 'M', '你'), - (0x2F805, 'M', '侮'), - (0x2F806, 'M', '侻'), - (0x2F807, 'M', '倂'), - (0x2F808, 'M', '偺'), - (0x2F809, 'M', '備'), - (0x2F80A, 'M', '僧'), - (0x2F80B, 'M', '像'), - (0x2F80C, 'M', '㒞'), - (0x2F80D, 'M', '𠘺'), - (0x2F80E, 'M', '免'), - (0x2F80F, 'M', '兔'), - (0x2F810, 'M', '兤'), - (0x2F811, 'M', '具'), - (0x2F812, 'M', '𠔜'), - (0x2F813, 'M', '㒹'), - (0x2F814, 'M', '內'), - (0x2F815, 'M', '再'), - (0x2F816, 'M', '𠕋'), - (0x2F817, 'M', '冗'), - (0x2F818, 'M', '冤'), - (0x2F819, 'M', '仌'), - (0x2F81A, 'M', '冬'), - (0x2F81B, 'M', '况'), - (0x2F81C, 'M', '𩇟'), - (0x2F81D, 'M', '凵'), - (0x2F81E, 'M', '刃'), - (0x2F81F, 'M', '㓟'), - (0x2F820, 'M', '刻'), - (0x2F821, 'M', '剆'), - (0x2F822, 'M', '割'), - (0x2F823, 'M', '剷'), - (0x2F824, 'M', '㔕'), - (0x2F825, 'M', '勇'), - (0x2F826, 'M', '勉'), - (0x2F827, 'M', '勤'), - (0x2F828, 'M', '勺'), - (0x2F829, 'M', '包'), - (0x2F82A, 'M', '匆'), - (0x2F82B, 'M', '北'), - (0x2F82C, 'M', '卉'), - (0x2F82D, 'M', '卑'), - (0x2F82E, 'M', '博'), - (0x2F82F, 'M', '即'), - (0x2F830, 'M', '卽'), - (0x2F831, 'M', '卿'), - (0x2F834, 'M', '𠨬'), - (0x2F835, 'M', '灰'), - (0x2F836, 'M', '及'), - (0x2F837, 'M', '叟'), - (0x2F838, 'M', '𠭣'), - (0x2F839, 'M', '叫'), - (0x2F83A, 'M', '叱'), - (0x2F83B, 'M', '吆'), - (0x2F83C, 'M', '咞'), - (0x2F83D, 'M', '吸'), - (0x2F83E, 'M', '呈'), - (0x2F83F, 'M', '周'), - (0x2F840, 'M', '咢'), - (0x2F841, 'M', '哶'), - (0x2F842, 'M', '唐'), - (0x2F843, 'M', '啓'), - (0x2F844, 'M', '啣'), - (0x2F845, 'M', '善'), - (0x2F847, 'M', '喙'), - (0x2F848, 'M', '喫'), - (0x2F849, 'M', '喳'), - (0x2F84A, 'M', '嗂'), - (0x2F84B, 'M', '圖'), - (0x2F84C, 'M', '嘆'), - (0x2F84D, 'M', '圗'), - (0x2F84E, 'M', '噑'), - (0x2F84F, 'M', '噴'), - (0x2F850, 'M', '切'), - (0x2F851, 'M', '壮'), - (0x2F852, 'M', '城'), - (0x2F853, 'M', '埴'), - (0x2F854, 'M', '堍'), - (0x2F855, 'M', '型'), - (0x2F856, 'M', '堲'), - (0x2F857, 'M', '報'), - (0x2F858, 'M', '墬'), - (0x2F859, 'M', '𡓤'), - (0x2F85A, 'M', '売'), - (0x2F85B, 'M', '壷'), - ] - -def _seg_75(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0x2F85C, 'M', '夆'), - (0x2F85D, 'M', '多'), - (0x2F85E, 'M', '夢'), - (0x2F85F, 'M', '奢'), - (0x2F860, 'M', '𡚨'), - (0x2F861, 'M', '𡛪'), - (0x2F862, 'M', '姬'), - (0x2F863, 'M', '娛'), - (0x2F864, 'M', '娧'), - (0x2F865, 'M', '姘'), - (0x2F866, 'M', '婦'), - (0x2F867, 'M', '㛮'), - (0x2F868, 'X'), - (0x2F869, 'M', '嬈'), - (0x2F86A, 'M', '嬾'), - (0x2F86C, 'M', '𡧈'), - (0x2F86D, 'M', '寃'), - (0x2F86E, 'M', '寘'), - (0x2F86F, 'M', '寧'), - (0x2F870, 'M', '寳'), - (0x2F871, 'M', '𡬘'), - (0x2F872, 'M', '寿'), - (0x2F873, 'M', '将'), - (0x2F874, 'X'), - (0x2F875, 'M', '尢'), - (0x2F876, 'M', '㞁'), - (0x2F877, 'M', '屠'), - (0x2F878, 'M', '屮'), - (0x2F879, 'M', '峀'), - (0x2F87A, 'M', '岍'), - (0x2F87B, 'M', '𡷤'), - (0x2F87C, 'M', '嵃'), - (0x2F87D, 'M', '𡷦'), - (0x2F87E, 'M', '嵮'), - (0x2F87F, 'M', '嵫'), - (0x2F880, 'M', '嵼'), - (0x2F881, 'M', '巡'), - (0x2F882, 'M', '巢'), - (0x2F883, 'M', '㠯'), - (0x2F884, 'M', '巽'), - (0x2F885, 'M', '帨'), - (0x2F886, 'M', '帽'), - (0x2F887, 'M', '幩'), - (0x2F888, 'M', '㡢'), - (0x2F889, 'M', '𢆃'), - (0x2F88A, 'M', '㡼'), - (0x2F88B, 'M', '庰'), - (0x2F88C, 'M', '庳'), - (0x2F88D, 'M', '庶'), - (0x2F88E, 'M', '廊'), - (0x2F88F, 'M', '𪎒'), - (0x2F890, 'M', '廾'), - (0x2F891, 'M', '𢌱'), - (0x2F893, 'M', '舁'), - (0x2F894, 'M', '弢'), - (0x2F896, 'M', '㣇'), - (0x2F897, 'M', '𣊸'), - (0x2F898, 'M', '𦇚'), - (0x2F899, 'M', '形'), - (0x2F89A, 'M', '彫'), - (0x2F89B, 'M', '㣣'), - (0x2F89C, 'M', '徚'), - (0x2F89D, 'M', '忍'), - (0x2F89E, 'M', '志'), - (0x2F89F, 'M', '忹'), - (0x2F8A0, 'M', '悁'), - (0x2F8A1, 'M', '㤺'), - (0x2F8A2, 'M', '㤜'), - (0x2F8A3, 'M', '悔'), - (0x2F8A4, 'M', '𢛔'), - (0x2F8A5, 'M', '惇'), - (0x2F8A6, 'M', '慈'), - (0x2F8A7, 'M', '慌'), - (0x2F8A8, 'M', '慎'), - (0x2F8A9, 'M', '慌'), - (0x2F8AA, 'M', '慺'), - (0x2F8AB, 'M', '憎'), - (0x2F8AC, 'M', '憲'), - (0x2F8AD, 'M', '憤'), - (0x2F8AE, 'M', '憯'), - (0x2F8AF, 'M', '懞'), - (0x2F8B0, 'M', '懲'), - (0x2F8B1, 'M', '懶'), - (0x2F8B2, 'M', '成'), - (0x2F8B3, 'M', '戛'), - (0x2F8B4, 'M', '扝'), - (0x2F8B5, 'M', '抱'), - (0x2F8B6, 'M', '拔'), - (0x2F8B7, 'M', '捐'), - (0x2F8B8, 'M', '𢬌'), - (0x2F8B9, 'M', '挽'), - (0x2F8BA, 'M', '拼'), - (0x2F8BB, 'M', '捨'), - (0x2F8BC, 'M', '掃'), - (0x2F8BD, 'M', '揤'), - (0x2F8BE, 'M', '𢯱'), - (0x2F8BF, 'M', '搢'), - (0x2F8C0, 'M', '揅'), - (0x2F8C1, 'M', '掩'), - (0x2F8C2, 'M', '㨮'), - ] - -def _seg_76(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0x2F8C3, 'M', '摩'), - (0x2F8C4, 'M', '摾'), - (0x2F8C5, 'M', '撝'), - (0x2F8C6, 'M', '摷'), - (0x2F8C7, 'M', '㩬'), - (0x2F8C8, 'M', '敏'), - (0x2F8C9, 'M', '敬'), - (0x2F8CA, 'M', '𣀊'), - (0x2F8CB, 'M', '旣'), - (0x2F8CC, 'M', '書'), - (0x2F8CD, 'M', '晉'), - (0x2F8CE, 'M', '㬙'), - (0x2F8CF, 'M', '暑'), - (0x2F8D0, 'M', '㬈'), - (0x2F8D1, 'M', '㫤'), - (0x2F8D2, 'M', '冒'), - (0x2F8D3, 'M', '冕'), - (0x2F8D4, 'M', '最'), - (0x2F8D5, 'M', '暜'), - (0x2F8D6, 'M', '肭'), - (0x2F8D7, 'M', '䏙'), - (0x2F8D8, 'M', '朗'), - (0x2F8D9, 'M', '望'), - (0x2F8DA, 'M', '朡'), - (0x2F8DB, 'M', '杞'), - (0x2F8DC, 'M', '杓'), - (0x2F8DD, 'M', '𣏃'), - (0x2F8DE, 'M', '㭉'), - (0x2F8DF, 'M', '柺'), - (0x2F8E0, 'M', '枅'), - (0x2F8E1, 'M', '桒'), - (0x2F8E2, 'M', '梅'), - (0x2F8E3, 'M', '𣑭'), - (0x2F8E4, 'M', '梎'), - (0x2F8E5, 'M', '栟'), - (0x2F8E6, 'M', '椔'), - (0x2F8E7, 'M', '㮝'), - (0x2F8E8, 'M', '楂'), - (0x2F8E9, 'M', '榣'), - (0x2F8EA, 'M', '槪'), - (0x2F8EB, 'M', '檨'), - (0x2F8EC, 'M', '𣚣'), - (0x2F8ED, 'M', '櫛'), - (0x2F8EE, 'M', '㰘'), - (0x2F8EF, 'M', '次'), - (0x2F8F0, 'M', '𣢧'), - (0x2F8F1, 'M', '歔'), - (0x2F8F2, 'M', '㱎'), - (0x2F8F3, 'M', '歲'), - (0x2F8F4, 'M', '殟'), - (0x2F8F5, 'M', '殺'), - (0x2F8F6, 'M', '殻'), - (0x2F8F7, 'M', '𣪍'), - (0x2F8F8, 'M', '𡴋'), - (0x2F8F9, 'M', '𣫺'), - (0x2F8FA, 'M', '汎'), - (0x2F8FB, 'M', '𣲼'), - (0x2F8FC, 'M', '沿'), - (0x2F8FD, 'M', '泍'), - (0x2F8FE, 'M', '汧'), - (0x2F8FF, 'M', '洖'), - (0x2F900, 'M', '派'), - (0x2F901, 'M', '海'), - (0x2F902, 'M', '流'), - (0x2F903, 'M', '浩'), - (0x2F904, 'M', '浸'), - (0x2F905, 'M', '涅'), - (0x2F906, 'M', '𣴞'), - (0x2F907, 'M', '洴'), - (0x2F908, 'M', '港'), - (0x2F909, 'M', '湮'), - (0x2F90A, 'M', '㴳'), - (0x2F90B, 'M', '滋'), - (0x2F90C, 'M', '滇'), - (0x2F90D, 'M', '𣻑'), - (0x2F90E, 'M', '淹'), - (0x2F90F, 'M', '潮'), - (0x2F910, 'M', '𣽞'), - (0x2F911, 'M', '𣾎'), - (0x2F912, 'M', '濆'), - (0x2F913, 'M', '瀹'), - (0x2F914, 'M', '瀞'), - (0x2F915, 'M', '瀛'), - (0x2F916, 'M', '㶖'), - (0x2F917, 'M', '灊'), - (0x2F918, 'M', '災'), - (0x2F919, 'M', '灷'), - (0x2F91A, 'M', '炭'), - (0x2F91B, 'M', '𠔥'), - (0x2F91C, 'M', '煅'), - (0x2F91D, 'M', '𤉣'), - (0x2F91E, 'M', '熜'), - (0x2F91F, 'X'), - (0x2F920, 'M', '爨'), - (0x2F921, 'M', '爵'), - (0x2F922, 'M', '牐'), - (0x2F923, 'M', '𤘈'), - (0x2F924, 'M', '犀'), - (0x2F925, 'M', '犕'), - (0x2F926, 'M', '𤜵'), - ] - -def _seg_77(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0x2F927, 'M', '𤠔'), - (0x2F928, 'M', '獺'), - (0x2F929, 'M', '王'), - (0x2F92A, 'M', '㺬'), - (0x2F92B, 'M', '玥'), - (0x2F92C, 'M', '㺸'), - (0x2F92E, 'M', '瑇'), - (0x2F92F, 'M', '瑜'), - (0x2F930, 'M', '瑱'), - (0x2F931, 'M', '璅'), - (0x2F932, 'M', '瓊'), - (0x2F933, 'M', '㼛'), - (0x2F934, 'M', '甤'), - (0x2F935, 'M', '𤰶'), - (0x2F936, 'M', '甾'), - (0x2F937, 'M', '𤲒'), - (0x2F938, 'M', '異'), - (0x2F939, 'M', '𢆟'), - (0x2F93A, 'M', '瘐'), - (0x2F93B, 'M', '𤾡'), - (0x2F93C, 'M', '𤾸'), - (0x2F93D, 'M', '𥁄'), - (0x2F93E, 'M', '㿼'), - (0x2F93F, 'M', '䀈'), - (0x2F940, 'M', '直'), - (0x2F941, 'M', '𥃳'), - (0x2F942, 'M', '𥃲'), - (0x2F943, 'M', '𥄙'), - (0x2F944, 'M', '𥄳'), - (0x2F945, 'M', '眞'), - (0x2F946, 'M', '真'), - (0x2F948, 'M', '睊'), - (0x2F949, 'M', '䀹'), - (0x2F94A, 'M', '瞋'), - (0x2F94B, 'M', '䁆'), - (0x2F94C, 'M', '䂖'), - (0x2F94D, 'M', '𥐝'), - (0x2F94E, 'M', '硎'), - (0x2F94F, 'M', '碌'), - (0x2F950, 'M', '磌'), - (0x2F951, 'M', '䃣'), - (0x2F952, 'M', '𥘦'), - (0x2F953, 'M', '祖'), - (0x2F954, 'M', '𥚚'), - (0x2F955, 'M', '𥛅'), - (0x2F956, 'M', '福'), - (0x2F957, 'M', '秫'), - (0x2F958, 'M', '䄯'), - (0x2F959, 'M', '穀'), - (0x2F95A, 'M', '穊'), - (0x2F95B, 'M', '穏'), - (0x2F95C, 'M', '𥥼'), - (0x2F95D, 'M', '𥪧'), - (0x2F95F, 'X'), - (0x2F960, 'M', '䈂'), - (0x2F961, 'M', '𥮫'), - (0x2F962, 'M', '篆'), - (0x2F963, 'M', '築'), - (0x2F964, 'M', '䈧'), - (0x2F965, 'M', '𥲀'), - (0x2F966, 'M', '糒'), - (0x2F967, 'M', '䊠'), - (0x2F968, 'M', '糨'), - (0x2F969, 'M', '糣'), - (0x2F96A, 'M', '紀'), - (0x2F96B, 'M', '𥾆'), - (0x2F96C, 'M', '絣'), - (0x2F96D, 'M', '䌁'), - (0x2F96E, 'M', '緇'), - (0x2F96F, 'M', '縂'), - (0x2F970, 'M', '繅'), - (0x2F971, 'M', '䌴'), - (0x2F972, 'M', '𦈨'), - (0x2F973, 'M', '𦉇'), - (0x2F974, 'M', '䍙'), - (0x2F975, 'M', '𦋙'), - (0x2F976, 'M', '罺'), - (0x2F977, 'M', '𦌾'), - (0x2F978, 'M', '羕'), - (0x2F979, 'M', '翺'), - (0x2F97A, 'M', '者'), - (0x2F97B, 'M', '𦓚'), - (0x2F97C, 'M', '𦔣'), - (0x2F97D, 'M', '聠'), - (0x2F97E, 'M', '𦖨'), - (0x2F97F, 'M', '聰'), - (0x2F980, 'M', '𣍟'), - (0x2F981, 'M', '䏕'), - (0x2F982, 'M', '育'), - (0x2F983, 'M', '脃'), - (0x2F984, 'M', '䐋'), - (0x2F985, 'M', '脾'), - (0x2F986, 'M', '媵'), - (0x2F987, 'M', '𦞧'), - (0x2F988, 'M', '𦞵'), - (0x2F989, 'M', '𣎓'), - (0x2F98A, 'M', '𣎜'), - (0x2F98B, 'M', '舁'), - (0x2F98C, 'M', '舄'), - (0x2F98D, 'M', '辞'), - ] - -def _seg_78(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0x2F98E, 'M', '䑫'), - (0x2F98F, 'M', '芑'), - (0x2F990, 'M', '芋'), - (0x2F991, 'M', '芝'), - (0x2F992, 'M', '劳'), - (0x2F993, 'M', '花'), - (0x2F994, 'M', '芳'), - (0x2F995, 'M', '芽'), - (0x2F996, 'M', '苦'), - (0x2F997, 'M', '𦬼'), - (0x2F998, 'M', '若'), - (0x2F999, 'M', '茝'), - (0x2F99A, 'M', '荣'), - (0x2F99B, 'M', '莭'), - (0x2F99C, 'M', '茣'), - (0x2F99D, 'M', '莽'), - (0x2F99E, 'M', '菧'), - (0x2F99F, 'M', '著'), - (0x2F9A0, 'M', '荓'), - (0x2F9A1, 'M', '菊'), - (0x2F9A2, 'M', '菌'), - (0x2F9A3, 'M', '菜'), - (0x2F9A4, 'M', '𦰶'), - (0x2F9A5, 'M', '𦵫'), - (0x2F9A6, 'M', '𦳕'), - (0x2F9A7, 'M', '䔫'), - (0x2F9A8, 'M', '蓱'), - (0x2F9A9, 'M', '蓳'), - (0x2F9AA, 'M', '蔖'), - (0x2F9AB, 'M', '𧏊'), - (0x2F9AC, 'M', '蕤'), - (0x2F9AD, 'M', '𦼬'), - (0x2F9AE, 'M', '䕝'), - (0x2F9AF, 'M', '䕡'), - (0x2F9B0, 'M', '𦾱'), - (0x2F9B1, 'M', '𧃒'), - (0x2F9B2, 'M', '䕫'), - (0x2F9B3, 'M', '虐'), - (0x2F9B4, 'M', '虜'), - (0x2F9B5, 'M', '虧'), - (0x2F9B6, 'M', '虩'), - (0x2F9B7, 'M', '蚩'), - (0x2F9B8, 'M', '蚈'), - (0x2F9B9, 'M', '蜎'), - (0x2F9BA, 'M', '蛢'), - (0x2F9BB, 'M', '蝹'), - (0x2F9BC, 'M', '蜨'), - (0x2F9BD, 'M', '蝫'), - (0x2F9BE, 'M', '螆'), - (0x2F9BF, 'X'), - (0x2F9C0, 'M', '蟡'), - (0x2F9C1, 'M', '蠁'), - (0x2F9C2, 'M', '䗹'), - (0x2F9C3, 'M', '衠'), - (0x2F9C4, 'M', '衣'), - (0x2F9C5, 'M', '𧙧'), - (0x2F9C6, 'M', '裗'), - (0x2F9C7, 'M', '裞'), - (0x2F9C8, 'M', '䘵'), - (0x2F9C9, 'M', '裺'), - (0x2F9CA, 'M', '㒻'), - (0x2F9CB, 'M', '𧢮'), - (0x2F9CC, 'M', '𧥦'), - (0x2F9CD, 'M', '䚾'), - (0x2F9CE, 'M', '䛇'), - (0x2F9CF, 'M', '誠'), - (0x2F9D0, 'M', '諭'), - (0x2F9D1, 'M', '變'), - (0x2F9D2, 'M', '豕'), - (0x2F9D3, 'M', '𧲨'), - (0x2F9D4, 'M', '貫'), - (0x2F9D5, 'M', '賁'), - (0x2F9D6, 'M', '贛'), - (0x2F9D7, 'M', '起'), - (0x2F9D8, 'M', '𧼯'), - (0x2F9D9, 'M', '𠠄'), - (0x2F9DA, 'M', '跋'), - (0x2F9DB, 'M', '趼'), - (0x2F9DC, 'M', '跰'), - (0x2F9DD, 'M', '𠣞'), - (0x2F9DE, 'M', '軔'), - (0x2F9DF, 'M', '輸'), - (0x2F9E0, 'M', '𨗒'), - (0x2F9E1, 'M', '𨗭'), - (0x2F9E2, 'M', '邔'), - (0x2F9E3, 'M', '郱'), - (0x2F9E4, 'M', '鄑'), - (0x2F9E5, 'M', '𨜮'), - (0x2F9E6, 'M', '鄛'), - (0x2F9E7, 'M', '鈸'), - (0x2F9E8, 'M', '鋗'), - (0x2F9E9, 'M', '鋘'), - (0x2F9EA, 'M', '鉼'), - (0x2F9EB, 'M', '鏹'), - (0x2F9EC, 'M', '鐕'), - (0x2F9ED, 'M', '𨯺'), - (0x2F9EE, 'M', '開'), - (0x2F9EF, 'M', '䦕'), - (0x2F9F0, 'M', '閷'), - (0x2F9F1, 'M', '𨵷'), - ] - -def _seg_79(): - # type: () -> List[Union[Tuple[int, str], Tuple[int, str, str]]] - return [ - (0x2F9F2, 'M', '䧦'), - (0x2F9F3, 'M', '雃'), - (0x2F9F4, 'M', '嶲'), - (0x2F9F5, 'M', '霣'), - (0x2F9F6, 'M', '𩅅'), - (0x2F9F7, 'M', '𩈚'), - (0x2F9F8, 'M', '䩮'), - (0x2F9F9, 'M', '䩶'), - (0x2F9FA, 'M', '韠'), - (0x2F9FB, 'M', '𩐊'), - (0x2F9FC, 'M', '䪲'), - (0x2F9FD, 'M', '𩒖'), - (0x2F9FE, 'M', '頋'), - (0x2FA00, 'M', '頩'), - (0x2FA01, 'M', '𩖶'), - (0x2FA02, 'M', '飢'), - (0x2FA03, 'M', '䬳'), - (0x2FA04, 'M', '餩'), - (0x2FA05, 'M', '馧'), - (0x2FA06, 'M', '駂'), - (0x2FA07, 'M', '駾'), - (0x2FA08, 'M', '䯎'), - (0x2FA09, 'M', '𩬰'), - (0x2FA0A, 'M', '鬒'), - (0x2FA0B, 'M', '鱀'), - (0x2FA0C, 'M', '鳽'), - (0x2FA0D, 'M', '䳎'), - (0x2FA0E, 'M', '䳭'), - (0x2FA0F, 'M', '鵧'), - (0x2FA10, 'M', '𪃎'), - (0x2FA11, 'M', '䳸'), - (0x2FA12, 'M', '𪄅'), - (0x2FA13, 'M', '𪈎'), - (0x2FA14, 'M', '𪊑'), - (0x2FA15, 'M', '麻'), - (0x2FA16, 'M', '䵖'), - (0x2FA17, 'M', '黹'), - (0x2FA18, 'M', '黾'), - (0x2FA19, 'M', '鼅'), - (0x2FA1A, 'M', '鼏'), - (0x2FA1B, 'M', '鼖'), - (0x2FA1C, 'M', '鼻'), - (0x2FA1D, 'M', '𪘀'), - (0x2FA1E, 'X'), - (0x30000, 'V'), - (0x3134B, 'X'), - (0xE0100, 'I'), - (0xE01F0, 'X'), - ] - -uts46data = tuple( - _seg_0() - + _seg_1() - + _seg_2() - + _seg_3() - + _seg_4() - + _seg_5() - + _seg_6() - + _seg_7() - + _seg_8() - + _seg_9() - + _seg_10() - + _seg_11() - + _seg_12() - + _seg_13() - + _seg_14() - + _seg_15() - + _seg_16() - + _seg_17() - + _seg_18() - + _seg_19() - + _seg_20() - + _seg_21() - + _seg_22() - + _seg_23() - + _seg_24() - + _seg_25() - + _seg_26() - + _seg_27() - + _seg_28() - + _seg_29() - + _seg_30() - + _seg_31() - + _seg_32() - + _seg_33() - + _seg_34() - + _seg_35() - + _seg_36() - + _seg_37() - + _seg_38() - + _seg_39() - + _seg_40() - + _seg_41() - + _seg_42() - + _seg_43() - + _seg_44() - + _seg_45() - + _seg_46() - + _seg_47() - + _seg_48() - + _seg_49() - + _seg_50() - + _seg_51() - + _seg_52() - + _seg_53() - + _seg_54() - + _seg_55() - + _seg_56() - + _seg_57() - + _seg_58() - + _seg_59() - + _seg_60() - + _seg_61() - + _seg_62() - + _seg_63() - + _seg_64() - + _seg_65() - + _seg_66() - + _seg_67() - + _seg_68() - + _seg_69() - + _seg_70() - + _seg_71() - + _seg_72() - + _seg_73() - + _seg_74() - + _seg_75() - + _seg_76() - + _seg_77() - + _seg_78() - + _seg_79() -) # type: Tuple[Union[Tuple[int, str], Tuple[int, str, str]], ...] diff --git a/venv/lib/python3.8/site-packages/pip-20.0.2.dist-info/INSTALLER b/venv/lib/python3.8/site-packages/pip-20.0.2.dist-info/INSTALLER deleted file mode 100644 index a1b589e..0000000 --- a/venv/lib/python3.8/site-packages/pip-20.0.2.dist-info/INSTALLER +++ /dev/null @@ -1 +0,0 @@ -pip diff --git a/venv/lib/python3.8/site-packages/pip-20.0.2.dist-info/LICENSE.txt b/venv/lib/python3.8/site-packages/pip-20.0.2.dist-info/LICENSE.txt deleted file mode 100644 index 737fec5..0000000 --- a/venv/lib/python3.8/site-packages/pip-20.0.2.dist-info/LICENSE.txt +++ /dev/null @@ -1,20 +0,0 @@ -Copyright (c) 2008-2019 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/venv/lib/python3.8/site-packages/pip-20.0.2.dist-info/METADATA b/venv/lib/python3.8/site-packages/pip-20.0.2.dist-info/METADATA deleted file mode 100644 index 5183c4e..0000000 --- a/venv/lib/python3.8/site-packages/pip-20.0.2.dist-info/METADATA +++ /dev/null @@ -1,84 +0,0 @@ -Metadata-Version: 2.1 -Name: pip -Version: 20.0.2 -Summary: The PyPA recommended tool for installing Python packages. -Home-page: https://pip.pypa.io/ -Author: The pip developers -Author-email: pypa-dev@groups.google.com -License: MIT -Project-URL: Documentation, https://pip.pypa.io -Project-URL: Source, https://github.com/pypa/pip -Keywords: distutils easy_install egg setuptools wheel virtualenv -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 :: 2 -Classifier: Programming Language :: Python :: 2.7 -Classifier: Programming Language :: Python :: 3 -Classifier: Programming Language :: Python :: 3.5 -Classifier: Programming Language :: Python :: 3.6 -Classifier: Programming Language :: Python :: 3.7 -Classifier: Programming Language :: Python :: 3.8 -Classifier: Programming Language :: Python :: Implementation :: CPython -Classifier: Programming Language :: Python :: Implementation :: PyPy -Requires-Python: >=2.7,!=3.0.*,!=3.1.*,!=3.2.*,!=3.3.*,!=3.4.* - -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`_ - -Updates are released regularly, with a new version every 3 months. More details can be found in our documentation: - -* `Release notes`_ -* `Release process`_ - -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`_ -* `Dev documentation`_ -* `Dev mailing list`_ -* `Dev IRC`_ - -Code of Conduct ---------------- - -Everyone interacting in the pip project's codebases, issue trackers, chat -rooms, and mailing lists is expected to follow the `PyPA 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 -.. _Dev documentation: https://pip.pypa.io/en/latest/development -.. _Issue tracking: https://github.com/pypa/pip/issues -.. _Discourse channel: https://discuss.python.org/c/packaging -.. _Dev mailing list: https://groups.google.com/forum/#!forum/pypa-dev -.. _User IRC: https://webchat.freenode.net/?channels=%23pypa -.. _Dev IRC: https://webchat.freenode.net/?channels=%23pypa-dev -.. _PyPA Code of Conduct: https://www.pypa.io/en/latest/code-of-conduct/ - - diff --git a/venv/lib/python3.8/site-packages/pip-20.0.2.dist-info/RECORD b/venv/lib/python3.8/site-packages/pip-20.0.2.dist-info/RECORD deleted file mode 100644 index 5f243ff..0000000 --- a/venv/lib/python3.8/site-packages/pip-20.0.2.dist-info/RECORD +++ /dev/null @@ -1,246 +0,0 @@ -../../../bin/pip,sha256=35bf9qD6lfp3oyaI2BON-lgqjbmrBkt8mkSbPIt_khk,261 -../../../bin/pip3,sha256=35bf9qD6lfp3oyaI2BON-lgqjbmrBkt8mkSbPIt_khk,261 -../../../bin/pip3.8,sha256=35bf9qD6lfp3oyaI2BON-lgqjbmrBkt8mkSbPIt_khk,261 -pip-20.0.2.dist-info/INSTALLER,sha256=zuuue4knoyJ-UwPPXg8fezS7VCrXJQrAP7zeNuwvFQg,4 -pip-20.0.2.dist-info/LICENSE.txt,sha256=W6Ifuwlk-TatfRU2LR7W1JMcyMj5_y1NkRkOEJvnRDE,1090 -pip-20.0.2.dist-info/METADATA,sha256=MSgjT2JTt8usp4Hopp5AGEmc-7sKR2Jd7HTMJqCoRhw,3352 -pip-20.0.2.dist-info/RECORD,, -pip-20.0.2.dist-info/WHEEL,sha256=kGT74LWyRUZrL4VgLh6_g12IeVl_9u9ZVhadrgXZUEY,110 -pip-20.0.2.dist-info/entry_points.txt,sha256=HtfDOwpUlr9s73jqLQ6wF9V0_0qvUXJwCBz7Vwx0Ue0,125 -pip-20.0.2.dist-info/top_level.txt,sha256=zuuue4knoyJ-UwPPXg8fezS7VCrXJQrAP7zeNuwvFQg,4 -pip/__init__.py,sha256=U1AM82iShMaw90K6Yq0Q2-AZ1EsOcqQLQRB-rxwFtII,455 -pip/__main__.py,sha256=NM95x7KuQr-lwPoTjAC0d_QzLJsJjpmAoxZg0mP8s98,632 -pip/__pycache__/__init__.cpython-38.pyc,, -pip/__pycache__/__main__.cpython-38.pyc,, -pip/_internal/__init__.py,sha256=j5fiII6yCeZjpW7_7wAVRMM4DwE-gyARGVU4yAADDeE,517 -pip/_internal/__pycache__/__init__.cpython-38.pyc,, -pip/_internal/__pycache__/build_env.cpython-38.pyc,, -pip/_internal/__pycache__/cache.cpython-38.pyc,, -pip/_internal/__pycache__/configuration.cpython-38.pyc,, -pip/_internal/__pycache__/exceptions.cpython-38.pyc,, -pip/_internal/__pycache__/legacy_resolve.cpython-38.pyc,, -pip/_internal/__pycache__/locations.cpython-38.pyc,, -pip/_internal/__pycache__/main.cpython-38.pyc,, -pip/_internal/__pycache__/pep425tags.cpython-38.pyc,, -pip/_internal/__pycache__/pyproject.cpython-38.pyc,, -pip/_internal/__pycache__/self_outdated_check.cpython-38.pyc,, -pip/_internal/__pycache__/wheel_builder.cpython-38.pyc,, -pip/_internal/build_env.py,sha256=--aNgzIdYrCOclHMwoAdpclCpfdFE_jooRuCy5gczwg,7532 -pip/_internal/cache.py,sha256=16GrnDRLBQNlfKWIuIF6Sa-EFS78kez_w1WEjT3ykTI,11605 -pip/_internal/cli/__init__.py,sha256=FkHBgpxxb-_gd6r1FjnNhfMOzAUYyXoXKJ6abijfcFU,132 -pip/_internal/cli/__pycache__/__init__.cpython-38.pyc,, -pip/_internal/cli/__pycache__/autocompletion.cpython-38.pyc,, -pip/_internal/cli/__pycache__/base_command.cpython-38.pyc,, -pip/_internal/cli/__pycache__/cmdoptions.cpython-38.pyc,, -pip/_internal/cli/__pycache__/command_context.cpython-38.pyc,, -pip/_internal/cli/__pycache__/main.cpython-38.pyc,, -pip/_internal/cli/__pycache__/main_parser.cpython-38.pyc,, -pip/_internal/cli/__pycache__/parser.cpython-38.pyc,, -pip/_internal/cli/__pycache__/req_command.cpython-38.pyc,, -pip/_internal/cli/__pycache__/status_codes.cpython-38.pyc,, -pip/_internal/cli/autocompletion.py,sha256=ekGNtcDI0p7rFVc-7s4T9Tbss4Jgb7vsB649XJIblRg,6547 -pip/_internal/cli/base_command.py,sha256=v6yl5XNRqye8BT9ep8wvpMu6lylP_Hu6D95r_HqbpbQ,7948 -pip/_internal/cli/cmdoptions.py,sha256=f1TVHuu_fR3lLlMo6b367H_GsWFv26tLI9cAS-kZfE0,28114 -pip/_internal/cli/command_context.py,sha256=ygMVoTy2jpNilKT-6416gFSQpaBtrKRBbVbi2fy__EU,975 -pip/_internal/cli/main.py,sha256=8iq3bHe5lxJTB2EvKOqZ38NS0MmoS79_S1kgj4QuH8A,2610 -pip/_internal/cli/main_parser.py,sha256=W9OWeryh7ZkqELohaFh0Ko9sB98ZkSeDmnYbOZ1imBc,2819 -pip/_internal/cli/parser.py,sha256=O9djTuYQuSfObiY-NU6p4MJCfWsRUnDpE2YGA_fwols,9487 -pip/_internal/cli/req_command.py,sha256=pAUAglpTn0mUA6lRs7KN71yOm1KDabD0ySVTQTqWTSA,12463 -pip/_internal/cli/status_codes.py,sha256=F6uDG6Gj7RNKQJUDnd87QKqI16Us-t-B0wPF_4QMpWc,156 -pip/_internal/commands/__init__.py,sha256=uTSj58QlrSKeXqCUSdL-eAf_APzx5BHy1ABxb0j5ZNE,3714 -pip/_internal/commands/__pycache__/__init__.cpython-38.pyc,, -pip/_internal/commands/__pycache__/check.cpython-38.pyc,, -pip/_internal/commands/__pycache__/completion.cpython-38.pyc,, -pip/_internal/commands/__pycache__/configuration.cpython-38.pyc,, -pip/_internal/commands/__pycache__/debug.cpython-38.pyc,, -pip/_internal/commands/__pycache__/download.cpython-38.pyc,, -pip/_internal/commands/__pycache__/freeze.cpython-38.pyc,, -pip/_internal/commands/__pycache__/hash.cpython-38.pyc,, -pip/_internal/commands/__pycache__/help.cpython-38.pyc,, -pip/_internal/commands/__pycache__/install.cpython-38.pyc,, -pip/_internal/commands/__pycache__/list.cpython-38.pyc,, -pip/_internal/commands/__pycache__/search.cpython-38.pyc,, -pip/_internal/commands/__pycache__/show.cpython-38.pyc,, -pip/_internal/commands/__pycache__/uninstall.cpython-38.pyc,, -pip/_internal/commands/__pycache__/wheel.cpython-38.pyc,, -pip/_internal/commands/check.py,sha256=mgLNYT3bd6Kmynwh4zzcBmVlFZ-urMo40jTgk6U405E,1505 -pip/_internal/commands/completion.py,sha256=UFQvq0Q4_B96z1bvnQyMOq82aPSu05RejbLmqeTZjC0,2975 -pip/_internal/commands/configuration.py,sha256=6riioZjMhsNSEct7dE-X8SobGodk3WERKJvuyjBje4Q,7226 -pip/_internal/commands/debug.py,sha256=a8llax2hRkxgK-tvwdJgaCaZCYPIx0fDvrlMDoYr8bQ,4209 -pip/_internal/commands/download.py,sha256=zX_0-IeFb4C8dxSmGHxk-6H5kehtyTSsdWpjNpAhSww,5007 -pip/_internal/commands/freeze.py,sha256=QS-4ib8jbKJ2wrDaDbTuyaB3Y_iJ5CQC2gAVHuAv9QU,3481 -pip/_internal/commands/hash.py,sha256=47teimfAPhpkaVbSDaafck51BT3XXYuL83lAqc5lOcE,1735 -pip/_internal/commands/help.py,sha256=Nhecq--ydFn80Gm1Zvbf9943EcRJfO0TnXUhsF0RO7s,1181 -pip/_internal/commands/install.py,sha256=T4P3J1rw7CQrZX4OUamtcoWMkTrJBfUe6gWpTfZW1bQ,27286 -pip/_internal/commands/list.py,sha256=2l0JiqHxjxDHNTCb2HZOjwwdo4duS1R0MsqZb6HSMKk,10660 -pip/_internal/commands/search.py,sha256=7Il8nKZ9mM7qF5jlnBoPvSIFY9f-0-5IbYoX3miTuZY,5148 -pip/_internal/commands/show.py,sha256=Vzsj2oX0JBl94MPyF3LV8YoMcigl8B2UsMM8zp0pH2s,6792 -pip/_internal/commands/uninstall.py,sha256=8mldFbrQecSoWDZRqxBgJkrlvx6Y9Iy7cs-2BIgtXt4,2983 -pip/_internal/commands/wheel.py,sha256=TMU5ZhjLo7BIZQApGPsYfoCsbGTnvP-N9jkgPJXhj1Y,7170 -pip/_internal/configuration.py,sha256=MgKrLFBJBkF3t2VJM4tvlnEspfSuS4scp_LhHWh53nY,14222 -pip/_internal/distributions/__init__.py,sha256=ECBUW5Gtu9TjJwyFLvim-i6kUMYVuikNh9I5asL6tbA,959 -pip/_internal/distributions/__pycache__/__init__.cpython-38.pyc,, -pip/_internal/distributions/__pycache__/base.cpython-38.pyc,, -pip/_internal/distributions/__pycache__/installed.cpython-38.pyc,, -pip/_internal/distributions/__pycache__/sdist.cpython-38.pyc,, -pip/_internal/distributions/__pycache__/wheel.cpython-38.pyc,, -pip/_internal/distributions/base.py,sha256=ruprpM_L2T2HNi3KLUHlbHimZ1sWVw-3Q0Lb8O7TDAI,1425 -pip/_internal/distributions/installed.py,sha256=YqlkBKr6TVP1MAYS6SG8ojud21wVOYLMZ8jMLJe9MSU,760 -pip/_internal/distributions/sdist.py,sha256=D4XTMlCwgPlK69l62GLYkNSVTVe99fR5iAcVt2EbGok,4086 -pip/_internal/distributions/wheel.py,sha256=95uD-TfaYoq3KiKBdzk9YMN4RRqJ28LNoSTS2K46gek,1294 -pip/_internal/exceptions.py,sha256=6YRuwXAK6F1iyUWKIkCIpWWN2khkAn1sZOgrFA9S8Ro,10247 -pip/_internal/index/__init__.py,sha256=vpt-JeTZefh8a-FC22ZeBSXFVbuBcXSGiILhQZJaNpQ,30 -pip/_internal/index/__pycache__/__init__.cpython-38.pyc,, -pip/_internal/index/__pycache__/collector.cpython-38.pyc,, -pip/_internal/index/__pycache__/package_finder.cpython-38.pyc,, -pip/_internal/index/collector.py,sha256=YS7Ix4oylU7ZbPTPFugh-244GSRqMvdHsGUG6nmz2gE,17892 -pip/_internal/index/package_finder.py,sha256=2Rg75AOpLj8BN1jyL8EI-Iw-Hv6ibJkrYVARCht3bX8,37542 -pip/_internal/legacy_resolve.py,sha256=L7R72I7CjVgJlPTggmA1j4b-H8NmxNu_dKVhrpGXGps,16277 -pip/_internal/locations.py,sha256=VifFEqhc7FWFV8QGoEM3CpECRY8Doq7kTytytxsEgx0,6734 -pip/_internal/main.py,sha256=IVBnUQ-FG7DK6617uEXRB5_QJqspAsBFmTmTesYkbdQ,437 -pip/_internal/models/__init__.py,sha256=3DHUd_qxpPozfzouoqa9g9ts1Czr5qaHfFxbnxriepM,63 -pip/_internal/models/__pycache__/__init__.cpython-38.pyc,, -pip/_internal/models/__pycache__/candidate.cpython-38.pyc,, -pip/_internal/models/__pycache__/format_control.cpython-38.pyc,, -pip/_internal/models/__pycache__/index.cpython-38.pyc,, -pip/_internal/models/__pycache__/link.cpython-38.pyc,, -pip/_internal/models/__pycache__/scheme.cpython-38.pyc,, -pip/_internal/models/__pycache__/search_scope.cpython-38.pyc,, -pip/_internal/models/__pycache__/selection_prefs.cpython-38.pyc,, -pip/_internal/models/__pycache__/target_python.cpython-38.pyc,, -pip/_internal/models/__pycache__/wheel.cpython-38.pyc,, -pip/_internal/models/candidate.py,sha256=Y58Bcm6oXUj0iS-yhmerlGo5CQJI2p0Ww9h6hR9zQDw,1150 -pip/_internal/models/format_control.py,sha256=ICzVjjGwfZYdX-eLLKHjMHLutEJlAGpfj09OG_eMqac,2673 -pip/_internal/models/index.py,sha256=K59A8-hVhBM20Xkahr4dTwP7OjkJyEqXH11UwHFVgqM,1060 -pip/_internal/models/link.py,sha256=y0H2ZOk0P6d1lfGUL2Pl09xFgZcRt5HwN2LElMifOpI,6827 -pip/_internal/models/scheme.py,sha256=vvhBrrno7eVDXcdKHiZWwxhPHf4VG5uSCEkC0QDR2RU,679 -pip/_internal/models/search_scope.py,sha256=2LXbU4wV8LwqdtXQXNXFYKv-IxiDI_QwSz9ZgbwtAfk,3898 -pip/_internal/models/selection_prefs.py,sha256=rPeif2KKjhTPXeMoQYffjqh10oWpXhdkxRDaPT1HO8k,1908 -pip/_internal/models/target_python.py,sha256=c-cFi6zCuo5HYbXNS3rVVpKRaHVh5yQlYEjEW23SidQ,3799 -pip/_internal/models/wheel.py,sha256=6KLuLKH5b0C5goWQXGSISRaq2UZtkHUEAU1y1Zsrwms,2766 -pip/_internal/network/__init__.py,sha256=jf6Tt5nV_7zkARBrKojIXItgejvoegVJVKUbhAa5Ioc,50 -pip/_internal/network/__pycache__/__init__.cpython-38.pyc,, -pip/_internal/network/__pycache__/auth.cpython-38.pyc,, -pip/_internal/network/__pycache__/cache.cpython-38.pyc,, -pip/_internal/network/__pycache__/download.cpython-38.pyc,, -pip/_internal/network/__pycache__/session.cpython-38.pyc,, -pip/_internal/network/__pycache__/utils.cpython-38.pyc,, -pip/_internal/network/__pycache__/xmlrpc.cpython-38.pyc,, -pip/_internal/network/auth.py,sha256=K3G1ukKb3PiH8w_UnpXTz8qQsTULO-qdbfOE9zTo1fE,11119 -pip/_internal/network/cache.py,sha256=51CExcRkXWrgMZ7WsrZ6cmijKfViD5tVgKbBvJHO1IE,2394 -pip/_internal/network/download.py,sha256=3D9vdJmVwmCUMxzC-TaVI_GvVOpQna3BLEYNPCSx3Fc,6260 -pip/_internal/network/session.py,sha256=u1IXQfv21R1xv86ulyiB58-be4sYm90eFB0Wp8fVMYw,14702 -pip/_internal/network/utils.py,sha256=iiixo1OeaQ3niUWiBjg59PN6f1w7vvTww1vFriTD_IU,1959 -pip/_internal/network/xmlrpc.py,sha256=AL115M3vFJ8xiHVJneb8Hi0ZFeRvdPhblC89w25OG5s,1597 -pip/_internal/operations/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -pip/_internal/operations/__pycache__/__init__.cpython-38.pyc,, -pip/_internal/operations/__pycache__/check.cpython-38.pyc,, -pip/_internal/operations/__pycache__/freeze.cpython-38.pyc,, -pip/_internal/operations/__pycache__/prepare.cpython-38.pyc,, -pip/_internal/operations/build/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -pip/_internal/operations/build/__pycache__/__init__.cpython-38.pyc,, -pip/_internal/operations/build/__pycache__/metadata.cpython-38.pyc,, -pip/_internal/operations/build/__pycache__/metadata_legacy.cpython-38.pyc,, -pip/_internal/operations/build/__pycache__/wheel.cpython-38.pyc,, -pip/_internal/operations/build/__pycache__/wheel_legacy.cpython-38.pyc,, -pip/_internal/operations/build/metadata.py,sha256=yHMi5gHYXcXyHcvUPWHdO-UyOo3McFWljn_nHfM1O9c,1307 -pip/_internal/operations/build/metadata_legacy.py,sha256=4n6N7BTysqVmEpITzT2UVClyt0Peij_Im8Qm965IWB4,3957 -pip/_internal/operations/build/wheel.py,sha256=ntltdNP6D2Tpr4V0agssu6rE0F9LaBpJkYT6zSdhEbw,1469 -pip/_internal/operations/build/wheel_legacy.py,sha256=DYSxQKutwSZnmNvWkwsl2HzE2XQBxV0i0wTphjtUe90,3349 -pip/_internal/operations/check.py,sha256=a6uHG0daoWpmSPCdL7iYJaGQYZ-CRvPvTnCv2PnIIs0,5353 -pip/_internal/operations/freeze.py,sha256=td4BeRnW10EXFTZrx6VgygO3CrjqD5B9f0BGzjQm-Ew,10180 -pip/_internal/operations/install/__init__.py,sha256=mX7hyD2GNBO2mFGokDQ30r_GXv7Y_PLdtxcUv144e-s,51 -pip/_internal/operations/install/__pycache__/__init__.cpython-38.pyc,, -pip/_internal/operations/install/__pycache__/editable_legacy.cpython-38.pyc,, -pip/_internal/operations/install/__pycache__/legacy.cpython-38.pyc,, -pip/_internal/operations/install/__pycache__/wheel.cpython-38.pyc,, -pip/_internal/operations/install/editable_legacy.py,sha256=rJ_xs2qtDUjpY2-n6eYlVyZiNoKbOtZXZrYrcnIELt4,1488 -pip/_internal/operations/install/legacy.py,sha256=eBV8gHbO9sBlBc-4nuR3Sd2nikHgEcnC9khfeLiypio,4566 -pip/_internal/operations/install/wheel.py,sha256=xdCjH6uIUyg39Pf8tUaMFUN4a7eozJAFMb_wKcgQlsY,23012 -pip/_internal/operations/prepare.py,sha256=ro2teBlbBpkRJhBKraP9CoJgVLpueSk62ziWhRToXww,20942 -pip/_internal/pep425tags.py,sha256=SlIQokevkoKnXhoK3PZvXiDoj8hFKoJ7thDifDtga3k,5490 -pip/_internal/pyproject.py,sha256=VJKsrXORGiGoDPVKCQhuu4tWlQSTOhoiRlVLRNu4rx4,7400 -pip/_internal/req/__init__.py,sha256=UVaYPlHZVGRBQQPjvGC_6jJDQtewXm0ws-8Lxhg_TiY,2671 -pip/_internal/req/__pycache__/__init__.cpython-38.pyc,, -pip/_internal/req/__pycache__/constructors.cpython-38.pyc,, -pip/_internal/req/__pycache__/req_file.cpython-38.pyc,, -pip/_internal/req/__pycache__/req_install.cpython-38.pyc,, -pip/_internal/req/__pycache__/req_set.cpython-38.pyc,, -pip/_internal/req/__pycache__/req_tracker.cpython-38.pyc,, -pip/_internal/req/__pycache__/req_uninstall.cpython-38.pyc,, -pip/_internal/req/constructors.py,sha256=w5-kWWVCqlSqcIBitw86yq7XGMPpKrHDfQZSE2mJ_xc,14388 -pip/_internal/req/req_file.py,sha256=ECqRUicCw5Y08R1YynZAAp8dSKQhDXoc1Q-mY3a9b6I,18485 -pip/_internal/req/req_install.py,sha256=wjsIr4lDpbVSLqANKJI9mXwRVHaRxcnj8q30UiHoLRA,30442 -pip/_internal/req/req_set.py,sha256=GsrKmupRKhNMhjkofVfCEHEHfgEvYBxClaQH5xLBQHg,8066 -pip/_internal/req/req_tracker.py,sha256=27fvVG8Y2MJS1KpU2rBMnQyUEMHG4lkHT_bzbzQK-c0,4723 -pip/_internal/req/req_uninstall.py,sha256=DWnOsuyYGju6-sylyoCm7GtUNevn9qMAVhjAGLcdXUE,23609 -pip/_internal/self_outdated_check.py,sha256=3KO1pTJUuYaiV9X0t87I9PimkGL82HbhLWbocqKZpBU,8009 -pip/_internal/utils/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -pip/_internal/utils/__pycache__/__init__.cpython-38.pyc,, -pip/_internal/utils/__pycache__/appdirs.cpython-38.pyc,, -pip/_internal/utils/__pycache__/compat.cpython-38.pyc,, -pip/_internal/utils/__pycache__/deprecation.cpython-38.pyc,, -pip/_internal/utils/__pycache__/distutils_args.cpython-38.pyc,, -pip/_internal/utils/__pycache__/encoding.cpython-38.pyc,, -pip/_internal/utils/__pycache__/entrypoints.cpython-38.pyc,, -pip/_internal/utils/__pycache__/filesystem.cpython-38.pyc,, -pip/_internal/utils/__pycache__/filetypes.cpython-38.pyc,, -pip/_internal/utils/__pycache__/glibc.cpython-38.pyc,, -pip/_internal/utils/__pycache__/hashes.cpython-38.pyc,, -pip/_internal/utils/__pycache__/inject_securetransport.cpython-38.pyc,, -pip/_internal/utils/__pycache__/logging.cpython-38.pyc,, -pip/_internal/utils/__pycache__/marker_files.cpython-38.pyc,, -pip/_internal/utils/__pycache__/misc.cpython-38.pyc,, -pip/_internal/utils/__pycache__/models.cpython-38.pyc,, -pip/_internal/utils/__pycache__/packaging.cpython-38.pyc,, -pip/_internal/utils/__pycache__/pkg_resources.cpython-38.pyc,, -pip/_internal/utils/__pycache__/setuptools_build.cpython-38.pyc,, -pip/_internal/utils/__pycache__/subprocess.cpython-38.pyc,, -pip/_internal/utils/__pycache__/temp_dir.cpython-38.pyc,, -pip/_internal/utils/__pycache__/typing.cpython-38.pyc,, -pip/_internal/utils/__pycache__/ui.cpython-38.pyc,, -pip/_internal/utils/__pycache__/unpacking.cpython-38.pyc,, -pip/_internal/utils/__pycache__/urls.cpython-38.pyc,, -pip/_internal/utils/__pycache__/virtualenv.cpython-38.pyc,, -pip/_internal/utils/__pycache__/wheel.cpython-38.pyc,, -pip/_internal/utils/appdirs.py,sha256=PVo_7-IQWHa9qNuNbWSFiF2QGqeLbSAR4eLcYYhQ9ek,1307 -pip/_internal/utils/compat.py,sha256=D7FKGLBdQwWH-dHIGaoWMawDZWBYApvtJVL1kFPJ930,8869 -pip/_internal/utils/deprecation.py,sha256=pBnNogoA4UGTxa_JDnPXBRRYpKMbExAhXpBwAwklOBs,3318 -pip/_internal/utils/distutils_args.py,sha256=a56mblNxk9BGifbpEETG61mmBrqhjtjRkJ4HYn-oOEE,1350 -pip/_internal/utils/encoding.py,sha256=hxZz0t3Whw3d4MHQEiofxalTlfKwxFdLc8fpeGfhKo8,1320 -pip/_internal/utils/entrypoints.py,sha256=vHcNpnksCv6mllihU6hfifdsKPEjwcaJ1aLIXEaynaU,1152 -pip/_internal/utils/filesystem.py,sha256=PXa3vMcz4mbEKtkD0joFI8pBwddLQxhfPFOkVH5xjfE,5255 -pip/_internal/utils/filetypes.py,sha256=R2FwzoeX7b-rZALOXx5cuO8VPPMhUQ4ne7wm3n3IcWA,571 -pip/_internal/utils/glibc.py,sha256=LOeNGgawCKS-4ke9fii78fwXD73dtNav3uxz1Bf-Ab8,3297 -pip/_internal/utils/hashes.py,sha256=my-wSnAWEDvl_8rQaOQcVIWjwh1-f_QiEvGy9TPf53U,3942 -pip/_internal/utils/inject_securetransport.py,sha256=M17ZlFVY66ApgeASVjKKLKNz0LAfk-SyU0HZ4ZB6MmI,810 -pip/_internal/utils/logging.py,sha256=aJL7NldPhS5KGFof6Qt3o3MG5cjm5TOoo7bGRu9_wsg,13033 -pip/_internal/utils/marker_files.py,sha256=CO5djQlrPIozJpJybViH_insoAaBGY1aqEt6-cC-iW0,741 -pip/_internal/utils/misc.py,sha256=uIb58Hiu_g2HRORo2aMcgnW_7R5d-5wUAuoW0fA2ZME,26085 -pip/_internal/utils/models.py,sha256=IA0hw_T4awQzui0kqfIEASm5yLtgZAB08ag59Nip5G8,1148 -pip/_internal/utils/packaging.py,sha256=VtiwcAAL7LBi7tGL2je7LeW4bE11KMHGCsJ1NZY5XtM,3035 -pip/_internal/utils/pkg_resources.py,sha256=ZX-k7V5q_aNWyDse92nN7orN1aCpRLsaxzpkBZ1XKzU,1254 -pip/_internal/utils/setuptools_build.py,sha256=DouaVolV9olDDFIIN9IszaL-FHdNaZt10ufOZFH9ZAU,5070 -pip/_internal/utils/subprocess.py,sha256=Ph3x5eHQBxFotyGhpZN8asSMBud-BBkmgaNfARG-di8,9922 -pip/_internal/utils/temp_dir.py,sha256=87Ib8aNic_hoSDEmUYJHTQIn5-prL2AYL5u_yZ3s4sI,7768 -pip/_internal/utils/typing.py,sha256=xkYwOeHlf4zsHXBDC4310HtEqwhQcYXFPq2h35Tcrl0,1401 -pip/_internal/utils/ui.py,sha256=0FNxXlGtbpPtTviv2oXS9t8bQG_NBdfUgP4GbubhS9U,13911 -pip/_internal/utils/unpacking.py,sha256=M944JTSiapBOSKLWu7lbawpVHSE7flfzZTEr3TAG7v8,9438 -pip/_internal/utils/urls.py,sha256=aNV9wq5ClUmrz6sG-al7hEWJ4ToitOy7l82CmFGFNW8,1481 -pip/_internal/utils/virtualenv.py,sha256=Q3S1WPlI7JWpGOT2jUVJ8l2chm_k7VPJ9cHA_cUluEU,3396 -pip/_internal/utils/wheel.py,sha256=grTRwZtMQwApwbbSPmRVLtac6FKy6SVKeCXNkWyyePA,7302 -pip/_internal/vcs/__init__.py,sha256=viJxJRqRE_mVScum85bgQIXAd6o0ozFt18VpC-qIJrM,617 -pip/_internal/vcs/__pycache__/__init__.cpython-38.pyc,, -pip/_internal/vcs/__pycache__/bazaar.cpython-38.pyc,, -pip/_internal/vcs/__pycache__/git.cpython-38.pyc,, -pip/_internal/vcs/__pycache__/mercurial.cpython-38.pyc,, -pip/_internal/vcs/__pycache__/subversion.cpython-38.pyc,, -pip/_internal/vcs/__pycache__/versioncontrol.cpython-38.pyc,, -pip/_internal/vcs/bazaar.py,sha256=84q1-kj1_nJ9AMzMu8RmMp-riRZu81M7K9kowcYgi3U,3957 -pip/_internal/vcs/git.py,sha256=CdLz3DTsZsLMLPZpEuUwiS40npvDaVB1CNRzoXgcuJQ,14352 -pip/_internal/vcs/mercurial.py,sha256=2mg7BdYI_Fe00fF6omaNccFQLPHBsDBG5CAEzvqn5sA,5110 -pip/_internal/vcs/subversion.py,sha256=Fpwy71AmuqXnoKi6h1SrXRtPjEMn8fieuM1O4j01IBg,12292 -pip/_internal/vcs/versioncontrol.py,sha256=nqoaM1_rzx24WnHtihXA8RcPpnUae0sV2sR_LS_5HFA,22600 -pip/_internal/wheel_builder.py,sha256=gr9jE14W5ZuYblpldo-tpRuyG0e0AVmHLttImuAvXlE,9441 -pip/_vendor/__init__.py,sha256=RcHf8jwLPL0ZEaa6uMhTSfyCrA_TpWgDWAW5br9xD7Y,4975 -pip/_vendor/__pycache__/__init__.cpython-38.pyc,, diff --git a/venv/lib/python3.8/site-packages/pip-20.0.2.dist-info/WHEEL b/venv/lib/python3.8/site-packages/pip-20.0.2.dist-info/WHEEL deleted file mode 100644 index ef99c6c..0000000 --- a/venv/lib/python3.8/site-packages/pip-20.0.2.dist-info/WHEEL +++ /dev/null @@ -1,6 +0,0 @@ -Wheel-Version: 1.0 -Generator: bdist_wheel (0.34.2) -Root-Is-Purelib: true -Tag: py2-none-any -Tag: py3-none-any - diff --git a/venv/lib/python3.8/site-packages/pip-20.0.2.dist-info/entry_points.txt b/venv/lib/python3.8/site-packages/pip-20.0.2.dist-info/entry_points.txt deleted file mode 100644 index d48bd8a..0000000 --- a/venv/lib/python3.8/site-packages/pip-20.0.2.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/venv/lib/python3.8/site-packages/pip-20.0.2.dist-info/top_level.txt b/venv/lib/python3.8/site-packages/pip-20.0.2.dist-info/top_level.txt deleted file mode 100644 index a1b589e..0000000 --- a/venv/lib/python3.8/site-packages/pip-20.0.2.dist-info/top_level.txt +++ /dev/null @@ -1 +0,0 @@ -pip diff --git a/venv/lib/python3.8/site-packages/pip/__init__.py b/venv/lib/python3.8/site-packages/pip/__init__.py deleted file mode 100644 index 827a4e2..0000000 --- a/venv/lib/python3.8/site-packages/pip/__init__.py +++ /dev/null @@ -1,18 +0,0 @@ -from pip._internal.utils.typing import MYPY_CHECK_RUNNING - -if MYPY_CHECK_RUNNING: - from typing import List, Optional - - -__version__ = "20.0.2" - - -def main(args=None): - # type: (Optional[List[str]]) -> 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. - """ - from pip._internal.utils.entrypoints import _wrapper - - return _wrapper(args) diff --git a/venv/lib/python3.8/site-packages/pip/__main__.py b/venv/lib/python3.8/site-packages/pip/__main__.py deleted file mode 100644 index e83b9e0..0000000 --- a/venv/lib/python3.8/site-packages/pip/__main__.py +++ /dev/null @@ -1,19 +0,0 @@ -from __future__ import absolute_import - -import os -import sys - -# If we are running from a wheel, add the wheel to sys.path -# This allows the usage python pip-*.whl/pip install pip-*.whl -if __package__ == '': - # __file__ is pip-*.whl/pip/__main__.py - # first dirname call strips of '/__main__.py', second strips off '/pip' - # Resulting path is the name of the wheel itself - # Add that to sys.path so we can import pip - path = os.path.dirname(os.path.dirname(__file__)) - sys.path.insert(0, path) - -from pip._internal.cli.main import main as _main # isort:skip # noqa - -if __name__ == '__main__': - sys.exit(_main()) diff --git a/venv/lib/python3.8/site-packages/pip/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/__pycache__/__init__.cpython-38.pyc deleted file mode 100644 index 1cfdc5295dcca8432e1af8fc758774ffde03da8e..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 629 zcmZuv&2H2%5Vn(S8kSZ0zjS*v53X7W;0d^$LEwnv z8a24Y7zu0$;Ghngune21j4H zcuc^aK`P^1UP>ceI3{a*k60nd(m8D(=J`UpWp|QQZIkO>vm7{cX>BKLzPs~aFIy8C z-wcc(p)13*76uyMhRlrqRhe}Ts57CQ>2(XI){Oie7!WgyOYjYu1kQd1i_WGUGS_B1d=_t)~KST|a%0IJ>AfR|NFdn72NH>Pt{}bYRE!D#K xp%3vN;D3Vg1jBVoKMP~w#VB1ft%Y3)*L+s;sA+jui^slu>!oi75xx;d;cxb8qICcO diff --git a/venv/lib/python3.8/site-packages/pip/__pycache__/__main__.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/__pycache__/__main__.cpython-38.pyc deleted file mode 100644 index 6c70a4ee8997c5d01002feef1f6dfd34f1a6fa18..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 422 zcmYjMyH3L}6t$hW4Sj(S;tv=)G-W`*fDjWS3u4J)h5Dv->pXBAwVnBqX5^Q=GVu#c z_(mXcCEwTaImdn(j|arZ&GkjPV}yL-@ISa89{j1-K1m{}COJ(g#hz)Fu&xG40HF*v z%sc{H^F!}9_gmW1ghSwWktD!d)-gkUln;_2B`}iQvoZ({V;H`Z7M0mEnfAWCADL2j zoW9njZY&6uSEaE}4!2>Rs=`G=U=?CIaRVW;#x@3oF#aRNv9fkSy|3L+h$>xd(xr!7 zSfzI5`cj!9%>flMr4i_ int - """This is preserved for old console scripts that may still be referencing - it. - - For additional details, see https://github.com/pypa/pip/issues/7498. - """ - from pip._internal.utils.entrypoints import _wrapper - - return _wrapper(args) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/__pycache__/__init__.cpython-38.pyc deleted file mode 100644 index 21fa558c4b42712b6c6454863b1ddf22cef0a3fe..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 678 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 tzJ diff --git a/venv/lib/python3.8/site-packages/pip/_internal/__pycache__/exceptions.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/__pycache__/exceptions.cpython-38.pyc deleted file mode 100644 index f26ec825f3f6858facbeaba23f2f5a2dd6de6ca4..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 12482 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 z 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 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/__pycache__/main.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/__pycache__/main.cpython-38.pyc deleted file mode 100644 index b20e095d3e4b3e2e5db15feab03088dc915213e1..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 615 zcmZuv&2H2%5Vn)-535!}h!Yol;Sh;UE>&9)LP)FfBOoB4hwf$N#?y_3lNgWFRZuy> zb8zPYc$r)|@d}(6Z&B3)BhRP#EYEy1wvTsrXN>G%|DOEG8T%E;b&H8SA;*kBF~tq5 z`I2)6+zH~5iRyS6*U2*BOpR5dM&I~yq~iB1o&2U8mh$1&>yx)9tHtx9#mm*Z>j1%> zgA!-06RlCAY#VG12rQkp9)+)@7q#pKdToq21>xWf95khF)-yq-eKy+$PpO1dN?-OT z6nLo(-WLcUD(@{m%=5MORd*zaw&OQ;3I9*41UOt2Fr{AT}}qyLG2!(4OHPl(GY=j+9TfZ|)SDD=$q^mO<1b3U7&uWI;y zzWq~AtZ3RlX)*noSUkW#`v$<*+M3UNJ!FyI))~!>&}bXQXtqs^W>|`>wiT7z<;ZT^ zQKemps_kkt*Pe@N?OJiB6wXKWcAaUwE+o!a;e}|Sy%1e&UyK&piv>*?e3sfvpfOID z`N|nM!}ruUY#? z{+hqyU&8FizVS?JTt43Xl*e3nk~?1PI|qr_cMbx%=j?p4<7{ny=sZlK)RVz(5C-zd zdG7VH<{MZ*YcO@e+s%@&FS#2;X(D8+QC0>h)P>IIP{>`06ROrpkK|qwk5)Yr8FYrL zg&>w(q=Eywu@`Z*G>!R+i!4ZDH6M8$Hw``6O+=JI`r_|C-}&5q_~?^|zjdE})@nU& zecCXT`6S4svVWgS9P&a{dfrb%4)Xb(LW4gH*&VN3Yrfxbuf6ckArKu#R~vmaFXR6Z z|7;DwXQ!HEQqSRkU;mSSSv%3s7_4Ztl=emk1u5_{31VeLUaE{t3P`SvuHXi7H~Ctl z=+eHucT+~`%``}F^yAd)>~sId!5-(~jiBHA^3KuL0qxzy5m*KHxS8@4-XLQ((<8Mq z&C->L8z+7u-z7y!4b2d%fHSwDn@|iJ_-9W6q;|@3?Tigr&cvgfo$6=W3-hnqKpz+b zQyRH`!T^mE*3}24KWklv2-RQP(#%V_d7}SXJ7EJWwsNh9F}Dgk%!njaZ2Xr<|3G>ccVn*#;TT^s|W%HZva!8#>7`}%EYN5^~_#QVQ;k* zb15<7qcDj3hnu%P*t$IsO(~q@pOdF`dy%h=A^6|n)4mE)6ZlQ!Kx$0&g;e

pPB!LGJt zvqiSd?9w6=A7bynY)k1<*!BS?Q&weUSF91eXG~nBqJVTTE02bax>I^Z%1Tk}p zZL=kQ20qFfhIT_2?_(*N01Z>zqOEEsVUUb!aN+Gjt+7cqiTXByEdperw{O4V_P88d zU{Wtzpv>w3nvQ6~&t_E}@kI8Rxib|#imBqxcQKK;HFA{go8p>8T=`V?khz#4kBcIR z0`UxmalF?>Z1`GH4&D$uK>%01Li6`%&Qy7n5^rn2RA@hH79*NAj${^qrq|fIE`EVo zrzmrT!$ylxGo1DT|IXi>S4ZU@2z8bt5Gz>xYQBbuK zmjMu%bu_h*M?98je@QIJ7;me)I&JK!uC)u=tawl8HnU)CnEIE%bx6(eNBfih@((O} z+5j(yL5WPeUlD6V(+^58Erpjpu&`Us@yfvNR&Jo~mVvQxLBc#j5Tcx7t*1NEIDxD7 z^+6@Ch%`4(O<6+SF6Xvy{LP?*kCzK9DtCc3hu8vF2Bihc(ilg{?mdH@pK{q3vEw;Z zGM%LBWc`#{KldH#O%BSm!@bU)GxD92rMwe#1MCNJ)xr10XeaxkSuGHEQ2@MXeBds4 zqiqIpZ;ZK4V&ont-jTC$`}T$dAse?hH?9}wi761RB<4-$Iq1fs4}vgscDdtaSwA8L zld-l=(ihH0A3ttRD=^NLyCa>C3ZeWE)!Z5HIY&v~Iq+iXeC36KKaoGaJ9Hgu^0-^5 zblvG^yx>%H8z(!;B#$NxXEdOI`yuJGf%w1cFcqi{@t#q_+YNq52cZAIg28Yox25z> ziicBuHtW&fcY_S=Ve;fN)ZCQj;sG*7d<1~x{T0nWo*?X^Mid!WRJbC!mBkMw+KZs_ zCa9hW%Em^u$ZTbg1)*udCdz<#RhfkMl!ym(lmx44kh!Cm?c0@Mo~rQV^ggJw-vDS! zrf#Ah*m|`XthkJ9C*%zfVY?R!z;_d|Z48cs%y)?_slU|YXht-;XCdJSf;8tD2f_9eS! M+tsSZir;tt0sa(|KL7v# diff --git a/venv/lib/python3.8/site-packages/pip/_internal/__pycache__/pyproject.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/__pycache__/pyproject.cpython-38.pyc deleted file mode 100644 index c3a0d36a0d37c5ac1981e10700b506a5b9cef792..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3732 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 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/__pycache__/wheel_builder.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/__pycache__/wheel_builder.cpython-38.pyc deleted file mode 100644 index 62f3651ccaf542c1f4b4bff7753516478141cf4d..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6699 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 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'] - # Note: prefer distutils' sysconfig to get the - # library paths so PyPy is correctly supported. - purelib = get_python_lib(plat_specific=False, prefix=path) - platlib = get_python_lib(plat_specific=True, prefix=path) - if purelib == platlib: - self.lib_dirs = [purelib] - else: - self.lib_dirs = [purelib, platlib] - - -class BuildEnvironment(object): - """Creates and manages an isolated environment to install build deps - """ - - def __init__(self): - # type: () -> None - self._temp_dir = TempDirectory(kind="build-env") - - self._prefixes = OrderedDict(( - (name, _Prefix(os.path.join(self._temp_dir.path, name))) - for name in ('normal', 'overlay') - )) - - self._bin_dirs = [] # type: List[str] - self._lib_dirs = [] # type: List[str] - for prefix in reversed(list(self._prefixes.values())): - self._bin_dirs.append(prefix.bin_dir) - self._lib_dirs.extend(prefix.lib_dirs) - - # Customize site to: - # - ensure .pth files are honored - # - prevent access to system site packages - system_sites = { - os.path.normcase(site) for site in ( - get_python_lib(plat_specific=False), - get_python_lib(plat_specific=True), - ) - } - self._site_dir = os.path.join(self._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( - ''' - import os, site, sys - - # First, drop system-sites related paths. - original_sys_path = sys.path[:] - known_paths = set() - for path in {system_sites!r}: - site.addsitedir(path, known_paths=known_paths) - system_paths = set( - os.path.normcase(path) - for path in sys.path[len(original_sys_path):] - ) - original_sys_path = [ - path for path in original_sys_path - if os.path.normcase(path) not in system_paths - ] - sys.path = original_sys_path - - # Second, add lib directories. - # ensuring .pth file are processed. - 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)) - - def __enter__(self): - self._save_env = { - name: os.environ.get(name, None) - for name in ('PATH', 'PYTHONNOUSERSITE', 'PYTHONPATH') - } - - path = self._bin_dirs[:] - 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), - }) - - def __exit__(self, exc_type, exc_val, exc_tb): - 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 cleanup(self): - # type: () -> None - self._temp_dir.cleanup() - - def check_requirements(self, reqs): - # type: (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 - """ - 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]))) - return conflicting, missing - - def install_requirements( - self, - finder, # type: PackageFinder - requirements, # type: Iterable[str] - prefix_as_string, # type: str - message # type: Optional[str] - ): - # type: (...) -> None - prefix = self._prefixes[prefix_as_string] - assert not prefix.setup - prefix.setup = True - if not requirements: - return - args = [ - sys.executable, os.path.dirname(pip_location), 'install', - '--ignore-installed', '--no-user', '--prefix', prefix.path, - '--no-warn-script-location', - ] # type: List[str] - if logger.getEffectiveLevel() <= logging.DEBUG: - 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:'})))) - - index_urls = finder.index_urls - if index_urls: - args.extend(['-i', index_urls[0]]) - for extra_index in index_urls[1:]: - args.extend(['--extra-index-url', extra_index]) - else: - args.append('--no-index') - for link in finder.find_links: - args.extend(['--find-links', link]) - - for host in finder.trusted_hosts: - args.extend(['--trusted-host', host]) - if finder.allow_all_prereleases: - args.append('--pre') - args.append('--') - args.extend(requirements) - with open_spinner(message) as spinner: - call_subprocess(args, spinner=spinner) - - -class NoOpBuildEnvironment(BuildEnvironment): - """A no-op drop-in replacement for BuildEnvironment - """ - - def __init__(self): - pass - - def __enter__(self): - pass - - def __exit__(self, exc_type, exc_val, exc_tb): - pass - - def cleanup(self): - pass - - def install_requirements(self, finder, requirements, prefix, message): - raise NotImplementedError() diff --git a/venv/lib/python3.8/site-packages/pip/_internal/cache.py b/venv/lib/python3.8/site-packages/pip/_internal/cache.py deleted file mode 100644 index abecd78..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/cache.py +++ /dev/null @@ -1,329 +0,0 @@ -"""Cache Management -""" - -# The following comment should be removed at some point in the future. -# mypy: strict-optional=False - -import hashlib -import json -import logging -import os - -from pip._vendor.packaging.tags import interpreter_name, interpreter_version -from pip._vendor.packaging.utils import canonicalize_name - -from pip._internal.exceptions import InvalidWheelFilename -from pip._internal.models.link import Link -from pip._internal.models.wheel import Wheel -from pip._internal.utils.temp_dir import TempDirectory -from pip._internal.utils.typing import MYPY_CHECK_RUNNING -from pip._internal.utils.urls import path_to_url - -if MYPY_CHECK_RUNNING: - from typing import Optional, Set, List, Any, Dict - - from pip._vendor.packaging.tags import Tag - - from pip._internal.models.format_control import FormatControl - -logger = logging.getLogger(__name__) - - -def _hash_dict(d): - # type: (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() - - -class Cache(object): - """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) - """ - - def __init__(self, cache_dir, format_control, allowed_formats): - # type: (str, FormatControl, Set[str]) -> None - super(Cache, self).__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_legacy(self, link): - # type: (Link) -> List[str] - """Get parts of part that must be os.path.joined with cache_dir - - Legacy cache key (pip < 20) for compatibility with older caches. - """ - - # 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 - # and we don't care about those. - key_parts = [link.url_without_fragment] - if link.hash_name is not None and link.hash is not None: - key_parts.append("=".join([link.hash_name, link.hash])) - key_url = "#".join(key_parts) - - # Encode our key url with sha224, we'll use this because it has similar - # security properties to sha256, but with a shorter total output (and - # thus less secure). However the differences don't make a lot of - # difference for our use case here. - hashed = hashlib.sha224(key_url.encode()).hexdigest() - - # We want to nest the directories some to prevent having a ton of top - # level directories where we might run out of sub directories on some - # FS. - parts = [hashed[:2], hashed[2:4], hashed[4:6], hashed[6:]] - - return parts - - def _get_cache_path_parts(self, link): - # type: (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 - # and we don't care about those. - key_parts = {"url": link.url_without_fragment} - if link.hash_name is not None and link.hash is not None: - key_parts[link.hash_name] = link.hash - if link.subdirectory_fragment: - key_parts["subdirectory"] = link.subdirectory_fragment - - # Include interpreter name, major and minor version in cache key - # to cope with ill-behaved sdists that build a different wheel - # depending on the python version their setup.py is being run on, - # and don't encode the difference in compatibility tags. - # https://github.com/pypa/pip/issues/7296 - key_parts["interpreter_name"] = interpreter_name() - key_parts["interpreter_version"] = interpreter_version() - - # Encode our key url with sha224, we'll use this because it has similar - # security properties to sha256, but with a shorter total output (and - # thus less secure). However the differences don't make a lot of - # difference for our use case here. - hashed = _hash_dict(key_parts) - - # We want to nest the directories some to prevent having a ton of top - # level directories where we might run out of sub directories on some - # FS. - parts = [hashed[:2], hashed[2:4], hashed[4:6], hashed[6:]] - - return parts - - def _get_candidates(self, link, canonical_package_name): - # type: (Link, Optional[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): - for candidate in os.listdir(path): - candidates.append((candidate, path)) - # TODO remove legacy path lookup in pip>=21 - legacy_path = self.get_path_for_link_legacy(link) - if os.path.isdir(legacy_path): - for candidate in os.listdir(legacy_path): - candidates.append((candidate, legacy_path)) - return candidates - - def get_path_for_link_legacy(self, link): - # type: (Link) -> str - raise NotImplementedError() - - def get_path_for_link(self, link): - # type: (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 - """Returns a link to a cached item if it exists, otherwise returns the - passed link. - """ - raise NotImplementedError() - - def cleanup(self): - # type: () -> None - pass - - -class SimpleWheelCache(Cache): - """A cache of wheels for future installs. - """ - - def __init__(self, cache_dir, format_control): - # type: (str, FormatControl) -> None - super(SimpleWheelCache, self).__init__( - cache_dir, format_control, {"binary"} - ) - - def get_path_for_link_legacy(self, link): - # type: (Link) -> str - parts = self._get_cache_path_parts_legacy(link) - return os.path.join(self.cache_dir, "wheels", *parts) - - def get_path_for_link(self, link): - # type: (Link) -> str - """Return a directory to store cached wheels for link - - Because there are M wheels for any one sdist, we provide a directory - to cache them in, and then consult that directory when looking up - cache hits. - - We only insert things into the cache if they have plausible version - numbers, so that we don't contaminate the cache with things that were - not unique. E.g. ./package might have dozens of installs done for it - and build a version of 0.0...and if we built and cached a wheel, we'd - end up using the same wheel even if the source has been edited. - - :param link: The link of the sdist for which this will cache wheels. - """ - parts = self._get_cache_path_parts(link) - - # Store wheels within the root cache_dir - return os.path.join(self.cache_dir, "wheels", *parts) - - def get( - self, - link, # type: Link - package_name, # type: Optional[str] - supported_tags, # type: List[Tag] - ): - # type: (...) -> 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 - ): - try: - wheel = Wheel(wheel_name) - except InvalidWheelFilename: - continue - if canonicalize_name(wheel.name) != canonical_package_name: - logger.debug( - "Ignoring cached wheel {} for {} as it " - "does not match the expected distribution name {}.".format( - wheel_name, link, package_name - ) - ) - continue - if not wheel.supported(supported_tags): - # Built for a different python/arch/etc - continue - candidates.append( - ( - wheel.support_index_min(supported_tags), - wheel_name, - wheel_dir, - ) - ) - - if not candidates: - return link - - _, wheel_name, wheel_dir = min(candidates) - return Link(path_to_url(os.path.join(wheel_dir, wheel_name))) - - -class EphemWheelCache(SimpleWheelCache): - """A SimpleWheelCache that creates it's own temporary cache directory - """ - - def __init__(self, format_control): - # type: (FormatControl) -> None - self._temp_dir = TempDirectory(kind="ephem-wheel-cache") - - super(EphemWheelCache, self).__init__( - self._temp_dir.path, format_control - ) - - def cleanup(self): - # type: () -> None - self._temp_dir.cleanup() - - -class WheelCache(Cache): - """Wraps EphemWheelCache and SimpleWheelCache into a single Cache - - This Cache allows for gracefully degradation, using the ephem wheel 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(WheelCache, self).__init__( - cache_dir, format_control, {'binary'} - ) - self._wheel_cache = SimpleWheelCache(cache_dir, format_control) - self._ephem_cache = EphemWheelCache(format_control) - - def get_path_for_link_legacy(self, link): - # type: (Link) -> str - return self._wheel_cache.get_path_for_link_legacy(link) - - def get_path_for_link(self, link): - # type: (Link) -> str - return self._wheel_cache.get_path_for_link(link) - - def get_ephem_path_for_link(self, link): - # type: (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 - retval = self._wheel_cache.get( - link=link, - package_name=package_name, - supported_tags=supported_tags, - ) - if retval is not link: - return retval - - return self._ephem_cache.get( - link=link, - package_name=package_name, - supported_tags=supported_tags, - ) - - def cleanup(self): - # type: () -> None - self._wheel_cache.cleanup() - self._ephem_cache.cleanup() diff --git a/venv/lib/python3.8/site-packages/pip/_internal/cli/__init__.py b/venv/lib/python3.8/site-packages/pip/_internal/cli/__init__.py deleted file mode 100644 index e589bb9..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/cli/__init__.py +++ /dev/null @@ -1,4 +0,0 @@ -"""Subpackage containing all of pip's command line interface related code -""" - -# This file intentionally does not import submodules diff --git a/venv/lib/python3.8/site-packages/pip/_internal/cli/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/cli/__pycache__/__init__.cpython-38.pyc deleted file mode 100644 index dbdc1daa5d96942fdce96c8bff94cf747232b66e..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 236 zcmYjMu?oU45KUba!GFji;!v}QI!JMIb15z^;Y_YIn5MB!kvjV`{*tSo;O6Aj$%FTf zcMsm<_M_2|(JU8ZxYK@h;(sC%8$vxG((J%=l(K2>woRL(2X%%Vxhh=%}9zzSuJkR(lza^~CTU|p2Dv6yrpyb0_Jt!zTP diff --git a/venv/lib/python3.8/site-packages/pip/_internal/cli/__pycache__/autocompletion.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/cli/__pycache__/autocompletion.cpython-38.pyc deleted file mode 100644 index 8fcaf4102cd2e6c67031269d86223d6cdcf7dfdd..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4953 zcmb7IZEqXL5#HT99?26$Nt7Z>isM{f8@91jplK7hiW|QOi4jE>EIThmo#Tmjk|-W| z)ZR(5gd@;GX=@iP;G#u==9BcLX#PUcAJLD&er$mP`3wFK_nAFXFSY};6n1ZKc6N4W zcAl9z-5DOX8Gdj7vt<0YL{vyJufU zeCq-GjCI7PEXf_Po=B`Dk9Ed6>p@~Km$K{Z?nKW@t<-2)awoNVxbv;wZSABvU$lx3 zg?s~}d`rl`C56MHZys^ZKq<7W=$GrKCMrqa!W+p-3s_n1*~v(1AAtUlZ&gmtkc_4| zXfl)zZH{eL!1+$El$JKflZnmeS_an7<82b{+&R*5vNxQX*kc%!sWn0SKwb@P-Y@yX zUobjPW=XR1by)WS{|#T`ei^fc)FevJ{0#$TGa?~k{HrjGd&Z-Wmu80*{MKbhm9zrQ#O8U@DtY1XLRvZEz45{AK+dnzaqRo*84C&dd1{>42)h^$#n$H? zr?1g?UmGF+3a{zwL%x%Y_>+e(YD=8cmN4iPN1V=gaz7f+Q~N(#=p=H_S&o{W#952v zDXcotnnQ?mfI%nTUhMm^P}a(h1&~D%BG?F$<15W zSH9r@PoHp&D2gd_BM7?yxEXImyQ;X|>0|g2zjzzCwZo|4g>KXd_ZqZ%@T2gULt83WS;;9uO`2!ilpb9;U3oxQhqX>Jbj1)&0wVXhH2=gx+@+3udQ=R*V# z3UHS{pmUk%EGF3g>982g&TF0G%NPvU&*(-WhL(<#3_ZdJ4_fN%| z$TZYC=&ou=BoijdB8u-o;bK2pv4wC3x5Un)CtJC`UEdypieL} zIKd&i4+}rz3}4~G5b$LZ?>3W-{$Uhv$qSHy$$Vp5$^cGAMwiD&`4Df%N3qWyg)W+m zp)Z<(us%wOF4|`U15~-b-^>I;n?RXeFWJa8I=kC#+HG((dfhj)$-cOFQBGoT#u79` z_o271V4%0RY5UE-e`ULJHI!k&rAw{$55b$yI>G0Vb9{nF+<9upW7|LJ*#o$UPB-7xB`Yll@sE`owgvX@-Plk2gXqC8Jm>k`hgGQ&;wx`7%e zKn|#Z=84sCfA@76ZFgh&J?t&%PSx<5jM{GVIQ4HL=v60_)!2=sAEO+hr~EOo4xPk1 zm@X3-tC16`+wt0{9%zMn4oBV&eeDG&^@u7SmnKSt4P{b&0<0VdQe{A{7Vg68YUD}f za-?#stZa8x#M2GE)gV+RhOsKIglvgRv+zaUDWjPfaChF3&I2rdxz ztjA`~;x=X=M>w>~9Od9gBMFm+#l>S2Qs`+J=eZCCUZ7Z`w!*fqZoN$VR*T*uGR*ryf@(N$$R8^EgLAg+4dLB3szIziRex%3jy;kBL29WOaCJk0T8Exixk zHUg;^Iy;_hQuPXnCz-Zhe@e*zBSR!qm}I` zgJfHFE5I0V*cs>$q)65r63spVN_92kWPTCAmvXje<9dfO3`_TGq$7qAh$U zQ3-%t^ctp>N%mI;Y`>I6N*y?L%sdX9syM$6B;D)E%fBSK6a!5m9`FC)yJF9&ls;Hl zE$CROqn&&k668CyzX5b-Q8(WX5|~md!|Uu-bMgxDT&3<7b&JH!qbJkHJjh#UF`b(g zXEYc~0B(iP0Fd^#1*3v;8gmT_bAum!xe$zAL5u%^j=oC{MT#_zq%Iz0??wtBp=M-< z01P;CM}9w}5IDt9w?qvQHC4!wz|> z-CKtIQqzm6g<|5%G_UXLV@W7amY=j2X!e-oiPYi_;a8?snpU_z$0Azh#ZQt41jmOr$33|R`|d;G<2(-z$dPNtpaI-E zvo6t8abT%ERq8v6EqiaO%|eSd=^SQIXP}}+2{OvHf4Af@^GEt1sUkQZ=l@ujmqWCDdg>(M}3qSN8 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/cli/__pycache__/base_command.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/cli/__pycache__/base_command.cpython-38.pyc deleted file mode 100644 index ca77a4a7ef69886a50a8c81efe37eb0ed3550cb5..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 5847 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 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/cli/__pycache__/cmdoptions.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/cli/__pycache__/cmdoptions.cpython-38.pyc deleted file mode 100644 index e8882ec9aab95baf08b068414128f820b62976d0..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 20328 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 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/cli/__pycache__/main_parser.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/cli/__pycache__/main_parser.cpython-38.pyc deleted file mode 100644 index 8803ae91e51d0083fd35814461df84f4fe1b1de5..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2159 zcmZWrTW{P%6!wh0w%6I+TpH4g09l2!T8Sj6LM;*@qDos@Q9?!AhZ-u&^-NqR<4b2| znnO!)MgY=xkI)xj#g%^27?=ZjUM%^Na z0;9WZrszdIGxk`&7(|0&HkviM&*qBxXdYQ~o;R>omn{@$qBF%}vbNO~fQmrCQ9Wj747LEaCC-6ztU7Y~5~hUg@w|?N{e@{G4(D`zzlV zc$I}lYG}gz8+heJ|c^>bY z>O&qk2L>+mP3S^`(Djtop+#(oKsvv6#+Jm}R%88y#;8FP`^Z9;bPlZs#U1HRJn8QE z4LZVO471$^A0enx2WA7}W{7yie`(2?N$<$IVI88g*4QT9Nx!j=V6}MAAgEh#aCOtX zwlMYKRE~HlPM60N6H;?ogqwHo1R=D83&C;?xe3>&DcuOao7U~|E#+pcdXlhVM|DOb z$*7u52#KFUq2ks_bpao3#gtPf1td|g_CQ%Ff?OOo8wMTd_o0jTL1d7Q$4lSiF&bk6 ziD>YSwT+jopYbyXj)M;T<&`VfM7S)VXr34W5cvMkR(SPeeg@)IZ~D4%UT#;vTl_p2 z|GvH^i+T+XxH2m1B;BQCW$!7aY$YFM&pzG%WKYknK?ne>OxRk=^0gCXUaj|4u+9Jk zuz0<3MZc^mFLwVsxb!wGR@YgTCQNL=;5bO3U^vTl6z^)GPp;0BTqI8zZFd$m0F#n9 z;hEsRp7*9u<@%CP^F^{tr}>RDUX5zi&uB?`!lvq+u0mUYsm0O9;5x;slS^6% zsb&ZjDbEe>hK}mCc#e1Xlsknsu%py#3BC-`CXcPSpw&KzbI`>_5SEJ(Mvm_PxPE|q z?Arqr*sdL5_g~-X;Wvt|kERo0nDHkJG%E}PP-7h-C_WzBPh77 z@H7*oJ@GYT8kEXfRsN5~9y%KIqb8Uqem&L_{#Uj~%Lc{%P6c#ioWoxy=m2fz3va5pj zZZT-k)KIqA7s?fqR3oW6dmQSia3z$-@{$T#D~GPhzgR|`X*^tZ+{s%caRV@Gj diff --git a/venv/lib/python3.8/site-packages/pip/_internal/cli/__pycache__/parser.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/cli/__pycache__/parser.cpython-38.pyc deleted file mode 100644 index d8b08e2b3a95cf8f9e21bd06f817d1ac88553e3f..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 8977 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 G_WlR_fE*bB diff --git a/venv/lib/python3.8/site-packages/pip/_internal/cli/__pycache__/req_command.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/cli/__pycache__/req_command.cpython-38.pyc deleted file mode 100644 index 4fe7f8e4f32a30f9db3cd40a096264cab1b36396..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 8289 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 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/cli/autocompletion.py b/venv/lib/python3.8/site-packages/pip/_internal/cli/autocompletion.py deleted file mode 100644 index 329de60..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/cli/autocompletion.py +++ /dev/null @@ -1,164 +0,0 @@ -"""Logic that powers autocompletion installed by ``pip completion``. -""" - -import optparse -import os -import sys -from itertools import chain - -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.utils.typing import MYPY_CHECK_RUNNING - -if MYPY_CHECK_RUNNING: - from typing import Any, Iterable, List, Optional - - -def autocomplete(): - # type: () -> 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: - return - cwords = os.environ['COMP_WORDS'].split()[1:] - cword = int(os.environ['COMP_CWORD']) - try: - current = cwords[cword - 1] - except IndexError: - current = '' - - parser = create_main_parser() - subcommands = list(commands_dict) - options = [] - - # subcommand - subcommand_name = None # type: Optional[str] - for word in cwords: - if word in subcommands: - subcommand_name = word - break - # subcommand options - if subcommand_name is not None: - # special case: 'help' subcommand has no options - if subcommand_name == 'help': - sys.exit(1) - # special case: list locally installed dists for show and uninstall - should_list_installed = ( - subcommand_name in ['show', 'uninstall'] and - not current.startswith('-') - ) - if should_list_installed: - installed = [] - lc = current.lower() - for dist in get_installed_distributions(local_only=True): - if dist.key.startswith(lc) and dist.key not in cwords[1:]: - installed.append(dist.key) - # if there are no dists installed, fall back to option completion - if installed: - for dist in installed: - print(dist) - sys.exit(1) - - subcommand = create_command(subcommand_name) - - for opt in subcommand.parser.option_list_all: - if opt.help != optparse.SUPPRESS_HELP: - for opt_str in opt._long_opts + opt._short_opts: - options.append((opt_str, opt.nargs)) - - # filter out previously specified options from available options - prev_opts = [x.split('=')[0] for x in cwords[1:cword - 1]] - options = [(x, v) for (x, v) in options if x not in prev_opts] - # filter options by current input - options = [(k, v) for k, v in options if k.startswith(current)] - # get completion type given cwords and available subcommand options - completion_type = get_path_completion_type( - cwords, cword, subcommand.parser.option_list_all, - ) - # get completion files and directories if ``completion_type`` is - # ````, ``

`` or ```` - if completion_type: - paths = auto_complete_paths(current, completion_type) - options = [(path, 0) for path in paths] - for option in options: - opt_label = option[0] - # append '=' to options which require args - if option[1] and option[0][:2] == "--": - opt_label += '=' - print(opt_label) - else: - # show main parser options only when necessary - - opts = [i.option_list for i in parser.option_groups] - opts.append(parser.option_list) - flattened_opts = chain.from_iterable(opts) - if current.startswith('-'): - for opt in flattened_opts: - if opt.help != optparse.SUPPRESS_HELP: - subcommands += opt._long_opts + opt._short_opts - else: - # get completion type given cwords and all available options - completion_type = get_path_completion_type(cwords, cword, - flattened_opts) - if completion_type: - subcommands = list(auto_complete_paths(current, - completion_type)) - - print(' '.join([x for x in subcommands if x.startswith(current)])) - sys.exit(1) - - -def get_path_completion_type(cwords, cword, opts): - # type: (List[str], int, Iterable[Any]) -> Optional[str] - """Get the type of path completion (``file``, ``dir``, ``path`` or None) - - :param cwords: same as the environmental variable ``COMP_WORDS`` - :param cword: same as the environmental variable ``COMP_CWORD`` - :param opts: The available options to check - :return: path completion type (``file``, ``dir``, ``path`` or None) - """ - if cword < 2 or not cwords[cword - 2].startswith('-'): - return None - for opt in opts: - if opt.help == optparse.SUPPRESS_HELP: - continue - for o in str(opt).split('/'): - if cwords[cword - 2].split('=')[0] == o: - if not opt.metavar or any( - x in ('path', 'file', 'dir') - for x in opt.metavar.split('/')): - return opt.metavar - return None - - -def auto_complete_paths(current, completion_type): - # type: (str, 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 - :return: A generator of regular files and/or directories - """ - directory, filename = os.path.split(current) - current_path = os.path.abspath(directory) - # Don't complete paths if they can't be accessed - if not os.access(current_path, os.R_OK): - return - filename = os.path.normcase(filename) - # list all files that start with ``filename`` - file_list = (x for x in os.listdir(current_path) - if os.path.normcase(x).startswith(filename)) - for f in file_list: - opt = os.path.join(current_path, f) - comp_file = os.path.normcase(os.path.join(directory, f)) - # complete regular files when there is not ```` after option - # complete directories when there is ````, ```` or - # ````after option - if completion_type != 'dir' and os.path.isfile(opt): - yield comp_file - elif os.path.isdir(opt): - yield os.path.join(comp_file, '') diff --git a/venv/lib/python3.8/site-packages/pip/_internal/cli/base_command.py b/venv/lib/python3.8/site-packages/pip/_internal/cli/base_command.py deleted file mode 100644 index 628faa3..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/cli/base_command.py +++ /dev/null @@ -1,226 +0,0 @@ -"""Base Command class, and related routines""" - -from __future__ import absolute_import, print_function - -import logging -import logging.config -import optparse -import os -import platform -import sys -import traceback - -from pip._internal.cli import cmdoptions -from pip._internal.cli.command_context import CommandContextMixIn -from pip._internal.cli.parser import ( - ConfigOptionParser, - UpdatingDefaultsHelpFormatter, -) -from pip._internal.cli.status_codes import ( - ERROR, - PREVIOUS_BUILD_DIR_ERROR, - SUCCESS, - UNKNOWN_ERROR, - VIRTUALENV_NOT_FOUND, -) -from pip._internal.exceptions import ( - BadCommand, - CommandError, - InstallationError, - 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 -from pip._internal.utils.temp_dir import global_tempdir_manager -from pip._internal.utils.typing import MYPY_CHECK_RUNNING -from pip._internal.utils.virtualenv import running_under_virtualenv - -if MYPY_CHECK_RUNNING: - from typing import List, Tuple, Any - from optparse import Values - -__all__ = ['Command'] - -logger = logging.getLogger(__name__) - - -class Command(CommandContextMixIn): - usage = None # type: str - ignore_require_venv = False # type: bool - - def __init__(self, name, summary, isolated=False): - # type: (str, str, bool) -> None - super(Command, self).__init__() - parser_kw = { - 'usage': self.usage, - 'prog': '%s %s' % (get_prog(), name), - 'formatter': UpdatingDefaultsHelpFormatter(), - 'add_help_option': False, - 'name': name, - 'description': self.__doc__, - 'isolated': isolated, - } - - self.name = name - self.summary = summary - self.parser = ConfigOptionParser(**parser_kw) - - # Commands should add options to this option group - optgroup_name = '%s Options' % self.name.capitalize() - self.cmd_opts = optparse.OptionGroup(self.parser, optgroup_name) - - # Add the general options - gen_opts = cmdoptions.make_option_group( - cmdoptions.general_group, - self.parser, - ) - self.parser.add_option_group(gen_opts) - - def handle_pip_version_check(self, options): - # type: (Values) -> None - """ - This is a no-op so that commands by default do not do the pip version - check. - """ - # Make sure we do the pip version check if the index_group options - # are present. - assert not hasattr(options, 'no_index') - - def run(self, options, args): - # type: (Values, List[Any]) -> Any - raise NotImplementedError - - def parse_args(self, args): - # type: (List[str]) -> Tuple[Any, Any] - # factored out for testability - return self.parser.parse_args(args) - - def main(self, args): - # type: (List[str]) -> int - try: - with self.main_context(): - return self._main(args) - finally: - logging.shutdown() - - def _main(self, args): - # type: (List[str]) -> int - # Intentionally set as early as possible so globally-managed temporary - # directories are available to the rest of the code. - self.enter_context(global_tempdir_manager()) - - options, args = self.parse_args(args) - - # Set verbosity so that it can be used elsewhere. - self.verbosity = options.verbose - options.quiet - - level_number = setup_logging( - verbosity=self.verbosity, - no_color=options.no_color, - user_log_file=options.log, - ) - - if ( - sys.version_info[:2] == (2, 7) and - not options.no_python_version_warning - ): - message = ( - "A future version of pip will drop support for Python 2.7. " - "More details about Python 2 support in pip, can be found at " - "https://pip.pypa.io/en/latest/development/release-process/#python-2-support" # noqa - ) - if platform.python_implementation() == "CPython": - message = ( - "Python 2.7 reached the end of its life on January " - "1st, 2020. Please upgrade your Python as Python 2.7 " - "is no longer maintained. " - ) + message - deprecated(message, replacement=None, gone_in=None) - - if options.skip_requirements_regex: - deprecated( - "--skip-requirements-regex is unsupported and will be removed", - replacement=( - "manage requirements/constraints files explicitly, " - "possibly generating them from metadata" - ), - gone_in="20.1", - issue=7297, - ) - - # 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. - - if options.no_input: - os.environ['PIP_NO_INPUT'] = '1' - - if options.exists_action: - os.environ['PIP_EXISTS_ACTION'] = ' '.join(options.exists_action) - - if options.require_venv and not self.ignore_require_venv: - # If a venv is required check if it can really be found - if not running_under_virtualenv(): - logger.critical( - 'Could not find an activated virtualenv (required).' - ) - sys.exit(VIRTUALENV_NOT_FOUND) - - if options.cache_dir: - options.cache_dir = normalize_path(options.cache_dir) - if not check_path_owner(options.cache_dir): - logger.warning( - "The directory '%s' or its parent directory is not owned " - "or is not writable by the current user. The cache " - "has been disabled. Check the permissions and owner of " - "that directory. If executing pip with sudo, you may want " - "sudo's -H flag.", - options.cache_dir, - ) - options.cache_dir = None - - try: - status = self.run(options, args) - # FIXME: all commands should return an exit status - # and when it is done, isinstance is not needed anymore - if 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) 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 - finally: - self.handle_pip_version_check(options) - - return SUCCESS diff --git a/venv/lib/python3.8/site-packages/pip/_internal/cli/cmdoptions.py b/venv/lib/python3.8/site-packages/pip/_internal/cli/cmdoptions.py deleted file mode 100644 index 447f319..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/cli/cmdoptions.py +++ /dev/null @@ -1,957 +0,0 @@ -""" -shared options and groups - -The principle here is to define options once, but *not* instantiate them -globally. One reason being that options with action='append' can carry state -between parses. pip parses general options twice internally, and shouldn't -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 - -from __future__ import absolute_import - -import logging -import os -import textwrap -import warnings -from distutils.util import strtobool -from functools import partial -from optparse import SUPPRESS_HELP, Option, OptionGroup -from textwrap import dedent - -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 -from pip._internal.models.index import PyPI -from pip._internal.models.target_python import TargetPython -from pip._internal.utils.hashes import STRONG_HASHES -from pip._internal.utils.typing import MYPY_CHECK_RUNNING -from pip._internal.utils.ui import BAR_TYPES - -if MYPY_CHECK_RUNNING: - from typing import Any, Callable, Dict, Optional, Tuple - from optparse import OptionParser, Values - from pip._internal.cli.parser import ConfigOptionParser - -logger = logging.getLogger(__name__) - - -def raise_option_error(parser, option, msg): - # type: (OptionParser, Option, str) -> None - """ - Raise an option parsing error using parser.error(). - - Args: - parser: an OptionParser instance. - option: an Option instance. - msg: the error text. - """ - msg = '{} error: {}'.format(option, msg) - msg = textwrap.fill(' '.join(msg.split())) - parser.error(msg) - - -def make_option_group(group, parser): - # type: (Dict[str, Any], ConfigOptionParser) -> OptionGroup - """ - Return an OptionGroup object - group -- assumed to be dict with 'name' and 'options' keys - parser -- an optparse Parser - """ - option_group = OptionGroup(parser, group['name']) - for option in group['options']: - option_group.add_option(option()) - 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 - """Function for determining if custom platform options are allowed. - - :param options: The OptionParser options. - :param check_target: Whether or not to check if --target is being used. - """ - dist_restriction_set = any([ - options.python_version, - options.platform, - options.abi, - options.implementation, - ]) - - binary_only = FormatControl(set(), {':all:'}) - sdist_dependencies_allowed = ( - options.format_control != binary_only and - not options.ignore_dependencies - ) - - # Installations or downloads using dist restrictions must not combine - # source distributions and dist-specific wheels, as they are not - # guaranteed to be locally compatible. - if dist_restriction_set and sdist_dependencies_allowed: - raise CommandError( - "When restricting platform and interpreter constraints using " - "--python-version, --platform, --abi, or --implementation, " - "either --no-deps must be set, or --only-binary=:all: must be " - "set and --no-binary must not be set (or must be set to " - ":none:)." - ) - - if check_target: - if dist_restriction_set and not options.target_dir: - raise CommandError( - "Can not use any platform or abi specific options unless " - "installing via '--target'" - ) - - -def _path_option_check(option, opt, value): - # type: (Option, str, str) -> str - return os.path.expanduser(value) - - -class PipOption(Option): - TYPES = Option.TYPES + ("path",) - TYPE_CHECKER = Option.TYPE_CHECKER.copy() - TYPE_CHECKER["path"] = _path_option_check - - -########### -# options # -########### - -help_ = partial( - Option, - '-h', '--help', - dest='help', - action='help', - help='Show help.', -) # type: Callable[..., Option] - -isolated_mode = partial( - Option, - "--isolated", - dest="isolated_mode", - action="store_true", - default=False, - help=( - "Run pip in an isolated mode, ignoring environment variables and user " - "configuration." - ), -) # type: Callable[..., Option] - -require_virtualenv = 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] - -verbose = partial( - Option, - '-v', '--verbose', - dest='verbose', - 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( - Option, - '--no-color', - dest='no_color', - action='store_true', - default=False, - help="Suppress colored output", -) # type: Callable[..., Option] - -version = partial( - Option, - '-V', '--version', - dest='version', - action='store_true', - help='Show version and exit.', -) # type: Callable[..., Option] - -quiet = partial( - Option, - '-q', '--quiet', - dest='quiet', - action='count', - default=0, - help=( - 'Give less output. Option is additive, and can be used up to 3' - ' times (corresponding to WARNING, ERROR, and CRITICAL logging' - ' levels).' - ), -) # type: Callable[..., Option] - -progress_bar = partial( - Option, - '--progress-bar', - dest='progress_bar', - type='choice', - choices=list(BAR_TYPES.keys()), - default='on', - help=( - 'Specify type of progress to be displayed [' + - '|'.join(BAR_TYPES.keys()) + '] (default: %default)' - ), -) # type: Callable[..., Option] - -log = partial( - PipOption, - "--log", "--log-file", "--local-log", - dest="log", - metavar="path", - type="path", - help="Path to a verbose appending log." -) # type: Callable[..., Option] - -no_input = partial( - Option, - # Don't ask for input - '--no-input', - dest='no_input', - action='store_true', - default=False, - help=SUPPRESS_HELP -) # type: Callable[..., Option] - -proxy = partial( - Option, - '--proxy', - dest='proxy', - type='str', - default='', - help="Specify a proxy in the form [user:passwd@]proxy.server:port." -) # type: Callable[..., Option] - -retries = partial( - Option, - '--retries', - dest='retries', - type='int', - default=5, - help="Maximum number of retries each connection should attempt " - "(default %default times).", -) # type: Callable[..., Option] - -timeout = partial( - Option, - '--timeout', '--default-timeout', - metavar='sec', - dest='timeout', - type='float', - default=15, - help='Set the socket timeout (default %default seconds).', -) # type: Callable[..., Option] - -skip_requirements_regex = partial( - Option, - # A regex to be used to skip requirements - '--skip-requirements-regex', - dest='skip_requirements_regex', - type='str', - default='', - help=SUPPRESS_HELP, -) # type: Callable[..., Option] - - -def exists_action(): - # type: () -> Option - return Option( - # Option when path already exist - '--exists-action', - dest='exists_action', - type='choice', - choices=['s', 'i', 'w', 'b', 'a'], - default=[], - action='append', - metavar='action', - help="Default action when a path already exists: " - "(s)witch, (i)gnore, (w)ipe, (b)ackup, (a)bort.", - ) - - -cert = partial( - PipOption, - '--cert', - dest='cert', - type='path', - metavar='path', - help="Path to alternate CA bundle.", -) # type: Callable[..., Option] - -client_cert = partial( - PipOption, - '--client-cert', - dest='client_cert', - type='path', - default=None, - 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( - Option, - '-i', '--index-url', '--pypi-url', - dest='index_url', - metavar='URL', - default=PyPI.simple_url, - help="Base URL of the Python Package Index (default %default). " - "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 - return Option( - '--extra-index-url', - dest='extra_index_urls', - metavar='URL', - action='append', - default=[], - help="Extra URLs of package indexes to use in addition to " - "--index-url. Should follow the same rules as " - "--index-url.", - ) - - -no_index = 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 - return Option( - '-f', '--find-links', - dest='find_links', - action='append', - default=[], - metavar='url', - help="If a url or path to an html file, then parse for links to " - "archives. If a local path or file:// url that's a directory, " - "then look for archives in the directory listing.", - ) - - -def trusted_host(): - # type: () -> Option - return Option( - "--trusted-host", - dest="trusted_hosts", - action="append", - metavar="HOSTNAME", - default=[], - help="Mark this host or host:port pair as trusted, even though it " - "does not have valid or any HTTPS.", - ) - - -def constraints(): - # type: () -> Option - return Option( - '-c', '--constraint', - dest='constraints', - action='append', - default=[], - metavar='file', - help='Constrain versions using the given constraints file. ' - 'This option can be used multiple times.' - ) - - -def requirements(): - # type: () -> Option - return Option( - '-r', '--requirement', - dest='requirements', - action='append', - default=[], - metavar='file', - help='Install from the given requirements file. ' - 'This option can be used multiple times.' - ) - - -def editable(): - # type: () -> Option - return Option( - '-e', '--editable', - dest='editables', - action='append', - default=[], - metavar='path/url', - help=('Install a project in editable mode (i.e. setuptools ' - '"develop mode") from a local project path or a VCS url.'), - ) - - -def _handle_src(option, opt_str, value, parser): - # type: (Option, str, str, OptionParser) -> None - value = os.path.abspath(value) - setattr(parser.values, option.dest, value) - - -src = partial( - PipOption, - '--src', '--source', '--source-dir', '--source-directory', - dest='src_dir', - type='path', - metavar='dir', - default=get_src_prefix(), - action='callback', - callback=_handle_src, - help='Directory to check out editable projects into. ' - 'The default in a virtualenv is "/src". ' - 'The default for global installs is "/src".' -) # type: Callable[..., Option] - - -def _get_format_control(values, option): - # type: (Values, 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 - existing = _get_format_control(parser.values, option) - FormatControl.handle_mutual_excludes( - value, existing.no_binary, existing.only_binary, - ) - - -def _handle_only_binary(option, opt_str, value, parser): - # type: (Option, str, str, OptionParser) -> None - existing = _get_format_control(parser.values, option) - FormatControl.handle_mutual_excludes( - value, existing.only_binary, existing.no_binary, - ) - - -def no_binary(): - # type: () -> Option - format_control = FormatControl(set(), set()) - return Option( - "--no-binary", dest="format_control", action="callback", - callback=_handle_no_binary, type="str", - default=format_control, - help="Do not use binary packages. Can be supplied multiple times, and " - "each time adds to the existing value. Accepts either :all: to " - "disable all binary packages, :none: to empty the set, or one or " - "more package names with commas between them (no colons). Note " - "that some packages are tricky to compile and may fail to " - "install when this option is used on them.", - ) - - -def only_binary(): - # type: () -> Option - format_control = FormatControl(set(), set()) - return Option( - "--only-binary", dest="format_control", action="callback", - callback=_handle_only_binary, type="str", - default=format_control, - help="Do not use source packages. Can be supplied multiple times, and " - "each time adds to the existing value. Accepts either :all: to " - "disable all source packages, :none: to empty the set, or one or " - "more package names with commas between them. Packages without " - "binary distributions will fail to install when this option is " - "used on them.", - ) - - -platform = partial( - Option, - '--platform', - dest='platform', - metavar='platform', - default=None, - help=("Only use wheels compatible with . " - "Defaults to the platform of the running system."), -) # 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]] - """ - Convert a version string like "3", "37", or "3.7.3" into a tuple of ints. - - :return: A 2-tuple (version_info, error_msg), where `error_msg` is - non-None if and only if there was a parsing error. - """ - if not value: - # The empty string is the same as not providing a value. - return (None, None) - - parts = value.split('.') - if len(parts) > 3: - return ((), 'at most three version parts are allowed') - - if len(parts) == 1: - # Then we are in the case of "3" or "37". - value = parts[0] - if len(value) > 1: - parts = [value[0], value[1:]] - - try: - version_info = tuple(int(part) for part in parts) - except ValueError: - return ((), 'each version part must be an integer') - - return (version_info, None) - - -def _handle_python_version(option, opt_str, value, parser): - # type: (Option, str, str, OptionParser) -> None - """ - Handle a provided --python-version value. - """ - version_info, error_msg = _convert_python_version(value) - if error_msg is not None: - msg = ( - 'invalid --python-version value: {!r}: {}'.format( - value, error_msg, - ) - ) - raise_option_error(parser, option=option, msg=msg) - - parser.values.python_version = version_info - - -python_version = partial( - Option, - '--python-version', - dest='python_version', - metavar='python_version', - action='callback', - callback=_handle_python_version, type='str', - default=None, - help=dedent("""\ - The Python interpreter version to use for wheel and "Requires-Python" - compatibility checks. Defaults to a version derived from the running - interpreter. The version can be specified using up to three dot-separated - integers (e.g. "3" for 3.0.0, "3.7" for 3.7.0, or "3.7.3"). A major-minor - version can also be given as a string without dots (e.g. "37" for 3.7.0). - """), -) # type: Callable[..., Option] - - -implementation = partial( - Option, - '--implementation', - dest='implementation', - metavar='implementation', - default=None, - help=("Only use wheels compatible with Python " - "implementation , e.g. 'pp', 'jy', 'cp', " - " or 'ip'. If not specified, then the current " - "interpreter implementation is used. Use 'py' to force " - "implementation-agnostic wheels."), -) # type: Callable[..., Option] - - -abi = partial( - Option, - '--abi', - dest='abi', - metavar='abi', - default=None, - help=("Only use wheels compatible with Python " - "abi , e.g. 'pypy_41'. If not specified, then the " - "current interpreter abi tag is used. Generally " - "you will need to specify --implementation, " - "--platform, and --python-version when using " - "this option."), -) # type: Callable[..., Option] - - -def add_target_python_options(cmd_opts): - # type: (OptionGroup) -> None - cmd_opts.add_option(platform()) - cmd_opts.add_option(python_version()) - cmd_opts.add_option(implementation()) - cmd_opts.add_option(abi()) - - -def make_target_python(options): - # type: (Values) -> TargetPython - target_python = TargetPython( - platform=options.platform, - py_version_info=options.python_version, - abi=options.abi, - implementation=options.implementation, - ) - - return target_python - - -def prefer_binary(): - # type: () -> Option - return Option( - "--prefer-binary", - dest="prefer_binary", - action="store_true", - default=False, - help="Prefer older binary packages over newer source packages." - ) - - -cache_dir = partial( - PipOption, - "--cache-dir", - dest="cache_dir", - default=USER_CACHE_DIR, - metavar="dir", - type='path', - help="Store the cache data in ." -) # type: Callable[..., Option] - - -def _handle_no_cache_dir(option, opt, value, parser): - # type: (Option, str, str, OptionParser) -> None - """ - Process a value provided for the --no-cache-dir option. - - This is an optparse.Option callback for the --no-cache-dir option. - """ - # The value argument will be None if --no-cache-dir is passed via the - # command-line, since the option doesn't accept arguments. However, - # the value can be non-None if the option is triggered e.g. by an - # environment variable, like PIP_NO_CACHE_DIR=true. - if value is not None: - # Then parse the string value to get argument error-checking. - try: - strtobool(value) - except ValueError as exc: - raise_option_error(parser, option=option, msg=str(exc)) - - # Originally, setting PIP_NO_CACHE_DIR to a value that strtobool() - # converted to 0 (like "false" or "no") caused cache_dir to be disabled - # rather than enabled (logic would say the latter). Thus, we disable - # the cache directory not just on values that parse to True, but (for - # backwards compatibility reasons) also on values that parse to False. - # In other words, always set it to False if the option is provided in - # some (valid) form. - parser.values.cache_dir = False - - -no_cache = 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( - Option, - '--no-deps', '--no-dependencies', - dest='ignore_dependencies', - action='store_true', - default=False, - help="Don't install package dependencies.", -) # type: Callable[..., Option] - - -def _handle_build_dir(option, opt, value, parser): - # type: (Option, str, str, OptionParser) -> None - if value: - value = os.path.abspath(value) - setattr(parser.values, option.dest, value) - - -build_dir = partial( - PipOption, - '-b', '--build', '--build-dir', '--build-directory', - dest='build_dir', - type='path', - metavar='dir', - action='callback', - callback=_handle_build_dir, - help='Directory to unpack packages into and build in. Note that ' - 'an initial build still takes place in a temporary directory. ' - 'The location of temporary directories can be controlled by setting ' - 'the TMPDIR environment variable (TEMP on Windows) appropriately. ' - 'When passed, build directories are not cleaned in case of failures.' -) # type: Callable[..., Option] - -ignore_requires_python = 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( - Option, - '--no-build-isolation', - dest='build_isolation', - action='store_false', - default=True, - 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] - - -def _handle_no_use_pep517(option, opt, value, parser): - # type: (Option, str, str, OptionParser) -> None - """ - Process a value provided for the --no-use-pep517 option. - - This is an optparse.Option callback for the no_use_pep517 option. - """ - # Since --no-use-pep517 doesn't accept arguments, the value argument - # will be None if --no-use-pep517 is passed via the command-line. - # However, the value can be non-None if the option is triggered e.g. - # by an environment variable, for example "PIP_NO_USE_PEP517=true". - if value is not None: - msg = """A value was passed for --no-use-pep517, - probably using either the PIP_NO_USE_PEP517 environment variable - or the "no-use-pep517" config file option. Use an appropriate value - of the PIP_USE_PEP517 environment variable or the "use-pep517" - config file option instead. - """ - 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( - Option, - '--use-pep517', - dest='use_pep517', - action='store_true', - default=None, - help='Use PEP 517 for building source distributions ' - '(use --no-use-pep517 to force legacy behaviour).' -) # type: Any - -no_use_pep517 = partial( - Option, - '--no-use-pep517', - dest='use_pep517', - action='callback', - callback=_handle_no_use_pep517, - default=None, - help=SUPPRESS_HELP -) # type: Any - -install_options = 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] - -global_options = partial( - Option, - '--global-option', - dest='global_options', - action='append', - metavar='options', - help="Extra global options to be supplied to the setup.py " - "call before the install command.", -) # type: Callable[..., Option] - -no_clean = partial( - Option, - '--no-clean', - action='store_true', - default=False, - help="Don't clean up build directories." -) # type: Callable[..., Option] - -pre = 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( - Option, - "--disable-pip-version-check", - dest="disable_pip_version_check", - action="store_true", - default=True, - 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] - - -# Deprecated, Remove later -always_unzip = partial( - Option, - '-Z', '--always-unzip', - dest='always_unzip', - action='store_true', - help=SUPPRESS_HELP, -) # type: Callable[..., Option] - - -def _handle_merge_hash(option, opt_str, value, parser): - # type: (Option, str, str, 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: - parser.values.hashes = {} - try: - algo, digest = value.split(':', 1) - except ValueError: - parser.error('Arguments to %s must be a hash name ' - 'followed by a value, like --hash=sha256:abcde...' % - opt_str) - if algo not in STRONG_HASHES: - parser.error('Allowed hash algorithms for %s are %s.' % - (opt_str, ', '.join(STRONG_HASHES))) - parser.values.hashes.setdefault(algo, []).append(digest) - - -hash = partial( - Option, - '--hash', - # Hash values eventually end up in InstallRequirement.hashes due to - # __dict__ copying in process_line(). - dest='hashes', - action='callback', - callback=_handle_merge_hash, - type='string', - help="Verify that the package's archive matches this " - 'hash before installing. Example: --hash=sha256:abcdef...', -) # type: Callable[..., Option] - - -require_hashes = partial( - Option, - '--require-hashes', - dest='require_hashes', - action='store_true', - default=False, - 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( - PipOption, - '--path', - dest='path', - type='path', - 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 - if options.path and (options.user or options.local): - raise CommandError( - "Cannot combine '--path' with '--user' or '--local'" - ) - - -no_python_version_warning = 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] - - -########## -# groups # -########## - -general_group = { - 'name': 'General Options', - 'options': [ - help_, - isolated_mode, - require_virtualenv, - verbose, - version, - quiet, - log, - no_input, - proxy, - retries, - timeout, - skip_requirements_regex, - exists_action, - trusted_host, - cert, - client_cert, - cache_dir, - no_cache, - disable_pip_version_check, - no_color, - no_python_version_warning, - ] -} # type: Dict[str, Any] - -index_group = { - 'name': 'Package Index Options', - 'options': [ - index_url, - extra_index_url, - no_index, - find_links, - ] -} # type: Dict[str, Any] diff --git a/venv/lib/python3.8/site-packages/pip/_internal/cli/command_context.py b/venv/lib/python3.8/site-packages/pip/_internal/cli/command_context.py deleted file mode 100644 index d1a64a7..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/cli/command_context.py +++ /dev/null @@ -1,36 +0,0 @@ -from contextlib import contextmanager - -from pip._vendor.contextlib2 import ExitStack - -from pip._internal.utils.typing import MYPY_CHECK_RUNNING - -if MYPY_CHECK_RUNNING: - from typing import Iterator, ContextManager, TypeVar - - _T = TypeVar('_T', covariant=True) - - -class CommandContextMixIn(object): - def __init__(self): - # type: () -> None - super(CommandContextMixIn, self).__init__() - self._in_main_context = False - self._main_context = ExitStack() - - @contextmanager - def main_context(self): - # type: () -> Iterator[None] - assert not self._in_main_context - - self._in_main_context = True - try: - with self._main_context: - yield - finally: - self._in_main_context = False - - def enter_context(self, context_provider): - # type: (ContextManager[_T]) -> _T - assert self._in_main_context - - return self._main_context.enter_context(context_provider) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/cli/main.py b/venv/lib/python3.8/site-packages/pip/_internal/cli/main.py deleted file mode 100644 index 5e97a51..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/cli/main.py +++ /dev/null @@ -1,75 +0,0 @@ -"""Primary application entrypoint. -""" -from __future__ import absolute_import - -import locale -import logging -import os -import sys - -from pip._internal.cli.autocompletion import autocomplete -from pip._internal.cli.main_parser import parse_command -from pip._internal.commands import create_command -from pip._internal.exceptions import PipError -from pip._internal.utils import deprecation -from pip._internal.utils.typing import MYPY_CHECK_RUNNING - -if MYPY_CHECK_RUNNING: - from typing import List, Optional - -logger = logging.getLogger(__name__) - - -# Do not import and use main() directly! Using it directly is actively -# discouraged by pip's maintainers. The name, location and behavior of -# this function is subject to change, so calling it directly is not -# portable across different pip versions. - -# In addition, running pip in-process is unsupported and unsafe. This is -# elaborated in detail at -# https://pip.pypa.io/en/stable/user_guide/#using-pip-from-your-program. -# That document also provides suggestions that should work for nearly -# all users that are considering importing and using main() directly. - -# However, we know that certain users will still want to invoke pip -# in-process. If you understand and accept the implications of using pip -# in an unsupported manner, the best approach is to use runpy to avoid -# depending on the exact location of this entry point. - -# The following example shows how to use runpy to invoke pip in that -# case: -# -# sys.argv = ["pip", your, args, here] -# runpy.run_module("pip", run_name="__main__") -# -# Note that this will exit the process after running, unlike a direct -# call to main. As it is not safe to do any processing after calling -# main, this should not be an issue in practice. - -def main(args=None): - # type: (Optional[List[str]]) -> int - if args is None: - args = sys.argv[1:] - - # Configure our deprecation warnings to be sent through loggers - deprecation.install_warning_logger() - - autocomplete() - - try: - cmd_name, cmd_args = parse_command(args) - except PipError as exc: - sys.stderr.write("ERROR: %s" % exc) - sys.stderr.write(os.linesep) - sys.exit(1) - - # Needed for locale.getpreferredencoding(False) to work - # in pip._internal.utils.encoding.auto_decode - try: - locale.setlocale(locale.LC_ALL, '') - except locale.Error as e: - # setlocale can apparently crash if locale are uninitialized - logger.debug("Ignoring error %s when setting locale", e) - command = create_command(cmd_name, isolated=("--isolated" in cmd_args)) - - return command.main(cmd_args) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/cli/main_parser.py b/venv/lib/python3.8/site-packages/pip/_internal/cli/main_parser.py deleted file mode 100644 index a89821d..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/cli/main_parser.py +++ /dev/null @@ -1,99 +0,0 @@ -"""A single place for constructing and exposing the main parser -""" - -import os -import sys - -from pip._internal.cli import cmdoptions -from pip._internal.cli.parser import ( - ConfigOptionParser, - UpdatingDefaultsHelpFormatter, -) -from pip._internal.commands import commands_dict, get_similar_commands -from pip._internal.exceptions import CommandError -from pip._internal.utils.misc import get_pip_version, get_prog -from pip._internal.utils.typing import MYPY_CHECK_RUNNING - -if MYPY_CHECK_RUNNING: - from typing import Tuple, List - - -__all__ = ["create_main_parser", "parse_command"] - - -def create_main_parser(): - # type: () -> ConfigOptionParser - """Creates and returns the main parser for pip's CLI - """ - - parser_kw = { - 'usage': '\n%prog [options]', - 'add_help_option': False, - 'formatter': UpdatingDefaultsHelpFormatter(), - 'name': 'global', - 'prog': get_prog(), - } - - parser = ConfigOptionParser(**parser_kw) - parser.disable_interspersed_args() - - parser.version = get_pip_version() - - # add the general options - gen_opts = cmdoptions.make_option_group(cmdoptions.general_group, parser) - parser.add_option_group(gen_opts) - - # so the help formatter knows - parser.main = True # type: ignore - - # create command listing for description - description = [''] + [ - '%-27s %s' % (name, command_info.summary) - for name, command_info in commands_dict.items() - ] - parser.description = '\n'.join(description) - - return parser - - -def parse_command(args): - # type: (List[str]) -> Tuple[str, List[str]] - parser = create_main_parser() - - # Note: parser calls disable_interspersed_args(), so the result of this - # call is to split the initial args into the general options before the - # subcommand and everything else. - # For example: - # args: ['--timeout=5', 'install', '--user', 'INITools'] - # general_options: ['--timeout==5'] - # args_else: ['install', '--user', 'INITools'] - general_options, args_else = parser.parse_args(args) - - # --version - if general_options.version: - sys.stdout.write(parser.version) # type: ignore - sys.stdout.write(os.linesep) - sys.exit() - - # pip || pip help -> print_help() - if not args_else or (args_else[0] == 'help' and len(args_else) == 1): - parser.print_help() - sys.exit() - - # the subcommand name - cmd_name = args_else[0] - - if cmd_name not in commands_dict: - guess = get_similar_commands(cmd_name) - - msg = ['unknown command "%s"' % cmd_name] - if guess: - msg.append('maybe you meant "%s"' % guess) - - raise CommandError(' - '.join(msg)) - - # all the args without the subcommand - cmd_args = args[:] - cmd_args.remove(cmd_name) - - return cmd_name, cmd_args diff --git a/venv/lib/python3.8/site-packages/pip/_internal/cli/parser.py b/venv/lib/python3.8/site-packages/pip/_internal/cli/parser.py deleted file mode 100644 index c99456b..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/cli/parser.py +++ /dev/null @@ -1,265 +0,0 @@ -"""Base option parser setup""" - -# The following comment should be removed at some point in the future. -# mypy: disallow-untyped-defs=False - -from __future__ import absolute_import - -import logging -import optparse -import sys -import textwrap -from distutils.util import strtobool - -from pip._vendor.six import string_types - -from pip._internal.cli.status_codes import UNKNOWN_ERROR -from pip._internal.configuration import Configuration, ConfigurationError -from pip._internal.utils.compat import get_terminal_size - -logger = logging.getLogger(__name__) - - -class PrettyHelpFormatter(optparse.IndentedHelpFormatter): - """A prettier/less verbose help formatter for optparse.""" - - def __init__(self, *args, **kwargs): - # help position must be aligned with __init__.parseopts.description - kwargs['max_help_position'] = 30 - kwargs['indent_increment'] = 1 - kwargs['width'] = get_terminal_size()[0] - 2 - optparse.IndentedHelpFormatter.__init__(self, *args, **kwargs) - - def format_option_strings(self, option): - return self._format_option_strings(option, ' <%s>', ', ') - - def _format_option_strings(self, option, mvarfmt=' <%s>', optsep=', '): - """ - Return a comma-separated list of option strings and metavars. - - :param option: tuple of (short opt, long opt), e.g: ('-f', '--format') - :param mvarfmt: metavar format string - evaluated as mvarfmt % metavar - :param optsep: separator - """ - opts = [] - - if option._short_opts: - opts.append(option._short_opts[0]) - if option._long_opts: - opts.append(option._long_opts[0]) - if len(opts) > 1: - opts.insert(1, optsep) - - if option.takes_value(): - metavar = option.metavar or option.dest.lower() - opts.append(mvarfmt % metavar.lower()) - - return ''.join(opts) - - def format_heading(self, heading): - if heading == 'Options': - return '' - return heading + ':\n' - - def format_usage(self, usage): - """ - Ensure there is only one newline between usage and the first heading - if there is no description. - """ - msg = '\nUsage: %s\n' % self.indent_lines(textwrap.dedent(usage), " ") - return msg - - def format_description(self, description): - # leave full control over description to us - if description: - if hasattr(self.parser, 'main'): - label = 'Commands' - else: - label = 'Description' - # some doc strings have initial newlines, some don't - description = description.lstrip('\n') - # some doc strings have final newlines and spaces, some don't - description = description.rstrip() - # dedent, then reindent - description = self.indent_lines(textwrap.dedent(description), " ") - description = '%s:\n%s\n' % (label, description) - return description - else: - return '' - - def format_epilog(self, epilog): - # leave full control over epilog to us - if epilog: - return epilog - else: - return '' - - def indent_lines(self, text, indent): - new_lines = [indent + line for line in text.split('\n')] - return "\n".join(new_lines) - - -class UpdatingDefaultsHelpFormatter(PrettyHelpFormatter): - """Custom help formatter for use in ConfigOptionParser. - - This is updates the defaults before expanding them, allowing - them to show up correctly in the help listing. - """ - - def expand_default(self, option): - if self.parser is not None: - self.parser._update_defaults(self.parser.defaults) - return optparse.IndentedHelpFormatter.expand_default(self, option) - - -class CustomOptionParser(optparse.OptionParser): - - def insert_option_group(self, idx, *args, **kwargs): - """Insert an OptionGroup at a given position.""" - group = self.add_option_group(*args, **kwargs) - - self.option_groups.pop() - self.option_groups.insert(idx, group) - - return group - - @property - def option_list_all(self): - """Get a list of all options, including those in option groups.""" - res = self.option_list[:] - for i in self.option_groups: - res.extend(i.option_list) - - return res - - -class ConfigOptionParser(CustomOptionParser): - """Custom option parser which updates its defaults by checking the - configuration files and environmental variables""" - - def __init__(self, *args, **kwargs): - self.name = kwargs.pop('name') - - isolated = kwargs.pop("isolated", False) - self.config = Configuration(isolated) - - assert self.name - optparse.OptionParser.__init__(self, *args, **kwargs) - - def check_default(self, option, key, val): - try: - return option.check_value(key, val) - except optparse.OptionValueError as exc: - print("An error occurred during configuration: %s" % exc) - sys.exit(3) - - def _get_ordered_configuration_items(self): - # Configuration gives keys in an unordered manner. Order them. - override_order = ["global", self.name, ":env:"] - - # Pool the options into different groups - section_items = {name: [] for name in override_order} - for section_key, val in self.config.items(): - # ignore empty values - if not val: - logger.debug( - "Ignoring configuration key '%s' as it's value is empty.", - section_key - ) - continue - - section, key = section_key.split(".", 1) - if section in override_order: - section_items[section].append((key, val)) - - # Yield each group in their override order - for section in override_order: - for key, val in section_items[section]: - yield key, val - - def _update_defaults(self, defaults): - """Updates the given defaults with values from the config files and - the environ. Does a little special handling for certain types of - options (lists).""" - - # Accumulate complex default state. - self.values = optparse.Values(self.defaults) - late_eval = set() - # Then set the options with those values - for key, val in self._get_ordered_configuration_items(): - # '--' because configuration supports only long names - option = self.get_option('--' + key) - - # Ignore options not present in this parser. E.g. non-globals put - # in [global] by users that want them to apply to all applicable - # commands. - if option is None: - continue - - if option.action in ('store_true', 'store_false', 'count'): - try: - val = strtobool(val) - except ValueError: - error_msg = invalid_config_error_message( - option.action, key, val - ) - self.error(error_msg) - - elif option.action == 'append': - val = val.split() - val = [self.check_default(option, key, v) for v in val] - elif option.action == 'callback': - late_eval.add(option.dest) - opt_str = option.get_opt_string() - val = option.convert_value(opt_str, val) - # From take_action - args = option.callback_args or () - kwargs = option.callback_kwargs or {} - option.callback(option, opt_str, val, self, *args, **kwargs) - else: - val = self.check_default(option, key, val) - - defaults[option.dest] = val - - for key in late_eval: - defaults[key] = getattr(self.values, key) - self.values = None - return defaults - - def get_default_values(self): - """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: - # Old, pre-Optik 1.5 behaviour. - return optparse.Values(self.defaults) - - # Load the configuration, or error out in case of an error - try: - self.config.load() - except ConfigurationError as err: - self.exit(UNKNOWN_ERROR, str(err)) - - defaults = self._update_defaults(self.defaults.copy()) # ours - for option in self._get_all_options(): - default = defaults.get(option.dest) - if isinstance(default, string_types): - opt_str = option.get_opt_string() - defaults[option.dest] = option.check_value(opt_str, default) - return optparse.Values(defaults) - - def error(self, msg): - self.print_usage(sys.stderr) - self.exit(UNKNOWN_ERROR, "%s\n" % msg) - - -def invalid_config_error_message(action, key, val): - """Returns a better error message when invalid configuration option - is provided.""" - if action in ('store_true', 'store_false'): - return ("{0} is not a valid value for {1} option, " - "please specify a boolean value like yes/no, " - "true/false or 1/0 instead.").format(val, key) - - return ("{0} is not a valid value for {1} option, " - "please specify a numerical value like 1/0 " - "instead.").format(val, key) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/cli/req_command.py b/venv/lib/python3.8/site-packages/pip/_internal/cli/req_command.py deleted file mode 100644 index 9383b3b..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/cli/req_command.py +++ /dev/null @@ -1,333 +0,0 @@ -"""Contains the Command base classes that depend on PipSession. - -The classes in this module are in a separate module so the commands not -needing download / PackageFinder capability don't unnecessarily import the -PackageFinder machinery and all its vendored dependencies, etc. -""" - -import logging -import os -from functools import partial - -from pip._internal.cli.base_command import Command -from pip._internal.cli.command_context import CommandContextMixIn -from pip._internal.exceptions import CommandError -from pip._internal.index.package_finder import PackageFinder -from pip._internal.legacy_resolve import Resolver -from pip._internal.models.selection_prefs import SelectionPreferences -from pip._internal.network.download import Downloader -from pip._internal.network.session import PipSession -from pip._internal.operations.prepare import RequirementPreparer -from pip._internal.req.constructors import ( - install_req_from_editable, - install_req_from_line, - install_req_from_req_string, -) -from pip._internal.req.req_file import parse_requirements -from pip._internal.self_outdated_check import ( - make_link_collector, - pip_self_version_check, -) -from pip._internal.utils.typing import MYPY_CHECK_RUNNING - -if MYPY_CHECK_RUNNING: - from optparse import Values - from typing import List, Optional, Tuple - from pip._internal.cache import WheelCache - from pip._internal.models.target_python import TargetPython - from pip._internal.req.req_set import RequirementSet - from pip._internal.req.req_tracker import RequirementTracker - from pip._internal.utils.temp_dir import TempDirectory - -logger = logging.getLogger(__name__) - - -class SessionCommandMixin(CommandContextMixIn): - - """ - A class mixin for command classes needing _build_session(). - """ - def __init__(self): - # type: () -> None - super(SessionCommandMixin, self).__init__() - self._session = None # Optional[PipSession] - - @classmethod - def _get_index_urls(cls, options): - # type: (Values) -> Optional[List[str]] - """Return a list of index urls from user-provided options.""" - index_urls = [] - if not getattr(options, "no_index", False): - url = getattr(options, "index_url", None) - if url: - index_urls.append(url) - urls = getattr(options, "extra_index_urls", None) - if urls: - index_urls.extend(urls) - # Return None rather than an empty list - return index_urls or None - - def get_default_session(self, options): - # type: (Values) -> PipSession - """Get a default-managed session.""" - if self._session is None: - self._session = self.enter_context(self._build_session(options)) - # there's no type annotation on requests.Session, so it's - # automatically ContextManager[Any] and self._session becomes Any, - # then https://github.com/python/mypy/issues/7696 kicks in - 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) - session = PipSession( - cache=( - os.path.join(options.cache_dir, "http") - if options.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), - ) - - # Handle custom ca-bundles from the user - if options.cert: - session.verify = options.cert - - # Handle SSL client certificate - if options.client_cert: - session.cert = options.client_cert - - # Handle timeouts - if options.timeout or timeout: - session.timeout = ( - timeout if timeout is not None else options.timeout - ) - - # Handle configured proxies - if options.proxy: - session.proxies = { - "http": options.proxy, - "https": options.proxy, - } - - # Determine if we can prompt the user for authentication or not - session.auth.prompting = not options.no_input - - return session - - -class IndexGroupCommand(Command, SessionCommandMixin): - - """ - Abstract base class for commands with the index_group options. - - This also corresponds to the commands that permit the pip version check. - """ - - def handle_pip_version_check(self, options): - # type: (Values) -> None - """ - Do the pip version check if not disabled. - - This overrides the default behavior of not doing the check. - """ - # Make sure the index_group options are present. - assert hasattr(options, 'no_index') - - if options.disable_pip_version_check or options.no_index: - return - - # Otherwise, check if we're using the latest version of pip available. - session = self._build_session( - options, - retries=0, - timeout=min(5, options.timeout) - ) - with session: - pip_self_version_check(session, options) - - -class RequirementCommand(IndexGroupCommand): - - @staticmethod - def make_requirement_preparer( - 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 - wheel_download_dir=None, # type: str - ): - # type: (...) -> RequirementPreparer - """ - Create a RequirementPreparer instance for the given parameters. - """ - downloader = Downloader(session, progress_bar=options.progress_bar) - - temp_build_dir_path = temp_build_dir.path - assert temp_build_dir_path is not None - - return RequirementPreparer( - build_dir=temp_build_dir_path, - src_dir=options.src_dir, - download_dir=download_dir, - wheel_download_dir=wheel_download_dir, - build_isolation=options.build_isolation, - req_tracker=req_tracker, - downloader=downloader, - finder=finder, - require_hashes=options.require_hashes, - use_user_site=use_user_site, - ) - - @staticmethod - def make_resolver( - 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: (...) -> Resolver - """ - Create a Resolver instance for the given parameters. - """ - make_install_req = partial( - install_req_from_req_string, - isolated=options.isolated_mode, - wheel_cache=wheel_cache, - use_pep517=use_pep517, - ) - return Resolver( - preparer=preparer, - finder=finder, - make_install_req=make_install_req, - use_user_site=use_user_site, - ignore_dependencies=options.ignore_dependencies, - ignore_installed=ignore_installed, - ignore_requires_python=ignore_requires_python, - force_reinstall=force_reinstall, - upgrade_strategy=upgrade_strategy, - py_version_info=py_version_info, - ) - - def populate_requirement_set( - self, - requirement_set, # type: RequirementSet - args, # type: List[str] - options, # type: Values - finder, # type: PackageFinder - session, # type: PipSession - wheel_cache, # type: Optional[WheelCache] - ): - # type: (...) -> None - """ - Marshal cmd line args into a requirement set. - """ - for filename in options.constraints: - for req_to_add in parse_requirements( - filename, - constraint=True, finder=finder, options=options, - session=session, wheel_cache=wheel_cache): - req_to_add.is_direct = True - requirement_set.add_requirement(req_to_add) - - for req in args: - req_to_add = install_req_from_line( - req, None, isolated=options.isolated_mode, - use_pep517=options.use_pep517, - wheel_cache=wheel_cache - ) - req_to_add.is_direct = True - requirement_set.add_requirement(req_to_add) - - for req in options.editables: - req_to_add = install_req_from_editable( - req, - isolated=options.isolated_mode, - use_pep517=options.use_pep517, - wheel_cache=wheel_cache - ) - req_to_add.is_direct = True - requirement_set.add_requirement(req_to_add) - - # NOTE: options.require_hashes may be set if --require-hashes is True - for filename in options.requirements: - for req_to_add in parse_requirements( - filename, - finder=finder, options=options, session=session, - wheel_cache=wheel_cache, - use_pep517=options.use_pep517): - req_to_add.is_direct = True - requirement_set.add_requirement(req_to_add) - - # If any requirement has hash options, enable hash checking. - requirements = ( - requirement_set.unnamed_requirements + - list(requirement_set.requirements.values()) - ) - if any(req.has_hash_options for req in requirements): - options.require_hashes = True - - if not (args or options.editables or options.requirements): - opts = {'name': self.name} - if options.find_links: - raise CommandError( - 'You must give at least one requirement to %(name)s ' - '(maybe you meant "pip %(name)s %(links)s"?)' % - dict(opts, links=' '.join(options.find_links))) - else: - raise CommandError( - 'You must give at least one requirement to %(name)s ' - '(see "pip help %(name)s")' % opts) - - @staticmethod - def trace_basic_info(finder): - # type: (PackageFinder) -> None - """ - Trace basic information about the provided objects. - """ - # Display where finder is looking for packages - search_scope = finder.search_scope - locations = search_scope.get_formatted_locations() - if locations: - logger.info(locations) - - 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 - """ - Create a package finder appropriate to this requirement command. - - :param ignore_requires_python: Whether to ignore incompatible - "Requires-Python" values in links. Defaults to False. - """ - link_collector = make_link_collector(session, options=options) - selection_prefs = SelectionPreferences( - allow_yanked=True, - format_control=options.format_control, - allow_all_prereleases=options.pre, - prefer_binary=options.prefer_binary, - ignore_requires_python=ignore_requires_python, - ) - - return PackageFinder.create( - link_collector=link_collector, - selection_prefs=selection_prefs, - target_python=target_python, - ) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/cli/status_codes.py b/venv/lib/python3.8/site-packages/pip/_internal/cli/status_codes.py deleted file mode 100644 index 275360a..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/cli/status_codes.py +++ /dev/null @@ -1,8 +0,0 @@ -from __future__ import absolute_import - -SUCCESS = 0 -ERROR = 1 -UNKNOWN_ERROR = 2 -VIRTUALENV_NOT_FOUND = 3 -PREVIOUS_BUILD_DIR_ERROR = 4 -NO_MATCHES_FOUND = 23 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/commands/__init__.py b/venv/lib/python3.8/site-packages/pip/_internal/commands/__init__.py deleted file mode 100644 index 2a311f8..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/commands/__init__.py +++ /dev/null @@ -1,114 +0,0 @@ -""" -Package containing all pip commands -""" - -# The following comment should be removed at some point in the future. -# mypy: disallow-untyped-defs=False - -from __future__ import absolute_import - -import importlib -from collections import OrderedDict, namedtuple - -from pip._internal.utils.typing import MYPY_CHECK_RUNNING - -if MYPY_CHECK_RUNNING: - from typing import Any - from pip._internal.cli.base_command import Command - - -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.', - )), - ('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] - - -def create_command(name, **kwargs): - # type: (str, **Any) -> Command - """ - Create an instance of the Command class with the given name. - """ - module_path, class_name, summary = commands_dict[name] - module = importlib.import_module(module_path) - command_class = getattr(module, class_name) - command = command_class(name=name, summary=summary, **kwargs) - - return command - - -def get_similar_commands(name): - """Command name auto-correct.""" - from difflib import get_close_matches - - name = name.lower() - - close_commands = get_close_matches(name, commands_dict.keys()) - - if close_commands: - return close_commands[0] - else: - return False diff --git a/venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/__init__.cpython-38.pyc deleted file mode 100644 index f39a689af66049211b159506d1c083a9868865dd..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2852 zcmc&$OK;mo5GE<=VZCf8ZWHIxFiq@4X)HI7=G8P!BFBx9#xZK7MT7zb%~?r=m!z^w zMvx#~>YjV;rH2IQrN5>BV6Q#(FZ57!c1apaYn@Ah%l&p{XJ)^d-POxlt*qg5`__u{ zLtWGUkYM^bj^H7_{GP69ptUv7!JxWtv<+SMb2Qh^;n$?5pKs^=Lc5^G^R(!f+9h2h zCANd|0-f{A?Xr>;X~nO$t0*f#3FZ!rc8%nrOlnYpD%1{g9Ruo!=3xOA6*`9KI4r>j z3Vn#^1e}Crg-#(l4QJr2LLVVI2Ns-H=wn0|;3BLjw2J5wT!w~1R}g&yS7A+|CZcut z6s{?B9nlTA37;u+3(;-319ug=hv;*-4__$s0MVE55FSa?tsm&^Iy{Efk6L>kHsA?< z7a+H*H8w{p zbx}z>TR|rrS$+sHC3fG5dRHx%I-J|m=2eTw7z`VVq8IQ8BOHB%AvSFkPSg}8^>{QoJ;RL@iptm6W-d-jaD)T2#CzdjrX?v9m0fHzOIIX7OGzYN7+B6; zcx3QRk#~E<-5;Hq5vG!gYD+3*=5K#XnAaH|5vtX5-pI=LvD~~pN-Q9K5&#KYk6?Ke za8Go+?&#tyXG$D1oE!#XsWlBV=c~`1KyEJ@x(>B)H(6a8?qN5volZtyoH)$w%}jG5 z7PVcamRVm;ptUpH*^-Go%rX)+=n+C^5~ZY~`khqDtX+H@dlW1s!n$CgZwYC0FddkyMvmRH8%@IXXX+?o352N}Gv# z=4S1Y)g!b|Saxh#F~_o(q@Znij;TZ^laL-DdvSLrJxVI78&WCru=<}eMGu{rDj#Y> z7f(+~5XLc^AQU1&*k*Q5D7$jfbhNzb;^lVul(3h__ZhzY9yXCS)|R#Ja}#5do0yUQ z))*V_^hrL-jq~H&fiWqJ3mw!Mo1p(>8^5)mo4I z{yG-YS{%spp1_(a>oqU#zP>ZOIgqmT!`ov$3wqtgF)y<1W`8K^t|G`zg>5v<)gP05 zT`%Kr$zV5d?7ckYaKOa3C6#YsqyCy`zCO`)%*I>eoi@?N`dEu{Z_Rfa<_Yu0nqvd> zWo=iJ*D{!xqx|SpD=k~eu;s*2xaNk85jScwSs8eTE+U0UK*))WM>w8+d~>^z7e(+o z9b}x{L^YA8;ear9N%qZsGUSb%B0Q1Slj+&|6?;i@T~1h%9=PXw)L|J9yo(ZE#YQu# zM#-ofrd~4GUBrz=QM7FcUE3CA+wR0s%!q9>17++oHlpH&l;Rq2qjM(7Vv;R!>is<* zM;_(PXxPUM#bnuwLJA5J{QK&sUUSbu64F($qO>b_j9Rryk_vBXb+SsBT4L#bQc@2j osr*-L%pxvJU%od5s; diff --git a/venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/check.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/check.cpython-38.pyc deleted file mode 100644 index dade849d3ff3cab9a5e0b1f6f2f29c1049850861..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1312 zcmZ7$%Z?jGuzTJfkEI2Xg`j|j!yX*5V}zoF1BzB!BreF82o6J{(RjLTPj+7J?#as5 z%*pux4*7s^@ zXJqQW1Dj+%rP{r&%QCIl)X*PgYo6UCO`6@LE1pQM^jDeSsp6-yWGU)0$t$VSqTmcn z1h*oGH+8F;R%K}T^ccWg0muh{IEg7EvB79;G9$K_$*k8TwwVnf^XVfaHPKuZ`XOY4s#h+wfe7Ak)V*%?($AyogS4+Ua3KE z(W-D;w|Au+o<;8loiFBfxDfRXuiiUC9T_g`wqnuL5;&LwYpLB=Tu7*`fcYiUiMAv! zmfAfOTwAGFNj*LpsCd$(pi!+7Xw5=ux6CE7dYskOvdA-qOaPZJd8U#oExGW}lYi{+ zR(n7XS9*-pAqH(iS^gm66L|jj)l8MmtjU|pwnF!uUEZ!aFD~Hyd0kw?X+36@p zU~CTa?IlCpNuvEEDQngi9OxiPHf>s9vcS1X!s-kNyOpqp0)rTmIzjhP<^VbakVtso z(=rFyG|+BQuU1&eFCoq7m}Zm}d9+9+PY(GCT+aVLsv9m~tzcuKp&CQ0ho= zypR#JFdGIyk5*j$1fIDNpQ2$0!vF>YJc%AVBrpZ-eScSkr#Mm){|-GPpl4QK_~yT{ C{bb?* diff --git a/venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/completion.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/completion.cpython-38.pyc deleted file mode 100644 index 49e0c1c46103581022e09b143e0a6e3fe2532617..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3013 zcmai0-*4Q;5#C+?xYOwr$4;XfZdz;=88`;zscMQeC@iC{q84rwOOR|Nxx^r7?%s(q zkEC~(R(v@<$v~c3pzi@HKjvTB*FF{f588)xhIi7PEGZ$uxeXdY6}J$!~Y`zRa>f^Q0J-nKWsUb8TW}U?x#%X#)KND`hTP z@jH}|7N1@bSdC`3I>Fh@*JnLky1D(y&hFOE$DeO>_-dyfMxSo)ezdo-vidbnPDWq6 z_xNaqe|b*zbgSvRUc8CA8>_Sa59{pQ--+%$dbk~-!pB<=w>H-K>N@|;-8CVfujN&i z@qo`6}p$=I@xCZ z@p*W!LN_rP5C8fjh#p>!Xw*;j{wez;0z3x~=UPIrvajaI#yb#DOpYwgF{S}uS-D!J zCK>Nsa`<6v_R&^u;xyMhOnDf-X4?dOLeHAz0l;{k)iXSh*Qc&t0Fx`gr5%C18 z&-~>~2l`jgk)%fjfl5cA%CVmN4e3+i2=`^P=Lt{vFGbeV716&Mqv&O?a-sqcdm>F?39h*#R5V zG5b5EWK0g6BWLU!xPl6X4x)3S@i!mlPznVYq%Dvx&Pm&138Zg;^x9NP4!jdzyg7DW zF)Zb9sOt|#ei$NXBNjffi`o=Q0!?#mln2gOuP(x)pKlEzinBvNSIGK+s2jM}kL%K5 zy;|40LTY1O#Af7$A;bghkCYE4NAFx|3zvaA7&utoR}EZ#_13sfA(jvuPgf8Hg-F_F z6s37;qR2Lrp@@poXxoZK-GcyFzl@cZ%Dx2&A(g=eAdUvAs7g4Bt7X==Zmb5{vZsgY zI@tV<+Jz`evRLaV`i}f}Yt0PHHOS(y%F8%;Dn)p>FJ%^{)!^BOFMfN7b8Fy+kt&a~ zwJAF^cBbF5ZuvsJ38p`UM}Ghfp*NV%T*?Te)BAtE|0CnZ=+@?$N$4R5yQk+*PT7vu z5qo?#;n4~jLr&-`a^xVXUJ}E`&N2On9MdCrOb>u=Pkr^7aZfy0=c7abZG>wY$0Vi8 zt9jFRMbF(im(5dLx z;z9ac!j~RD{^v4(*aVX8pySBs!!F1*LQ7ba-k>e&(l*f5{T^;_ znfbK+{pjsW5e%A`m3cgrkd>_{8Wy6;u-}fNXH}d{XBtr?iUh=OrGp$Rk&@4<6yCsy z=XJKIF6?fXrn#5^N1|xX)tfM@FvN8wcpo|%OG1;n%w_FcwKP~n5Bimn(6K^1s-5@R0o@1VuPE{xrf-*?%C#@ b2?Tdhp=NU%Fm19nZ8O(n3v7}7$A9<#PDc}! diff --git a/venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/configuration.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/configuration.cpython-38.pyc deleted file mode 100644 index 639e7ce42da38fe9bc92bf02c99ade1571b36b34..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6575 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 WQr$7R?9edKF_Q>4=S<|hr2h*<$+6S` diff --git a/venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/debug.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/debug.cpython-38.pyc deleted file mode 100644 index 1850a39a1c9b49bac7ec3ffa67125c7357a70a89..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4089 zcmZu!TW=f372erh?k*`(k|j&FW4GD32@Gi(kc+erZP9-~J?5q8V;=fT=Cx0G=?^GSxZfF4vJ`uXo$HyiXU_S~h4)&m zhK1*6KYb;+zie6mrpf8Y#pGSQ)ql`%i?htiS;QEP?aYpB(>sx4dN*=SUyEw!oy^Pq z$TzfZ7UcD)ZpO8&kuO9GX6$9nycM;~*v}U8rD(~FgKRlJ7o9WXdbX0UMyqDr$j;|$ z(HgVFn*1lev5>9j7orRK#pq&wDY|56n%N8a<>)eKoaq(uy(1QVpSSqpV=H=*FY#sc zAwS1g(7(i2`FZqLKeYH7Uw>@zb+K^hL_gs6w$;AyE$(c!nO;hEsxliY5vTc}lxhoW zwTHVx3JeAcDv^Dm;=zI1Eej&pzPGV)YkQkcrUe&; zinFqh*^(hk2k`?TD{vzYzyAE=&*P1cZf*Q3zH@JD>la%ewjJ%fR~%^fc3LSN{KkAZ z$w2IVnq)&!b!`%Q{?ORNyMeb_N29DM<7{e=tuZ^YkBl90Q+sRVJ(|27KAM2P2YLEJ zYBw!*x>*AAE@Wpx>?&mU6G ziGu!x31_%IlyS%=_Sl}XBWvQIx6!-Yp47&!>~Lr5jNKzPsd0DeD0l1}vT^Omo_MM@ z^~N5l7wYtRZQqiE`99ls<$!w=e+;i5vp?FGz!~cHC%y`x?zeEp*|fe`nFPc|)yKgh zBTo1KF!tp?c(CV;8L$6^o&L&q%+lEUmI9N!h-TCZUz@p+LFi}=J~n`vb}|vFq+ikM zqsh0VjJqF<-syBYjo*Ec%1VWgupMVC&$_iN&ce)a!&e|ZqEE6?xzn#Av^?Xi1fK^D?N!5GFa1(GdDV}aL^QjM;M&3LyAY}y2oYHaAE{nPV;QgnPQYCJ z8ul{Yb&M8g>uedl{ls?c|9P(b5$MlAs)hx+zJs^Q&?xKBny@i~$dLsDU-`W~u>mRy zDE8FhFfs=ijHwsLta_6>+ZK0ujeC9P&(>E~k8z&|kApGWBv`s*xB86Nw*jK5%jNd&CI-)3*wU;c$*QB)R;j{jAi8NU#pV69s1%H4g0RSRz+u&_O!yh;DPmCiTE$xt zj{1P|7t4^J{mI(*B;vu}?fdTbER-2#BFfpFH*_r%4@CAgi!Pf%6|3Du#U<=2Q!e6u zR_-L(Dc^0}$PkSY+Xgp3r;m}&JZ4*gHM-hO;+?T=t6NBR;+M6*P z*{_Ff4}cL$*HR_&N;?VXx>gOcRB2C&93p6UuS|<}O?%z4=%syxYZ4Z;`{F>-U84&# ze#Zi*1$=;LW)lAxB+`VO#j~<~OrpPl#zK@?X6rT}V`7f|#B*k2c@w*5!ZMK)Jm{(3 zKqIV(aSL?;Lrq|#9&n0_%}q)M^TauNxe?;oOmXYv zAT)U*B-K$CLS*ik?a{jF!tj-WEc@Y&xp&>Xdj3>?F|xHAsx=s?wKe+Y?rvIz^J*i+ zuq?8JFc(RoLO^K-t3EuV6K+jUAS~8Si6(av;0An-qOvK8F(|L)sOc(Efrctrg$>3Om5P*jl0=prF~I6NM%`Q2Mi>6he?Xk$EfYd z4{6~QYCfWdD&VKSryV&g6qc&j&>-#uSkBuVIExD#m6Ir4(}tYsP9Oe+M^a*tki# grurcoAc~ov-Lz-Oo3}vYdEl+#1ht?QTn$$L58c;CJOBUy diff --git a/venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/download.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/download.cpython-38.pyc deleted file mode 100644 index b3f4c8e7910cfeb5449f3b3ba1d51179e8009cf3..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3921 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 ayUkARVRG_o(DWd9EVZXB?kfs}l=eNYCVasF diff --git a/venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/freeze.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/freeze.cpython-38.pyc deleted file mode 100644 index 32d80c7e1bbe78d1fb6e28925053007892b455e2..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2929 zcmZWr-EZ8+5$88~)SW(U*>w_!K_=BSSKp+tJ3S8d)bBPc^bZy)!e~B*y33c=HFa zK^yDsMsgrZR!bUZc~x@x0C@fvb4uCWB%MND4bE8;lCbO`u8wA+HLI*@eL-bi$+Bc3@<}En&ko?Pt$mFDYDSf$x;Pg?QahlUYieRcXI`P%CORa>{fWb~+ zCQL|zG!Zm})o39ynLVa~0Dpq8`^EcAu(4M1t39h!$0(TPD!V$C#Sqc@(p zml98b10@KMRmlipLN>`3*(N*B0CxRa*T{9n-36}QanCJjpF0=Y#fv}QAU8qlSLD{Y zE4>SSS0k@H0~q&fyh>gJ>FrD2;M^y#qwK;!=t7Kw2aOT(W)uPnE<=U)r~4rbu^m!k*T0YEm$Ae1S#P9MGT^5XHP^GOJ)EndMYW#&&BFDkK<{Vs5l9q0E>vInAB>9Vb|Fmj4N+yv&#A;Fyl%wbmAO1t~g&QR~HVR%9}c zTMsH_4A6lPL!^)bU~mhS23RQKDv|TnIxMrI_3qvOXZ*K6fBJdrR0&6q?O^HPvY!^u zcv)9tv$X_e)7DBjR8r&U_*=al#Bs_JA>#O3?fD<~WnS$=g$?ThJwr*TDr%V3vq$fr zynBqYeXvkcUL-Rxc|$CIT4(`A`QJ3MIU-@DMnf1$%-cc$8zacW8^d57l0 z1lp3iw9fQX8#uOjdjX|Mx>%Z|cRpC?it<6W25ks!1Z^GK2DD9RTMKJ}bGM29%s+LS zU(0J#ZQ*>Q-_yRjcIwLOhr8!D7A`SvsDk%MexdzNTUh5i7n-hp*_AKz!PsxtR;m@> z1(RD}rDI$|7PJFIdPmv_1V9O*I_7jnpR`^E$8ZA2MZ2cr7pHjqLi9m}zlv+={`e+$ zkTT&c<>;$+ptNF=agP4tuOQQ@D*`L=H;|*yw+l<9M^JKl4E7j<3YMjkucIEC%Wq33lzd@1P zpL+aF9IbbUYn*o12>uQ*`Mc0XqrMIt9V_r#P%$b0Es9mQhqFyy7k>pp;7HTg^`Y(o z_I$%P4Bfi&B0jAjosj`ryGFBh6@#$Oc!0TFBsqm#_G8>y&5$0(@gu04y~K@UQl`MR zYXP@~c8!&@816GP$%V=#ejhCx^;w!y#^QLz?lDL?nybnOmQR8AMo+gK%dm{$TZ%v4 zLKCL7tf7v_+(7-0p=);_pC_03JW&8pV2HL}lCZ3c{_S7zCkJp<0gtOv!0}$%zHwCv z!^*_urPv_)qSvo#mQV=c1clq-q>EP<|65nJYMH@u@JGN^2UUemOz;)gyojs!Vdwpi T5WfPQG&DS82;uEtW8M5e)96Vr diff --git a/venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/hash.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/hash.cpython-38.pyc deleted file mode 100644 index 2fa485be1cd4e82d6282e546a99cf2211c94bc8d..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1990 zcmZuxTW=IM6t+Fry(KB2h*A|z5vjUTchd)Y5uy}CDYUABnxq#^g{;ZgyE|cSu|1@$ zHZKhlPqcp_dE}S$Klrsz{R_O%WA6qQ39sxqwvWB%eBXEcbFbG%(7ya)Bl*Wi=wCBg zZZ1r2L6?8Rz!1YZDsYUku}My1V!ux8*smMA@O5&p@MGWlxOq^7acFHXZx!vhU3B7( zo%?yW=*7KaC0@aZJ147r?G(rF-9s#3;Zwvy?jJkxIo4wBrzk$p$PVgv{)0GBAM4d* zPgZ%OIL(T>5^4+9f;&}FBqamWySu&pV7pIr@4MT-JlOtz_b$DEd*{CH?d)zp*t%yY zcXwdFBY47SI%&#BQg;tU1~*oXsvDJ>e_C$NVj@2SgQFNT1o>mgoj~4B>^(yx%v|O@ z4P&4AEP$wkXUIiy2$6@nb3c)jMTpbq?Fbso;GcMuL=)JHsu5Uul_q&qC+VYP3_Bv7 zWRLlMXZALnkOpR z%elQNE2T>ETn_DQdTFB;)j0aSs#R8%@?mtt9K9J0hr`_zFQH&S=s;hEE`NYQA%$n? znCz1oo{_&m8Z)%-?7Ivz!W`u>SNY6i{z;&`Q@jr3J`b!PIz7mlV88BJ=xS;h!)IrNNHAPic%e>1)~6q)a`^>3vLilD@b_8 z)7`JKQu}oxBp3QT;L3$E2f&SvMb*@ON4t{eBkd+)EH!y__yX$|rD>i>N$Csp@|#Un z)SGoy51P^t&)MK`!g)T(n(@I`Pp%!By-kQnaZx7uW;)lo+%&Wg>nGwIMDihYc?kxD z&tV@EMDUwm_=>#r!|8=32@cOvObw@J&Eyn9zXM&~gkeVHIfm z?Z_uUkW>sP5a!tt=4BEl7Tu#JQCf|tQDxr~7tLz05UY6q%v-y4q9(#1F&{1)KSwlW z9}IZ`283O_f?eX{5G()*g|DWo%di;lmJvXi6dVN5rnIP7lN-BB=|Pj^i=BW{R;94) z%~Lp^jZ07{U6dew%*)4?8nI#G=q)Hud7e|c6y*o7D@>?XdxlGCa)$r|7eeiJ?RrXJ z?W`G^j8H92x4=+Pb_^erzdt!53ZFnRp5h}%0Y%3cNLo1pVouzdYY05J{44q#{e-sB zZwOYsQ&W6o`q4I5jVL2^R$nX|L;1{KB?J6W6S3F#wOiF3ipX%1XM5Ty`Jo6P2JJUB zOBC0w3IAh$7`VC$JC;iwEFLo`J2EqBoG!{n7`?yC30_3iNN|H!!%9$J zdi$nEW$&-}@%w#cN}8Tf)KW*Gf0M cF_+#=QxI0aT@r$FL%^kr*YFx?J8M_|2Re%i`v3p{ diff --git a/venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/help.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/help.cpython-38.pyc deleted file mode 100644 index 4bbc049f6ba883385893181efc4f6b397bb89009..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1186 zcmZuw&2Aev5GI%Vr?u<=iJ>|`Q7i)Zpo67L(B=@N0ory z$HMAT=hSy7U?2NRy!O;r=&8e%6sSRmn9*<~&V2LD=+ouki;3r&i5)$l8g*KseBn^!QlHF;a=u*k_Fu7!AF#ZJcR0z-TOgQ%_ie=vbd~o(o2Y>7qw3Fb$PR#BjjoII zr<_2MtvKdl&{I(JI~b0E6X0h>q_^@VSpgr*aSv#oqE+}aQb#^&{i{U3z{s68 z2+^--fqp@K*psVBw|&rucX$$lZPQI^ckLM42Y)0?r)o-yv$pBkZZw!^G(zq7NVu5lx4;AHfWZIow`!> zjoLDjK07wgmWPtvo{RLh?ouh3YS&Sco}|+~J88;hMoZNStyneNR@D)}(2gcO0%MaO z6&D|dQEInbHe^jB6xV^f`0wgc*|1^S2yK%_Lq6)pGfk{-M0H`Kx@pT=8S67$n9sAv zx#UzaDQr-5!Wc`WDQvU>^C!|@K$U;Kowu@?1KyKPH7vgp{N(0Ri0Y*5it87*&u`p! z^H06Zx4q0Al386$Yj0*gYcp6d1HKl6EDWGmtY?scn9Do-ty7Tw$0$x8Ejxo z2Z)r~gi=}at`gvnDZTDk<-o%&qLkM;I6-GvA?%Z~P_-6Ri|ek0&-X&T*H5AN(9w=L zaxmb^D81H~!2df)~c7SdCa?Qglw-N*DF)#{;{0j+BIFtYY diff --git a/venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/install.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/install.cpython-38.pyc deleted file mode 100644 index 8f75a42e17e545f70208a8ce269ba24b2e957c9e..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 16661 zcmbVzYit}>mR?nLb@hYIHzkpJmMF~;@?y$h2Mmmu4hUa?rXZ)`cP?z z(@8g1A1)1Z+Hyzgqoq+!r`)mncxjx|X?LPNS(@Z@#+|C~EA8WS*4Yl8hDxKo= znEO=ybm=sw$K5mad@0ZA3HRyxGo@!ZJ?WmU7fOYCu~e*|E1j!9TY8qur`)g9pDR7b z>3#0=_4B3koZj!gP=B%XBBu|y7wQ*F7wa#TUeYz^{6k&-W313LR_Nu@%iLndeWiY> zbgBMo>DBt>(&hSBOJC*kgYMVrS4vkneaO99pDWFA`Y<3~D_!IC5zKhLG!Mv$?d#5K zJ9_DLaa0_;ua$1RrU_ddzpsho&c1tz($~eTIDzsv#7S`qzi*0yI4#cH*Gq4Sym%TV z3*s4Z7Qb%`V@b;we@@hq*Td1uve$ImzEiH%TTSUNplo>Q_Tu8r`K6`u>+^3eQbB8D zwJaU4*_KtuL&12p(r7kn)rwo|IORsA?w~OH&YI)6bCv2E=c;wlZ27fjgE~yqD;rMP zugF!$FSoY*wPu4#Z#s9{HR;ryhCkP=*DDQ?H^Sun&6{uE3{y+D=jMP!J`v`k%6Tc9 zG916r@cfGFRtUH%+P5g3yR~N9yV|a~;#y5|@h5sXCTgDF_G_+J_J9}Tc>sy(M!BY- zl&j6gid(Dt9)=#-h0v1YhZAw5)!JRBfhD*@lQ}?>KsrXf?8{1Z!;z@U3a2HVYQ=X1 za#O8}^qg`Z2h86CR^z_o`Q=Sn^DE0P)yupYW}SxDmYfUs(FoDljws)Cq=&hNXIir9 zJ5{V;tyNx;&3d`s6txxX11&`v|C_ajXl{C8j(|JmX4`MIePA+t%c-}pF6i8pTPT=# z>)pk7%X6>K&%IH;d3#~u#=>ia@ZFm9+ZESo+$}en+goe4T~X#- zd8H|19I=RM_w>;EX2orTNX#&CrLh&JZ}^U+S%&7D*orXyHq!*40;%gwS+8K{8@_B( z!9=vPyLJJk`>)m-6}ffAb(@=xz)lOAFwxkwY&ROU#%j6U5RNSOk+14R-q9a8o|cHd z-WU=;&{lMz3*&yes|PwxLt^0ZM~=P2()!gW(Au1I?~2Hy{mtuZ6^YKNADWK z2#gJj!Q2Y1Wk#0vvyH89IjtAIazQ2mBsA%qgp;(jpkA5_Eg=@b1BoX8>PRTuW9+_0(`T__Sh}fa@#(xs*gvUp@sisFJMb;8swP{S!R?> z-s^-g@24TllEMN9v_wjz@tYDEk;QNN2b!ssGT6YOa3rF@h~ZRjfRM5_{-Sc5R=Be2 zcs3osm$O_~uot%$Z`fzRzU-#I=13c-(D?v|z;1gWPkR@yu)UU3#gWB{E=HZdIk#lv zV6WqB+HL9f%HN~~?bU!u@ZqgFdm1z);Mc(yY{j4Lima}IU7;BdfZeyTF-_ZRw}``g zz>fJRVMepCXLsR;iPc=kn>}l9uGOk*H2mF~a2QghVLKIX%igSP**@U$Ot$O_nl@d> z2Ggj?W`meHRWCd7K#ovTtw1KL)wJzX0K96y7fFcs?Mu6G= `@Lwv3%sO-Ui)HE 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 JihHrq`Y&!*gaQBn diff --git a/venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/show.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/show.cpython-38.pyc deleted file mode 100644 index 23703d2a712fecc8d905bdd2b67b81571f3fa8e3..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6325 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 TvYBduP#RAOWiC}ZZ+`e64lFUo diff --git a/venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/uninstall.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/uninstall.cpython-38.pyc deleted file mode 100644 index b8ec3db86806e01b644776c0eb5406727388230b..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2694 zcmZuzUvC@75#PQ4q)5w>+8{yNbd%JH378a+7Hv@&L6Ep8inc}&#{qIha5~*C$(8P( zcK5`Hpk895c~UrZD&d$!xpWn>#@o?BD@ci~S zchZ0E5b|%FY(G9sK7dc3!@vorIVosNDbh~v6mINV+ReSfk9|vfc~FFLXlXx>ieB8a zbddLpop{I6VLm8^@zByyeyiAxcPaTJ;XU4eN_b!RB7EY-xB1Q^G8+5`&L$(;?xx4O z${QmRS=5y>z}m~wvMObk=5i^LGA#r!!;h+>NJ|dn!6Tuytjdn_SNWwZaoe9tZPGkX z4Xph^sY(HJzfP4Fi4tdxRH6{2(ZKzwT#F(Z7Ce{^jG&nmdrz8T(tccKi!=zYFI3Y%*DkGWN2} zSh4%tu(5X94H+b7^I+b4@a@8`D!ZNP#IvDJoLOjD3)Lrna6s#QgqY6w9h|Dpg?%k5$txgmaM#i{Qz~RktAI3WKlqalq6-Mfth`yeRC0ZImRklqN~q zC@XjZ-oUvjw-nkM*cPGM13;fp1_iLzXR2!Ik=uG&Ec`3_L3yaQ>~Na zTk_q5LsQg;P>tiJL{terUd)Ba$FiB7{qEw|3tT${3jp(FnjdECHl`0Z6$@3QUI9aY z0iXUQ4215}fI7sXoAsExS5SjseAHk>p1;dIwBP;rx zUb>Q8dMoDv`Qn{RA0X?m=m|8eE9Wv;1t+fBUj-}Act}5?_sQ8ltotB+?=m#ODg(|5OQPbo8$~z5saD@fpJ?lRw))G8> z2TmG*{E&yI9*@AHXceh%R?)Lt&j}@G-`IlaJ%oN8Nw_>xfbz&`!>+vBP_OTY9E^|=RzGUOKyTCj zHHiP$_W}U6XXpJF&I`|XXz(KN2Eg-31o9qT{^SR+R!upIu!zwjDB^yCacXj;2T5|) zq?$@Bd7dO&KD+^|3LUYn;x-T(a}rUn?|Fj*%Y8W7 z!$YTyfjbg*J0Q@$4mqDB&^CFcChOY-kT9{gr_EmbhLyOk`$?9|$#DvQMY;x{JXG`Z z9|}PRHZu56t$p?TGB+2vg+;vg{bks0G4t~Iz@GptHMH6cdahn$?9qf@1qwQ<2G>MrJL9NKWI%7mjD0& diff --git a/venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/wheel.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/commands/__pycache__/wheel.cpython-38.pyc deleted file mode 100644 index 2e545230d887701facc25f4adcc1945301a77bd0..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 5246 zcmai2Taz2b6`mQ5MkB4Hz50F|jGfIomX@R-5Xadv7z`ASLomcxgqj+wdv|AdZtfnf zy()V0l6DQAk*sZ*T_xuQcL%*hqs{DXF1SrUNdZe}F5TdE+>2tcz>C>mrt@S~p zQ8Vy+`KK2H>$G9~gMi7O4d5DH`2`wgFf%e@vtydnw<4=!>2Il1(qFq{<6DZ#vD0z% z96PGSZpYRAa#W3Loto}D(M(+L)Z<2{q2Wr@jAuKuy6;AF@qA}q_p8xDyx3WcmpV%t zu0==Uqn)F=KNB5`k9Usiemy!7pX{8BPjyb220t!7ha8RQbbO|BMvph6v+=pkx!CJ? z7`OJHe!g+_z8IYE4z=fE7>;JGiJvh;Hibho(x&l*o;PjH`wLN$|A#6cAHxt|63CI}nv z^Ed-*-py07OM?CK?z?yW>un1BP`;prz zvodoY86D?$hHZ2z(04`E3#Aqd27fmVqvqkKRpjY0FA&|$aED6|0(!e?Pk0lWkseg- zF`n^+@uVAa*{*301#O6NkG7Y$GH5W^;KU^k^2?eoU0>%ydif^z0=5$*IZa5{y(G;w z6X-FGvoH#ijbde)uICQ|!9CU!gycJ1?0R7$^B{`a-VI0?r!>s-AdKW?PjXJ|H8-tX zkELCC#oNsDOkP=C)ws6c0mCdBYKQ46PgbKK=Q3X{_A+4~AeB7tWqF!La_tu{v|lN9 zQt&CJFK1!qX~eSElTaM(?;gX^73Vv_!Q&5e7!<77TNi1pXKG3<@K|Mes&&Y)Q5Nom ztQSND|FN?B|I+h4?_ws>4ez6oV|?sgoj58_X1p7&hg__A?RNWrP_)Dp5l%gf`1cWf z)Z$oYrz<_Iy#>SfdLsJ&1X0?>F2*F}KHo=kb!3FZd-ZT~7v_5SE2HP)oy9Br7|D&? z92k4nmNhU3)*lc#2gX)uSQ?bJY-Tcxydp1eIph_O5iADQIyDTAG56j3G$dU`@zc zrI=et3*0`_Lqq<^ zQB-Bzae|COS^sBmJVeY#?Az#3PQm){LGH<3mPH|F1TO19(9U)zeR~faRNYpw$<8*(tANP7NS{zV=4NbV$lNYjYRs6l}Q(ei^Gi~h=#CQ=xli+(ky$U zRB|ZQnXzbvNaa>56I|6K(iKOR>+u`?yKg7msK+>*leYwqcpwp;b(G)XQJRrHJj7j! zTC(lEwmUwi%N_;3G>LW*G!iB~MCE%Ce>!)iB=q{nNeEJjAO~JKt;*0V7h(~Ra(zEc z!rb?jixf|~k*XFj-NTB?N~LmO2{?Q~HIk|(sedm_0e_!`x(z(`ti%Ef$<4&rim}^kzM#3BJE{r z1}fzbM}U(BLUN%Nk@~pEr)I8{l`VO+u54JZRMz$bah~*4D;SVMKQmR;$I<}=@jo-Z zytbOh*(y%2)k`Spa5i$>u(xslmE9K~(AX-@CFdduqScXA$x-^ucExj8;U&Cs6OCam zSdL|zmSLInp!b#IHcfiaA3t9?l>+xnOO)dWbcfK_ng>Sld}EiJX8*_?T@n`6OM7fM z-El!gqRiuM;JuDl8WyF6eRE*y5O3@wH5`~o3C4a2Ndf^3!Oh&VvrA~pbz@l09rP-A z-92mQR8zmK<# zmF5T40i`5+P#QP~lz5D-g@Fr91sGbtMycs>Wmv<=;-E&j0m-q1_XsOLc7`+HL*bVa z)y)2}L6v&UVUt>-ot+UDKY*zTPlEfBK1;IU5FZAKSmRhK*r! z(0JYWcrctD%x;}|Vv0-j-8%cklBiEzV7rOG<%psIEl;#a(`71Fy%?2m$a|y3Qew|GbTd(z6la>lA5z<`o%?oa zrcMo&ld7R3bT0$n2$8um0@d*>&3bfA7zcjJix4VTCv@g{j;ieD$zUQ?rw5fwIIqG{GJ3RW&d!{d|jC-@lLh-e{!aBhGYzF83tv$~x_e z`=r9gD4%zE6#4#yKGrZQ$o+MBbq*a#c8zT}?Mi)3V^=QHn(Mus{@L&aMIBWklYl9R z3q%_bY7tdH`>+aV7lDhst26)1NE8;%eCEIKxNF}Z|G^>X&IU)C;>sU(dGWu_Q=@y9 zKX??*`3!&HHUH7yHQJS*+i@tng}amYtJBjm6mxVcpd>)SK%M-~DZ3e|hzbmK zYI=eWYei^+r)$5Z;H+E}U`6#dN1&4zET~Qq3xug6$lcWLCwy2$eDb-5<0rd*}CjbBd diff --git a/venv/lib/python3.8/site-packages/pip/_internal/commands/check.py b/venv/lib/python3.8/site-packages/pip/_internal/commands/check.py deleted file mode 100644 index 9689446..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/commands/check.py +++ /dev/null @@ -1,45 +0,0 @@ -# The following comment should be removed at some point in the future. -# mypy: disallow-untyped-defs=False - -import logging - -from pip._internal.cli.base_command import Command -from pip._internal.operations.check import ( - check_package_set, - create_package_set_from_installed, -) -from pip._internal.utils.misc import write_output - -logger = logging.getLogger(__name__) - - -class CheckCommand(Command): - """Verify installed packages have compatible dependencies.""" - - usage = """ - %prog [options]""" - - def run(self, options, args): - package_set, parsing_probs = create_package_set_from_installed() - missing, conflicting = check_package_set(package_set) - - for project_name in missing: - version = package_set[project_name].version - for dependency in missing[project_name]: - write_output( - "%s %s requires %s, which is not installed.", - project_name, version, dependency[0], - ) - - for project_name in conflicting: - version = package_set[project_name].version - 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, - ) - - if missing or conflicting or parsing_probs: - return 1 - else: - write_output("No broken requirements found.") diff --git a/venv/lib/python3.8/site-packages/pip/_internal/commands/completion.py b/venv/lib/python3.8/site-packages/pip/_internal/commands/completion.py deleted file mode 100644 index c532806..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/commands/completion.py +++ /dev/null @@ -1,96 +0,0 @@ -# The following comment should be removed at some point in the future. -# mypy: disallow-untyped-defs=False - -from __future__ import absolute_import - -import sys -import textwrap - -from pip._internal.cli.base_command import Command -from pip._internal.utils.misc import get_prog - -BASE_COMPLETION = """ -# pip %(shell)s completion start%(script)s# pip %(shell)s completion end -""" - -COMPLETION_SCRIPTS = { - 'bash': """ - _pip_completion() - { - COMPREPLY=( $( COMP_WORDS="${COMP_WORDS[*]}" \\ - COMP_CWORD=$COMP_CWORD \\ - PIP_AUTO_COMPLETE=1 $1 2>/dev/null ) ) - } - complete -o default -F _pip_completion %(prog)s - """, - '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)s - """, - 'fish': """ - function __fish_complete_pip - set -lx COMP_WORDS (commandline -o) "" - set -lx COMP_CWORD ( \\ - math (contains -i -- (commandline -t) $COMP_WORDS)-1 \\ - ) - set -lx PIP_AUTO_COMPLETE 1 - string split \\ -- (eval $COMP_WORDS[1]) - end - complete -fa "(__fish_complete_pip)" -c %(prog)s - """, -} - - -class CompletionCommand(Command): - """A helper command to be used for command completion.""" - - ignore_require_venv = True - - def __init__(self, *args, **kw): - super(CompletionCommand, self).__init__(*args, **kw) - - cmd_opts = self.cmd_opts - - cmd_opts.add_option( - '--bash', '-b', - action='store_const', - const='bash', - dest='shell', - help='Emit completion code for bash') - cmd_opts.add_option( - '--zsh', '-z', - action='store_const', - const='zsh', - dest='shell', - help='Emit completion code for zsh') - cmd_opts.add_option( - '--fish', '-f', - action='store_const', - const='fish', - dest='shell', - help='Emit completion code for fish') - - self.parser.insert_option_group(0, cmd_opts) - - def run(self, options, args): - """Prints the completion code of the given shell""" - shells = COMPLETION_SCRIPTS.keys() - shell_options = ['--' + shell for shell in sorted(shells)] - if options.shell in shells: - script = textwrap.dedent( - COMPLETION_SCRIPTS.get(options.shell, '') % { - 'prog': get_prog(), - } - ) - print(BASE_COMPLETION % {'script': script, 'shell': options.shell}) - else: - sys.stderr.write( - 'ERROR: You must pass %s\n' % ' or '.join(shell_options) - ) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/commands/configuration.py b/venv/lib/python3.8/site-packages/pip/_internal/commands/configuration.py deleted file mode 100644 index efcf5bb..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/commands/configuration.py +++ /dev/null @@ -1,233 +0,0 @@ -# The following comment should be removed at some point in the future. -# mypy: disallow-untyped-defs=False - -import logging -import os -import subprocess - -from pip._internal.cli.base_command import Command -from pip._internal.cli.status_codes import ERROR, SUCCESS -from pip._internal.configuration import ( - Configuration, - get_configuration_files, - kinds, -) -from pip._internal.exceptions import PipError -from pip._internal.utils.misc import get_prog, write_output - -logger = logging.getLogger(__name__) - - -class ConfigurationCommand(Command): - """Manage local and global configuration. - - Subcommands: - - 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 - - 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 - default. - """ - - ignore_require_venv = True - usage = """ - %prog [] list - %prog [] [--editor ] edit - - %prog [] get name - %prog [] set name value - %prog [] unset name - """ - - def __init__(self, *args, **kwargs): - super(ConfigurationCommand, self).__init__(*args, **kwargs) - - self.configuration = None - - self.cmd_opts.add_option( - '--editor', - dest='editor', - action='store', - default=None, - help=( - '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', - default=False, - help='Use the system-wide configuration file only' - ) - - self.cmd_opts.add_option( - '--user', - dest='user_file', - action='store_true', - default=False, - help='Use the user configuration file only' - ) - - self.cmd_opts.add_option( - '--site', - dest='site_file', - action='store_true', - default=False, - help='Use the current environment configuration file only' - ) - - self.parser.insert_option_group(0, self.cmd_opts) - - def run(self, options, args): - handlers = { - "list": self.list_values, - "edit": self.open_in_editor, - "get": self.get_name, - "set": self.set_name_value, - "unset": self.unset_name - } - - # Determine action - if not args or args[0] not in handlers: - logger.error("Need an action ({}) to perform.".format( - ", ".join(sorted(handlers))) - ) - return ERROR - - action = args[0] - - # Determine which configuration files are to be loaded - # Depends on whether the command is modifying. - try: - load_only = self._determine_file( - options, need_value=(action in ["get", "set", "unset", "edit"]) - ) - except PipError as e: - logger.error(e.args[0]) - return ERROR - - # Load a new configuration - self.configuration = Configuration( - isolated=options.isolated_mode, load_only=load_only - ) - self.configuration.load() - - # Error handling happens here, not in the action-handlers. - try: - handlers[action](options, args[1:]) - except PipError as e: - logger.error(e.args[0]) - return ERROR - - return SUCCESS - - def _determine_file(self, options, need_value): - 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: - return None - # Default to user, unless there's a site file. - elif any( - os.path.exists(site_config_file) - for site_config_file in get_configuration_files()[kinds.SITE] - ): - return kinds.SITE - else: - return kinds.USER - elif len(file_options) == 1: - return file_options[0] - - raise PipError( - "Need exactly one file to operate upon " - "(--user, --site, --global) to perform." - ) - - def list_values(self, options, args): - 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): - 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): - 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): - key = self._get_n_args(args, "unset [name]", n=1) - self.configuration.unset_value(key) - - self._save_configuration() - - def open_in_editor(self, options, args): - editor = self._determine_editor(options) - - fname = self.configuration.get_file_to_edit() - if fname is None: - raise PipError("Could not determine appropriate file.") - - try: - subprocess.check_call([editor, fname]) - except subprocess.CalledProcessError as e: - raise PipError( - "Editor Subprocess exited with exit code {}" - .format(e.returncode) - ) - - def _get_n_args(self, args, example, n): - """Helper to make sure the command got the right number of arguments - """ - if len(args) != n: - msg = ( - 'Got unexpected number of arguments, expected {}. ' - '(example: "{} config {}")' - ).format(n, get_prog(), example) - raise PipError(msg) - - if n == 1: - return args[0] - else: - return args - - def _save_configuration(self): - # We successfully ran a modifying command. Need to save the - # configuration. - try: - self.configuration.save() - except Exception: - logger.error( - "Unable to save configuration. Please report this as a bug.", - exc_info=1 - ) - raise PipError("Internal Error.") - - def _determine_editor(self, options): - if options.editor is not None: - return options.editor - elif "VISUAL" in os.environ: - return os.environ["VISUAL"] - elif "EDITOR" in os.environ: - return os.environ["EDITOR"] - else: - raise PipError("Could not determine editor to use.") diff --git a/venv/lib/python3.8/site-packages/pip/_internal/commands/debug.py b/venv/lib/python3.8/site-packages/pip/_internal/commands/debug.py deleted file mode 100644 index fe93b3a..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/commands/debug.py +++ /dev/null @@ -1,142 +0,0 @@ -# The following comment should be removed at some point in the future. -# mypy: disallow-untyped-defs=False - -from __future__ import absolute_import - -import locale -import logging -import os -import sys - -from pip._vendor.certifi import where - -from pip._internal.cli import cmdoptions -from pip._internal.cli.base_command import Command -from pip._internal.cli.cmdoptions import make_target_python -from pip._internal.cli.status_codes import SUCCESS -from pip._internal.utils.logging import indent_log -from pip._internal.utils.misc import get_pip_version -from pip._internal.utils.typing import MYPY_CHECK_RUNNING - -if MYPY_CHECK_RUNNING: - from typing import Any, List, Optional - from optparse import Values - -logger = logging.getLogger(__name__) - - -def show_value(name, value): - # type: (str, Optional[str]) -> None - logger.info('{}: {}'.format(name, value)) - - -def show_sys_implementation(): - # type: () -> None - logger.info('sys.implementation:') - if hasattr(sys, 'implementation'): - implementation = sys.implementation # type: ignore - implementation_name = implementation.name - else: - implementation_name = '' - - with indent_log(): - show_value('name', implementation_name) - - -def show_tags(options): - # type: (Values) -> None - tag_limit = 10 - - target_python = make_target_python(options) - tags = target_python.get_tags() - - # Display the target options that were explicitly provided. - formatted_target = target_python.format_given() - suffix = '' - if formatted_target: - suffix = ' (target: {})'.format(formatted_target) - - msg = 'Compatible tags: {}{}'.format(len(tags), suffix) - logger.info(msg) - - if options.verbose < 1 and len(tags) > tag_limit: - tags_limited = True - tags = tags[:tag_limit] - else: - tags_limited = False - - with indent_log(): - for tag in tags: - logger.info(str(tag)) - - if tags_limited: - msg = ( - '...\n' - '[First {tag_limit} tags shown. Pass --verbose to show all.]' - ).format(tag_limit=tag_limit) - logger.info(msg) - - -def ca_bundle_info(config): - levels = set() - for key, value in config.items(): - levels.add(key.split('.')[0]) - - if not levels: - return "Not specified" - - 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' - - levels.remove('global') - return ", ".join(levels) - - -class DebugCommand(Command): - """ - Display debug information. - """ - - usage = """ - %prog """ - ignore_require_venv = True - - def __init__(self, *args, **kw): - super(DebugCommand, self).__init__(*args, **kw) - - cmd_opts = self.cmd_opts - cmdoptions.add_target_python_options(cmd_opts) - self.parser.insert_option_group(0, cmd_opts) - self.parser.config.load() - - def run(self, options, args): - # type: (Values, List[Any]) -> 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( - 'locale.getpreferredencoding', locale.getpreferredencoding(), - ) - 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("pip._vendor.certifi.where()", where()) - - show_tags(options) - - return SUCCESS diff --git a/venv/lib/python3.8/site-packages/pip/_internal/commands/download.py b/venv/lib/python3.8/site-packages/pip/_internal/commands/download.py deleted file mode 100644 index 24da3eb..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/commands/download.py +++ /dev/null @@ -1,147 +0,0 @@ -# The following comment should be removed at some point in the future. -# mypy: disallow-untyped-defs=False - -from __future__ import absolute_import - -import logging -import os - -from pip._internal.cli import cmdoptions -from pip._internal.cli.cmdoptions import make_target_python -from pip._internal.cli.req_command import RequirementCommand -from pip._internal.req import RequirementSet -from pip._internal.req.req_tracker import get_requirement_tracker -from pip._internal.utils.misc import ensure_dir, normalize_path, write_output -from pip._internal.utils.temp_dir import TempDirectory - -logger = logging.getLogger(__name__) - - -class DownloadCommand(RequirementCommand): - """ - Download packages from: - - - PyPI (and other indexes) using requirement specifiers. - - VCS project urls. - - Local project directories. - - Local or remote source archives. - - pip also supports downloading from "requirements files", which provide - an easy way to specify a whole environment to be downloaded. - """ - - usage = """ - %prog [options] [package-index-options] ... - %prog [options] -r [package-index-options] ... - %prog [options] ... - %prog [options] ... - %prog [options] ...""" - - def __init__(self, *args, **kw): - super(DownloadCommand, self).__init__(*args, **kw) - - cmd_opts = self.cmd_opts - - cmd_opts.add_option(cmdoptions.constraints()) - cmd_opts.add_option(cmdoptions.requirements()) - cmd_opts.add_option(cmdoptions.build_dir()) - cmd_opts.add_option(cmdoptions.no_deps()) - cmd_opts.add_option(cmdoptions.global_options()) - cmd_opts.add_option(cmdoptions.no_binary()) - cmd_opts.add_option(cmdoptions.only_binary()) - cmd_opts.add_option(cmdoptions.prefer_binary()) - cmd_opts.add_option(cmdoptions.src()) - cmd_opts.add_option(cmdoptions.pre()) - cmd_opts.add_option(cmdoptions.no_clean()) - cmd_opts.add_option(cmdoptions.require_hashes()) - cmd_opts.add_option(cmdoptions.progress_bar()) - cmd_opts.add_option(cmdoptions.no_build_isolation()) - cmd_opts.add_option(cmdoptions.use_pep517()) - cmd_opts.add_option(cmdoptions.no_use_pep517()) - - cmd_opts.add_option( - '-d', '--dest', '--destination-dir', '--destination-directory', - dest='download_dir', - metavar='dir', - default=os.curdir, - help=("Download packages into ."), - ) - - cmdoptions.add_target_python_options(cmd_opts) - - 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, cmd_opts) - - def run(self, options, args): - options.ignore_installed = True - # editable doesn't really make sense for `pip download`, but the bowels - # of the RequirementSet code require that property. - options.editables = [] - - cmdoptions.check_dist_restriction(options) - - options.download_dir = normalize_path(options.download_dir) - - ensure_dir(options.download_dir) - - session = self.get_default_session(options) - - target_python = make_target_python(options) - finder = self._build_package_finder( - options=options, - session=session, - target_python=target_python, - ) - build_delete = (not (options.no_clean or options.build_dir)) - - with get_requirement_tracker() as req_tracker, TempDirectory( - options.build_dir, delete=build_delete, kind="download" - ) as directory: - - requirement_set = RequirementSet() - self.populate_requirement_set( - requirement_set, - args, - options, - finder, - session, - None - ) - - preparer = self.make_requirement_preparer( - temp_build_dir=directory, - options=options, - req_tracker=req_tracker, - session=session, - finder=finder, - download_dir=options.download_dir, - use_user_site=False, - ) - - resolver = self.make_resolver( - preparer=preparer, - finder=finder, - options=options, - py_version_info=options.python_version, - ) - - self.trace_basic_info(finder) - - resolver.resolve(requirement_set) - - downloaded = ' '.join([ - req.name for req in requirement_set.successfully_downloaded - ]) - if downloaded: - write_output('Successfully downloaded %s', downloaded) - - # Clean up - if not options.no_clean: - requirement_set.cleanup_files() - - return requirement_set diff --git a/venv/lib/python3.8/site-packages/pip/_internal/commands/freeze.py b/venv/lib/python3.8/site-packages/pip/_internal/commands/freeze.py deleted file mode 100644 index e96c083..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/commands/freeze.py +++ /dev/null @@ -1,103 +0,0 @@ -# The following comment should be removed at some point in the future. -# mypy: disallow-untyped-defs=False - -from __future__ import absolute_import - -import sys - -from pip._internal.cache import WheelCache -from pip._internal.cli import cmdoptions -from pip._internal.cli.base_command import Command -from pip._internal.models.format_control import FormatControl -from pip._internal.operations.freeze import freeze -from pip._internal.utils.compat import stdlib_pkgs - -DEV_PKGS = {'pip', 'setuptools', 'distribute', 'wheel', 'pkg-resources'} - - -class FreezeCommand(Command): - """ - Output installed packages in requirements format. - - packages are listed in a case-insensitive sorted order. - """ - - usage = """ - %prog [options]""" - log_streams = ("ext://sys.stderr", "ext://sys.stderr") - - def __init__(self, *args, **kw): - super(FreezeCommand, self).__init__(*args, **kw) - - 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.") - self.cmd_opts.add_option( - '-f', '--find-links', - dest='find_links', - action='append', - default=[], - metavar='URL', - help='URL for finding packages, which will be added to the ' - 'output.') - self.cmd_opts.add_option( - '-l', '--local', - dest='local', - action='store_true', - default=False, - 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', - default=False, - 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:' - ' %s' % ', '.join(DEV_PKGS)) - self.cmd_opts.add_option( - '--exclude-editable', - dest='exclude_editable', - action='store_true', - help='Exclude editable package from output.') - - self.parser.insert_option_group(0, self.cmd_opts) - - def run(self, options, args): - format_control = FormatControl(set(), set()) - wheel_cache = WheelCache(options.cache_dir, format_control) - skip = set(stdlib_pkgs) - if not options.freeze_all: - skip.update(DEV_PKGS) - - cmdoptions.check_list_path_option(options) - - freeze_kwargs = dict( - requirement=options.requirements, - find_links=options.find_links, - local_only=options.local, - user_only=options.user, - paths=options.path, - skip_regex=options.skip_requirements_regex, - isolated=options.isolated_mode, - wheel_cache=wheel_cache, - skip=skip, - exclude_editable=options.exclude_editable, - ) - - try: - for line in freeze(**freeze_kwargs): - sys.stdout.write(line + '\n') - finally: - wheel_cache.cleanup() diff --git a/venv/lib/python3.8/site-packages/pip/_internal/commands/hash.py b/venv/lib/python3.8/site-packages/pip/_internal/commands/hash.py deleted file mode 100644 index 1dc7fb0..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/commands/hash.py +++ /dev/null @@ -1,58 +0,0 @@ -# The following comment should be removed at some point in the future. -# mypy: disallow-untyped-defs=False - -from __future__ import absolute_import - -import hashlib -import logging -import sys - -from pip._internal.cli.base_command import Command -from pip._internal.cli.status_codes import ERROR -from pip._internal.utils.hashes import FAVORITE_HASH, STRONG_HASHES -from pip._internal.utils.misc import read_chunks, write_output - -logger = logging.getLogger(__name__) - - -class HashCommand(Command): - """ - Compute a hash of a local package archive. - - These can be used with --hash in a requirements file to do repeatable - installs. - """ - - usage = '%prog [options] ...' - ignore_require_venv = True - - def __init__(self, *args, **kw): - super(HashCommand, self).__init__(*args, **kw) - self.cmd_opts.add_option( - '-a', '--algorithm', - dest='algorithm', - choices=STRONG_HASHES, - action='store', - default=FAVORITE_HASH, - help='The hash algorithm to use: one of %s' % - ', '.join(STRONG_HASHES)) - self.parser.insert_option_group(0, self.cmd_opts) - - def run(self, options, args): - 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)) - - -def _hash_of_file(path, algorithm): - """Return the hash digest of a file.""" - with open(path, 'rb') as archive: - hash = hashlib.new(algorithm) - for chunk in read_chunks(archive): - hash.update(chunk) - return hash.hexdigest() diff --git a/venv/lib/python3.8/site-packages/pip/_internal/commands/help.py b/venv/lib/python3.8/site-packages/pip/_internal/commands/help.py deleted file mode 100644 index 75af999..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/commands/help.py +++ /dev/null @@ -1,41 +0,0 @@ -# The following comment should be removed at some point in the future. -# mypy: disallow-untyped-defs=False - -from __future__ import absolute_import - -from pip._internal.cli.base_command import Command -from pip._internal.cli.status_codes import SUCCESS -from pip._internal.exceptions import CommandError - - -class HelpCommand(Command): - """Show help for commands""" - - usage = """ - %prog """ - ignore_require_venv = True - - def run(self, options, args): - from pip._internal.commands import ( - commands_dict, create_command, get_similar_commands, - ) - - try: - # 'pip help' with no args is handled by pip.__init__.parseopt() - cmd_name = args[0] # the command we need help for - except IndexError: - return SUCCESS - - if cmd_name not in commands_dict: - guess = get_similar_commands(cmd_name) - - msg = ['unknown command "%s"' % cmd_name] - if guess: - msg.append('maybe you meant "%s"' % guess) - - raise CommandError(' - '.join(msg)) - - command = create_command(cmd_name) - command.parser.print_help() - - return SUCCESS diff --git a/venv/lib/python3.8/site-packages/pip/_internal/commands/install.py b/venv/lib/python3.8/site-packages/pip/_internal/commands/install.py deleted file mode 100644 index cb2fb28..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/commands/install.py +++ /dev/null @@ -1,727 +0,0 @@ -# The following comment should be removed at some point in the future. -# It's included for now because without it InstallCommand.run() has a -# couple errors where we have to know req.name is str rather than -# Optional[str] for the InstallRequirement req. -# mypy: strict-optional=False -# mypy: disallow-untyped-defs=False - -from __future__ import absolute_import - -import errno -import logging -import operator -import os -import shutil -import site -from optparse import SUPPRESS_HELP - -from pip._vendor import pkg_resources -from pip._vendor.packaging.utils import canonicalize_name - -from pip._internal.cache import WheelCache -from pip._internal.cli import cmdoptions -from pip._internal.cli.cmdoptions import make_target_python -from pip._internal.cli.req_command import RequirementCommand -from pip._internal.cli.status_codes import ERROR, SUCCESS -from pip._internal.exceptions import ( - CommandError, - InstallationError, - PreviousBuildDirError, -) -from pip._internal.locations import distutils_scheme -from pip._internal.operations.check import check_install_conflicts -from pip._internal.req import RequirementSet, install_given_reqs -from pip._internal.req.req_tracker import get_requirement_tracker -from pip._internal.utils.deprecation import deprecated -from pip._internal.utils.distutils_args import parse_distutils_args -from pip._internal.utils.filesystem import test_writable_dir -from pip._internal.utils.misc import ( - ensure_dir, - get_installed_version, - protect_pip_from_modification_on_windows, - write_output, -) -from pip._internal.utils.temp_dir import TempDirectory -from pip._internal.utils.typing import MYPY_CHECK_RUNNING -from pip._internal.utils.virtualenv import virtualenv_no_global -from pip._internal.wheel_builder import build, should_build_for_install_command - -if MYPY_CHECK_RUNNING: - from optparse import Values - from typing import Any, Iterable, List, Optional - - from pip._internal.models.format_control import FormatControl - from pip._internal.req.req_install import InstallRequirement - from pip._internal.wheel_builder import BinaryAllowedPredicate - -from pip._internal.locations import running_under_virtualenv - -logger = logging.getLogger(__name__) - - -def get_check_binary_allowed(format_control): - # type: (FormatControl) -> BinaryAllowedPredicate - def check_binary_allowed(req): - # type: (InstallRequirement) -> bool - if req.use_pep517: - return True - canonical_name = canonicalize_name(req.name) - allowed_formats = format_control.get_allowed_formats(canonical_name) - return "binary" in allowed_formats - - return check_binary_allowed - - -class InstallCommand(RequirementCommand): - """ - Install packages from: - - - PyPI (and other indexes) using requirement specifiers. - - VCS project urls. - - Local project directories. - - Local or remote source archives. - - pip also supports installing from "requirements files", which provide - an easy way to specify a whole environment to be installed. - """ - - usage = """ - %prog [options] [package-index-options] ... - %prog [options] -r [package-index-options] ... - %prog [options] [-e] ... - %prog [options] [-e] ... - %prog [options] ...""" - - def __init__(self, *args, **kw): - super(InstallCommand, self).__init__(*args, **kw) - - cmd_opts = self.cmd_opts - - cmd_opts.add_option(cmdoptions.requirements()) - cmd_opts.add_option(cmdoptions.constraints()) - cmd_opts.add_option(cmdoptions.no_deps()) - cmd_opts.add_option(cmdoptions.pre()) - - cmd_opts.add_option(cmdoptions.editable()) - cmd_opts.add_option( - '-t', '--target', - dest='target_dir', - metavar='dir', - default=None, - help='Install packages into . ' - 'By default this will not replace existing files/folders in ' - '. Use --upgrade to replace existing packages in ' - 'with new versions.' - ) - cmdoptions.add_target_python_options(cmd_opts) - - 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.) On Debian systems, this is the " - "default when running outside of a virtual environment " - "and not as root.") - - cmd_opts.add_option( - '--no-user', - dest='use_system_location', - action='store_true', - help=SUPPRESS_HELP) - cmd_opts.add_option( - '--root', - dest='root_path', - metavar='dir', - default=None, - help="Install everything relative to this alternate root " - "directory.") - cmd_opts.add_option( - '--prefix', - dest='prefix_path', - metavar='dir', - default=None, - help="Installation prefix where lib, bin and other top-level " - "folders are placed") - - cmd_opts.add_option( - '--system', - dest='use_system_location', - action='store_true', - help="Install using the system scheme (overrides --user on " - "Debian systems)") - - cmd_opts.add_option(cmdoptions.build_dir()) - - cmd_opts.add_option(cmdoptions.src()) - - 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.' - ) - - 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).' - ) - - cmd_opts.add_option( - '--force-reinstall', - dest='force_reinstall', - action='store_true', - help='Reinstall all packages even if they are already ' - 'up-to-date.') - - 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!' - ) - - cmd_opts.add_option(cmdoptions.ignore_requires_python()) - cmd_opts.add_option(cmdoptions.no_build_isolation()) - cmd_opts.add_option(cmdoptions.use_pep517()) - cmd_opts.add_option(cmdoptions.no_use_pep517()) - - cmd_opts.add_option(cmdoptions.install_options()) - cmd_opts.add_option(cmdoptions.global_options()) - - cmd_opts.add_option( - "--compile", - action="store_true", - dest="compile", - default=True, - help="Compile Python source files to bytecode", - ) - - cmd_opts.add_option( - "--no-compile", - action="store_false", - dest="compile", - help="Do not compile Python source files to bytecode", - ) - - cmd_opts.add_option( - "--no-warn-script-location", - action="store_false", - dest="warn_script_location", - default=True, - help="Do not warn when installing scripts outside PATH", - ) - cmd_opts.add_option( - "--no-warn-conflicts", - action="store_false", - dest="warn_about_conflicts", - default=True, - help="Do not warn about broken dependencies", - ) - - cmd_opts.add_option(cmdoptions.no_binary()) - cmd_opts.add_option(cmdoptions.only_binary()) - cmd_opts.add_option(cmdoptions.prefer_binary()) - cmd_opts.add_option(cmdoptions.no_clean()) - cmd_opts.add_option(cmdoptions.require_hashes()) - cmd_opts.add_option(cmdoptions.progress_bar()) - - 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, cmd_opts) - - def run(self, options, args): - # type: (Values, List[Any]) -> int - cmdoptions.check_install_build_global(options) - upgrade_strategy = "to-satisfy-only" - if options.upgrade: - upgrade_strategy = options.upgrade_strategy - - cmdoptions.check_dist_restriction(options, check_target=True) - - if options.python_version: - python_versions = [options.python_version] - else: - python_versions = None - - # compute install location defaults - if (not options.use_user_site and not options.prefix_path and not - options.target_dir and not options.use_system_location): - if not running_under_virtualenv() and os.geteuid() != 0: - options.use_user_site = True - - if options.use_system_location: - options.use_user_site = False - - options.src_dir = os.path.abspath(options.src_dir) - install_options = options.install_options or [] - - options.use_user_site = decide_user_install( - options.use_user_site, - prefix_path=options.prefix_path, - target_dir=options.target_dir, - root_path=options.root_path, - isolated_mode=options.isolated_mode, - ) - - target_temp_dir = None # type: Optional[TempDirectory] - target_temp_dir_path = None # type: Optional[str] - 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)): - raise CommandError( - "Target path exists but is not a directory, will not " - "continue." - ) - - # Create a target directory for using with the target option - target_temp_dir = TempDirectory(kind="target") - target_temp_dir_path = target_temp_dir.path - - global_options = options.global_options or [] - - session = self.get_default_session(options) - - target_python = make_target_python(options) - finder = self._build_package_finder( - options=options, - session=session, - target_python=target_python, - ignore_requires_python=options.ignore_requires_python, - ) - build_delete = (not (options.no_clean or options.build_dir)) - wheel_cache = WheelCache(options.cache_dir, options.format_control) - - with get_requirement_tracker() as req_tracker, TempDirectory( - options.build_dir, delete=build_delete, kind="install" - ) as directory: - requirement_set = RequirementSet( - check_supported_wheels=not options.target_dir, - ) - - try: - self.populate_requirement_set( - requirement_set, args, options, finder, session, - wheel_cache - ) - - warn_deprecated_install_options( - requirement_set, options.install_options - ) - - preparer = self.make_requirement_preparer( - temp_build_dir=directory, - options=options, - req_tracker=req_tracker, - session=session, - finder=finder, - use_user_site=options.use_user_site, - ) - resolver = self.make_resolver( - preparer=preparer, - finder=finder, - options=options, - wheel_cache=wheel_cache, - use_user_site=options.use_user_site, - ignore_installed=options.ignore_installed, - ignore_requires_python=options.ignore_requires_python, - force_reinstall=options.force_reinstall, - upgrade_strategy=upgrade_strategy, - use_pep517=options.use_pep517, - ) - - self.trace_basic_info(finder) - - resolver.resolve(requirement_set) - - try: - pip_req = requirement_set.get_requirement("pip") - except KeyError: - modifying_pip = None - else: - # 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 - ) - - reqs_to_build = [ - r for r in requirement_set.requirements.values() - if should_build_for_install_command( - r, check_binary_allowed - ) - ] - - _, build_failures = build( - reqs_to_build, - wheel_cache=wheel_cache, - build_options=[], - global_options=[], - ) - - # If we're using PEP 517, we cannot do a direct install - # so we fail here. - # We don't care about failures building legacy - # requirements, as we'll fall through to a direct - # install for those. - pep517_build_failures = [ - r for r in build_failures if r.use_pep517 - ] - if pep517_build_failures: - raise InstallationError( - "Could not build wheels for {} which use" - " PEP 517 and cannot be installed directly".format( - ", ".join(r.name for r in pep517_build_failures))) - - to_install = resolver.get_installation_order( - requirement_set - ) - - # Consistency Checking of the package set we're installing. - should_warn_about_conflicts = ( - not options.ignore_dependencies and - options.warn_about_conflicts - ) - if should_warn_about_conflicts: - self._warn_about_conflicts(to_install) - - # Don't warn about script install locations if - # --target has been specified - warn_script_location = options.warn_script_location - if options.target_dir: - warn_script_location = False - - installed = install_given_reqs( - to_install, - install_options, - global_options, - root=options.root_path, - home=target_temp_dir_path, - prefix=options.prefix_path, - pycompile=options.compile, - warn_script_location=warn_script_location, - use_user_site=options.use_user_site, - ) - - lib_locations = get_lib_location_guesses( - user=options.use_user_site, - home=target_temp_dir_path, - root=options.root_path, - prefix=options.prefix_path, - isolated=options.isolated_mode, - ) - working_set = pkg_resources.WorkingSet(lib_locations) - - installed.sort(key=operator.attrgetter('name')) - items = [] - for result in installed: - item = result.name - try: - installed_version = get_installed_version( - result.name, working_set=working_set - ) - if installed_version: - item += '-' + installed_version - except Exception: - pass - items.append(item) - installed_desc = ' '.join(items) - if installed_desc: - write_output( - 'Successfully installed %s', installed_desc, - ) - except EnvironmentError as error: - show_traceback = (self.verbosity >= 1) - - message = create_env_error_message( - error, show_traceback, options.use_user_site, - ) - logger.error(message, exc_info=show_traceback) - - return ERROR - except PreviousBuildDirError: - options.no_clean = True - raise - finally: - # Clean up - if not options.no_clean: - requirement_set.cleanup_files() - wheel_cache.cleanup() - - if options.target_dir: - self._handle_target_dir( - options.target_dir, target_temp_dir, options.upgrade - ) - - return SUCCESS - - def _handle_target_dir(self, target_dir, target_temp_dir, upgrade): - ensure_dir(target_dir) - - # Checking both purelib and platlib directories for installed - # packages to be moved to target directory - lib_dir_list = [] - - with target_temp_dir: - # Checking both purelib and platlib directories for installed - # packages to be moved to target directory - scheme = distutils_scheme('', home=target_temp_dir.path) - purelib_dir = scheme['purelib'] - platlib_dir = scheme['platlib'] - data_dir = scheme['data'] - - if os.path.exists(purelib_dir): - lib_dir_list.append(purelib_dir) - if os.path.exists(platlib_dir) and platlib_dir != purelib_dir: - lib_dir_list.append(platlib_dir) - if os.path.exists(data_dir): - lib_dir_list.append(data_dir) - - for lib_dir in lib_dir_list: - for item in os.listdir(lib_dir): - if lib_dir == data_dir: - ddir = os.path.join(data_dir, item) - if any(s.startswith(ddir) for s in lib_dir_list[:-1]): - continue - target_item_dir = os.path.join(target_dir, item) - 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 - ) - 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 - ) - continue - if os.path.isdir(target_item_dir): - shutil.rmtree(target_item_dir) - else: - os.remove(target_item_dir) - - shutil.move( - os.path.join(lib_dir, item), - target_item_dir - ) - - def _warn_about_conflicts(self, to_install): - try: - package_set, _dep_info = check_install_conflicts(to_install) - except Exception: - logger.error("Error checking for conflicts.", exc_info=True) - return - missing, conflicting = _dep_info - - # NOTE: There is some duplication here from pip check - for project_name in missing: - version = package_set[project_name][0] - for dependency in missing[project_name]: - logger.critical( - "%s %s requires %s, which is not installed.", - project_name, version, dependency[1], - ) - - for project_name in conflicting: - version = package_set[project_name][0] - for dep_name, dep_version, req in conflicting[project_name]: - logger.critical( - "%s %s has requirement %s, but you'll have %s %s which is " - "incompatible.", - project_name, version, req, dep_name, dep_version, - ) - - -def get_lib_location_guesses(*args, **kwargs): - scheme = distutils_scheme('', *args, **kwargs) - return [scheme['purelib'], scheme['platlib']] - - -def site_packages_writable(**kwargs): - return all( - test_writable_dir(d) for d in set(get_lib_location_guesses(**kwargs)) - ) - - -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 - """Determine whether to do a user install based on the input options. - - If use_user_site is False, no additional checks are done. - If use_user_site is True, it is checked for compatibility with other - options. - If use_user_site is None, the default behaviour depends on the environment, - which is provided by the other arguments. - """ - # In some cases (config from tox), use_user_site can be set to an integer - # rather than a bool, which 'use_user_site is False' wouldn't catch. - if (use_user_site is not None) and (not use_user_site): - logger.debug("Non-user install by explicit request") - return False - - if use_user_site: - if prefix_path: - raise CommandError( - "Can not combine '--user' and '--prefix' as they imply " - "different installation locations" - ) - if virtualenv_no_global(): - raise InstallationError( - "Can not perform a '--user' install. User site-packages " - "are not visible in this virtualenv." - ) - logger.debug("User install by explicit request") - return True - - # If we are here, user installs have not been explicitly requested/avoided - assert use_user_site is None - - # user install incompatible with --prefix/--target - if prefix_path or target_dir: - logger.debug("Non-user install due to --prefix or --target option") - return False - - # If user installs are not enabled, choose a non-user install - if not site.ENABLE_USER_SITE: - logger.debug("Non-user install because user site-packages disabled") - return False - - # If we have permission for a non-user install, do that, - # otherwise do a user install. - if site_packages_writable(root=root_path, isolated=isolated_mode): - 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 warn_deprecated_install_options(requirement_set, options): - # type: (RequirementSet, 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] - - requirements = ( - requirement_set.unnamed_requirements + - list(requirement_set.requirements.values()) - ) - - offenders = [] - - for requirement in requirements: - install_options = requirement.options.get("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 - - deprecated( - reason=( - "Location-changing options found in --install-option: {}. " - "This configuration may cause unexpected behavior and is " - "unsupported.".format( - "; ".join(offenders) - ) - ), - replacement=( - "using pip-level options like --user, --prefix, --root, and " - "--target" - ), - gone_in="20.2", - issue=7309, - ) - - -def create_env_error_message(error, show_traceback, using_user_site): - """Format an error message for an EnvironmentError - - It may occur anytime during the execution of the install command. - """ - parts = [] - - # Mention the error if we are not going to show a traceback - parts.append("Could not install packages due to an EnvironmentError") - if not show_traceback: - parts.append(": ") - parts.append(str(error)) - else: - parts.append(".") - - # Spilt the error indication from a helper message (if any) - parts[-1] += "\n" - - # Suggest useful actions to the user: - # (1) using user site-packages or (2) verifying the permissions - if error.errno == errno.EACCES: - user_option_part = "Consider using the `--user` option" - permissions_part = "Check the permissions" - - if not using_user_site: - parts.extend([ - user_option_part, " or ", - permissions_part.lower(), - ]) - else: - parts.append(permissions_part) - parts.append(".\n") - - return "".join(parts).strip() + "\n" diff --git a/venv/lib/python3.8/site-packages/pip/_internal/commands/list.py b/venv/lib/python3.8/site-packages/pip/_internal/commands/list.py deleted file mode 100644 index d006206..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/commands/list.py +++ /dev/null @@ -1,315 +0,0 @@ -# The following comment should be removed at some point in the future. -# mypy: disallow-untyped-defs=False - -from __future__ import absolute_import - -import json -import logging - -from pip._vendor import six -from pip._vendor.six.moves import zip_longest - -from pip._internal.cli import cmdoptions -from pip._internal.cli.req_command import IndexGroupCommand -from pip._internal.exceptions import CommandError -from pip._internal.index.package_finder import PackageFinder -from pip._internal.models.selection_prefs import SelectionPreferences -from pip._internal.self_outdated_check import make_link_collector -from pip._internal.utils.misc import ( - dist_is_editable, - get_installed_distributions, - write_output, -) -from pip._internal.utils.packaging import get_installer - -from pip._vendor.packaging.version import parse - -logger = logging.getLogger(__name__) - - -class ListCommand(IndexGroupCommand): - """ - List installed packages, including editables. - - Packages are listed in a case-insensitive sorted order. - """ - - usage = """ - %prog [options]""" - - def __init__(self, *args, **kw): - super(ListCommand, self).__init__(*args, **kw) - - cmd_opts = self.cmd_opts - - cmd_opts.add_option( - '-o', '--outdated', - action='store_true', - default=False, - help='List outdated packages') - cmd_opts.add_option( - '-u', '--uptodate', - action='store_true', - default=False, - help='List uptodate packages') - cmd_opts.add_option( - '-e', '--editable', - action='store_true', - default=False, - help='List editable projects.') - cmd_opts.add_option( - '-l', '--local', - action='store_true', - default=False, - 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', - default=False, - help='Only output packages installed in user-site.') - cmd_opts.add_option(cmdoptions.list_path()) - cmd_opts.add_option( - '--pre', - action='store_true', - default=False, - help=("Include pre-release and development versions. By default, " - "pip only finds stable versions."), - ) - - cmd_opts.add_option( - '--format', - action='store', - dest='list_format', - default="columns", - choices=('columns', 'freeze', 'json'), - help="Select the output format among: columns (default), freeze, " - "or json", - ) - - cmd_opts.add_option( - '--not-required', - action='store_true', - dest='not_required', - help="List packages that are not dependencies of " - "installed packages.", - ) - - cmd_opts.add_option( - '--exclude-editable', - action='store_false', - dest='include_editable', - help='Exclude editable package from output.', - ) - cmd_opts.add_option( - '--include-editable', - action='store_true', - dest='include_editable', - help='Include editable package from output.', - default=True, - ) - 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, cmd_opts) - - def _build_package_finder(self, options, session): - """ - Create a package finder appropriate to this list command. - """ - link_collector = make_link_collector(session, options=options) - - # Pass allow_yanked=False to ignore yanked versions. - selection_prefs = SelectionPreferences( - allow_yanked=False, - allow_all_prereleases=options.pre, - ) - - return PackageFinder.create( - link_collector=link_collector, - selection_prefs=selection_prefs, - ) - - def run(self, options, args): - if options.outdated and options.uptodate: - raise CommandError( - "Options --outdated and --uptodate cannot be combined.") - - cmdoptions.check_list_path_option(options) - - packages = get_installed_distributions( - local_only=options.local, - user_only=options.user, - editables_only=options.editable, - include_editables=options.include_editable, - paths=options.path, - ) - - # get_not_required must be called firstly in order to find and - # filter out all dependencies correctly. Otherwise a package - # can't be identified as requirement because some parent packages - # could be filtered out before. - if options.not_required: - packages = self.get_not_required(packages, options) - - if options.outdated: - packages = self.get_outdated(packages, options) - elif options.uptodate: - packages = self.get_uptodate(packages, options) - - self.output_package_listing(packages, options) - - def get_outdated(self, packages, options): - return [ - dist for dist in self.iter_packages_latest_infos(packages, options) - if parse(str(dist.latest_version)) > parse(str(dist.parsed_version)) - ] - - def get_uptodate(self, packages, options): - return [ - dist for dist in self.iter_packages_latest_infos(packages, options) - if parse(str(dist.latest_version)) == parse(str(dist.parsed_version)) - ] - - def get_not_required(self, packages, options): - dep_keys = set() - for dist in packages: - dep_keys.update(requirement.key for requirement in dist.requires()) - return {pkg for pkg in packages if pkg.key not in dep_keys} - - def iter_packages_latest_infos(self, packages, options): - with self._build_session(options) as session: - finder = self._build_package_finder(options, session) - - for dist in packages: - typ = 'unknown' - all_candidates = finder.find_all_candidates(dist.key) - if not options.pre: - # Remove prereleases - all_candidates = [candidate for candidate in all_candidates - if not candidate.version.is_prerelease] - - evaluator = finder.make_candidate_evaluator( - project_name=dist.project_name, - ) - best_candidate = evaluator.sort_best_candidate(all_candidates) - if best_candidate is None: - continue - - remote_version = best_candidate.version - if best_candidate.link.is_wheel: - typ = 'wheel' - else: - typ = 'sdist' - # This is dirty but makes the rest of the code much cleaner - dist.latest_version = remote_version - dist.latest_filetype = typ - yield dist - - def output_package_listing(self, packages, options): - packages = sorted( - packages, - key=lambda dist: dist.project_name.lower(), - ) - 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': - for dist in packages: - if options.verbose >= 1: - write_output("%s==%s (%s)", dist.project_name, - dist.version, dist.location) - else: - write_output("%s==%s", dist.project_name, dist.version) - elif options.list_format == 'json': - write_output(format_for_json(packages, options)) - - def output_package_listing_columns(self, data, header): - # insert the header first: we need to know the size of column names - if len(data) > 0: - data.insert(0, header) - - pkg_strings, sizes = tabulate(data) - - # Create and add a separator. - if len(data) > 0: - pkg_strings.insert(1, " ".join(map(lambda x: '-' * x, sizes))) - - for val in pkg_strings: - write_output(val) - - -def tabulate(vals): - # From pfmoore on GitHub: - # https://github.com/pypa/pip/issues/3651#issuecomment-216932564 - assert len(vals) > 0 - - sizes = [0] * max(len(x) for x in vals) - for row in vals: - sizes = [max(s, len(str(c))) for s, c in zip_longest(sizes, row)] - - result = [] - for row in vals: - display = " ".join([str(c).ljust(s) if c is not None else '' - for s, c in zip_longest(sizes, row)]) - result.append(display) - - return result, sizes - - -def format_for_columns(pkgs, options): - """ - Convert the package data into something usable - by output_package_listing_columns. - """ - 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"] - - data = [] - if options.verbose >= 1 or any(dist_is_editable(x) for x in pkgs): - header.append("Location") - if options.verbose >= 1: - header.append("Installer") - - 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] - - if running_outdated: - row.append(proj.latest_version) - row.append(proj.latest_filetype) - - if options.verbose >= 1 or dist_is_editable(proj): - row.append(proj.location) - if options.verbose >= 1: - row.append(get_installer(proj)) - - data.append(row) - - return data, header - - -def format_for_json(packages, options): - data = [] - for dist in packages: - info = { - 'name': dist.project_name, - 'version': six.text_type(dist.version), - } - if options.verbose >= 1: - info['location'] = dist.location - info['installer'] = get_installer(dist) - if options.outdated: - info['latest_version'] = six.text_type(dist.latest_version) - info['latest_filetype'] = dist.latest_filetype - data.append(info) - return json.dumps(data) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/commands/search.py b/venv/lib/python3.8/site-packages/pip/_internal/commands/search.py deleted file mode 100644 index 2e880ee..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/commands/search.py +++ /dev/null @@ -1,145 +0,0 @@ -# The following comment should be removed at some point in the future. -# mypy: disallow-untyped-defs=False - -from __future__ import absolute_import - -import logging -import sys -import textwrap -from collections import OrderedDict - -from pip._vendor import pkg_resources -from pip._vendor.packaging.version import parse as parse_version -# NOTE: XMLRPC Client is not annotated in typeshed as on 2017-07-17, which is -# why we ignore the type on this import -from pip._vendor.six.moves import xmlrpc_client # type: ignore - -from pip._internal.cli.base_command import Command -from pip._internal.cli.req_command import SessionCommandMixin -from pip._internal.cli.status_codes import NO_MATCHES_FOUND, SUCCESS -from pip._internal.exceptions import CommandError -from pip._internal.models.index import PyPI -from pip._internal.network.xmlrpc import PipXmlrpcTransport -from pip._internal.utils.compat import get_terminal_size -from pip._internal.utils.logging import indent_log -from pip._internal.utils.misc import write_output - -logger = logging.getLogger(__name__) - - -class SearchCommand(Command, SessionCommandMixin): - """Search for PyPI packages whose name or summary contains .""" - - usage = """ - %prog [options] """ - ignore_require_venv = True - - def __init__(self, *args, **kw): - super(SearchCommand, self).__init__(*args, **kw) - self.cmd_opts.add_option( - '-i', '--index', - dest='index', - metavar='URL', - default=PyPI.pypi_url, - help='Base URL of Python Package Index (default %default)') - - self.parser.insert_option_group(0, self.cmd_opts) - - def run(self, options, args): - if not args: - raise CommandError('Missing required argument (search query).') - query = args - pypi_hits = self.search(query, options) - hits = transform_hits(pypi_hits) - - terminal_width = None - if sys.stdout.isatty(): - terminal_width = get_terminal_size()[0] - - print_results(hits, terminal_width=terminal_width) - if pypi_hits: - return SUCCESS - return NO_MATCHES_FOUND - - def search(self, query, options): - index_url = options.index - - session = self.get_default_session(options) - - transport = PipXmlrpcTransport(index_url, session) - pypi = xmlrpc_client.ServerProxy(index_url, transport) - hits = pypi.search({'name': query, 'summary': query}, 'or') - return hits - - -def transform_hits(hits): - """ - 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() - for hit in hits: - name = hit['name'] - summary = hit['summary'] - version = hit['version'] - - if name not in packages.keys(): - packages[name] = { - 'name': name, - 'summary': summary, - 'versions': [version], - } - else: - 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 - - return list(packages.values()) - - -def print_results(hits, name_column_width=None, terminal_width=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 - - installed_packages = [p.project_name for p in pkg_resources.working_set] - for hit in hits: - 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 = textwrap.wrap(summary, target_width) - summary = ('\n' + ' ' * (name_column_width + 3)).join(summary) - - line = '%-*s - %s' % (name_column_width, - '%s (%s)' % (name, latest), summary) - try: - write_output(line) - if name in installed_packages: - dist = pkg_resources.get_distribution(name) - 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) - except UnicodeEncodeError: - pass - - -def highest_version(versions): - return max(versions, key=parse_version) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/commands/show.py b/venv/lib/python3.8/site-packages/pip/_internal/commands/show.py deleted file mode 100644 index a46b08e..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/commands/show.py +++ /dev/null @@ -1,180 +0,0 @@ -# The following comment should be removed at some point in the future. -# mypy: disallow-untyped-defs=False - -from __future__ import absolute_import - -import logging -import os -from email.parser import FeedParser - -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.utils.misc import write_output - -logger = logging.getLogger(__name__) - - -class ShowCommand(Command): - """ - Show information about one or more installed packages. - - The output is in RFC-compliant mail header format. - """ - - usage = """ - %prog [options] ...""" - ignore_require_venv = True - - def __init__(self, *args, **kw): - super(ShowCommand, self).__init__(*args, **kw) - self.cmd_opts.add_option( - '-f', '--files', - dest='files', - action='store_true', - default=False, - 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): - if not args: - 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): - return ERROR - return SUCCESS - - -def search_packages_info(query): - """ - 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 - - 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): - 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 = None - 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 = [l.split(',')[0] for l 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') - 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): - """ - Print the informations from installed distributions found. - """ - results_printed = False - for i, dist in enumerate(distributions): - results_printed = True - 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', []))) - - if verbose: - write_output("Metadata-Version: %s", - dist.get('metadata-version', '')) - write_output("Installer: %s", dist.get('installer', '')) - write_output("Classifiers:") - for classifier in dist.get('classifiers', []): - write_output(" %s", classifier) - write_output("Entry-points:") - for entry in dist.get('entry_points', []): - write_output(" %s", entry.strip()) - 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") - return results_printed diff --git a/venv/lib/python3.8/site-packages/pip/_internal/commands/uninstall.py b/venv/lib/python3.8/site-packages/pip/_internal/commands/uninstall.py deleted file mode 100644 index 1bde414..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/commands/uninstall.py +++ /dev/null @@ -1,82 +0,0 @@ -# The following comment should be removed at some point in the future. -# mypy: disallow-untyped-defs=False - -from __future__ import absolute_import - -from pip._vendor.packaging.utils import canonicalize_name - -from pip._internal.cli.base_command import Command -from pip._internal.cli.req_command import SessionCommandMixin -from pip._internal.exceptions import InstallationError -from pip._internal.req import parse_requirements -from pip._internal.req.constructors import install_req_from_line -from pip._internal.utils.misc import protect_pip_from_modification_on_windows - - -class UninstallCommand(Command, SessionCommandMixin): - """ - Uninstall packages. - - pip is able to uninstall most installed packages. Known exceptions are: - - - Pure distutils packages installed with ``python setup.py install``, which - leave behind no metadata to determine what files were installed. - - Script wrappers installed by ``python setup.py develop``. - """ - - usage = """ - %prog [options] ... - %prog [options] -r ...""" - - def __init__(self, *args, **kw): - super(UninstallCommand, self).__init__(*args, **kw) - self.cmd_opts.add_option( - '-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.', - ) - self.cmd_opts.add_option( - '-y', '--yes', - dest='yes', - action='store_true', - help="Don't ask for confirmation of uninstall deletions.") - - self.parser.insert_option_group(0, self.cmd_opts) - - def run(self, options, args): - session = self.get_default_session(options) - - reqs_to_uninstall = {} - for name in args: - req = install_req_from_line( - name, isolated=options.isolated_mode, - ) - if req.name: - reqs_to_uninstall[canonicalize_name(req.name)] = req - for filename in options.requirements: - for req in parse_requirements( - filename, - options=options, - session=session): - if req.name: - reqs_to_uninstall[canonicalize_name(req.name)] = req - if not reqs_to_uninstall: - raise InstallationError( - 'You must give at least one requirement to %(name)s (see ' - '"pip help %(name)s")' % dict(name=self.name) - ) - - 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, - ) - if uninstall_pathset: - uninstall_pathset.commit() diff --git a/venv/lib/python3.8/site-packages/pip/_internal/commands/wheel.py b/venv/lib/python3.8/site-packages/pip/_internal/commands/wheel.py deleted file mode 100644 index eb44bce..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/commands/wheel.py +++ /dev/null @@ -1,197 +0,0 @@ -# -*- coding: utf-8 -*- - -# The following comment should be removed at some point in the future. -# mypy: disallow-untyped-defs=False - -from __future__ import absolute_import - -import logging -import os -import shutil - -from pip._internal.cache import WheelCache -from pip._internal.cli import cmdoptions -from pip._internal.cli.req_command import RequirementCommand -from pip._internal.exceptions import CommandError, PreviousBuildDirError -from pip._internal.req import RequirementSet -from pip._internal.req.req_tracker import get_requirement_tracker -from pip._internal.utils.misc import ensure_dir, normalize_path -from pip._internal.utils.temp_dir import TempDirectory -from pip._internal.utils.typing import MYPY_CHECK_RUNNING -from pip._internal.wheel_builder import build, should_build_for_wheel_command - -if MYPY_CHECK_RUNNING: - from optparse import Values - from typing import Any, List - - -logger = logging.getLogger(__name__) - - -class WheelCommand(RequirementCommand): - """ - Build Wheel archives for your requirements and dependencies. - - Wheel is a built-package format, and offers the advantage of not - 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. - - """ - - usage = """ - %prog [options] ... - %prog [options] -r ... - %prog [options] [-e] ... - %prog [options] [-e] ... - %prog [options] ...""" - - def __init__(self, *args, **kw): - super(WheelCommand, self).__init__(*args, **kw) - - cmd_opts = self.cmd_opts - - cmd_opts.add_option( - '-w', '--wheel-dir', - dest='wheel_dir', - metavar='dir', - default=os.curdir, - help=("Build wheels into , where the default is the " - "current working directory."), - ) - cmd_opts.add_option(cmdoptions.no_binary()) - cmd_opts.add_option(cmdoptions.only_binary()) - cmd_opts.add_option(cmdoptions.prefer_binary()) - cmd_opts.add_option( - '--build-option', - dest='build_options', - metavar='options', - action='append', - help="Extra arguments to be supplied to 'setup.py bdist_wheel'.", - ) - cmd_opts.add_option(cmdoptions.no_build_isolation()) - cmd_opts.add_option(cmdoptions.use_pep517()) - cmd_opts.add_option(cmdoptions.no_use_pep517()) - cmd_opts.add_option(cmdoptions.constraints()) - cmd_opts.add_option(cmdoptions.editable()) - cmd_opts.add_option(cmdoptions.requirements()) - cmd_opts.add_option(cmdoptions.src()) - cmd_opts.add_option(cmdoptions.ignore_requires_python()) - cmd_opts.add_option(cmdoptions.no_deps()) - cmd_opts.add_option(cmdoptions.build_dir()) - cmd_opts.add_option(cmdoptions.progress_bar()) - - cmd_opts.add_option( - '--global-option', - dest='global_options', - action='append', - metavar='options', - help="Extra global options to be supplied to the setup.py " - "call before the 'bdist_wheel' command.") - - cmd_opts.add_option( - '--pre', - action='store_true', - default=False, - help=("Include pre-release and development versions. By default, " - "pip only finds stable versions."), - ) - - cmd_opts.add_option(cmdoptions.no_clean()) - cmd_opts.add_option(cmdoptions.require_hashes()) - - 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, cmd_opts) - - def run(self, options, args): - # type: (Values, List[Any]) -> None - cmdoptions.check_install_build_global(options) - - session = self.get_default_session(options) - - finder = self._build_package_finder(options, session) - build_delete = (not (options.no_clean or options.build_dir)) - wheel_cache = WheelCache(options.cache_dir, options.format_control) - - options.wheel_dir = normalize_path(options.wheel_dir) - ensure_dir(options.wheel_dir) - - with get_requirement_tracker() as req_tracker, TempDirectory( - options.build_dir, delete=build_delete, kind="wheel" - ) as directory: - - requirement_set = RequirementSet() - - try: - self.populate_requirement_set( - requirement_set, args, options, finder, session, - wheel_cache - ) - - preparer = self.make_requirement_preparer( - temp_build_dir=directory, - options=options, - req_tracker=req_tracker, - session=session, - finder=finder, - wheel_download_dir=options.wheel_dir, - use_user_site=False, - ) - - resolver = self.make_resolver( - preparer=preparer, - finder=finder, - options=options, - wheel_cache=wheel_cache, - ignore_requires_python=options.ignore_requires_python, - use_pep517=options.use_pep517, - ) - - self.trace_basic_info(finder) - - resolver.resolve(requirement_set) - - reqs_to_build = [ - r for r in requirement_set.requirements.values() - if should_build_for_wheel_command(r) - ] - - # build wheels - build_successes, build_failures = build( - reqs_to_build, - wheel_cache=wheel_cache, - build_options=options.build_options or [], - global_options=options.global_options or [], - ) - for req in build_successes: - assert req.link and req.link.is_wheel - assert req.local_file_path - # copy from cache to target directory - try: - shutil.copy(req.local_file_path, options.wheel_dir) - except OSError as e: - logger.warning( - "Building wheel for %s failed: %s", - req.name, e, - ) - build_failures.append(req) - if len(build_failures) != 0: - raise CommandError( - "Failed to build one or more wheels" - ) - except PreviousBuildDirError: - options.no_clean = True - raise - finally: - if not options.no_clean: - requirement_set.cleanup_files() - wheel_cache.cleanup() diff --git a/venv/lib/python3.8/site-packages/pip/_internal/configuration.py b/venv/lib/python3.8/site-packages/pip/_internal/configuration.py deleted file mode 100644 index f09a1ae..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/configuration.py +++ /dev/null @@ -1,422 +0,0 @@ -"""Configuration management setup - -Some terminology: -- name - As written in config files. -- value - Value associated with a name -- key - Name combined with it's section (section.name) -- variant - A single word describing where the configuration key-value pair came from -""" - -# The following comment should be removed at some point in the future. -# mypy: strict-optional=False - -import locale -import logging -import os -import sys - -from pip._vendor.six.moves import configparser - -from pip._internal.exceptions import ( - ConfigurationError, - ConfigurationFileCouldNotBeLoaded, -) -from pip._internal.utils import appdirs -from pip._internal.utils.compat import WINDOWS, expanduser -from pip._internal.utils.misc import ensure_dir, enum -from pip._internal.utils.typing import MYPY_CHECK_RUNNING - -if MYPY_CHECK_RUNNING: - from typing import ( - Any, Dict, Iterable, List, NewType, Optional, Tuple - ) - - RawConfigParser = configparser.RawConfigParser # Shorthand - Kind = NewType("Kind", str) - -logger = logging.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('--'): - name = name[2:] # only prefer long opts - return name - - -def _disassemble_key(name): - # type: (str) -> List[str] - if "." not in name: - error_message = ( - "Key does not contain dot separated section and key. " - "Perhaps you wanted to use 'global.{}' instead?" - ).format(name) - raise ConfigurationError(error_message) - return name.split(".", 1) - - -# 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 - ENV_VAR="env-var", # from Environment Variables -) - - -CONFIG_BASENAME = 'pip.ini' if WINDOWS else 'pip.conf' - - -def get_configuration_files(): - # type: () -> Dict[Kind, List[str]] - global_config_files = [ - 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( - expanduser('~'), - 'pip' if WINDOWS else '.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], - kinds.USER: [legacy_config_file, new_config_file], - } - - -class Configuration(object): - """Handles management of configuration. - - Provides an interface to accessing and managing configuration files. - - This class converts provides an API that takes "section.key-name" style - keys and stores the value associated with it as "key-name" under the - section "section". - - This allows for a clean interface wherein the both the section and the - key-name are preserved in an easy to manage form in the configuration files - and the data stored is also nice. - """ - - def __init__(self, isolated, load_only=None): - # type: (bool, Kind) -> None - super(Configuration, self).__init__() - - _valid_load_only = [kinds.USER, kinds.GLOBAL, kinds.SITE, None] - if load_only not in _valid_load_only: - raise ConfigurationError( - "Got invalid value for load_only - should be one of {}".format( - ", ".join(map(repr, _valid_load_only[:-1])) - ) - ) - self.isolated = isolated # type: bool - self.load_only = load_only # type: Optional[Kind] - - # The order here determines the override order. - self._override_order = [ - kinds.GLOBAL, kinds.USER, kinds.SITE, kinds.ENV, kinds.ENV_VAR - ] - - self._ignore_env_names = ["version", "help"] - - # Because we keep track of where we got the data from - self._parsers = { - variant: [] for variant in self._override_order - } # type: Dict[Kind, List[Tuple[str, RawConfigParser]]] - self._config = { - variant: {} for variant in self._override_order - } # type: Dict[Kind, Dict[str, Any]] - self._modified_parsers = [] # type: List[Tuple[str, RawConfigParser]] - - def load(self): - # type: () -> 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" - - try: - return self._get_parser_to_modify()[0] - except IndexError: - return None - - def items(self): - # type: () -> 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. - """ - try: - return self._dictionary[key] - except KeyError: - raise ConfigurationError("No such key - {}".format(key)) - - def set_value(self, key, value): - # type: (str, Any) -> None - """Modify a value in the configuration. - """ - self._ensure_have_load_only() - - fname, parser = self._get_parser_to_modify() - - if parser is not None: - section, name = _disassemble_key(key) - - # Modify the parser and the configuration - if not parser.has_section(section): - parser.add_section(section) - parser.set(section, name, value) - - self._config[self.load_only][key] = value - self._mark_as_modified(fname, parser) - - def unset_value(self, key): - # type: (str) -> None - """Unset a value in the configuration. - """ - self._ensure_have_load_only() - - if key not in self._config[self.load_only]: - raise ConfigurationError("No such key - {}".format(key)) - - fname, parser = self._get_parser_to_modify() - - if parser is not None: - section, name = _disassemble_key(key) - - # Remove the key in the parser - modified_something = False - if parser.has_section(section): - # Returns whether the option was removed or not - modified_something = parser.remove_option(section, name) - - if modified_something: - # name removed from parser, section may now be empty - section_iter = iter(parser.items(section)) - try: - val = next(section_iter) - except StopIteration: - val = None - - if val is None: - parser.remove_section(section) - - self._mark_as_modified(fname, parser) - else: - raise ConfigurationError( - "Fatal Internal error [id=1]. Please report as a bug." - ) - - del self._config[self.load_only][key] - - def save(self): - # type: () -> None - """Save the current in-memory state. - """ - self._ensure_have_load_only() - - for fname, parser in self._modified_parsers: - logger.info("Writing to %s", fname) - - # Ensure directory exists. - ensure_dir(os.path.dirname(fname)) - - with open(fname, "w") as f: - parser.write(f) - - # - # Private routines - # - - def _ensure_have_load_only(self): - # type: () -> 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. - """ - # NOTE: Dictionaries are not populated if not loaded. So, conditionals - # are not needed here. - retval = {} - - for variant in self._override_order: - retval.update(self._config[variant]) - - return retval - - def _load_config_files(self): - # type: () -> None - """Loads configuration from configuration files - """ - config_files = dict(self._iter_config_files()) - if config_files[kinds.ENV][0:1] == [os.devnull]: - logger.debug( - "Skipping loading configuration files due to " - "environment's PIP_CONFIG_FILE being os.devnull" - ) - return - - for variant, files in config_files.items(): - for fname in files: - # 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 - ) - continue - - parser = self._load_file(variant, fname) - - # 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) - parser = self._construct_parser(fname) - - for section in parser.sections(): - items = parser.items(section) - self._config[variant].update(self._normalized_keys(section, items)) - - return parser - - def _construct_parser(self, fname): - # type: (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): - try: - parser.read(fname) - except UnicodeDecodeError: - # See https://github.com/pypa/pip/issues/4963 - raise ConfigurationFileCouldNotBeLoaded( - reason="contains invalid {} characters".format( - locale.getpreferredencoding(False) - ), - fname=fname, - ) - except configparser.Error as error: - # See https://github.com/pypa/pip/issues/4893 - raise ConfigurationFileCouldNotBeLoaded(error=error) - return parser - - def _load_environment_vars(self): - # type: () -> 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] - """Normalizes items to construct a dictionary with normalized keys. - - This routine is where the names become keys and are made the same - regardless of source - configuration files or environment. - """ - normalized = {} - for name, val in items: - key = section + "." + _normalize_name(name) - normalized[key] = val - return normalized - - def _get_environ_vars(self): - # type: () -> Iterable[Tuple[str, str]] - """Returns a generator with all environmental vars with prefix PIP_""" - for key, val in os.environ.items(): - should_be_yielded = ( - key.startswith("PIP_") and - key[4:].lower() not in self._ignore_env_names - ) - if should_be_yielded: - yield key[4:].lower(), val - - # XXX: This is patched in the tests. - def _iter_config_files(self): - # type: () -> Iterable[Tuple[Kind, List[str]]] - """Yields variant and configuration files associated with it. - - This should be treated like items of a dictionary. - """ - # SMELL: Move the conditions out of this function - - # environment variables have the lowest priority - config_file = os.environ.get('PIP_CONFIG_FILE', None) - if config_file is not None: - yield kinds.ENV, [config_file] - else: - yield kinds.ENV, [] - - config_files = get_configuration_files() - - # at the base we have any global configuration - yield kinds.GLOBAL, config_files[kinds.GLOBAL] - - # per-user configuration next - should_load_user_config = not self.isolated and not ( - config_file and os.path.exists(config_file) - ) - if should_load_user_config: - # The legacy config file is overridden by the new config file - yield kinds.USER, config_files[kinds.USER] - - # finally virtualenv configuration first trumping others - yield kinds.SITE, config_files[kinds.SITE] - - def _get_parser_to_modify(self): - # type: () -> Tuple[str, RawConfigParser] - # Determine which parser to modify - parsers = self._parsers[self.load_only] - if not parsers: - # This should not happen if everything works correctly. - raise ConfigurationError( - "Fatal Internal error [id=2]. Please report as a bug." - ) - - # Use the highest priority parser. - return parsers[-1] - - # XXX: This is patched in the tests. - def _mark_as_modified(self, fname, parser): - # type: (str, RawConfigParser) -> None - file_parser_tuple = (fname, parser) - if file_parser_tuple not in self._modified_parsers: - self._modified_parsers.append(file_parser_tuple) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/distributions/__init__.py b/venv/lib/python3.8/site-packages/pip/_internal/distributions/__init__.py deleted file mode 100644 index d5c1afc..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/distributions/__init__.py +++ /dev/null @@ -1,24 +0,0 @@ -from pip._internal.distributions.sdist import SourceDistribution -from pip._internal.distributions.wheel import WheelDistribution -from pip._internal.utils.typing import MYPY_CHECK_RUNNING - -if MYPY_CHECK_RUNNING: - from pip._internal.distributions.base import AbstractDistribution - from pip._internal.req.req_install import InstallRequirement - - -def make_distribution_for_install_requirement(install_req): - # type: (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. - if install_req.editable: - return SourceDistribution(install_req) - - # If it's a wheel, it's a WheelDistribution - if install_req.is_wheel: - return WheelDistribution(install_req) - - # Otherwise, a SourceDistribution - return SourceDistribution(install_req) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/distributions/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/distributions/__pycache__/__init__.cpython-38.pyc deleted file mode 100644 index 77fd3f51b25936701d01570a32456a5cb4664ef9..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 812 zcmaJ<&2G~`5Z?7)oTNo+)l&tMk>KD%> z;AMCU-osZ;yaFd?Tmnv!7;9GZ^X-2AX7_A+yGOvDJ$;;hvkCc*N!u()j==RBSTd4P zNphM{im@fF+)nH!wxyH1iAxE0)e-a@>E)fI)AU^F=iQ_Wv6pqekffLS6B2fRz=YFTWCn z7xeQaHhCGBq8wC3na(bGHfZ(?L^WR?te#wBFJ_`JTotK|v(_|q%%C9*V^O)P!#us@ ztleku;{a%8g`DeQA+c_rhv!k>Mps)<8-@M)A<#vC=%V&(FXlSO|TKc%zKg<_dCHZrF85*T- KQTQweSNj+A`sgzN diff --git a/venv/lib/python3.8/site-packages/pip/_internal/distributions/__pycache__/base.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/distributions/__pycache__/base.cpython-38.pyc deleted file mode 100644 index 3faa360227670e897bc12d9642b83ef7ddca4cc1..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1928 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 F_zx$QxXl0n diff --git a/venv/lib/python3.8/site-packages/pip/_internal/distributions/base.py b/venv/lib/python3.8/site-packages/pip/_internal/distributions/base.py deleted file mode 100644 index b836b98..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/distributions/base.py +++ /dev/null @@ -1,45 +0,0 @@ -import abc - -from pip._vendor.six import add_metaclass - -from pip._internal.utils.typing import MYPY_CHECK_RUNNING - -if MYPY_CHECK_RUNNING: - from typing import Optional - - from pip._vendor.pkg_resources import Distribution - from pip._internal.req import InstallRequirement - from pip._internal.index.package_finder import PackageFinder - - -@add_metaclass(abc.ABCMeta) -class AbstractDistribution(object): - """A base class for handling installable artifacts. - - The requirements for anything installable are as follows: - - - we must be able to determine the requirement name - (or we can't correctly handle the non-upgrade case). - - - for packages with setup requirements, we must also be able - to determine their requirements without installing additional - packages (for the same reason as run-time dependencies) - - - we must be able to create a Distribution object exposing the - above metadata. - """ - - def __init__(self, req): - # type: (InstallRequirement) -> None - super(AbstractDistribution, self).__init__() - self.req = req - - @abc.abstractmethod - def get_pkg_resources_distribution(self): - # type: () -> Optional[Distribution] - raise NotImplementedError() - - @abc.abstractmethod - def prepare_distribution_metadata(self, finder, build_isolation): - # type: (PackageFinder, bool) -> None - raise NotImplementedError() diff --git a/venv/lib/python3.8/site-packages/pip/_internal/distributions/installed.py b/venv/lib/python3.8/site-packages/pip/_internal/distributions/installed.py deleted file mode 100644 index 0d15bf4..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/distributions/installed.py +++ /dev/null @@ -1,24 +0,0 @@ -from pip._internal.distributions.base import AbstractDistribution -from pip._internal.utils.typing import MYPY_CHECK_RUNNING - -if MYPY_CHECK_RUNNING: - from typing import Optional - - from pip._vendor.pkg_resources import Distribution - from pip._internal.index.package_finder import PackageFinder - - -class InstalledDistribution(AbstractDistribution): - """Represents an installed package. - - This does not need any preparation as the required information has already - been computed. - """ - - def get_pkg_resources_distribution(self): - # type: () -> Optional[Distribution] - return self.req.satisfied_by - - def prepare_distribution_metadata(self, finder, build_isolation): - # type: (PackageFinder, bool) -> None - pass diff --git a/venv/lib/python3.8/site-packages/pip/_internal/distributions/sdist.py b/venv/lib/python3.8/site-packages/pip/_internal/distributions/sdist.py deleted file mode 100644 index be3d7d9..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/distributions/sdist.py +++ /dev/null @@ -1,104 +0,0 @@ -import logging - -from pip._internal.build_env import BuildEnvironment -from pip._internal.distributions.base import AbstractDistribution -from pip._internal.exceptions import InstallationError -from pip._internal.utils.subprocess import runner_with_spinner_message -from pip._internal.utils.typing import MYPY_CHECK_RUNNING - -if MYPY_CHECK_RUNNING: - from typing import Set, Tuple - - from pip._vendor.pkg_resources import Distribution - from pip._internal.index.package_finder import PackageFinder - - -logger = logging.getLogger(__name__) - - -class SourceDistribution(AbstractDistribution): - """Represents a source distribution. - - The preparation step for these needs metadata for the packages to be - generated, either using PEP 517 or using the legacy `setup.py egg_info`. - """ - - def get_pkg_resources_distribution(self): - # type: () -> Distribution - return self.req.get_dist() - - def prepare_distribution_metadata(self, finder, build_isolation): - # type: (PackageFinder, 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}." - ) - error_message = format_string.format( - requirement=self.req, - conflicting_with=conflicting_with, - description=', '.join( - '{} is incompatible with {}'.format(installed, wanted) - for installed, wanted in sorted(conflicting) - ) - ) - raise InstallationError(error_message) - - # Isolate in a BuildEnvironment and install the build-time - # requirements. - pyproject_requires = self.req.pyproject_requires - assert pyproject_requires is not None - - self.req.build_env = BuildEnvironment() - self.req.build_env.install_requirements( - finder, pyproject_requires, 'overlay', - "Installing 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) - if missing: - logger.warning( - "Missing build requirements in pyproject.toml for %s.", - self.req, - ) - logger.warning( - "The project does not specify a build backend, and " - "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. - 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() - - conflicting, missing = self.req.build_env.check_requirements(reqs) - if conflicting: - _raise_conflicts("the backend dependencies", conflicting) - self.req.build_env.install_requirements( - finder, missing, 'normal', - "Installing backend dependencies" - ) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/distributions/wheel.py b/venv/lib/python3.8/site-packages/pip/_internal/distributions/wheel.py deleted file mode 100644 index bf3482b..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/distributions/wheel.py +++ /dev/null @@ -1,36 +0,0 @@ -from zipfile import ZipFile - -from pip._internal.distributions.base import AbstractDistribution -from pip._internal.utils.typing import MYPY_CHECK_RUNNING -from pip._internal.utils.wheel import pkg_resources_distribution_for_wheel - -if MYPY_CHECK_RUNNING: - from pip._vendor.pkg_resources import Distribution - from pip._internal.index.package_finder import PackageFinder - - -class WheelDistribution(AbstractDistribution): - """Represents a wheel distribution. - - This does not need any preparation as wheels can be directly unpacked. - """ - - def get_pkg_resources_distribution(self): - # type: () -> Distribution - """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 - pass diff --git a/venv/lib/python3.8/site-packages/pip/_internal/exceptions.py b/venv/lib/python3.8/site-packages/pip/_internal/exceptions.py deleted file mode 100644 index dddec78..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/exceptions.py +++ /dev/null @@ -1,308 +0,0 @@ -"""Exceptions used throughout package""" - -# The following comment should be removed at some point in the future. -# mypy: disallow-untyped-defs=False - -from __future__ import absolute_import - -from itertools import chain, groupby, repeat - -from pip._vendor.six import iteritems - -from pip._internal.utils.typing import MYPY_CHECK_RUNNING - -if MYPY_CHECK_RUNNING: - from typing import Optional - from pip._vendor.pkg_resources import Distribution - from pip._internal.req.req_install import InstallRequirement - - -class PipError(Exception): - """Base pip exception""" - - -class ConfigurationError(PipError): - """General exception in configuration""" - - -class InstallationError(PipError): - """General exception during installation""" - - -class UninstallationError(PipError): - """General exception during uninstallation""" - - -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"). - """ - - def __init__(self, dist, metadata_name): - # type: (Distribution, str) -> None - """ - :param dist: A Distribution object. - :param metadata_name: The name of the metadata being accessed - (can be "METADATA" or "PKG-INFO"). - """ - self.dist = dist - self.metadata_name = metadata_name - - def __str__(self): - # type: () -> 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, - ) - ) - - -class DistributionNotFound(InstallationError): - """Raised when a distribution cannot be found to satisfy a requirement""" - - -class RequirementsFileParseError(InstallationError): - """Raised when a general error occurs parsing a requirements file line.""" - - -class BestVersionAlreadyInstalled(PipError): - """Raised when the most up-to-date version of a package is already - installed.""" - - -class BadCommand(PipError): - """Raised when virtualenv or a command is not found""" - - -class CommandError(PipError): - """Raised when there is an error in command-line arguments""" - - -class PreviousBuildDirError(PipError): - """Raised when there's a previous conflicting build directory""" - - -class InvalidWheelFilename(InstallationError): - """Invalid wheel filename.""" - - -class UnsupportedWheel(InstallationError): - """Unsupported wheel.""" - - -class HashErrors(InstallationError): - """Multiple HashError instances rolled into one for reporting""" - - def __init__(self): - self.errors = [] - - def append(self, error): - self.errors.append(error) - - def __str__(self): - 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) - - def __nonzero__(self): - return bool(self.errors) - - def __bool__(self): - return self.__nonzero__() - - -class HashError(InstallationError): - """ - A failure to verify a package against known-good hashes - - :cvar order: An int sorting hash exception classes by difficulty of - recovery (lower being harder), so the user doesn't bother fretting - about unpinned packages when he has deeper issues, like VCS - dependencies, to deal with. Also keeps error reports in a - deterministic order. - :cvar head: A section heading for display above potentially many - exceptions of this kind - :ivar req: The InstallRequirement that triggered this error. This is - pasted on after the exception is instantiated, because it's not - typically available earlier. - - """ - req = None # type: Optional[InstallRequirement] - head = '' - - def body(self): - """Return a summary of me for display under the heading. - - This default implementation simply prints a description of the - triggering requirement. - - :param req: The InstallRequirement that provoked this error, with - populate_link() having already been called - - """ - return ' %s' % self._requirement_name() - - def __str__(self): - return '%s\n%s' % (self.head, self.body()) - - def _requirement_name(self): - """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' - - -class VcsHashUnsupported(HashError): - """A hash was provided for a version-control-system-based requirement, but - 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:") - - -class DirectoryUrlHashUnsupported(HashError): - """A hash was provided for a version-control-system-based requirement, but - 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:") - - -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): - """ - :param gotten_hash: The hash of the (possibly malicious) archive we - just downloaded - """ - self.gotten_hash = gotten_hash - - def body(self): - # Dodge circular import. - from pip._internal.utils.hashes import FAVORITE_HASH - - package = None - if self.req: - # 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 ' %s --hash=%s:%s' % (package or 'unknown package', - FAVORITE_HASH, - self.gotten_hash) - - -class HashUnpinned(HashError): - """A requirement had a hash specified but was not pinned to a specific - version.""" - - order = 3 - head = ('In --require-hashes mode, all requirements must have their ' - 'versions pinned with ==. These do not:') - - -class HashMismatch(HashError): - """ - Distribution file hash values don't match. - - :ivar package_name: The name of the package that triggered the hash - mismatch. Feel free to write to this after the exception is raise to - 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): - """ - :param allowed: A dict of algorithm names pointing to lists of allowed - hex digests - :param gots: A dict of algorithm names pointing to hashes we - actually got from the files under suspicion - """ - self.allowed = allowed - self.gots = gots - - def body(self): - return ' %s:\n%s' % (self._requirement_name(), - self._hash_comparison()) - - def _hash_comparison(self): - """ - Return a comparison of actual and expected hash values. - - Example:: - - Expected sha256 abcdeabcdeabcdeabcdeabcdeabcdeabcdeabcdeabcde - or 123451234512345123451234512345123451234512345 - Got bcdefbcdefbcdefbcdefbcdefbcdefbcdefbcdefbcdef - - """ - def hash_then_or(hash_name): - # 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')) - - lines = [] - for hash_name, expecteds in iteritems(self.allowed): - prefix = hash_then_or(hash_name) - lines.extend((' Expected %s %s' % (next(prefix), e)) - for e in expecteds) - lines.append(' Got %s\n' % - self.gots[hash_name].hexdigest()) - return '\n'.join(lines) - - -class UnsupportedPythonVersion(InstallationError): - """Unsupported python version according to Requires-Python package - metadata.""" - - -class ConfigurationFileCouldNotBeLoaded(ConfigurationError): - """When there are errors while loading a configuration file - """ - - def __init__(self, reason="could not be loaded", fname=None, error=None): - super(ConfigurationFileCouldNotBeLoaded, self).__init__(error) - self.reason = reason - self.fname = fname - self.error = error - - def __str__(self): - if self.fname is not None: - message_part = " in {}.".format(self.fname) - else: - assert self.error is not None - message_part = ".\n{}\n".format(self.error.message) - return "Configuration file {}{}".format(self.reason, message_part) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/index/__init__.py b/venv/lib/python3.8/site-packages/pip/_internal/index/__init__.py deleted file mode 100644 index 7a17b7b..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/index/__init__.py +++ /dev/null @@ -1,2 +0,0 @@ -"""Index interaction code -""" diff --git a/venv/lib/python3.8/site-packages/pip/_internal/index/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/index/__pycache__/__init__.cpython-38.pyc deleted file mode 100644 index 6adc64dc26d78238bda86117cf6b144d4cde3d3e..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 190 zcmWIL<>g`k0&_FfL^&Y+7{oyaj6jY95EpX*i4=w?h7`tN22G|aanHPz)Cz^nypq(S z#N?99{5*x^{FGEKKTXD4?D6p_`N{F|D;bKIfV#lMF9-dS+yecA%mUrgyn@8!?9>$9 z@{H8f9No;)^g@eDlX8%pemvN~yu=*+Opy8d@j!vhlK6PNg34PQHo5sJr8%i~AUAym GVg>*P%`uh$ diff --git a/venv/lib/python3.8/site-packages/pip/_internal/index/__pycache__/collector.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/index/__pycache__/collector.cpython-38.pyc deleted file mode 100644 index 9bc9977a1bbbaa63369a5e29f6ba019edf6b505a..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 14156 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�-{FdlG7OqrLLINYsyt+KC##y5RB| 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 a+x&y+Lr*Dl-mYuB@lTsbH2vh|ThzMPlqTz#}r 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 F|1Yo8;2;11 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/index/collector.py b/venv/lib/python3.8/site-packages/pip/_internal/index/collector.py deleted file mode 100644 index 8330793..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/index/collector.py +++ /dev/null @@ -1,544 +0,0 @@ -""" -The main purpose of this module is to expose LinkCollector.collect_links(). -""" - -import cgi -import itertools -import logging -import mimetypes -import os -from collections import OrderedDict - -from pip._vendor import html5lib, requests -from pip._vendor.distlib.compat import unescape -from pip._vendor.requests.exceptions import HTTPError, RetryError, SSLError -from pip._vendor.six.moves.urllib import parse as urllib_parse -from pip._vendor.six.moves.urllib import request as urllib_request - -from pip._internal.models.link import Link -from pip._internal.utils.filetypes import ARCHIVE_EXTENSIONS -from pip._internal.utils.misc import redact_auth_from_url -from pip._internal.utils.typing import MYPY_CHECK_RUNNING -from pip._internal.utils.urls import path_to_url, url_to_path -from pip._internal.vcs import is_url, vcs - -if MYPY_CHECK_RUNNING: - from typing import ( - Callable, Iterable, List, MutableMapping, Optional, Sequence, Tuple, - Union, - ) - import xml.etree.ElementTree - - from pip._vendor.requests import Response - - from pip._internal.models.search_scope import SearchScope - from pip._internal.network.session import PipSession - - HTMLElement = xml.etree.ElementTree.Element - ResponseHeaders = MutableMapping[str, str] - - -logger = logging.getLogger(__name__) - - -def _match_vcs_scheme(url): - # type: (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 '+:': - return scheme - return None - - -def _is_url_like_archive(url): - # type: (str) -> bool - """Return whether the URL looks like an archive. - """ - filename = Link(url).filename - for bad_ext in ARCHIVE_EXTENSIONS: - if filename.endswith(bad_ext): - return True - return False - - -class _NotHTML(Exception): - def __init__(self, content_type, request_desc): - # type: (str, str) -> None - super(_NotHTML, self).__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. - - Raises `_NotHTML` if the content type is not text/html. - """ - content_type = response.headers.get("Content-Type", "") - if not content_type.lower().startswith("text/html"): - raise _NotHTML(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. - - Raises `_NotHTTP` if the URL is not available for a HEAD request, or - `_NotHTML` if the content type is not text/html. - """ - scheme, netloc, path, query, fragment = urllib_parse.urlsplit(url) - if scheme not in {'http', 'https'}: - raise _NotHTTP() - - resp = session.head(url, allow_redirects=True) - resp.raise_for_status() - - _ensure_html_header(resp) - - -def _get_html_response(url, session): - # type: (str, PipSession) -> Response - """Access an HTML page 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. - 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. - """ - if _is_url_like_archive(url): - _ensure_html_response(url, session=session) - - logger.debug('Getting page %s', redact_auth_from_url(url)) - - resp = session.get( - url, - headers={ - "Accept": "text/html", - # We don't want to blindly returned cached data for - # /simple/, because authors generally expecting that - # twine upload && pip install will function, but if - # they've done a pip install in the last ~10 minutes - # it won't. Thus by setting this to zero we will not - # blindly use any cached data, however the benefit of - # using max-age=0 instead of no-cache, is that we will - # still support conditional requests, so we will still - # minimize traffic sent in cases where the page hasn't - # changed at all, we will just always incur the round - # trip for the conditional GET now instead of only - # once per 10 minutes. - # For more information, please see pypa/pip#5670. - "Cache-Control": "max-age=0", - }, - ) - resp.raise_for_status() - - # 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) - - return resp - - -def _get_encoding_from_headers(headers): - # type: (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'] - return None - - -def _determine_base_url(document, page_url): - # type: (HTMLElement, str) -> str - """Determine the HTML document's base URL. - - This looks for a ```` 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_link(url): - # type: (str) -> str - """Makes sure a link is fully encoded. That is, if a ' ' shows up in - the link, it will be rewritten to %20 (while not over-quoting - % or other characters).""" - # Split the URL into parts according to the general structure - # `scheme://netloc/path;parameters?query#fragment`. Note that the - # `netloc` can be empty and the URI will then refer to a local - # filesystem path. - result = urllib_parse.urlparse(url) - # In both cases below we unquote prior to quoting to make sure - # nothing is double quoted. - if result.netloc == "": - # 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. - path = urllib_request.pathname2url( - urllib_request.url2pathname(result.path)) - else: - # In addition to the `/` character we protect `@` so that - # revision strings in VCS URLs are properly parsed. - path = urllib_parse.quote(urllib_parse.unquote(result.path), safe="/@") - 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 = unescape(pyrequire) if pyrequire else None - - yanked_reason = anchor.get('data-yanked') - if yanked_reason: - # This is a unicode string in Python 2 (and 3). - yanked_reason = unescape(yanked_reason) - - link = Link( - url, - comes_from=page_url, - requires_python=pyrequire, - yanked_reason=yanked_reason, - ) - - return link - - -def parse_links(page): - # type: (HTMLPage) -> Iterable[Link] - """ - Parse an HTML document, and yield its anchor elements as Link objects. - """ - document = html5lib.parse( - page.content, - transport_encoding=page.encoding, - namespaceHTMLElements=False, - ) - - 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, - ) - if link is None: - continue - yield link - - -class HTMLPage(object): - """Represents one page, along with its URL""" - - def __init__( - self, - content, # type: bytes - encoding, # type: Optional[str] - url, # type: str - ): - # type: (...) -> None - """ - :param encoding: the encoding to decode the given content. - :param url: the URL from which the HTML was downloaded. - """ - self.content = content - self.encoding = encoding - self.url = url - - def __str__(self): - # type: () -> 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 - if meth is None: - meth = logger.debug - meth("Could not fetch URL %s: %s - skipping", link, reason) - - -def _make_html_page(response): - # type: (Response) -> HTMLPage - encoding = _get_encoding_from_headers(response.headers) - return HTMLPage(response.content, encoding=encoding, url=response.url) - - -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] - - # Check for VCS schemes that do not support lookup as web pages. - vcs_scheme = _match_vcs_scheme(url) - if vcs_scheme: - logger.debug('Cannot look at %s URL %s', 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))): - # 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) - - try: - resp = _get_html_response(url, session=session) - except _NotHTTP: - logger.debug( - 'Skipping page %s because it looks like an archive, and cannot ' - 'be checked by HEAD.', link, - ) - except _NotHTML as exc: - logger.debug( - 'Skipping page %s because the %s request got Content-Type: %s', - link, exc.request_desc, exc.content_type, - ) - except HTTPError as exc: - _handle_get_page_fail(link, exc) - except RetryError as exc: - _handle_get_page_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) - except requests.ConnectionError as exc: - _handle_get_page_fail(link, "connection error: %s" % exc) - except requests.Timeout: - _handle_get_page_fail(link, "timed out") - else: - return _make_html_page(resp) - return None - - -def _remove_duplicate_links(links): - # type: (Iterable[Link]) -> List[Link] - """ - Return a list of links, with duplicates removed and ordering preserved. - """ - # We preserve the ordering when removing duplicates because we can. - return list(OrderedDict.fromkeys(links)) - - -def group_locations(locations, expand_dir=False): - # type: (Sequence[str], bool) -> Tuple[List[str], List[str]] - """ - Divide a list of locations into two groups: "files" (archives) and "urls." - - :return: A pair of lists (files, urls). - """ - files = [] - urls = [] - - # puts the url for the given file path into the appropriate list - def sort_path(path): - # type: (str) -> None - url = path_to_url(path) - if mimetypes.guess_type(url, strict=False)[0] == 'text/html': - urls.append(url) - else: - files.append(url) - - for url in locations: - - is_local_path = os.path.exists(url) - is_file_url = url.startswith('file:') - - if is_local_path or is_file_url: - if is_local_path: - path = url - else: - path = url_to_path(url) - if os.path.isdir(path): - if expand_dir: - path = os.path.realpath(path) - for item in os.listdir(path): - sort_path(os.path.join(path, item)) - elif is_file_url: - urls.append(url) - else: - logger.warning( - "Path '{0}' is ignored: " - "it is a directory.".format(path), - ) - elif os.path.isfile(path): - sort_path(path) - else: - logger.warning( - "Url '%s' is ignored: it is neither a file " - "nor a directory.", url, - ) - elif is_url(url): - # Only add url with clear scheme - urls.append(url) - else: - logger.warning( - "Url '%s' is ignored. It is either a non-existing " - "path or lacks a specific scheme.", url, - ) - - return files, urls - - -class CollectedLinks(object): - - """ - Encapsulates the return value of a call to LinkCollector.collect_links(). - - The return value includes both URLs to project pages containing package - links, as well as individual package Link objects collected from other - sources. - - This info is stored separately as: - - (1) links from the configured file locations, - (2) links from the configured find_links, and - (3) urls to HTML project pages, as described by the PEP 503 simple - repository API. - """ - - def __init__( - self, - files, # type: List[Link] - find_links, # type: List[Link] - project_urls, # type: List[Link] - ): - # type: (...) -> None - """ - :param files: Links from file locations. - :param find_links: Links from find_links. - :param project_urls: URLs to HTML project pages, as described by - the PEP 503 simple repository API. - """ - self.files = files - self.find_links = find_links - self.project_urls = project_urls - - -class LinkCollector(object): - - """ - Responsible for collecting Link objects from all configured locations, - making network requests as needed. - - The class's main method is its collect_links() method. - """ - - def __init__( - self, - session, # type: PipSession - search_scope, # type: SearchScope - ): - # type: (...) -> None - self.search_scope = search_scope - self.session = session - - @property - def find_links(self): - # type: () -> List[str] - return self.search_scope.find_links - - def fetch_page(self, location): - # type: (Link) -> Optional[HTMLPage] - """ - Fetch an HTML page containing package links. - """ - return _get_html_page(location, session=self.session) - - def collect_links(self, project_name): - # type: (str) -> CollectedLinks - """Find all available links for the given project name. - - :return: All the Link objects (unfiltered), as a CollectedLinks object. - """ - search_scope = self.search_scope - index_locations = search_scope.get_index_urls_locations(project_name) - index_file_loc, index_url_loc = group_locations(index_locations) - fl_file_loc, fl_url_loc = group_locations( - self.find_links, expand_dir=True, - ) - - file_links = [ - Link(url) for url in itertools.chain(index_file_loc, fl_file_loc) - ] - - # We trust every directly linked archive in find_links - find_link_links = [Link(url, '-f') for url in self.find_links] - - # We trust every url that the user has given us whether it was given - # via --index-url or --find-links. - # We want to filter out anything that does not have a secure origin. - url_locations = [ - link for link in itertools.chain( - (Link(url) for url in index_url_loc), - (Link(url) for url in fl_url_loc), - ) - if self.session.is_secure_origin(link) - ] - - url_locations = _remove_duplicate_links(url_locations) - lines = [ - '{} location(s) to search for versions of {}:'.format( - len(url_locations), project_name, - ), - ] - for link in url_locations: - lines.append('* {}'.format(link)) - logger.debug('\n'.join(lines)) - - return CollectedLinks( - files=file_links, - find_links=find_link_links, - project_urls=url_locations, - ) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/index/package_finder.py b/venv/lib/python3.8/site-packages/pip/_internal/index/package_finder.py deleted file mode 100644 index a74d78d..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/index/package_finder.py +++ /dev/null @@ -1,1013 +0,0 @@ -"""Routines related to PyPI, indexes""" - -# The following comment should be removed at some point in the future. -# mypy: strict-optional=False - -from __future__ import absolute_import - -import logging -import re - -from pip._vendor.packaging import specifiers -from pip._vendor.packaging.utils import canonicalize_name -from pip._vendor.packaging.version import parse as parse_version - -from pip._internal.exceptions import ( - BestVersionAlreadyInstalled, - DistributionNotFound, - InvalidWheelFilename, - UnsupportedWheel, -) -from pip._internal.index.collector import parse_links -from pip._internal.models.candidate import InstallationCandidate -from pip._internal.models.format_control import FormatControl -from pip._internal.models.link import Link -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.utils.filetypes import WHEEL_EXTENSION -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.typing import MYPY_CHECK_RUNNING -from pip._internal.utils.unpacking import SUPPORTED_EXTENSIONS -from pip._internal.utils.urls import url_to_path - -if MYPY_CHECK_RUNNING: - from typing import ( - FrozenSet, Iterable, List, Optional, Set, Text, Tuple, Union, - ) - - from pip._vendor.packaging.tags import Tag - from pip._vendor.packaging.version import _BaseVersion - - from pip._internal.index.collector import LinkCollector - from pip._internal.models.search_scope import SearchScope - from pip._internal.req import InstallRequirement - from pip._internal.utils.hashes import Hashes - - BuildTag = Union[Tuple[()], Tuple[int, str]] - CandidateSortingKey = ( - Tuple[int, int, int, _BaseVersion, BuildTag, Optional[int]] - ) - - -__all__ = ['FormatControl', 'BestCandidateResult', 'PackageFinder'] - - -logger = logging.getLogger(__name__) - - -def _check_link_requires_python( - link, # type: Link - version_info, # type: Tuple[int, int, int] - ignore_requires_python=False, # type: bool -): - # type: (...) -> bool - """ - Return whether the given Python version is compatible with a link's - "Requires-Python" value. - - :param version_info: A 3-tuple of ints representing the Python - major-minor-micro version to check. - :param ignore_requires_python: Whether to ignore the "Requires-Python" - value if the given Python version isn't compatible. - """ - try: - is_compatible = check_requires_python( - link.requires_python, version_info=version_info, - ) - except specifiers.InvalidSpecifier: - logger.debug( - "Ignoring invalid Requires-Python (%r) for link: %s", - link.requires_python, link, - ) - else: - if not is_compatible: - 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, - ) - return False - - logger.debug( - 'Ignoring failed Requires-Python check (%s not in: %r) ' - 'for link: %s', - version, link.requires_python, link, - ) - - return True - - -class LinkEvaluator(object): - - """ - Responsible for evaluating links for a particular project. - """ - - _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 - # that decision to be made explicit in the calling code, which helps - # 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 - """ - :param project_name: The user supplied package name. - :param canonical_name: The canonical package name. - :param formats: The formats allowed for this package. Should be a set - with 'binary' or 'source' or both in it. - :param target_python: The target Python interpreter to use when - evaluating link compatibility. This is used, for example, to - check wheel compatibility, as well as when checking the Python - version, e.g. the Python version embedded in a link filename - (or egg fragment) and against an HTML link's optional PEP 503 - "data-requires-python" attribute. - :param allow_yanked: Whether files marked as yanked (in the sense - of PEP 592) are permitted to be candidates for install. - :param ignore_requires_python: Whether to ignore incompatible - PEP 503 "data-requires-python" values in HTML links. Defaults - to False. - """ - if ignore_requires_python is None: - ignore_requires_python = False - - self._allow_yanked = allow_yanked - self._canonical_name = canonical_name - self._ignore_requires_python = ignore_requires_python - self._formats = formats - self._target_python = target_python - - self.project_name = project_name - - def evaluate_link(self, link): - # type: (Link) -> Tuple[bool, Optional[Text]] - """ - 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. - """ - version = None - if link.is_yanked and not self._allow_yanked: - reason = link.yanked_reason or '' - # Mark this as a unicode string to prevent "UnicodeEncodeError: - # 'ascii' codec can't encode character" in Python 2 when - # the reason contains non-ascii characters. - return (False, u'yanked for reason: {}'.format(reason)) - - if link.egg_fragment: - egg_info = link.egg_fragment - ext = link.ext - else: - egg_info, ext = link.splitext() - if not ext: - return (False, 'not a file') - if ext not in SUPPORTED_EXTENSIONS: - return (False, 'unsupported archive format: %s' % ext) - if "binary" not in self._formats and ext == WHEEL_EXTENSION: - reason = 'No binaries permitted for %s' % self.project_name - return (False, reason) - if "macosx10" in link.path and ext == '.zip': - return (False, 'macosx10 one') - if ext == WHEEL_EXTENSION: - try: - wheel = Wheel(link.filename) - except InvalidWheelFilename: - return (False, 'invalid wheel filename') - if canonicalize_name(wheel.name) != self._canonical_name: - reason = 'wrong project name (not %s)' % self.project_name - return (False, 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() - reason = ( - "none of the wheel's tags match: {}".format( - ', '.join(file_tags) - ) - ) - return (False, 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: - return (False, 'No sources permitted for %s' % self.project_name) - - if not version: - version = _extract_version_from_fragment( - egg_info, self._canonical_name, - ) - if not version: - return ( - False, 'Missing project version for %s' % self.project_name, - ) - - match = self._py_version_re.search(version) - if match: - version = version[:match.start()] - py_version = match.group(1) - if py_version != self._target_python.py_version: - return (False, 'Python version is incorrect') - - supports_python = _check_link_requires_python( - 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) - - logger.debug('Found link %s, version: %s', link, version) - - return (True, version) - - -def filter_unallowed_hashes( - candidates, # type: List[InstallationCandidate] - hashes, # type: Hashes - project_name, # type: str -): - # type: (...) -> List[InstallationCandidate] - """ - Filter out candidates whose hashes aren't allowed, and return a new - list of candidates. - - If at least one candidate has an allowed hash, then all candidates with - either an allowed hash or no hash specified are returned. Otherwise, - the given candidates are returned. - - Including the candidates with no hash specified when there is a match - allows a warning to be logged if there is a more preferred candidate - with no hash specified. Returning all candidates in the case of no - matches lets pip report the hash of the candidate that would otherwise - have been installed (e.g. permitting the user to more easily update - their requirements file with the desired hash). - """ - if not hashes: - logger.debug( - 'Given no hashes to check %s links for project %r: ' - 'discarding no candidates', - len(candidates), - project_name, - ) - # Make sure we're not returning back the given value. - return list(candidates) - - matches_or_no_digest = [] - # Collect the non-matches for logging purposes. - non_matches = [] - match_count = 0 - for candidate in candidates: - link = candidate.link - if not link.has_hash: - pass - elif link.is_hash_allowed(hashes=hashes): - match_count += 1 - else: - non_matches.append(candidate) - continue - - matches_or_no_digest.append(candidate) - - if match_count: - filtered = matches_or_no_digest - else: - # Make sure we're not returning back the given value. - filtered = list(candidates) - - if len(filtered) == len(candidates): - discard_message = 'discarding no candidates' - else: - discard_message = 'discarding {} non-matches:\n {}'.format( - len(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', - len(candidates), - project_name, - hashes.digest_count, - match_count, - len(matches_or_no_digest) - match_count, - discard_message - ) - - return filtered - - -class CandidatePreferences(object): - - """ - Encapsulates some of the preferences for filtering and sorting - InstallationCandidate objects. - """ - - def __init__( - self, - prefer_binary=False, # type: bool - allow_all_prereleases=False, # type: bool - ): - # type: (...) -> None - """ - :param allow_all_prereleases: Whether to allow all pre-releases. - """ - self.allow_all_prereleases = allow_all_prereleases - self.prefer_binary = prefer_binary - - -class BestCandidateResult(object): - """A collection of candidates, returned by `PackageFinder.find_best_candidate`. - - This class is only intended to be instantiated by CandidateEvaluator's - `compute_best_candidate()` method. - """ - - def __init__( - self, - candidates, # type: List[InstallationCandidate] - applicable_candidates, # type: List[InstallationCandidate] - best_candidate, # type: Optional[InstallationCandidate] - ): - # type: (...) -> None - """ - :param candidates: A sequence of all available candidates found. - :param applicable_candidates: The applicable candidates. - :param best_candidate: The most preferred candidate found, or None - if no applicable candidates were found. - """ - assert set(applicable_candidates) <= set(candidates) - - if best_candidate is None: - assert not applicable_candidates - else: - assert best_candidate in applicable_candidates - - self._applicable_candidates = applicable_candidates - self._candidates = candidates - - self.best_candidate = best_candidate - - def iter_all(self): - # type: () -> Iterable[InstallationCandidate] - """Iterate through all candidates. - """ - return iter(self._candidates) - - def iter_applicable(self): - # type: () -> Iterable[InstallationCandidate] - """Iterate through the applicable candidates. - """ - return iter(self._applicable_candidates) - - -class CandidateEvaluator(object): - - """ - Responsible for filtering and sorting candidates for installation based - on what tags are valid. - """ - - @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 - """Create a CandidateEvaluator object. - - :param target_python: The target Python interpreter to use when - checking compatibility. If None (the default), a TargetPython - object will be constructed from the running Python. - :param specifier: An optional object implementing `filter` - (e.g. `packaging.specifiers.SpecifierSet`) to filter applicable - versions. - :param hashes: An optional collection of allowed hashes. - """ - if target_python is None: - target_python = TargetPython() - if specifier is None: - specifier = specifiers.SpecifierSet() - - supported_tags = target_python.get_tags() - - return cls( - project_name=project_name, - supported_tags=supported_tags, - specifier=specifier, - prefer_binary=prefer_binary, - allow_all_prereleases=allow_all_prereleases, - hashes=hashes, - ) - - 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 - """ - :param supported_tags: The PEP 425 tags supported by the target - Python in order of preference (most preferred first). - """ - self._allow_all_prereleases = allow_all_prereleases - self._hashes = hashes - self._prefer_binary = prefer_binary - self._project_name = project_name - self._specifier = specifier - self._supported_tags = supported_tags - - def get_applicable_candidates( - self, - candidates, # type: List[InstallationCandidate] - ): - # type: (...) -> List[InstallationCandidate] - """ - Return the applicable candidates from a list of candidates. - """ - # Using None infers from the specifier instead. - allow_prereleases = self._allow_all_prereleases or None - specifier = self._specifier - versions = { - 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 - # pkg_resources._vendor.packaging.version.Version as different - # types. This way we'll use a str as a common data interchange - # format. If we stop using the pkg_resources provided specifier - # and start using our own, we can drop the cast to str(). - (str(c.version) for c in candidates), - prereleases=allow_prereleases, - ) - } - - # Again, converting version to str to deal with debundling. - applicable_candidates = [ - c for c in candidates if str(c.version) in versions - ] - - filtered_applicable_candidates = filter_unallowed_hashes( - candidates=applicable_candidates, - hashes=self._hashes, - project_name=self._project_name, - ) - - return sorted(filtered_applicable_candidates, key=self._sort_key) - - def _sort_key(self, candidate): - # type: (InstallationCandidate) -> CandidateSortingKey - """ - Function to pass as the `key` argument to a call to sorted() to sort - InstallationCandidates by preference. - - Returns a tuple such that tuples sorting as greater using Python's - default comparison operator are more preferred. - - The preference is as follows: - - First and foremost, candidates with allowed (matching) hashes are - always preferred over candidates without matching hashes. This is - because e.g. if the only candidate with an allowed hash is yanked, - we still want to use that candidate. - - Second, excepting hash considerations, candidates that have been - yanked (in the sense of PEP 592) are always less preferred than - candidates that haven't been yanked. Then: - - If not finding wheels, they are sorted by version only. - If finding wheels, then the sort order is by version, then: - 1. existing installs - 2. wheels ordered via Wheel.support_index_min(self._supported_tags) - 3. source archives - If prefer_binary was set, then all wheels are sorted above sources. - - Note: it was considered to embed this logic into the Link - comparison operators, but then different sdist links - with the same version, would have to be considered equal - """ - valid_tags = self._supported_tags - support_num = len(valid_tags) - build_tag = () # type: BuildTag - binary_preference = 0 - link = candidate.link - if link.is_wheel: - # can raise InvalidWheelFilename - wheel = Wheel(link.filename) - if not wheel.supported(valid_tags): - raise UnsupportedWheel( - "%s is not a supported wheel for this platform. It " - "can't be sorted." % wheel.filename - ) - if self._prefer_binary: - binary_preference = 1 - pri = -(wheel.support_index_min(valid_tags)) - if wheel.build_tag is not None: - match = re.match(r'^(\d+)(.*)$', wheel.build_tag) - build_tag_groups = match.groups() - build_tag = (int(build_tag_groups[0]), build_tag_groups[1]) - else: # sdist - pri = -(support_num) - 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, - build_tag, pri, - ) - - def sort_best_candidate( - self, - candidates, # type: List[InstallationCandidate] - ): - # type: (...) -> Optional[InstallationCandidate] - """ - Return the best candidate per the instance's sort order, or None if - no candidate is acceptable. - """ - if not candidates: - return None - - best_candidate = max(candidates, key=self._sort_key) - - # Log a warning per PEP 592 if necessary before returning. - link = best_candidate.link - if link.is_yanked: - reason = link.yanked_reason or '' - msg = ( - # Mark this as a unicode string to prevent - # "UnicodeEncodeError: 'ascii' codec can't encode character" - # in Python 2 when the reason contains non-ascii characters. - u'The candidate selected for download or install is a ' - 'yanked version: {candidate}\n' - 'Reason for being yanked: {reason}' - ).format(candidate=best_candidate, reason=reason) - logger.warning(msg) - - return best_candidate - - def compute_best_candidate( - self, - candidates, # type: List[InstallationCandidate] - ): - # type: (...) -> BestCandidateResult - """ - Compute and return a `BestCandidateResult` instance. - """ - applicable_candidates = self.get_applicable_candidates(candidates) - - best_candidate = self.sort_best_candidate(applicable_candidates) - - return BestCandidateResult( - candidates, - applicable_candidates=applicable_candidates, - best_candidate=best_candidate, - ) - - -class PackageFinder(object): - """This finds packages. - - This is meant to match easy_install's technique for looking for - packages, by reading pages and looking for appropriate links. - """ - - 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 - """ - This constructor is primarily meant to be used by the create() class - method and from tests. - - :param format_control: A FormatControl object, used to control - the selection of source packages / binary packages when consulting - the index and links. - :param candidate_prefs: Options to use when creating a - CandidateEvaluator object. - """ - if candidate_prefs is None: - candidate_prefs = CandidatePreferences() - - format_control = format_control or FormatControl(set(), set()) - - self._allow_yanked = allow_yanked - self._candidate_prefs = candidate_prefs - self._ignore_requires_python = ignore_requires_python - self._link_collector = link_collector - self._target_python = target_python - - self.format_control = format_control - - # These are boring links that have already been logged somehow. - self._logged_links = set() # type: Set[Link] - - # Don't include an allow_yanked default value to make sure each call - # site considers whether yanked releases are allowed. This also causes - # that decision to be made explicit in the calling code, which helps - # people when reading the code. - @classmethod - def create( - cls, - link_collector, # type: LinkCollector - selection_prefs, # type: SelectionPreferences - target_python=None, # type: Optional[TargetPython] - ): - # type: (...) -> PackageFinder - """Create a PackageFinder. - - :param selection_prefs: The candidate selection preferences, as a - SelectionPreferences object. - :param target_python: The target Python interpreter to use when - checking compatibility. If None (the default), a TargetPython - object will be constructed from the running Python. - """ - if target_python is None: - target_python = TargetPython() - - candidate_prefs = CandidatePreferences( - prefer_binary=selection_prefs.prefer_binary, - allow_all_prereleases=selection_prefs.allow_all_prereleases, - ) - - return cls( - candidate_prefs=candidate_prefs, - link_collector=link_collector, - target_python=target_python, - allow_yanked=selection_prefs.allow_yanked, - format_control=selection_prefs.format_control, - ignore_requires_python=selection_prefs.ignore_requires_python, - ) - - @property - def search_scope(self): - # type: () -> SearchScope - return self._link_collector.search_scope - - @search_scope.setter - def search_scope(self, search_scope): - # type: (SearchScope) -> None - self._link_collector.search_scope = search_scope - - @property - def find_links(self): - # type: () -> List[str] - return self._link_collector.find_links - - @property - def index_urls(self): - # type: () -> List[str] - return self.search_scope.index_urls - - @property - def trusted_hosts(self): - # type: () -> 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 - return self._candidate_prefs.allow_all_prereleases - - def set_allow_all_prereleases(self): - # type: () -> None - self._candidate_prefs.allow_all_prereleases = True - - def make_link_evaluator(self, project_name): - # type: (str) -> LinkEvaluator - canonical_name = canonicalize_name(project_name) - formats = self.format_control.get_allowed_formats(canonical_name) - - return LinkEvaluator( - project_name=project_name, - canonical_name=canonical_name, - formats=formats, - target_python=self._target_python, - allow_yanked=self._allow_yanked, - ignore_requires_python=self._ignore_requires_python, - ) - - def _sort_links(self, links): - # type: (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] - for link in links: - if link not in seen: - seen.add(link) - if link.egg_fragment: - eggs.append(link) - else: - no_eggs.append(link) - return no_eggs + eggs - - def _log_skipped_link(self, link, reason): - # type: (Link, Text) -> None - if link not in self._logged_links: - # Mark this as a unicode string to prevent "UnicodeEncodeError: - # 'ascii' codec can't encode character" in Python 2 when - # the reason contains non-ascii characters. - # Also, put the link at the end so the reason is more visible - # and because the link string is usually very long. - logger.debug(u'Skipping link: %s: %s', reason, link) - self._logged_links.add(link) - - def get_install_candidate(self, link_evaluator, link): - # type: (LinkEvaluator, 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) - return None - - return InstallationCandidate( - name=link_evaluator.project_name, - link=link, - # Convert the Text result to str since InstallationCandidate - # accepts str. - version=str(result), - ) - - def evaluate_links(self, link_evaluator, links): - # type: (LinkEvaluator, Iterable[Link]) -> List[InstallationCandidate] - """ - Convert links that are candidates to InstallationCandidate objects. - """ - candidates = [] - for link in self._sort_links(links): - candidate = self.get_install_candidate(link_evaluator, link) - if candidate is not None: - candidates.append(candidate) - - return candidates - - def process_project_url(self, project_url, link_evaluator): - # type: (Link, LinkEvaluator) -> List[InstallationCandidate] - logger.debug( - 'Fetching project page and analyzing links: %s', project_url, - ) - html_page = self._link_collector.fetch_page(project_url) - if html_page is None: - return [] - - page_links = list(parse_links(html_page)) - - with indent_log(): - package_links = self.evaluate_links( - link_evaluator, - links=page_links, - ) - - return package_links - - def find_all_candidates(self, project_name): - # type: (str) -> List[InstallationCandidate] - """Find all available InstallationCandidate for project_name - - This checks index_urls and find_links. - All versions found are returned as an InstallationCandidate list. - - See LinkEvaluator.evaluate_link() for details on which files - are accepted. - """ - collected_links = self._link_collector.collect_links(project_name) - - link_evaluator = self.make_link_evaluator(project_name) - - find_links_versions = self.evaluate_links( - link_evaluator, - links=collected_links.find_links, - ) - - page_versions = [] - for project_url in collected_links.project_urls: - package_links = self.process_project_url( - project_url, link_evaluator=link_evaluator, - ) - page_versions.extend(package_links) - - file_versions = self.evaluate_links( - link_evaluator, - links=collected_links.files, - ) - if file_versions: - file_versions.sort(reverse=True) - logger.debug( - 'Local files found: %s', - ', '.join([ - url_to_path(candidate.link.url) - for candidate in file_versions - ]) - ) - - # This is an intentional priority ordering - return file_versions + find_links_versions + page_versions - - 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. - """ - candidate_prefs = self._candidate_prefs - return CandidateEvaluator.create( - project_name=project_name, - target_python=self._target_python, - prefer_binary=candidate_prefs.prefer_binary, - allow_all_prereleases=candidate_prefs.allow_all_prereleases, - specifier=specifier, - hashes=hashes, - ) - - def find_best_candidate( - self, - project_name, # type: str - specifier=None, # type: Optional[specifiers.BaseSpecifier] - hashes=None, # type: Optional[Hashes] - ): - # type: (...) -> BestCandidateResult - """Find matches for the given project and specifier. - - :param specifier: An optional object implementing `filter` - (e.g. `packaging.specifiers.SpecifierSet`) to filter applicable - versions. - - :return: A `BestCandidateResult` instance. - """ - candidates = self.find_all_candidates(project_name) - candidate_evaluator = self.make_candidate_evaluator( - project_name=project_name, - specifier=specifier, - hashes=hashes, - ) - return candidate_evaluator.compute_best_candidate(candidates) - - def find_requirement(self, req, upgrade): - # type: (InstallRequirement, bool) -> Optional[Link] - """Try to find a Link matching req - - Expects req, an InstallRequirement and upgrade, a boolean - Returns a Link if found, - Raises DistributionNotFound or BestVersionAlreadyInstalled otherwise - """ - hashes = req.hashes(trust_internet=False) - best_candidate_result = self.find_best_candidate( - req.name, specifier=req.specifier, hashes=hashes, - ) - best_candidate = best_candidate_result.best_candidate - - installed_version = None # type: Optional[_BaseVersion] - if req.satisfied_by is not None: - installed_version = parse_version(req.satisfied_by.version) - - def _format_versions(cand_iter): - # type: (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" - - 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)', - req, - _format_versions(best_candidate_result.iter_all()), - ) - - raise DistributionNotFound( - 'No matching distribution found for %s' % req - ) - - best_installed = False - if installed_version and ( - best_candidate is None or - best_candidate.version <= installed_version): - best_installed = True - - if not upgrade and installed_version is not None: - if best_installed: - logger.debug( - 'Existing installed version (%s) is most up-to-date and ' - 'satisfies requirement', - installed_version, - ) - else: - logger.debug( - 'Existing installed version (%s) satisfies requirement ' - '(most up-to-date version is %s)', - installed_version, - best_candidate.version, - ) - return None - - if best_installed: - # We have an existing version, and its the best version - logger.debug( - 'Installed version (%s) is most up-to-date (past versions: ' - '%s)', - installed_version, - _format_versions(best_candidate_result.iter_applicable()), - ) - raise BestVersionAlreadyInstalled - - logger.debug( - 'Using version %s (newest of versions: %s)', - best_candidate.version, - _format_versions(best_candidate_result.iter_applicable()), - ) - return best_candidate.link - - -def _find_name_version_sep(fragment, canonical_name): - # type: (str, str) -> int - """Find the separator's index based on the package's canonical name. - - :param fragment: A + filename "fragment" (stem) or - egg fragment. - :param canonical_name: The package's canonical name. - - This function is needed since the canonicalized name does not necessarily - have the same length as the egg info's name part. An example:: - - >>> fragment = 'foo__bar-1.0' - >>> canonical_name = 'foo-bar' - >>> _find_name_version_sep(fragment, canonical_name) - 8 - """ - # Project name and version must be separated by one single dash. Find all - # occurrences of dashes; if the string in front of it matches the canonical - # name, this is the one separating the name and version parts. - for i, c in enumerate(fragment): - if c != "-": - continue - if canonicalize_name(fragment[:i]) == canonical_name: - return i - raise ValueError("{} does not match {}".format(fragment, canonical_name)) - - -def _extract_version_from_fragment(fragment, canonical_name): - # type: (str, str) -> Optional[str] - """Parse the version string from a + filename - "fragment" (stem) or egg fragment. - - :param fragment: The string to parse. E.g. foo-2.1 - :param canonical_name: The canonicalized name of the package this - belongs to. - """ - try: - version_start = _find_name_version_sep(fragment, canonical_name) + 1 - except ValueError: - return None - version = fragment[version_start:] - if not version: - return None - return version diff --git a/venv/lib/python3.8/site-packages/pip/_internal/legacy_resolve.py b/venv/lib/python3.8/site-packages/pip/_internal/legacy_resolve.py deleted file mode 100644 index ca26912..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/legacy_resolve.py +++ /dev/null @@ -1,430 +0,0 @@ -"""Dependency Resolution - -The dependency resolution in pip is performed as follows: - -for top-level requirements: - a. only one spec allowed per project, regardless of conflicts or not. - otherwise a "double requirement" exception is raised - b. they override sub-dependency requirements. -for sub-dependencies - a. "first found, wins" (where the order is breadth first) -""" - -# The following comment should be removed at some point in the future. -# mypy: strict-optional=False -# mypy: disallow-untyped-defs=False - -import logging -import sys -from collections import defaultdict -from itertools import chain - -from pip._vendor.packaging import specifiers - -from pip._internal.exceptions import ( - BestVersionAlreadyInstalled, - DistributionNotFound, - HashError, - HashErrors, - UnsupportedPythonVersion, -) -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.typing import MYPY_CHECK_RUNNING - -if MYPY_CHECK_RUNNING: - from typing import Callable, DefaultDict, List, Optional, Set, Tuple - from pip._vendor import pkg_resources - - from pip._internal.distributions import AbstractDistribution - from pip._internal.index.package_finder import PackageFinder - from pip._internal.operations.prepare import RequirementPreparer - from pip._internal.req.req_install import InstallRequirement - from pip._internal.req.req_set import RequirementSet - - InstallRequirementProvider = Callable[ - [str, InstallRequirement], InstallRequirement - ] - DiscoveredDependencies = DefaultDict[str, List[InstallRequirement]] - -logger = logging.getLogger(__name__) - - -def _check_dist_requires_python( - dist, # type: pkg_resources.Distribution - version_info, # type: Tuple[int, int, int] - ignore_requires_python=False, # type: bool -): - # type: (...) -> None - """ - Check whether the given Python version is compatible with a distribution's - "Requires-Python" value. - - :param version_info: A 3-tuple of ints representing the Python - major-minor-micro version to check. - :param ignore_requires_python: Whether to ignore the "Requires-Python" - value if the given Python version isn't compatible. - - :raises UnsupportedPythonVersion: When the given Python version isn't - compatible. - """ - requires_python = get_requires_python(dist) - try: - is_compatible = check_requires_python( - 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, - ) - return - - if is_compatible: - return - - 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, version, requires_python, - ) - return - - raise UnsupportedPythonVersion( - 'Package {!r} requires a different Python: {} not in {!r}'.format( - dist.project_name, version, requires_python, - )) - - -class Resolver(object): - """Resolves which packages need to be installed/uninstalled to perform \ - the requested operation without breaking the requirements of any package. - """ - - _allowed_strategies = {"eager", "only-if-needed", "to-satisfy-only"} - - def __init__( - self, - preparer, # type: RequirementPreparer - finder, # type: PackageFinder - 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 - super(Resolver, self).__init__() - assert upgrade_strategy in self._allowed_strategies - - if py_version_info is None: - py_version_info = sys.version_info[:3] - else: - py_version_info = normalize_version_info(py_version_info) - - self._py_version_info = py_version_info - - self.preparer = preparer - self.finder = finder - - self.upgrade_strategy = upgrade_strategy - self.force_reinstall = force_reinstall - self.ignore_dependencies = ignore_dependencies - self.ignore_installed = ignore_installed - self.ignore_requires_python = ignore_requires_python - self.use_user_site = use_user_site - self._make_install_req = make_install_req - - self._discovered_dependencies = \ - defaultdict(list) # type: DiscoveredDependencies - - def resolve(self, requirement_set): - # type: (RequirementSet) -> None - """Resolve what operations need to be done - - As a side-effect of this method, the packages (and their dependencies) - are downloaded, unpacked and prepared for installation. This - preparation is done by ``pip.operations.prepare``. - - Once PyPI has static dependency metadata available, it would be - possible to move the preparation to become a step separated from - dependency resolution. - """ - # If any top-level requirement has a hash specified, enter - # hash-checking mode, which requires hashes from all. - root_reqs = ( - requirement_set.unnamed_requirements + - list(requirement_set.requirements.values()) - ) - - # Actually prepare the files, and collect any exceptions. Most hash - # exceptions cannot be checked ahead of time, because - # req.populate_link() needs to be called before we can make decisions - # based on link type. - discovered_reqs = [] # type: List[InstallRequirement] - hash_errors = HashErrors() - for req in chain(root_reqs, discovered_reqs): - try: - discovered_reqs.extend(self._resolve_one(requirement_set, req)) - except HashError as exc: - exc.req = req - hash_errors.append(exc) - - if hash_errors: - raise hash_errors - - def _is_upgrade_allowed(self, req): - # type: (InstallRequirement) -> bool - if self.upgrade_strategy == "to-satisfy-only": - return False - elif self.upgrade_strategy == "eager": - return True - else: - assert self.upgrade_strategy == "only-if-needed" - return req.is_direct - - def _set_req_to_reinstall(self, req): - # type: (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): - req.should_reinstall = True - req.satisfied_by = None - - def _check_skip_installed(self, req_to_install): - # type: (InstallRequirement) -> Optional[str] - """Check if req_to_install should be skipped. - - This will check if the req is installed, and whether we should upgrade - or reinstall it, taking into account all the relevant user options. - - After calling this req_to_install will only have satisfied_by set to - None if the req_to_install is to be upgraded/reinstalled etc. Any - other value will be a dist recording the current thing installed that - satisfies the requirement. - - Note that for vcs urls and the like we can't assess skipping in this - routine - we simply identify that we need to pull the thing down, - then later on it is pulled down and introspected to assess upgrade/ - reinstalls etc. - - :return: A text reason for why it was skipped, or None. - """ - if self.ignore_installed: - return None - - req_to_install.check_if_exists(self.use_user_site) - if not req_to_install.satisfied_by: - return None - - if self.force_reinstall: - self._set_req_to_reinstall(req_to_install) - return None - - if not self._is_upgrade_allowed(req_to_install): - if self.upgrade_strategy == "only-if-needed": - return 'already satisfied, skipping upgrade' - return 'already satisfied' - - # Check for the possibility of an upgrade. For link-based - # requirements we have to pull the tree down and inspect to assess - # the version #, so it's handled way down. - if not req_to_install.link: - try: - self.finder.find_requirement(req_to_install, upgrade=True) - except BestVersionAlreadyInstalled: - # Then the best version is installed. - return 'already up-to-date' - except DistributionNotFound: - # No distribution found, so we squash the error. It will - # be raised later when we re-try later to do the install. - # Why don't we just raise here? - pass - - self._set_req_to_reinstall(req_to_install) - return None - - def _get_abstract_dist_for(self, req): - # type: (InstallRequirement) -> AbstractDistribution - """Takes a InstallRequirement and returns a single AbstractDist \ - representing a prepared variant of the same. - """ - if req.editable: - return self.preparer.prepare_editable_requirement(req) - - # satisfied_by is only evaluated by calling _check_skip_installed, - # so it must be None here. - assert req.satisfied_by is None - skip_reason = self._check_skip_installed(req) - - if req.satisfied_by: - return self.preparer.prepare_installed_requirement( - req, skip_reason - ) - - upgrade_allowed = self._is_upgrade_allowed(req) - - # We eagerly populate the link, since that's our "legacy" behavior. - require_hashes = self.preparer.require_hashes - req.populate_link(self.finder, upgrade_allowed, require_hashes) - abstract_dist = self.preparer.prepare_linked_requirement(req) - - # NOTE - # The following portion is for determining if a certain package is - # going to be re-installed/upgraded or not and reporting to the user. - # This should probably get cleaned up in a future refactor. - - # req.req is only avail after unpack for URL - # pkgs repeat check_if_exists to uninstall-on-upgrade - # (#14) - if not self.ignore_installed: - req.check_if_exists(self.use_user_site) - - if req.satisfied_by: - should_modify = ( - self.upgrade_strategy != "to-satisfy-only" or - self.force_reinstall or - self.ignore_installed or - req.link.scheme == 'file' - ) - if should_modify: - self._set_req_to_reinstall(req) - else: - logger.info( - 'Requirement already satisfied (use --upgrade to upgrade):' - ' %s', req, - ) - - return abstract_dist - - def _resolve_one( - self, - requirement_set, # type: RequirementSet - req_to_install, # type: InstallRequirement - ): - # type: (...) -> List[InstallRequirement] - """Prepare a single requirements file. - - :return: A list of additional InstallRequirements to also install. - """ - # Tell user what we are doing for this requirement: - # obtain (editable), skipping, processing (local url), collecting - # (remote url or package name) - if req_to_install.constraint or req_to_install.prepared: - return [] - - req_to_install.prepared = True - - # register tmp src for cleanup in case something goes wrong - requirement_set.reqs_to_cleanup.append(req_to_install) - - abstract_dist = self._get_abstract_dist_for(req_to_install) - - # Parse and return dependencies - dist = abstract_dist.get_pkg_resources_distribution() - # This will raise UnsupportedPythonVersion if the given Python - # version isn't compatible with the distribution's Requires-Python. - _check_dist_requires_python( - dist, version_info=self._py_version_info, - ignore_requires_python=self.ignore_requires_python, - ) - - more_reqs = [] # type: List[InstallRequirement] - - def add_req(subreq, extras_requested): - 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( - sub_install_req, - parent_req_name=parent_req_name, - extras_requested=extras_requested, - ) - if parent_req_name and add_to_parent: - self._discovered_dependencies[parent_req_name].append( - add_to_parent - ) - more_reqs.extend(to_scan_again) - - with indent_log(): - # We add req_to_install before its dependencies, so that we - # can refer to it when adding dependencies. - if not requirement_set.has_requirement(req_to_install.name): - # 'unnamed' requirements will get added here - # 'unnamed' requirements can only come from being directly - # provided by the user. - assert req_to_install.is_direct - requirement_set.add_requirement( - req_to_install, parent_req_name=None, - ) - - if not self.ignore_dependencies: - if req_to_install.extras: - logger.debug( - "Installing extra requirements: %r", - ','.join(req_to_install.extras), - ) - missing_requested = sorted( - set(req_to_install.extras) - set(dist.extras) - ) - for missing in missing_requested: - logger.warning( - '%s does not provide the extra \'%s\'', - dist, missing - ) - - available_requested = sorted( - set(dist.extras) & set(req_to_install.extras) - ) - for subreq in dist.requires(available_requested): - add_req(subreq, extras_requested=available_requested) - - if not req_to_install.editable and not req_to_install.satisfied_by: - # XXX: --no-install leads this to report 'Successfully - # downloaded' for only non-editable reqs, even though we took - # action on them. - requirement_set.successfully_downloaded.append(req_to_install) - - return more_reqs - - def get_installation_order(self, req_set): - # type: (RequirementSet) -> List[InstallRequirement] - """Create the installation order. - - The installation order is topological - requirements are installed - before the requiring thing. We break cycles at an arbitrary point, - and make no other guarantees. - """ - # The current implementation, which we may change at any point - # 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] - - def schedule(req): - if req.satisfied_by or req in ordered_reqs: - return - if req.constraint: - return - ordered_reqs.add(req) - for dep in self._discovered_dependencies[req.name]: - schedule(dep) - order.append(req) - - for install_req in req_set.requirements.values(): - schedule(install_req) - return order diff --git a/venv/lib/python3.8/site-packages/pip/_internal/locations.py b/venv/lib/python3.8/site-packages/pip/_internal/locations.py deleted file mode 100644 index 0c11553..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/locations.py +++ /dev/null @@ -1,194 +0,0 @@ -"""Locations where we look for configs, install stuff, etc""" - -# The following comment should be removed at some point in the future. -# mypy: strict-optional=False - -from __future__ import absolute_import - -import os -import os.path -import platform -import site -import sys -import sysconfig -from distutils import sysconfig as distutils_sysconfig -from distutils.command.install import SCHEME_KEYS # type: ignore -from distutils.command.install import install as distutils_install_command - -from pip._internal.models.scheme import Scheme -from pip._internal.utils import appdirs -from pip._internal.utils.compat import WINDOWS -from pip._internal.utils.typing import MYPY_CHECK_RUNNING, cast -from pip._internal.utils.virtualenv import running_under_virtualenv - -if MYPY_CHECK_RUNNING: - from typing import Dict, List, Optional, Union - - from distutils.cmd import Command as DistutilsCommand - - -# Application Directories -USER_CACHE_DIR = appdirs.user_cache_dir("pip") - - -def get_major_minor_version(): - # type: () -> str - """ - Return the major-minor version of the current Python as a string, e.g. - "3.7" or "3.10". - """ - return '{}.{}'.format(*sys.version_info) - - -def get_src_prefix(): - # type: () -> str - if running_under_virtualenv(): - src_prefix = os.path.join(sys.prefix, 'src') - else: - # FIXME: keep src in cwd for now (it is not a temporary folder) - try: - src_prefix = os.path.join(os.getcwd(), 'src') - except OSError: - # In case the current working directory has been renamed or deleted - sys.exit( - "The folder you are executing pip from can no longer be found." - ) - - # under macOS + virtualenv sys.prefix is not properly resolved - # it is something like /path/to/python/bin/.. - return os.path.abspath(src_prefix) - - -# FIXME doesn't account for venv linked to global site-packages - -site_packages = sysconfig.get_path("purelib") # type: Optional[str] - -# This is because of a bug in PyPy's sysconfig module, see -# https://bitbucket.org/pypy/pypy/issues/2506/sysconfig-returns-incorrect-paths -# for more information. -if platform.python_implementation().lower() == "pypy": - site_packages = distutils_sysconfig.get_python_lib() -try: - # Use getusersitepackages if this is present, as it ensures that the - # value is initialised properly. - user_site = site.getusersitepackages() -except AttributeError: - user_site = site.USER_SITE - -if WINDOWS: - bin_py = os.path.join(sys.prefix, 'Scripts') - bin_user = os.path.join(user_site, 'Scripts') - # buildout uses 'bin' on Windows too? - if not os.path.exists(bin_py): - bin_py = os.path.join(sys.prefix, 'bin') - bin_user = os.path.join(user_site, 'bin') -else: - bin_py = os.path.join(sys.prefix, 'bin') - bin_user = os.path.join(user_site, 'bin') - - # 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/': - bin_py = '/usr/local/bin' - - -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] - """ - Return a distutils install scheme - """ - from distutils.dist import Distribution - - dist_args = {'name': dist_name} # type: Dict[str, Union[str, List[str]]] - if isolated: - dist_args["script_args"] = ["--no-user-cfg"] - - d = Distribution(dist_args) - d.parse_config_files() - obj = None # type: Optional[DistutilsCommand] - obj = d.get_command_obj('install', create=True) - assert obj is not None - i = cast(distutils_install_command, obj) - # NOTE: setting user or home has the side-effect of creating the home dir - # or user base for installations during finalize_options() - # ideally, we'd prefer a scheme class that has no side-effects. - assert not (user and prefix), "user={} prefix={}".format(user, prefix) - assert not (home and prefix), "home={} prefix={}".format(home, prefix) - i.user = user or i.user - if user or home: - i.prefix = "" - i.prefix = prefix or i.prefix - i.home = home or i.home - i.root = root or i.root - i.finalize_options() - - scheme = {} - for key in SCHEME_KEYS: - scheme[key] = getattr(i, 'install_' + key) - - # install_lib specified in setup.cfg should install *everything* - # into there (i.e. it takes precedence over both purelib and - # platlib). Note, i.install_lib is *always* set after - # finalize_options(); we only want to override here if the user - # has explicitly requested it hence going back to the config - if 'install_lib' in d.get_option_dict('install'): - scheme.update(dict(purelib=i.install_lib, platlib=i.install_lib)) - - if running_under_virtualenv(): - scheme['headers'] = os.path.join( - sys.prefix, - 'include', - 'site', - 'python{}'.format(get_major_minor_version()), - dist_name, - ) - - 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:], - ) - - 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 - """ - Get the "scheme" corresponding to the input parameters. The distutils - documentation provides the context for the available schemes: - https://docs.python.org/3/install/index.html#alternate-installation - - :param dist_name: the name of the package to retrieve the scheme for, used - in the headers scheme path - :param user: indicates to use the "user" scheme - :param home: indicates to use the "home" scheme and provides the base - directory for the same - :param root: root under which other directories are re-based - :param isolated: equivalent to --no-user-cfg, i.e. do not consider - ~/.pydistutils.cfg (posix) or ~/pydistutils.cfg (non-posix) for - scheme paths - :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 - ) - return Scheme( - platlib=scheme["platlib"], - purelib=scheme["purelib"], - headers=scheme["headers"], - scripts=scheme["scripts"], - data=scheme["data"], - ) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/main.py b/venv/lib/python3.8/site-packages/pip/_internal/main.py deleted file mode 100644 index 3208d5b..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/main.py +++ /dev/null @@ -1,16 +0,0 @@ -from pip._internal.utils.typing import MYPY_CHECK_RUNNING - -if MYPY_CHECK_RUNNING: - from typing import Optional, List - - -def main(args=None): - # type: (Optional[List[str]]) -> int - """This is preserved for old console scripts that may still be referencing - it. - - For additional details, see https://github.com/pypa/pip/issues/7498. - """ - from pip._internal.utils.entrypoints import _wrapper - - return _wrapper(args) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/models/__init__.py b/venv/lib/python3.8/site-packages/pip/_internal/models/__init__.py deleted file mode 100644 index 7855226..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/models/__init__.py +++ /dev/null @@ -1,2 +0,0 @@ -"""A package that contains models that represent entities. -""" diff --git a/venv/lib/python3.8/site-packages/pip/_internal/models/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/models/__pycache__/__init__.cpython-38.pyc deleted file mode 100644 index 40066fb255660d0150d4a0d42784ee278f79d084..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 224 zcmYjLF%E)25IkrkB>v$V3ktZ#D1}k^fQ_-Sxm>snT!iD~ju8BjU!wI1c2+LZILXXr zW|P^yESDicY&R=$!1WX_htov!l fxY7<+Vd^#hu9`JlQjLqMsCM{B3v1J;VU;LV(`$w1e=Hs9viF{(?#e39MWckFS2ufNZwuVyRz=rMZG<(YBAbXa{I+orSx_& z-Fg1Y?8g_l*N2==nM&w>Igv`+{*hQ&Ju_cGUNpM}K)jH4Xy|q57WMwyyRh~bvK7k_ z#UsmsegHNAv!?+h{RcGzJr}zD>$hs{rB~Kwz5Mc`dG&pAjOo=w)`akzrEnkVV7`PK z%-2VN7ovOy>VxxhFtcr=d5kjnYWDx9-?BLJd2hLhbdw`JlgrD$O70{R1)0~ zE#GcD%z&qxb8X(VY11)%>Pa_42& diff --git a/venv/lib/python3.8/site-packages/pip/_internal/models/__pycache__/format_control.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/models/__pycache__/format_control.cpython-38.pyc deleted file mode 100644 index 9de7f7a7a23ceb0617d807cae04e17212cffcb98..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2416 zcmaJ@TW=dh6rS0e*N&4mX=qDZ=pqWjP}_hiilTxlg*F9*si^u;OE7GACh;bFv1iv! ze|5v|KPsFrmMFNs{h=Wwl^$NhFc>^FyrGFb5Dc29_? z84foFU+>)7R%>k*Cb^J^MLSNph_ZHhVHT85Y4vvsmq94Z8C!(fOdUZCmpT;PaOmjb zj2Bx|;Xqw_+SL5m2};A5Y{C(nWDAjyRWOh&IERM;&UtCbd9VsQ&3i)X+mypO#dR1H z1IDgmp6N4;(eh~%l)zgCs7UB2lm_g>fCE~GmyZmP%Mg%DYETZGJu(rDT?h9+k5mEy zg~YU}xs9%myod>>IFfAAO@w#TM7Iu1=^y_hr_cHxvED5_8x`B}!8 za*e7m#!iHpYA2mG6_Qf)C1W4r#7rZFVIf!+wf=cKRHf)lzABTC&Hf9-nC!#!11gtt z%8gz62Xb`Z;N}6HpajR}mLq>38~f$~q44PO*W%UzKxb@n^nF`V+`dHqG`<0#U{^(6 zQyD(EHa5Q_zkWHf#uj(B3^|(W81UQ~Te}o1#(rg7YNPv*Q+fwn?QT>$hqO7m-E1al zv#buU?KPXKK&Eu6!N!wfFbt*0ye~XoZVY3Q8`v|(Hc1`fHbkvaElr$ zTIShynD?a0o5IfeQJ5EY5D8xvrq6j{hY1(YrOLsg!ow`^B}e$|XMQvkg#!f}B9|A` zvYCkO!crkT9j}W$z-1&@Jj{oF#KiL;8gh|+hF#gm7>HS;1~pz=_`3R6qsvF-r)UGc zMn^YhE8uLUGZmq3rTQv*wvK@#x;!^sPL>X3Amn>EyBa63a#(`~_7SxcF|rK)cQT{T)i(c!%hX1#aD{{OG+vP9qt z?W62vgRP}#gQ5ruv_Oz02>P*TArz60<;s#m(oSr6 zOMp!M56+ms#I;lZLYMYP+o%ha08j7k#N*w2{MzZX5v(__U!>1ngnk%jb3qKfhb<4l zFvM_yMmQlD9U(@TbAy<}oogp?xyxMEVBU93 zGEBo&Dzv#UEm>HLYLYW9L!QcLJH5( zHCd25gwY%@b(Fhk%<&x_df>rcG#Pk+eT#|3tvP{6n;~f3InkcXM|HuqTTkmedY~I} zTyr7JUD~HKFLOnycE+O60hl5`qn14FgD2}ESK2GNDymF(D1>Og67Yu_==QR*32NU| zw`jMY7o18}2_THJYLw<>jMb=)>%8uc%Noe$ zta~}&yy)iR^NWM&t4ouMpG97UcqD?8xHU45aJP2|WHv^kjb38&wmy1}K2XCJaAIa=q$o v$TPKkn(pcJ^jP~}ptM07v)L)lY}$Xfr0Nix0Uv=0ob7#r2_nBeXZigDX3s02 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/models/__pycache__/link.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/models/__pycache__/link.cpython-38.pyc deleted file mode 100644 index 5c49d785a16e04025296a8465f5f58a9371257c0..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6659 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 wewsMZ$DRTAvX9BVY2n>0g5RgI7Sku6f{s6@~ diff --git a/venv/lib/python3.8/site-packages/pip/_internal/models/__pycache__/scheme.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/models/__pycache__/scheme.cpython-38.pyc deleted file mode 100644 index 3e412e7b82cf6a3ec17f4f499349736a299c6d07..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 862 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 F{{TAePXPb` diff --git a/venv/lib/python3.8/site-packages/pip/_internal/models/candidate.py b/venv/lib/python3.8/site-packages/pip/_internal/models/candidate.py deleted file mode 100644 index 1dc1a57..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/models/candidate.py +++ /dev/null @@ -1,36 +0,0 @@ -from pip._vendor.packaging.version import parse as parse_version - -from pip._internal.utils.models import KeyBasedCompareMixin -from pip._internal.utils.typing import MYPY_CHECK_RUNNING - -if MYPY_CHECK_RUNNING: - from pip._vendor.packaging.version import _BaseVersion - from pip._internal.models.link import Link - - -class InstallationCandidate(KeyBasedCompareMixin): - """Represents a potential "candidate" for installation. - """ - - def __init__(self, name, version, link): - # type: (str, str, Link) -> None - self.name = name - self.version = parse_version(version) # type: _BaseVersion - self.link = link - - super(InstallationCandidate, self).__init__( - key=(self.name, self.version, self.link), - defining_class=InstallationCandidate - ) - - def __repr__(self): - # type: () -> str - return "".format( - self.name, self.version, self.link, - ) - - def __str__(self): - # type: () -> str - return '{!r} candidate (version {} at {})'.format( - self.name, self.version, self.link, - ) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/models/format_control.py b/venv/lib/python3.8/site-packages/pip/_internal/models/format_control.py deleted file mode 100644 index 2e13727..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/models/format_control.py +++ /dev/null @@ -1,84 +0,0 @@ -# The following comment should be removed at some point in the future. -# mypy: strict-optional=False - -from pip._vendor.packaging.utils import canonicalize_name - -from pip._internal.exceptions import CommandError -from pip._internal.utils.typing import MYPY_CHECK_RUNNING - -if MYPY_CHECK_RUNNING: - from typing import Optional, Set, FrozenSet - - -class FormatControl(object): - """Helper for managing formats from which a package can be installed. - """ - - def __init__(self, no_binary=None, only_binary=None): - # type: (Optional[Set[str]], Optional[Set[str]]) -> None - if no_binary is None: - no_binary = set() - if only_binary is None: - only_binary = set() - - self.no_binary = no_binary - self.only_binary = only_binary - - def __eq__(self, other): - # type: (object) -> bool - return self.__dict__ == other.__dict__ - - def __ne__(self, other): - # type: (object) -> bool - return not self.__eq__(other) - - def __repr__(self): - # type: () -> str - return "{}({}, {})".format( - self.__class__.__name__, - self.no_binary, - self.only_binary - ) - - @staticmethod - def handle_mutual_excludes(value, target, other): - # type: (str, Optional[Set[str]], Optional[Set[str]]) -> None - if value.startswith('-'): - raise CommandError( - "--no-binary / --only-binary option requires 1 argument." - ) - new = value.split(',') - while ':all:' in new: - other.clear() - target.clear() - 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: - return - for name in new: - 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] - result = {"binary", "source"} - if canonical_name in self.only_binary: - 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') - return frozenset(result) - - def disallow_binaries(self): - # type: () -> None - self.handle_mutual_excludes( - ':all:', self.no_binary, self.only_binary, - ) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/models/index.py b/venv/lib/python3.8/site-packages/pip/_internal/models/index.py deleted file mode 100644 index ead1efb..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/models/index.py +++ /dev/null @@ -1,31 +0,0 @@ -from pip._vendor.six.moves.urllib import parse as urllib_parse - - -class PackageIndex(object): - """Represents a Package Index and provides easier access to endpoints - """ - - def __init__(self, url, file_storage_domain): - # type: (str, str) -> None - super(PackageIndex, self).__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') - - # 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 - return urllib_parse.urljoin(self.url, path) - - -PyPI = PackageIndex( - 'https://pypi.org/', file_storage_domain='files.pythonhosted.org' -) -TestPyPI = PackageIndex( - 'https://test.pypi.org/', file_storage_domain='test-files.pythonhosted.org' -) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/models/link.py b/venv/lib/python3.8/site-packages/pip/_internal/models/link.py deleted file mode 100644 index 34fbcbf..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/models/link.py +++ /dev/null @@ -1,227 +0,0 @@ -import os -import posixpath -import re - -from pip._vendor.six.moves.urllib import parse as urllib_parse - -from pip._internal.utils.filetypes import WHEEL_EXTENSION -from pip._internal.utils.misc import ( - redact_auth_from_url, - split_auth_from_netloc, - splitext, -) -from pip._internal.utils.models import KeyBasedCompareMixin -from pip._internal.utils.typing import MYPY_CHECK_RUNNING -from pip._internal.utils.urls import path_to_url, url_to_path - -if MYPY_CHECK_RUNNING: - from typing import Optional, Text, Tuple, Union - from pip._internal.index.collector import HTMLPage - from pip._internal.utils.hashes import Hashes - - -class Link(KeyBasedCompareMixin): - """Represents a parsed link from a Package Index's simple URL - """ - - 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[Text] - ): - # type: (...) -> None - """ - :param url: url of the resource pointed to (href of the link) - :param comes_from: instance of HTMLPage 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 - a data-requires-python attribute in the HTML link tag, as - described in PEP 503. - :param yanked_reason: the reason the file has been yanked, if the - file has been yanked, or None if the file hasn't been yanked. - This is the value of the "data-yanked" attribute, if present, in - 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. - """ - - # url can be a UNC windows share - if url.startswith('\\\\'): - url = path_to_url(url) - - self._parsed_url = urllib_parse.urlsplit(url) - # Store the url as a private attribute to prevent accidentally - # trying to set a new value. - self._url = url - - self.comes_from = comes_from - self.requires_python = requires_python if requires_python else None - self.yanked_reason = yanked_reason - - super(Link, self).__init__(key=url, defining_class=Link) - - def __str__(self): - # type: () -> str - if self.requires_python: - rp = ' (requires-python:%s)' % self.requires_python - else: - rp = '' - if self.comes_from: - return '%s (from %s)%s' % (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 '' % self - - @property - def url(self): - # type: () -> str - return self._url - - @property - def filename(self): - # type: () -> str - path = self.path.rstrip('/') - name = posixpath.basename(path) - if not name: - # Make sure we don't leak auth information if the netloc - # includes a username and password. - netloc, user_pass = split_auth_from_netloc(self.netloc) - return netloc - - name = urllib_parse.unquote(name) - assert name, ('URL %r produced no filename' % self._url) - return name - - @property - def file_path(self): - # type: () -> str - return url_to_path(self.url) - - @property - def scheme(self): - # type: () -> str - return self._parsed_url.scheme - - @property - def netloc(self): - # type: () -> str - """ - This can contain auth information. - """ - return self._parsed_url.netloc - - @property - def path(self): - # type: () -> str - return urllib_parse.unquote(self._parsed_url.path) - - def splitext(self): - # type: () -> Tuple[str, str] - return splitext(posixpath.basename(self.path.rstrip('/'))) - - @property - def ext(self): - # type: () -> str - return self.splitext()[1] - - @property - def url_without_fragment(self): - # type: () -> str - scheme, netloc, path, query, fragment = self._parsed_url - return urllib_parse.urlunsplit((scheme, netloc, path, query, None)) - - _egg_fragment_re = re.compile(r'[#&]egg=([^&]*)') - - @property - def egg_fragment(self): - # type: () -> 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=([^&]*)') - - @property - def subdirectory_fragment(self): - # type: () -> 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]+)' - ) - - @property - def hash(self): - # type: () -> Optional[str] - match = self._hash_re.search(self._url) - if match: - return match.group(2) - return None - - @property - def hash_name(self): - # type: () -> Optional[str] - match = self._hash_re.search(self._url) - if match: - return match.group(1) - return None - - @property - def show_url(self): - # type: () -> 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_existing_dir(self): - # type: () -> bool - return self.is_file and os.path.isdir(self.file_path) - - @property - def is_wheel(self): - # type: () -> bool - return self.ext == WHEEL_EXTENSION - - @property - def is_vcs(self): - # type: () -> bool - from pip._internal.vcs import vcs - - return self.scheme in vcs.all_schemes - - @property - def is_yanked(self): - # type: () -> bool - return self.yanked_reason is not None - - @property - def has_hash(self): - # type: () -> bool - return self.hash_name is not None - - def is_hash_allowed(self, hashes): - # type: (Optional[Hashes]) -> bool - """ - Return True if the link has a hash and it is allowed. - """ - if hashes is None or not self.has_hash: - 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 hashes.is_hash_allowed(self.hash_name, hex_digest=self.hash) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/models/scheme.py b/venv/lib/python3.8/site-packages/pip/_internal/models/scheme.py deleted file mode 100644 index af07b40..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/models/scheme.py +++ /dev/null @@ -1,25 +0,0 @@ -""" -For types associated with installation schemes. - -For a general overview of available schemes and their context, see -https://docs.python.org/3/install/index.html#alternate-installation. -""" - - -class Scheme(object): - """A Scheme holds paths which are used as the base directories for - artifacts associated with a Python package. - """ - def __init__( - self, - platlib, # type: str - purelib, # type: str - headers, # type: str - scripts, # type: str - data, # type: str - ): - self.platlib = platlib - self.purelib = purelib - self.headers = headers - self.scripts = scripts - self.data = data diff --git a/venv/lib/python3.8/site-packages/pip/_internal/models/search_scope.py b/venv/lib/python3.8/site-packages/pip/_internal/models/search_scope.py deleted file mode 100644 index 138d1b6..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/models/search_scope.py +++ /dev/null @@ -1,114 +0,0 @@ -import itertools -import logging -import os -import posixpath - -from pip._vendor.packaging.utils import canonicalize_name -from pip._vendor.six.moves.urllib import parse as urllib_parse - -from pip._internal.models.index import PyPI -from pip._internal.utils.compat import has_tls -from pip._internal.utils.misc import normalize_path, redact_auth_from_url -from pip._internal.utils.typing import MYPY_CHECK_RUNNING - -if MYPY_CHECK_RUNNING: - from typing import List - - -logger = logging.getLogger(__name__) - - -class SearchScope(object): - - """ - Encapsulates the locations that pip is configured to search. - """ - - @classmethod - def create( - cls, - find_links, # type: List[str] - index_urls, # type: List[str] - ): - # type: (...) -> SearchScope - """ - Create a SearchScope object after normalizing the `find_links`. - """ - # Build find_links. If an argument starts with ~, it may be - # a local file relative to a home directory. So try normalizing - # 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] - for link in find_links: - if link.startswith('~'): - new_link = normalize_path(link) - if os.path.exists(new_link): - link = new_link - built_find_links.append(link) - - # If we don't have TLS enabled, then WARN if anyplace we're looking - # relies on TLS. - if not has_tls(): - for link in itertools.chain(index_urls, built_find_links): - parsed = urllib_parse.urlparse(link) - if parsed.scheme == 'https': - logger.warning( - '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, - ) - - def __init__( - self, - find_links, # type: List[str] - index_urls, # type: List[str] - ): - # type: (...) -> None - self.find_links = find_links - self.index_urls = index_urls - - def get_formatted_locations(self): - # type: () -> str - lines = [] - if self.index_urls and self.index_urls != [PyPI.simple_url]: - lines.append( - 'Looking in indexes: {}'.format(', '.join( - redact_auth_from_url(url) for url in self.index_urls)) - ) - if self.find_links: - lines.append( - 'Looking in links: {}'.format(', '.join( - redact_auth_from_url(url) for url in self.find_links)) - ) - return '\n'.join(lines) - - def get_index_urls_locations(self, project_name): - # type: (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 - loc = posixpath.join( - 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 + '/' - return loc - - return [mkurl_pypi_url(url) for url in self.index_urls] diff --git a/venv/lib/python3.8/site-packages/pip/_internal/models/selection_prefs.py b/venv/lib/python3.8/site-packages/pip/_internal/models/selection_prefs.py deleted file mode 100644 index f58fdce..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/models/selection_prefs.py +++ /dev/null @@ -1,47 +0,0 @@ -from pip._internal.utils.typing import MYPY_CHECK_RUNNING - -if MYPY_CHECK_RUNNING: - from typing import Optional - from pip._internal.models.format_control import FormatControl - - -class SelectionPreferences(object): - - """ - Encapsulates the candidate selection preferences for downloading - and installing files. - """ - - # Don't include an allow_yanked default value to make sure each call - # site considers whether yanked releases are allowed. This also causes - # that decision to be made explicit in the calling code, which helps - # 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 - """Create a SelectionPreferences object. - - :param allow_yanked: Whether files marked as yanked (in the sense - of PEP 592) are permitted to be candidates for install. - :param format_control: A FormatControl object or None. Used to control - the selection of source packages / binary packages when consulting - the index and links. - :param prefer_binary: Whether to prefer an old, but valid, binary - dist over a new source dist. - :param ignore_requires_python: Whether to ignore incompatible - "Requires-Python" values in links. Defaults to False. - """ - if ignore_requires_python is None: - ignore_requires_python = False - - self.allow_yanked = allow_yanked - self.allow_all_prereleases = allow_all_prereleases - self.format_control = format_control - self.prefer_binary = prefer_binary - self.ignore_requires_python = ignore_requires_python diff --git a/venv/lib/python3.8/site-packages/pip/_internal/models/target_python.py b/venv/lib/python3.8/site-packages/pip/_internal/models/target_python.py deleted file mode 100644 index 97ae85a..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/models/target_python.py +++ /dev/null @@ -1,107 +0,0 @@ -import sys - -from pip._internal.pep425tags import get_supported, version_info_to_nodot -from pip._internal.utils.misc import normalize_version_info -from pip._internal.utils.typing import MYPY_CHECK_RUNNING - -if MYPY_CHECK_RUNNING: - from typing import List, Optional, Tuple - - from pip._vendor.packaging.tags import Tag - - -class TargetPython(object): - - """ - Encapsulates the properties of a Python interpreter one is targeting - for a package install, download, etc. - """ - - def __init__( - self, - platform=None, # type: Optional[str] - py_version_info=None, # type: Optional[Tuple[int, ...]] - abi=None, # type: Optional[str] - implementation=None, # type: Optional[str] - ): - # type: (...) -> None - """ - :param platform: A string or None. If None, searches for packages - that are supported by the current system. Otherwise, will find - packages that can be built on the platform passed in. These - packages will only be downloaded for distribution: they will - not be built locally. - :param py_version_info: An optional tuple of ints representing the - Python version information to use (e.g. `sys.version_info[:3]`). - This can have length 1, 2, or 3 when provided. - :param abi: A string or None. This is passed to pep425tags.py's - get_supported() function as is. - :param implementation: A string or None. This is passed to - pep425tags.py's get_supported() function as is. - """ - # Store the given py_version_info for when we call get_supported(). - self._given_py_version_info = py_version_info - - if py_version_info is None: - py_version_info = sys.version_info[:3] - else: - py_version_info = normalize_version_info(py_version_info) - - py_version = '.'.join(map(str, py_version_info[:2])) - - self.abi = abi - self.implementation = implementation - self.platform = platform - self.py_version = py_version - 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]] - - def format_given(self): - # type: () -> str - """ - Format the given, non-None attributes for display. - """ - display_version = None - if self._given_py_version_info is not None: - display_version = '.'.join( - str(part) for part in self._given_py_version_info - ) - - key_values = [ - ('platform', self.platform), - ('version_info', display_version), - ('abi', self.abi), - ('implementation', self.implementation), - ] - return ' '.join( - '{}={!r}'.format(key, value) for key, value in key_values - if value is not None - ) - - def get_tags(self): - # type: () -> List[Tag] - """ - Return the supported PEP 425 tags to check wheel candidates against. - - The tags are returned in order of preference (most preferred first). - """ - if self._valid_tags is None: - # Pass versions=None if no py_version_info was given since - # versions=None uses special default logic. - py_version_info = self._given_py_version_info - if py_version_info is None: - version = None - else: - version = version_info_to_nodot(py_version_info) - - tags = get_supported( - version=version, - platform=self.platform, - abi=self.abi, - impl=self.implementation, - ) - self._valid_tags = tags - - return self._valid_tags diff --git a/venv/lib/python3.8/site-packages/pip/_internal/models/wheel.py b/venv/lib/python3.8/site-packages/pip/_internal/models/wheel.py deleted file mode 100644 index f1e3f44..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/models/wheel.py +++ /dev/null @@ -1,78 +0,0 @@ -"""Represents a wheel file and provides access to the various parts of the -name that have meaning. -""" -import re - -from pip._vendor.packaging.tags import Tag - -from pip._internal.exceptions import InvalidWheelFilename -from pip._internal.utils.typing import MYPY_CHECK_RUNNING - -if MYPY_CHECK_RUNNING: - from typing import List - - -class Wheel(object): - """A wheel file""" - - wheel_file_re = re.compile( - r"""^(?P(?P.+?)-(?P.*?)) - ((-(?P\d[^-]*?))?-(?P.+?)-(?P.+?)-(?P.+?) - \.whl|\.dist-info)$""", - re.VERBOSE - ) - - def __init__(self, filename): - # type: (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( - "%s is not a valid wheel filename." % filename - ) - self.filename = filename - 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('.') - - # 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 - } - - def get_formatted_file_tags(self): - # type: () -> 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 - """Return the lowest index that one of the wheel's file_tag combinations - achieves in the given list of supported tags. - - For example, if there are 8 supported tags and one of the file tags - is first in the list, then return 0. - - :param tags: the PEP 425 tags to check the wheel against, in order - with most preferred first. - - :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 supported(self, tags): - # type: (List[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. - """ - return not self.file_tags.isdisjoint(tags) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/network/__init__.py b/venv/lib/python3.8/site-packages/pip/_internal/network/__init__.py deleted file mode 100644 index b51bde9..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/network/__init__.py +++ /dev/null @@ -1,2 +0,0 @@ -"""Contains purely network-related utilities. -""" diff --git a/venv/lib/python3.8/site-packages/pip/_internal/network/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/network/__pycache__/__init__.cpython-38.pyc deleted file mode 100644 index c9932b2669d353eca66eedb4165109569f6849bb..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 212 zcmWIL<>g`k0&_FfL?a;m7{oyaj6jY95EpX*i4=w?h7`tN22G|aZRh;FlElosVugaz zqSTy9g}l^~^8BJ~T_7j1BsE2$v?Mbpvm`UMSdYt3lkpaNe0)lNa(w(sh9V}QNnqla zlYU8Vfqp?|fo^GDL1J=tYKm@oMrvw~Zf0qEp+%)hIY>@FJ~OW*wJ0w!M;~g3emqbp bvm`!Vub}c4hfQvNN@-529mu7hftUdRcgs4V diff --git a/venv/lib/python3.8/site-packages/pip/_internal/network/__pycache__/auth.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/network/__pycache__/auth.cpython-38.pyc deleted file mode 100644 index c0f0bc50d517d104d0c048d033f4a24ef6216063..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6978 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 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/network/__pycache__/download.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/network/__pycache__/download.cpython-38.pyc deleted file mode 100644 index 833736f6f0c03abadce2a787c1232a7589821f68..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4370 zcmbVPO>^7E8D1wNt(2iNz*!t?bxAJORi&1I~bT)QIPP# zES8qVkUm5?wtt}0gEZ|WxAfXm5B(K;?J4~UnQ7DKU67K$aw#}?_ubuh7rW2<$-7fi zHHPQipIr>qB4hue&XbRW&WCu53l?J$Yq7|Rcw)6I)AANKt=+Os>$DuSc2Y^*mTQr$ zlT=f$0)a!U1}|v`8vLLwsqFxwUNg>Ez|~eCs^c@xxby ze`K{@jb@_RuUP9sG#AaIeJwf_EueipdMP@M_F{A06vnXzdDwoA- z?OOu6*|4-H#pgXyr~>@_)!WU@wdQ7U_4?iB&0yn3YYn5$`u_S2v{P{rY{@(g+F^TJ zU|b<}pFqU|_Sy1FewoV3uj--by~tVx+m?cEgnB{#9T z-z^8}q=etsOrF6ZzWenRm3FUmxS)J5v}ZP3z4kEz0T+F?Z3T8b5{a{gVd{|Kvv|4Ve z+Tmox2bCjkv8---cG&}8KVoWXXL{F>DsqNyc4@TgOVe8(*u@{B3dZLLcH~0pPp0S4 zteP1xHG9B^)qz`lGpKGbH8ss|Rl!E5%bUkv>>zZf?9Gk1$P>-ffSBmZL2 zpB|eS4PPui-i$x|Gh@(+oraGZ^9CR70^=laONvAK6nRuoz8jWECAr7;87lI~^gl6K7kwo`cfXwzfoD#Sg_T@lYhX zN&+~Vc5XC3zAar^N!pT=APrBRrd^x_hOX;l_YNL}QrA_k!XzkdQrmR0n)z5{PB~@H zJ6@sP(r=9cmIPs#>A9dQMK_dm%`%)cFkHL`!d#EnEswk0q8t5=4>?@PK19kovWCvUk*_P; zxDWX5r2*ZU_Ycf**F#zSzZbsjhgoEHkwW!kW^jwdR@h6F$q59XA8(m)#0VOW3tyyN zwO@iIe~fcC9BsEdF^r4O5|m(S8-{8wjbL|b3`}$ax}F_<=@>0t2^0dJcCk;G7H03~ zur9yxg8hDvlN6>zaHp-B<=CDje~z)|Fem>ocJw6}1Sd9x9g#H|w1KL$bF74zLkFjSJGSyvMK33k&#GymIqvKuV<6~(` z#Fc)2O(>|sN7f3H6X1=(k|}rK>Y0Cib93DvN9xP|R+zx0JN^TNe_!QBjU-HdezFIY zm*tAGI_1Qu)LMV6kCi9%@hzpgetm@OiqQmX)JiSPV@|$Jgdmj@AbKK=Q$b>dp6Q?{ zC<3Hukx>ejZ<5pskyVgJ#l#?akp{?Oe!eHoylwa-vFXMJ`f}8nhGUlXoTewKFa)01m5{Fcaz9C@_q%0VitsP zLV_>27XP=q2t=-7tW6V7J`{~U#9J(Y2!>Lbm1Q!DNIRlCJK7uPzBXYveu$^l#*Zk! z3=p{j2D@f~1>a!-rvm6}tBG)mqOq*}O5MK&act}qBH5CkpmQ?(tTlK6N|;y$!CxU( zkmItdi?q?78=q=*EYYO11_4E^AkeiSNb{(N931F+5PaSXlX6Dhq7R-RX*kMb@;b<0 z@S1oH#Hjznh%ICGdBh?I$iaeuoU3c&GYa`s@nmD^F?OV^C$S^c(t3vjuCs#L5}O(Evy~axdV&B;60YT zM|CbLyPCXiv7v3T{-SaYD-qPa<09Z$M;QB(-DB^d>K)pT?axpJXZ$mUI*+4PhkthO3;W4!V=bWy@hPtXEWAxoe7URxrK zx5LC(lb$U73CS3xHEGd=15;DTJLtk24SXgVncBz_&mc&ag#D5r_&XL9r0lX7HeSVC zs#EL*s#p+h>i>BL-g0FVQSVc%lT9MGi5T0vN8E|RP7H7z6W`!9TJtP#Lefa%EnN-Z z;O!ug6u9JTMBXPt@l{Wv&|eLZAEI2A@SJ;MWOe+1Z58eylET!5`mB){|2Y^O=# zcvP0JRqkj*pZTc%$7NtKR(Ni%#LXN5zpZ09ZA+{zbPWqv}Wn)HRbJBDL2X)nt%D}`SA_M0hruUPrwLoncBNl zq>n*U>zB4f1znjADcu+&)o%V^2c>ywcBH-+Xlm%-@+$|D7(RR^`P`5~{>>BVoM YLOj*YW`x&l&+{(ho$(gES7xXF2LOms%>V!Z diff --git a/venv/lib/python3.8/site-packages/pip/_internal/network/__pycache__/session.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/network/__pycache__/session.cpython-38.pyc deleted file mode 100644 index b8482c87ca1eef50f34132001ab3d04b669d80d5..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 8851 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 HhphhvF9cbD diff --git a/venv/lib/python3.8/site-packages/pip/_internal/network/__pycache__/utils.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/network/__pycache__/utils.cpython-38.pyc deleted file mode 100644 index 6f66cdff79c226c6c0ddbc242644531f4d83ef52..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 706 zcmYjO%Wl&^6rCA6iLuhO$^xXa@rH$^#$kb=i;7nWB~%#HCO|A9%k>P68^1C$Zj>nO z*zymsLj2Nf*}yNb;!c`Kz0$q%xpRE(YqYatBd|vg??pcw2>sUJrWpX9f{P;v6j7X_ z3ao(+P&vQC*Oi(D`ltM;4myD>cWdne)P$oB{SF=VZQWIU1ukBQdVm~PJkkHN(d z!qQoxOLU1>m|{x4kr(Kb{e`T^dxX)f{Q>2ki6oiY+{ci?NVC5iEBpg%mUupUz2V*; zqnvz%fuMDBd3c;$vD}Fq&Sn)8QaIa&51f)0R|#c~oG^z*GIHWcl~09dJ76!N^%iAu zL0K3Vxn#NYT~ir6nyb2yoJE;xJ(H3r=apoA&I_(g$Wqr(7T+vI*=xyABul1h>+fHP zw_x0VPr5QIyJb>#s=SQiDWjeFgt4@fR2Q?u#e=zi>xKzb=6RHMb0+5npLQ#mq{1r~ zYIj>Cyl(rJ-sEiv$RwnW$sO{?-f!ZT(ZnVunD4=h?^^0E=z1Y6g%;e~ZpF)B&Qx%H zBCcs-DRzg0;pqRpqk%`Kzk_elUm$jL$y3pMK#J@&_7s2Lodd zrak~6NJ0b^PC*k2|8C)wZsJn(v4WLe;&r-L_+^lUlt{XaWW1tD?`tA_5j-U#klwWa zvzrWr^O%gn`MvA1P)%0kC*wnvR=TN`8RlhE$Wm4&HF;gdf5O#de?)Dl>G1eDn2-MhdU%QK;~xHhPBGhMebBZaBC7 znJR!`-Z5lDu-2NdvkCBQ1HMs0uGe5ko@H7Vr#8wfA+I@XvB72yj?t2DVyCUZ+2!?lV;~q>|9NxEOzqQ*~NpKkFRiT7vLGGsrIObKDIs`%J7L930=WqT$G2`1;W=P=ez@o<4k@*`aEt!&*wvK=z7Ua}l zcm~P!fKY$_0E;@OivXhBDQo@KZ3C>1U)dsT!=<+(l(eiPoh*YkoQ5m<1c+zEMAP^@ zR=-fPh$xxAW_ruM@Y-lPm~OTH3Yz05@`QW>cP^qIqa*SIshlIQAZh;oy#KHU3M#X6 zc+<#vXymm)4h~1IWk7IhgNaOqRNDI5D4CY?cfL71JQzx)YBjvChgXxlki#=+OkSOV zWAuXR!D|(=W@E@2@(*pH`siRyt&M$Ar8y+6LPDYlQcHh1XiYsL#%%vSFrjlV@pxeYx4tTc60YTF6nX2HmX_yfv7ll_+3af78VL zq!u^ob&SB)HQKs>SG^1l^)7l{d7X9Tv=-aw3pShI2BYg}Lbstb94HQu#QDc}Lh3`g zY*PkapE!RrHh<$eWwSX5J}Zy#=VQB6X(^#yV$RE2%nH=|oL|h+VzUx(F6xZ)t~}NI z2o>x7jzE+OD-jh9UsMuO#$vzojkeTB;IRQR2nn-2XoE4ol$EGe$8++^9nV1VWhi|(asSnVJWGRHwfw%*t<8 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/network/auth.py b/venv/lib/python3.8/site-packages/pip/_internal/network/auth.py deleted file mode 100644 index 1e1da54..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/network/auth.py +++ /dev/null @@ -1,298 +0,0 @@ -"""Network Authentication Helpers - -Contains interface (MultiDomainBasicAuth) and associated glue code for -providing credentials in the context of network requests. -""" - -# The following comment should be removed at some point in the future. -# mypy: disallow-untyped-defs=False - -import logging - -from pip._vendor.requests.auth import AuthBase, HTTPBasicAuth -from pip._vendor.requests.utils import get_netrc_auth -from pip._vendor.six.moves.urllib import parse as urllib_parse - -from pip._internal.utils.misc import ( - ask, - ask_input, - ask_password, - remove_auth_from_url, - split_auth_netloc_from_url, -) -from pip._internal.utils.typing import MYPY_CHECK_RUNNING - -if MYPY_CHECK_RUNNING: - from optparse import Values - from typing import Dict, Optional, Tuple - - from pip._internal.vcs.versioncontrol import AuthInfo - - Credentials = Tuple[str, str, str] - -logger = logging.getLogger(__name__) - -try: - import keyring # noqa -except ImportError: - keyring = None -except Exception as exc: - logger.warning( - "Keyring is skipped due to an exception: %s", str(exc), - ) - keyring = None - - -def get_keyring_auth(url, username): - """Return the tuple auth for a given url from keyring.""" - if not url or not keyring: - return None - - try: - try: - get_credential = keyring.get_credential - except AttributeError: - pass - else: - logger.debug("Getting credentials from keyring for %s", url) - cred = get_credential(url, username) - if cred is not None: - return cred.username, cred.password - return None - - if username: - logger.debug("Getting password from keyring for %s", url) - password = keyring.get_password(url, username) - if password: - return username, password - - except Exception as exc: - logger.warning( - "Keyring is skipped due to an exception: %s", str(exc), - ) - - -class MultiDomainBasicAuth(AuthBase): - - def __init__(self, prompting=True, index_urls=None): - # type: (bool, Optional[Values]) -> None - self.prompting = prompting - self.index_urls = index_urls - self.passwords = {} # type: 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] - - def _get_index_url(self, url): - """Return the original index URL matching the requested URL. - - Cached or dynamically generated credentials may work against - the original index URL rather than just the netloc. - - The provided url should have had its username and password - removed already. If the original index url had credentials then - they will be included in the return value. - - Returns None if no matching index was found, or if --no-index - was specified by the user. - """ - 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 - - def _get_new_credentials(self, original_url, allow_netrc=True, - allow_keyring=True): - """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( - original_url, - ) - - # Start with the credentials embedded in the url - username, password = url_user_password - if username is not None and password is not None: - logger.debug("Found credentials in url for %s", netloc) - return url_user_password - - # Find a matching index url for this request - index_url = self._get_index_url(url) - if index_url: - # Split the credentials from the url. - index_info = split_auth_netloc_from_url(index_url) - if index_info: - index_url, _, index_url_user_password = index_info - logger.debug("Found index url %s", index_url) - - # If an index URL was found, try its embedded credentials - if index_url and index_url_user_password[0] is not None: - username, password = index_url_user_password - if username is not None and password is not None: - logger.debug("Found credentials in index url for %s", netloc) - return index_url_user_password - - # Get creds from netrc if we still don't have them - if allow_netrc: - netrc_auth = get_netrc_auth(original_url) - if netrc_auth: - logger.debug("Found credentials in netrc for %s", netloc) - return netrc_auth - - # 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 - kr_auth = ( - get_keyring_auth(index_url, username) or - get_keyring_auth(netloc, username) - ) - 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): - """Return the credentials to use for the provided URL. - - If allowed, netrc and keyring may be used to obtain the - correct credentials. - - Returns (url_without_credentials, username, password). Note - that even if the original URL contains credentials, this - function may return a different username and password. - """ - 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)) - - 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 username is not None or password is not None: - # Convert the username and password if they're None, so that - # this netloc will show up as "cached" in the conditional above. - # Further, HTTPBasicAuth doesn't accept None, so it makes sense to - # cache the value that is going to be used. - username = username or "" - password = password or "" - - # Store any acquired credentials. - self.passwords[netloc] = (username, password) - - assert ( - # Credentials were found - (username is not None and password is not None) or - # Credentials were not found - (username is None and password is None) - ), "Could not load credentials from url: {}".format(original_url) - - return url, username, password - - def __call__(self, req): - # Get credentials for this request - url, username, password = self._get_url_and_credentials(req.url) - - # Set the url of the request to the url without any credentials - req.url = url - - if username is not None and password is not None: - # Send the basic auth with this request - req = HTTPBasicAuth(username, password)(req) - - # Attach a hook to handle 401 responses - req.register_hook("response", self.handle_401) - - return req - - # Factored out to allow for easy patching in tests - def _prompt_for_password(self, netloc): - username = ask_input("User for %s: " % netloc) - if not username: - return None, None - auth = get_keyring_auth(netloc, username) - if auth: - 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): - if not keyring: - return False - return ask("Save credentials to keyring [y/N]: ", ["y", "n"]) == "y" - - def handle_401(self, resp, **kwargs): - # We only care about 401 responses, anything else we want to just - # pass through the actual response - if resp.status_code != 401: - return resp - - # We are not able to prompt the user so simply return the response - if not self.prompting: - return resp - - parsed = urllib_parse.urlparse(resp.url) - - # Prompt the user for a new username and password - username, password, save = self._prompt_for_password(parsed.netloc) - - # Store the new username and password to use for future requests - self._credentials_to_save = None - if username is not None and password is not None: - self.passwords[parsed.netloc] = (username, password) - - # Prompt to save the password to keyring - if save and self._should_save_password_to_keyring(): - self._credentials_to_save = (parsed.netloc, username, password) - - # Consume content and release the original connection to allow our new - # request to reuse the same one. - resp.content - resp.raw.release_conn() - - # Add our new username and password to the request - req = HTTPBasicAuth(username or "", password or "")(resp.request) - req.register_hook("response", self.warn_on_401) - - # On successful request, save the credentials that were used to - # keyring. (Note that if the user responded "no" above, this member - # is not set and nothing will be saved.) - if self._credentials_to_save: - req.register_hook("response", self.save_credentials) - - # Send our new request - new_resp = resp.connection.send(req, **kwargs) - new_resp.history.append(resp) - - return new_resp - - def warn_on_401(self, resp, **kwargs): - """Response callback to warn about incorrect credentials.""" - if resp.status_code == 401: - logger.warning( - '401 Error, Credentials not correct for %s', resp.request.url, - ) - - def save_credentials(self, resp, **kwargs): - """Response callback to save credentials on success.""" - assert keyring is not None, "should never reach here without keyring" - if not keyring: - return - - 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) - except Exception: - logger.exception('Failed to save credentials') diff --git a/venv/lib/python3.8/site-packages/pip/_internal/network/cache.py b/venv/lib/python3.8/site-packages/pip/_internal/network/cache.py deleted file mode 100644 index c9386e1..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/network/cache.py +++ /dev/null @@ -1,81 +0,0 @@ -"""HTTP cache implementation. -""" - -# The following comment should be removed at some point in the future. -# mypy: disallow-untyped-defs=False - -import os -from contextlib import contextmanager - -from pip._vendor.cachecontrol.cache import BaseCache -from pip._vendor.cachecontrol.caches import FileCache -from pip._vendor.requests.models import Response - -from pip._internal.utils.filesystem import adjacent_tmp_file, replace -from pip._internal.utils.misc import ensure_dir -from pip._internal.utils.typing import MYPY_CHECK_RUNNING - -if MYPY_CHECK_RUNNING: - from typing import Optional - - -def is_from_cache(response): - # type: (Response) -> bool - return getattr(response, "from_cache", False) - - -@contextmanager -def suppressed_cache_errors(): - """If we can't access the cache then we can just skip caching and process - requests as if caching wasn't enabled. - """ - try: - yield - except (OSError, IOError): - pass - - -class SafeFileCache(BaseCache): - """ - A file based cache which is safe to use even when the target directory may - not be accessible or writable. - """ - - def __init__(self, directory): - # type: (str) -> None - assert directory is not None, "Cache directory must not be None." - super(SafeFileCache, self).__init__() - self.directory = directory - - def _get_cache_path(self, name): - # type: (str) -> str - # From cachecontrol.caches.file_cache.FileCache._fn, brought into our - # class for backwards-compatibility and to avoid using a non-public - # method. - hashed = FileCache.encode(name) - parts = list(hashed[:5]) + [hashed] - return os.path.join(self.directory, *parts) - - def get(self, key): - # type: (str) -> Optional[bytes] - path = self._get_cache_path(key) - with suppressed_cache_errors(): - with open(path, 'rb') as f: - return f.read() - - def set(self, key, value): - # type: (str, bytes) -> None - path = self._get_cache_path(key) - with suppressed_cache_errors(): - ensure_dir(os.path.dirname(path)) - - with adjacent_tmp_file(path) as f: - f.write(value) - - replace(f.name, path) - - def delete(self, key): - # type: (str) -> None - path = self._get_cache_path(key) - with suppressed_cache_errors(): - os.remove(path) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/network/download.py b/venv/lib/python3.8/site-packages/pip/_internal/network/download.py deleted file mode 100644 index c90c4bf..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/network/download.py +++ /dev/null @@ -1,200 +0,0 @@ -"""Download files with progress indicators. -""" -import cgi -import logging -import mimetypes -import os - -from pip._vendor import requests -from pip._vendor.requests.models import CONTENT_CHUNK_SIZE - -from pip._internal.models.index import PyPI -from pip._internal.network.cache import is_from_cache -from pip._internal.network.utils import response_chunks -from pip._internal.utils.misc import ( - format_size, - redact_auth_from_url, - splitext, -) -from pip._internal.utils.typing import MYPY_CHECK_RUNNING -from pip._internal.utils.ui import DownloadProgressProvider - -if MYPY_CHECK_RUNNING: - from typing import Iterable, Optional - - from pip._vendor.requests.models import Response - - from pip._internal.models.link import Link - from pip._internal.network.session import PipSession - -logger = logging.getLogger(__name__) - - -def _get_http_response_size(resp): - # type: (Response) -> Optional[int] - try: - 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] - total_length = _get_http_response_size(resp) - - if link.netloc == PyPI.file_storage_domain: - url = link.show_url - else: - url = link.url_without_fragment - - logged_url = redact_auth_from_url(url) - - if total_length: - logged_url = '{} ({})'.format(logged_url, format_size(total_length)) - - if is_from_cache(resp): - logger.info("Using cached %s", logged_url) - else: - logger.info("Downloading %s", logged_url) - - if logger.getEffectiveLevel() > logging.INFO: - show_progress = False - elif is_from_cache(resp): - show_progress = False - elif not total_length: - show_progress = True - elif total_length > (40 * 1000): - show_progress = True - else: - show_progress = False - - chunks = response_chunks(resp, CONTENT_CHUNK_SIZE) - - if not show_progress: - return chunks - - return DownloadProgressProvider( - progress_bar, max=total_length - )(chunks) - - -def sanitize_content_filename(filename): - # type: (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 - """ - 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') - if filename: - # We need to sanitize the filename to prevent directory traversal - # in case the filename contains ".." path parts. - filename = sanitize_content_filename(filename) - return filename or default_filename - - -def _get_http_response_filename(resp, link): - # type: (Response, 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') - if content_disposition: - filename = parse_content_disposition(content_disposition, filename) - ext = splitext(filename)[1] # type: Optional[str] - if not ext: - ext = mimetypes.guess_extension( - resp.headers.get('content-type', '') - ) - if ext: - filename += ext - if not ext and link.url != resp.url: - ext = os.path.splitext(resp.url)[1] - if ext: - filename += ext - return filename - - -def _http_get_download(session, link): - # type: (PipSession, Link) -> Response - target_url = link.url.split('#', 1)[0] - resp = session.get( - target_url, - # We use Accept-Encoding: identity here because requests - # defaults to accepting compressed responses. This breaks in - # a variety of ways depending on how the server is configured. - # - Some servers will notice that the file isn't a compressible - # file and will leave the file alone and with an empty - # Content-Encoding - # - Some servers will notice that the file is already - # compressed and will leave the file alone and will add a - # Content-Encoding: gzip header - # - Some servers won't notice anything at all and will take - # a file that's already been compressed and compress it again - # and set the Content-Encoding: gzip header - # By setting this to request only the identity encoding We're - # hoping to eliminate the third case. Hopefully there does not - # exist a server which when given a file will notice it is - # already compressed and that 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"}, - stream=True, - ) - resp.raise_for_status() - return resp - - -class Download(object): - def __init__( - self, - response, # type: Response - filename, # type: str - chunks, # type: Iterable[bytes] - ): - # type: (...) -> None - self.response = response - self.filename = filename - self.chunks = chunks - - -class Downloader(object): - def __init__( - self, - session, # type: PipSession - progress_bar, # type: str - ): - # type: (...) -> None - self._session = session - self._progress_bar = progress_bar - - def __call__(self, link): - # type: (Link) -> Download - try: - resp = _http_get_download(self._session, link) - except requests.HTTPError as e: - logger.critical( - "HTTP error %s while getting %s", e.response.status_code, link - ) - raise - - return Download( - resp, - _get_http_response_filename(resp, link), - _prepare_download(resp, link, self._progress_bar), - ) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/network/session.py b/venv/lib/python3.8/site-packages/pip/_internal/network/session.py deleted file mode 100644 index f5eb15e..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/network/session.py +++ /dev/null @@ -1,405 +0,0 @@ -"""PipSession and supporting code, containing all pip-specific -network request configuration and behavior. -""" - -# The following comment should be removed at some point in the future. -# mypy: disallow-untyped-defs=False - -import email.utils -import json -import logging -import mimetypes -import os -import platform -import sys -import warnings - -from pip._vendor import requests, six, urllib3 -from pip._vendor.cachecontrol import CacheControlAdapter -from pip._vendor.requests.adapters import BaseAdapter, HTTPAdapter -from pip._vendor.requests.models import Response -from pip._vendor.requests.structures import CaseInsensitiveDict -from pip._vendor.six.moves.urllib import parse as urllib_parse -from pip._vendor.urllib3.exceptions import InsecureRequestWarning - -from pip import __version__ -from pip._internal.network.auth import MultiDomainBasicAuth -from pip._internal.network.cache import SafeFileCache -# Import ssl from compat so the initial import occurs in only one place. -from pip._internal.utils.compat import has_tls, ipaddress -from pip._internal.utils.glibc import libc_ver -from pip._internal.utils.misc import ( - build_url_from_netloc, - get_installed_version, - parse_netloc, -) -from pip._internal.utils.typing import MYPY_CHECK_RUNNING -from pip._internal.utils.urls import url_to_path - -if MYPY_CHECK_RUNNING: - from typing import ( - Iterator, List, Optional, Tuple, Union, - ) - - from pip._internal.models.link import Link - - SecureOrigin = Tuple[str, str, Optional[Union[int, str]]] - - -logger = logging.getLogger(__name__) - - -# Ignore warning raised when using --trusted-host. -warnings.filterwarnings("ignore", category=InsecureRequestWarning) - - -SECURE_ORIGINS = [ - # protocol, hostname, port - # Taken from Chrome's list of secure origins (See: http://bit.ly/1qrySKC) - ("https", "*", "*"), - ("*", "localhost", "*"), - ("*", "127.0.0.0/8", "*"), - ("*", "::1/128", "*"), - ("file", "*", None), - # ssh is always secure. - ("ssh", "*", "*"), -] # type: List[SecureOrigin] - - -# These are environment variables present when running under various -# CI systems. For each variable, some CI systems that use the variable -# are indicated. The collection was chosen so that for each of a number -# of popular systems, at least one of the environment variables is used. -# This list is used to provide some indication of and lower bound for -# CI traffic to PyPI. Thus, it is okay if the list is not comprehensive. -# For more background, see: https://github.com/pypa/pip/issues/5499 -CI_ENVIRONMENT_VARIABLES = ( - # Azure Pipelines - 'BUILD_BUILDID', - # Jenkins - 'BUILD_ID', - # AppVeyor, CircleCI, Codeship, Gitlab CI, Shippable, Travis CI - 'CI', - # Explicit environment variable. - 'PIP_IS_CI', -) - - -def looks_like_ci(): - # type: () -> bool - """ - Return whether it looks like pip is running under CI. - """ - # We don't use the method of checking for a tty (e.g. using isatty()) - # because some CI systems mimic a tty (e.g. Travis CI). Thus that - # method doesn't provide definitive information in either direction. - return any(name in os.environ for name in CI_ENVIRONMENT_VARIABLES) - - -def user_agent(): - """ - Return a string representing the user agent. - """ - data = { - "installer": {"name": "pip", "version": __version__}, - "python": platform.python_version(), - "implementation": { - "name": platform.python_implementation(), - }, - } - - if data["implementation"]["name"] == 'CPython': - data["implementation"]["version"] = platform.python_version() - elif data["implementation"]["name"] == 'PyPy': - if sys.pypy_version_info.releaselevel == 'final': - pypy_version_info = sys.pypy_version_info[:3] - else: - pypy_version_info = sys.pypy_version_info - data["implementation"]["version"] = ".".join( - [str(x) for x in pypy_version_info] - ) - elif data["implementation"]["name"] == 'Jython': - # Complete Guess - data["implementation"]["version"] = platform.python_version() - elif data["implementation"]["name"] == 'IronPython': - # Complete Guess - data["implementation"]["version"] = platform.python_version() - - if sys.platform.startswith("linux"): - from pip._vendor import distro - distro_infos = dict(filter( - lambda x: x[1], - zip(["name", "version", "id"], distro.linux_distribution()), - )) - libc = dict(filter( - lambda x: x[1], - zip(["lib", "version"], libc_ver()), - )) - if libc: - distro_infos["libc"] = libc - if distro_infos: - data["distro"] = distro_infos - - if sys.platform.startswith("darwin") and platform.mac_ver()[0]: - data["distro"] = {"name": "macOS", "version": platform.mac_ver()[0]} - - if platform.system(): - data.setdefault("system", {})["name"] = platform.system() - - if platform.release(): - data.setdefault("system", {})["release"] = platform.release() - - if platform.machine(): - data["cpu"] = platform.machine() - - if has_tls(): - import _ssl as ssl - data["openssl_version"] = ssl.OPENSSL_VERSION - - setuptools_version = get_installed_version("setuptools") - if setuptools_version is not None: - data["setuptools_version"] = setuptools_version - - # 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 - # value to make it easier to know that the check has been run. - data["ci"] = True if looks_like_ci() else None - - user_data = os.environ.get("PIP_USER_AGENT_USER_DATA") - if user_data is not None: - data["user_data"] = user_data - - return "{data[installer][name]}/{data[installer][version]} {json}".format( - data=data, - json=json.dumps(data, separators=(",", ":"), sort_keys=True), - ) - - -class LocalFSAdapter(BaseAdapter): - - def send(self, request, stream=None, timeout=None, verify=None, cert=None, - proxies=None): - pathname = url_to_path(request.url) - - resp = Response() - resp.status_code = 200 - resp.url = request.url - - try: - stats = os.stat(pathname) - except OSError as exc: - resp.status_code = 404 - resp.raw = exc - 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.raw = open(pathname, "rb") - resp.close = resp.raw.close - - return resp - - def close(self): - pass - - -class InsecureHTTPAdapter(HTTPAdapter): - - def cert_verify(self, conn, url, verify, cert): - super(InsecureHTTPAdapter, self).cert_verify( - conn=conn, url=url, verify=False, cert=cert - ) - - -class PipSession(requests.Session): - - timeout = None # type: Optional[int] - - def __init__(self, *args, **kwargs): - """ - :param trusted_hosts: Domains not to emit warnings for when not using - HTTPS. - """ - retries = kwargs.pop("retries", 0) - cache = kwargs.pop("cache", None) - trusted_hosts = kwargs.pop("trusted_hosts", []) # type: List[str] - index_urls = kwargs.pop("index_urls", None) - - super(PipSession, self).__init__(*args, **kwargs) - - # 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]]] - - # Attach our User Agent to the request - self.headers["User-Agent"] = user_agent() - - # Attach our Authentication handler to the session - self.auth = MultiDomainBasicAuth(index_urls=index_urls) - - # Create our urllib3.Retry instance which will allow us to customize - # how we handle retries. - retries = urllib3.Retry( - # 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 - # retry it. - # 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, - ) - - # We want to _only_ cache responses on securely fetched origins. We do - # this because we can't validate the response of an insecurely fetched - # origin, and we don't want someone to be able to poison the cache and - # require manual eviction from the cache to fix it. - if cache: - secure_adapter = CacheControlAdapter( - cache=SafeFileCache(cache), - max_retries=retries, - ) - else: - secure_adapter = HTTPAdapter(max_retries=retries) - - # Our Insecure HTTPAdapter disables HTTPS validation. It does not - # support caching (see above) so we'll use it for all http:// URLs as - # well as any https:// host that we've marked as ignoring TLS errors - # for. - insecure_adapter = InsecureHTTPAdapter(max_retries=retries) - # Save this for later use in add_insecure_host(). - self._insecure_adapter = insecure_adapter - - self.mount("https://", secure_adapter) - self.mount("http://", insecure_adapter) - - # Enable file:// urls - self.mount("file://", LocalFSAdapter()) - - for host in trusted_hosts: - self.add_trusted_host(host, suppress_logging=True) - - def add_trusted_host(self, host, source=None, suppress_logging=False): - # type: (str, Optional[str], bool) -> None - """ - :param host: It is okay to provide a host that has previously been - added. - :param source: An optional source string, for logging where the host - string came from. - """ - if not suppress_logging: - msg = 'adding trusted host: {!r}'.format(host) - if source is not None: - msg += ' (from {})'.format(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) - - self.mount(build_url_from_netloc(host) + '/', self._insecure_adapter) - if not host_port[1]: - # Mount wildcard ports for the same host. - self.mount( - build_url_from_netloc(host) + ':', - self._insecure_adapter - ) - - def iter_secure_origins(self): - # type: () -> Iterator[SecureOrigin] - for secure_origin in SECURE_ORIGINS: - yield secure_origin - for host, port in self.pip_trusted_origins: - yield ('*', host, '*' if port is None else port) - - def is_secure_origin(self, location): - # type: (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, - ) - - # 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] - - # Determine if our origin is a secure origin by looking through our - # hardcoded list of secure origins, as well as any additional ones - # configured on this PackageFinder instance. - for secure_origin in self.iter_secure_origins(): - secure_protocol, secure_host, secure_port = secure_origin - if origin_protocol != secure_protocol and secure_protocol != "*": - continue - - try: - addr = ipaddress.ip_address( - None - if origin_host is None - else six.ensure_text(origin_host) - ) - network = ipaddress.ip_network( - six.ensure_text(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 != "*" - ): - continue - else: - # We have a valid address and network, so see if the address - # is contained within the network. - if addr not in network: - continue - - # Check to see if the port matches. - if ( - origin_port != secure_port and - secure_port != "*" and - secure_port is not None - ): - continue - - # If we've gotten here, then this origin matches the current - # secure origin and we should return True - return True - - # If we've gotten to this point, then the origin isn't secure and we - # will not accept it as a valid location to search. We will however - # log a warning that we are ignoring it. - logger.warning( - "The repository located at %s is not a trusted or secure host and " - "is being ignored. If this repository is available via HTTPS we " - "recommend you use HTTPS instead, otherwise you may silence " - "this warning and allow it anyway with '--trusted-host %s'.", - origin_host, - origin_host, - ) - - return False - - def request(self, method, url, *args, **kwargs): - # Allow setting a default timeout on a session - kwargs.setdefault("timeout", self.timeout) - - # Dispatch the actual request - return super(PipSession, self).request(method, url, *args, **kwargs) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/network/utils.py b/venv/lib/python3.8/site-packages/pip/_internal/network/utils.py deleted file mode 100644 index a19050b..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/network/utils.py +++ /dev/null @@ -1,48 +0,0 @@ -from pip._vendor.requests.models import CONTENT_CHUNK_SIZE, Response - -from pip._internal.utils.typing import MYPY_CHECK_RUNNING - -if MYPY_CHECK_RUNNING: - from typing import Iterator - - -def response_chunks(response, chunk_size=CONTENT_CHUNK_SIZE): - # type: (Response, int) -> Iterator[bytes] - """Given a requests Response, provide the data chunks. - """ - try: - # Special case for urllib3. - for chunk in response.raw.stream( - chunk_size, - # We use decode_content=False here because we don't - # want urllib3 to mess with the raw bytes we get - # from the server. If we decompress inside of - # urllib3 then we cannot verify the checksum - # because the checksum will be of the compressed - # file. This breakage will only occur if the - # server adds a Content-Encoding header, which - # depends on how the server was configured: - # - Some servers will notice that the file isn't a - # compressible file and will leave the file alone - # and with an empty Content-Encoding - # - Some servers will notice that the file is - # already compressed and will leave the file - # alone and will add a Content-Encoding: gzip - # header - # - Some servers won't notice anything at all and - # will take a file that's already been compressed - # and compress it again and set the - # Content-Encoding: gzip header - # - # By setting this not to decode automatically we - # hope to eliminate problems with the second case. - decode_content=False, - ): - yield chunk - except AttributeError: - # Standard file-like object. - while True: - chunk = response.raw.read(chunk_size) - if not chunk: - break - yield chunk diff --git a/venv/lib/python3.8/site-packages/pip/_internal/network/xmlrpc.py b/venv/lib/python3.8/site-packages/pip/_internal/network/xmlrpc.py deleted file mode 100644 index 121edd9..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/network/xmlrpc.py +++ /dev/null @@ -1,44 +0,0 @@ -"""xmlrpclib.Transport implementation -""" - -# The following comment should be removed at some point in the future. -# mypy: disallow-untyped-defs=False - -import logging - -from pip._vendor import requests -# NOTE: XMLRPC Client is not annotated in typeshed as on 2017-07-17, which is -# why we ignore the type on this import -from pip._vendor.six.moves import xmlrpc_client # type: ignore -from pip._vendor.six.moves.urllib import parse as urllib_parse - -logger = logging.getLogger(__name__) - - -class PipXmlrpcTransport(xmlrpc_client.Transport): - """Provide a `xmlrpclib.Transport` implementation via a `PipSession` - object. - """ - - def __init__(self, index_url, session, use_datetime=False): - xmlrpc_client.Transport.__init__(self, 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): - 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) - response.raise_for_status() - self.verbose = verbose - return self.parse_response(response.raw) - except requests.HTTPError as exc: - logger.critical( - "HTTP error %s while getting %s", - exc.response.status_code, url, - ) - raise diff --git a/venv/lib/python3.8/site-packages/pip/_internal/operations/__init__.py b/venv/lib/python3.8/site-packages/pip/_internal/operations/__init__.py deleted file mode 100644 index e69de29..0000000 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/operations/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/operations/__pycache__/__init__.cpython-38.pyc deleted file mode 100644 index ce5d08889af886690492df2b27752693b6e4f4c9..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 160 zcmWIL<>g`k0&_FfL=gQLL?8o3AjbiSi&=m~3PUi1CZpd^EiC(_dfLb z)Rd#)`QfeW!MF38_IFxLJ|-4-F{G<&TBvzisD~`pJsrPB%o4*hblNjxGpTtsHLt~1 zQupd=ZpC)e@EU4fkDa9HHPzgXTgj9+rE6S2n&#);=-v#U690gvMm(F$d2>q2iO(nV z-h8s)EhLNHVsgQ|kSuvi$+EYctavLpy~r|a4DP#XJ6^wYB(33$IkU| zK3u@>_rt~T0)F2Q*;B2(eDMA+gE$I$)Ky@HFIUC*qRUgP_w7dR#i+l99LC zdg-J=!oz$xh&fiXogmH9r~@Sj+$R<`7oPCFVI+9M)BJHDB)>02CctPXL7)3!By$mM z59ytLHxqu8$~=f;Uz{F;@Wmd_k6AoCb4r3e_u2Eu&;8Ax-{1VyfAaa(*2Arz(eA@a z*TfCl_0srhx?kFxct@}u^U}N*b@I~w#ei-Q#HI0+=Vk2~eNt&Y!tKiG$JKY=<9QIp zvaG-0LPEH-$9I$+vd8gbVba9-6hr<2q|hR*&%_*oFEswbMp%yk!4b=~F1UZx?`gmK zYGmYkVeGO)ePkXiv&dHu)^&B82d zZwSh@5&J^>NDHk|?d#f?+H;)v5(DR1mt0&w_;@o*asOPpfg9uNl%FSjAl)dorERFX|Q}(05!FAsi3{2NFCRP=2zLpXT_i~uJL!zeT$vjq)+i z-R95)OsZ&h^PM1fb0ikvTPZny2f@M((hva6hax5TZ)aJ|gS3M8RtF{Ga8v=WA7AV;wqNq)S27fr=!Z-`oRr_qe<|rZKyz!ch=4vdWNjk90)Er zZYDXUHlxq?+pW@ok*e@8=+%q#LMsVGA2DL{7ePD(JWC@8LlsG7Lk@T+>PEzdVUf8~ zSz0m^IS-*M7wx84Ax-a*rg{=d3g5B`*=~%CNQ>4n+Eq-o#xg$2f-Gky1gjkbp|9+M zdqEqoF7mFCX8*?&KgI>*hag(r)@=iU!)#{h7PEDRz;O&4q2%C?0*V=qKBLbeyk@YT zV}cHzaUFS!5)GM2-U6X;`HGDw-Rgk1e#nq&0Z5wt9&4mp{kK{dp%=1Oc4)k=Ql)vo zA0U0H>r!F^V)Gq-S`+u(o(Kjz?n^=_q3{&GZqP+4p`?jqs;U_&=tVDhdL}elygep)wTkly%7h=b{O0#AoNcR?Vw$m z`?#ncJ58SA@AynxS5Ro1Do>TmzKoJ#OgV3SSfxZi>z1?rI2oSafxOT*ODE5cr4_hJ z-7n{qf&A?gJpcxMo*>^;fpg*iTr!4)q>`Xn4s#60U`VG-bN*xgTl@sOXObx;(i+Al zhI|B~(j-%8Y5`k^glv<~9D%b`#0+d+QVO=8W??_tWHW<~+V*Y@L0+=Ec z7~)4Df5NE1g!DomNy&vOw9OR1t#7q&ly%<^vyShVb?QIH88MEb9}S-r6r1Hmv^e>j6RzX6YadiBq$QsOl?PfLl{9Pd)I?VX$8sEy_(H3d(&9L9MCcb9ZiR#Abj zaHzaA;n@@Smi9)Hg~OQNq4X)&Kuna97HiQkh*Ce+(pPJk>(guo#iPZh4ST^^w-@Y% F{{m)M#6SQ5 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/operations/__pycache__/freeze.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/operations/__pycache__/freeze.cpython-38.pyc deleted file mode 100644 index fe2605c54f7f9f23344f449d51e70618d9c0c2f6..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 5803 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 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/operations/build/__pycache__/metadata.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/operations/build/__pycache__/metadata.cpython-38.pyc deleted file mode 100644 index 7553793e8dd92b6998abfd5347d4c54e77a47341..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1208 zcmZux&2HQ_5GE}XH^Z6vW~djNn*#*n(Klabdp(5y_QLxk z0O5Q1%qdJ9rHErrN}S?uB`JY5D1(Zo6nl)8y(&z@Zr>~WRg^{;iAbLS7M2^;ARTmA zzx=2grbEE+^``jv2B%v*;v0XUbeof3(P(h_;JL6F&ukVKLJ6H&S*y6L3z^5SYaN@q z)wzhdG*-)L>rs;o{(&gb(FnUe-72tR7t+p{X=Eoy$##tK;7@Wz7UUFP1q<{x!N?L$f5%sJfv*!DFf7$>Ai1 z(38O+hH)%xtCflEOspsdwe?ke#ZJ;`Uv5=37h3JF6i!CO(KD&I+b+s_3RKKll_}tt zU+zw{Xfo|%xtIx2u5TUnweKiLo6OF%C(iAdcG~DVhuW}Z(Oleg=7Oz!F{n73`dYB= zK1XWf=xHt0D0CZ3K&W%qpJw@)fRMJ0d~H0s;N| zYz#KzMmGDcYW#hCzjL}T+v3f)^9L6m8#Ada(2p?_DnU zz=zp|355g`MBaroBq5FP5K~Ov?Na?2V51$^XN=c5W3CTfUjUbS2!Q(vyeDh#33PsG zk~-?;8cuqIQ_d3Fqt%!77<{e7O6{Iaam`Mg)a|)d-$@#& z*Ym2rn>5o_uT}LM$(6L-Ygc_QnMr4Rvy_OoEMb2$xth-P=F<7ze6`+67Se0IYp_m_ z7sX3s+FRmRc>5{oUFS1=7QV}zJtUp0!?!;WI^>}a{l3VA40W7mev+2~L+|6Znam?YKi`%>l-CR-v?11SO?S&9gU>(uJh=Pr{kwk&Hb2?ecyHqY z%vz5l)nUedA1-6O4-33Zn83o^p9gWm?`Mx=nP;iUbj0w2CyxtX2VOLd`U)B}#Z&SP z`3KnnV{rSaH)7o3?o%?dN;0xbD!U~s?ISvJvSm&7=rN3VW6VajCdXE3k71>B)Mwh} z-m!z@Bl;E9Zs{C>N%n17l+IqGw0P?orDSqK>F_Hz$Qa>o5AVMdXWS1nzYBP*ARd04 z`CB#K2%U&@E)Ta}_qRhOxDUqJiUB+x>u@^}TiuoqPeehV$%Fj{ybs}3cc7_%xN1Q$ zRC{cVY0<4_Kow97=K%tohif?-#@dcE;}(Z{H_uGtVI<>1t6}S-YN9Kih>l}eu8duT zde<}(@dT^^!@V5$)uRrT;2Y#Qk=Nk!-R7!Ji`617Rt8xSM*D)V9PA2_ti*%p_?VB76J`R2>aY ztYy0N{jeMC0L)X$b=Q&{*rwLImv27@CvpbiL><(Bpy`tl1^d&IjOjh{<=?-sz9Azv zvNYSXV7vs(u}ik^%3CEnhW;3A|LB%>N_K?uYa{z>*uUoYvz{l3rA?e#)h%A00(ifRp&H9uRyJSgBtx3nv#6E zh&my|;ZAhS{z~A^j01-{bfaU*S&*uXDd(XF-p9Ikj1BY*o>ODXJlB7kuw z1*@?S!en0}#f%4tW??FnaivJ}$HLeseu_N0mWHc?_t_W_Oe+dA9z*Tb}s)NwfIxQpdFN6AJ5K#yOVK!Z)E$Y#>-KGn)&E{yE-lW4jKUe2-roy0v zM5s*lDs)P6Of=mCpBdBYYs;6XbKo<@E1X_O{;>^-n?YkI$_JS~<)X2aD2y8>8om&0 zQ00q8T;QV6yFtEl8cW{b~ zEZ2}Z2N2aEkpFG;ZFPCbTKnR#R>V8ipz| zVnQ%i&SU}k8f=tZY;NNbO{74@qZ*D5u2il$dtTEeSWvg1A&%E*U-KF^wP}mZ!fR7T zy%%<)4GfTf1c|7Mrzi^#!qKs zvr3zo56w)4P*5BORlaVW(g`BrNiAW#SmjW{32qu3Qf-_l`4${!Y^=~OI@bJ2xhR4O zd>@0XLMD(@|gm(LZ?E_+`3eBT8dVvnwysi z>B9oAi@ssz&kI1AT1R#FL>AlGp-`eB9H m8Ec#-EN?B%`5+PN7;>t_Zd)Gp7`X7{58Qf=wOPyZ-u?mOAAh_6 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/operations/build/__pycache__/wheel.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/operations/build/__pycache__/wheel.cpython-38.pyc deleted file mode 100644 index 96716bae2e1cbd340f36c143f81d17ca288adf76..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1306 zcmZuxO>Y}T7@pa0Z=8@;6;c}nBSfTH!fREc6d{D5CM6Zc4MA0#J+Rt%Ce9}N)tOn0 z&E^6exKvy@+DCo_e`Kzl_zN5;?~F|vB*vPt-+8~D=b0Hl+1v~fjC=3zroX!g{h^Jk z!v^CMnBp5)D55w=@#-7L7;G!I3Oly3-m`P3aAOxE=JI{8o!l$@*e`-OFn%}h6k!~K zA1yXmcZuUo>QVnE6mL=dHR=U_LJu_RVYS1XvSd7&X7V%U@~yIpbrXcsYFd)qy#L zDSm~ewJ1LCh^|CG;MV5vNW8G9)uI#pI$C0&03hf0Vb`X1>ntsdq(hyB+k*E;eBriu z;kE7(|8fJP7N7a80~OsD)`j;J-9=xaL-Y(iMdjNLlEHb%f5u3EOcxJoK)oZ=;~A2j zvv9Ei`QFk3Vf^`v`%RWpQk9H6EQJIzhwOQiaaOQWl160Zgve7y4)zWRFeb+)yyn#y zM2o_Zz&K>G;iVvTDo=^5$n=!4oMb0NG-Dlh(&YKfWXgy%0+kk4&Y} z{J}6S%Sx{MtSX&Uoa~A8C^5)XXYac)Gt`t-3FT;k zm2*~QWzSbmnHEg>$LaW-m6YpCr#4sFD>;O6B`a#Gymjr+R84f=Z;0Q7gunI&vZx1j zR`;8-)|F`A1og9K^8AC@dsFQjBv~mLhpRuRYQ~MGVqjVgOmtMw)b%UCliECwE$AR_ z!-Be9>{uRlUV4^;E!?#%9K3XF*age_`-ZcHyEwpn2V#4#DPKzm67y}a)tdkzx`Yrl zGRsBuO1YJ!xBf3k&ftYlxc;kA-r8`$;QFv<8ZTdpe>sVe--H s6obU*mLy!iYy;FNcxAbzQ-Y6*iZ(g>7=tA={s0G77brV;8`jYN2XPsERsaA1 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/operations/build/__pycache__/wheel_legacy.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/operations/build/__pycache__/wheel_legacy.cpython-38.pyc deleted file mode 100644 index dfa07cd8704b0f24a62c5e83381f4367e111fa2a..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2567 zcma)8TW{P%6rS;YolVlFNlLlNjategvJnW{Dnb=%l3pMrkW$(%0^@il8#lfzGvlV& zc%NGFM8#i7#1n7)o_Xb|e*q|PX1v)(rAT&|-N@k{Z=5(CQ?YNoO@wCiJ8=2qn^}C&p zWz9|#BkHs7K;KEnvx&|`HrbiXPIOLy937mbQ-`>7inzpkj5^b#L40`5kTKGP=Pbdu zP;2}t>;4ktxCnQ*DNVzOb$QE_W2@`e!{wV_-CSPTkdtwg zrXepkd#s2l=knB6!Lmq%agk+FPHH18r#`#)`Mq%I#>&#C;l}N?wVP|#VYz0}qj|`C zNuE;%uB}yAO?vA+kra89O6yDdP{fAX-SD#DX~Vq)H~$s}fhzO}4-A42aAh3gfmvZ5 zR3J2~tN+^$|C7>q1AT|r8 zzppQdthdlhdh=!8i{c$h<~3I4ld}8$<-HGf)whK($pvLl&;_VBi&Sy>!e*JIWT8e@ zO1n|K*Y54fnL3&gd>G|rDrR6UJ`DqMJnS15_VENfeeB^A273kMvC75K<-p4bBmyQw zkN{Np`y-&(l`V|QtgJ_>+_o?etja#b&{@VUBy0sMVghJ3iKU=bp+jTvpEkm|?;dy+ zt`M=$fTo7dl?`YlmIq>+2E9mZtD>rR9W($*PXx_+1&i2TpfeJXghA~Jw%6{zx2p3p z{7`HS4HfG4&$2-fGa3m>g1iW}l9ckczxEVExc$!mG|UPHNZXF`03fM-wEb(~DUUMB zgSX@DqTqmS_`fyAKy#|mDYm9_CNkc+Xp5FllehvoYd)P9J zzYW9q%Q68TFl(y0X&~d7WhuZgr5G!C99?Srim)}G{0c7s6<~r2pg`~wYv2$l{1%=? z16Sb6eT08{Jn$5!5EH;+VAP)yR^Xf9uycu{ zfP~RKbO(KizCau3XGGjv=q?i8K|=v>;0wR=rjMbK&)(u{YBbcctCv?*f+>%V?20vwY%*cV-|wQLqZ zt=U;M%&B1nz}6U3=M8h!pdoD&x>(|wHdR0&v>}HwvX;_vYChIm zKhjlBUu>7D<2_PW{RY_c%P^pE0}p?HI<6000zGmhdFI=yZ<=@tsC6X8#vhK$E`n|A zG@FEnbPL|r3+u4Y0mZjR6yGjIlJfTPzYq$YI;rx_m#U8bJm}*{C%Qh`UVWLm*n`A$ znQCG=`!alnbg;*=s*XCQnaKMn fD@d8rD~biVl6%-Qn&!0KghX0++VD+p#(VQ0Y8KMp diff --git a/venv/lib/python3.8/site-packages/pip/_internal/operations/build/metadata.py b/venv/lib/python3.8/site-packages/pip/_internal/operations/build/metadata.py deleted file mode 100644 index b13fbde..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/operations/build/metadata.py +++ /dev/null @@ -1,40 +0,0 @@ -"""Metadata generation logic for source distributions. -""" - -import logging -import os - -from pip._internal.utils.subprocess import runner_with_spinner_message -from pip._internal.utils.temp_dir import TempDirectory -from pip._internal.utils.typing import MYPY_CHECK_RUNNING - -if MYPY_CHECK_RUNNING: - from pip._internal.build_env import BuildEnvironment - from pip._vendor.pep517.wrappers import Pep517HookCaller - -logger = logging.getLogger(__name__) - - -def generate_metadata(build_env, backend): - # type: (BuildEnvironment, Pep517HookCaller) -> str - """Generate metadata using mechanisms described in PEP 517. - - Returns the generated metadata directory. - """ - metadata_tmpdir = TempDirectory( - kind="modern-metadata", globally_managed=True - ) - - metadata_dir = metadata_tmpdir.path - - with build_env: - # Note that Pep517HookCaller 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") - with backend.subprocess_runner(runner): - distinfo_dir = backend.prepare_metadata_for_build_wheel( - metadata_dir - ) - - return os.path.join(metadata_dir, distinfo_dir) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/operations/build/metadata_legacy.py b/venv/lib/python3.8/site-packages/pip/_internal/operations/build/metadata_legacy.py deleted file mode 100644 index b6813f8..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/operations/build/metadata_legacy.py +++ /dev/null @@ -1,122 +0,0 @@ -"""Metadata generation logic for legacy source distributions. -""" - -import logging -import os - -from pip._internal.exceptions import InstallationError -from pip._internal.utils.misc import ensure_dir -from pip._internal.utils.setuptools_build import make_setuptools_egg_info_args -from pip._internal.utils.subprocess import call_subprocess -from pip._internal.utils.typing import MYPY_CHECK_RUNNING -from pip._internal.vcs import vcs - -if MYPY_CHECK_RUNNING: - from typing import List, Optional - - from pip._internal.build_env import BuildEnvironment - -logger = logging.getLogger(__name__) - - -def _find_egg_info(source_directory, is_editable): - # type: (str, bool) -> str - """Find an .egg-info in `source_directory`, based on `is_editable`. - """ - - def looks_like_virtual_env(path): - # type: (str) -> bool - return ( - os.path.lexists(os.path.join(path, 'bin', 'python')) or - os.path.exists(os.path.join(path, 'Scripts', 'Python.exe')) - ) - - def locate_editable_egg_info(base): - # type: (str) -> List[str] - candidates = [] # type: List[str] - for root, dirs, files in os.walk(base): - for dir_ in vcs.dirnames: - if dir_ in dirs: - dirs.remove(dir_) - # Iterate over a copy of ``dirs``, since mutating - # a list while iterating over it can cause trouble. - # (See https://github.com/pypa/pip/pull/462.) - for dir_ in list(dirs): - if looks_like_virtual_env(os.path.join(root, dir_)): - dirs.remove(dir_) - # Also don't search through tests - elif dir_ == 'test' or dir_ == 'tests': - dirs.remove(dir_) - candidates.extend(os.path.join(root, dir_) for dir_ in dirs) - return [f for f in candidates if f.endswith('.egg-info')] - - def depth_of_directory(dir_): - # type: (str) -> int - return ( - dir_.count(os.path.sep) + - (os.path.altsep and dir_.count(os.path.altsep) or 0) - ) - - base = source_directory - if is_editable: - filenames = locate_editable_egg_info(base) - else: - base = os.path.join(base, 'pip-egg-info') - filenames = os.listdir(base) - - if not filenames: - raise InstallationError( - "Files/directories not found in {}".format(base) - ) - - # If we have more than one match, we pick the toplevel one. This - # can easily be the case if there is a dist folder which contains - # an extracted tarball for testing purposes. - if len(filenames) > 1: - filenames.sort(key=depth_of_directory) - - return os.path.join(base, filenames[0]) - - -def generate_metadata( - build_env, # type: BuildEnvironment - setup_py_path, # type: str - source_dir, # type: str - editable, # type: bool - isolated, # type: bool - details, # type: str -): - # type: (...) -> 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, - ) - - egg_info_dir = None # type: Optional[str] - # For non-editable installs, don't put the .egg-info files at the root, - # to avoid confusion due to the source code being considered an installed - # egg. - if not editable: - egg_info_dir = os.path.join(source_dir, 'pip-egg-info') - # setuptools complains if the target directory does not exist. - ensure_dir(egg_info_dir) - - args = make_setuptools_egg_info_args( - setup_py_path, - egg_info_dir=egg_info_dir, - no_user_config=isolated, - ) - - with build_env: - call_subprocess( - args, - cwd=source_dir, - command_desc='python setup.py egg_info', - ) - - # Return the .egg-info directory. - return _find_egg_info(source_dir, editable) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/operations/build/wheel.py b/venv/lib/python3.8/site-packages/pip/_internal/operations/build/wheel.py deleted file mode 100644 index 1266ce0..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/operations/build/wheel.py +++ /dev/null @@ -1,46 +0,0 @@ -import logging -import os - -from pip._internal.utils.subprocess import runner_with_spinner_message -from pip._internal.utils.typing import MYPY_CHECK_RUNNING - -if MYPY_CHECK_RUNNING: - from typing import List, Optional - from pip._vendor.pep517.wrappers import Pep517HookCaller - -logger = logging.getLogger(__name__) - - -def build_wheel_pep517( - name, # type: str - backend, # type: Pep517HookCaller - metadata_directory, # type: str - build_options, # type: List[str] - tempd, # type: str -): - # type: (...) -> 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 - if build_options: - # PEP 517 does not support --build-options - logger.error('Cannot build wheel for %s using PEP 517 when ' - '--build-option is present' % (name,)) - return None - try: - logger.debug('Destination directory: %s', tempd) - - runner = runner_with_spinner_message( - 'Building wheel for {} (PEP 517)'.format(name) - ) - with backend.subprocess_runner(runner): - wheel_name = backend.build_wheel( - tempd, - metadata_directory=metadata_directory, - ) - except Exception: - logger.error('Failed building wheel for %s', name) - return None - return os.path.join(tempd, wheel_name) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/operations/build/wheel_legacy.py b/venv/lib/python3.8/site-packages/pip/_internal/operations/build/wheel_legacy.py deleted file mode 100644 index 3ebd9fe..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/operations/build/wheel_legacy.py +++ /dev/null @@ -1,115 +0,0 @@ -import logging -import os.path - -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.typing import MYPY_CHECK_RUNNING -from pip._internal.utils.ui import open_spinner - -if MYPY_CHECK_RUNNING: - from typing import List, Optional, Text - -logger = logging.getLogger(__name__) - - -def format_command_result( - command_args, # type: List[str] - command_output, # type: Text -): - # type: (...) -> str - """Format command information for logging.""" - command_desc = format_command_args(command_args) - text = 'Command arguments: {}\n'.format(command_desc) - - if not command_output: - text += 'Command output: None' - elif logger.getEffectiveLevel() > logging.DEBUG: - text += 'Command output: [use --verbose to show]' - else: - if not command_output.endswith('\n'): - command_output += '\n' - text += 'Command output:\n{}{}'.format(command_output, LOG_DIVIDER) - - 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: Text -): - # type: (...) -> 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 += 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' - ).format(name, names) - msg += format_command_result(command_args, command_output) - logger.warning(msg) - - return os.path.join(temp_dir, names[0]) - - -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] - """Build one unpacked package using the "legacy" build process. - - Returns path to wheel if successfully built. Otherwise, returns None. - """ - wheel_args = make_setuptools_bdist_wheel_args( - setup_py_path, - global_options=global_options, - build_options=build_options, - destination_dir=tempd, - ) - - spin_message = 'Building wheel for %s (setup.py)' % (name,) - with open_spinner(spin_message) as spinner: - logger.debug('Destination directory: %s', tempd) - - try: - output = call_subprocess( - wheel_args, - cwd=source_dir, - spinner=spinner, - ) - except Exception: - spinner.finish("error") - logger.error('Failed building wheel for %s', name) - return None - - names = os.listdir(tempd) - wheel_path = get_legacy_build_wheel_path( - names=names, - temp_dir=tempd, - name=name, - command_args=wheel_args, - command_output=output, - ) - return wheel_path diff --git a/venv/lib/python3.8/site-packages/pip/_internal/operations/check.py b/venv/lib/python3.8/site-packages/pip/_internal/operations/check.py deleted file mode 100644 index b85a123..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/operations/check.py +++ /dev/null @@ -1,163 +0,0 @@ -"""Validation of dependencies of packages -""" - -# The following comment should be removed at some point in the future. -# mypy: strict-optional=False -# mypy: disallow-untyped-defs=False - -import logging -from collections import namedtuple - -from pip._vendor.packaging.utils import canonicalize_name -from pip._vendor.pkg_resources import RequirementParseError - -from pip._internal.distributions import ( - make_distribution_for_install_requirement, -) -from pip._internal.utils.misc import get_installed_distributions -from pip._internal.utils.typing import MYPY_CHECK_RUNNING - -logger = logging.getLogger(__name__) - -if MYPY_CHECK_RUNNING: - from pip._internal.req.req_install import InstallRequirement - from typing import ( - Any, Callable, Dict, Optional, Set, Tuple, List - ) - - # Shorthands - PackageSet = Dict[str, 'PackageDetails'] - Missing = Tuple[str, Any] - Conflicting = Tuple[str, str, Any] - - MissingDict = Dict[str, List[Missing]] - ConflictingDict = Dict[str, List[Conflicting]] - CheckResult = Tuple[MissingDict, ConflictingDict] - -PackageDetails = namedtuple('PackageDetails', ['version', 'requires']) - - -def create_package_set_from_installed(**kwargs): - # type: (**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": ()} - - package_set = {} - problems = False - for dist in get_installed_distributions(**kwargs): - name = canonicalize_name(dist.project_name) - try: - package_set[name] = PackageDetails(dist.version, dist.requires()) - except RequirementParseError as e: - # Don't crash on 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 - """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. - """ - if should_ignore is None: - def should_ignore(name): - return False - - missing = {} - conflicting = {} - - for package_name in package_set: - # Info about dependencies of package_name - missing_deps = set() # type: Set[Missing] - conflicting_deps = set() # type: Set[Conflicting] - - if should_ignore(package_name): - continue - - for req in package_set[package_name].requires: - name = canonicalize_name(req.project_name) # type: str - - # Check if it's missing - if name not in package_set: - missed = True - if req.marker is not None: - missed = req.marker.evaluate() - if missed: - missing_deps.add((name, req)) - continue - - # Check if there's a conflict - version = package_set[name].version # type: str - if not req.specifier.contains(version, prereleases=True): - conflicting_deps.add((name, version, req)) - - if missing_deps: - missing[package_name] = sorted(missing_deps, key=str) - if conflicting_deps: - conflicting[package_name] = sorted(conflicting_deps, key=str) - - return missing, conflicting - - -def check_install_conflicts(to_install): - # type: (List[InstallRequirement]) -> Tuple[PackageSet, CheckResult] - """For checking if the dependency graph would be consistent after \ - installing given requirements - """ - # Start from the current state - package_set, _ = create_package_set_from_installed() - # Install packages - would_be_installed = _simulate_installation_of(to_install, package_set) - - # Only warn about directly-dependent packages; create a whitelist of them - whitelist = _create_whitelist(would_be_installed, package_set) - - return ( - 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[str] - """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() - - name = canonicalize_name(dist.key) - package_set[name] = PackageDetails(dist.version, dist.requires()) - - installed.add(name) - - return installed - - -def _create_whitelist(would_be_installed, package_set): - # type: (Set[str], PackageSet) -> Set[str] - 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: - if canonicalize_name(req.name) in packages_affected: - packages_affected.add(package_name) - break - - return packages_affected diff --git a/venv/lib/python3.8/site-packages/pip/_internal/operations/freeze.py b/venv/lib/python3.8/site-packages/pip/_internal/operations/freeze.py deleted file mode 100644 index 36a5c33..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/operations/freeze.py +++ /dev/null @@ -1,265 +0,0 @@ -# The following comment should be removed at some point in the future. -# mypy: strict-optional=False -# mypy: disallow-untyped-defs=False - -from __future__ import absolute_import - -import collections -import logging -import os -import re - -from pip._vendor import six -from pip._vendor.packaging.utils import canonicalize_name -from pip._vendor.pkg_resources import RequirementParseError - -from pip._internal.exceptions import BadCommand, InstallationError -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.misc import ( - dist_is_editable, - get_installed_distributions, -) -from pip._internal.utils.typing import MYPY_CHECK_RUNNING - -if MYPY_CHECK_RUNNING: - from typing import ( - Iterator, Optional, List, Container, Set, Dict, Tuple, Iterable, Union - ) - from pip._internal.cache import WheelCache - from pip._vendor.pkg_resources import ( - Distribution, Requirement - ) - - RequirementInfo = Tuple[Optional[Union[str, Requirement]], bool, List[str]] - - -logger = logging.getLogger(__name__) - - -def freeze( - requirement=None, # type: Optional[List[str]] - find_links=None, # type: Optional[List[str]] - local_only=None, # type: Optional[bool] - user_only=None, # type: Optional[bool] - paths=None, # type: Optional[List[str]] - skip_regex=None, # type: Optional[str] - isolated=False, # type: bool - wheel_cache=None, # type: Optional[WheelCache] - exclude_editable=False, # type: bool - skip=() # type: Container[str] -): - # type: (...) -> Iterator[str] - find_links = find_links or [] - skip_match = None - - if skip_regex: - skip_match = re.compile(skip_regex).search - - for link in find_links: - yield '-f %s' % 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 - if exclude_editable and req.editable: - continue - installations[req.canonical_name] = req - - if requirement: - # the options that don't get turned into an InstallRequirement - # 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] - # 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]] - 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 - (skip_match and skip_match(line)) or - line.startswith(( - '-r', '--requirement', - '-Z', '--always-unzip', - '-f', '--find-links', - '-i', '--index-url', - '--pre', - '--trusted-host', - '--process-dependency-links', - '--extra-index-url'))): - 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'): - line = line[2:].strip() - else: - line = line[len('--editable'):].strip().lstrip('=') - line_req = install_req_from_editable( - line, - isolated=isolated, - wheel_cache=wheel_cache, - ) - else: - line_req = install_req_from_line( - COMMENT_RE.sub('', line).strip(), - isolated=isolated, - wheel_cache=wheel_cache, - ) - - if not line_req.name: - logger.info( - "Skipping line in requirement file [%s] because " - "it's not clear what it would install: %s", - 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) - if line_req_canonical_name not in installations: - # either it's not installed, or it is installed - # but has been processed already - if not req_files[line_req.name]: - logger.warning( - "Requirement file [%s] contains %s, but " - "package %r is not installed", - req_file_path, - 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() - del installations[line_req_canonical_name] - req_files[line_req.name].append(req_file_path) - - # Warn about requirements that were included multiple times (in a - # single requirements file or in different requirements files). - for name, files in six.iteritems(req_files): - if len(files) > 1: - 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()): - if installation.canonical_name not in skip: - yield str(installation).rstrip() - - -def get_requirement_info(dist): - # type: (Distribution) -> RequirementInfo - """ - Compute and return values (req, editable, comments) for use in - FrozenRequirement.from_dist(). - """ - if not dist_is_editable(dist): - return (None, False, []) - - location = os.path.normcase(os.path.abspath(dist.location)) - - from pip._internal.vcs import vcs, RemoteNotFoundError - vcs_backend = vcs.get_backend_for_dir(location) - - if vcs_backend is None: - req = dist.as_requirement() - logger.debug( - 'No VCS found for editable requirement "%s" in: %r', req, - location, - ) - comments = [ - '# Editable install with no version control ({})'.format(req) - ] - return (location, True, comments) - - try: - req = vcs_backend.get_src_requirement(location, dist.project_name) - except RemoteNotFoundError: - req = dist.as_requirement() - comments = [ - '# Editable {} install with no remote ({})'.format( - type(vcs_backend).__name__, req, - ) - ] - return (location, True, comments) - - except BadCommand: - logger.warning( - 'cannot determine version of editable source in %s ' - '(%s command not found in path)', - location, - vcs_backend.name, - ) - return (None, True, []) - - except InstallationError as exc: - logger.warning( - "Error when trying to get requirement for VCS system %s, " - "falling back to uneditable format", exc - ) - else: - if req is not None: - return (req, True, []) - - logger.warning( - 'Could not determine repository location of %s', location - ) - comments = ['## !! Could not determine repository location'] - - return (None, False, comments) - - -class FrozenRequirement(object): - def __init__(self, name, req, editable, comments=()): - # type: (str, Union[str, Requirement], bool, Iterable[str]) -> None - self.name = name - self.canonical_name = canonicalize_name(name) - self.req = req - self.editable = editable - self.comments = comments - - @classmethod - def from_dist(cls, dist): - # type: (Distribution) -> FrozenRequirement - req, editable, comments = get_requirement_info(dist) - if req is None: - req = dist.as_requirement() - - return cls(dist.project_name, req, editable, comments=comments) - - def __str__(self): - req = self.req - if self.editable: - req = '-e %s' % req - return '\n'.join(list(self.comments) + [str(req)]) + '\n' diff --git a/venv/lib/python3.8/site-packages/pip/_internal/operations/install/__init__.py b/venv/lib/python3.8/site-packages/pip/_internal/operations/install/__init__.py deleted file mode 100644 index 24d6a5d..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/operations/install/__init__.py +++ /dev/null @@ -1,2 +0,0 @@ -"""For modules related to installing packages. -""" diff --git a/venv/lib/python3.8/site-packages/pip/_internal/operations/install/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/operations/install/__pycache__/__init__.cpython-38.pyc deleted file mode 100644 index 50867c4d9ff1446d3aaa1be477379d32af4f633d..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 224 zcmYjLu?oU46imA)h5kbp2f;Rjq7EWXZn}tzO9;)Q2Gb-aDWZSmFLm`3+?-6*!GpWU zagXV2*n(spIQAL~ru*eMd=;cG@Sa#YeRfvh!Lh}Ra^&NT#f*;5N&;)UniHC5h|1i htC%F(fMs52<;d?5p&=EX($ZYJ{^Hwc8CyRC(HkdeKGFaH diff --git a/venv/lib/python3.8/site-packages/pip/_internal/operations/install/__pycache__/editable_legacy.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/operations/install/__pycache__/editable_legacy.cpython-38.pyc deleted file mode 100644 index a2037313b46a60f5872b02c6d7a2631db937bac7..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1302 zcmZux&5zSY6d!-YahzncEGr?PYOSgqB6X7sv^`XSSRsnKr0oJ~aSyXz&#W_I>@hRr zU9vJKxFY@qIQGBkd9FS6Pbde}H%|5gX~&vh=6(6S`Mu{n9S$P|>-+C+q9*&9hea>xIf(Y;9{6>6 zRP>X6F-Qi*Fd4Q!Azv#-$q0O$_v`f12PfGeJrcb^$z|d`M&thRogJE|*&?Qd>2#md zn3YPWoTr+JGOnb^s8Zj?Y(gjTo}#+0CevVi1S%ebuwRv)&Nw_&R%02;jqZkx^r*FoBC zg2ri3({0?wYkcCq?Y@e%_Zq$X+CfeDZUcP$CTe=bdkg-*qg&`Vw2S^YcOpJ8*g5|5 z;gYd9jjJ?!p5~UrGd>GJfVxLQ=@{-_+cFiLC^##%rRP%A`8YZi# vLyT=hF_xEXu)TWQm2+^-hJ-)Dq}QC@c0f{_0KOZ#1E+ml-`R8rUgZ4`mIZ!x diff --git a/venv/lib/python3.8/site-packages/pip/_internal/operations/install/__pycache__/legacy.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/operations/install/__pycache__/legacy.cpython-38.pyc deleted file mode 100644 index 7cd5d87ef2984daa4daab122580b082a4ccf70a1..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3048 zcmZuzOK&5`5$+xihr{i(o& zuON8ddhn|Ew>ComP=lLK0S50v<9`7{&=3(!j0g|0{u)CAzJ;g|n?n<;IWsE8*3i=Z zVpNLlp{@H?RE{gditd-9YFr!Ebl;BZabwuf{c_ZdTf>&_SE6>@8FnzD9rh>CTaC8j z?ywv8hP`-uxUFSs(N4TO+|~VhbSK^$?twg>@6)>rJUk!`(tL)7_lWTb^;^>i4{6}} zmrj^);YE=r!ZdL*mim^M zW{motphS(rgwRB|Q5vWbP56XSmxK&PcVq9Ix>~hJ(}=q(3tW!{9On1gBuOZ9FG4YP zc^2wH3|4soh3WdoG|t`+VJ(reOJH<<{@E`+bKm>fkKg;yJ^AGL_=Dr0_6yQ{7;+)) zk22+#7fJgOeLSIwuT)r%{4tGHuk*pu`xBT1l`+`tmz9UBX9vCwXe#Xd8;p=Zxp9Sa zbcW{;>HsZ_9W*n5i#J?j#l^XOR+yEANeaY#j<5eZtBB&6H816rGm8`##;huA&{WQi z9Ou<9P+rW-xtUwQtK=nOJ+IDcqDo5h8gS|hSYcKdjVpBh8b-irUU%VJ&(&;;*v}1& zeuaL3eu+-duW$79n(e&0!2Iu`Gv6X*=--h2Bf$6(B9$DuUD3;{SNOU!Yvhgj_5#g! z7HHPIP3!N`2tY_`&+J(%Z@!Oy^ZKl%W`#wAMf5dVF^97R=<` z`8_>*AJ*zYB(@gD0_*iMm~$2gBk@wcbp<>vSIV~t$jr9E<89KtGOqWu&o7f6#HR~( z^>)Czn>(tk>Te&*Mi8Z^UgV}4SzI>P@Le-3fM&{67MSOd2Gh<;;Bd(wh$o_7VNF03 zYXOnXCEp!|5ly_9N>injv>=^E;S*UIQ;$G8K=Md)oWgv4!l?_5xjYn9Hj;EX^3!A# z2C|%8`e~ejw(0#7NTo0dobM*GGfJ8Bbk;Xy!H)@$3o_k3(RMq^4(C+o^klt#*>nR#L?iy`+; zIWs^(AG3S#`7>r+^+8{KcqHQNC=0X0Ns@W~IVFb|V@jjLa1uQJ;pO)))Z7u&4M7>? z_EDNqrt23!TJ7~wq>CGrE?I+p%xFS%q52dS;1&>Mbg^kn4_5Mnx1-eeBL2?cru4Kt zph0jLCZlxv?CH!QA^8!QgMqt@EjUt{723tBg_AbF-WfKbvkmM zzA+m(KLK%t6c7Y-2+tQ_Grg(7S&BL$bt0-~W9K|cFBC)TR$kJOZFCQ&=9_N}-V8t8 zhsc={(C+axkyY5`$n$jxm8Bp}D8xranNR3+YqLRz3SC^~fW#LPSNg9=Gg6hhv`(Kw zKw-25J!dwAiXAATAR^7PG)$NZpsZ_W-R#oUc(OyD!XZWpE2&uvHY)anG*w11Q?bgY zlQ1GKO@1ryta0V?bi#anGA$z|E&2q^;nISmE1*mk2|b+zvc2-a18rT9(OI16V%2!!i>r!Ve z#7>{I5|3nURfMz)>=h*oaY?8wZ$K<-kPHyiQL1ZEIiVNs(qns5x^ywrm5l4Ku$Mp+ za};@5=`5|*SBCQ60YPmG*It;0rUlEW;TATq3GLf2aQeOYo{ zlKQSIODg)1l^S}oK>!jH5k`EVs4iOaKGdMWrUvN=K3HFZ;LfoO`u=TFYvmf2ySGWi zA@`Rs_}*>PH!e>a)XR*xcdO{+bakm)CdS>{gf<{i=_dDX6}g0)SiscfNLpe!P*-JE zRivia-|;n0356Y7p|P$c4!*4!06l;Po2aj#Ox?6(8S?+(GWTrPRf*)f?15TD1!)N= ljVetvs_eI6tw}`RQD+l(fS5Y8HGtEN*D!HcaSD~fe*xM}kIMi6 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/operations/install/__pycache__/wheel.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/operations/install/__pycache__/wheel.cpython-38.pyc deleted file mode 100644 index 60e606a292dff8c695147fa641ea8cbfe4d9fbd3..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 14582 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 IlgJ_e-&l4p(EtDd diff --git a/venv/lib/python3.8/site-packages/pip/_internal/operations/install/editable_legacy.py b/venv/lib/python3.8/site-packages/pip/_internal/operations/install/editable_legacy.py deleted file mode 100644 index a668a61..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/operations/install/editable_legacy.py +++ /dev/null @@ -1,52 +0,0 @@ -"""Legacy editable installation process, i.e. `setup.py develop`. -""" -import logging - -from pip._internal.utils.logging import indent_log -from pip._internal.utils.setuptools_build import make_setuptools_develop_args -from pip._internal.utils.subprocess import call_subprocess -from pip._internal.utils.typing import MYPY_CHECK_RUNNING - -if MYPY_CHECK_RUNNING: - from typing import List, Optional, Sequence - - from pip._internal.build_env import BuildEnvironment - - -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 - """Install a package in editable mode. Most arguments are pass-through - to setuptools. - """ - 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, - use_user_site=use_user_site, - ) - - with indent_log(): - with build_env: - call_subprocess( - args, - cwd=unpacked_source_directory, - ) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/operations/install/legacy.py b/venv/lib/python3.8/site-packages/pip/_internal/operations/install/legacy.py deleted file mode 100644 index 2d4adc4..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/operations/install/legacy.py +++ /dev/null @@ -1,129 +0,0 @@ -"""Legacy installation process, i.e. `setup.py install`. -""" - -import logging -import os -from distutils.util import change_root - -from pip._internal.utils.deprecation import deprecated -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 -from pip._internal.utils.typing import MYPY_CHECK_RUNNING - -if MYPY_CHECK_RUNNING: - from typing import List, Optional, Sequence - - from pip._internal.models.scheme import Scheme - from pip._internal.req.req_install import InstallRequirement - - -logger = logging.getLogger(__name__) - - -def install( - install_req, # type: InstallRequirement - 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 -): - # type: (...) -> None - # 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) + \ - install_req.options.get('global_options', []) - install_options = list(install_options) + \ - install_req.options.get('install_options', []) - - header_dir = scheme.headers - - with TempDirectory(kind="record") as temp_dir: - record_filename = os.path.join(temp_dir.path, 'install-record.txt') - install_args = make_setuptools_install_args( - install_req.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=install_req.isolated, - pycompile=pycompile, - ) - - runner = runner_with_spinner_message( - "Running setup.py install for {}".format(install_req.name) - ) - with indent_log(), install_req.build_env: - runner( - cmd=install_args, - cwd=install_req.unpacked_source_directory, - ) - - if not os.path.exists(record_filename): - logger.debug('Record file %s not found', record_filename) - return - install_req.install_succeeded = True - - # 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: - deprecated( - reason=( - "{} did not indicate that it installed an " - ".egg-info directory. Only setup.py projects " - "generating .egg-info directories are supported." - ).format(install_req), - replacement=( - "for maintainers: updating the setup.py of {0}. " - "For users: contact the maintainers of {0} to let " - "them know to update their setup.py.".format( - install_req.name - ) - ), - gone_in="20.2", - issue=6998, - ) - # FIXME: put the record somewhere - return - 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') diff --git a/venv/lib/python3.8/site-packages/pip/_internal/operations/install/wheel.py b/venv/lib/python3.8/site-packages/pip/_internal/operations/install/wheel.py deleted file mode 100644 index aac975c..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/operations/install/wheel.py +++ /dev/null @@ -1,615 +0,0 @@ -"""Support for installing and building the "wheel" binary package format. -""" - -# The following comment should be removed at some point in the future. -# mypy: strict-optional=False - -from __future__ import absolute_import - -import collections -import compileall -import csv -import logging -import os.path -import re -import shutil -import stat -import sys -import warnings -from base64 import urlsafe_b64encode -from zipfile import ZipFile - -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.six import StringIO - -from pip._internal.exceptions import InstallationError -from pip._internal.locations import get_major_minor_version -from pip._internal.utils.misc import captured_stdout, ensure_dir, hash_file -from pip._internal.utils.temp_dir import TempDirectory -from pip._internal.utils.typing import MYPY_CHECK_RUNNING -from pip._internal.utils.unpacking import unpack_file -from pip._internal.utils.wheel import parse_wheel - -if MYPY_CHECK_RUNNING: - from email.message import Message - from typing import ( - Dict, List, Optional, Sequence, Tuple, IO, Text, Any, - Iterable, Callable, Set, - ) - - from pip._internal.models.scheme import Scheme - - InstalledCSVRow = Tuple[str, ...] - - -logger = logging.getLogger(__name__) - - -def normpath(src, p): - # type: (str, str) -> str - return os.path.relpath(src, p).replace(os.path.sep, '/') - - -def rehash(path, blocksize=1 << 20): - # type: (str, int) -> 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('=') - # unicode/str python2 issues - return (digest, str(length)) # type: ignore - - -def open_for_csv(name, mode): - # type: (str, Text) -> IO[Any] - if sys.version_info[0] < 3: - nl = {} # type: Dict[str, Any] - bin = 'b' - else: - nl = {'newline': ''} # type: Dict[str, Any] - bin = '' - return open(name, mode + bin, **nl) - - -def fix_script(path): - # type: (str) -> Optional[bool] - """Replace #!python with #!/path/to/python - Return True if file was changed. - """ - # XXX RECORD hashes will need to be updated - if os.path.isfile(path): - with open(path, 'rb') as script: - firstline = script.readline() - if not firstline.startswith(b'#!python'): - return False - exename = sys.executable.encode(sys.getfilesystemencoding()) - firstline = b'#!' + exename + os.linesep.encode("ascii") - rest = script.read() - with open(path, 'wb') as script: - script.write(firstline) - script.write(rest) - return True - return None - - -def wheel_root_is_purelib(metadata): - # type: (Message) -> bool - return metadata.get("Root-Is-Purelib", "").lower() == "true" - - -def get_entrypoints(filename): - # type: (str) -> Tuple[Dict[str, str], Dict[str, str]] - if not os.path.exists(filename): - return {}, {} - - # This is done because you can pass a string to entry_points wrappers which - # means that they may or may not be valid INI files. The attempt here is to - # strip leading and trailing whitespace in order to make them valid INI - # files. - with open(filename) as fp: - data = StringIO() - for line in fp: - data.write(line.strip()) - data.write("\n") - data.seek(0) - - # get the entry points and then the script names - entry_points = pkg_resources.EntryPoint.parse_map(data) - console = entry_points.get('console_scripts', {}) - gui = entry_points.get('gui_scripts', {}) - - 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] - """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. - """ - if not scripts: - return None - - # Group scripts by the path they were installed in - grouped_by_dir = collections.defaultdict(set) # type: Dict[str, Set[str]] - for destfile in scripts: - parent_dir = os.path.dirname(destfile) - script_name = os.path.basename(destfile) - grouped_by_dir[parent_dir].add(script_name) - - # 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) - ] - # 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]] - 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] - if len(sorted_scripts) == 1: - start_text = "script {} is".format(sorted_scripts[0]) - else: - start_text = "scripts {} are".format( - ", ".join(sorted_scripts[:-1]) + " and " + sorted_scripts[-1] - ) - - msg_lines.append( - "The {} installed in '{}' which is not on PATH." - .format(start_text, parent_dir) - ) - - last_line_fmt = ( - "Consider adding {} to PATH or, if you prefer " - "to suppress this warning, use --no-warn-script-location." - ) - if len(msg_lines) == 1: - msg_lines.append(last_line_fmt.format("this directory")) - else: - msg_lines.append(last_line_fmt.format("these directories")) - - # Add a note if any directory starts with ~ - warn_for_tilde = any( - i[0] == "~" for i in os.environ.get("PATH", "").split(os.pathsep) if i - ) - if warn_for_tilde: - tilde_warning_msg = ( - "NOTE: The current PATH contains path(s) starting with `~`, " - "which may not be expanded by all applications." - ) - msg_lines.append(tilde_warning_msg) - - # Returns the formatted multiline message - return "\n".join(msg_lines) - - -def sorted_outrows(outrows): - # type: (Iterable[InstalledCSVRow]) -> List[InstalledCSVRow] - """Return the given rows of a RECORD file in sorted order. - - Each row is a 3-tuple (path, hash, size) and corresponds to a record of - a RECORD file (see PEP 376 and PEP 427 for details). For the rows - passed to this function, the size can be an integer as an int or string, - or the empty string. - """ - # Normally, there should only be one row per path, in which case the - # second and third elements don't come into play when sorting. - # However, in cases in the wild where a path might happen to occur twice, - # we don't want the sort operation to trigger an error (but still want - # determinism). Since the third element can be an int or string, we - # coerce each element to a string to avoid a TypeError in this case. - # For additional background, see-- - # https://github.com/pypa/pip/issues/5868 - return sorted(outrows, key=lambda row: tuple(str(x) for x in row)) - - -def get_csv_rows_for_installed( - old_csv_rows, # type: Iterable[List[str]] - installed, # type: Dict[str, str] - changed, # type: Set[str] - generated, # type: List[str] - lib_dir, # type: str -): - # type: (...) -> List[InstalledCSVRow] - """ - :param installed: A map from archive RECORD path to installation RECORD - path. - """ - installed_rows = [] # type: List[InstalledCSVRow] - for row in old_csv_rows: - if len(row) > 3: - logger.warning( - 'RECORD line has more than three elements: {}'.format(row) - ) - # Make a copy because we are mutating the row. - row = list(row) - old_path = row[0] - new_path = installed.pop(old_path, old_path) - row[0] = new_path - if new_path in changed: - digest, length = rehash(new_path) - row[1] = digest - row[2] = length - installed_rows.append(tuple(row)) - for f in generated: - digest, length = rehash(f) - installed_rows.append((normpath(f, lib_dir), digest, str(length))) - for f in installed: - installed_rows.append((installed[f], '', '')) - return installed_rows - - -class MissingCallableSuffix(Exception): - pass - - -def _raise_for_invalid_entrypoint(specification): - # type: (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] - _raise_for_invalid_entrypoint(specification) - return super(PipScriptMaker, self).make(specification, options) - - -def install_unpacked_wheel( - name, # type: str - wheeldir, # type: str - wheel_zip, # type: ZipFile - scheme, # type: Scheme - req_description, # type: str - pycompile=True, # type: bool - warn_script_location=True # type: bool -): - # type: (...) -> None - """Install a wheel. - - :param name: Name of the project to install - :param wheeldir: Base directory of the unpacked wheel - :param wheel_zip: open ZipFile for wheel being installed - :param scheme: Distutils scheme dictating the install directories - :param req_description: String used in place of the requirement, for - logging - :param pycompile: Whether to byte-compile installed Python files - :param warn_script_location: Whether to check that scripts are installed - into a directory on PATH - :raises UnsupportedWheel: - * when the directory holds an unpacked wheel with incompatible - Wheel-Version - * when the .dist-info dir does not match the wheel - """ - # TODO: Investigate and break this up. - # TODO: Look into moving this into a dedicated class for representing an - # installation. - - source = wheeldir.rstrip(os.path.sep) + os.path.sep - - info_dir, metadata = parse_wheel(wheel_zip, name) - - if wheel_root_is_purelib(metadata): - lib_dir = scheme.purelib - else: - lib_dir = scheme.platlib - - subdirs = os.listdir(source) - data_dirs = [s for s in subdirs if s.endswith('.data')] - - # Record details of the files moved - # 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[str, str] - changed = set() - generated = [] # type: List[str] - - # Compile all of the pyc files that we're going to be installing - if pycompile: - with captured_stdout() as stdout: - with warnings.catch_warnings(): - warnings.filterwarnings('ignore') - compileall.compile_dir(source, force=True, quiet=True) - logger.debug(stdout.getvalue()) - - def record_installed(srcfile, destfile, modified=False): - # type: (str, str, bool) -> None - """Map archive RECORD paths to installation RECORD paths.""" - oldpath = normpath(srcfile, wheeldir) - newpath = normpath(destfile, lib_dir) - installed[oldpath] = newpath - if modified: - changed.add(destfile) - - def clobber( - source, # type: str - dest, # type: str - is_base, # type: bool - fixer=None, # type: Optional[Callable[[str], Any]] - filter=None # type: Optional[Callable[[str], bool]] - ): - # type: (...) -> None - ensure_dir(dest) # common for the 'include' path - - for dir, subdirs, files in os.walk(source): - basedir = dir[len(source):].lstrip(os.path.sep) - destdir = os.path.join(dest, basedir) - if is_base and basedir == '': - subdirs[:] = [s for s in subdirs if not s.endswith('.data')] - for f in files: - # Skip unwanted files - if filter and filter(f): - continue - srcfile = os.path.join(dir, f) - destfile = os.path.join(dest, basedir, f) - # directory creation is lazy and after the file filtering above - # to ensure we don't install empty dirs; empty dirs can't be - # uninstalled. - ensure_dir(destdir) - - # copyfile (called below) truncates the destination if it - # exists and then writes the new contents. This is fine in most - # cases, but can cause a segfault if pip has loaded a shared - # object (e.g. from pyopenssl through its vendored urllib3) - # Since the shared object is mmap'd an attempt to call a - # symbol in it will then cause a segfault. Unlinking the file - # allows writing of new contents while allowing the process to - # continue to use the old copy. - if os.path.exists(destfile): - os.unlink(destfile) - - # We use copyfile (not move, copy, or copy2) to be extra sure - # that we are not moving directories over (copyfile fails for - # directories) as well as to ensure that we are not copying - # over any metadata because we want more control over what - # metadata we actually copy over. - shutil.copyfile(srcfile, destfile) - - # Copy over the metadata for the file, currently this only - # includes the atime and mtime. - st = os.stat(srcfile) - if hasattr(os, "utime"): - os.utime(destfile, (st.st_atime, st.st_mtime)) - - # If our file is executable, then make our destination file - # executable. - if os.access(srcfile, os.X_OK): - st = os.stat(srcfile) - permissions = ( - st.st_mode | stat.S_IXUSR | stat.S_IXGRP | stat.S_IXOTH - ) - os.chmod(destfile, permissions) - - changed = False - if fixer: - changed = fixer(destfile) - record_installed(srcfile, destfile, changed) - - clobber(source, lib_dir, True) - - dest_info_dir = os.path.join(lib_dir, info_dir) - - # Get the defined entry points - ep_file = os.path.join(dest_info_dir, 'entry_points.txt') - console, gui = get_entrypoints(ep_file) - - def is_entrypoint_wrapper(name): - # type: (str) -> bool - # EP, EP.exe and EP-script.py are scripts generated for - # entry point EP by setuptools - if name.lower().endswith('.exe'): - matchname = name[:-4] - 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) - - for datadir in data_dirs: - fixer = None - filter = None - for subdir in os.listdir(os.path.join(wheeldir, datadir)): - fixer = None - if subdir == 'scripts': - fixer = fix_script - filter = is_entrypoint_wrapper - source = os.path.join(wheeldir, datadir, subdir) - dest = getattr(scheme, subdir) - clobber(source, dest, False, fixer=fixer, filter=filter) - - maker = PipScriptMaker(None, scheme.scripts) - - # Ensure old scripts are overwritten. - # See https://github.com/pypa/pip/issues/1800 - maker.clobber = True - - # 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 = {''} - - # This is required because otherwise distlib creates scripts that are not - # executable. - # See https://bitbucket.org/pypa/distlib/issue/32/ - maker.set_mode = True - - scripts_to_generate = [] - - # Special case pip and setuptools to generate versioned wrappers - # - # The issue is that some projects (specifically, pip and setuptools) use - # code in setup.py to create "versioned" entry points - pip2.7 on Python - # 2.7, pip3.3 on Python 3.3, etc. But these entry points are baked into - # the wheel metadata at build time, and so if the wheel is installed with - # a *different* version of Python the entry points will be wrong. The - # correct fix for this is to enhance the metadata to be able to describe - # such versioned entry points, but that won't happen till Metadata 2.0 is - # available. - # In the meantime, projects using versioned entry points will either have - # incorrect versioned entry points, or they will not be able to distribute - # "universal" wheels (i.e., they will need a wheel per Python version). - # - # Because setuptools and pip are bundled with _ensurepip and virtualenv, - # we need to use universal wheels. So, as a stopgap until Metadata 2.0, we - # override the versioned entry points in the wheel and generate the - # correct ones. This code is purely a short-term measure until Metadata 2.0 - # is available. - # - # To add the level of hack in this section of code, in order to support - # ensurepip this code will look for an ``ENSUREPIP_OPTIONS`` environment - # variable which will control which version scripts get installed. - # - # ENSUREPIP_OPTIONS=altinstall - # - Only pipX.Y and easy_install-X.Y will be generated and installed - # ENSUREPIP_OPTIONS=install - # - pipX.Y, pipX, easy_install-X.Y will be generated and installed. Note - # that this option is technically if ENSUREPIP_OPTIONS is set and is - # not altinstall - # DEFAULT - # - The default behavior is to install pip, pipX, pipX.Y, easy_install - # and easy_install-X.Y. - pip_script = console.pop('pip', None) - if pip_script: - if "ENSUREPIP_OPTIONS" not in os.environ: - scripts_to_generate.append('pip = ' + pip_script) - - if os.environ.get("ENSUREPIP_OPTIONS", "") != "altinstall": - scripts_to_generate.append( - 'pip%s = %s' % (sys.version_info[0], pip_script) - ) - - scripts_to_generate.append( - 'pip%s = %s' % (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)] - for k in pip_ep: - del console[k] - 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-%s = %s' % ( - 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) - ] - for k in easy_install_ep: - del console[k] - - # Generate the console and GUI entry points specified in the wheel - scripts_to_generate.extend( - '%s = %s' % kv for kv in console.items() - ) - - gui_scripts_to_generate = [ - '%s = %s' % kv for kv in gui.items() - ] - - generated_console_scripts = [] # type: List[str] - - try: - 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}) - ) - except MissingCallableSuffix as e: - entry = e.args[0] - raise InstallationError( - "Invalid script entry point: {} for req: {} - A callable " - "suffix is required. Cf https://packaging.python.org/" - "specifications/entry-points/#use-for-scripts for more " - "information.".format(entry, req_description) - ) - - if warn_script_location: - msg = message_about_scripts_not_on_PATH(generated_console_scripts) - if msg is not None: - logger.warning(msg) - - # Record pip as the installer - installer = os.path.join(dest_info_dir, 'INSTALLER') - temp_installer = os.path.join(dest_info_dir, 'INSTALLER.pip') - with open(temp_installer, 'wb') as installer_file: - installer_file.write(b'pip\n') - shutil.move(temp_installer, installer) - generated.append(installer) - - # Record details of all files installed - record = os.path.join(dest_info_dir, 'RECORD') - temp_record = os.path.join(dest_info_dir, 'RECORD.pip') - with open_for_csv(record, 'r') as record_in: - with open_for_csv(temp_record, 'w+') as record_out: - reader = csv.reader(record_in) - outrows = get_csv_rows_for_installed( - reader, installed=installed, changed=changed, - generated=generated, lib_dir=lib_dir, - ) - writer = csv.writer(record_out) - # Sort to simplify testing. - for row in sorted_outrows(outrows): - writer.writerow(row) - shutil.move(temp_record, record) - - -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 - _temp_dir_for_testing=None, # type: Optional[str] -): - # type: (...) -> None - with TempDirectory( - path=_temp_dir_for_testing, kind="unpacked-wheel" - ) as unpacked_dir, ZipFile(wheel_path, allowZip64=True) as z: - unpack_file(wheel_path, unpacked_dir.path) - install_unpacked_wheel( - name=name, - wheeldir=unpacked_dir.path, - wheel_zip=z, - scheme=scheme, - req_description=req_description, - pycompile=pycompile, - warn_script_location=warn_script_location, - ) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/operations/prepare.py b/venv/lib/python3.8/site-packages/pip/_internal/operations/prepare.py deleted file mode 100644 index 0b61f20..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/operations/prepare.py +++ /dev/null @@ -1,591 +0,0 @@ -"""Prepares a distribution for installation -""" - -# The following comment should be removed at some point in the future. -# mypy: strict-optional=False - -import logging -import mimetypes -import os -import shutil -import sys - -from pip._vendor import requests -from pip._vendor.six import PY2 - -from pip._internal.distributions import ( - make_distribution_for_install_requirement, -) -from pip._internal.distributions.installed import InstalledDistribution -from pip._internal.exceptions import ( - DirectoryUrlHashUnsupported, - HashMismatch, - HashUnpinned, - InstallationError, - PreviousBuildDirError, - VcsHashUnsupported, -) -from pip._internal.utils.filesystem import copy2_fixed -from pip._internal.utils.hashes import MissingHashes -from pip._internal.utils.logging import indent_log -from pip._internal.utils.marker_files import write_delete_marker_file -from pip._internal.utils.misc import ( - ask_path_exists, - backup_dir, - display_path, - hide_url, - path_to_display, - rmtree, -) -from pip._internal.utils.temp_dir import TempDirectory -from pip._internal.utils.typing import MYPY_CHECK_RUNNING -from pip._internal.utils.unpacking import unpack_file -from pip._internal.vcs import vcs - -if MYPY_CHECK_RUNNING: - from typing import ( - Callable, List, Optional, Tuple, - ) - - from mypy_extensions import TypedDict - - from pip._internal.distributions import AbstractDistribution - from pip._internal.index.package_finder import PackageFinder - from pip._internal.models.link import Link - from pip._internal.network.download import Downloader - from pip._internal.req.req_install import InstallRequirement - from pip._internal.req.req_tracker import RequirementTracker - from pip._internal.utils.hashes import Hashes - - if PY2: - CopytreeKwargs = TypedDict( - 'CopytreeKwargs', - { - 'ignore': Callable[[str, List[str]], List[str]], - 'symlinks': bool, - }, - total=False, - ) - else: - CopytreeKwargs = TypedDict( - 'CopytreeKwargs', - { - 'copy_function': Callable[[str, str], None], - 'ignore': Callable[[str, List[str]], List[str]], - 'ignore_dangling_symlinks': bool, - 'symlinks': bool, - }, - total=False, - ) - -logger = logging.getLogger(__name__) - - -def _get_prepared_distribution( - req, # type: InstallRequirement - req_tracker, # type: RequirementTracker - finder, # type: PackageFinder - build_isolation # type: bool -): - # type: (...) -> AbstractDistribution - """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 - - -def unpack_vcs_link(link, location): - # type: (Link, str) -> 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)) - - -def _copy_file(filename, location, link): - # type: (str, str, Link) -> None - copy = True - download_location = os.path.join(location, link.filename) - if os.path.exists(download_location): - response = ask_path_exists( - 'The file {} exists. (i)gnore, (w)ipe, (b)ackup, (a)abort'.format( - display_path(download_location) - ), - ('i', 'w', 'b', 'a'), - ) - if response == 'i': - copy = False - elif response == 'w': - logger.warning('Deleting %s', display_path(download_location)) - os.remove(download_location) - elif response == 'b': - dest_file = backup_dir(download_location) - logger.warning( - 'Backing up %s to %s', - display_path(download_location), - display_path(dest_file), - ) - shutil.move(download_location, dest_file) - elif response == 'a': - sys.exit(-1) - if copy: - shutil.copy(filename, download_location) - logger.info('Saved %s', display_path(download_location)) - - -def unpack_http_url( - link, # type: Link - location, # type: str - downloader, # type: Downloader - download_dir=None, # type: Optional[str] - hashes=None, # type: Optional[Hashes] -): - # type: (...) -> str - 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 - ) - - if already_downloaded_path: - from_path = already_downloaded_path - content_type = mimetypes.guess_type(from_path)[0] - else: - # let's download to a tmp dir - from_path, content_type = _download_http_url( - link, downloader, temp_dir.path, hashes - ) - - # unpack the archive to the build dir location. even when only - # downloading archives, they have to be unpacked to parse dependencies - unpack_file(from_path, location, content_type) - - return from_path - - -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), - path_to_display(src), - path_to_display(dest), - ) - - -def _copy_source_tree(source, target): - # type: (str, str) -> None - def ignore(d, names): - # type: (str, List[str]) -> List[str] - # 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 - return ['.tox', '.nox'] if d == source else [] - - kwargs = dict(ignore=ignore, symlinks=True) # type: CopytreeKwargs - - if not PY2: - # Python 2 does not support copy_function, so we only ignore - # errors on special file copy in Python 3. - kwargs['copy_function'] = _copy2_ignoring_special_files - - shutil.copytree(source, target, **kwargs) - - -def unpack_file_url( - link, # type: Link - location, # type: str - download_dir=None, # type: Optional[str] - hashes=None # type: Optional[Hashes] -): - # type: (...) -> Optional[str] - """Unpack link into location. - """ - link_path = link.file_path - # If it's a url to a local directory - if link.is_existing_dir(): - if os.path.isdir(location): - rmtree(location) - _copy_source_tree(link_path, location) - return None - - # 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 - ) - - if already_downloaded_path: - from_path = already_downloaded_path - else: - from_path = link_path - - # If --require-hashes is off, `hashes` is either empty, the - # link's embedded hash, or MissingHashes; it is required to - # match. If --require-hashes is on, we are satisfied by any - # hash in `hashes` matching: a URL-based or an option-based - # one; no internet-sourced hash will be in `hashes`. - if hashes: - hashes.check_against_path(from_path) - - content_type = mimetypes.guess_type(from_path)[0] - - # unpack the archive to the build dir location. even when only downloading - # archives, they have to be unpacked to parse dependencies - unpack_file(from_path, location, content_type) - - return from_path - - -def unpack_url( - link, # type: Link - location, # type: str - downloader, # type: Downloader - download_dir=None, # type: Optional[str] - hashes=None, # type: Optional[Hashes] -): - # type: (...) -> Optional[str] - """Unpack link into location, downloading if required. - - :param hashes: A Hashes object, one of whose embedded hashes must match, - or HashMismatch will be raised. If the Hashes is empty, no matches are - required, and unhashable types of requirements (like VCS ones, which - would ordinarily raise HashUnsupported) are allowed. - """ - # non-editable vcs urls - if link.is_vcs: - unpack_vcs_link(link, location) - return None - - # file urls - elif link.is_file: - return unpack_file_url(link, location, download_dir, hashes=hashes) - - # http urls - else: - return unpack_http_url( - link, - location, - downloader, - download_dir, - hashes=hashes, - ) - - -def _download_http_url( - link, # type: Link - downloader, # type: Downloader - temp_dir, # type: str - hashes, # type: Optional[Hashes] -): - # type: (...) -> Tuple[str, str] - """Download link url into temp_dir using provided session""" - download = downloader(link) - - file_path = os.path.join(temp_dir, download.filename) - with open(file_path, 'wb') as content_file: - for chunk in download.chunks: - content_file.write(chunk) - - if hashes: - hashes.check_against_path(file_path) - - return file_path, download.response.headers.get('content-type', '') - - -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 - """ - download_path = os.path.join(download_dir, link.filename) - - if not os.path.exists(download_path): - return None - - # If already downloaded, does its hash match? - 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 - ) - os.unlink(download_path) - return None - return download_path - - -class RequirementPreparer(object): - """Prepares a Requirement - """ - - def __init__( - self, - build_dir, # type: str - download_dir, # type: Optional[str] - src_dir, # type: str - wheel_download_dir, # type: Optional[str] - build_isolation, # type: bool - req_tracker, # type: RequirementTracker - downloader, # type: Downloader - finder, # type: PackageFinder - require_hashes, # type: bool - use_user_site, # type: bool - ): - # type: (...) -> None - super(RequirementPreparer, self).__init__() - - self.src_dir = src_dir - self.build_dir = build_dir - self.req_tracker = req_tracker - self.downloader = downloader - self.finder = finder - - # Where still-packed archives should be written to. If None, they are - # not saved, and are deleted immediately after unpacking. - self.download_dir = download_dir - - # Where still-packed .whl files should be written to. If None, they are - # written to the download_dir parameter. Separate to download_dir to - # permit only keeping wheel archives for pip wheel. - self.wheel_download_dir = wheel_download_dir - - # NOTE - # download_dir and wheel_download_dir overlap semantically and may - # be combined if we're willing to have non-wheel archives present in - # the wheelhouse output by 'pip wheel'. - - # Is build isolation allowed? - self.build_isolation = build_isolation - - # Should hash-checking be required? - self.require_hashes = require_hashes - - # Should install in user site-packages? - self.use_user_site = use_user_site - - @property - def _download_should_save(self): - # type: () -> bool - if not self.download_dir: - return False - - if os.path.exists(self.download_dir): - return True - - logger.critical('Could not find download directory') - raise InstallationError( - "Could not find or access download directory '{}'" - .format(self.download_dir)) - - def prepare_linked_requirement( - self, - req, # type: InstallRequirement - ): - # type: (...) -> AbstractDistribution - """Prepare a requirement that would be obtained from req.link - """ - assert req.link - link = req.link - - # TODO: Breakup into smaller functions - if link.scheme == 'file': - path = link.file_path - logger.info('Processing %s', display_path(path)) - else: - logger.info('Collecting %s', req.req or req) - - with indent_log(): - # @@ if filesystem packages are not marked - # editable in a req, a non deterministic error - # occurs when the script attempts to unpack the - # build directory - # Since source_dir is only set for editable requirements. - assert req.source_dir is None - req.ensure_has_source_dir(self.build_dir) - # If a checkout exists, it's unwise to keep going. version - # inconsistencies are logged later, but do not fail the - # 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')): - raise PreviousBuildDirError( - "pip can't proceed with requirements '{}' due to a" - " pre-existing build directory ({}). This is " - "likely due to a previous installation that failed" - ". pip is being responsible and not assuming it " - "can delete this. Please delete it and try again." - .format(req, req.source_dir) - ) - - # Now that we have the real link, we can tell what kind of - # requirements we have and raise some more informative errors - # than otherwise. (For example, we can raise VcsHashUnsupported - # for a VCS URL rather than HashMissing.) - if self.require_hashes: - # We could check these first 2 conditions inside - # unpack_url and save repetition of conditions, but then - # we would report less-useful error messages for - # unhashable requirements, complaining that there's no - # hash provided. - if link.is_vcs: - raise VcsHashUnsupported() - elif link.is_existing_dir(): - raise DirectoryUrlHashUnsupported() - if not req.original_link and not req.is_pinned: - # Unpinned packages are asking for trouble when a new - # version is uploaded. This isn't a security check, but - # it saves users a surprising hash mismatch in the - # future. - # - # file:/// URLs aren't pinnable, so don't complain - # about them not being pinned. - raise HashUnpinned() - - hashes = req.hashes(trust_internet=not self.require_hashes) - if self.require_hashes and not hashes: - # Known-good hashes are missing for this requirement, so - # shim it with a facade object that will provoke hash - # computation and then raise a HashMissing exception - # showing the user what the hash should be. - hashes = MissingHashes() - - download_dir = self.download_dir - if link.is_wheel and self.wheel_download_dir: - # when doing 'pip wheel` we download wheels to a - # dedicated dir. - download_dir = self.wheel_download_dir - - try: - local_path = unpack_url( - link, req.source_dir, self.downloader, download_dir, - hashes=hashes, - ) - except requests.HTTPError as exc: - logger.critical( - 'Could not install requirement %s because of error %s', - req, - exc, - ) - raise InstallationError( - 'Could not install requirement {} because of HTTP ' - 'error {} for URL {}'.format(req, exc, link) - ) - - # For use in later processing, preserve the file path on the - # requirement. - if local_path: - req.local_file_path = local_path - - if link.is_wheel: - if download_dir: - # When downloading, we only unpack wheels to get - # metadata. - autodelete_unpacked = True - else: - # When installing a wheel, we use the unpacked - # wheel. - autodelete_unpacked = False - else: - # We always delete unpacked sdists after pip runs. - autodelete_unpacked = True - if autodelete_unpacked: - write_delete_marker_file(req.source_dir) - - abstract_dist = _get_prepared_distribution( - req, self.req_tracker, self.finder, self.build_isolation, - ) - - if download_dir: - if link.is_existing_dir(): - logger.info('Link is a directory, ignoring download_dir') - elif local_path and not os.path.exists( - os.path.join(download_dir, link.filename) - ): - _copy_file(local_path, download_dir, link) - - if self._download_should_save: - # Make a .zip of the source_dir we already created. - if link.is_vcs: - req.archive(self.download_dir) - return abstract_dist - - def prepare_editable_requirement( - self, - req, # type: InstallRequirement - ): - # type: (...) -> AbstractDistribution - """Prepare an editable requirement - """ - assert req.editable, "cannot prepare a non-editable req as editable" - - 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) - ) - req.ensure_has_source_dir(self.src_dir) - req.update_editable(not self._download_should_save) - - abstract_dist = _get_prepared_distribution( - req, self.req_tracker, self.finder, self.build_isolation, - ) - - if self._download_should_save: - req.archive(self.download_dir) - req.check_if_exists(self.use_user_site) - - return abstract_dist - - def prepare_installed_requirement( - self, - req, # type: InstallRequirement - skip_reason # type: str - ): - # type: (...) -> AbstractDistribution - """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 - ) - 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.' - ) - abstract_dist = InstalledDistribution(req) - - return abstract_dist diff --git a/venv/lib/python3.8/site-packages/pip/_internal/pep425tags.py b/venv/lib/python3.8/site-packages/pip/_internal/pep425tags.py deleted file mode 100644 index a2386ee..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/pep425tags.py +++ /dev/null @@ -1,167 +0,0 @@ -"""Generate and work with PEP 425 Compatibility Tags.""" -from __future__ import absolute_import - -import logging -import re - -from pip._vendor.packaging.tags import ( - Tag, - compatible_tags, - cpython_tags, - generic_tags, - interpreter_name, - interpreter_version, - mac_platforms, -) - -from pip._internal.utils.typing import MYPY_CHECK_RUNNING - -if MYPY_CHECK_RUNNING: - from typing import List, Optional, Tuple - - from pip._vendor.packaging.tags import PythonVersion - -logger = logging.getLogger(__name__) - -_osx_arch_pat = re.compile(r'(.+)_(\d+)_(\d+)_(.+)') - - -def version_info_to_nodot(version_info): - # type: (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] - match = _osx_arch_pat.match(arch) - if match: - name, major, minor, actual_arch = match.groups() - mac_version = (int(major), int(minor)) - arches = [ - # Since we have always only checked that the platform starts - # with "macosx", for backwards-compatibility we extract the - # actual prefix provided by the user in case they provided - # something like "macosxcustom_". It may be good to remove - # this as undocumented or deprecate it in the future. - '{}_{}'.format(name, arch[len('macosx_'):]) - for arch in mac_platforms(mac_version, actual_arch) - ] - else: - # arch pattern didn't match (?!) - arches = [arch] - return arches - - -def _custom_manylinux_platforms(arch): - # type: (str) -> List[str] - arches = [arch] - arch_prefix, arch_sep, arch_suffix = arch.partition('_') - if arch_prefix == 'manylinux2014': - # manylinux1/manylinux2010 wheels run on most manylinux2014 systems - # with the exception of wheels depending on ncurses. PEP 599 states - # manylinux1/manylinux2010 wheels should be considered - # manylinux2014 wheels: - # https://www.python.org/dev/peps/pep-0599/#backwards-compatibility-with-manylinux2010-wheels - if arch_suffix in {'i686', 'x86_64'}: - arches.append('manylinux2010' + arch_sep + arch_suffix) - arches.append('manylinux1' + arch_sep + arch_suffix) - elif arch_prefix == 'manylinux2010': - # manylinux1 wheels run on most manylinux2010 systems with the - # exception of wheels depending on ncurses. PEP 571 states - # manylinux1 wheels should be considered manylinux2010 wheels: - # https://www.python.org/dev/peps/pep-0571/#backwards-compatibility-with-manylinux1-wheels - arches.append('manylinux1' + arch_sep + arch_suffix) - return arches - - -def _get_custom_platforms(arch): - # type: (str) -> List[str] - arch_prefix, arch_sep, arch_suffix = arch.partition('_') - if arch.startswith('macosx'): - arches = _mac_platforms(arch) - elif arch_prefix in ['manylinux2014', 'manylinux2010']: - arches = _custom_manylinux_platforms(arch) - else: - arches = [arch] - return arches - - -def _get_python_version(version): - # type: (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 - if implementation is None: - implementation = interpreter_name() - if version is None: - version = interpreter_version() - return "{}{}".format(implementation, version) - - -def get_supported( - version=None, # type: Optional[str] - platform=None, # type: Optional[str] - impl=None, # type: Optional[str] - abi=None # type: Optional[str] -): - # type: (...) -> List[Tag] - """Return a list of supported tags for each version specified in - `versions`. - - :param version: a string version, of the form "33" or "32", - or None. The version will be assumed to support our ABI. - :param platform: specify the exact platform you want valid - tags for, or None. If None, use the local system platform. - :param impl: specify the exact implementation you want valid - tags for, or None. If None, use the local interpreter impl. - :param abi: specify the exact abi you want valid - tags for, or None. If None, use the local interpreter abi. - """ - supported = [] # type: List[Tag] - - python_version = None # type: Optional[PythonVersion] - if version is not None: - python_version = _get_python_version(version) - - interpreter = _get_custom_interpreter(impl, version) - - abis = None # type: Optional[List[str]] - if abi is not None: - abis = [abi] - - platforms = None # type: Optional[List[str]] - if platform is not None: - platforms = _get_custom_platforms(platform) - - is_cpython = (impl or interpreter_name()) == "cp" - if is_cpython: - supported.extend( - cpython_tags( - python_version=python_version, - abis=abis, - platforms=platforms, - ) - ) - else: - supported.extend( - generic_tags( - interpreter=interpreter, - abis=abis, - platforms=platforms, - ) - ) - supported.extend( - compatible_tags( - python_version=python_version, - interpreter=interpreter, - platforms=platforms, - ) - ) - - return supported diff --git a/venv/lib/python3.8/site-packages/pip/_internal/pyproject.py b/venv/lib/python3.8/site-packages/pip/_internal/pyproject.py deleted file mode 100644 index 6b4faf7..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/pyproject.py +++ /dev/null @@ -1,196 +0,0 @@ -from __future__ import absolute_import - -import io -import os -import sys -from collections import namedtuple - -from pip._vendor import six, toml -from pip._vendor.packaging.requirements import InvalidRequirement, Requirement - -from pip._internal.exceptions import InstallationError -from pip._internal.utils.typing import MYPY_CHECK_RUNNING - -if MYPY_CHECK_RUNNING: - from typing import Any, Optional, List - - -def _is_list_of_str(obj): - # type: (Any) -> bool - return ( - isinstance(obj, list) and - all(isinstance(item, six.string_types) for item in obj) - ) - - -def make_pyproject_path(unpacked_source_directory): - # type: (str) -> str - path = os.path.join(unpacked_source_directory, 'pyproject.toml') - - # Python2 __file__ should not be unicode - if six.PY2 and isinstance(path, six.text_type): - path = path.encode(sys.getfilesystemencoding()) - - return 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] - """Load the pyproject.toml file. - - Parameters: - use_pep517 - Has the user requested PEP 517 processing? None - means the user hasn't explicitly specified. - pyproject_toml - Location of the project's pyproject.toml file - setup_py - Location of the project's setup.py file - req_name - The name of the requirement we're processing (for - error reporting) - - Returns: - None if we should use the legacy code path, otherwise a tuple - ( - requirements from pyproject.toml, - name of PEP 517 backend, - requirements we should check are installed after setting - up the build environment - directory paths to import the backend from (backend-path), - relative to the project root. - ) - """ - has_pyproject = os.path.isfile(pyproject_toml) - has_setup = os.path.isfile(setup_py) - - if has_pyproject: - with io.open(pyproject_toml, encoding="utf-8") as f: - pp_toml = toml.load(f) - build_system = pp_toml.get("build-system") - else: - build_system = None - - # The following cases must use PEP 517 - # We check for use_pep517 being non-None and falsey because that means - # the user explicitly requested --no-use-pep517. The value 0 as - # opposed to False can occur when the value is provided via an - # environment variable or config file option (due to the quirk of - # strtobool() returning an integer in pip's configuration code). - if has_pyproject and not has_setup: - if use_pep517 is not None and not use_pep517: - raise InstallationError( - "Disabling PEP 517 processing is invalid: " - "project does not have a setup.py" - ) - use_pep517 = True - elif build_system and "build-backend" in build_system: - if use_pep517 is not None and not use_pep517: - raise InstallationError( - "Disabling PEP 517 processing is invalid: " - "project specifies a build backend of {} " - "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. - elif use_pep517 is None: - use_pep517 = has_pyproject - - # At this point, we know whether we're going to use PEP 517. - assert use_pep517 is not None - - # If we're using the legacy code path, there is nothing further - # for us to do here. - if not use_pep517: - return None - - if build_system is None: - # Either the user has a pyproject.toml with no build-system - # section, or the user has no pyproject.toml, but has opted in - # explicitly via --use-pep517. - # In the absence of any explicit backend specification, we - # assume the setuptools backend that most closely emulates the - # traditional direct setup.py execution, and require wheel and - # a version of setuptools that supports that backend. - - build_system = { - "requires": ["setuptools>=40.8.0", "wheel"], - "build-backend": "setuptools.build_meta:__legacy__", - } - - # If we're using PEP 517, we have build system information (either - # from pyproject.toml, or defaulted by the code above). - # Note that at this point, we do not know if the user has actually - # specified a backend, though. - assert build_system is not None - - # 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" - )) - ) - - # 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( - package=req_name, - reason="'build-system.requires' 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) - ), - ) - ) - - backend = build_system.get("build-backend") - backend_path = build_system.get("backend-path", []) - check = [] # type: 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 - # 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 - # adopted PEP 518 early for the ability to specify requirements to - # execute setup.py, but never considered needing to mention the build - # 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"] - - return BuildSystemDetails(requires, backend, check, backend_path) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/req/__init__.py b/venv/lib/python3.8/site-packages/pip/_internal/req/__init__.py deleted file mode 100644 index d2d027a..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/req/__init__.py +++ /dev/null @@ -1,92 +0,0 @@ -# The following comment should be removed at some point in the future. -# mypy: strict-optional=False - -from __future__ import absolute_import - -import logging - -from pip._internal.utils.logging import indent_log -from pip._internal.utils.typing import MYPY_CHECK_RUNNING - -from .req_file import parse_requirements -from .req_install import InstallRequirement -from .req_set import RequirementSet - -if MYPY_CHECK_RUNNING: - from typing import Any, List, Sequence - -__all__ = [ - "RequirementSet", "InstallRequirement", - "parse_requirements", "install_given_reqs", -] - -logger = logging.getLogger(__name__) - - -class InstallationResult(object): - def __init__(self, name): - # type: (str) -> None - self.name = name - - def __repr__(self): - # type: () -> str - return "InstallationResult(name={!r})".format(self.name) - - -def install_given_reqs( - to_install, # type: List[InstallRequirement] - install_options, # type: List[str] - global_options=(), # type: Sequence[str] - *args, # type: Any - **kwargs # type: Any -): - # type: (...) -> List[InstallationResult] - """ - Install everything in the given list. - - (to be called after having downloaded and unpacked the packages) - """ - - if to_install: - logger.info( - 'Installing collected packages: %s', - ', '.join([req.name for req in to_install]), - ) - - installed = [] - - with indent_log(): - for requirement in to_install: - if requirement.should_reinstall: - logger.info('Attempting uninstall: %s', requirement.name) - with indent_log(): - uninstalled_pathset = requirement.uninstall( - auto_confirm=True - ) - try: - requirement.install( - install_options, - global_options, - *args, - **kwargs - ) - except Exception: - should_rollback = ( - requirement.should_reinstall and - not requirement.install_succeeded - ) - # if install did not succeed, rollback previous uninstall - if should_rollback: - uninstalled_pathset.rollback() - raise - else: - should_commit = ( - requirement.should_reinstall and - requirement.install_succeeded - ) - if should_commit: - uninstalled_pathset.commit() - - installed.append(InstallationResult(requirement.name)) - - return installed diff --git a/venv/lib/python3.8/site-packages/pip/_internal/req/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/req/__pycache__/__init__.cpython-38.pyc deleted file mode 100644 index 69f65990bceefe360e4815e3ff00dd4a924a1a96..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2194 zcmaJCO>Y}TbY^zFUT^%7IBlu=AzVaJEm5Zj3J8^`Ra=!pF_2KTS*coWJY##){cvVy z8)BRb?G+GLgivy8FPu2>3-}FlW-aYFl zfc=4o!^?!jW!ULY065_^BoTEfMVy7qW$-mZBQjkxr!4ne*W)}p#wj~Z?xns?`c$Ki9l%4-ADT@Y-yDHivrd*lY;b>4VH zctae0Xt>9ClP~bvBkI1!*(zx-J_QR&o9c$Yo+e?Ygcn4kM5->(oFL{RR$iD4;MDwd z?ejJ7>POeFe&Vg%?sji>Z#<<_;pWJfsqm!O%mOJQkV#SCW}GTN3|F3$fm%OwTotNq zXyZz}t<76Os=ctdp%dak{y>^`pHOYaek9sV zo2dx8ZC{2(fKSM`MvvspWhk^5uOjS!RGth?`+}Sk{85E$k-2; zz?UTtj)C&L&S+cP#o;8rog2l*CugxdWN)Y7>tPm(g}4DbH@pf6r@LfAHs~G&(^+?X z`c+Nm(3cOtJ|lP9;E~l&WaO*dr#6-Ipd)u|3Yu_46QvkQ&wCwC|8L@yuiGx65WeGi z+VQ+7;aP}y)$=wpKb+pkMSSe&i!WkOB|a-_08YS8vA=9;n>i)7tA{=p3-dJx`!m?- zp8zIAwiMZ=SPZ*tS_%_#jXZ>?>@i9PWT&KzhvfTTDezt+_a5(96Klhi{amU9cnSG( zo+j{E8y2^C`CGbEzC$jOFUShHOUB26UWP(peKs+EW)t%}X!$!NzF-n%-*@CMl;96F zCqDwLRLPD#vE}1QdDq#4n{UV(iBH^}a{PuIJC#XA{towZct0uaR#gq?CA6H9%?r<8 zpI~9zud_ZoN>cSlO7h zRm>9RcL1@!=j_l4-5@`(O>=ctcXhafx@4UT+JI(xxfq>G=uIz)M#~pb6&8mD%{zW8 zcx7gEE`62?{4&s5^|lDHqps9o0<48wtt+6>}; zqRovYh$VWV=hI=5g&Z1VrXg=2T{+OG%d-nzx&Bp8zYpjW9y>i~iF z&%D9%JGRdZ_KcbAZ`-Ofi(31vWCD+ESk&BSCgAK8gAs%ipnV+2Mn6-Tgs~y9cyt+a z0a?>0VWM^pCTb^BL6~-Cm(%Q=_%9B%JpyTo1p`qRn_fQ%#q|FMqf-Pq{~OX}q(E5m zewUYG>XpHI9!f+i5;lY&C_ND1? gTt>UnHvm+b&8oDD8=y>qCq8-nW?^ELA9U+VTlK>z>% diff --git a/venv/lib/python3.8/site-packages/pip/_internal/req/__pycache__/constructors.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/req/__pycache__/constructors.cpython-38.pyc deleted file mode 100644 index 26d4e01f745a6a438b0695d36cff2cb292757b29..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 10363 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 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/req/__pycache__/req_file.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/req/__pycache__/req_file.cpython-38.pyc deleted file mode 100644 index 547438d184287a8e568ddde121e5219ec1bc3019..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 12702 zcmbVSTWlQHd7hb_om~!>7m*SrQ5TQyT$x--wl0>eDzatCk|R+xNnf;)AAo+}uz%P8t+JkfJ0Iv~cp!0xg0TX!{VLC{PrAEQ)#UlVAFf07W1)alijR zv*a!%2W^*}Gv}N+_y7L?=dHdzQ^D{2xns`R8;bHDROtNmp>PFHP}CH~Rf>wMx|*+6 zw4$a`KINy1DSqoko!{wVn%_pz;CH5&!CUvUm7Zb`_euL^rMH;lyy5p%`iuRX&-eqC z!Qx@w|-Z5}x0| za~aQ<@La+33Z7T-T*dPmo@)#%s!BwfN=N6?d;Y z`jO&}dbb{@inrZ!?tXXpBegi?9&itSq!jPC=iTRA3pLYdd&oVEwuiaxo9+?!C|b<8 z$K2z1&*J+DcMRXhyg7{ZmYa7^qW*37d3PM|ciaiLfcLxZqgLqzsO?|$Lc1Y+J18w->!>l_cKn7HjeQ$DjwqFq+M@>c|cx)(g3KT^$jZ}{eq-j^dDX3F11PrFs@ny z&etkl!1x*Kj#vz09V8G?Jw)Jlh+~*f9H-<2B{aRrQ*x4$&Eph@P>i!S z&Z`{S_PZzrIV6f{sO`Vz@YV(k?UqxY>eP+aXWOx9+m)Kz@F}0O?bU|k%P(RaV|7f& z6VsgH2$Fa31aw4MmCM&lSrpno5>8YmpaexEkuJ! zeXO_4$Xv(CM(GXhHRb)It=>?NdU4`9+89yhvC+y!Iagij5vQWu+ls2Jo^n+%D9t&9 zb?`nd$Lgd9$*P>HYps<%-?g45Ig2?&wd4f_)3orr2&!@_+>uVwvvjjMq8+fb~hKSP&B;pHs{AtZ+({s4Gy^E2`gN3s(d1J zc29w$YX+u%yF~2n;#2$QkA*FU*m=s0z_aUK{p{)USQ>L>+AgNICMNK0LVinjC8wOq zr{mqhO1a*}GErFc9>oL1>xootz(4RrJTlY4S2snF5X5rgUhL2X!LT&xV|tA<3E*Qx z0+neu&Lro`q#O5k>^C;I_8?C4sGaj0$vS%Z?ebJ{3a8mYkW7pF&~+J4Kx{(Ullxpt zWmQepz`pSJxvmdxm1GURmxyrNzZ5c?9R4B-;Oxq}y1@$N$68ARl@hgTVM@LuRTMy* zpxwvxHJ#LIpv6@42eWm*9F7x4fQye?M19LOpeF4ukY&NL5g0^uRymQKT?7c+3ZZRW zWSAy}Hi)0XsZPw;#Ow~N=I@`8RD%pnL)#D`m~@XGg%4;o4YBAnUjJ*s1OwpV>%L!y>R6A1FDIFl?_Le=C^(Wp_`2D;d+3$HF} zU_QZjv9_QeiIN#qv-s0h6REg?nvy~F$!{2MvJ0-_3H}RPav_+O6_Il_uvW0oWh!e6 zsS%|Gp|qS5KaMmp9%;)uzU!?FO0S0Lb%R9Na%KazLRkSr&VuERw|c;gQM=r;Vu&|n zF6!Bd|VV|sbGkX>8M?Er;?q)wWl0N<7Ke zYIn-qqMFnVxjidc)E{3|lA2+ZE=Rd_*>ZS8RprVCQ2%}IJwR(|^@Y2ZN7i?9x(D^@ z2L4+8T;3b?M}64u0GCFifel*Gx1)hpU(~z458p6qxF3Qm=b9j%!Duj2?E^geLA3mv zNL_z!1Hvmxq4W!`w?0wp|GcQM(A%-?T!*66@}X!)H01Vv3|M`luKtUg1EKXfe+e4C z!F&jWM7nsQm3wYC(|Lijwf4cUKoDSwJGw)pwkwUfty; zOo@`WC9?85WFliXvHXz4K?pr&+X%#yYgK=(En#HaCFg+$)?j%H3tlPYr8vT~NPV|v z-stdul@4aa?iYtXRi$Fm)6m5IS*PrkM@im zSnbsV>eyQXBie2oL=~Vw8Fonfh4Pm*pQeeTBBgirMh*Jkv(5RDn z=ecI3KVZv zugJa&AQTKa$W;EY?6#$XlUR-W+AAPc*%N818->zRT7mM-)~h|=DEqFx=-1{QpSAUP z^qGikzjkeQj?{0rT!PjPb)hCIPAG_}LnI}pYan{4+@D~zz2pP{rT8)`#Vu~Rx%@a= ztzi|=72`ozn8J|--dSv*#;dxqR)fJ&hkh1k+%jw{SSA@*>|CRhz@wJ1t%BHa>UH!G zq`k+vfK6>!z#z9c1yYIk2GEoM_1Z&9ZBz-*_Z(@jhl2GePA;x-M?ZApnUsN293d=-hZS5tFPi}cTpw4wGx9`|cHB=R10 zNF|L*C#@>^L;hDrE{j&0YARH#Q~KXV7Ii6UikXn-Gzz7ro>NEg=Ca14{Kn7?4H927 zc>E!aS5u;ebpA+fyMiYm)9h)J*41I!>TcRK@J_oKH;cF7_CQ{k;ze{R5$3jkl&1k% zm7ufuA{&?NT5%K&@?Mxp<@hqgUUK>Qey+tY^9KS8Q3r;@iG6u6ug zvR)TAxD59&)E?c{TIuSbY?0KYTItYO&qPpwL_N%|_u%++s6Tqu;(C2U4L%9Y<=*ui zr+w5?w!nJ&p$1B8-h?u0@L~UGHMe=}z^lAI#hm;4Tz(+#O%9T&l^Cydd(0vi=Rn7s zj;^>Dk}PqX1aZ$STz9vxK}`T3XNDE$z}Nlqyc{piphQeg+@&$e9UO?Et1dPXR9rG~pyArzjz|$W92xTR~HIEQc3% zi0X*jXK78uK4DPyWi#2sQU;)Q^GEzYl{~>9GT%@ZRQ8c(TWUmXF*ViY4yLnA;~_gV z_y9?$JXWYFISg8w3m2)aeNz$EH^~~*>=YaYh;t-ZmtIEXX+;rNB7HsMYOtzc(XD60 z9@vs#CB&K0G7V+{$Laz*6sGd2&uEpO(afLGT4TKtF1(cQjdN1xV%{j?A;J{bTX3M; z!X76_y?Be7_e%|n5lGbhcxWC*&x*~UO|%O5t=ED$_rL?{)T&UR7HUw4suUi8l}=KD zo5Odo|gz(Dcf?OnPS2TKFlQaDh@)AG3M>$4~7m&M4 zlacsQwA_fGnl304gz4*5Ji!7I5-u)T!78k2IDTBs)qWq*Gl&@#+~WnnQC~;Q5#rz+ z=KxJ{2`<{1)q|0?4kzx0N;dC$%1u*l^`NV+!-cc~WWyW%7}`ej?_VY0SdBW{4zwSb zsxb3lD-yuios^ud1-b;G7cA?Y#Ke5)R70`}8A^#w1NRe*!75ogd`5X5I2mG`4LN-0 z!7&ogL1yx%rR0beU1brvo-}NKO>FY09hv_M{Mx;wlb(PGyGJOJoQZc}0cZ92BQNhG|queXPRQ;e5NBes8C=z0aUAp{B%WBOH2{B^{|(AY zd%-Co3|fXY*xyyN78|lGe)RON#Me>x2eca!K}tHOkqgvNb9y#yX#Djl_Oz+{(s*v0 zF_9DPffP1iLkfu)F&3(l0g2_!+(o!bbzlWpkoW)$3MFPxxDFxN(t<|XDlxm&uR$2; zvJBl-3q+KHz~esaX_|o<8or1hfH8LUXTu`h{N5W-KEb=BzZ=#y*%R=Toj73;OJI%! zL;69v)(B*qG4D~ytA`c>1~5cwWNxDmBUsxPod>&ue}|pxU_{I+LubVc;IH8k*(cEU znJ<(@5OSj=8uCQFC%%uPixol)tckf(Y+k){`}Vb|IZ~$6@Jo~=!(v`Vu5$#J0CHBB zhU=nSam1Rm1EtyoXN31q>cqc`!KHxgMq%+PKKz(~Z6Twib!K5ZRTDrb`*@HvW7yid zIt0PTt-FAqqE2{9cmlH7BLezK0G&b<2wcD;4n2YheO)7+1c0FsqLzRVW)7(}&C`6E zv$P|4MiU1=%NM9#2uWC8r5>*FktOz?_;bt#eMEeUH&lkky!a_{sG#!@U%26``1*6& zFmX{}H*;)kjq0Cb4J3AHi+nn?9kQst1unLwnL(k_TG%#kL;Blh5tfik1?b_6WymFX zReMl&fgrGBD6B4{EK{`*5jPTi9RF&6Bo7~Z`-q!_$d;r#v(2`dMz0#eN4n@|oS z(BNKWgAM5^aT&GH?;G;Bnmc8UVm3h~>{BIcamuRLm_isg5w%Ay^ z8KNs1d{Bt6RO;l>p@V{|!|0evHYkVx3w)94&TGj1E1f=Z3?*Yi9~V^DwI}+v$x&{h zz)1D#7E+O_0yH}+c}tjZ3^JaA!s-Z64N45zy5JWhUC72K;`|g6aK@|qP6?_8T&9Q_ zl|`*eK_zQ5b|gVZ+6SDvh>?MfJ^g$ z4hZKA;5YYi2-sCZ;VPToFc}qsnJowqkm-0fv zx+bR~GaKGWXy9=7mqaZHESz0PTg3e%$l&b@Z-?)3D)8Xc!ESL;i2?-@#W~~w$FgI& z<)GBy3p8yud4CZsxG`_l8@|7JD6saeBQKskea5=PcWEw8PReElpx$JCt?uwu73wod z%`V@!6SyE44O_OfglhyP&>MW{)lCRn@H&{9qoH#FCPbp!HV&ypV%gq>z971j&6vc!)fW4#ycR5!gFS60xg zr`-!`MLNu__kkU#JVF}%Rq+pQ7VY{ePc5Q!OKBbt2f#SZ$J%#>TA6S#%B=6$z&cu4 z@}|70%qZ{To=x=(JTOBmCgO$r;e&xww7C=O?hS{dp2wlmqw>5pT`hq9`B}22ldnK=Y7_F-3A< zfYQyq@%G51mt2*;8e%7nYMIPviB~gTP)EEku#Q+0CnwN@G@*;QwNmmyFMK1gO_p2y zj~G*%zLV=Y@aM^^E5tUg6XPN;U2;c9PL;I$KV8QGZ6_{ljQ+p9QG>XWPA3zmnN!3% ztylaVu(Wxu)5Rn2$RPM7yamKe=*|(HE<9c1Q1i&L#A&fP|3tmW5>)&d26>`RK2alx zz4_+RtF;DhF;VQ1*g_{0l(#a;Z8nwPDd_f9oC1}`gSc4+=LJ|MJP}UV2;vmZF4jYe z6p?#Skkk`oq>8_#Uc>UnqmOu#?FtH^Ai(nz`jTcgBpy&c)2OaCphDn!8>@tLna!&T zay-U540t!r+`PjcIB@`Vh(7!yUefJe3_2lc)>qkBd{#f46gs57Cis zJOme!QOvBCrHF}2#sWoNG}ZWA-gn6{7deQOV=i#K<;ers}c&StQ_u~vAbhVPaAGgrJT~6GO6J*DVKcR#@$$v$;KcwW_ zNQ%4Y)|QRXfm;)Wp!}#%sXc%bij_&Y&+`X6*T`UuHX*E9F{e^8KIL-KaE&R(Q0L5Nvc%Zvs)q~0-R&a`}GzfCg z#VMRfF$dx%)^iIIIbbv|nv^H+25f5J4+JJ~=C7%TdQ*gWv*jRuMmcs(4r~k9inr-g zK#4#CyDW(ZbFee+L8N!ST!qaA2P1;=NkPm}2ZuW3I^(Tz&hZ~QYk}RUHp_MKr_^Ae z9j}(wILvezvTny$!OKAUVx2~urVd7JeiI$n9bpDzd8Ot)LT)B diff --git a/venv/lib/python3.8/site-packages/pip/_internal/req/__pycache__/req_install.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/req/__pycache__/req_install.cpython-38.pyc deleted file mode 100644 index 814b966833a2fb6da1844f7dc46af26f7c25c9c3..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 21338 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 E7gDc^B>(^b diff --git a/venv/lib/python3.8/site-packages/pip/_internal/req/constructors.py b/venv/lib/python3.8/site-packages/pip/_internal/req/constructors.py deleted file mode 100644 index 1f3cd8a..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/req/constructors.py +++ /dev/null @@ -1,436 +0,0 @@ -"""Backing implementation for InstallRequirement's various constructors - -The idea here is that these formed a major chunk of InstallRequirement's size -so, moving them and support code dedicated to them outside of that class -helps creates for better understandability for the rest of the code. - -These are meant to be used elsewhere within pip to create instances of -InstallRequirement. -""" - -# The following comment should be removed at some point in the future. -# mypy: strict-optional=False - -import logging -import os -import re - -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_install import InstallRequirement -from pip._internal.utils.filetypes import ARCHIVE_EXTENSIONS -from pip._internal.utils.misc import is_installable_dir, splitext -from pip._internal.utils.typing import MYPY_CHECK_RUNNING -from pip._internal.utils.urls import path_to_url -from pip._internal.vcs import is_url, vcs - -if MYPY_CHECK_RUNNING: - from typing import ( - Any, Dict, Optional, Set, Tuple, Union, - ) - from pip._internal.cache import WheelCache - - -__all__ = [ - "install_req_from_editable", "install_req_from_line", - "parse_editable" -] - -logger = logging.getLogger(__name__) -operators = Specifier._operators.keys() - - -def is_archive_file(name): - # type: (str) -> bool - """Return True if `name` is a considered as an archive file.""" - ext = splitext(name)[1].lower() - if ext in ARCHIVE_EXTENSIONS: - return True - return False - - -def _strip_extras(path): - # type: (str) -> Tuple[str, Optional[str]] - m = re.match(r'^(.+)(\[[^\]]+\])$', path) - extras = None - if m: - path_no_extras = m.group(1) - extras = m.group(2) - else: - path_no_extras = path - - return path_no_extras, extras - - -def convert_extras(extras): - # type: (Optional[str]) -> Set[str] - if not extras: - return set() - return Requirement("placeholder" + extras.lower()).extras - - -def parse_editable(editable_req): - # type: (str) -> Tuple[Optional[str], str, Optional[Set[str]]] - """Parses an editable requirement into: - - a requirement name - - an URL - - extras - - editable options - Accepted requirements: - svn+http://blahblah@rev#egg=Foobar[baz]&subdirectory=version_subdir - .[some_extra] - """ - - url = editable_req - - # If a file path is specified with extras, strip off the extras. - url_no_extras, extras = _strip_extras(url) - - if os.path.isdir(url_no_extras): - if not os.path.exists(os.path.join(url_no_extras, 'setup.py')): - msg = ( - 'File "setup.py" 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 setup.py 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:'): - package_name = Link(url_no_extras).egg_fragment - if extras: - return ( - package_name, - url_no_extras, - Requirement("placeholder" + extras.lower()).extras, - ) - else: - return package_name, url_no_extras, None - - for version_control in vcs: - if url.lower().startswith('%s:' % version_control): - url = '%s+%s' % (version_control, url) - break - - if '+' not in url: - raise InstallationError( - '{} is not a valid editable requirement. ' - 'It should either be a path to a local project or a VCS URL ' - '(beginning with svn+, git+, hg+, or bzr+).'.format(editable_req) - ) - - vc_type = url.split('+', 1)[0].lower() - - if not vcs.get_backend(vc_type): - error_message = 'For --editable=%s only ' % editable_req + \ - ', '.join([backend.name + '+URL' for backend in vcs.backends]) + \ - ' is currently supported' - raise InstallationError(error_message) - - package_name = Link(url).egg_fragment - if not package_name: - raise InstallationError( - "Could not detect requirement name for '%s', please specify one " - "with #egg=your_package_name" % editable_req - ) - return package_name, url, None - - -def deduce_helpful_msg(req): - # type: (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 = " It does exist." - # Try to parse and check if it is a requirements file. - try: - with open(req, 'r') as fp: - # parse first line only - next(parse_requirements(fp.read())) - msg += " The argument you provided " + \ - "(%s) appears to be a" % (req) + \ - " requirements file. If that is the" + \ - " case, use the '-r' flag to install" + \ - " the packages specified within it." - except RequirementParseError: - logger.debug("Cannot parse '%s' as requirements \ - file" % (req), exc_info=True) - else: - msg += " File '%s' does not exist." % (req) - return msg - - -class RequirementParts(object): - def __init__( - self, - requirement, # type: Optional[Requirement] - link, # type: Optional[Link] - markers, # type: Optional[Marker] - extras, # type: Set[str] - ): - self.requirement = requirement - self.link = link - self.markers = markers - self.extras = extras - - -def parse_req_from_editable(editable_req): - # type: (str) -> RequirementParts - name, url, extras_override = parse_editable(editable_req) - - if name is not None: - try: - req = Requirement(name) - except InvalidRequirement: - raise InstallationError("Invalid requirement: '%s'" % name) - else: - req = None - - link = Link(url) - - return RequirementParts(req, link, None, extras_override) - - -# ---- The actual constructors follow ---- - - -def install_req_from_editable( - editable_req, # type: str - comes_from=None, # type: Optional[str] - use_pep517=None, # type: Optional[bool] - isolated=False, # type: bool - options=None, # type: Optional[Dict[str, Any]] - wheel_cache=None, # type: Optional[WheelCache] - constraint=False # type: bool -): - # type: (...) -> InstallRequirement - - parts = parse_req_from_editable(editable_req) - - source_dir = parts.link.file_path if parts.link.scheme == 'file' else None - - return InstallRequirement( - parts.requirement, comes_from, source_dir=source_dir, - editable=True, - link=parts.link, - constraint=constraint, - use_pep517=use_pep517, - isolated=isolated, - options=options if options else {}, - wheel_cache=wheel_cache, - extras=parts.extras, - ) - - -def _looks_like_path(name): - # type: (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 - appearance. - - Returns true if any of the following conditions is true: - * a path separator is found (either os.path.sep or os.path.altsep); - * a dot is found (which represents the current directory). - """ - if os.path.sep in name: - return True - if os.path.altsep is not None and os.path.altsep in name: - return True - if name.startswith("."): - return True - return False - - -def _get_url_from_path(path, name): - # type: (str, str) -> 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. - - 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 - an @, it will treat it as a PEP 440 URL requirement and return the path. - """ - if _looks_like_path(name) and os.path.isdir(path): - if is_installable_dir(path): - return path_to_url(path) - raise InstallationError( - "Directory %r is not installable. Neither 'setup.py' " - "nor 'pyproject.toml' found." % name - ) - if not is_archive_file(path): - return None - if os.path.isfile(path): - return path_to_url(path) - 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 - ) - return path_to_url(path) - - -def parse_req_from_line(name, line_source): - # type: (str, Optional[str]) -> RequirementParts - if is_url(name): - marker_sep = '; ' - else: - marker_sep = ';' - if marker_sep in name: - name, markers_as_string = name.split(marker_sep, 1) - markers_as_string = markers_as_string.strip() - if not markers_as_string: - markers = None - else: - markers = Marker(markers_as_string) - else: - markers = None - name = name.strip() - req_as_string = None - path = os.path.normpath(os.path.abspath(name)) - link = None - extras_as_string = None - - if is_url(name): - link = Link(name) - else: - p, extras_as_string = _strip_extras(path) - url = _get_url_from_path(p, name) - if url is not None: - link = Link(url) - - # 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)))) - # wheel file - if link.is_wheel: - wheel = Wheel(link.filename) # can raise InvalidWheelFilename - req_as_string = "%s==%s" % (wheel.name, wheel.version) - else: - # set the req to the egg fragment. when it's not there, this - # will become an 'unnamed' requirement - req_as_string = link.egg_fragment - - # a requirement specifier - else: - req_as_string = name - - extras = convert_extras(extras_as_string) - - def with_source(text): - # type: (str) -> str - if not line_source: - return text - return '{} (from {})'.format(text, line_source) - - if req_as_string is not None: - try: - req = 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)): - add_msg = "= is not a valid operator. Did you mean == ?" - else: - add_msg = '' - msg = with_source( - 'Invalid requirement: {!r}'.format(req_as_string) - ) - if add_msg: - msg += '\nHint: {}'.format(add_msg) - raise InstallationError(msg) - else: - req = None - - return RequirementParts(req, link, markers, extras) - - -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]] - wheel_cache=None, # type: Optional[WheelCache] - constraint=False, # type: bool - line_source=None, # type: Optional[str] -): - # type: (...) -> InstallRequirement - """Creates an InstallRequirement from a name, which might be a - requirement, directory containing 'setup.py', filename, or URL. - - :param line_source: An optional string describing where the line is from, - for logging purposes in case of an error. - """ - 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, - options=options if options else {}, - wheel_cache=wheel_cache, - constraint=constraint, - extras=parts.extras, - ) - - -def install_req_from_req_string( - req_string, # type: str - comes_from=None, # type: Optional[InstallRequirement] - isolated=False, # type: bool - wheel_cache=None, # type: Optional[WheelCache] - use_pep517=None # type: Optional[bool] -): - # type: (...) -> InstallRequirement - try: - req = Requirement(req_string) - except InvalidRequirement: - raise InstallationError("Invalid requirement: '%s'" % req_string) - - domains_not_allowed = [ - 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): - # Explicitly disallow pypi packages that depend on external urls - raise InstallationError( - "Packages installed from PyPI cannot depend on packages " - "which are not also hosted on PyPI.\n" - "%s depends on %s " % (comes_from.name, req) - ) - - return InstallRequirement( - req, comes_from, isolated=isolated, wheel_cache=wheel_cache, - use_pep517=use_pep517 - ) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/req/req_file.py b/venv/lib/python3.8/site-packages/pip/_internal/req/req_file.py deleted file mode 100644 index 8c78104..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/req/req_file.py +++ /dev/null @@ -1,546 +0,0 @@ -""" -Requirements file parsing -""" - -# The following comment should be removed at some point in the future. -# mypy: strict-optional=False - -from __future__ import absolute_import - -import optparse -import os -import re -import shlex -import sys - -from pip._vendor.six.moves import filterfalse -from pip._vendor.six.moves.urllib import parse as urllib_parse - -from pip._internal.cli import cmdoptions -from pip._internal.exceptions import ( - InstallationError, - RequirementsFileParseError, -) -from pip._internal.models.search_scope import SearchScope -from pip._internal.req.constructors import ( - install_req_from_editable, - install_req_from_line, -) -from pip._internal.utils.encoding import auto_decode -from pip._internal.utils.typing import MYPY_CHECK_RUNNING -from pip._internal.utils.urls import get_url_scheme - -if MYPY_CHECK_RUNNING: - from optparse import Values - from typing import ( - Any, Callable, Iterator, List, NoReturn, Optional, Text, Tuple, - ) - - from pip._internal.req import InstallRequirement - from pip._internal.cache import WheelCache - from pip._internal.index.package_finder import PackageFinder - from pip._internal.network.session import PipSession - - ReqFileLines = Iterator[Tuple[int, Text]] - - LineParser = Callable[[Text], Tuple[str, Values]] - - -__all__ = ['parse_requirements'] - -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\$\{(?P[A-Z0-9_]+)\})') - -SUPPORTED_OPTIONS = [ - cmdoptions.index_url, - cmdoptions.extra_index_url, - cmdoptions.no_index, - cmdoptions.constraints, - cmdoptions.requirements, - cmdoptions.editable, - cmdoptions.find_links, - cmdoptions.no_binary, - cmdoptions.only_binary, - cmdoptions.require_hashes, - cmdoptions.pre, - cmdoptions.trusted_host, - cmdoptions.always_unzip, # Deprecated -] # type: List[Callable[..., optparse.Option]] - -# options to be passed to requirements -SUPPORTED_OPTIONS_REQ = [ - cmdoptions.install_options, - cmdoptions.global_options, - cmdoptions.hash, -] # type: List[Callable[..., optparse.Option]] - -# the 'dest' string values -SUPPORTED_OPTIONS_REQ_DEST = [str(o().dest) for o in SUPPORTED_OPTIONS_REQ] - - -class ParsedLine(object): - def __init__( - self, - filename, # type: str - lineno, # type: int - comes_from, # type: str - args, # type: str - opts, # type: Values - constraint, # type: bool - ): - # type: (...) -> None - self.filename = filename - self.lineno = lineno - self.comes_from = comes_from - self.args = args - self.opts = opts - self.constraint = constraint - - -def parse_requirements( - filename, # type: str - session, # type: PipSession - finder=None, # type: Optional[PackageFinder] - comes_from=None, # type: Optional[str] - options=None, # type: Optional[optparse.Values] - constraint=False, # type: bool - wheel_cache=None, # type: Optional[WheelCache] - use_pep517=None # type: Optional[bool] -): - # type: (...) -> Iterator[InstallRequirement] - """Parse a requirements file and yield InstallRequirement instances. - - :param filename: Path or url of requirements file. - :param session: PipSession instance. - :param finder: Instance of pip.index.PackageFinder. - :param comes_from: Origin description of requirements. - :param options: cli options. - :param constraint: If true, parsing a constraint file rather than - requirements file. - :param wheel_cache: Instance of pip.wheel.WheelCache - :param use_pep517: Value of the --use-pep517 option. - """ - skip_requirements_regex = ( - options.skip_requirements_regex if options else None - ) - line_parser = get_line_parser(finder) - parser = RequirementsFileParser( - session, line_parser, comes_from, skip_requirements_regex - ) - - for parsed_line in parser.parse(filename, constraint): - req = handle_line( - parsed_line, finder, options, session, wheel_cache, use_pep517 - ) - if req is not None: - yield req - - -def preprocess(content, skip_requirements_regex): - # type: (Text, Optional[str]) -> ReqFileLines - """Split, filter, and join lines, and return a line iterator - - :param content: the content of the requirements file - :param options: cli options - """ - lines_enum = enumerate(content.splitlines(), start=1) # type: ReqFileLines - lines_enum = join_lines(lines_enum) - lines_enum = ignore_comments(lines_enum) - if skip_requirements_regex: - lines_enum = skip_regex(lines_enum, skip_requirements_regex) - lines_enum = expand_env_variables(lines_enum) - return lines_enum - - -def handle_line( - line, # type: ParsedLine - finder=None, # type: Optional[PackageFinder] - options=None, # type: Optional[optparse.Values] - session=None, # type: Optional[PipSession] - wheel_cache=None, # type: Optional[WheelCache] - use_pep517=None, # type: Optional[bool] -): - # type: (...) -> Optional[InstallRequirement] - """Handle a single parsed requirements line; This can result in - creating/yielding requirements, or updating the finder. - - For lines that contain requirements, the only options that have an effect - are from SUPPORTED_OPTIONS_REQ, and they are scoped to the - requirement. Other options from SUPPORTED_OPTIONS may be present, but are - ignored. - - For lines that do not contain requirements, the only options that have an - effect are from SUPPORTED_OPTIONS. Options from SUPPORTED_OPTIONS_REQ may - be present, but are ignored. These lines may contain multiple options - (although our docs imply only one is supported), and all our parsed and - affect the finder. - """ - - # preserve for the nested code path - line_comes_from = '%s %s (line %s)' % ( - '-c' if line.constraint else '-r', line.filename, line.lineno, - ) - - # return a line requirement - if line.args: - isolated = options.isolated_mode if options else False - if 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 = 'line {} of {}'.format(line.lineno, line.filename) - return install_req_from_line( - line.args, - comes_from=line_comes_from, - use_pep517=use_pep517, - isolated=isolated, - options=req_options, - wheel_cache=wheel_cache, - constraint=line.constraint, - line_source=line_source, - ) - - # return an editable requirement - elif line.opts.editables: - isolated = options.isolated_mode if options else False - return install_req_from_editable( - line.opts.editables[0], comes_from=line_comes_from, - use_pep517=use_pep517, - constraint=line.constraint, isolated=isolated, - wheel_cache=wheel_cache - ) - - # percolate hash-checking option upward - elif line.opts.require_hashes: - options.require_hashes = line.opts.require_hashes - - # set finder options - elif finder: - find_links = finder.find_links - index_urls = finder.index_urls - if line.opts.index_url: - index_urls = [line.opts.index_url] - if line.opts.no_index is True: - index_urls = [] - if line.opts.extra_index_urls: - index_urls.extend(line.opts.extra_index_urls) - if line.opts.find_links: - # FIXME: it would be nice to keep track of the source - # of the find_links: support a find-links local path - # relative to a requirements file. - value = line.opts.find_links[0] - req_dir = os.path.dirname(os.path.abspath(line.filename)) - relative_to_reqs_file = os.path.join(req_dir, value) - if os.path.exists(relative_to_reqs_file): - value = relative_to_reqs_file - find_links.append(value) - - search_scope = SearchScope( - find_links=find_links, - index_urls=index_urls, - ) - finder.search_scope = search_scope - - if line.opts.pre: - finder.set_allow_all_prereleases() - - if session: - for host in line.opts.trusted_hosts or []: - source = 'line {} of {}'.format(line.lineno, line.filename) - session.add_trusted_host(host, source=source) - - return None - - -class RequirementsFileParser(object): - def __init__( - self, - session, # type: PipSession - line_parser, # type: LineParser - comes_from, # type: str - skip_requirements_regex, # type: Optional[str] - ): - # type: (...) -> None - self._session = session - self._line_parser = line_parser - self._comes_from = comes_from - self._skip_requirements_regex = skip_requirements_regex - - def parse(self, filename, constraint): - # type: (str, bool) -> Iterator[ParsedLine] - """Parse a given file, yielding parsed lines. - """ - for line in self._parse_and_recurse(filename, constraint): - yield line - - def _parse_and_recurse(self, filename, constraint): - # type: (str, bool) -> Iterator[ParsedLine] - for line in self._parse_file(filename, constraint): - if ( - not line.args and - not line.opts.editables and - (line.opts.requirements or line.opts.constraints) - ): - # parse a nested requirements file - if line.opts.requirements: - req_path = line.opts.requirements[0] - nested_constraint = False - else: - req_path = line.opts.constraints[0] - nested_constraint = True - - # original file is over http - if SCHEME_RE.search(filename): - # do a url join so relative paths work - req_path = urllib_parse.urljoin(filename, req_path) - # original file and nested file are paths - 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, - ) - - for inner_line in self._parse_and_recurse( - req_path, nested_constraint, - ): - yield inner_line - else: - yield line - - def _parse_file(self, filename, constraint): - # type: (str, bool) -> Iterator[ParsedLine] - _, content = get_file_content( - filename, self._session, comes_from=self._comes_from - ) - - lines_enum = preprocess(content, self._skip_requirements_regex) - - for line_number, line in lines_enum: - try: - args_str, opts = self._line_parser(line) - except OptionParsingError as e: - # add offending line - msg = 'Invalid requirement: %s\n%s' % (line, e.msg) - raise RequirementsFileParseError(msg) - - yield ParsedLine( - filename, - line_number, - self._comes_from, - args_str, - opts, - constraint, - ) - - -def get_line_parser(finder): - # type: (Optional[PackageFinder]) -> LineParser - def parse_line(line): - # type: (Text) -> Tuple[str, Values] - # Build new parser for each line since it accumulates appendable - # options. - parser = build_parser() - defaults = parser.get_default_values() - defaults.index_url = None - if finder: - defaults.format_control = finder.format_control - - args_str, options_str = break_args_options(line) - # Prior to 2.7.3, shlex cannot deal with unicode entries - if sys.version_info < (2, 7, 3): - # https://github.com/python/mypy/issues/1174 - options_str = options_str.encode('utf8') # type: ignore - - # https://github.com/python/mypy/issues/1174 - opts, _ = parser.parse_args( - shlex.split(options_str), defaults) # type: ignore - - return args_str, opts - - return parse_line - - -def break_args_options(line): - # type: (Text) -> Tuple[str, Text] - """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(' ') - args = [] - options = tokens[:] - for token in tokens: - if token.startswith('-') or token.startswith('--'): - break - else: - args.append(token) - options.pop(0) - return ' '.join(args), ' '.join(options) # type: ignore - - -class OptionParsingError(Exception): - def __init__(self, msg): - # type: (str) -> None - self.msg = msg - - -def build_parser(): - # type: () -> optparse.OptionParser - """ - Return a parser for parsing requirement lines - """ - parser = optparse.OptionParser(add_help_option=False) - - option_factories = SUPPORTED_OPTIONS + SUPPORTED_OPTIONS_REQ - for option_factory in option_factories: - option = option_factory() - parser.add_option(option) - - # 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 - raise OptionParsingError(msg) - # NOTE: mypy disallows assigning to a method - # https://github.com/python/mypy/issues/2427 - parser.exit = parser_exit # type: ignore - - return parser - - -def join_lines(lines_enum): - # type: (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[Text] - for line_number, line in lines_enum: - if not line.endswith('\\') or COMMENT_RE.match(line): - if COMMENT_RE.match(line): - # this ensures comments are always matched later - line = ' ' + line - if new_line: - new_line.append(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('\\')) - - # last line contains \ - if new_line: - yield primary_line_number, ''.join(new_line) - - # TODO: handle space after '\'. - - -def ignore_comments(lines_enum): - # type: (ReqFileLines) -> ReqFileLines - """ - Strips comments and filter empty lines. - """ - for line_number, line in lines_enum: - line = COMMENT_RE.sub('', line) - line = line.strip() - if line: - yield line_number, line - - -def skip_regex(lines_enum, pattern): - # type: (ReqFileLines, str) -> ReqFileLines - """ - Skip lines that match the provided pattern - - Note: the regex pattern is only built once - """ - matcher = re.compile(pattern) - lines_enum = filterfalse(lambda e: matcher.search(e[1]), lines_enum) - return lines_enum - - -def expand_env_variables(lines_enum): - # type: (ReqFileLines) -> ReqFileLines - """Replace all environment variables that can be retrieved via `os.getenv`. - - The only allowed format for environment variables defined in the - requirement file is `${MY_VARIABLE_1}` to ensure two things: - - 1. Strings that contain a `$` aren't accidentally (partially) expanded. - 2. Ensure consistency across platforms for requirement files. - - These points are the result of a discussion on the `github pull - request #3514 `_. - - Valid characters in variable names follow the `POSIX standard - `_ and are limited - to uppercase letter, digits and the `_` (underscore). - """ - for line_number, line in lines_enum: - for env_var, var_name in ENV_VAR_RE.findall(line): - value = os.getenv(var_name) - if not value: - continue - - line = line.replace(env_var, value) - - yield line_number, line - - -def get_file_content(url, session, comes_from=None): - # type: (str, PipSession, Optional[str]) -> Tuple[str, Text] - """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. - - :param url: File path or url. - :param session: PipSession instance. - :param comes_from: Origin description of requirements. - """ - scheme = get_url_scheme(url) - - if scheme in ['http', 'https']: - # FIXME: catch some errors - resp = session.get(url) - resp.raise_for_status() - return resp.url, resp.text - - elif scheme == 'file': - if comes_from and comes_from.startswith('http'): - raise InstallationError( - 'Requirements file %s references URL %s, which is local' - % (comes_from, url)) - - path = url.split(':', 1)[1] - path = path.replace('\\', '/') - match = _url_slash_drive_re.match(path) - if match: - path = match.group(1) + ':' + path.split('|', 1)[1] - path = urllib_parse.unquote(path) - if path.startswith('/'): - path = '/' + path.lstrip('/') - url = path - - try: - with open(url, 'rb') as f: - content = auto_decode(f.read()) - except IOError as exc: - raise InstallationError( - 'Could not open requirements file: %s' % str(exc) - ) - return url, content - - -_url_slash_drive_re = re.compile(r'/*([a-z])\|', re.I) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/req/req_install.py b/venv/lib/python3.8/site-packages/pip/_internal/req/req_install.py deleted file mode 100644 index 22ac24b..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/req/req_install.py +++ /dev/null @@ -1,830 +0,0 @@ -# The following comment should be removed at some point in the future. -# mypy: strict-optional=False - -from __future__ import absolute_import - -import logging -import os -import shutil -import sys -import zipfile - -from pip._vendor import pkg_resources, six -from pip._vendor.packaging.requirements import Requirement -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._internal import pep425tags -from pip._internal.build_env import NoOpBuildEnvironment -from pip._internal.exceptions import InstallationError -from pip._internal.locations import get_scheme -from pip._internal.models.link import Link -from pip._internal.operations.build.metadata import generate_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 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.hashes import Hashes -from pip._internal.utils.logging import indent_log -from pip._internal.utils.marker_files import ( - PIP_DELETE_MARKER_FILENAME, - has_delete_marker_file, - write_delete_marker_file, -) -from pip._internal.utils.misc import ( - ask_path_exists, - backup_dir, - display_path, - dist_in_site_packages, - dist_in_usersite, - get_installed_version, - hide_url, - redact_auth_from_url, - rmtree, -) -from pip._internal.utils.packaging import get_metadata -from pip._internal.utils.temp_dir import TempDirectory -from pip._internal.utils.typing import MYPY_CHECK_RUNNING -from pip._internal.utils.virtualenv import running_under_virtualenv -from pip._internal.vcs import vcs - -if MYPY_CHECK_RUNNING: - from typing import ( - Any, Dict, Iterable, List, Optional, Sequence, Union, - ) - from pip._internal.build_env import BuildEnvironment - from pip._internal.cache import WheelCache - from pip._internal.index.package_finder import PackageFinder - from pip._vendor.pkg_resources import Distribution - from pip._vendor.packaging.specifiers import SpecifierSet - from pip._vendor.packaging.markers import Marker - - -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) - - # Determine the correct Distribution object type. - if dist_dir.endswith(".egg-info"): - dist_cls = pkg_resources.Distribution - else: - assert dist_dir.endswith(".dist-info") - dist_cls = pkg_resources.DistInfoDistribution - - # Build a PathMetadata object, from path to metadata. :wink: - base_dir, dist_dir_name = os.path.split(dist_dir) - dist_name = os.path.splitext(dist_dir_name)[0] - metadata = pkg_resources.PathMetadata(base_dir, dist_dir) - - return dist_cls( - base_dir, - project_name=dist_name, - metadata=metadata, - ) - - -class InstallRequirement(object): - """ - Represents something that may be installed later on, may have information - about where to fetch the relevant requirement and also contains logic for - installing the said requirement. - """ - - def __init__( - self, - req, # type: Optional[Requirement] - comes_from, # type: Optional[Union[str, InstallRequirement]] - source_dir=None, # type: Optional[str] - editable=False, # type: bool - link=None, # type: Optional[Link] - markers=None, # type: Optional[Marker] - use_pep517=None, # type: Optional[bool] - isolated=False, # type: bool - options=None, # type: Optional[Dict[str, Any]] - wheel_cache=None, # type: Optional[WheelCache] - constraint=False, # type: bool - extras=() # type: Iterable[str] - ): - # type: (...) -> None - assert req is None or isinstance(req, Requirement), req - self.req = req - self.comes_from = comes_from - self.constraint = constraint - if source_dir is None: - self.source_dir = None # type: Optional[str] - else: - self.source_dir = os.path.normpath(os.path.abspath(source_dir)) - self.editable = editable - - self._wheel_cache = wheel_cache - if link is None and req and req.url: - # PEP 508 URL requirement - link = Link(req.url) - self.link = self.original_link = link - # Path to any downloaded or already-existing package. - self.local_file_path = None # type: Optional[str] - 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 - } - 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] - # 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] - # Set to True after successful installation - self.install_succeeded = None # type: Optional[bool] - self.options = options if options else {} - # Set to True after successful preparation of this requirement - self.prepared = False - self.is_direct = False - - self.isolated = isolated - self.build_env = NoOpBuildEnvironment() # type: BuildEnvironment - - # 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] - - # The static build requirements (from pyproject.toml) - self.pyproject_requires = None # type: Optional[List[str]] - - # Build requirements that we will check are available - self.requirements_to_check = [] # type: List[str] - - # The PEP 517 backend we should use to build the project - self.pep517_backend = None # type: Optional[Pep517HookCaller] - - # Are we using PEP 517 for this requirement? - # After pyproject.toml has been loaded, the only valid values are True - # and False. Before loading, None is valid (meaning "use the default"). - # Setting an explicit value before loading pyproject.toml is supported, - # but after loading this flag should be treated as read only. - self.use_pep517 = use_pep517 - - def __str__(self): - # type: () -> str - if self.req: - s = str(self.req) - if self.link: - s += ' from %s' % redact_auth_from_url(self.link.url) - elif self.link: - s = redact_auth_from_url(self.link.url) - else: - s = '' - if self.satisfied_by is not None: - s += ' in %s' % display_path(self.satisfied_by.location) - if self.comes_from: - if isinstance(self.comes_from, six.string_types): - comes_from = self.comes_from # type: Optional[str] - else: - comes_from = self.comes_from.from_path() - if comes_from: - s += ' (from %s)' % comes_from - return s - - def __repr__(self): - # type: () -> str - return '<%s object: %s editable=%r>' % ( - self.__class__.__name__, str(self), self.editable) - - def format_debug(self): - # type: () -> 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( - name=self.__class__.__name__, - state=", ".join(state), - ) - - def populate_link(self, finder, upgrade, require_hashes): - # type: (PackageFinder, bool, bool) -> None - """Ensure that if a link can be found for this, that it is found. - - Note that self.link may still be None - if Upgrade is False and the - requirement is already installed. - - If require_hashes is True, don't use the wheel cache, because cached - wheels, always built locally, have different hashes than the files - downloaded from the index server and thus throw false hash mismatches. - Furthermore, cached wheels at present have undeterministic contents due - to file modification times. - """ - if self.link is None: - self.link = finder.find_requirement(self, upgrade) - if self._wheel_cache is not None and not require_hashes: - old_link = self.link - supported_tags = pep425tags.get_supported() - self.link = self._wheel_cache.get( - link=self.link, - package_name=self.name, - supported_tags=supported_tags, - ) - if old_link != self.link: - logger.debug('Using cached wheel link: %s', self.link) - - # Things that are valid for all kinds of requirements? - @property - def name(self): - # type: () -> Optional[str] - if self.req is None: - return None - return six.ensure_str(pkg_resources.safe_name(self.req.name)) - - @property - def specifier(self): - # type: () -> SpecifierSet - return self.req.specifier - - @property - def is_pinned(self): - # type: () -> 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 {'==', '==='}) - - @property - def installed_version(self): - # type: () -> Optional[str] - return get_installed_version(self.name) - - def match_markers(self, extras_requested=None): - # type: (Optional[Iterable[str]]) -> bool - if not extras_requested: - # Provide an extra to safely evaluate the markers - # without matching any extra - extras_requested = ('',) - if self.markers is not None: - return any( - self.markers.evaluate({'extra': extra}) - for extra in extras_requested) - else: - return True - - @property - def has_hash_options(self): - # type: () -> bool - """Return whether any known-good hashes are specified as options. - - These activate --require-hashes mode; hashes specified as part of a - URL do not. - - """ - return bool(self.options.get('hashes', {})) - - def hashes(self, trust_internet=True): - # type: (bool) -> Hashes - """Return a hash-comparer that considers my option- and URL-based - hashes to be known-good. - - Hashes in URLs--ones embedded in the requirements file, not ones - downloaded from an index server--are almost peers with ones from - flags. They satisfy --require-hashes (whether it was implicitly or - explicitly activated) but do not activate it. md5 and sha224 are not - allowed in flags, which should nudge people toward good algos. We - always OR all hashes together, even ones from URLs. - - :param trust_internet: Whether to trust URL-based (#md5=...) hashes - downloaded from the internet, as by populate_link() - - """ - good_hashes = self.options.get('hashes', {}).copy() - link = self.link if trust_internet else self.original_link - 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" - """ - if self.req is None: - return None - s = str(self.req) - if self.comes_from: - if isinstance(self.comes_from, six.string_types): - comes_from = self.comes_from - else: - comes_from = self.comes_from.from_path() - if comes_from: - s += '->' + comes_from - return s - - def ensure_build_location(self, build_dir): - # type: (str) -> str - assert build_dir is not None - if self._temp_build_dir is not None: - assert self._temp_build_dir.path - return self._temp_build_dir.path - if self.req is None: - # Some systems have /tmp as a symlink which confuses custom - # builds (such as numpy). Thus, we ensure that the real path - # is returned. - self._temp_build_dir = TempDirectory(kind="req-build") - - return self._temp_build_dir.path - if self.editable: - name = self.name.lower() - else: - name = self.name - # 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) - os.makedirs(build_dir) - write_delete_marker_file(build_dir) - return os.path.join(build_dir, name) - - def _set_requirement(self): - # type: () -> None - """Set requirement after generating metadata. - """ - assert self.req is None - assert self.metadata is not None - assert self.source_dir is not None - - # Construct a Requirement object from the generated metadata - if isinstance(parse_version(self.metadata["Version"]), Version): - op = "==" - else: - op = "===" - - self.req = Requirement( - "".join([ - self.metadata["Name"], - op, - self.metadata["Version"], - ]) - ) - - def warn_on_mismatching_name(self): - # type: () -> None - metadata_name = canonicalize_name(self.metadata["Name"]) - if canonicalize_name(self.req.name) == metadata_name: - # Everything is fine. - return - - # 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 - ) - self.req = Requirement(metadata_name) - - def remove_temporary_source(self): - # type: () -> None - """Remove the source files from this requirement, if they are marked - for deletion""" - if self.source_dir and has_delete_marker_file(self.source_dir): - logger.debug('Removing source in %s', self.source_dir) - rmtree(self.source_dir) - self.source_dir = None - if self._temp_build_dir: - self._temp_build_dir.cleanup() - self._temp_build_dir = None - self.build_env.cleanup() - - def check_if_exists(self, use_user_site): - # type: (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 - # get_distribution() will resolve the entire list of requirements - # anyway, and we've already determined that we need the requirement - # in question, so strip the marker so that we don't try to - # evaluate it. - no_marker = Requirement(str(self.req)) - no_marker.marker = None - try: - self.satisfied_by = pkg_resources.get_distribution(str(no_marker)) - except pkg_resources.DistributionNotFound: - return - except pkg_resources.VersionConflict: - existing_dist = pkg_resources.get_distribution( - self.req.name - ) - if use_user_site: - if dist_in_usersite(existing_dist): - self.should_reinstall = True - elif (running_under_virtualenv() and - dist_in_site_packages(existing_dist)): - raise InstallationError( - "Will not install to the user site because it will " - "lack sys.path precedence to %s in %s" % - (existing_dist.project_name, existing_dist.location) - ) - else: - self.should_reinstall = True - else: - if self.editable and self.satisfied_by: - self.should_reinstall = True - # when installing editables, nothing pre-existing should ever - # satisfy - self.satisfied_by = None - - # Things valid for wheels - @property - def is_wheel(self): - # type: () -> bool - if not self.link: - return False - return self.link.is_wheel - - # Things valid for sdists - @property - def unpacked_source_directory(self): - # type: () -> str - return os.path.join( - self.source_dir, - self.link and self.link.subdirectory_fragment or '') - - @property - def setup_py_path(self): - # type: () -> str - assert self.source_dir, "No source dir for %s" % self - setup_py = os.path.join(self.unpacked_source_directory, 'setup.py') - - # Python2 __file__ should not be unicode - if six.PY2 and isinstance(setup_py, six.text_type): - setup_py = setup_py.encode(sys.getfilesystemencoding()) - - return setup_py - - @property - def pyproject_toml_path(self): - # type: () -> str - assert self.source_dir, "No source dir for %s" % self - return make_pyproject_path(self.unpacked_source_directory) - - def load_pyproject_toml(self): - # type: () -> None - """Load the pyproject.toml file. - - After calling this routine, all of the attributes related to PEP 517 - processing for this requirement have been set. In particular, the - use_pep517 attribute can be used to determine whether we should - 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) - ) - - if pyproject_toml_data is None: - self.use_pep517 = False - return - - self.use_pep517 = True - 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, - ) - - def _generate_metadata(self): - # type: () -> str - """Invokes metadata generator functions, with the required arguments. - """ - if not self.use_pep517: - assert self.unpacked_source_directory - - return generate_metadata_legacy( - build_env=self.build_env, - setup_py_path=self.setup_py_path, - source_dir=self.unpacked_source_directory, - editable=self.editable, - isolated=self.isolated, - details=self.name or "from {}".format(self.link) - ) - - 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 - """Ensure that project metadata is available. - - Under PEP 517, 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() - - # Act on the newly generated metadata, based on the name and version. - if not self.name: - self._set_requirement() - else: - self.warn_on_mismatching_name() - - self.assert_source_matches_version() - - @property - def metadata(self): - # type: () -> Any - if not hasattr(self, '_metadata'): - self._metadata = get_metadata(self.get_dist()) - - return self._metadata - - def get_dist(self): - # type: () -> Distribution - return _get_dist(self.metadata_directory) - - def assert_source_matches_version(self): - # type: () -> None - assert self.source_dir - version = self.metadata['version'] - if self.req.specifier and version not in self.req.specifier: - logger.warning( - 'Requested %s, but installing version %s', - self, - version, - ) - else: - logger.debug( - 'Source in %s has version %s, which satisfies requirement %s', - display_path(self.source_dir), - version, - self, - ) - - # For both source distributions and editables - def ensure_has_source_dir(self, parent_dir): - # type: (str) -> None - """Ensure that a source_dir is set. - - This will create a temporary build dir if the name of the requirement - isn't known yet. - - :param parent_dir: The ideal pip parent_dir for the source_dir. - Generally src_dir for editables and build_dir for sdists. - :return: self.source_dir - """ - if self.source_dir is None: - self.source_dir = self.ensure_build_location(parent_dir) - - # For editable installations - def update_editable(self, obtain=True): - # type: (bool) -> None - if not self.link: - logger.debug( - "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': - # Static paths don't get updated - return - assert '+' in self.link.url, "bad url: %r" % self.link.url - vc_type, url = self.link.url.split('+', 1) - vcs_backend = vcs.get_backend(vc_type) - if vcs_backend: - if not self.link.is_vcs: - reason = ( - "This form of VCS requirement is being deprecated: {}." - ).format( - self.link.url - ) - replacement = None - if self.link.url.startswith("git+git@"): - replacement = ( - "git+https://git@example.com/..., " - "git+ssh://git@example.com/..., " - "or the insecure git+git://git@example.com/..." - ) - deprecated(reason, replacement, gone_in="21.0", issue=7554) - hidden_url = hide_url(self.link.url) - if obtain: - vcs_backend.obtain(self.source_dir, url=hidden_url) - else: - vcs_backend.export(self.source_dir, url=hidden_url) - else: - assert 0, ( - 'Unexpected version control type (in %s): %s' - % (self.link, vc_type)) - - # Top-level Actions - def uninstall(self, auto_confirm=False, verbose=False): - # type: (bool, bool) -> Optional[UninstallPathSet] - """ - Uninstall the distribution currently satisfying this requirement. - - Prompts before removing or modifying files unless - ``auto_confirm`` is True. - - Refuses to delete or modify files outside of ``sys.prefix`` - - thus uninstallation within a virtual environment can only - modify that virtual environment, even if the virtualenv is - linked to global site-packages. - - """ - assert self.req - try: - dist = pkg_resources.get_distribution(self.req.name) - except pkg_resources.DistributionNotFound: - logger.warning("Skipping %s as it is not installed.", self.name) - return None - else: - 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), ( - "name %r doesn't start with prefix %r" % (name, prefix) - ) - 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 - - def archive(self, build_dir): - # type: (str) -> None - """Saves archive to provided build_dir. - - Used for saving downloaded VCS requirements as part of `pip download`. - """ - assert self.source_dir - - create_archive = True - archive_name = '%s-%s.zip' % (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 %s exists. (i)gnore, (w)ipe, (b)ackup, (a)bort ' % - 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)) - os.remove(archive_path) - elif response == 'b': - dest_file = backup_dir(archive_path) - logger.warning( - 'Backing up %s to %s', - display_path(archive_path), - display_path(dest_file), - ) - shutil.move(archive_path, dest_file) - elif response == 'a': - sys.exit(-1) - - if not create_archive: - return - - zip_output = zipfile.ZipFile( - archive_path, 'w', zipfile.ZIP_DEFLATED, allowZip64=True, - ) - with zip_output: - dir = os.path.normcase( - os.path.abspath(self.unpacked_source_directory) - ) - for dirpath, dirnames, filenames in os.walk(dir): - if 'pip-egg-info' in dirnames: - dirnames.remove('pip-egg-info') - for dirname in dirnames: - dir_arcname = self._get_archive_name( - dirname, parentdir=dirpath, rootdir=dir, - ) - zipdir = zipfile.ZipInfo(dir_arcname + '/') - zipdir.external_attr = 0x1ED << 16 # 0o755 - zip_output.writestr(zipdir, '') - for filename in filenames: - if filename == PIP_DELETE_MARKER_FILENAME: - continue - file_arcname = self._get_archive_name( - 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)) - - 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 - scheme = get_scheme( - self.name, - user=use_user_site, - home=home, - root=root, - isolated=self.isolated, - prefix=prefix, - ) - - global_options = global_options if global_options is not None else [] - if self.editable: - install_editable_legacy( - install_options, - global_options, - prefix=prefix, - home=home, - use_user_site=use_user_site, - name=self.name, - setup_py_path=self.setup_py_path, - isolated=self.isolated, - build_env=self.build_env, - unpacked_source_directory=self.unpacked_source_directory, - ) - self.install_succeeded = True - return - - if 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, - ) - self.install_succeeded = True - return - - install_legacy( - self, - install_options=install_options, - global_options=global_options, - root=root, - home=home, - prefix=prefix, - use_user_site=use_user_site, - pycompile=pycompile, - scheme=scheme, - ) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/req/req_set.py b/venv/lib/python3.8/site-packages/pip/_internal/req/req_set.py deleted file mode 100644 index 087ac59..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/req/req_set.py +++ /dev/null @@ -1,209 +0,0 @@ -# The following comment should be removed at some point in the future. -# mypy: strict-optional=False - -from __future__ import absolute_import - -import logging -from collections import OrderedDict - -from pip._vendor.packaging.utils import canonicalize_name - -from pip._internal import pep425tags -from pip._internal.exceptions import InstallationError -from pip._internal.models.wheel import Wheel -from pip._internal.utils.logging import indent_log -from pip._internal.utils.typing import MYPY_CHECK_RUNNING - -if MYPY_CHECK_RUNNING: - from typing import Dict, Iterable, List, Optional, Tuple - from pip._internal.req.req_install import InstallRequirement - - -logger = logging.getLogger(__name__) - - -class RequirementSet(object): - - def __init__(self, check_supported_wheels=True): - # type: (bool) -> None - """Create a RequirementSet. - """ - - self.requirements = OrderedDict() # type: Dict[str, InstallRequirement] # noqa: E501 - self.check_supported_wheels = check_supported_wheels - - self.unnamed_requirements = [] # type: List[InstallRequirement] - self.successfully_downloaded = [] # type: List[InstallRequirement] - self.reqs_to_cleanup = [] # type: List[InstallRequirement] - - def __str__(self): - # type: () -> str - requirements = sorted( - (req for req in self.requirements.values() if not req.comes_from), - key=lambda req: canonicalize_name(req.name), - ) - return ' '.join(str(req.req) for req in requirements) - - def __repr__(self): - # type: () -> str - requirements = sorted( - self.requirements.values(), - key=lambda req: canonicalize_name(req.name), - ) - - 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), - ) - - def add_unnamed_requirement(self, install_req): - # type: (InstallRequirement) -> None - assert not install_req.name - self.unnamed_requirements.append(install_req) - - def add_named_requirement(self, install_req): - # type: (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]] # noqa: E501 - """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 = pep425tags.get_supported() - if (self.check_supported_wheels and not wheel.supported(tags)): - raise InstallationError( - "%s is not a supported wheel on this platform." % - wheel.filename - ) - - # This next bit is really a sanity check. - assert install_req.is_direct == (parent_req_name is None), ( - "a direct req shouldn't have a parent and also, " - "a non direct req should 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) - 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.specifier != install_req.req.specifier - ) - if has_conflicting_requirement: - raise InstallationError( - "Double requirement given: %s (already in %s, name=%r)" - % (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: - self.reqs_to_cleanup.append(install_req) - raise InstallationError( - "Could not satisfy constraints for '%s': " - "installation from path or url cannot be " - "constrained to a version" % install_req.name, - ) - # If we're now installing a constraint, mark the existing - # object for real installation. - existing_req.constraint = False - 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 - project_name = canonicalize_name(name) - - return ( - project_name in self.requirements and - not self.requirements[project_name].constraint - ) - - def get_requirement(self, name): - # type: (str) -> InstallRequirement - project_name = canonicalize_name(name) - - if project_name in self.requirements: - return self.requirements[project_name] - - raise KeyError("No project with the name %r" % name) - - def cleanup_files(self): - # type: () -> None - """Clean up files, remove builds.""" - logger.debug('Cleaning up...') - with indent_log(): - for req in self.reqs_to_cleanup: - req.remove_temporary_source() diff --git a/venv/lib/python3.8/site-packages/pip/_internal/req/req_tracker.py b/venv/lib/python3.8/site-packages/pip/_internal/req/req_tracker.py deleted file mode 100644 index 84e0c04..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/req/req_tracker.py +++ /dev/null @@ -1,150 +0,0 @@ -# The following comment should be removed at some point in the future. -# mypy: strict-optional=False - -from __future__ import absolute_import - -import contextlib -import errno -import hashlib -import logging -import os - -from pip._vendor import contextlib2 - -from pip._internal.utils.temp_dir import TempDirectory -from pip._internal.utils.typing import MYPY_CHECK_RUNNING - -if MYPY_CHECK_RUNNING: - from types import TracebackType - from typing import Dict, Iterator, Optional, Set, Type, Union - from pip._internal.req.req_install import InstallRequirement - from pip._internal.models.link import Link - -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 contextlib2.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(object): - - 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. - """ - - # 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 IOError as e: - # if the error is anything other than "file does not exist", raise. - if e.errno != errno.ENOENT: - raise - else: - message = '%s is already being built: %s' % (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') 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. - """ - - # 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/venv/lib/python3.8/site-packages/pip/_internal/req/req_uninstall.py b/venv/lib/python3.8/site-packages/pip/_internal/req/req_uninstall.py deleted file mode 100644 index 5971b13..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/req/req_uninstall.py +++ /dev/null @@ -1,644 +0,0 @@ -from __future__ import absolute_import - -import csv -import functools -import logging -import os -import sys -import sysconfig - -from pip._vendor import pkg_resources - -from pip._internal.exceptions import UninstallationError -from pip._internal.locations import bin_py, bin_user -from pip._internal.utils.compat import WINDOWS, cache_from_source, uses_pycache -from pip._internal.utils.logging import indent_log -from pip._internal.utils.misc import ( - FakeFile, - ask, - dist_in_usersite, - dist_is_local, - egg_link_path, - is_local, - normalize_path, - renames, - rmtree, -) -from pip._internal.utils.temp_dir import AdjacentTempDirectory, TempDirectory -from pip._internal.utils.typing import MYPY_CHECK_RUNNING - -if MYPY_CHECK_RUNNING: - from typing import ( - Any, Callable, Dict, Iterable, Iterator, List, Optional, Set, Tuple, - ) - from pip._vendor.pkg_resources import Distribution - -logger = logging.getLogger(__name__) - - -def _script_names(dist, script_name, is_gui): - # type: (Distribution, str, bool) -> List[str] - """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 = bin_user - else: - bin_dir = bin_py - 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 - - -def _unique(fn): - # type: (Callable[..., Iterator[Any]]) -> Callable[..., Iterator[Any]] - @functools.wraps(fn) - def unique(*args, **kw): - # type: (Any, Any) -> Iterator[Any] - seen = set() # type: Set[Any] - 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] - """ - Yield all the uninstallation paths for dist based on RECORD-without-.py[co] - - Yield paths to all the files in RECORD. For each .py file in RECORD, add - the .pyc and .pyo in the same directory. - - UninstallPathSet.add() takes care of the __pycache__ .py[co]. - """ - r = csv.reader(FakeFile(dist.get_metadata_lines('RECORD'))) - for row in r: - path = os.path.join(dist.location, row[0]) - yield path - if path.endswith('.py'): - dn, fn = os.path.split(path) - base = fn[:-3] - path = os.path.join(dn, base + '.pyc') - yield path - path = os.path.join(dn, base + '.pyo') - yield path - - -def compact(paths): - # type: (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] - for path in sorted(paths, key=len): - should_skip = any( - path.startswith(shortpath.rstrip("*")) and - path[len(shortpath.rstrip("*").rstrip(sep))] == sep - for shortpath in short_paths - ) - if not should_skip: - short_paths.add(path) - return short_paths - - -def compress_for_rename(paths): - # type: (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 - included every file on disk. - """ - case_map = dict((os.path.normcase(p), p) for p in paths) - remaining = set(case_map) - unchecked = sorted(set(os.path.split(p)[0] - for p in case_map.values()), key=len) - wildcards = set() # type: Set[str] - - def norm_join(*a): - # type: (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): - # This directory has already been handled. - continue - - all_files = set() # type: Set[str] - all_subdirs = set() # type: Set[str] - 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) - # 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. - if not (all_files - remaining): - remaining.difference_update(all_files) - wildcards.add(root + os.sep) - - return set(map(case_map.__getitem__, remaining)) | wildcards - - -def compress_for_output_listing(paths): - # type: (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 - are not added and the top-level directory of the package has a '*' added - at the end - to signify that all it's contents are removed. - - The second set contains files that would have been skipped in the above - folders. - """ - - will_remove = set(paths) - will_skip = set() - - # Determine folders and files - folders = set() - files = set() - for path in will_remove: - if path.endswith(".pyc"): - continue - if path.endswith("__init__.py") or ".dist-info" in path: - folders.add(os.path.dirname(path)) - files.add(path) - - # probably this one https://github.com/python/mypy/issues/390 - _normcased_files = set(map(os.path.normcase, files)) # type: ignore - - folders = compact(folders) - - # This walks the tree using os.walk to not miss extra folders - # that might get added. - for folder in folders: - for dirpath, _, dirfiles in os.walk(folder): - for fname in dirfiles: - if fname.endswith(".pyc"): - continue - - file_ = os.path.join(dirpath, fname) - 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 - } - - return will_remove, will_skip - - -class StashedUninstallPathSet(object): - """A set of file rename operations to stash files while - tentatively uninstalling them.""" - def __init__(self): - # type: () -> None - # Mapping from source file root to [Adjacent]TempDirectory - # for files under that directory. - self._save_dirs = {} # type: Dict[str, TempDirectory] - # (old path, new path) tuples for each move that may need - # to be undone. - self._moves = [] # type: List[Tuple[str, str]] - - def _get_directory_stash(self, path): - # type: (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 - 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 - """Stashes a file. - - If no root has been provided, one will be created for the directory - in the user's temp directory.""" - path = os.path.normcase(path) - head, old_head = os.path.dirname(path), None - save_dir = None - - while head != old_head: - try: - save_dir = self._save_dirs[head] - break - except KeyError: - pass - head, old_head = os.path.dirname(head), head - else: - # Did not find any suitable root - head = os.path.dirname(path) - save_dir = TempDirectory(kind='uninstall') - self._save_dirs[head] = save_dir - - relpath = os.path.relpath(path, head) - if relpath and relpath != os.path.curdir: - return os.path.join(save_dir.path, relpath) - return save_dir.path - - def stash(self, path): - # type: (str) -> str - """Stashes the directory or file and returns its new location. - Handle symlinks as files to avoid modifying the symlink targets. - """ - path_is_dir = os.path.isdir(path) and not os.path.islink(path) - if path_is_dir: - new_path = self._get_directory_stash(path) - else: - new_path = self._get_file_stash(path) - - self._moves.append((path, 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. - # We just created new_path ourselves, so it will - # be removable. - os.rmdir(new_path) - renames(path, new_path) - return new_path - - def commit(self): - # type: () -> 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 - """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) - if os.path.isfile(new_path) or os.path.islink(new_path): - os.unlink(new_path) - elif os.path.isdir(new_path): - rmtree(new_path) - renames(path, new_path) - except OSError as ex: - logger.error("Failed to restore %s", new_path) - logger.debug("Exception: %s", ex) - - self.commit() - - @property - def can_rollback(self): - # type: () -> bool - return bool(self._moves) - - -class UninstallPathSet(object): - """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 - self._moved_paths = StashedUninstallPathSet() - - def _permitted(self, path): - # type: (str) -> bool - """ - Return True if the given path is one we are permitted to - remove/modify, False otherwise. - - """ - return is_local(path) - - def add(self, path): - # type: (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)) - - if not os.path.exists(path): - return - if self._permitted(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' and uses_pycache: - self.add(cache_from_source(path)) - - def add_pth(self, pth_file, entry): - # type: (str, str) -> None - pth_file = normalize_path(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) - 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 - ``auto_confirm`` is True).""" - - if not self.paths: - logger.info( - "Can't uninstall '%s'. No files were found to uninstall.", - self.dist.project_name, - ) - return - - dist_name_version = ( - self.dist.project_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 path in sorted(compact(for_rename)): - moved.stash(path) - logger.debug('Removing file or directory %s', path) - - for pth in self.pth.values(): - pth.remove() - - 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 _display(msg, paths): - # type: (str, Iterable[str]) -> None - if not paths: - return - - logger.info(msg) - with indent_log(): - for path in sorted(compact(paths)): - logger.info(path) - - if not verbose: - 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_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) - if verbose: - _display('Will actually move:', compress_for_rename(self.paths)) - - return ask('Proceed (y/n)? ', ('y', 'n')) == 'y' - - def rollback(self): - # type: () -> 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, - ) - return - logger.info('Rolling back uninstall of %s', self.dist.project_name) - self._moved_paths.rollback() - for pth in self.pth.values(): - pth.rollback() - - def commit(self): - # type: () -> 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): - logger.info( - "Not uninstalling %s at %s, outside environment %s", - dist.key, - dist_path, - sys.prefix, - ) - return cls(dist) - - if dist_path 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, - ) - 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) - - # 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) - # 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: - namespaces = [] - 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) - paths_to_remove.add(path) - paths_to_remove.add(path + '.py') - paths_to_remove.add(path + '.pyc') - paths_to_remove.add(path + '.pyo') - - elif distutils_egg_info: - 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, - ) - ) - - elif dist.location.endswith('.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) - - elif egg_info_exists and dist.egg_info.endswith('.dist-info'): - for path in uninstallation_paths(dist): - paths_to_remove.add(path) - - elif develop_egg_link: - # develop egg - with open(develop_egg_link, 'r') as fh: - link_pointer = os.path.normcase(fh.readline().strip()) - assert (link_pointer == dist.location), ( - 'Egg-link %s does not match installed location of %s ' - '(at %s)' % (link_pointer, dist.project_name, 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) - - else: - logger.debug( - 'Not sure how to uninstall: %s - Check: %s', - dist, dist.location, - ) - - # 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 = bin_user - else: - bin_dir = bin_py - 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(s) - - return paths_to_remove - - -class UninstallPthEntries(object): - def __init__(self, pth_file): - # type: (str) -> None - if not os.path.isfile(pth_file): - raise UninstallationError( - "Cannot remove entries from nonexistent file %s" % pth_file - ) - self.file = pth_file - self.entries = set() # type: Set[str] - self._saved_lines = None # type: Optional[List[bytes]] - - def add(self, entry): - # type: (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 - # paths outside of site-packages, but all the others use forward - # slashes. - # os.path.splitdrive is used instead of os.path.isabs because isabs - # treats non-absolute paths with drive letter markings like c:foo\bar - # as absolute paths. It also does not recognize UNC paths if they don't - # have more than "\\sever\share". Valid examples: "\\server\share\" or - # "\\server\share\folder". Python 2.7.8+ support UNC in splitdrive. - if WINDOWS and not os.path.splitdrive(entry)[0]: - entry = entry.replace('\\', '/') - self.entries.add(entry) - - def remove(self): - # type: () -> None - logger.debug('Removing pth entries from %s:', self.file) - 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' - else: - 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) - lines.remove((entry + endline).encode("utf-8")) - except ValueError: - pass - with open(self.file, 'wb') as fh: - fh.writelines(lines) - - def rollback(self): - # type: () -> bool - if self._saved_lines is None: - 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: - fh.writelines(self._saved_lines) - return True diff --git a/venv/lib/python3.8/site-packages/pip/_internal/self_outdated_check.py b/venv/lib/python3.8/site-packages/pip/_internal/self_outdated_check.py deleted file mode 100644 index 8fc3c59..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/self_outdated_check.py +++ /dev/null @@ -1,242 +0,0 @@ -# The following comment should be removed at some point in the future. -# mypy: disallow-untyped-defs=False - -from __future__ import absolute_import - -import datetime -import hashlib -import json -import logging -import os.path -import sys - -from pip._vendor import pkg_resources -from pip._vendor.packaging import version as packaging_version -from pip._vendor.six import ensure_binary - -from pip._internal.index.collector import LinkCollector -from pip._internal.index.package_finder import PackageFinder -from pip._internal.models.search_scope import SearchScope -from pip._internal.models.selection_prefs import SelectionPreferences -from pip._internal.utils.filesystem import ( - adjacent_tmp_file, - check_path_owner, - replace, -) -from pip._internal.utils.misc import ( - ensure_dir, - get_installed_version, - redact_auth_from_url, -) -from pip._internal.utils.packaging import get_installer -from pip._internal.utils.typing import MYPY_CHECK_RUNNING - -if MYPY_CHECK_RUNNING: - import optparse - from optparse import Values - from typing import Any, Dict, Text, Union - - from pip._internal.network.session import PipSession - - -SELFCHECK_DATE_FMT = "%Y-%m-%dT%H:%M:%SZ" - - -logger = logging.getLogger(__name__) - - -def make_link_collector( - session, # type: PipSession - options, # type: Values - suppress_no_index=False, # type: bool -): - # type: (...) -> LinkCollector - """ - :param session: The Session to use to make requests. - :param suppress_no_index: Whether to ignore the --no-index option - when constructing the SearchScope object. - """ - 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), - ) - index_urls = [] - - # Make sure find_links is a list before passing to create(). - find_links = options.find_links or [] - - search_scope = SearchScope.create( - find_links=find_links, index_urls=index_urls, - ) - - link_collector = LinkCollector(session=session, search_scope=search_scope) - - return link_collector - - -def _get_statefile_name(key): - # type: (Union[str, Text]) -> str - key_bytes = ensure_binary(key) - name = hashlib.sha224(key_bytes).hexdigest() - return name - - -class SelfCheckState(object): - def __init__(self, cache_dir): - # type: (str) -> None - self.state = {} # type: Dict[str, Any] - self.statefile_path = None - - # Try to load the existing state - if cache_dir: - self.statefile_path = os.path.join( - cache_dir, "selfcheck", _get_statefile_name(self.key) - ) - try: - with open(self.statefile_path) as statefile: - self.state = json.load(statefile) - except (IOError, ValueError, KeyError): - # Explicitly suppressing exceptions, since we don't want to - # error out if the cache file is invalid. - pass - - @property - def key(self): - return sys.prefix - - def save(self, pypi_version, current_time): - # type: (str, datetime.datetime) -> None - # If we do not have a path to cache in, don't bother saving. - 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)): - 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)) - - 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), - "pypi_version": pypi_version, - } - - text = json.dumps(state, sort_keys=True, separators=(",", ":")) - - with adjacent_tmp_file(self.statefile_path) as f: - f.write(ensure_binary(text)) - - 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) - except OSError: - # Best effort. - pass - - -def was_installed_by_pip(pkg): - # type: (str) -> bool - """Checks whether pkg was installed by pip - - This is used not to display the upgrade message when pip is in fact - installed by system package manager, such as dnf on Fedora. - """ - try: - dist = pkg_resources.get_distribution(pkg) - return "pip" == get_installer(dist) - except pkg_resources.DistributionNotFound: - return False - - -def pip_self_version_check(session, options): - # type: (PipSession, optparse.Values) -> None - """Check for an update for pip. - - Limit the frequency of checks to once per week. State is stored either in - the active virtualenv or in the user's USER_CACHE_DIR keyed off the prefix - of the pip script path. - """ - installed_version = get_installed_version("pip") - if not installed_version: - return - - pip_version = packaging_version.parse(installed_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 = make_link_collector( - 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 = packaging_version.parse(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 = "{} -m pip".format(sys.executable) - 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 - ) - except Exception: - logger.debug( - "There was an error checking the latest version of pip", - exc_info=True, - ) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/__init__.py b/venv/lib/python3.8/site-packages/pip/_internal/utils/__init__.py deleted file mode 100644 index e69de29..0000000 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/__init__.cpython-38.pyc deleted file mode 100644 index d9c4fbc2feca77530450b6bbb7ae636b30a9d976..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 155 zcmWIL<>g`k0&_FfL=gQLL?8o3AjbiSi&=m~3PUi1CZpdyIxC{<0c4@9Lh@z2(Tp}Es`FJCV){lMN^?@oI`XW=p`*N-dBd) z2nw8AuKo|n(SK>LJ@qHFr_8LRBJr&hIGP7Jk8g(iVlYTOT#p`pBkxC^_ZJDDuK|HC{iqFJxgMR{B#vxIp%fhTC|OVJjqgHdC71(JFlQSlr;dlbi6k8I>MQ>dYocN z%}wdhWU7*5c=QW;3C3x@z0+7ZN6&MRs*!oVI^-8x*QT6zo}ISN@>*JZn95RdjTyV{ z99K})cm}=7bEkphWxjESY4U6#%ehwL^lt>(8?kmM&uo=9P771i6}Tzt;!WMi9{m3D zkC)>3>CeZ%i9cUVr@u~rL2dZVSeG$!v0222xQ}t$JtWS1#V)%xUik=hFg?M0JLp(8 zZc)L=ZxgWz)9y7^gUDpI&;s$^WKhaNUwc4<^Y7z{E9waXdDN7(%r3M#S}wHCk4!Uv z{ln_}CD|r|P=!+Flg63cPB#9>^$HU7a))yBk$8S5pJtsv3S7kFXs#>RM`l~WC63}1 zj>|RG;6o2hZ48wxup21HBoEgWROPvuQwi5T?4TY7M5ux_*(Hw9xrck33dtw`FBRzH zoo(zv7h6duDKZSvbTcHC^EK{mNRq#3-xtL{K-*9EWrHZNXp1;ph|9}C(K4PaM zb}|~au@I`tglJPC&KrEsS_mK@;4YGO7bj{g)}I2P@6$Trd!2eaXyb0s#%@JV6X*f7 yy^TP#)Qwr!a3ILL_@AZS4F=6boBX)`#Qa3>$lgX0CVfBg`}hl4KS-i9O5;!X%}j3q diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/compat.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/compat.cpython-38.pyc deleted file mode 100644 index e81e1c602da88e4713111f50f87656c4c3071594..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6120 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 BLdF09 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/deprecation.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/deprecation.cpython-38.pyc deleted file mode 100644 index 9f81e460ff524d53018e60920c1971deff501286..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2826 zcmaJ@-HzMF73Po>#no!>y5d%{oMXNTJ0wYKZ!!WW~yN=ODF&yW|LJM|QGm_}# zpJ#?EYpuQM`nEtH!M^N+^d)%PtGqxjf&%GxNUc_mi<01Qe$SlqoipE=uXc7i4xZnB z@(c0ruH*cR8k>)g#;5qq-%&_sRfZ!xc(bkm*DPI_T<0psE5;sZx+$<8ZBcGT{vH@YM}aamrH+p_zL zjjqTYdEu2adQV=K7v(N`u1fDqr+4Le*xBQ0F3Uu5I}?`2X_2T@W!7+;=SiGR@#iWN z2biIRS@5~g8M+M@2YG3^RE1V!VdFeA{myr=(&@44qBt;lQd$*3V6N>DeXT-hqfpt7 zq9dgZRzwk+mp^~{=xMb7+5P=LM32834j&F5^xVqZ%NAAmML~i^a=dfz{-ekD_xGMW z{9<^Uk7=9DhoSK)J_8>(${8_0?Mem{-RkP2xVU$&q6P)j zyHWJK6iGAk4@Z;8y7+#7VAEny#Kp}rE5!Iv$(!?;QpwG@oId~E;^R4u4Wc-+N<-;E zY2(BUHW2C;3mrn-&q!4lMab&*I6(dEX`@2lK0Y%-vGk>LxTQa^2q65ww$9R7vZcH9 zmj1GJieSlZS+-=>J$3ax>%B%Gy8&e*P6JbnkK-Et2DW*-Ut*NqqL|y5sy_(%?SM5|8Bc`ef z5h`k$Yxs5&Cy1+5RRO|GWqIXOPvuh!eYK2p@bwOmfNwUm_&EXeYZML(@w&`)*6$C2 z*YP^6>%QHquVeN*(bGa_jrOllvCcClfu(e%_cxC@)&uGxq5sSmo^4qtfPsH_S zDk+pE<~R!{kjIPISmKjOnT?xM9ot2})8TkDs3p&C*L7+?Q7A%0zOUFTj%KM@sTIYs3;{ zk40>-5OJ1k!{b`kFAX1;T7%Bln*gjS(1z;R1FGekE22A~yS9QhZv@jZSLYBtq$bbG z^Z?6&54po?V!~RQ30L#vs!g}FT#Ok+DM5BlRg9TbZ~)M=)+ z&kP{(d&b9<0M8x|6=DNJ-v=m`&Y$1^lY7EW=-g8Z!C8Kd6!M0B?J(!LThke%938-> zR9NIjxBpS)9f_n0t-_sv0%n~E8!q0uGgX;-QRusWp^b=hd=@yNb9`fc>Sg~KL7GTgrxubhu>EIvpmi;8CG3fMfBMn zqM_9rG~^Ref`EgDPO9w<^sDwNII32ST(xCzEL1jDMqk0=A6wTsx8W{^4J8iedIxkH zP^S68{g1!Z!9Q&Ml!dM)QbslfhQr>qsvSi#A2;`kNoh-sJBB8!^)3~p?C3_FcaM-V za^0ufgrNM{Uy(s$tA{z7T&aJ9qWV#)uCEt;yC|?u6Wv$AszJWcbcfJA>TZA2++T->6-oB2|FS%H37A&5^-~$i@ z5gefyI~dEk5-G9jsO4OZv{-j^jHu2w0MjBPt~iz0bWFf?Vvq_kNtM*d60t~~ER#E= z5m-)@s>7K1Zx65``yo?aV%lJn6pSOTr|uy~IvW&ZsYJG4O;v@Hk9p&4w0x!XGT|>()yBb~3c{Qea< z_;oOAbM>iw7dH_z6}A<3fl+tHs9Q4XieUz+V45^AZWgjMm?1T$3(qP{6VBwHq4Zvc lzaUmiyUjQyc|@Pc3gZtzSlCi5MZ*nE0sgo2KU&jN{{e_PFZTcd diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/encoding.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/encoding.cpython-38.pyc deleted file mode 100644 index 22e7645e34605a056412369141a3c1f8db0cbb46..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1247 zcmZuv&u<$=6rR~%Uay@tP16cWkyb)Taly74qYzbqs@e`9QnzZ7L$`^n&Cb}~X1u$d znN{k@IRO{`0FKD!#=kUIPC0Xe3%pq;mJiHo-}k=vX5ahf?HsMGc?i~*JD-MIHbQ@D zvbtO#PvI56f+2`thJpp+02kZ{i~`NT1T>g6wgVd@YV!_olR4v3P#U{|J1z%hh@-b2 zu?7ZUh1dmFiBsSjDHV8&xCP!OBMF!Cg`%Yd@i2li&kXyLAQH zP_Ks7#`D)NU-#SJb=yDmUmf*&-}k<)nabLag;e%oo-wMdL;7A`*ts0kcP|_bk9RK0 z3#^~grOW6d+uB})THDJkxQvSX&@)O&oDAPQ`TFEoJlc9wKR$1qd{&FF)^oiqKo~4) z!z+FVBT)yPe12?P;!9(SW_XI{m|IgMjVb;S6a2IBA)1*}V~!1k(E)k~xtT?P6HH8< zh3`9;=F}t>u{9^onZY~Ko;gz!YAwB4X^x1ctC7-t(QUPE2kM&Aot23@$JuYvn^op$ zt_NDa_@zCf(U~9mrxQtqFC>R^`h%21=-G?szD)fn<(x*6O?*NnIKCWFpC*fuc%Bby zFJ$aAggUUDrBTReV@PGj>43tw=U%+v-phqX-1Q+nx7{A%ZVJNNvrpl9;bI@ zfaTh~(xwQ0qU=yaalBWnDhp&CC{M_cOK~2{kun)gltU;eqRJK-i>0b`d+iq;xEB3a zUF8TG@@S--Ay4y6C}*KjZT_D~Wr~SV8;~M&5avwYsIOVdBB2bGd76%udlOa`ixc_> z;va$9f1WnwIBRBcR?m|RCPGR5d_*a$$NBKx?&OPeoon{vL{grFteMN0iRMkMMmABE zFqdh6aT;AxY=S{{6?^!haUVaxAK-Ot;q`y{#}KdGQ;t4&B=}vR%HWjW)6N6v(^&Rt z6nz?UlELrgdcw-NCMFQBFE7`(SGh3W{?Xyyt}0)9k9Smc>Gq#>SJ{4dxvjOmOtiLF zw*lMl@`^5AiqdfwGs@R>Kdrx*+KPEtX!vTJlAO_Rv@GF+adGh&Rl~xY<~3Wy{1L`=H>Ws%%1`+8r*t#p>DS3( z_B-Mv>qXk(ADoF0y|1m5b6EruzH~8Df>vw!=ex z;7Zc&Uk*X+1i>6_0WNB31TWyZs8|~W*cxOAtq21a^D;=Yh1y#U zSI@35mk_#8I2M~F=vGDPlz^))Hr9kC#70OD$OYq6lsf)nhJ&^t4tR);Yc$f?5iA?{ zNfRQH6?_TEzy}CzU1OR=w}U9PK#(KWuoZEnr|k~8k7-|9s)^W176k^80UT;G#&_QC zBu5y~qH36tK@UaTGjE8;7#5ihB)Rkg+2j9#YeZlJSb1-qAJCm*l^6gTq1+Po0*u`s zYB?%XkLkAl{~`g3anLag5Euih)_YV1tP#an_j@S&H_u*>k)Di23UDiklQcW~o#1fW z5iPPnsJwLXAJhV_DfzubgVana+<&tY|=4NM&?JF~3rRq3A&fXkv8XNm*`X zY}(tRvbuDgVZImjM zM~9?vT|c`yh(?fMhD~xlO|!r9nLoq+B3&=u@>A^f?_s3kU$ml9vY<<1pw{30@8l4w xh@Hct`3dcw9tL=gCH{mOf*%q&YTl-$v!~kfR*8@3Dhb4EmYt<%S)RT#`5S)ij2r*} diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/filesystem.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/filesystem.cpython-38.pyc deleted file mode 100644 index 3bbdfc1603592aa2e2af88df008982205354d20f..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4035 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 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/filetypes.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/filetypes.cpython-38.pyc deleted file mode 100644 index 71366cd6913187ec306c8d6ab72968d9c74a5980..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 556 zcmY*VO-sW-6x?i+Cat!Dh=M0C9&%^`A}T0iEzuS=N?X775~91Ui<>m23AOu={7bod z@-KMNmsqsE-J|B^uR8nU;x8b*2q4F{nW*%wXj;#46DG8X{F%=^?W!S5LTL$uwdcJRFST zz)$!nw5lI437JZ^d~ttu@3q=a>&)w3yKcul1y$>(kzi7_CQrh|(y$UgwjSgbD9M8~ zHK`ZMtIUNT6mllQrBb*;20r+bM`mf}4T}dq=*OJ@f*mUG>v#n~#fw-~@`i&A==#?;7MYn) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/glibc.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/glibc.cpython-38.pyc deleted file mode 100644 index b431e01f27a02ffd8a97de3db84ae34ac0c6c7bb..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1708 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 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/inject_securetransport.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/inject_securetransport.cpython-38.pyc deleted file mode 100644 index c209d4807737756a867658cf984598ecea0da7d7..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 932 zcmZuwOK;Oa5Z<+&)-`=ZAQh=dXfH?@HBNa5I3QF&IaDeRs#_ktSR3!QakANUch?O; z^aMWyj{GHGIq?@bF?Ld^s#s}9GufGMzM0QCT3ZVcoM%t((FZOXmV zRGLC*yG@iN`J{HEAUGWIML^6@m4cB0Crn9Bs3DwcF{_2+$rCsuYrf69RkK96%PMmi63zwsfaIo!tUC_$4h9V{`UDCk=p*`y zMjms=Exp@Rw4uTit;x~_#&y+JU1gU~9H<;!tHeM2pS7NV6Sm@NiBUbxr3PJ5zR^bQ z5LX+f5z$_X7_L;VnVHHj1hpqhParg+y0O>j+S6L;YP0{Y7sEQz_q~H;uOFxJ(c9O( zgX&I^7g2i7B~v;owGjE>ag-@(bw1GWJ)&y4pUfd{&9|QB(yDZk8ajFjlA6q4NUwtb zH}2X=(FNR2DGQo`79G%ri%wpio;{yEnbvRJ8is30MYpuMFx>_Cwb7ztR&D^piLUPHH9PE)3`G}Ru&&5sS!E2ajk{1@|o%*%S&rk=}N I@m>G+KWIV$FaQ7m diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/logging.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/logging.cpython-38.pyc deleted file mode 100644 index 04c80d0f07c62949d9e39b3c66be95294b7dbaa8..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 9159 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 G#Qz6C{+*xz diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/models.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/models.cpython-38.pyc deleted file mode 100644 index 7644515642878d5455abe649aca8a838ecb077d0..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1924 zcmb_cO>fgc5Z$$%)J>E08zfMXB?M9qZ7v8nR8>U}2q7Y*suId&<$AV_Q^$69H~atC|y1|GGP>&P-^caQ69*XFb?BWua|&~bma%4 zuvS3hWV7&PAG`j9gJf-vf3koRD%jVo?SKO%v?VCR0@^aTu!wd6DzJpsg(}q0EmpVP}q((Me|0ZvFSo8>SW!_vc>I^wMS;rrZ5E^@B4B+ZP=vqwTPN zdj5Lw;)3>?B8-hxu^%=2cr3bEoWf2z$XtPYp%J1+ROyr%FZ0W-y9C-9`v#o+MvdmT zvC<_nY{K^2MYqYKZ{vfY$AiL zd06}pE#&zOEgm2PZw?j&aBnT*Sz6GYcsd6Q0{Ej$QHthi^8_cDx>%?%c`dzSFmb40 zb?qVV+E=$}2Ae7n#0B4&|OSodl*YG+q1W z*frGz#;e@1W>ub1;9HO>NH0xEwrxbE0;UA>$vvhqsXJ-DAI3~!^v@11}5K_fXmT~ Sa<^O1-lN)?7hR|1+P?q{=8{MN diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/packaging.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/packaging.cpython-38.pyc deleted file mode 100644 index cfcb4ef4b798f542207f2ce2c78bd724a5cf0a77..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2608 zcmaJ@%Wm676y=bVMA4MxR~$P@(`kSN5fI636SRd<6fqnpH4-a^?EnpnfMUdvM4PY7 zjN;mmfwu0lAJC<|>@W0FrpvDS3*EGLhLRvVKq+vZmzQ_$J?BubDivFU>&q|h`hU)7 z+Fx=qeHk!$3^)4&nm`Lsq{YZZNRIVLcXjBE$cRnXRBL8bh>LDfjSEpJwp=SNyJa;m zMs_^o&Zu!Ia^i|xQDZBbjjL`IX{1Vj1%KseE}nPi;{|s??c32}yyPya@l13rUUrwk zRv%s`D;LOJ4V<9zi{{=4W`ip9H-oug9{O9sLa+$^M}fYt)t3H-__Z1mRsStZqdq5I z7-uQvO<1#^5)$nClo1NEN_N!sC}C-zwh620!e$w1hnpWGCX9Dj2XSN6zT{ z%ix_U-Kki*iEMot(HpSV23SrmiFKI+h4mj{5TG-}0r4Ci>gPJWH_(R00FbRlrW~E= z$)|EP0L0VBfqn*j7>;+Ad0|)#3|<;&ht@f|&_PekGku^31z=E*mj{~U%Fl?~=bB{8 zaAp90kOm{?LId6uPk+i`PV-uS!2k6z%0L7r1eS0Iong2IMfc*7Ufi#>CfJey#lUvl z>JmO}F@hSy@=ZB9gtfDEu<>N$VB^%BoxFHZUhmsMI8C z$ThPAQYs4VC}jjNY06B9$~ZVL@na&a@l?!6YmiE*yb5!9vnt(TXdb}LZbPFLP2?c! zUtM>QjbN-VAXB#hIz_`q%Jvd?WGwPl;JF6_37m5P&;Silpr8VU*N@8d4hIOp4zy5W zXDRq;dF8;37xi+wy@><1W@WVMtR(A6a6c%*iD0Z*%Ymu0kBGgSP-fRxik zh!qxO$oYpzil`TaZBCb9?MjlwqAb%Dc0B{ToLxnkAj`0HDie7rLGr6INzmso0j2=M zfHw^osT4iY-mIvE=@%MZg2X|uYY3R|Zb^MpjixAXH}?-VUcA`aqqo2bME)^!VqqFR zUKA#TiGrj=Rs-Tn3sWv$JxxVErmz}CgnkEh`8jkO%_0kK`k8#mZDD&}rw=MjJdetg zh>`>-08=<5_QR+#f|NX=m;se)fVL$;N)-XzYf~#=I?^kpxVgrzD1))EHOLQbqCVJ6 zAzfVAR=U@SL)OlDapUsS`8GevByq|zqT*;GC6L0uE+};#cAWnQpbo6LtCymj{!cqX8>%TvsPYzKIUK2>wp3K7xuI}+RCIQ*eK|DB#-y;yE`7PtaJ#BN8fxI{9zOFJ1(jN z_Q(_X^*#_m1dT~TeM*sMF-t7pGQ1VrNyBeYA{**4oY`?RY5A?h@tvgYw<&o>L_;*+ z5z&;LOUv(y)&cRHKS3+;Xwf~7WGr|brBcJPBU3$9lIvW-YW?}q{t@5a-P!(u|8zJS z?Twy!R$)Jl!n|u`KK#Bb|q+uR0hkp1`knfk@(0L3}2tZwV%>cf_}aEgCR` zZ=wZrQ#hgxb4zqY7iLHF#0t!9u`1SJ?ub74eW&Q5_2)7VM34uw?Y)xSSJ|6LNaf}y zLGCIU2<;|IG50u%rFM^1mbif{KtYtHfjS>_To@s`S`Os#--cgfhURomIDmdYuIT8B z7HwW?^;ltR86Ou;xpPI-DqQ(%XP76G;Ut=DP18vbo=LIw_C(5fE1Hg9e|!GmEuIZ| zlmdil5D%w$6zk#SY|NF^*;Iv64<_e@!$Bm8U0x1 z*U{et8B+*^G1{knc9+iTC{(3uC}760jSUJ|7>L1pz~BSDq|01*Ore&OSP_&V1Xxtl> z(NWWsFGRlv#bpvcuKDwi%*g9v6QerLiw@^WCZ;j+JB#H(8}R51_#2suObu#}jVVEY zt$MDbpG{8{n`XCsss`q%8sz7bC><*-p`y85G+?2cNLpq)dvz+q+*rTO>B4!uK;t`1 PkLj=;?Xe!S>0Rq@*Ak$N diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/setuptools_build.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/setuptools_build.cpython-38.pyc deleted file mode 100644 index b50b823d835124d7b461efcacb78baac1262c60a..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2927 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 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/temp_dir.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/temp_dir.cpython-38.pyc deleted file mode 100644 index 00114e619f9632393fc4cd33b0ac0ed18c61232d..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6711 zcmcgw&2!tv6~`Arkdi1_{&s8!apj5G+H#sWiJQ7<)^bc?k>F+JTFG-&1so-D<56_*foI_eLECDfNxy^HtR@F3m~G8gUN2#q^h_0V_FS*z-D z+FwnRxGk6$HChQ5%lK9alBQr!MZ<6Ub;j|fwDdF*cZ452#EZ=vf-{Dv*&Fw7-S@73 zvUK%V-tEtpm#;5hs}`iW(A<>PViXAJTo;V{BH_}x*%DFG^kZ3E*=(`TeJ%}eMNX}- zMr$$REI^}8h%Bro?PeIz?E061hZ1i3n7)ldXj|I1XL_2@yPBc(bYJh3L+x`-*Y0ZX zYF)hFQ%}FvZfp0jns>Ap`f}CawBT~a6Bsg#xYt+DkcE^~lLwPH++F)Z;|J00{n6#kOHZioq8Gt%99mv%izrSn(oi18ns05&BlS30 z_2be4)2%rjdCca^RCkE4W_U0i`qqvsbr(?qV~ zR`~?1_MSW%Au^+eDZe`0U6S+Mu zqHU&bp))r&lhLJ_A9e_oZP1G@dL|eT6^6RodRGti9rA0V^V@4oxNzXLsNUu*9G$wm z7W;K~Eg>6Z>W+=?3Si^>K)aBw`R!P^E40 zPlPvq1jU=UQwN2kTc%?|c+{+q2{@-}6c9&E(T|Lo z?QVcKlW;^GW%73GTy;#=qN00R9=5L@sxfBV%z!^SUf=ZR-6$jDOjp|A>-W{OjcGF(v)$6)Dq`Nx26DD z#=RWc)j}SkNDjY%4yvo1$!IFx%yXd-!Mfym%FV#4L-HhkWw=wKeyv!sW^~Iyx?(w;LGhX&5eQ)06uV)^E&VH4aKluV>CC~QAXa%t z;`%|rKmoZST+-(Q_gSxM@$-KFHyr? z##dTB9Dt%d`O~$j{1^A+k;IkGzeffGOdEfY;;O|HyNfo@LgGt0BQ99%|Yf;Q(vGFjZ z7llV@$4MRAI#~$WYP+7NuNjvpfR0<2{}8tLGwv)eaBO`B-ZG!Np@8> zJ%a~DjUd(y1C*(4SUWmDEeiCsMPx{JG&?`P%^JyL1d;s%$skx#^rzq~Tx{R+{K>_& zvRt(@I`}z;%&cN##Z!@HoIohv&kgzesCa=pB_L>)tylJ_*$1b!yv%7M_HlJ8^KDX( z|A2})Du^+q)8fbmx!BA+|6Qt}WSD&cH{%VkG^6%xv_0@R2G6hT%?T%Sl$uC?Rw8Ij0-O1F>R!?CmYHKxt~CztC?U-)wVXJ_B~@!RiQdiTBe zFaKnD-~F@+u%v|OuD%VY-Jy&|7a+r~wq-LIvSYF#FCH!>Ykt{`CY!F z@)4SFcoBsz#f)?_#n^5z5OLncrpBd4%|r}jWF6>03@3$3eCnQ~6Nc3U!f$P2=g?H4 z4?zuC+ZrADAW0?N1~T&A)uDTQM=8xq{Y$BV%4LE3%{r52%$l+kK^>7KaVk#*Nn;hH zpyYX^4CPQ{g$DdpPJOzxu!sXm98WIXz9X%TBx=&(WPq*~*+J@&EMYSkMj^~DohEyt zP8@b+i*nkl=S!oi(|-`KTohV)7Ac0M+21?H38WikGkZ7iK8yFx*;l}JT;5m~LPrl1 zxUb?)|B52ZLJ%Q=%Lhi!=)ncIEkY@9x7xE*J#99u9ivz10GZo%w?J9RU9I_+rHSIh zGLLnwXX{#Lwrg)V!r3SR%@4j(XQUx&zO?UY_q9hS?`5Nvsei8kr2pyBNhQB5CN?IK z1x<})K?PCSo<5M5cBab zsG#IP7AduZ>&s%2srGN&`*|D^KiKjRQms&WV1doxc#GIi0z2I>YB>DhT16)RQF~`hBX>(aef!VP~kC z&cLOetZv{;S{-Wfv-J5*DkvGs0?N>UgZLqxE7@`3hr}W&?F%QdSMC2M4gB;;Yzs~r TlV;hpOxSi}=BWCw%&h(wa*B}E diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/typing.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/typing.cpython-38.pyc deleted file mode 100644 index 6ad94fe2e5608470190565bb909d60971469d883..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1437 zcmZWpO^@3)5S7;6%|bwW=&|U5m$X>GlF+0`i$xK%U3Al+s1c-_L-yjO#j!<1B2|9a z70_ex3a0x>4wU=%^Qlnx`$lw>}#1FGQ6U;4Wk&;p<5WXQ>`8)xq_ zY;Ek6SP~axT_7c75H6ywo_Q)JrMRTfVqqnHiPC>|4d_fJZ4Q-^$sZWijlV z4}=FUm5uGWsUQum0OoEKz;M(<#AFsjXb`GS6W+wO;#k>053gA-r5!4SZB=xf>d;`Q ze#MIHZ3bcof3XJ-%*8rNmkfY5>xO_~;4@@ASixH)26b69z_t-+Qp1KCUQ4VU$)*)8 z!Lo@s+Rkl2?icBx%vj9B@hA^sI_l6(It!g`U+za$wEJu-4v3^7WI)Up*}@|HYk?o#ne}BYkN2D!P66JI8y0*W*Xlem31bSS*xn7K`1dAFHxE+3!!m@3`#0P5`z${ci85 SXIzgz#W4MRI+^C5O#cU963LDL diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/ui.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/ui.cpython-38.pyc deleted file mode 100644 index 8f846c63cd0590d8daac41acba29bc282e8df276..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 11802 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 UXLyQJlHm-JiSbI5cGJcG0TG~irT_o{ diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/virtualenv.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/utils/__pycache__/virtualenv.cpython-38.pyc deleted file mode 100644 index 012f6d674cb7141355725c08c715960f7a4d0fc3..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3280 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 diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/appdirs.py b/venv/lib/python3.8/site-packages/pip/_internal/utils/appdirs.py deleted file mode 100644 index 93d17b5..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/utils/appdirs.py +++ /dev/null @@ -1,44 +0,0 @@ -""" -This code wraps the vendored appdirs module to so the return values are -compatible for the current pip code base. - -The intention is to rewrite current usages gradually, keeping the tests pass, -and eventually drop this after all usages are changed. -""" - -from __future__ import absolute_import - -import os - -from pip._vendor import appdirs as _appdirs - -from pip._internal.utils.typing import MYPY_CHECK_RUNNING - -if MYPY_CHECK_RUNNING: - from typing import List - - -def user_cache_dir(appname): - # type: (str) -> str - return _appdirs.user_cache_dir(appname, appauthor=False) - - -def user_config_dir(appname, roaming=True): - # type: (str, bool) -> str - return _appdirs.user_config_dir(appname, appauthor=False, roaming=roaming) - - -def user_data_dir(appname, roaming=False): - # type: (str, bool) -> str - return _appdirs.user_data_dir(appname, appauthor=False, roaming=roaming) - - -# for the discussion regarding site_config_dir locations -# see -def site_config_dirs(appname): - # type: (str) -> List[str] - 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] diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/compat.py b/venv/lib/python3.8/site-packages/pip/_internal/utils/compat.py deleted file mode 100644 index 6efa52a..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/utils/compat.py +++ /dev/null @@ -1,269 +0,0 @@ -"""Stuff that differs in different Python versions and platform -distributions.""" - -# The following comment should be removed at some point in the future. -# mypy: disallow-untyped-defs=False - -from __future__ import absolute_import, division - -import codecs -import locale -import logging -import os -import shutil -import sys - -from pip._vendor.six import PY2, text_type - -from pip._internal.utils.typing import MYPY_CHECK_RUNNING - -if MYPY_CHECK_RUNNING: - from typing import Optional, Text, Tuple, Union - -try: - import ipaddress -except ImportError: - try: - from pip._vendor import ipaddress # type: ignore - except ImportError: - import ipaddr as ipaddress # type: ignore - ipaddress.ip_address = ipaddress.IPAddress # type: ignore - ipaddress.ip_network = ipaddress.IPNetwork # type: ignore - - -__all__ = [ - "ipaddress", "uses_pycache", "console_to_str", - "get_path_uid", "stdlib_pkgs", "WINDOWS", "samefile", "get_terminal_size", -] - - -logger = logging.getLogger(__name__) - -if PY2: - import imp - - try: - cache_from_source = imp.cache_from_source # type: ignore - except AttributeError: - # does not use __pycache__ - cache_from_source = None - - uses_pycache = cache_from_source is not None -else: - uses_pycache = True - from importlib.util import cache_from_source - - -if PY2: - # In Python 2.7, backslashreplace exists - # but does not support use for decoding. - # We implement our own replace handler for this - # situation, so that we can consistently use - # backslash replacement for all versions. - def backslashreplace_decode_fn(err): - raw_bytes = (err.object[i] for i in range(err.start, err.end)) - # Python 2 gave us characters - convert to numeric bytes - raw_bytes = (ord(b) for b in raw_bytes) - return u"".join(u"\\x%x" % c for c in raw_bytes), err.end - codecs.register_error( - "backslashreplace_decode", - backslashreplace_decode_fn, - ) - backslashreplace_decode = "backslashreplace_decode" -else: - backslashreplace_decode = "backslashreplace" - - -def has_tls(): - # type: () -> bool - try: - import _ssl # noqa: F401 # ignore unused - return True - except ImportError: - pass - - from pip._vendor.urllib3.util import IS_PYOPENSSL - return IS_PYOPENSSL - - -def str_to_display(data, desc=None): - # type: (Union[bytes, Text], Optional[str]) -> Text - """ - For display or logging purposes, convert a bytes object (or text) to - text (e.g. unicode in Python 2) safe for output. - - :param desc: An optional phrase describing the input data, for use in - the log message if a warning is logged. Defaults to "Bytes object". - - This function should never error out and so can take a best effort - approach. It is okay to be lossy if needed since the return value is - just for display. - - We assume the data is in the locale preferred encoding. If it won't - decode properly, we warn the user but decode as best we can. - - We also ensure that the output can be safely written to standard output - without encoding errors. - """ - if isinstance(data, text_type): - return data - - # Otherwise, data is a bytes object (str in Python 2). - # First, get the encoding we assume. This is the preferred - # encoding for the locale, unless that is not found, or - # it is ASCII, in which case assume UTF-8 - encoding = locale.getpreferredencoding() - if (not encoding) or codecs.lookup(encoding).name == "ascii": - encoding = "utf-8" - - # Now try to decode the data - if we fail, warn the user and - # decode with replacement. - try: - decoded_data = data.decode(encoding) - except UnicodeDecodeError: - if desc is None: - desc = 'Bytes object' - msg_format = '{} does not appear to be encoded as %s'.format(desc) - logger.warning(msg_format, encoding) - decoded_data = data.decode(encoding, errors=backslashreplace_decode) - - # Make sure we can print the output, by encoding it to the output - # encoding with replacement of unencodable characters, and then - # decoding again. - # We use stderr's encoding because it's less likely to be - # redirected and if we don't find an encoding we skip this - # step (on the assumption that output is wrapped by something - # that won't fail). - # The double getattr is to deal with the possibility that we're - # being called in a situation where sys.__stderr__ doesn't exist, - # or doesn't have an encoding attribute. Neither of these cases - # should occur in normal pip use, but there's no harm in checking - # in case people use pip in (unsupported) unusual situations. - output_encoding = getattr(getattr(sys, "__stderr__", None), - "encoding", None) - - if output_encoding: - output_encoded = decoded_data.encode( - output_encoding, - errors="backslashreplace" - ) - decoded_data = output_encoded.decode(output_encoding) - - return decoded_data - - -def console_to_str(data): - # type: (bytes) -> Text - """Return a string, safe for output, of subprocess output. - """ - return str_to_display(data, desc='Subprocess output') - - -def get_path_uid(path): - # type: (str) -> int - """ - Return path's uid. - - Does not follow symlinks: - https://github.com/pypa/pip/pull/935#discussion_r5307003 - - Placed this function in compat due to differences on AIX and - Jython, that should eventually go away. - - :raises OSError: When path is a symlink or can't be read. - """ - if hasattr(os, 'O_NOFOLLOW'): - fd = os.open(path, os.O_RDONLY | os.O_NOFOLLOW) - file_uid = os.fstat(fd).st_uid - os.close(fd) - else: # AIX and Jython - # WARNING: time of check vulnerability, but best we can do w/o NOFOLLOW - if not os.path.islink(path): - # older versions of Jython don't have `os.fstat` - file_uid = os.stat(path).st_uid - else: - # raise OSError for parity with os.O_NOFOLLOW above - raise OSError( - "%s is a symlink; Will not return uid for symlinks" % path - ) - return file_uid - - -def expanduser(path): - # type: (str) -> str - """ - Expand ~ and ~user constructions. - - Includes a workaround for https://bugs.python.org/issue14768 - """ - expanded = os.path.expanduser(path) - if path.startswith('~/') and expanded.startswith('//'): - expanded = expanded[1:] - return expanded - - -# packages in the stdlib that may have installation metadata, but should not be -# considered 'installed'. this theoretically could be determined based on -# dist.location (py27:`sysconfig.get_paths()['stdlib']`, -# py26:sysconfig.get_config_vars('LIBDEST')), but fear platform variation may -# make this ineffective, so hard-coding -stdlib_pkgs = {"python", "wsgiref", "argparse"} - - -# windows detection, covers cpython and ironpython -WINDOWS = (sys.platform.startswith("win") or - (sys.platform == 'cli' and os.name == 'nt')) - - -def samefile(file1, file2): - # type: (str, str) -> bool - """Provide an alternative for os.path.samefile on Windows/Python2""" - if hasattr(os.path, 'samefile'): - return os.path.samefile(file1, file2) - else: - path1 = os.path.normcase(os.path.abspath(file1)) - path2 = os.path.normcase(os.path.abspath(file2)) - return path1 == path2 - - -if hasattr(shutil, 'get_terminal_size'): - def get_terminal_size(): - # type: () -> Tuple[int, int] - """ - Returns a tuple (x, y) representing the width(x) and the height(y) - in characters of the terminal window. - """ - return tuple(shutil.get_terminal_size()) # type: ignore -else: - def get_terminal_size(): - # type: () -> Tuple[int, int] - """ - Returns a tuple (x, y) representing the width(x) and the height(y) - in characters of the terminal window. - """ - def ioctl_GWINSZ(fd): - try: - import fcntl - import termios - import struct - cr = struct.unpack_from( - 'hh', - fcntl.ioctl(fd, termios.TIOCGWINSZ, '12345678') - ) - except Exception: - return None - if cr == (0, 0): - return None - return cr - cr = ioctl_GWINSZ(0) or ioctl_GWINSZ(1) or ioctl_GWINSZ(2) - if not cr: - if sys.platform != "win32": - try: - fd = os.open(os.ctermid(), os.O_RDONLY) - cr = ioctl_GWINSZ(fd) - os.close(fd) - except Exception: - pass - if not cr: - cr = (os.environ.get('LINES', 25), os.environ.get('COLUMNS', 80)) - return int(cr[1]), int(cr[0]) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/deprecation.py b/venv/lib/python3.8/site-packages/pip/_internal/utils/deprecation.py deleted file mode 100644 index 2f20cfd..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/utils/deprecation.py +++ /dev/null @@ -1,104 +0,0 @@ -""" -A module that implements tooling to enable easy warnings about deprecations. -""" - -# The following comment should be removed at some point in the future. -# mypy: disallow-untyped-defs=False - -from __future__ import absolute_import - -import logging -import warnings - -from pip._vendor.packaging.version import parse - -from pip import __version__ as current_version -from pip._internal.utils.typing import MYPY_CHECK_RUNNING - -if MYPY_CHECK_RUNNING: - from typing import Any, Optional - - -DEPRECATION_MSG_PREFIX = "DEPRECATION: " - - -class PipDeprecationWarning(Warning): - pass - - -_original_showwarning = None # type: Any - - -# Warnings <-> Logging Integration -def _showwarning(message, category, filename, lineno, file=None, line=None): - if file is not None: - if _original_showwarning is not None: - _original_showwarning( - message, category, filename, lineno, file, line, - ) - elif issubclass(category, PipDeprecationWarning): - # We use a specially named logger which will handle all of the - # deprecation messages for pip. - logger = logging.getLogger("pip._internal.deprecations") - logger.warning(message) - else: - _original_showwarning( - message, category, filename, lineno, file, line, - ) - - -def install_warning_logger(): - # type: () -> None - # Enable our Deprecation Warnings - warnings.simplefilter("default", PipDeprecationWarning, append=True) - - global _original_showwarning - - if _original_showwarning is None: - _original_showwarning = warnings.showwarning - warnings.showwarning = _showwarning - - -def deprecated(reason, replacement, gone_in, issue=None): - # type: (str, Optional[str], Optional[str], Optional[int]) -> None - """Helper to deprecate existing functionality. - - reason: - Textual reason shown to the user about why this functionality has - been deprecated. - 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 - this. - 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 {}."), - (issue, ( - "You can find discussion regarding this at " - "https://github.com/pypa/pip/issues/{}." - )), - ] - message = " ".join( - template.format(val) for val, template in sentences if val 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 PipDeprecationWarning(message) - - warnings.warn(message, category=PipDeprecationWarning, stacklevel=2) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/distutils_args.py b/venv/lib/python3.8/site-packages/pip/_internal/utils/distutils_args.py deleted file mode 100644 index e38e402..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/utils/distutils_args.py +++ /dev/null @@ -1,48 +0,0 @@ -from distutils.errors import DistutilsArgError -from distutils.fancy_getopt import FancyGetopt - -from pip._internal.utils.typing import MYPY_CHECK_RUNNING - -if MYPY_CHECK_RUNNING: - 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/venv/lib/python3.8/site-packages/pip/_internal/utils/encoding.py b/venv/lib/python3.8/site-packages/pip/_internal/utils/encoding.py deleted file mode 100644 index ab4d4b9..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/utils/encoding.py +++ /dev/null @@ -1,42 +0,0 @@ -# The following comment should be removed at some point in the future. -# mypy: strict-optional=False - -import codecs -import locale -import re -import sys - -from pip._internal.utils.typing import MYPY_CHECK_RUNNING - -if MYPY_CHECK_RUNNING: - from typing import List, Tuple, Text - -BOMS = [ - (codecs.BOM_UTF8, 'utf-8'), - (codecs.BOM_UTF16, 'utf-16'), - (codecs.BOM_UTF16_BE, 'utf-16-be'), - (codecs.BOM_UTF16_LE, 'utf-16-le'), - (codecs.BOM_UTF32, 'utf-32'), - (codecs.BOM_UTF32_BE, 'utf-32-be'), - (codecs.BOM_UTF32_LE, 'utf-32-le'), -] # type: List[Tuple[bytes, Text]] - -ENCODING_RE = re.compile(br'coding[:=]\s*([-\w.]+)') - - -def auto_decode(data): - # type: (bytes) -> Text - """Check a bytes string for a BOM to correctly detect the encoding - - Fallback to locale.getpreferredencoding(False) like open() on Python3""" - for bom, encoding in BOMS: - if data.startswith(bom): - return data[len(bom):].decode(encoding) - # Lets check the first two lines as in PEP263 - for line in data.split(b'\n')[:2]: - if line[0:1] == b'#' and ENCODING_RE.search(line): - encoding = ENCODING_RE.search(line).groups()[0].decode('ascii') - return data.decode(encoding) - return data.decode( - locale.getpreferredencoding(False) or sys.getdefaultencoding(), - ) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/entrypoints.py b/venv/lib/python3.8/site-packages/pip/_internal/utils/entrypoints.py deleted file mode 100644 index befd01c..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/utils/entrypoints.py +++ /dev/null @@ -1,31 +0,0 @@ -import sys - -from pip._internal.cli.main import main -from pip._internal.utils.typing import MYPY_CHECK_RUNNING - -if MYPY_CHECK_RUNNING: - from typing import Optional, List - - -def _wrapper(args=None): - # type: (Optional[List[str]]) -> int - """Central wrapper for all old entrypoints. - - Historically pip has had several entrypoints defined. Because of issues - arising from PATH, sys.path, multiple Pythons, their interactions, and most - of them having a pip installed, users suffer every time an entrypoint gets - moved. - - To alleviate this pain, and provide a mechanism for warning users and - directing them to an appropriate place for help, we now define all of - our old entrypoints as wrappers for the current one. - """ - sys.stderr.write( - "WARNING: pip is being invoked by an old script wrapper. This will " - "fail in a future version of pip.\n" - "Please see https://github.com/pypa/pip/issues/5599 for advice on " - "fixing the underlying issue.\n" - "To avoid this problem you can invoke Python with '-m pip' instead of " - "running pip directly.\n" - ) - return main(args) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/filesystem.py b/venv/lib/python3.8/site-packages/pip/_internal/utils/filesystem.py deleted file mode 100644 index 6f1537e..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/utils/filesystem.py +++ /dev/null @@ -1,171 +0,0 @@ -import errno -import os -import os.path -import random -import shutil -import stat -import sys -from contextlib import contextmanager -from tempfile import NamedTemporaryFile - -# NOTE: retrying is not annotated in typeshed as on 2017-07-17, which is -# why we ignore the type on this import. -from pip._vendor.retrying import retry # type: ignore -from pip._vendor.six import PY2 - -from pip._internal.utils.compat import get_path_uid -from pip._internal.utils.typing import MYPY_CHECK_RUNNING, cast - -if MYPY_CHECK_RUNNING: - from typing import BinaryIO, Iterator - - class NamedTemporaryFileResult(BinaryIO): - @property - def file(self): - # type: () -> BinaryIO - pass - - -def check_path_owner(path): - # type: (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"): - return True - - assert os.path.isabs(path) - - previous = None - while path != previous: - if os.path.lexists(path): - # Check if path is writable by current user. - if os.geteuid() == 0: - # Special handling for root user in order to handle properly - # cases where users use sudo without -H flag. - try: - path_uid = get_path_uid(path) - except OSError: - return False - return path_uid == 0 - else: - return os.access(path, os.W_OK) - else: - previous, path = path, os.path.dirname(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, IOError): - 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("`%s` is a socket" % f) - - raise - - -def is_socket(path): - # type: (str) -> bool - return stat.S_ISSOCK(os.lstat(path).st_mode) - - -@contextmanager -def adjacent_tmp_file(path): - # type: (str) -> Iterator[NamedTemporaryFileResult] - """Given a path to a file, open a temp file next to it securely and ensure - it is written to disk after the context reaches its end. - """ - with NamedTemporaryFile( - delete=False, - dir=os.path.dirname(path), - prefix=os.path.basename(path), - suffix='.tmp', - ) as f: - result = cast('NamedTemporaryFileResult', f) - try: - yield result - finally: - result.file.flush() - os.fsync(result.file.fileno()) - - -_replace_retry = retry(stop_max_delay=1000, wait_fixed=250) - -if PY2: - @_replace_retry - def replace(src, dest): - # type: (str, str) -> None - try: - os.rename(src, dest) - except OSError: - os.remove(dest) - os.rename(src, dest) - -else: - 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 - """Check if a directory is writable. - - Uses os.access() on POSIX, tries creating files on Windows. - """ - # If the directory doesn't exist, find the closest parent that does. - while not os.path.isdir(path): - parent = os.path.dirname(path) - if parent == path: - break # Should never get here, but infinite loops are bad - path = parent - - if os.name == 'posix': - return os.access(path, os.W_OK) - - return _test_writable_dir_win(path) - - -def _test_writable_dir_win(path): - # type: (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_' - alphabet = 'abcdefghijklmnopqrstuvwxyz0123456789' - for i in range(10): - name = basename + ''.join(random.choice(alphabet) for _ in range(6)) - file = os.path.join(path, name) - try: - fd = os.open(file, os.O_RDWR | os.O_CREAT | os.O_EXCL) - except OSError as e: - if e.errno == errno.EEXIST: - continue - if e.errno == errno.EPERM: - # This could be because there's a directory with the same name. - # But it's highly unlikely there's a directory called that, - # so we'll assume it's because the parent dir is not writable. - return False - raise - else: - os.close(fd) - os.unlink(file) - return True - - # This should never be reached - raise EnvironmentError( - 'Unexpected condition testing for writable directory' - ) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/filetypes.py b/venv/lib/python3.8/site-packages/pip/_internal/utils/filetypes.py deleted file mode 100644 index daa0ca7..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/utils/filetypes.py +++ /dev/null @@ -1,16 +0,0 @@ -"""Filetype information. -""" -from pip._internal.utils.typing import MYPY_CHECK_RUNNING - -if MYPY_CHECK_RUNNING: - from typing import Tuple - -WHEEL_EXTENSION = '.whl' -BZ2_EXTENSIONS = ('.tar.bz2', '.tbz') # type: Tuple[str, ...] -XZ_EXTENSIONS = ('.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, ...] -ARCHIVE_EXTENSIONS = ( - ZIP_EXTENSIONS + BZ2_EXTENSIONS + TAR_EXTENSIONS + XZ_EXTENSIONS -) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/glibc.py b/venv/lib/python3.8/site-packages/pip/_internal/utils/glibc.py deleted file mode 100644 index 3610424..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/utils/glibc.py +++ /dev/null @@ -1,98 +0,0 @@ -# The following comment should be removed at some point in the future. -# mypy: strict-optional=False - -from __future__ import absolute_import - -import os -import sys - -from pip._internal.utils.typing import MYPY_CHECK_RUNNING - -if MYPY_CHECK_RUNNING: - from typing import Optional, Tuple - - -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 - if sys.platform == "win32": - return None - try: - # os.confstr("CS_GNU_LIBC_VERSION") returns a string like "glibc 2.17": - _, version = os.confstr("CS_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] - "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. - process_namespace = ctypes.CDLL(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() - # py2 / py3 compatibility: - if not isinstance(version_str, str): - version_str = version_str.decode("ascii") - - return version_str - - -# platform.libc_ver regularly returns completely nonsensical glibc -# versions. E.g. on my computer, platform says: -# -# ~$ python2.7 -c 'import platform; print(platform.libc_ver())' -# ('glibc', '2.7') -# ~$ python3.5 -c 'import platform; print(platform.libc_ver())' -# ('glibc', '2.9') -# -# But the truth is: -# -# ~$ ldd --version -# ldd (Debian GLIBC 2.22-11) 2.22 -# -# This is unfortunate, because it means that the linehaul data on libc -# 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] - """Try to determine the glibc version - - Returns a tuple of strings (lib, version) which default to empty strings - in case the lookup fails. - """ - glibc_version = glibc_version_string() - if glibc_version is None: - return ("", "") - else: - return ("glibc", glibc_version) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/hashes.py b/venv/lib/python3.8/site-packages/pip/_internal/utils/hashes.py deleted file mode 100644 index 4c41551..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/utils/hashes.py +++ /dev/null @@ -1,131 +0,0 @@ -from __future__ import absolute_import - -import hashlib - -from pip._vendor.six import iteritems, iterkeys, itervalues - -from pip._internal.exceptions import ( - HashMismatch, - HashMissing, - InstallationError, -) -from pip._internal.utils.misc import read_chunks -from pip._internal.utils.typing import MYPY_CHECK_RUNNING - -if MYPY_CHECK_RUNNING: - from typing import ( - Dict, List, BinaryIO, NoReturn, Iterator - ) - from pip._vendor.six import PY3 - if PY3: - from hashlib import _Hash - else: - from hashlib import _hash as _Hash - - -# The recommended hash algo of the moment. Change this whenever the state of -# the art changes; it won't hurt backward compatibility. -FAVORITE_HASH = 'sha256' - - -# Names of hashlib algorithms allowed by the --hash option and ``pip hash`` -# Currently, those are the ones at least as collision-resistant as sha256. -STRONG_HASHES = ['sha256', 'sha384', 'sha512'] - - -class Hashes(object): - """A wrapper that builds multiple hashes at once and checks them against - known-good values - - """ - def __init__(self, hashes=None): - # type: (Dict[str, List[str]]) -> None - """ - :param hashes: A dict of algorithm names pointing to lists of allowed - hex digests - """ - self._allowed = {} if hashes is None else hashes - - @property - def digest_count(self): - # type: () -> 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 - """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 - """Check good hashes against ones built from iterable of chunks of - data. - - Raise HashMismatch if none match. - - """ - gots = {} - for hash_name in iterkeys(self._allowed): - try: - gots[hash_name] = hashlib.new(hash_name) - except (ValueError, TypeError): - raise InstallationError('Unknown hash name: %s' % hash_name) - - for chunk in chunks: - for hash in itervalues(gots): - hash.update(chunk) - - for hash_name, got in iteritems(gots): - if got.hexdigest() in self._allowed[hash_name]: - return - self._raise(gots) - - def _raise(self, gots): - # type: (Dict[str, _Hash]) -> NoReturn - raise HashMismatch(self._allowed, gots) - - def check_against_file(self, file): - # type: (BinaryIO) -> None - """Check good hashes against a file-like object - - Raise HashMismatch if none match. - - """ - return self.check_against_chunks(read_chunks(file)) - - def check_against_path(self, path): - # type: (str) -> None - with open(path, 'rb') as file: - return self.check_against_file(file) - - def __nonzero__(self): - # type: () -> bool - """Return whether I know any known-good hashes.""" - return bool(self._allowed) - - def __bool__(self): - # type: () -> bool - return self.__nonzero__() - - -class MissingHashes(Hashes): - """A workalike for Hashes used when we're missing a hash for a requirement - - It computes the actual hash of the requirement and raises a HashMissing - exception showing it to the user. - - """ - def __init__(self): - # type: () -> 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(MissingHashes, self).__init__(hashes={FAVORITE_HASH: []}) - - def _raise(self, gots): - # type: (Dict[str, _Hash]) -> NoReturn - raise HashMissing(gots[FAVORITE_HASH].hexdigest()) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/inject_securetransport.py b/venv/lib/python3.8/site-packages/pip/_internal/utils/inject_securetransport.py deleted file mode 100644 index 5b93b1d..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/utils/inject_securetransport.py +++ /dev/null @@ -1,36 +0,0 @@ -"""A helper module that injects SecureTransport, on import. - -The import should be done as early as possible, to ensure all requests and -sessions (or whatever) are created after injecting SecureTransport. - -Note that we only do the injection on macOS, when the linked OpenSSL is too -old to handle TLSv1.2. -""" - -import sys - - -def inject_securetransport(): - # type: () -> None - # Only relevant on macOS - if sys.platform != "darwin": - return - - try: - import ssl - except ImportError: - return - - # Checks for OpenSSL 1.0.1 - if ssl.OPENSSL_VERSION_NUMBER >= 0x1000100f: - return - - try: - from pip._vendor.urllib3.contrib import securetransport - except (ImportError, OSError): - return - - securetransport.inject_into_urllib3() - - -inject_securetransport() diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/logging.py b/venv/lib/python3.8/site-packages/pip/_internal/utils/logging.py deleted file mode 100644 index 7767111..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/utils/logging.py +++ /dev/null @@ -1,398 +0,0 @@ -# The following comment should be removed at some point in the future. -# mypy: disallow-untyped-defs=False - -from __future__ import absolute_import - -import contextlib -import errno -import logging -import logging.handlers -import os -import sys -from logging import Filter, getLogger - -from pip._vendor.six import PY2 - -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: - # Use "import as" and set colorama in the else clause to avoid mypy - # errors and get the following correct revealed type for colorama: - # `Union[_importlib_modulespec.ModuleType, None]` - # Otherwise, we get an error like the following in the except block: - # > Incompatible types in assignment (expression has type "None", - # variable has type Module) - # TODO: eliminate the need to use "import as" once mypy addresses some - # of its issues with conditional imports. Here is an umbrella issue: - # https://github.com/python/mypy/issues/1297 - from pip._vendor import colorama as _colorama -# Lots of different errors can come from this, including SystemError and -# ImportError. -except Exception: - colorama = None -else: - # Import Fore explicitly rather than accessing below as colorama.Fore - # to avoid the following error running mypy: - # > Module has no attribute "Fore" - # TODO: eliminate the need to import Fore once mypy addresses some of its - # issues with conditional imports. This particular case could be an - # instance of the following issue (but also see the umbrella issue above): - # https://github.com/python/mypy/issues/3500 - from pip._vendor.colorama import Fore - - colorama = _colorama - - -_log_state = threading.local() -_log_state.indentation = 0 -subprocess_logger = getLogger('pip.subprocessor') - - -class BrokenStdoutLoggingError(Exception): - """ - Raised if BrokenPipeError occurs for the stdout stream while logging. - """ - pass - - -# BrokenPipeError does not exist in Python 2 and, in addition, manifests -# differently in Windows and non-Windows. -if WINDOWS: - # In Windows, a broken pipe can show up as EINVAL rather than EPIPE: - # https://bugs.python.org/issue19612 - # https://bugs.python.org/issue30418 - if PY2: - def _is_broken_pipe_error(exc_class, exc): - """See the docstring for non-Windows Python 3 below.""" - return (exc_class is IOError and - exc.errno in (errno.EINVAL, errno.EPIPE)) - else: - # In Windows, a broken pipe IOError became OSError in Python 3. - def _is_broken_pipe_error(exc_class, exc): - """See the docstring for non-Windows Python 3 below.""" - return ((exc_class is BrokenPipeError) or # noqa: F821 - (exc_class is OSError and - exc.errno in (errno.EINVAL, errno.EPIPE))) -elif PY2: - def _is_broken_pipe_error(exc_class, exc): - """See the docstring for non-Windows Python 3 below.""" - return (exc_class is IOError and exc.errno == errno.EPIPE) -else: - # Then we are in the non-Windows Python 3 case. - def _is_broken_pipe_error(exc_class, exc): - """ - Return whether an exception is a broken pipe error. - - Args: - exc_class: an exception class. - exc: an exception instance. - """ - return (exc_class is BrokenPipeError) # noqa: F821 - - -@contextlib.contextmanager -def indent_log(num=2): - """ - A context manager which will cause the log output to be indented for any - log messages emitted inside it. - """ - _log_state.indentation += num - try: - yield - finally: - _log_state.indentation -= num - - -def get_indentation(): - return getattr(_log_state, 'indentation', 0) - - -class IndentingFormatter(logging.Formatter): - - def __init__(self, *args, **kwargs): - """ - A logging.Formatter that obeys the indent_log() context manager. - - :param add_timestamp: A bool indicating output lines should be prefixed - with their record's timestamp. - """ - self.add_timestamp = kwargs.pop("add_timestamp", False) - super(IndentingFormatter, self).__init__(*args, **kwargs) - - def get_message_start(self, formatted, levelno): - """ - Return the start of the formatted log message (not counting the - prefix to add to each line). - """ - if levelno < logging.WARNING: - return '' - if formatted.startswith(DEPRECATION_MSG_PREFIX): - # Then the message already has a prefix. We don't want it to - # look like "WARNING: DEPRECATION: ...." - return '' - if levelno < logging.ERROR: - return 'WARNING: ' - - return 'ERROR: ' - - def format(self, record): - """ - Calls the standard formatter, but will indent all of the log message - lines by our current indentation level. - """ - formatted = super(IndentingFormatter, self).format(record) - message_start = self.get_message_start(formatted, record.levelno) - formatted = message_start + formatted - - prefix = '' - if self.add_timestamp: - # TODO: Use Formatter.default_time_format after dropping PY2. - t = self.formatTime(record, "%Y-%m-%dT%H:%M:%S") - prefix = '%s,%03d ' % (t, record.msecs) - prefix += " " * get_indentation() - formatted = "".join([ - prefix + line - for line in formatted.splitlines(True) - ]) - return formatted - - -def _color_wrap(*colors): - def wrapped(inp): - 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(Fore.RED)), - (logging.WARNING, _color_wrap(Fore.YELLOW)), - ] - else: - COLORS = [] - - def __init__(self, stream=None, no_color=None): - logging.StreamHandler.__init__(self, stream) - self._no_color = no_color - - if WINDOWS and colorama: - self.stream = colorama.AnsiToWin32(self.stream) - - def _using_stdout(self): - """ - Return whether the handler is using sys.stdout. - """ - if WINDOWS and colorama: - # Then self.stream is an AnsiToWin32 object. - return self.stream.wrapped is sys.stdout - - return self.stream is sys.stdout - - def should_color(self): - # 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 - ) - - # 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 - - # If anything else we should not color it - return False - - def format(self, record): - msg = logging.StreamHandler.format(self, 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): - 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 - # exception so we can handle it in main() instead of logging the - # broken pipe error and continuing. - if (exc_class and self._using_stdout() and - _is_broken_pipe_error(exc_class, exc)): - raise BrokenStdoutLoggingError() - - return super(ColorizedStreamHandler, self).handleError(record) - - -class BetterRotatingFileHandler(logging.handlers.RotatingFileHandler): - - def _open(self): - ensure_dir(os.path.dirname(self.baseFilename)) - return logging.handlers.RotatingFileHandler._open(self) - - -class MaxLevelFilter(Filter): - - def __init__(self, level): - self.level = level - - def filter(self, record): - return record.levelno < self.level - - -class ExcludeLoggerFilter(Filter): - - """ - A logging Filter that excludes records from a logger (or its children). - """ - - def filter(self, record): - # The base Filter class allows only records from a logger (or its - # children). - return not super(ExcludeLoggerFilter, self).filter(record) - - -def setup_logging(verbosity, no_color, user_log_file): - """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" - elif verbosity == -1: - level = "WARNING" - elif verbosity == -2: - level = "ERROR" - elif verbosity <= -3: - level = "CRITICAL" - else: - level = "INFO" - - level_number = getattr(logging, level) - - # The "root" logger should match the "console" level *unless* we also need - # to log to a user log file. - include_user_log = user_log_file is not None - if include_user_log: - additional_log_file = user_log_file - root_level = "DEBUG" - else: - additional_log_file = "/dev/null" - root_level = level - - # Disable any logging besides WARNING unless we have DEBUG level logging - # enabled for vendored libraries. - vendored_log_level = "WARNING" if level in ["INFO", "ERROR"] else "DEBUG" - - # Shorthands for clarity - log_streams = { - "stdout": "ext://sys.stdout", - "stderr": "ext://sys.stderr", - } - handler_classes = { - "stream": "pip._internal.utils.logging.ColorizedStreamHandler", - "file": "pip._internal.utils.logging.BetterRotatingFileHandler", - } - handlers = ["console", "console_errors", "console_subprocess"] + ( - ["user_log"] if include_user_log else [] - ) - - logging.config.dictConfig({ - "version": 1, - "disable_existing_loggers": False, - "filters": { - "exclude_warnings": { - "()": "pip._internal.utils.logging.MaxLevelFilter", - "level": logging.WARNING, - }, - "restrict_to_subprocess": { - "()": "logging.Filter", - "name": subprocess_logger.name, - }, - "exclude_subprocess": { - "()": "pip._internal.utils.logging.ExcludeLoggerFilter", - "name": subprocess_logger.name, - }, - }, - "formatters": { - "indent": { - "()": IndentingFormatter, - "format": "%(message)s", - }, - "indent_with_timestamp": { - "()": IndentingFormatter, - "format": "%(message)s", - "add_timestamp": True, - }, - }, - "handlers": { - "console": { - "level": level, - "class": handler_classes["stream"], - "no_color": no_color, - "stream": log_streams["stdout"], - "filters": ["exclude_subprocess", "exclude_warnings"], - "formatter": "indent", - }, - "console_errors": { - "level": "WARNING", - "class": handler_classes["stream"], - "no_color": no_color, - "stream": log_streams["stderr"], - "filters": ["exclude_subprocess"], - "formatter": "indent", - }, - # A handler responsible for logging to the console messages - # from the "subprocessor" logger. - "console_subprocess": { - "level": level, - "class": handler_classes["stream"], - "no_color": no_color, - "stream": log_streams["stderr"], - "filters": ["restrict_to_subprocess"], - "formatter": "indent", - }, - "user_log": { - "level": "DEBUG", - "class": handler_classes["file"], - "filename": additional_log_file, - "delay": True, - "formatter": "indent_with_timestamp", - }, - }, - "root": { - "level": root_level, - "handlers": handlers, - }, - "loggers": { - "pip._vendor": { - "level": vendored_log_level - } - }, - }) - - return level_number diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/marker_files.py b/venv/lib/python3.8/site-packages/pip/_internal/utils/marker_files.py deleted file mode 100644 index 42ea814..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/utils/marker_files.py +++ /dev/null @@ -1,25 +0,0 @@ -import os.path - -DELETE_MARKER_MESSAGE = '''\ -This file is placed here by pip to indicate the source was put -here by pip. - -Once this package is successfully installed this source code will be -deleted (unless you remove this file). -''' -PIP_DELETE_MARKER_FILENAME = 'pip-delete-this-directory.txt' - - -def has_delete_marker_file(directory): - # type: (str) -> bool - return os.path.exists(os.path.join(directory, PIP_DELETE_MARKER_FILENAME)) - - -def write_delete_marker_file(directory): - # type: (str) -> None - """ - Write the pip delete marker file into this directory. - """ - filepath = os.path.join(directory, PIP_DELETE_MARKER_FILENAME) - with open(filepath, 'w') as marker_fp: - marker_fp.write(DELETE_MARKER_MESSAGE) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/misc.py b/venv/lib/python3.8/site-packages/pip/_internal/utils/misc.py deleted file mode 100644 index 554af0b..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/utils/misc.py +++ /dev/null @@ -1,904 +0,0 @@ -# The following comment should be removed at some point in the future. -# mypy: strict-optional=False -# mypy: disallow-untyped-defs=False - -from __future__ import absolute_import - -import contextlib -import errno -import getpass -import hashlib -import io -import logging -import os -import posixpath -import shutil -import stat -import sys -from collections import deque - -from pip._vendor import pkg_resources -# NOTE: retrying is not annotated in typeshed as on 2017-07-17, which is -# why we ignore the type on this import. -from pip._vendor.retrying import retry # type: ignore -from pip._vendor.six import PY2, text_type -from pip._vendor.six.moves import input -from pip._vendor.six.moves.urllib import parse as urllib_parse -from pip._vendor.six.moves.urllib.parse import unquote as urllib_unquote - -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, - expanduser, - stdlib_pkgs, - str_to_display, -) -from pip._internal.utils.typing import MYPY_CHECK_RUNNING, cast -from pip._internal.utils.virtualenv import ( - running_under_virtualenv, - virtualenv_no_global, -) - -if PY2: - from io import BytesIO as StringIO -else: - from io import StringIO - -if MYPY_CHECK_RUNNING: - from typing import ( - Any, AnyStr, Container, Iterable, List, Optional, Text, - Tuple, Union, - ) - from pip._vendor.pkg_resources import Distribution - - VersionInfo = Tuple[int, int, int] - - -__all__ = ['rmtree', 'display_path', 'backup_dir', - 'ask', 'splitext', - 'format_size', 'is_installable_dir', - 'normalize_path', - 'renames', 'get_prog', - 'captured_stdout', 'ensure_dir', - 'get_installed_version', 'remove_auth_from_url'] - - -logger = logging.getLogger(__name__) - - -def get_pip_version(): - # type: () -> str - pip_pkg_dir = os.path.join(os.path.dirname(__file__), "..", "..") - pip_pkg_dir = os.path.abspath(pip_pkg_dir) - - return ( - 'pip {} from {} (python {})'.format( - __version__, pip_pkg_dir, get_major_minor_version(), - ) - ) - - -def normalize_version_info(py_version_info): - # type: (Tuple[int, ...]) -> Tuple[int, int, int] - """ - Convert a tuple of ints representing a Python version to one of length - three. - - :param py_version_info: a tuple of ints representing a Python version, - or None to specify no version. The tuple can have any length. - - :return: a tuple of length three if `py_version_info` is non-None. - Otherwise, return `py_version_info` unchanged (i.e. None). - """ - if len(py_version_info) < 3: - py_version_info += (3 - len(py_version_info)) * (0,) - elif len(py_version_info) > 3: - py_version_info = py_version_info[:3] - - return cast('VersionInfo', py_version_info) - - -def ensure_dir(path): - # type: (AnyStr) -> None - """os.path.makedirs without EEXIST.""" - try: - os.makedirs(path) - except OSError as e: - # Windows can raise spurious ENOTEMPTY errors. See #6426. - if e.errno != errno.EEXIST and e.errno != errno.ENOTEMPTY: - raise - - -def get_prog(): - # type: () -> str - try: - prog = os.path.basename(sys.argv[0]) - if prog in ('__main__.py', '-c'): - return "%s -m pip" % sys.executable - else: - return prog - except (AttributeError, TypeError, IndexError): - pass - return 'pip' - - -# Retry every half second for up to 3 seconds -@retry(stop_max_delay=3000, wait_fixed=500) -def rmtree(dir, ignore_errors=False): - # type: (str, bool) -> None - shutil.rmtree(dir, ignore_errors=ignore_errors, - onerror=rmtree_errorhandler) - - -def rmtree_errorhandler(func, path, exc_info): - """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.""" - try: - has_attr_readonly = not (os.stat(path).st_mode & stat.S_IWRITE) - except (IOError, OSError): - # it's equivalent to os.path.exists - return - - if has_attr_readonly: - # convert to read/write - os.chmod(path, stat.S_IWRITE) - # use the original function to repeat the operation - func(path) - return - else: - raise - - -def path_to_display(path): - # type: (Optional[Union[str, Text]]) -> Optional[Text] - """ - Convert a bytes (or text) path to text (unicode in Python 2) for display - and logging purposes. - - This function should never error out. Also, this function is mainly needed - for Python 2 since in Python 3 str paths are already text. - """ - if path is None: - return None - if isinstance(path, text_type): - return path - # Otherwise, path is a bytes object (str in Python 2). - try: - display_path = path.decode(sys.getfilesystemencoding(), 'strict') - except UnicodeDecodeError: - # Include the full bytes to make troubleshooting easier, even though - # it may not be very human readable. - if PY2: - # Convert the bytes to a readable str representation using - # repr(), and then convert the str to unicode. - # Also, we add the prefix "b" to the repr() return value both - # to make the Python 2 output look like the Python 3 output, and - # to signal to the user that this is a bytes representation. - display_path = str_to_display('b{!r}'.format(path)) - else: - # Silence the "F821 undefined name 'ascii'" flake8 error since - # in Python 3 ascii() is a built-in. - display_path = ascii(path) # noqa: F821 - - return display_path - - -def display_path(path): - # type: (Union[str, Text]) -> str - """Gives the display value for a given path, making it relative to cwd - if possible.""" - path = os.path.normcase(os.path.abspath(path)) - if sys.version_info[0] == 2: - path = path.decode(sys.getfilesystemencoding(), 'replace') - path = path.encode(sys.getdefaultencoding(), 'replace') - if path.startswith(os.getcwd() + os.path.sep): - path = '.' + path[len(os.getcwd()):] - return path - - -def backup_dir(dir, ext='.bak'): - # type: (str, str) -> str - """Figure out the name of a directory to back up the given dir to - (adding .bak, .bak2, etc)""" - n = 1 - extension = ext - while os.path.exists(dir + extension): - n += 1 - extension = ext + str(n) - return dir + extension - - -def ask_path_exists(message, options): - # type: (str, 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 - """Raise an error if no input is allowed.""" - if os.environ.get('PIP_NO_INPUT'): - raise Exception( - 'No input was expected ($PIP_NO_INPUT set); question: %s' % - message - ) - - -def ask(message, options): - # type: (str, Iterable[str]) -> str - """Ask the message interactively, with the given possible responses""" - while 1: - _check_no_input(message) - response = input(message) - response = response.strip().lower() - if response not in options: - print( - 'Your response (%r) was not one of the expected responses: ' - '%s' % (response, ', '.join(options)) - ) - else: - return response - - -def ask_input(message): - # type: (str) -> str - """Ask for input interactively.""" - _check_no_input(message) - return input(message) - - -def ask_password(message): - # type: (str) -> str - """Ask for a password interactively.""" - _check_no_input(message) - return getpass.getpass(message) - - -def format_size(bytes): - # type: (float) -> str - if bytes > 1000 * 1000: - return '%.1f MB' % (bytes / 1000.0 / 1000) - elif bytes > 10 * 1000: - return '%i kB' % (bytes / 1000) - elif bytes > 1000: - return '%.1f kB' % (bytes / 1000.0) - else: - return '%i bytes' % bytes - - -def is_installable_dir(path): - # type: (str) -> bool - """Is path is a directory containing setup.py or pyproject.toml? - """ - if not os.path.isdir(path): - return False - setup_py = os.path.join(path, 'setup.py') - if os.path.isfile(setup_py): - return True - pyproject_toml = os.path.join(path, 'pyproject.toml') - if os.path.isfile(pyproject_toml): - return True - return False - - -def read_chunks(file, size=io.DEFAULT_BUFFER_SIZE): - """Yield pieces of data from a file-like object until EOF.""" - while True: - chunk = file.read(size) - if not chunk: - break - yield chunk - - -def normalize_path(path, resolve_symlinks=True): - # type: (str, bool) -> str - """ - Convert a path to its canonical, case-normalized, absolute version. - - """ - path = expanduser(path) - if resolve_symlinks: - path = os.path.realpath(path) - else: - path = os.path.abspath(path) - return os.path.normcase(path) - - -def splitext(path): - # type: (str) -> Tuple[str, str] - """Like os.path.splitext, but take off .tar too""" - base, ext = posixpath.splitext(path) - if base.lower().endswith('.tar'): - ext = base[-4:] + ext - base = base[:-4] - return base, ext - - -def renames(old, new): - # type: (str, str) -> None - """Like os.renames(), but handles renaming across devices.""" - # Implementation borrowed from os.renames(). - head, tail = os.path.split(new) - if head and tail and not os.path.exists(head): - os.makedirs(head) - - shutil.move(old, new) - - head, tail = os.path.split(old) - if head and tail: - try: - os.removedirs(head) - except OSError: - pass - - -def is_local(path): - # type: (str) -> bool - """ - Return True if this is a path pip is allowed to modify. - - If we're in a virtualenv, sys.prefix points to the virtualenv's - prefix; only sys.prefix is considered local. - - If we're not in a virtualenv, in general we can modify anything. - However, if the OS vendor has configured distutils to install - somewhere other than sys.prefix (which could be a subdirectory of - sys.prefix, e.g. /usr/local), we consider sys.prefix itself nonlocal - and the domain of the OS vendor. (In other words, everything _other - than_ sys.prefix is considered local.) - - Caution: this function assumes the head of path has been normalized - with normalize_path. - """ - - path = normalize_path(path) - prefix = normalize_path(sys.prefix) - - if running_under_virtualenv(): - return path.startswith(normalize_path(sys.prefix)) - else: - from pip._internal.locations import distutils_scheme - if path.startswith(prefix): - for local_path in distutils_scheme("").values(): - if path.startswith(normalize_path(local_path)): - return True - return False - else: - return True - - -def dist_is_local(dist): - # type: (Distribution) -> bool - """ - Return True if given Distribution object is installed somewhere pip - is allowed to modify. - - """ - 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. - - If ``local_only`` is True (default), only return installations - local to the current virtualenv, if in a virtualenv. - - ``skip`` argument is an iterable of lower-case project names to - ignore; defaults to stdlib_pkgs - - If ``include_editables`` is False, don't report editables. - - If ``editables_only`` is True , only report editables. - - If ``user_only`` is True , only report installations in the user - site directory. - - If ``paths`` is set, only report the distributions present at the - specified list of locations. - """ - if paths: - working_set = pkg_resources.WorkingSet(paths) - else: - working_set = pkg_resources.working_set - - if local_only: - local_test = dist_is_local - else: - def local_test(d): - return True - - if include_editables: - def editable_test(d): - return True - else: - def editable_test(d): - return not dist_is_editable(d) - - if editables_only: - def editables_only_test(d): - return dist_is_editable(d) - else: - def editables_only_test(d): - return True - - if user_only: - user_test = dist_in_usersite - else: - def user_test(d): - return True - - return [d for d in working_set - if local_test(d) and - d.key not in skip and - editable_test(d) and - editables_only_test(d) and - user_test(d) - ] - - -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: (str, str) -> None - logger.info(msg, *args) - - -class FakeFile(object): - """Wrap a list of lines in an object with readline() to make - ConfigParser happy.""" - def __init__(self, lines): - self._gen = (l for l in lines) - - def readline(self): - try: - try: - return next(self._gen) - except NameError: - return self._gen.next() - except StopIteration: - return '' - - def __iter__(self): - return self._gen - - -class StreamWrapper(StringIO): - - @classmethod - def from_stream(cls, orig_stream): - cls.orig_stream = orig_stream - return cls() - - # compileall.compile_dir() needs stdout.encoding to print to stdout - @property - def encoding(self): - return self.orig_stream.encoding - - -@contextlib.contextmanager -def captured_output(stream_name): - """Return a context manager used by captured_stdout/stdin/stderr - that temporarily replaces the sys stream *stream_name* with a StringIO. - - Taken from Lib/support/__init__.py in the CPython repo. - """ - orig_stdout = getattr(sys, stream_name) - setattr(sys, stream_name, StreamWrapper.from_stream(orig_stdout)) - try: - yield getattr(sys, stream_name) - finally: - setattr(sys, stream_name, orig_stdout) - - -def captured_stdout(): - """Capture the output of sys.stdout: - - with captured_stdout() as stdout: - print('hello') - self.assertEqual(stdout.getvalue(), 'hello\n') - - Taken from Lib/support/__init__.py in the CPython repo. - """ - return captured_output('stdout') - - -def captured_stderr(): - """ - See captured_stdout(). - """ - return captured_output('stderr') - - -class cached_property(object): - """A property that is only computed once per instance and then replaces - itself with an ordinary attribute. Deleting the attribute resets the - property. - - Source: https://github.com/bottlepy/bottle/blob/0.11.5/bottle.py#L175 - """ - - def __init__(self, func): - self.__doc__ = getattr(func, '__doc__') - self.func = func - - def __get__(self, obj, cls): - if obj is None: - # We're being accessed from the class itself, not from an object - return self - value = obj.__dict__[self.func.__name__] = self.func(obj) - return value - - -def get_installed_version(dist_name, working_set=None): - """Get the installed version of dist_name avoiding pkg_resources cache""" - # Create a requirement that we'll look for inside of setuptools. - req = pkg_resources.Requirement.parse(dist_name) - - if working_set is None: - # We want to avoid having this cached, so we need to construct a new - # working set each time. - working_set = pkg_resources.WorkingSet() - - # Get the installed distribution from our working set - dist = working_set.find(req) - - # Check to see if we got an installed distribution or not, if we did - # we want to return it's version. - return dist.version if dist else None - - -def consume(iterator): - """Consume an iterable at C speed.""" - deque(iterator, maxlen=0) - - -# Simulates an enum -def enum(*sequential, **named): - 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 - """ - Build a netloc from a host-port pair - """ - if port is None: - return host - if ':' in host: - # Only wrap host with square brackets when it is IPv6 - host = '[{}]'.format(host) - return '{}:{}'.format(host, port) - - -def build_url_from_netloc(netloc, scheme='https'): - # type: (str, str) -> str - """ - Build a full URL from a netloc. - """ - if netloc.count(':') >= 2 and '@' not in netloc and '[' not in netloc: - # It must be a bare IPv6 address, so wrap it with brackets. - netloc = '[{}]'.format(netloc) - return '{}://{}'.format(scheme, netloc) - - -def parse_netloc(netloc): - # type: (str) -> Tuple[str, Optional[int]] - """ - Return the host-port pair from a netloc. - """ - url = build_url_from_netloc(netloc) - parsed = urllib_parse.urlparse(url) - return parsed.hostname, parsed.port - - -def split_auth_from_netloc(netloc): - """ - Parse out and remove the auth information from a netloc. - - Returns: (netloc, (username, password)). - """ - if '@' not in netloc: - return netloc, (None, None) - - # Split from the right because that's how urllib.parse.urlsplit() - # 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) - 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 - # using the password attribute of the return value) - user_pass = auth.split(':', 1) - else: - user_pass = auth, None - - user_pass = tuple( - None if x is None else urllib_unquote(x) for x in user_pass - ) - - return netloc, user_pass - - -def redact_netloc(netloc): - # type: (str) -> str - """ - Replace the sensitive data in a netloc with "****", if it exists. - - For example: - - "user:pass@example.com" returns "user:****@example.com" - - "accesstoken@example.com" returns "****@example.com" - """ - netloc, (user, password) = split_auth_from_netloc(netloc) - if user is None: - return netloc - if password is None: - user = '****' - password = '' - else: - user = urllib_parse.quote(user) - password = ':****' - return '{user}{password}@{netloc}'.format(user=user, - password=password, - netloc=netloc) - - -def _transform_url(url, transform_netloc): - """Transform and replace netloc in a url. - - transform_netloc is a function taking the netloc and returning a - tuple. The first element of this tuple is the new netloc. The - entire tuple is returned. - - Returns a tuple containing the transformed url as item 0 and the - original tuple returned by transform_netloc as item 1. - """ - purl = urllib_parse.urlsplit(url) - netloc_tuple = transform_netloc(purl.netloc) - # stripped url - url_pieces = ( - purl.scheme, netloc_tuple[0], purl.path, purl.query, purl.fragment - ) - surl = urllib_parse.urlunsplit(url_pieces) - return surl, netloc_tuple - - -def _get_netloc(netloc): - return split_auth_from_netloc(netloc) - - -def _redact_netloc(netloc): - return (redact_netloc(netloc),) - - -def split_auth_netloc_from_url(url): - # type: (str) -> Tuple[str, str, Tuple[str, str]] - """ - Parse a url into separate netloc, auth, and url with no auth. - - Returns: (url_without_auth, netloc, (username, password)) - """ - url_without_auth, (netloc, auth) = _transform_url(url, _get_netloc) - return url_without_auth, netloc, auth - - -def remove_auth_from_url(url): - # type: (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 - """Replace the password in a given url with ****.""" - return _transform_url(url, _redact_netloc)[0] - - -class HiddenText(object): - def __init__( - self, - secret, # type: str - redacted, # type: str - ): - # type: (...) -> None - self.secret = secret - self.redacted = redacted - - def __repr__(self): - # type: (...) -> str - return ''.format(str(self)) - - def __str__(self): - # type: (...) -> str - return self.redacted - - # This is useful for testing. - def __eq__(self, other): - # type: (Any) -> bool - if type(self) != type(other): - return False - - # The string being used for redaction doesn't also have to match, - # just the raw, original string. - return (self.secret == other.secret) - - # We need to provide an explicit __ne__ implementation for Python 2. - # TODO: remove this when we drop PY2 support. - def __ne__(self, other): - # type: (Any) -> bool - return not self == other - - -def hide_value(value): - # type: (str) -> HiddenText - return HiddenText(value, redacted='****') - - -def hide_url(url): - # type: (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 - """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]) - ] - - # See https://github.com/pypa/pip/issues/1299 for more discussion - should_show_use_python_msg = ( - modifying_pip and - WINDOWS and - os.path.basename(sys.argv[0]) in pip_names - ) - - if should_show_use_python_msg: - new_command = [ - sys.executable, "-m", "pip" - ] + sys.argv[1:] - raise CommandError( - 'To modify pip, please run the following command:\n{}' - .format(" ".join(new_command)) - ) - - -def is_console_interactive(): - # type: () -> 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] - """Return (hash, length) for path using hashlib.sha256() - """ - - h = hashlib.sha256() - length = 0 - with open(path, 'rb') as f: - for block in read_chunks(f, size=blocksize): - length += len(block) - h.update(block) - return h, length - - -def is_wheel_installed(): - """ - Return whether the wheel package is installed. - """ - try: - import wheel # noqa: F401 - except ImportError: - return False - - return True diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/models.py b/venv/lib/python3.8/site-packages/pip/_internal/utils/models.py deleted file mode 100644 index 29e1441..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/utils/models.py +++ /dev/null @@ -1,42 +0,0 @@ -"""Utilities for defining models -""" -# The following comment should be removed at some point in the future. -# mypy: disallow-untyped-defs=False - -import operator - - -class KeyBasedCompareMixin(object): - """Provides comparison capabilities that is based on a key - """ - - def __init__(self, key, defining_class): - self._compare_key = key - self._defining_class = defining_class - - def __hash__(self): - return hash(self._compare_key) - - def __lt__(self, other): - return self._compare(other, operator.__lt__) - - def __le__(self, other): - return self._compare(other, operator.__le__) - - def __gt__(self, other): - return self._compare(other, operator.__gt__) - - def __ge__(self, other): - return self._compare(other, operator.__ge__) - - def __eq__(self, other): - return self._compare(other, operator.__eq__) - - def __ne__(self, other): - return self._compare(other, operator.__ne__) - - def _compare(self, other, method): - if not isinstance(other, self._defining_class): - return NotImplemented - - return method(self._compare_key, other._compare_key) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/packaging.py b/venv/lib/python3.8/site-packages/pip/_internal/utils/packaging.py deleted file mode 100644 index 68aa86e..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/utils/packaging.py +++ /dev/null @@ -1,94 +0,0 @@ -from __future__ import absolute_import - -import logging -from email.parser import FeedParser - -from pip._vendor import pkg_resources -from pip._vendor.packaging import specifiers, version - -from pip._internal.exceptions import NoneMetadataError -from pip._internal.utils.misc import display_path -from pip._internal.utils.typing import MYPY_CHECK_RUNNING - -if MYPY_CHECK_RUNNING: - from typing import Optional, Tuple - from email.message import Message - from pip._vendor.pkg_resources import Distribution - - -logger = logging.getLogger(__name__) - - -def check_requires_python(requires_python, version_info): - # type: (Optional[str], Tuple[int, ...]) -> bool - """ - Check if the given Python version matches a "Requires-Python" specifier. - - :param version_info: A 3-tuple of ints representing a Python - major-minor-micro version to check (e.g. `sys.version_info[:3]`). - - :return: `True` if the given Python version satisfies the requirement. - Otherwise, return `False`. - - :raises InvalidSpecifier: If `requires_python` has an invalid format. - """ - if requires_python is None: - # The package provides no information - return True - requires_python_specifier = specifiers.SpecifierSet(requires_python) - - python_version = version.parse('.'.join(map(str, 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 = '' - - 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 get_requires_python(dist): - # type: (pkg_resources.Distribution) -> Optional[str] - """ - 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 '' diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/pkg_resources.py b/venv/lib/python3.8/site-packages/pip/_internal/utils/pkg_resources.py deleted file mode 100644 index 0bc129a..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/utils/pkg_resources.py +++ /dev/null @@ -1,44 +0,0 @@ -from pip._vendor.pkg_resources import yield_lines -from pip._vendor.six import ensure_str - -from pip._internal.utils.typing import MYPY_CHECK_RUNNING - -if MYPY_CHECK_RUNNING: - from typing import Dict, Iterable, List - - -class DictMetadata(object): - """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 ensure_str(self._metadata[name]) - except UnicodeDecodeError as e: - # Mirrors handling done in pkg_resources.NullProvider. - e.reason += " in {} file".format(name) - 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/venv/lib/python3.8/site-packages/pip/_internal/utils/setuptools_build.py b/venv/lib/python3.8/site-packages/pip/_internal/utils/setuptools_build.py deleted file mode 100644 index 4147a65..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/utils/setuptools_build.py +++ /dev/null @@ -1,181 +0,0 @@ -import sys - -from pip._internal.utils.typing import MYPY_CHECK_RUNNING - -if MYPY_CHECK_RUNNING: - 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 sys, setuptools, tokenize; sys.argv[0] = {0!r}; __file__={0!r};" - "f=getattr(tokenize, 'open', open)(__file__);" - "code=f.read().replace('\\r\\n', '\\n');" - "f.close();" - "exec(compile(code, __file__, 'exec'))" -) - - -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] - """ - Get setuptools command arguments with shim wrapped setup file invocation. - - :param setup_py_path: The path to setup.py to be wrapped. - :param global_options: Additional global options. - :param no_user_config: If True, disables personal user configuration. - :param unbuffered_output: If True, adds the unbuffered switch to the - argument list. - """ - args = [sys.executable] - if unbuffered_output: - args += ["-u"] - args += ["-c", _SETUPTOOLS_SHIM.format(setup_py_path)] - if global_options: - args += global_options - if no_user_config: - args += ["--no-user-cfg"] - return 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] - # 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 - # virtualenv. - args = make_setuptools_shim_args( - setup_py_path, - global_options=global_options, - unbuffered_output=True - ) - args += ["bdist_wheel", "-d", destination_dir] - args += build_options - return args - - -def make_setuptools_clean_args( - setup_py_path, # type: str - global_options, # type: Sequence[str] -): - # type: (...) -> List[str] - args = make_setuptools_shim_args( - setup_py_path, - global_options=global_options, - unbuffered_output=True - ) - args += ["clean", "--all"] - return 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] - assert not (use_user_site and prefix) - - args = make_setuptools_shim_args( - setup_py_path, - global_options=global_options, - no_user_config=no_user_config, - ) - - args += ["develop", "--no-deps"] - - args += install_options - - if prefix: - args += ["--prefix", prefix] - if home is not None: - args += ["--home", home] - - if use_user_site: - args += ["--user", "--prefix="] - - return 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] - args = make_setuptools_shim_args(setup_py_path) - if no_user_config: - args += ["--no-user-cfg"] - - args += ["egg_info"] - - if egg_info_dir: - 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/venv/lib/python3.8/site-packages/pip/_internal/utils/subprocess.py b/venv/lib/python3.8/site-packages/pip/_internal/utils/subprocess.py deleted file mode 100644 index ea0176d..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/utils/subprocess.py +++ /dev/null @@ -1,278 +0,0 @@ -# The following comment should be removed at some point in the future. -# mypy: strict-optional=False - -from __future__ import absolute_import - -import logging -import os -import subprocess - -from pip._vendor.six.moves import shlex_quote - -from pip._internal.exceptions import InstallationError -from pip._internal.utils.compat import console_to_str, str_to_display -from pip._internal.utils.logging import subprocess_logger -from pip._internal.utils.misc import HiddenText, path_to_display -from pip._internal.utils.typing import MYPY_CHECK_RUNNING -from pip._internal.utils.ui import open_spinner - -if MYPY_CHECK_RUNNING: - from typing import ( - Any, Callable, Iterable, List, Mapping, Optional, Text, Union, - ) - from pip._internal.utils.ui import SpinnerInterface - - CommandArgs = List[Union[str, HiddenText]] - - -LOG_DIVIDER = '----------------------------------------' - - -def make_command(*args): - # type: (Union[str, HiddenText, CommandArgs]) -> CommandArgs - """ - Create a CommandArgs object. - """ - command_args = [] # type: CommandArgs - for arg in args: - # Check for list instead of CommandArgs since CommandArgs is - # only known during type-checking. - if isinstance(arg, list): - command_args.extend(arg) - else: - # Otherwise, arg is str or HiddenText. - command_args.append(arg) - - return command_args - - -def format_command_args(args): - # type: (Union[List[str], CommandArgs]) -> str - """ - Format command arguments for display. - """ - # For HiddenText arguments, display the redacted form by calling str(). - # Also, we don't apply str() to arguments that aren't HiddenText since - # this can trigger a UnicodeDecodeError in Python 2 if the argument - # has type unicode and includes a non-ascii character. (The type - # checker doesn't ensure the annotations are correct in all cases.) - return ' '.join( - shlex_quote(str(arg)) if isinstance(arg, HiddenText) - else shlex_quote(arg) for arg in args - ) - - -def reveal_command_args(args): - # type: (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[Text] - exit_status, # type: int -): - # type: (...) -> Text - """ - 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) - # Convert `command` and `cwd` to text (unicode in Python 2) so we can use - # them as arguments in the unicode format string below. This avoids - # "UnicodeDecodeError: 'ascii' codec can't decode byte ..." in Python 2 - # if either contains a non-ascii character. - command_display = str_to_display(command, desc='command bytes') - cwd_display = path_to_display(cwd) - - # 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. - u'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_display, - cwd_display=cwd_display, - 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] -): - # type: (...) -> Text - """ - Args: - show_stdout: if true, use INFO to log the subprocess's stderr and - stdout streams. Otherwise, use DEBUG. Defaults to False. - extra_ok_returncodes: an iterable of integer return codes that are - acceptable, in addition to 0. Defaults to None, which means []. - unset_environ: an iterable of environment variable names to unset - prior to calling subprocess.Popen(). - log_failed_cmd: if false, failed commands are not logged, only raised. - """ - if extra_ok_returncodes is None: - extra_ok_returncodes = [] - if unset_environ is None: - unset_environ = [] - # Most places in pip use show_stdout=False. What this means is-- - # - # - We connect the child's output (combined stderr and stdout) to a - # single pipe, which we read. - # - We log this output to stderr at DEBUG level as it is received. - # - If DEBUG logging isn't enabled (e.g. if --verbose logging wasn't - # requested), then we show a spinner so the user can still see the - # subprocess is in progress. - # - If the subprocess exits with an error, we log the output to stderr - # at ERROR level if it hasn't already been displayed to the console - # (e.g. if --verbose logging wasn't enabled). This way we don't log - # the output to the console twice. - # - # If show_stdout=True, then the above is still done, but with DEBUG - # replaced by INFO. - if show_stdout: - # Then log the subprocess output at INFO level. - log_subprocess = subprocess_logger.info - used_level = logging.INFO - else: - # Then log the subprocess output using DEBUG. 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 - - # Whether the subprocess will be visible in the console. - showing_subprocess = subprocess_logger.getEffectiveLevel() <= used_level - - # Only use the spinner if we're not showing the subprocess output - # 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: - env.update(extra_environ) - for name in unset_environ: - env.pop(name, None) - try: - proc = subprocess.Popen( - # Convert HiddenText objects to the underlying str. - reveal_command_args(cmd), - stderr=subprocess.STDOUT, stdin=subprocess.PIPE, - stdout=subprocess.PIPE, cwd=cwd, env=env, - ) - proc.stdin.close() - except Exception as exc: - if log_failed_cmd: - subprocess_logger.critical( - "Error %s while executing command %s", exc, command_desc, - ) - raise - all_output = [] - while True: - # The "line" value is a unicode string in Python 2. - line = console_to_str(proc.stdout.readline()) - if not line: - break - line = line.rstrip() - all_output.append(line + '\n') - - # Show the line immediately. - log_subprocess(line) - # Update the spinner. - if use_spinner: - spinner.spin() - try: - proc.wait() - finally: - if proc.stdout: - proc.stdout.close() - proc_had_error = ( - proc.returncode and proc.returncode not in extra_ok_returncodes - ) - if use_spinner: - if proc_had_error: - spinner.finish("error") - else: - 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, - ) - subprocess_logger.error(msg) - exc_msg = ( - 'Command errored out with exit status {}: {} ' - 'Check the logs for full command output.' - ).format(proc.returncode, command_desc) - raise InstallationError(exc_msg) - elif on_returncode == 'warn': - subprocess_logger.warning( - 'Command "%s" had error code %s in %s', - command_desc, proc.returncode, cwd, - ) - elif on_returncode == 'ignore': - pass - else: - raise ValueError('Invalid value: on_returncode=%s' % - repr(on_returncode)) - return ''.join(all_output) - - -def runner_with_spinner_message(message): - # type: (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. - """ - - def runner( - cmd, # type: List[str] - cwd=None, # type: Optional[str] - extra_environ=None # type: Optional[Mapping[str, Any]] - ): - # type: (...) -> None - with open_spinner(message) as spinner: - call_subprocess( - cmd, - cwd=cwd, - extra_environ=extra_environ, - spinner=spinner, - ) - - return runner diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/temp_dir.py b/venv/lib/python3.8/site-packages/pip/_internal/utils/temp_dir.py deleted file mode 100644 index 65e41bc..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/utils/temp_dir.py +++ /dev/null @@ -1,250 +0,0 @@ -from __future__ import absolute_import - -import errno -import itertools -import logging -import os.path -import tempfile -from contextlib import contextmanager - -from pip._vendor.contextlib2 import ExitStack - -from pip._internal.utils.misc import rmtree -from pip._internal.utils.typing import MYPY_CHECK_RUNNING - -if MYPY_CHECK_RUNNING: - from typing import Any, Dict, Iterator, Optional, TypeVar - - _T = TypeVar('_T', bound='TempDirectory') - - -logger = logging.getLogger(__name__) - - -_tempdir_manager = None # type: Optional[ExitStack] - - -@contextmanager -def global_tempdir_manager(): - # type: () -> Iterator[None] - global _tempdir_manager - with ExitStack() as stack: - old_tempdir_manager, _tempdir_manager = _tempdir_manager, stack - try: - yield - finally: - _tempdir_manager = old_tempdir_manager - - -class TempDirectoryTypeRegistry(object): - """Manages temp directory behavior - """ - - def __init__(self): - # type: () -> None - self._should_delete = {} # type: Dict[str, bool] - - def set_delete(self, kind, value): - # type: (str, 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 - """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] - - -@contextmanager -def tempdir_registry(): - # type: () -> Iterator[TempDirectoryTypeRegistry] - """Provides a scoped global tempdir registry that can be used to dictate - whether directories should be deleted. - """ - global _tempdir_registry - old_tempdir_registry = _tempdir_registry - _tempdir_registry = TempDirectoryTypeRegistry() - try: - yield _tempdir_registry - finally: - _tempdir_registry = old_tempdir_registry - - -class TempDirectory(object): - """Helper class that owns and cleans up a temporary directory. - - This class can be used as a context manager or as an OO representation of a - temporary directory. - - Attributes: - path - Location to the created temporary directory - delete - Whether the directory should be deleted when exiting - (when used as a contextmanager) - - Methods: - cleanup() - Deletes the temporary directory - - When used as a context manager, if the delete attribute is True, on - exiting the context the temporary directory is deleted. - """ - - def __init__( - self, - path=None, # type: Optional[str] - delete=None, # type: Optional[bool] - kind="temp", # type: str - globally_managed=False, # type: bool - ): - super(TempDirectory, self).__init__() - - # If we were given an explicit directory, resolve delete option now. - # Otherwise we wait until cleanup and see what tempdir_registry says. - if path is not None and delete is None: - delete = False - - if path is None: - path = self._create(kind) - - self._path = path - self._deleted = False - self.delete = delete - self.kind = kind - - if globally_managed: - assert _tempdir_manager is not None - _tempdir_manager.enter_context(self) - - @property - def path(self): - # type: () -> str - assert not self._deleted, ( - "Attempted to access deleted path: {}".format(self._path) - ) - return self._path - - def __repr__(self): - # type: () -> str - return "<{} {!r}>".format(self.__class__.__name__, self.path) - - def __enter__(self): - # type: (_T) -> _T - return self - - def __exit__(self, exc, value, tb): - # type: (Any, Any, Any) -> None - if self.delete is not None: - delete = self.delete - elif _tempdir_registry: - delete = _tempdir_registry.get_delete(self.kind) - else: - delete = True - - if delete: - self.cleanup() - - def _create(self, kind): - # type: (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 - # scripts, so we canonicalize the path by traversing potential - # symlinks here. - path = os.path.realpath( - tempfile.mkdtemp(prefix="pip-{}-".format(kind)) - ) - logger.debug("Created temporary directory: {}".format(path)) - return path - - def cleanup(self): - # type: () -> None - """Remove the temporary directory created and reset state - """ - self._deleted = True - if os.path.exists(self._path): - rmtree(self._path) - - -class AdjacentTempDirectory(TempDirectory): - """Helper class that creates a temporary directory adjacent to a real one. - - Attributes: - original - The original directory to create a temp directory for. - path - After calling create() or entering, contains the full - path to the temporary directory. - delete - Whether the directory should be deleted when exiting - (when used as a contextmanager) - - """ - # The characters that may be used to name the temp directory - # We always prepend a ~ and then rotate through these until - # a usable name is found. - # pkg_resources raises a different error for .dist-info folder - # with leading '-' and invalid metadata - LEADING_CHARS = "-~.=%0123456789" - - def __init__(self, original, delete=None): - # type: (str, Optional[bool]) -> None - self.original = original.rstrip('/\\') - super(AdjacentTempDirectory, self).__init__(delete=delete) - - @classmethod - def _generate_names(cls, name): - # type: (str) -> Iterator[str] - """Generates a series of temporary names. - - The algorithm replaces the leading characters in the name - with ones that are valid filesystem characters, but are not - valid package names (for both Python and pip definitions of - package). - """ - for i in range(1, len(name)): - for candidate in itertools.combinations_with_replacement( - cls.LEADING_CHARS, i - 1): - new_name = '~' + ''.join(candidate) + name[i:] - if new_name != name: - yield new_name - - # If we make it this far, we will have to make a longer name - for i in range(len(cls.LEADING_CHARS)): - for candidate in itertools.combinations_with_replacement( - cls.LEADING_CHARS, i): - new_name = '~' + ''.join(candidate) + name - if new_name != name: - yield new_name - - def _create(self, kind): - # type: (str) -> str - root, name = os.path.split(self.original) - for candidate in self._generate_names(name): - path = os.path.join(root, candidate) - try: - os.mkdir(path) - except OSError as ex: - # Continue if the name exists already - if ex.errno != errno.EEXIST: - raise - else: - path = os.path.realpath(path) - break - else: - # Final fallback on the default behavior. - path = os.path.realpath( - tempfile.mkdtemp(prefix="pip-{}-".format(kind)) - ) - - logger.debug("Created temporary directory: {}".format(path)) - return path diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/typing.py b/venv/lib/python3.8/site-packages/pip/_internal/utils/typing.py deleted file mode 100644 index 8505a29..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/utils/typing.py +++ /dev/null @@ -1,38 +0,0 @@ -"""For neatly implementing static typing in pip. - -`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 pip, all static-typing related imports should be guarded as follows: - - from pip._internal.utils.typing import MYPY_CHECK_RUNNING - - if MYPY_CHECK_RUNNING: - from typing import ... - -Ref: https://github.com/python/mypy/issues/3216 -""" - -MYPY_CHECK_RUNNING = False - - -if MYPY_CHECK_RUNNING: - from typing import cast -else: - # typing's cast() is needed at runtime, but we don't want to import typing. - # Thus, we use a dummy no-op version, which we tell mypy to ignore. - def cast(type_, value): # type: ignore - return value diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/ui.py b/venv/lib/python3.8/site-packages/pip/_internal/utils/ui.py deleted file mode 100644 index 87782aa..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/utils/ui.py +++ /dev/null @@ -1,428 +0,0 @@ -# The following comment should be removed at some point in the future. -# mypy: strict-optional=False -# mypy: disallow-untyped-defs=False - -from __future__ import absolute_import, division - -import contextlib -import itertools -import logging -import sys -import time -from signal import SIGINT, default_int_handler, signal - -from pip._vendor import six -from pip._vendor.progress import HIDE_CURSOR, SHOW_CURSOR -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 -from pip._internal.utils.typing import MYPY_CHECK_RUNNING - -if MYPY_CHECK_RUNNING: - from typing import Any, Iterator, IO - -try: - from pip._vendor import colorama -# Lots of different errors can come from this, including SystemError and -# ImportError. -except Exception: - colorama = None - -logger = logging.getLogger(__name__) - - -def _select_progress_class(preferred, fallback): - 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", six.text_type()), - getattr(preferred, "fill", six.text_type()), - ] - 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: - six.text_type().join(characters).encode(encoding) - except UnicodeEncodeError: - return fallback - else: - return preferred - - -_BaseBar = _select_progress_class(IncrementalBar, Bar) # type: Any - - -class InterruptibleMixin(object): - """ - 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): - """ - Save the original SIGINT handler for later. - """ - super(InterruptibleMixin, self).__init__(*args, **kwargs) - - 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): - """ - Restore the original SIGINT handler after finishing. - - This should happen regardless of whether the progress display finishes - normally, or gets interrupted. - """ - super(InterruptibleMixin, self).finish() - signal(SIGINT, self.original_handler) - - def handle_sigint(self, signum, frame): - """ - 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): - pass - - -class BlueEmojiBar(IncrementalBar): - - suffix = "%(percent)d%%" - bar_prefix = " " - bar_suffix = " " - phases = (u"\U0001F539", u"\U0001F537", u"\U0001F535") # type: Any - - -class DownloadProgressMixin(object): - - def __init__(self, *args, **kwargs): - super(DownloadProgressMixin, self).__init__(*args, **kwargs) - self.message = (" " * (get_indentation() + 2)) + self.message - - @property - def downloaded(self): - return format_size(self.index) - - @property - def download_speed(self): - # Avoid zero division errors... - if self.avg == 0.0: - return "..." - return format_size(1 / self.avg) + "/s" - - @property - def pretty_eta(self): - if self.eta: - return "eta %s" % self.eta_td - return "" - - def iter(self, it): - for x in it: - yield x - self.next(len(x)) - self.finish() - - -class WindowsMixin(object): - - def __init__(self, *args, **kwargs): - # 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: - self.hide_cursor = False - - super(WindowsMixin, self).__init__(*args, **kwargs) - - # 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) - # 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" - -# NOTE: The "type: ignore" comments on the following classes are there to -# work around https://github.com/python/typing/issues/241 - - -class DefaultDownloadProgressBar(BaseDownloadProgressBar, - _BaseBar): - pass - - -class DownloadSilentBar(BaseDownloadProgressBar, SilentBar): # type: ignore - pass - - -class DownloadBar(BaseDownloadProgressBar, # type: ignore - Bar): - pass - - -class DownloadFillingCirclesBar(BaseDownloadProgressBar, # type: ignore - FillingCirclesBar): - pass - - -class DownloadBlueEmojiProgressBar(BaseDownloadProgressBar, # type: ignore - BlueEmojiBar): - pass - - -class DownloadProgressSpinner(WindowsMixin, InterruptibleMixin, - DownloadProgressMixin, Spinner): - - file = sys.stdout - suffix = "%(downloaded)s %(download_speed)s" - - def next_phase(self): - if not hasattr(self, "_phaser"): - self._phaser = itertools.cycle(self.phases) - return next(self._phaser) - - def update(self): - message = self.message % self - phase = self.next_phase() - suffix = self.suffix % self - line = ''.join([ - message, - " " if message else "", - phase, - " " if suffix else "", - suffix, - ]) - - self.writeln(line) - - -BAR_TYPES = { - "off": (DownloadSilentBar, DownloadSilentBar), - "on": (DefaultDownloadProgressBar, DownloadProgressSpinner), - "ascii": (DownloadBar, DownloadProgressSpinner), - "pretty": (DownloadFillingCirclesBar, DownloadProgressSpinner), - "emoji": (DownloadBlueEmojiProgressBar, DownloadProgressSpinner) -} - - -def DownloadProgressProvider(progress_bar, max=None): - if max is None or max == 0: - return BAR_TYPES[progress_bar][1]().iter - else: - return BAR_TYPES[progress_bar][0](max=max).iter - - -################################################################ -# Generic "something is happening" spinners -# -# We don't even try using progress.spinner.Spinner here because it's actually -# simpler to reimplement from scratch than to coerce their code into doing -# what we need. -################################################################ - -@contextlib.contextmanager -def hidden_cursor(file): - # type: (IO[Any]) -> Iterator[None] - # The Windows terminal does not support the hide/show cursor ANSI codes, - # even via colorama. So don't even try. - if WINDOWS: - yield - # We don't want to clutter the output with control characters if we're - # writing to a file, or if the user is running with --quiet. - # See https://github.com/pypa/pip/issues/3418 - elif not file.isatty() or logger.getEffectiveLevel() > logging.INFO: - yield - else: - file.write(HIDE_CURSOR) - try: - yield - finally: - file.write(SHOW_CURSOR) - - -class RateLimiter(object): - def __init__(self, min_update_interval_seconds): - # type: (float) -> None - self._min_update_interval_seconds = min_update_interval_seconds - self._last_update = 0 # type: float - - def ready(self): - # type: () -> bool - now = time.time() - delta = now - self._last_update - return delta >= self._min_update_interval_seconds - - def reset(self): - # type: () -> None - self._last_update = time.time() - - -class SpinnerInterface(object): - def spin(self): - # type: () -> None - raise NotImplementedError() - - def finish(self, final_status): - # type: (str) -> None - raise NotImplementedError() - - -class InteractiveSpinner(SpinnerInterface): - def __init__(self, message, file=None, spin_chars="-\\|/", - # Empirically, 8 updates/second looks nice - min_update_interval_seconds=0.125): - self._message = message - if file is None: - file = sys.stdout - self._file = file - self._rate_limiter = RateLimiter(min_update_interval_seconds) - self._finished = False - - self._spin_cycle = itertools.cycle(spin_chars) - - self._file.write(" " * get_indentation() + self._message + " ... ") - self._width = 0 - - def _write(self, status): - 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 - backup = "\b" * self._width - self._file.write(backup + " " * self._width + backup) - # Now we have a blank slate to add our status - self._file.write(status) - self._width = len(status) - self._file.flush() - self._rate_limiter.reset() - - def spin(self): - # type: () -> 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 - if self._finished: - return - self._write(final_status) - self._file.write("\n") - self._file.flush() - self._finished = True - - -# Used for dumb terminals, non-interactive installs (no tty), etc. -# We still print updates occasionally (once every 60 seconds by default) to -# 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 - self._message = message - self._finished = False - self._rate_limiter = RateLimiter(min_update_interval_seconds) - self._update("started") - - def _update(self, status): - assert not self._finished - self._rate_limiter.reset() - logger.info("%s: %s", self._message, status) - - def spin(self): - # type: () -> None - if self._finished: - return - if not self._rate_limiter.ready(): - return - self._update("still running...") - - def finish(self, final_status): - # type: (str) -> None - if self._finished: - return - self._update("finished with status '%s'" % (final_status,)) - self._finished = True - - -@contextlib.contextmanager -def open_spinner(message): - # type: (str) -> Iterator[SpinnerInterface] - # 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 - else: - spinner = NonInteractiveSpinner(message) - try: - with hidden_cursor(sys.stdout): - yield spinner - except KeyboardInterrupt: - spinner.finish("canceled") - raise - except Exception: - spinner.finish("error") - raise - else: - spinner.finish("done") diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/unpacking.py b/venv/lib/python3.8/site-packages/pip/_internal/utils/unpacking.py deleted file mode 100644 index 7252dc2..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/utils/unpacking.py +++ /dev/null @@ -1,272 +0,0 @@ -"""Utilities related archives. -""" - -# The following comment should be removed at some point in the future. -# mypy: strict-optional=False -# mypy: disallow-untyped-defs=False - -from __future__ import absolute_import - -import logging -import os -import shutil -import stat -import tarfile -import zipfile - -from pip._internal.exceptions import InstallationError -from pip._internal.utils.filetypes import ( - BZ2_EXTENSIONS, - TAR_EXTENSIONS, - XZ_EXTENSIONS, - ZIP_EXTENSIONS, -) -from pip._internal.utils.misc import ensure_dir -from pip._internal.utils.typing import MYPY_CHECK_RUNNING - -if MYPY_CHECK_RUNNING: - from typing import Iterable, List, Optional, Text, Union - - -logger = logging.getLogger(__name__) - - -SUPPORTED_EXTENSIONS = ZIP_EXTENSIONS + TAR_EXTENSIONS - -try: - import bz2 # noqa - SUPPORTED_EXTENSIONS += BZ2_EXTENSIONS -except ImportError: - logger.debug('bz2 module is not available') - -try: - # Only for Python 3.3+ - import lzma # noqa - SUPPORTED_EXTENSIONS += XZ_EXTENSIONS -except ImportError: - logger.debug('lzma module is not available') - - -def current_umask(): - """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: (Union[str, Text]) -> List[Union[str, Text]] - path = path.lstrip('/').lstrip('\\') - if ( - '/' in path and ( - ('\\' in path and path.find('/') < path.find('\\')) or - '\\' not in path - ) - ): - return path.split('/', 1) - elif '\\' in path: - return path.split('\\', 1) - else: - return [path, ''] - - -def has_leading_dir(paths): - # type: (Iterable[Union[str, Text]]) -> 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 - for path in paths: - prefix, rest = split_leading_dir(path) - if not prefix: - return False - elif common_prefix is None: - common_prefix = prefix - elif prefix != common_prefix: - return False - return True - - -def is_within_directory(directory, target): - # type: ((Union[str, Text]), (Union[str, Text])) -> bool - """ - Return true if the absolute path of target is within the directory - """ - abs_directory = os.path.abspath(directory) - abs_target = os.path.abspath(target) - - prefix = os.path.commonprefix([abs_directory, abs_target]) - return prefix == abs_directory - - -def unzip_file(filename, location, flatten=True): - # type: (str, str, bool) -> 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 - not preserved), except that regular file members with any execute - permissions (user, group, or world) have "chmod +x" applied after being - written. Note that for windows, any execute changes using os.chmod are - no-ops per the python docs. - """ - ensure_dir(location) - zipfp = open(filename, 'rb') - try: - zip = zipfile.ZipFile(zipfp, allowZip64=True) - leading = has_leading_dir(zip.namelist()) and flatten - for info in zip.infolist(): - name = info.filename - fn = name - if leading: - fn = split_leading_dir(name)[1] - fn = os.path.join(location, fn) - dir = os.path.dirname(fn) - if not is_within_directory(location, fn): - message = ( - 'The zip file ({}) has a file ({}) trying to install ' - 'outside target directory ({})' - ) - raise InstallationError(message.format(filename, fn, location)) - if fn.endswith('/') or fn.endswith('\\'): - # A directory - ensure_dir(fn) - else: - ensure_dir(dir) - # Don't use read() to avoid allocating an arbitrarily large - # chunk of memory for the file's content - fp = zip.open(name) - try: - with open(fn, 'wb') as destfp: - shutil.copyfileobj(fp, destfp) - finally: - fp.close() - mode = info.external_attr >> 16 - # if mode and regular file and any execute permissions for - # user/group/world? - if mode and stat.S_ISREG(mode) and mode & 0o111: - # make dest file have execute for user/group/world - # (chmod +x) no-op on windows per python docs - os.chmod(fn, (0o777 - current_umask() | 0o111)) - finally: - zipfp.close() - - -def untar_file(filename, location): - # type: (str, 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 - are not preserved), except that regular file members with any execute - permissions (user, group, or world) have "chmod +x" applied after being - written. Note that for windows, any execute changes using os.chmod are - no-ops per the python docs. - """ - ensure_dir(location) - if filename.lower().endswith('.gz') or filename.lower().endswith('.tgz'): - mode = 'r:gz' - elif filename.lower().endswith(BZ2_EXTENSIONS): - mode = 'r:bz2' - elif filename.lower().endswith(XZ_EXTENSIONS): - mode = 'r:xz' - elif filename.lower().endswith('.tar'): - mode = 'r' - else: - logger.warning( - 'Cannot determine compression type for file %s', filename, - ) - mode = 'r:*' - tar = tarfile.open(filename, mode) - try: - leading = has_leading_dir([ - member.name for member in tar.getmembers() - ]) - for member in tar.getmembers(): - fn = member.name - if leading: - # https://github.com/python/mypy/issues/1174 - fn = split_leading_dir(fn)[1] # type: ignore - path = os.path.join(location, fn) - if not is_within_directory(location, path): - message = ( - 'The tar file ({}) has a file ({}) trying to install ' - 'outside target directory ({})' - ) - raise InstallationError( - message.format(filename, path, location) - ) - if member.isdir(): - ensure_dir(path) - elif member.issym(): - try: - # https://github.com/python/typeshed/issues/2673 - tar._extract_member(member, path) # type: ignore - except Exception as exc: - # Some corrupt tar files seem to produce this - # (specifically bad symlinks) - logger.warning( - 'In the tar file %s the member %s is invalid: %s', - filename, member.name, exc, - ) - continue - else: - try: - fp = tar.extractfile(member) - except (KeyError, AttributeError) as exc: - # Some corrupt tar files seem to produce this - # (specifically bad symlinks) - logger.warning( - 'In the tar file %s the member %s is invalid: %s', - filename, member.name, exc, - ) - continue - ensure_dir(os.path.dirname(path)) - with open(path, 'wb') as destfp: - shutil.copyfileobj(fp, destfp) - fp.close() - # Update the timestamp (useful for cython compiled files) - # https://github.com/python/typeshed/issues/2673 - tar.utime(member, path) # type: ignore - # member have any execute permissions for user/group/world? - if member.mode & 0o111: - # make dest file have execute for user/group/world - # no-op on windows per python docs - os.chmod(path, (0o777 - current_umask() | 0o111)) - finally: - tar.close() - - -def unpack_file( - filename, # type: str - location, # type: str - content_type=None, # type: Optional[str] -): - # type: (...) -> None - filename = os.path.realpath(filename) - if ( - content_type == 'application/zip' or - filename.lower().endswith(ZIP_EXTENSIONS) or - zipfile.is_zipfile(filename) - ): - unzip_file( - filename, - location, - flatten=not filename.endswith('.whl') - ) - elif ( - content_type == 'application/x-gzip' or - tarfile.is_tarfile(filename) or - filename.lower().endswith( - TAR_EXTENSIONS + BZ2_EXTENSIONS + XZ_EXTENSIONS - ) - ): - untar_file(filename, location) - else: - # FIXME: handle? - # FIXME: magic signatures? - logger.critical( - 'Cannot unpack file %s (downloaded from %s, content-type: %s); ' - 'cannot detect archive format', - filename, location, content_type, - ) - raise InstallationError( - 'Cannot determine archive format of {}'.format(location) - ) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/urls.py b/venv/lib/python3.8/site-packages/pip/_internal/utils/urls.py deleted file mode 100644 index 9ad40fe..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/utils/urls.py +++ /dev/null @@ -1,54 +0,0 @@ -import os -import sys - -from pip._vendor.six.moves.urllib import parse as urllib_parse -from pip._vendor.six.moves.urllib import request as urllib_request - -from pip._internal.utils.typing import MYPY_CHECK_RUNNING - -if MYPY_CHECK_RUNNING: - from typing import Optional, Text, Union - - -def get_url_scheme(url): - # type: (Union[str, Text]) -> Optional[Text] - if ':' not in url: - return None - return url.split(':', 1)[0].lower() - - -def path_to_url(path): - # type: (Union[str, Text]) -> str - """ - Convert a path to a file: URL. The path will be made absolute and have - quoted path parts. - """ - path = os.path.normpath(os.path.abspath(path)) - url = urllib_parse.urljoin('file:', urllib_request.pathname2url(path)) - return url - - -def url_to_path(url): - # type: (str) -> str - """ - Convert a file: URL to a path. - """ - assert url.startswith('file:'), ( - "You can only turn file: urls into filenames (not %r)" % url) - - _, netloc, path, _, _ = urllib_parse.urlsplit(url) - - if not netloc or netloc == 'localhost': - # According to RFC 8089, same as empty authority. - netloc = '' - elif sys.platform == 'win32': - # If we have a UNC path, prepend UNC share notation. - netloc = '\\\\' + netloc - else: - raise ValueError( - 'non-local file URIs are not supported on this platform: %r' - % url - ) - - path = urllib_request.url2pathname(netloc + path) - return path diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/virtualenv.py b/venv/lib/python3.8/site-packages/pip/_internal/utils/virtualenv.py deleted file mode 100644 index d81e6ac..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/utils/virtualenv.py +++ /dev/null @@ -1,115 +0,0 @@ -from __future__ import absolute_import - -import logging -import os -import re -import site -import sys - -from pip._internal.utils.typing import MYPY_CHECK_RUNNING - -if MYPY_CHECK_RUNNING: - from typing import List, Optional - -logger = logging.getLogger(__name__) -_INCLUDE_SYSTEM_SITE_PACKAGES_REGEX = re.compile( - r"include-system-site-packages\s*=\s*(?Ptrue|false)" -) - - -def _running_under_venv(): - # type: () -> bool - """Checks if sys.base_prefix and sys.prefix match. - - This handles PEP 405 compliant virtual environments. - """ - return sys.prefix != getattr(sys, "base_prefix", sys.prefix) - - -def _running_under_regular_virtualenv(): - # type: () -> bool - """Checks if sys.real_prefix is set. - - This handles virtual environments created with pypa's virtualenv. - """ - # pypa/virtualenv case - 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 _get_pyvenv_cfg_lines(): - # type: () -> 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. - """ - pyvenv_cfg_file = os.path.join(sys.prefix, 'pyvenv.cfg') - try: - with open(pyvenv_cfg_file) as f: - return f.read().splitlines() # avoids trailing newlines - except IOError: - return None - - -def _no_global_under_venv(): - # type: () -> bool - """Check `{sys.prefix}/pyvenv.cfg` for system site-packages inclusion - - PEP 405 specifies that when system site-packages are not supposed to be - visible from a virtual environment, `pyvenv.cfg` must contain the following - line: - - include-system-site-packages = false - - Additionally, log a warning if accessing the file fails. - """ - cfg_lines = _get_pyvenv_cfg_lines() - if cfg_lines is None: - # We're not in a "sane" venv, so assume there is no system - # site-packages access (since that's PEP 405's default state). - logger.warning( - "Could not access 'pyvenv.cfg' despite a virtual environment " - "being active. Assuming global site-packages is not accessible " - "in this environment." - ) - return True - - for line in cfg_lines: - match = _INCLUDE_SYSTEM_SITE_PACKAGES_REGEX.match(line) - if match is not None and match.group('value') == 'false': - return True - return False - - -def _no_global_under_regular_virtualenv(): - # type: () -> bool - """Check if "no-global-site-packages.txt" exists beside site.py - - This mirrors logic in pypa/virtualenv for determining whether system - site-packages are visible in the virtual environment. - """ - site_mod_dir = os.path.dirname(os.path.abspath(site.__file__)) - no_global_site_packages_file = os.path.join( - site_mod_dir, 'no-global-site-packages.txt', - ) - return os.path.exists(no_global_site_packages_file) - - -def virtualenv_no_global(): - # type: () -> bool - """Returns a boolean, whether running in venv with no system site-packages. - """ - - if _running_under_regular_virtualenv(): - return _no_global_under_regular_virtualenv() - - if _running_under_venv(): - return _no_global_under_venv() - - return False diff --git a/venv/lib/python3.8/site-packages/pip/_internal/utils/wheel.py b/venv/lib/python3.8/site-packages/pip/_internal/utils/wheel.py deleted file mode 100644 index 837e0af..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/utils/wheel.py +++ /dev/null @@ -1,225 +0,0 @@ -"""Support functions for working with wheel files. -""" - -from __future__ import absolute_import - -import logging -from email.parser import Parser -from zipfile import ZipFile - -from pip._vendor.packaging.utils import canonicalize_name -from pip._vendor.pkg_resources import DistInfoDistribution -from pip._vendor.six import PY2, ensure_str - -from pip._internal.exceptions import UnsupportedWheel -from pip._internal.utils.pkg_resources import DictMetadata -from pip._internal.utils.typing import MYPY_CHECK_RUNNING - -if MYPY_CHECK_RUNNING: - from email.message import Message - from typing import Dict, Tuple - - from pip._vendor.pkg_resources import Distribution - -if PY2: - from zipfile import BadZipfile as BadZipFile -else: - from zipfile import BadZipFile - - -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(WheelMetadata, self).__init__(metadata) - self._wheel_name = wheel_name - - def get_metadata(self, name): - # type: (str) -> str - try: - return super(WheelMetadata, self).get_metadata(name) - except UnicodeDecodeError as e: - # Augment the default error with the origin of the file. - raise UnsupportedWheel( - "Error decoding metadata for {}: {}".format( - 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("{}/".format(info_dir)) - ] - - metadata_text = {} # type: Dict[str, bytes] - for path in metadata_files: - # If a flag is set, namelist entries may be unicode in Python 2. - # We coerce them to native str type to match the types used in the rest - # of the code. This cannot fail because unicode can always be encoded - # with UTF-8. - full_path = ensure_str(path) - _, metadata_name = full_path.split("/", 1) - - try: - metadata_text[metadata_name] = read_wheel_metadata_file( - wheel_zip, full_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] - """Extract information from the provided wheel, ensuring it meets basic - standards. - - Returns the name of the .dist-info directory and the parsed WHEEL metadata. - """ - try: - info_dir = wheel_dist_info_dir(wheel_zip, name) - metadata = wheel_metadata(wheel_zip, info_dir) - version = wheel_version(metadata) - except UnsupportedWheel as e: - raise UnsupportedWheel( - "{} has an invalid wheel, {}".format(name, str(e)) - ) - - check_compatibility(version, name) - - return info_dir, metadata - - -def wheel_dist_info_dir(source, name): - # type: (ZipFile, str) -> str - """Returns the name of the contained .dist-info directory. - - Raises AssertionError or UnsupportedWheel if not found, >1 found, or - it doesn't match the provided name. - """ - # Zip file path separators must be / - subdirs = list(set(p.split("/")[0] for p in source.namelist())) - - info_dirs = [s for s in subdirs if s.endswith('.dist-info')] - - if not info_dirs: - raise UnsupportedWheel(".dist-info directory not found") - - if len(info_dirs) > 1: - raise UnsupportedWheel( - "multiple .dist-info directories found: {}".format( - ", ".join(info_dirs) - ) - ) - - info_dir = info_dirs[0] - - info_dir_name = canonicalize_name(info_dir) - canonical_name = canonicalize_name(name) - if not info_dir_name.startswith(canonical_name): - raise UnsupportedWheel( - ".dist-info directory {!r} does not start with {!r}".format( - info_dir, canonical_name - ) - ) - - # Zip file paths can be unicode or str depending on the zip entry flags, - # so normalize it. - return ensure_str(info_dir) - - -def read_wheel_metadata_file(source, path): - # type: (ZipFile, str) -> bytes - try: - return source.read(path) - # BadZipFile for general corruption, KeyError for missing entry, - # and RuntimeError for password-protected files - except (BadZipFile, KeyError, RuntimeError) as e: - raise UnsupportedWheel( - "could not read {!r} file: {!r}".format(path, e) - ) - - -def wheel_metadata(source, dist_info_dir): - # type: (ZipFile, str) -> Message - """Return the WHEEL metadata of an extracted wheel, if possible. - Otherwise, raise UnsupportedWheel. - """ - path = "{}/WHEEL".format(dist_info_dir) - # Zip file path separators must be / - wheel_contents = read_wheel_metadata_file(source, path) - - try: - wheel_text = ensure_str(wheel_contents) - except UnicodeDecodeError as e: - raise UnsupportedWheel("error decoding {!r}: {!r}".format(path, e)) - - # FeedParser (used by Parser) does not raise any exceptions. The returned - # message may have .defects populated, but for backwards-compatibility we - # currently ignore them. - return Parser().parsestr(wheel_text) - - -def wheel_version(wheel_data): - # type: (Message) -> Tuple[int, ...] - """Given WHEEL metadata, return the parsed Wheel-Version. - Otherwise, raise UnsupportedWheel. - """ - version_text = wheel_data["Wheel-Version"] - if version_text is None: - raise UnsupportedWheel("WHEEL is missing Wheel-Version") - - version = version_text.strip() - - try: - return tuple(map(int, version.split('.'))) - except ValueError: - raise UnsupportedWheel("invalid Wheel-Version: {!r}".format(version)) - - -def check_compatibility(version, name): - # type: (Tuple[int, ...], 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 - ahead of what it's compatible with (e.g 2.0 > 1.1); and warn when - installing a version only minor version ahead (e.g 1.2 > 1.1). - - version: a 2-tuple representing a Wheel-Version (Major, Minor) - name: name of wheel or package to raise exception about - - :raises UnsupportedWheel: when an incompatible Wheel-Version is given - """ - if version[0] > VERSION_COMPATIBLE[0]: - raise UnsupportedWheel( - "%s's Wheel-Version (%s) is not compatible with this version " - "of pip" % (name, '.'.join(map(str, version))) - ) - elif version > VERSION_COMPATIBLE: - logger.warning( - 'Installing from a newer Wheel-Version (%s)', - '.'.join(map(str, version)), - ) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/vcs/__init__.py b/venv/lib/python3.8/site-packages/pip/_internal/vcs/__init__.py deleted file mode 100644 index 2a4eb13..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/vcs/__init__.py +++ /dev/null @@ -1,15 +0,0 @@ -# Expose a limited set of classes and functions so callers outside of -# the vcs package don't need to import deeper than `pip._internal.vcs`. -# (The test directory and imports protected by MYPY_CHECK_RUNNING may -# still need to import from a vcs sub-package.) -# Import all vcs modules to register each VCS in the VcsSupport object. -import pip._internal.vcs.bazaar -import pip._internal.vcs.git -import pip._internal.vcs.mercurial -import pip._internal.vcs.subversion # noqa: F401 -from pip._internal.vcs.versioncontrol import ( # noqa: F401 - RemoteNotFoundError, - is_url, - make_vcs_requirement_url, - vcs, -) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/vcs/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/vcs/__pycache__/__init__.cpython-38.pyc deleted file mode 100644 index ee80bcaedc7b46fb9fd4f630d41e657a49e464cc..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 448 zcmZXQy-ve06os9pP1A}_2&obbEDRl*EC?8?iUr0FAeJnan^?uFf6^PfRe2*`$!jNG zfr;xD^^3kri&PDYL4>bf$t3>54rDRu`tujAjO7bspN-Si6MzAqh=w|leyrG<({0&M z;2S4^E3WO4#28M7eq4(>qe5E_n#l~qY{@uUwoC^{p6#&pC(^E+}yms`7vhaXjh`kWF&JO*8Yo-Dk}$f%Yl|kZ zMBDCMm_05Y^i>t&tKc*_P=}AqLvG z`LJ6vff@~klnXf1L`jkjGMyx*wj*?^wKPo_IM24=C2$+LOk5#sC*T{N@s-H8ji1UL zWx~gM^nT7vJxO|bs#KCZcfP;1p^M?hFdMFo2E(-XSn##Iz7Y9ZHrjde!T!5@w6=lI zY9Zk$8*rSBEvwS?;l8|x@BI`_h3Fi%*-Dj2u$a(gZeUu`agIA)oqqNQOg*yA>>(S~(Cqi` zfY8n(b_5$8Gr6L@2|I+PCeD#RagW*8?ty#YO`J!84k0J(IPs2Z$IhY8UGDwE1)hCK z9*iG0I@9N)rv&7V?u$+(Pe+PjsWM&4{Z3jfz+xR;S{^Qx&IT!gu#=ZPOPriVhNRQ( zK_7FfU+yJJ^KyhR5gE5s#;+oSc$z7#WPr<(@CgCJFL5sgRzI3-QdXKZgP6s;a zTvyi>Y4y62OE~^}ckKzl)4)Zianyu)xw9jr@iW9TNy1rWNOB_CMb`~0ZTMsr`3_C5 zp{vv}J0r3wx=lVdbxJ!mFE{6Is58)lbo8 z5SrPqI`)iQ5E53nAPN0VxacU)CHaedA6?fwukygE z{Jfm+(gunIRo4M!!qJeYT6_*#SR`7;O550*r%WmwO+tURWM#TjWy)rBt@>eZ_zzKvoX=}FR})U*!Yc8F>QwG*_X~-mQa0S z9*qIH4QD%KA~K10;7(jJ)gPU29w4N7M=rqUaUbJ5FrIhhO?)Wf1}L8>9$a=T=mG+r z{F?^&4w>sPL~jP;PJ&nTlN(R2a58wfDSw4;-+S)LpW!V(K-YE0D?I`#fwbK2RJr$N zXFQLLg)Db6@q$tVaxx(iS{&w?&a;6~NPt>qLwSql13Pb4l1wEOvnbHb!mFfo0t^%U zy!AeBqQmUhO$! z339m;OI*X?|5<|jmq};ArU?*k2jxBadvL#aiD!o7+n4}kUR@{xXGV40`CBxrTU3jW zu}wA6Ij+xq7|eYcdgJ9YvR9mEQX@%DHn0#U^l%3G-0@qt^SyLmb>Ow5LfEvmTUC>) z!^^?Xb*D%Xh3;9IX5tdyj6X;VabDCVn2xGflrb4k#FJ5)OE6b4$QxgtiupsX?h4gE zbR_DZMv@dIALT?hlY~yGR^%pqxyCb8D}^w1vbo)4Y6^Z>2xW^F(*#a+)+>bWmt0ar zv#Cw~hA0Y*@+KWLXDg*C7lBmXr|vWAC={92w3zCNJWrBSm$d-z5FeFplxEdi=qMxD zU(l?%tl>rTQ9JUZz-8?S;}%-zGP|dHjjp*p(j$p$N(yeKMoA1gPhQ6;zKYsxJ=sOE zSITvjJzX!#U7^Q52be602B2&F84U)f_Yp>%`qphJVdjbK= z77kZl$E5d%BoU?e*MEs%XwhjpXZNF+T%Y<q>m)S&BQ)Xk+&P*dca|;csP2$d zW}7;k{!cci%P(k>%I;~MEX59rB9zUqlE_J{HPNlgbv`5~SA@|f5_RM@kx`oVw*cS} Lz2G&xg}?p}&mW+f diff --git a/venv/lib/python3.8/site-packages/pip/_internal/vcs/__pycache__/git.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/vcs/__pycache__/git.cpython-38.pyc deleted file mode 100644 index d32b9608f5b1b2b7e9c438e15c6a55318b03eb30..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 9559 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 QF+Kdb*7R?*-)O=A0+tw;mH+?% diff --git a/venv/lib/python3.8/site-packages/pip/_internal/vcs/__pycache__/mercurial.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/vcs/__pycache__/mercurial.cpython-38.pyc deleted file mode 100644 index d412bb0a7f4b69c924d0da4f0994397943c37877..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4888 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 D+VPJq diff --git a/venv/lib/python3.8/site-packages/pip/_internal/vcs/__pycache__/versioncontrol.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_internal/vcs/__pycache__/versioncontrol.cpython-38.pyc deleted file mode 100644 index 1898c9586766b8218df5512bbd79e9fbb94f5057..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 19216 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 K+w*q{x&I4X2Bgja diff --git a/venv/lib/python3.8/site-packages/pip/_internal/vcs/bazaar.py b/venv/lib/python3.8/site-packages/pip/_internal/vcs/bazaar.py deleted file mode 100644 index 347c06f..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/vcs/bazaar.py +++ /dev/null @@ -1,120 +0,0 @@ -# The following comment should be removed at some point in the future. -# mypy: disallow-untyped-defs=False - -from __future__ import absolute_import - -import logging -import os - -from pip._vendor.six.moves.urllib import parse as urllib_parse - -from pip._internal.utils.misc import display_path, rmtree -from pip._internal.utils.subprocess import make_command -from pip._internal.utils.typing import MYPY_CHECK_RUNNING -from pip._internal.utils.urls import path_to_url -from pip._internal.vcs.versioncontrol import VersionControl, vcs - -if MYPY_CHECK_RUNNING: - from typing import Optional, Tuple - from pip._internal.utils.misc import HiddenText - from pip._internal.vcs.versioncontrol import AuthInfo, RevOptions - - -logger = logging.getLogger(__name__) - - -class Bazaar(VersionControl): - name = 'bzr' - dirname = '.bzr' - repo_name = 'branch' - schemes = ( - 'bzr', 'bzr+http', 'bzr+https', 'bzr+ssh', 'bzr+sftp', 'bzr+ftp', - 'bzr+lp', - ) - - def __init__(self, *args, **kwargs): - super(Bazaar, self).__init__(*args, **kwargs) - # This is only needed for python <2.7.5 - # Register lp but do not expose as a scheme to support bzr+lp. - if getattr(urllib_parse, 'uses_fragment', None): - urllib_parse.uses_fragment.extend(['lp']) - - @staticmethod - def get_base_rev_args(rev): - return ['-r', rev] - - def export(self, location, url): - # type: (str, HiddenText) -> None - """ - Export the Bazaar repository at the url to the destination location - """ - # Remove the location to make sure Bazaar can export it correctly - if os.path.exists(location): - rmtree(location) - - url, rev_options = self.get_url_rev_options(url) - self.run_command( - make_command('export', location, url, rev_options.to_args()), - show_stdout=False, - ) - - def fetch_new(self, dest, url, rev_options): - # type: (str, HiddenText, RevOptions) -> None - rev_display = rev_options.to_display() - logger.info( - 'Checking out %s%s to %s', - url, - rev_display, - display_path(dest), - ) - cmd_args = ( - make_command('branch', '-q', 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 update(self, dest, url, rev_options): - # type: (str, HiddenText, RevOptions) -> None - cmd_args = make_command('pull', '-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 - url, rev, user_pass = super(Bazaar, cls).get_url_rev_and_auth(url) - if url.startswith('ssh://'): - url = 'bzr+' + url - return url, rev, user_pass - - @classmethod - def get_remote_url(cls, location): - urls = cls.run_command(['info'], show_stdout=False, cwd=location) - for line in urls.splitlines(): - line = line.strip() - for x in ('checkout of branch: ', - 'parent branch: '): - if line.startswith(x): - repo = line.split(x)[1] - if cls._is_local_repository(repo): - return path_to_url(repo) - return repo - return None - - @classmethod - def get_revision(cls, location): - revision = cls.run_command( - ['revno'], show_stdout=False, cwd=location, - ) - return revision.splitlines()[-1] - - @classmethod - def is_commit_id_equal(cls, dest, name): - """Always assume the versions don't match""" - return False - - -vcs.register(Bazaar) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/vcs/git.py b/venv/lib/python3.8/site-packages/pip/_internal/vcs/git.py deleted file mode 100644 index d706064..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/vcs/git.py +++ /dev/null @@ -1,395 +0,0 @@ -# The following comment should be removed at some point in the future. -# mypy: disallow-untyped-defs=False - -from __future__ import absolute_import - -import logging -import os.path -import re - -from pip._vendor.packaging.version import parse as parse_version -from pip._vendor.six.moves.urllib import parse as urllib_parse -from pip._vendor.six.moves.urllib import request as urllib_request - -from pip._internal.exceptions import BadCommand -from pip._internal.utils.misc import display_path, hide_url -from pip._internal.utils.subprocess import make_command -from pip._internal.utils.temp_dir import TempDirectory -from pip._internal.utils.typing import MYPY_CHECK_RUNNING -from pip._internal.vcs.versioncontrol import ( - RemoteNotFoundError, - VersionControl, - find_path_to_setup_from_repo_root, - vcs, -) - -if MYPY_CHECK_RUNNING: - from typing import Optional, Tuple - from pip._internal.utils.misc import HiddenText - from pip._internal.vcs.versioncontrol import AuthInfo, RevOptions - - -urlsplit = urllib_parse.urlsplit -urlunsplit = urllib_parse.urlunsplit - - -logger = logging.getLogger(__name__) - - -HASH_REGEX = re.compile('^[a-fA-F0-9]{40}$') - - -def looks_like_hash(sha): - return bool(HASH_REGEX.match(sha)) - - -class Git(VersionControl): - name = 'git' - dirname = '.git' - repo_name = 'clone' - schemes = ( - 'git', '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' - - @staticmethod - def get_base_rev_args(rev): - return [rev] - - def is_immutable_rev_checkout(self, url, dest): - # type: (str, str) -> bool - _, rev_options = self.get_url_rev_options(hide_url(url)) - if not rev_options.rev: - return False - if not self.is_commit_id_equal(dest, rev_options.rev): - # the current commit is different from rev, - # which means rev was something else than a commit hash - return False - # 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] - ) - return not is_tag_or_branch - - def get_git_version(self): - VERSION_PFX = 'git version ' - version = self.run_command(['version'], show_stdout=False) - 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) - - @classmethod - def get_current_branch(cls, location): - """ - Return the current branch, or None if HEAD isn't at a branch - (e.g. detached HEAD). - """ - # git-symbolic-ref exits with empty stdout if "HEAD" is a detached - # 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'] - output = cls.run_command( - args, extra_ok_returncodes=(1, ), show_stdout=False, cwd=location, - ) - ref = output.strip() - - if ref.startswith('refs/heads/'): - return ref[len('refs/heads/'):] - - return None - - def export(self, location, url): - # type: (str, HiddenText) -> None - """Export the Git repository at the url to the destination location""" - if not location.endswith('/'): - location = location + '/' - - with TempDirectory(kind="export") as temp_dir: - self.unpack(temp_dir.path, url=url) - self.run_command( - ['checkout-index', '-a', '-f', '--prefix', location], - show_stdout=False, cwd=temp_dir.path - ) - - @classmethod - def get_revision_sha(cls, dest, rev): - """ - 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. - - Args: - dest: the repository directory. - rev: the revision name. - """ - # Pass rev to pre-filter the list. - output = cls.run_command(['show-ref', rev], cwd=dest, - show_stdout=False, on_returncode='ignore') - refs = {} - # NOTE: We do not use splitlines here since that would split on other - # unicode separators, which can be maliciously used to install a - # different revision. - for line in output.strip().split("\n"): - line = line.rstrip("\r") - if not line: - continue - try: - sha, ref = line.split(" ", maxsplit=2) - except ValueError: - # Include the offending line to simplify troubleshooting if - # this error ever occurs. - raise ValueError('unexpected show-ref line: {!r}'.format(line)) - - refs[ref] = sha - - branch_ref = 'refs/remotes/origin/{}'.format(rev) - tag_ref = 'refs/tags/{}'.format(rev) - - sha = refs.get(branch_ref) - if sha is not None: - return (sha, True) - - sha = refs.get(tag_ref) - - return (sha, False) - - @classmethod - def resolve_revision(cls, dest, url, rev_options): - # type: (str, HiddenText, RevOptions) -> RevOptions - """ - Resolve a revision to a new RevOptions object with the SHA1 of the - branch, tag, or ref if found. - - Args: - rev_options: a RevOptions object. - """ - rev = rev_options.arg_rev - # The arg_rev property's implementation for Git ensures that the - # rev return value is always non-None. - assert rev is not None - - sha, is_branch = cls.get_revision_sha(dest, rev) - - if sha is not None: - rev_options = rev_options.make_new(sha) - rev_options.branch_name = rev if is_branch else None - - return rev_options - - # Do not show a warning for the common case of something that has - # the form of a Git commit hash. - if not looks_like_hash(rev): - logger.warning( - "Did not find branch or tag '%s', assuming revision or ref.", - rev, - ) - - if not rev.startswith('refs/'): - return rev_options - - # If it looks like a ref, we have to fetch it explicitly. - cls.run_command( - 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') - rev_options = rev_options.make_new(sha) - - return rev_options - - @classmethod - def is_commit_id_equal(cls, dest, name): - """ - Return whether the current commit hash equals the given name. - - Args: - dest: the repository directory. - name: a string name. - """ - if not name: - # Then avoid an unnecessary subprocess call. - return False - - return cls.get_revision(dest) == name - - def fetch_new(self, dest, url, rev_options): - # type: (str, HiddenText, RevOptions) -> 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)) - - 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) - 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(), - ) - 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 = 'origin/{}'.format(branch_name) - cmd_args = [ - 'checkout', '-b', branch_name, '--track', track_branch, - ] - self.run_command(cmd_args, cwd=dest) - - #: repo may contain submodules - self.update_submodules(dest) - - def switch(self, dest, url, rev_options): - # type: (str, HiddenText, RevOptions) -> None - self.run_command( - make_command('config', 'remote.origin.url', url), - cwd=dest, - ) - 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 - # First fetch changes from the default remote - if self.get_git_version() >= parse_version('1.9.0'): - # fetch tags in addition to everything else - self.run_command(['fetch', '-q', '--tags'], cwd=dest) - else: - 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()) - self.run_command(cmd_args, cwd=dest) - #: update submodules - self.update_submodules(dest) - - @classmethod - def get_remote_url(cls, location): - """ - Return URL of the first remote encountered. - - Raises RemoteNotFoundError if the repository does not have a remote - url configured. - """ - # 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, ), show_stdout=False, cwd=location, - ) - remotes = stdout.splitlines() - try: - found_remote = remotes[0] - except IndexError: - raise RemoteNotFoundError - - for remote in remotes: - if remote.startswith('remote.origin.url '): - found_remote = remote - break - url = found_remote.split(' ')[1] - return url.strip() - - @classmethod - def get_revision(cls, location, rev=None): - if rev is None: - rev = 'HEAD' - current_rev = cls.run_command( - ['rev-parse', rev], show_stdout=False, cwd=location, - ) - return current_rev.strip() - - @classmethod - def get_subdirectory(cls, location): - """ - Return the path to setup.py, relative to the repo root. - Return None if setup.py is in the repo root. - """ - # find the repo root - git_dir = cls.run_command( - ['rev-parse', '--git-dir'], - show_stdout=False, 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) - - @classmethod - def get_url_rev_and_auth(cls, url): - # type: (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 - work with a ssh:// scheme (e.g. GitHub). But we need a scheme for - parsing. Hence we remove it again afterwards and return it as a stub. - """ - # 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('/') - ) - url = urlunsplit((scheme, netloc, newpath, query, fragment)) - 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://') - url, rev, user_pass = super(Git, cls).get_url_rev_and_auth(url) - url = url.replace('ssh://', '') - else: - url, rev, user_pass = super(Git, cls).get_url_rev_and_auth(url) - - return url, rev, user_pass - - @classmethod - def update_submodules(cls, location): - if not os.path.exists(os.path.join(location, '.gitmodules')): - return - cls.run_command( - ['submodule', 'update', '--init', '--recursive', '-q'], - cwd=location, - ) - - @classmethod - def controls_location(cls, location): - if super(Git, cls).controls_location(location): - return True - try: - r = cls.run_command(['rev-parse'], - cwd=location, - show_stdout=False, - on_returncode='ignore', - log_failed_cmd=False) - return not r - except BadCommand: - logger.debug("could not determine if %s is under git control " - "because git is not available", location) - return False - - -vcs.register(Git) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/vcs/mercurial.py b/venv/lib/python3.8/site-packages/pip/_internal/vcs/mercurial.py deleted file mode 100644 index d9b58cf..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/vcs/mercurial.py +++ /dev/null @@ -1,155 +0,0 @@ -# The following comment should be removed at some point in the future. -# mypy: disallow-untyped-defs=False - -from __future__ import absolute_import - -import logging -import os - -from pip._vendor.six.moves import configparser - -from pip._internal.exceptions import BadCommand, InstallationError -from pip._internal.utils.misc import display_path -from pip._internal.utils.subprocess import make_command -from pip._internal.utils.temp_dir import TempDirectory -from pip._internal.utils.typing import MYPY_CHECK_RUNNING -from pip._internal.utils.urls import path_to_url -from pip._internal.vcs.versioncontrol import ( - VersionControl, - find_path_to_setup_from_repo_root, - vcs, -) - -if MYPY_CHECK_RUNNING: - from pip._internal.utils.misc import HiddenText - from pip._internal.vcs.versioncontrol import RevOptions - - -logger = logging.getLogger(__name__) - - -class Mercurial(VersionControl): - name = 'hg' - dirname = '.hg' - repo_name = 'clone' - schemes = ( - 'hg', 'hg+file', 'hg+http', 'hg+https', 'hg+ssh', 'hg+static-http', - ) - - @staticmethod - def get_base_rev_args(rev): - return [rev] - - def export(self, location, url): - # type: (str, HiddenText) -> None - """Export the Hg repository at the url to the destination location""" - with TempDirectory(kind="export") as temp_dir: - self.unpack(temp_dir.path, url=url) - - self.run_command( - ['archive', location], show_stdout=False, cwd=temp_dir.path - ) - - def fetch_new(self, dest, url, rev_options): - # type: (str, HiddenText, RevOptions) -> None - rev_display = rev_options.to_display() - logger.info( - 'Cloning hg %s%s to %s', - url, - rev_display, - display_path(dest), - ) - self.run_command(make_command('clone', '--noupdate', '-q', url, dest)) - self.run_command( - make_command('update', '-q', 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') - config = configparser.RawConfigParser() - try: - config.read(repo_config) - 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, - ) - else: - 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()) - self.run_command(cmd_args, cwd=dest) - - @classmethod - def get_remote_url(cls, location): - url = cls.run_command( - ['showconfig', 'paths.default'], - show_stdout=False, cwd=location).strip() - if cls._is_local_repository(url): - url = path_to_url(url) - return url.strip() - - @classmethod - def get_revision(cls, location): - """ - Return the repository-local changeset revision number, as an integer. - """ - current_revision = cls.run_command( - ['parents', '--template={rev}'], - show_stdout=False, cwd=location).strip() - return current_revision - - @classmethod - def get_requirement_revision(cls, location): - """ - Return the changeset identification hash, as a 40-character - hexadecimal string - """ - current_rev_hash = cls.run_command( - ['parents', '--template={node}'], - show_stdout=False, cwd=location).strip() - return current_rev_hash - - @classmethod - def is_commit_id_equal(cls, dest, name): - """Always assume the versions don't match""" - return False - - @classmethod - def get_subdirectory(cls, location): - """ - Return the path to setup.py, relative to the repo root. - Return None if setup.py is in the repo root. - """ - # find the repo root - repo_root = cls.run_command( - ['root'], show_stdout=False, 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) - - @classmethod - def controls_location(cls, location): - if super(Mercurial, cls).controls_location(location): - return True - try: - cls.run_command( - ['identify'], - cwd=location, - show_stdout=False, - on_returncode='raise', - log_failed_cmd=False) - return True - except (BadCommand, InstallationError): - return False - - -vcs.register(Mercurial) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/vcs/subversion.py b/venv/lib/python3.8/site-packages/pip/_internal/vcs/subversion.py deleted file mode 100644 index 6c76d1a..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/vcs/subversion.py +++ /dev/null @@ -1,333 +0,0 @@ -# The following comment should be removed at some point in the future. -# mypy: disallow-untyped-defs=False - -from __future__ import absolute_import - -import logging -import os -import re - -from pip._internal.utils.logging import indent_log -from pip._internal.utils.misc import ( - display_path, - is_console_interactive, - rmtree, - split_auth_from_netloc, -) -from pip._internal.utils.subprocess import make_command -from pip._internal.utils.typing import MYPY_CHECK_RUNNING -from pip._internal.vcs.versioncontrol import VersionControl, vcs - -_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'(.*)') - - -if MYPY_CHECK_RUNNING: - from typing import Optional, Tuple - from pip._internal.utils.subprocess import CommandArgs - from pip._internal.utils.misc import HiddenText - from pip._internal.vcs.versioncontrol import AuthInfo, RevOptions - - -logger = logging.getLogger(__name__) - - -class Subversion(VersionControl): - name = 'svn' - dirname = '.svn' - repo_name = 'checkout' - schemes = ('svn', 'svn+ssh', 'svn+http', 'svn+https', 'svn+svn') - - @classmethod - def should_add_vcs_url_prefix(cls, remote_url): - return True - - @staticmethod - def get_base_rev_args(rev): - return ['-r', rev] - - @classmethod - def get_revision(cls, location): - """ - Return the maximum revision for all files under a given location - """ - # Note: taken from setuptools.command.egg_info - revision = 0 - - for base, dirs, files in os.walk(location): - if cls.dirname not in dirs: - dirs[:] = [] - continue # no sense walking uncontrolled subdirs - dirs.remove(cls.dirname) - entries_fn = os.path.join(base, cls.dirname, 'entries') - if not os.path.exists(entries_fn): - # FIXME: should we warn? - continue - - dirurl, localrev = cls._get_svn_url_rev(base) - - if base == location: - 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 - revision = max(revision, localrev) - return revision - - @classmethod - def get_netloc_and_auth(cls, netloc, scheme): - """ - 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': - # The --username and --password options can't be used for - # svn+ssh URLs, so keep the auth information in the URL. - return super(Subversion, cls).get_netloc_and_auth(netloc, scheme) - - 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 - url, rev, user_pass = super(Subversion, cls).get_url_rev_and_auth(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 - if username: - extra_args += ['--username', username] - if password: - extra_args += ['--password', password] - - return extra_args - - @classmethod - def get_remote_url(cls, location): - # 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 - orig_location = location - while not os.path.exists(os.path.join(location, 'setup.py')): - 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 - logger.warning( - "Could not find setup.py for directory %s (tried all " - "parent directories)", - orig_location, - ) - return None - - return cls._get_svn_url_rev(location)[0] - - @classmethod - def _get_svn_url_rev(cls, location): - from pip._internal.exceptions import InstallationError - - 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 = '' - - if (data.startswith('8') or - data.startswith('9') or - data.startswith('10')): - data = list(map(str.splitlines, data.split('\n\x0c\n'))) - del data[0][0] # get rid of the '8' - url = data[0][3] - revs = [int(d[9]) for d in data if len(d) > 9 and d[9]] + [0] - elif data.startswith('= 1.7 - # Note that using get_remote_call_options is not necessary here - # because `svn info` is being run against a local directory. - # We don't need to worry about making sure interactive mode - # is being used to prompt for passwords, because passwords - # are only potentially needed for remote server requests. - xml = cls.run_command( - ['info', '--xml', location], - show_stdout=False, - ) - url = _svn_info_xml_url_re.search(xml).group(1) - revs = [ - int(m.group(1)) for m in _svn_info_xml_rev_re.finditer(xml) - ] - except InstallationError: - url, revs = None, [] - - if revs: - rev = max(revs) - else: - rev = 0 - - return url, rev - - @classmethod - def is_commit_id_equal(cls, dest, name): - """Always assume the versions don't match""" - return False - - def __init__(self, use_interactive=None): - # type: (bool) -> None - if use_interactive is None: - use_interactive = is_console_interactive() - self.use_interactive = use_interactive - - # This member is used to cache the fetched version of the current - # ``svn`` client. - # Special value definitions: - # None: Not evaluated yet. - # Empty tuple: Could not parse version. - self._vcs_version = None # type: Optional[Tuple[int, ...]] - - super(Subversion, self).__init__() - - def call_vcs_version(self): - # type: () -> Tuple[int, ...] - """Query the version of the currently installed Subversion client. - - :return: A tuple containing the parts of the version information or - ``()`` if the version returned from ``svn`` could not be parsed. - :raises: BadCommand: If ``svn`` is not installed. - """ - # Example versions: - # svn, version 1.10.3 (r1842928) - # compiled Feb 25 2019, 14:20:39 on x86_64-apple-darwin17.0.0 - # svn, version 1.7.14 (r1542130) - # compiled Mar 28 2018, 08:49:13 on x86_64-pc-linux-gnu - version_prefix = 'svn, version ' - version = self.run_command(['--version'], show_stdout=False) - if not version.startswith(version_prefix): - return () - - version = version[len(version_prefix):].split()[0] - version_list = version.split('.') - try: - parsed_version = tuple(map(int, version_list)) - except ValueError: - return () - - return parsed_version - - def get_vcs_version(self): - # type: () -> Tuple[int, ...] - """Return the version of the currently installed Subversion client. - - If the version of the Subversion client has already been queried, - a cached value will be used. - - :return: A tuple containing the parts of the version information or - ``()`` if the version returned from ``svn`` could not be parsed. - :raises: BadCommand: If ``svn`` is not installed. - """ - if self._vcs_version is not None: - # Use cached version, if available. - # If parsing the version failed previously (empty tuple), - # do not attempt to parse it again. - return self._vcs_version - - vcs_version = self.call_vcs_version() - self._vcs_version = vcs_version - return vcs_version - - def get_remote_call_options(self): - # type: () -> CommandArgs - """Return options to be used on calls to Subversion that contact the server. - - These options are applicable for the following ``svn`` subcommands used - in this class. - - - checkout - - export - - switch - - update - - :return: A list of command line arguments to pass to ``svn``. - """ - 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'] - - svn_version = self.get_vcs_version() - # By default, Subversion >= 1.8 runs in non-interactive mode if - # stdin is not a TTY. Since that is how pip invokes SVN, in - # call_subprocess(), pip must pass --force-interactive to ensure - # the user can be prompted for a password, if required. - # SVN added the --force-interactive option in SVN 1.8. Since - # e.g. RHEL/CentOS 7, which is supported until 2024, ships with - # 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 [] - - def export(self, location, url): - # type: (str, HiddenText) -> None - """Export the svn repository at the url to the destination location""" - url, rev_options = self.get_url_rev_options(url) - - logger.info('Exporting svn repository %s to %s', url, location) - with indent_log(): - if os.path.exists(location): - # Subversion doesn't like to check out over an existing - # directory --force fixes this, but was only added in svn 1.5 - rmtree(location) - cmd_args = make_command( - 'export', self.get_remote_call_options(), - rev_options.to_args(), url, location, - ) - self.run_command(cmd_args, show_stdout=False) - - def fetch_new(self, dest, url, rev_options): - # type: (str, HiddenText, RevOptions) -> None - rev_display = rev_options.to_display() - logger.info( - 'Checking out %s%s to %s', - url, - rev_display, - display_path(dest), - ) - cmd_args = make_command( - 'checkout', '-q', 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 - cmd_args = make_command( - '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 - cmd_args = make_command( - 'update', self.get_remote_call_options(), rev_options.to_args(), - dest, - ) - self.run_command(cmd_args) - - -vcs.register(Subversion) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/vcs/versioncontrol.py b/venv/lib/python3.8/site-packages/pip/_internal/vcs/versioncontrol.py deleted file mode 100644 index 7cfd568..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/vcs/versioncontrol.py +++ /dev/null @@ -1,700 +0,0 @@ -"""Handles all VCS (version control) support""" - -from __future__ import absolute_import - -import errno -import logging -import os -import shutil -import sys - -from pip._vendor import pkg_resources -from pip._vendor.six.moves.urllib import parse as urllib_parse - -from pip._internal.exceptions import BadCommand -from pip._internal.utils.compat import samefile -from pip._internal.utils.misc import ( - ask_path_exists, - backup_dir, - display_path, - hide_url, - hide_value, - rmtree, -) -from pip._internal.utils.subprocess import call_subprocess, make_command -from pip._internal.utils.typing import MYPY_CHECK_RUNNING -from pip._internal.utils.urls import get_url_scheme - -if MYPY_CHECK_RUNNING: - from typing import ( - Any, Dict, Iterable, Iterator, List, Mapping, Optional, Text, Tuple, - Type, Union - ) - from pip._internal.utils.ui import SpinnerInterface - from pip._internal.utils.misc import HiddenText - from pip._internal.utils.subprocess import CommandArgs - - AuthInfo = Tuple[Optional[str], Optional[str]] - - -__all__ = ['vcs'] - - -logger = logging.getLogger(__name__) - - -def is_url(name): - # type: (Union[str, Text]) -> 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 - - -def make_vcs_requirement_url(repo_url, rev, project_name, subdir=None): - # type: (str, str, str, Optional[str]) -> str - """ - Return the URL for a VCS requirement. - - Args: - repo_url: the remote VCS url, with any needed VCS prefix (e.g. "git+"). - project_name: the (unescaped) project name. - """ - egg_project_name = pkg_resources.to_filename(project_name) - req = '{}@{}#egg={}'.format(repo_url, rev, egg_project_name) - if subdir: - req += '&subdirectory={}'.format(subdir) - - return req - - -def find_path_to_setup_from_repo_root(location, repo_root): - # type: (str, 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 setup.py - orig_location = location - while not os.path.exists(os.path.join(location, 'setup.py')): - 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 - logger.warning( - "Could not find setup.py for directory %s (tried all " - "parent directories)", - orig_location, - ) - return None - - if samefile(repo_root, location): - return None - - return os.path.relpath(location, repo_root) - - -class RemoteNotFoundError(Exception): - pass - - -class RevOptions(object): - - """ - Encapsulates a VCS-specific revision to install, along with any VCS - install options. - - Instances of this class should be treated as if immutable. - """ - - def __init__( - self, - vc_class, # type: Type[VersionControl] - rev=None, # type: Optional[str] - extra_args=None, # type: Optional[CommandArgs] - ): - # type: (...) -> None - """ - Args: - vc_class: a VersionControl subclass. - rev: the name of the revision to install. - extra_args: a list of extra options. - """ - if extra_args is None: - extra_args = [] - - self.extra_args = extra_args - self.rev = rev - self.vc_class = vc_class - self.branch_name = None # type: Optional[str] - - def __repr__(self): - # type: () -> str - return ''.format(self.vc_class.name, self.rev) - - @property - def arg_rev(self): - # type: () -> Optional[str] - if self.rev is None: - return self.vc_class.default_arg_rev - - return self.rev - - def to_args(self): - # type: () -> CommandArgs - """ - Return the VCS-specific command arguments. - """ - args = [] # type: CommandArgs - rev = self.arg_rev - if rev is not None: - args += self.vc_class.get_base_rev_args(rev) - args += self.extra_args - - return args - - def to_display(self): - # type: () -> str - if not self.rev: - return '' - - return ' (to revision {})'.format(self.rev) - - def make_new(self, rev): - # type: (str) -> RevOptions - """ - Make a copy of the current instance, but with a new rev. - - Args: - rev: the name of the revision for the new object. - """ - return self.vc_class.make_rev_options(rev, extra_args=self.extra_args) - - -class VcsSupport(object): - _registry = {} # type: Dict[str, VersionControl] - schemes = ['ssh', 'git', 'hg', 'bzr', 'sftp', 'svn'] - - def __init__(self): - # type: () -> None - # Register more schemes with urlparse for various version control - # systems - urllib_parse.uses_netloc.extend(self.schemes) - # Python >= 2.7.4, 3.3 doesn't have uses_fragment - if getattr(urllib_parse, 'uses_fragment', None): - urllib_parse.uses_fragment.extend(self.schemes) - super(VcsSupport, self).__init__() - - def __iter__(self): - # type: () -> Iterator[str] - return self._registry.__iter__() - - @property - def backends(self): - # type: () -> List[VersionControl] - return list(self._registry.values()) - - @property - def dirnames(self): - # type: () -> List[str] - return [backend.dirname for backend in self.backends] - - @property - def all_schemes(self): - # type: () -> List[str] - schemes = [] # type: 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__) - return - if cls.name not in self._registry: - self._registry[cls.name] = cls() - logger.debug('Registered VCS backend: %s', cls.name) - - def unregister(self, name): - # type: (str) -> None - if name in self._registry: - del self._registry[name] - - def get_backend_for_dir(self, location): - # type: (str) -> Optional[VersionControl] - """ - Return a VersionControl object if a repository of that type is found - at the given directory. - """ - for vcs_backend in self._registry.values(): - if vcs_backend.controls_location(location): - logger.debug('Determine that %s uses VCS: %s', - location, vcs_backend.name) - return vcs_backend - return None - - def get_backend_for_scheme(self, scheme): - # type: (str) -> Optional[VersionControl] - """ - Return a VersionControl object or None. - """ - for vcs_backend in self._registry.values(): - if scheme in vcs_backend.schemes: - return vcs_backend - return None - - def get_backend(self, name): - # type: (str) -> Optional[VersionControl] - """ - Return a VersionControl object or None. - """ - name = name.lower() - return self._registry.get(name) - - -vcs = VcsSupport() - - -class VersionControl(object): - name = '' - dirname = '' - repo_name = '' - # List of supported schemes for this Version Control - schemes = () # type: Tuple[str, ...] - # Iterable of environment variable names to pass to call_subprocess(). - unset_environ = () # type: Tuple[str, ...] - default_arg_rev = None # type: Optional[str] - - @classmethod - def should_add_vcs_url_prefix(cls, remote_url): - # type: (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('{}:'.format(cls.name)) - - @classmethod - def get_subdirectory(cls, location): - # type: (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 None - - @classmethod - def get_requirement_revision(cls, repo_dir): - # type: (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) -> Optional[str] - """ - Return the requirement string to use to redownload the files - currently at the given repository directory. - - Args: - project_name: the (unescaped) project name. - - The return value has a form similar to the following: - - {repository_url}@{revision}#egg={project_name} - """ - repo_url = cls.get_remote_url(repo_dir) - if repo_url is None: - return None - - if cls.should_add_vcs_url_prefix(repo_url): - repo_url = '{}+{}'.format(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) - - return req - - @staticmethod - def get_base_rev_args(rev): - # type: (str) -> List[str] - """ - Return the base revision arguments for a vcs command. - - Args: - rev: the name of a revision to install. Cannot be None. - """ - raise NotImplementedError - - def is_immutable_rev_checkout(self, url, dest): - # type: (str, str) -> bool - """ - Return true if the commit hash checked out at dest matches - the revision in url. - - Always return False, if the VCS does not support immutable commit - hashes. - - This method does not check if there are local uncommitted changes - in dest after checkout, as pip currently has no use case for that. - """ - return False - - @classmethod - def make_rev_options(cls, rev=None, extra_args=None): - # type: (Optional[str], Optional[CommandArgs]) -> RevOptions - """ - Return a RevOptions object. - - Args: - rev: the name of a revision to install. - extra_args: a list of extra options. - """ - return RevOptions(cls, rev, extra_args=extra_args) - - @classmethod - def _is_local_repository(cls, repo): - # type: (str) -> bool - """ - 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) - - def export(self, location, url): - # type: (str, HiddenText) -> None - """ - Export the repository at the url to the destination location - i.e. only download the files, without vcs informations - - :param url: the repository URL starting with a vcs prefix. - """ - raise NotImplementedError - - @classmethod - def get_netloc_and_auth(cls, netloc, scheme): - # type: (str, 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. - - Args: - netloc: the original repository URL netloc. - scheme: the repository URL's scheme without the vcs prefix. - - This is mainly for the Subversion class to override, so that auth - information can be provided via the --username and --password options - instead of through the URL. For other subclasses like Git without - such an option, auth information must stay in the URL. - - Returns: (netloc, (username, password)). - """ - return netloc, (None, None) - - @classmethod - def get_url_rev_and_auth(cls, url): - # type: (str) -> Tuple[str, Optional[str], AuthInfo] - """ - Parse the repository URL to use, and return the URL, revision, - and auth info to use. - - Returns: (url, rev, (username, password)). - """ - scheme, netloc, path, query, frag = urllib_parse.urlsplit(url) - if '+' not in scheme: - raise ValueError( - "Sorry, {!r} is a malformed VCS url. " - "The format is +://, " - "e.g. svn+http://myrepo/svn/MyApp#egg=MyApp".format(url) - ) - # Remove the vcs prefix. - 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) - 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 - """ - Return the RevOptions "extra arguments" to use in obtain(). - """ - return [] - - def get_url_rev_options(self, url): - # type: (HiddenText) -> Tuple[HiddenText, RevOptions] - """ - Return the URL and RevOptions object to use in obtain() and in - some cases export(), 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] - if secret_password is not None: - password = hide_value(secret_password) - extra_args = self.make_rev_args(username, password) - rev_options = self.make_rev_options(rev, extra_args=extra_args) - - return hide_url(secret_url), rev_options - - @staticmethod - def normalize_url(url): - # type: (str) -> str - """ - Normalize a URL for comparison by unquoting it and removing any - trailing slash. - """ - return urllib_parse.unquote(url).rstrip('/') - - @classmethod - def compare_urls(cls, url1, url2): - # type: (str, str) -> bool - """ - Compare two repo URLs for identity, ignoring incidental differences. - """ - return (cls.normalize_url(url1) == cls.normalize_url(url2)) - - def fetch_new(self, dest, url, rev_options): - # type: (str, HiddenText, RevOptions) -> None - """ - Fetch a revision from a repository, in the case that this is the - first fetch from the repository. - - Args: - dest: the directory to fetch the repository to. - rev_options: a RevOptions object. - """ - raise NotImplementedError - - def switch(self, dest, url, rev_options): - # type: (str, HiddenText, RevOptions) -> None - """ - Switch the repo at ``dest`` to point to ``URL``. - - Args: - rev_options: a RevOptions object. - """ - raise NotImplementedError - - def update(self, dest, url, rev_options): - # type: (str, HiddenText, RevOptions) -> None - """ - Update an already-existing repo to the given ``rev_options``. - - Args: - rev_options: a RevOptions object. - """ - raise NotImplementedError - - @classmethod - def is_commit_id_equal(cls, dest, name): - # type: (str, Optional[str]) -> bool - """ - Return whether the id of the current commit equals the given name. - - Args: - dest: the repository directory. - name: a string name. - """ - raise NotImplementedError - - def obtain(self, dest, url): - # type: (str, HiddenText) -> 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. - """ - url, rev_options = self.get_url_rev_options(url) - - if not os.path.exists(dest): - self.fetch_new(dest, url, rev_options) - return - - rev_display = rev_options.to_display() - if self.is_repository_directory(dest): - 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)', - 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', - display_path(dest), - self.repo_name, - rev_display, - ) - self.update(dest, url, rev_options) - else: - logger.info('Skipping because already up-to-date.') - return - - logger.warning( - '%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')) - else: - logger.warning( - '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')) - - logger.warning( - 'The plan is to install the %s repository %s', - self.name, - url, - ) - response = ask_path_exists('What to do? %s' % prompt[0], prompt[1]) - - if response == 'a': - sys.exit(-1) - - if response == 'w': - logger.warning('Deleting %s', display_path(dest)) - rmtree(dest) - self.fetch_new(dest, url, rev_options) - return - - if response == 'b': - dest_dir = backup_dir(dest) - logger.warning( - 'Backing up %s to %s', display_path(dest), dest_dir, - ) - shutil.move(dest, dest_dir) - self.fetch_new(dest, url, rev_options) - return - - # Do nothing if the response is "i". - if response == 's': - logger.info( - 'Switching %s %s to %s%s', - self.repo_name, - display_path(dest), - url, - rev_display, - ) - self.switch(dest, url, rev_options) - - def unpack(self, location, url): - # type: (str, HiddenText) -> 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. - """ - if os.path.exists(location): - rmtree(location) - self.obtain(location, url=url) - - @classmethod - def get_remote_url(cls, location): - # type: (str) -> str - """ - Return the url used at location - - Raises RemoteNotFoundError if the repository does not have a remote - url configured. - """ - raise NotImplementedError - - @classmethod - def get_revision(cls, location): - # type: (str) -> str - """ - Return the current commit id of the files at the given location. - """ - raise NotImplementedError - - @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 - ): - # type: (...) -> Text - """ - 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) - 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) - except OSError as e: - # errno.ENOENT = no such file or directory - # In other words, the VCS executable isn't available - if e.errno == errno.ENOENT: - raise BadCommand( - 'Cannot find command %r - do you have ' - '%r installed and in your ' - 'PATH?' % (cls.name, cls.name)) - else: - raise # re-raise exception if a different error occurred - - @classmethod - def is_repository_directory(cls, path): - # type: (str) -> bool - """ - Return whether a directory path is a repository directory. - """ - 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 controls_location(cls, location): - # type: (str) -> bool - """ - Check if a location is controlled by the vcs. - It is meant to be overridden to implement smarter detection - mechanisms for specific vcs. - - This can do more than is_repository_directory() alone. For example, - the Git override checks that Git is actually available. - """ - return cls.is_repository_directory(location) diff --git a/venv/lib/python3.8/site-packages/pip/_internal/wheel_builder.py b/venv/lib/python3.8/site-packages/pip/_internal/wheel_builder.py deleted file mode 100644 index 7c7820d..0000000 --- a/venv/lib/python3.8/site-packages/pip/_internal/wheel_builder.py +++ /dev/null @@ -1,305 +0,0 @@ -"""Orchestrator for building wheels from InstallRequirements. -""" - -# The following comment should be removed at some point in the future. -# mypy: strict-optional=False - -import logging -import os.path -import re -import shutil - -from pip._internal.models.link import Link -from pip._internal.operations.build.wheel import build_wheel_pep517 -from pip._internal.operations.build.wheel_legacy import build_wheel_legacy -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.setuptools_build import make_setuptools_clean_args -from pip._internal.utils.subprocess import call_subprocess -from pip._internal.utils.temp_dir import TempDirectory -from pip._internal.utils.typing import MYPY_CHECK_RUNNING -from pip._internal.utils.urls import path_to_url -from pip._internal.vcs import vcs - -if MYPY_CHECK_RUNNING: - from typing import ( - Any, Callable, Iterable, List, Optional, Pattern, Tuple, - ) - - from pip._internal.cache import WheelCache - from pip._internal.req.req_install import InstallRequirement - - BinaryAllowedPredicate = Callable[[InstallRequirement], bool] - BuildResult = Tuple[List[InstallRequirement], List[InstallRequirement]] - -logger = logging.getLogger(__name__) - - -def _contains_egg_info( - s, _egg_info_re=re.compile(r'([a-z0-9_.]+)-([a-z0-9_.!+-]+)', re.I)): - # type: (str, Pattern[str]) -> bool - """Determine whether the string looks like an egg_info. - - :param s: The string to parse. E.g. foo-2.1 - """ - return bool(_egg_info_re.search(s)) - - -def _should_build( - req, # type: InstallRequirement - need_wheel, # type: bool - check_binary_allowed, # type: BinaryAllowedPredicate -): - # type: (...) -> bool - """Return whether an InstallRequirement should be built into a wheel.""" - if req.constraint: - # never build requirements that are merely constraints - return False - if req.is_wheel: - if need_wheel: - logger.info( - 'Skipping %s, due to already being wheel.', req.name, - ) - return False - - if need_wheel: - # i.e. pip wheel, not pip install - return True - - # From this point, this concerns the pip install command only - # (need_wheel=False). - - if not req.use_pep517 and not is_wheel_installed(): - # we don't build legacy requirements if wheel is not installed - return False - - if req.editable or not req.source_dir: - return False - - if not check_binary_allowed(req): - logger.info( - "Skipping wheel build for %s, due to binaries " - "being disabled for it.", req.name, - ) - return False - - 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 - ) - - -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 - ) - - -def _should_cache( - req, # type: InstallRequirement -): - # type: (...) -> Optional[bool] - """ - Return whether a built InstallRequirement can be stored in the persistent - wheel cache, assuming the wheel cache is available, and _should_build() - has determined a wheel needs to be built. - """ - if not should_build_for_install_command( - req, check_binary_allowed=_always_true - ): - # never cache if pip install would not have built - # (editable mode, etc) - return False - - if req.link and req.link.is_vcs: - # VCS checkout. Do not cache - # unless it points to an immutable commit hash. - assert not req.editable - assert req.source_dir - vcs_backend = vcs.get_backend_for_scheme(req.link.scheme) - assert vcs_backend - if vcs_backend.is_immutable_rev_checkout(req.link.url, req.source_dir): - return True - return False - - base, ext = req.link.splitext() - if _contains_egg_info(base): - return True - - # Otherwise, do not cache. - return False - - -def _get_cache_dir( - req, # type: InstallRequirement - wheel_cache, # type: WheelCache -): - # type: (...) -> str - """Return the persistent or temporary cache directory where the built - wheel need to be stored. - """ - cache_available = bool(wheel_cache.cache_dir) - if cache_available and _should_cache(req): - cache_dir = wheel_cache.get_path_for_link(req.link) - else: - cache_dir = wheel_cache.get_ephem_path_for_link(req.link) - return cache_dir - - -def _always_true(_): - # type: (Any) -> bool - return True - - -def _build_one( - req, # type: InstallRequirement - output_dir, # type: str - build_options, # type: List[str] - global_options, # type: List[str] -): - # type: (...) -> Optional[str] - """Build one wheel. - - :return: The filename of the built wheel, or None if the build failed. - """ - try: - ensure_dir(output_dir) - except OSError as e: - logger.warning( - "Building wheel for %s failed: %s", - req.name, e, - ) - return None - - # Install build deps into temporary directory (PEP 518) - with req.build_env: - return _build_one_inside_env( - req, output_dir, build_options, global_options - ) - - -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] - with TempDirectory(kind="wheel") as temp_dir: - if req.use_pep517: - wheel_path = build_wheel_pep517( - name=req.name, - backend=req.pep517_backend, - metadata_directory=req.metadata_directory, - build_options=build_options, - tempd=temp_dir.path, - ) - else: - wheel_path = build_wheel_legacy( - name=req.name, - setup_py_path=req.setup_py_path, - source_dir=req.unpacked_source_directory, - global_options=global_options, - build_options=build_options, - tempd=temp_dir.path, - ) - - if wheel_path is not None: - wheel_name = os.path.basename(wheel_path) - dest_path = os.path.join(output_dir, wheel_name) - 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) - return dest_path - except Exception as e: - logger.warning( - "Building wheel for %s failed: %s", - req.name, e, - ) - # Ignore return, we can't do anything else useful. - if not req.use_pep517: - _clean_one_legacy(req, global_options) - return None - - -def _clean_one_legacy(req, global_options): - # type: (InstallRequirement, 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) - try: - call_subprocess(clean_args, cwd=req.source_dir) - return True - except Exception: - logger.error('Failed cleaning build dir for %s', req.name) - return False - - -def build( - requirements, # type: Iterable[InstallRequirement] - wheel_cache, # type: WheelCache - build_options, # type: List[str] - global_options, # type: List[str] -): - # type: (...) -> BuildResult - """Build wheels. - - :return: The list of InstallRequirement that succeeded to build and - the list of InstallRequirement that failed to build. - """ - if not requirements: - return [], [] - - # Build the wheels. - logger.info( - 'Building wheels for collected packages: %s', - ', '.join(req.name for req in requirements), - ) - - with indent_log(): - build_successes, build_failures = [], [] - for req in requirements: - cache_dir = _get_cache_dir(req, wheel_cache) - wheel_file = _build_one( - req, cache_dir, build_options, global_options - ) - if wheel_file: - # Update the link for this. - req.link = Link(path_to_url(wheel_file)) - req.local_file_path = req.link.file_path - assert req.link.is_wheel - build_successes.append(req) - else: - build_failures.append(req) - - # notify success/failure - if build_successes: - logger.info( - 'Successfully built %s', - ' '.join([req.name for req in build_successes]), - ) - if build_failures: - logger.info( - 'Failed to build %s', - ' '.join([req.name for req in build_failures]), - ) - # Return a list of requirements that failed to build - return build_successes, build_failures diff --git a/venv/lib/python3.8/site-packages/pip/_vendor/__init__.py b/venv/lib/python3.8/site-packages/pip/_vendor/__init__.py deleted file mode 100644 index e02eaef..0000000 --- a/venv/lib/python3.8/site-packages/pip/_vendor/__init__.py +++ /dev/null @@ -1,119 +0,0 @@ -""" -pip._vendor is for vendoring dependencies of pip to prevent needing pip to -depend on something external. - -Files inside of pip._vendor should be considered immutable and should only be -updated to versions from upstream. -""" -from __future__ import absolute_import - -import glob -import os.path -import sys - -# Downstream redistributors which have debundled our dependencies should also -# patch this value to be true. This will trigger the additional patching -# to cause things like "six" to be available as pip. -DEBUNDLED = True - -# By default, look in this directory for a bunch of .whl files which we will -# add to the beginning of sys.path before attempting to import anything. This -# is done to support downstream re-distributors like Debian and Fedora who -# wish to create their own Wheels for our dependencies to aid in debundling. -prefix = getattr(sys, "base_prefix", sys.prefix) -if prefix.startswith('/usr/lib/pypy'): - prefix = '/usr' -WHEEL_DIR = os.path.abspath(os.path.join(prefix, 'share', 'python-wheels')) - - -# Define a small helper function to alias our vendored modules to the real ones -# if the vendored ones do not exist. This idea of this was taken from -# https://github.com/kennethreitz/requests/pull/2567. -def vendored(modulename): - vendored_name = "{0}.{1}".format(__name__, modulename) - - try: - __import__(modulename, globals(), locals(), level=0) - except ImportError: - # We can just silently allow import failures to pass here. If we - # got to this point it means that ``import pip._vendor.whatever`` - # failed and so did ``import whatever``. Since we're importing this - # upfront in an attempt to alias imports, not erroring here will - # just mean we get a regular import error whenever pip *actually* - # tries to import one of these modules to use it, which actually - # gives us a better error message than we would have otherwise - # gotten. - pass - else: - sys.modules[vendored_name] = sys.modules[modulename] - base, head = vendored_name.rsplit(".", 1) - setattr(sys.modules[base], head, sys.modules[modulename]) - - -# If we're operating in a debundled setup, then we want to go ahead and trigger -# the aliasing of our vendored libraries as well as looking for wheels to add -# to our sys.path. This will cause all of this code to be a no-op typically -# however downstream redistributors can enable it in a consistent way across -# all platforms. -if DEBUNDLED: - # Actually look inside of WHEEL_DIR to find .whl files and add them to the - # front of our sys.path. - sys.path[:] = glob.glob(os.path.join(WHEEL_DIR, "*.whl")) + sys.path - - # Actually alias all of our vendored dependencies. - vendored("appdirs") - vendored("cachecontrol") - vendored("colorama") - vendored("contextlib2") - vendored("distlib") - vendored("distro") - vendored("html5lib") - vendored("six") - vendored("six.moves") - vendored("six.moves.urllib") - vendored("six.moves.urllib.parse") - vendored("packaging") - vendored("packaging.version") - vendored("packaging.specifiers") - vendored("pep517") - vendored("pkg_resources") - vendored("progress") - vendored("retrying") - vendored("requests") - vendored("requests.exceptions") - vendored("requests.packages") - vendored("requests.packages.urllib3") - vendored("requests.packages.urllib3._collections") - vendored("requests.packages.urllib3.connection") - vendored("requests.packages.urllib3.connectionpool") - vendored("requests.packages.urllib3.contrib") - vendored("requests.packages.urllib3.contrib.ntlmpool") - vendored("requests.packages.urllib3.contrib.pyopenssl") - vendored("requests.packages.urllib3.exceptions") - vendored("requests.packages.urllib3.fields") - vendored("requests.packages.urllib3.filepost") - vendored("requests.packages.urllib3.packages") - try: - vendored("requests.packages.urllib3.packages.ordered_dict") - vendored("requests.packages.urllib3.packages.six") - except ImportError: - # Debian already unbundles these from requests. - pass - vendored("requests.packages.urllib3.packages.ssl_match_hostname") - vendored("requests.packages.urllib3.packages.ssl_match_hostname." - "_implementation") - vendored("requests.packages.urllib3.poolmanager") - vendored("requests.packages.urllib3.request") - vendored("requests.packages.urllib3.response") - vendored("requests.packages.urllib3.util") - vendored("requests.packages.urllib3.util.connection") - vendored("requests.packages.urllib3.util.request") - vendored("requests.packages.urllib3.util.response") - vendored("requests.packages.urllib3.util.retry") - vendored("requests.packages.urllib3.util.ssl_") - vendored("requests.packages.urllib3.util.timeout") - vendored("requests.packages.urllib3.util.url") - vendored("toml") - vendored("toml.encoder") - vendored("toml.decoder") - vendored("urllib3") diff --git a/venv/lib/python3.8/site-packages/pip/_vendor/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/pip/_vendor/__pycache__/__init__.cpython-38.pyc deleted file mode 100644 index 996d06e61b94db4f77f92ecda8d37e6f50db2212..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3037 zcmbW3TXWPl6o7qOd)L{`rG${smYO?(#>*{`(v&i7!a#@Np)CX5>5Ru&DOo4BWh6Oa zP4X1_*cpC8^4R~-U!v(-pZE(r^~hGXnRc>auxIs2M@PrfIY-hyYqeYrp1XH0hUA2% z{Vf}ZpE@)iz>oc4Xd2Qw8q$#w>xt1ZbXhlJvtyRDI<=B^$3|Ai!F6n-8n)LPyJn|> z8+$IY_jURRInb)DkL)$evV|L{jvD*szTO!{E*g2Gb;hvs)}Rluxo0Y!QPkWw_I0o} za!QjWGLiY4v8drO)Y{c`$x+2I#c{<6#ZMGZC{8M#RGd;gr8uoPqj*~JQ^n5|KUX}X z_=TdUcvkV8;(5gjiWe0xDPC5*qByH~Rq>kQmy*RKtb9&Me97lpI%R2ie8YXK(?4}h zzQ1Ux@k08jtu(JI-cY=$cuVoN;=JM=#k-0NieD+-Q~X+SQSlqa`-P5_31yrplUGosmpa-Yj2s4kYdZ6ra;$;+r4);=wkyNY1Zl&#!)MF&U zyeGTxD~@Rz#=h%5jAF17r7S{N85?|=^++BgZv}f@QYui4yeLU>9#LPhB2dUn+LkPCPYz#DB4d8=k@g+|MiU>D(43)uEh|bSm^${Qs4?3 z;+lk9)Po=m6C4D>4U{*a?ySXRC5)M{W73rzd0aYbnNmW9$@)w<2|+o;PuP@Yam0ng zFb_GWvzBnHK51CAs^r0_{Eo1spM}-KA^Jn3Ct-H)7ur0@+K@7Hd76dY4U8)1&PDm! z%Z2{!E!o#rDcOcurV$SUKkJM7fo%`$uyH6fy=fTwv_9Ifjd6Wkr>8(x)UNtly;wM5 zmZ69;(d>rZ9)`r?l*FRmB{8945{eNif&_)g-xLmtn5+p~Rwxnm9#7(VDKQx&NdpQ$ zA)A;LHJo3p>Nv{EfS! zm2IpA6f=_3F8IBkQL+Y2s8P&mA8g9n%N#S#iW3JlAHVA2jLYp%Obmq8hhXY6{}ZVt z+$t^|+2se|vKV(Os~3*e1AnHKT5;t=v@$~C;_OgOPQkrbk5%zg9z)84xogMkW_<$3 z8e?%WWG#pM=pAhmLKY)doExSQA{bzm!yLG-%Zjy5qEs}V zKU!XX5-dIbu{_;r6D*cD$)RFOex<%x-9z`~oyXolVL45suESfi>`~p-Eq&UqpSH~l YW+|0DANd+EuBne3wj5u5;|NRt0I8|6M*si- diff --git a/venv/lib/python3.8/site-packages/pkg_resources-0.0.0.dist-info/AUTHORS.txt b/venv/lib/python3.8/site-packages/pkg_resources-0.0.0.dist-info/AUTHORS.txt deleted file mode 100644 index 72c87d7..0000000 --- a/venv/lib/python3.8/site-packages/pkg_resources-0.0.0.dist-info/AUTHORS.txt +++ /dev/null @@ -1,562 +0,0 @@ -A_Rog -Aakanksha Agrawal <11389424+rasponic@users.noreply.github.com> -Abhinav Sagar <40603139+abhinavsagar@users.noreply.github.com> -ABHYUDAY PRATAP SINGH -abs51295 -AceGentile -Adam Chainz -Adam Tse -Adam Tse -Adam Wentz -admin -Adrien Morison -ahayrapetyan -Ahilya -AinsworthK -Akash Srivastava -Alan Yee -Albert Tugushev -Albert-Guan -albertg -Aleks Bunin -Alethea Flowers -Alex Gaynor -Alex Grönholm -Alex Loosley -Alex Morega -Alex Stachowiak -Alexander Shtyrov -Alexandre Conrad -Alexey Popravka -Alexey Popravka -Alli -Ami Fischman -Ananya Maiti -Anatoly Techtonik -Anders Kaseorg -Andreas Lutro -Andrei Geacar -Andrew Gaul -Andrey Bulgakov -Andrés Delfino <34587441+andresdelfino@users.noreply.github.com> -Andrés Delfino -Andy Freeland -Andy Freeland -Andy Kluger -Ani Hayrapetyan -Aniruddha Basak -Anish Tambe -Anrs Hu -Anthony Sottile -Antoine Musso -Anton Ovchinnikov -Anton Patrushev -Antonio Alvarado Hernandez -Antony Lee -Antti Kaihola -Anubhav Patel -Anuj Godase -AQNOUCH Mohammed -AraHaan -Arindam Choudhury -Armin Ronacher -Artem -Ashley Manton -Ashwin Ramaswami -atse -Atsushi Odagiri -Avner Cohen -Baptiste Mispelon -Barney Gale -barneygale -Bartek Ogryczak -Bastian Venthur -Ben Darnell -Ben Hoyt -Ben Rosser -Bence Nagy -Benjamin Peterson -Benjamin VanEvery -Benoit Pierre -Berker Peksag -Bernardo B. Marques -Bernhard M. Wiedemann -Bertil Hatt -Bogdan Opanchuk -BorisZZZ -Brad Erickson -Bradley Ayers -Brandon L. Reiss -Brandt Bucher -Brett Randall -Brian Cristante <33549821+brcrista@users.noreply.github.com> -Brian Cristante -Brian Rosner -BrownTruck -Bruno Oliveira -Bruno Renié -Bstrdsmkr -Buck Golemon -burrows -Bussonnier Matthias -c22 -Caleb Martinez -Calvin Smith -Carl Meyer -Carlos Liam -Carol Willing -Carter Thayer -Cass -Chandrasekhar Atina -Chih-Hsuan Yen -Chih-Hsuan Yen -Chris Brinker -Chris Hunt -Chris Jerdonek -Chris McDonough -Chris Wolfe -Christian Heimes -Christian Oudard -Christopher Hunt -Christopher Snyder -Clark Boylan -Clay McClure -Cody -Cody Soyland -Colin Watson -Connor Osborn -Cooper Lees -Cooper Ry Lees -Cory Benfield -Cory Wright -Craig Kerstiens -Cristian Sorinel -Curtis Doty -cytolentino -Damian Quiroga -Dan Black -Dan Savilonis -Dan Sully -daniel -Daniel Collins -Daniel Hahler -Daniel Holth -Daniel Jost -Daniel Shaulov -Daniele Esposti -Daniele Procida -Danny Hermes -Dav Clark -Dave Abrahams -Dave Jones -David Aguilar -David Black -David Bordeynik -David Bordeynik -David Caro -David Evans -David Linke -David Pursehouse -David Tucker -David Wales -Davidovich -derwolfe -Desetude -Diego Caraballo -DiegoCaraballo -Dmitry Gladkov -Domen Kožar -Donald Stufft -Dongweiming -Douglas Thor -DrFeathers -Dustin Ingram -Dwayne Bailey -Ed Morley <501702+edmorley@users.noreply.github.com> -Ed Morley -Eitan Adler -ekristina -elainechan -Eli Schwartz -Eli Schwartz -Emil Burzo -Emil Styrke -Endoh Takanao -enoch -Erdinc Mutlu -Eric Gillingham -Eric Hanchrow -Eric Hopper -Erik M. Bray -Erik Rose -Ernest W Durbin III -Ernest W. Durbin III -Erwin Janssen -Eugene Vereshchagin -everdimension -Felix Yan -fiber-space -Filip Kokosiński -Florian Briand -Florian Rathgeber -Francesco -Francesco Montesano -Frost Ming -Gabriel Curio -Gabriel de Perthuis -Garry Polley -gdanielson -Geoffrey Lehée -Geoffrey Sneddon -George Song -Georgi Valkov -Giftlin Rajaiah -gizmoguy1 -gkdoc <40815324+gkdoc@users.noreply.github.com> -Gopinath M <31352222+mgopi1990@users.noreply.github.com> -GOTO Hayato <3532528+gh640@users.noreply.github.com> -gpiks -Guilherme Espada -Guy Rozendorn -gzpan123 -Hanjun Kim -Hari Charan -Harsh Vardhan -Herbert Pfennig -Hsiaoming Yang -Hugo -Hugo Lopes Tavares -Hugo van Kemenade -hugovk -Hynek Schlawack -Ian Bicking -Ian Cordasco -Ian Lee -Ian Stapleton Cordasco -Ian Wienand -Ian Wienand -Igor Kuzmitshov -Igor Sobreira -Ilya Baryshev -INADA Naoki -Ionel Cristian Mărieș -Ionel Maries Cristian -Ivan Pozdeev -Jacob Kim -jakirkham -Jakub Stasiak -Jakub Vysoky -Jakub Wilk -James Cleveland -James Cleveland -James Firth -James Polley -Jan Pokorný -Jannis Leidel -jarondl -Jason R. Coombs -Jay Graves -Jean-Christophe Fillion-Robin -Jeff Barber -Jeff Dairiki -Jelmer Vernooij -jenix21 -Jeremy Stanley -Jeremy Zafran -Jiashuo Li -Jim Garrison -Jivan Amara -John Paton -John-Scott Atlakson -johnthagen -johnthagen -Jon Banafato -Jon Dufresne -Jon Parise -Jonas Nockert -Jonathan Herbert -Joost Molenaar -Jorge Niedbalski -Joseph Long -Josh Bronson -Josh Hansen -Josh Schneier -Juanjo Bazán -Julian Berman -Julian Gethmann -Julien Demoor -jwg4 -Jyrki Pulliainen -Kai Chen -Kamal Bin Mustafa -kaustav haldar -keanemind -Keith Maxwell -Kelsey Hightower -Kenneth Belitzky -Kenneth Reitz -Kenneth Reitz -Kevin Burke -Kevin Carter -Kevin Frommelt -Kevin R Patterson -Kexuan Sun -Kit Randel -kpinc -Krishna Oza -Kumar McMillan -Kyle Persohn -lakshmanaram -Laszlo Kiss-Kollar -Laurent Bristiel -Laurie Opperman -Leon Sasson -Lev Givon -Lincoln de Sousa -Lipis -Loren Carvalho -Lucas Cimon -Ludovic Gasc -Luke Macken -Luo Jiebin -luojiebin -luz.paz -László Kiss Kollár -László Kiss Kollár -Marc Abramowitz -Marc Tamlyn -Marcus Smith -Mariatta -Mark Kohler -Mark Williams -Mark Williams -Markus Hametner -Masaki -Masklinn -Matej Stuchlik -Mathew Jennings -Mathieu Bridon -Matt Good -Matt Maker -Matt Robenolt -matthew -Matthew Einhorn -Matthew Gilliard -Matthew Iversen -Matthew Trumbell -Matthew Willson -Matthias Bussonnier -mattip -Maxim Kurnikov -Maxime Rouyrre -mayeut -mbaluna <44498973+mbaluna@users.noreply.github.com> -mdebi <17590103+mdebi@users.noreply.github.com> -memoselyk -Michael -Michael Aquilina -Michael E. Karpeles -Michael Klich -Michael Williamson -michaelpacer -Mickaël Schoentgen -Miguel Araujo Perez -Mihir Singh -Mike -Mike Hendricks -Min RK -MinRK -Miro Hrončok -Monica Baluna -montefra -Monty Taylor -Nate Coraor -Nathaniel J. Smith -Nehal J Wani -Neil Botelho -Nick Coghlan -Nick Stenning -Nick Timkovich -Nicolas Bock -Nikhil Benesch -Nitesh Sharma -Nowell Strite -NtaleGrey -nvdv -Ofekmeister -ofrinevo -Oliver Jeeves -Oliver Tonnhofer -Olivier Girardot -Olivier Grisel -Ollie Rutherfurd -OMOTO Kenji -Omry Yadan -Oren Held -Oscar Benjamin -Oz N Tiram -Pachwenko <32424503+Pachwenko@users.noreply.github.com> -Patrick Dubroy -Patrick Jenkins -Patrick Lawson -patricktokeeffe -Patrik Kopkan -Paul Kehrer -Paul Moore -Paul Nasrat -Paul Oswald -Paul van der Linden -Paulus Schoutsen -Pavithra Eswaramoorthy <33131404+QueenCoffee@users.noreply.github.com> -Pawel Jasinski -Pekka Klärck -Peter Lisák -Peter Waller -petr-tik -Phaneendra Chiruvella -Phil Freo -Phil Pennock -Phil Whelan -Philip Jägenstedt -Philip Molloy -Philippe Ombredanne -Pi Delport -Pierre-Yves Rofes -pip -Prabakaran Kumaresshan -Prabhjyotsing Surjit Singh Sodhi -Prabhu Marappan -Pradyun Gedam -Pratik Mallya -Preet Thakkar -Preston Holmes -Przemek Wrzos -Pulkit Goyal <7895pulkit@gmail.com> -Qiangning Hong -Quentin Pradet -R. David Murray -Rafael Caricio -Ralf Schmitt -Razzi Abuissa -rdb -Remi Rampin -Remi Rampin -Rene Dudfield -Riccardo Magliocchetti -Richard Jones -RobberPhex -Robert Collins -Robert McGibbon -Robert T. McGibbon -robin elisha robinson -Roey Berman -Rohan Jain -Rohan Jain -Rohan Jain -Roman Bogorodskiy -Romuald Brunet -Ronny Pfannschmidt -Rory McCann -Ross Brattain -Roy Wellington Ⅳ -Roy Wellington Ⅳ -Ryan Wooden -ryneeverett -Sachi King -Salvatore Rinchiera -Savio Jomton -schlamar -Scott Kitterman -Sean -seanj -Sebastian Jordan -Sebastian Schaetz -Segev Finer -SeongSoo Cho -Sergey Vasilyev -Seth Woodworth -Shlomi Fish -Shovan Maity -Simeon Visser -Simon Cross -Simon Pichugin -sinoroc -Sorin Sbarnea -Stavros Korokithakis -Stefan Scherfke -Stephan Erb -stepshal -Steve (Gadget) Barnes -Steve Barnes -Steve Dower -Steve Kowalik -Steven Myint -stonebig -Stéphane Bidoul (ACSONE) -Stéphane Bidoul -Stéphane Klein -Sumana Harihareswara -Sviatoslav Sydorenko -Sviatoslav Sydorenko -Swat009 -Takayuki SHIMIZUKAWA -tbeswick -Thijs Triemstra -Thomas Fenzl -Thomas Grainger -Thomas Guettler -Thomas Johansson -Thomas Kluyver -Thomas Smith -Tim D. Smith -Tim Gates -Tim Harder -Tim Heap -tim smith -tinruufu -Tom Forbes -Tom Freudenheim -Tom V -Tomas Orsava -Tomer Chachamu -Tony Beswick -Tony Zhaocheng Tan -TonyBeswick -toonarmycaptain -Toshio Kuratomi -Travis Swicegood -Tzu-ping Chung -Valentin Haenel -Victor Stinner -victorvpaulo -Viktor Szépe -Ville Skyttä -Vinay Sajip -Vincent Philippon -Vinicyus Macedo <7549205+vinicyusmacedo@users.noreply.github.com> -Vitaly Babiy -Vladimir Rutsky -W. Trevor King -Wil Tan -Wilfred Hughes -William ML Leslie -William T Olson -Wilson Mo -wim glenn -Wolfgang Maier -Xavier Fernandez -Xavier Fernandez -xoviat -xtreak -YAMAMOTO Takashi -Yen Chi Hsuan -Yeray Diaz Diaz -Yoval P -Yu Jian -Yuan Jing Vincent Yan -Zearin -Zearin -Zhiping Deng -Zvezdan Petkovic -Łukasz Langa -Семён Марьясин diff --git a/venv/lib/python3.8/site-packages/pkg_resources-0.0.0.dist-info/INSTALLER b/venv/lib/python3.8/site-packages/pkg_resources-0.0.0.dist-info/INSTALLER deleted file mode 100644 index a1b589e..0000000 --- a/venv/lib/python3.8/site-packages/pkg_resources-0.0.0.dist-info/INSTALLER +++ /dev/null @@ -1 +0,0 @@ -pip diff --git a/venv/lib/python3.8/site-packages/pkg_resources-0.0.0.dist-info/LICENSE.txt b/venv/lib/python3.8/site-packages/pkg_resources-0.0.0.dist-info/LICENSE.txt deleted file mode 100644 index 737fec5..0000000 --- a/venv/lib/python3.8/site-packages/pkg_resources-0.0.0.dist-info/LICENSE.txt +++ /dev/null @@ -1,20 +0,0 @@ -Copyright (c) 2008-2019 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/venv/lib/python3.8/site-packages/pkg_resources-0.0.0.dist-info/METADATA b/venv/lib/python3.8/site-packages/pkg_resources-0.0.0.dist-info/METADATA deleted file mode 100644 index cf6c930..0000000 --- a/venv/lib/python3.8/site-packages/pkg_resources-0.0.0.dist-info/METADATA +++ /dev/null @@ -1,13 +0,0 @@ -Metadata-Version: 2.1 -Name: pkg_resources -Version: 0.0.0 -Summary: UNKNOWN -Home-page: UNKNOWN -Author: UNKNOWN -Author-email: UNKNOWN -License: UNKNOWN -Platform: UNKNOWN - -UNKNOWN - - diff --git a/venv/lib/python3.8/site-packages/pkg_resources-0.0.0.dist-info/RECORD b/venv/lib/python3.8/site-packages/pkg_resources-0.0.0.dist-info/RECORD deleted file mode 100644 index 2bbae1d..0000000 --- a/venv/lib/python3.8/site-packages/pkg_resources-0.0.0.dist-info/RECORD +++ /dev/null @@ -1,38 +0,0 @@ -pkg_resources-0.0.0.dist-info/AUTHORS.txt,sha256=RtqU9KfonVGhI48DAA4-yTOBUhBtQTjFhaDzHoyh7uU,21518 -pkg_resources-0.0.0.dist-info/INSTALLER,sha256=zuuue4knoyJ-UwPPXg8fezS7VCrXJQrAP7zeNuwvFQg,4 -pkg_resources-0.0.0.dist-info/LICENSE.txt,sha256=W6Ifuwlk-TatfRU2LR7W1JMcyMj5_y1NkRkOEJvnRDE,1090 -pkg_resources-0.0.0.dist-info/METADATA,sha256=V9_WPOtD1FnuKrTGv6Ique7kAOn2lasvT8W0_iMCCCk,177 -pkg_resources-0.0.0.dist-info/RECORD,, -pkg_resources-0.0.0.dist-info/WHEEL,sha256=kGT74LWyRUZrL4VgLh6_g12IeVl_9u9ZVhadrgXZUEY,110 -pkg_resources/__init__.py,sha256=0IssxXPnaDKpYZRra8Ime0JG4hwosQljItGD0bnIkGk,108349 -pkg_resources/__pycache__/__init__.cpython-38.pyc,, -pkg_resources/__pycache__/py31compat.cpython-38.pyc,, -pkg_resources/_vendor/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -pkg_resources/_vendor/__pycache__/__init__.cpython-38.pyc,, -pkg_resources/_vendor/__pycache__/appdirs.cpython-38.pyc,, -pkg_resources/_vendor/__pycache__/pyparsing.cpython-38.pyc,, -pkg_resources/_vendor/__pycache__/six.cpython-38.pyc,, -pkg_resources/_vendor/appdirs.py,sha256=MievUEuv3l_mQISH5SF0shDk_BNhHHzYiAPrT3ITN4I,24701 -pkg_resources/_vendor/packaging/__about__.py,sha256=zkcCPTN_6TcLW0Nrlg0176-R1QQ_WVPTm8sz1R4-HjM,720 -pkg_resources/_vendor/packaging/__init__.py,sha256=_vNac5TrzwsrzbOFIbF-5cHqc_Y2aPT2D7zrIR06BOo,513 -pkg_resources/_vendor/packaging/__pycache__/__about__.cpython-38.pyc,, -pkg_resources/_vendor/packaging/__pycache__/__init__.cpython-38.pyc,, -pkg_resources/_vendor/packaging/__pycache__/_compat.cpython-38.pyc,, -pkg_resources/_vendor/packaging/__pycache__/_structures.cpython-38.pyc,, -pkg_resources/_vendor/packaging/__pycache__/markers.cpython-38.pyc,, -pkg_resources/_vendor/packaging/__pycache__/requirements.cpython-38.pyc,, -pkg_resources/_vendor/packaging/__pycache__/specifiers.cpython-38.pyc,, -pkg_resources/_vendor/packaging/__pycache__/utils.cpython-38.pyc,, -pkg_resources/_vendor/packaging/__pycache__/version.cpython-38.pyc,, -pkg_resources/_vendor/packaging/_compat.py,sha256=Vi_A0rAQeHbU-a9X0tt1yQm9RqkgQbDSxzRw8WlU9kA,860 -pkg_resources/_vendor/packaging/_structures.py,sha256=RImECJ4c_wTlaTYYwZYLHEiebDMaAJmK1oPARhw1T5o,1416 -pkg_resources/_vendor/packaging/markers.py,sha256=uEcBBtGvzqltgnArqb9c4RrcInXezDLos14zbBHhWJo,8248 -pkg_resources/_vendor/packaging/requirements.py,sha256=SikL2UynbsT0qtY9ltqngndha_sfo0w6XGFhAhoSoaQ,4355 -pkg_resources/_vendor/packaging/specifiers.py,sha256=SAMRerzO3fK2IkFZCaZkuwZaL_EGqHNOz4pni4vhnN0,28025 -pkg_resources/_vendor/packaging/utils.py,sha256=3m6WvPm6NNxE8rkTGmn0r75B_GZSGg7ikafxHsBN1WA,421 -pkg_resources/_vendor/packaging/version.py,sha256=OwGnxYfr2ghNzYx59qWIBkrK3SnB6n-Zfd1XaLpnnM0,11556 -pkg_resources/_vendor/pyparsing.py,sha256=tmrp-lu-qO1i75ZzIN5A12nKRRD1Cm4Vpk-5LR9rims,232055 -pkg_resources/_vendor/six.py,sha256=A6hdJZVjI3t_geebZ9BzUvwRrIXo0lfwzQlM2LcKyas,30098 -pkg_resources/extern/__init__.py,sha256=cHiEfHuLmm6rs5Ve_ztBfMI7Lr31vss-D4wkqF5xzlI,2498 -pkg_resources/extern/__pycache__/__init__.cpython-38.pyc,, -pkg_resources/py31compat.py,sha256=-WQ0e4c3RG_acdhwC3gLiXhP_lg4G5q7XYkZkQg0gxU,558 diff --git a/venv/lib/python3.8/site-packages/pkg_resources-0.0.0.dist-info/WHEEL b/venv/lib/python3.8/site-packages/pkg_resources-0.0.0.dist-info/WHEEL deleted file mode 100644 index ef99c6c..0000000 --- a/venv/lib/python3.8/site-packages/pkg_resources-0.0.0.dist-info/WHEEL +++ /dev/null @@ -1,6 +0,0 @@ -Wheel-Version: 1.0 -Generator: bdist_wheel (0.34.2) -Root-Is-Purelib: true -Tag: py2-none-any -Tag: py3-none-any - diff --git a/venv/lib/python3.8/site-packages/pkg_resources/__init__.py b/venv/lib/python3.8/site-packages/pkg_resources/__init__.py deleted file mode 100644 index 2f5aa64..0000000 --- a/venv/lib/python3.8/site-packages/pkg_resources/__init__.py +++ /dev/null @@ -1,3296 +0,0 @@ -# coding: utf-8 -""" -Package resource API --------------------- - -A resource is a logical file contained within a package, or a logical -subdirectory thereof. The package resource API expects resource names -to have their path parts separated with ``/``, *not* whatever the local -path separator is. Do not use os.path operations to manipulate resource -names being passed into the API. - -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 - -import sys -import os -import io -import time -import re -import types -import zipfile -import zipimport -import warnings -import stat -import functools -import pkgutil -import operator -import platform -import collections -import plistlib -import email.parser -import errno -import tempfile -import textwrap -import itertools -import inspect -import ntpath -import posixpath -from pkgutil import get_importer - -try: - import _imp -except ImportError: - # Python 3.2 compatibility - import imp as _imp - -try: - FileExistsError -except NameError: - FileExistsError = OSError - -from pkg_resources.extern import six -from pkg_resources.extern.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 - WRITE_SUPPORT = False - -from os import open as os_open -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 pkg_resources.extern import appdirs -from pkg_resources.extern import packaging -__import__('pkg_resources.extern.packaging.version') -__import__('pkg_resources.extern.packaging.specifiers') -__import__('pkg_resources.extern.packaging.requirements') -__import__('pkg_resources.extern.packaging.markers') - - -__metaclass__ = type - - -if (3, 0) < 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 -working_set = None -add_activation_listener = None -resources_stream = None -cleanup_resources = None -resource_dir = None -resource_stream = None -set_extraction_path = None -resource_isdir = None -resource_string = None -iter_entry_points = None -resource_listdir = None -resource_filename = None -resource_exists = None -_distribution_finders = None -_namespace_handlers = None -_namespace_packages = None - - -class PEP440Warning(RuntimeWarning): - """ - Used when there is an issue with a version or specifier not complying with - PEP 440. - """ - - -def parse_version(v): - try: - return packaging.version.Version(v) - except packaging.version.InvalidVersion: - return packaging.version.LegacyVersion(v) - - -_state_vars = {} - - -def _declare_state(vartype, **kw): - globals().update(kw) - _state_vars.update(dict.fromkeys(kw, vartype)) - - -def __getstate__(): - state = {} - g = globals() - for k, v in _state_vars.items(): - state[k] = g['_sget_' + v](g[k]) - return state - - -def __setstate__(state): - g = globals() - for k, v in state.items(): - g['_sset_' + _state_vars[k]](k, g[k], v) - return state - - -def _sget_dict(val): - return val.copy() - - -def _sset_dict(key, ob, state): - ob.clear() - ob.update(state) - - -def _sget_object(val): - return val.__getstate__() - - -def _sset_object(key, ob, state): - ob.__setstate__(state) - - -_sget_none = _sset_none = lambda *args: None - - -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 - 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 - current version of the OS. - - If this condition occurs for any other platform with a version in its - platform strings, this function should be extended accordingly. - """ - plat = get_build_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)) - except ValueError: - # not Mac OS X - 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', - 'iter_entry_points', - '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', - 'get_default_cache', - - # Primary implementation classes - 'Environment', 'WorkingSet', 'ResourceManager', - 'Distribution', 'Requirement', 'EntryPoint', - - # Exceptions - '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', - - # filesystem utilities - 'ensure_directory', 'normalize_path', - - # Distribution "precedence" constants - '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', - - # Warnings - 'PkgResourcesDeprecationWarning', - - # Deprecated/backward compatibility only - 'run_main', 'AvailableDistributions', -] - - -class ResolutionError(Exception): - """Abstract base for dependency resolution errors""" - - def __repr__(self): - return self.__class__.__name__ + repr(self.args) - - -class VersionConflict(ResolutionError): - """ - An already-installed version conflicts with the requested version. - - Should be initialized with the installed Distribution and the requested - Requirement. - """ - - _template = "{self.dist} is installed but {self.req} is required" - - @property - def dist(self): - return self.args[0] - - @property - def req(self): - return self.args[1] - - def report(self): - return self._template.format(**locals()) - - def with_context(self, required_by): - """ - If required_by is non-empty, return a version of self that is a - ContextualVersionConflict. - """ - if not required_by: - return self - args = self.args + (required_by,) - return ContextualVersionConflict(*args) - - -class ContextualVersionConflict(VersionConflict): - """ - A VersionConflict that accepts a third parameter, the set of the - requirements that required the installed Distribution. - """ - - _template = VersionConflict._template + ' by {self.required_by}' - - @property - def required_by(self): - return self.args[2] - - -class DistributionNotFound(ResolutionError): - """A requested distribution was not found""" - - _template = ("The '{self.req}' distribution was not found " - "and is required by {self.requirers_str}") - - @property - def req(self): - return self.args[0] - - @property - def requirers(self): - return self.args[1] - - @property - def requirers_str(self): - if not self.requirers: - return 'the application' - return ', '.join(self.requirers) - - def report(self): - return self._template.format(**locals()) - - def __str__(self): - return self.report() - - -class UnknownExtra(ResolutionError): - """Distribution doesn't have an "extra feature" of the given name""" - - -_provider_factories = {} - -PY_MAJOR = '{}.{}'.format(*sys.version_info) -EGG_DIST = 3 -BINARY_DIST = 2 -SOURCE_DIST = 1 -CHECKOUT_DIST = 0 -DEVELOP_DIST = -1 - - -def register_loader_type(loader_type, provider_factory): - """Register `provider_factory` to make providers for `loader_type` - - `loader_type` is the type or class of a PEP 302 ``module.__loader__``, - and `provider_factory` is a function that, passed a *module* object, - returns an ``IResourceProvider`` for that module. - """ - _provider_factories[loader_type] = provider_factory - - -def get_provider(moduleOrReq): - """Return an IResourceProvider for the named module or requirement""" - if isinstance(moduleOrReq, Requirement): - return working_set.find(moduleOrReq) or require(str(moduleOrReq))[0] - try: - module = sys.modules[moduleOrReq] - except KeyError: - __import__(moduleOrReq) - module = sys.modules[moduleOrReq] - loader = getattr(module, '__loader__', None) - return _find_adapter(_provider_factories, loader)(module) - - -def _macosx_vers(_cache=[]): - if not _cache: - version = platform.mac_ver()[0] - # fallback for MacPorts - if version == '': - plist = '/System/Library/CoreServices/SystemVersion.plist' - if os.path.exists(plist): - if hasattr(plistlib, 'readPlist'): - plist_content = plistlib.readPlist(plist) - if 'ProductVersion' in plist_content: - version = plist_content['ProductVersion'] - - _cache.append(version.split('.')) - return _cache[0] - - -def _macosx_arch(machine): - return {'PowerPC': 'ppc', 'Power_Macintosh': 'ppc'}.get(machine, machine) - - -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. - """ - from sysconfig import get_platform - - plat = get_platform() - if sys.platform == "darwin" and not plat.startswith('macosx-'): - try: - version = _macosx_vers() - machine = os.uname()[4].replace(" ", "_") - return "macosx-%d.%d-%s" % ( - int(version[0]), int(version[1]), - _macosx_arch(machine), - ) - except ValueError: - # if someone is running a non-Mac darwin system, this will fall - # through to the default implementation - pass - return plat - - -macosVersionString = re.compile(r"macosx-(\d+)\.(\d+)-(.*)") -darwinVersionString = re.compile(r"darwin-(\d+)\.(\d+)\.(\d+)-(.*)") -# XXX backward compat -get_platform = get_build_platform - - -def compatible_platforms(provided, required): - """Can code for the `provided` platform run on the `required` platform? - - Returns true if either platform is ``None``, or the platforms are equal. - - XXX Needs compatibility checks for Linux and other unixy OSes. - """ - if provided is None or required is None or provided == required: - # easy case - return True - - # Mac OS X special cases - reqMac = macosVersionString.match(required) - if reqMac: - provMac = macosVersionString.match(provided) - - # is this a Mac package? - 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. - 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": - return True - # egg isn't macosx 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): - return False - - # is the required OS major update >= the provided one? - if int(provMac.group(2)) > int(reqMac.group(2)): - return False - - return True - - # XXX Linux and other platforms' special cases should go here - return False - - -def run_script(dist_spec, script_name): - """Locate distribution `dist_spec` and run its `script_name` script""" - ns = sys._getframe(1).f_globals - name = ns['__name__'] - ns.clear() - ns['__name__'] = name - require(dist_spec)[0].run_script(script_name, ns) - - -# backward compatibility -run_main = run_script - - -def get_distribution(dist): - """Return a current distribution object for a Requirement or string""" - if isinstance(dist, six.string_types): - dist = Requirement.parse(dist) - if isinstance(dist, Requirement): - dist = get_provider(dist) - if not isinstance(dist, Distribution): - raise TypeError("Expected string, Requirement, or Distribution", dist) - return dist - - -def load_entry_point(dist, group, name): - """Return `name` entry point of `group` for `dist` or raise ImportError""" - return get_distribution(dist).load_entry_point(group, name) - - -def get_entry_map(dist, group=None): - """Return the entry point map for `group`, or the full entry map""" - return get_distribution(dist).get_entry_map(group) - - -def get_entry_info(dist, group, name): - """Return the EntryPoint object for `group`+`name`, or ``None``""" - return get_distribution(dist).get_entry_info(group, name) - - -class IMetadataProvider: - def has_metadata(name): - """Does the package's distribution contain the named metadata?""" - - def get_metadata(name): - """The named metadata resource as a string""" - - 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.""" - - def metadata_isdir(name): - """Is the named metadata a directory? (like ``os.path.isdir()``)""" - - def metadata_listdir(name): - """List of metadata names in the directory (like ``os.listdir()``)""" - - def run_script(script_name, namespace): - """Execute the named script in the supplied namespace dictionary""" - - -class IResourceProvider(IMetadataProvider): - """An object that provides access to package resources""" - - def get_resource_filename(manager, resource_name): - """Return a true filesystem path for `resource_name` - - `manager` must be an ``IResourceManager``""" - - def get_resource_stream(manager, resource_name): - """Return a readable file-like object for `resource_name` - - `manager` must be an ``IResourceManager``""" - - def get_resource_string(manager, resource_name): - """Return a string containing the contents of `resource_name` - - `manager` must be an ``IResourceManager``""" - - def has_resource(resource_name): - """Does the package contain the named resource?""" - - def resource_isdir(resource_name): - """Is the named resource a directory? (like ``os.path.isdir()``)""" - - def resource_listdir(resource_name): - """List of resource names in the directory (like ``os.listdir()``)""" - - -class WorkingSet: - """A collection of active distributions on sys.path (or a similar list)""" - - def __init__(self, entries=None): - """Create working set from list of path entries (default=sys.path)""" - self.entries = [] - self.entry_keys = {} - self.by_key = {} - self.callbacks = [] - - if entries is None: - entries = sys.path - - for entry in entries: - self.add_entry(entry) - - @classmethod - def _build_master(cls): - """ - Prepare the master working set. - """ - ws = cls() - try: - from __main__ import __requires__ - except ImportError: - # The main program does not list any requirements - return ws - - # ensure the requirements are met - try: - ws.require(__requires__) - except VersionConflict: - return cls._build_from_requirements(__requires__) - - return ws - - @classmethod - def _build_from_requirements(cls, req_spec): - """ - Build a working set from a requirement spec. Rewrites sys.path. - """ - # try it without defaults already on sys.path - # by starting with an empty path - ws = cls([]) - reqs = parse_requirements(req_spec) - dists = ws.resolve(reqs, Environment()) - for dist in dists: - ws.add(dist) - - # add any missing entries from sys.path - for entry in sys.path: - if entry not in ws.entries: - ws.add_entry(entry) - - # then copy back to sys.path - sys.path[:] = ws.entries - return ws - - def add_entry(self, entry): - """Add a path item to ``.entries``, finding any distributions on it - - ``find_distributions(entry, True)`` is used to find distributions - corresponding to the path entry, and they are added. `entry` is - always appended to ``.entries``, even if it is already present. - (This is because ``sys.path`` can contain the same value more than - once, and the ``.entries`` of the ``sys.path`` WorkingSet should always - equal ``sys.path``.) - """ - self.entry_keys.setdefault(entry, []) - self.entries.append(entry) - for dist in find_distributions(entry, True): - self.add(dist, entry, False) - - def __contains__(self, dist): - """True if `dist` is the active distribution for its project""" - return self.by_key.get(dist.key) == dist - - def find(self, req): - """Find a distribution matching requirement `req` - - If there is an active distribution for the requested project, this - returns it as long as it meets the version requirement specified by - `req`. But, if there is an active distribution for the project and it - does *not* meet the `req` requirement, ``VersionConflict`` is raised. - If there is no active distribution for the requested project, ``None`` - is returned. - """ - dist = self.by_key.get(req.key) - if dist is not None and dist not in req: - # XXX add more info - raise VersionConflict(dist, req) - return dist - - def iter_entry_points(self, group, name=None): - """Yield entry point objects from `group` matching `name` - - If `name` is None, yields all entry points in `group` from all - distributions in the working set, otherwise only ones matching - both `group` and `name` are yielded (in distribution order). - """ - return ( - entry - for dist in self - for entry in dist.get_entry_map(group).values() - if name is None or name == entry.name - ) - - def run_script(self, requires, script_name): - """Locate distribution for `requires` and run `script_name` script""" - ns = sys._getframe(1).f_globals - name = ns['__name__'] - ns.clear() - ns['__name__'] = name - self.require(requires)[0].run_script(script_name, ns) - - def __iter__(self): - """Yield distributions for non-duplicate projects in the working set - - The yield order is the order in which the items' path entries were - added to the working set. - """ - seen = {} - for item in self.entries: - if item not in self.entry_keys: - # workaround a cache issue - continue - - for key in self.entry_keys[item]: - if key not in seen: - seen[key] = 1 - yield self.by_key[key] - - def add(self, dist, entry=None, insert=True, replace=False): - """Add `dist` to working set, associated with `entry` - - If `entry` is unspecified, it defaults to the ``.location`` of `dist`. - On exit from this routine, `entry` is added to the end of the working - set's ``.entries`` (if it wasn't already present). - - `dist` is only added to the working set if it's for a project that - doesn't already have a distribution in the set, unless `replace=True`. - If it's added, any callbacks registered with the ``subscribe()`` method - will be called. - """ - if insert: - dist.insert_on(self.entries, entry, replace=replace) - - if entry is None: - entry = dist.location - keys = self.entry_keys.setdefault(entry, []) - keys2 = self.entry_keys.setdefault(dist.location, []) - if not replace and dist.key in self.by_key: - # ignore hidden distros - return - - self.by_key[dist.key] = dist - 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): - """List all distributions needed to (recursively) meet `requirements` - - `requirements` must be a sequence of ``Requirement`` objects. `env`, - if supplied, should be an ``Environment`` instance. If - not supplied, it defaults to all distributions available within any - entry or distribution in the working set. `installer`, if supplied, - will be invoked with each requirement that cannot be met by an - already-installed distribution; it should return a ``Distribution`` or - ``None``. - - Unless `replace_conflicting=True`, raises a VersionConflict exception - if - any requirements are found on the path that have the correct name but - the wrong version. Otherwise, if an `installer` is supplied it will be - invoked to obtain the correct version of the requirement and activate - it. - - `extras` is a list of the extras to be used with these requirements. - This is important because extra requirements may look like `my_req; - extra = "my_extra"`, which would otherwise be interpreted as a purely - optional requirement. Instead, we want to be able to assert that these - requirements are truly required. - """ - - # set up the stack - requirements = list(requirements)[::-1] - # set of processed requirements - processed = {} - # key -> dist - best = {} - to_activate = [] - - req_extras = _ReqExtras() - - # Mapping of requirement to set of distributions that required it; - # useful for reporting info about conflicts. - required_by = collections.defaultdict(set) - - while requirements: - # process dependencies breadth-first - req = requirements.pop(0) - if req in processed: - # Ignore cyclic or redundant dependencies - continue - - 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) - - # push the new requirements onto the stack - new_requirements = dist.requires(req.extras)[::-1] - requirements.extend(new_requirements) - - # Register the new requirements needed by req - for new_requirement in new_requirements: - required_by[new_requirement].add(req.project_name) - req_extras[new_requirement] = req.extras - - processed[req] = True - - # return list of distros to activate - return to_activate - - def find_plugins( - self, plugin_env, full_env=None, installer=None, fallback=True): - """Find all activatable distributions in `plugin_env` - - Example usage:: - - distributions, errors = working_set.find_plugins( - Environment(plugin_dirlist) - ) - # add plugins+libs to sys.path - map(working_set.add, distributions) - # display errors - print('Could not load', errors) - - The `plugin_env` should be an ``Environment`` instance that contains - only distributions that are in the project's "plugin directory" or - directories. The `full_env`, if supplied, should be an ``Environment`` - contains all currently-available distributions. If `full_env` is not - supplied, one is created automatically from the ``WorkingSet`` this - method is called on, which will typically mean that every directory on - ``sys.path`` will be scanned for distributions. - - `installer` is a standard installer callback as used by the - ``resolve()`` method. The `fallback` flag indicates whether we should - attempt to resolve older versions of a plugin if the newest version - cannot be resolved. - - This method returns a 2-tuple: (`distributions`, `error_info`), where - `distributions` is a list of the distributions found in `plugin_env` - that were loadable, along with any other distributions that are needed - to resolve their dependencies. `error_info` is a dictionary mapping - unloadable plugin distributions to an exception instance describing the - error that occurred. Usually this will be a ``DistributionNotFound`` or - ``VersionConflict`` instance. - """ - - plugin_projects = list(plugin_env) - # scan project names in alphabetic order - plugin_projects.sort() - - error_info = {} - distributions = {} - - if full_env is None: - env = Environment(self.entries) - env += plugin_env - else: - env = full_env + plugin_env - - shadow_set = self.__class__([]) - # put all our entries in shadow_set - list(map(shadow_set.add, self)) - - for project_name in plugin_projects: - - for dist in plugin_env[project_name]: - - req = [dist.as_requirement()] - - try: - resolvees = shadow_set.resolve(req, env, installer) - - except ResolutionError as v: - # save error info - error_info[dist] = v - if fallback: - # try the next older version of project - continue - else: - # give up on this project, keep going - break - - else: - list(map(shadow_set.add, resolvees)) - distributions.update(dict.fromkeys(resolvees)) - - # success, no need to try any more versions of this project - break - - distributions = list(distributions) - distributions.sort() - - return distributions, error_info - - def require(self, *requirements): - """Ensure that distributions matching `requirements` are activated - - `requirements` must be a string or a (possibly-nested) sequence - thereof, specifying the distributions and versions required. The - return value is a sequence of the distributions that needed to be - activated to fulfill the requirements; all relevant distributions are - included, even if they were already activated in this working set. - """ - needed = self.resolve(parse_requirements(requirements)) - - for dist in needed: - self.add(dist) - - return needed - - def subscribe(self, callback, existing=True): - """Invoke `callback` for all distributions - - If `existing=True` (default), - call on all existing ones, as well. - """ - if callback in self.callbacks: - return - self.callbacks.append(callback) - if not existing: - return - for dist in self: - callback(dist) - - def _added_new(self, dist): - for callback in self.callbacks: - callback(dist) - - def __getstate__(self): - return ( - self.entries[:], self.entry_keys.copy(), self.by_key.copy(), - self.callbacks[:] - ) - - def __setstate__(self, e_k_b_c): - entries, keys, by_key, callbacks = e_k_b_c - self.entries = entries[:] - self.entry_keys = keys.copy() - self.by_key = by_key.copy() - self.callbacks = callbacks[:] - - -class _ReqExtras(dict): - """ - Map each requirement to the extras that demanded it. - """ - - def markers_pass(self, req, extras=None): - """ - Evaluate markers for req against each extra that - demanded it. - - Return False if the req has a marker and fails - evaluation. Otherwise, return True. - """ - extra_evals = ( - req.marker.evaluate({'extra': extra}) - for extra in self.get(req, ()) + (extras or (None,)) - ) - return not req.marker or any(extra_evals) - - -class Environment: - """Searchable snapshot of distributions on a search path""" - - def __init__( - 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. - `search_path` should be a sequence of ``sys.path`` items. If not - supplied, ``sys.path`` is used. - - `platform` is an optional string specifying the name of the platform - that platform-specific distributions must be compatible with. If - unspecified, it defaults to the current platform. `python` is an - optional string naming the desired version of Python (e.g. ``'3.6'``); - it defaults to the current version. - - You may explicitly set `platform` (and/or `python`) to ``None`` if you - wish to map *all* distributions, not just those compatible with the - running platform or Python version. - """ - self._distmap = {} - self.platform = platform - self.python = python - self.scan(search_path) - - def can_add(self, dist): - """Is distribution `dist` acceptable for this environment? - - The distribution must match the platform and python version - requirements specified when this environment was created, or False - is returned. - """ - py_compat = ( - self.python is None - or dist.py_version is None - or dist.py_version == self.python - ) - return py_compat and compatible_platforms(dist.platform, self.platform) - - def remove(self, dist): - """Remove `dist` from the environment""" - self._distmap[dist.key].remove(dist) - - def scan(self, search_path=None): - """Scan `search_path` for distributions usable in this environment - - Any distributions found are added to the environment. - `search_path` should be a sequence of ``sys.path`` items. If not - supplied, ``sys.path`` is used. Only distributions conforming to - the platform/python version defined at initialization are added. - """ - if search_path is None: - search_path = sys.path - - for item in search_path: - for dist in find_distributions(item): - self.add(dist) - - def __getitem__(self, project_name): - """Return a newest-to-oldest list of distributions for `project_name` - - Uses case-insensitive `project_name` comparison, assuming all the - project's distributions use their project's name converted to all - lowercase as their key. - - """ - distribution_key = project_name.lower() - return self._distmap.get(distribution_key, []) - - def add(self, dist): - """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): - """Find distribution best matching `req` and usable on `working_set` - - This calls the ``find(req)`` method of the `working_set` to see if a - suitable distribution is already active. (This may raise - ``VersionConflict`` if an unsuitable version of the project is already - active in the specified `working_set`.) If a suitable distribution - isn't active, this method returns the newest distribution in the - environment that meets the ``Requirement`` in `req`. If no suitable - distribution is found, and `installer` is supplied, then the result of - calling the environment's ``obtain(req, installer)`` method will be - returned. - """ - try: - dist = working_set.find(req) - except VersionConflict: - if not replace_conflicting: - raise - dist = None - if dist is not None: - return dist - for dist in self[req.key]: - if dist in req: - return dist - # try to download/install - return self.obtain(req, installer) - - def obtain(self, requirement, installer=None): - """Obtain a distribution matching `requirement` (e.g. via download) - - Obtain a distro that matches requirement (e.g. via download). In the - base ``Environment`` class, this routine just returns - ``installer(requirement)``, unless `installer` is None, in which case - None is returned instead. This method is a hook that allows subclasses - to attempt other ways of obtaining a distribution before falling back - to the `installer` argument.""" - if installer is not None: - return installer(requirement) - - def __iter__(self): - """Yield the unique project names of the available distributions""" - for key in self._distmap.keys(): - if self[key]: - yield key - - def __iadd__(self, other): - """In-place addition of a distribution or environment""" - if isinstance(other, Distribution): - self.add(other) - elif isinstance(other, Environment): - for project in other: - for dist in other[project]: - self.add(dist) - else: - raise TypeError("Can't add %r to environment" % (other,)) - return self - - def __add__(self, other): - """Add an environment or distribution to an environment""" - new = self.__class__([], platform=None, python=None) - for env in self, other: - new += env - return new - - -# XXX backward compatibility -AvailableDistributions = Environment - - -class ExtractionError(RuntimeError): - """An error occurred extracting a resource - - The following attributes are available from instances of this exception: - - manager - The resource manager that raised this exception - - cache_path - The base directory for resource extraction - - original_error - The exception instance that caused extraction to fail - """ - - -class ResourceManager: - """Manage resource extraction and packages""" - extraction_path = None - - def __init__(self): - self.cached_files = {} - - def resource_exists(self, package_or_requirement, resource_name): - """Does the named resource exist?""" - return get_provider(package_or_requirement).has_resource(resource_name) - - 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 - ) - - def resource_filename(self, package_or_requirement, resource_name): - """Return a true filesystem path for specified resource""" - return get_provider(package_or_requirement).get_resource_filename( - self, resource_name - ) - - def resource_stream(self, package_or_requirement, resource_name): - """Return a readable file-like object for specified resource""" - return get_provider(package_or_requirement).get_resource_stream( - self, resource_name - ) - - def resource_string(self, package_or_requirement, resource_name): - """Return specified resource as a string""" - return get_provider(package_or_requirement).get_resource_string( - self, resource_name - ) - - 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 - ) - - def extraction_error(self): - """Give an error message for problems extracting file(s)""" - - old_exc = sys.exc_info()[1] - cache_path = self.extraction_path or get_default_cache() - - tmpl = textwrap.dedent(""" - Can't extract file(s) to egg cache - - The following error occurred while trying to extract file(s) - to the Python egg cache: - - {old_exc} - - The Python egg cache directory is currently set to: - - {cache_path} - - 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() - err = ExtractionError(tmpl.format(**locals())) - err.manager = self - err.cache_path = cache_path - err.original_error = old_exc - raise err - - def get_cache_path(self, archive_name, names=()): - """Return absolute location in cache for `archive_name` and `names` - - The parent directory of the resulting path will be created if it does - not already exist. `archive_name` should be the base filename of the - enclosing egg (which may not be the name of the enclosing zipfile!), - including its ".egg" extension. `names`, if provided, should be a - sequence of path name parts "under" the egg's extraction location. - - This method should only be called by resource providers that need to - obtain an extraction location, and only for names they intend to - extract, as it tracks the generated names for possible cleanup later. - """ - extract_path = self.extraction_path or get_default_cache() - target_path = os.path.join(extract_path, archive_name + '-tmp', *names) - try: - _bypass_ensure_directory(target_path) - except Exception: - self.extraction_error() - - self._warn_unsafe_extraction_path(extract_path) - - self.cached_files[target_path] = 1 - return target_path - - @staticmethod - def _warn_unsafe_extraction_path(path): - """ - If the default extraction path is overridden and set to an insecure - location, such as /tmp, it opens up an opportunity for an attacker to - replace an extracted file with an unauthorized payload. Warn the user - if a known insecure location is used. - - See Distribute #375 for more details. - """ - if os.name == 'nt' and not path.startswith(os.environ['windir']): - # On Windows, permissions are generally restrictive by default - # and temp directories are not writable by other users, so - # bypass the warning. - return - 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 " - "location (set with .set_extraction_path or the " - "PYTHON_EGG_CACHE environment variable)." % path - ) - warnings.warn(msg, UserWarning) - - def postprocess(self, tempname, filename): - """Perform any platform-specific postprocessing of `tempname` - - This is where Mac header rewrites should be done; other platforms don't - have anything special they should do. - - Resource providers should call this method ONLY after successfully - extracting a compressed resource. They must NOT call it on resources - that are already in the filesystem. - - `tempname` is the current (temporary) name of the file, and `filename` - is the name it will be renamed to by the caller after this routine - returns. - """ - - if os.name == 'posix': - # Make the resource executable - mode = ((os.stat(tempname).st_mode) | 0o555) & 0o7777 - os.chmod(tempname, mode) - - def set_extraction_path(self, path): - """Set the base path where resources will be extracted to, if needed. - - If you do not call this routine before any extractions take place, the - path defaults to the return value of ``get_default_cache()``. (Which - is based on the ``PYTHON_EGG_CACHE`` environment variable, with various - platform-specific fallbacks. See that routine's documentation for more - details.) - - Resources are extracted to subdirectories of this path based upon - information given by the ``IResourceProvider``. You may set this to a - temporary directory, but then you must call ``cleanup_resources()`` to - delete the extracted files when done. There is no guarantee that - ``cleanup_resources()`` will be able to remove all extracted files. - - (Note: you may not change the extraction path for a given resource - manager once resources have been extracted, unless you first call - ``cleanup_resources()``.) - """ - if self.cached_files: - raise ValueError( - "Can't change extraction path, files already extracted" - ) - - self.extraction_path = path - - def cleanup_resources(self, force=False): - """ - Delete all extracted resource files and directories, returning a list - of the file and directory names that could not be successfully removed. - This function does not have any concurrency protection, so it should - generally only be called when the extraction path is a temporary - directory exclusive to a single process. This method is not - automatically called; you must call it explicitly or register it as an - ``atexit`` function if you wish to ensure cleanup of a temporary - directory used for extractions. - """ - # XXX - - -def get_default_cache(): - """ - Return the ``PYTHON_EGG_CACHE`` environment variable - 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') - ) - - -def safe_name(name): - """Convert an arbitrary string to a standard distribution name - - Any runs of non-alphanumeric/. characters are replaced with a single '-'. - """ - return re.sub('[^A-Za-z0-9.]+', '-', name) - - -def safe_version(version): - """ - Convert an arbitrary string to a standard version string - """ - try: - # normalize the version - return str(packaging.version.Version(version)) - except packaging.version.InvalidVersion: - version = version.replace(' ', '.') - return re.sub('[^A-Za-z0-9.]+', '-', version) - - -def safe_extra(extra): - """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. - """ - return re.sub('[^A-Za-z0-9.-]+', '_', extra).lower() - - -def to_filename(name): - """Convert a project or version name to its filename-escaped form - - Any '-' characters are currently replaced with '_'. - """ - return name.replace('-', '_') - - -def invalid_marker(text): - """ - Validate text as a PEP 508 environment marker; return an exception - if invalid or False otherwise. - """ - try: - evaluate_marker(text) - except SyntaxError as e: - e.filename = None - e.lineno = None - return e - return False - - -def evaluate_marker(text, extra=None): - """ - Evaluate a PEP 508 environment marker. - Return a boolean indicating the marker result in this environment. - Raise SyntaxError if marker is invalid. - - This implementation uses the 'pyparsing' module. - """ - try: - marker = packaging.markers.Marker(text) - return marker.evaluate() - except packaging.markers.InvalidMarker as e: - raise SyntaxError(e) - - -class NullProvider: - """Try to implement resources and metadata for arbitrary PEP 302 loaders""" - - egg_name = None - egg_info = None - loader = None - - def __init__(self, module): - self.loader = getattr(module, '__loader__', None) - self.module_path = os.path.dirname(getattr(module, '__file__', '')) - - def get_resource_filename(self, manager, resource_name): - return self._fn(self.module_path, resource_name) - - def get_resource_stream(self, manager, resource_name): - return io.BytesIO(self.get_resource_string(manager, resource_name)) - - def get_resource_string(self, manager, resource_name): - return self._get(self._fn(self.module_path, resource_name)) - - def has_resource(self, resource_name): - return self._has(self._fn(self.module_path, resource_name)) - - def _get_metadata_path(self, name): - return self._fn(self.egg_info, name) - - def has_metadata(self, name): - if not self.egg_info: - return self.egg_info - - path = self._get_metadata_path(name) - return self._has(path) - - def get_metadata(self, name): - if not self.egg_info: - 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: - # Include the path in the error message to simplify - # troubleshooting, and without changing the exception type. - exc.reason += ' in {} file at path: {}'.format(name, path) - raise - - def get_metadata_lines(self, name): - return yield_lines(self.get_metadata(name)) - - def resource_isdir(self, resource_name): - return self._isdir(self._fn(self.module_path, resource_name)) - - def metadata_isdir(self, name): - return self.egg_info and self._isdir(self._fn(self.egg_info, name)) - - def resource_listdir(self, resource_name): - return self._listdir(self._fn(self.module_path, resource_name)) - - def metadata_listdir(self, name): - if self.egg_info: - return self._listdir(self._fn(self.egg_info, name)) - return [] - - def run_script(self, script_name, namespace): - 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_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() - 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 - ) - script_code = compile(script_text, script_filename, 'exec') - exec(script_code, namespace, namespace) - - def _has(self, path): - raise NotImplementedError( - "Can't perform this operation for unregistered loader type" - ) - - def _isdir(self, path): - raise NotImplementedError( - "Can't perform this operation for unregistered loader type" - ) - - def _listdir(self, path): - raise NotImplementedError( - "Can't perform this operation for unregistered loader type" - ) - - def _fn(self, base, resource_name): - self._validate_resource_path(resource_name) - if resource_name: - return os.path.join(base, *resource_name.split('/')) - return base - - @staticmethod - 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 - - >>> warned = getfixture('recwarn') - >>> warnings.simplefilter('always') - >>> vrp = NullProvider._validate_resource_path - >>> vrp('foo/bar.txt') - >>> bool(warned) - False - >>> vrp('../foo/bar.txt') - >>> bool(warned) - True - >>> warned.clear() - >>> vrp('/foo/bar.txt') - >>> bool(warned) - True - >>> vrp('foo/../../bar.txt') - >>> bool(warned) - True - >>> warned.clear() - >>> vrp('foo/f../bar.txt') - >>> bool(warned) - False - - Windows path separators are straight-up disallowed. - >>> vrp(r'\\foo/bar.txt') - Traceback (most recent call last): - ... - ValueError: Use of .. or absolute path in a resource path \ -is not allowed. - - >>> vrp(r'C:\\foo/bar.txt') - Traceback (most recent call last): - ... - ValueError: Use of .. or absolute path in a resource path \ -is not allowed. - - Blank values are allowed - - >>> vrp('') - >>> bool(warned) - False - - Non-string values are not. - - >>> vrp(None) - Traceback (most recent call last): - ... - AttributeError: ... - """ - invalid = ( - os.path.pardir in path.split(posixpath.sep) or - posixpath.isabs(path) or - ntpath.isabs(path) - ) - if not invalid: - return - - msg = "Use of .. or absolute path in a resource path is not allowed." - - # Aggressively disallow Windows absolute paths - if ntpath.isabs(path) and not posixpath.isabs(path): - raise ValueError(msg) - - # for compatibility, warn; in future - # raise ValueError(msg) - warnings.warn( - msg[:-1] + " and will raise exceptions in a future release.", - DeprecationWarning, - stacklevel=4, - ) - - def _get(self, path): - if hasattr(self.loader, 'get_data'): - return self.loader.get_data(path) - raise NotImplementedError( - "Can't perform this operation for loaders without 'get_data()'" - ) - - -register_loader_type(object, NullProvider) - - -class EggProvider(NullProvider): - """Provider based on a virtual filesystem""" - - def __init__(self, module): - NullProvider.__init__(self, 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) - - -class DefaultProvider(EggProvider): - """Provides access to package resources in the filesystem""" - - def _has(self, path): - return os.path.exists(path) - - def _isdir(self, path): - return os.path.isdir(path) - - def _listdir(self, path): - return os.listdir(path) - - def get_resource_stream(self, manager, resource_name): - return open(self._fn(self.module_path, resource_name), 'rb') - - def _get(self, path): - with open(path, 'rb') as stream: - return stream.read() - - @classmethod - def _register(cls): - loader_names = 'SourceFileLoader', 'SourcelessFileLoader', - for name in loader_names: - loader_cls = getattr(importlib_machinery, name, type(None)) - register_loader_type(loader_cls, cls) - - -DefaultProvider._register() - - -class EmptyProvider(NullProvider): - """Provider that returns nothing for all requests""" - - module_path = None - - _isdir = _has = lambda self, path: False - - def _get(self, path): - return '' - - def _listdir(self, path): - return [] - - def __init__(self): - pass - - -empty_provider = EmptyProvider() - - -class ZipManifests(dict): - """ - zip manifest builder - """ - - @classmethod - def build(cls, path): - """ - Build a dictionary similar to the zipimport directory - caches, except instead of tuples, store ZipInfo objects. - - Use a platform-specific path separator (os.sep) for the path keys - for compatibility with pypy on Windows. - """ - with zipfile.ZipFile(path) as zfile: - items = ( - ( - name.replace('/', os.sep), - zfile.getinfo(name), - ) - for name in zfile.namelist() - ) - return dict(items) - - load = build - - -class MemoizedZipManifests(ZipManifests): - """ - Memoized zipfile manifests. - """ - manifest_mod = collections.namedtuple('manifest_mod', 'manifest mtime') - - def load(self, path): - """ - Load a manifest at path or return a suitable manifest already loaded. - """ - path = os.path.normpath(path) - mtime = os.stat(path).st_mtime - - if path not in self or self[path].mtime != mtime: - manifest = self.build(path) - self[path] = self.manifest_mod(manifest, mtime) - - return self[path].manifest - - -class ZipProvider(EggProvider): - """Resource support for zips and eggs""" - - eagers = None - _zip_manifests = MemoizedZipManifests() - - def __init__(self, module): - EggProvider.__init__(self, module) - self.zip_pre = self.loader.archive + os.sep - - def _zipinfo_name(self, fspath): - # Convert a virtual filename (full path to file) into a zipfile subpath - # usable with the zipimport directory cache for our target archive - fspath = fspath.rstrip(os.sep) - 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) - ) - - 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) - ) - - @property - def zipinfo(self): - return self._zip_manifests.load(self.loader.archive) - - def get_resource_filename(self, manager, resource_name): - if not self.egg_name: - raise NotImplementedError( - "resource_filename() only supported for .egg, not .zip" - ) - # no need to lock for extraction, since we use temp names - zip_path = self._resource_to_zip(resource_name) - eagers = self._get_eager_resources() - if '/'.join(self._parts(zip_path)) in eagers: - for name in eagers: - self._extract_resource(manager, self._eager_to_zip(name)) - return self._extract_resource(manager, zip_path) - - @staticmethod - def _get_date_and_size(zip_stat): - size = zip_stat.file_size - # ymdhms+wday, yday, dst - date_time = zip_stat.date_time + (0, 0, -1) - # 1980 offset already done - timestamp = time.mktime(date_time) - return timestamp, size - - def _extract_resource(self, manager, zip_path): - - if zip_path in self._index(): - for name in self._index()[zip_path]: - 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) - ) - - if self._is_current(real_path, zip_path): - return real_path - - outf, tmpnam = _mkstemp( - ".$extract", - dir=os.path.dirname(real_path), - ) - os.write(outf, self.loader.get_data(zip_path)) - os.close(outf) - utime(tmpnam, (timestamp, timestamp)) - manager.postprocess(tmpnam, real_path) - - try: - rename(tmpnam, real_path) - - except os.error: - if os.path.isfile(real_path): - if self._is_current(real_path, zip_path): - # the file became current since it was checked above, - # so proceed. - return real_path - # Windows, del old file and retry - elif os.name == 'nt': - unlink(real_path) - rename(tmpnam, real_path) - return real_path - raise - - except os.error: - # report a user-friendly error - manager.extraction_error() - - return real_path - - def _is_current(self, file_path, zip_path): - """ - Return True if the file_path is current for this zip_path - """ - timestamp, size = self._get_date_and_size(self.zipinfo[zip_path]) - if not os.path.isfile(file_path): - return False - stat = os.stat(file_path) - if stat.st_size != size or stat.st_mtime != timestamp: - return False - # check that the contents match - zip_contents = self.loader.get_data(zip_path) - with open(file_path, 'rb') as f: - file_contents = f.read() - return zip_contents == file_contents - - def _get_eager_resources(self): - if self.eagers is None: - eagers = [] - for name in ('native_libs.txt', 'eager_resources.txt'): - if self.has_metadata(name): - eagers.extend(self.get_metadata_lines(name)) - self.eagers = eagers - return self.eagers - - def _index(self): - try: - return self._dirindex - except AttributeError: - ind = {} - for path in self.zipinfo: - parts = path.split(os.sep) - while parts: - parent = os.sep.join(parts[:-1]) - if parent in ind: - ind[parent].append(parts[-1]) - break - else: - ind[parent] = [parts.pop()] - self._dirindex = ind - return ind - - def _has(self, fspath): - zip_path = self._zipinfo_name(fspath) - return zip_path in self.zipinfo or zip_path in self._index() - - def _isdir(self, fspath): - return self._zipinfo_name(fspath) in self._index() - - def _listdir(self, fspath): - return list(self._index().get(self._zipinfo_name(fspath), ())) - - def _eager_to_zip(self, resource_name): - return self._zipinfo_name(self._fn(self.egg_root, resource_name)) - - def _resource_to_zip(self, resource_name): - return self._zipinfo_name(self._fn(self.module_path, resource_name)) - - -register_loader_type(zipimport.zipimporter, ZipProvider) - - -class FileMetadata(EmptyProvider): - """Metadata handler for standalone PKG-INFO files - - Usage:: - - metadata = FileMetadata("/path/to/PKG-INFO") - - This provider rejects all data and metadata requests except for PKG-INFO, - which is treated as existing, and will be the contents of the file at - the provided location. - """ - - def __init__(self, path): - self.path = path - - def _get_metadata_path(self, name): - return self.path - - def has_metadata(self, name): - return name == 'PKG-INFO' and os.path.isfile(self.path) - - def get_metadata(self, name): - if name != 'PKG-INFO': - raise KeyError("No metadata except PKG-INFO is available") - - with io.open(self.path, encoding='utf-8', errors="replace") as f: - metadata = f.read() - self._warn_on_replacement(metadata) - return metadata - - def _warn_on_replacement(self, metadata): - # Python 2.7 compat for: replacement_char = '�' - replacement_char = b'\xef\xbf\xbd'.decode('utf-8') - if replacement_char in metadata: - tmpl = "{self.path} could not be properly decoded in UTF-8" - msg = tmpl.format(**locals()) - warnings.warn(msg) - - def get_metadata_lines(self, name): - return yield_lines(self.get_metadata(name)) - - -class PathMetadata(DefaultProvider): - """Metadata provider for egg directories - - Usage:: - - # Development eggs: - - egg_info = "/path/to/PackageName.egg-info" - base_dir = os.path.dirname(egg_info) - metadata = PathMetadata(base_dir, egg_info) - dist_name = os.path.splitext(os.path.basename(egg_info))[0] - dist = Distribution(basedir, project_name=dist_name, metadata=metadata) - - # Unpacked egg directories: - - egg_path = "/path/to/PackageName-ver-pyver-etc.egg" - metadata = PathMetadata(egg_path, os.path.join(egg_path,'EGG-INFO')) - dist = Distribution.from_filename(egg_path, metadata=metadata) - """ - - def __init__(self, path, egg_info): - self.module_path = path - self.egg_info = egg_info - - -class EggMetadata(ZipProvider): - """Metadata provider for .egg files""" - - def __init__(self, importer): - """Create a metadata provider from a zipimporter""" - - self.zip_pre = importer.archive + os.sep - self.loader = importer - if importer.prefix: - self.module_path = os.path.join(importer.archive, importer.prefix) - else: - self.module_path = importer.archive - self._setup_prefix() - - -_declare_state('dict', _distribution_finders={}) - - -def register_finder(importer_type, distribution_finder): - """Register `distribution_finder` to find distributions in sys.path items - - `importer_type` is the type or class of a PEP 302 "Importer" (sys.path item - handler), and `distribution_finder` is a callable that, passed a path - item and the importer instance, yields ``Distribution`` instances found on - that path item. See ``pkg_resources.find_on_path`` for an example.""" - _distribution_finders[importer_type] = distribution_finder - - -def find_distributions(path_item, only=False): - """Yield distributions accessible via `path_item`""" - importer = get_importer(path_item) - finder = _find_adapter(_distribution_finders, importer) - return finder(importer, path_item, only) - - -def find_eggs_in_zip(importer, path_item, only=False): - """ - Find eggs in zip files; possibly multiple nested eggs. - """ - if importer.archive.endswith('.whl'): - # wheels are not supported with this finder - # they don't have PKG-INFO metadata, and won't ever contain eggs - return - metadata = EggMetadata(importer) - if metadata.has_metadata('PKG-INFO'): - yield Distribution.from_filename(path_item, metadata=metadata) - if only: - # don't yield nested distros - return - for subitem in metadata.resource_listdir(''): - if _is_egg_path(subitem): - subpath = os.path.join(path_item, subitem) - dists = find_eggs_in_zip(zipimport.zipimporter(subpath), subpath) - for dist in dists: - yield dist - elif subitem.lower().endswith('.dist-info'): - subpath = os.path.join(path_item, subitem) - submeta = EggMetadata(zipimport.zipimporter(subpath)) - submeta.egg_info = subpath - yield Distribution.from_location(path_item, subitem, submeta) - - -register_finder(zipimport.zipimporter, find_eggs_in_zip) - - -def find_nothing(importer, path_item, only=False): - return () - - -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') - ) - ) - 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) - ) - - # scan for .egg and .egg-info in directory - path_item_entries = _by_version_descending(filtered) - for entry in path_item_entries: - fullpath = os.path.join(path_item, entry) - factory = dist_factory(path_item, entry, only) - for dist in factory(fullpath): - yield dist - - -def dist_factory(path_item, entry, only): - """ - Return a dist_factory for a path_item and entry - """ - lower = entry.lower() - is_meta = any(map(lower.endswith, ('.egg-info', '.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() - ) - - -class NoDists: - """ - >>> bool(NoDists()) - False - - >>> list(NoDists()('anything')) - [] - """ - def __bool__(self): - return False - if six.PY2: - __nonzero__ = __bool__ - - def __call__(self, fullpath): - return iter(()) - - -def safe_listdir(path): - """ - Attempt to list contents of path, but suppress some exceptions. - """ - try: - return os.listdir(path) - except (PermissionError, NotADirectoryError): - pass - 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: - raise - return () - - -def distributions_from_metadata(path): - root = os.path.dirname(path) - if os.path.isdir(path): - if len(os.listdir(path)) == 0: - # empty metadata dir; skip - return - metadata = PathMetadata(root, path) - else: - metadata = FileMetadata(path) - entry = os.path.basename(path) - yield Distribution.from_location( - root, entry, metadata, precedence=DEVELOP_DIST, - ) - - -def non_empty_lines(path): - """ - Yield non-empty lines from file at path - """ - with open(path) as f: - for line in f: - line = line.strip() - if line: - yield line - - -def resolve_egg_link(path): - """ - Given a path to an .egg-link, resolve distributions - present in the referenced path. - """ - referenced_paths = non_empty_lines(path) - resolved_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(importlib_machinery, 'FileFinder'): - register_finder(importlib_machinery.FileFinder, find_on_path) - -_declare_state('dict', _namespace_handlers={}) -_declare_state('dict', _namespace_packages={}) - - -def register_namespace_handler(importer_type, namespace_handler): - """Register `namespace_handler` to declare namespace packages - - `importer_type` is the type or class of a PEP 302 "Importer" (sys.path item - handler), and `namespace_handler` is a callable like this:: - - def namespace_handler(importer, path_entry, moduleName, module): - # return a path_entry to use for child packages - - Namespace handlers are only called if the importer object has already - agreed that it can handle the relevant path item, and they should only - return a subpath if the module __path__ does not already contain an - equivalent subpath. For an example namespace handler, see - ``pkg_resources.file_ns_handler``. - """ - _namespace_handlers[importer_type] = namespace_handler - - -def _handle_ns(packageName, path_item): - """Ensure that named package includes a subpath of path_item (if needed)""" - - importer = get_importer(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) - - if loader is None: - return None - module = sys.modules.get(packageName) - if module is None: - module = sys.modules[packageName] = types.ModuleType(packageName) - module.__path__ = [] - _set_parent_ns(packageName) - elif not hasattr(module, '__path__'): - raise TypeError("Not a package:", packageName) - handler = _find_adapter(_namespace_handlers, importer) - subpath = handler(importer, path_item, packageName, module) - if subpath is not None: - path = module.__path__ - path.append(subpath) - loader.load_module(packageName) - _rebuild_mod_path(path, packageName, module) - return subpath - - -def _rebuild_mod_path(orig_path, package_name, module): - """ - Rebuild module.__path__ ensuring that all entries are ordered - corresponding to their sys.path order - """ - sys_path = [_normalize_cached(p) for p in sys.path] - - def safe_sys_path_index(entry): - """ - Workaround for #520 and #513. - """ - try: - return sys_path.index(entry) - except ValueError: - return float('inf') - - def position_in_sys_path(path): - """ - Return the ordinal of the path based on its position in sys.path - """ - path_parts = path.split(os.sep) - module_parts = package_name.count('.') + 1 - parts = path_parts[:-module_parts] - return safe_sys_path_index(_normalize_cached(os.sep.join(parts))) - - new_path = sorted(orig_path, key=position_in_sys_path) - new_path = [_normalize_cached(p) for p in new_path] - - if isinstance(module.__path__, list): - module.__path__[:] = new_path - else: - module.__path__ = new_path - - -def declare_namespace(packageName): - """Declare that package 'packageName' is a namespace package""" - - _imp.acquire_lock() - try: - if packageName in _namespace_packages: - return - - path = sys.path - parent, _, _ = packageName.rpartition('.') - - if parent: - declare_namespace(parent) - if parent not in _namespace_packages: - __import__(parent) - try: - path = sys.modules[parent].__path__ - except AttributeError: - raise TypeError("Not a package:", parent) - - # Track what packages are namespaces, so when new path items are added, - # they can be updated - _namespace_packages.setdefault(parent or None, []).append(packageName) - _namespace_packages.setdefault(packageName, []) - - for path_item in path: - # Ensure all the parent's path items are reflected in the child, - # if they apply - _handle_ns(packageName, path_item) - - finally: - _imp.release_lock() - - -def fixup_namespace_packages(path_item, parent=None): - """Ensure that previously-declared namespace packages include path_item""" - _imp.acquire_lock() - try: - for package in _namespace_packages.get(parent, ()): - subpath = _handle_ns(package, path_item) - if subpath: - fixup_namespace_packages(subpath, package) - finally: - _imp.release_lock() - - -def file_ns_handler(importer, path_item, packageName, module): - """Compute an ns-package subpath for a filesystem or zipfile importer""" - - subpath = os.path.join(path_item, packageName.split('.')[-1]) - normalized = _normalize_cached(subpath) - for item in module.__path__: - if _normalize_cached(item) == normalized: - break - else: - # Only return the path if it's not already there - return subpath - - -register_namespace_handler(pkgutil.ImpImporter, file_ns_handler) -register_namespace_handler(zipimport.zipimporter, file_ns_handler) - -if hasattr(importlib_machinery, 'FileFinder'): - register_namespace_handler(importlib_machinery.FileFinder, file_ns_handler) - - -def null_ns_handler(importer, path_item, packageName, module): - return None - - -register_namespace_handler(object, null_ns_handler) - - -def normalize_path(filename): - """Normalize a file/dir name for comparison purposes""" - return os.path.normcase(os.path.realpath(os.path.normpath(_cygwin_patch(filename)))) - - -def _cygwin_patch(filename): # pragma: nocover - """ - Contrary to POSIX 2008, on Cygwin, getcwd (3) contains - symlink components. Using - os.path.abspath() works around this limitation. A fix in os.getcwd() - would probably better, in Cygwin even more so, except - that this seems to be by design... - """ - return os.path.abspath(filename) if sys.platform == 'cygwin' else filename - - -def _normalize_cached(filename, _cache={}): - try: - return _cache[filename] - except KeyError: - _cache[filename] = result = normalize_path(filename) - return result - - -def _is_egg_path(path): - """ - Determine if given path appears to be an egg. - """ - return path.lower().endswith('.egg') - - -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')) - ) - - -def _set_parent_ns(packageName): - parts = packageName.split('.') - name = parts.pop() - if parts: - parent = '.'.join(parts) - 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""" - (?P[^-]+) ( - -(?P[^-]+) ( - -py(?P[^-]+) ( - -(?P.+) - )? - )? - )? - """, - re.VERBOSE | re.IGNORECASE, -).match - - -class EntryPoint: - """Object representing an advertised importable object""" - - def __init__(self, name, module_name, attrs=(), extras=(), dist=None): - if not MODULE(module_name): - raise ValueError("Invalid module name", module_name) - self.name = name - self.module_name = module_name - self.attrs = tuple(attrs) - self.extras = tuple(extras) - self.dist = dist - - def __str__(self): - s = "%s = %s" % (self.name, self.module_name) - if self.attrs: - s += ':' + '.'.join(self.attrs) - if self.extras: - s += ' [%s]' % ','.join(self.extras) - return s - - def __repr__(self): - return "EntryPoint.parse(%r)" % str(self) - - def load(self, require=True, *args, **kwargs): - """ - Require packages for this EntryPoint, then resolve it. - """ - if not require or args or kwargs: - warnings.warn( - "Parameters to load are deprecated. Call .resolve and " - ".require separately.", - PkgResourcesDeprecationWarning, - stacklevel=2, - ) - if require: - self.require(*args, **kwargs) - return self.resolve() - - def resolve(self): - """ - Resolve the entry point from its module and attrs. - """ - module = __import__(self.module_name, fromlist=['__name__'], level=0) - try: - return functools.reduce(getattr, self.attrs, module) - except AttributeError as exc: - raise ImportError(str(exc)) - - def require(self, env=None, installer=None): - if self.extras and not self.dist: - raise UnknownExtra("Can't require() without a distribution", self) - - # Get the requirements for this entry point with all its extras and - # then resolve them. We have to pass `extras` along when resolving so - # that the working set knows what extras we want. Otherwise, for - # dist-info distributions, the working set will assume that the - # requirements for that extra are purely optional and skip over them. - reqs = self.dist.requires(self.extras) - items = working_set.resolve(reqs, env, installer, extras=self.extras) - list(map(working_set.add, items)) - - pattern = re.compile( - r'\s*' - r'(?P.+?)\s*' - r'=\s*' - r'(?P[\w.]+)\s*' - r'(:\s*(?P[\w.]+))?\s*' - r'(?P\[.*\])?\s*$' - ) - - @classmethod - def parse(cls, src, dist=None): - """Parse a single entry point from string `src` - - Entry point syntax follows the form:: - - name = some.module:some.attr [extra1, extra2] - - The entry name and module name are required, but the ``:attrs`` and - ``[extras]`` parts are optional - """ - m = cls.pattern.match(src) - if not m: - msg = "EntryPoint must be in 'name=module:attrs [extras]' format" - raise ValueError(msg, src) - res = m.groupdict() - extras = cls._parse_extras(res['extras']) - attrs = res['attr'].split('.') if res['attr'] else () - return cls(res['name'], res['module'], attrs, extras, dist) - - @classmethod - def _parse_extras(cls, extras_spec): - if not extras_spec: - return () - req = Requirement.parse('x' + extras_spec) - if req.specs: - raise ValueError() - return req.extras - - @classmethod - def parse_group(cls, group, lines, dist=None): - """Parse an entry point group""" - if not MODULE(group): - raise ValueError("Invalid group name", group) - this = {} - for line in yield_lines(lines): - ep = cls.parse(line, dist) - if ep.name in this: - raise ValueError("Duplicate entry point", group, ep.name) - this[ep.name] = ep - return this - - @classmethod - def parse_map(cls, data, dist=None): - """Parse a map of entry point groups""" - if isinstance(data, dict): - data = data.items() - else: - data = split_sections(data) - maps = {} - for group, lines in data: - if group is None: - if not lines: - continue - raise ValueError("Entry points must be listed in groups") - group = group.strip() - if group in maps: - raise ValueError("Duplicate group name", group) - maps[group] = cls.parse_group(group, lines, dist) - 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(':') - return safe_version(value.strip()) or None - - -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.project_name = safe_name(project_name or 'Unknown') - if version is not None: - self._version = safe_version(version) - self.py_version = py_version - self.platform = platform - self.location = location - self.precedence = precedence - self._provider = metadata or empty_provider - - @classmethod - def from_location(cls, location, basename, metadata=None, **kw): - project_name, version, py_version, platform = [None] * 4 - basename, ext = os.path.splitext(basename) - if ext.lower() in _distributionImpl: - cls = _distributionImpl[ext.lower()] - - match = EGG_NAME(basename) - if match: - project_name, version, py_version, platform = match.group( - 'name', 'ver', 'pyver', 'plat' - ) - return cls( - location, metadata, project_name=project_name, version=version, - py_version=py_version, platform=platform, **kw - )._reload_version() - - def _reload_version(self): - return self - - @property - def hashcmp(self): - return ( - self.parsed_version, - self.precedence, - self.key, - _remove_md5_fragment(self.location), - self.py_version or '', - self.platform or '', - ) - - def __hash__(self): - return hash(self.hashcmp) - - def __lt__(self, other): - return self.hashcmp < other.hashcmp - - def __le__(self, other): - return self.hashcmp <= other.hashcmp - - def __gt__(self, other): - return self.hashcmp > other.hashcmp - - def __ge__(self, other): - return self.hashcmp >= other.hashcmp - - def __eq__(self, other): - if not isinstance(other, self.__class__): - # It's not a Distribution, so they are not equal - return False - return self.hashcmp == other.hashcmp - - def __ne__(self, other): - return not self == other - - # These properties have to be lazy so that we don't have to load any - # metadata until/unless it's actually needed. (i.e., some distributions - # may not know their name or version without loading PKG-INFO) - - @property - def key(self): - try: - return self._key - except AttributeError: - self._key = key = self.project_name.lower() - return key - - @property - def parsed_version(self): - if not hasattr(self, "_parsed_version"): - self._parsed_version = parse_version(self.version) - - 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 - - # 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 - - 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', ' ') - - warnings.warn(tmpl.format(**vars(self)), PEP440Warning) - - @property - def version(self): - try: - return self._version - except AttributeError: - 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) - - return version - - @property - def _dep_map(self): - """ - A map of extra to its list of (direct) requirements - for this distribution, including the null extra. - """ - try: - return self.__dep_map - except AttributeError: - self.__dep_map = self._filter_extras(self._build_dep_map()) - return self.__dep_map - - @staticmethod - def _filter_extras(dm): - """ - Given a mapping of extras to dependencies, strip off - environment markers and filter out any dependencies - not matching the markers. - """ - for extra in list(filter(None, dm)): - new_extra = extra - reqs = dm.pop(extra) - new_extra, _, marker = extra.partition(':') - fails_marker = marker and ( - invalid_marker(marker) - or not evaluate_marker(marker) - ) - if fails_marker: - reqs = [] - new_extra = safe_extra(new_extra) or None - - dm.setdefault(new_extra, []).extend(reqs) - return dm - - def _build_dep_map(self): - dm = {} - for name in 'requires.txt', 'depends.txt': - for extra, reqs in split_sections(self._get_metadata(name)): - dm.setdefault(extra, []).extend(parse_requirements(reqs)) - return dm - - def requires(self, extras=()): - """List of Requirements needed for this distro if `extras` are used""" - dm = self._dep_map - deps = [] - deps.extend(dm.get(None, ())) - for ext in extras: - try: - deps.extend(dm[safe_extra(ext)]) - except KeyError: - raise UnknownExtra( - "%s has no such extra feature %r" % (self, ext) - ) - return deps - - def _get_metadata_path_for_display(self, name): - """ - Return the path to the given metadata file, if available. - """ - try: - # We need to access _get_metadata_path() on the provider object - # directly rather than through this class's __getattr__() - # since _get_metadata_path() is marked private. - path = self._provider._get_metadata_path(name) - - # Handle exceptions e.g. in case the distribution's metadata - # provider doesn't support _get_metadata_path(). - except Exception: - return '[could not detect]' - - return path - - def _get_metadata(self, name): - if self.has_metadata(name): - for line in self.get_metadata_lines(name): - yield line - - def _get_version(self): - lines = self._get_metadata(self.PKG_INFO) - version = _version_from_file(lines) - - return version - - def activate(self, path=None, replace=False): - """Ensure distribution is importable on `path` (default=sys.path)""" - if path is None: - path = sys.path - self.insert_on(path, replace=replace) - if path is sys.path: - fixup_namespace_packages(self.location) - for pkg in self._get_metadata('namespace_packages.txt'): - if pkg in sys.modules: - declare_namespace(pkg) - - 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 - ) - - if self.platform: - filename += '-' + self.platform - return filename - - def __repr__(self): - if self.location: - return "%s (%s)" % (self, self.location) - else: - return str(self) - - def __str__(self): - try: - version = getattr(self, 'version', None) - except ValueError: - version = None - version = version or "[unknown version]" - return "%s %s" % (self.project_name, version) - - def __getattr__(self, attr): - """Delegate all unrecognized public attributes to .metadata provider""" - if attr.startswith('_'): - raise AttributeError(attr) - return getattr(self._provider, attr) - - def __dir__(self): - return list( - set(super(Distribution, self).__dir__()) - | 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 - ) - - def as_requirement(self): - """Return a ``Requirement`` that matches this distribution exactly""" - if isinstance(self.parsed_version, packaging.version.Version): - spec = "%s==%s" % (self.project_name, self.parsed_version) - else: - spec = "%s===%s" % (self.project_name, self.parsed_version) - - return Requirement.parse(spec) - - def load_entry_point(self, group, name): - """Return the `name` entry point of `group` or raise ImportError""" - ep = self.get_entry_info(group, name) - if ep is None: - raise ImportError("Entry point %r not found" % ((group, name),)) - return ep.load() - - def get_entry_map(self, group=None): - """Return the entry point map for `group`, or the full entry map""" - try: - ep_map = self._ep_map - except AttributeError: - ep_map = self._ep_map = EntryPoint.parse_map( - self._get_metadata('entry_points.txt'), self - ) - if group is not None: - return ep_map.get(group, {}) - return ep_map - - def get_entry_info(self, group, name): - """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): - """Ensure self.location is on path - - If replace=False (default): - - If location is already in path anywhere, do nothing. - - Else: - - If it's an egg and its parent directory is on path, - insert just ahead of the parent. - - Else: add to the end of path. - If replace=True: - - If location is already on path anywhere (not eggs) - or higher priority than its parent (eggs) - do nothing. - - Else: - - If it's an egg and its parent directory is on path, - insert just ahead of the parent, - removing any lower-priority entries. - - Else: add it to the front of path. - """ - - loc = loc or self.location - if not loc: - return - - nloc = _normalize_cached(loc) - bdir = os.path.dirname(nloc) - npath = [(p and _normalize_cached(p) or p) for p in path] - - for p, item in enumerate(npath): - if item == nloc: - if replace: - break - else: - # don't modify path (even removing duplicates) if - # found and not replace - return - elif item == bdir and self.precedence == EGG_DIST: - # if it's an .egg, give it precedence over its directory - # UNLESS it's already been added to sys.path and replace=False - if (not replace) and nloc in npath[p:]: - return - if path is sys.path: - self.check_version_conflict() - path.insert(p, loc) - npath.insert(p, nloc) - break - else: - if path is sys.path: - self.check_version_conflict() - if replace: - path.insert(0, loc) - else: - path.append(loc) - return - - # p is the spot where we found or inserted loc; now remove duplicates - while True: - try: - np = npath.index(nloc, p + 1) - except ValueError: - break - else: - del npath[np], path[np] - # ha! - p = np - - return - - def check_version_conflict(self): - if self.key == 'setuptools': - # ignore the inevitable setuptools self-conflicts :( - return - - 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): - 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)): - continue - issue_warning( - "Module %s was already imported from %s, but %s is being added" - " to sys.path" % (modname, fn, self.location), - ) - - def has_version(self): - try: - self.version - except ValueError: - issue_warning("Unbuilt egg for " + repr(self)) - return False - return True - - def clone(self, **kw): - """Copy this distribution, substituting in any changed keyword args""" - names = 'project_name version py_version platform location precedence' - for attr in names.split(): - kw.setdefault(attr, getattr(self, attr, None)) - kw.setdefault('metadata', self._provider) - return self.__class__(**kw) - - @property - def extras(self): - return [dep for dep in self._dep_map if dep] - - -class EggInfoDistribution(Distribution): - def _reload_version(self): - """ - Packages installed by distutils (e.g. numpy or scipy), - which uses an old safe_version, and so - their version numbers can get mangled when - converted to filenames (e.g., 1.11.0.dev0+2329eae to - 1.11.0.dev0_2329eae). These distributions will not be - parsed properly - downstream by Distribution and safe_version, so - take an extra step and try to get the version number from - the metadata file itself instead of the filename. - """ - md_version = self._get_version() - if md_version: - self._version = md_version - return self - - -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*([,\)])") - - @property - def _parsed_pkg_info(self): - """Parse and cache metadata""" - try: - return self._pkg_info - except AttributeError: - metadata = self.get_metadata(self.PKG_INFO) - self._pkg_info = email.parser.Parser().parsestr(metadata) - return self._pkg_info - - @property - def _dep_map(self): - try: - return self.__dep_map - except AttributeError: - self.__dep_map = self._compute_dependencies() - return self.__dep_map - - def _compute_dependencies(self): - """Recompute this distribution's dependencies.""" - dm = self.__dep_map = {None: []} - - reqs = [] - # Including any condition expressions - for req in self._parsed_pkg_info.get_all('Requires-Dist') or []: - reqs.extend(parse_requirements(req)) - - def reqs_for_extra(extra): - for req in reqs: - if not req.marker or req.marker.evaluate({'extra': extra}): - yield req - - common = frozenset(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) - - return dm - - -_distributionImpl = { - '.egg': Distribution, - '.egg-info': EggInfoDistribution, - '.dist-info': DistInfoDistribution, -} - - -def issue_warning(*args, **kw): - level = 1 - g = globals() - try: - # find the first stack frame that is *not* code in - # the pkg_resources module, to use for the warning - while sys._getframe(level).f_globals is g: - level += 1 - except ValueError: - pass - 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` - - `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)) - - 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 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)) - 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.extras = tuple(map(safe_extra, self.extras)) - self.hashCmp = ( - self.key, - self.url, - self.specifier, - frozenset(self.extras), - str(self.marker) if self.marker else None, - ) - self.__hash = hash(self.hashCmp) - - def __eq__(self, other): - return ( - isinstance(other, Requirement) and - self.hashCmp == other.hashCmp - ) - - def __ne__(self, other): - return not self == other - - def __contains__(self, item): - if isinstance(item, Distribution): - if item.key != self.key: - return False - - item = item.version - - # Allow prereleases always in order to match the previous behavior of - # this method. In the future this should be smarter and follow PEP 440 - # more accurately. - return self.specifier.contains(item, prereleases=True) - - def __hash__(self): - return self.__hash - - def __repr__(self): - return "Requirement.parse(%r)" % str(self) - - @staticmethod - def parse(s): - req, = parse_requirements(s) - return req - - -def _always_object(classes): - """ - Ensure object appears in the mro even - for old-style classes. - """ - if object not in classes: - return classes + (object,) - return classes - - -def _find_adapter(registry, ob): - """Return an adapter factory for `ob` from `registry`""" - types = _always_object(inspect.getmro(getattr(ob, '__class__', type(ob)))) - for t in types: - if t in registry: - return registry[t] - - -def ensure_directory(path): - """Ensure that the parent directory of `path` exists""" - dirname = os.path.dirname(path) - py31compat.makedirs(dirname, exist_ok=True) - - -def _bypass_ensure_directory(path): - """Sandbox-bypassing version of ensure_directory()""" - if not WRITE_SUPPORT: - raise IOError('"os.mkdir" not supported on this platform.') - dirname, filename = split(path) - if dirname and filename and not isdir(dirname): - _bypass_ensure_directory(dirname) - try: - mkdir(dirname, 0o755) - except FileExistsError: - pass - - -def split_sections(s): - """Split a string or iterable thereof into (section, content) pairs - - Each ``section`` is a stripped version of the section header ("[section]") - and each ``content`` is a list of stripped lines excluding blank lines and - comment-only lines. If there are any such lines before the first section - header, they're returned in a first ``section`` of ``None``. - """ - section = None - content = [] - for line in yield_lines(s): - if line.startswith("["): - if line.endswith("]"): - if section or content: - yield section, content - section = line[1:-1].strip() - content = [] - else: - raise ValueError("Invalid section heading", line) - else: - content.append(line) - - # wrap up last segment - yield section, content - - -def _mkstemp(*args, **kw): - old_open = os.open - try: - # temporarily bypass sandboxing - os.open = os_open - return tempfile.mkstemp(*args, **kw) - finally: - # and then put it back - os.open = old_open - - -# Silence the PEP440Warning by default, so that end users don't get hit by it -# randomly just because they use pkg_resources. We want to append the rule -# because we want earlier uses of filterwarnings to take precedence over this -# one. -warnings.filterwarnings("ignore", category=PEP440Warning, append=True) - - -# from jaraco.functools 1.3 -def _call_aside(f, *args, **kwargs): - f(*args, **kwargs) - return f - - -@_call_aside -def _initialize(g=globals()): - "Set up global resource manager (deliberately not state-saved)" - manager = ResourceManager() - g['_manager'] = manager - g.update( - (name, getattr(manager, name)) - for name in dir(manager) - if not name.startswith('_') - ) - - -@_call_aside -def _initialize_master_working_set(): - """ - Prepare the master working set and make the ``require()`` - API available. - - This function has explicit effects on the global state - of pkg_resources. It is intended to be invoked once at - the initialization of this module. - - Invocation by other packages is unsupported and done - at their own risk. - """ - working_set = WorkingSet._build_master() - _declare_state('object', working_set=working_set) - - require = working_set.require - iter_entry_points = working_set.iter_entry_points - add_activation_listener = working_set.subscribe - run_script = working_set.run_script - # backward compatibility - run_main = run_script - # Activate all distributions already on sys.path with replace=False and - # 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 - ) - add_activation_listener( - lambda dist: dist.activate(replace=True), - existing=False, - ) - working_set.entries = [] - # 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/venv/lib/python3.8/site-packages/pkg_resources/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/pkg_resources/__pycache__/__init__.cpython-38.pyc deleted file mode 100644 index ddeb95c2e9e331d282f79bba0be23058dda23d2b..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 100356 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 >V^A-WFxDTY$&6TM8h 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 diff --git a/venv/lib/python3.8/site-packages/pkg_resources/__pycache__/py31compat.cpython-38.pyc b/venv/lib/python3.8/site-packages/pkg_resources/__pycache__/py31compat.cpython-38.pyc deleted file mode 100644 index bbe8caa4f7e6503785ab028c3af6cc4c2a8202b0..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 600 zcmYjO&2AGh5T3EU$tFrdPly-bu!l4xZQ)W?2$ZTws33)(b}u1{UAo!L?smL^q)Is; z9t4iOlCPZd3LFsQAgYe#Z#?#R=9`(f?RFDbo;-dy*%bi4ym40~8&7%L4-6VKW)T0= z7~|F!vCu-xOwLuT5OhNay7mp@z^GZRe5vb3%<2jxq*$EjFoj$RK!`&V(mNC6%D}7< zH#CkQYHm0SoNkaYLMLsqJf1SGTk&)};pe>V3Bz@#g73J7ABgZC@_hxBNSpKw;YJ`_ z-(Mp=T8o*iZK24C6hfD5=0U&I-lL(ZsyQ{!nAI8j&^&L^qS30YTvH5w8Xrab0N8Bw}t~LIje!SNYeU;n!pui69@S+aiMPlO{ zu~Ggk=^iWE@!(q(;c?U?|3q~LZsN+inpswca`NA{A)I`DK5(s1hHO&g<0QW*Tqie1 n+gkz@cxPYJ9ccTI;o-c{i_9GPIa!}ML|&pLo2?o?_#@O`tEz?) diff --git a/venv/lib/python3.8/site-packages/pkg_resources/_vendor/__init__.py b/venv/lib/python3.8/site-packages/pkg_resources/_vendor/__init__.py deleted file mode 100644 index e69de29..0000000 diff --git a/venv/lib/python3.8/site-packages/pkg_resources/_vendor/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/pkg_resources/_vendor/__pycache__/__init__.cpython-38.pyc deleted file mode 100644 index 020243cb5a83bd38f45ced7b747476c3c5fdfa2a..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 157 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 Yp6SB@NBY3UA^cLLCjHWX`lXuw57nVPd;kCd diff --git a/venv/lib/python3.8/site-packages/pkg_resources/_vendor/__pycache__/pyparsing.cpython-38.pyc b/venv/lib/python3.8/site-packages/pkg_resources/_vendor/__pycache__/pyparsing.cpython-38.pyc deleted file mode 100644 index 26a703feff59e4e2b1fefa2b4131c6f87fc0b9d9..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 201634 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 z zd=ocuaRY(#H;0?$rCfk0u1L3T#_PIST6a}yn9>!MgF?)+z#JA?xt0v0dfklQ#!)Yt zc{7?DO?$CMy(}pMvTXC;Lr6B#Nkf(2Ci#w&eAXZdW@WQ+ zm`9Cx1u?r||0X2}9rp!qMvUKbzY=jnB9gOFeF@D35|upIB_kNYN3Oz=q;`mq}LEAk)+A@?HJoHWY|jq~>TvfYsD<}0qzC~XWw zuSH&qzGhAF_wR6Jkt?*!lrB{Zc*r4&Ojq71~B7p|(+QH`OMW?RCyfiez%5=@fC9Y-z^N4_-sXdK?D7}u|HJ2NPF_Nvd zQgPeRYD#J;2_k-+q`S=5$N2g|zJ$p>N=PQ?hXJi&tsL)&H5Av3>FPI$#5PlSYDpev^aer|%(YiZ4=AvZr?;TO~%9Z3MlUzi~mr-xm z9~6cVzc$#4uL2gzqVV$`I&Rq&D zp8@3_B7rEgybN9Niy|5I0mQ=Ym5>llbkJ_+AkhYRu2{Sm`1_Xp*64Rc5C>vXY6UCc zj}i$PuOAK}kqmud_wEkbf-UgJkjYzxJq&(1111G?E8cVnS_Ergh0t|>gfM=BC?Z8V zT9C?(ZXC9dV+%sW#M-$236$z$4hSdFb~$FU0cv0T<(kA<)OzqB&ku6S#?=KLb;uei z#$vjpm#)hfXe<092I0`nAV720l_;*BP{9Bz@>+^7e)d60fc}iNa?=8SosRKX<_ATA zNi5(P7iz-;C z&`@urm6YTunDnXjy#ISP#cg4y+xIPVCXm(h!Li&r+x6<*3m)>11%}=V*-Y38` ze}ZZwt<4SjX`U6k(q68Da#RV%pWkLCQsy*&3PJQMb1d>RWYM3+3+IH~uo!_Qa#0xf zrnhNpH`$mc8j&Q0>i^8W-q~6tPaj3$zbT^tycuH0Z2z5%xcuc``lg}Kbf(^Xp>o^ z#}>_bTMXMZZ-Bnh)3!EoBD!&TM1JGMCRz188UJxDo4#=8LY4~;)wv`RF^A4#t-t!+Mt0kqs6Ns$m)9| z==)eVy#>6!G1zm=&}?TU4}s00DUV(C!+i0u5N>DqQ2^-QJjh#(uYXW0?NCwnR&_+u zQNojR^5AGO@VoGCV77KFkzLaj72@1oK0uu(f|`dxS`Ku0#NuU1le*%$KgRM&CLZVO z1YbM`5K}bH*Jm``>#;EKi}};U?W*L2`Qn0bc@Bq=HFq1Q25yomAY0NZR z&n3*onhqrzX5rLF6;zhxVU3JRz#M zs9drDi^$UAAO#`g-^iqEOF&XlK7O9n-xyx}2Zxn#`9o}b9A5acQ?--(pZX%v2vTwyP z76!wh#QK53C`)D&*?t*IP>cT@&7=<}W1tUg3K;JIiYGxIP)VL_EE`*!z_?3I9es!~ zm;Vo*7)1VdC`%ffGUO=WAh`j{uX3TU#-wcU8S!ySTiJM)`B|4(N|=xT95JNfKN%gg zhSNjYOk!;`%Lj2os4u&7Ez6~{)`+w_lupL7+3Zku4RJ>c;DF)85O@LHjQnxyF9Bvh B+hYI# diff --git a/venv/lib/python3.8/site-packages/pkg_resources/_vendor/appdirs.py b/venv/lib/python3.8/site-packages/pkg_resources/_vendor/appdirs.py deleted file mode 100644 index ae67001..0000000 --- a/venv/lib/python3.8/site-packages/pkg_resources/_vendor/appdirs.py +++ /dev/null @@ -1,608 +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 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_info__ = (1, 4, 3) -__version__ = '.'.join(map(str, __version_info__)) - - -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' -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 ".". - 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 - - for a discussion of issues. - - Typical user data directories are: - Mac OS X: ~/Library/Application Support/ - Unix: ~/.local/share/ # or in $XDG_DATA_HOME, if defined - Win XP (not roaming): C:\Documents and Settings\\Application Data\\ - Win XP (roaming): C:\Documents and Settings\\Local Settings\Application Data\\ - Win 7 (not roaming): C:\Users\\AppData\Local\\ - Win 7 (roaming): C:\Users\\AppData\Roaming\\ - - For Unix, we follow the XDG spec and support $XDG_DATA_HOME. - That means, by default "~/.local/share/". - """ - 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 ".". - 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/', - if XDG_DATA_DIRS is not set - - Typical site data directories are: - Mac OS X: /Library/Application Support/ - Unix: /usr/local/share/ or /usr/share/ - Win XP: C:\Documents and Settings\All Users\Application Data\\ - Vista: (Fail! "C:\ProgramData" is a hidden *system* directory on Vista.) - Win 7: C:\ProgramData\\ # 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.sep.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 ".". - 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 - - for a discussion of issues. - - Typical user config directories are: - Mac OS X: same as user_data_dir - Unix: ~/.config/ # 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/". - """ - 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 - - -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 ".". - 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/', if XDG_CONFIG_DIRS is not set - - Typical site config directories are: - Mac OS X: same as site_data_dir - Unix: /etc/xdg/ or $XDG_CONFIG_DIRS[i]/ 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 - # only first, if multipath is False - path = os.getenv('XDG_CONFIG_DIRS', '/etc/xdg') - 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.sep.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 ".". - 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/ - Unix: ~/.cache/ (XDG default) - Win XP: C:\Documents and Settings\\Local Settings\Application Data\\\Cache - Vista: C:\Users\\AppData\Local\\\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\\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")) - 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 ".". - 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 - - for a discussion of issues. - - Typical user state directories are: - Mac OS X: same as user_data_dir - Unix: ~/.local/state/ # or in $XDG_STATE_HOME, if defined - Win *: same as user_data_dir - - For Unix, we follow this Debian proposal - to extend the XDG spec and support $XDG_STATE_HOME. - - That means, by default "~/.local/state/". - """ - 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 ".". - 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/ - Unix: ~/.cache//log # or under $XDG_CACHE_HOME if defined - Win XP: C:\Documents and Settings\\Local Settings\Application Data\\\Logs - Vista: C:\Users\\AppData\Local\\\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 - # . - 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 - # . - 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 - # . - 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: - import win32com.shell - _get_win_folder = _get_win_folder_with_pywin32 - except ImportError: - 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 - - -#---- 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/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__about__.py b/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__about__.py deleted file mode 100644 index 95d330e..0000000 --- a/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__about__.py +++ /dev/null @@ -1,21 +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 - -__all__ = [ - "__title__", "__summary__", "__uri__", "__version__", "__author__", - "__email__", "__license__", "__copyright__", -] - -__title__ = "packaging" -__summary__ = "Core utilities for Python packages" -__uri__ = "https://github.com/pypa/packaging" - -__version__ = "16.8" - -__author__ = "Donald Stufft and individual contributors" -__email__ = "donald@stufft.io" - -__license__ = "BSD or Apache License, Version 2.0" -__copyright__ = "Copyright 2014-2016 %s" % __author__ diff --git a/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__init__.py b/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__init__.py deleted file mode 100644 index 5ee6220..0000000 --- a/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__init__.py +++ /dev/null @@ -1,14 +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 - -from .__about__ import ( - __author__, __copyright__, __email__, __license__, __summary__, __title__, - __uri__, __version__ -) - -__all__ = [ - "__title__", "__summary__", "__uri__", "__version__", "__author__", - "__email__", "__license__", "__copyright__", -] diff --git a/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/__about__.cpython-38.pyc b/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/__about__.cpython-38.pyc deleted file mode 100644 index b89fa20133a87a97a39c5297c7f27e68abe31721..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 707 zcmYk4OK%e~5XZfbB%4LC)zHc<%(AyjCOfGS0B*o(E<@n)^=u3bNZvfqer z!#P(@d<6~&I{_7s{IkazkNqF}^KjThw!K`Qr{8^qemLj<7Fp-Yc6Dn32)q(iUgA}L z;#WZucnEw5AcPjQp#u?gH&GHoFKIzPX~Q7tz%Ys6BU{)k%M|1F{zOPtYm%Ef)6VY_qM0r!A^Scd%2ZV0; zVkA4RZmD#8t}i}~f$Vu{byr^(QjAvfAcD_7cQMlx^+EnMBw($++_+)~@26BvstVjH;MyX$@RH s)F!s4ueq^xpNZW*dQ)*QC4K8|rp6Xe10Vf0?=b!jTcKyox8~^m0mRVFf&c&j diff --git a/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/__init__.cpython-38.pyc deleted file mode 100644 index 1ea67109d3944fcbcf690457e5db482a839c3f69..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 545 zcmYk4O>WyT5QQnp)~}T!K(0_AUN}OF{%ne(2Pm>>yWwWQh_pxG+O}qRK7M#Dl9aJuBwn5p#TR_$?+D3cVwg>MVpE>ljAsdx zsm#pEuKC*LJhufeY{^So@ygb`wheFWhHucfl53gELYA_UwQPoxw{r81ZQCd8%(mI` zO5DxP#GpXi$@#F9QXloK-MCy#UXKCxaqI)?r-UlXr3Mf&9GnMOT7ce7C$EP?Kv@AO zE40Da2EgcEjk7w7Ia(|H>1+x*82VlSM6b_=qw+Krz&AL@(}Mhl&=PV2t;JV_0&%;& zpe*|sqQ_<)7s-4^SRp8jxN{L>or|gDMTh79&y)TSp*X@|_($e1$xZnEwF`FYCOz%q zIEnsV$=%O`QfBw&-NXBbw|mn~_XBt}yXbp0cW_jrbiO0681y)F0D9Dz<7PT7DoUag9>2;p6e;5A-ynp@zCMAqt diff --git a/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/_compat.cpython-38.pyc b/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/_compat.cpython-38.pyc deleted file mode 100644 index 115cd2f9412ffe0a82286272f654e5b6401e23a1..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 981 zcmah{OKTKC5bnq9?quC;1cTz^upSilkR6P#O9+C32O$We;2<=e>E2|_ywcs1upyoj zNPdPM^OySSDSyF}RlOl@P8L*6RZaI-Usd(z<>fvBdHw2%{Kg6SjlrTY2;P9&FJKf= zv>+u-X~|Mn@|07|u_8(%9ewX8a-S%^$I|X~6hYL}J@Zb-Q<^SSUERm8>ZtB1NpC6k ziHv)ffKA5SugGm%7p>DGFPqvpAFKQzw|QOpVPo>jiD_G94&tp#Bz6gmNk;MZm0+R^ z+5@#u!MrDDVo;s+>a36;AH-M zNL<+@P2Q}vRU@-Kt=0~AwJz44z1V-bzdkLJW^YFrZR^%#+9u*aSE@D%o|QX!wUdaf zE*t44&CK_NsPv%_kB}d(h0vq%e_Nbf-P!{3G5Ek-2;Uc?tW{f}KM-QSmBsvzxed61 zyulI7y%q5M()H9HLKq0d)U4vK6{qnXNi!2+bK%yQ`N+*09T3Od3=wV_4c=KO5zvP> z8^I$sET?yun|lzA2S|F_y4C<`gZ&$P3I0*FZs%ezrcx^OQLezWuVoG*)uB?9fm^GEi#JR#rlVY21mVGnxv z4hBY;=8>M((t3JJ?-?yaBOeIUnQ=~-!E-~SmFM{(Y31Q_R&Tx1nig}KC**$T`HY!$3r zi>;4-+x1;};%ESpG+bkU3q3^VFb%ZzrU2)W5gBQ5F63TYnDD5EpPw4C7c>Gls7HQa zJ4c+=zjitI>QA2yb_UyRuMr$|sNi8g5)Ka=^qBjsFB+(8cU-^IprI6zBO}n+3Ql5+ zf_5M%EuszR3Zk7ZC)REy(kZhIP*i4@VIhgs&d5+3g83t@Inv`?*ABaJ4v!WE(D;1? zfj|h08kFMpG}y7!Q3inuHe646Yos^dtHVdSus|Ws_hpxh>v$%mo}{z_8VOou;*uzv zk0q+GeSGrrwAW`5rdM31bP(CzSR#;c1*WxF#bFHxjEUI50bM8V;eZ#M zD2mIhRaAo&8e-mBx@BDbDY*lpD-BC=5Bh(kOtA^)&vyLr{iTB1gOd%ZQry5$U z7)3kXxE`v%pgL8f0vRkV&MGQT=0M(*=4NNHihW}O>UPTQZpd*n%SGka_BGpd^=^j|n?<=FrL diff --git a/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/markers.cpython-38.pyc b/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/markers.cpython-38.pyc deleted file mode 100644 index c0839d1a6d8763def637530b9fa04a339932e1c9..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 8919 zcmbVR&2t+^cAxGU3qNmlv2o&gAu z((c+o_3Q7~{kq>*zxilzFmK>@;nkzwYp!AZGgW$jIaDqog_lgj5QboNqru9o!OOg1 zmQ6-&yl#~(ooC7!o!ezw=h<==xmkA_xpJ(8UUM~tFADi31(A=JmjIO^l_5b7_WzE|u+eV?wo zs85JV)F*ZQupAZpHyGf74R+Z;{#=?rpXLYC{7{;|kmhchA5QbBG=DM8kEHq0G(VQ+ z$J6{onitdjB<1BP@uHX#hr|ow0RAt1ZI@q^Q=3P`DRKHM;}K)D!;;?bbUN=$nx9Sc zb7}r^n!l3f=P55Al}CZ$)wJz`ZaXHAVTISaD~yQOvBHRWL-!t+$I<&{w|7*`==Cq^ z-V<_49tYl{9Fj$OY{HPm31fqmPs)>+HQO`mtqr#M(j%jM3hQ4=%cte=hEXoblbC%< zmN5G?%?7?{S(4LoP@bUH4K`uS8lZhZk10$Ti=^pA}2u9WnnEE1whZ(rV&8 zg3?-j8R-?I^GL5ET|jzGy#KXReqCG<-^1KDz%fSoP4R)airS30CKixi6xYQf@>%hr z7)1USIOc{Z0CPce*d@W2jN;92NVbY*JnY>LgL*5Hm0F`2s3>+s?S3t+1%5o#R5d@U zEVuk>g!)3!iiZ|G70USsRoSGbxS;DdWZ0@lVLT8dwoQ$ed4XWtFfXPy#q;loxCNwK8o7FnFVT8pIe>fbQhA&UzMqDu6zDZ?UeY_|-iE!RAC7X!vV@`YTk`BJ?eoUc?G zfoRpKT&Ps;wY+-TldV)lP_0xR8|rziuEEv^(@~>2-K;fFxBRA8y(`7(&+bTBKYjL< zd*|<+Tdq$x@2*so41<=c%5b`JU-}|Y(=^sw!F^6Adk#y@hnlGUL^KC**tb5EF*=mR zore-MapA;J`dqvyl8q)-xqM3J$q9g()oLmdFSjc}8S~gWMK5$bUYz76KuwgrW1JGNreX zLNdl});21zt4qdXwg5@Y=&OJTTA{2jD;Gm{95-=k&96n3N{NtY>}+k2mMV36sw6m_ zAC>#ojEuIi$~M@Nq3GJMmI53BX!EL51i9H@o|y;iAI>s}aEDr%B;^CE#G z1iB)pIggG)$tE`T3OYL*>l{VWvukH`9C~LC3X$<8bV}zSSUk26L{}Qkx+Hxi#k^91 zdg{tKXp|cC;+nkBv-FTYlWx~SF`E!T;;ar3m?A*@rcMwzNno2OUD7gj2pz<6A??!P zj!Az-tyQGHAKmRGq>zq!H;3Y=q1kRhF?+Y`a@TQmIU_j^x}Nknzzfehc)jn7v?fhA z*xG0Ze`%Ze$JS2bpGoaYK=Nh>ox>H?zZ0FATcpW$5orS7+k~G)F5$*UAd`47GX)-; zDl&BpT~E7eO{<=q(mJfy=pj^{rm0W6MUv1tBz;Vvi|XHrE`Ghai>PPcoFdM7CM{Pw z8^XO6t~Y-xLZ&h2z0N!kLiKnb+?hmDv|)i!Q`)IH)U10EiE^d+FuD`?Dc8~z23z%(#51?U3#I6w_7@^ZMQVM>K*tY@o;xm_%MW>gO`=;qcf#|_DW|^ zoDD*~g)J0HWPY}&ztrj9>Ml@9=l8UvOKx>Zh5>&X$$OvPoRJSAtK&f&lfQd)VE$B&O|LR_%oOIQD=!Qc4CVacL{R$cw7u5;~cRKt|kQ| zC!=k=qg8SnR*EcD(Ol?5Kw7{;T0+tmUkir9p{pY1KF{|x3{5U^ThksRtS3mnlgq@bL;YzHXcp940Og*T2^>7x2&NQIT z^*XBEF^9N3w3XV?9+y_m62I8fUOP8{)d{W}gd1r`7c?{tA`k#3J|>%jO0T z$0O@YB0f3A_oED%G{Nq2^**%% z*$jj!((;5MvJ*IWe@f3Je4ErK912b(vuQ^6=JE?_2>aDix$6#zq>vK13An-0;voj>C;}Gb_@U51MLrlUAX- zwCFAm_ao@J#m@LG=BiIHTzwy4*S-nSF5YXiP2-W#$9svZbDQw&knvB^_LoT8{5AE= zJ#BNAqkb22VvAbT$Aos6>O*rOJP>;4Xx}Y1>(W=A9=RISe7wf(;B94yH!mgnPO&T+2s_VFeOBPFfu$f0UO2=CgdL#3B_3~#%B zCyY&XXO{qww)-0-t?hmb#MxfNs!lU^oGoGe+YZK}qi#_7LjsEgt`Ycvzyg7*1g-=0 zsX*dPqD2!$i>w`p$cbXOW&Q}-d4S(D+BJ*xul^8gd8Q(Yj!Y4-C+_c(= zOhLpln|3nm5nH#~h$G&0)a@uM_@+ZIA&8i{!M-XecR%-lR=5fjp!o-Mh6MnF6*y7o5QPs>@1rn>hAfh% z@E=iFF;*C8g9-ce@77JINt0A>s;H+@MU6J7&dZ5cu$h5M2K^i0Dd@bsol!in3^nBH|irHMhanvu%4dx9<3(RA0~P9<-px>0-{ev+YdV*)S8_ZG@5T z+TmZ*K2SDcBJyp%nOV_MRIEK9@Un+0=VXG(L=^3XZ=T>+%7CNd64vH=*?qDzV1&03q3I4MU0d&x&ML$$c13BRddyXDn=VhnRVtn zg0JJF3=s>D$X?Av*-ht>0hrS;uc4*kfQE%m8Lo%*d)ixC&5F#|1DgHgq5j8P%+9C) z+xUj=qBx-F7StI6ZxDEuz$*kU5I9fZWddgjyhh-4fZ|}Bz2k+5N-D&n9)_B3^@r5` z`ve{UKs$%A(|MH1q(0S2qD^_cC$G{}wPnLC@jo>=C zG5W;fYs1%cX#cy$Ikm&4{*3ldo? znuH+(Uyz|olwRsiaqkFLm`~gW>3Zqam-0Grj_)Y$4H>nRPqB3Ob`U_ce0Ny|jjpTV zujsxNNS5FE)Z(p>hZS`L@Pwzw#VGYw+*$~)%?zSizA>yhnrD)kj9k6kmD!`YSF!^3U z`^UF9tt4W*)fBL_+WctdK}6*+&O5P!V=12A?^rt+D|S*hO}ccuBuGY%6nuW0qdOyt z_zLiwg2sPAi*NI;F6n3qX%&1`?*@$>3K|#L&Egz=&{}TcV(~#s5qm3Q9Yq`*I~})J z{V}!ugaEzw<3oKPtxAYhN#!HJMM95nR!WPxO~c9QQ$&{{7f_KRQv(FZRH;FLm|cyt z2pixFVU)bo^5kRdZ;WB$xNCPEUm9@t^abt~c@OhC06$7t#t4uT8{5I{RauR6G(2%v zNCzh|N$1wwjVp7Pug)uyi+CuM(IUk<=JfZ~c;MFjjioEs7bR$&8bMB%x=(<7?1b~k70?W+jmOjOAECSC zqvb5!Yxpk!b=Xe1wm+Yy@$TWkpub8fzns+MI7*om9p9mB7{*il0-qWo&NQEd`RDm0O2c@DkMll0gE&7kLf8n% zUgkMIwsnOkw*CO^>O9%eoLQiaenz{-XZf`vajwH2t}CtAJ6c(uonWJX)7cnky8-&o z@*AN49JCvtjXF2^&D}q;lkC)cvPUW5DSi|7`4w<(@ms+8x`#8o12fn+z#Hbnz_Sl| z-#WMXZ9WXAxWjM3DtFY0?(*qF{5w7Y_+@pv@A%z$0F$>(4v7T`tjE1t&+l-4;YOFUG{s=qDIh)x$B3`hKQxb{8xVDH|jFi6n;H+H(K>t4C6|{keMh3 z+U9EPfn=&PDAk$lZwPCq24)YQ62y%4rRpA7YcH}l8m&5;uv-xqksUp6v;qb)8(i3N!(J(^ z*t0V?rj!!2s^z+MFXXN()2$)#nUU0xkx-M(fT=zF3PQpeN*k75B!{&6; zZ%(%AO|SNXv&q-bIS(c;Uwt|I^2$aq-F&g>3LZ6DqQ;|X_Z6?RhL}cK5B#+`-Lvs% zs`*w7gYH4J2BaloQ8nJDKkU<|`}D#-E$q{YeR^x3&b9SPcS;(#yLRG-zuHePNxdZk zX+i)9FS-w|N^dp%`l<>TX?bkRtAXug$`#&gHv&i1bXcSNA&#zCfEHoy+}5^8(_$2Y zRjWu+prQcO-*ibMNdrmaBRhywz>(JNzzd%-@9s4i{TCV$(@0O@S}G{MSP&1X7PJ7_ z2Ct72wVc3M=;*(6h$*wnO!O8F2VG1aC!AzEf z-eeZ+C?zw!asE$ri*2trzNgYEZo8aKA7ZMPZ+Ef+Tnz|yKaOm;zHu~RN3Gg(8?FXM z42-%ynNZr+tK|vXt24V3JyUko^CKSFU*0{tQHT9J^H}h9a-$(aju-3jW-4W!4Ro$o z4eikVu;^lFDX;t+kajL6yL6lG(RbP-QlB$Oti4E!3MKEL1h>ayozY!mn{Mk{32aOo zA?Uq5xkM?J;`T+$OFGeNy~AwstMVK)bPRY^B7{0MiPlqF)h@ zeuWiu)P-^|Gg&toM2ee?GeF6Te<0lL+XL;J5HrBZ#yOxtSp~cwu)O#e!n&sB6pe&jIK&VD@ zG!M|AgCDhz!-hponuVY75ojMZ&7x_|q+>v75B1!DsjjLT=BDn4F@@(>anuH6n{1Iy z`VM@uMa9K!x(lgf7YfL(5hswg0}+Nlijt<7Lx~vty=5XtQ7!RU&C_>vpj(I1DbZAP zL(x+mI!j27gW#|?iMt43b6=Npg7Dy_xTQ?t_t3SE&c>d zRnf>7?(GOv3P~}78crY>MKFe-gy129GJ?a(+rd;Zm<0w(L>LhkHL})mYd|2ia1ZPG zMk{U!sOR|5CqhSn#|6800$PLj(AS@o=_yEpT-2c)V~j)43rt+XM36+F?p_Kp%w{5k zAd8?60oqW~vOM>@N+bWxRM>dMqbayKf&WbOGC zR@YUgzxRR`FJUg}i9JI1tSy)>yt}Ox~w|Eco z(&GI^d=FN@+DBt)REkR_nJ7J8s}`lcUR^{`mKjA@b<2yZYtrltz)J$(pBTmF z7Gw@`-wI~oqIy#w2`g^?;BmWJS}9eFYs>h;RnJ{H*ws?3+;b0TIXIBpGakSr-*bCX zwz!UdH5<>icr8{j`FkM@FQ?9<^DYKvv;klU5~8J@prY|4`O(k~kOU1nBw;{o!&+Q4;lQTOLV{rIjU0b{yMrC|Z_nB~BgMl@!OOWp9@|LvpG8 zq3#SNkzOWgq|{29xJjC}d2j;>Ezk%k&;n`G1PzKl^q~)ZEDCh`STulN+lLkcZ1wxj z{Os)RtW6hA3KZSt+`Th%|IWGRp8MT%&*c}##)=v~k3aT_>RMCN{*^b$PYySyaJj!g zU~9JC(3<+3-ZbWnW@av<^O?~w=S=y{&Sm8{H)K~EJ7?#wYj)n*axF7Af%}3zg8LDt=$Ok}oo&|)Jl~GzMSB#_ zN1g4spTvF19>e{ZGl}~h_PD*}x;D2H&nN7yc)nGh?{e}tciY=;>2rJR?e-*6?6r5; zJMnuDQtq;MBjs)>@m||FrhwN>+QKl`rEEQVilJ-k?~cxx+;>yKZldrOt3<5g>os_UZ2{L7A#0>)l&7OSW*6fT+zbk z>6TRw-dJw*%DPf@t%de#%RXwYx@d;wF11%1wxyf}M_FFmdg-~BtVbU`F(pOJmQBA< zskEw1r&95Yl}fX1uQnJjRVtTOtBvqYzEZKMO@qTPxMt zMaMpNWyx_G#~yz4(x)yxvd}oba&fVu9JjryYL0una@lFwZFQV!tBYXZ@wnOU)XJI~ zMaf&p2LnMtm-_)`nRs`KiN1;;VwRIxHf`NDu4~uyxvbnlBIPb8cUe0pcX_$X+XcBR z;BLeov5Rt7bc)NP_Go;^GPl}e_V{%jrIsY;HhYUbA@^f;2~xD(A3I%jow#Re?91rG zIIm}Lxoo$sBa5;Awy>T(c-HY&Rm-)!CC7qHp_5j?E~n*HDQ{ML0dMNA6&G(c>K7fW zJ-_VKyeaEE-o-_Q-8}E~6ml7P8qyoNMe5Poo4S)ifS_Jr%+m3D&j z?7g_Kpch@MsvOJVP#fqGLrtPdezwh0`^n5zD$b=!&PWEoh;KK8QLd*p$pI4p7(EQy6r|l!Fd+9rOqO(3R+4>6&Vz(Z1r?*8G|X zW?WRPy8626)!&a1(tPPa9Zg-Jew!ZfIg|I~T6xtSzpFSlKCD{}$zZcVTzIu^TB#l?qd594-FdM>$wzW`i zfL2lYP0MYAlB#F5TaC3a&6TBkZ7D8{%HczZ?~zilrtbAiWI1F<0j-c0rLrU!wCqfR zA$i`8TdgNU6pcj3e+f)%lt~4lw1ZYRv;2T58*B2Vd`Gu!q53CY*@Utf=;i zqr5d~j-PWK5A9PH6CPj?BaI-&=}2uuz(QRMLBTNfVh&d}{AE16N_ZxzYe?Ahp*Wtx z<=#XPA&9yLxMdN?Ue|$h1up>S3Q_>h6^sC!J8GAJC<}rLw7C&M1KL~>IAI%}k2<9Q zdjcvpPUfa* z8@KeE*;|^#GeLa8=xCK(hhg5 zHy_z3&y;iOVLVsI7*KWkBbds#c&JolSos++DAKqYmO4m0v0|lCL2j3WLdz8HjvK~% z2IN17ukqec1_U{K7(n$*CI|yKux)*rOwiw^5E!%TIZ*KC!y9EIXf%10Hqps|Z{TI1 zQ}y+GhjfBq%Hd7mdexH#Tmxpl4Si$yCNY~DS~ImwJ5lqn?jM5u3dkzdzZ6uhd-^p) zJ-R;L(QXFLSY|PUx7?bj>q!+N}_)Cg8tg2Xv-Dqd<`&hpZMg zy{H@dIKB{i-89zk8N%;WDEP~x8AC#7Rwqed8X24lHa;>Lg83+@(T8zzQo4>JK&gqw zY)9XtLEmw?4-qa^YV9Ug;7$dy%vJg#mh7IVM53|wjg*-SAs66nv{(Aa-B<;g;*>W~ zUnJ-U(ixvjJ^<-rg-vEqemvbX77R$xP7kX3n!W+`5^@rHaR#Z>2m^MU;ur~aggU|p zeL7+b=ykC0#kbdBf-&d)&nJ;vIZ5M{)0q~Rw}C# zv&DdD#LAexOvO^cd=w3;&*GW7mqBlrOTF)O>m4XHgLg7gq*U!DO1>2d7<$ga>qw&R zN4&3i+JqudT&dhdf=KxHr_z^9JpiKPraXyqItC`&f`YDH);0h>Lf``FUpCZ(9m9Q) zrV~8RAcc7g&+(h(z`kwFp22j=NmM8@Ovx+W^WE;(#PN1`tH1u5VykcvgG;^hOQ@ zX`LJpS{~%+o&18{$-a$l=;T56DN}smE z1&1LhN>&{J0+W3U5A`%^P>(X8D5Whq0x1yjD8!47u26{ZJjlGCXJ9d4yAwpoIFkj) zA-tHySV6DP#@3n29bdNARY&T`?C$qvw;y-6>q|WdzYegmz!Y zyqUEPC$kHN^j#W^<2hXU)7mWqOAlF`aACql$vZhLLV`s}Fd7>`b5R%pmN{l*@6t z3+|CP&OD(uorxdP()ijNM?Z7HEx&%mI%u7%0|W)@cr5U%)`5mYQ~81JD&wfEmub5U z3+pM1Ptj_Rr;2*R!hg?Nx-WHJS?+k6Kq8OI8t`-vdyWf(wS(4JuG6d^tF;?2&C*cWtg4GJ_qnSp+&4Hnw7jZSYqSCU7A>NWmW3!t z4~c?tBWSkMVk($8>aC$Aff>z!Ehw|yY@$h0R^2;99)?Atov4WGvaThd+f#SUH_%yk zOau@3Sux4^Be2fFoQMUczop?|83L#s5B<&3{AZbaP6caSV<$bq2^iIZ=-F%gzfLmRU@ZcHpf zft4s$^=rpup_rwiL3UtsmOtvw*9va%V!F-!;UX1L9Hm}=>F$*$@ zRt@jOIQgat?qytQvK$1+T;N8EGr4dwWGuG#7hL|%UG z?CBTJJ?9sn|Lp9GXP2uF1?hgd>KZn0^7%VVYWU$1b&S05AcUW|1^K*FdPq>2F zJOgAhjyYQ^-Zf1F3+wQECpQ9|!Z}{Pin)5$2?icecTk78fl9ln-@w}QEp0)Ujmbi! z(#n}$!(F6yws*5~9SChWPRx4)s27R|JLBk;Uqc!!PGub^OF#~HY}^?Ot$;c)jODK= zLOXku{lP_xW&q9V>t(R^(rO*+-*BFYdU0yH(XLe+?#xt}6ULSi+4ROPm+NQwl#Aj^ zC`u^?!oU^Aq{iLDN`@;yq>u~xxT#i=g>CNnjNtARF88Mh{%0_V5a^x496SjE5CqHW zDB|3!rIodWxL9ZrA46RH0}vlaJhIVlK|He2P9VO=-Ya>x+V|M^!a}>v*>2xw?~`Yf z&gAkA`~K+8wg9B|`y*WlmBlu8Jc;*0s4t)F^r0x+pG+XBq3G%GQ%}ZacCpWS;G?x_)IW<q{Ym?T4#J z(Jv{ubfEmGOqLa(L-3dTNV3TUH0ufDfL{rl(b19g^wQb|j4ZIzQ_XNmJltxx$^u}9 zi6g|pMt3V)x?U7dPuZ;PV1#6`P1Yu)C&;4bi_IM~kh4^UV*_5<&H{D?A<}S~u&~#j zQc`zFgs7MujjT>f_U5?#)=M}W5OgxuI_T!^XQ0D{&|q7S(i_|s2O5#q$S`Ke^3&PqG6BN)92k|NKAsUTWDf>#IOks$lnX{AS56Tb(!Wid1l6TWt= za$)NA!PfHK;c92TQ|qW&r`lLq!VL_n9Tdpxa^1PoD?`k|&j*z#q;yx3K?chz57rOL zqqm7)(9_21Zx|Dp5*d$$9P5zf0ey#=uY+cHR5^SUv}KS6G-iOi2d!735<@Kpzbgwa z1U-UYg{)qtXNX9AB;P6Jcx{-B=|uubm(4OtcT@JgQD{d-O%q$p!Q=J{9fgv~+W zFT!~W69<_;Kvg{UFikCT7bjh>e7RStfbs#og3{AkH7It!BF*xUG%^$ij37)=qJgW{ zLo)q4Rhu1DwT|@mKqzlf=O%vtuj!oxX%hVv>7o8=<8k=Z2Mlh=8+B3I=r^!e~k#Im2*+-JXj4=deQI%)R8SS%9gWZ>5Tq zVc4T$2O&fYS{NlrNkJ<)-Y{h?)UT$LCOC|cDOTui>cHL~!20Cy7BD9xMF32-ff<4> zW+7N~2X#n)hX(ft6U+?&&=tU7q8OP8+*QosBxj)Y!-})ptwUajTrt-;Q~ztK zE6#!TL!MJe_Ld93Nx7ZLcy?mVkr=F=}Rc!j~M4CWZThQJ@G zs`)y+$kbZ7aL4%aNp*p*UT5$I1NywE-(XNha3_Q1SdVdwmKd5xp26jEuLk}A8n@PO z!lT~KT!-5R3@Z99T()MLUpMF_Krbmf`?!W*4ZAPcZ41UvW%er5LH;D3Fx;4U(qhC!} zsl>EWm~K>?^LBOSJ2a(`vXWl7yM8>jHPEIV*p0jV?HY8V-0$AS=Z-OTBw!vHTF&|A za=YI0%|;#V8KHBaCkCGp5BL&0AF#TO$F?GOrGY*nOG6JWWg{+DZ$B3(&;GV=PiflM zNCvmAwNVr1HTWtSx%Z5_X3n@{-Ze)H#)Lk8cm2K(B(JBlGboB|kBEr4J1+Az3?*)r$wK)YP@^uXJyJt zv)+qM^AE{1x}<2CqEXCDWJ}oza{_yfIqaye?@nQsEJcU&Nwzn*xd9q(85B&h_?Gp+ zgj!=;#l|NA1yRhZf6I2z)`>F!_omc3e8YgfBt67EcGx%3OV{*^(RKk`4`Op>f4#Ki z{#~Np11a^!HtxV&KR|bS?eU(#cTq(u@0al6?-O-@BBkz4SpDPbr%_%&I>d?MgI*QK z24h)wpMbN2uAZP9&@!0Abo{+&s3(|)&Y-t5vuDo3n^%~{oqWGE4?q!((Nr2}|NaNk zz&_VZ?zfw{l0K=M+0;Iac{!YmRKh)En42d9#AU>>axR6?xrk8pJyZcbLqh#=dUQZ# zhJaQ5E*`4yFsL!;lT(`d|Bdv@cuCT076Yp9|BzlBPB=9?n|%#Fp|?U7Fc$9*!bmPd z9OL;4T$xkam)MPqXE_r?D%y=p8&+|`o;in76-(Ax+`v~P@L8Q;OdJq(C^4!o>_J@2 zsagC&WvNq8k(dW>>5N4)AeABq<+7<}Z43=N2i2CJh4YBazB1>^?7N1l)H(xsag8y$ zmYqL?v=8&{1cPrepqr7RpoT8!2~V89Zle!Io_yGbh=#7p!3C#~*`}8ehhO84Zl__g z2}Qvj*jJ`2RR+zG~Pd1v3Yl)8xGRD%J|Pim^gfX=3g9VqT?sBbd( z;BBbiXA<^T;It%uCtYSpOcXAiLbg+opGBm=t*J`N))cp>{wp^Mhm*ay4n&S8;qPwz z?n7R^xC`F!EOC9`8;3*d*I@v@$beT4pFPkcVw_jAxP+sp5P?IJY>E@wz~$&Dghq#V zEWi!nlRD9%i#c4&ZvjxjL1`TKm|3GZ1j?9IZ=xJvkE{R+e~j)$Sa=27e(ES*`Z?#S zhe_1WiT%q}UtkV1@H@)keB5foQ{tZXNxbME|2OdL5c^W}9sR-KB5UdsMoE`BxJP72 zASFcz`~@P5_!@9Q137>ZA!d|=g&la`05gIt5E#7yp1ck*i{BtmN6@8h5@^_3fGvYO znD$Iy%>Fk9&?fNaB7lc&c2f|e25EO|*NjQjE~WIQ4O4V;b^Ot{6fBxz-ADLeuR3} zJFIM2jgO;7^+Tp$>lMY+*H6HkjnbmN&fvEgyv5*c1bz-XRe-pDrdhq}XKPD1P=wR3 zX2V&)xdc^TT=M)PZ*V99P}d)oN5M@$$-jg09-)v~h`o|mrF$%?|SYFPoQ8a!V{}Fi4vSZ$%ZFTa-p+VK6Lgfgw9?gp|e-G zw<#x4qMgk#XKZ;Kdz&~5&HYb%x4j1?Z^8a0&z|UT1hc}kCtKyj$$q~SD_a~Z3!LwI zCPgxvyS6fHs0)L$w;1hkSfgeT%&lMJVv2g=$qjRT8-@+17&90|@TK2pVyM8E{^h`z zUfyS;_pjppE4YBhGdN^{<0x_{r4YI{_J|QWLY4p`zW3s05d!@BB%P-z#tKlMzuz@3 z(Y1jZ7C`qner_ASF?GV%-M;?yi_=^aaX~e6mff5~;v9xZL0c~;c@v)|NeX(D^NxPB zJfi*pS#g}hf!tMXTXe8E{EHI-w%JvC-GN+sI5*>Bm&=tY6f-H|3s#5W#+PzKr_Epo z)gOsp^fg@^Azx&hWg^W?!r!t0VcZ5ixHD5U6B8-=Hg10^Kc#z*pdB%?NIeaMPDO`P z3qrG)v+7gG5uAJ3J)LCMVL1`QLnJfM=7JRB126)c)Dz6voeO0ed=k%W(nCGnJ>)V# z$B;uU6jh;vUKxQMAg}>|CWC@XaSYo1r${lt2M$x0*G>eGs&On31p$f&F3?kV=|tqG ze#D@c1b<|D(P=qXSJX_4gmBU^Ax!IslH7?-Q70rR$_4Or9eHq~3T}ot8uI6?WBXu5 z;`-WT6}aeQHknpI4~dcH7Z#DjAP%m`JaiMR2n{vOiiTE6wyY$o?BcXQyi!ivkfpq& z&L1E`hRSK1$-w&$tL|}m#*+{SJb1o%26TymX)ZidbD9EYRB!-m8UKRzRW}L z&neYb5n$$$L;aXRpHSgkKI+8Ldotfb0v-k8*EDkaHe(VoUL{xv01@wEwbw5VlD!8G zQEcL#IfI*&o_SE7!4Rg7dh8K!i`qWXV^4ZmK6JSoO499oKL-w>f?(VWFN6)d_^g*w zIq>vNQW+q+fJ#Ai#`^YTe_#lu9&`G*Ns3)Af6CUTHJQrh`M?fqgp7~$F-bf# zbWHMJHo(MGsr-;FU`Z*eKoWdJRp9eHwHjV8Ph`?jxN<8|alb+cQVi4__t6xZ3*i}9 z$+~-~Yk7)QFgKJ`puI6n;Za9D7JW!DFHzf^MxnM#1Ov-jpVEfiNqqlPl(zZ{Wc)Gd zh}HE&J+hWqg{G@)ncyhYnD|?3srs6g|1s;3xlIE$wyl6 z{w3>WcFh$FrZsrRwW@dieE$hk?jrR_eZhz=P8x zS1i#%xEoOR-_UMgH3dcg0A$1bhJHhLAGv|aKs`c}k(YZ*dkZTYnb`|Sk&k7=oINuj z9K-~lWNpNX5mH=6t*qnQMkpjG7v`LwBgt$)Go|FV5v)8#Y=nLRDHN7}BA{c+!i=mN+o(kxZqG4um zN|$yly@W$g6SQabPF$%6owoHGp&n)Z#KVa*PJhMQ_FGtxwOqUk=x)aCp5FQXP#@lTBKzgQIV zYKp^HaTutB45);Ig?IxoOijTqRRDzYd`ZRyf-gfrr2i*;HYypOKK;xW;8y16g8!Ez z|I$H@Q^^8KJc@%wl^Es-CxfjPF1n?WX|(!<>EIt-&9J2|IW&obfAYl+)MRENxBJr* WU(rS;9xaUE_bb|V9ON1;-1FbA$=hK7 diff --git a/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/utils.cpython-38.pyc b/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/utils.cpython-38.pyc deleted file mode 100644 index d24880bccb4791e34fc337ab8934a94bee83dcfb..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 466 zcmY*Vy-ve05VoB(jSA&Q@CpnON+T+M7KD(PSh^sVAY`Sn8>~9Ev6B`mMjoUc7lHzac=e;G++q{d;=@AL@VH=&}a=)r*weJLP){Ng0lt1 znpX712Bsa`4wrMP6KF$G)btZ*fBX72YigA#rqWiZqMTBa&Yvjd>B;Hy+4FG1Gc~Q; z7$aLl%f9D#%?;S{)cCTNq~-L=HyY19L~+myegFudb?*QG diff --git a/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/version.cpython-38.pyc b/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/__pycache__/version.cpython-38.pyc deleted file mode 100644 index db38c68b84ad368670118b271503aa66d5512e43..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 10634 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 diff --git a/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/_compat.py b/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/_compat.py deleted file mode 100644 index 210bb80..0000000 --- a/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/_compat.py +++ /dev/null @@ -1,30 +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 - - -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): - """ - 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): - def __new__(cls, name, this_bases, d): - return meta(name, bases, d) - return type.__new__(metaclass, 'temporary_class', (), {}) diff --git a/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/_structures.py b/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/_structures.py deleted file mode 100644 index ccc2786..0000000 --- a/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/_structures.py +++ /dev/null @@ -1,68 +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 - - -class Infinity(object): - - def __repr__(self): - return "Infinity" - - def __hash__(self): - return hash(repr(self)) - - def __lt__(self, other): - return False - - def __le__(self, other): - return False - - def __eq__(self, other): - return isinstance(other, self.__class__) - - def __ne__(self, other): - return not isinstance(other, self.__class__) - - def __gt__(self, other): - return True - - def __ge__(self, other): - return True - - def __neg__(self): - return NegativeInfinity - -Infinity = Infinity() - - -class NegativeInfinity(object): - - def __repr__(self): - return "-Infinity" - - def __hash__(self): - return hash(repr(self)) - - def __lt__(self, other): - return True - - def __le__(self, other): - return True - - def __eq__(self, other): - return isinstance(other, self.__class__) - - def __ne__(self, other): - return not isinstance(other, self.__class__) - - def __gt__(self, other): - return False - - def __ge__(self, other): - return False - - def __neg__(self): - return Infinity - -NegativeInfinity = NegativeInfinity() diff --git a/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/markers.py b/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/markers.py deleted file mode 100644 index 892e578..0000000 --- a/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/markers.py +++ /dev/null @@ -1,301 +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 operator -import os -import platform -import sys - -from pkg_resources.extern.pyparsing import ParseException, ParseResults, stringStart, stringEnd -from pkg_resources.extern.pyparsing import ZeroOrMore, Group, Forward, QuotedString -from pkg_resources.extern.pyparsing import Literal as L # noqa - -from ._compat import string_types -from .specifiers import Specifier, InvalidSpecifier - - -__all__ = [ - "InvalidMarker", "UndefinedComparison", "UndefinedEnvironmentName", - "Marker", "default_environment", -] - - -class InvalidMarker(ValueError): - """ - An invalid marker was found, users should refer to PEP 508. - """ - - -class UndefinedComparison(ValueError): - """ - An invalid operation was attempted on a value that doesn't support it. - """ - - -class UndefinedEnvironmentName(ValueError): - """ - A name was attempted to be used that does not exist inside of the - environment. - """ - - -class Node(object): - - def __init__(self, value): - self.value = value - - def __str__(self): - return str(self.value) - - def __repr__(self): - return "<{0}({1!r})>".format(self.__class__.__name__, str(self)) - - def serialize(self): - raise NotImplementedError - - -class Variable(Node): - - def serialize(self): - return str(self) - - -class Value(Node): - - def serialize(self): - return '"{0}"'.format(self) - - -class Op(Node): - - def serialize(self): - return str(self) - - -VARIABLE = ( - L("implementation_version") | - L("platform_python_implementation") | - L("implementation_name") | - L("python_full_version") | - L("platform_release") | - L("platform_version") | - L("platform_machine") | - L("platform_system") | - L("python_version") | - L("sys_platform") | - L("os_name") | - L("os.name") | # PEP-345 - L("sys.platform") | # PEP-345 - L("platform.version") | # PEP-345 - L("platform.machine") | # PEP-345 - L("platform.python_implementation") | # PEP-345 - L("python_implementation") | # undocumented setuptools legacy - L("extra") -) -ALIASES = { - 'os.name': 'os_name', - 'sys.platform': 'sys_platform', - 'platform.version': 'platform_version', - 'platform.machine': 'platform_machine', - 'platform.python_implementation': 'platform_python_implementation', - 'python_implementation': 'platform_python_implementation' -} -VARIABLE.setParseAction(lambda s, l, t: Variable(ALIASES.get(t[0], t[0]))) - -VERSION_CMP = ( - L("===") | - L("==") | - L(">=") | - L("<=") | - L("!=") | - L("~=") | - L(">") | - L("<") -) - -MARKER_OP = VERSION_CMP | L("not in") | L("in") -MARKER_OP.setParseAction(lambda s, l, t: Op(t[0])) - -MARKER_VALUE = QuotedString("'") | QuotedString('"') -MARKER_VALUE.setParseAction(lambda s, l, t: Value(t[0])) - -BOOLOP = L("and") | L("or") - -MARKER_VAR = VARIABLE | MARKER_VALUE - -MARKER_ITEM = Group(MARKER_VAR + MARKER_OP + MARKER_VAR) -MARKER_ITEM.setParseAction(lambda s, l, t: tuple(t[0])) - -LPAREN = L("(").suppress() -RPAREN = L(")").suppress() - -MARKER_EXPR = Forward() -MARKER_ATOM = MARKER_ITEM | Group(LPAREN + MARKER_EXPR + RPAREN) -MARKER_EXPR << MARKER_ATOM + ZeroOrMore(BOOLOP + MARKER_EXPR) - -MARKER = stringStart + MARKER_EXPR + stringEnd - - -def _coerce_parse_result(results): - if isinstance(results, ParseResults): - return [_coerce_parse_result(i) for i in results] - else: - return results - - -def _format_marker(marker, first=True): - assert isinstance(marker, (list, tuple, string_types)) - - # 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 - # the rest of this function so that we don't get extraneous () on the - # outside. - if (isinstance(marker, list) and len(marker) == 1 and - isinstance(marker[0], (list, tuple))): - return _format_marker(marker[0]) - - if isinstance(marker, list): - inner = (_format_marker(m, first=False) for m in marker) - if first: - return " ".join(inner) - else: - return "(" + " ".join(inner) + ")" - elif isinstance(marker, tuple): - return " ".join([m.serialize() for m in marker]) - else: - return marker - - -_operators = { - "in": lambda lhs, rhs: lhs in rhs, - "not in": lambda lhs, rhs: lhs not in rhs, - "<": operator.lt, - "<=": operator.le, - "==": operator.eq, - "!=": operator.ne, - ">=": operator.ge, - ">": operator.gt, -} - - -def _eval_op(lhs, op, rhs): - try: - spec = Specifier("".join([op.serialize(), rhs])) - except InvalidSpecifier: - pass - else: - return spec.contains(lhs) - - oper = _operators.get(op.serialize()) - if oper is None: - raise UndefinedComparison( - "Undefined {0!r} on {1!r} and {2!r}.".format(op, lhs, rhs) - ) - - return oper(lhs, rhs) - - -_undefined = object() - - -def _get_env(environment, name): - value = environment.get(name, _undefined) - - if value is _undefined: - raise UndefinedEnvironmentName( - "{0!r} does not exist in evaluation environment.".format(name) - ) - - return value - - -def _evaluate_markers(markers, environment): - groups = [[]] - - for marker in markers: - assert isinstance(marker, (list, tuple, string_types)) - - if isinstance(marker, list): - groups[-1].append(_evaluate_markers(marker, environment)) - elif isinstance(marker, tuple): - lhs, op, rhs = marker - - if isinstance(lhs, Variable): - lhs_value = _get_env(environment, lhs.value) - rhs_value = rhs.value - else: - lhs_value = lhs.value - rhs_value = _get_env(environment, rhs.value) - - groups[-1].append(_eval_op(lhs_value, op, rhs_value)) - else: - assert marker in ["and", "or"] - if marker == "or": - groups.append([]) - - return any(all(item) for item in groups) - - -def format_full_version(info): - version = '{0.major}.{0.minor}.{0.micro}'.format(info) - kind = info.releaselevel - if kind != 'final': - version += kind[0] + str(info.serial) - return version - - -def default_environment(): - if hasattr(sys, 'implementation'): - iver = format_full_version(sys.implementation.version) - implementation_name = sys.implementation.name - else: - iver = '0' - implementation_name = '' - - return { - "implementation_name": implementation_name, - "implementation_version": iver, - "os_name": os.name, - "platform_machine": platform.machine(), - "platform_release": platform.release(), - "platform_system": platform.system(), - "platform_version": platform.version(), - "python_full_version": platform.python_version(), - "platform_python_implementation": platform.python_implementation(), - "python_version": platform.python_version()[:3], - "sys_platform": sys.platform, - } - - -class Marker(object): - - def __init__(self, marker): - 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(err_str) - - def __str__(self): - return _format_marker(self._markers) - - def __repr__(self): - return "".format(str(self)) - - def evaluate(self, environment=None): - """Evaluate a marker. - - Return the boolean from evaluating the given marker against the - environment. environment is an optional argument to override all or - part of the determined environment. - - The environment is determined from the current Python process. - """ - current_environment = default_environment() - if environment is not None: - current_environment.update(environment) - - return _evaluate_markers(self._markers, current_environment) diff --git a/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/requirements.py b/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/requirements.py deleted file mode 100644 index 0c8c4a3..0000000 --- a/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/requirements.py +++ /dev/null @@ -1,127 +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 string -import re - -from pkg_resources.extern.pyparsing import stringStart, stringEnd, originalTextFor, ParseException -from pkg_resources.extern.pyparsing import ZeroOrMore, Word, Optional, Regex, Combine -from pkg_resources.extern.pyparsing import Literal as L # noqa -from pkg_resources.extern.six.moves.urllib import parse as urlparse - -from .markers import MARKER_EXPR, Marker -from .specifiers import LegacySpecifier, Specifier, SpecifierSet - - -class InvalidRequirement(ValueError): - """ - An invalid requirement was found, users should refer to PEP 508. - """ - - -ALPHANUM = Word(string.ascii_letters + string.digits) - -LBRACKET = L("[").suppress() -RBRACKET = L("]").suppress() -LPAREN = L("(").suppress() -RPAREN = L(")").suppress() -COMMA = L(",").suppress() -SEMICOLON = L(";").suppress() -AT = L("@").suppress() - -PUNCTUATION = Word("-_.") -IDENTIFIER_END = ALPHANUM | (ZeroOrMore(PUNCTUATION) + ALPHANUM) -IDENTIFIER = Combine(ALPHANUM + ZeroOrMore(IDENTIFIER_END)) - -NAME = IDENTIFIER("name") -EXTRA = IDENTIFIER - -URI = Regex(r'[^ ]+')("url") -URL = (AT + URI) - -EXTRAS_LIST = EXTRA + ZeroOrMore(COMMA + EXTRA) -EXTRAS = (LBRACKET + Optional(EXTRAS_LIST) + RBRACKET)("extras") - -VERSION_PEP440 = Regex(Specifier._regex_str, re.VERBOSE | re.IGNORECASE) -VERSION_LEGACY = Regex(LegacySpecifier._regex_str, re.VERBOSE | re.IGNORECASE) - -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.setParseAction(lambda s, l, t: t._raw_spec or '') - -VERSION_SPEC = originalTextFor(_VERSION_SPEC)("specifier") -VERSION_SPEC.setParseAction(lambda s, l, t: t[1]) - -MARKER_EXPR = originalTextFor(MARKER_EXPR())("marker") -MARKER_EXPR.setParseAction( - lambda s, l, t: Marker(s[t._original_start:t._original_end]) -) -MARKER_SEPERATOR = SEMICOLON -MARKER = MARKER_SEPERATOR + MARKER_EXPR - -VERSION_AND_MARKER = VERSION_SPEC + Optional(MARKER) -URL_AND_MARKER = URL + Optional(MARKER) - -NAMED_REQUIREMENT = \ - NAME + Optional(EXTRAS) + (URL_AND_MARKER | VERSION_AND_MARKER) - -REQUIREMENT = stringStart + NAMED_REQUIREMENT + stringEnd - - -class Requirement(object): - """Parse a requirement. - - Parse a given requirement string into its parts, such as name, specifier, - URL, and extras. Raises InvalidRequirement on a badly-formed requirement - string. - """ - - # TODO: Can we test whether something is contained within a requirement? - # If so how do we do that? Do we need to test against the _name_ of - # 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): - try: - req = REQUIREMENT.parseString(requirement_string) - except ParseException as e: - raise InvalidRequirement( - "Invalid requirement, parse error at \"{0!r}\"".format( - requirement_string[e.loc:e.loc + 8])) - - self.name = req.name - if req.url: - parsed_url = urlparse.urlparse(req.url) - if not (parsed_url.scheme and parsed_url.netloc) or ( - not parsed_url.scheme and not parsed_url.netloc): - raise InvalidRequirement("Invalid URL given") - self.url = req.url - else: - self.url = None - self.extras = set(req.extras.asList() if req.extras else []) - self.specifier = SpecifierSet(req.specifier) - self.marker = req.marker if req.marker else None - - def __str__(self): - parts = [self.name] - - if self.extras: - parts.append("[{0}]".format(",".join(sorted(self.extras)))) - - if self.specifier: - parts.append(str(self.specifier)) - - if self.url: - parts.append("@ {0}".format(self.url)) - - if self.marker: - parts.append("; {0}".format(self.marker)) - - return "".join(parts) - - def __repr__(self): - return "".format(str(self)) diff --git a/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/specifiers.py b/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/specifiers.py deleted file mode 100644 index 7f5a76c..0000000 --- a/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/specifiers.py +++ /dev/null @@ -1,774 +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 abc -import functools -import itertools -import re - -from ._compat import string_types, with_metaclass -from .version import Version, LegacyVersion, parse - - -class InvalidSpecifier(ValueError): - """ - An invalid specifier was found, users should refer to PEP 440. - """ - - -class BaseSpecifier(with_metaclass(abc.ABCMeta, object)): - - @abc.abstractmethod - def __str__(self): - """ - Returns the str representation of this Specifier like object. This - should be representative of the Specifier itself. - """ - - @abc.abstractmethod - def __hash__(self): - """ - Returns a hash value for this Specifier like object. - """ - - @abc.abstractmethod - def __eq__(self, other): - """ - Returns a boolean representing whether or not the two Specifier like - objects are equal. - """ - - @abc.abstractmethod - def __ne__(self, other): - """ - Returns a boolean representing whether or not the two Specifier like - objects are not equal. - """ - - @abc.abstractproperty - def prereleases(self): - """ - Returns whether or not pre-releases as a whole are allowed by this - specifier. - """ - - @prereleases.setter - def prereleases(self, value): - """ - Sets whether or not pre-releases as a whole are allowed by this - specifier. - """ - - @abc.abstractmethod - def contains(self, item, prereleases=None): - """ - Determines if the given item is contained within this specifier. - """ - - @abc.abstractmethod - def filter(self, iterable, prereleases=None): - """ - Takes an iterable of items and filters them so that only items which - are contained within this specifier are allowed in it. - """ - - -class _IndividualSpecifier(BaseSpecifier): - - _operators = {} - - def __init__(self, spec="", prereleases=None): - match = self._regex.search(spec) - if not match: - raise InvalidSpecifier("Invalid specifier: '{0}'".format(spec)) - - self._spec = ( - match.group("operator").strip(), - match.group("version").strip(), - ) - - # Store whether or not this Specifier should accept prereleases - self._prereleases = prereleases - - def __repr__(self): - pre = ( - ", prereleases={0!r}".format(self.prereleases) - if self._prereleases is not None - else "" - ) - - return "<{0}({1!r}{2})>".format( - self.__class__.__name__, - str(self), - pre, - ) - - def __str__(self): - return "{0}{1}".format(*self._spec) - - def __hash__(self): - return hash(self._spec) - - def __eq__(self, other): - if isinstance(other, string_types): - try: - other = self.__class__(other) - except InvalidSpecifier: - return NotImplemented - elif not isinstance(other, self.__class__): - return NotImplemented - - return self._spec == other._spec - - def __ne__(self, other): - if isinstance(other, string_types): - try: - other = self.__class__(other) - except InvalidSpecifier: - return NotImplemented - elif not isinstance(other, self.__class__): - return NotImplemented - - return self._spec != other._spec - - def _get_operator(self, op): - return getattr(self, "_compare_{0}".format(self._operators[op])) - - def _coerce_version(self, version): - if not isinstance(version, (LegacyVersion, Version)): - version = parse(version) - return version - - @property - def operator(self): - return self._spec[0] - - @property - def version(self): - return self._spec[1] - - @property - def prereleases(self): - return self._prereleases - - @prereleases.setter - def prereleases(self, value): - self._prereleases = value - - def __contains__(self, item): - return self.contains(item) - - def contains(self, item, prereleases=None): - # Determine if prereleases are to be allowed or not. - if prereleases is None: - prereleases = self.prereleases - - # Normalize item to a Version or LegacyVersion, this allows us to have - # a shortcut for ``"2.0" in Specifier(">=2") - item = self._coerce_version(item) - - # Determine if we should be supporting prereleases in this specifier - # or not, if we do not support prereleases than we can short circuit - # logic if this version is a prereleases. - if item.is_prerelease and not prereleases: - return False - - # Actually do the comparison to determine if this item is contained - # within this Specifier or not. - return self._get_operator(self.operator)(item, self.version) - - def filter(self, iterable, prereleases=None): - yielded = False - found_prereleases = [] - - kw = {"prereleases": prereleases if prereleases is not None else True} - - # Attempt to iterate over all the values in the iterable and if any of - # them match, yield them. - for version in iterable: - parsed_version = self._coerce_version(version) - - 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 - # else matches this specifier. - if (parsed_version.is_prerelease and not - (prereleases or self.prereleases)): - found_prereleases.append(version) - # Either this is not a prerelease, or we should have been - # accepting prereleases from the begining. - else: - yielded = True - yield version - - # Now that we've iterated over everything, determine if we've yielded - # any values, and if we have not and we have any prereleases stored up - # then we will go ahead and yield the prereleases. - if not yielded and found_prereleases: - for version in found_prereleases: - yield version - - -class LegacySpecifier(_IndividualSpecifier): - - _regex_str = ( - r""" - (?P(==|!=|<=|>=|<|>)) - \s* - (?P - [^,;\s)]* # Since this is a "legacy" specifier, and the version - # string can be just about anything, we match everything - # except for whitespace, a semi-colon for marker support, - # a closing paren since versions can be enclosed in - # them, and a comma since it's a version separator. - ) - """ - ) - - _regex = re.compile( - r"^\s*" + _regex_str + r"\s*$", re.VERBOSE | re.IGNORECASE) - - _operators = { - "==": "equal", - "!=": "not_equal", - "<=": "less_than_equal", - ">=": "greater_than_equal", - "<": "less_than", - ">": "greater_than", - } - - def _coerce_version(self, version): - if not isinstance(version, LegacyVersion): - version = LegacyVersion(str(version)) - return version - - def _compare_equal(self, prospective, spec): - return prospective == self._coerce_version(spec) - - def _compare_not_equal(self, prospective, spec): - return prospective != self._coerce_version(spec) - - def _compare_less_than_equal(self, prospective, spec): - return prospective <= self._coerce_version(spec) - - def _compare_greater_than_equal(self, prospective, spec): - return prospective >= self._coerce_version(spec) - - def _compare_less_than(self, prospective, spec): - return prospective < self._coerce_version(spec) - - def _compare_greater_than(self, prospective, spec): - return prospective > self._coerce_version(spec) - - -def _require_version_compare(fn): - @functools.wraps(fn) - def wrapped(self, prospective, spec): - if not isinstance(prospective, Version): - return False - return fn(self, prospective, spec) - return wrapped - - -class Specifier(_IndividualSpecifier): - - _regex_str = ( - r""" - (?P(~=|==|!=|<=|>=|<|>|===)) - (?P - (?: - # The identity operators allow for an escape hatch that will - # do an exact string match of the version you wish to install. - # This will not be parsed by PEP 440 and we cannot determine - # any semantic meaning from it. This operator is discouraged - # but included entirely as an escape hatch. - (?<====) # Only match for the identity operator - \s* - [^\s]* # We just match everything, except for whitespace - # since we are only testing for strict identity. - ) - | - (?: - # The (non)equality operators allow for wild card and local - # versions to be specified so we have to define these two - # operators separately to enable that. - (?<===|!=) # Only match for equals and not equals - - \s* - v? - (?:[0-9]+!)? # epoch - [0-9]+(?:\.[0-9]+)* # release - (?: # pre release - [-_\.]? - (a|b|c|rc|alpha|beta|pre|preview) - [-_\.]? - [0-9]* - )? - (?: # post release - (?:-[0-9]+)|(?:[-_\.]?(post|rev|r)[-_\.]?[0-9]*) - )? - - # You cannot use a wild card and a dev or local version - # together so group them with a | and make them optional. - (?: - (?:[-_\.]?dev[-_\.]?[0-9]*)? # dev release - (?:\+[a-z0-9]+(?:[-_\.][a-z0-9]+)*)? # local - | - \.\* # Wild card syntax of .* - )? - ) - | - (?: - # The compatible operator requires at least two digits in the - # release segment. - (?<=~=) # Only match for the compatible operator - - \s* - v? - (?:[0-9]+!)? # epoch - [0-9]+(?:\.[0-9]+)+ # release (We have a + instead of a *) - (?: # pre release - [-_\.]? - (a|b|c|rc|alpha|beta|pre|preview) - [-_\.]? - [0-9]* - )? - (?: # post release - (?:-[0-9]+)|(?:[-_\.]?(post|rev|r)[-_\.]?[0-9]*) - )? - (?:[-_\.]?dev[-_\.]?[0-9]*)? # dev release - ) - | - (?: - # All other operators only allow a sub set of what the - # (non)equality operators do. Specifically they do not allow - # local versions to be specified nor do they allow the prefix - # matching wild cards. - (?=": "greater_than_equal", - "<": "less_than", - ">": "greater_than", - "===": "arbitrary", - } - - @_require_version_compare - def _compare_compatible(self, prospective, spec): - # Compatible releases have an equivalent combination of >= and ==. That - # is that ~=2.2 is equivalent to >=2.2,==2.*. This allows us to - # implement this in terms of the other specifiers instead of - # implementing it ourselves. The only thing we need to do is construct - # 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. - prefix = ".".join( - list( - itertools.takewhile( - lambda x: (not x.startswith("post") and not - x.startswith("dev")), - _version_split(spec), - ) - )[:-1] - ) - - # Add the prefix notation to the end of our string - prefix += ".*" - - return (self._get_operator(">=")(prospective, spec) and - self._get_operator("==")(prospective, prefix)) - - @_require_version_compare - def _compare_equal(self, prospective, spec): - # We need special logic to handle prefix matching - if spec.endswith(".*"): - # In the case of prefix matching we want to ignore local segment. - prospective = Version(prospective.public) - # Split the spec out by dots, and pretend that there is an implicit - # dot in between a release segment and a pre-release segment. - spec = _version_split(spec[:-2]) # Remove the trailing .* - - # Split the prospective version out by dots, and pretend that there - # is an implicit dot in between a release segment and a pre-release - # segment. - prospective = _version_split(str(prospective)) - - # Shorten the prospective version to be the same length as the spec - # so that we can determine if the specifier is a prefix of the - # prospective version or not. - prospective = prospective[:len(spec)] - - # Pad out our two sides with zeros so that they both equal the same - # length. - spec, prospective = _pad_version(spec, prospective) - else: - # Convert our spec string into a Version - spec = Version(spec) - - # If the specifier does not have a local segment, then we want to - # act as if the prospective version also does not have a local - # segment. - if not spec.local: - prospective = Version(prospective.public) - - return prospective == spec - - @_require_version_compare - def _compare_not_equal(self, prospective, spec): - return not self._compare_equal(prospective, spec) - - @_require_version_compare - def _compare_less_than_equal(self, prospective, spec): - return prospective <= Version(spec) - - @_require_version_compare - def _compare_greater_than_equal(self, prospective, spec): - return prospective >= Version(spec) - - @_require_version_compare - def _compare_less_than(self, prospective, spec): - # Convert our spec to a Version instance, since we'll want to work with - # it as a version. - spec = Version(spec) - - # Check to see if the prospective version is less than the spec - # version. If it's not we can short circuit and just return False now - # instead of doing extra unneeded work. - if not prospective < spec: - return False - - # This special case is here so that, unless the specifier itself - # includes is a pre-release version, that we do not accept pre-release - # versions for the version mentioned in the specifier (e.g. <3.1 should - # not match 3.1.dev0, but should match 3.0.dev0). - if not spec.is_prerelease and prospective.is_prerelease: - if Version(prospective.base_version) == Version(spec.base_version): - return False - - # If we've gotten to here, it means that prospective version is both - # less than the spec version *and* it's not a pre-release of the same - # version in the spec. - return True - - @_require_version_compare - def _compare_greater_than(self, prospective, spec): - # Convert our spec to a Version instance, since we'll want to work with - # it as a version. - spec = Version(spec) - - # Check to see if the prospective version is greater than the spec - # version. If it's not we can short circuit and just return False now - # instead of doing extra unneeded work. - if not prospective > spec: - return False - - # This special case is here so that, unless the specifier itself - # includes is a post-release version, that we do not accept - # post-release versions for the version mentioned in the specifier - # (e.g. >3.1 should not match 3.0.post0, but should match 3.2.post0). - if not spec.is_postrelease and prospective.is_postrelease: - if Version(prospective.base_version) == Version(spec.base_version): - return False - - # Ensure that we do not allow a local version of the version mentioned - # in the specifier, which is techincally greater than, to match. - if prospective.local is not None: - if Version(prospective.base_version) == Version(spec.base_version): - return False - - # If we've gotten to here, it means that prospective version is both - # greater than the spec version *and* it's not a pre-release of the - # same version in the spec. - return True - - def _compare_arbitrary(self, prospective, spec): - return str(prospective).lower() == str(spec).lower() - - @property - def prereleases(self): - # If there is an explicit prereleases set for this, then we'll just - # blindly use that. - if self._prereleases is not None: - return self._prereleases - - # Look at all of our specifiers and determine if they are inclusive - # operators, and if they are if they are including an explicit - # prerelease. - operator, version = self._spec - if operator in ["==", ">=", "<=", "~=", "==="]: - # The == specifier can include a trailing .*, if it does we - # want to remove before parsing. - if operator == "==" and version.endswith(".*"): - version = version[:-2] - - # Parse the version, and if it is a pre-release than this - # specifier allows pre-releases. - if parse(version).is_prerelease: - return True - - return False - - @prereleases.setter - def prereleases(self, value): - self._prereleases = value - - -_prefix_regex = re.compile(r"^([0-9]+)((?:a|b|c|rc)[0-9]+)$") - - -def _version_split(version): - result = [] - for item in version.split("."): - match = _prefix_regex.search(item) - if match: - result.extend(match.groups()) - else: - result.append(item) - return result - - -def _pad_version(left, right): - left_split, right_split = [], [] - - # Get the release segment of our versions - left_split.append(list(itertools.takewhile(lambda x: x.isdigit(), left))) - right_split.append(list(itertools.takewhile(lambda x: x.isdigit(), right))) - - # Get the rest of our versions - left_split.append(left[len(left_split[0]):]) - right_split.append(right[len(right_split[0]):]) - - # Insert our padding - left_split.insert( - 1, - ["0"] * max(0, len(right_split[0]) - len(left_split[0])), - ) - right_split.insert( - 1, - ["0"] * max(0, len(left_split[0]) - len(right_split[0])), - ) - - return ( - list(itertools.chain(*left_split)), - list(itertools.chain(*right_split)), - ) - - -class SpecifierSet(BaseSpecifier): - - def __init__(self, specifiers="", prereleases=None): - # Split on , to break each indidivual specifier into it's own item, and - # strip each item to remove leading/trailing whitespace. - specifiers = [s.strip() for s in specifiers.split(",") if s.strip()] - - # Parsed each individual specifier, attempting first to make it a - # Specifier and falling back to a LegacySpecifier. - parsed = set() - for specifier in specifiers: - try: - parsed.add(Specifier(specifier)) - except InvalidSpecifier: - parsed.add(LegacySpecifier(specifier)) - - # Turn our parsed specifiers into a frozen set and save them for later. - self._specs = frozenset(parsed) - - # Store our prereleases value so we can use it later to determine if - # we accept prereleases or not. - self._prereleases = prereleases - - def __repr__(self): - pre = ( - ", prereleases={0!r}".format(self.prereleases) - if self._prereleases is not None - else "" - ) - - return "".format(str(self), pre) - - def __str__(self): - return ",".join(sorted(str(s) for s in self._specs)) - - def __hash__(self): - return hash(self._specs) - - def __and__(self, other): - if isinstance(other, string_types): - other = SpecifierSet(other) - elif not isinstance(other, SpecifierSet): - return NotImplemented - - specifier = SpecifierSet() - specifier._specs = frozenset(self._specs | other._specs) - - if self._prereleases is None and other._prereleases is not None: - specifier._prereleases = other._prereleases - elif self._prereleases is not None and other._prereleases is None: - specifier._prereleases = self._prereleases - elif self._prereleases == other._prereleases: - specifier._prereleases = self._prereleases - else: - raise ValueError( - "Cannot combine SpecifierSets with True and False prerelease " - "overrides." - ) - - return specifier - - def __eq__(self, other): - if isinstance(other, string_types): - other = SpecifierSet(other) - elif isinstance(other, _IndividualSpecifier): - other = SpecifierSet(str(other)) - elif not isinstance(other, SpecifierSet): - return NotImplemented - - return self._specs == other._specs - - def __ne__(self, other): - if isinstance(other, string_types): - other = SpecifierSet(other) - elif isinstance(other, _IndividualSpecifier): - other = SpecifierSet(str(other)) - elif not isinstance(other, SpecifierSet): - return NotImplemented - - return self._specs != other._specs - - def __len__(self): - return len(self._specs) - - def __iter__(self): - return iter(self._specs) - - @property - def prereleases(self): - # If we have been given an explicit prerelease modifier, then we'll - # pass that through here. - if self._prereleases is not None: - return self._prereleases - - # If we don't have any specifiers, and we don't have a forced value, - # then we'll just return None since we don't know if this should have - # pre-releases or not. - if not self._specs: - return None - - # Otherwise we'll see if any of the given specifiers accept - # prereleases, if any of them do we'll return True, otherwise False. - return any(s.prereleases for s in self._specs) - - @prereleases.setter - def prereleases(self, value): - self._prereleases = value - - def __contains__(self, item): - return self.contains(item) - - def contains(self, item, prereleases=None): - # Ensure that our item is a Version or LegacyVersion instance. - if not isinstance(item, (LegacyVersion, Version)): - item = parse(item) - - # 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 - # SpecifierSet thinks for whether or not we should support prereleases. - if prereleases is None: - prereleases = self.prereleases - - # We can determine if we're going to allow pre-releases by looking to - # see if any of the underlying items supports them. If none of them do - # and this item is a pre-release then we do not allow it and we can - # short circuit that here. - # Note: This means that 1.0.dev1 would not be contained in something - # like >=1.0.devabc however it would be in >=1.0.debabc,>0.0.dev0 - if not prereleases and item.is_prerelease: - return False - - # We simply dispatch to the underlying specs here to make sure that the - # given version is contained within all of them. - # Note: This use of all() here means that an empty set of specifiers - # will always return True, this is an explicit design decision. - return all( - s.contains(item, prereleases=prereleases) - for s in self._specs - ) - - def filter(self, iterable, prereleases=None): - # 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 - # SpecifierSet thinks for whether or not we should support prereleases. - if prereleases is None: - prereleases = self.prereleases - - # If we have any specifiers, then we want to wrap our iterable in the - # filter method for each one, this will act as a logical AND amongst - # each specifier. - if self._specs: - for spec in self._specs: - iterable = spec.filter(iterable, prereleases=bool(prereleases)) - return iterable - # If we do not have any specifiers, then we need to have a rough filter - # which will filter out any pre-releases, unless there are no final - # releases, and which will filter out LegacyVersion in general. - else: - filtered = [] - found_prereleases = [] - - for item in iterable: - # Ensure that we some kind of Version class for this item. - if not isinstance(item, (LegacyVersion, Version)): - parsed_version = parse(item) - else: - parsed_version = item - - # Filter out any item which is parsed as a LegacyVersion - if isinstance(parsed_version, LegacyVersion): - continue - - # Store any item which is a pre-release for later unless we've - # already found a final version or we are accepting prereleases - if parsed_version.is_prerelease and not prereleases: - if not filtered: - found_prereleases.append(item) - else: - filtered.append(item) - - # If we've found no items except for pre-releases, then we'll go - # ahead and use the pre-releases - if not filtered and found_prereleases and prereleases is None: - return found_prereleases - - return filtered diff --git a/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/utils.py b/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/utils.py deleted file mode 100644 index 942387c..0000000 --- a/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/utils.py +++ /dev/null @@ -1,14 +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 re - - -_canonicalize_regex = re.compile(r"[-_.]+") - - -def canonicalize_name(name): - # This is taken from PEP 503. - return _canonicalize_regex.sub("-", name).lower() diff --git a/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/version.py b/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/version.py deleted file mode 100644 index 83b5ee8..0000000 --- a/venv/lib/python3.8/site-packages/pkg_resources/_vendor/packaging/version.py +++ /dev/null @@ -1,393 +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 collections -import itertools -import re - -from ._structures import Infinity - - -__all__ = [ - "parse", "Version", "LegacyVersion", "InvalidVersion", "VERSION_PATTERN" -] - - -_Version = collections.namedtuple( - "_Version", - ["epoch", "release", "dev", "pre", "post", "local"], -) - - -def parse(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 - a valid PEP 440 version or a legacy version. - """ - try: - return Version(version) - except InvalidVersion: - return LegacyVersion(version) - - -class InvalidVersion(ValueError): - """ - An invalid version was found, users should refer to PEP 440. - """ - - -class _BaseVersion(object): - - def __hash__(self): - return hash(self._key) - - def __lt__(self, other): - return self._compare(other, lambda s, o: s < o) - - def __le__(self, other): - return self._compare(other, lambda s, o: s <= o) - - def __eq__(self, other): - return self._compare(other, lambda s, o: s == o) - - def __ge__(self, other): - return self._compare(other, lambda s, o: s >= o) - - def __gt__(self, other): - return self._compare(other, lambda s, o: s > o) - - def __ne__(self, other): - return self._compare(other, lambda s, o: s != o) - - def _compare(self, other, method): - if not isinstance(other, _BaseVersion): - return NotImplemented - - return method(self._key, other._key) - - -class LegacyVersion(_BaseVersion): - - def __init__(self, version): - self._version = str(version) - self._key = _legacy_cmpkey(self._version) - - def __str__(self): - return self._version - - def __repr__(self): - return "".format(repr(str(self))) - - @property - def public(self): - return self._version - - @property - def base_version(self): - return self._version - - @property - def local(self): - return None - - @property - def is_prerelease(self): - return False - - @property - def is_postrelease(self): - return False - - -_legacy_version_component_re = re.compile( - r"(\d+ | [a-z]+ | \.| -)", re.VERBOSE, -) - -_legacy_version_replacement_map = { - "pre": "c", "preview": "c", "-": "final-", "rc": "c", "dev": "@", -} - - -def _parse_version_parts(s): - for part in _legacy_version_component_re.split(s): - part = _legacy_version_replacement_map.get(part, part) - - if not part or part == ".": - continue - - if part[:1] in "0123456789": - # pad for numeric comparison - yield part.zfill(8) - else: - yield "*" + part - - # ensure that alpha/beta/candidate are before final - yield "*final" - - -def _legacy_cmpkey(version): - # 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, - # which uses the defacto standard originally implemented by setuptools, - # as before all PEP 440 versions. - epoch = -1 - - # This scheme is taken from pkg_resources.parse_version setuptools prior to - # it's adoption of the packaging library. - parts = [] - for part in _parse_version_parts(version.lower()): - if part.startswith("*"): - # remove "-" before a prerelease tag - if part < "*final": - while parts and parts[-1] == "*final-": - parts.pop() - - # remove trailing zeros from each series of numeric parts - while parts and parts[-1] == "00000000": - parts.pop() - - parts.append(part) - parts = tuple(parts) - - return epoch, parts - -# Deliberately not anchored to the start and end of the string, to make it -# easier for 3rd party code to reuse -VERSION_PATTERN = r""" - v? - (?: - (?:(?P[0-9]+)!)? # epoch - (?P[0-9]+(?:\.[0-9]+)*) # release segment - (?P

                                          # pre-release
-            [-_\.]?
-            (?P(a|b|c|rc|alpha|beta|pre|preview))
-            [-_\.]?
-            (?P[0-9]+)?
-        )?
-        (?P                                         # post release
-            (?:-(?P[0-9]+))
-            |
-            (?:
-                [-_\.]?
-                (?Ppost|rev|r)
-                [-_\.]?
-                (?P[0-9]+)?
-            )
-        )?
-        (?P                                          # dev release
-            [-_\.]?
-            (?Pdev)
-            [-_\.]?
-            (?P[0-9]+)?
-        )?
-    )
-    (?:\+(?P[a-z0-9]+(?:[-_\.][a-z0-9]+)*))?       # local version
-"""
-
-
-class Version(_BaseVersion):
-
-    _regex = re.compile(
-        r"^\s*" + VERSION_PATTERN + r"\s*$",
-        re.VERBOSE | re.IGNORECASE,
-    )
-
-    def __init__(self, version):
-        # Validate the version and parse it into pieces
-        match = self._regex.search(version)
-        if not match:
-            raise InvalidVersion("Invalid version: '{0}'".format(version))
-
-        # Store the parsed out pieces of the version
-        self._version = _Version(
-            epoch=int(match.group("epoch")) if match.group("epoch") else 0,
-            release=tuple(int(i) for i in match.group("release").split(".")),
-            pre=_parse_letter_version(
-                match.group("pre_l"),
-                match.group("pre_n"),
-            ),
-            post=_parse_letter_version(
-                match.group("post_l"),
-                match.group("post_n1") or match.group("post_n2"),
-            ),
-            dev=_parse_letter_version(
-                match.group("dev_l"),
-                match.group("dev_n"),
-            ),
-            local=_parse_local_version(match.group("local")),
-        )
-
-        # Generate a key which will be used for sorting
-        self._key = _cmpkey(
-            self._version.epoch,
-            self._version.release,
-            self._version.pre,
-            self._version.post,
-            self._version.dev,
-            self._version.local,
-        )
-
-    def __repr__(self):
-        return "".format(repr(str(self)))
-
-    def __str__(self):
-        parts = []
-
-        # Epoch
-        if self._version.epoch != 0:
-            parts.append("{0}!".format(self._version.epoch))
-
-        # Release segment
-        parts.append(".".join(str(x) for x in self._version.release))
-
-        # Pre-release
-        if self._version.pre is not None:
-            parts.append("".join(str(x) for x in self._version.pre))
-
-        # Post-release
-        if self._version.post is not None:
-            parts.append(".post{0}".format(self._version.post[1]))
-
-        # Development release
-        if self._version.dev is not None:
-            parts.append(".dev{0}".format(self._version.dev[1]))
-
-        # Local version segment
-        if self._version.local is not None:
-            parts.append(
-                "+{0}".format(".".join(str(x) for x in self._version.local))
-            )
-
-        return "".join(parts)
-
-    @property
-    def public(self):
-        return str(self).split("+", 1)[0]
-
-    @property
-    def base_version(self):
-        parts = []
-
-        # Epoch
-        if self._version.epoch != 0:
-            parts.append("{0}!".format(self._version.epoch))
-
-        # Release segment
-        parts.append(".".join(str(x) for x in self._version.release))
-
-        return "".join(parts)
-
-    @property
-    def local(self):
-        version_string = str(self)
-        if "+" in version_string:
-            return version_string.split("+", 1)[1]
-
-    @property
-    def is_prerelease(self):
-        return bool(self._version.dev or self._version.pre)
-
-    @property
-    def is_postrelease(self):
-        return bool(self._version.post)
-
-
-def _parse_letter_version(letter, number):
-    if letter:
-        # We consider there to be an implicit 0 in a pre-release if there is
-        # not a numeral associated with it.
-        if number is None:
-            number = 0
-
-        # We normalize any letters to their lower case form
-        letter = letter.lower()
-
-        # We consider some words to be alternate spellings of other words and
-        # in those cases we want to normalize the spellings to our preferred
-        # spelling.
-        if letter == "alpha":
-            letter = "a"
-        elif letter == "beta":
-            letter = "b"
-        elif letter in ["c", "pre", "preview"]:
-            letter = "rc"
-        elif letter in ["rev", "r"]:
-            letter = "post"
-
-        return letter, int(number)
-    if not letter and number:
-        # We assume if we are given a number, but we are not given a letter
-        # then this is using the implicit post release syntax (e.g. 1.0-1)
-        letter = "post"
-
-        return letter, int(number)
-
-
-_local_version_seperators = re.compile(r"[\._-]")
-
-
-def _parse_local_version(local):
-    """
-    Takes a string like abc.1.twelve and turns it into ("abc", 1, "twelve").
-    """
-    if local is not None:
-        return tuple(
-            part.lower() if not part.isdigit() else int(part)
-            for part in _local_version_seperators.split(local)
-        )
-
-
-def _cmpkey(epoch, release, pre, post, dev, local):
-    # 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
-    # leading zeros until we come to something non zero, then take the rest
-    # re-reverse it back into the correct order and make it a tuple and use
-    # that for our sorting key.
-    release = tuple(
-        reversed(list(
-            itertools.dropwhile(
-                lambda x: x == 0,
-                reversed(release),
-            )
-        ))
-    )
-
-    # We need to "trick" the sorting algorithm to put 1.0.dev0 before 1.0a0.
-    # We'll do this by abusing the pre segment, but we _only_ want to do this
-    # 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 = -Infinity
-    # Versions without a pre-release (except as noted above) should sort after
-    # those with one.
-    elif pre is None:
-        pre = Infinity
-
-    # Versions without a post segment should sort before those with one.
-    if post is None:
-        post = -Infinity
-
-    # Versions without a development segment should sort after those with one.
-    if dev is None:
-        dev = Infinity
-
-    if local is None:
-        # Versions without a local segment should sort before those with one.
-        local = -Infinity
-    else:
-        # Versions with a local segment need that segment parsed to implement
-        # the sorting rules in PEP440.
-        # - Alpha numeric segments sort before numeric segments
-        # - Alpha numeric segments sort lexicographically
-        # - Numeric segments sort numerically
-        # - Shorter versions sort before longer versions when the prefixes
-        #   match exactly
-        local = tuple(
-            (i, "") if isinstance(i, int) else (-Infinity, i)
-            for i in local
-        )
-
-    return epoch, release, pre, post, dev, local
diff --git a/venv/lib/python3.8/site-packages/pkg_resources/_vendor/pyparsing.py b/venv/lib/python3.8/site-packages/pkg_resources/_vendor/pyparsing.py
deleted file mode 100644
index cf75e1e..0000000
--- a/venv/lib/python3.8/site-packages/pkg_resources/_vendor/pyparsing.py
+++ /dev/null
@@ -1,5742 +0,0 @@
-# module pyparsing.py
-#
-# Copyright (c) 2003-2018  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 
-C{", !"}), built up using L{Word}, L{Literal}, and L{And} elements 
-(L{'+'} operator gives L{And} expressions, strings are auto-converted to
-L{Literal} expressions)::
-
-    from 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 L{ParseResults} object returned from L{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 L{ParserElement} and L{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 L{Literal} and L{CaselessLiteral} classes
- - construct character word-group expressions using the L{Word} class
- - see how to create repetitive expressions using L{ZeroOrMore} and L{OneOrMore} classes
- - use L{'+'}, L{'|'}, L{'^'}, and L{'&'} operators to combine simple expressions into more complex ones
- - associate names with your parsed results using L{ParserElement.setResultsName}
- - find some helpful expression short-cuts like L{delimitedList} and L{oneOf}
- - find more useful common expressions in the L{pyparsing_common} namespace class
-"""
-
-__version__ = "2.2.1"
-__versionTime__ = "18 Sep 2018 00:49 UTC"
-__author__ = "Paul McGuire "
-
-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
-
-try:
-    from _thread import RLock
-except ImportError:
-    from threading import RLock
-
-try:
-    # Python 3
-    from collections.abc import Iterable
-    from collections.abc import MutableMapping
-except ImportError:
-    # Python 2.7
-    from collections import Iterable
-    from collections import MutableMapping
-
-try:
-    from collections import OrderedDict as _OrderedDict
-except ImportError:
-    try:
-        from ordereddict import OrderedDict as _OrderedDict
-    except ImportError:
-        _OrderedDict = None
-
-#~ sys.stderr.write( "testing pyparsing module, version %s, %s\n" % (__version__,__versionTime__ ) )
-
-__all__ = [
-'And', 'CaselessKeyword', 'CaselessLiteral', 'CharsNotIn', 'Combine', 'Dict', 'Each', 'Empty',
-'FollowedBy', 'Forward', 'GoToColumn', 'Group', 'Keyword', 'LineEnd', 'LineStart', 'Literal',
-'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',
-'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',
-]
-
-system_version = tuple(sys.version_info)[:3]
-PY_3 = system_version[0] == 3
-if PY_3:
-    _MAX_INT = sys.maxsize
-    basestring = str
-    unichr = chr
-    _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
-
-class _Constants(object):
-    pass
-
-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)
-
-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 ):
-        return "%s (at char %d), (line:%d, col:%d)" % \
-                ( self.msg, 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
-    """
-    pass
-
-class ParseFatalException(ParseBaseException):
-    """user-throwable exception thrown when inconsistent parse content
-       is found; stops all parsing immediately"""
-    pass
-
-class ParseSyntaxException(ParseFatalException):
-    """just like L{ParseFatalException}, but thrown internally when an
-       L{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 L{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 (C{len(results)})
-       - by list index (C{results[0], results[1]}, etc.)
-       - by attribute (C{results.} - see L{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(toklist.copy(),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 (Python 3.x only)."""
-
-        values = _itervalues
-        """Returns an iterator of all named result values (Python 3.x only)."""
-
-        items = _iteritems
-        """Returns an iterator of all named result key-value tuples (Python 3.x only)."""
-
-    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=C{last}).
-        Supports both C{list} and C{dict} semantics for C{pop()}. If passed no
-        argument or an integer argument, it will use C{list} semantics
-        and pop tokens from the list of parsed tokens. If passed a 
-        non-integer argument (most likely a string), it will use C{dict}
-        semantics and pop the corresponding value from any defined 
-        results names. A second default return value argument is 
-        supported, just as in C{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 C{defaultValue} or C{None} if no
-        C{defaultValue} is specified.
-
-        Similar to C{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 C{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 += 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 ""
-            
-        if name in self.__tokdict:
-            if name not in self.__accumNames:
-                return self.__tokdict[name][-1][0]
-            else:
-                return ParseResults([ v[0] for v in self.__tokdict[name] ])
-        else:
-            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) # ->  ['sldkj', 'lsdkj', 'sldkj']
-            
-            # Use asList() to create an actual list
-            result_list = result.asList()
-            print(type(result_list), result_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)) # ->  (['12', '/', '31', '/', '1999'], {'day': [('1999', 4)], 'year': [('12', 0)], 'month': [('31', 2)]})
-            
-            result_dict = result.asDict()
-            print(type(result_dict), repr(result_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 C{ParseResults} object.
-        """
-        ret = ParseResults( self.__toklist )
-        ret.__tokdict = self.__tokdict.copy()
-        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,
-                                                "" ]
-
-        out += [ nl, indent, "" ]
-        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='', depth=0, full=True):
-        """
-        Diagnostic method for listing out the contents of a C{ParseResults}.
-        Accepts an optional C{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'
-        out.append( indent+_ustr(self.asList()) )
-        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,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,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 C{pprint} module.
-        Accepts additional positional or keyword args as defined for the 
-        C{pprint.pprint} method. (U{http://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()))
-
-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 L{I{ParserElement.parseString}} for more information
-   on parsing strings containing C{}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} for more information
-   on parsing strings containing C{}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:
-                        del tb
-
-                if limit[0] <= maxargs:
-                    limit[0] += 1
-                    continue
-                raise
-
-    # copy func name to wrapper for sensible debug output
-    func_name = ""
-    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,  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
-
-    def __init__( self, savelist=False ):
-        self.parseAction = list()
-        self.failAction = None
-        #~ self.name = ""  # don't define self.name, let subclasses try/except upcall
-        self.strRepr = None
-        self.resultsName = None
-        self.saveAsList = savelist
-        self.skipWhitespace = True
-        self.whiteChars = 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 C{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 C{expr.copy()} is just C{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 hasattr(self,"exception"):
-            self.exception.msg = self.errmsg
-        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 C{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,
-        C{expr("name")} in place of C{expr.setResultsName("name")} - 
-        see L{I{__call__}<__call__>}.
-
-        Example::
-            date_str = (integer.setResultsName("year") + '/' 
-                        + integer.setResultsName("month") + '/' 
-                        + integer.setResultsName("day"))
-
-            # equivalent form:
-            date_str = integer("year") + '/' + integer("month") + '/' + integer("day")
-        """
-        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 C{breakFlag} to True to enable, False to
-           disable.
-        """
-        if breakFlag:
-            _parseMethod = self._parse
-            def breaker(instring, loc, doActions=True, callPreParse=True):
-                import pdb
-                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 C{fn(s,loc,toks)},
-        C{fn(loc,toks)}, C{fn(toks)}, or just C{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 C{L{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.
-
-        Optional keyword arguments:
-         - callDuringTry = (default=C{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 L{I{parseString}} for more information
-        on parsing strings containing C{}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]
-        """
-        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 L{I{setParseAction}}.
-        
-        See examples in L{I{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 
-        L{I{setParseAction}} for function call signatures. Unlike C{setParseAction}, 
-        functions passed to C{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)
-        """
-        msg = kwargs.get("message", "failed user-defined condition")
-        exc_type = ParseFatalException if kwargs.get("fatal", False) else ParseException
-        for fn in fns:
-            def pa(s,l,t):
-                if not bool(_trim_arity(fn)(s,l,t)):
-                    raise exc_type(s,l,msg)
-            self.parseAction.append(pa)
-        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
-           C{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 C{L{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 ):
-        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[0] ):
-                self.debugActions[0]( instring, loc, self )
-            if callPreParse and self.callPreparse:
-                preloc = self.preParse( instring, loc )
-            else:
-                preloc = loc
-            tokensStart = preloc
-            try:
-                try:
-                    loc,tokens = self.parseImpl( instring, preloc, doActions )
-                except IndexError:
-                    raise ParseException( instring, len(instring), self.errmsg, self )
-            except ParseBaseException as err:
-                #~ print ("Exception raised:", err)
-                if self.debugActions[2]:
-                    self.debugActions[2]( 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:
-                        tokens = fn( instring, tokensStart, retTokens )
-                        if tokens is not None:
-                            retTokens = ParseResults( tokens,
-                                                      self.resultsName,
-                                                      asList=self.saveAsList and isinstance(tokens,(ParseResults,list)),
-                                                      modal=self.modalResults )
-                except ParseBaseException as err:
-                    #~ print "Exception raised in user parse action:", err
-                    if (self.debugActions[2] ):
-                        self.debugActions[2]( instring, tokensStart, self, err )
-                    raise
-            else:
-                for fn in self.parseAction:
-                    tokens = fn( instring, tokensStart, retTokens )
-                    if tokens is not None:
-                        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[1] ):
-                self.debugActions[1]( 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=C{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 C{ParserElement.enablePackrat()}.  If
-           your program uses C{psyco} to "compile as you go", you must call
-           C{enablePackrat} before calling C{psyco.full()}.  If you do not do this,
-           Python will crash.  For best results, call C{enablePackrat()} immediately
-           after importing pyparsing.
-           
-           Example::
-               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.
-
-        If you want the grammar to require that the entire input string be
-        successfully parsed, then set C{parseAll} to True (equivalent to ending
-        the grammar with C{L{StringEnd()}}).
-
-        Note: C{parseString} implicitly calls C{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 C{loc} argument to index into the
-        string being parsed, you can ensure you have a consistent view of the input
-        string by:
-         - calling C{parseWithTabs} on your grammar before calling C{parseString}
-           (see L{I{parseWithTabs}})
-         - define your parse action using the full C{(s,loc,toks)} signature, and
-           reference the input string using the parse action's C{s} argument
-         - explictly expand the tabs in your input string before calling
-           C{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, clears out pyparsing internal stack trace
-                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
-        C{maxMatches} argument, to clip scanning after 'n' matches are found.  If
-        C{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 L{I{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, clears out pyparsing internal stack trace
-                raise exc
-
-    def transformString( self, instring ):
-        """
-        Extension to C{L{scanString}}, to modify matching text with modified tokens that may
-        be returned from a parse action.  To use C{transformString}, define a grammar and
-        attach a parse action to it that modifies the returned token list.
-        Invoking C{transformString()} on a target string will then scan for matches,
-        and replace the matched text patterns according to the logic in the parse
-        action.  C{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 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, clears out pyparsing internal stack trace
-                raise exc
-
-    def searchString( self, instring, maxMatches=_MAX_INT ):
-        """
-        Another extension to C{L{scanString}}, simplifying the access to the tokens found
-        to match the given parse expression.  May be called with optional
-        C{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, clears out pyparsing internal stack trace
-                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 C{maxsplit} argument, to limit the number of splits;
-        and the optional C{includeSeparators} argument (default=C{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 C{L{And}}. Adding strings to a ParserElement
-        converts them to L{Literal}s by default.
-        
-        Example::
-            greet = Word(alphas) + "," + Word(alphas) + "!"
-            hello = "Hello, World!"
-            print (hello, "->", greet.parseString(hello))
-        Prints::
-            Hello, World! -> ['Hello', ',', 'World', '!']
-        """
-        if isinstance( other, basestring ):
-            other = ParserElement._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 C{L{ParserElement}}
-        """
-        if isinstance( other, basestring ):
-            other = ParserElement._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 C{L{And}} with error stop
-        """
-        if isinstance( other, basestring ):
-            other = ParserElement._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 C{L{ParserElement}}
-        """
-        if isinstance( other, basestring ):
-            other = ParserElement._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 C{expr * 3} in place of
-        C{expr + expr + expr}.  Expressions may also me multiplied by a 2-integer
-        tuple, similar to C{{min,max}} multipliers in regular expressions.  Tuples
-        may also include C{None} as in:
-         - C{expr*(n,None)} or C{expr*(n,)} is equivalent
-              to C{expr*n + L{ZeroOrMore}(expr)}
-              (read as "at least n instances of C{expr}")
-         - C{expr*(None,n)} is equivalent to C{expr*(0,n)}
-              (read as "0 to n instances of C{expr}")
-         - C{expr*(None,None)} is equivalent to C{L{ZeroOrMore}(expr)}
-         - C{expr*(1,None)} is equivalent to C{L{OneOrMore}(expr)}
-
-        Note that C{expr*(None,n)} does not raise an exception if
-        more than n exprs exist in the input stream; that is,
-        C{expr*(None,n)} does not enforce a maximum number of expr
-        occurrences.  If this behavior is desired, then write
-        C{expr*(None,n) + ~expr}
-        """
-        if isinstance(other,int):
-            minElements, optElements = other,0
-        elif isinstance(other,tuple):
-            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 C{L{MatchFirst}}
-        """
-        if isinstance( other, basestring ):
-            other = ParserElement._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 C{L{ParserElement}}
-        """
-        if isinstance( other, basestring ):
-            other = ParserElement._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 C{L{Or}}
-        """
-        if isinstance( other, basestring ):
-            other = ParserElement._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 C{L{ParserElement}}
-        """
-        if isinstance( other, basestring ):
-            other = ParserElement._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 C{L{Each}}
-        """
-        if isinstance( other, basestring ):
-            other = ParserElement._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 C{L{ParserElement}}
-        """
-        if isinstance( other, basestring ):
-            other = ParserElement._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 C{L{NotAny}}
-        """
-        return NotAny( self )
-
-    def __call__(self, name=None):
-        """
-        Shortcut for C{L{setResultsName}}, with C{listAllMatches=False}.
-        
-        If C{name} is given with a trailing C{'*'} character, then C{listAllMatches} will be
-        passed as C{True}.
-           
-        If C{name} is omitted, same as calling C{L{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 C{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
-        C{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 C{}s to spaces before parsing the input string.
-        Must be called before C{parseString} when the input grammar contains elements that
-        match C{} 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 C{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 L{setDebugActions}. Prior to attempting
-        to match the C{wd} expression, the debugging message C{"Match  at loc (,)"}
-        is shown. Then if the parse succeeds, a C{"Matched"} message is shown, or an C{"Exception raised"}
-        message is shown. Also note the use of L{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 C{Word} expression without calling C{setName} is C{"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=[] ):
-        """
-        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, clears out pyparsing internal stack trace
-                raise exc
-
-    def __eq__(self,other):
-        if isinstance(other, ParserElement):
-            return self is other or vars(self) == vars(other)
-        elif isinstance(other, basestring):
-            return self.matches(other)
-        else:
-            return super(ParserElement,self)==other
-
-    def __ne__(self,other):
-        return not (self == other)
-
-    def __hash__(self):
-        return hash(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=C{True}) - flag to pass to C{L{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):
-        """
-        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=C{True}) - flag to pass to C{L{parseString}} when running tests           
-         - comment - (default=C{'#'}) - expression for indicating embedded comments in the test 
-              string; pass None to disable comment filtering
-         - fullDump - (default=C{True}) - dump results as list followed by results names in nested outline;
-              if False, only dump nested list
-         - printResults - (default=C{True}) prints test output to stdout
-         - failureTests - (default=C{False}) indicates if these tests are expected to fail parsing
-
-        Returns: a (success, results) tuple, where success indicates that all tests succeeded
-        (or failed if C{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)
-        allResults = []
-        comments = []
-        success = True
-        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'.join(comments), t]
-            comments = []
-            try:
-                t = t.replace(r'\n','\n')
-                result = self.parseString(t, parseAll=parseAll)
-                out.append(result.dump(full=fullDump))
-                success = success and not failureTests
-            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
-
-            if printResults:
-                if fullDump:
-                    out.append('')
-                print('\n'.join(out))
-
-            allResults.append((t, result))
-        
-        return success, allResults
-
-        
-class Token(ParserElement):
-    """
-    Abstract C{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 L{CaselessLiteral}.
-    
-    For keyword matching (force word break before and after the matched string),
-    use L{Keyword} or L{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: this routine gets called a *lot*
-    # if this is a single character match string  and the first character matches,
-    # short-circuit as quickly as possible, and avoid calling startswith
-    #~ @profile
-    def parseImpl( self, instring, loc, doActions=True ):
-        if (instring[loc] == self.firstMatchChar and
-            (self.matchLen==1 or instring.startswith(self.match,loc)) ):
-            return loc+self.matchLen, 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 C{L{Literal}}:
-     - C{Literal("if")} will match the leading C{'if'} in C{'ifAndOnlyIf'}.
-     - C{Keyword("if")} will not; it will only match the leading C{'if'} in C{'if x=1'}, or C{'if(y==2)'}
-    Accepts two optional constructor arguments in addition to the keyword string:
-     - C{identChars} is a string of characters that would be valid identifier characters,
-          defaulting to all alphanumerics + "_" and "$"
-     - C{caseless} allows case-insensitive matching, default is C{False}.
-       
-    Example::
-        Keyword("start").parseString("start")  # -> ['start']
-        Keyword("start").parseString("starting")  # -> Exception
-
-    For case-insensitive matching, use L{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 and
-                (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 L{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 L{Keyword}.
-
-    Example::
-        OneOrMore(CaselessKeyword("CMD")).parseString("cmd CMD Cmd10") # -> ['CMD', 'CMD']
-        
-    (Contrast with example for L{CaselessLiteral}.)
-    """
-    def __init__( self, matchString, identChars=None ):
-        super(CaselessKeyword,self).__init__( matchString, identChars, caseless=True )
-
-    def parseImpl( self, instring, loc, doActions=True ):
-        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) ):
-            return loc+self.matchLen, self.match
-        raise ParseException(instring, loc, self.errmsg, self)
-
-class CloseMatch(Token):
-    """
-    A variation on L{Literal} which matches "close" matches, that is, 
-    strings with at most 'n' mismatching characters. C{CloseMatch} takes parameters:
-     - C{match_string} - string to be matched
-     - C{maxMismatches} - (C{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:
-     - C{mismatches} - a list of the positions within the match_string where mismatches were found
-     - C{original} - the original match_string used to compare against the input string
-    
-    If C{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], self.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'] = self.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 C{min} is 1 (a
-    minimum value < 1 is not valid); the default values for C{max} and C{exact}
-    are 0, meaning no maximum or exact length restriction. An optional
-    C{excludeChars} parameter can list characters that might be found in 
-    the input C{bodyChars} string; useful to define a word of all printables
-    except for one or two characters, for instance.
-    
-    L{srange} is useful for defining custom character set strings for defining 
-    C{Word} expressions, using range notation from regular expression character sets.
-    
-    A common mistake is to use C{Word} to match a specific literal string, as in 
-    C{Word("Address")}. Remember that C{Word} uses the string argument to define
-    I{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 L{Literal} or L{Keyword}.
-
-    pyparsing includes helper strings for building Words:
-     - L{alphas}
-     - L{nums}
-     - L{alphanums}
-     - L{hexnums}
-     - L{alphas8bit} (alphabetic characters in ASCII range 128-255 - accented, tilded, umlauted, etc.)
-     - L{punc8bit} (non-alphabetic characters in ASCII range 128-255 - currency, symbols, superscripts, diacriticals, etc.)
-     - L{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:
-            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
-
-    def parseImpl( self, instring, loc, doActions=True ):
-        if self.re:
-            result = self.re.match(instring,loc)
-            if not result:
-                raise ParseException(instring, loc, self.errmsg, self)
-
-            loc = result.end()
-            return loc, result.group()
-
-        if not(instring[ loc ] 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
-        if self.maxSpecified and loc < instrlen and instring[loc] in bodychars:
-            throwException = True
-        if self.asKeyword:
-            if (start>0 and instring[start-1] in bodychars) or (loc4:
-                    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 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 inbuilt Python re module.
-    If the given regex contains named groups (defined using C{(?P...)}), these will be preserved as 
-    named parse results.
-
-    Example::
-        realnum = Regex(r"[+-]?\d+\.\d*")
-        date = Regex(r'(?P\d{4})-(?P\d\d?)-(?P\d\d?)')
-        # ref: http://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?C{0,3})(XC|XL|L?X{0,3})(IX|IV|V?I{0,3})")
-    """
-    compiledREtype = type(re.compile("[A-Z]"))
-    def __init__( self, pattern, flags=0):
-        """The parameters C{pattern} and C{flags} are passed to the C{re.compile()} function as-is. See the Python C{re} 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 isinstance(pattern, Regex.compiledREtype):
-            self.re = pattern
-            self.pattern = \
-            self.reString = str(pattern)
-            self.flags = flags
-            
-        else:
-            raise ValueError("Regex may only be constructed with a string or a compiled RE object")
-
-        self.name = _ustr(self)
-        self.errmsg = "Expected " + self.name
-        self.mayIndexError = False
-        self.mayReturnEmpty = True
-
-    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()
-        d = result.groupdict()
-        ret = ParseResults(result.group())
-        if d:
-            for k in d:
-                ret[k] = d[k]
-        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
-
-
-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=C{None})
-        - escQuote - special quote sequence to escape an embedded quote string (such as SQL's "" to escape an embedded ") (default=C{None})
-        - multiline - boolean indicating whether quotes can span multiple lines (default=C{False})
-        - unquoteResults - boolean indicating whether the matched text should be unquoted (default=C{True})
-        - endQuoteChar - string of one or more characters defining the end of the quote delimited string (default=C{None} => same as quoteChar)
-        - convertWhitespaceEscapes - convert escaped whitespace (C{'\t'}, C{'\n'}, etc.) to actual whitespace (default=C{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
-        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 I{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 C{min} is 1 (a
-    minimum value < 1 is not valid); the default values for C{max} and C{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 C{" \\t\\r\\n"}.  Also takes optional C{min}, C{max}, and C{exact} arguments,
-    as defined for the C{L{Word}} class.
-    """
-    whiteStrs = {
-        " " : "",
-        "\t": "",
-        "\n": "",
-        "\r": "",
-        "\f": "",
-        }
-    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 not(instring[ loc ] 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):
-    """
-    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):
-            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 C{wordChars}
-    (default=C{printables}). To emulate the C{\b} behavior of regular expressions,
-    use C{WordStart(alphanums)}. C{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 C{wordChars}
-    (default=C{printables}). To emulate the C{\b} behavior of regular expressions,
-    use C{WordEnd(alphanums)}. C{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 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:
-            matches.sort(key=lambda x: -x[0])
-            for _,e in matches:
-                try:
-                    return e._parse( instring, loc, doActions )
-                except ParseException as err:
-                    err.__traceback__ = None
-                    if err.loc > maxExcLoc:
-                        maxException = err
-                        maxExcLoc = err.loc
-
-        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 = ParserElement._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 )
-
-
-class MatchFirst(ParseExpression):
-    """
-    Requires that at least one C{ParseExpression} is found.
-    If two expressions match, the first one listed is the one that will match.
-    May be constructed using the C{'|'} 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 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 = ParserElement._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 )
-
-
-class Each(ParseExpression):
-    """
-    Requires all given C{ParseExpression}s to be found, but in any order.
-    Expressions may be separated by whitespace.
-    May be constructed using the C{'&'} 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
-
-    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)]
-            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 C{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(ParserElement._literalStringClass, Token):
-                expr = ParserElement._literalStringClass(expr)
-            else:
-                expr = ParserElement._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=[] ):
-        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.  C{FollowedBy}
-    does I{not} advance the parsing position within the input string, it only
-    verifies that the specified parse expression matches at the current
-    position.  C{FollowedBy} always returns a null token list.
-
-    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 ):
-        self.expr.tryParse( instring, loc )
-        return loc, []
-
-
-class NotAny(ParseElementEnhance):
-    """
-    Lookahead to disallow matching with the given parse expression.  C{NotAny}
-    does I{not} advance the parsing position within the input string, it only
-    verifies that the specified parse expression does I{not} match at the current
-    position.  Also, C{NotAny} does I{not} skip over leading whitespace. C{NotAny}
-    always returns a null token list.  May be constructed using the '~' operator.
-
-    Example::
-        
-    """
-    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 = ParserElement._literalStringClass(ender)
-        self.not_ender = ~ender if ender is not None else None
-
-    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
-        
-class OneOrMore(_MultipleMatch):
-    """
-    Repetition of one or more of the given expression.
-    
-    Parameters:
-     - expr - expression that must match one or more times
-     - stopOn - (default=C{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=C{None}) - expression for a terminating sentinel
-          (only required if the sentinel would ordinarily match the repetition 
-          expression)          
-
-    Example: similar to L{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 ""
-
-_optionalNotMatched = _NullToken()
-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)
-    """
-    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 _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=C{False}) if True, the target expression is also parsed 
-          (the skipped text and target expression are returned as a 2-element list).
-     - ignore - (default=C{None}) used to define grammars (typically quoted strings and 
-          comments) that might contain false matches to the target expression
-     - failOn - (default=C{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.asList = False
-        if isinstance(failOn, basestring):
-            self.failOn = ParserElement._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 C{Forward} variable using the '<<' operator.
-
-    Note: take care when assigning to C{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 C{Forward}::
-        fwdExpr << (a | b | c)
-    Converting to use the '<<=' operator instead will avoid this problem.
-
-    See L{ParseResults.pprint} for an example of a recursive parser created using
-    C{Forward}.
-    """
-    def __init__( self, other=None ):
-        super(Forward,self).__init__( other, savelist=False )
-
-    def __lshift__( self, other ):
-        if isinstance( other, basestring ):
-            other = ParserElement._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=[] ):
-        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
-        return self.__class__.__name__ + ": ..."
-
-        # stubbed out for now - creates awful memory and perf issues
-        self._revertClass = self.__class__
-        self.__class__ = _ForwardNoRecurse
-        try:
-            if self.expr is not None:
-                retString = _ustr(self.expr)
-            else:
-                retString = "None"
-        finally:
-            self.__class__ = self._revertClass
-        return self.__class__.__name__ + ": " + retString
-
-    def copy(self):
-        if self.expr is not None:
-            return super(Forward,self).copy()
-        else:
-            ret = Forward()
-            ret <<= self
-            return ret
-
-class _ForwardNoRecurse(Forward):
-    def __str__( self ):
-        return "..."
-
-class TokenConverter(ParseElementEnhance):
-    """
-    Abstract subclass of C{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 C{'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 C{L{ZeroOrMore}} and C{L{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 L{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 L{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 C{">> entering I{method-name}(line:I{current_source_line}, I{parse_location}, I{matched_tokens})".}
-    When the parse action completes, the decorator will print C{"<<"} 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'], {}))
-        <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( "< ['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 C{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 C{"1:1"}, but not C{"1:2"}.  Because this matches a
-    previous literal, will also match the leading C{"1:1"} in C{"1:10"}.
-    If this is not desired, use C{matchPreviousExpr}.
-    Do I{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 C{"1:1"}, but not C{"1:2"}.  Because this matches by
-    expressions, will I{not} match the leading C{"1:1"} in C{"1:10"};
-    the expressions are evaluated first, and then compared, so
-    C{"1"} is compared with C{"10"}.
-    Do I{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 ):
-    """
-    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 C{L{MatchFirst}} for best performance.
-
-    Parameters:
-     - strs - a string of space-delimited literals, or a collection of string literals
-     - caseless - (default=C{False}) - treat all literals as caseless
-     - useRegex - (default=C{True}) - as an optimization, will generate a Regex
-          object; otherwise, will generate a C{MatchFirst} object (if C{caseless=True}, or
-          if creating a C{Regex} raises an exception)
-
-    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 caseless:
-        isequal = ( lambda a,b: a.upper() == b.upper() )
-        masks = ( lambda a,b: b.upper().startswith(a.upper()) )
-        parseElementClass = CaselessLiteral
-    else:
-        isequal = ( lambda a,b: a == b )
-        masks = ( lambda a,b: b.startswith(a) )
-        parseElementClass = 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()
-
-    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)
-                cur = other
-                break
-        else:
-            i += 1
-
-    if not caseless 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 C{L{Dict}}, C{L{ZeroOrMore}}, and C{L{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 C{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( ZeroOrMore( 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 C{asString} argument is passed as C{False}, then the return value is a 
-    C{L{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 C{L{originalTextFor}} contains expressions with defined
-    results names, you must set C{asString} to C{False} if you want to preserve those
-    results name values.
-
-    Example::
-        src = "this is test  bold text  normal text "
-        for tag in ("b","i"):
-            opener,closer = makeHTMLTags(tag)
-            patt = originalTextFor(opener + SkipTo(closer) + closer)
-            print(patt.searchString(src)[0])
-    prints::
-        [' bold text ']
-        ['text']
-    """
-    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).setParseAction(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 C{} characters, you may want to call
-    C{L{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 C{\-} or C{\]})
-     - an escaped hex character with a leading C{'\x'} (C{\x21}, which is a C{'!'} character) 
-         (C{\0x##} is also supported for backwards compatibility) 
-     - an escaped octal character with a leading C{'\0'} (C{\041}, which is a C{'!'} character)
-     - a range of any of the above, separated by a dash (C{'a-z'}, etc.)
-     - any combination of the above (C{'aeiouy'}, C{'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 C{L{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 C{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 L{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 L{pyparsing_common.upcaseTokens}"""
-
-downcaseTokens = tokenMap(lambda t: _ustr(t).lower())
-"""(Deprecated) Helper parse action to convert tokens to lower case. Deprecated in favor of L{pyparsing_common.downcaseTokens}"""
-    
-def _makeTags(tagStr, xml):
-    """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("<") + tagStr("tag") + \
-                Dict(ZeroOrMore(Group( tagAttrName + Suppress("=") + tagAttrValue ))) + \
-                Optional("/",default=[False]).setResultsName("empty").setParseAction(lambda s,l,t:t[0]=='/') + Suppress(">")
-    else:
-        printablesLessRAbrack = "".join(c for c in printables if c not in ">")
-        tagAttrValue = quotedString.copy().setParseAction( removeQuotes ) | Word(printablesLessRAbrack)
-        openTag = Suppress("<") + tagStr("tag") + \
-                Dict(ZeroOrMore(Group( tagAttrName.setParseAction(downcaseTokens) + \
-                Optional( Suppress("=") + tagAttrValue ) ))) + \
-                Optional("/",default=[False]).setResultsName("empty").setParseAction(lambda s,l,t:t[0]=='/') + Suppress(">")
-    closeTag = Combine(_L("")
-
-    openTag = openTag.setResultsName("start"+"".join(resname.replace(":"," ").title().split())).setName("<%s>" % resname)
-    closeTag = closeTag.setResultsName("end"+"".join(resname.replace(":"," ").title().split())).setName("" % resname)
-    openTag.tag = resname
-    closeTag.tag = resname
-    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 = 'More info at the pyparsing wiki page'
-        # 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  tag (like "href" shown here) are also accessible as named results
-            print(link.link_text, '->', link.href)
-    prints::
-        pyparsing -> http://pyparsing.wikispaces.com
-    """
-    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 L{makeHTMLTags}
-    """
-    return _makeTags( tagStr, True )
-
-def withAttribute(*args,**attrDict):
-    """
-    Helper to create a validating parse action to be used with start tags created
-    with C{L{makeXMLTags}} or C{L{makeHTMLTags}}. Use C{withAttribute} to qualify a starting tag
-    with a required attribute value, to avoid false matches on common tags such as
-    C{} or C{
}. - - Call C{withAttribute} with a series of attribute names and values. Specify the list - of filter attributes names and values as: - - keyword arguments, as in C{(align="right")}, or - - as an explicit dict with C{**} operator, when an attribute name is also a Python - reserved word, as in C{**{"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 C{class} (with or without a namespace), use C{L{withClass}}. - - To verify that the attribute exists, but without specifying a value, pass - C{withAttribute.ANY_VALUE} as the value. - - Example:: - html = ''' -
- Some text -
1 4 0 1 0
-
1,3 2,3 1,1
-
this has no type
-
- - ''' - 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 C{L{withAttribute}} when matching on a div class - made - difficult because C{class} is a reserved word in Python. - - Example:: - html = ''' -
- Some text -
1 4 0 1 0
-
1,3 2,3 1,1
-
this <div> has no class
-
- - ''' - 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 = _Constants() -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 L{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 C{opAssoc.RIGHT} and C{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 C{setParseAction(*fn)} (L{ParserElement.setParseAction}) - - lpar - expression for matching left-parentheses (default=C{Suppress('(')}) - - rpar - expression for matching right-parentheses (default=C{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]]] - """ - 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 = FollowedBy(lastExpr + opExpr) + Group( lastExpr + OneOrMore( opExpr ) ) - elif arity == 2: - if opExpr is not None: - matchExpr = FollowedBy(lastExpr + opExpr + lastExpr) + Group( lastExpr + OneOrMore( opExpr + lastExpr ) ) - else: - matchExpr = FollowedBy(lastExpr+lastExpr) + Group( lastExpr + OneOrMore(lastExpr) ) - elif arity == 3: - matchExpr = FollowedBy(lastExpr + opExpr1 + lastExpr + opExpr2 + lastExpr) + \ - Group( lastExpr + 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 = FollowedBy(opExpr.expr + thisExpr) + Group( opExpr + thisExpr ) - elif arity == 2: - if opExpr is not None: - matchExpr = FollowedBy(lastExpr + opExpr + thisExpr) + Group( lastExpr + OneOrMore( opExpr + thisExpr ) ) - else: - matchExpr = FollowedBy(lastExpr + thisExpr) + Group( lastExpr + OneOrMore( thisExpr ) ) - elif arity == 3: - matchExpr = FollowedBy(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 C{L{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=C{"("}); can also be a pyparsing expression - - closer - closing character for a nested list (default=C{")"}); can also be a pyparsing expression - - content - expression for items within the nested lists (default=C{None}) - - ignoreExpr - expression for ignoring opening and closing delimiters (default=C{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 C{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 C{L{Or}} or C{L{MatchFirst}}. - The default is L{quotedString}, but if no expressions are to be ignored, - then pass C{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 - the current level; set to False for block of left-most statements - (default=C{True}) - - A valid block must contain at least one C{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']]]]]]] - """ - def checkPeerIndent(s,l,t): - if l >= len(s): return - curCol = col(l,s) - if curCol != indentStack[-1]: - if curCol > indentStack[-1]: - raise ParseFatalException(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 < indentStack[-1] and curCol <= indentStack[-2]): - raise ParseException(s,l,"not an unindent") - indentStack.pop() - - NL = OneOrMore(LineEnd().setWhitespaceChars("\t ").suppress()) - INDENT = (Empty() + Empty().setParseAction(checkSubIndent)).setName('INDENT') - PEER = Empty().setParseAction(checkPeerIndent).setName('') - UNDENT = Empty().setParseAction(checkUnindent).setName('UNINDENT') - if indent: - smExpr = Group( Optional(NL) + - #~ FollowedBy(blockStatementExpr) + - INDENT + (OneOrMore( PEER + Group(blockStatementExpr) + Optional(NL) )) + UNDENT) - else: - smExpr = Group( Optional(NL) + - (OneOrMore( PEER + Group(blockStatementExpr) + Optional(NL) )) ) - 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' + '|'.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 C{/* ... */}" - -htmlComment = Regex(r"").setName("HTML comment") -"Comment of the form C{}" - -restOfLine = Regex(r".*").leaveWhitespace().setName("rest of line") -dblSlashComment = Regex(r"//(?:\\\n|[^\n])*").setName("// comment") -"Comment of the form C{// ... (to end of line)}" - -cppStyleComment = Combine(Regex(r"/\*(?:[^*]|\*(?!/))*") + '*/'| dblSlashComment).setName("C++ style comment") -"Comment of either form C{L{cStyleComment}} or C{L{dblSlashComment}}" - -javaStyleComment = cppStyleComment -"Same as C{L{cppStyleComment}}" - -pythonStyleComment = Regex(r"#.*").setName("Python style comment") -"Comment of the form C{# ... (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 L{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 (L{integers}, L{reals}, L{scientific notation}) - - common L{programming identifiers} - - network addresses (L{MAC}, L{IPv4}, L{IPv6}) - - ISO8601 L{dates} and L{datetime} - - L{UUID} - - L{comma-separated list} - Parse actions: - - C{L{convertToInteger}} - - C{L{convertToFloat}} - - C{L{convertToDate}} - - C{L{convertToDatetime}} - - C{L{stripHTMLTags}} - - C{L{upcaseTokens}} - - C{L{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*').setName("real number").setParseAction(convertToFloat) - """expression that parses a floating point number and returns a float""" - - sci_real = Regex(r'[+-]?\d+([eE][+-]?\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 (C{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=C{"%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=C{"%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\d{4})(?:-(?P\d\d)(?:-(?P\d\d))?)?').setName("ISO8601 date") - "ISO8601 date (C{yyyy-mm-dd})" - - iso8601_datetime = Regex(r'(?P\d{4})-(?P\d\d)-(?P\d\d)[T ](?P\d\d):(?P\d\d)(:(?P\d\d(\.\d*)?)?)?(?PZ|[+-]\d\d:?\d\d)?').setName("ISO8601 datetime") - "ISO8601 datetime (C{yyyy-mm-ddThh:mm:ss.s(Z|+-00:00)}) - trailing seconds, milliseconds, and timezone optional; accepts separating C{'T'} or C{' '}" - - uuid = Regex(r'[0-9a-fA-F]{8}(-[0-9a-fA-F]{4}){3}-[0-9a-fA-F]{12}').setName("UUID") - "UUID (C{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 = 'More info at the
pyparsing wiki page' - td,td_end = makeHTMLTags("TD") - table_text = td + SkipTo(td_end).setParseAction(pyparsing_common.stripHTMLTags)("body") + td_end - - print(table_text.parseString(text).body) # -> '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.""" - - -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/venv/lib/python3.8/site-packages/pkg_resources/_vendor/six.py b/venv/lib/python3.8/site-packages/pkg_resources/_vendor/six.py deleted file mode 100644 index 190c023..0000000 --- a/venv/lib/python3.8/site-packages/pkg_resources/_vendor/six.py +++ /dev/null @@ -1,868 +0,0 @@ -"""Utilities for writing code that runs on Python 2 and 3""" - -# Copyright (c) 2010-2015 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 -# 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 absolute_import - -import functools -import itertools -import operator -import sys -import types - -__author__ = "Benjamin Peterson " -__version__ = "1.10.0" - - -# Useful for very coarse version differentiation. -PY2 = sys.version_info[0] == 2 -PY3 = sys.version_info[0] == 3 -PY34 = sys.version_info[0:2] >= (3, 4) - -if PY3: - string_types = str, - integer_types = int, - class_types = type, - text_type = str - binary_type = bytes - - MAXSIZE = sys.maxsize -else: - string_types = basestring, - integer_types = (int, long) - class_types = (type, types.ClassType) - text_type = unicode - binary_type = str - - if sys.platform.startswith("java"): - # Jython always uses 32 bits. - MAXSIZE = int((1 << 31) - 1) - else: - # It's possible to have sizeof(long) != sizeof(Py_ssize_t). - class X(object): - - def __len__(self): - return 1 << 31 - try: - len(X()) - except OverflowError: - # 32-bit - MAXSIZE = int((1 << 31) - 1) - else: - # 64-bit - MAXSIZE = int((1 << 63) - 1) - del X - - -def _add_doc(func, doc): - """Add documentation to a function.""" - func.__doc__ = doc - - -def _import_module(name): - """Import module, returning the module after the last dot.""" - __import__(name) - return sys.modules[name] - - -class _LazyDescr(object): - - def __init__(self, name): - self.name = name - - def __get__(self, obj, tp): - result = self._resolve() - setattr(obj, self.name, result) # Invokes __set__. - try: - # This is a bit ugly, but it avoids running this again by - # removing this descriptor. - delattr(obj.__class__, self.name) - except AttributeError: - pass - return result - - -class MovedModule(_LazyDescr): - - def __init__(self, name, old, new=None): - super(MovedModule, self).__init__(name) - if PY3: - if new is None: - new = name - self.mod = new - else: - self.mod = old - - def _resolve(self): - return _import_module(self.mod) - - def __getattr__(self, attr): - _module = self._resolve() - value = getattr(_module, attr) - setattr(self, attr, value) - return value - - -class _LazyModule(types.ModuleType): - - def __init__(self, name): - super(_LazyModule, self).__init__(name) - self.__doc__ = self.__class__.__doc__ - - def __dir__(self): - attrs = ["__doc__", "__name__"] - attrs += [attr.name for attr in self._moved_attributes] - return attrs - - # Subclasses should override this - _moved_attributes = [] - - -class MovedAttribute(_LazyDescr): - - def __init__(self, name, old_mod, new_mod, old_attr=None, new_attr=None): - super(MovedAttribute, self).__init__(name) - if PY3: - if new_mod is None: - new_mod = name - self.mod = new_mod - if new_attr is None: - if old_attr is None: - new_attr = name - else: - new_attr = old_attr - self.attr = new_attr - else: - self.mod = old_mod - if old_attr is None: - old_attr = name - self.attr = old_attr - - def _resolve(self): - module = _import_module(self.mod) - return getattr(module, self.attr) - - -class _SixMetaPathImporter(object): - - """ - A meta path importer to import six.moves and its submodules. - - This class implements a PEP302 finder and loader. It should be compatible - with Python 2.5 and all existing versions of Python3 - """ - - def __init__(self, six_module_name): - self.name = six_module_name - self.known_modules = {} - - def _add_module(self, mod, *fullnames): - for fullname in fullnames: - self.known_modules[self.name + "." + fullname] = mod - - def _get_module(self, fullname): - return self.known_modules[self.name + "." + fullname] - - def find_module(self, fullname, path=None): - if fullname in self.known_modules: - return self - return None - - def __get_module(self, fullname): - try: - return self.known_modules[fullname] - except KeyError: - raise ImportError("This loader does not know module " + fullname) - - def load_module(self, fullname): - try: - # in case of a reload - return sys.modules[fullname] - except KeyError: - pass - mod = self.__get_module(fullname) - if isinstance(mod, MovedModule): - mod = mod._resolve() - else: - mod.__loader__ = self - sys.modules[fullname] = mod - return mod - - def is_package(self, fullname): - """ - Return true, if the named module is a package. - - We need this method to get correct spec objects with - Python 3.4 (see PEP451) - """ - return hasattr(self.__get_module(fullname), "__path__") - - def get_code(self, fullname): - """Return None - - Required, if is_package is implemented""" - self.__get_module(fullname) # eventually raises ImportError - return None - get_source = get_code # same as get_code - -_importer = _SixMetaPathImporter(__name__) - - -class _MovedItems(_LazyModule): - - """Lazy loading of moved objects""" - __path__ = [] # mark as package - - -_moved_attributes = [ - MovedAttribute("cStringIO", "cStringIO", "io", "StringIO"), - MovedAttribute("filter", "itertools", "builtins", "ifilter", "filter"), - MovedAttribute("filterfalse", "itertools", "itertools", "ifilterfalse", "filterfalse"), - MovedAttribute("input", "__builtin__", "builtins", "raw_input", "input"), - MovedAttribute("intern", "__builtin__", "sys"), - MovedAttribute("map", "itertools", "builtins", "imap", "map"), - MovedAttribute("getcwd", "os", "os", "getcwdu", "getcwd"), - MovedAttribute("getcwdb", "os", "os", "getcwd", "getcwdb"), - MovedAttribute("range", "__builtin__", "builtins", "xrange", "range"), - MovedAttribute("reload_module", "__builtin__", "importlib" if PY34 else "imp", "reload"), - MovedAttribute("reduce", "__builtin__", "functools"), - MovedAttribute("shlex_quote", "pipes", "shlex", "quote"), - MovedAttribute("StringIO", "StringIO", "io"), - MovedAttribute("UserDict", "UserDict", "collections"), - MovedAttribute("UserList", "UserList", "collections"), - MovedAttribute("UserString", "UserString", "collections"), - MovedAttribute("xrange", "__builtin__", "builtins", "xrange", "range"), - MovedAttribute("zip", "itertools", "builtins", "izip", "zip"), - MovedAttribute("zip_longest", "itertools", "itertools", "izip_longest", "zip_longest"), - MovedModule("builtins", "__builtin__"), - MovedModule("configparser", "ConfigParser"), - MovedModule("copyreg", "copy_reg"), - MovedModule("dbm_gnu", "gdbm", "dbm.gnu"), - MovedModule("_dummy_thread", "dummy_thread", "_dummy_thread"), - MovedModule("http_cookiejar", "cookielib", "http.cookiejar"), - MovedModule("http_cookies", "Cookie", "http.cookies"), - MovedModule("html_entities", "htmlentitydefs", "html.entities"), - MovedModule("html_parser", "HTMLParser", "html.parser"), - MovedModule("http_client", "httplib", "http.client"), - MovedModule("email_mime_multipart", "email.MIMEMultipart", "email.mime.multipart"), - MovedModule("email_mime_nonmultipart", "email.MIMENonMultipart", "email.mime.nonmultipart"), - MovedModule("email_mime_text", "email.MIMEText", "email.mime.text"), - MovedModule("email_mime_base", "email.MIMEBase", "email.mime.base"), - MovedModule("BaseHTTPServer", "BaseHTTPServer", "http.server"), - MovedModule("CGIHTTPServer", "CGIHTTPServer", "http.server"), - MovedModule("SimpleHTTPServer", "SimpleHTTPServer", "http.server"), - MovedModule("cPickle", "cPickle", "pickle"), - MovedModule("queue", "Queue"), - MovedModule("reprlib", "repr"), - MovedModule("socketserver", "SocketServer"), - MovedModule("_thread", "thread", "_thread"), - MovedModule("tkinter", "Tkinter"), - MovedModule("tkinter_dialog", "Dialog", "tkinter.dialog"), - MovedModule("tkinter_filedialog", "FileDialog", "tkinter.filedialog"), - MovedModule("tkinter_scrolledtext", "ScrolledText", "tkinter.scrolledtext"), - MovedModule("tkinter_simpledialog", "SimpleDialog", "tkinter.simpledialog"), - MovedModule("tkinter_tix", "Tix", "tkinter.tix"), - MovedModule("tkinter_ttk", "ttk", "tkinter.ttk"), - MovedModule("tkinter_constants", "Tkconstants", "tkinter.constants"), - MovedModule("tkinter_dnd", "Tkdnd", "tkinter.dnd"), - MovedModule("tkinter_colorchooser", "tkColorChooser", - "tkinter.colorchooser"), - MovedModule("tkinter_commondialog", "tkCommonDialog", - "tkinter.commondialog"), - MovedModule("tkinter_tkfiledialog", "tkFileDialog", "tkinter.filedialog"), - MovedModule("tkinter_font", "tkFont", "tkinter.font"), - MovedModule("tkinter_messagebox", "tkMessageBox", "tkinter.messagebox"), - MovedModule("tkinter_tksimpledialog", "tkSimpleDialog", - "tkinter.simpledialog"), - MovedModule("urllib_parse", __name__ + ".moves.urllib_parse", "urllib.parse"), - MovedModule("urllib_error", __name__ + ".moves.urllib_error", "urllib.error"), - MovedModule("urllib", __name__ + ".moves.urllib", __name__ + ".moves.urllib"), - MovedModule("urllib_robotparser", "robotparser", "urllib.robotparser"), - MovedModule("xmlrpc_client", "xmlrpclib", "xmlrpc.client"), - MovedModule("xmlrpc_server", "SimpleXMLRPCServer", "xmlrpc.server"), -] -# Add windows specific modules. -if sys.platform == "win32": - _moved_attributes += [ - MovedModule("winreg", "_winreg"), - ] - -for attr in _moved_attributes: - setattr(_MovedItems, attr.name, attr) - if isinstance(attr, MovedModule): - _importer._add_module(attr, "moves." + attr.name) -del attr - -_MovedItems._moved_attributes = _moved_attributes - -moves = _MovedItems(__name__ + ".moves") -_importer._add_module(moves, "moves") - - -class Module_six_moves_urllib_parse(_LazyModule): - - """Lazy loading of moved objects in six.moves.urllib_parse""" - - -_urllib_parse_moved_attributes = [ - MovedAttribute("ParseResult", "urlparse", "urllib.parse"), - MovedAttribute("SplitResult", "urlparse", "urllib.parse"), - MovedAttribute("parse_qs", "urlparse", "urllib.parse"), - MovedAttribute("parse_qsl", "urlparse", "urllib.parse"), - MovedAttribute("urldefrag", "urlparse", "urllib.parse"), - MovedAttribute("urljoin", "urlparse", "urllib.parse"), - MovedAttribute("urlparse", "urlparse", "urllib.parse"), - MovedAttribute("urlsplit", "urlparse", "urllib.parse"), - MovedAttribute("urlunparse", "urlparse", "urllib.parse"), - MovedAttribute("urlunsplit", "urlparse", "urllib.parse"), - MovedAttribute("quote", "urllib", "urllib.parse"), - MovedAttribute("quote_plus", "urllib", "urllib.parse"), - MovedAttribute("unquote", "urllib", "urllib.parse"), - MovedAttribute("unquote_plus", "urllib", "urllib.parse"), - MovedAttribute("urlencode", "urllib", "urllib.parse"), - MovedAttribute("splitquery", "urllib", "urllib.parse"), - MovedAttribute("splittag", "urllib", "urllib.parse"), - MovedAttribute("splituser", "urllib", "urllib.parse"), - MovedAttribute("uses_fragment", "urlparse", "urllib.parse"), - MovedAttribute("uses_netloc", "urlparse", "urllib.parse"), - MovedAttribute("uses_params", "urlparse", "urllib.parse"), - MovedAttribute("uses_query", "urlparse", "urllib.parse"), - MovedAttribute("uses_relative", "urlparse", "urllib.parse"), -] -for attr in _urllib_parse_moved_attributes: - setattr(Module_six_moves_urllib_parse, attr.name, attr) -del attr - -Module_six_moves_urllib_parse._moved_attributes = _urllib_parse_moved_attributes - -_importer._add_module(Module_six_moves_urllib_parse(__name__ + ".moves.urllib_parse"), - "moves.urllib_parse", "moves.urllib.parse") - - -class Module_six_moves_urllib_error(_LazyModule): - - """Lazy loading of moved objects in six.moves.urllib_error""" - - -_urllib_error_moved_attributes = [ - MovedAttribute("URLError", "urllib2", "urllib.error"), - MovedAttribute("HTTPError", "urllib2", "urllib.error"), - MovedAttribute("ContentTooShortError", "urllib", "urllib.error"), -] -for attr in _urllib_error_moved_attributes: - setattr(Module_six_moves_urllib_error, attr.name, attr) -del attr - -Module_six_moves_urllib_error._moved_attributes = _urllib_error_moved_attributes - -_importer._add_module(Module_six_moves_urllib_error(__name__ + ".moves.urllib.error"), - "moves.urllib_error", "moves.urllib.error") - - -class Module_six_moves_urllib_request(_LazyModule): - - """Lazy loading of moved objects in six.moves.urllib_request""" - - -_urllib_request_moved_attributes = [ - MovedAttribute("urlopen", "urllib2", "urllib.request"), - MovedAttribute("install_opener", "urllib2", "urllib.request"), - MovedAttribute("build_opener", "urllib2", "urllib.request"), - MovedAttribute("pathname2url", "urllib", "urllib.request"), - MovedAttribute("url2pathname", "urllib", "urllib.request"), - MovedAttribute("getproxies", "urllib", "urllib.request"), - MovedAttribute("Request", "urllib2", "urllib.request"), - MovedAttribute("OpenerDirector", "urllib2", "urllib.request"), - MovedAttribute("HTTPDefaultErrorHandler", "urllib2", "urllib.request"), - MovedAttribute("HTTPRedirectHandler", "urllib2", "urllib.request"), - MovedAttribute("HTTPCookieProcessor", "urllib2", "urllib.request"), - MovedAttribute("ProxyHandler", "urllib2", "urllib.request"), - MovedAttribute("BaseHandler", "urllib2", "urllib.request"), - MovedAttribute("HTTPPasswordMgr", "urllib2", "urllib.request"), - MovedAttribute("HTTPPasswordMgrWithDefaultRealm", "urllib2", "urllib.request"), - MovedAttribute("AbstractBasicAuthHandler", "urllib2", "urllib.request"), - MovedAttribute("HTTPBasicAuthHandler", "urllib2", "urllib.request"), - MovedAttribute("ProxyBasicAuthHandler", "urllib2", "urllib.request"), - MovedAttribute("AbstractDigestAuthHandler", "urllib2", "urllib.request"), - MovedAttribute("HTTPDigestAuthHandler", "urllib2", "urllib.request"), - MovedAttribute("ProxyDigestAuthHandler", "urllib2", "urllib.request"), - MovedAttribute("HTTPHandler", "urllib2", "urllib.request"), - MovedAttribute("HTTPSHandler", "urllib2", "urllib.request"), - MovedAttribute("FileHandler", "urllib2", "urllib.request"), - MovedAttribute("FTPHandler", "urllib2", "urllib.request"), - MovedAttribute("CacheFTPHandler", "urllib2", "urllib.request"), - MovedAttribute("UnknownHandler", "urllib2", "urllib.request"), - MovedAttribute("HTTPErrorProcessor", "urllib2", "urllib.request"), - MovedAttribute("urlretrieve", "urllib", "urllib.request"), - MovedAttribute("urlcleanup", "urllib", "urllib.request"), - MovedAttribute("URLopener", "urllib", "urllib.request"), - MovedAttribute("FancyURLopener", "urllib", "urllib.request"), - MovedAttribute("proxy_bypass", "urllib", "urllib.request"), -] -for attr in _urllib_request_moved_attributes: - setattr(Module_six_moves_urllib_request, attr.name, attr) -del attr - -Module_six_moves_urllib_request._moved_attributes = _urllib_request_moved_attributes - -_importer._add_module(Module_six_moves_urllib_request(__name__ + ".moves.urllib.request"), - "moves.urllib_request", "moves.urllib.request") - - -class Module_six_moves_urllib_response(_LazyModule): - - """Lazy loading of moved objects in six.moves.urllib_response""" - - -_urllib_response_moved_attributes = [ - MovedAttribute("addbase", "urllib", "urllib.response"), - MovedAttribute("addclosehook", "urllib", "urllib.response"), - MovedAttribute("addinfo", "urllib", "urllib.response"), - MovedAttribute("addinfourl", "urllib", "urllib.response"), -] -for attr in _urllib_response_moved_attributes: - setattr(Module_six_moves_urllib_response, attr.name, attr) -del attr - -Module_six_moves_urllib_response._moved_attributes = _urllib_response_moved_attributes - -_importer._add_module(Module_six_moves_urllib_response(__name__ + ".moves.urllib.response"), - "moves.urllib_response", "moves.urllib.response") - - -class Module_six_moves_urllib_robotparser(_LazyModule): - - """Lazy loading of moved objects in six.moves.urllib_robotparser""" - - -_urllib_robotparser_moved_attributes = [ - MovedAttribute("RobotFileParser", "robotparser", "urllib.robotparser"), -] -for attr in _urllib_robotparser_moved_attributes: - setattr(Module_six_moves_urllib_robotparser, attr.name, attr) -del attr - -Module_six_moves_urllib_robotparser._moved_attributes = _urllib_robotparser_moved_attributes - -_importer._add_module(Module_six_moves_urllib_robotparser(__name__ + ".moves.urllib.robotparser"), - "moves.urllib_robotparser", "moves.urllib.robotparser") - - -class Module_six_moves_urllib(types.ModuleType): - - """Create a six.moves.urllib namespace that resembles the Python 3 namespace""" - __path__ = [] # mark as package - parse = _importer._get_module("moves.urllib_parse") - error = _importer._get_module("moves.urllib_error") - request = _importer._get_module("moves.urllib_request") - response = _importer._get_module("moves.urllib_response") - robotparser = _importer._get_module("moves.urllib_robotparser") - - def __dir__(self): - return ['parse', 'error', 'request', 'response', 'robotparser'] - -_importer._add_module(Module_six_moves_urllib(__name__ + ".moves.urllib"), - "moves.urllib") - - -def add_move(move): - """Add an item to six.moves.""" - setattr(_MovedItems, move.name, move) - - -def remove_move(name): - """Remove item from six.moves.""" - try: - delattr(_MovedItems, name) - except AttributeError: - try: - del moves.__dict__[name] - except KeyError: - raise AttributeError("no such move, %r" % (name,)) - - -if PY3: - _meth_func = "__func__" - _meth_self = "__self__" - - _func_closure = "__closure__" - _func_code = "__code__" - _func_defaults = "__defaults__" - _func_globals = "__globals__" -else: - _meth_func = "im_func" - _meth_self = "im_self" - - _func_closure = "func_closure" - _func_code = "func_code" - _func_defaults = "func_defaults" - _func_globals = "func_globals" - - -try: - advance_iterator = next -except NameError: - def advance_iterator(it): - return it.next() -next = advance_iterator - - -try: - callable = callable -except NameError: - def callable(obj): - return any("__call__" in klass.__dict__ for klass in type(obj).__mro__) - - -if PY3: - def get_unbound_function(unbound): - return unbound - - create_bound_method = types.MethodType - - def create_unbound_method(func, cls): - return func - - Iterator = object -else: - def get_unbound_function(unbound): - return unbound.im_func - - def create_bound_method(func, obj): - return types.MethodType(func, obj, obj.__class__) - - def create_unbound_method(func, cls): - return types.MethodType(func, None, cls) - - class Iterator(object): - - def next(self): - return type(self).__next__(self) - - callable = callable -_add_doc(get_unbound_function, - """Get the function out of a possibly unbound function""") - - -get_method_function = operator.attrgetter(_meth_func) -get_method_self = operator.attrgetter(_meth_self) -get_function_closure = operator.attrgetter(_func_closure) -get_function_code = operator.attrgetter(_func_code) -get_function_defaults = operator.attrgetter(_func_defaults) -get_function_globals = operator.attrgetter(_func_globals) - - -if PY3: - def iterkeys(d, **kw): - return iter(d.keys(**kw)) - - def itervalues(d, **kw): - return iter(d.values(**kw)) - - def iteritems(d, **kw): - return iter(d.items(**kw)) - - def iterlists(d, **kw): - return iter(d.lists(**kw)) - - viewkeys = operator.methodcaller("keys") - - viewvalues = operator.methodcaller("values") - - viewitems = operator.methodcaller("items") -else: - def iterkeys(d, **kw): - return d.iterkeys(**kw) - - def itervalues(d, **kw): - return d.itervalues(**kw) - - def iteritems(d, **kw): - return d.iteritems(**kw) - - def iterlists(d, **kw): - return d.iterlists(**kw) - - viewkeys = operator.methodcaller("viewkeys") - - viewvalues = operator.methodcaller("viewvalues") - - viewitems = operator.methodcaller("viewitems") - -_add_doc(iterkeys, "Return an iterator over the keys of a dictionary.") -_add_doc(itervalues, "Return an iterator over the values of a dictionary.") -_add_doc(iteritems, - "Return an iterator over the (key, value) pairs of a dictionary.") -_add_doc(iterlists, - "Return an iterator over the (key, [values]) pairs of a dictionary.") - - -if PY3: - def b(s): - return s.encode("latin-1") - - def u(s): - return s - unichr = chr - import struct - int2byte = struct.Struct(">B").pack - del struct - byte2int = operator.itemgetter(0) - indexbytes = operator.getitem - iterbytes = iter - import io - StringIO = io.StringIO - BytesIO = io.BytesIO - _assertCountEqual = "assertCountEqual" - if sys.version_info[1] <= 1: - _assertRaisesRegex = "assertRaisesRegexp" - _assertRegex = "assertRegexpMatches" - else: - _assertRaisesRegex = "assertRaisesRegex" - _assertRegex = "assertRegex" -else: - def b(s): - return s - # Workaround for standalone backslash - - def u(s): - return unicode(s.replace(r'\\', r'\\\\'), "unicode_escape") - unichr = unichr - int2byte = chr - - def byte2int(bs): - return ord(bs[0]) - - def indexbytes(buf, i): - return ord(buf[i]) - iterbytes = functools.partial(itertools.imap, ord) - import StringIO - StringIO = BytesIO = StringIO.StringIO - _assertCountEqual = "assertItemsEqual" - _assertRaisesRegex = "assertRaisesRegexp" - _assertRegex = "assertRegexpMatches" -_add_doc(b, """Byte literal""") -_add_doc(u, """Text literal""") - - -def assertCountEqual(self, *args, **kwargs): - return getattr(self, _assertCountEqual)(*args, **kwargs) - - -def assertRaisesRegex(self, *args, **kwargs): - return getattr(self, _assertRaisesRegex)(*args, **kwargs) - - -def assertRegex(self, *args, **kwargs): - return getattr(self, _assertRegex)(*args, **kwargs) - - -if PY3: - exec_ = getattr(moves.builtins, "exec") - - def reraise(tp, value, tb=None): - if value is None: - value = tp() - if value.__traceback__ is not tb: - raise value.with_traceback(tb) - raise value - -else: - def exec_(_code_, _globs_=None, _locs_=None): - """Execute code in a namespace.""" - if _globs_ is None: - frame = sys._getframe(1) - _globs_ = frame.f_globals - if _locs_ is None: - _locs_ = frame.f_locals - del frame - elif _locs_ is None: - _locs_ = _globs_ - exec("""exec _code_ in _globs_, _locs_""") - - exec_("""def reraise(tp, value, tb=None): - raise tp, value, tb -""") - - -if sys.version_info[:2] == (3, 2): - exec_("""def raise_from(value, from_value): - if from_value is None: - raise value - raise value from from_value -""") -elif sys.version_info[:2] > (3, 2): - exec_("""def raise_from(value, from_value): - raise value from from_value -""") -else: - def raise_from(value, from_value): - raise value - - -print_ = getattr(moves.builtins, "print", None) -if print_ is None: - def print_(*args, **kwargs): - """The new-style print function for Python 2.4 and 2.5.""" - fp = kwargs.pop("file", sys.stdout) - if fp is None: - return - - def write(data): - if not isinstance(data, basestring): - data = str(data) - # If the file has an encoding, encode unicode with it. - if (isinstance(fp, file) and - isinstance(data, unicode) and - fp.encoding is not None): - errors = getattr(fp, "errors", None) - if errors is None: - errors = "strict" - data = data.encode(fp.encoding, errors) - fp.write(data) - want_unicode = False - sep = kwargs.pop("sep", None) - if sep is not None: - if isinstance(sep, unicode): - want_unicode = True - elif not isinstance(sep, str): - raise TypeError("sep must be None or a string") - end = kwargs.pop("end", None) - if end is not None: - if isinstance(end, unicode): - want_unicode = True - elif not isinstance(end, str): - raise TypeError("end must be None or a string") - if kwargs: - raise TypeError("invalid keyword arguments to print()") - if not want_unicode: - for arg in args: - if isinstance(arg, unicode): - want_unicode = True - break - if want_unicode: - newline = unicode("\n") - space = unicode(" ") - else: - newline = "\n" - space = " " - if sep is None: - sep = space - if end is None: - end = newline - for i, arg in enumerate(args): - if i: - write(sep) - write(arg) - write(end) -if sys.version_info[:2] < (3, 3): - _print = print_ - - def print_(*args, **kwargs): - fp = kwargs.get("file", sys.stdout) - flush = kwargs.pop("flush", False) - _print(*args, **kwargs) - if flush and fp is not None: - fp.flush() - -_add_doc(reraise, """Reraise an exception.""") - -if sys.version_info[0:2] < (3, 4): - 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 -else: - wraps = functools.wraps - - -def with_metaclass(meta, *bases): - """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): - - def __new__(cls, name, this_bases, d): - return meta(name, bases, d) - return type.__new__(metaclass, 'temporary_class', (), {}) - - -def add_metaclass(metaclass): - """Class decorator for creating a class with a metaclass.""" - def wrapper(cls): - orig_vars = cls.__dict__.copy() - slots = orig_vars.get('__slots__') - if slots is not None: - if isinstance(slots, str): - slots = [slots] - for slots_var in slots: - orig_vars.pop(slots_var) - orig_vars.pop('__dict__', None) - orig_vars.pop('__weakref__', None) - return metaclass(cls.__name__, cls.__bases__, orig_vars) - return wrapper - - -def python_2_unicode_compatible(klass): - """ - A 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 - returning text and apply this decorator to the class. - """ - if PY2: - if '__str__' not in klass.__dict__: - raise ValueError("@python_2_unicode_compatible cannot be applied " - "to %s because it doesn't define __str__()." % - klass.__name__) - klass.__unicode__ = klass.__str__ - klass.__str__ = lambda self: self.__unicode__().encode('utf-8') - return klass - - -# Complete the moves implementation. -# This code is at the end of this module to speed up module loading. -# Turn this module into a package. -__path__ = [] # required for PEP 302 and PEP 451 -__package__ = __name__ # see PEP 366 @ReservedAssignment -if globals().get("__spec__") is not None: - __spec__.submodule_search_locations = [] # PEP 451 @UndefinedVariable -# Remove other six meta path importers, since they cause problems. This can -# happen if six is removed from sys.modules and then reloaded. (Setuptools does -# this for some reason.) -if sys.meta_path: - for i, importer in enumerate(sys.meta_path): - # Here's some real nastiness: Another "instance" of the six module might - # be floating around. Therefore, we can't use isinstance() to check for - # the six meta path importer, since the other six instance will have - # inserted an importer with different class. - if (type(importer).__name__ == "_SixMetaPathImporter" and - importer.name == __name__): - del sys.meta_path[i] - break - del i, importer -# Finally, add the importer to the meta path import hook. -sys.meta_path.append(_importer) diff --git a/venv/lib/python3.8/site-packages/pkg_resources/extern/__init__.py b/venv/lib/python3.8/site-packages/pkg_resources/extern/__init__.py deleted file mode 100644 index c1eb9e9..0000000 --- a/venv/lib/python3.8/site-packages/pkg_resources/extern/__init__.py +++ /dev/null @@ -1,73 +0,0 @@ -import sys - - -class VendorImporter: - """ - A PEP 302 meta path importer for finding optionally-vendored - or otherwise naturally-installed packages from root_name. - """ - - def __init__(self, root_name, vendored_names=(), vendor_pkg=None): - self.root_name = root_name - self.vendored_names = set(vendored_names) - self.vendor_pkg = vendor_pkg or root_name.replace('extern', '_vendor') - - @property - def search_path(self): - """ - Search first the vendor package then as a natural package. - """ - yield self.vendor_pkg + '.' - yield '' - - def find_module(self, fullname, path=None): - """ - Return self when fullname starts with root_name and the - target module is one vendored through this importer. - """ - root, base, target = fullname.partition(self.root_name + '.') - if root: - return - if not any(map(target.startswith, self.vendored_names)): - return - return self - - def load_module(self, fullname): - """ - Iterate over the search path to locate and load fullname. - """ - root, base, target = fullname.partition(self.root_name + '.') - for prefix in self.search_path: - try: - extant = prefix + target - __import__(extant) - mod = sys.modules[extant] - sys.modules[fullname] = mod - # mysterious hack: - # Remove the reference to the extant package/module - # on later Python versions to cause relative imports - # in the vendor package to resolve the same modules - # as those going through this importer. - if prefix and sys.version_info > (3, 3): - del sys.modules[extant] - return mod - except ImportError: - pass - else: - raise ImportError( - "The '{target}' package is required; " - "normally this is bundled with this package so if you get " - "this warning, consult the packager of your " - "distribution.".format(**locals()) - ) - - def install(self): - """ - Install this importer into sys.meta_path if not already present. - """ - if self not in sys.meta_path: - sys.meta_path.append(self) - - -names = 'packaging', 'pyparsing', 'six', 'appdirs' -VendorImporter(__name__, names).install() diff --git a/venv/lib/python3.8/site-packages/pkg_resources/extern/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/pkg_resources/extern/__pycache__/__init__.cpython-38.pyc deleted file mode 100644 index 7e7a5dfd037ec1ea9a00593e5df91630a44d0b00..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2406 zcmZ`)TW=gS6t?HSlS@k<5?V@Sfl9T|Bv8slqM%l7g(^@~wNPMH7){sSWRlsLiS2E= z%j^pq@yG)b@6BWX20z2EJoPUiAvnjgyGaw_(VVfzw{y<-`SZ6+OEH1+$;X$|KU;+S zg^lCIg~m;I)m1Q@aGH}2`I2yly9b236Q@JD*Kq_Du5c#KbMKH)81;~}{g*Iy2I3S&fFY+b$wzvzs zoHfgjM8QjWuV0l?3pqN78I)V>{@wfR!}qVTzR)SFQoYTx=@8Z{CF^Ac&x$QpRyr$- zG|z`?Pwhg2+XY}qskepP&y-+Ast3}J$qJ>RA~-DB-A%WIVm(>*nJi146lq_q+u1K5 zaPL^uSjYD^yy_h=HLXcPG_9Qp)|}d{F4gq8%PDsb9r)vM0^zxvCJ@gctipsz<6ql1 zt@&=oRYIHPndjC6WkM;cJnae-Hyuf}yVdrLr$pY90qia#G>E)JIIQ{m)`sp^8&y`V z4GIiS@U{JIA@a2kuJ3)ccdeIiz%q#xsvO9!P#cY38%dHCnNE`RYG|Ta1D95~6QKc( z>1g%QDTwfT5Kr z!imU^4eVlWX9bfnXTYb>0JJeciUA(d$L`o2dt<+Lp=Wk_juI!AA&kv-U|JRImEk$E>@sdz42|1QD-$P&fz%q~5the*9_dkM7id?X8k=0H6dDN{RM%{5m*K#$g@WI=w+^Up|If-%Is7i z1*F&;WK!_YSW(J8s@{|Uiai+=9JSA~%Ccgrf=rbx>#<=uV8|!iwV%oY6!t3XmW3MR z&GDR$2XVEdCF7aWGJ7&W_N;HVV|fnTYeecbsF@g~!s>RCfY=Q|+!_ifvk2)>Fbnjj zSDJ<90=O$>DNO(h-%qs(Fg3YqN6n!|O_8soIgjQ7t{+rV^s;AGX466gZA*TNdYINJ z_1=a_>MbzDTLEQrXarA8<6zl-!8#5NT<;&}-&2Gn=Gy&NLN~kX; z$=)Ef$_1@3NqE^!61jvvMU^ZoA@xuqA>=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*, !=3.4.*, !=3.5.* -Description-Content-Type: text/markdown -Requires-Dist: urllib3 (<1.27,>=1.21.1) -Requires-Dist: certifi (>=2017.4.17) -Requires-Dist: chardet (<5,>=3.0.2) ; python_version < "3" -Requires-Dist: idna (<3,>=2.5) ; python_version < "3" -Requires-Dist: charset-normalizer (~=2.0.0) ; python_version >= "3" -Requires-Dist: idna (<4,>=2.5) ; python_version >= "3" -Provides-Extra: security -Provides-Extra: socks -Requires-Dist: PySocks (!=1.5.7,>=1.5.6) ; extra == 'socks' -Requires-Dist: win-inet-pton ; (sys_platform == "win32" and python_version == "2.7") and extra == 'socks' -Provides-Extra: use_chardet_on_py3 -Requires-Dist: chardet (<5,>=3.0.2) ; extra == 'use_chardet_on_py3' - -# Requests - -**Requests** is a simple, yet elegant, HTTP library. - -```python ->>> import requests ->>> r = requests.get('https://api.github.com/user', auth=('user', 'pass')) ->>> r.status_code -200 ->>> r.headers['content-type'] -'application/json; charset=utf8' ->>> r.encoding -'utf-8' ->>> r.text -'{"type":"User"...' ->>> r.json() -{'disk_usage': 368627, 'private_gists': 484, ...} -``` - -Requests allows you to send HTTP/1.1 requests extremely easily. There’s no need to manually add query strings to your URLs, or to form-encode your `PUT` & `POST` data — but nowadays, just use the `json` method! - -Requests is one of the most downloaded Python package today, pulling in around `14M downloads / week`— according to GitHub, Requests is currently [depended upon](https://github.com/psf/requests/network/dependents?package_id=UGFja2FnZS01NzA4OTExNg%3D%3D) by `500,000+` repositories. You may certainly put your trust in this code. - -[![Downloads](https://pepy.tech/badge/requests/month)](https://pepy.tech/project/requests/month) -[![Supported Versions](https://img.shields.io/pypi/pyversions/requests.svg)](https://pypi.org/project/requests) -[![Contributors](https://img.shields.io/github/contributors/psf/requests.svg)](https://github.com/psf/requests/graphs/contributors) - -## Installing Requests and Supported Versions - -Requests is available on PyPI: - -```console -$ python -m pip install requests -``` - -Requests officially supports Python 2.7 & 3.6+. - -## Supported Features & Best–Practices - -Requests is ready for the demands of building robust and reliable HTTP–speaking applications, for the needs of today. - -- Keep-Alive & Connection Pooling -- International Domains and URLs -- Sessions with Cookie Persistence -- Browser-style TLS/SSL Verification -- Basic & Digest Authentication -- Familiar `dict`–like Cookies -- Automatic Content Decompression and Decoding -- Multi-part File Uploads -- SOCKS Proxy Support -- Connection Timeouts -- Streaming Downloads -- Automatic honoring of `.netrc` -- Chunked HTTP Requests - -## API Reference and User Guide available on [Read the Docs](https://requests.readthedocs.io) - -[![Read the Docs](https://raw.githubusercontent.com/psf/requests/master/ext/ss.png)](https://requests.readthedocs.io) - -## Cloning the repository - -When cloning the Requests repository, you may need to add the `-c -fetch.fsck.badTimezone=ignore` flag to avoid an error about a bad commit (see -[this issue](https://github.com/psf/requests/issues/2690) for more background): - -```shell -git clone -c fetch.fsck.badTimezone=ignore https://github.com/psf/requests.git -``` - -You can also apply this setting to your global Git config: - -```shell -git config --global fetch.fsck.badTimezone ignore -``` - ---- - -[![Kenneth Reitz](https://raw.githubusercontent.com/psf/requests/master/ext/kr.png)](https://kennethreitz.org) [![Python Software Foundation](https://raw.githubusercontent.com/psf/requests/master/ext/psf.png)](https://www.python.org/psf) - - diff --git a/venv/lib/python3.8/site-packages/requests-2.26.0.dist-info/RECORD b/venv/lib/python3.8/site-packages/requests-2.26.0.dist-info/RECORD deleted file mode 100644 index df77bf0..0000000 --- a/venv/lib/python3.8/site-packages/requests-2.26.0.dist-info/RECORD +++ /dev/null @@ -1,42 +0,0 @@ -requests-2.26.0.dist-info/INSTALLER,sha256=zuuue4knoyJ-UwPPXg8fezS7VCrXJQrAP7zeNuwvFQg,4 -requests-2.26.0.dist-info/LICENSE,sha256=CeipvOyAZxBGUsFoaFqwkx54aPnIKEtm9a5u2uXxEws,10142 -requests-2.26.0.dist-info/METADATA,sha256=hWaDQ1HOaMvAc-KaJFZgv1-fov-CKxGSwEIsZGhiBB8,4753 -requests-2.26.0.dist-info/RECORD,, -requests-2.26.0.dist-info/WHEEL,sha256=Z-nyYpwrcSqxfdux5Mbn_DQ525iP7J2DG3JgGvOYyTQ,110 -requests-2.26.0.dist-info/top_level.txt,sha256=fMSVmHfb5rbGOo6xv-O_tUX6j-WyixssE-SnwcDRxNQ,9 -requests/__init__.py,sha256=h2SCZm8MM-UeAS48UuY7Lz97fEqsma6g6oVsKUi0eyw,4907 -requests/__pycache__/__init__.cpython-38.pyc,, -requests/__pycache__/__version__.cpython-38.pyc,, -requests/__pycache__/_internal_utils.cpython-38.pyc,, -requests/__pycache__/adapters.cpython-38.pyc,, -requests/__pycache__/api.cpython-38.pyc,, -requests/__pycache__/auth.cpython-38.pyc,, -requests/__pycache__/certs.cpython-38.pyc,, -requests/__pycache__/compat.cpython-38.pyc,, -requests/__pycache__/cookies.cpython-38.pyc,, -requests/__pycache__/exceptions.cpython-38.pyc,, -requests/__pycache__/help.cpython-38.pyc,, -requests/__pycache__/hooks.cpython-38.pyc,, -requests/__pycache__/models.cpython-38.pyc,, -requests/__pycache__/packages.cpython-38.pyc,, -requests/__pycache__/sessions.cpython-38.pyc,, -requests/__pycache__/status_codes.cpython-38.pyc,, -requests/__pycache__/structures.cpython-38.pyc,, -requests/__pycache__/utils.cpython-38.pyc,, -requests/__version__.py,sha256=PZEyPTSIN_jRIAIB51wV7pw81m3qAw0InSR7OrKZUnE,441 -requests/_internal_utils.py,sha256=Zx3PnEUccyfsB-ie11nZVAW8qClJy0gx1qNME7rgT18,1096 -requests/adapters.py,sha256=WelSM1BCQXdbjEuDsBxqKDADeY8BHmxlrwbNnLN2rr4,21344 -requests/api.py,sha256=hjuoP79IAEmX6Dysrw8t032cLfwLHxbI_wM4gC5G9t0,6402 -requests/auth.py,sha256=OMoJIVKyRLy9THr91y8rxysZuclwPB-K1Xg1zBomUhQ,10207 -requests/certs.py,sha256=dOB5rV2DZ13dEhq9BUa_4hd5kAqg59e_zUZB00faYz8,453 -requests/compat.py,sha256=0fzHbLvfnFi2WR0o7XkrvXlElG0_VgQmmOgiooaXh_Y,1852 -requests/cookies.py,sha256=Y-bKX6TvW3FnYlE6Au0SXtVVWcaNdFvuAwQxw-G0iTI,18430 -requests/exceptions.py,sha256=AiGbnc4Z7wjlpETMcTwmsmYvZVep8Qmsd46_yp0h0mY,3238 -requests/help.py,sha256=ywPNssPohrch_Q_q4_JLJM1z2bP0TirHkA9QnoOF0sY,3968 -requests/hooks.py,sha256=QReGyy0bRcr5rkwCuObNakbYsc7EkiKeBwG4qHekr2Q,757 -requests/models.py,sha256=BtTPURThE_VpZZmUfDguGhZj5qUmqmY9rk9pIU3w3X4,34859 -requests/packages.py,sha256=kr9J9dYZr9Ef4JmwHbCEUgwViwcCyOUPgfXZvIL84Os,932 -requests/sessions.py,sha256=57O4ud9yRL6eLYh-dtFbqC1kO4d_EwZcCgYXEkujlfs,30168 -requests/status_codes.py,sha256=gT79Pbs_cQjBgp-fvrUgg1dn2DQO32bDj4TInjnMPSc,4188 -requests/structures.py,sha256=msAtr9mq1JxHd-JRyiILfdFlpbJwvvFuP3rfUQT_QxE,3005 -requests/utils.py,sha256=Ws5IP5Z7KdFkWNlMkk8L6M3iXaDwBt6CLwgWq8yXSF4,31382 diff --git a/venv/lib/python3.8/site-packages/requests-2.26.0.dist-info/WHEEL b/venv/lib/python3.8/site-packages/requests-2.26.0.dist-info/WHEEL deleted file mode 100644 index 01b8fc7..0000000 --- a/venv/lib/python3.8/site-packages/requests-2.26.0.dist-info/WHEEL +++ /dev/null @@ -1,6 +0,0 @@ -Wheel-Version: 1.0 -Generator: bdist_wheel (0.36.2) -Root-Is-Purelib: true -Tag: py2-none-any -Tag: py3-none-any - diff --git a/venv/lib/python3.8/site-packages/requests-2.26.0.dist-info/top_level.txt b/venv/lib/python3.8/site-packages/requests-2.26.0.dist-info/top_level.txt deleted file mode 100644 index f229360..0000000 --- a/venv/lib/python3.8/site-packages/requests-2.26.0.dist-info/top_level.txt +++ /dev/null @@ -1 +0,0 @@ -requests diff --git a/venv/lib/python3.8/site-packages/requests/__init__.py b/venv/lib/python3.8/site-packages/requests/__init__.py deleted file mode 100644 index 0ac7713..0000000 --- a/venv/lib/python3.8/site-packages/requests/__init__.py +++ /dev/null @@ -1,152 +0,0 @@ -# -*- coding: utf-8 -*- - -# __ -# /__) _ _ _ _ _/ _ -# / ( (- (/ (/ (- _) / _) -# / - -""" -Requests HTTP Library -~~~~~~~~~~~~~~~~~~~~~ - -Requests is an HTTP library, written in Python, for human beings. -Basic GET usage: - - >>> import requests - >>> r = requests.get('https://www.python.org') - >>> r.status_code - 200 - >>> b'Python is a programming language' in r.content - True - -... or POST: - - >>> payload = dict(key1='value1', key2='value2') - >>> r = requests.post('https://httpbin.org/post', data=payload) - >>> print(r.text) - { - ... - "form": { - "key1": "value1", - "key2": "value2" - }, - ... - } - -The other HTTP methods are supported - see `requests.api`. Full documentation -is at . - -:copyright: (c) 2017 by Kenneth Reitz. -:license: Apache 2.0, see LICENSE for more details. -""" - -import urllib3 -import warnings -from .exceptions import RequestsDependencyWarning - -try: - from charset_normalizer import __version__ as charset_normalizer_version -except ImportError: - charset_normalizer_version = None - -try: - from chardet import __version__ as chardet_version -except ImportError: - chardet_version = None - -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') - - # 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 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, < 5.0.0 - assert (3, 0, 2) <= (major, minor, patch) < (5, 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 < 3.0.0 - assert (2, 0, 0) <= (major, minor, patch) < (3, 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('.'))) - except ValueError: - return - - if cryptography_version < [1, 3, 4]: - 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, charset_normalizer_version) -except (AssertionError, ValueError): - 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 -# 'ssl' library isn't available. -try: - try: - import ssl - except ImportError: - ssl = None - - if not getattr(ssl, "HAS_SNI", False): - from 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 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 -) - -# Set default logging handler to avoid "No handler found" warnings. -import logging -from logging import NullHandler - -logging.getLogger(__name__).addHandler(NullHandler()) - -# FileModeWarnings go off per the default. -warnings.simplefilter('default', FileModeWarning, append=True) diff --git a/venv/lib/python3.8/site-packages/requests/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/requests/__pycache__/__init__.cpython-38.pyc deleted file mode 100644 index 388e40a9ca05e18ba76caa1f470f680e022920f8..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3850 zcmbVOOLr8x6|P6WTyDP&*ua1=19pSmHs)=>Jk2A+FdXm%MknVK<(6z0U8<@`YD|0D zS;WaQ=gd#Am-!=EWR;U;ZL?yNA25p~_f}OmJ%=oEQhoYLy1J6?)&2BI-wzEr27DiH zp7SnF7{))a(f?uZJ@~88G7M%=gPF__b1>SqJhXY?&@zpD^>@3~)c-L$*5~Cvduxwnc6^+V zu|Zbdw|_F#c^EMiOo&N3X&QX;;K(6Hgz+AQD2{=y%8%`vsYge%xPLO`YBpyci^+zA zDKSl_!P+`F&PMn&dIftp8kEEddP1C}C&gFvE10pA>c>ETik=du>1jbI5ohR`R6h>- z89F1*(z9uMBKTUIqvz84B-GE-^J)D^Fe~QhoT$;7xIizYx}(8GF;C~k0$mVwS{I9S zQ7q9Vafx0M%XC>>rk7K@W5E@1m0lIs=(V&x6-;S-#+KFv9E|1Wen?)n^>!4_lg&ty?Un%34ep0qs_s1Sl;0pv*49Z&d0TwNaR?!+tE6UUE5#y*_URvt* zZOmq#5%izLGTM@!5a1aJyl|@p4$Y$bvfhY72u0(#b=l&MQ?J(v1oQH{*Xy5sj=gpe zc??`+enZbSdHd3x*$-aO;+JOU2{f1U=5n8V{QWc^?+wemSXAyf~4(4g^PQFYp z!dUvDo|ARWKk8KZBl<}Q_?T5@VBf{e3d!|^%%E$an8}=*na}L9j^$p*@=T`R%lq>Q z_Z(+^o0CXybD8B_aL6x%J(QfNR*aeBj4TkvIeFJjVcm=UcXjf(6$FGujh287^|T*_ z4(`4tx4W6_4UpVpum~8dx*x699cQHx#ck*Qh}*FI^`aZSoBdL-2vT;=bOk zJ1c?T;GyCxqCditZOn1-0 zBOddR@vzZ;-NTV~T% zQ`-E!sjZH&Z!)`S$vW5otK+%s7{9Ui?7hNXQ5QP)z6r9B%HqCh8#*+i05dugqy0>Te-j-WV>0(ZY=%RwmMG6PXg6`zVdMVe4M)n^vD;`0zx>|XyNYLSowYymilA?+OUnj%&mEsZsy(VQO6FcBxQu1QNPh!In zO$OFJHh7E{FlwYF1K`TbT_`0Z`P@Cl@h@HI^%aHp9@Z!VSz!@-y0QIdLry~|KVMzc zB3_LBc%c;n{F|ID>}+!$EV#=7+qfFF7P}{G(RKaM*RBi9nM}YzX*7W*1wfp+Tv&X=4193Y7>?##NW9$naOiKP1V2{@d$$;x>UkBWElM&Zt zTs5Sh!WqNWoW)(YW+g*FwO#Iq z-U>9mCaeg)6~@=uHpzTgJk5T8j}KN%8Dzb|D^mntDqP7zEFUj(R}*eVNc5I zzTgo|HTeCj=h*9m6Upd$6n*Q3?N^*ZyP;JwfN!o0Un37AxX~J)*<|FgAMkHsiToN$ zhI5PF+^@j-yaDbEzJPo7sTZ<<%cRWsrq>Gedd-xhn1?5r7r0kpC(AjOM6|ZwZ+)Pvthm)(ZG4vb5R+Q8-&MD`pi)XB0@s z>6MjJm8xZq!>?i%;4NbP+p?^GIc3YV;4(nVVJItbMO0yA2}^4Vh-);xEGEr4&{oa) JGR{42{|8B6B0B&8 diff --git a/venv/lib/python3.8/site-packages/requests/__pycache__/__version__.cpython-38.pyc b/venv/lib/python3.8/site-packages/requests/__pycache__/__version__.cpython-38.pyc deleted file mode 100644 index 24f4c3feb947d61fe3d3607243df708c81989619..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 507 zcmZ8e%WB*(6xB@T;c+sww2N#4)h2;J#vTkUZ7C(Cn?NCiJT}@0$M-fCV_U8sZO8x6 zKPY6I?7Ho*%rg0bth?%UUL?6fmvhe55%)?*<8jC+e!g2z|8^L=Y{|nQjcwDmTa0)yW?T4$Tpy}8SE#di)5_xM+B z_>M2r%0|tr+_~DmkK?pEW zMlr1rX>-zqpXxNrktfl#S^KQ(xlt#%RLK9v5KI2!Xzy5FnyPM%+B&AcX zKq(i`qy)5?QMFULB4H?{HwA%ZDZit!H!3-fy()n8P|DQPoQCl8dyHkOZe4}Su(Ivt zV=1${-iQW7(-{@cnQ7a)PXFG$fSVd*V^B|TKu4+sGcu^ T52XfQ;KzRZbuTFOI#1Vsd7ho` diff --git a/venv/lib/python3.8/site-packages/requests/__pycache__/_internal_utils.cpython-38.pyc b/venv/lib/python3.8/site-packages/requests/__pycache__/_internal_utils.cpython-38.pyc deleted file mode 100644 index 8431975e27d3a75aa1b1f20536ca01a18d1d0d93..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1272 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 TGsUIC{A%&m{L=jGqWkwh#l5~c diff --git a/venv/lib/python3.8/site-packages/requests/__pycache__/auth.cpython-38.pyc b/venv/lib/python3.8/site-packages/requests/__pycache__/auth.cpython-38.pyc deleted file mode 100644 index ea2d70c1f665a6eb70610326bcd68ae8d5afdf43..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 8291 zcmdT}+ix3JdY?OoBa))-vf?;nukD1XBwyA}QrB_p*xoq13GLcScSE!ojCe*8DU!pS z8T!Hww-=>o(jp7@Wfv$=fI@)+`U?v5Z|FnO$Me#Mq6NIK+b8#u{=PFLB}#TT*~LDT z(wsTxJJ;`ezVDk)@_9$W@9}S+@&Dy@Mfq219Q+w*T*njrBMPQe6s9t*p;lD+)+(BO z>lIzTjfx@PX2q0mt774;H!@ATVyg->nAylSor=?(s7y3-m7IiGjeN6EDad-JG1)9u zin4Aurkc~0Y1Ffo8Rk@G*#ygdu2kkeP*|Q7K37;FnBUPW3usTWBHG1Z0qsS!r`R;w z)4?Lz$IzZ(vuMxC{w1b8P)c*%KX7>PStp3%Xw~n;Th5OU{v2m*s}{MM*SR>$(yAg8t{%}R-83?A7ORC7OzjY~SRYMj$QvoXJ z!tU@!+viar^eE=SS@$EHg4bG`7(O37j=5iry=oY4*Mi84L$B_0^b}ERVb6zwHyS-9 z*YQ{l6Se}M1-yIGZ?_wR!<~D)^61f{6`ZWOf=$z7uD{J?5I5&rOHwF<(uW>~W$FU@9}?Z0sXv9tX^=wMKk&zq@)Kf9}0T049+fJPdd&#UNa-2i4ep5_VpH7`SaeiqffX{NYL7 zE4guq;|#WiV5~ohvFl(CHXuQ21wMB-IyieEhd&H!%x&{#y zZS^SR?EeE2!fHTbTNk=k%9&q~3S24Wg;R^5PqE*s2HXNn*pGbPf(k^!pqj8qGW}Rg z-wN71NOkRp=@4$x1S5XZ4uqA;G`9ibB*Ma|hqab4iS%u$Yy+MPdq_BuAr;1eJ%t~` zl;;=D#m)A)cCEeAX|?_8cEDC1Z3RJN#k<&G>zBjMxuK;vM>AL3PsF4Lt*uo(YLhx1 z$2!q@6pG`hhHB{Ae`|*JpH{}!(zZ2h>yGLG=4ggG`?Y28S1_ka6A%6flk0e*MHGPo zd#jMGg`L%y4jX7N1EOyVn?xO?4Z4@8bgK;r2ZYOyT^|BYr*mt~HUtV5OWLc*g^_>_ zaW{C_98-GQlOCz`IaFd;`yKU9u{ZY8%H89%nY#tM1jE>gV$zx_w(%jbB(5{%F#d43 zS-@^{9`Zd+7*WvJ5Gt3nPKzb1E^N=E*`D_Uv?AJBQM*$^gjR>WUsPm7CNvOahTJFl1Fz?iRf0dRYQ}Im(!lu`C{5L6Fe}P z#WHwX%w}1lU=1;0G+!fjb1of(*hY_%gCR17opT z)p3mBkLn{H712o4MDdhFLn-;Rrk!vVZV2OW`@(IxQ)rjt>xtFe}lccAR(+c;HSmu)R=Z)!X0101Tnf1o`>=#T;l z5Sh&YQX2F0?3z5gFhkJhi1b*V7kuVCPTLIt@E=@DUNo|Dn5O zTgySrIpLAg=-j9_k|2RiTad!vN7qnbk8DQ+j%-JKyGgT1pHn)4HrftoMc3(796;)r z$dk;3yw;VssIxENW2$lGlFh$E3!J9n3>9ao zc$10?R9vLurJ4j+QMrpJBI=PQ*@kV|IwyD)&)APheI3s)vt?3m?(y*P6R9`vj_Zx= zkT?6d-uN%k8rpUEqxv`HKzBy&v@*sAehDkQl;oS}JVf#l8vAC9pQ1ISEbSN4F1>{g zHe5s6C4#)1j`z^}?d%epfPJ!Aj^**rvI3jL+hIjEh4%!ThV0FV0x8a|+9rHa$$;zQ z3`l!kz=2=EauM1GEmy4d^kb_L7$0MhFM=K ziN&mKo3F7<&u-a?MKaN|6PsnWwWxu&y{+*s%QEM4rI$^zUn;HZfKCAVG?ne1lQ@9B z31|V(zf0r7-b6A1=q#X9fc^uUW;0kJm*l=w{#@Bm*({s;-0tPSP~`sq%&Z5f^$M|( z;J)fjCX;ou{qJnPS47R?|CJQk0@W6jx0POzEdrBFLU`L7`n=McV#grc#SIPh=`WOI z3Tw>ZJ&pHllF}r*tvyxw_lX9EQg_(W+ql*}r)9Gxf_V;mh2C`sYs|$6eyC2N4?7NO z%_sATk=AhnwBmffu&azgCi_M9>aI%t@l=00ncr3WGrPcxo%l22%|c2~oZ_E=_hK@G zlP%Es>9mRYRE>U~$==Dym!H^^%(>_QOtX`FdGrG1qTtw&(?%eow zapT{|QI4R+KO)?WXv@FA%cyel9gbjwZi&s$(D^H4GhC#b0X8caFTeGh#K^*K*y80l zO{4=PT7Pp0t+&4olMbwtVs`n$#osh$*y8`j3R~x##M8U0d!INgL@bzwD;=DQy;)5%CW!*Jwbh@@dmuc46P% zJw@licCG5WXQE}dy1!L7J8<#NM5Q?{-ID8sfsUX|n8=PH2qTUNqwU9A!h~t$PxhTO zehq#6Jt`~B|B~r&x` zX~}QVpxab@kBSedxPt<@fDy+0cL};i1x1AXN7S$V;1=bFVo(9eA5W%A8Q+p!H!cY6 z#zmpuK?TJ{k!e*Q`VF8|p?)i+i^%XGYRmbOPU|%|W9vw?q=H3ppiC`@nHQMYKSFQx z7bp}nr{>gx{6nY&Kh)NWs%=>0gN>DjmP5ax8!DxZEVZCbs|2yNf;x?NPMyXoc(i%g z`Dx8UjJJfqSA+K;|Gu{LoQ^$oO)Y$Fpg)IIhEGxJp8DlRXG{x8t|@wwDVk|i5U(n{ zK$<9>U`oL1-O~La3SxK6HASuzt}9ZjNRjh^)sVwOqFpLV8ELtRTI3DEsjR(^)k}kP zg^RkdwvhaQf` zhMH(UA(z~$AMd}Kz-OV^iRBpyxx#6rBe5^#yWz-vTJyJ&)!GmLNLR={xzKPI=~r~7 z255zB&azwEK*~E{0b6xOYYg48VS;rPq9hj?ji@~ZXKMd}A{Cx)kv?hAii1Qzz^_Vi zN%wk2;@Zum4HsESbEDyJB2t1CB8lYRMStmpn4p-b6CuJvK2#bz5WpQTj*8 zF2X>;BBXX)kSHpV0vJdkmXj4uN}Z)V36##)$XwuYadn}Q#@i3-HNb$my>s&uDOgL>_zA$InMO6$0x#Ll+E*HkD26m`(^snXJZ zL`pIt!}Z)Qlz7z2Q)?j91(|m<%2FzXJ(OT6X{AX{2TX-SUT)*;NG0M648gaE04Yo< zI|XD-cx}BC2QvRH@;ulCj}VJf;+&Hg$p3^2DQ+jIHXgmptlK=qJ(@?Sg1f?2=V9Z) z1T(!u>=)%R(!|~oGLx7|GQWY!H%-v;-@;(NOvO1W4jqsZgm2OTiHD=S>)avUr}^0< z2O{3f139RC)5NPxN1mrGX*xa=9Nmo4uH{nhCL&uQzxt-;VG?O~NKVUdz?-c#BKegIu9&P#D|7tj-SXP)@|w5y>Al|Zrop!-<%NM$}gDmBZ$o0a!NZ&gbr|g oL6e#lI)+83Q5c#1G?ES1WfqnIe`FbSd%2h?&K2$d1#R)!TmS$7 diff --git a/venv/lib/python3.8/site-packages/requests/__pycache__/certs.cpython-38.pyc b/venv/lib/python3.8/site-packages/requests/__pycache__/certs.cpython-38.pyc deleted file mode 100644 index 6d73935e9ef97c13d2a7609d755e460d6140e494..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 573 zcmY*W!DlbPzVx;x2UM944r z6Ml$4F-JZ53!dzm9YG7a=z8>fRj=#g(UBA>9$p>m@0k!k`{LioQ}H$(f0B|BH^O8l zud^n<$uofm=HNEx=QzRqQ9NduFq02rK8+ViN-}^t@Y426Ke#< z5ScuLEkes!Au}28Rd;BZMDcz77)oy<*o4 z#Ylx#m$!O@g_M^S>|6w$*n7~@2Hua;E&z*7v4F}kXn1ESK7g@4uwBPs9l?M%nv#~0 zNOzVUHArDGh?bh5+-ln3&^%eNWcR!Z?)!;f%pthZaq8f))tqeAJ2_5hdc&hh`73?9 zm}lK|;C3^m8f{6btNFA$RLZzgsqS#}$o;nZH>4X(__Sq9;hW%D!iV(xbQPL*)!KF$ tsqcqonUt|!s?*x6U%I&ZySCM^wxZp2v)B7Iy_qB#|0Jc!(`WfC`vc`rv&jGe diff --git a/venv/lib/python3.8/site-packages/requests/__pycache__/compat.cpython-38.pyc b/venv/lib/python3.8/site-packages/requests/__pycache__/compat.cpython-38.pyc deleted file mode 100644 index 3182fd7fa7babca13740e4403f4d68508ccf035f..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1667 zcmZuwTaVjB6!tBS<2cFQFEn)1%TfZnN!e`?NEJdVJoI7PN(BM)VmbC?GrKb$@65Pu zR*2ug-{2qcTjrIgm3ZKpC(hW}63UJ>pU-9H_&dkveBbGW7Ob~l?k7*0mi32GmRA7E z*RbVZwq<1&vM!^{&KznZ`v)uUdlq)iLvdhR=BYd`vVXF2=f_&}kcYjq2J*3=*}GQe zo;#?ykUfxtMZ6XYm*V}r6fZzinT4if! zjjf|~wt+S(K0e)Kn`o15p)IzJw%HEaVY_Iz@-^uP>=wGU;N3@kh#k-m*==;YvbE?Q z+e3Sm9MS>1gYK}q=q|g5?y>vmzHQ-s^bza__+zw>hiHgD!Jp!Tsf!McGg2-e8;$Ue48w=YyjG+zA)T@hH49?f3l30labnhArK= zD7nJAS?0A6R-#g3pVM7NHxJZPAxFD5zEjK|v<0P-#vVbhLVUXdeNKS{g?p4R)nNmeeiBw?n zPdG%OAO)|KAo=OD7eh}6PZLU$356t2lA-{!?w*v&Sg!T<3z1=gvu{YMhN0*{X++mR z&%lZSGpxch&@kW|fT6a;D!{NI){NXTV1{0_4MYGyrj>GjPViYGhPK!-HdkyK|CWJm zWB6P*<2d7K9P4H}OMs2i?Pt}G{#FPs(3-JItm2#tmQZqug?8l}%KsV*Nq8QUe9E;K zgQ|TZ<6?facpsxsLeEfqCV8&C3Vo;~C6gNysxrMHlN-xovWMoWq8(L5xK0l=4LBPF^xBNE)ko0k=AE0H0#9P@|gZsBW?DLR*ZX_DnO0UBfdnB8;W^aZ)>k z>)sOcQ8Gz?v&0uBEdzfaj}$MQG@Cr;<@kEk$MxKfin$J+ z)RX;{8AbULzzZBZvb%QI37WnexskKbecwKC```;;N6wDx+4U3Jq2t>RZR0bZ$lh>j IPXK5C0ZD_+^#A|> diff --git a/venv/lib/python3.8/site-packages/requests/__pycache__/cookies.cpython-38.pyc b/venv/lib/python3.8/site-packages/requests/__pycache__/cookies.cpython-38.pyc deleted file mode 100644 index 4a0d146b1b7dd43a68625578d8e7a64794a215ea..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 18786 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 Mj})EZcaqNj3w58MVgLXD diff --git a/venv/lib/python3.8/site-packages/requests/__pycache__/help.cpython-38.pyc b/venv/lib/python3.8/site-packages/requests/__pycache__/help.cpython-38.pyc deleted file mode 100644 index c48ddb787fed8c516c36989465a0188bcf961725..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2845 zcmZ`5U2oh(&|ZI@<6J&U(^9@%piNIoE~2GERDcjApj0%8nih(MWSrYg&KI9;)_ZL) zT%@A(6~qJLsSoWV|AYtLk@l6RzVn1o%goxBCaE~z&g_h5XJ%(-#(QgW($nB~@BMS} z{V7fR3yH%&7l@Bxl(w#ER0}n#Qc4#Z?gpR^)=u(qf zX`}Cj6S}tRE3O~!9HRXs|&; zcA#?(I1X^`A8<_S?&%|Kq|?Sj0`c(TKVd&Nm>BRZhy$8*L~u6|-9U6%us#&sJPVS3 zk+MF6aA5#~IHN(m^S0*&@LT8korJPrGp`qBai1wU)Kbd^`PTm{Rcbl|&cRAL4EP|! zgJ}n!?yGa?0Pd2!l^PMu-WTiN43b(sHTpwNuk}N1B?Kn&zy` z=D{UU6KsLw*Q)TrY=!4pQpEEP$yILL~) zv%~1(-7aJ4VstU3o0s#!5@+8HAo%4HR(rb`%Bf?!cnhobJOFLNC9dx2E-(f0^7s0rApu_+u*;jN?I8p7oqC|6M?Hf(Bx9ZNL$FQU=2sRPjK zP0T@?Kt9O&Vv@Sl+BZO}t?1?f?TD$~#GXry5w@HL|ARUscMe)RwLrRoO=Q#%)A&xH zggdfEWMqzvkv(!i*Gz&<#>XbJd;W8lF&+!ddrZ(O>oIZTL*2IxhiyZ?2-cTQoeJEC z=MWP(n|M4*GO>x?*&? zF)x{jAP@U-n(Q(jLNi~3X1=lUg>(iyO_R+_(m^@Ogq(eGf%H3kScrU^$3=H2&4gyL zbjNAdnyox~9o>2Z-EvmemN|!l#>C-oB0$&q+XyiEq*L1u4Rm5|ZGCwaCefG6H#Sz* zR-@Hh*FRalA)RdoO<8b$4i{p=LcNtKw{SK+wm%M0%L^yRM*ik) zuyLe@(WnhW)$kdZ2uTc)&>255d|o=J-i`bDXHt0HqeMt!)# z`~d1o)Tt4E8K88d2>Ea?IVGJaqIoBZq!+;*20uMf#8H@ELZC`z7H10xFomjo#9FJ8 zauH{knQ~&KkC&t>bumq$rmE^_<86v3n=12o3s~ms08{s&{i+8s@!{xwy{UVL@HEgSCICtp?pgOk*YfoL02;>#nE(I) diff --git a/venv/lib/python3.8/site-packages/requests/__pycache__/hooks.cpython-38.pyc b/venv/lib/python3.8/site-packages/requests/__pycache__/hooks.cpython-38.pyc deleted file mode 100644 index d89ba531aff87422e67eb1d8ee67eeed713b128b..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 944 zcmY*Y&ubJh6i(*XPNNkR!HY;dC~Tp#Qc$pzqS!;B(t=wrg)*B?vb$ktccw|Ub<3=m z_Uy%fK#v~%cXIV_@Z!mrbW68yc;95cyu8WxW#;qhDnSrm-o9Xe1BCv#hvfhcy@S-x z0602A91rjj<^d0{&{4o69>YE4Nf)(S7r%)Tr&FPg&W2Sr(&X!%Amnf;H62%cS_)dL z>P&K>sTm4du$rC7QW^b^<;8#3muVo)WsQCR+4* zn}k9fLem?L4#Y$#W(22wRgEd5i_RIb=}l1q0`G*A{sB@y0N^0`3K_J6E-^?A_Y1sK z>`EiZE~I`0AW?&k$s9L$fW8N(Q5XF}%2l-k8)UC+EY8Hlc*euOjgA@Dom$rG(@D*W zk>Km+Lm|rbe52$iud8Y2#@UY7oYgZ+wzw=zQH|?u_fDMvBq)IE;yD+6HZ4tlUA$FR z1uOM-cDtgDZM=JMu-Coa#PukKE_U_K`iHK&+daZ61uQ~0UW9wA)4m6(KLRwkP9$>L ze}D@=u^Xvf1IY1Zpk9I}p4&mkPv=n+H9;RY;Ws>wo0tcq6}8sH^Wb!?37pXvZ+4`v znJI?wVK9H-)XA3BgsB;=CO{4(xJhd%3PGzr<;<|mrg;vU%RJu)&%=Q*wl!p$8Kc^X z4M$>TV{eXKaktzpvdQS2se!hUqb%|6`I#k?7XB5lWLtU8t0K=;3kdI{pIU0|ELOgMx^?}NY&)m@!AAFzFirjgzjW_+ diff --git a/venv/lib/python3.8/site-packages/requests/__pycache__/models.cpython-38.pyc b/venv/lib/python3.8/site-packages/requests/__pycache__/models.cpython-38.pyc deleted file mode 100644 index 7b3e99740fbe729025eb0b51abca3e394ff8a55f..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 24428 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 O#7(e^w;kW^b@4BbZ?-M~ diff --git a/venv/lib/python3.8/site-packages/requests/__pycache__/sessions.cpython-38.pyc b/venv/lib/python3.8/site-packages/requests/__pycache__/sessions.cpython-38.pyc deleted file mode 100644 index 284c09bd4c68ebc89e2a2194f575e5d5fd6b85f4..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 19887 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 diff --git a/venv/lib/python3.8/site-packages/requests/__pycache__/status_codes.cpython-38.pyc b/venv/lib/python3.8/site-packages/requests/__pycache__/status_codes.cpython-38.pyc deleted file mode 100644 index 0f9313a48a4ad6e350b9e00ccc77ea9f904a5852..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4199 zcmaJ^U2q&n5#HVV(djH%k}dzlV6uRXk+CHIh1kX@0qhV+FsZWP!Le(#+Mc`HXm95{ zJEy;rd9kZV3KB>R2>}Oes`xPl#RG2?FTe}`@H~&<$SPbbzL5hGyv?9iqc@gpSf9^kI6Gj?r;CK_8)$^ii6l$LMkT7=4^RL8s_6Jwczm ze(HQdc=RNF>P7c_kv>gNU3JcvMCpnHE1y2=OnoNY>^V;LTtoQt^N}Qx&CmOC;W-g$ zpF}NAMdpWoGilGZ2FOGHf8FkVH3QXRQ{9a&OPI2I@Ik;)O)`B8H6eLnzl;#S3i>T~GxA#gUF>8miT5tVJ`Msa8*~gw0kW zPMoM#ef;L;=KQ$Xl1lqZTxyFlc z?KqLkc#XnL_)9`%a2rvmRS}y`cta)pFkvy8@t;6|L>`I*-QAjzi}UmS(Py9H5tgcU zb`$(?67v-|#Z)r5>p+3-{b?5wbck0NG5cL}CshfqJ(3YCt-q{kWR5T=S|#BP3& z*Mu4Crb3snsn3qh=6kp?)*lZOI7FPXoaENAp|}~Kyx7O_-h`+jW5j!^U?!S!Nl<{q zYKAH7PF79Hk~mh=m{h9CcFIv1&V&e%hC-Q=eSkTVN*y#M#kJV3FpQOWV^>z0neTOH zTrgWUmXsOm)9k8dxJQ6-TY6^oiqK3TjOY*85wsIji58}ulVIbfg^(a>OWPDMU^Cij zXD`?6?vA&@)h0Z(awu#vh`*&kco=PIAtn+jd(7Th_ty&32!?02GzGGP0%mlo%WN7L zK*MG`w8<2rVZn>tHXt^kuq^r-XG?!|&i$2D%Qln!_r56B9qVSjj+;WZwHfNXU_mag zT9TJqu`W|Cv#~^^b=~MK0u@_Z=wYbf*sfj+;{=|M3=%PKXLlW5U9aY47pgkz+}7pw zD$g@#hMEm zg(P}AXNEcyFt-ivR!>4b#!c5V6Wk+F#9aOP*=8zT64*N$=nO&ysMLhA{?3~5w^JaD zoQ4+e_?a+8v^@c0RSAvb5DmP+%?$4#?petF4;Gk{l3dOLv@=Aj)8G_3yqVZQ!qnX; z%q8TZ4KM00NJJfz(7`gSYew%Gasoz4481{=Nc6L=muQ;Xa8L-9Vs0iBj>AAGB^CP5 zz-X;7D=&0f|7%b-#$}4TKq9yo*yd%MM;+(Ea>$--<>}~>!GM`&)4+hWbi{*hIeKPS zL+e)1Ih6B^?iPm`8RTL5j-^n=AzTWROa`f_OPmY1(10}=qo``NII=Eh8dniip=Wk3 z;EZ053B{en%~%IwB@%*A%fmemrrX9WR&Wx5#if=Cy)4z@1G~`3pa4$5`-)GUx=l#7 z+k&CSP-j?U_zlBv8Ggs`dxk$S{E^{L41Z?$3&Wd$_yBGT@ifB>!z{x=hC>X88ICX< zW%w$?%M7nDTx0ke!`B&JWq6I@8w{^Ae3Ri@4A&XnVE8t}cNlIk++_GJ!}l1z&+r3= zA2Qrx_z}a88Ggd>Q-)tK{F32U48Lah8^hlj{=x81hJP{qo8dnUcNqT5@IQvT3~vFD zsP+nsrhwZnHm}Gxx^F95W2!@cR8axNab;9YhuyX!9A_h0t3rwi-e zx^t!AI_utzBDpu+Y%-_bDBW~&&ZWsq74oQX)p^0uWpWmW)e@e?9S#+541Lk5x%?4w zwW2H9xdP2spk;@XdiY#{G%o)`XQsS6?u9$1i9pqi>cmPd47H` zzC6y{;uh%595imKp2q|WcaG2MW^1+;x2DmyL+;bl%MBrt>ELie3y;Y5Y`0g=4(`EB zYt;;&tcw(C z6){zsZ-F>4?8l243IaG71nNbeSI+WVYQdU<6FSz3$V|yTbCa$?E{{yfTCvEM?F2aP zxLa{Y+^Re2RffuUEAFnhik^2@y#d~tsj_+2EcLVUGgYrL{(r3tIW7PI diff --git a/venv/lib/python3.8/site-packages/requests/__pycache__/structures.cpython-38.pyc b/venv/lib/python3.8/site-packages/requests/__pycache__/structures.cpython-38.pyc deleted file mode 100644 index 62478385409f89a5677d7300db9daaf4434e1587..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4412 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 SMk!fayKcffngd&m} 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 being sent. - :param stream: (optional) Whether to stream the request content. - :param timeout: (optional) How long to wait for the server to send - data before giving up, as a float, or a :ref:`(connect timeout, - read timeout) ` tuple. - :type timeout: float or tuple - :param verify: (optional) Either a boolean, in which case it controls whether we verify - the server's TLS certificate, or a string, in which case it must be a path - to a CA bundle to use - :param cert: (optional) Any user-provided SSL certificate to be trusted. - :param proxies: (optional) The proxies dictionary to apply to the request. - """ - raise NotImplementedError - - def close(self): - """Cleans up adapter specific items.""" - raise NotImplementedError - - -class HTTPAdapter(BaseAdapter): - """The built-in HTTP Adapter for urllib3. - - Provides a general-case interface for Requests sessions to contact HTTP and - HTTPS urls by implementing the Transport Adapter interface. This class will - usually be created by the :class:`Session ` class under the - covers. - - :param pool_connections: The number of urllib3 connection pools to cache. - :param pool_maxsize: The maximum number of connections to save in the pool. - :param max_retries: The maximum number of retries each connection - should attempt. Note, this applies only to failed DNS lookups, socket - connections and connection timeouts, never to requests where data has - made it to the server. By default, Requests does not retry failed - connections. If you need granular control over the conditions under - which we retry a request, import urllib3's ``Retry`` class and pass - that instead. - :param pool_block: Whether the connection pool should block for connections. - - Usage:: - - >>> import requests - >>> s = requests.Session() - >>> 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): - if max_retries == DEFAULT_RETRIES: - self.max_retries = Retry(0, read=False) - else: - self.max_retries = Retry.from_int(max_retries) - self.config = {} - self.proxy_manager = {} - - super(HTTPAdapter, self).__init__() - - self._pool_connections = pool_connections - self._pool_maxsize = pool_maxsize - self._pool_block = pool_block - - self.init_poolmanager(pool_connections, pool_maxsize, block=pool_block) - - def __getstate__(self): - return {attr: getattr(self, attr, None) for attr in self.__attrs__} - - def __setstate__(self, state): - # Can't handle by adding 'proxy_manager' to self.__attrs__ because - # self.poolmanager uses a lambda function, which isn't pickleable. - self.proxy_manager = {} - self.config = {} - - for attr, value in state.items(): - setattr(self, attr, value) - - self.init_poolmanager(self._pool_connections, self._pool_maxsize, - block=self._pool_block) - - 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 - exposed for use when subclassing the - :class:`HTTPAdapter `. - - :param connections: The number of urllib3 connection pools to cache. - :param maxsize: The maximum number of connections to save in the pool. - :param block: Block when no free connections are available. - :param pool_kwargs: Extra keyword arguments used to initialize the Pool Manager. - """ - # save these values for pickling - self._pool_connections = connections - self._pool_maxsize = maxsize - self._pool_block = block - - self.poolmanager = PoolManager(num_pools=connections, maxsize=maxsize, - block=block, strict=True, **pool_kwargs) - - def proxy_manager_for(self, proxy, **proxy_kwargs): - """Return urllib3 ProxyManager for the given proxy. - - This method should not be called from user code, and is only - exposed for use when subclassing the - :class:`HTTPAdapter `. - - :param proxy: The proxy to return a urllib3 ProxyManager for. - :param proxy_kwargs: Extra keyword arguments used to configure the Proxy Manager. - :returns: ProxyManager - :rtype: urllib3.ProxyManager - """ - if proxy in self.proxy_manager: - manager = self.proxy_manager[proxy] - elif proxy.lower().startswith('socks'): - username, password = get_auth_from_url(proxy) - manager = self.proxy_manager[proxy] = SOCKSProxyManager( - proxy, - username=username, - password=password, - num_pools=self._pool_connections, - maxsize=self._pool_maxsize, - block=self._pool_block, - **proxy_kwargs - ) - else: - proxy_headers = self.proxy_headers(proxy) - manager = self.proxy_manager[proxy] = proxy_from_url( - proxy, - proxy_headers=proxy_headers, - num_pools=self._pool_connections, - maxsize=self._pool_maxsize, - block=self._pool_block, - **proxy_kwargs) - - return manager - - def cert_verify(self, conn, url, verify, cert): - """Verify a SSL certificate. This method should not be called from user - code, and is only exposed for use when subclassing the - :class:`HTTPAdapter `. - - :param conn: The urllib3 connection object associated with the cert. - :param url: The requested URL. - :param verify: Either a boolean, in which case it controls whether we verify - the server's TLS certificate, or a string, in which case it must be a path - to a CA bundle to use - :param cert: The SSL certificate to verify. - """ - if url.lower().startswith('https') and verify: - - cert_loc = None - - # Allow self-specified cert location. - if verify is not True: - cert_loc = verify - - if not cert_loc: - 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)) - - 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.ca_certs = None - conn.ca_cert_dir = None - - if cert: - if not isinstance(cert, basestring): - conn.cert_file = cert[0] - conn.key_file = cert[1] - else: - 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)) - 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)) - - def build_response(self, req, resp): - """Builds a :class:`Response ` object from a urllib3 - response. This should not be called from user code, and is only exposed - for use when subclassing the - :class:`HTTPAdapter ` - - :param req: The :class:`PreparedRequest ` used to generate the response. - :param resp: The urllib3 response object. - :rtype: requests.Response - """ - response = Response() - - # Fallback to None if there's no status_code, for whatever reason. - response.status_code = getattr(resp, 'status', None) - - # Make headers case-insensitive. - response.headers = CaseInsensitiveDict(getattr(resp, 'headers', {})) - - # Set encoding. - response.encoding = get_encoding_from_headers(response.headers) - response.raw = resp - response.reason = response.raw.reason - - if isinstance(req.url, bytes): - response.url = req.url.decode('utf-8') - else: - response.url = req.url - - # Add new cookies from the server. - extract_cookies_to_jar(response.cookies, req, resp) - - # Give the Response some context. - response.request = req - response.connection = self - - return response - - def get_connection(self, url, proxies=None): - """Returns a urllib3 connection for the given URL. This should not be - called from user code, and is only exposed for use when subclassing the - :class:`HTTPAdapter `. - - :param url: The URL to connect to. - :param proxies: (optional) A Requests-style dictionary of proxies used on this request. - :rtype: urllib3.ConnectionPool - """ - proxy = select_proxy(url, proxies) - - if proxy: - 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.") - proxy_manager = self.proxy_manager_for(proxy) - conn = proxy_manager.connection_from_url(url) - else: - # Only scheme should be lower case - parsed = urlparse(url) - url = parsed.geturl() - conn = self.poolmanager.connection_from_url(url) - - return conn - - def close(self): - """Disposes of any internal state. - - Currently, this closes the PoolManager and any active ProxyManager, - which closes any pooled connections. - """ - self.poolmanager.clear() - for proxy in self.proxy_manager.values(): - proxy.clear() - - def request_url(self, request, proxies): - """Obtain the url to use when making the final request. - - If the message is being sent through a HTTP proxy, the full URL has to - be used. Otherwise, we should only use the path portion of the URL. - - This should not be called from user code, and is only exposed for use - when subclassing the - :class:`HTTPAdapter `. - - :param request: The :class:`PreparedRequest ` being sent. - :param proxies: A dictionary of schemes or schemes and hosts to proxy URLs. - :rtype: str - """ - proxy = select_proxy(request.url, proxies) - scheme = urlparse(request.url).scheme - - 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') - - url = request.path_url - if is_proxied_http_request and not using_socks_proxy: - url = urldefragauth(request.url) - - return url - - def add_headers(self, request, **kwargs): - """Add any headers needed by the connection. As of v2.0 this does - nothing by default, but is left for overriding by users that subclass - the :class:`HTTPAdapter `. - - This should not be called from user code, and is only exposed for use - when subclassing the - :class:`HTTPAdapter `. - - :param request: The :class:`PreparedRequest ` to add headers to. - :param kwargs: The keyword arguments from the call to send(). - """ - pass - - def proxy_headers(self, proxy): - """Returns a dictionary of the headers to add to any request sent - through a proxy. This works with urllib3 magic to ensure that they are - correctly sent to the proxy, rather than in a tunnelled request if - CONNECT is being used. - - This should not be called from user code, and is only exposed for use - when subclassing the - :class:`HTTPAdapter `. - - :param proxy: The url of the proxy being used for this request. - :rtype: dict - """ - headers = {} - username, password = get_auth_from_url(proxy) - - if username: - headers['Proxy-Authorization'] = _basic_auth_str(username, - password) - - return headers - - 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 ` being sent. - :param stream: (optional) Whether to stream the request content. - :param timeout: (optional) How long to wait for the server to send - data before giving up, as a float, or a :ref:`(connect timeout, - read timeout) ` tuple. - :type timeout: float or tuple or urllib3 Timeout object - :param verify: (optional) Either a boolean, in which case it controls whether - we verify the server's TLS certificate, or a string, in which case it - must be a path to a CA bundle to use - :param cert: (optional) Any user-provided SSL certificate to be trusted. - :param proxies: (optional) The proxies dictionary to apply to the request. - :rtype: requests.Response - """ - - try: - conn = self.get_connection(request.url, proxies) - except LocationValueError as e: - raise InvalidURL(e, request=request) - - 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) - - 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) - 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 - ) - - # 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: - raise ConnectionError(err, request=request) - - except MaxRetryError as e: - if isinstance(e.reason, ConnectTimeoutError): - # TODO: Remove this in 3.0.0: see #2811 - if not isinstance(e.reason, NewConnectionError): - raise ConnectTimeout(e, request=request) - - if isinstance(e.reason, ResponseError): - raise RetryError(e, request=request) - - if isinstance(e.reason, _ProxyError): - raise ProxyError(e, request=request) - - if isinstance(e.reason, _SSLError): - # This branch is for urllib3 v1.22 and later. - raise SSLError(e, request=request) - - raise ConnectionError(e, request=request) - - except ClosedPoolError as e: - raise ConnectionError(e, request=request) - - except _ProxyError as e: - raise ProxyError(e) - - except (_SSLError, _HTTPError) as e: - if isinstance(e, _SSLError): - # This branch is for urllib3 versions earlier than v1.22 - raise SSLError(e, request=request) - elif isinstance(e, ReadTimeoutError): - raise ReadTimeout(e, request=request) - else: - raise - - return self.build_response(request, resp) diff --git a/venv/lib/python3.8/site-packages/requests/api.py b/venv/lib/python3.8/site-packages/requests/api.py deleted file mode 100644 index 4cba90e..0000000 --- a/venv/lib/python3.8/site-packages/requests/api.py +++ /dev/null @@ -1,159 +0,0 @@ -# -*- coding: utf-8 -*- - -""" -requests.api -~~~~~~~~~~~~ - -This module implements the Requests API. - -:copyright: (c) 2012 by Kenneth Reitz. -:license: Apache2, see LICENSE for more details. -""" - -from . import sessions - - -def request(method, url, **kwargs): - """Constructs and sends a :class:`Request `. - - :param method: method for the new :class:`Request` object: ``GET``, ``OPTIONS``, ``HEAD``, ``POST``, ``PUT``, ``PATCH``, or ``DELETE``. - :param url: URL for the new :class:`Request` object. - :param params: (optional) Dictionary, list of tuples or bytes to send - in the query string for the :class:`Request`. - :param data: (optional) Dictionary, list of tuples, bytes, or file-like - object 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 headers: (optional) Dictionary of HTTP Headers to send with the :class:`Request`. - :param cookies: (optional) Dict or CookieJar object to send with the :class:`Request`. - :param files: (optional) Dictionary of ``'name': file-like-objects`` (or ``{'name': file-tuple}``) for multipart encoding upload. - ``file-tuple`` can be a 2-tuple ``('filename', fileobj)``, 3-tuple ``('filename', fileobj, 'content_type')`` - or a 4-tuple ``('filename', fileobj, 'content_type', custom_headers)``, where ``'content-type'`` is a string - defining the content type of the given file and ``custom_headers`` a dict-like object containing additional headers - to add for the file. - :param auth: (optional) Auth tuple to enable Basic/Digest/Custom HTTP Auth. - :param timeout: (optional) How many seconds to wait for the server to send data - before giving up, as a float, or a :ref:`(connect timeout, read - timeout) ` tuple. - :type timeout: float or tuple - :param allow_redirects: (optional) Boolean. Enable/disable GET/OPTIONS/POST/PUT/PATCH/DELETE/HEAD redirection. Defaults to ``True``. - :type allow_redirects: bool - :param proxies: (optional) Dictionary mapping protocol to the URL of the proxy. - :param verify: (optional) Either a boolean, in which case it controls whether we verify - the server's TLS certificate, or a string, in which case it must be a path - to a CA bundle to use. Defaults to ``True``. - :param stream: (optional) if ``False``, the response content will be immediately downloaded. - :param cert: (optional) if String, path to ssl client cert file (.pem). If Tuple, ('cert', 'key') pair. - :return: :class:`Response ` object - :rtype: requests.Response - - Usage:: - - >>> import requests - >>> req = requests.request('GET', 'https://httpbin.org/get') - >>> req - - """ - - # By using the 'with' statement we are sure the session is closed, thus we - # avoid leaving sockets open which can trigger a ResourceWarning in some - # cases, and look like a memory leak in others. - with sessions.Session() as session: - return session.request(method=method, url=url, **kwargs) - - -def get(url, params=None, **kwargs): - r"""Sends a GET request. - - :param url: URL for the new :class:`Request` object. - :param params: (optional) Dictionary, list of tuples or bytes to send - in the query string for the :class:`Request`. - :param \*\*kwargs: Optional arguments that ``request`` takes. - :return: :class:`Response ` object - :rtype: requests.Response - """ - - return request('get', url, params=params, **kwargs) - - -def options(url, **kwargs): - r"""Sends an OPTIONS request. - - :param url: URL for the new :class:`Request` object. - :param \*\*kwargs: Optional arguments that ``request`` takes. - :return: :class:`Response ` object - :rtype: requests.Response - """ - - return request('options', url, **kwargs) - - -def head(url, **kwargs): - r"""Sends a HEAD request. - - :param url: URL for the new :class:`Request` object. - :param \*\*kwargs: Optional arguments that ``request`` takes. If - `allow_redirects` is not provided, it will be set to `False` (as - opposed to the default :meth:`request` behavior). - :return: :class:`Response ` object - :rtype: requests.Response - """ - - kwargs.setdefault('allow_redirects', False) - return request('head', url, **kwargs) - - -def post(url, data=None, json=None, **kwargs): - r"""Sends a POST request. - - :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 \*\*kwargs: Optional arguments that ``request`` takes. - :return: :class:`Response ` object - :rtype: requests.Response - """ - - return request('post', url, data=data, json=json, **kwargs) - - -def put(url, data=None, **kwargs): - r"""Sends a PUT request. - - :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 \*\*kwargs: Optional arguments that ``request`` takes. - :return: :class:`Response ` object - :rtype: requests.Response - """ - - return request('put', url, data=data, **kwargs) - - -def patch(url, data=None, **kwargs): - r"""Sends a PATCH request. - - :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 \*\*kwargs: Optional arguments that ``request`` takes. - :return: :class:`Response ` object - :rtype: requests.Response - """ - - return request('patch', url, data=data, **kwargs) - - -def delete(url, **kwargs): - r"""Sends a DELETE request. - - :param url: URL for the new :class:`Request` object. - :param \*\*kwargs: Optional arguments that ``request`` takes. - :return: :class:`Response ` object - :rtype: requests.Response - """ - - return request('delete', url, **kwargs) diff --git a/venv/lib/python3.8/site-packages/requests/auth.py b/venv/lib/python3.8/site-packages/requests/auth.py deleted file mode 100644 index eeface3..0000000 --- a/venv/lib/python3.8/site-packages/requests/auth.py +++ /dev/null @@ -1,305 +0,0 @@ -# -*- coding: utf-8 -*- - -""" -requests.auth -~~~~~~~~~~~~~ - -This module contains the authentication handlers for Requests. -""" - -import os -import re -import time -import hashlib -import threading -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 .utils import parse_dict_header - -CONTENT_TYPE_FORM_URLENCODED = 'application/x-www-form-urlencoded' -CONTENT_TYPE_MULTI_PART = 'multipart/form-data' - - -def _basic_auth_str(username, password): - """Returns a Basic Auth string.""" - - # "I want us to put a big-ol' comment on top of it that - # says that this behaviour is dumb but we need to preserve - # it because people are relying on it." - # - Lukasa - # - # These are here solely to maintain backwards compatibility - # for things like ints. This will be removed in 3.0.0. - if not isinstance(username, basestring): - warnings.warn( - "Non-string usernames will no longer be supported in Requests " - "3.0.0. Please convert the object you've passed in ({!r}) to " - "a string or bytes object in the near future to avoid " - "problems.".format(username), - category=DeprecationWarning, - ) - username = str(username) - - if not isinstance(password, basestring): - warnings.warn( - "Non-string passwords will no longer be supported in Requests " - "3.0.0. Please convert the object you've passed in ({!r}) to " - "a string or bytes object in the near future to avoid " - "problems.".format(type(password)), - category=DeprecationWarning, - ) - password = str(password) - # -- End Removal -- - - if isinstance(username, str): - username = username.encode('latin1') - - if isinstance(password, str): - password = password.encode('latin1') - - authstr = 'Basic ' + to_native_string( - b64encode(b':'.join((username, password))).strip() - ) - - return authstr - - -class AuthBase(object): - """Base class that all auth implementations derive from""" - - def __call__(self, r): - raise NotImplementedError('Auth hooks must be callable.') - - -class HTTPBasicAuth(AuthBase): - """Attaches HTTP Basic Authentication to the given Request object.""" - - def __init__(self, username, password): - self.username = username - self.password = password - - def __eq__(self, other): - 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) - return r - - -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) - return r - - -class HTTPDigestAuth(AuthBase): - """Attaches HTTP Digest Authentication to the given Request object.""" - - def __init__(self, username, password): - self.username = username - self.password = password - # Keep state in per-thread local storage - self._thread_local = threading.local() - - def init_per_thread_state(self): - # Ensure state is initialized just once per-thread - if not hasattr(self._thread_local, 'init'): - self._thread_local.init = True - self._thread_local.last_nonce = '' - self._thread_local.nonce_count = 0 - self._thread_local.chal = {} - self._thread_local.pos = None - self._thread_local.num_401_calls = None - - def build_digest_header(self, method, url): - """ - :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') - hash_utf8 = None - - if algorithm is None: - _algorithm = 'MD5' - else: - _algorithm = algorithm.upper() - # lambdas assume digest modules are imported at the top level - if _algorithm == 'MD5' or _algorithm == 'MD5-SESS': - def md5_utf8(x): - if isinstance(x, str): - x = x.encode('utf-8') - return hashlib.md5(x).hexdigest() - hash_utf8 = md5_utf8 - elif _algorithm == 'SHA': - def sha_utf8(x): - if isinstance(x, str): - x = x.encode('utf-8') - return hashlib.sha1(x).hexdigest() - hash_utf8 = sha_utf8 - elif _algorithm == 'SHA-256': - def sha256_utf8(x): - if isinstance(x, str): - x = x.encode('utf-8') - return hashlib.sha256(x).hexdigest() - hash_utf8 = sha256_utf8 - elif _algorithm == 'SHA-512': - def sha512_utf8(x): - if isinstance(x, str): - x = x.encode('utf-8') - return hashlib.sha512(x).hexdigest() - hash_utf8 = sha512_utf8 - - KD = lambda s, d: hash_utf8("%s:%s" % (s, d)) - - if hash_utf8 is None: - return None - - # XXX not implemented yet - entdig = None - p_parsed = urlparse(url) - #: 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 - - A1 = '%s:%s:%s' % (self.username, realm, self.password) - A2 = '%s:%s' % (method, path) - - HA1 = hash_utf8(A1) - HA2 = hash_utf8(A2) - - if nonce == self._thread_local.last_nonce: - 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') - s += os.urandom(8) - - cnonce = (hashlib.sha1(s).hexdigest()[:16]) - if _algorithm == 'MD5-SESS': - HA1 = hash_utf8('%s:%s:%s' % (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, noncebit) - else: - # XXX handle auth-int. - return None - - 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) - if opaque: - base += ', opaque="%s"' % opaque - if algorithm: - base += ', algorithm="%s"' % algorithm - if entdig: - base += ', digest="%s"' % entdig - if qop: - base += ', qop="auth", nc=%s, cnonce="%s"' % (ncvalue, cnonce) - - return 'Digest %s' % (base) - - def handle_redirect(self, r, **kwargs): - """Reset num_401_calls counter on redirects.""" - if r.is_redirect: - self._thread_local.num_401_calls = 1 - - def handle_401(self, r, **kwargs): - """ - Takes the given response and tries digest-auth, if needed. - - :rtype: requests.Response - """ - - # If response is not 4xx, do not auth - # See https://github.com/psf/requests/issues/3772 - if not 400 <= r.status_code < 500: - self._thread_local.num_401_calls = 1 - return r - - if self._thread_local.pos is not None: - # 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', '') - - 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)) - - # Consume content and release the original connection - # to allow our new request to reuse the same one. - r.content - r.close() - prep = r.request.copy() - 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) - _r = r.connection.send(prep, **kwargs) - _r.history.append(r) - _r.request = prep - - return _r - - self._thread_local.num_401_calls = 1 - return r - - def __call__(self, r): - # Initialize per-thread state, if needed - 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) - try: - self._thread_local.pos = r.body.tell() - except AttributeError: - # In the case of HTTPDigestAuth being reused and the body of - # the previous request was a file-like object, pos has the - # 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) - 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) - ]) - - def __ne__(self, other): - return not self == other diff --git a/venv/lib/python3.8/site-packages/requests/certs.py b/venv/lib/python3.8/site-packages/requests/certs.py deleted file mode 100644 index d1a378d..0000000 --- a/venv/lib/python3.8/site-packages/requests/certs.py +++ /dev/null @@ -1,18 +0,0 @@ -#!/usr/bin/env python -# -*- coding: utf-8 -*- - -""" -requests.certs -~~~~~~~~~~~~~~ - -This module returns the preferred default CA certificate bundle. There is -only one — the one from the certifi package. - -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 certifi import where - -if __name__ == '__main__': - print(where()) diff --git a/venv/lib/python3.8/site-packages/requests/compat.py b/venv/lib/python3.8/site-packages/requests/compat.py deleted file mode 100644 index 0b14f50..0000000 --- a/venv/lib/python3.8/site-packages/requests/compat.py +++ /dev/null @@ -1,75 +0,0 @@ -# -*- coding: utf-8 -*- - -""" -requests.compat -~~~~~~~~~~~~~~~ - -This module handles import compatibility issues between Python 2 and -Python 3. -""" - -try: - import chardet -except ImportError: - import charset_normalizer as chardet - -import sys - -# ------- -# Pythons -# ------- - -# Syntax sugar. -_ver = sys.version_info - -#: Python 2.x? -is_py2 = (_ver[0] == 2) - -#: Python 3.x? -is_py3 = (_ver[0] == 3) - -try: - import simplejson as json -except ImportError: - import json - -# --------- -# 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) - -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 - - builtin_str = str - str = str - bytes = bytes - basestring = (str, bytes) - numeric_types = (int, float) - integer_types = (int,) diff --git a/venv/lib/python3.8/site-packages/requests/cookies.py b/venv/lib/python3.8/site-packages/requests/cookies.py deleted file mode 100644 index 56fccd9..0000000 --- a/venv/lib/python3.8/site-packages/requests/cookies.py +++ /dev/null @@ -1,549 +0,0 @@ -# -*- coding: utf-8 -*- - -""" -requests.cookies -~~~~~~~~~~~~~~~~ - -Compatibility code to be able to use `cookielib.CookieJar` with requests. - -requests.utils imports from here, so be careful with imports. -""" - -import copy -import time -import calendar - -from ._internal_utils import to_native_string -from .compat import cookielib, urlparse, urlunparse, Morsel, MutableMapping - -try: - import threading -except ImportError: - import dummy_threading as threading - - -class MockRequest(object): - """Wraps a `requests.Request` to mimic a `urllib2.Request`. - - The code in `cookielib.CookieJar` expects this interface in order to correctly - manage cookie policies, i.e., determine whether a cookie can be set, given the - domains of the request and the cookie. - - The original request object is read-only. The client is responsible for collecting - the new headers via `get_new_headers()` and interpreting them appropriately. You - probably want `get_cookie_header`, defined below. - """ - - def __init__(self, request): - self._r = request - self._new_headers = {} - self.type = urlparse(self._r.url).scheme - - def get_type(self): - return self.type - - def get_host(self): - return urlparse(self._r.url).netloc - - def get_origin_req_host(self): - return self.get_host() - - 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'): - 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') - 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 - ]) - - def is_unverifiable(self): - return True - - def has_header(self, name): - return name in self._r.headers or name in self._new_headers - - def get_header(self, name, default=None): - return self._r.headers.get(name, self._new_headers.get(name, default)) - - 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()") - - def add_unredirected_header(self, name, value): - self._new_headers[name] = value - - def get_new_headers(self): - return self._new_headers - - @property - def unverifiable(self): - return self.is_unverifiable() - - @property - def origin_req_host(self): - return self.get_origin_req_host() - - @property - def host(self): - return self.get_host() - - -class MockResponse(object): - """Wraps a `httplib.HTTPMessage` to mimic a `urllib.addinfourl`. - - ...what? Basically, expose the parsed HTTP headers from the server response - the way `cookielib` expects to see them. - """ - - def __init__(self, headers): - """Make a MockResponse for `cookielib` to read. - - :param headers: a httplib.HTTPMessage or analogous carrying the headers - """ - self._headers = headers - - def info(self): - return self._headers - - def getheaders(self, name): - self._headers.getheaders(name) - - -def extract_cookies_to_jar(jar, request, response): - """Extract the cookies from the response into a CookieJar. - - :param jar: cookielib.CookieJar (not necessarily a RequestsCookieJar) - :param request: our own requests.Request object - :param response: urllib3.HTTPResponse object - """ - if not (hasattr(response, '_original_response') and - response._original_response): - return - # the _original_response field is the wrapped httplib.HTTPResponse object, - req = MockRequest(request) - # pull out the HTTPMessage with the headers and put it in the mock: - res = MockResponse(response._original_response.msg) - jar.extract_cookies(res, req) - - -def get_cookie_header(jar, request): - """ - Produce an appropriate Cookie header string to be sent with `request`, or None. - - :rtype: str - """ - r = MockRequest(request) - jar.add_cookie_header(r) - return r.get_new_headers().get('Cookie') - - -def remove_cookie_by_name(cookiejar, name, domain=None, path=None): - """Unsets a cookie by name, by default over all domains and paths. - - Wraps CookieJar.clear(), is O(n). - """ - clearables = [] - for cookie in cookiejar: - if cookie.name != name: - continue - if domain is not None and domain != cookie.domain: - continue - if path is not None and path != cookie.path: - continue - clearables.append((cookie.domain, cookie.path, cookie.name)) - - for domain, path, name in clearables: - cookiejar.clear(domain, path, name) - - -class CookieConflictError(RuntimeError): - """There are two cookies that meet the criteria specified in the cookie jar. - Use .get and .set and include domain and path args in order to be more specific. - """ - - -class RequestsCookieJar(cookielib.CookieJar, MutableMapping): - """Compatibility class; is a cookielib.CookieJar, but exposes a dict - interface. - - This is the CookieJar we create by default for requests and sessions that - don't specify one, since some clients may expect response.cookies and - session.cookies to support dict operations. - - Requests does not use the dict interface internally; it's just for - compatibility with external client code. All requests code should work - out of the box with externally provided instances of ``CookieJar``, e.g. - ``LWPCookieJar`` and ``FileCookieJar``. - - Unlike a regular CookieJar, this class is pickleable. - - .. warning:: dictionary operations that are normally O(1) may be O(n). - """ - - def get(self, name, default=None, domain=None, path=None): - """Dict-like get() that also supports optional domain and path args in - order to resolve naming collisions from using one cookie jar over - multiple domains. - - .. warning:: operation is O(n), not O(1). - """ - try: - return self._find_no_duplicates(name, domain, path) - except KeyError: - return default - - def set(self, name, value, **kwargs): - """Dict-like set() that also supports optional domain and path args in - order to resolve naming collisions from using one cookie jar over - multiple domains. - """ - # 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')) - return - - if isinstance(value, Morsel): - c = morsel_to_cookie(value) - else: - c = create_cookie(name, value, **kwargs) - self.set_cookie(c) - return c - - def iterkeys(self): - """Dict-like iterkeys() that returns an iterator of names of cookies - from the jar. - - .. seealso:: itervalues() and iteritems(). - """ - for cookie in iter(self): - yield cookie.name - - def keys(self): - """Dict-like keys() that returns a list of names of cookies from the - jar. - - .. seealso:: values() and items(). - """ - return list(self.iterkeys()) - - def itervalues(self): - """Dict-like itervalues() that returns an iterator of values of cookies - from the jar. - - .. seealso:: iterkeys() and iteritems(). - """ - for cookie in iter(self): - yield cookie.value - - def values(self): - """Dict-like values() that returns a list of values of cookies from the - jar. - - .. seealso:: keys() and items(). - """ - return list(self.itervalues()) - - def iteritems(self): - """Dict-like iteritems() that returns an iterator of name-value tuples - from the jar. - - .. seealso:: iterkeys() and itervalues(). - """ - for cookie in iter(self): - yield cookie.name, cookie.value - - def items(self): - """Dict-like items() that returns a list of name-value tuples from the - jar. Allows client-code to call ``dict(RequestsCookieJar)`` and get a - vanilla python dict of key value pairs. - - .. seealso:: keys() and values(). - """ - return list(self.iteritems()) - - def list_domains(self): - """Utility method to list all the domains in the jar.""" - domains = [] - for cookie in iter(self): - if cookie.domain not in domains: - domains.append(cookie.domain) - return domains - - def list_paths(self): - """Utility method to list all the paths in the jar.""" - paths = [] - for cookie in iter(self): - if cookie.path not in paths: - paths.append(cookie.path) - return paths - - def multiple_domains(self): - """Returns True if there are multiple domains in the jar. - Returns False otherwise. - - :rtype: bool - """ - domains = [] - for cookie in iter(self): - if cookie.domain is not None and cookie.domain in domains: - return True - domains.append(cookie.domain) - return False # there is only one domain in jar - - def get_dict(self, domain=None, path=None): - """Takes as an argument an optional domain and path and returns a plain - old Python dict of name-value pairs of cookies that meet the - requirements. - - :rtype: dict - """ - dictionary = {} - for cookie in iter(self): - 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) - except CookieConflictError: - return True - - def __getitem__(self, name): - """Dict-like __getitem__() for compatibility with client code. Throws - exception if there are more than one cookie with name. In that case, - use the more explicit get() method instead. - - .. warning:: operation is O(n), not O(1). - """ - return self._find_no_duplicates(name) - - def __setitem__(self, name, value): - """Dict-like __setitem__ for compatibility with client code. Throws - exception if there is already a cookie of that name in the jar. In that - case, use the more explicit set() method instead. - """ - self.set(name, value) - - def __delitem__(self, name): - """Deletes a cookie given a name. Wraps ``cookielib.CookieJar``'s - ``remove_cookie_by_name()``. - """ - 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) - - def update(self, other): - """Updates this jar with cookies from another CookieJar or dict-like""" - if isinstance(other, cookielib.CookieJar): - for cookie in other: - self.set_cookie(copy.copy(cookie)) - else: - super(RequestsCookieJar, self).update(other) - - def _find(self, name, domain=None, path=None): - """Requests uses this method internally to get cookie values. - - If there are conflicting cookies, _find arbitrarily chooses one. - See _find_no_duplicates if you want an exception thrown if there are - conflicting cookies. - - :param name: a string containing name of cookie - :param domain: (optional) string containing domain of cookie - :param path: (optional) string containing path of cookie - :return: cookie.value - """ - for cookie in iter(self): - if cookie.name == name: - if domain is None or cookie.domain == domain: - if path is None or cookie.path == path: - return cookie.value - - raise KeyError('name=%r, domain=%r, path=%r' % (name, domain, path)) - - def _find_no_duplicates(self, name, domain=None, path=None): - """Both ``__get_item__`` and ``get`` call this function: it's never - used elsewhere in Requests. - - :param name: a string containing name of cookie - :param domain: (optional) string containing domain of cookie - :param path: (optional) string containing path of cookie - :raises KeyError: if cookie is not found - :raises CookieConflictError: if there are multiple cookies - that match name and optionally domain and path - :return: cookie.value - """ - toReturn = None - for cookie in iter(self): - 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: - return toReturn - raise KeyError('name=%r, domain=%r, path=%r' % (name, domain, path)) - - def __getstate__(self): - """Unlike a normal CookieJar, this class is pickleable.""" - state = self.__dict__.copy() - # remove the unpickleable RLock object - 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__: - self._cookies_lock = threading.RLock() - - def copy(self): - """Return a copy of this RequestsCookieJar.""" - new_cj = RequestsCookieJar() - new_cj.set_policy(self.get_policy()) - new_cj.update(self) - return new_cj - - def get_policy(self): - """Return the CookiePolicy instance used.""" - return self._policy - - -def _copy_cookie_jar(jar): - if jar is None: - return None - - if hasattr(jar, 'copy'): - # We're dealing with an instance of RequestsCookieJar - return jar.copy() - # We're dealing with a generic CookieJar instance - new_jar = copy.copy(jar) - new_jar.clear() - for cookie in jar: - new_jar.set_cookie(copy.copy(cookie)) - return new_jar - - -def create_cookie(name, value, **kwargs): - """Make a cookie from underspecified parameters. - - By default, the pair of `name` and `value` will be set for the domain '' - 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, - } - - badargs = set(kwargs) - set(result) - if badargs: - err = 'create_cookie() got unexpected keyword arguments: %s' - raise TypeError(err % 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']) - - return cookielib.Cookie(**result) - - -def morsel_to_cookie(morsel): - """Convert a Morsel object into a Cookie containing the one k/v pair.""" - - expires = None - if morsel['max-age']: - try: - 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) - ) - return create_cookie( - comment=morsel['comment'], - comment_url=bool(morsel['comment']), - discard=False, - domain=morsel['domain'], - expires=expires, - name=morsel.key, - path=morsel['path'], - port=None, - rest={'HttpOnly': morsel['httponly']}, - rfc2109=False, - secure=bool(morsel['secure']), - value=morsel.value, - version=morsel['version'] or 0, - ) - - -def cookiejar_from_dict(cookie_dict, cookiejar=None, overwrite=True): - """Returns a CookieJar from a key/value dictionary. - - :param cookie_dict: Dict of key/values to insert into CookieJar. - :param cookiejar: (optional) A cookiejar to add the cookies to. - :param overwrite: (optional) If False, will not replace cookies - already in the jar with new ones. - :rtype: CookieJar - """ - if cookiejar is None: - cookiejar = RequestsCookieJar() - - if cookie_dict is not None: - names_from_jar = [cookie.name for cookie in cookiejar] - for name in cookie_dict: - if overwrite or (name not in names_from_jar): - cookiejar.set_cookie(create_cookie(name, cookie_dict[name])) - - return cookiejar - - -def merge_cookies(cookiejar, cookies): - """Add cookies to cookiejar and returns a merged CookieJar. - - :param cookiejar: CookieJar object to add the cookies to. - :param cookies: Dictionary or CookieJar object to be added. - :rtype: CookieJar - """ - if not isinstance(cookiejar, cookielib.CookieJar): - raise ValueError('You can only merge into CookieJar') - - if isinstance(cookies, dict): - cookiejar = cookiejar_from_dict( - cookies, cookiejar=cookiejar, overwrite=False) - elif isinstance(cookies, cookielib.CookieJar): - try: - cookiejar.update(cookies) - except AttributeError: - for cookie_in_jar in cookies: - cookiejar.set_cookie(cookie_in_jar) - - return cookiejar diff --git a/venv/lib/python3.8/site-packages/requests/exceptions.py b/venv/lib/python3.8/site-packages/requests/exceptions.py deleted file mode 100644 index c412ec9..0000000 --- a/venv/lib/python3.8/site-packages/requests/exceptions.py +++ /dev/null @@ -1,127 +0,0 @@ -# -*- coding: utf-8 -*- - -""" -requests.exceptions -~~~~~~~~~~~~~~~~~~~ - -This module contains the set of Requests' exceptions. -""" -from urllib3.exceptions import HTTPError as BaseHTTPError - - -class RequestException(IOError): - """There was an ambiguous exception that occurred while handling your - request. - """ - - def __init__(self, *args, **kwargs): - """Initialize RequestException with `request` and `response` objects.""" - 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 = self.response.request - super(RequestException, self).__init__(*args, **kwargs) - - -class InvalidJSONError(RequestException): - """A JSON error occurred.""" - - -class HTTPError(RequestException): - """An HTTP error occurred.""" - - -class ConnectionError(RequestException): - """A Connection error occurred.""" - - -class ProxyError(ConnectionError): - """A proxy error occurred.""" - - -class SSLError(ConnectionError): - """An SSL error occurred.""" - - -class Timeout(RequestException): - """The request timed out. - - Catching this error will catch both - :exc:`~requests.exceptions.ConnectTimeout` and - :exc:`~requests.exceptions.ReadTimeout` errors. - """ - - -class ConnectTimeout(ConnectionError, Timeout): - """The request timed out while trying to connect to the remote server. - - Requests that produced this error are safe to retry. - """ - - -class ReadTimeout(Timeout): - """The server did not send any data in the allotted amount of time.""" - - -class URLRequired(RequestException): - """A valid URL is required to make a request.""" - - -class TooManyRedirects(RequestException): - """Too many redirects.""" - - -class MissingSchema(RequestException, ValueError): - """The URL schema (e.g. http or https) is missing.""" - - -class InvalidSchema(RequestException, ValueError): - """See defaults.py for valid schemas.""" - - -class InvalidURL(RequestException, ValueError): - """The URL provided was somehow invalid.""" - - -class InvalidHeader(RequestException, ValueError): - """The header value provided was somehow invalid.""" - - -class InvalidProxyURL(InvalidURL): - """The proxy URL provided is invalid.""" - - -class ChunkedEncodingError(RequestException): - """The server declared chunked encoding but sent an invalid chunk.""" - - -class ContentDecodingError(RequestException, BaseHTTPError): - """Failed to decode response content.""" - - -class StreamConsumedError(RequestException, TypeError): - """The content for this response was already consumed.""" - - -class RetryError(RequestException): - """Custom retries logic failed""" - - -class UnrewindableBodyError(RequestException): - """Requests encountered an error when trying to rewind a body.""" - -# Warnings - - -class RequestsWarning(Warning): - """Base warning for Requests.""" - - -class FileModeWarning(RequestsWarning, DeprecationWarning): - """A file was opened in text mode, but Requests determined its binary length.""" - - -class RequestsDependencyWarning(RequestsWarning): - """An imported dependency doesn't match the expected version range.""" diff --git a/venv/lib/python3.8/site-packages/requests/help.py b/venv/lib/python3.8/site-packages/requests/help.py deleted file mode 100644 index 4cd6389..0000000 --- a/venv/lib/python3.8/site-packages/requests/help.py +++ /dev/null @@ -1,135 +0,0 @@ -"""Module containing bug report helper(s).""" -from __future__ import print_function - -import json -import platform -import sys -import ssl - -import idna -import urllib3 - -from . import __version__ as requests_version - -try: - import charset_normalizer -except ImportError: - charset_normalizer = None - -try: - import chardet -except ImportError: - chardet = None - -try: - from urllib3.contrib import pyopenssl -except ImportError: - pyopenssl = None - OpenSSL = None - cryptography = None -else: - import OpenSSL - import cryptography - - -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'}. - - This function works best on CPython and PyPy: in particular, it probably - doesn't work for Jython or IronPython. Future investigation should be done - to work out the correct shape of the code for those platforms. - """ - implementation = platform.python_implementation() - - 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': - implementation_version = platform.python_version() # Complete Guess - elif implementation == 'IronPython': - implementation_version = platform.python_version() # Complete Guess - else: - implementation_version = 'Unknown' - - return {'name': implementation, 'version': implementation_version} - - -def info(): - """Generate information for a bug report.""" - try: - platform_info = { - 'system': platform.system(), - 'release': platform.release(), - } - except IOError: - platform_info = { - 'system': 'Unknown', - 'release': 'Unknown', - } - - implementation_info = _implementation() - 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': '', - } - if OpenSSL: - pyopenssl_info = { - 'version': OpenSSL.__version__, - 'openssl_version': '%x' % OpenSSL.SSL.OPENSSL_VERSION_NUMBER, - } - cryptography_info = { - 'version': getattr(cryptography, '__version__', ''), - } - idna_info = { - 'version': getattr(idna, '__version__', ''), - } - - system_ssl = ssl.OPENSSL_VERSION_NUMBER - system_ssl_info = { - 'version': '%x' % system_ssl 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, - '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, - }, - } - - -def main(): - """Pretty-print the bug information as JSON.""" - print(json.dumps(info(), sort_keys=True, indent=2)) - - -if __name__ == '__main__': - main() diff --git a/venv/lib/python3.8/site-packages/requests/hooks.py b/venv/lib/python3.8/site-packages/requests/hooks.py deleted file mode 100644 index 7a51f21..0000000 --- a/venv/lib/python3.8/site-packages/requests/hooks.py +++ /dev/null @@ -1,34 +0,0 @@ -# -*- coding: utf-8 -*- - -""" -requests.hooks -~~~~~~~~~~~~~~ - -This module provides the capabilities for the Requests hooks system. - -Available hooks: - -``response``: - The response generated from a Request. -""" -HOOKS = ['response'] - - -def default_hooks(): - return {event: [] for event in HOOKS} - -# TODO: response is the only one - - -def dispatch_hook(key, hooks, hook_data, **kwargs): - """Dispatches a hook dictionary on a given piece of data.""" - hooks = hooks or {} - hooks = hooks.get(key) - if hooks: - if hasattr(hooks, '__call__'): - hooks = [hooks] - for hook in hooks: - _hook_data = hook(hook_data, **kwargs) - if _hook_data is not None: - hook_data = _hook_data - return hook_data diff --git a/venv/lib/python3.8/site-packages/requests/models.py b/venv/lib/python3.8/site-packages/requests/models.py deleted file mode 100644 index aa6fb86..0000000 --- a/venv/lib/python3.8/site-packages/requests/models.py +++ /dev/null @@ -1,966 +0,0 @@ -# -*- coding: utf-8 -*- - -""" -requests.models -~~~~~~~~~~~~~~~ - -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 - -from urllib3.fields import RequestField -from urllib3.filepost import encode_multipart_formdata -from urllib3.util import parse_url -from 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, InvalidJSONError) -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 .compat import ( - Callable, Mapping, - cookielib, urlunparse, urlsplit, urlencode, str, bytes, - is_py2, chardet, builtin_str, basestring) -from .compat import json as complexjson -from .status_codes import codes - -#: The set of HTTP status codes that indicate an automatically -#: processable redirect. -REDIRECT_STATI = ( - codes.moved, # 301 - codes.found, # 302 - codes.other, # 303 - codes.temporary_redirect, # 307 - codes.permanent_redirect, # 308 -) - -DEFAULT_REDIRECT_LIMIT = 30 -CONTENT_CHUNK_SIZE = 10 * 1024 -ITER_CHUNK_SIZE = 512 - - -class RequestEncodingMixin(object): - @property - def path_url(self): - """Build the path URL to use.""" - - url = [] - - p = urlsplit(self.url) - - path = p.path - if not path: - path = '/' - - url.append(path) - - query = p.query - if query: - url.append('?') - url.append(query) - - return ''.join(url) - - @staticmethod - def _encode_params(data): - """Encode parameters in a piece of data. - - Will successfully encode parameters when passed as a dict or a list of - 2-tuples. Order is retained if data is a list of 2-tuples but arbitrary - if parameters are supplied as a dict. - """ - - if isinstance(data, (str, bytes)): - return data - elif hasattr(data, 'read'): - return data - elif hasattr(data, '__iter__'): - result = [] - for k, vs in to_key_val_list(data): - 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)) - return urlencode(result, doseq=True) - else: - return data - - @staticmethod - def _encode_files(files, data): - """Build the body for a multipart/form-data request. - - Will successfully encode files when passed as a dict or a list of - tuples. Order is retained if data is a list of tuples but arbitrary - if parameters are supplied as a dict. - The tuples may be 2-tuples (filename, fileobj), 3-tuples (filename, fileobj, contentype) - or 4-tuples (filename, fileobj, contentype, custom_headers). - """ - if (not files): - raise ValueError("Files must be provided.") - elif isinstance(data, basestring): - raise ValueError("Data must not be a string.") - - new_fields = [] - fields = to_key_val_list(data or {}) - files = to_key_val_list(files or {}) - - for field, val in fields: - if isinstance(val, basestring) or not hasattr(val, '__iter__'): - val = [val] - for v in val: - if v is not None: - # Don't call str() on bytestrings: in Py3 it all goes wrong. - if not isinstance(v, bytes): - 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)) - - for (k, v) in files: - # support for explicit filename - ft = None - fh = None - if isinstance(v, (tuple, list)): - if len(v) == 2: - fn, fp = v - elif len(v) == 3: - fn, fp, ft = v - else: - fn, fp, ft, fh = v - else: - fn = guess_filename(v) or k - fp = v - - if isinstance(fp, (str, bytes, bytearray)): - fdata = fp - elif hasattr(fp, 'read'): - fdata = fp.read() - elif fp is None: - continue - else: - fdata = fp - - rf = RequestField(name=k, data=fdata, filename=fn, headers=fh) - rf.make_multipart(content_type=ft) - new_fields.append(rf) - - body, content_type = encode_multipart_formdata(new_fields) - - return body, content_type - - -class RequestHooksMixin(object): - 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)) - - if isinstance(hook, Callable): - self.hooks[event].append(hook) - elif hasattr(hook, '__iter__'): - self.hooks[event].extend(h for h in hook if isinstance(h, Callable)) - - def deregister_hook(self, event, hook): - """Deregister a previously registered hook. - Returns True if the hook existed, False if not. - """ - - try: - self.hooks[event].remove(hook) - return True - except ValueError: - return False - - -class Request(RequestHooksMixin): - """A user-created :class:`Request ` object. - - Used to prepare a :class:`PreparedRequest `, which is sent to the server. - - :param method: HTTP method to use. - :param url: URL to send. - :param headers: dictionary of headers to send. - :param files: dictionary of {filename: fileobject} files to multipart upload. - :param data: the body to attach to the request. If a dictionary or - list of tuples ``[(key, value)]`` is provided, form-encoding will - take place. - :param json: json for the body to attach to the request (if files or data is not specified). - :param params: URL parameters to append to the URL. If a dictionary or - list of tuples ``[(key, value)]`` is provided, form-encoding will - take place. - :param auth: Auth handler or (user, pass) tuple. - :param cookies: dictionary or CookieJar of cookies to attach to this request. - :param hooks: dictionary of callback hooks, for internal usage. - - Usage:: - - >>> import requests - >>> req = requests.Request('GET', 'https://httpbin.org/get') - >>> req.prepare() - - """ - - 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 - files = [] if files is None else files - headers = {} if headers is None else headers - params = {} if params is None else params - hooks = {} if hooks is None else hooks - - self.hooks = default_hooks() - for (k, v) in list(hooks.items()): - self.register_hook(event=k, hook=v) - - self.method = method - self.url = url - self.headers = headers - self.files = files - self.data = data - self.json = json - self.params = params - self.auth = auth - self.cookies = cookies - - def __repr__(self): - return '' % (self.method) - - def prepare(self): - """Constructs a :class:`PreparedRequest ` for transmission and returns it.""" - p = PreparedRequest() - p.prepare( - method=self.method, - url=self.url, - headers=self.headers, - files=self.files, - data=self.data, - json=self.json, - params=self.params, - auth=self.auth, - cookies=self.cookies, - hooks=self.hooks, - ) - return p - - -class PreparedRequest(RequestEncodingMixin, RequestHooksMixin): - """The fully mutable :class:`PreparedRequest ` object, - containing the exact bytes that will be sent to the server. - - Instances are generated from a :class:`Request ` object, and - should not be instantiated manually; doing so may produce undesirable - effects. - - Usage:: - - >>> import requests - >>> req = requests.Request('GET', 'https://httpbin.org/get') - >>> r = req.prepare() - >>> r - - - >>> s = requests.Session() - >>> s.send(r) - - """ - - def __init__(self): - #: HTTP verb to send to the server. - self.method = None - #: HTTP URL to send the request to. - self.url = None - #: dictionary of HTTP headers. - self.headers = None - # The `CookieJar` used to create the Cookie header will be stored here - # after prepare_cookies is called - self._cookies = None - #: request body to send to the server. - self.body = None - #: dictionary of callback hooks, for internal usage. - self.hooks = default_hooks() - #: 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): - """Prepares the entire request with the given parameters.""" - - self.prepare_method(method) - self.prepare_url(url, params) - self.prepare_headers(headers) - self.prepare_cookies(cookies) - self.prepare_body(data, files, json) - self.prepare_auth(auth, url) - - # Note that prepare_auth must be last to enable authentication schemes - # such as OAuth to work on a fully prepared request. - - # This MUST go after prepare_auth. Authenticators could add a hook - self.prepare_hooks(hooks) - - def __repr__(self): - return '' % (self.method) - - def copy(self): - p = PreparedRequest() - p.method = self.method - p.url = self.url - p.headers = self.headers.copy() if self.headers is not None else None - p._cookies = _copy_cookie_jar(self._cookies) - p.body = self.body - p.hooks = self.hooks - p._body_position = self._body_position - return p - - def prepare_method(self, method): - """Prepares the given HTTP method.""" - self.method = method - if self.method is not None: - self.method = to_native_string(self.method.upper()) - - @staticmethod - def _get_idna_encoded_host(host): - import idna - - try: - host = idna.encode(host, uts46=True).decode('utf-8') - except idna.IDNAError: - raise UnicodeError - return host - - def prepare_url(self, url, params): - """Prepares the given HTTP URL.""" - #: Accept objects that have string representations. - #: We're unable to blindly call unicode/str functions - #: as this will include the bytestring indicator (b'') - #: on python 3.x. - #: https://github.com/psf/requests/pull/2238 - if isinstance(url, bytes): - url = url.decode('utf8') - else: - url = unicode(url) if is_py2 else str(url) - - # Remove leading whitespaces from url - url = url.lstrip() - - # 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'): - self.url = url - return - - # Support for unicode domain names and paths. - try: - scheme, auth, host, port, path, query, fragment = parse_url(url) - except LocationParseError as e: - 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) - - if not host: - raise InvalidURL("Invalid URL %r: No host supplied" % url) - - # 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 - # behaviour. For strings containing only ASCII characters, we need to also verify - # it doesn't start with a wildcard (*), before allowing the unencoded hostname. - if not unicode_is_ascii(host): - 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.') - - # Carefully reconstruct the network location - netloc = auth or '' - if netloc: - netloc += '@' - netloc += host - if port: - netloc += ':' + str(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') - - if isinstance(params, (str, bytes)): - params = to_native_string(params) - - enc_params = self._encode_params(params) - if enc_params: - if query: - query = '%s&%s' % (query, enc_params) - else: - query = enc_params - - url = requote_uri(urlunparse([scheme, netloc, path, None, query, fragment])) - self.url = url - - def prepare_headers(self, headers): - """Prepares the given HTTP headers.""" - - self.headers = CaseInsensitiveDict() - if headers: - for header in headers.items(): - # Raise exception on invalid header value. - check_header_validity(header) - name, value = header - self.headers[to_native_string(name)] = value - - def prepare_body(self, data, files, json=None): - """Prepares the given HTTP body data.""" - - # Check if file, fo, generator, iterator. - # If not, run through normal process. - - # Nottin' on you. - body = None - content_type = None - - 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' - - 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') - - is_stream = all([ - hasattr(data, '__iter__'), - not isinstance(data, (basestring, list, tuple, Mapping)) - ]) - - if is_stream: - try: - length = super_len(data) - except (TypeError, AttributeError, UnsupportedOperation): - length = None - - body = data - - 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): - # 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.') - - if length: - self.headers['Content-Length'] = builtin_str(length) - else: - self.headers['Transfer-Encoding'] = 'chunked' - else: - # Multi-part file uploads. - if files: - (body, content_type) = self._encode_files(files, data) - else: - if data: - body = self._encode_params(data) - if isinstance(data, basestring) or hasattr(data, 'read'): - content_type = None - else: - 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 - - self.body = body - - def prepare_content_length(self, body): - """Prepare Content-Length header based on request method and body""" - if body is not None: - length = super_len(body) - 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: - # 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' - - def prepare_auth(self, auth, url=''): - """Prepares the given HTTP auth data.""" - - # If no Auth is explicitly provided, extract it from the URL first. - if auth is None: - url_auth = get_auth_from_url(self.url) - auth = url_auth if any(url_auth) else None - - if auth: - if isinstance(auth, tuple) and len(auth) == 2: - # special-case basic HTTP auth - auth = HTTPBasicAuth(*auth) - - # Allow auth to make its changes. - r = auth(self) - - # Update self to reflect the auth changes. - self.__dict__.update(r.__dict__) - - # Recompute Content-Length - self.prepare_content_length(self.body) - - def prepare_cookies(self, cookies): - """Prepares the given HTTP cookie data. - - This function eventually generates a ``Cookie`` header from the - given cookies using cookielib. Due to cookielib's design, the header - will not be regenerated if it already exists, meaning this function - can only be called once for the life of the - :class:`PreparedRequest ` object. Any subsequent calls - to ``prepare_cookies`` will have no actual effect, unless the "Cookie" - header is removed beforehand. - """ - if isinstance(cookies, cookielib.CookieJar): - self._cookies = cookies - else: - self._cookies = cookiejar_from_dict(cookies) - - cookie_header = get_cookie_header(self._cookies, self) - if cookie_header is not None: - self.headers['Cookie'] = cookie_header - - def prepare_hooks(self, hooks): - """Prepares the given hooks.""" - # hooks can be passed as None to the prepare method and to this - # method. To prevent iterating over None, simply use an empty list - # if hooks is False-y - hooks = hooks or [] - for event in hooks: - self.register_hook(event, hooks[event]) - - -class Response(object): - """The :class:`Response ` object, which contains a - server's response to an HTTP request. - """ - - __attrs__ = [ - '_content', 'status_code', 'headers', 'url', 'history', - 'encoding', 'reason', 'cookies', 'elapsed', 'request' - ] - - def __init__(self): - self._content = False - self._content_consumed = False - self._next = None - - #: Integer Code of responded HTTP Status, e.g. 404 or 200. - self.status_code = None - - #: Case-insensitive Dictionary of Response Headers. - #: For example, ``headers['content-encoding']`` will return the - #: value of a ``'Content-Encoding'`` response header. - self.headers = CaseInsensitiveDict() - - #: File-like object representation of response (for advanced usage). - #: Use of ``raw`` requires that ``stream=True`` be set on the request. - #: This requirement does not apply for use internally to Requests. - self.raw = None - - #: Final URL location of Response. - self.url = None - - #: Encoding to decode with when accessing r.text. - self.encoding = None - - #: A list of :class:`Response ` objects from - #: the history of the Request. Any redirect responses will end - #: up here. The list is sorted from the oldest to the most recent request. - self.history = [] - - #: Textual reason of responded HTTP Status, e.g. "Not Found" or "OK". - self.reason = None - - #: A CookieJar of Cookies the server sent back. - self.cookies = cookiejar_from_dict({}) - - #: The amount of time elapsed between sending the request - #: and the arrival of the response (as a timedelta). - #: This property specifically measures the time taken between sending - #: the first byte of the request and finishing parsing the headers. It - #: is therefore unaffected by consuming the response content or the - #: value of the ``stream`` keyword argument. - self.elapsed = datetime.timedelta(0) - - #: The :class:`PreparedRequest ` object to which this - #: is a response. - self.request = None - - def __enter__(self): - return self - - def __exit__(self, *args): - self.close() - - def __getstate__(self): - # Consume everything; accessing the content attribute makes - # sure the content has been fully read. - if not self._content_consumed: - self.content - - return {attr: getattr(self, attr, None) for attr in self.__attrs__} - - def __setstate__(self, state): - for name, value in state.items(): - setattr(self, name, value) - - # pickled objects do not have .raw - setattr(self, '_content_consumed', True) - setattr(self, 'raw', None) - - def __repr__(self): - return '' % (self.status_code) - - def __bool__(self): - """Returns True if :attr:`status_code` is less than 400. - - This attribute checks if the status code of the response is between - 400 and 600 to see if there was a client error or a server error. If - the status code, is between 200 and 400, this will return True. This - is **not** a check to see if the response code is ``200 OK``. - """ - return self.ok - - def __nonzero__(self): - """Returns True if :attr:`status_code` is less than 400. - - This attribute checks if the status code of the response is between - 400 and 600 to see if there was a client error or a server error. If - the status code, is between 200 and 400, this will return True. This - is **not** a check to see if the response code is ``200 OK``. - """ - return self.ok - - def __iter__(self): - """Allows you to use a response as an iterator.""" - return self.iter_content(128) - - @property - def ok(self): - """Returns True if :attr:`status_code` is less than 400, False if not. - - This attribute checks if the status code of the response is between - 400 and 600 to see if there was a client error or a server error. If - the status code is between 200 and 400, this will return True. This - is **not** a check to see if the response code is ``200 OK``. - """ - try: - self.raise_for_status() - except HTTPError: - return False - return True - - @property - def is_redirect(self): - """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) - - @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)) - - @property - def next(self): - """Returns a PreparedRequest for the next request in a redirect chain, if there is one.""" - return self._next - - @property - def apparent_encoding(self): - """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 - request, this avoids reading the content at once into memory for - large responses. The chunk size is the number of bytes it should - read into memory. This is not necessarily the length of each item - returned as decoding can take place. - - chunk_size must be of type int or None. A value of None will - function differently depending on the value of `stream`. - stream=True will read data as it arrives in whatever size the - chunks are received. If stream=False, data is returned as - a single chunk. - - If decode_unicode is True, content will be decoded using the best - available encoding based on the response. - """ - - def generate(): - # Special case for urllib3. - if hasattr(self.raw, 'stream'): - try: - for chunk in self.raw.stream(chunk_size, decode_content=True): - yield chunk - except ProtocolError as e: - raise ChunkedEncodingError(e) - except DecodeError as e: - raise ContentDecodingError(e) - except ReadTimeoutError as e: - raise ConnectionError(e) - else: - # Standard file-like object. - while True: - chunk = self.raw.read(chunk_size) - if not chunk: - break - yield chunk - - self._content_consumed = True - - 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)) - # simulate reading small chunks of the content - reused_chunks = iter_slices(self._content, chunk_size) - - stream_chunks = generate() - - chunks = reused_chunks if self._content_consumed else stream_chunks - - if decode_unicode: - chunks = stream_decode_response_unicode(chunks, self) - - return chunks - - 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. - - .. note:: This method is not reentrant safe. - """ - - pending = None - - for chunk in self.iter_content(chunk_size=chunk_size, decode_unicode=decode_unicode): - - if pending is not None: - chunk = pending + chunk - - if delimiter: - lines = chunk.split(delimiter) - else: - lines = chunk.splitlines() - - if lines and lines[-1] and chunk and lines[-1][-1] == chunk[-1]: - pending = lines.pop() - else: - pending = None - - for line in lines: - yield line - - if pending is not None: - yield pending - - @property - def content(self): - """Content of the response, in bytes.""" - - if self._content is False: - # Read the contents. - if self._content_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_consumed = True - # don't need to release the connection; that's been handled by urllib3 - # since we exhausted the data. - return self._content - - @property - def text(self): - """Content of the response, in unicode. - - If Response.encoding is None, encoding will be guessed using - ``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 - non-HTTP knowledge to make a better guess at the encoding, you should - set ``r.encoding`` appropriately before accessing this property. - """ - - # Try charset from content-type - content = None - encoding = self.encoding - - if not self.content: - return str('') - - # Fallback to auto-detected encoding. - if self.encoding is None: - encoding = self.apparent_encoding - - # Decode unicode from given encoding. - try: - 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. - # - # A TypeError can be raised if encoding is None - # - # So we try blindly encoding. - content = str(self.content, errors='replace') - - return content - - def json(self, **kwargs): - r"""Returns the json-encoded content of a response, if any. - - :param \*\*kwargs: Optional arguments that ``json.loads`` takes. - :raises simplejson.JSONDecodeError: If the response body does not - contain valid json and simplejson is installed. - :raises json.JSONDecodeError: If the response body does not contain - valid json and simplejson is not installed on Python 3. - :raises ValueError: If the response body does not contain valid - json and simplejson is not installed on Python 2. - """ - - 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 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 - ) - 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) - - @property - def links(self): - """Returns the parsed header links of the response, if any.""" - - header = self.headers.get('link') - - # l = MultiDict() - l = {} - - if header: - links = parse_header_links(header) - - for link in links: - key = link.get('rel') or link.get('url') - l[key] = link - - return l - - def raise_for_status(self): - """Raises :class:`HTTPError`, if one occurred.""" - - 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') - except UnicodeDecodeError: - 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) - - elif 500 <= self.status_code < 600: - http_error_msg = u'%s Server Error: %s for url: %s' % (self.status_code, reason, self.url) - - if http_error_msg: - raise HTTPError(http_error_msg, response=self) - - def close(self): - """Releases the connection back to the pool. Once this method has been - called the underlying ``raw`` object must not be accessed again. - - *Note: Should not normally need to be called explicitly.* - """ - if not self._content_consumed: - self.raw.close() - - release_conn = getattr(self.raw, 'release_conn', None) - if release_conn is not None: - release_conn() diff --git a/venv/lib/python3.8/site-packages/requests/packages.py b/venv/lib/python3.8/site-packages/requests/packages.py deleted file mode 100644 index 00196bf..0000000 --- a/venv/lib/python3.8/site-packages/requests/packages.py +++ /dev/null @@ -1,26 +0,0 @@ -import sys - -try: - import chardet -except ImportError: - import charset_normalizer as chardet - import warnings - - warnings.filterwarnings('ignore', 'Trying to detect', module='charset_normalizer') - -# This code exists for backwards compatibility reasons. -# I don't like it either. Just look the other way. :) - -for package in ('urllib3', 'idna'): - locals()[package] = __import__(package) - # This traversal is apparently necessary such that the identities are - # preserved (requests.packages.urllib3.* is urllib3.*) - for mod in list(sys.modules): - if mod == package or mod.startswith(package + '.'): - sys.modules['requests.packages.' + mod] = sys.modules[mod] - -target = chardet.__name__ -for mod in list(sys.modules): - if mod == target or mod.startswith(target + '.'): - sys.modules['requests.packages.' + target.replace(target, 'chardet')] = sys.modules[mod] -# Kinda cool, though, right? diff --git a/venv/lib/python3.8/site-packages/requests/sessions.py b/venv/lib/python3.8/site-packages/requests/sessions.py deleted file mode 100644 index ae4bcc8..0000000 --- a/venv/lib/python3.8/site-packages/requests/sessions.py +++ /dev/null @@ -1,781 +0,0 @@ -# -*- coding: utf-8 -*- - -""" -requests.sessions -~~~~~~~~~~~~~~~~~ - -This module provides a Session object to manage and persist settings across -requests (cookies, auth, proxies). -""" -import os -import sys -import time -from datetime import timedelta -from collections import OrderedDict - -from .auth import _basic_auth_str -from .compat import cookielib, is_py3, urljoin, urlparse, Mapping -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 -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 -) - -from .status_codes import codes - -# formerly defined here, reexposed here for backward compatibility -from .models import REDIRECT_STATI - -# 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 -else: - preferred_clock = time.time - - -def merge_setting(request_setting, session_setting, dict_class=OrderedDict): - """Determines appropriate setting for a given request, taking into account - the explicit setting on that request, and the setting in the session. If a - setting is a dictionary, they will be merged together using `dict_class` - """ - - if session_setting is None: - return request_setting - - if request_setting is None: - return session_setting - - # Bypass if not a dictionary (e.g. verify) - if not ( - isinstance(session_setting, Mapping) and - isinstance(request_setting, Mapping) - ): - return request_setting - - merged_setting = dict_class(to_key_val_list(session_setting)) - merged_setting.update(to_key_val_list(request_setting)) - - # Remove keys that are set to None. Extract keys first to avoid altering - # the dictionary during iteration. - none_keys = [k for (k, v) in merged_setting.items() if v is None] - for key in none_keys: - del merged_setting[key] - - return merged_setting - - -def merge_hooks(request_hooks, session_hooks, dict_class=OrderedDict): - """Properly merges both requests and session hooks. - - This is necessary because when request_hooks == {'response': []}, the - merge breaks Session hooks entirely. - """ - if session_hooks is None or session_hooks.get('response') == []: - return request_hooks - - 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): - - 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 - # be called at least once upon the original response and at least twice - # on each subsequent redirect response (if any). - # If a custom mixin is used to handle this logic, it may be advantageous - # to cache the redirect location onto the response object as a private - # attribute. - if resp.is_redirect: - 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') - return None - - def should_strip_auth(self, old_url, new_url): - """Decide whether Authorization header should be removed when redirecting""" - old_parsed = urlparse(old_url) - new_parsed = urlparse(new_url) - if old_parsed.hostname != new_parsed.hostname: - return True - # Special case: allow http -> https redirect when using the standard - # 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)): - 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): - 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): - """Receives a Response. Returns a generator of Responses or Requests.""" - - hist = [] # keep track of history - - url = self.get_redirect_target(resp) - previous_fragment = urlparse(req.url).fragment - while url: - prepared_request = req.copy() - - # Update history and keep track of redirects. - # resp.history must ignore the original request in this loop - hist.append(resp) - resp.history = hist[1:] - - try: - resp.content # Consume socket so it can be released - except (ChunkedEncodingError, ContentDecodingError, RuntimeError): - resp.raw.read(decode_content=False) - - if len(resp.history) >= self.max_redirects: - raise TooManyRedirects('Exceeded {} redirects.'.format(self.max_redirects), response=resp) - - # Release the connection back into the pool. - resp.close() - - # Handle redirection without scheme (see: RFC 1808 Section 4) - if url.startswith('//'): - parsed_rurl = urlparse(resp.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: - parsed = parsed._replace(fragment=previous_fragment) - elif parsed.fragment: - previous_fragment = parsed.fragment - url = parsed.geturl() - - # Facilitate relative 'location' headers, as allowed by RFC 7231. - # (e.g. '/path/to/resource' instead of 'http://domain.tld/path/to/resource') - # Compliant with RFC3986, we percent encode the url. - if not parsed.netloc: - url = urljoin(resp.url, requote_uri(url)) - else: - url = requote_uri(url) - - prepared_request.url = to_native_string(url) - - 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): - # https://github.com/psf/requests/issues/3490 - 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) - - # Extract any cookies sent on the response to the cookiejar - # in the new request. Because we've mutated our copied prepared - # request, use the old one that we haven't yet touched. - extract_cookies_to_jar(prepared_request._cookies, req, resp.raw) - merge_cookies(prepared_request._cookies, self.cookies) - prepared_request.prepare_cookies(prepared_request._cookies) - - # Rebuild auth and proxy information. - proxies = self.rebuild_proxies(prepared_request, proxies) - self.rebuild_auth(prepared_request, resp) - - # 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) - ) - - # Attempt to rewind consumed file-like object. - if rewindable: - rewind_body(prepared_request) - - # Override the original request. - req = prepared_request - - if yield_requests: - yield req - else: - - resp = self.send( - req, - stream=stream, - timeout=timeout, - verify=verify, - cert=cert, - proxies=proxies, - allow_redirects=False, - **adapter_kwargs - ) - - extract_cookies_to_jar(self.cookies, prepared_request, resp.raw) - - # extract redirect url, if any, for the next loop - url = self.get_redirect_target(resp) - yield resp - - def rebuild_auth(self, prepared_request, response): - """When being redirected we may want to strip authentication from the - request to avoid leaking credentials. This method intelligently removes - and reapplies authentication where possible to avoid credential loss. - """ - headers = prepared_request.headers - url = prepared_request.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'] - - # .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 - NO_PROXY, we strip the proxy configuration. Otherwise, we set missing - proxy keys for this URL (in case they were stripped by a previous - redirect). - - This method also replaces the Proxy-Authorization header where - necessary. - - :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') - - 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'] - - 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) - - return new_proxies - - def rebuild_method(self, prepared_request, response): - """When being redirected we may want to change the method of the request - based on certain specs or browser behavior. - """ - 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' - - # Do what the browsers do, despite standards... - # First, turn 302s into GETs. - 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' - - prepared_request.method = method - - -class Session(SessionRedirectMixin): - """A Requests session. - - Provides cookie persistence, connection-pooling, and configuration. - - Basic Usage:: - - >>> import requests - >>> s = requests.Session() - >>> s.get('https://httpbin.org/get') - - - Or as a context manager:: - - >>> with requests.Session() as s: - ... s.get('https://httpbin.org/get') - - """ - - __attrs__ = [ - 'headers', 'cookies', 'auth', 'proxies', 'hooks', 'params', 'verify', - 'cert', 'adapters', 'stream', 'trust_env', - 'max_redirects', - ] - - def __init__(self): - - #: A case-insensitive dictionary of headers to be sent on each - #: :class:`Request ` sent from this - #: :class:`Session `. - self.headers = default_headers() - - #: Default Authentication tuple or object to attach to - #: :class:`Request `. - self.auth = None - - #: Dictionary mapping protocol or protocol and host to the URL of the proxy - #: (e.g. {'http': 'foo.bar:3128', 'http://host.name': 'foo.bar:4012'}) to - #: be used on each :class:`Request `. - self.proxies = {} - - #: Event-handling hooks. - self.hooks = default_hooks() - - #: Dictionary of querystring data to attach to each - #: :class:`Request `. The dictionary values may be lists for - #: representing multivalued query parameters. - self.params = {} - - #: Stream response content default. - self.stream = False - - #: SSL Verification default. - #: Defaults to `True`, requiring requests to verify the TLS certificate at the - #: remote end. - #: If verify is set to `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. - #: Only set this to `False` for testing. - self.verify = True - - #: SSL client certificate default, if String, path to ssl client - #: cert file (.pem). If Tuple, ('cert', 'key') pair. - self.cert = None - - #: Maximum number of redirects allowed. If the request exceeds this - #: limit, a :class:`TooManyRedirects` exception is raised. - #: This defaults to requests.models.DEFAULT_REDIRECT_LIMIT, which is - #: 30. - self.max_redirects = DEFAULT_REDIRECT_LIMIT - - #: Trust environment settings for proxy configuration, default - #: authentication and similar. - self.trust_env = True - - #: A CookieJar containing all currently outstanding cookies set on this - #: session. By default it is a - #: :class:`RequestsCookieJar `, but - #: may be any other ``cookielib.CookieJar`` compatible object. - self.cookies = cookiejar_from_dict({}) - - # Default connection adapters. - self.adapters = OrderedDict() - self.mount('https://', HTTPAdapter()) - self.mount('http://', HTTPAdapter()) - - def __enter__(self): - return self - - def __exit__(self, *args): - self.close() - - def prepare_request(self, request): - """Constructs a :class:`PreparedRequest ` for - transmission and returns it. The :class:`PreparedRequest` has settings - merged from the :class:`Request ` instance and those of the - :class:`Session`. - - :param request: :class:`Request` instance to prepare with this - session's settings. - :rtype: requests.PreparedRequest - """ - cookies = request.cookies or {} - - # Bootstrap CookieJar. - if not isinstance(cookies, cookielib.CookieJar): - cookies = cookiejar_from_dict(cookies) - - # Merge with session cookies - merged_cookies = merge_cookies( - merge_cookies(RequestsCookieJar(), self.cookies), cookies) - - # Set environment's basic authentication if not explicitly set. - auth = request.auth - if self.trust_env and not auth and not self.auth: - auth = get_netrc_auth(request.url) - - p = PreparedRequest() - p.prepare( - method=request.method.upper(), - url=request.url, - files=request.files, - data=request.data, - json=request.json, - 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, - hooks=merge_hooks(request.hooks, self.hooks), - ) - 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): - """Constructs a :class:`Request `, prepares it and sends it. - Returns :class:`Response ` object. - - :param method: method for the new :class:`Request` object. - :param url: URL for the new :class:`Request` object. - :param params: (optional) Dictionary or bytes to be sent in the query - string for the :class:`Request`. - :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 to send in the body of the - :class:`Request`. - :param headers: (optional) Dictionary of HTTP Headers to send with the - :class:`Request`. - :param cookies: (optional) Dict or CookieJar object to send with the - :class:`Request`. - :param files: (optional) Dictionary of ``'filename': file-like-objects`` - for multipart encoding upload. - :param auth: (optional) Auth tuple or callable to enable - Basic/Digest/Custom HTTP Auth. - :param timeout: (optional) How long to wait for the server to send - data before giving up, as a float, or a :ref:`(connect timeout, - read timeout) ` tuple. - :type timeout: float or tuple - :param allow_redirects: (optional) Set to True by default. - :type allow_redirects: bool - :param proxies: (optional) Dictionary mapping protocol or protocol and - hostname to the URL of the proxy. - :param stream: (optional) whether to immediately download the response - content. Defaults to ``False``. - :param verify: (optional) Either a boolean, in which case it controls whether we verify - the server's TLS certificate, or a string, in which case it must be a path - to a CA bundle to use. Defaults to ``True``. When set to - ``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`` - 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. - :rtype: requests.Response - """ - # Create the Request. - req = Request( - method=method.upper(), - url=url, - headers=headers, - files=files, - data=data or {}, - json=json, - params=params or {}, - auth=auth, - cookies=cookies, - hooks=hooks, - ) - prep = self.prepare_request(req) - - proxies = proxies or {} - - settings = self.merge_environment_settings( - prep.url, proxies, stream, verify, cert - ) - - # Send the request. - send_kwargs = { - 'timeout': timeout, - 'allow_redirects': allow_redirects, - } - send_kwargs.update(settings) - resp = self.send(prep, **send_kwargs) - - return resp - - def get(self, url, **kwargs): - r"""Sends a GET request. Returns :class:`Response` object. - - :param url: URL for the new :class:`Request` object. - :param \*\*kwargs: Optional arguments that ``request`` takes. - :rtype: requests.Response - """ - - 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. - - :param url: URL for the new :class:`Request` object. - :param \*\*kwargs: Optional arguments that ``request`` takes. - :rtype: requests.Response - """ - - 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. - - :param url: URL for the new :class:`Request` object. - :param \*\*kwargs: Optional arguments that ``request`` takes. - :rtype: requests.Response - """ - - 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. - - :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 to send in the body of the :class:`Request`. - :param \*\*kwargs: Optional arguments that ``request`` takes. - :rtype: requests.Response - """ - - 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. - - :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 \*\*kwargs: Optional arguments that ``request`` takes. - :rtype: requests.Response - """ - - return self.request('PUT', url, data=data, **kwargs) - - def patch(self, url, data=None, **kwargs): - r"""Sends a PATCH request. Returns :class:`Response` object. - - :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 \*\*kwargs: Optional arguments that ``request`` takes. - :rtype: requests.Response - """ - - return self.request('PATCH', url, data=data, **kwargs) - - def delete(self, url, **kwargs): - r"""Sends a DELETE request. Returns :class:`Response` object. - - :param url: URL for the new :class:`Request` object. - :param \*\*kwargs: Optional arguments that ``request`` takes. - :rtype: requests.Response - """ - - return self.request('DELETE', url, **kwargs) - - def send(self, request, **kwargs): - """Send a given PreparedRequest. - - :rtype: requests.Response - """ - # 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.rebuild_proxies(request, self.proxies)) - - # 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.') - - # Set up variables needed for resolve_redirects and dispatching of hooks - allow_redirects = kwargs.pop('allow_redirects', True) - stream = kwargs.get('stream') - hooks = request.hooks - - # Get the appropriate adapter to use - adapter = self.get_adapter(url=request.url) - - # Start time (approximately) of the request - start = preferred_clock() - - # Send the request - r = adapter.send(request, **kwargs) - - # Total elapsed time of the request (approximately) - elapsed = preferred_clock() - start - r.elapsed = timedelta(seconds=elapsed) - - # Response manipulation hooks - r = dispatch_hook('response', hooks, r, **kwargs) - - # Persist cookies - if r.history: - - # If the hooks create history then we want those cookies too - for resp in r.history: - extract_cookies_to_jar(self.cookies, resp.request, resp.raw) - - extract_cookies_to_jar(self.cookies, request, r.raw) - - # Resolve redirects if allowed. - if allow_redirects: - # Redirect resolving generator. - gen = self.resolve_redirects(r, request, **kwargs) - history = [resp for resp in gen] - else: - history = [] - - # Shuffle things around if there's history. - if history: - # Insert the first (original) request at the start - history.insert(0, r) - # Get the last request made - r = history.pop() - r.history = history - - # 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)) - except StopIteration: - pass - - if not stream: - r.content - - return r - - def merge_environment_settings(self, url, proxies, stream, verify, cert): - """ - Check the environment and merge it with some settings. - - :rtype: dict - """ - # 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 - 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. - if verify is True or verify is None: - verify = (os.environ.get('REQUESTS_CA_BUNDLE') or - os.environ.get('CURL_CA_BUNDLE')) - - # Merge all the kwargs. - proxies = merge_setting(proxies, self.proxies) - stream = merge_setting(stream, self.stream) - verify = merge_setting(verify, self.verify) - cert = merge_setting(cert, self.cert) - - return {'verify': verify, 'proxies': proxies, 'stream': stream, - 'cert': cert} - - def get_adapter(self, url): - """ - Returns the appropriate connection adapter for the given URL. - - :rtype: requests.adapters.BaseAdapter - """ - for (prefix, adapter) in self.adapters.items(): - - if url.lower().startswith(prefix.lower()): - return adapter - - # Nothing matches :-/ - raise InvalidSchema("No connection adapters were found for {!r}".format(url)) - - def close(self): - """Closes all adapters and as such the session""" - for v in self.adapters.values(): - v.close() - - def mount(self, prefix, adapter): - """Registers a connection adapter to a prefix. - - Adapters are sorted in descending order by prefix length. - """ - self.adapters[prefix] = adapter - keys_to_move = [k for k in self.adapters if len(k) < len(prefix)] - - for key in keys_to_move: - self.adapters[key] = self.adapters.pop(key) - - def __getstate__(self): - state = {attr: getattr(self, attr, None) for attr in self.__attrs__} - return state - - def __setstate__(self, state): - for attr, value in state.items(): - setattr(self, attr, value) - - -def session(): - """ - Returns a :class:`Session` for context-management. - - .. deprecated:: 1.0.0 - - This method has been deprecated since version 1.0.0 and is only kept for - backwards compatibility. New code should use :class:`~requests.sessions.Session` - to create a session. This may be removed at a future date. - - :rtype: Session - """ - return Session() diff --git a/venv/lib/python3.8/site-packages/requests/status_codes.py b/venv/lib/python3.8/site-packages/requests/status_codes.py deleted file mode 100644 index d80a7cd..0000000 --- a/venv/lib/python3.8/site-packages/requests/status_codes.py +++ /dev/null @@ -1,123 +0,0 @@ -# -*- 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 -items. - -Example:: - - >>> import requests - >>> requests.codes['temporary_redirect'] - 307 - >>> requests.codes.teapot - 418 - >>> requests.codes['\o/'] - 200 - -Some codes have multiple names, and both upper- and lower-case versions of -the names are allowed. For example, ``codes.ok``, ``codes.OK``, and -``codes.okay`` all correspond to the HTTP status code 200. -""" - -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',), - - # 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 - - # 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',), - - # 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'), -} - -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(('\\', '/')): - setattr(codes, title.upper(), code) - - def doc(code): - names = ', '.join('``%s``' % 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) - -_init() diff --git a/venv/lib/python3.8/site-packages/requests/structures.py b/venv/lib/python3.8/site-packages/requests/structures.py deleted file mode 100644 index 8ee0ba7..0000000 --- a/venv/lib/python3.8/site-packages/requests/structures.py +++ /dev/null @@ -1,105 +0,0 @@ -# -*- coding: utf-8 -*- - -""" -requests.structures -~~~~~~~~~~~~~~~~~~~ - -Data structures that power Requests. -""" - -from collections import OrderedDict - -from .compat import Mapping, MutableMapping - - -class CaseInsensitiveDict(MutableMapping): - """A case-insensitive ``dict``-like object. - - Implements all methods and operations of - ``MutableMapping`` as well as dict's ``copy``. Also - provides ``lower_items``. - - All keys are expected to be strings. The structure remembers the - case of the last key to be set, and ``iter(instance)``, - ``keys()``, ``items()``, ``iterkeys()``, and ``iteritems()`` - will contain case-sensitive keys. However, querying and contains - testing is case insensitive:: - - cid = CaseInsensitiveDict() - cid['Accept'] = 'application/json' - cid['aCCEPT'] == 'application/json' # True - list(cid) == ['Accept'] # True - - For example, ``headers['content-encoding']`` will return the - value of a ``'Content-Encoding'`` response header, regardless - of how the header name was originally stored. - - If the constructor, ``.update``, or equality comparison - operations are given keys that have equal ``.lower()``s, the - behavior is undefined. - """ - - def __init__(self, data=None, **kwargs): - self._store = OrderedDict() - if data is None: - data = {} - self.update(data, **kwargs) - - def __setitem__(self, key, value): - # Use the lowercased key for lookups, but store the actual - # key alongside the value. - self._store[key.lower()] = (key, value) - - def __getitem__(self, key): - return self._store[key.lower()][1] - - def __delitem__(self, key): - del self._store[key.lower()] - - def __iter__(self): - return (casedkey for casedkey, mappedvalue in self._store.values()) - - def __len__(self): - return len(self._store) - - def lower_items(self): - """Like iteritems(), but with all lowercase keys.""" - return ( - (lowerkey, keyval[1]) - for (lowerkey, keyval) - in self._store.items() - ) - - def __eq__(self, other): - if isinstance(other, Mapping): - other = CaseInsensitiveDict(other) - else: - return NotImplemented - # Compare insensitively - return dict(self.lower_items()) == dict(other.lower_items()) - - # Copy is required - def copy(self): - return CaseInsensitiveDict(self._store.values()) - - def __repr__(self): - return str(dict(self.items())) - - -class LookupDict(dict): - """Dictionary lookup object.""" - - def __init__(self, name=None): - self.name = name - super(LookupDict, self).__init__() - - def __repr__(self): - return '' % (self.name) - - def __getitem__(self, key): - # We allow fall-through here, so values default to None - - return self.__dict__.get(key, None) - - def get(self, key, default=None): - return self.__dict__.get(key, default) diff --git a/venv/lib/python3.8/site-packages/requests/utils.py b/venv/lib/python3.8/site-packages/requests/utils.py deleted file mode 100644 index dbb02a0..0000000 --- a/venv/lib/python3.8/site-packages/requests/utils.py +++ /dev/null @@ -1,1013 +0,0 @@ -# -*- coding: utf-8 -*- - -""" -requests.utils -~~~~~~~~~~~~~~ - -This module provides utility functions that are used within Requests -that are also useful for external consumption. -""" - -import codecs -import contextlib -import io -import os -import re -import socket -import struct -import sys -import tempfile -import warnings -import zipfile -from collections import OrderedDict -from urllib3.util import make_headers - -from .__version__ import __version__ -from . import certs -# to_native_string is unused here, but imported here for backwards compatibility -from ._internal_utils import to_native_string -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) -from .cookies import cookiejar_from_dict -from .structures import CaseInsensitiveDict -from .exceptions import ( - InvalidURL, InvalidHeader, FileModeWarning, UnrewindableBodyError) - -NETRC_FILES = ('.netrc', '_netrc') - -DEFAULT_CA_BUNDLE_PATH = certs.where() - -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': - # 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 - except ImportError: - return False - - try: - 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]) - # ProxyOverride is almost always a string - proxyOverride = winreg.QueryValueEx(internetSettings, - 'ProxyOverride')[0] - except OSError: - return False - if not proxyEnable or not proxyOverride: - return False - - # make a check value list from the registry entry: replace the - # '' string by the localhost entry and the corresponding - # canonical entry. - proxyOverride = proxyOverride.split(';') - # now check if we match one of the registry values. - for test in proxyOverride: - if test == '': - 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 - if re.match(test, host, re.I): - return True - return False - - def proxy_bypass(host): # noqa - """Return True, if the host should be bypassed. - - Checks proxy settings gathered from the environment, if specified, - or the registry. - """ - if getproxies_environment(): - return proxy_bypass_environment(host) - else: - return proxy_bypass_registry(host) - - -def dict_to_sequence(d): - """Returns an internal sequence dictionary update.""" - - if hasattr(d, 'items'): - d = d.items() - - return d - - -def super_len(o): - total_length = None - current_position = 0 - - if hasattr(o, '__len__'): - total_length = len(o) - - elif hasattr(o, 'len'): - total_length = o.len - - elif hasattr(o, 'fileno'): - try: - fileno = o.fileno() - except io.UnsupportedOperation: - 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 hasattr(o, 'tell'): - try: - current_position = o.tell() - except (OSError, IOError): - # 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 - # let requests chunk it instead. - 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 - try: - # seek to end of file - o.seek(0, 2) - total_length = o.tell() - - # seek back to current position to support - # partially read file-like objects - o.seek(current_position or 0) - except (OSError, IOError): - total_length = 0 - - if total_length is None: - total_length = 0 - - return max(0, total_length - current_position) - - -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') - if netrc_file is not None: - netrc_locations = (netrc_file,) - else: - netrc_locations = ('~/{}'.format(f) for f in NETRC_FILES) - - try: - from netrc import netrc, NetrcParseError - - netrc_path = None - - for f in netrc_locations: - try: - loc = os.path.expanduser(f) - except KeyError: - # os.path.expanduser can fail when $HOME is undefined and - # getpwuid fails. See https://bugs.python.org/issue20164 & - # https://github.com/psf/requests/issues/1846 - return - - if os.path.exists(loc): - netrc_path = loc - break - - # Abort early if there isn't one. - if netrc_path is None: - return - - ri = urlparse(url) - - # Strip port numbers from netloc. This weird `if...encode`` dance is - # used for Python 3.2, which doesn't support unicode literals. - splitstr = b':' - if isinstance(url, str): - 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) - return (_netrc[login_i], _netrc[2]) - except (NetrcParseError, IOError): - # 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: - raise - - # App Engine hackiness. - except (ImportError, AttributeError): - pass - - -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] != '>'): - return os.path.basename(name) - - -def extract_zipped_paths(path): - """Replace nonexistent paths that look like they refer to a member of a zip - archive with the location of an extracted copy of the target, or else - just return the provided path unchanged. - """ - if os.path.exists(path): - # this is already a valid path, no need to do anything further - return path - - # find the first valid part of the provided path and treat that as a zip archive - # assume the rest of the path is the name of a member in the archive - 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 zipfile.is_zipfile(archive): - return path - - zip_file = zipfile.ZipFile(archive) - if member not in zip_file.namelist(): - return 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('/')[-1]) - if not os.path.exists(extracted_path): - # 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""" - replacer = os.rename if sys.version_info[0] == 2 else os.replace - tmp_descriptor, tmp_name = tempfile.mkstemp(dir=os.path.dirname(filename)) - try: - with os.fdopen(tmp_descriptor, 'wb') as tmp_handler: - yield tmp_handler - replacer(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 - OrderedDict, e.g., - - :: - - >>> from_key_val_list([('key', 'val')]) - OrderedDict([('key', 'val')]) - >>> from_key_val_list('string') - Traceback (most recent call last): - ... - ValueError: cannot encode objects that are not 2-tuples - >>> from_key_val_list({'key': 'val'}) - OrderedDict([('key', 'val')]) - - :rtype: OrderedDict - """ - if value is None: - return None - - if isinstance(value, (str, bytes, bool, int)): - raise ValueError('cannot encode objects that are not 2-tuples') - - return OrderedDict(value) - - -def to_key_val_list(value): - """Take an object and test to see if it can be represented as a - dictionary. If it can be, return a list of tuples, e.g., - - :: - - >>> to_key_val_list([('key', 'val')]) - [('key', 'val')] - >>> to_key_val_list({'key': 'val'}) - [('key', 'val')] - >>> to_key_val_list('string') - Traceback (most recent call last): - ... - ValueError: cannot encode objects that are not 2-tuples - - :rtype: list - """ - if value is None: - return None - - if isinstance(value, (str, bytes, bool, int)): - raise ValueError('cannot encode objects that are not 2-tuples') - - if isinstance(value, Mapping): - value = value.items() - - return list(value) - - -# From mitsuhiko/werkzeug (used with permission). -def parse_list_header(value): - """Parse lists as described by RFC 2068 Section 2. - - In particular, parse comma-separated lists where the elements of - the list may include quoted-strings. A quoted-string could - contain a comma. A non-quoted string could have quotes in the - middle. Quotes are removed automatically after parsing. - - It basically works like :func:`parse_set_header` just that items - may appear multiple times and case sensitivity is preserved. - - The return value is a standard :class:`list`: - - >>> parse_list_header('token, "quoted value"') - ['token', 'quoted value'] - - To create a header from the :class:`list` again, use the - :func:`dump_header` function. - - :param value: a string with a list header. - :return: :class:`list` - :rtype: list - """ - result = [] - for item in _parse_list_header(value): - if item[:1] == item[-1:] == '"': - item = unquote_header_value(item[1:-1]) - result.append(item) - return result - - -# From mitsuhiko/werkzeug (used with permission). -def parse_dict_header(value): - """Parse lists of key, value pairs as described by RFC 2068 Section 2 and - convert them into a python dict: - - >>> d = parse_dict_header('foo="is a fish", bar="as well"') - >>> type(d) is dict - True - >>> sorted(d.items()) - [('bar', 'as well'), ('foo', 'is a fish')] - - If there is no value for a key it will be `None`: - - >>> parse_dict_header('key_without_value') - {'key_without_value': None} - - To create a header from the :class:`dict` again, use the - :func:`dump_header` function. - - :param value: a string with a dict header. - :return: :class:`dict` - :rtype: dict - """ - result = {} - for item in _parse_list_header(value): - if '=' not in item: - result[item] = None - continue - name, value = item.split('=', 1) - if value[:1] == value[-1:] == '"': - value = unquote_header_value(value[1:-1]) - result[name] = value - return result - - -# From mitsuhiko/werkzeug (used with permission). -def unquote_header_value(value, is_filename=False): - r"""Unquotes a header value. (Reversal of :func:`quote_header_value`). - This does not use the real unquoting but what browsers are actually - using for quoting. - - :param value: the header value to unquote. - :rtype: str - """ - if value and value[0] == value[-1] == '"': - # this is not the real unquoting, but fixing this so that the - # RFC is met will result in bugs with internet explorer and - # probably some other browsers as well. IE for example is - # uploading files with "C:\foo\bar.txt" as filename - value = value[1:-1] - - # if this is a filename and the starting characters look like - # a UNC path, then just return the value without quotes. Using the - # 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('\\"', '"') - return value - - -def dict_from_cookiejar(cj): - """Returns a key/value dictionary from a CookieJar. - - :param cj: CookieJar object to extract cookies from. - :rtype: dict - """ - - cookie_dict = {} - - for cookie in cj: - cookie_dict[cookie.name] = cookie.value - - return cookie_dict - - -def add_dict_to_cookiejar(cj, cookie_dict): - """Returns a CookieJar from a key/value dictionary. - - :param cj: CookieJar to insert cookies into. - :param cookie_dict: Dict of key/values to insert into CookieJar. - :rtype: CookieJar - """ - - return cookiejar_from_dict(cookie_dict, cj) - - -def get_encodings_from_content(content): - """Returns encodings from given content string. - - :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) - - charset_re = re.compile(r']', flags=re.I) - pragma_re = re.compile(r']', flags=re.I) - xml_re = re.compile(r'^<\?xml.*?encoding=["\']*(.+?)["\'>]') - - return (charset_re.findall(content) + - pragma_re.findall(content) + - xml_re.findall(content)) - - -def _parse_content_type_header(header): - """Returns content type and parameters from given header - - :param header: string - :return: tuple containing content type and dictionary of - parameters - """ - - tokens = header.split(';') - content_type, params = tokens[0].strip(), tokens[1:] - params_dict = {} - items_to_strip = "\"' " - - for param in params: - param = param.strip() - if param: - key, value = param, True - 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) - params_dict[key.lower()] = value - return content_type, params_dict - - -def get_encoding_from_headers(headers): - """Returns encodings from given HTTP Header Dict. - - :param headers: dictionary to extract encoding from. - :rtype: str - """ - - 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 'text' in content_type: - return 'ISO-8859-1' - - 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' - - -def stream_decode_response_unicode(iterator, r): - """Stream decodes a iterator.""" - - if r.encoding is None: - for item in iterator: - yield item - return - - 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) - if rv: - yield rv - - -def iter_slices(string, slice_length): - """Iterate over slices of a string.""" - pos = 0 - if slice_length is None or slice_length <= 0: - slice_length = len(string) - while pos < len(string): - yield string[pos:pos + slice_length] - pos += slice_length - - -def get_unicode_from_response(r): - """Returns the requested content back in unicode. - - :param r: Response object to get unicode content from. - - Tried: - - 1. charset from content-type - 2. fall back and replace all unicode characters - - :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) - - tried_encodings = [] - - # Try charset from content-type - encoding = get_encoding_from_headers(r.headers) - - if encoding: - try: - return str(r.content, encoding) - except UnicodeError: - tried_encodings.append(encoding) - - # Fall back: - try: - return str(r.content, encoding, errors='replace') - except TypeError: - return r.content - - -# The unreserved URI characters (RFC 3986) -UNRESERVED_SET = frozenset( - "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz" + "0123456789-._~") - - -def unquote_unreserved(uri): - """Un-escape any percent-escape sequences in a URI that are unreserved - characters. This leaves all reserved, illegal and non-ASCII bytes encoded. - - :rtype: str - """ - 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) - - if c in UNRESERVED_SET: - parts[i] = c + parts[i][2:] - else: - parts[i] = '%' + parts[i] - else: - parts[i] = '%' + parts[i] - return ''.join(parts) - - -def requote_uri(uri): - """Re-quote the given URI. - - This function passes the given URI through an unquote/quote cycle to - ensure that it is fully and consistently quoted. - - :rtype: str - """ - safe_with_percent = "!#$%&'()*+,/:;=?@[]~" - safe_without_percent = "!#$&'()*+,/:;=?@[]~" - try: - # Unquote only the unreserved characters - # Then quote only illegal characters (do not quote reserved, - # unreserved, or '%') - return quote(unquote_unreserved(uri), safe=safe_with_percent) - except InvalidURL: - # We couldn't unquote the given URI, so let's try quoting it, but - # there may be unquoted '%'s in the URI. We need to make sure they're - # properly quoted so they do not cause issues elsewhere. - return quote(uri, safe=safe_without_percent) - - -def address_in_network(ip, net): - """This function allows you to check if an IP belongs to a network subnet - - Example: returns True if ip = 192.168.1.1 and net = 192.168.1.0/24 - returns False if ip = 192.168.1.1 and net = 192.168.100.0/24 - - :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 - return (ipaddr & netmask) == (network & netmask) - - -def dotted_netmask(mask): - """Converts mask from /xx format to xxx.xxx.xxx.xxx - - Example: if mask is 24 function returns 255.255.255.0 - - :rtype: str - """ - bits = 0xffffffff ^ (1 << 32 - mask) - 1 - return socket.inet_ntoa(struct.pack('>I', bits)) - - -def is_ipv4_address(string_ip): - """ - :rtype: bool - """ - try: - socket.inet_aton(string_ip) - except socket.error: - return False - return True - - -def is_valid_cidr(string_network): - """ - Very simple check of the cidr format in no_proxy variable. - - :rtype: bool - """ - if string_network.count('/') == 1: - try: - mask = int(string_network.split('/')[1]) - except ValueError: - return False - - if mask < 1 or mask > 32: - return False - - try: - socket.inet_aton(string_network.split('/')[0]) - except socket.error: - return False - else: - return False - return True - - -@contextlib.contextmanager -def set_environ(env_name, value): - """Set the environment variable 'env_name' to 'value' - - Save previous value, yield, and then restore the previous value stored in - the environment variable 'env_name'. - - If 'value' is None, do nothing""" - value_changed = value is not None - if value_changed: - old_value = os.environ.get(env_name) - os.environ[env_name] = value - try: - yield - finally: - if value_changed: - if old_value is None: - del os.environ[env_name] - else: - os.environ[env_name] = old_value - - -def should_bypass_proxies(url, no_proxy): - """ - Returns whether we should bypass proxies or not. - - :rtype: bool - """ - # 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()) - - # 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') - parsed = urlparse(url) - - if parsed.hostname is None: - # URLs don't always have hostnames, e.g. file:/// urls. - return True - - 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 - ) - - if is_ipv4_address(parsed.hostname): - for proxy_ip in no_proxy: - if is_valid_cidr(proxy_ip): - if address_in_network(parsed.hostname, proxy_ip): - return True - elif parsed.hostname == proxy_ip: - # If no_proxy ip was defined in plain IP notation instead of cidr notation & - # matches the IP of the index - return True - else: - host_with_port = parsed.hostname - if parsed.port: - host_with_port += ':{}'.format(parsed.port) - - for host in no_proxy: - if parsed.hostname.endswith(host) or host_with_port.endswith(host): - # The URL does match something in no_proxy, so we don't want - # to apply the proxies on this URL. - return True - - 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) - except (TypeError, socket.gaierror): - bypass = False - - if bypass: - return True - - return False - - -def get_environ_proxies(url, no_proxy=None): - """ - Return a dict of environment proxies. - - :rtype: dict - """ - if should_bypass_proxies(url, no_proxy=no_proxy): - return {} - else: - return getproxies() - - -def select_proxy(url, proxies): - """Select a proxy for the url, if applicable. - - :param url: The url being for the request - :param proxies: A dictionary of schemes or schemes and hosts to proxy URLs - """ - proxies = proxies or {} - urlparts = urlparse(url) - if urlparts.hostname is None: - return proxies.get(urlparts.scheme, proxies.get('all')) - - proxy_keys = [ - urlparts.scheme + '://' + urlparts.hostname, - urlparts.scheme, - 'all://' + urlparts.hostname, - 'all', - ] - proxy = None - for proxy_key in proxy_keys: - if proxy_key in proxies: - proxy = proxies[proxy_key] - break - - return proxy - - -def default_user_agent(name="python-requests"): - """ - Return a string representing the default user agent. - - :rtype: str - """ - return '%s/%s' % (name, __version__) - - -def default_headers(): - """ - :rtype: requests.structures.CaseInsensitiveDict - """ - return CaseInsensitiveDict({ - 'User-Agent': default_user_agent(), - 'Accept-Encoding': DEFAULT_ACCEPT_ENCODING, - 'Accept': '*/*', - 'Connection': 'keep-alive', - }) - - -def parse_header_links(value): - """Return a list of parsed link headers proxies. - - i.e. Link: ; rel=front; type="image/jpeg",; rel=back;type="image/jpeg" - - :rtype: list - """ - - links = [] - - replace_chars = ' \'"' - - value = value.strip(replace_chars) - if not value: - return links - - for val in re.split(', *<', value): - try: - url, params = val.split(';', 1) - except ValueError: - url, params = val, '' - - link = {'url': url.strip('<> \'"')} - - for param in params.split(';'): - try: - key, value = param.split('=') - except ValueError: - break - - link[key.strip(replace_chars)] = value.strip(replace_chars) - - links.append(link) - - return links - - -# Null bytes; no need to recreate these on each call to guess_json_utf -_null = '\x00'.encode('ascii') # encoding to ASCII for Python 3 -_null2 = _null * 2 -_null3 = _null * 3 - - -def guess_json_utf(data): - """ - :rtype: str - """ - # JSON always starts with two ASCII characters, so detection is as - # easy as counting the nulls and from their location and count - # 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 - if sample[:3] == codecs.BOM_UTF8: - 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 - nullcount = sample.count(_null) - if nullcount == 0: - return 'utf-8' - if nullcount == 2: - 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' - # Did not detect 2 valid UTF-16 ascii-range characters - if nullcount == 3: - if sample[:3] == _null3: - return 'utf-32-be' - if sample[1:] == _null3: - return 'utf-32-le' - # Did not detect a valid UTF-32 ascii-range character - return None - - -def prepend_scheme_if_needed(url, new_scheme): - """Given a URL that may or may not have a scheme, prepend the given scheme. - Does not replace a present scheme with the one provided as an argument. - - :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. - if not netloc: - netloc, path = path, netloc - - return urlunparse((scheme, netloc, path, params, query, fragment)) - - -def get_auth_from_url(url): - """Given a url with authentication components, extract them into a tuple of - username,password. - - :rtype: (str,str) - """ - parsed = urlparse(url) - - try: - auth = (unquote(parsed.username), unquote(parsed.password)) - except (AttributeError, TypeError): - 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. - - :param header: tuple, in the format (name, value). - """ - name, value = header - - if isinstance(value, bytes): - pat = _CLEAN_HEADER_REGEX_BYTE - 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))) - - -def urldefragauth(url): - """ - Given a url remove the fragment and the authentication part. - - :rtype: str - """ - scheme, netloc, path, params, query, fragment = urlparse(url) - - # see func:`prepend_scheme_if_needed` - if not netloc: - netloc, path = path, netloc - - netloc = netloc.rsplit('@', 1)[-1] - - 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): - try: - body_seek(prepared_request._body_position) - except (IOError, 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/venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/AUTHORS.txt b/venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/AUTHORS.txt deleted file mode 100644 index 72c87d7..0000000 --- a/venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/AUTHORS.txt +++ /dev/null @@ -1,562 +0,0 @@ -A_Rog -Aakanksha Agrawal <11389424+rasponic@users.noreply.github.com> -Abhinav Sagar <40603139+abhinavsagar@users.noreply.github.com> -ABHYUDAY PRATAP SINGH -abs51295 -AceGentile -Adam Chainz -Adam Tse -Adam Tse -Adam Wentz -admin -Adrien Morison -ahayrapetyan -Ahilya -AinsworthK -Akash Srivastava -Alan Yee -Albert Tugushev -Albert-Guan -albertg -Aleks Bunin -Alethea Flowers -Alex Gaynor -Alex Grönholm -Alex Loosley -Alex Morega -Alex Stachowiak -Alexander Shtyrov -Alexandre Conrad -Alexey Popravka -Alexey Popravka -Alli -Ami Fischman -Ananya Maiti -Anatoly Techtonik -Anders Kaseorg -Andreas Lutro -Andrei Geacar -Andrew Gaul -Andrey Bulgakov -Andrés Delfino <34587441+andresdelfino@users.noreply.github.com> -Andrés Delfino -Andy Freeland -Andy Freeland -Andy Kluger -Ani Hayrapetyan -Aniruddha Basak -Anish Tambe -Anrs Hu -Anthony Sottile -Antoine Musso -Anton Ovchinnikov -Anton Patrushev -Antonio Alvarado Hernandez -Antony Lee -Antti Kaihola -Anubhav Patel -Anuj Godase -AQNOUCH Mohammed -AraHaan -Arindam Choudhury -Armin Ronacher -Artem -Ashley Manton -Ashwin Ramaswami -atse -Atsushi Odagiri -Avner Cohen -Baptiste Mispelon -Barney Gale -barneygale -Bartek Ogryczak -Bastian Venthur -Ben Darnell -Ben Hoyt -Ben Rosser -Bence Nagy -Benjamin Peterson -Benjamin VanEvery -Benoit Pierre -Berker Peksag -Bernardo B. Marques -Bernhard M. Wiedemann -Bertil Hatt -Bogdan Opanchuk -BorisZZZ -Brad Erickson -Bradley Ayers -Brandon L. Reiss -Brandt Bucher -Brett Randall -Brian Cristante <33549821+brcrista@users.noreply.github.com> -Brian Cristante -Brian Rosner -BrownTruck -Bruno Oliveira -Bruno Renié -Bstrdsmkr -Buck Golemon -burrows -Bussonnier Matthias -c22 -Caleb Martinez -Calvin Smith -Carl Meyer -Carlos Liam -Carol Willing -Carter Thayer -Cass -Chandrasekhar Atina -Chih-Hsuan Yen -Chih-Hsuan Yen -Chris Brinker -Chris Hunt -Chris Jerdonek -Chris McDonough -Chris Wolfe -Christian Heimes -Christian Oudard -Christopher Hunt -Christopher Snyder -Clark Boylan -Clay McClure -Cody -Cody Soyland -Colin Watson -Connor Osborn -Cooper Lees -Cooper Ry Lees -Cory Benfield -Cory Wright -Craig Kerstiens -Cristian Sorinel -Curtis Doty -cytolentino -Damian Quiroga -Dan Black -Dan Savilonis -Dan Sully -daniel -Daniel Collins -Daniel Hahler -Daniel Holth -Daniel Jost -Daniel Shaulov -Daniele Esposti -Daniele Procida -Danny Hermes -Dav Clark -Dave Abrahams -Dave Jones -David Aguilar -David Black -David Bordeynik -David Bordeynik -David Caro -David Evans -David Linke -David Pursehouse -David Tucker -David Wales -Davidovich -derwolfe -Desetude -Diego Caraballo -DiegoCaraballo -Dmitry Gladkov -Domen Kožar -Donald Stufft -Dongweiming -Douglas Thor -DrFeathers -Dustin Ingram -Dwayne Bailey -Ed Morley <501702+edmorley@users.noreply.github.com> -Ed Morley -Eitan Adler -ekristina -elainechan -Eli Schwartz -Eli Schwartz -Emil Burzo -Emil Styrke -Endoh Takanao -enoch -Erdinc Mutlu -Eric Gillingham -Eric Hanchrow -Eric Hopper -Erik M. Bray -Erik Rose -Ernest W Durbin III -Ernest W. Durbin III -Erwin Janssen -Eugene Vereshchagin -everdimension -Felix Yan -fiber-space -Filip Kokosiński -Florian Briand -Florian Rathgeber -Francesco -Francesco Montesano -Frost Ming -Gabriel Curio -Gabriel de Perthuis -Garry Polley -gdanielson -Geoffrey Lehée -Geoffrey Sneddon -George Song -Georgi Valkov -Giftlin Rajaiah -gizmoguy1 -gkdoc <40815324+gkdoc@users.noreply.github.com> -Gopinath M <31352222+mgopi1990@users.noreply.github.com> -GOTO Hayato <3532528+gh640@users.noreply.github.com> -gpiks -Guilherme Espada -Guy Rozendorn -gzpan123 -Hanjun Kim -Hari Charan -Harsh Vardhan -Herbert Pfennig -Hsiaoming Yang -Hugo -Hugo Lopes Tavares -Hugo van Kemenade -hugovk -Hynek Schlawack -Ian Bicking -Ian Cordasco -Ian Lee -Ian Stapleton Cordasco -Ian Wienand -Ian Wienand -Igor Kuzmitshov -Igor Sobreira -Ilya Baryshev -INADA Naoki -Ionel Cristian Mărieș -Ionel Maries Cristian -Ivan Pozdeev -Jacob Kim -jakirkham -Jakub Stasiak -Jakub Vysoky -Jakub Wilk -James Cleveland -James Cleveland -James Firth -James Polley -Jan Pokorný -Jannis Leidel -jarondl -Jason R. Coombs -Jay Graves -Jean-Christophe Fillion-Robin -Jeff Barber -Jeff Dairiki -Jelmer Vernooij -jenix21 -Jeremy Stanley -Jeremy Zafran -Jiashuo Li -Jim Garrison -Jivan Amara -John Paton -John-Scott Atlakson -johnthagen -johnthagen -Jon Banafato -Jon Dufresne -Jon Parise -Jonas Nockert -Jonathan Herbert -Joost Molenaar -Jorge Niedbalski -Joseph Long -Josh Bronson -Josh Hansen -Josh Schneier -Juanjo Bazán -Julian Berman -Julian Gethmann -Julien Demoor -jwg4 -Jyrki Pulliainen -Kai Chen -Kamal Bin Mustafa -kaustav haldar -keanemind -Keith Maxwell -Kelsey Hightower -Kenneth Belitzky -Kenneth Reitz -Kenneth Reitz -Kevin Burke -Kevin Carter -Kevin Frommelt -Kevin R Patterson -Kexuan Sun -Kit Randel -kpinc -Krishna Oza -Kumar McMillan -Kyle Persohn -lakshmanaram -Laszlo Kiss-Kollar -Laurent Bristiel -Laurie Opperman -Leon Sasson -Lev Givon -Lincoln de Sousa -Lipis -Loren Carvalho -Lucas Cimon -Ludovic Gasc -Luke Macken -Luo Jiebin -luojiebin -luz.paz -László Kiss Kollár -László Kiss Kollár -Marc Abramowitz -Marc Tamlyn -Marcus Smith -Mariatta -Mark Kohler -Mark Williams -Mark Williams -Markus Hametner -Masaki -Masklinn -Matej Stuchlik -Mathew Jennings -Mathieu Bridon -Matt Good -Matt Maker -Matt Robenolt -matthew -Matthew Einhorn -Matthew Gilliard -Matthew Iversen -Matthew Trumbell -Matthew Willson -Matthias Bussonnier -mattip -Maxim Kurnikov -Maxime Rouyrre -mayeut -mbaluna <44498973+mbaluna@users.noreply.github.com> -mdebi <17590103+mdebi@users.noreply.github.com> -memoselyk -Michael -Michael Aquilina -Michael E. Karpeles -Michael Klich -Michael Williamson -michaelpacer -Mickaël Schoentgen -Miguel Araujo Perez -Mihir Singh -Mike -Mike Hendricks -Min RK -MinRK -Miro Hrončok -Monica Baluna -montefra -Monty Taylor -Nate Coraor -Nathaniel J. Smith -Nehal J Wani -Neil Botelho -Nick Coghlan -Nick Stenning -Nick Timkovich -Nicolas Bock -Nikhil Benesch -Nitesh Sharma -Nowell Strite -NtaleGrey -nvdv -Ofekmeister -ofrinevo -Oliver Jeeves -Oliver Tonnhofer -Olivier Girardot -Olivier Grisel -Ollie Rutherfurd -OMOTO Kenji -Omry Yadan -Oren Held -Oscar Benjamin -Oz N Tiram -Pachwenko <32424503+Pachwenko@users.noreply.github.com> -Patrick Dubroy -Patrick Jenkins -Patrick Lawson -patricktokeeffe -Patrik Kopkan -Paul Kehrer -Paul Moore -Paul Nasrat -Paul Oswald -Paul van der Linden -Paulus Schoutsen -Pavithra Eswaramoorthy <33131404+QueenCoffee@users.noreply.github.com> -Pawel Jasinski -Pekka Klärck -Peter Lisák -Peter Waller -petr-tik -Phaneendra Chiruvella -Phil Freo -Phil Pennock -Phil Whelan -Philip Jägenstedt -Philip Molloy -Philippe Ombredanne -Pi Delport -Pierre-Yves Rofes -pip -Prabakaran Kumaresshan -Prabhjyotsing Surjit Singh Sodhi -Prabhu Marappan -Pradyun Gedam -Pratik Mallya -Preet Thakkar -Preston Holmes -Przemek Wrzos -Pulkit Goyal <7895pulkit@gmail.com> -Qiangning Hong -Quentin Pradet -R. David Murray -Rafael Caricio -Ralf Schmitt -Razzi Abuissa -rdb -Remi Rampin -Remi Rampin -Rene Dudfield -Riccardo Magliocchetti -Richard Jones -RobberPhex -Robert Collins -Robert McGibbon -Robert T. McGibbon -robin elisha robinson -Roey Berman -Rohan Jain -Rohan Jain -Rohan Jain -Roman Bogorodskiy -Romuald Brunet -Ronny Pfannschmidt -Rory McCann -Ross Brattain -Roy Wellington Ⅳ -Roy Wellington Ⅳ -Ryan Wooden -ryneeverett -Sachi King -Salvatore Rinchiera -Savio Jomton -schlamar -Scott Kitterman -Sean -seanj -Sebastian Jordan -Sebastian Schaetz -Segev Finer -SeongSoo Cho -Sergey Vasilyev -Seth Woodworth -Shlomi Fish -Shovan Maity -Simeon Visser -Simon Cross -Simon Pichugin -sinoroc -Sorin Sbarnea -Stavros Korokithakis -Stefan Scherfke -Stephan Erb -stepshal -Steve (Gadget) Barnes -Steve Barnes -Steve Dower -Steve Kowalik -Steven Myint -stonebig -Stéphane Bidoul (ACSONE) -Stéphane Bidoul -Stéphane Klein -Sumana Harihareswara -Sviatoslav Sydorenko -Sviatoslav Sydorenko -Swat009 -Takayuki SHIMIZUKAWA -tbeswick -Thijs Triemstra -Thomas Fenzl -Thomas Grainger -Thomas Guettler -Thomas Johansson -Thomas Kluyver -Thomas Smith -Tim D. Smith -Tim Gates -Tim Harder -Tim Heap -tim smith -tinruufu -Tom Forbes -Tom Freudenheim -Tom V -Tomas Orsava -Tomer Chachamu -Tony Beswick -Tony Zhaocheng Tan -TonyBeswick -toonarmycaptain -Toshio Kuratomi -Travis Swicegood -Tzu-ping Chung -Valentin Haenel -Victor Stinner -victorvpaulo -Viktor Szépe -Ville Skyttä -Vinay Sajip -Vincent Philippon -Vinicyus Macedo <7549205+vinicyusmacedo@users.noreply.github.com> -Vitaly Babiy -Vladimir Rutsky -W. Trevor King -Wil Tan -Wilfred Hughes -William ML Leslie -William T Olson -Wilson Mo -wim glenn -Wolfgang Maier -Xavier Fernandez -Xavier Fernandez -xoviat -xtreak -YAMAMOTO Takashi -Yen Chi Hsuan -Yeray Diaz Diaz -Yoval P -Yu Jian -Yuan Jing Vincent Yan -Zearin -Zearin -Zhiping Deng -Zvezdan Petkovic -Łukasz Langa -Семён Марьясин diff --git a/venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/INSTALLER b/venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/INSTALLER deleted file mode 100644 index a1b589e..0000000 --- a/venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/INSTALLER +++ /dev/null @@ -1 +0,0 @@ -pip diff --git a/venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/LICENSE.txt b/venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/LICENSE.txt deleted file mode 100644 index 737fec5..0000000 --- a/venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/LICENSE.txt +++ /dev/null @@ -1,20 +0,0 @@ -Copyright (c) 2008-2019 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/venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/METADATA b/venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/METADATA deleted file mode 100644 index 4adf953..0000000 --- a/venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/METADATA +++ /dev/null @@ -1,82 +0,0 @@ -Metadata-Version: 2.1 -Name: setuptools -Version: 44.0.0 -Summary: Easily download, build, install, upgrade, and uninstall Python packages -Home-page: https://github.com/pypa/setuptools -Author: Python Packaging Authority -Author-email: distutils-sig@python.org -License: UNKNOWN -Project-URL: Documentation, https://setuptools.readthedocs.io/ -Keywords: CPAN PyPI distutils eggs package management -Platform: UNKNOWN -Classifier: Development Status :: 5 - Production/Stable -Classifier: Intended Audience :: Developers -Classifier: License :: OSI Approved :: MIT License -Classifier: Operating System :: OS Independent -Classifier: Programming Language :: Python :: 2 -Classifier: Programming Language :: Python :: 2.7 -Classifier: Programming Language :: Python :: 3 -Classifier: Programming Language :: Python :: 3.5 -Classifier: Programming Language :: Python :: 3.6 -Classifier: Programming Language :: Python :: 3.7 -Classifier: Programming Language :: Python :: 3.8 -Classifier: Topic :: Software Development :: Libraries :: Python Modules -Classifier: Topic :: System :: Archiving :: Packaging -Classifier: Topic :: System :: Systems Administration -Classifier: Topic :: Utilities -Requires-Python: !=3.0.*,!=3.1.*,!=3.2.*,!=3.3.*,!=3.4.*,>=2.7 -Description-Content-Type: text/x-rst; charset=UTF-8 - -.. image:: https://img.shields.io/pypi/v/setuptools.svg - :target: https://pypi.org/project/setuptools - -.. image:: https://img.shields.io/readthedocs/setuptools/latest.svg - :target: https://setuptools.readthedocs.io - -.. image:: https://img.shields.io/travis/pypa/setuptools/master.svg?label=Linux%20CI&logo=travis&logoColor=white - :target: https://travis-ci.org/pypa/setuptools - -.. image:: https://img.shields.io/appveyor/ci/pypa/setuptools/master.svg?label=Windows%20CI&logo=appveyor&logoColor=white - :target: https://ci.appveyor.com/project/pypa/setuptools/branch/master - -.. image:: https://img.shields.io/codecov/c/github/pypa/setuptools/master.svg?logo=codecov&logoColor=white - :target: https://codecov.io/gh/pypa/setuptools - -.. image:: https://tidelift.com/badges/github/pypa/setuptools?style=flat - :target: https://tidelift.com/subscription/pkg/pypi-setuptools?utm_source=pypi-setuptools&utm_medium=readme - -.. image:: https://img.shields.io/pypi/pyversions/setuptools.svg - -See the `Installation Instructions -`_ in the Python Packaging -User's Guide for instructions on installing, upgrading, and uninstalling -Setuptools. - -Questions and comments should be directed to the `distutils-sig -mailing list `_. -Bug reports and especially tested patches may be -submitted directly to the `bug tracker -`_. - -To report a security vulnerability, please use the -`Tidelift security contact `_. -Tidelift will coordinate the fix and disclosure. - - -For Enterprise -============== - -Available as part of the Tidelift Subscription. - -Setuptools and the maintainers of thousands of other packages are working with Tidelift to deliver one enterprise subscription that covers all of the open source you use. - -`Learn more `_. - -Code of Conduct -=============== - -Everyone interacting in the setuptools project's codebases, issue trackers, -chat rooms, and mailing lists is expected to follow the -`PyPA Code of Conduct `_. - - diff --git a/venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/RECORD b/venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/RECORD deleted file mode 100644 index 32b8a84..0000000 --- a/venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/RECORD +++ /dev/null @@ -1,163 +0,0 @@ -../../../bin/easy_install,sha256=4DRAdRywY6MW0wB-bN1--ZtEd9HSTgvoauVDQ47yHPY,270 -../../../bin/easy_install-3.8,sha256=4DRAdRywY6MW0wB-bN1--ZtEd9HSTgvoauVDQ47yHPY,270 -__pycache__/easy_install.cpython-38.pyc,, -easy_install.py,sha256=MDC9vt5AxDsXX5qcKlBz2TnW6Tpuv_AobnfhCJ9X3PM,126 -setuptools-44.0.0.dist-info/AUTHORS.txt,sha256=RtqU9KfonVGhI48DAA4-yTOBUhBtQTjFhaDzHoyh7uU,21518 -setuptools-44.0.0.dist-info/INSTALLER,sha256=zuuue4knoyJ-UwPPXg8fezS7VCrXJQrAP7zeNuwvFQg,4 -setuptools-44.0.0.dist-info/LICENSE.txt,sha256=W6Ifuwlk-TatfRU2LR7W1JMcyMj5_y1NkRkOEJvnRDE,1090 -setuptools-44.0.0.dist-info/METADATA,sha256=L93fcafgVw4xoJUNG0lehyy0prVj-jU_JFxRh0ZUtos,3523 -setuptools-44.0.0.dist-info/RECORD,, -setuptools-44.0.0.dist-info/WHEEL,sha256=kGT74LWyRUZrL4VgLh6_g12IeVl_9u9ZVhadrgXZUEY,110 -setuptools-44.0.0.dist-info/dependency_links.txt,sha256=HlkCFkoK5TbZ5EMLbLKYhLcY_E31kBWD8TqW2EgmatQ,239 -setuptools-44.0.0.dist-info/entry_points.txt,sha256=ZmIqlp-SBdsBS2cuetmU2NdSOs4DG0kxctUR9UJ8Xk0,3150 -setuptools-44.0.0.dist-info/top_level.txt,sha256=2HUXVVwA4Pff1xgTFr3GsTXXKaPaO6vlG6oNJ_4u4Tg,38 -setuptools-44.0.0.dist-info/zip-safe,sha256=AbpHGcgLb-kRsJGnwFEktk7uzpZOCcBY74-YBdrKVGs,1 -setuptools/__init__.py,sha256=WBpCcn2lvdckotabeae1TTYonPOcgCIF3raD2zRWzBc,7283 -setuptools/__pycache__/__init__.cpython-38.pyc,, -setuptools/__pycache__/_deprecation_warning.cpython-38.pyc,, -setuptools/__pycache__/_imp.cpython-38.pyc,, -setuptools/__pycache__/archive_util.cpython-38.pyc,, -setuptools/__pycache__/build_meta.cpython-38.pyc,, -setuptools/__pycache__/config.cpython-38.pyc,, -setuptools/__pycache__/dep_util.cpython-38.pyc,, -setuptools/__pycache__/depends.cpython-38.pyc,, -setuptools/__pycache__/dist.cpython-38.pyc,, -setuptools/__pycache__/errors.cpython-38.pyc,, -setuptools/__pycache__/extension.cpython-38.pyc,, -setuptools/__pycache__/glob.cpython-38.pyc,, -setuptools/__pycache__/installer.cpython-38.pyc,, -setuptools/__pycache__/launch.cpython-38.pyc,, -setuptools/__pycache__/lib2to3_ex.cpython-38.pyc,, -setuptools/__pycache__/monkey.cpython-38.pyc,, -setuptools/__pycache__/msvc.cpython-38.pyc,, -setuptools/__pycache__/namespaces.cpython-38.pyc,, -setuptools/__pycache__/package_index.cpython-38.pyc,, -setuptools/__pycache__/py27compat.cpython-38.pyc,, -setuptools/__pycache__/py31compat.cpython-38.pyc,, -setuptools/__pycache__/py33compat.cpython-38.pyc,, -setuptools/__pycache__/py34compat.cpython-38.pyc,, -setuptools/__pycache__/sandbox.cpython-38.pyc,, -setuptools/__pycache__/site-patch.cpython-38.pyc,, -setuptools/__pycache__/ssl_support.cpython-38.pyc,, -setuptools/__pycache__/unicode_utils.cpython-38.pyc,, -setuptools/__pycache__/version.cpython-38.pyc,, -setuptools/__pycache__/wheel.cpython-38.pyc,, -setuptools/__pycache__/windows_support.cpython-38.pyc,, -setuptools/_deprecation_warning.py,sha256=jU9-dtfv6cKmtQJOXN8nP1mm7gONw5kKEtiPtbwnZyI,218 -setuptools/_imp.py,sha256=jloslOkxrTKbobgemfP94YII0nhqiJzE1bRmCTZ1a5I,2223 -setuptools/_vendor/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -setuptools/_vendor/__pycache__/__init__.cpython-38.pyc,, -setuptools/_vendor/__pycache__/ordered_set.cpython-38.pyc,, -setuptools/_vendor/__pycache__/pyparsing.cpython-38.pyc,, -setuptools/_vendor/__pycache__/six.cpython-38.pyc,, -setuptools/_vendor/ordered_set.py,sha256=dbaCcs27dyN9gnMWGF5nA_BrVn6Q-NrjKYJpV9_fgBs,15130 -setuptools/_vendor/packaging/__about__.py,sha256=CpuMSyh1V7adw8QMjWKkY3LtdqRUkRX4MgJ6nF4stM0,744 -setuptools/_vendor/packaging/__init__.py,sha256=6enbp5XgRfjBjsI9-bn00HjHf5TH21PDMOKkJW8xw-w,562 -setuptools/_vendor/packaging/__pycache__/__about__.cpython-38.pyc,, -setuptools/_vendor/packaging/__pycache__/__init__.cpython-38.pyc,, -setuptools/_vendor/packaging/__pycache__/_compat.cpython-38.pyc,, -setuptools/_vendor/packaging/__pycache__/_structures.cpython-38.pyc,, -setuptools/_vendor/packaging/__pycache__/markers.cpython-38.pyc,, -setuptools/_vendor/packaging/__pycache__/requirements.cpython-38.pyc,, -setuptools/_vendor/packaging/__pycache__/specifiers.cpython-38.pyc,, -setuptools/_vendor/packaging/__pycache__/tags.cpython-38.pyc,, -setuptools/_vendor/packaging/__pycache__/utils.cpython-38.pyc,, -setuptools/_vendor/packaging/__pycache__/version.cpython-38.pyc,, -setuptools/_vendor/packaging/_compat.py,sha256=Ugdm-qcneSchW25JrtMIKgUxfEEBcCAz6WrEeXeqz9o,865 -setuptools/_vendor/packaging/_structures.py,sha256=pVd90XcXRGwpZRB_qdFuVEibhCHpX_bL5zYr9-N0mc8,1416 -setuptools/_vendor/packaging/markers.py,sha256=-meFl9Fr9V8rF5Rduzgett5EHK9wBYRUqssAV2pj0lw,8268 -setuptools/_vendor/packaging/requirements.py,sha256=3dwIJekt8RRGCUbgxX8reeAbgmZYjb0wcCRtmH63kxI,4742 -setuptools/_vendor/packaging/specifiers.py,sha256=0ZzQpcUnvrQ6LjR-mQRLzMr8G6hdRv-mY0VSf_amFtI,27778 -setuptools/_vendor/packaging/tags.py,sha256=EPLXhO6GTD7_oiWEO1U0l0PkfR8R_xivpMDHXnsTlts,12933 -setuptools/_vendor/packaging/utils.py,sha256=VaTC0Ei7zO2xl9ARiWmz2YFLFt89PuuhLbAlXMyAGms,1520 -setuptools/_vendor/packaging/version.py,sha256=Npdwnb8OHedj_2L86yiUqscujb7w_i5gmSK1PhOAFzg,11978 -setuptools/_vendor/pyparsing.py,sha256=tmrp-lu-qO1i75ZzIN5A12nKRRD1Cm4Vpk-5LR9rims,232055 -setuptools/_vendor/six.py,sha256=A6hdJZVjI3t_geebZ9BzUvwRrIXo0lfwzQlM2LcKyas,30098 -setuptools/archive_util.py,sha256=kw8Ib_lKjCcnPKNbS7h8HztRVK0d5RacU3r_KRdVnmM,6592 -setuptools/build_meta.py,sha256=-9Nmj9YdbW4zX3TssPJZhsENrTa4fw3k86Jm1cdKMik,9597 -setuptools/cli-32.exe,sha256=dfEuovMNnA2HLa3jRfMPVi5tk4R7alCbpTvuxtCyw0Y,65536 -setuptools/cli-64.exe,sha256=KLABu5pyrnokJCv6skjXZ6GsXeyYHGcqOUT3oHI3Xpo,74752 -setuptools/cli.exe,sha256=dfEuovMNnA2HLa3jRfMPVi5tk4R7alCbpTvuxtCyw0Y,65536 -setuptools/command/__init__.py,sha256=QCAuA9whnq8Bnoc0bBaS6Lw_KAUO0DiHYZQXEMNn5hg,568 -setuptools/command/__pycache__/__init__.cpython-38.pyc,, -setuptools/command/__pycache__/alias.cpython-38.pyc,, -setuptools/command/__pycache__/bdist_egg.cpython-38.pyc,, -setuptools/command/__pycache__/bdist_rpm.cpython-38.pyc,, -setuptools/command/__pycache__/bdist_wininst.cpython-38.pyc,, -setuptools/command/__pycache__/build_clib.cpython-38.pyc,, -setuptools/command/__pycache__/build_ext.cpython-38.pyc,, -setuptools/command/__pycache__/build_py.cpython-38.pyc,, -setuptools/command/__pycache__/develop.cpython-38.pyc,, -setuptools/command/__pycache__/dist_info.cpython-38.pyc,, -setuptools/command/__pycache__/easy_install.cpython-38.pyc,, -setuptools/command/__pycache__/egg_info.cpython-38.pyc,, -setuptools/command/__pycache__/install.cpython-38.pyc,, -setuptools/command/__pycache__/install_egg_info.cpython-38.pyc,, -setuptools/command/__pycache__/install_lib.cpython-38.pyc,, -setuptools/command/__pycache__/install_scripts.cpython-38.pyc,, -setuptools/command/__pycache__/py36compat.cpython-38.pyc,, -setuptools/command/__pycache__/register.cpython-38.pyc,, -setuptools/command/__pycache__/rotate.cpython-38.pyc,, -setuptools/command/__pycache__/saveopts.cpython-38.pyc,, -setuptools/command/__pycache__/sdist.cpython-38.pyc,, -setuptools/command/__pycache__/setopt.cpython-38.pyc,, -setuptools/command/__pycache__/test.cpython-38.pyc,, -setuptools/command/__pycache__/upload.cpython-38.pyc,, -setuptools/command/__pycache__/upload_docs.cpython-38.pyc,, -setuptools/command/alias.py,sha256=KjpE0sz_SDIHv3fpZcIQK-sCkJz-SrC6Gmug6b9Nkc8,2426 -setuptools/command/bdist_egg.py,sha256=nnfV8Ah8IRC_Ifv5Loa9FdxL66MVbyDXwy-foP810zM,18185 -setuptools/command/bdist_rpm.py,sha256=B7l0TnzCGb-0nLlm6rS00jWLkojASwVmdhW2w5Qz_Ak,1508 -setuptools/command/bdist_wininst.py,sha256=_6dz3lpB1tY200LxKPLM7qgwTCceOMgaWFF-jW2-pm0,637 -setuptools/command/build_clib.py,sha256=bQ9aBr-5ZSO-9fGsGsDLz0mnnFteHUZnftVLkhvHDq0,4484 -setuptools/command/build_ext.py,sha256=Ib42YUGksBswm2mL5xmQPF6NeTA6HcqrvAtEgFCv32A,13019 -setuptools/command/build_py.py,sha256=yWyYaaS9F3o9JbIczn064A5g1C5_UiKRDxGaTqYbtLE,9596 -setuptools/command/develop.py,sha256=MQlnGS6uP19erK2JCNOyQYoYyquk3PADrqrrinqqLtA,8184 -setuptools/command/dist_info.py,sha256=5t6kOfrdgALT-P3ogss6PF9k-Leyesueycuk3dUyZnI,960 -setuptools/command/easy_install.py,sha256=0lY8Agxe-7IgMtxgxFuOY1NrDlBzOUlpCKsvayXlTYY,89903 -setuptools/command/egg_info.py,sha256=0e_TXrMfpa8nGTO7GmJcmpPCMWzliZi6zt9aMchlumc,25578 -setuptools/command/install.py,sha256=8doMxeQEDoK4Eco0mO2WlXXzzp9QnsGJQ7Z7yWkZPG8,4705 -setuptools/command/install_egg_info.py,sha256=4zq_Ad3jE-EffParuyDEnvxU6efB-Xhrzdr8aB6Ln_8,3195 -setuptools/command/install_lib.py,sha256=9zdc-H5h6RPxjySRhOwi30E_WfcVva7gpfhZ5ata60w,5023 -setuptools/command/install_scripts.py,sha256=UD0rEZ6861mTYhIdzcsqKnUl8PozocXWl9VBQ1VTWnc,2439 -setuptools/command/launcher manifest.xml,sha256=xlLbjWrB01tKC0-hlVkOKkiSPbzMml2eOPtJ_ucCnbE,628 -setuptools/command/py36compat.py,sha256=SzjZcOxF7zdFUT47Zv2n7AM3H8koDys_0OpS-n9gIfc,4986 -setuptools/command/register.py,sha256=kk3DxXCb5lXTvqnhfwx2g6q7iwbUmgTyXUCaBooBOUk,468 -setuptools/command/rotate.py,sha256=co5C1EkI7P0GGT6Tqz-T2SIj2LBJTZXYELpmao6d4KQ,2164 -setuptools/command/saveopts.py,sha256=za7QCBcQimKKriWcoCcbhxPjUz30gSB74zuTL47xpP4,658 -setuptools/command/sdist.py,sha256=IL1LepD2h8qGKOFJ3rrQVbjNH_Q6ViD40l0QADr4MEU,8088 -setuptools/command/setopt.py,sha256=NTWDyx-gjDF-txf4dO577s7LOzHVoKR0Mq33rFxaRr8,5085 -setuptools/command/test.py,sha256=u2kXngIIdSYqtvwFlHiN6Iye1IB4TU6uadB2uiV1szw,9602 -setuptools/command/upload.py,sha256=XT3YFVfYPAmA5qhGg0euluU98ftxRUW-PzKcODMLxUs,462 -setuptools/command/upload_docs.py,sha256=oXiGplM_cUKLwE4CWWw98RzCufAu8tBhMC97GegFcms,7311 -setuptools/config.py,sha256=6SB2OY3qcooOJmG_rsK_s0pKBsorBlDpfMJUyzjQIGk,20575 -setuptools/dep_util.py,sha256=fgixvC1R7sH3r13ktyf7N0FALoqEXL1cBarmNpSEoWg,935 -setuptools/depends.py,sha256=qt2RWllArRvhnm8lxsyRpcthEZYp4GHQgREl1q0LkFw,5517 -setuptools/dist.py,sha256=xtXaNsOsE32MwwQqErzgXJF7jsTQz9GYFRrwnPFQ0J0,49865 -setuptools/errors.py,sha256=MVOcv381HNSajDgEUWzOQ4J6B5BHCBMSjHfaWcEwA1o,524 -setuptools/extension.py,sha256=uc6nHI-MxwmNCNPbUiBnybSyqhpJqjbhvOQ-emdvt_E,1729 -setuptools/extern/__init__.py,sha256=4q9gtShB1XFP6CisltsyPqtcfTO6ZM9Lu1QBl3l-qmo,2514 -setuptools/extern/__pycache__/__init__.cpython-38.pyc,, -setuptools/glob.py,sha256=o75cHrOxYsvn854thSxE0x9k8JrKDuhP_rRXlVB00Q4,5084 -setuptools/gui-32.exe,sha256=XBr0bHMA6Hpz2s9s9Bzjl-PwXfa9nH4ie0rFn4V2kWA,65536 -setuptools/gui-64.exe,sha256=aYKMhX1IJLn4ULHgWX0sE0yREUt6B3TEHf_jOw6yNyE,75264 -setuptools/gui.exe,sha256=XBr0bHMA6Hpz2s9s9Bzjl-PwXfa9nH4ie0rFn4V2kWA,65536 -setuptools/installer.py,sha256=TCFRonRo01I79zo-ucf3Ymhj8TenPlmhMijN916aaJs,5337 -setuptools/launch.py,sha256=sd7ejwhBocCDx_wG9rIs0OaZ8HtmmFU8ZC6IR_S0Lvg,787 -setuptools/lib2to3_ex.py,sha256=t5e12hbR2pi9V4ezWDTB4JM-AISUnGOkmcnYHek3xjg,2013 -setuptools/monkey.py,sha256=FGc9fffh7gAxMLFmJs2DW_OYWpBjkdbNS2n14UAK4NA,5264 -setuptools/msvc.py,sha256=8baJ6aYgCA4TRdWQQi185qB9dnU8FaP4wgpbmd7VODs,46751 -setuptools/namespaces.py,sha256=F0Nrbv8KCT2OrO7rwa03om4N4GZKAlnce-rr-cgDQa8,3199 -setuptools/package_index.py,sha256=6pb-B1POtHyLycAbkDETk4fO-Qv8_sY-rjTXhUOoh6k,40605 -setuptools/py27compat.py,sha256=tvmer0Tn-wk_JummCkoM22UIjpjL-AQ8uUiOaqTs8sI,1496 -setuptools/py31compat.py,sha256=h2rtZghOfwoGYd8sQ0-auaKiF3TcL3qX0bX3VessqcE,838 -setuptools/py33compat.py,sha256=SMF9Z8wnGicTOkU1uRNwZ_kz5Z_bj29PUBbqdqeeNsc,1330 -setuptools/py34compat.py,sha256=KYOd6ybRxjBW8NJmYD8t_UyyVmysppFXqHpFLdslGXU,245 -setuptools/sandbox.py,sha256=9UbwfEL5QY436oMI1LtFWohhoZ-UzwHvGyZjUH_qhkw,14276 -setuptools/script (dev).tmpl,sha256=RUzQzCQUaXtwdLtYHWYbIQmOaES5Brqq1FvUA_tu-5I,218 -setuptools/script.tmpl,sha256=WGTt5piezO27c-Dbx6l5Q4T3Ff20A5z7872hv3aAhYY,138 -setuptools/site-patch.py,sha256=OumkIHMuoSenRSW1382kKWI1VAwxNE86E5W8iDd34FY,2302 -setuptools/ssl_support.py,sha256=nLjPUBBw7RTTx6O4RJZ5eAMGgjJG8beiDbkFXDZpLuM,8493 -setuptools/unicode_utils.py,sha256=NOiZ_5hD72A6w-4wVj8awHFM3n51Kmw1Ic_vx15XFqw,996 -setuptools/version.py,sha256=og_cuZQb0QI6ukKZFfZWPlr1HgJBPPn2vO2m_bI9ZTE,144 -setuptools/wheel.py,sha256=zct-SEj5_LoHg6XELt2cVRdulsUENenCdS1ekM7TlZA,8455 -setuptools/windows_support.py,sha256=5GrfqSP2-dLGJoZTq2g6dCKkyQxxa2n5IQiXlJCoYEE,714 diff --git a/venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/WHEEL b/venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/WHEEL deleted file mode 100644 index ef99c6c..0000000 --- a/venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/WHEEL +++ /dev/null @@ -1,6 +0,0 @@ -Wheel-Version: 1.0 -Generator: bdist_wheel (0.34.2) -Root-Is-Purelib: true -Tag: py2-none-any -Tag: py3-none-any - diff --git a/venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/dependency_links.txt b/venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/dependency_links.txt deleted file mode 100644 index e87d021..0000000 --- a/venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/dependency_links.txt +++ /dev/null @@ -1,2 +0,0 @@ -https://files.pythonhosted.org/packages/source/c/certifi/certifi-2016.9.26.tar.gz#md5=baa81e951a29958563689d868ef1064d -https://files.pythonhosted.org/packages/source/w/wincertstore/wincertstore-0.2.zip#md5=ae728f2f007185648d0c7a8679b361e2 diff --git a/venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/entry_points.txt b/venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/entry_points.txt deleted file mode 100644 index 0fed3f1..0000000 --- a/venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/entry_points.txt +++ /dev/null @@ -1,68 +0,0 @@ -[console_scripts] -easy_install = setuptools.command.easy_install:main - -[distutils.commands] -alias = setuptools.command.alias:alias -bdist_egg = setuptools.command.bdist_egg:bdist_egg -bdist_rpm = setuptools.command.bdist_rpm:bdist_rpm -bdist_wininst = setuptools.command.bdist_wininst:bdist_wininst -build_clib = setuptools.command.build_clib:build_clib -build_ext = setuptools.command.build_ext:build_ext -build_py = setuptools.command.build_py:build_py -develop = setuptools.command.develop:develop -dist_info = setuptools.command.dist_info:dist_info -easy_install = setuptools.command.easy_install:easy_install -egg_info = setuptools.command.egg_info:egg_info -install = setuptools.command.install:install -install_egg_info = setuptools.command.install_egg_info:install_egg_info -install_lib = setuptools.command.install_lib:install_lib -install_scripts = setuptools.command.install_scripts:install_scripts -rotate = setuptools.command.rotate:rotate -saveopts = setuptools.command.saveopts:saveopts -sdist = setuptools.command.sdist:sdist -setopt = setuptools.command.setopt:setopt -test = setuptools.command.test:test -upload_docs = setuptools.command.upload_docs:upload_docs - -[distutils.setup_keywords] -convert_2to3_doctests = setuptools.dist:assert_string_list -dependency_links = setuptools.dist:assert_string_list -eager_resources = setuptools.dist:assert_string_list -entry_points = setuptools.dist:check_entry_points -exclude_package_data = setuptools.dist:check_package_data -extras_require = setuptools.dist:check_extras -include_package_data = setuptools.dist:assert_bool -install_requires = setuptools.dist:check_requirements -namespace_packages = setuptools.dist:check_nsp -package_data = setuptools.dist:check_package_data -packages = setuptools.dist:check_packages -python_requires = setuptools.dist:check_specifier -setup_requires = setuptools.dist:check_requirements -test_loader = setuptools.dist:check_importable -test_runner = setuptools.dist:check_importable -test_suite = setuptools.dist:check_test_suite -tests_require = setuptools.dist:check_requirements -use_2to3 = setuptools.dist:assert_bool -use_2to3_exclude_fixers = setuptools.dist:assert_string_list -use_2to3_fixers = setuptools.dist:assert_string_list -zip_safe = setuptools.dist:assert_bool - -[egg_info.writers] -PKG-INFO = setuptools.command.egg_info:write_pkg_info -dependency_links.txt = setuptools.command.egg_info:overwrite_arg -depends.txt = setuptools.command.egg_info:warn_depends_obsolete -eager_resources.txt = setuptools.command.egg_info:overwrite_arg -entry_points.txt = setuptools.command.egg_info:write_entries -namespace_packages.txt = setuptools.command.egg_info:overwrite_arg -requires.txt = setuptools.command.egg_info:write_requirements -top_level.txt = setuptools.command.egg_info:write_toplevel_names - -[setuptools.finalize_distribution_options] -2to3_doctests = setuptools.dist:Distribution._finalize_2to3_doctests -features = setuptools.dist:Distribution._finalize_feature_opts -keywords = setuptools.dist:Distribution._finalize_setup_keywords -parent_finalize = setuptools.dist:_Distribution.finalize_options - -[setuptools.installation] -eggsecutable = setuptools.command.easy_install:bootstrap - diff --git a/venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/top_level.txt b/venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/top_level.txt deleted file mode 100644 index 4577c6a..0000000 --- a/venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/top_level.txt +++ /dev/null @@ -1,3 +0,0 @@ -easy_install -pkg_resources -setuptools diff --git a/venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/zip-safe b/venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/zip-safe deleted file mode 100644 index 8b13789..0000000 --- a/venv/lib/python3.8/site-packages/setuptools-44.0.0.dist-info/zip-safe +++ /dev/null @@ -1 +0,0 @@ - diff --git a/venv/lib/python3.8/site-packages/setuptools/__init__.py b/venv/lib/python3.8/site-packages/setuptools/__init__.py deleted file mode 100644 index a71b2bb..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/__init__.py +++ /dev/null @@ -1,228 +0,0 @@ -"""Extensions to the 'distutils' for large or complex distributions""" - -import os -import sys -import functools -import distutils.core -import distutils.filelist -import re -from distutils.errors import DistutilsOptionError -from distutils.util import convert_path -from fnmatch import fnmatchcase - -from ._deprecation_warning import SetuptoolsDeprecationWarning - -from setuptools.extern.six import PY3, string_types -from setuptools.extern.six.moves import filter, map - -import setuptools.version -from setuptools.extension import Extension -from setuptools.dist import Distribution, Feature -from setuptools.depends import Require -from . import monkey - -__metaclass__ = type - - -__all__ = [ - 'setup', 'Distribution', 'Feature', 'Command', 'Extension', 'Require', - 'SetuptoolsDeprecationWarning', - 'find_packages' -] - -if PY3: - __all__.append('find_namespace_packages') - -__version__ = setuptools.version.__version__ - -bootstrap_install_from = None - -# If we run 2to3 on .py files, should we also convert docstrings? -# Default: yes; assume that we can detect doctests reliably -run_2to3_on_doctests = True -# Standard package names for fixer packages -lib2to3_fixer_packages = ['lib2to3.fixes'] - - -class PackageFinder: - """ - Generate a list of all Python packages found within a directory - """ - - @classmethod - def find(cls, where='.', exclude=(), include=('*',)): - """Return a list all Python packages found within directory 'where' - - 'where' is the root directory which will be searched for packages. It - should be supplied as a "cross-platform" (i.e. URL-style) path; it will - be converted to the appropriate local path syntax. - - 'exclude' is a sequence of package names to exclude; '*' can be used - as a wildcard in the names, such that 'foo.*' will exclude all - subpackages of 'foo' (but not 'foo' itself). - - 'include' is a sequence of package names to include. If it's - specified, only the named packages will be included. If it's not - specified, all found packages will be included. 'include' can contain - shell style wildcard patterns just like 'exclude'. - """ - - return list(cls._find_packages_iter( - convert_path(where), - cls._build_filter('ez_setup', '*__pycache__', *exclude), - cls._build_filter(*include))) - - @classmethod - def _find_packages_iter(cls, where, exclude, include): - """ - All the packages found in 'where' that pass the 'include' filter, but - not the 'exclude' filter. - """ - for root, dirs, files in os.walk(where, followlinks=True): - # Copy dirs to iterate over it, then empty dirs. - all_dirs = dirs[:] - dirs[:] = [] - - for dir in all_dirs: - full_path = os.path.join(root, dir) - rel_path = os.path.relpath(full_path, where) - package = rel_path.replace(os.path.sep, '.') - - # Skip directory trees that are not valid packages - if ('.' in dir or not cls._looks_like_package(full_path)): - continue - - # Should this package be included? - if include(package) and not exclude(package): - yield package - - # Keep searching subdirectories, as there may be more packages - # down there, even if the parent was excluded. - dirs.append(dir) - - @staticmethod - def _looks_like_package(path): - """Does a directory look like a package?""" - return os.path.isfile(os.path.join(path, '__init__.py')) - - @staticmethod - def _build_filter(*patterns): - """ - Given a list of patterns, return a callable that will be true only if - the input matches at least one of the patterns. - """ - return lambda name: any(fnmatchcase(name, pat=pat) for pat in patterns) - - -class PEP420PackageFinder(PackageFinder): - @staticmethod - def _looks_like_package(path): - return True - - -find_packages = PackageFinder.find - -if PY3: - find_namespace_packages = PEP420PackageFinder.find - - -def _install_setup_requires(attrs): - # Note: do not use `setuptools.Distribution` directly, as - # our PEP 517 backend patch `distutils.core.Distribution`. - dist = distutils.core.Distribution(dict( - (k, v) for k, v in attrs.items() - if k in ('dependency_links', 'setup_requires') - )) - # Honor setup.cfg's options. - dist.parse_config_files(ignore_option_errors=True) - if dist.setup_requires: - dist.fetch_build_eggs(dist.setup_requires) - - -def setup(**attrs): - # Make sure we have any requirements needed to interpret 'attrs'. - _install_setup_requires(attrs) - return distutils.core.setup(**attrs) - -setup.__doc__ = distutils.core.setup.__doc__ - - -_Command = monkey.get_unpatched(distutils.core.Command) - - -class Command(_Command): - __doc__ = _Command.__doc__ - - command_consumes_arguments = False - - def __init__(self, dist, **kw): - """ - Construct the command for dist, updating - vars(self) with any keyword parameters. - """ - _Command.__init__(self, dist) - vars(self).update(kw) - - def _ensure_stringlike(self, option, what, default=None): - val = getattr(self, option) - if val is None: - setattr(self, option, default) - return default - elif not isinstance(val, string_types): - raise DistutilsOptionError("'%s' must be a %s (got `%s`)" - % (option, what, val)) - return val - - def ensure_string_list(self, option): - r"""Ensure that 'option' is a list of strings. If 'option' is - currently a string, we split it either on /,\s*/ or /\s+/, so - "foo bar baz", "foo,bar,baz", and "foo, bar baz" all become - ["foo", "bar", "baz"]. - """ - val = getattr(self, option) - if val is None: - return - elif isinstance(val, string_types): - setattr(self, option, re.split(r',\s*|\s+', val)) - else: - if isinstance(val, list): - ok = all(isinstance(v, string_types) for v in val) - else: - ok = False - if not ok: - raise DistutilsOptionError( - "'%s' must be a list of strings (got %r)" - % (option, val)) - - def reinitialize_command(self, command, reinit_subcommands=0, **kw): - cmd = _Command.reinitialize_command(self, command, reinit_subcommands) - vars(cmd).update(kw) - return cmd - - -def _find_all_simple(path): - """ - Find all files under 'path' - """ - results = ( - os.path.join(base, file) - for base, dirs, files in os.walk(path, followlinks=True) - for file in files - ) - return filter(os.path.isfile, results) - - -def findall(dir=os.curdir): - """ - Find all files under 'dir' and return the list of full filenames. - Unless dir is '.', return full filenames with dir prepended. - """ - files = _find_all_simple(dir) - if dir == os.curdir: - make_rel = functools.partial(os.path.relpath, start=dir) - files = map(make_rel, files) - return list(files) - - -# Apply monkey patches -monkey.patch_all() diff --git a/venv/lib/python3.8/site-packages/setuptools/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/__pycache__/__init__.cpython-38.pyc deleted file mode 100644 index 4f566699c348f9c001f476f31ddfd46322e47b83..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 7768 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 W)`9KN#_C~h**|YSdr{H95ab7TS&euA diff --git a/venv/lib/python3.8/site-packages/setuptools/__pycache__/_imp.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/__pycache__/_imp.cpython-38.pyc deleted file mode 100644 index 40c92b88c7118ae8cdb6e715a0a3429984259c35..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1890 zcmZuyTW{Mo6xM~7W%-&kO)tYXZCIPSYZ7cJ+F=-qA+7_sXq_ULAr%G)ib%(@Wl1Gz zqzUAgrRZ~iLIUiiPkZb0eg|K-7ypI4bcb@9I9)08ko9<_RfXypM z>K|&V^$=U-IhfOrG`gBu7#IPbmo_*zg3yf+HzmRgN7@KzTw4eM(LG$ zW$^HZS27C&=aDkXkId-rOy30kKSBTflztWT-}Blh`fouWy;bSY(r#q%ncnR2mDD&< zap4AdO!L68)SK%Y^j~a68ZM5^DeRPA9qG~SGi1JRfTs$-2H5Nwc0I#veq*GkI={-V zb+rsx<2O?yHDQM+D#4!5caS2$^QoEY9rz#xN{0`h3>mk>pik@tIKicQ#f!iZ_G7eoSPU>APq zF(wKF&+i5ip$DR}mL>mWQE*gv{=!|`Sa+IjQC*engXm(e;jV7Co^G|;LW`L|iO0Lb zWJwrs@`{V<=KA(Vqv>vLudTIqnwy!g2_|M%Uu-oS>yM{qi?C8-{n_)@)8=C_+uYe| zwl`br?F;i_!#zg@iW3sm3&NP3gUHFnfkPHE)Q4LwP$vk9W5Dit;L~qp#0@s=bb?m` zffaeD&>sLiU0LRXWH||v#bG2*p5Vp(E+OIKOV)YWW1anFM))w{aU8N`7mf-}Rurd_ zXHMSSCmGLFM+P9(G~D^>6wr( z2!fhD6L+EW=`+E;f+s?qej<)@sdA!jD(|#5h38kP8?*`ytw}K>#jF(bAcQF&J|Ch| z*QxYQzn9{k6f#H?@gwxa%>SOqM*uUqfCBrFyQUAI?@PuXi)4Pz{x%FQv4<;tnLS6T zegw?veNe6EK1*A=ucHgH0tHbg{w!rnQl2DA6Ra+C{Ym;!+wxZxdDq3U@4D0mR8-)w zC--tmUdxPzxN-rWUmM3t4p#2_@c^=rN@DaoDda}!9Vxz+;!7#y!DjKHa^b1qW?{}E fZ2mIg`bhq#uS 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 diff --git a/venv/lib/python3.8/site-packages/setuptools/__pycache__/build_meta.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/__pycache__/build_meta.cpython-38.pyc deleted file mode 100644 index 9535ea6d8c1a180f949dc337dfbc3eb3f0b6f02f..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 8495 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 diff --git a/venv/lib/python3.8/site-packages/setuptools/__pycache__/config.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/__pycache__/config.cpython-38.pyc deleted file mode 100644 index 66578d0f229eca7622c6515fb5d7b962b88b14f1..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 17896 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 M&oNlWZGIO22m7PykN^Mx diff --git a/venv/lib/python3.8/site-packages/setuptools/__pycache__/depends.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/__pycache__/depends.cpython-38.pyc deleted file mode 100644 index 9aa026dc6fe40cc91ec7091487ee67c767aa0815..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 5216 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 WCQ1SPzOyTfcj`^&N6!28rT+qGkwqE+ diff --git a/venv/lib/python3.8/site-packages/setuptools/__pycache__/dist.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/__pycache__/dist.cpython-38.pyc deleted file mode 100644 index 98fa40231e56c9b632ef058693eacffba0011074..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 42326 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 x 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 YFZLY6Dk%2j*8~5X@V{J+CLc|*zscwFR{#J2 diff --git a/venv/lib/python3.8/site-packages/setuptools/__pycache__/extension.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/__pycache__/extension.cpython-38.pyc deleted file mode 100644 index eebaabe50c1f86f7cc92d69ca0c7c63c55a5192f..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1961 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 diff --git a/venv/lib/python3.8/site-packages/setuptools/__pycache__/launch.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/__pycache__/launch.cpython-38.pyc deleted file mode 100644 index ca908b37cef7a8273d35a2dccbe2d1394ffccd6b..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 824 zcmYjP%Wl*#6!jyorY#$UXjyr~Vvsr`7Qm)LNNiD6f!IuoA~*JQToNa>ot7D8Rs&1^ zpa1AR%!*0nuyu=05FnocnQiH%B0^UOwdyDMCMkb6*HJZ(!RoD1oL(U_mN8 z#hWjg5_g-t7mL^>Yq}ym>CqbBq_=2AdwP?J zM5MQ56}hcGg0nKHiCx~uJzf(aO@Z{*@;GN8@4JEEU%Cp2FYK6`^Q)8RpBM*jGo~Dy zbFnEulTtIKubR(5Q*+lDUR8_nCU=K{iqDFo=1LdE(TE0TrYcz!!P2}AR$3IIDZz-E zR_bMRYEJc%oN6D*FR~nM`<r~~GwopX@kB2k!MD+ zEtDtcwfzZ2e)L}&=u@Bi7xL6|X0@_xoV;X~Idh+L<~!dx`|IMOPoRA9`GfX9bwd8d z!F+LGunSfG4uX-0Fv_fyW>#cV?Axi6xshx7PFlR%7+ogw=Wd z+>U%0d#nND2Df2sG50wM{n45KWGGdUB_qy)ACuE0f2@kn0y!KE3ZcIC{a`z2GbXE< zpj(KbQ{*qXP)XhkSkX~jD(Uu>8X0??D^tSmqaYW zrZ->hsBEw^NCw-(9N)y*_Q?y*)9qu~J?_iy$&Tb|I8XqB+)0x|^iIrATZ1#*0IXu8 zV-+njrqa>9x4oq`+kWj;Xe!occ*ombC4i!&dY6;r-Qv;~4VV+iVzGb%pHqq@=;;Mi zmvJe_U|fLCm<^ zU>37qQ(!aj*s$3IIV*H^O zOvahs=ZR@f0_V>ZYp*&TIwl~r+f7m~Bd@wiQ!z&ZyHU;M8+)D<#Kw zVaDy(7y$zOR`%bra~JO`!@n**0WIQV5YgQ#6_p50v$51QeyVuR1R5qbap!X7zbW>R zMKEz_I=BH#^uaA&Y{6EEJ|_Un6dKxuZ?ts<&n@S!A%&rUAz+aD0XhosVYEliZG#Qq zWRQ3`rV|^`fUzMy1xz+ySz`<4oTHj}gzdx~o7Lk-h)ihhM@!eq1$m+lf2+1qqC{YQ zhQRfW;sKaqFx54|v*INW%cL4DPd82pEhGPmh&NGNiQ#uJPwp?_R@nqW3{XqJDW8ru z=i$13U_YdLVNGC?7I#ssqd=01k5C|0=d@nsF=Qa_nC3D6j#nn1a6#8&3?)d8OBl@N z*V;m9l9Tup4(Y~hrTks4Oexi>;!L2=N+u!aOi12lhxWcHbMdzr9_Hyz139u{dG^Y} E|El;zVgLXD diff --git a/venv/lib/python3.8/site-packages/setuptools/__pycache__/monkey.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/__pycache__/monkey.cpython-38.pyc deleted file mode 100644 index d600c0a7ab67462bc21b4119310493f4444358a8..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4644 zcmaJ_&5zs06(@%jMQODkwl|K`1Pzg|Mop}ZQzuOV!;Nb@sDpUp+K!VDO$n}slBlIf zd1kch6|_LnHPG}@1O<943j3Jf2YCXk74j3iu@xgZiN=NIm_(OHZ2Ps)4HK++Dce4trvP| zovb?WL*FjHsf9Jr+^jxW30J1HM%d_D;VQ3i@1Yg0@hbPxuJanNqut;uyn*%O={zgWLnkwH6)CAFPGpf3Z7{SzMS9GEpXZ-3gV zn=d~v#I6itQH*jP#CecPIZA>e4?aFnJv95hL?l6)%VE-1t!|2RK+bX5qX`|UD zff^ZJMXusBCv_7eBWRE+nPimsL`Ti06{C~IOVyU&i8*icS> z){NbL1>-<@IXM%1XdT)U*xeD?nzOyckj$0J9Te%J;^;Q*Z6gn)b5oTJ%%H3qSfc$) zSv=U`@#P<4^bZtk{31y}Lc@O&-nx_(?KqQ{(J5CptGb>_Xivp?I}s#t4m+KhLzIb7u&EmZ13N! zB1rj5x*>JUmHhz*r7}syNA@+8Lt8MYq#9~j1gRgz8Yd$5=L zj2qn2^v>dq z?Fyh)kkelmq7Y5joH<-0)rvgMO5D*d!H;$ZvU@@taRywrP~-+G%k!A`)T{V#WgmZL zwoMbW-;#y>4OC_IZN>UdWGgr^f`)yFOAs%C?txy7JVR%@*6^1c7S^x0FwtGB_>jB1 zR_-!f4rVF~Ga+#)XXq-0;2zm4xcU8BR97oU_y(f}?TfP7ajsckt-*e+extuOaiX>R zU!%X?-=G!I#=O5CZSX2~I<@PGzfP$b@#=FHR-Gok22K3!rt^dx=}85Zco`K4WNc5W zR1wO-dx`#pG}3fTU%XBPvWV%Vcm@6Oi!-=K41tRPKZj|n5Z$dT>BjAYt?~17E1*y? zKp<)DjM9upxW(of@f?`w>eX^akdZt2=de?kRK6{fqgo?b>zbIh%IFp|FMif9kHdgw;#dPB%^#a23Tc<3Q1`f-EKrzV$uZi@?#3+Nxig7*f`U5 zKv9Rsg3G3(*Oocx)uqqFO@f`-htbp;wws==Vj@;b7y}X)A%m_0{S3)i(dObU-ke@D zpwFcxx|%2Z(HYr>R(No;Pd* zaeo3iwYwJ!X`%~HIx&(@@gc}fSFbFbF{~d8plfr>DIY2}!3$QCyUah+u zj`$ekrC3Nw5nX{%IYllC``kXFV9vJ1HBg$iIV`fIS{wG2!mX1NTZ*$-_bU`h#&6kX z+@|jAM|=1v)XKl0QnZWxTe!p{hIa$ob;LRD+_8Rxw*z;1<)IIUF>eR%JvI(Q?+9K+ zpN(Hom5I&$Bl~v*>eR25{m-p@)3ubhTNjy)IotZu%Gnpzcmt~#uYYIN@BhcDmG7+j z^WrKxWwSB<#R+pG*pp;#1bF5_6~Iz}KvTEOiaZH!rfpHkqN9R)sT{$|uDxG+sZ>I9h~%y81aVy4aW7ZKGmnkbWkSKuZBxeu4`AVIfX6ILjG#C<0FGM;3P< z+s{(2W`AuVTVsc=BHytOEAS(z?}*8tB9Fs`Adhp2(jg%$>( zpnR?!n;S`NM$iLK+c1=qUO=pLg(P}E^h^_lRcbF>jIrzTv{vo}E;68J! R{+eI&Py0XctNtn9{V({X+hPC! diff --git a/venv/lib/python3.8/site-packages/setuptools/__pycache__/msvc.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/__pycache__/msvc.cpython-38.pyc deleted file mode 100644 index 26145e33a84060399adb70c9b3539ba486e5e05a..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 39631 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 diff --git a/venv/lib/python3.8/site-packages/setuptools/__pycache__/package_index.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/__pycache__/package_index.cpython-38.pyc deleted file mode 100644 index 0cb3c049904dcb39395a2683e49c2fe0f8976758..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 32970 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 diff --git a/venv/lib/python3.8/site-packages/setuptools/__pycache__/py27compat.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/__pycache__/py27compat.cpython-38.pyc deleted file mode 100644 index c44177c1a809886c8bceb733c96897262d1c1700..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1749 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 x+kbNS^y_b%pUIU;%xBY(*& z6F-23iF1Nb&$@SazIV^o-S>KJKs!0!kG?T}+G5jMSX`j12?7H~G6>|ZW{)3nEMJLZJ3PQflt3s9mX-S;m>UDqFgtj(a&oz7*MPpxLxe#t=qBJF~F z&+H_*D5cJlnd$$hqe>^4>D<(sI~E4cJCu(>iP3KDXOY P1B902kS^&H&u!u_$en6h diff --git a/venv/lib/python3.8/site-packages/setuptools/__pycache__/sandbox.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/__pycache__/sandbox.cpython-38.pyc deleted file mode 100644 index 3d9aa089403d6c5e135573292bc5937d3185a84f..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 15536 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 Fe*vQ<4v7E& diff --git a/venv/lib/python3.8/site-packages/setuptools/__pycache__/version.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/__pycache__/version.cpython-38.pyc deleted file mode 100644 index bebb447e154b4ee3140c078af579b38a4e7d184d..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 292 zcmYjMJ5Iwu5S?8c#W6B+$pt7<7*m-BAsSj5ga~d{!8-|#o!!lTFmMWv03}!2mWnG- zu||>Ljb`SJ^yYVyWhn%lR!581kUz)bKax;f1UFR(960HrhL;@Sjd1!-*0hdpK^(?_ zahK{70;BP$j_yFvdC*_OEdC0;aOG2j)+sAxZ~VlGPRK#b_I#$g71L;>(+wJ*uh25y z8mrrTXIm-!%sajPyp%zVtycix3`(kUB j+qGE^<=++MZrZVW_Q}~sa@XTI38T#Tc0wu1$pQHR`X^BW diff --git a/venv/lib/python3.8/site-packages/setuptools/__pycache__/wheel.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/__pycache__/wheel.cpython-38.pyc deleted file mode 100644 index 8767df96fb3c15782f6a2060329965362794e84e..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 7383 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 diff --git a/venv/lib/python3.8/site-packages/setuptools/__pycache__/windows_support.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/__pycache__/windows_support.cpython-38.pyc deleted file mode 100644 index 2ab9e442f11a6fa434985f752b759354eb5274d9..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 989 zcmZWo&u`N(6tR}4y99f zVY~59Y)AeT{sdn+?aYl6&nbfePx5=8pPoNIf3}a8mu&?0a_f2URYT~Tn%p-XCU0Qy z7vKmYI6~ecVh68zk?zgGcip7V)4RAzN8W~?j<#4u&CH2I7R8rQHihIumh(-<>>N>=Yv zl_0}a8sRFoFslOkOG0&Kb+SUjHUI(gU1E#`9&2NLY+PVKrLkG~@=%*&-zsngkWI7; z$js4PyVNf9xz6_mzFxXPpD@vt?B}0t2dqnlBSzF2g@n+=34~zbX)dUf!o(Sd5g_J} zkkNri*{p6CtM*tLJ0l^o*RIP22%UbQY#61}`XG(nvz&4frU`e~Uu|t{tZ#0*i)ANS zAVw!noO9uvQb*8_qF(TwuMEU2qr46Z72sA~f2UTJw(p0rx*p$`=AuZNO2;UY)`YTz zMw=VnDjZ`EdfmBepZ7iMj>|LK@A}=|kymQ=509GCf=5$q;u*V#hizGA&@SxmS^Y3+ zF_yBLAq~~4_wYYn`FQW3-ST&Oy`zKO<6g_(KWH{v9jP-a{=M%Ch)R8>;S!vNKLCd+ z7Pj#!wlzbuv4PnW$khy1fxuRjQ}3Y2-eW5sc=3d+?KmZQL>uaBa0{G;E!{FT{1d=R B_=Nxf diff --git a/venv/lib/python3.8/site-packages/setuptools/_deprecation_warning.py b/venv/lib/python3.8/site-packages/setuptools/_deprecation_warning.py deleted file mode 100644 index 086b64d..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/_deprecation_warning.py +++ /dev/null @@ -1,7 +0,0 @@ -class SetuptoolsDeprecationWarning(Warning): - """ - Base class for warning deprecations in ``setuptools`` - - This class is not derived from ``DeprecationWarning``, and as such is - visible by default. - """ diff --git a/venv/lib/python3.8/site-packages/setuptools/_imp.py b/venv/lib/python3.8/site-packages/setuptools/_imp.py deleted file mode 100644 index a3cce9b..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/_imp.py +++ /dev/null @@ -1,73 +0,0 @@ -""" -Re-implementation of find_module and get_frozen_object -from the deprecated imp module. -""" - -import os -import importlib.util -import importlib.machinery - -from .py34compat import module_from_spec - - -PY_SOURCE = 1 -PY_COMPILED = 2 -C_EXTENSION = 3 -C_BUILTIN = 6 -PY_FROZEN = 7 - - -def find_module(module, paths=None): - """Just like 'imp.find_module()', but with package support""" - spec = importlib.util.find_spec(module, paths) - if spec is None: - raise ImportError("Can't find %s" % module) - if not spec.has_location and hasattr(spec, 'submodule_search_locations'): - spec = importlib.util.spec_from_loader('__init__.py', spec.loader) - - kind = -1 - file = None - static = isinstance(spec.loader, type) - if spec.origin == 'frozen' or static and issubclass( - spec.loader, importlib.machinery.FrozenImporter): - kind = PY_FROZEN - path = None # imp compabilty - suffix = mode = '' # imp compability - elif spec.origin == 'built-in' or static and issubclass( - spec.loader, importlib.machinery.BuiltinImporter): - kind = C_BUILTIN - path = None # imp compabilty - suffix = mode = '' # imp compability - elif spec.has_location: - path = spec.origin - suffix = os.path.splitext(path)[1] - mode = 'r' if suffix in importlib.machinery.SOURCE_SUFFIXES else 'rb' - - if suffix in importlib.machinery.SOURCE_SUFFIXES: - kind = PY_SOURCE - elif suffix in importlib.machinery.BYTECODE_SUFFIXES: - kind = PY_COMPILED - elif suffix in importlib.machinery.EXTENSION_SUFFIXES: - kind = C_EXTENSION - - if kind in {PY_SOURCE, PY_COMPILED}: - file = open(path, mode) - else: - path = None - suffix = mode = '' - - return file, path, (suffix, mode, kind) - - -def get_frozen_object(module, paths=None): - spec = importlib.util.find_spec(module, paths) - if not spec: - raise ImportError("Can't find %s" % module) - return spec.loader.get_code(module) - - -def get_module(module, paths, info): - spec = importlib.util.find_spec(module, paths) - if not spec: - raise ImportError("Can't find %s" % module) - return module_from_spec(spec) diff --git a/venv/lib/python3.8/site-packages/setuptools/_vendor/__init__.py b/venv/lib/python3.8/site-packages/setuptools/_vendor/__init__.py deleted file mode 100644 index e69de29..0000000 diff --git a/venv/lib/python3.8/site-packages/setuptools/_vendor/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/_vendor/__pycache__/__init__.cpython-38.pyc deleted file mode 100644 index 350e481674a278b548c786cb8281247ead2525fd..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 154 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 diff --git a/venv/lib/python3.8/site-packages/setuptools/_vendor/__pycache__/six.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/_vendor/__pycache__/six.cpython-38.pyc deleted file mode 100644 index 9571fb9eef54e7ec5f6044e412afd87b0d03ac60..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 24427 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

n-8Rhe#-G)j8eLlPP{ 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 v)>> OrderedSet([1, 1, 2, 3, 2]) - OrderedSet([1, 2, 3]) - """ - - def __init__(self, iterable=None): - self.items = [] - self.map = {} - if iterable is not None: - self |= iterable - - def __len__(self): - """ - Returns the number of unique elements in the ordered set - - Example: - >>> len(OrderedSet([])) - 0 - >>> len(OrderedSet([1, 2])) - 2 - """ - return len(self.items) - - def __getitem__(self, index): - """ - Get the item at a given index. - - If `index` is a slice, you will get back that slice of items, as a - new OrderedSet. - - If `index` is a list or a similar iterable, you'll get a list of - items corresponding to those indices. This is similar to NumPy's - "fancy indexing". The result is not an OrderedSet because you may ask - for duplicate indices, and the number of elements returned should be - the number of elements asked for. - - Example: - >>> oset = OrderedSet([1, 2, 3]) - >>> oset[1] - 2 - """ - if isinstance(index, slice) and index == SLICE_ALL: - return self.copy() - elif is_iterable(index): - return [self.items[i] for i in index] - elif hasattr(index, "__index__") or isinstance(index, slice): - result = self.items[index] - if isinstance(result, list): - return self.__class__(result) - else: - return result - else: - raise TypeError("Don't know how to index an OrderedSet by %r" % index) - - def copy(self): - """ - Return a shallow copy of this object. - - Example: - >>> this = OrderedSet([1, 2, 3]) - >>> other = this.copy() - >>> this == other - True - >>> this is other - False - """ - return self.__class__(self) - - def __getstate__(self): - if len(self) == 0: - # The state can't be an empty list. - # We need to return a truthy value, or else __setstate__ won't be run. - # - # This could have been done more gracefully by always putting the state - # in a tuple, but this way is backwards- and forwards- compatible with - # previous versions of OrderedSet. - return (None,) - else: - return list(self) - - def __setstate__(self, state): - if state == (None,): - self.__init__([]) - else: - self.__init__(state) - - def __contains__(self, key): - """ - Test if the item is in this ordered set - - Example: - >>> 1 in OrderedSet([1, 3, 2]) - True - >>> 5 in OrderedSet([1, 3, 2]) - False - """ - return key in self.map - - def add(self, key): - """ - Add `key` as an item to this OrderedSet, then return its index. - - If `key` is already in the OrderedSet, return the index it already - had. - - Example: - >>> oset = OrderedSet() - >>> oset.append(3) - 0 - >>> print(oset) - OrderedSet([3]) - """ - if key not in self.map: - self.map[key] = len(self.items) - self.items.append(key) - return self.map[key] - - append = add - - def update(self, sequence): - """ - Update the set with the given iterable sequence, then return the index - of the last element inserted. - - Example: - >>> oset = OrderedSet([1, 2, 3]) - >>> oset.update([3, 1, 5, 1, 4]) - 4 - >>> print(oset) - OrderedSet([1, 2, 3, 5, 4]) - """ - item_index = None - try: - for item in sequence: - item_index = self.add(item) - except TypeError: - raise ValueError( - "Argument needs to be an iterable, got %s" % type(sequence) - ) - return item_index - - def index(self, key): - """ - Get the index of a given entry, raising an IndexError if it's not - present. - - `key` can be an iterable of entries that is not a string, in which case - this returns a list of indices. - - Example: - >>> oset = OrderedSet([1, 2, 3]) - >>> oset.index(2) - 1 - """ - if is_iterable(key): - return [self.index(subkey) for subkey in key] - return self.map[key] - - # Provide some compatibility with pd.Index - get_loc = index - get_indexer = index - - def pop(self): - """ - Remove and return the last element from the set. - - Raises KeyError if the set is empty. - - Example: - >>> oset = OrderedSet([1, 2, 3]) - >>> oset.pop() - 3 - """ - if not self.items: - raise KeyError("Set is empty") - - elem = self.items[-1] - del self.items[-1] - del self.map[elem] - return elem - - def discard(self, key): - """ - Remove an element. Do not raise an exception if absent. - - The MutableSet mixin uses this to implement the .remove() method, which - *does* raise an error when asked to remove a non-existent item. - - Example: - >>> oset = OrderedSet([1, 2, 3]) - >>> oset.discard(2) - >>> print(oset) - OrderedSet([1, 3]) - >>> oset.discard(2) - >>> print(oset) - OrderedSet([1, 3]) - """ - if key in self: - i = self.map[key] - del self.items[i] - del self.map[key] - for k, v in self.map.items(): - if v >= i: - self.map[k] = v - 1 - - def clear(self): - """ - Remove all items from this OrderedSet. - """ - del self.items[:] - self.map.clear() - - def __iter__(self): - """ - Example: - >>> list(iter(OrderedSet([1, 2, 3]))) - [1, 2, 3] - """ - return iter(self.items) - - def __reversed__(self): - """ - Example: - >>> list(reversed(OrderedSet([1, 2, 3]))) - [3, 2, 1] - """ - return reversed(self.items) - - def __repr__(self): - if not self: - return "%s()" % (self.__class__.__name__,) - return "%s(%r)" % (self.__class__.__name__, list(self)) - - def __eq__(self, other): - """ - Returns true if the containers have the same items. If `other` is a - Sequence, then order is checked, otherwise it is ignored. - - Example: - >>> oset = OrderedSet([1, 3, 2]) - >>> oset == [1, 3, 2] - True - >>> oset == [1, 2, 3] - False - >>> oset == [2, 3] - False - >>> oset == OrderedSet([3, 2, 1]) - False - """ - # In Python 2 deque is not a Sequence, so treat it as one for - # consistent behavior with Python 3. - if isinstance(other, (Sequence, deque)): - # Check that this OrderedSet contains the same elements, in the - # same order, as the other object. - return list(self) == list(other) - try: - other_as_set = set(other) - except TypeError: - # If `other` can't be converted into a set, it's not equal. - return False - else: - return set(self) == other_as_set - - def union(self, *sets): - """ - Combines all unique items. - Each items order is defined by its first appearance. - - Example: - >>> oset = OrderedSet.union(OrderedSet([3, 1, 4, 1, 5]), [1, 3], [2, 0]) - >>> print(oset) - OrderedSet([3, 1, 4, 5, 2, 0]) - >>> oset.union([8, 9]) - OrderedSet([3, 1, 4, 5, 2, 0, 8, 9]) - >>> oset | {10} - OrderedSet([3, 1, 4, 5, 2, 0, 10]) - """ - cls = self.__class__ if isinstance(self, OrderedSet) else OrderedSet - containers = map(list, it.chain([self], sets)) - items = it.chain.from_iterable(containers) - return cls(items) - - def __and__(self, other): - # the parent implementation of this is backwards - return self.intersection(other) - - def intersection(self, *sets): - """ - Returns elements in common between all sets. Order is defined only - by the first set. - - Example: - >>> oset = OrderedSet.intersection(OrderedSet([0, 1, 2, 3]), [1, 2, 3]) - >>> print(oset) - OrderedSet([1, 2, 3]) - >>> oset.intersection([2, 4, 5], [1, 2, 3, 4]) - OrderedSet([2]) - >>> oset.intersection() - OrderedSet([1, 2, 3]) - """ - cls = self.__class__ if isinstance(self, OrderedSet) else OrderedSet - if sets: - common = set.intersection(*map(set, sets)) - items = (item for item in self if item in common) - else: - items = self - return cls(items) - - def difference(self, *sets): - """ - Returns all elements that are in this set but not the others. - - Example: - >>> OrderedSet([1, 2, 3]).difference(OrderedSet([2])) - OrderedSet([1, 3]) - >>> OrderedSet([1, 2, 3]).difference(OrderedSet([2]), OrderedSet([3])) - OrderedSet([1]) - >>> OrderedSet([1, 2, 3]) - OrderedSet([2]) - OrderedSet([1, 3]) - >>> OrderedSet([1, 2, 3]).difference() - OrderedSet([1, 2, 3]) - """ - cls = self.__class__ - if sets: - other = set.union(*map(set, sets)) - items = (item for item in self if item not in other) - else: - items = self - return cls(items) - - def issubset(self, other): - """ - Report whether another set contains this set. - - Example: - >>> OrderedSet([1, 2, 3]).issubset({1, 2}) - False - >>> OrderedSet([1, 2, 3]).issubset({1, 2, 3, 4}) - True - >>> OrderedSet([1, 2, 3]).issubset({1, 4, 3, 5}) - False - """ - if len(self) > len(other): # Fast check for obvious cases - return False - return all(item in other for item in self) - - def issuperset(self, other): - """ - Report whether this set contains another set. - - Example: - >>> OrderedSet([1, 2]).issuperset([1, 2, 3]) - False - >>> OrderedSet([1, 2, 3, 4]).issuperset({1, 2, 3}) - True - >>> OrderedSet([1, 4, 3, 5]).issuperset({1, 2, 3}) - False - """ - if len(self) < len(other): # Fast check for obvious cases - return False - return all(item in self for item in other) - - def symmetric_difference(self, other): - """ - Return the symmetric difference of two OrderedSets as a new set. - That is, the new set will contain all elements that are in exactly - one of the sets. - - Their order will be preserved, with elements from `self` preceding - elements from `other`. - - Example: - >>> this = OrderedSet([1, 4, 3, 5, 7]) - >>> other = OrderedSet([9, 7, 1, 3, 2]) - >>> this.symmetric_difference(other) - OrderedSet([4, 5, 9, 2]) - """ - cls = self.__class__ if isinstance(self, OrderedSet) else OrderedSet - diff1 = cls(self).difference(other) - diff2 = cls(other).difference(self) - return diff1.union(diff2) - - def _update_items(self, items): - """ - Replace the 'items' list of this OrderedSet with a new one, updating - self.map accordingly. - """ - self.items = items - self.map = {item: idx for (idx, item) in enumerate(items)} - - def difference_update(self, *sets): - """ - Update this OrderedSet to remove items from one or more other sets. - - Example: - >>> this = OrderedSet([1, 2, 3]) - >>> this.difference_update(OrderedSet([2, 4])) - >>> print(this) - OrderedSet([1, 3]) - - >>> this = OrderedSet([1, 2, 3, 4, 5]) - >>> this.difference_update(OrderedSet([2, 4]), OrderedSet([1, 4, 6])) - >>> print(this) - OrderedSet([3, 5]) - """ - items_to_remove = set() - for other in sets: - items_to_remove |= set(other) - self._update_items([item for item in self.items if item not in items_to_remove]) - - def intersection_update(self, other): - """ - Update this OrderedSet to keep only items in another set, preserving - their order in this set. - - Example: - >>> this = OrderedSet([1, 4, 3, 5, 7]) - >>> other = OrderedSet([9, 7, 1, 3, 2]) - >>> this.intersection_update(other) - >>> print(this) - OrderedSet([1, 3, 7]) - """ - other = set(other) - self._update_items([item for item in self.items if item in other]) - - def symmetric_difference_update(self, other): - """ - Update this OrderedSet to remove items from another set, then - add items from the other set that were not present in this set. - - Example: - >>> this = OrderedSet([1, 4, 3, 5, 7]) - >>> other = OrderedSet([9, 7, 1, 3, 2]) - >>> this.symmetric_difference_update(other) - >>> print(this) - OrderedSet([4, 5, 9, 2]) - """ - items_to_add = [item for item in other if item not in self] - items_to_remove = set(other) - self._update_items( - [item for item in self.items if item not in items_to_remove] + items_to_add - ) diff --git a/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__about__.py b/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__about__.py deleted file mode 100644 index dc95138..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__about__.py +++ /dev/null @@ -1,27 +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 - -__all__ = [ - "__title__", - "__summary__", - "__uri__", - "__version__", - "__author__", - "__email__", - "__license__", - "__copyright__", -] - -__title__ = "packaging" -__summary__ = "Core utilities for Python packages" -__uri__ = "https://github.com/pypa/packaging" - -__version__ = "19.2" - -__author__ = "Donald Stufft and individual contributors" -__email__ = "donald@stufft.io" - -__license__ = "BSD or Apache License, Version 2.0" -__copyright__ = "Copyright 2014-2019 %s" % __author__ diff --git a/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__init__.py b/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__init__.py deleted file mode 100644 index a0cf67d..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__init__.py +++ /dev/null @@ -1,26 +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 - -from .__about__ import ( - __author__, - __copyright__, - __email__, - __license__, - __summary__, - __title__, - __uri__, - __version__, -) - -__all__ = [ - "__title__", - "__summary__", - "__uri__", - "__version__", - "__author__", - "__email__", - "__license__", - "__copyright__", -] diff --git a/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/__about__.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/__about__.cpython-38.pyc deleted file mode 100644 index 2b22a7199e9f430b7dd7ff37adc86dcb010a406f..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 704 zcmY+C%We}f6o%)PW^!x8MO~XnT|^?8HbS5xgbM8nAyg@Xg*Vn@jwj*Hc=;ICy@Bs{Q7e+XRL)?QS+=nq9z$4l_4)72jFN5im zpDt@Kjdw@+N{iYWN?0R>GP@MmhG{1F?ocYm4Jj=zjMqIv3^O$)WH%s0+os9Y)`>15 zRSAyp?prx^8 zX;97qG49I*o7boi+$grPMkw8m;of?o@2ztt+R6Ln6>_J)b6G2jKJG979DUhWiWc+J z_W1H|6=-pK_G0F6j!yKa>BzUCw8kn|u5!;DsMsTM@O{f`*Avz8O9viZ5C8J2=i&bl zHSicZd<)dr&pm#B$V?+M$>hv(UoVB(T}5d~Nj&_(3JGyDV9p3Qgw diff --git a/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/__init__.cpython-38.pyc deleted file mode 100644 index 179fd13932d7c8e87c4421276a6990d671265c73..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 542 zcmY+AJ#HH@5QVwBlJ?(50AC@1RVWLjNSYu>o5oF&hRt9tQW70&iDU zQhCM#0*4EJ*hjpXd6-{)-!MF%KfND6=8Qd(czY@o-|&W?2*E_AnaOx&a-N%l7a0?| zDD=WC`O>WT%9Ok`6|YRqYt!(?w7fMP@6fjpOR*BAs6;Iq(e5kWi|z+o_fOcFt&90` zybV^TC_x!#eVi+yjw&cS%@@wADZ(yI+lcxpql#*70LBy#)&tBvz}C8xSNlUmSp!Hj zDviG_fL2>M1$h=B88iCR*%VdO^j-oaug->}^fVQ~w>Zbsf_z8l2`d7v#n*%qakIXl zEV~qw$7UWE$$UXrASlatYZJyg7gNcb4zK-RC;b~jaYl{d|1kfK+=Rd1hiKg3l-s1q zjoaT+Y#t6$>dk%F-QR`X!w_UlE?TR@07p3q>jyH9do}F`05vHL@xh(u>Wi@=Y5A1` PhAYHXe%6^O?n96-vUSqUV#R233PaH^0HNbJRO*G{|bzG{0Lr7EXZ zYJUbC`)W5)qnN3yF6C=%dW^8}+jmKZt*ZTzI?VA@$aYBA$uqq6KccAVY7)>BY4(Lo zde?wWCOnMPuB-CK8<`b#WqpWrcAUAaD#Nh0S?T4hDN_&e&NULd2F4_%c>6{$(FN^+ zx|d)+k_&P{XG~Mg&Lhn(=^6jQJo!mandVw#1@Jq9rBU1yFoq;llZ34nPq^k#N}N1LMEMVIE3Zs(1*)%D=q!DK@D^X@&!^ZI zbzEolW>eNGJv4fAzHdyvdE{nC2W~cxo$*cWt15S~JT|4SY>WrhURLhKGOdbQ`Dwif zJt<2wm+~2s!?wpTfr#1-+!}dw2dVk^50+)AJU-^G-6%;7n~LJA^-pY diff --git a/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/_structures.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/_structures.cpython-38.pyc deleted file mode 100644 index 376e52fd22eb3e3c2e18a4f5c3cb34ae77c47fb8..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2760 zcmcImOK%e~5Vm)d%_dFT^nprwUl3F%jgSzP5THsR5E9A-xa49jYbV{3>~3stt5&_G z2mVU_(q1|77dSEFuqADGlY+pJ$B(i7jc3N+=F{S0jX>FXdf)q6Cgd9qrb`J1yHM3@ z5S(z@Cj;7{1FK^V?2b*zTf!}FpAv41(#YL*&TU=T-Ar!Ef;0u@AIx)jSG)U2C?zJ{@nJEn^TgI%cVBM3n{l#`Cd zDYs5Z$L2OKK@0fYfws&m+=bTRRbGR(!WVcQT9+^KC1|UBnKz)V@fE%b?E+r|E7w!^ zUDyr6Kp*)OK(c~;tgoOdbPlJm+G;# z-aOnBqTd{jq4_iv;B-T;XS1ooRLLSK$F7$dq*lRJRW#a2Z3bh>{r7mMq#F8-= z4M0B-dc2aEx}9k+*=)l?V{;uknrM1LMsx(Wk7;{srKLSj?WH9=T2^4iZ~J8xh6sx* z7+Zi*9_&Qx8-rj87VKYg)!1skF^7*WiC0L=k=_&XBA&xoUo*A@D>Ag@sY{}6K9+32 z_Q}aBXFU@bb0@?QjG-zQ19X=#F1Yao+_+Ci)(0ZdG2qA=Bygy-7y2Tt!U26xDF{jd zz8EsLUVx9fVtn+BCK-O6{IWn^gZUz~5N@(H1>V2L~cct=!zNFcyj)WB1^wEKwTS4tQ}!*&f&N zk%Zm=EJ$mN4I-XkdZl&7hKbjoXe6?&Tt=~m0)sEFqu4}o6U8kQcTk*>$fSo^Yj_4< zs9FW#QrABJGkPCX=L$Z>U8w(&FC~U#w(EaU<#Dx{d2e#B9KtbvdWaSqMxn=>7enYQJ5YZDcPZta diff --git a/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/markers.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/markers.cpython-38.pyc deleted file mode 100644 index 22cd495e959e5175f09947c799b428ea1f821cd0..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 8927 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 Yk*$U8?fidj7o2^z=?plB9LJgXKYr28Q~&?~ diff --git a/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/requirements.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/requirements.cpython-38.pyc deleted file mode 100644 index 7b3ec72eb0f8fb13949c95e634621a4bffe502e0..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3995 zcmZ`5+fp0JwR>hX8eI?qV=%_MJH9Tmxq0LJZIQ9;B@2QGSli=rrpD?9k31vEJtJSV zIF$-cs*F#swwZ6VIf$!>- zv)&&D3Hc{ZdcOorW?@8|8X=4@8jz4WG}Ig|)E%87O$!XiQ2z-h0snenhDj$GT80(n`(%ddA6wStlFzIelTy$%Xw+zv3l;mv;sfZU%$l5oZYSB(s8};jl9tjyNM~ zo(hhIqt0k}+&LbOIb)POAS}%??+MHB6I;6T1kdZ@C$4R+Cpay9WBt z@N1y|ER1WQjXKx)_3ayMjGcH-b|@u0#jnFTzW~lneiJxf_Hc%`U5aEx&V@fb1+!@>w{E1$dDcx9_r(cn0w4 zDRvrsdYaFHPwz2pg%r+wz_={vvfq0aHG)>mT|aC#L@X`lzw#r$QJ1-<@awU=-l|t) zn3oHN%tSHJHdbN}BvYM9sm^47L--qh-3wOvoA`c1$lS6gB3^n^%2f^a>0+e@B%;+O;q)P;(0ZhSu9q*FIC*q zqveV;7d`QU3%tex-|(t$SDL))ulroc)B&2^M^|`U#e4UDsCO1dln20xLm6>2Mjc(* zNtc83^;cftvkHIN@&ylhJ#POpZNpcr+kS^{i4@WJk{%t$=~d zIu~}_u$N2A_T`ytQ%VV1)pFgs7joB?Y1a)KtQ8=hb={XOFX(cTuFD!#*ZqlzF*v9K zyNlCt*qm2?8AL8hTIT#U^&`qsI zniiuFsajc*0u=?I{-jG9Ng7BR9~eQL0FJb71zz}!d3UbD>|Zd5m_~XE_fipYXhXcD z+Ry@I6I?z@)OG>`p`-u8KBjDrJ1Mm{5SalW%}_<)A>{@zmGU7#VzP-hqA;}IYon0$ zun{d6bb;2E{qA1&xRFY%z5@cdO#Hu7+=0dF6m9*@lc!afee&V`W?@9*06q@(;Ml3Q+aHAy%9c@R*}2M+3+E-dii#zE%p3Ic7p>TdOQg*j}C4oe-L`E1n78Od~K|5}ri*-h~ zjZM0#*Ah6GHbT&afSWto7X2N4NG=lw(!bFkk;kO2JwjI}H;J2se@py5PHm?UgB^@b zqn2j+3r+k5sF_V;2SdVop^Kkk9|N`3$5BT76<}7ubo4Xg5lSTBBuW!XA_luyb(2AO zxmMfH*8PCD2f7}y!DF`aeLLSn0{NMDg(DC}rC+VhS4xYe@~X^0 z1Vp@34Fu{^rA3i(&KLN5yYGi}H1Eq2*55q)uluDDY=yRt&&S9xl~7vnHcsvSgDd_DDvRdr{W|Wteu!e7w=NLow$jZ zI1ki9y5qa9FPcp(Tv#ThfsFv12yY9{lxL(44p3h1_(&6YYt`rD=yMN1-vepaeFY-X zF#v>GVAc~b@-PO$^l0Wmt$pNEBdb-P*ck1-Uzc+*0gI9tEQ}U|durwO(5)UN<0=CR zcM6)iiCBas(24M{pPv#sxZq7V<{yEn+9x^W^^QQfkQ5`R0q-J45gbSG9fBnU%Lw*+ zdY zBWV>EmcJ{O*A}G}wVF-ABcLtZtrX|JFReIw?GEsW8S}96>tul{b zL1q+T#a)HTk$sbCUyGtwJwD||+rAle82zU;NE3l&r&%;ZXW)9{H zr3b~i$1=0WUn-Ymc5kv+EI*cg?%s4|xilwp;E`o4lSTDzKM+>jeD?vpQUV(kSC{Y= zt)A3!a8FCIe9!IDa&RHHXFh;ezUTH7cX18fbsc~-8_#OI8mo}}Ul9ziw9f1H4#s8l z9KeufK|UX&C!kDbwLBft^JZQH{NM)?dB}ALc%WM-qYc5Zun-fCXdewt`;Vay(H!t| VT8eQ>#?D2kFOS(ZnVV{7%GWXDY$N1|leR^r5=9ZT_pmb_i=49TVT zLERZjBE3q|NU3Ecag($~Q#3&(6lf!$XbUuGQ#1(jAN1!=e=HExKNKhsph%TA?)RN} z?CkEWO&3lI6eTs6cV_O~d(OG%p8MT%&(#;k#)=w#KK`+fRKL>Dw14JJ@+XIz)41H9 zBC$1FZ)i<@UT+%nMl&;?(fQ11nDeIm&CX}#Z*D#(fAjNsJ7b%TLUUw(q*a`_6Y7roT6i{Y;`7Y7)vvu>3G#zqw2b-GXIjJq=K>MoTX}Q zJ-W@VR+a12*l_ZPwVuZ1P9Sl#dEM6L4O^ej2%#B&;@Q@fYNKwSTXkyn#k!+5K3%l% z^JL4a2X8DldSzX$y4GTQtz{pv)?AQbxy$XfhHWWl(NUJywqAJV1?#cLj?YLHb7j*n zR4T1%)2USaVx`h-+iMNxOO?vywQ3`Lldn|lcCAvmt0@vG$-U1W^O~#2R_m)r*IKL9 z+9k(6dUe@x8b>d?iv9V zkJv@ID>}uMQF}DLW1U;=F?;-`j#^9d<)ppEo{;-7y95>5=8v7Jx=!3JHFjk5!#uC2 zaJi)0*71q4@wUjF-S;Adqgt-zEjtzz3O%%{9M@@iRVtg+Uc{TaYsJ-Djrt|WYA>uf zHE+f`k9ToZVIMCzJ(XNRX;$JS>Zp6J(^w2TpG3?_SKifqlh3=ItG0qT~lo|+E*RhT38pwjH`-G zSAVyqD&;7eh+23g!PKtaE=!c!RKM9VIp-YD?N`7Lm94vxHp)Ql>o0X5czV3c*IX@w zo9Ku6w1M?vO#Rc2=cs1A1@YGdbG1~*WMS1kr)j|e*4i+Mcx_vpXzQ)OMhxwOyP06* znEYO7>!a5%gf+USKwC6^`iw+WWK+ESe$31H>LqHC5U;8WP$O7i62gbJwODU}S26ib z%WZ>`s%N!ZjrFk1)#Z9^Ij)Sx;eD9z(Nc(}?)7VAITS|$R0u_>BFP1mJ(CbfpFs%< zl=V6O8&@TiRAWrWk@%VFLd_oslJZow<^c;Ww{5kZuQ_$7T}*bf;6zkrRkc?g<*f@j zehx?h^eKx4_cMuMMv&ulq$ZKDQrALK&`rIV!<7yHG9O+gJd@Hj6zut-I-bVm-bNB3 zh`I)>Wf8>Q)B$n@F975UQUJ&mi~x{3YL@^f3xW!?`4K?_+I$f>VG_?rol*ciffvS* z7x0PvIPwBNk>BEMS(&hR5sdQA-fiE9FSpwJ>^=7VXnWG$Z|}7qKyI60zXSeM<=GbT zsEs)yMgqRpJH`kvcs+&7J&UBHt!TIPj($hKp6O)Vy&mA??F{d4=wH!0ncJpq+|h4m z?`V?G1o=gyqg8Sprg>WfS~2G~rbF!6MVL=m55IBz`on&K{a5wc%Fka3;BL9#=PJrs za;~vItE#pvD9+DeVsBPGKf9#bYpZ^i=ox=19Kyhv3A1nKd}=XK{(-j)#)7wM!#v2PCFLj*wH! zu#M}wosoM0LoeGw_d%K&k3$OyS*e!}u>FHl zlF7U<&cST!D^wf(ZFamdw~+(oZ#;6nYy`woHffWa400PU13Rj3>=`0_!I8sBU>ABq zzzyK!yRb2aZxW}ep)J$0EG1eV*6l;kUICv9_b&uZ>z;nYP>*elceLAv3?2Pt?ef#6 z=4CDw)o~rOn67zdPJ0y+dPQqZfLu|K8;1L|XPzVR*^a)Fy@chZ`Xnm7oAZlUNVZ(B z+NwE_!I6g^~-{HrlKG<87>hkK&SFMthN>?@t$eviJaui;Xme zLH+S`&sa2|K|4H{=NtNUn3YhHu!XZIrAC;r;}pk8XdBcaKIpRzTfncQY7Um#;(oY+ zGA?DML0t;^#)Ih;_kQ%=LzEMX4Iztw6^+PUefS71I66?omE zLG>v-Q+t^7cDc0sd);;iYR%xCj1;L=yN#OfL<)wUv+z37s0WbmtDa7v2nbgy-$8*$ z`S+#rmn=O1oMTd+Ks_A;lWal3)~;yR0XRai0_|Th)I%M^eTeQ7JkOwnc?Zw&H_L&2 z*O)ttX_S+vB3$*y>TUu;C~~W)c)<|a%Uqw(EIj)oTrTH5%_!(OvzRUFra5E+jYQDH z5=SJ5a}AfcqikTUCG9$pl`sbc(J_D=GIjkrriG`qi)XIqz>wC-0hQ&!j^4>H>YeP{ z=!Q-nY`+4wU%~SXQuDUSa=LaIuoM_B_Yx+b%NDR)r(-HysIQ3ng6FFtT01LZIbY6- zWCAe#9O#qBey+N@3Ljj#AjVGZi(ll|>rTUVY=5gb4inOJedE$q5hQ$}^j+GKZRwZk ze$@6C6a_OHkeF#qnFYOQjGH;#c-PR)ca2QRH1$HZKwFePZH0>rL(r3~Gynvq`W74N zNwlCIV?tF*TV@1WAnH+w7aCoq5aoG@-+qRP#e{Sxm=cwdMaRQ<@i|=XK_mskG>XN- zNFjsYQT%2KSwk;oq6H1PhU3xDXi)7b2x_Au<;FzsE!W_m*J!F^`1@%=T`7 zOW>4_R}X%nm4oG=vf$y+>YQseXVnw`BUa#^SO49fx@W$Q&bntJdC<>_8_pkrM-DDT zEGqpi4F}5)cp_TigUKc3RIwOOJ{yS(`K9FRa_*jS^5i{ZAFdO)W>4PJPu$aIhfhRZ zK`(JQ{2&V`*yzxMvYR~i`q8pZN?x}UV-fsEf~w)27#H6(F<83>Yqz1q zY)_Tde}7R9)N z^F!2oGbbADTD9TM&V*mW$uc6l+uWk{vwX_M@MSisn26w3nUfZ$ht&*p8X4k(KAu%v z=+iXy{EXo4G%ojtNd9N=htTJ{g?WSw1mFi=)KTQQFH4VV33>6xB0q+_1OgyGj(p^g z-GY4NkDWk%m%UrQ-D=-w?}0aV(%EL;Z|{|7Q_j@NcKdgD?DU~0+@DM!sG+Fo;Hf9#I=h(XJaAFnhOemZty>X70|?+2m7o)#3dgNgR~_uB z!ett4E?liQ8Yz|8ZEjLH*Wj#=z*K;i!VTjHSgg0#uyS_BS=Bdd|vsZ7!aNXMpR z?-P(LSS)bgEDSdgXa`IN?1NdxvZFnp6xx8{2)wG`v}QH2(Mlk-sM^>J3irKZ_PIS| z*WFrsO;wki?uJ;GvIT%bAg0C|);AV~hmE*(+2-q&Ru?!$-yS@50{wNeYyrDI&n=oj zK*1(;N>>bUl0?W+rLO^s0S)8lfc0{ST>D|_5%fz69v!GZs*`mEs1Wkyo{?-Q0mXVE zIN(;oWps3;J-xhkfg&sH^fWVE6A!l9t+D`@Vd@BVu+iPhmaZ4W(^EHFI}jmQY>BlA zLEFo~fRLx7cqaDg60uR>R^FbYI8KGN@$db~DV#f%t% zrpv|{wYw>M+^Do8qo#@NRXR zrMQ=l^_EwcUHNeD5(*?p31i!{IGzx>gQy+5zJx$2OdJ&c09WzY!!)(T-J5i~^2J`G z0?r5Q3TjWIYEbQdO_t@b5E-fiMi8bbvA|X9uuT6>)n*4(twX&%5b9ghxrx93*X&M$ zHOc;(>`;HR@i;v79)lbDMq89Nx_i5CGXv;JfIEpri@}#00F3~ER^b&}z<5A7%OXON zFq+aw&M@3yw`ZbQIjm4Pb1ysV7GNspTWKO?81|UhK?u=;6-EtGQ$Quh8>Xzq`n8nW z1cwna#RlC?9oYK7E5`Uzs7V3x?Q|slzJ>!cf)djw~$mDe<6(+yQ zq>AKT2FtM?rxraibdNlR%bi1lH~@`X>bDU(Z)a{ITmudj{SGc$v(2v>j1FK#l%4&! zhQAtiU9ih0ZWp8doZRQ-J|i&%g*jiJ>GA)-%^|)YI)>b7B=i{D*i$WO?H!Vb_qYV_ z9=t!kNvP>(V1vuLUqlp$@?3^6!jYq2OL(WmwNg0Is5Teu>g-Ll@iWw{Z5)gJ4D@3M zzT&QIyUv{G%Xi+z&pl)2P#`!8vz+tIm3F=5n~geX8DS8h#N+!T9kNrgM zY6Ja2afXpt%0^y1-F_}Goc(lfOCjwFy+Pc0)kaM?*GxU9=YDCtYi5mKnD3g!f-$Wd zn(^+&{qMceSQb3*KQb+E~fE%iTJu9NZ2-hpL-s_nlut$cS_+U@KL6Q(`k9 zowbEVy{6tm5yd?VKhtnpjBcyOd!~L?Cag4{y?8ReMX@muMavY8VrC*+%1)RQ*kR0J zA9Z6oMOd;B9WE!?)Zmr|c(`LwEyd4U)&s|BjkJn~PZFx3I8%Q>I_T*{wEv!zR)=pB zu$QEVxU&xLCVJ_Heks}{K)^xl%+AT}M-DgNeML=~G`va{esJKEk`>OuoT{!9|LS8U~vu;&1x8 zjgc3>pd2QV(a=>n1l|-flX?kxL^E#h$_3L+s0!}DZZeJ2Q@A7m7DH_F!BX4sX=vN# z$~*ctqtqqTsTxe0Oj=CZOuG9{+}TiHWAfgcPk+E7?5`kHNuo`+7su{J=8 zU<(XJZ-63i!Vbi5@J&ZBrEL;m*jj)ngKse1nLw8PZwz2epv)xz4%_UOATkZgPHQ)e zDYP!N^p*`vbieABCG9Kuj`23=2=f`{7YSAJb3OeG?UGn;0j;#P1gdu;GypW3ue;*$ zQeVQ$eu@7Uo*jb3)mM<&*qa12gAnusw5z_y#)h?cIBHRXOcmAC*N-E1joPAqo5`C@ zZZY{CBz_M2QvkPqrdhq_XKTwiGK9meX2V&;$pckiTK4=RZ*c4YAlDz2N5M@$%ilzO z4^hcDOc8ON*{$!E>xh2DP<&hCi{wuRH>YvAw2|@N=HBp32^JhYgNm~y!I_e5c%~#5 zhH~Y@P_9B4$~6*(a)mpXa<(MezZ`SMR>rY|iKETj<+P{mU8s2rb}4z9L`RsH6`m&9 zDrZRc`K8#X;-FX%TGuoAQMlZjm0?1g7o4WW=tejiErDQb{RWpzvFmSO)Z6J7o`l7CTaI*x3 zy*S0tXsWFOr03sn8J8Kjz%BxyJ%&Gb4d0kK?(1$}fBMA}T>WtAG<$;GnnU3nhD1Tz zC?{nTpAktacJ$>v{YZI4eFvZ7kcI<2tJ=2MTnXowPyuYFtM-NiJ@jxA#>HNiD^n$A zOu`hb0mJPr<%S`d!9J-!62IspUBVncL7HX4%uFGgvVcip5_WG#rf4Q6O!RF`f2usC zdue531d)2i1)Yixr`3ZcG3V58;EUii%k+t)unx*O7akFrh4mIhaFj(QxRUTlJ58!z!D>HP>4PVOib{11=>Bt*7?1;psmp5z z5@^*p7J`EGB)%3Xsk=lH7QT;SeJuDRCzhO+b8S`4zCuPg$(T^4jfa!ciOxkQG%5ND zAnB|424|!YM2LeQf5kSo4K^f!tuM0)T#O)_N^78p#mLf2S5v}Z4uQrzQWLEF3`LkR zyh(~>KG9@be z;a`%;C&g&1AK=69k&oD1AMVk$#A-9$WXl9crN+eHT2HmtZ2WDuA#l*q@rVa}Z$P!3{(kFqsl#Rw^`pjEc<4I@+%)C;%Gk5FVT;F(%-*9cacqBg?6 zfD|grkI8zhEC+j-j}8Q-X-YUV5KjjVJPJL~OG*RU(`W=^jt=rb=s#voTDFk;Q?@L| z(ZI1iIP!7@Oar+-s29=DgX9bNJcdYARym54IA;ad%0F!u1^Hg`Ai5a?*vbd-+Zdb40#{r`Pj%m-lcoOSLYa!7-+Sx`ks* zw>qZ#?N0XgNO*|p3=T9U^6vLLS@r#pHsmqC0Lsf+03HPPQMnk1j6A6QNPLt3>q;=^ z^vRZD4V(!5C!2zei$ZX!2uSOBmK4{*=b7tMcsBDB%Ki{CaG}CC1;@KM6M3AefZiw? zW(MbP>8sL9M#-F@&#HIQN&K z3}cHTTP)-tSriVsEl@1bw3XV$w%#s^qL;UJn};om0!4wo6$eFM`edMQeM^ybzyBYS zB54QRT`Z+J=ghgx{O7;_|Cu*NM>86J&!2m$^xN>TJicvJ1<7k-`t7;c*U3*IlPg$DptY_p+U86sqmnx=&CG0zzpW1PEwaePJUbNp$ zy`zQ3+sTY{G0ihG#SGUY#SyNv#VpsO#ZlpilyF5_WW>m)c5%!fS=%SF>w0ngWlfBV zu{)X=^Cz~=;-uIo#_wpw{bE8)qMj1_#T4oT;((Y&JuMy+GpHXE2gT#4XT%|K81+H% zgm@D5$!I$HnvF1=LTA7sX4cpAlad^QiN} zxS{12?h_^Qy4qJ-ifWZc?0Z4AUXyVFeUpoC-&`!*xcYj*yYa@AD_7rMyio>;dOrg# z3)dxF(G-dmt);!6ZR;&vXa}|L8XFc~p-WnGPsLbsBs0j);9CDa_XD$YAsZ$a;IU{H|bG#}zH1@UtVp8l!ofT6+<^g5iEUl=l7lg4d>(WQ5EU&Z_sI*tF zl;Y)@td?p2-5<4yP)wvFXteYlZ5M>{^p??S87;HZGKF?SyQdfOma;3gTfUS;S9ySn zX%y(UBEPb%M*0CT>HTi^^?US{DJ)U02WW%X^Pa|C>4E~x~Y-O%HIKWxNF?2D| zw4$Z00WkR(nqVk`>7FhRq8fUcd>nlza7DCd&1mkUcl5#f^Sp+4{UjbU{E|cHJB6$J zk`%oJIQV%UPS})>diY@sob7u!W2uYVGH(l`^rJRijHP2}5SCi{nznA#j-U-WT+=&k z18rj+BA?*Ul=K=&8)1~?4aTOjYw;?GPE3;&OhL!<{0+~00lg9HawDr}9vDXEi)JRF zAq_vYdwL4PM)ZmaIvtmR%Um|M^)4)6snt@nI>c#@!VR$!P4&EQ5-5y|9vdYC4*_BK z10lfs{b1~xkSU|kbhp~G{15(iNQ6r9&jL=$^P*UK-o-v>MiPW@|3kp^Ffxf10+ecL zF>taCg>jeEu~}$N&2N!_wR7il-0%X?Ug(l1MMLPp{ZTvt>P&nYo}^y~WQ%=}b;K8n_;Qyd!EX8UbQ9~6>4WaZ=+GFbVkzHVx<;Go+qE6H@bCMtNSwEWVT5dh*>Fz zQF(-lV^ol=_puReoV9`6j~2lm&7g3NjN#gbo-w)su2J1whsH{DJ_4H~i8vRh6owQcUg z-PoAlnA^z3R!b+|1T8+-XO%t&TVcWqDLblHf>@a)As9TBUY50{A7U);Dl>*!wopVW z+ox_KWkD}QD%};}Xb*3Don9ZNSm4t2l8k&0kGqPkMr719-OyD*@wM%z_c){!@x{*cmmFqP&(AjeG~KVvpY5V*43M@c-P)} z?ZT_CzJ5vRRVbrh#V8kQA0GHd;p(N=FE4sGt`-;X6Hf*Y9*l$M8qE<9yhFP-NSW%= zktp6g(l@vz{H4Z9d#k<)#;erI?X5;RI@``$@;as}n}?x{I>XAM;e0yLis@)GD%Zm0 zU`35#S6^qdop5rSTr# z5S>S%>6SjJ!{q82%hjiF=c1kM)UNJ4Fm(5UVLG~HPNLVK3!VY~9#}uM9Jz#N3^;{E zNOG%4q@o|7Xc^F$hrxy>>PaxU_OV9Hvu(Z!M{FazVSS__Fo8O`;xn^-`3-c~{XjY+ltX_vQ@H*ClLbbv6p83d|Md*cOv9advVL2%(8s!64mLLJg+%k-+V-j zz_yQ#T{GRA03FDxdJQ-%z$+ysCf8A*%@n*u9ZWJVSlkXk-1@@>kL~4OVrC+FsTq(B z0oN_`lu6RMKT?$>eN48SXduIZ$PolM42PfmsmV6XSj!Z8%j&oy;~OrM4C*xL>8+V; zo5|en$i}>2)7Si4#=~{wL1oCej{J>=AC~=GZ8=Ahg3eN$D@i{GM>j$u)DLl6mbD1< ztkx@j6&G6@Ia1l&BujhxjY3VC^8;LoA zB%M4#l8p%P@fCv9;Fuk*@(QOW!a8O-n037~>wMoVTckR(zJ*yXW;HP@y>3Noo!Mb$ zHgo~Sh~W{;%V6H87#~@;}~hy6^4r64THO|LWO-|>X#I10*}knTkYW%O!e9QWDI{TS#a z?_%ZvwP=&Q%)lSwhWxW#t(RzmSB9wkbc`etQbxv(O=&1PN1~j;wy~|lkHbCYT#S)= z!o7~%f*q%Tb54Q?Ca!w}sRcatdzC#pn@a3hbRU0;CK=Bbt?> z)yN#A?j}jAc;n5M4GOtQW=CEDsEKx5qZYZD&Ew$HT6Ej%C{onyE_+)8IBNsrtUpO` z)abw%B4Kj9REjtr{-;-4H~L4S*8KPiXp(wisg`=<2NKe=sFFhC)Na%+(KfSYV2y zXkrEgC-^hIupYQ6`Fof*KztI_9`Px|)jSLrSgRlv6zg!!DOxoiV=})5akVsJf@K3o zl4p}6$>i8Ewp;oq7)LIV386-ii=eFqOBFxwAnjU(f~*8#MvaLA=n$X9TFV&p0x z!!1f#lWOb&QWn7yPUn*QX=K4a@cW+StyF@ga^6G`iG;2i<=Za)B>DZr_?q#c)p~F5 zdsG@6lPFmOSp{PXV&fQc2ahP@>ir1)Z`h~7lr)}<^i>?qm5F81tFR1SiCS~=x-v+g6e zdg=13ud1n)umQg-_6P^PO@9iQlw0=7t0n2xDa{$tA{_8VNbbZX7*HgEkO^{xPq`nY zmj0NQOd!Es_M?bX;}OmpeffR#%ipD9i0KX_c<;WmlO3HV3{GRZX1GoU*_ezzhMYD6 zK`5GxA<4}g@FeJ|bTKYpK_dwTTiPyi+AT9W78^SVv0B=+7IP|(JOl8Sx#N&R-^Mu) zPI<0$dTj17)=4Qi2%Mk!=Cyft&lcW2HT&ZGU(3HY$6cfXx?Rn0EZ(mB<=7WFW}U7> z1}83F&7Fp00d5Rohoc-nYK|4iiQGypeku1GM%?dGK7N%Qc+8d zT}NUusQPau-ST&^S!J)tTB8p96N=TCgnJW6Uw}K28Rm3EP;FE_ex;-kXP68~`>y)s z^+94hM^u=>Y%N8ZGRle>II@Do+mhrIt{nu1Hf?ebvVBiXYm4tL;mn@xo2jT%Ti)1TF2}LawG3Q2h z%w1#zzC(#I@)w>&mf%T&RGBc5@!~@Z_!8uH9(#|ELWmt;cMLiAu||y2GItI58~B1^ za%YIy(aNwRaCcRB5%(gF^5BMvHHajI07G*QHe^0&uyNA#6Sua|#MEZ_lQLHBpP@%Xk_KR&(DL znfUhJF^Z7@PjOV<*~4QZIUzUjQ$%%jKhA)8qzjFH8Suz(QX%8hxU3Vw$WpRk9Ybk^v%Z(_c?F^ zFa|W)==}g5F*Fn0gEZGxoB^`vWXssLpzSiG$2h;S8WypJqNE?hBY1)tXHh!wD9?8u zn*Y7<*?6o)$M4XWow@t)WO(8a&HYI{&Larh2j2M~e72Bk{`BdOX$_opa`e1N{C+m1`1i3@ow0J8HSQ3~DlnH{p^<##RSM%I%Ti$8QqJX)L_S8@uaW|k9OsRInE46Ll*e8|d2PMrAX%r_^RIeE#f!#OYx-18~U%&74`fLYWMMMu(~oW7l* z)*&i}IMxLaoE?aXOXn~{OF_*+-I2<3;k;7RN4d8QN^<(qf+I$?ixYMEZ&(3SUdTU7 zpFu1)kY~YX5RwF2jrFwq94U9!cxr!wJb0UPh=x`J!dU0_;EMmTCVLLbthcP}=c?xD;yT8G>N MZYn#C8Md4HKZ8PYVE_OC diff --git a/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/utils.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/utils.cpython-38.pyc deleted file mode 100644 index bf810c428192922c0a08315e1d62bd50aaa5f0d8..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1435 zcmbVM%aR*46qVF3yT^7y9#j@tG?15T;`XdyGc}bes8qpXHb4MFs;kG6?e_F*B-x%Z zo(_W3Ht~s>)|tBw0~cQkw?P=9$W>(sXK>l{y*C%Atn&;Y*5J znCX03&eJ^O&xEwRU^`g)KlYON`R)*TZyJtW=$}JZ*8wzHQ%+Z8!`5s=AQX1^n)V=) zo5?UOt1=sc@1;nj7>iTmsM(S6@@gSumm0TB3voeY8~nU}+Sf(hud}*0E9-Q4EO>7* z5hCxMsL{z(jTU_+^sLrZm8*U-7bUM`ABpKWE64qr&T#W7%W?wtjG&`PQD}M9hYc&9Ljr?;AcgA@&hFKJsFd8NP5aRJ$B^N6|7-HxX_lVBNoqN#23!F7$WNG~&8a8ZKoS#9YjA z;O+u;+cLntK7jE=T@5G3PwN^Uh4Dv~EK+Tl6cP*DxYH^tO|ZRokpV1cWu#mY0g0Po`HO=t2xu(~Z1Ch!-e zXHq1I#K$L5P>BM_y9l2kU}82!6AY`O&T=7}xP;HwI(jcUdy7`o#(q)pSuPIHo5JL8 Mu?D;Dgigcz8!X^mZU6uP diff --git a/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/version.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/__pycache__/version.cpython-38.pyc deleted file mode 100644 index e850a418d873a3115964acfeff754c2857c8d131..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 12065 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 UGY70O>zHAWKDXY@>DJ)?1EAYZlK=n! diff --git a/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/_compat.py b/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/_compat.py deleted file mode 100644 index 25da473..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/_compat.py +++ /dev/null @@ -1,31 +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 - - -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): - """ - 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): - def __new__(cls, name, this_bases, d): - return meta(name, bases, d) - - return type.__new__(metaclass, "temporary_class", (), {}) diff --git a/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/_structures.py b/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/_structures.py deleted file mode 100644 index 68dcca6..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/_structures.py +++ /dev/null @@ -1,68 +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 - - -class Infinity(object): - def __repr__(self): - return "Infinity" - - def __hash__(self): - return hash(repr(self)) - - def __lt__(self, other): - return False - - def __le__(self, other): - return False - - def __eq__(self, other): - return isinstance(other, self.__class__) - - def __ne__(self, other): - return not isinstance(other, self.__class__) - - def __gt__(self, other): - return True - - def __ge__(self, other): - return True - - def __neg__(self): - return NegativeInfinity - - -Infinity = Infinity() - - -class NegativeInfinity(object): - def __repr__(self): - return "-Infinity" - - def __hash__(self): - return hash(repr(self)) - - def __lt__(self, other): - return True - - def __le__(self, other): - return True - - def __eq__(self, other): - return isinstance(other, self.__class__) - - def __ne__(self, other): - return not isinstance(other, self.__class__) - - def __gt__(self, other): - return False - - def __ge__(self, other): - return False - - def __neg__(self): - return Infinity - - -NegativeInfinity = NegativeInfinity() diff --git a/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/markers.py b/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/markers.py deleted file mode 100644 index 4bdfdb2..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/markers.py +++ /dev/null @@ -1,296 +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 operator -import os -import platform -import sys - -from setuptools.extern.pyparsing import ParseException, ParseResults, stringStart, stringEnd -from setuptools.extern.pyparsing import ZeroOrMore, Group, Forward, QuotedString -from setuptools.extern.pyparsing import Literal as L # noqa - -from ._compat import string_types -from .specifiers import Specifier, InvalidSpecifier - - -__all__ = [ - "InvalidMarker", - "UndefinedComparison", - "UndefinedEnvironmentName", - "Marker", - "default_environment", -] - - -class InvalidMarker(ValueError): - """ - An invalid marker was found, users should refer to PEP 508. - """ - - -class UndefinedComparison(ValueError): - """ - An invalid operation was attempted on a value that doesn't support it. - """ - - -class UndefinedEnvironmentName(ValueError): - """ - A name was attempted to be used that does not exist inside of the - environment. - """ - - -class Node(object): - def __init__(self, value): - self.value = value - - def __str__(self): - return str(self.value) - - def __repr__(self): - return "<{0}({1!r})>".format(self.__class__.__name__, str(self)) - - def serialize(self): - raise NotImplementedError - - -class Variable(Node): - def serialize(self): - return str(self) - - -class Value(Node): - def serialize(self): - return '"{0}"'.format(self) - - -class Op(Node): - def serialize(self): - return str(self) - - -VARIABLE = ( - L("implementation_version") - | L("platform_python_implementation") - | L("implementation_name") - | L("python_full_version") - | L("platform_release") - | L("platform_version") - | L("platform_machine") - | L("platform_system") - | L("python_version") - | L("sys_platform") - | L("os_name") - | L("os.name") - | L("sys.platform") # PEP-345 - | L("platform.version") # PEP-345 - | L("platform.machine") # PEP-345 - | L("platform.python_implementation") # PEP-345 - | L("python_implementation") # PEP-345 - | L("extra") # undocumented setuptools legacy -) -ALIASES = { - "os.name": "os_name", - "sys.platform": "sys_platform", - "platform.version": "platform_version", - "platform.machine": "platform_machine", - "platform.python_implementation": "platform_python_implementation", - "python_implementation": "platform_python_implementation", -} -VARIABLE.setParseAction(lambda s, l, t: Variable(ALIASES.get(t[0], t[0]))) - -VERSION_CMP = ( - L("===") | L("==") | L(">=") | L("<=") | L("!=") | L("~=") | L(">") | L("<") -) - -MARKER_OP = VERSION_CMP | L("not in") | L("in") -MARKER_OP.setParseAction(lambda s, l, t: Op(t[0])) - -MARKER_VALUE = QuotedString("'") | QuotedString('"') -MARKER_VALUE.setParseAction(lambda s, l, t: Value(t[0])) - -BOOLOP = L("and") | L("or") - -MARKER_VAR = VARIABLE | MARKER_VALUE - -MARKER_ITEM = Group(MARKER_VAR + MARKER_OP + MARKER_VAR) -MARKER_ITEM.setParseAction(lambda s, l, t: tuple(t[0])) - -LPAREN = L("(").suppress() -RPAREN = L(")").suppress() - -MARKER_EXPR = Forward() -MARKER_ATOM = MARKER_ITEM | Group(LPAREN + MARKER_EXPR + RPAREN) -MARKER_EXPR << MARKER_ATOM + ZeroOrMore(BOOLOP + MARKER_EXPR) - -MARKER = stringStart + MARKER_EXPR + stringEnd - - -def _coerce_parse_result(results): - if isinstance(results, ParseResults): - return [_coerce_parse_result(i) for i in results] - else: - return results - - -def _format_marker(marker, first=True): - assert isinstance(marker, (list, tuple, string_types)) - - # 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 - # the rest of this function so that we don't get extraneous () on the - # outside. - if ( - isinstance(marker, list) - and len(marker) == 1 - and isinstance(marker[0], (list, tuple)) - ): - return _format_marker(marker[0]) - - if isinstance(marker, list): - inner = (_format_marker(m, first=False) for m in marker) - if first: - return " ".join(inner) - else: - return "(" + " ".join(inner) + ")" - elif isinstance(marker, tuple): - return " ".join([m.serialize() for m in marker]) - else: - return marker - - -_operators = { - "in": lambda lhs, rhs: lhs in rhs, - "not in": lambda lhs, rhs: lhs not in rhs, - "<": operator.lt, - "<=": operator.le, - "==": operator.eq, - "!=": operator.ne, - ">=": operator.ge, - ">": operator.gt, -} - - -def _eval_op(lhs, op, rhs): - try: - spec = Specifier("".join([op.serialize(), rhs])) - except InvalidSpecifier: - pass - else: - return spec.contains(lhs) - - oper = _operators.get(op.serialize()) - if oper is None: - raise UndefinedComparison( - "Undefined {0!r} on {1!r} and {2!r}.".format(op, lhs, rhs) - ) - - return oper(lhs, rhs) - - -_undefined = object() - - -def _get_env(environment, name): - value = environment.get(name, _undefined) - - if value is _undefined: - raise UndefinedEnvironmentName( - "{0!r} does not exist in evaluation environment.".format(name) - ) - - return value - - -def _evaluate_markers(markers, environment): - groups = [[]] - - for marker in markers: - assert isinstance(marker, (list, tuple, string_types)) - - if isinstance(marker, list): - groups[-1].append(_evaluate_markers(marker, environment)) - elif isinstance(marker, tuple): - lhs, op, rhs = marker - - if isinstance(lhs, Variable): - lhs_value = _get_env(environment, lhs.value) - rhs_value = rhs.value - else: - lhs_value = lhs.value - rhs_value = _get_env(environment, rhs.value) - - groups[-1].append(_eval_op(lhs_value, op, rhs_value)) - else: - assert marker in ["and", "or"] - if marker == "or": - groups.append([]) - - return any(all(item) for item in groups) - - -def format_full_version(info): - version = "{0.major}.{0.minor}.{0.micro}".format(info) - kind = info.releaselevel - if kind != "final": - version += kind[0] + str(info.serial) - return version - - -def default_environment(): - if hasattr(sys, "implementation"): - iver = format_full_version(sys.implementation.version) - implementation_name = sys.implementation.name - else: - iver = "0" - implementation_name = "" - - return { - "implementation_name": implementation_name, - "implementation_version": iver, - "os_name": os.name, - "platform_machine": platform.machine(), - "platform_release": platform.release(), - "platform_system": platform.system(), - "platform_version": platform.version(), - "python_full_version": platform.python_version(), - "platform_python_implementation": platform.python_implementation(), - "python_version": ".".join(platform.python_version_tuple()[:2]), - "sys_platform": sys.platform, - } - - -class Marker(object): - def __init__(self, marker): - 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(err_str) - - def __str__(self): - return _format_marker(self._markers) - - def __repr__(self): - return "".format(str(self)) - - def evaluate(self, environment=None): - """Evaluate a marker. - - Return the boolean from evaluating the given marker against the - environment. environment is an optional argument to override all or - part of the determined environment. - - The environment is determined from the current Python process. - """ - current_environment = default_environment() - if environment is not None: - current_environment.update(environment) - - return _evaluate_markers(self._markers, current_environment) diff --git a/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/requirements.py b/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/requirements.py deleted file mode 100644 index 8a0c2cb..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/requirements.py +++ /dev/null @@ -1,138 +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 string -import re - -from setuptools.extern.pyparsing import stringStart, stringEnd, originalTextFor, ParseException -from setuptools.extern.pyparsing import ZeroOrMore, Word, Optional, Regex, Combine -from setuptools.extern.pyparsing import Literal as L # noqa -from setuptools.extern.six.moves.urllib import parse as urlparse - -from .markers import MARKER_EXPR, Marker -from .specifiers import LegacySpecifier, Specifier, SpecifierSet - - -class InvalidRequirement(ValueError): - """ - An invalid requirement was found, users should refer to PEP 508. - """ - - -ALPHANUM = Word(string.ascii_letters + string.digits) - -LBRACKET = L("[").suppress() -RBRACKET = L("]").suppress() -LPAREN = L("(").suppress() -RPAREN = L(")").suppress() -COMMA = L(",").suppress() -SEMICOLON = L(";").suppress() -AT = L("@").suppress() - -PUNCTUATION = Word("-_.") -IDENTIFIER_END = ALPHANUM | (ZeroOrMore(PUNCTUATION) + ALPHANUM) -IDENTIFIER = Combine(ALPHANUM + ZeroOrMore(IDENTIFIER_END)) - -NAME = IDENTIFIER("name") -EXTRA = IDENTIFIER - -URI = Regex(r"[^ ]+")("url") -URL = AT + URI - -EXTRAS_LIST = EXTRA + ZeroOrMore(COMMA + EXTRA) -EXTRAS = (LBRACKET + Optional(EXTRAS_LIST) + RBRACKET)("extras") - -VERSION_PEP440 = Regex(Specifier._regex_str, re.VERBOSE | re.IGNORECASE) -VERSION_LEGACY = Regex(LegacySpecifier._regex_str, re.VERBOSE | re.IGNORECASE) - -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.setParseAction(lambda s, l, t: t._raw_spec or "") - -VERSION_SPEC = originalTextFor(_VERSION_SPEC)("specifier") -VERSION_SPEC.setParseAction(lambda s, l, t: t[1]) - -MARKER_EXPR = originalTextFor(MARKER_EXPR())("marker") -MARKER_EXPR.setParseAction( - lambda s, l, t: Marker(s[t._original_start : t._original_end]) -) -MARKER_SEPARATOR = SEMICOLON -MARKER = MARKER_SEPARATOR + MARKER_EXPR - -VERSION_AND_MARKER = VERSION_SPEC + Optional(MARKER) -URL_AND_MARKER = URL + Optional(MARKER) - -NAMED_REQUIREMENT = NAME + Optional(EXTRAS) + (URL_AND_MARKER | VERSION_AND_MARKER) - -REQUIREMENT = stringStart + NAMED_REQUIREMENT + stringEnd -# setuptools.extern.pyparsing isn't thread safe during initialization, so we do it eagerly, see -# issue #104 -REQUIREMENT.parseString("x[]") - - -class Requirement(object): - """Parse a requirement. - - Parse a given requirement string into its parts, such as name, specifier, - URL, and extras. Raises InvalidRequirement on a badly-formed requirement - string. - """ - - # TODO: Can we test whether something is contained within a requirement? - # If so how do we do that? Do we need to test against the _name_ of - # 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): - 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 - ) - ) - - self.name = req.name - if req.url: - parsed_url = urlparse.urlparse(req.url) - if parsed_url.scheme == "file": - if urlparse.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 - else: - self.url = None - self.extras = set(req.extras.asList() if req.extras else []) - self.specifier = SpecifierSet(req.specifier) - self.marker = req.marker if req.marker else None - - def __str__(self): - parts = [self.name] - - if self.extras: - parts.append("[{0}]".format(",".join(sorted(self.extras)))) - - if self.specifier: - parts.append(str(self.specifier)) - - if self.url: - parts.append("@ {0}".format(self.url)) - if self.marker: - parts.append(" ") - - if self.marker: - parts.append("; {0}".format(self.marker)) - - return "".join(parts) - - def __repr__(self): - return "".format(str(self)) diff --git a/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/specifiers.py b/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/specifiers.py deleted file mode 100644 index 743576a..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/specifiers.py +++ /dev/null @@ -1,749 +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 abc -import functools -import itertools -import re - -from ._compat import string_types, with_metaclass -from .version import Version, LegacyVersion, parse - - -class InvalidSpecifier(ValueError): - """ - An invalid specifier was found, users should refer to PEP 440. - """ - - -class BaseSpecifier(with_metaclass(abc.ABCMeta, object)): - @abc.abstractmethod - def __str__(self): - """ - Returns the str representation of this Specifier like object. This - should be representative of the Specifier itself. - """ - - @abc.abstractmethod - def __hash__(self): - """ - Returns a hash value for this Specifier like object. - """ - - @abc.abstractmethod - def __eq__(self, other): - """ - Returns a boolean representing whether or not the two Specifier like - objects are equal. - """ - - @abc.abstractmethod - def __ne__(self, other): - """ - Returns a boolean representing whether or not the two Specifier like - objects are not equal. - """ - - @abc.abstractproperty - def prereleases(self): - """ - Returns whether or not pre-releases as a whole are allowed by this - specifier. - """ - - @prereleases.setter - def prereleases(self, value): - """ - Sets whether or not pre-releases as a whole are allowed by this - specifier. - """ - - @abc.abstractmethod - def contains(self, item, prereleases=None): - """ - Determines if the given item is contained within this specifier. - """ - - @abc.abstractmethod - def filter(self, iterable, prereleases=None): - """ - Takes an iterable of items and filters them so that only items which - are contained within this specifier are allowed in it. - """ - - -class _IndividualSpecifier(BaseSpecifier): - - _operators = {} - - def __init__(self, spec="", prereleases=None): - match = self._regex.search(spec) - if not match: - raise InvalidSpecifier("Invalid specifier: '{0}'".format(spec)) - - self._spec = (match.group("operator").strip(), match.group("version").strip()) - - # Store whether or not this Specifier should accept prereleases - self._prereleases = prereleases - - def __repr__(self): - pre = ( - ", prereleases={0!r}".format(self.prereleases) - if self._prereleases is not None - else "" - ) - - return "<{0}({1!r}{2})>".format(self.__class__.__name__, str(self), pre) - - def __str__(self): - return "{0}{1}".format(*self._spec) - - def __hash__(self): - return hash(self._spec) - - def __eq__(self, other): - if isinstance(other, string_types): - try: - other = self.__class__(other) - except InvalidSpecifier: - return NotImplemented - elif not isinstance(other, self.__class__): - return NotImplemented - - return self._spec == other._spec - - def __ne__(self, other): - if isinstance(other, string_types): - try: - other = self.__class__(other) - except InvalidSpecifier: - return NotImplemented - elif not isinstance(other, self.__class__): - return NotImplemented - - return self._spec != other._spec - - def _get_operator(self, op): - return getattr(self, "_compare_{0}".format(self._operators[op])) - - def _coerce_version(self, version): - if not isinstance(version, (LegacyVersion, Version)): - version = parse(version) - return version - - @property - def operator(self): - return self._spec[0] - - @property - def version(self): - return self._spec[1] - - @property - def prereleases(self): - return self._prereleases - - @prereleases.setter - def prereleases(self, value): - self._prereleases = value - - def __contains__(self, item): - return self.contains(item) - - def contains(self, item, prereleases=None): - # Determine if prereleases are to be allowed or not. - if prereleases is None: - prereleases = self.prereleases - - # Normalize item to a Version or LegacyVersion, this allows us to have - # a shortcut for ``"2.0" in Specifier(">=2") - item = self._coerce_version(item) - - # Determine if we should be supporting prereleases in this specifier - # or not, if we do not support prereleases than we can short circuit - # logic if this version is a prereleases. - if item.is_prerelease and not prereleases: - return False - - # Actually do the comparison to determine if this item is contained - # within this Specifier or not. - return self._get_operator(self.operator)(item, self.version) - - def filter(self, iterable, prereleases=None): - yielded = False - found_prereleases = [] - - kw = {"prereleases": prereleases if prereleases is not None else True} - - # Attempt to iterate over all the values in the iterable and if any of - # them match, yield them. - for version in iterable: - parsed_version = self._coerce_version(version) - - 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 - # else matches this specifier. - if parsed_version.is_prerelease and not ( - prereleases or self.prereleases - ): - found_prereleases.append(version) - # Either this is not a prerelease, or we should have been - # accepting prereleases from the beginning. - else: - yielded = True - yield version - - # Now that we've iterated over everything, determine if we've yielded - # any values, and if we have not and we have any prereleases stored up - # then we will go ahead and yield the prereleases. - if not yielded and found_prereleases: - for version in found_prereleases: - yield version - - -class LegacySpecifier(_IndividualSpecifier): - - _regex_str = r""" - (?P(==|!=|<=|>=|<|>)) - \s* - (?P - [^,;\s)]* # Since this is a "legacy" specifier, and the version - # string can be just about anything, we match everything - # except for whitespace, a semi-colon for marker support, - # a closing paren since versions can be enclosed in - # them, and a comma since it's a version separator. - ) - """ - - _regex = re.compile(r"^\s*" + _regex_str + r"\s*$", re.VERBOSE | re.IGNORECASE) - - _operators = { - "==": "equal", - "!=": "not_equal", - "<=": "less_than_equal", - ">=": "greater_than_equal", - "<": "less_than", - ">": "greater_than", - } - - def _coerce_version(self, version): - if not isinstance(version, LegacyVersion): - version = LegacyVersion(str(version)) - return version - - def _compare_equal(self, prospective, spec): - return prospective == self._coerce_version(spec) - - def _compare_not_equal(self, prospective, spec): - return prospective != self._coerce_version(spec) - - def _compare_less_than_equal(self, prospective, spec): - return prospective <= self._coerce_version(spec) - - def _compare_greater_than_equal(self, prospective, spec): - return prospective >= self._coerce_version(spec) - - def _compare_less_than(self, prospective, spec): - return prospective < self._coerce_version(spec) - - def _compare_greater_than(self, prospective, spec): - return prospective > self._coerce_version(spec) - - -def _require_version_compare(fn): - @functools.wraps(fn) - def wrapped(self, prospective, spec): - if not isinstance(prospective, Version): - return False - return fn(self, prospective, spec) - - return wrapped - - -class Specifier(_IndividualSpecifier): - - _regex_str = r""" - (?P(~=|==|!=|<=|>=|<|>|===)) - (?P - (?: - # The identity operators allow for an escape hatch that will - # do an exact string match of the version you wish to install. - # This will not be parsed by PEP 440 and we cannot determine - # any semantic meaning from it. This operator is discouraged - # but included entirely as an escape hatch. - (?<====) # Only match for the identity operator - \s* - [^\s]* # We just match everything, except for whitespace - # since we are only testing for strict identity. - ) - | - (?: - # The (non)equality operators allow for wild card and local - # versions to be specified so we have to define these two - # operators separately to enable that. - (?<===|!=) # Only match for equals and not equals - - \s* - v? - (?:[0-9]+!)? # epoch - [0-9]+(?:\.[0-9]+)* # release - (?: # pre release - [-_\.]? - (a|b|c|rc|alpha|beta|pre|preview) - [-_\.]? - [0-9]* - )? - (?: # post release - (?:-[0-9]+)|(?:[-_\.]?(post|rev|r)[-_\.]?[0-9]*) - )? - - # You cannot use a wild card and a dev or local version - # together so group them with a | and make them optional. - (?: - (?:[-_\.]?dev[-_\.]?[0-9]*)? # dev release - (?:\+[a-z0-9]+(?:[-_\.][a-z0-9]+)*)? # local - | - \.\* # Wild card syntax of .* - )? - ) - | - (?: - # The compatible operator requires at least two digits in the - # release segment. - (?<=~=) # Only match for the compatible operator - - \s* - v? - (?:[0-9]+!)? # epoch - [0-9]+(?:\.[0-9]+)+ # release (We have a + instead of a *) - (?: # pre release - [-_\.]? - (a|b|c|rc|alpha|beta|pre|preview) - [-_\.]? - [0-9]* - )? - (?: # post release - (?:-[0-9]+)|(?:[-_\.]?(post|rev|r)[-_\.]?[0-9]*) - )? - (?:[-_\.]?dev[-_\.]?[0-9]*)? # dev release - ) - | - (?: - # All other operators only allow a sub set of what the - # (non)equality operators do. Specifically they do not allow - # local versions to be specified nor do they allow the prefix - # matching wild cards. - (?=": "greater_than_equal", - "<": "less_than", - ">": "greater_than", - "===": "arbitrary", - } - - @_require_version_compare - def _compare_compatible(self, prospective, spec): - # Compatible releases have an equivalent combination of >= and ==. That - # is that ~=2.2 is equivalent to >=2.2,==2.*. This allows us to - # implement this in terms of the other specifiers instead of - # implementing it ourselves. The only thing we need to do is construct - # 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. - prefix = ".".join( - list( - itertools.takewhile( - lambda x: (not x.startswith("post") and not x.startswith("dev")), - _version_split(spec), - ) - )[:-1] - ) - - # Add the prefix notation to the end of our string - prefix += ".*" - - return self._get_operator(">=")(prospective, spec) and self._get_operator("==")( - prospective, prefix - ) - - @_require_version_compare - def _compare_equal(self, prospective, spec): - # We need special logic to handle prefix matching - if spec.endswith(".*"): - # In the case of prefix matching we want to ignore local segment. - prospective = Version(prospective.public) - # Split the spec out by dots, and pretend that there is an implicit - # dot in between a release segment and a pre-release segment. - spec = _version_split(spec[:-2]) # Remove the trailing .* - - # Split the prospective version out by dots, and pretend that there - # is an implicit dot in between a release segment and a pre-release - # segment. - prospective = _version_split(str(prospective)) - - # Shorten the prospective version to be the same length as the spec - # so that we can determine if the specifier is a prefix of the - # prospective version or not. - prospective = prospective[: len(spec)] - - # Pad out our two sides with zeros so that they both equal the same - # length. - spec, prospective = _pad_version(spec, prospective) - else: - # Convert our spec string into a Version - spec = Version(spec) - - # If the specifier does not have a local segment, then we want to - # act as if the prospective version also does not have a local - # segment. - if not spec.local: - prospective = Version(prospective.public) - - return prospective == spec - - @_require_version_compare - def _compare_not_equal(self, prospective, spec): - return not self._compare_equal(prospective, spec) - - @_require_version_compare - def _compare_less_than_equal(self, prospective, spec): - return prospective <= Version(spec) - - @_require_version_compare - def _compare_greater_than_equal(self, prospective, spec): - return prospective >= Version(spec) - - @_require_version_compare - def _compare_less_than(self, prospective, spec): - # Convert our spec to a Version instance, since we'll want to work with - # it as a version. - spec = Version(spec) - - # Check to see if the prospective version is less than the spec - # version. If it's not we can short circuit and just return False now - # instead of doing extra unneeded work. - if not prospective < spec: - return False - - # This special case is here so that, unless the specifier itself - # includes is a pre-release version, that we do not accept pre-release - # versions for the version mentioned in the specifier (e.g. <3.1 should - # not match 3.1.dev0, but should match 3.0.dev0). - if not spec.is_prerelease and prospective.is_prerelease: - if Version(prospective.base_version) == Version(spec.base_version): - return False - - # If we've gotten to here, it means that prospective version is both - # less than the spec version *and* it's not a pre-release of the same - # version in the spec. - return True - - @_require_version_compare - def _compare_greater_than(self, prospective, spec): - # Convert our spec to a Version instance, since we'll want to work with - # it as a version. - spec = Version(spec) - - # Check to see if the prospective version is greater than the spec - # version. If it's not we can short circuit and just return False now - # instead of doing extra unneeded work. - if not prospective > spec: - return False - - # This special case is here so that, unless the specifier itself - # includes is a post-release version, that we do not accept - # post-release versions for the version mentioned in the specifier - # (e.g. >3.1 should not match 3.0.post0, but should match 3.2.post0). - if not spec.is_postrelease and prospective.is_postrelease: - if Version(prospective.base_version) == Version(spec.base_version): - return False - - # Ensure that we do not allow a local version of the version mentioned - # in the specifier, which is technically greater than, to match. - if prospective.local is not None: - if Version(prospective.base_version) == Version(spec.base_version): - return False - - # If we've gotten to here, it means that prospective version is both - # greater than the spec version *and* it's not a pre-release of the - # same version in the spec. - return True - - def _compare_arbitrary(self, prospective, spec): - return str(prospective).lower() == str(spec).lower() - - @property - def prereleases(self): - # If there is an explicit prereleases set for this, then we'll just - # blindly use that. - if self._prereleases is not None: - return self._prereleases - - # Look at all of our specifiers and determine if they are inclusive - # operators, and if they are if they are including an explicit - # prerelease. - operator, version = self._spec - if operator in ["==", ">=", "<=", "~=", "==="]: - # The == specifier can include a trailing .*, if it does we - # want to remove before parsing. - if operator == "==" and version.endswith(".*"): - version = version[:-2] - - # Parse the version, and if it is a pre-release than this - # specifier allows pre-releases. - if parse(version).is_prerelease: - return True - - return False - - @prereleases.setter - def prereleases(self, value): - self._prereleases = value - - -_prefix_regex = re.compile(r"^([0-9]+)((?:a|b|c|rc)[0-9]+)$") - - -def _version_split(version): - result = [] - for item in version.split("."): - match = _prefix_regex.search(item) - if match: - result.extend(match.groups()) - else: - result.append(item) - return result - - -def _pad_version(left, right): - left_split, right_split = [], [] - - # Get the release segment of our versions - left_split.append(list(itertools.takewhile(lambda x: x.isdigit(), left))) - right_split.append(list(itertools.takewhile(lambda x: x.isdigit(), right))) - - # Get the rest of our versions - left_split.append(left[len(left_split[0]) :]) - right_split.append(right[len(right_split[0]) :]) - - # Insert our padding - left_split.insert(1, ["0"] * max(0, len(right_split[0]) - len(left_split[0]))) - right_split.insert(1, ["0"] * max(0, len(left_split[0]) - len(right_split[0]))) - - return (list(itertools.chain(*left_split)), list(itertools.chain(*right_split))) - - -class SpecifierSet(BaseSpecifier): - def __init__(self, specifiers="", prereleases=None): - # Split on , to break each indidivual specifier into it's own item, and - # strip each item to remove leading/trailing whitespace. - specifiers = [s.strip() for s in specifiers.split(",") if s.strip()] - - # Parsed each individual specifier, attempting first to make it a - # Specifier and falling back to a LegacySpecifier. - parsed = set() - for specifier in specifiers: - try: - parsed.add(Specifier(specifier)) - except InvalidSpecifier: - parsed.add(LegacySpecifier(specifier)) - - # Turn our parsed specifiers into a frozen set and save them for later. - self._specs = frozenset(parsed) - - # Store our prereleases value so we can use it later to determine if - # we accept prereleases or not. - self._prereleases = prereleases - - def __repr__(self): - pre = ( - ", prereleases={0!r}".format(self.prereleases) - if self._prereleases is not None - else "" - ) - - return "".format(str(self), pre) - - def __str__(self): - return ",".join(sorted(str(s) for s in self._specs)) - - def __hash__(self): - return hash(self._specs) - - def __and__(self, other): - if isinstance(other, string_types): - other = SpecifierSet(other) - elif not isinstance(other, SpecifierSet): - return NotImplemented - - specifier = SpecifierSet() - specifier._specs = frozenset(self._specs | other._specs) - - if self._prereleases is None and other._prereleases is not None: - specifier._prereleases = other._prereleases - elif self._prereleases is not None and other._prereleases is None: - specifier._prereleases = self._prereleases - elif self._prereleases == other._prereleases: - specifier._prereleases = self._prereleases - else: - raise ValueError( - "Cannot combine SpecifierSets with True and False prerelease " - "overrides." - ) - - return specifier - - def __eq__(self, other): - if isinstance(other, string_types): - other = SpecifierSet(other) - elif isinstance(other, _IndividualSpecifier): - other = SpecifierSet(str(other)) - elif not isinstance(other, SpecifierSet): - return NotImplemented - - return self._specs == other._specs - - def __ne__(self, other): - if isinstance(other, string_types): - other = SpecifierSet(other) - elif isinstance(other, _IndividualSpecifier): - other = SpecifierSet(str(other)) - elif not isinstance(other, SpecifierSet): - return NotImplemented - - return self._specs != other._specs - - def __len__(self): - return len(self._specs) - - def __iter__(self): - return iter(self._specs) - - @property - def prereleases(self): - # If we have been given an explicit prerelease modifier, then we'll - # pass that through here. - if self._prereleases is not None: - return self._prereleases - - # If we don't have any specifiers, and we don't have a forced value, - # then we'll just return None since we don't know if this should have - # pre-releases or not. - if not self._specs: - return None - - # Otherwise we'll see if any of the given specifiers accept - # prereleases, if any of them do we'll return True, otherwise False. - return any(s.prereleases for s in self._specs) - - @prereleases.setter - def prereleases(self, value): - self._prereleases = value - - def __contains__(self, item): - return self.contains(item) - - def contains(self, item, prereleases=None): - # Ensure that our item is a Version or LegacyVersion instance. - if not isinstance(item, (LegacyVersion, Version)): - item = parse(item) - - # 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 - # SpecifierSet thinks for whether or not we should support prereleases. - if prereleases is None: - prereleases = self.prereleases - - # We can determine if we're going to allow pre-releases by looking to - # see if any of the underlying items supports them. If none of them do - # and this item is a pre-release then we do not allow it and we can - # short circuit that here. - # Note: This means that 1.0.dev1 would not be contained in something - # like >=1.0.devabc however it would be in >=1.0.debabc,>0.0.dev0 - if not prereleases and item.is_prerelease: - return False - - # We simply dispatch to the underlying specs here to make sure that the - # given version is contained within all of them. - # Note: This use of all() here means that an empty set of specifiers - # will always return True, this is an explicit design decision. - return all(s.contains(item, prereleases=prereleases) for s in self._specs) - - def filter(self, iterable, prereleases=None): - # 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 - # SpecifierSet thinks for whether or not we should support prereleases. - if prereleases is None: - prereleases = self.prereleases - - # If we have any specifiers, then we want to wrap our iterable in the - # filter method for each one, this will act as a logical AND amongst - # each specifier. - if self._specs: - for spec in self._specs: - iterable = spec.filter(iterable, prereleases=bool(prereleases)) - return iterable - # If we do not have any specifiers, then we need to have a rough filter - # which will filter out any pre-releases, unless there are no final - # releases, and which will filter out LegacyVersion in general. - else: - filtered = [] - found_prereleases = [] - - for item in iterable: - # Ensure that we some kind of Version class for this item. - if not isinstance(item, (LegacyVersion, Version)): - parsed_version = parse(item) - else: - parsed_version = item - - # Filter out any item which is parsed as a LegacyVersion - if isinstance(parsed_version, LegacyVersion): - continue - - # Store any item which is a pre-release for later unless we've - # already found a final version or we are accepting prereleases - if parsed_version.is_prerelease and not prereleases: - if not filtered: - found_prereleases.append(item) - else: - filtered.append(item) - - # If we've found no items except for pre-releases, then we'll go - # ahead and use the pre-releases - if not filtered and found_prereleases and prereleases is None: - return found_prereleases - - return filtered diff --git a/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/tags.py b/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/tags.py deleted file mode 100644 index ec9942f..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/tags.py +++ /dev/null @@ -1,404 +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 - -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 platform -import re -import sys -import sysconfig -import warnings - - -INTERPRETER_SHORT_NAMES = { - "python": "py", # Generic. - "cpython": "cp", - "pypy": "pp", - "ironpython": "ip", - "jython": "jy", -} - - -_32_BIT_INTERPRETER = sys.maxsize <= 2 ** 32 - - -class Tag(object): - - __slots__ = ["_interpreter", "_abi", "_platform"] - - def __init__(self, interpreter, abi, platform): - self._interpreter = interpreter.lower() - self._abi = abi.lower() - self._platform = platform.lower() - - @property - def interpreter(self): - return self._interpreter - - @property - def abi(self): - return self._abi - - @property - def platform(self): - return self._platform - - def __eq__(self, other): - return ( - (self.platform == other.platform) - and (self.abi == other.abi) - and (self.interpreter == other.interpreter) - ) - - def __hash__(self): - return hash((self._interpreter, self._abi, self._platform)) - - def __str__(self): - return "{}-{}-{}".format(self._interpreter, self._abi, self._platform) - - def __repr__(self): - return "<{self} @ {self_id}>".format(self=self, self_id=id(self)) - - -def parse_tag(tag): - tags = set() - interpreters, abis, platforms = tag.split("-") - for interpreter in interpreters.split("."): - for abi in abis.split("."): - for platform_ in platforms.split("."): - tags.add(Tag(interpreter, abi, platform_)) - return frozenset(tags) - - -def _normalize_string(string): - return string.replace(".", "_").replace("-", "_") - - -def _cpython_interpreter(py_version): - # TODO: Is using py_version_nodot for interpreter version critical? - return "cp{major}{minor}".format(major=py_version[0], minor=py_version[1]) - - -def _cpython_abis(py_version): - abis = [] - version = "{}{}".format(*py_version[:2]) - debug = pymalloc = ucs4 = "" - with_debug = sysconfig.get_config_var("Py_DEBUG") - has_refcount = hasattr(sys, "gettotalrefcount") - # Windows doesn't set Py_DEBUG, so checking for support of debug-compiled - # extension modules is the best option. - # https://github.com/pypa/pip/issues/3383#issuecomment-173267692 - has_ext = "_d.pyd" in EXTENSION_SUFFIXES - if with_debug or (with_debug is None and (has_refcount or has_ext)): - debug = "d" - if py_version < (3, 8): - with_pymalloc = sysconfig.get_config_var("WITH_PYMALLOC") - if with_pymalloc or with_pymalloc is None: - pymalloc = "m" - if py_version < (3, 3): - unicode_size = sysconfig.get_config_var("Py_UNICODE_SIZE") - if unicode_size == 4 or ( - unicode_size is None and sys.maxunicode == 0x10FFFF - ): - ucs4 = "u" - 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.insert( - 0, - "cp{version}{debug}{pymalloc}{ucs4}".format( - version=version, debug=debug, pymalloc=pymalloc, ucs4=ucs4 - ), - ) - return abis - - -def _cpython_tags(py_version, interpreter, abis, platforms): - for abi in abis: - for platform_ in platforms: - yield Tag(interpreter, abi, platform_) - 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 - # PEP 384 was first implemented in Python 3.2. - for minor_version in range(py_version[1] - 1, 1, -1): - for platform_ in platforms: - interpreter = "cp{major}{minor}".format( - major=py_version[0], minor=minor_version - ) - yield Tag(interpreter, "abi3", platform_) - - -def _pypy_interpreter(): - return "pp{py_major}{pypy_major}{pypy_minor}".format( - py_major=sys.version_info[0], - pypy_major=sys.pypy_version_info.major, - pypy_minor=sys.pypy_version_info.minor, - ) - - -def _generic_abi(): - abi = sysconfig.get_config_var("SOABI") - if abi: - return _normalize_string(abi) - else: - return "none" - - -def _pypy_tags(py_version, interpreter, abi, platforms): - for tag in (Tag(interpreter, abi, platform) for platform in platforms): - yield tag - for tag in (Tag(interpreter, "none", platform) for platform in platforms): - yield tag - - -def _generic_tags(interpreter, py_version, abi, platforms): - for tag in (Tag(interpreter, abi, platform) for platform in platforms): - yield tag - if abi != "none": - tags = (Tag(interpreter, "none", platform_) for platform_ in platforms) - for tag in tags: - yield tag - - -def _py_interpreter_range(py_version): - """ - Yield Python versions in descending order. - - After the latest version, the major-only version will be yielded, and then - all following versions up to 'end'. - """ - yield "py{major}{minor}".format(major=py_version[0], minor=py_version[1]) - yield "py{major}".format(major=py_version[0]) - for minor in range(py_version[1] - 1, -1, -1): - yield "py{major}{minor}".format(major=py_version[0], minor=minor) - - -def _independent_tags(interpreter, py_version, platforms): - """ - Return the sequence of tags that are consistent across implementations. - - The tags consist of: - - py*-none- - - -none-any - - py*-none-any - """ - for version in _py_interpreter_range(py_version): - for platform_ in platforms: - yield Tag(version, "none", platform_) - yield Tag(interpreter, "none", "any") - for version in _py_interpreter_range(py_version): - yield Tag(version, "none", "any") - - -def _mac_arch(arch, is_32bit=_32_BIT_INTERPRETER): - if not is_32bit: - return arch - - if arch.startswith("ppc"): - return "ppc" - - return "i386" - - -def _mac_binary_formats(version, cpu_arch): - formats = [cpu_arch] - if cpu_arch == "x86_64": - if version < (10, 4): - return [] - formats.extend(["intel", "fat64", "fat32"]) - - elif cpu_arch == "i386": - if version < (10, 4): - return [] - formats.extend(["intel", "fat32", "fat"]) - - elif cpu_arch == "ppc64": - # TODO: Need to care about 32-bit PPC for ppc64 through 10.2? - if version > (10, 5) or version < (10, 4): - return [] - formats.append("fat64") - - elif cpu_arch == "ppc": - if version > (10, 6): - return [] - formats.extend(["fat32", "fat"]) - - formats.append("universal") - return formats - - -def _mac_platforms(version=None, arch=None): - version_str, _, cpu_arch = platform.mac_ver() - if version is None: - version = tuple(map(int, version_str.split(".")[:2])) - if arch is None: - arch = _mac_arch(cpu_arch) - platforms = [] - for minor_version in range(version[1], -1, -1): - compat_version = version[0], minor_version - binary_formats = _mac_binary_formats(compat_version, arch) - for binary_format in binary_formats: - platforms.append( - "macosx_{major}_{minor}_{binary_format}".format( - major=compat_version[0], - minor=compat_version[1], - binary_format=binary_format, - ) - ) - return platforms - - -# From PEP 513. -def _is_manylinux_compatible(name, glibc_version): - # Check for presence of _manylinux module. - try: - import _manylinux - - return bool(getattr(_manylinux, name + "_compatible")) - except (ImportError, AttributeError): - # Fall through to heuristic check below. - pass - - return _have_compatible_glibc(*glibc_version) - - -def _glibc_version_string(): - # Returns glibc version string, or None if not using glibc. - import ctypes - - # 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. - process_namespace = ctypes.CDLL(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() - # py2 / py3 compatibility: - if not isinstance(version_str, str): - version_str = version_str.decode("ascii") - - return version_str - - -# Separated out from have_compatible_glibc for easier unit testing. -def _check_glibc_version(version_str, required_major, minimum_minor): - # Parse string and check against requested 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[0-9]+)\.(?P[0-9]+)", version_str) - if not m: - warnings.warn( - "Expected glibc version with 2 components major.minor," - " got: %s" % version_str, - RuntimeWarning, - ) - return False - return ( - int(m.group("major")) == required_major - and int(m.group("minor")) >= minimum_minor - ) - - -def _have_compatible_glibc(required_major, minimum_minor): - version_str = _glibc_version_string() - if version_str is None: - return False - return _check_glibc_version(version_str, required_major, minimum_minor) - - -def _linux_platforms(is_32bit=_32_BIT_INTERPRETER): - linux = _normalize_string(distutils.util.get_platform()) - if linux == "linux_x86_64" and is_32bit: - linux = "linux_i686" - manylinux_support = ( - ("manylinux2014", (2, 17)), # CentOS 7 w/ glibc 2.17 (PEP 599) - ("manylinux2010", (2, 12)), # CentOS 6 w/ glibc 2.12 (PEP 571) - ("manylinux1", (2, 5)), # CentOS 5 w/ glibc 2.5 (PEP 513) - ) - manylinux_support_iter = iter(manylinux_support) - for name, glibc_version in manylinux_support_iter: - if _is_manylinux_compatible(name, glibc_version): - platforms = [linux.replace("linux", name)] - break - else: - platforms = [] - # Support for a later manylinux implies support for an earlier version. - platforms += [linux.replace("linux", name) for name, _ in manylinux_support_iter] - platforms.append(linux) - return platforms - - -def _generic_platforms(): - platform = _normalize_string(distutils.util.get_platform()) - return [platform] - - -def _interpreter_name(): - name = platform.python_implementation().lower() - return INTERPRETER_SHORT_NAMES.get(name) or name - - -def _generic_interpreter(name, py_version): - version = sysconfig.get_config_var("py_version_nodot") - if not version: - version = "".join(map(str, py_version[:2])) - return "{name}{version}".format(name=name, version=version) - - -def sys_tags(): - """ - 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. - """ - py_version = sys.version_info[:2] - interpreter_name = _interpreter_name() - if platform.system() == "Darwin": - platforms = _mac_platforms() - elif platform.system() == "Linux": - platforms = _linux_platforms() - else: - platforms = _generic_platforms() - - if interpreter_name == "cp": - interpreter = _cpython_interpreter(py_version) - abis = _cpython_abis(py_version) - for tag in _cpython_tags(py_version, interpreter, abis, platforms): - yield tag - elif interpreter_name == "pp": - interpreter = _pypy_interpreter() - abi = _generic_abi() - for tag in _pypy_tags(py_version, interpreter, abi, platforms): - yield tag - else: - interpreter = _generic_interpreter(interpreter_name, py_version) - abi = _generic_abi() - for tag in _generic_tags(interpreter, py_version, abi, platforms): - yield tag - for tag in _independent_tags(interpreter, py_version, platforms): - yield tag diff --git a/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/utils.py b/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/utils.py deleted file mode 100644 index 8841878..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/utils.py +++ /dev/null @@ -1,57 +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 re - -from .version import InvalidVersion, Version - - -_canonicalize_regex = re.compile(r"[-_.]+") - - -def canonicalize_name(name): - # This is taken from PEP 503. - return _canonicalize_regex.sub("-", name).lower() - - -def canonicalize_version(version): - """ - This is very similar to Version.__str__, but has one subtle differences - with the way it handles the release segment. - """ - - try: - version = Version(version) - except InvalidVersion: - # Legacy versions cannot be normalized - return version - - parts = [] - - # Epoch - if version.epoch != 0: - parts.append("{0}!".format(version.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))) - - # Pre-release - if version.pre is not None: - parts.append("".join(str(x) for x in version.pre)) - - # Post-release - if version.post is not None: - parts.append(".post{0}".format(version.post)) - - # Development release - if version.dev is not None: - parts.append(".dev{0}".format(version.dev)) - - # Local version segment - if version.local is not None: - parts.append("+{0}".format(version.local)) - - return "".join(parts) diff --git a/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/version.py b/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/version.py deleted file mode 100644 index 95157a1..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/_vendor/packaging/version.py +++ /dev/null @@ -1,420 +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 collections -import itertools -import re - -from ._structures import Infinity - - -__all__ = ["parse", "Version", "LegacyVersion", "InvalidVersion", "VERSION_PATTERN"] - - -_Version = collections.namedtuple( - "_Version", ["epoch", "release", "dev", "pre", "post", "local"] -) - - -def parse(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 - a valid PEP 440 version or a legacy version. - """ - try: - return Version(version) - except InvalidVersion: - return LegacyVersion(version) - - -class InvalidVersion(ValueError): - """ - An invalid version was found, users should refer to PEP 440. - """ - - -class _BaseVersion(object): - def __hash__(self): - return hash(self._key) - - def __lt__(self, other): - return self._compare(other, lambda s, o: s < o) - - def __le__(self, other): - return self._compare(other, lambda s, o: s <= o) - - def __eq__(self, other): - return self._compare(other, lambda s, o: s == o) - - def __ge__(self, other): - return self._compare(other, lambda s, o: s >= o) - - def __gt__(self, other): - return self._compare(other, lambda s, o: s > o) - - def __ne__(self, other): - return self._compare(other, lambda s, o: s != o) - - def _compare(self, other, method): - if not isinstance(other, _BaseVersion): - return NotImplemented - - return method(self._key, other._key) - - -class LegacyVersion(_BaseVersion): - def __init__(self, version): - self._version = str(version) - self._key = _legacy_cmpkey(self._version) - - def __str__(self): - return self._version - - def __repr__(self): - return "".format(repr(str(self))) - - @property - def public(self): - return self._version - - @property - def base_version(self): - return self._version - - @property - def epoch(self): - return -1 - - @property - def release(self): - return None - - @property - def pre(self): - return None - - @property - def post(self): - return None - - @property - def dev(self): - return None - - @property - def local(self): - return None - - @property - def is_prerelease(self): - return False - - @property - def is_postrelease(self): - return False - - @property - def is_devrelease(self): - return False - - -_legacy_version_component_re = re.compile(r"(\d+ | [a-z]+ | \.| -)", re.VERBOSE) - -_legacy_version_replacement_map = { - "pre": "c", - "preview": "c", - "-": "final-", - "rc": "c", - "dev": "@", -} - - -def _parse_version_parts(s): - for part in _legacy_version_component_re.split(s): - part = _legacy_version_replacement_map.get(part, part) - - if not part or part == ".": - continue - - if part[:1] in "0123456789": - # pad for numeric comparison - yield part.zfill(8) - else: - yield "*" + part - - # ensure that alpha/beta/candidate are before final - yield "*final" - - -def _legacy_cmpkey(version): - # 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, - # which uses the defacto standard originally implemented by setuptools, - # as before all PEP 440 versions. - epoch = -1 - - # This scheme is taken from pkg_resources.parse_version setuptools prior to - # it's adoption of the packaging library. - parts = [] - for part in _parse_version_parts(version.lower()): - if part.startswith("*"): - # remove "-" before a prerelease tag - if part < "*final": - while parts and parts[-1] == "*final-": - parts.pop() - - # remove trailing zeros from each series of numeric parts - while parts and parts[-1] == "00000000": - parts.pop() - - parts.append(part) - parts = tuple(parts) - - return epoch, parts - - -# Deliberately not anchored to the start and end of the string, to make it -# easier for 3rd party code to reuse -VERSION_PATTERN = r""" - v? - (?: - (?:(?P[0-9]+)!)? # epoch - (?P[0-9]+(?:\.[0-9]+)*) # release segment - (?P

                                          # pre-release
-            [-_\.]?
-            (?P(a|b|c|rc|alpha|beta|pre|preview))
-            [-_\.]?
-            (?P[0-9]+)?
-        )?
-        (?P                                         # post release
-            (?:-(?P[0-9]+))
-            |
-            (?:
-                [-_\.]?
-                (?Ppost|rev|r)
-                [-_\.]?
-                (?P[0-9]+)?
-            )
-        )?
-        (?P                                          # dev release
-            [-_\.]?
-            (?Pdev)
-            [-_\.]?
-            (?P[0-9]+)?
-        )?
-    )
-    (?:\+(?P[a-z0-9]+(?:[-_\.][a-z0-9]+)*))?       # local version
-"""
-
-
-class Version(_BaseVersion):
-
-    _regex = re.compile(r"^\s*" + VERSION_PATTERN + r"\s*$", re.VERBOSE | re.IGNORECASE)
-
-    def __init__(self, version):
-        # Validate the version and parse it into pieces
-        match = self._regex.search(version)
-        if not match:
-            raise InvalidVersion("Invalid version: '{0}'".format(version))
-
-        # Store the parsed out pieces of the version
-        self._version = _Version(
-            epoch=int(match.group("epoch")) if match.group("epoch") else 0,
-            release=tuple(int(i) for i in match.group("release").split(".")),
-            pre=_parse_letter_version(match.group("pre_l"), match.group("pre_n")),
-            post=_parse_letter_version(
-                match.group("post_l"), match.group("post_n1") or match.group("post_n2")
-            ),
-            dev=_parse_letter_version(match.group("dev_l"), match.group("dev_n")),
-            local=_parse_local_version(match.group("local")),
-        )
-
-        # Generate a key which will be used for sorting
-        self._key = _cmpkey(
-            self._version.epoch,
-            self._version.release,
-            self._version.pre,
-            self._version.post,
-            self._version.dev,
-            self._version.local,
-        )
-
-    def __repr__(self):
-        return "".format(repr(str(self)))
-
-    def __str__(self):
-        parts = []
-
-        # Epoch
-        if self.epoch != 0:
-            parts.append("{0}!".format(self.epoch))
-
-        # Release segment
-        parts.append(".".join(str(x) for x in self.release))
-
-        # Pre-release
-        if self.pre is not None:
-            parts.append("".join(str(x) for x in self.pre))
-
-        # Post-release
-        if self.post is not None:
-            parts.append(".post{0}".format(self.post))
-
-        # Development release
-        if self.dev is not None:
-            parts.append(".dev{0}".format(self.dev))
-
-        # Local version segment
-        if self.local is not None:
-            parts.append("+{0}".format(self.local))
-
-        return "".join(parts)
-
-    @property
-    def epoch(self):
-        return self._version.epoch
-
-    @property
-    def release(self):
-        return self._version.release
-
-    @property
-    def pre(self):
-        return self._version.pre
-
-    @property
-    def post(self):
-        return self._version.post[1] if self._version.post else None
-
-    @property
-    def dev(self):
-        return self._version.dev[1] if self._version.dev else None
-
-    @property
-    def local(self):
-        if self._version.local:
-            return ".".join(str(x) for x in self._version.local)
-        else:
-            return None
-
-    @property
-    def public(self):
-        return str(self).split("+", 1)[0]
-
-    @property
-    def base_version(self):
-        parts = []
-
-        # Epoch
-        if self.epoch != 0:
-            parts.append("{0}!".format(self.epoch))
-
-        # Release segment
-        parts.append(".".join(str(x) for x in self.release))
-
-        return "".join(parts)
-
-    @property
-    def is_prerelease(self):
-        return self.dev is not None or self.pre is not None
-
-    @property
-    def is_postrelease(self):
-        return self.post is not None
-
-    @property
-    def is_devrelease(self):
-        return self.dev is not None
-
-
-def _parse_letter_version(letter, number):
-    if letter:
-        # We consider there to be an implicit 0 in a pre-release if there is
-        # not a numeral associated with it.
-        if number is None:
-            number = 0
-
-        # We normalize any letters to their lower case form
-        letter = letter.lower()
-
-        # We consider some words to be alternate spellings of other words and
-        # in those cases we want to normalize the spellings to our preferred
-        # spelling.
-        if letter == "alpha":
-            letter = "a"
-        elif letter == "beta":
-            letter = "b"
-        elif letter in ["c", "pre", "preview"]:
-            letter = "rc"
-        elif letter in ["rev", "r"]:
-            letter = "post"
-
-        return letter, int(number)
-    if not letter and number:
-        # We assume if we are given a number, but we are not given a letter
-        # then this is using the implicit post release syntax (e.g. 1.0-1)
-        letter = "post"
-
-        return letter, int(number)
-
-
-_local_version_separators = re.compile(r"[\._-]")
-
-
-def _parse_local_version(local):
-    """
-    Takes a string like abc.1.twelve and turns it into ("abc", 1, "twelve").
-    """
-    if local is not None:
-        return tuple(
-            part.lower() if not part.isdigit() else int(part)
-            for part in _local_version_separators.split(local)
-        )
-
-
-def _cmpkey(epoch, release, pre, post, dev, local):
-    # 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
-    # leading zeros until we come to something non zero, then take the rest
-    # re-reverse it back into the correct order and make it a tuple and use
-    # that for our sorting key.
-    release = tuple(
-        reversed(list(itertools.dropwhile(lambda x: x == 0, reversed(release))))
-    )
-
-    # We need to "trick" the sorting algorithm to put 1.0.dev0 before 1.0a0.
-    # We'll do this by abusing the pre segment, but we _only_ want to do this
-    # 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 = -Infinity
-    # Versions without a pre-release (except as noted above) should sort after
-    # those with one.
-    elif pre is None:
-        pre = Infinity
-
-    # Versions without a post segment should sort before those with one.
-    if post is None:
-        post = -Infinity
-
-    # Versions without a development segment should sort after those with one.
-    if dev is None:
-        dev = Infinity
-
-    if local is None:
-        # Versions without a local segment should sort before those with one.
-        local = -Infinity
-    else:
-        # Versions with a local segment need that segment parsed to implement
-        # the sorting rules in PEP440.
-        # - Alpha numeric segments sort before numeric segments
-        # - Alpha numeric segments sort lexicographically
-        # - Numeric segments sort numerically
-        # - Shorter versions sort before longer versions when the prefixes
-        #   match exactly
-        local = tuple((i, "") if isinstance(i, int) else (-Infinity, i) for i in local)
-
-    return epoch, release, pre, post, dev, local
diff --git a/venv/lib/python3.8/site-packages/setuptools/_vendor/pyparsing.py b/venv/lib/python3.8/site-packages/setuptools/_vendor/pyparsing.py
deleted file mode 100644
index cf75e1e..0000000
--- a/venv/lib/python3.8/site-packages/setuptools/_vendor/pyparsing.py
+++ /dev/null
@@ -1,5742 +0,0 @@
-# module pyparsing.py
-#
-# Copyright (c) 2003-2018  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 
-C{", !"}), built up using L{Word}, L{Literal}, and L{And} elements 
-(L{'+'} operator gives L{And} expressions, strings are auto-converted to
-L{Literal} expressions)::
-
-    from 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 L{ParseResults} object returned from L{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 L{ParserElement} and L{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 L{Literal} and L{CaselessLiteral} classes
- - construct character word-group expressions using the L{Word} class
- - see how to create repetitive expressions using L{ZeroOrMore} and L{OneOrMore} classes
- - use L{'+'}, L{'|'}, L{'^'}, and L{'&'} operators to combine simple expressions into more complex ones
- - associate names with your parsed results using L{ParserElement.setResultsName}
- - find some helpful expression short-cuts like L{delimitedList} and L{oneOf}
- - find more useful common expressions in the L{pyparsing_common} namespace class
-"""
-
-__version__ = "2.2.1"
-__versionTime__ = "18 Sep 2018 00:49 UTC"
-__author__ = "Paul McGuire "
-
-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
-
-try:
-    from _thread import RLock
-except ImportError:
-    from threading import RLock
-
-try:
-    # Python 3
-    from collections.abc import Iterable
-    from collections.abc import MutableMapping
-except ImportError:
-    # Python 2.7
-    from collections import Iterable
-    from collections import MutableMapping
-
-try:
-    from collections import OrderedDict as _OrderedDict
-except ImportError:
-    try:
-        from ordereddict import OrderedDict as _OrderedDict
-    except ImportError:
-        _OrderedDict = None
-
-#~ sys.stderr.write( "testing pyparsing module, version %s, %s\n" % (__version__,__versionTime__ ) )
-
-__all__ = [
-'And', 'CaselessKeyword', 'CaselessLiteral', 'CharsNotIn', 'Combine', 'Dict', 'Each', 'Empty',
-'FollowedBy', 'Forward', 'GoToColumn', 'Group', 'Keyword', 'LineEnd', 'LineStart', 'Literal',
-'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',
-'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',
-]
-
-system_version = tuple(sys.version_info)[:3]
-PY_3 = system_version[0] == 3
-if PY_3:
-    _MAX_INT = sys.maxsize
-    basestring = str
-    unichr = chr
-    _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
-
-class _Constants(object):
-    pass
-
-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)
-
-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 ):
-        return "%s (at char %d), (line:%d, col:%d)" % \
-                ( self.msg, 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
-    """
-    pass
-
-class ParseFatalException(ParseBaseException):
-    """user-throwable exception thrown when inconsistent parse content
-       is found; stops all parsing immediately"""
-    pass
-
-class ParseSyntaxException(ParseFatalException):
-    """just like L{ParseFatalException}, but thrown internally when an
-       L{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 L{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 (C{len(results)})
-       - by list index (C{results[0], results[1]}, etc.)
-       - by attribute (C{results.} - see L{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(toklist.copy(),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 (Python 3.x only)."""
-
-        values = _itervalues
-        """Returns an iterator of all named result values (Python 3.x only)."""
-
-        items = _iteritems
-        """Returns an iterator of all named result key-value tuples (Python 3.x only)."""
-
-    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=C{last}).
-        Supports both C{list} and C{dict} semantics for C{pop()}. If passed no
-        argument or an integer argument, it will use C{list} semantics
-        and pop tokens from the list of parsed tokens. If passed a 
-        non-integer argument (most likely a string), it will use C{dict}
-        semantics and pop the corresponding value from any defined 
-        results names. A second default return value argument is 
-        supported, just as in C{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 C{defaultValue} or C{None} if no
-        C{defaultValue} is specified.
-
-        Similar to C{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 C{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 += 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 ""
-            
-        if name in self.__tokdict:
-            if name not in self.__accumNames:
-                return self.__tokdict[name][-1][0]
-            else:
-                return ParseResults([ v[0] for v in self.__tokdict[name] ])
-        else:
-            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) # ->  ['sldkj', 'lsdkj', 'sldkj']
-            
-            # Use asList() to create an actual list
-            result_list = result.asList()
-            print(type(result_list), result_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)) # ->  (['12', '/', '31', '/', '1999'], {'day': [('1999', 4)], 'year': [('12', 0)], 'month': [('31', 2)]})
-            
-            result_dict = result.asDict()
-            print(type(result_dict), repr(result_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 C{ParseResults} object.
-        """
-        ret = ParseResults( self.__toklist )
-        ret.__tokdict = self.__tokdict.copy()
-        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,
-                                                "" ]
-
-        out += [ nl, indent, "" ]
-        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='', depth=0, full=True):
-        """
-        Diagnostic method for listing out the contents of a C{ParseResults}.
-        Accepts an optional C{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'
-        out.append( indent+_ustr(self.asList()) )
-        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,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,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 C{pprint} module.
-        Accepts additional positional or keyword args as defined for the 
-        C{pprint.pprint} method. (U{http://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()))
-
-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 L{I{ParserElement.parseString}} for more information
-   on parsing strings containing C{}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} for more information
-   on parsing strings containing C{}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:
-                        del tb
-
-                if limit[0] <= maxargs:
-                    limit[0] += 1
-                    continue
-                raise
-
-    # copy func name to wrapper for sensible debug output
-    func_name = ""
-    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,  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
-
-    def __init__( self, savelist=False ):
-        self.parseAction = list()
-        self.failAction = None
-        #~ self.name = ""  # don't define self.name, let subclasses try/except upcall
-        self.strRepr = None
-        self.resultsName = None
-        self.saveAsList = savelist
-        self.skipWhitespace = True
-        self.whiteChars = 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 C{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 C{expr.copy()} is just C{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 hasattr(self,"exception"):
-            self.exception.msg = self.errmsg
-        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 C{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,
-        C{expr("name")} in place of C{expr.setResultsName("name")} - 
-        see L{I{__call__}<__call__>}.
-
-        Example::
-            date_str = (integer.setResultsName("year") + '/' 
-                        + integer.setResultsName("month") + '/' 
-                        + integer.setResultsName("day"))
-
-            # equivalent form:
-            date_str = integer("year") + '/' + integer("month") + '/' + integer("day")
-        """
-        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 C{breakFlag} to True to enable, False to
-           disable.
-        """
-        if breakFlag:
-            _parseMethod = self._parse
-            def breaker(instring, loc, doActions=True, callPreParse=True):
-                import pdb
-                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 C{fn(s,loc,toks)},
-        C{fn(loc,toks)}, C{fn(toks)}, or just C{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 C{L{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.
-
-        Optional keyword arguments:
-         - callDuringTry = (default=C{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 L{I{parseString}} for more information
-        on parsing strings containing C{}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]
-        """
-        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 L{I{setParseAction}}.
-        
-        See examples in L{I{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 
-        L{I{setParseAction}} for function call signatures. Unlike C{setParseAction}, 
-        functions passed to C{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)
-        """
-        msg = kwargs.get("message", "failed user-defined condition")
-        exc_type = ParseFatalException if kwargs.get("fatal", False) else ParseException
-        for fn in fns:
-            def pa(s,l,t):
-                if not bool(_trim_arity(fn)(s,l,t)):
-                    raise exc_type(s,l,msg)
-            self.parseAction.append(pa)
-        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
-           C{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 C{L{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 ):
-        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[0] ):
-                self.debugActions[0]( instring, loc, self )
-            if callPreParse and self.callPreparse:
-                preloc = self.preParse( instring, loc )
-            else:
-                preloc = loc
-            tokensStart = preloc
-            try:
-                try:
-                    loc,tokens = self.parseImpl( instring, preloc, doActions )
-                except IndexError:
-                    raise ParseException( instring, len(instring), self.errmsg, self )
-            except ParseBaseException as err:
-                #~ print ("Exception raised:", err)
-                if self.debugActions[2]:
-                    self.debugActions[2]( 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:
-                        tokens = fn( instring, tokensStart, retTokens )
-                        if tokens is not None:
-                            retTokens = ParseResults( tokens,
-                                                      self.resultsName,
-                                                      asList=self.saveAsList and isinstance(tokens,(ParseResults,list)),
-                                                      modal=self.modalResults )
-                except ParseBaseException as err:
-                    #~ print "Exception raised in user parse action:", err
-                    if (self.debugActions[2] ):
-                        self.debugActions[2]( instring, tokensStart, self, err )
-                    raise
-            else:
-                for fn in self.parseAction:
-                    tokens = fn( instring, tokensStart, retTokens )
-                    if tokens is not None:
-                        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[1] ):
-                self.debugActions[1]( 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=C{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 C{ParserElement.enablePackrat()}.  If
-           your program uses C{psyco} to "compile as you go", you must call
-           C{enablePackrat} before calling C{psyco.full()}.  If you do not do this,
-           Python will crash.  For best results, call C{enablePackrat()} immediately
-           after importing pyparsing.
-           
-           Example::
-               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.
-
-        If you want the grammar to require that the entire input string be
-        successfully parsed, then set C{parseAll} to True (equivalent to ending
-        the grammar with C{L{StringEnd()}}).
-
-        Note: C{parseString} implicitly calls C{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 C{loc} argument to index into the
-        string being parsed, you can ensure you have a consistent view of the input
-        string by:
-         - calling C{parseWithTabs} on your grammar before calling C{parseString}
-           (see L{I{parseWithTabs}})
-         - define your parse action using the full C{(s,loc,toks)} signature, and
-           reference the input string using the parse action's C{s} argument
-         - explictly expand the tabs in your input string before calling
-           C{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, clears out pyparsing internal stack trace
-                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
-        C{maxMatches} argument, to clip scanning after 'n' matches are found.  If
-        C{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 L{I{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, clears out pyparsing internal stack trace
-                raise exc
-
-    def transformString( self, instring ):
-        """
-        Extension to C{L{scanString}}, to modify matching text with modified tokens that may
-        be returned from a parse action.  To use C{transformString}, define a grammar and
-        attach a parse action to it that modifies the returned token list.
-        Invoking C{transformString()} on a target string will then scan for matches,
-        and replace the matched text patterns according to the logic in the parse
-        action.  C{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 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, clears out pyparsing internal stack trace
-                raise exc
-
-    def searchString( self, instring, maxMatches=_MAX_INT ):
-        """
-        Another extension to C{L{scanString}}, simplifying the access to the tokens found
-        to match the given parse expression.  May be called with optional
-        C{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, clears out pyparsing internal stack trace
-                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 C{maxsplit} argument, to limit the number of splits;
-        and the optional C{includeSeparators} argument (default=C{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 C{L{And}}. Adding strings to a ParserElement
-        converts them to L{Literal}s by default.
-        
-        Example::
-            greet = Word(alphas) + "," + Word(alphas) + "!"
-            hello = "Hello, World!"
-            print (hello, "->", greet.parseString(hello))
-        Prints::
-            Hello, World! -> ['Hello', ',', 'World', '!']
-        """
-        if isinstance( other, basestring ):
-            other = ParserElement._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 C{L{ParserElement}}
-        """
-        if isinstance( other, basestring ):
-            other = ParserElement._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 C{L{And}} with error stop
-        """
-        if isinstance( other, basestring ):
-            other = ParserElement._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 C{L{ParserElement}}
-        """
-        if isinstance( other, basestring ):
-            other = ParserElement._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 C{expr * 3} in place of
-        C{expr + expr + expr}.  Expressions may also me multiplied by a 2-integer
-        tuple, similar to C{{min,max}} multipliers in regular expressions.  Tuples
-        may also include C{None} as in:
-         - C{expr*(n,None)} or C{expr*(n,)} is equivalent
-              to C{expr*n + L{ZeroOrMore}(expr)}
-              (read as "at least n instances of C{expr}")
-         - C{expr*(None,n)} is equivalent to C{expr*(0,n)}
-              (read as "0 to n instances of C{expr}")
-         - C{expr*(None,None)} is equivalent to C{L{ZeroOrMore}(expr)}
-         - C{expr*(1,None)} is equivalent to C{L{OneOrMore}(expr)}
-
-        Note that C{expr*(None,n)} does not raise an exception if
-        more than n exprs exist in the input stream; that is,
-        C{expr*(None,n)} does not enforce a maximum number of expr
-        occurrences.  If this behavior is desired, then write
-        C{expr*(None,n) + ~expr}
-        """
-        if isinstance(other,int):
-            minElements, optElements = other,0
-        elif isinstance(other,tuple):
-            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 C{L{MatchFirst}}
-        """
-        if isinstance( other, basestring ):
-            other = ParserElement._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 C{L{ParserElement}}
-        """
-        if isinstance( other, basestring ):
-            other = ParserElement._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 C{L{Or}}
-        """
-        if isinstance( other, basestring ):
-            other = ParserElement._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 C{L{ParserElement}}
-        """
-        if isinstance( other, basestring ):
-            other = ParserElement._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 C{L{Each}}
-        """
-        if isinstance( other, basestring ):
-            other = ParserElement._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 C{L{ParserElement}}
-        """
-        if isinstance( other, basestring ):
-            other = ParserElement._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 C{L{NotAny}}
-        """
-        return NotAny( self )
-
-    def __call__(self, name=None):
-        """
-        Shortcut for C{L{setResultsName}}, with C{listAllMatches=False}.
-        
-        If C{name} is given with a trailing C{'*'} character, then C{listAllMatches} will be
-        passed as C{True}.
-           
-        If C{name} is omitted, same as calling C{L{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 C{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
-        C{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 C{}s to spaces before parsing the input string.
-        Must be called before C{parseString} when the input grammar contains elements that
-        match C{} 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 C{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 L{setDebugActions}. Prior to attempting
-        to match the C{wd} expression, the debugging message C{"Match  at loc (,)"}
-        is shown. Then if the parse succeeds, a C{"Matched"} message is shown, or an C{"Exception raised"}
-        message is shown. Also note the use of L{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 C{Word} expression without calling C{setName} is C{"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=[] ):
-        """
-        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, clears out pyparsing internal stack trace
-                raise exc
-
-    def __eq__(self,other):
-        if isinstance(other, ParserElement):
-            return self is other or vars(self) == vars(other)
-        elif isinstance(other, basestring):
-            return self.matches(other)
-        else:
-            return super(ParserElement,self)==other
-
-    def __ne__(self,other):
-        return not (self == other)
-
-    def __hash__(self):
-        return hash(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=C{True}) - flag to pass to C{L{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):
-        """
-        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=C{True}) - flag to pass to C{L{parseString}} when running tests           
-         - comment - (default=C{'#'}) - expression for indicating embedded comments in the test 
-              string; pass None to disable comment filtering
-         - fullDump - (default=C{True}) - dump results as list followed by results names in nested outline;
-              if False, only dump nested list
-         - printResults - (default=C{True}) prints test output to stdout
-         - failureTests - (default=C{False}) indicates if these tests are expected to fail parsing
-
-        Returns: a (success, results) tuple, where success indicates that all tests succeeded
-        (or failed if C{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)
-        allResults = []
-        comments = []
-        success = True
-        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'.join(comments), t]
-            comments = []
-            try:
-                t = t.replace(r'\n','\n')
-                result = self.parseString(t, parseAll=parseAll)
-                out.append(result.dump(full=fullDump))
-                success = success and not failureTests
-            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
-
-            if printResults:
-                if fullDump:
-                    out.append('')
-                print('\n'.join(out))
-
-            allResults.append((t, result))
-        
-        return success, allResults
-
-        
-class Token(ParserElement):
-    """
-    Abstract C{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 L{CaselessLiteral}.
-    
-    For keyword matching (force word break before and after the matched string),
-    use L{Keyword} or L{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: this routine gets called a *lot*
-    # if this is a single character match string  and the first character matches,
-    # short-circuit as quickly as possible, and avoid calling startswith
-    #~ @profile
-    def parseImpl( self, instring, loc, doActions=True ):
-        if (instring[loc] == self.firstMatchChar and
-            (self.matchLen==1 or instring.startswith(self.match,loc)) ):
-            return loc+self.matchLen, 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 C{L{Literal}}:
-     - C{Literal("if")} will match the leading C{'if'} in C{'ifAndOnlyIf'}.
-     - C{Keyword("if")} will not; it will only match the leading C{'if'} in C{'if x=1'}, or C{'if(y==2)'}
-    Accepts two optional constructor arguments in addition to the keyword string:
-     - C{identChars} is a string of characters that would be valid identifier characters,
-          defaulting to all alphanumerics + "_" and "$"
-     - C{caseless} allows case-insensitive matching, default is C{False}.
-       
-    Example::
-        Keyword("start").parseString("start")  # -> ['start']
-        Keyword("start").parseString("starting")  # -> Exception
-
-    For case-insensitive matching, use L{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 and
-                (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 L{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 L{Keyword}.
-
-    Example::
-        OneOrMore(CaselessKeyword("CMD")).parseString("cmd CMD Cmd10") # -> ['CMD', 'CMD']
-        
-    (Contrast with example for L{CaselessLiteral}.)
-    """
-    def __init__( self, matchString, identChars=None ):
-        super(CaselessKeyword,self).__init__( matchString, identChars, caseless=True )
-
-    def parseImpl( self, instring, loc, doActions=True ):
-        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) ):
-            return loc+self.matchLen, self.match
-        raise ParseException(instring, loc, self.errmsg, self)
-
-class CloseMatch(Token):
-    """
-    A variation on L{Literal} which matches "close" matches, that is, 
-    strings with at most 'n' mismatching characters. C{CloseMatch} takes parameters:
-     - C{match_string} - string to be matched
-     - C{maxMismatches} - (C{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:
-     - C{mismatches} - a list of the positions within the match_string where mismatches were found
-     - C{original} - the original match_string used to compare against the input string
-    
-    If C{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], self.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'] = self.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 C{min} is 1 (a
-    minimum value < 1 is not valid); the default values for C{max} and C{exact}
-    are 0, meaning no maximum or exact length restriction. An optional
-    C{excludeChars} parameter can list characters that might be found in 
-    the input C{bodyChars} string; useful to define a word of all printables
-    except for one or two characters, for instance.
-    
-    L{srange} is useful for defining custom character set strings for defining 
-    C{Word} expressions, using range notation from regular expression character sets.
-    
-    A common mistake is to use C{Word} to match a specific literal string, as in 
-    C{Word("Address")}. Remember that C{Word} uses the string argument to define
-    I{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 L{Literal} or L{Keyword}.
-
-    pyparsing includes helper strings for building Words:
-     - L{alphas}
-     - L{nums}
-     - L{alphanums}
-     - L{hexnums}
-     - L{alphas8bit} (alphabetic characters in ASCII range 128-255 - accented, tilded, umlauted, etc.)
-     - L{punc8bit} (non-alphabetic characters in ASCII range 128-255 - currency, symbols, superscripts, diacriticals, etc.)
-     - L{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:
-            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
-
-    def parseImpl( self, instring, loc, doActions=True ):
-        if self.re:
-            result = self.re.match(instring,loc)
-            if not result:
-                raise ParseException(instring, loc, self.errmsg, self)
-
-            loc = result.end()
-            return loc, result.group()
-
-        if not(instring[ loc ] 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
-        if self.maxSpecified and loc < instrlen and instring[loc] in bodychars:
-            throwException = True
-        if self.asKeyword:
-            if (start>0 and instring[start-1] in bodychars) or (loc4:
-                    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 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 inbuilt Python re module.
-    If the given regex contains named groups (defined using C{(?P...)}), these will be preserved as 
-    named parse results.
-
-    Example::
-        realnum = Regex(r"[+-]?\d+\.\d*")
-        date = Regex(r'(?P\d{4})-(?P\d\d?)-(?P\d\d?)')
-        # ref: http://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?C{0,3})(XC|XL|L?X{0,3})(IX|IV|V?I{0,3})")
-    """
-    compiledREtype = type(re.compile("[A-Z]"))
-    def __init__( self, pattern, flags=0):
-        """The parameters C{pattern} and C{flags} are passed to the C{re.compile()} function as-is. See the Python C{re} 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 isinstance(pattern, Regex.compiledREtype):
-            self.re = pattern
-            self.pattern = \
-            self.reString = str(pattern)
-            self.flags = flags
-            
-        else:
-            raise ValueError("Regex may only be constructed with a string or a compiled RE object")
-
-        self.name = _ustr(self)
-        self.errmsg = "Expected " + self.name
-        self.mayIndexError = False
-        self.mayReturnEmpty = True
-
-    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()
-        d = result.groupdict()
-        ret = ParseResults(result.group())
-        if d:
-            for k in d:
-                ret[k] = d[k]
-        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
-
-
-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=C{None})
-        - escQuote - special quote sequence to escape an embedded quote string (such as SQL's "" to escape an embedded ") (default=C{None})
-        - multiline - boolean indicating whether quotes can span multiple lines (default=C{False})
-        - unquoteResults - boolean indicating whether the matched text should be unquoted (default=C{True})
-        - endQuoteChar - string of one or more characters defining the end of the quote delimited string (default=C{None} => same as quoteChar)
-        - convertWhitespaceEscapes - convert escaped whitespace (C{'\t'}, C{'\n'}, etc.) to actual whitespace (default=C{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
-        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 I{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 C{min} is 1 (a
-    minimum value < 1 is not valid); the default values for C{max} and C{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 C{" \\t\\r\\n"}.  Also takes optional C{min}, C{max}, and C{exact} arguments,
-    as defined for the C{L{Word}} class.
-    """
-    whiteStrs = {
-        " " : "",
-        "\t": "",
-        "\n": "",
-        "\r": "",
-        "\f": "",
-        }
-    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 not(instring[ loc ] 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):
-    """
-    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):
-            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 C{wordChars}
-    (default=C{printables}). To emulate the C{\b} behavior of regular expressions,
-    use C{WordStart(alphanums)}. C{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 C{wordChars}
-    (default=C{printables}). To emulate the C{\b} behavior of regular expressions,
-    use C{WordEnd(alphanums)}. C{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 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:
-            matches.sort(key=lambda x: -x[0])
-            for _,e in matches:
-                try:
-                    return e._parse( instring, loc, doActions )
-                except ParseException as err:
-                    err.__traceback__ = None
-                    if err.loc > maxExcLoc:
-                        maxException = err
-                        maxExcLoc = err.loc
-
-        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 = ParserElement._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 )
-
-
-class MatchFirst(ParseExpression):
-    """
-    Requires that at least one C{ParseExpression} is found.
-    If two expressions match, the first one listed is the one that will match.
-    May be constructed using the C{'|'} 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 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 = ParserElement._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 )
-
-
-class Each(ParseExpression):
-    """
-    Requires all given C{ParseExpression}s to be found, but in any order.
-    Expressions may be separated by whitespace.
-    May be constructed using the C{'&'} 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
-
-    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)]
-            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 C{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(ParserElement._literalStringClass, Token):
-                expr = ParserElement._literalStringClass(expr)
-            else:
-                expr = ParserElement._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=[] ):
-        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.  C{FollowedBy}
-    does I{not} advance the parsing position within the input string, it only
-    verifies that the specified parse expression matches at the current
-    position.  C{FollowedBy} always returns a null token list.
-
-    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 ):
-        self.expr.tryParse( instring, loc )
-        return loc, []
-
-
-class NotAny(ParseElementEnhance):
-    """
-    Lookahead to disallow matching with the given parse expression.  C{NotAny}
-    does I{not} advance the parsing position within the input string, it only
-    verifies that the specified parse expression does I{not} match at the current
-    position.  Also, C{NotAny} does I{not} skip over leading whitespace. C{NotAny}
-    always returns a null token list.  May be constructed using the '~' operator.
-
-    Example::
-        
-    """
-    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 = ParserElement._literalStringClass(ender)
-        self.not_ender = ~ender if ender is not None else None
-
-    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
-        
-class OneOrMore(_MultipleMatch):
-    """
-    Repetition of one or more of the given expression.
-    
-    Parameters:
-     - expr - expression that must match one or more times
-     - stopOn - (default=C{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=C{None}) - expression for a terminating sentinel
-          (only required if the sentinel would ordinarily match the repetition 
-          expression)          
-
-    Example: similar to L{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 ""
-
-_optionalNotMatched = _NullToken()
-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)
-    """
-    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 _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=C{False}) if True, the target expression is also parsed 
-          (the skipped text and target expression are returned as a 2-element list).
-     - ignore - (default=C{None}) used to define grammars (typically quoted strings and 
-          comments) that might contain false matches to the target expression
-     - failOn - (default=C{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.asList = False
-        if isinstance(failOn, basestring):
-            self.failOn = ParserElement._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 C{Forward} variable using the '<<' operator.
-
-    Note: take care when assigning to C{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 C{Forward}::
-        fwdExpr << (a | b | c)
-    Converting to use the '<<=' operator instead will avoid this problem.
-
-    See L{ParseResults.pprint} for an example of a recursive parser created using
-    C{Forward}.
-    """
-    def __init__( self, other=None ):
-        super(Forward,self).__init__( other, savelist=False )
-
-    def __lshift__( self, other ):
-        if isinstance( other, basestring ):
-            other = ParserElement._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=[] ):
-        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
-        return self.__class__.__name__ + ": ..."
-
-        # stubbed out for now - creates awful memory and perf issues
-        self._revertClass = self.__class__
-        self.__class__ = _ForwardNoRecurse
-        try:
-            if self.expr is not None:
-                retString = _ustr(self.expr)
-            else:
-                retString = "None"
-        finally:
-            self.__class__ = self._revertClass
-        return self.__class__.__name__ + ": " + retString
-
-    def copy(self):
-        if self.expr is not None:
-            return super(Forward,self).copy()
-        else:
-            ret = Forward()
-            ret <<= self
-            return ret
-
-class _ForwardNoRecurse(Forward):
-    def __str__( self ):
-        return "..."
-
-class TokenConverter(ParseElementEnhance):
-    """
-    Abstract subclass of C{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 C{'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 C{L{ZeroOrMore}} and C{L{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 L{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 L{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 C{">> entering I{method-name}(line:I{current_source_line}, I{parse_location}, I{matched_tokens})".}
-    When the parse action completes, the decorator will print C{"<<"} 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'], {}))
-        <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( "< ['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 C{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 C{"1:1"}, but not C{"1:2"}.  Because this matches a
-    previous literal, will also match the leading C{"1:1"} in C{"1:10"}.
-    If this is not desired, use C{matchPreviousExpr}.
-    Do I{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 C{"1:1"}, but not C{"1:2"}.  Because this matches by
-    expressions, will I{not} match the leading C{"1:1"} in C{"1:10"};
-    the expressions are evaluated first, and then compared, so
-    C{"1"} is compared with C{"10"}.
-    Do I{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 ):
-    """
-    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 C{L{MatchFirst}} for best performance.
-
-    Parameters:
-     - strs - a string of space-delimited literals, or a collection of string literals
-     - caseless - (default=C{False}) - treat all literals as caseless
-     - useRegex - (default=C{True}) - as an optimization, will generate a Regex
-          object; otherwise, will generate a C{MatchFirst} object (if C{caseless=True}, or
-          if creating a C{Regex} raises an exception)
-
-    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 caseless:
-        isequal = ( lambda a,b: a.upper() == b.upper() )
-        masks = ( lambda a,b: b.upper().startswith(a.upper()) )
-        parseElementClass = CaselessLiteral
-    else:
-        isequal = ( lambda a,b: a == b )
-        masks = ( lambda a,b: b.startswith(a) )
-        parseElementClass = 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()
-
-    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)
-                cur = other
-                break
-        else:
-            i += 1
-
-    if not caseless 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 C{L{Dict}}, C{L{ZeroOrMore}}, and C{L{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 C{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( ZeroOrMore( 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 C{asString} argument is passed as C{False}, then the return value is a 
-    C{L{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 C{L{originalTextFor}} contains expressions with defined
-    results names, you must set C{asString} to C{False} if you want to preserve those
-    results name values.
-
-    Example::
-        src = "this is test  bold text  normal text "
-        for tag in ("b","i"):
-            opener,closer = makeHTMLTags(tag)
-            patt = originalTextFor(opener + SkipTo(closer) + closer)
-            print(patt.searchString(src)[0])
-    prints::
-        [' bold text ']
-        ['text']
-    """
-    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).setParseAction(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 C{} characters, you may want to call
-    C{L{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 C{\-} or C{\]})
-     - an escaped hex character with a leading C{'\x'} (C{\x21}, which is a C{'!'} character) 
-         (C{\0x##} is also supported for backwards compatibility) 
-     - an escaped octal character with a leading C{'\0'} (C{\041}, which is a C{'!'} character)
-     - a range of any of the above, separated by a dash (C{'a-z'}, etc.)
-     - any combination of the above (C{'aeiouy'}, C{'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 C{L{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 C{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 L{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 L{pyparsing_common.upcaseTokens}"""
-
-downcaseTokens = tokenMap(lambda t: _ustr(t).lower())
-"""(Deprecated) Helper parse action to convert tokens to lower case. Deprecated in favor of L{pyparsing_common.downcaseTokens}"""
-    
-def _makeTags(tagStr, xml):
-    """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("<") + tagStr("tag") + \
-                Dict(ZeroOrMore(Group( tagAttrName + Suppress("=") + tagAttrValue ))) + \
-                Optional("/",default=[False]).setResultsName("empty").setParseAction(lambda s,l,t:t[0]=='/') + Suppress(">")
-    else:
-        printablesLessRAbrack = "".join(c for c in printables if c not in ">")
-        tagAttrValue = quotedString.copy().setParseAction( removeQuotes ) | Word(printablesLessRAbrack)
-        openTag = Suppress("<") + tagStr("tag") + \
-                Dict(ZeroOrMore(Group( tagAttrName.setParseAction(downcaseTokens) + \
-                Optional( Suppress("=") + tagAttrValue ) ))) + \
-                Optional("/",default=[False]).setResultsName("empty").setParseAction(lambda s,l,t:t[0]=='/') + Suppress(">")
-    closeTag = Combine(_L("")
-
-    openTag = openTag.setResultsName("start"+"".join(resname.replace(":"," ").title().split())).setName("<%s>" % resname)
-    closeTag = closeTag.setResultsName("end"+"".join(resname.replace(":"," ").title().split())).setName("" % resname)
-    openTag.tag = resname
-    closeTag.tag = resname
-    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 = 'More info at the pyparsing wiki page'
-        # 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  tag (like "href" shown here) are also accessible as named results
-            print(link.link_text, '->', link.href)
-    prints::
-        pyparsing -> http://pyparsing.wikispaces.com
-    """
-    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 L{makeHTMLTags}
-    """
-    return _makeTags( tagStr, True )
-
-def withAttribute(*args,**attrDict):
-    """
-    Helper to create a validating parse action to be used with start tags created
-    with C{L{makeXMLTags}} or C{L{makeHTMLTags}}. Use C{withAttribute} to qualify a starting tag
-    with a required attribute value, to avoid false matches on common tags such as
-    C{} or C{
}. - - Call C{withAttribute} with a series of attribute names and values. Specify the list - of filter attributes names and values as: - - keyword arguments, as in C{(align="right")}, or - - as an explicit dict with C{**} operator, when an attribute name is also a Python - reserved word, as in C{**{"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 C{class} (with or without a namespace), use C{L{withClass}}. - - To verify that the attribute exists, but without specifying a value, pass - C{withAttribute.ANY_VALUE} as the value. - - Example:: - html = ''' -
- Some text -
1 4 0 1 0
-
1,3 2,3 1,1
-
this has no type
-
- - ''' - 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 C{L{withAttribute}} when matching on a div class - made - difficult because C{class} is a reserved word in Python. - - Example:: - html = ''' -
- Some text -
1 4 0 1 0
-
1,3 2,3 1,1
-
this <div> has no class
-
- - ''' - 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 = _Constants() -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 L{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 C{opAssoc.RIGHT} and C{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 C{setParseAction(*fn)} (L{ParserElement.setParseAction}) - - lpar - expression for matching left-parentheses (default=C{Suppress('(')}) - - rpar - expression for matching right-parentheses (default=C{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]]] - """ - 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 = FollowedBy(lastExpr + opExpr) + Group( lastExpr + OneOrMore( opExpr ) ) - elif arity == 2: - if opExpr is not None: - matchExpr = FollowedBy(lastExpr + opExpr + lastExpr) + Group( lastExpr + OneOrMore( opExpr + lastExpr ) ) - else: - matchExpr = FollowedBy(lastExpr+lastExpr) + Group( lastExpr + OneOrMore(lastExpr) ) - elif arity == 3: - matchExpr = FollowedBy(lastExpr + opExpr1 + lastExpr + opExpr2 + lastExpr) + \ - Group( lastExpr + 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 = FollowedBy(opExpr.expr + thisExpr) + Group( opExpr + thisExpr ) - elif arity == 2: - if opExpr is not None: - matchExpr = FollowedBy(lastExpr + opExpr + thisExpr) + Group( lastExpr + OneOrMore( opExpr + thisExpr ) ) - else: - matchExpr = FollowedBy(lastExpr + thisExpr) + Group( lastExpr + OneOrMore( thisExpr ) ) - elif arity == 3: - matchExpr = FollowedBy(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 C{L{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=C{"("}); can also be a pyparsing expression - - closer - closing character for a nested list (default=C{")"}); can also be a pyparsing expression - - content - expression for items within the nested lists (default=C{None}) - - ignoreExpr - expression for ignoring opening and closing delimiters (default=C{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 C{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 C{L{Or}} or C{L{MatchFirst}}. - The default is L{quotedString}, but if no expressions are to be ignored, - then pass C{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 - the current level; set to False for block of left-most statements - (default=C{True}) - - A valid block must contain at least one C{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']]]]]]] - """ - def checkPeerIndent(s,l,t): - if l >= len(s): return - curCol = col(l,s) - if curCol != indentStack[-1]: - if curCol > indentStack[-1]: - raise ParseFatalException(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 < indentStack[-1] and curCol <= indentStack[-2]): - raise ParseException(s,l,"not an unindent") - indentStack.pop() - - NL = OneOrMore(LineEnd().setWhitespaceChars("\t ").suppress()) - INDENT = (Empty() + Empty().setParseAction(checkSubIndent)).setName('INDENT') - PEER = Empty().setParseAction(checkPeerIndent).setName('') - UNDENT = Empty().setParseAction(checkUnindent).setName('UNINDENT') - if indent: - smExpr = Group( Optional(NL) + - #~ FollowedBy(blockStatementExpr) + - INDENT + (OneOrMore( PEER + Group(blockStatementExpr) + Optional(NL) )) + UNDENT) - else: - smExpr = Group( Optional(NL) + - (OneOrMore( PEER + Group(blockStatementExpr) + Optional(NL) )) ) - 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' + '|'.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 C{/* ... */}" - -htmlComment = Regex(r"").setName("HTML comment") -"Comment of the form C{}" - -restOfLine = Regex(r".*").leaveWhitespace().setName("rest of line") -dblSlashComment = Regex(r"//(?:\\\n|[^\n])*").setName("// comment") -"Comment of the form C{// ... (to end of line)}" - -cppStyleComment = Combine(Regex(r"/\*(?:[^*]|\*(?!/))*") + '*/'| dblSlashComment).setName("C++ style comment") -"Comment of either form C{L{cStyleComment}} or C{L{dblSlashComment}}" - -javaStyleComment = cppStyleComment -"Same as C{L{cppStyleComment}}" - -pythonStyleComment = Regex(r"#.*").setName("Python style comment") -"Comment of the form C{# ... (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 L{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 (L{integers}, L{reals}, L{scientific notation}) - - common L{programming identifiers} - - network addresses (L{MAC}, L{IPv4}, L{IPv6}) - - ISO8601 L{dates} and L{datetime} - - L{UUID} - - L{comma-separated list} - Parse actions: - - C{L{convertToInteger}} - - C{L{convertToFloat}} - - C{L{convertToDate}} - - C{L{convertToDatetime}} - - C{L{stripHTMLTags}} - - C{L{upcaseTokens}} - - C{L{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*').setName("real number").setParseAction(convertToFloat) - """expression that parses a floating point number and returns a float""" - - sci_real = Regex(r'[+-]?\d+([eE][+-]?\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 (C{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=C{"%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=C{"%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\d{4})(?:-(?P\d\d)(?:-(?P\d\d))?)?').setName("ISO8601 date") - "ISO8601 date (C{yyyy-mm-dd})" - - iso8601_datetime = Regex(r'(?P\d{4})-(?P\d\d)-(?P\d\d)[T ](?P\d\d):(?P\d\d)(:(?P\d\d(\.\d*)?)?)?(?PZ|[+-]\d\d:?\d\d)?').setName("ISO8601 datetime") - "ISO8601 datetime (C{yyyy-mm-ddThh:mm:ss.s(Z|+-00:00)}) - trailing seconds, milliseconds, and timezone optional; accepts separating C{'T'} or C{' '}" - - uuid = Regex(r'[0-9a-fA-F]{8}(-[0-9a-fA-F]{4}){3}-[0-9a-fA-F]{12}').setName("UUID") - "UUID (C{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 = 'More info at the
pyparsing wiki page' - td,td_end = makeHTMLTags("TD") - table_text = td + SkipTo(td_end).setParseAction(pyparsing_common.stripHTMLTags)("body") + td_end - - print(table_text.parseString(text).body) # -> '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.""" - - -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/venv/lib/python3.8/site-packages/setuptools/_vendor/six.py b/venv/lib/python3.8/site-packages/setuptools/_vendor/six.py deleted file mode 100644 index 190c023..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/_vendor/six.py +++ /dev/null @@ -1,868 +0,0 @@ -"""Utilities for writing code that runs on Python 2 and 3""" - -# Copyright (c) 2010-2015 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 -# 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 absolute_import - -import functools -import itertools -import operator -import sys -import types - -__author__ = "Benjamin Peterson " -__version__ = "1.10.0" - - -# Useful for very coarse version differentiation. -PY2 = sys.version_info[0] == 2 -PY3 = sys.version_info[0] == 3 -PY34 = sys.version_info[0:2] >= (3, 4) - -if PY3: - string_types = str, - integer_types = int, - class_types = type, - text_type = str - binary_type = bytes - - MAXSIZE = sys.maxsize -else: - string_types = basestring, - integer_types = (int, long) - class_types = (type, types.ClassType) - text_type = unicode - binary_type = str - - if sys.platform.startswith("java"): - # Jython always uses 32 bits. - MAXSIZE = int((1 << 31) - 1) - else: - # It's possible to have sizeof(long) != sizeof(Py_ssize_t). - class X(object): - - def __len__(self): - return 1 << 31 - try: - len(X()) - except OverflowError: - # 32-bit - MAXSIZE = int((1 << 31) - 1) - else: - # 64-bit - MAXSIZE = int((1 << 63) - 1) - del X - - -def _add_doc(func, doc): - """Add documentation to a function.""" - func.__doc__ = doc - - -def _import_module(name): - """Import module, returning the module after the last dot.""" - __import__(name) - return sys.modules[name] - - -class _LazyDescr(object): - - def __init__(self, name): - self.name = name - - def __get__(self, obj, tp): - result = self._resolve() - setattr(obj, self.name, result) # Invokes __set__. - try: - # This is a bit ugly, but it avoids running this again by - # removing this descriptor. - delattr(obj.__class__, self.name) - except AttributeError: - pass - return result - - -class MovedModule(_LazyDescr): - - def __init__(self, name, old, new=None): - super(MovedModule, self).__init__(name) - if PY3: - if new is None: - new = name - self.mod = new - else: - self.mod = old - - def _resolve(self): - return _import_module(self.mod) - - def __getattr__(self, attr): - _module = self._resolve() - value = getattr(_module, attr) - setattr(self, attr, value) - return value - - -class _LazyModule(types.ModuleType): - - def __init__(self, name): - super(_LazyModule, self).__init__(name) - self.__doc__ = self.__class__.__doc__ - - def __dir__(self): - attrs = ["__doc__", "__name__"] - attrs += [attr.name for attr in self._moved_attributes] - return attrs - - # Subclasses should override this - _moved_attributes = [] - - -class MovedAttribute(_LazyDescr): - - def __init__(self, name, old_mod, new_mod, old_attr=None, new_attr=None): - super(MovedAttribute, self).__init__(name) - if PY3: - if new_mod is None: - new_mod = name - self.mod = new_mod - if new_attr is None: - if old_attr is None: - new_attr = name - else: - new_attr = old_attr - self.attr = new_attr - else: - self.mod = old_mod - if old_attr is None: - old_attr = name - self.attr = old_attr - - def _resolve(self): - module = _import_module(self.mod) - return getattr(module, self.attr) - - -class _SixMetaPathImporter(object): - - """ - A meta path importer to import six.moves and its submodules. - - This class implements a PEP302 finder and loader. It should be compatible - with Python 2.5 and all existing versions of Python3 - """ - - def __init__(self, six_module_name): - self.name = six_module_name - self.known_modules = {} - - def _add_module(self, mod, *fullnames): - for fullname in fullnames: - self.known_modules[self.name + "." + fullname] = mod - - def _get_module(self, fullname): - return self.known_modules[self.name + "." + fullname] - - def find_module(self, fullname, path=None): - if fullname in self.known_modules: - return self - return None - - def __get_module(self, fullname): - try: - return self.known_modules[fullname] - except KeyError: - raise ImportError("This loader does not know module " + fullname) - - def load_module(self, fullname): - try: - # in case of a reload - return sys.modules[fullname] - except KeyError: - pass - mod = self.__get_module(fullname) - if isinstance(mod, MovedModule): - mod = mod._resolve() - else: - mod.__loader__ = self - sys.modules[fullname] = mod - return mod - - def is_package(self, fullname): - """ - Return true, if the named module is a package. - - We need this method to get correct spec objects with - Python 3.4 (see PEP451) - """ - return hasattr(self.__get_module(fullname), "__path__") - - def get_code(self, fullname): - """Return None - - Required, if is_package is implemented""" - self.__get_module(fullname) # eventually raises ImportError - return None - get_source = get_code # same as get_code - -_importer = _SixMetaPathImporter(__name__) - - -class _MovedItems(_LazyModule): - - """Lazy loading of moved objects""" - __path__ = [] # mark as package - - -_moved_attributes = [ - MovedAttribute("cStringIO", "cStringIO", "io", "StringIO"), - MovedAttribute("filter", "itertools", "builtins", "ifilter", "filter"), - MovedAttribute("filterfalse", "itertools", "itertools", "ifilterfalse", "filterfalse"), - MovedAttribute("input", "__builtin__", "builtins", "raw_input", "input"), - MovedAttribute("intern", "__builtin__", "sys"), - MovedAttribute("map", "itertools", "builtins", "imap", "map"), - MovedAttribute("getcwd", "os", "os", "getcwdu", "getcwd"), - MovedAttribute("getcwdb", "os", "os", "getcwd", "getcwdb"), - MovedAttribute("range", "__builtin__", "builtins", "xrange", "range"), - MovedAttribute("reload_module", "__builtin__", "importlib" if PY34 else "imp", "reload"), - MovedAttribute("reduce", "__builtin__", "functools"), - MovedAttribute("shlex_quote", "pipes", "shlex", "quote"), - MovedAttribute("StringIO", "StringIO", "io"), - MovedAttribute("UserDict", "UserDict", "collections"), - MovedAttribute("UserList", "UserList", "collections"), - MovedAttribute("UserString", "UserString", "collections"), - MovedAttribute("xrange", "__builtin__", "builtins", "xrange", "range"), - MovedAttribute("zip", "itertools", "builtins", "izip", "zip"), - MovedAttribute("zip_longest", "itertools", "itertools", "izip_longest", "zip_longest"), - MovedModule("builtins", "__builtin__"), - MovedModule("configparser", "ConfigParser"), - MovedModule("copyreg", "copy_reg"), - MovedModule("dbm_gnu", "gdbm", "dbm.gnu"), - MovedModule("_dummy_thread", "dummy_thread", "_dummy_thread"), - MovedModule("http_cookiejar", "cookielib", "http.cookiejar"), - MovedModule("http_cookies", "Cookie", "http.cookies"), - MovedModule("html_entities", "htmlentitydefs", "html.entities"), - MovedModule("html_parser", "HTMLParser", "html.parser"), - MovedModule("http_client", "httplib", "http.client"), - MovedModule("email_mime_multipart", "email.MIMEMultipart", "email.mime.multipart"), - MovedModule("email_mime_nonmultipart", "email.MIMENonMultipart", "email.mime.nonmultipart"), - MovedModule("email_mime_text", "email.MIMEText", "email.mime.text"), - MovedModule("email_mime_base", "email.MIMEBase", "email.mime.base"), - MovedModule("BaseHTTPServer", "BaseHTTPServer", "http.server"), - MovedModule("CGIHTTPServer", "CGIHTTPServer", "http.server"), - MovedModule("SimpleHTTPServer", "SimpleHTTPServer", "http.server"), - MovedModule("cPickle", "cPickle", "pickle"), - MovedModule("queue", "Queue"), - MovedModule("reprlib", "repr"), - MovedModule("socketserver", "SocketServer"), - MovedModule("_thread", "thread", "_thread"), - MovedModule("tkinter", "Tkinter"), - MovedModule("tkinter_dialog", "Dialog", "tkinter.dialog"), - MovedModule("tkinter_filedialog", "FileDialog", "tkinter.filedialog"), - MovedModule("tkinter_scrolledtext", "ScrolledText", "tkinter.scrolledtext"), - MovedModule("tkinter_simpledialog", "SimpleDialog", "tkinter.simpledialog"), - MovedModule("tkinter_tix", "Tix", "tkinter.tix"), - MovedModule("tkinter_ttk", "ttk", "tkinter.ttk"), - MovedModule("tkinter_constants", "Tkconstants", "tkinter.constants"), - MovedModule("tkinter_dnd", "Tkdnd", "tkinter.dnd"), - MovedModule("tkinter_colorchooser", "tkColorChooser", - "tkinter.colorchooser"), - MovedModule("tkinter_commondialog", "tkCommonDialog", - "tkinter.commondialog"), - MovedModule("tkinter_tkfiledialog", "tkFileDialog", "tkinter.filedialog"), - MovedModule("tkinter_font", "tkFont", "tkinter.font"), - MovedModule("tkinter_messagebox", "tkMessageBox", "tkinter.messagebox"), - MovedModule("tkinter_tksimpledialog", "tkSimpleDialog", - "tkinter.simpledialog"), - MovedModule("urllib_parse", __name__ + ".moves.urllib_parse", "urllib.parse"), - MovedModule("urllib_error", __name__ + ".moves.urllib_error", "urllib.error"), - MovedModule("urllib", __name__ + ".moves.urllib", __name__ + ".moves.urllib"), - MovedModule("urllib_robotparser", "robotparser", "urllib.robotparser"), - MovedModule("xmlrpc_client", "xmlrpclib", "xmlrpc.client"), - MovedModule("xmlrpc_server", "SimpleXMLRPCServer", "xmlrpc.server"), -] -# Add windows specific modules. -if sys.platform == "win32": - _moved_attributes += [ - MovedModule("winreg", "_winreg"), - ] - -for attr in _moved_attributes: - setattr(_MovedItems, attr.name, attr) - if isinstance(attr, MovedModule): - _importer._add_module(attr, "moves." + attr.name) -del attr - -_MovedItems._moved_attributes = _moved_attributes - -moves = _MovedItems(__name__ + ".moves") -_importer._add_module(moves, "moves") - - -class Module_six_moves_urllib_parse(_LazyModule): - - """Lazy loading of moved objects in six.moves.urllib_parse""" - - -_urllib_parse_moved_attributes = [ - MovedAttribute("ParseResult", "urlparse", "urllib.parse"), - MovedAttribute("SplitResult", "urlparse", "urllib.parse"), - MovedAttribute("parse_qs", "urlparse", "urllib.parse"), - MovedAttribute("parse_qsl", "urlparse", "urllib.parse"), - MovedAttribute("urldefrag", "urlparse", "urllib.parse"), - MovedAttribute("urljoin", "urlparse", "urllib.parse"), - MovedAttribute("urlparse", "urlparse", "urllib.parse"), - MovedAttribute("urlsplit", "urlparse", "urllib.parse"), - MovedAttribute("urlunparse", "urlparse", "urllib.parse"), - MovedAttribute("urlunsplit", "urlparse", "urllib.parse"), - MovedAttribute("quote", "urllib", "urllib.parse"), - MovedAttribute("quote_plus", "urllib", "urllib.parse"), - MovedAttribute("unquote", "urllib", "urllib.parse"), - MovedAttribute("unquote_plus", "urllib", "urllib.parse"), - MovedAttribute("urlencode", "urllib", "urllib.parse"), - MovedAttribute("splitquery", "urllib", "urllib.parse"), - MovedAttribute("splittag", "urllib", "urllib.parse"), - MovedAttribute("splituser", "urllib", "urllib.parse"), - MovedAttribute("uses_fragment", "urlparse", "urllib.parse"), - MovedAttribute("uses_netloc", "urlparse", "urllib.parse"), - MovedAttribute("uses_params", "urlparse", "urllib.parse"), - MovedAttribute("uses_query", "urlparse", "urllib.parse"), - MovedAttribute("uses_relative", "urlparse", "urllib.parse"), -] -for attr in _urllib_parse_moved_attributes: - setattr(Module_six_moves_urllib_parse, attr.name, attr) -del attr - -Module_six_moves_urllib_parse._moved_attributes = _urllib_parse_moved_attributes - -_importer._add_module(Module_six_moves_urllib_parse(__name__ + ".moves.urllib_parse"), - "moves.urllib_parse", "moves.urllib.parse") - - -class Module_six_moves_urllib_error(_LazyModule): - - """Lazy loading of moved objects in six.moves.urllib_error""" - - -_urllib_error_moved_attributes = [ - MovedAttribute("URLError", "urllib2", "urllib.error"), - MovedAttribute("HTTPError", "urllib2", "urllib.error"), - MovedAttribute("ContentTooShortError", "urllib", "urllib.error"), -] -for attr in _urllib_error_moved_attributes: - setattr(Module_six_moves_urllib_error, attr.name, attr) -del attr - -Module_six_moves_urllib_error._moved_attributes = _urllib_error_moved_attributes - -_importer._add_module(Module_six_moves_urllib_error(__name__ + ".moves.urllib.error"), - "moves.urllib_error", "moves.urllib.error") - - -class Module_six_moves_urllib_request(_LazyModule): - - """Lazy loading of moved objects in six.moves.urllib_request""" - - -_urllib_request_moved_attributes = [ - MovedAttribute("urlopen", "urllib2", "urllib.request"), - MovedAttribute("install_opener", "urllib2", "urllib.request"), - MovedAttribute("build_opener", "urllib2", "urllib.request"), - MovedAttribute("pathname2url", "urllib", "urllib.request"), - MovedAttribute("url2pathname", "urllib", "urllib.request"), - MovedAttribute("getproxies", "urllib", "urllib.request"), - MovedAttribute("Request", "urllib2", "urllib.request"), - MovedAttribute("OpenerDirector", "urllib2", "urllib.request"), - MovedAttribute("HTTPDefaultErrorHandler", "urllib2", "urllib.request"), - MovedAttribute("HTTPRedirectHandler", "urllib2", "urllib.request"), - MovedAttribute("HTTPCookieProcessor", "urllib2", "urllib.request"), - MovedAttribute("ProxyHandler", "urllib2", "urllib.request"), - MovedAttribute("BaseHandler", "urllib2", "urllib.request"), - MovedAttribute("HTTPPasswordMgr", "urllib2", "urllib.request"), - MovedAttribute("HTTPPasswordMgrWithDefaultRealm", "urllib2", "urllib.request"), - MovedAttribute("AbstractBasicAuthHandler", "urllib2", "urllib.request"), - MovedAttribute("HTTPBasicAuthHandler", "urllib2", "urllib.request"), - MovedAttribute("ProxyBasicAuthHandler", "urllib2", "urllib.request"), - MovedAttribute("AbstractDigestAuthHandler", "urllib2", "urllib.request"), - MovedAttribute("HTTPDigestAuthHandler", "urllib2", "urllib.request"), - MovedAttribute("ProxyDigestAuthHandler", "urllib2", "urllib.request"), - MovedAttribute("HTTPHandler", "urllib2", "urllib.request"), - MovedAttribute("HTTPSHandler", "urllib2", "urllib.request"), - MovedAttribute("FileHandler", "urllib2", "urllib.request"), - MovedAttribute("FTPHandler", "urllib2", "urllib.request"), - MovedAttribute("CacheFTPHandler", "urllib2", "urllib.request"), - MovedAttribute("UnknownHandler", "urllib2", "urllib.request"), - MovedAttribute("HTTPErrorProcessor", "urllib2", "urllib.request"), - MovedAttribute("urlretrieve", "urllib", "urllib.request"), - MovedAttribute("urlcleanup", "urllib", "urllib.request"), - MovedAttribute("URLopener", "urllib", "urllib.request"), - MovedAttribute("FancyURLopener", "urllib", "urllib.request"), - MovedAttribute("proxy_bypass", "urllib", "urllib.request"), -] -for attr in _urllib_request_moved_attributes: - setattr(Module_six_moves_urllib_request, attr.name, attr) -del attr - -Module_six_moves_urllib_request._moved_attributes = _urllib_request_moved_attributes - -_importer._add_module(Module_six_moves_urllib_request(__name__ + ".moves.urllib.request"), - "moves.urllib_request", "moves.urllib.request") - - -class Module_six_moves_urllib_response(_LazyModule): - - """Lazy loading of moved objects in six.moves.urllib_response""" - - -_urllib_response_moved_attributes = [ - MovedAttribute("addbase", "urllib", "urllib.response"), - MovedAttribute("addclosehook", "urllib", "urllib.response"), - MovedAttribute("addinfo", "urllib", "urllib.response"), - MovedAttribute("addinfourl", "urllib", "urllib.response"), -] -for attr in _urllib_response_moved_attributes: - setattr(Module_six_moves_urllib_response, attr.name, attr) -del attr - -Module_six_moves_urllib_response._moved_attributes = _urllib_response_moved_attributes - -_importer._add_module(Module_six_moves_urllib_response(__name__ + ".moves.urllib.response"), - "moves.urllib_response", "moves.urllib.response") - - -class Module_six_moves_urllib_robotparser(_LazyModule): - - """Lazy loading of moved objects in six.moves.urllib_robotparser""" - - -_urllib_robotparser_moved_attributes = [ - MovedAttribute("RobotFileParser", "robotparser", "urllib.robotparser"), -] -for attr in _urllib_robotparser_moved_attributes: - setattr(Module_six_moves_urllib_robotparser, attr.name, attr) -del attr - -Module_six_moves_urllib_robotparser._moved_attributes = _urllib_robotparser_moved_attributes - -_importer._add_module(Module_six_moves_urllib_robotparser(__name__ + ".moves.urllib.robotparser"), - "moves.urllib_robotparser", "moves.urllib.robotparser") - - -class Module_six_moves_urllib(types.ModuleType): - - """Create a six.moves.urllib namespace that resembles the Python 3 namespace""" - __path__ = [] # mark as package - parse = _importer._get_module("moves.urllib_parse") - error = _importer._get_module("moves.urllib_error") - request = _importer._get_module("moves.urllib_request") - response = _importer._get_module("moves.urllib_response") - robotparser = _importer._get_module("moves.urllib_robotparser") - - def __dir__(self): - return ['parse', 'error', 'request', 'response', 'robotparser'] - -_importer._add_module(Module_six_moves_urllib(__name__ + ".moves.urllib"), - "moves.urllib") - - -def add_move(move): - """Add an item to six.moves.""" - setattr(_MovedItems, move.name, move) - - -def remove_move(name): - """Remove item from six.moves.""" - try: - delattr(_MovedItems, name) - except AttributeError: - try: - del moves.__dict__[name] - except KeyError: - raise AttributeError("no such move, %r" % (name,)) - - -if PY3: - _meth_func = "__func__" - _meth_self = "__self__" - - _func_closure = "__closure__" - _func_code = "__code__" - _func_defaults = "__defaults__" - _func_globals = "__globals__" -else: - _meth_func = "im_func" - _meth_self = "im_self" - - _func_closure = "func_closure" - _func_code = "func_code" - _func_defaults = "func_defaults" - _func_globals = "func_globals" - - -try: - advance_iterator = next -except NameError: - def advance_iterator(it): - return it.next() -next = advance_iterator - - -try: - callable = callable -except NameError: - def callable(obj): - return any("__call__" in klass.__dict__ for klass in type(obj).__mro__) - - -if PY3: - def get_unbound_function(unbound): - return unbound - - create_bound_method = types.MethodType - - def create_unbound_method(func, cls): - return func - - Iterator = object -else: - def get_unbound_function(unbound): - return unbound.im_func - - def create_bound_method(func, obj): - return types.MethodType(func, obj, obj.__class__) - - def create_unbound_method(func, cls): - return types.MethodType(func, None, cls) - - class Iterator(object): - - def next(self): - return type(self).__next__(self) - - callable = callable -_add_doc(get_unbound_function, - """Get the function out of a possibly unbound function""") - - -get_method_function = operator.attrgetter(_meth_func) -get_method_self = operator.attrgetter(_meth_self) -get_function_closure = operator.attrgetter(_func_closure) -get_function_code = operator.attrgetter(_func_code) -get_function_defaults = operator.attrgetter(_func_defaults) -get_function_globals = operator.attrgetter(_func_globals) - - -if PY3: - def iterkeys(d, **kw): - return iter(d.keys(**kw)) - - def itervalues(d, **kw): - return iter(d.values(**kw)) - - def iteritems(d, **kw): - return iter(d.items(**kw)) - - def iterlists(d, **kw): - return iter(d.lists(**kw)) - - viewkeys = operator.methodcaller("keys") - - viewvalues = operator.methodcaller("values") - - viewitems = operator.methodcaller("items") -else: - def iterkeys(d, **kw): - return d.iterkeys(**kw) - - def itervalues(d, **kw): - return d.itervalues(**kw) - - def iteritems(d, **kw): - return d.iteritems(**kw) - - def iterlists(d, **kw): - return d.iterlists(**kw) - - viewkeys = operator.methodcaller("viewkeys") - - viewvalues = operator.methodcaller("viewvalues") - - viewitems = operator.methodcaller("viewitems") - -_add_doc(iterkeys, "Return an iterator over the keys of a dictionary.") -_add_doc(itervalues, "Return an iterator over the values of a dictionary.") -_add_doc(iteritems, - "Return an iterator over the (key, value) pairs of a dictionary.") -_add_doc(iterlists, - "Return an iterator over the (key, [values]) pairs of a dictionary.") - - -if PY3: - def b(s): - return s.encode("latin-1") - - def u(s): - return s - unichr = chr - import struct - int2byte = struct.Struct(">B").pack - del struct - byte2int = operator.itemgetter(0) - indexbytes = operator.getitem - iterbytes = iter - import io - StringIO = io.StringIO - BytesIO = io.BytesIO - _assertCountEqual = "assertCountEqual" - if sys.version_info[1] <= 1: - _assertRaisesRegex = "assertRaisesRegexp" - _assertRegex = "assertRegexpMatches" - else: - _assertRaisesRegex = "assertRaisesRegex" - _assertRegex = "assertRegex" -else: - def b(s): - return s - # Workaround for standalone backslash - - def u(s): - return unicode(s.replace(r'\\', r'\\\\'), "unicode_escape") - unichr = unichr - int2byte = chr - - def byte2int(bs): - return ord(bs[0]) - - def indexbytes(buf, i): - return ord(buf[i]) - iterbytes = functools.partial(itertools.imap, ord) - import StringIO - StringIO = BytesIO = StringIO.StringIO - _assertCountEqual = "assertItemsEqual" - _assertRaisesRegex = "assertRaisesRegexp" - _assertRegex = "assertRegexpMatches" -_add_doc(b, """Byte literal""") -_add_doc(u, """Text literal""") - - -def assertCountEqual(self, *args, **kwargs): - return getattr(self, _assertCountEqual)(*args, **kwargs) - - -def assertRaisesRegex(self, *args, **kwargs): - return getattr(self, _assertRaisesRegex)(*args, **kwargs) - - -def assertRegex(self, *args, **kwargs): - return getattr(self, _assertRegex)(*args, **kwargs) - - -if PY3: - exec_ = getattr(moves.builtins, "exec") - - def reraise(tp, value, tb=None): - if value is None: - value = tp() - if value.__traceback__ is not tb: - raise value.with_traceback(tb) - raise value - -else: - def exec_(_code_, _globs_=None, _locs_=None): - """Execute code in a namespace.""" - if _globs_ is None: - frame = sys._getframe(1) - _globs_ = frame.f_globals - if _locs_ is None: - _locs_ = frame.f_locals - del frame - elif _locs_ is None: - _locs_ = _globs_ - exec("""exec _code_ in _globs_, _locs_""") - - exec_("""def reraise(tp, value, tb=None): - raise tp, value, tb -""") - - -if sys.version_info[:2] == (3, 2): - exec_("""def raise_from(value, from_value): - if from_value is None: - raise value - raise value from from_value -""") -elif sys.version_info[:2] > (3, 2): - exec_("""def raise_from(value, from_value): - raise value from from_value -""") -else: - def raise_from(value, from_value): - raise value - - -print_ = getattr(moves.builtins, "print", None) -if print_ is None: - def print_(*args, **kwargs): - """The new-style print function for Python 2.4 and 2.5.""" - fp = kwargs.pop("file", sys.stdout) - if fp is None: - return - - def write(data): - if not isinstance(data, basestring): - data = str(data) - # If the file has an encoding, encode unicode with it. - if (isinstance(fp, file) and - isinstance(data, unicode) and - fp.encoding is not None): - errors = getattr(fp, "errors", None) - if errors is None: - errors = "strict" - data = data.encode(fp.encoding, errors) - fp.write(data) - want_unicode = False - sep = kwargs.pop("sep", None) - if sep is not None: - if isinstance(sep, unicode): - want_unicode = True - elif not isinstance(sep, str): - raise TypeError("sep must be None or a string") - end = kwargs.pop("end", None) - if end is not None: - if isinstance(end, unicode): - want_unicode = True - elif not isinstance(end, str): - raise TypeError("end must be None or a string") - if kwargs: - raise TypeError("invalid keyword arguments to print()") - if not want_unicode: - for arg in args: - if isinstance(arg, unicode): - want_unicode = True - break - if want_unicode: - newline = unicode("\n") - space = unicode(" ") - else: - newline = "\n" - space = " " - if sep is None: - sep = space - if end is None: - end = newline - for i, arg in enumerate(args): - if i: - write(sep) - write(arg) - write(end) -if sys.version_info[:2] < (3, 3): - _print = print_ - - def print_(*args, **kwargs): - fp = kwargs.get("file", sys.stdout) - flush = kwargs.pop("flush", False) - _print(*args, **kwargs) - if flush and fp is not None: - fp.flush() - -_add_doc(reraise, """Reraise an exception.""") - -if sys.version_info[0:2] < (3, 4): - 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 -else: - wraps = functools.wraps - - -def with_metaclass(meta, *bases): - """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): - - def __new__(cls, name, this_bases, d): - return meta(name, bases, d) - return type.__new__(metaclass, 'temporary_class', (), {}) - - -def add_metaclass(metaclass): - """Class decorator for creating a class with a metaclass.""" - def wrapper(cls): - orig_vars = cls.__dict__.copy() - slots = orig_vars.get('__slots__') - if slots is not None: - if isinstance(slots, str): - slots = [slots] - for slots_var in slots: - orig_vars.pop(slots_var) - orig_vars.pop('__dict__', None) - orig_vars.pop('__weakref__', None) - return metaclass(cls.__name__, cls.__bases__, orig_vars) - return wrapper - - -def python_2_unicode_compatible(klass): - """ - A 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 - returning text and apply this decorator to the class. - """ - if PY2: - if '__str__' not in klass.__dict__: - raise ValueError("@python_2_unicode_compatible cannot be applied " - "to %s because it doesn't define __str__()." % - klass.__name__) - klass.__unicode__ = klass.__str__ - klass.__str__ = lambda self: self.__unicode__().encode('utf-8') - return klass - - -# Complete the moves implementation. -# This code is at the end of this module to speed up module loading. -# Turn this module into a package. -__path__ = [] # required for PEP 302 and PEP 451 -__package__ = __name__ # see PEP 366 @ReservedAssignment -if globals().get("__spec__") is not None: - __spec__.submodule_search_locations = [] # PEP 451 @UndefinedVariable -# Remove other six meta path importers, since they cause problems. This can -# happen if six is removed from sys.modules and then reloaded. (Setuptools does -# this for some reason.) -if sys.meta_path: - for i, importer in enumerate(sys.meta_path): - # Here's some real nastiness: Another "instance" of the six module might - # be floating around. Therefore, we can't use isinstance() to check for - # the six meta path importer, since the other six instance will have - # inserted an importer with different class. - if (type(importer).__name__ == "_SixMetaPathImporter" and - importer.name == __name__): - del sys.meta_path[i] - break - del i, importer -# Finally, add the importer to the meta path import hook. -sys.meta_path.append(_importer) diff --git a/venv/lib/python3.8/site-packages/setuptools/archive_util.py b/venv/lib/python3.8/site-packages/setuptools/archive_util.py deleted file mode 100644 index 8143604..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/archive_util.py +++ /dev/null @@ -1,173 +0,0 @@ -"""Utilities for extracting common archive formats""" - -import zipfile -import tarfile -import os -import shutil -import posixpath -import contextlib -from distutils.errors import DistutilsError - -from pkg_resources import ensure_directory - -__all__ = [ - "unpack_archive", "unpack_zipfile", "unpack_tarfile", "default_filter", - "UnrecognizedFormat", "extraction_drivers", "unpack_directory", -] - - -class UnrecognizedFormat(DistutilsError): - """Couldn't recognize the archive type""" - - -def default_filter(src, dst): - """The default progress/filter callback; returns True for all files""" - return dst - - -def unpack_archive(filename, extract_dir, progress_filter=default_filter, - drivers=None): - """Unpack `filename` to `extract_dir`, or raise ``UnrecognizedFormat`` - - `progress_filter` is a function taking two arguments: a source path - internal to the archive ('/'-separated), and a filesystem path where it - will be extracted. The callback must return the desired extract path - (which may be the same as the one passed in), or else ``None`` to skip - that file or directory. The callback can thus be used to report on the - progress of the extraction, as well as to filter the items extracted or - alter their extraction paths. - - `drivers`, if supplied, must be a non-empty sequence of functions with the - same signature as this function (minus the `drivers` argument), that raise - ``UnrecognizedFormat`` if they do not support extracting the designated - archive type. The `drivers` are tried in sequence until one is found that - does not raise an error, or until all are exhausted (in which case - ``UnrecognizedFormat`` is raised). If you do not supply a sequence of - drivers, the module's ``extraction_drivers`` constant will be used, which - means that ``unpack_zipfile`` and ``unpack_tarfile`` will be tried, in that - order. - """ - for driver in drivers or extraction_drivers: - try: - driver(filename, extract_dir, progress_filter) - except UnrecognizedFormat: - continue - else: - return - else: - raise UnrecognizedFormat( - "Not a recognized archive type: %s" % filename - ) - - -def unpack_directory(filename, extract_dir, progress_filter=default_filter): - """"Unpack" a directory, using the same interface as for archives - - Raises ``UnrecognizedFormat`` if `filename` is not a directory - """ - if not os.path.isdir(filename): - raise UnrecognizedFormat("%s is not a directory" % filename) - - paths = { - filename: ('', extract_dir), - } - for base, dirs, files in os.walk(filename): - src, dst = paths[base] - for d in dirs: - paths[os.path.join(base, d)] = src + d + '/', os.path.join(dst, d) - for f in files: - target = os.path.join(dst, f) - target = progress_filter(src + f, target) - if not target: - # skip non-files - continue - ensure_directory(target) - f = os.path.join(base, f) - shutil.copyfile(f, target) - shutil.copystat(f, target) - - -def unpack_zipfile(filename, extract_dir, progress_filter=default_filter): - """Unpack zip `filename` to `extract_dir` - - Raises ``UnrecognizedFormat`` if `filename` is not a zipfile (as determined - by ``zipfile.is_zipfile()``). See ``unpack_archive()`` for an explanation - of the `progress_filter` argument. - """ - - if not zipfile.is_zipfile(filename): - raise UnrecognizedFormat("%s is not a zip file" % (filename,)) - - with zipfile.ZipFile(filename) as z: - for info in z.infolist(): - name = info.filename - - # don't extract absolute paths or ones with .. in them - if name.startswith('/') or '..' in name.split('/'): - continue - - target = os.path.join(extract_dir, *name.split('/')) - target = progress_filter(name, target) - if not target: - continue - if name.endswith('/'): - # directory - ensure_directory(target) - else: - # file - ensure_directory(target) - data = z.read(info.filename) - with open(target, 'wb') as f: - f.write(data) - unix_attributes = info.external_attr >> 16 - if unix_attributes: - os.chmod(target, unix_attributes) - - -def unpack_tarfile(filename, extract_dir, progress_filter=default_filter): - """Unpack tar/tar.gz/tar.bz2 `filename` to `extract_dir` - - Raises ``UnrecognizedFormat`` if `filename` is not a tarfile (as determined - by ``tarfile.open()``). See ``unpack_archive()`` for an explanation - of the `progress_filter` argument. - """ - try: - tarobj = tarfile.open(filename) - except tarfile.TarError: - raise UnrecognizedFormat( - "%s is not a compressed or uncompressed tar file" % (filename,) - ) - with contextlib.closing(tarobj): - # don't do any chowning! - tarobj.chown = lambda *args: None - for member in tarobj: - name = member.name - # don't extract absolute paths or ones with .. in them - if not name.startswith('/') and '..' not in name.split('/'): - prelim_dst = os.path.join(extract_dir, *name.split('/')) - - # resolve any links and to extract the link targets as normal - # files - while member is not None and (member.islnk() or member.issym()): - linkpath = member.linkname - if member.issym(): - base = posixpath.dirname(member.name) - linkpath = posixpath.join(base, linkpath) - linkpath = posixpath.normpath(linkpath) - member = tarobj._getmember(linkpath) - - if member is not None and (member.isfile() or member.isdir()): - final_dst = progress_filter(name, prelim_dst) - if final_dst: - if final_dst.endswith(os.sep): - final_dst = final_dst[:-1] - try: - # XXX Ugh - tarobj._extract_member(member, final_dst) - except tarfile.ExtractError: - # chown/chmod/mkfifo/mknode/makedev failed - pass - return True - - -extraction_drivers = unpack_directory, unpack_zipfile, unpack_tarfile diff --git a/venv/lib/python3.8/site-packages/setuptools/build_meta.py b/venv/lib/python3.8/site-packages/setuptools/build_meta.py deleted file mode 100644 index 10c4b52..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/build_meta.py +++ /dev/null @@ -1,257 +0,0 @@ -"""A PEP 517 interface to setuptools - -Previously, when a user or a command line tool (let's call it a "frontend") -needed to make a request of setuptools to take a certain action, for -example, generating a list of installation requirements, the frontend would -would call "setup.py egg_info" or "setup.py bdist_wheel" on the command line. - -PEP 517 defines a different method of interfacing with setuptools. Rather -than calling "setup.py" directly, the frontend should: - - 1. Set the current directory to the directory with a setup.py file - 2. Import this module into a safe python interpreter (one in which - setuptools can potentially set global variables or crash hard). - 3. Call one of the functions defined in PEP 517. - -What each function does is defined in PEP 517. However, here is a "casual" -definition of the functions (this definition should not be relied on for -bug reports or API stability): - - - `build_wheel`: build a wheel in the folder and return the basename - - `get_requires_for_build_wheel`: get the `setup_requires` to build - - `prepare_metadata_for_build_wheel`: get the `install_requires` - - `build_sdist`: build an sdist in the folder and return the basename - - `get_requires_for_build_sdist`: get the `setup_requires` to build - -Again, this is not a formal definition! Just a "taste" of the module. -""" - -import io -import os -import sys -import tokenize -import shutil -import contextlib - -import setuptools -import distutils -from setuptools.py31compat import TemporaryDirectory - -from pkg_resources import parse_requirements -from pkg_resources.py31compat import makedirs - -__all__ = ['get_requires_for_build_sdist', - 'get_requires_for_build_wheel', - 'prepare_metadata_for_build_wheel', - 'build_wheel', - 'build_sdist', - '__legacy__', - 'SetupRequirementsError'] - -class SetupRequirementsError(BaseException): - def __init__(self, specifiers): - self.specifiers = specifiers - - -class Distribution(setuptools.dist.Distribution): - def fetch_build_eggs(self, specifiers): - specifier_list = list(map(str, parse_requirements(specifiers))) - - raise SetupRequirementsError(specifier_list) - - @classmethod - @contextlib.contextmanager - def patch(cls): - """ - Replace - distutils.dist.Distribution with this class - for the duration of this context. - """ - orig = distutils.core.Distribution - distutils.core.Distribution = cls - try: - yield - finally: - distutils.core.Distribution = orig - - -def _to_str(s): - """ - Convert a filename to a string (on Python 2, explicitly - a byte string, not Unicode) as distutils checks for the - exact type str. - """ - if sys.version_info[0] == 2 and not isinstance(s, str): - # Assume it's Unicode, as that's what the PEP says - # should be provided. - return s.encode(sys.getfilesystemencoding()) - return s - - -def _get_immediate_subdirectories(a_dir): - return [name for name in os.listdir(a_dir) - if os.path.isdir(os.path.join(a_dir, name))] - - -def _file_with_extension(directory, extension): - matching = ( - f for f in os.listdir(directory) - if f.endswith(extension) - ) - file, = matching - return file - - -def _open_setup_script(setup_script): - if not os.path.exists(setup_script): - # Supply a default setup.py - return io.StringIO(u"from setuptools import setup; setup()") - - return getattr(tokenize, 'open', open)(setup_script) - - -class _BuildMetaBackend(object): - - def _fix_config(self, config_settings): - config_settings = config_settings or {} - config_settings.setdefault('--global-option', []) - return config_settings - - def _get_build_requires(self, config_settings, requirements): - config_settings = self._fix_config(config_settings) - - sys.argv = sys.argv[:1] + ['egg_info'] + \ - config_settings["--global-option"] - try: - with Distribution.patch(): - self.run_setup() - except SetupRequirementsError as e: - requirements += e.specifiers - - return requirements - - def run_setup(self, setup_script='setup.py'): - # Note that we can reuse our build directory between calls - # Correctness comes first, then optimization later - __file__ = setup_script - __name__ = '__main__' - - with _open_setup_script(__file__) as f: - code = f.read().replace(r'\r\n', r'\n') - - exec(compile(code, __file__, 'exec'), locals()) - - def get_requires_for_build_wheel(self, config_settings=None): - config_settings = self._fix_config(config_settings) - return self._get_build_requires(config_settings, requirements=['wheel']) - - def get_requires_for_build_sdist(self, config_settings=None): - config_settings = self._fix_config(config_settings) - return self._get_build_requires(config_settings, requirements=[]) - - def prepare_metadata_for_build_wheel(self, metadata_directory, - config_settings=None): - sys.argv = sys.argv[:1] + ['dist_info', '--egg-base', - _to_str(metadata_directory)] - self.run_setup() - - dist_info_directory = metadata_directory - while True: - dist_infos = [f for f in os.listdir(dist_info_directory) - if f.endswith('.dist-info')] - - if (len(dist_infos) == 0 and - len(_get_immediate_subdirectories(dist_info_directory)) == 1): - - dist_info_directory = os.path.join( - dist_info_directory, os.listdir(dist_info_directory)[0]) - continue - - assert len(dist_infos) == 1 - break - - # PEP 517 requires that the .dist-info directory be placed in the - # metadata_directory. To comply, we MUST copy the directory to the root - if dist_info_directory != metadata_directory: - shutil.move( - os.path.join(dist_info_directory, dist_infos[0]), - metadata_directory) - shutil.rmtree(dist_info_directory, ignore_errors=True) - - return dist_infos[0] - - def _build_with_temp_dir(self, setup_command, result_extension, - result_directory, config_settings): - config_settings = self._fix_config(config_settings) - result_directory = os.path.abspath(result_directory) - - # Build in a temporary directory, then copy to the target. - makedirs(result_directory, exist_ok=True) - with TemporaryDirectory(dir=result_directory) as tmp_dist_dir: - sys.argv = (sys.argv[:1] + setup_command + - ['--dist-dir', tmp_dist_dir] + - config_settings["--global-option"]) - self.run_setup() - - result_basename = _file_with_extension(tmp_dist_dir, result_extension) - result_path = os.path.join(result_directory, result_basename) - if os.path.exists(result_path): - # os.rename will fail overwriting on non-Unix. - os.remove(result_path) - os.rename(os.path.join(tmp_dist_dir, result_basename), result_path) - - return result_basename - - - def build_wheel(self, wheel_directory, config_settings=None, - metadata_directory=None): - return self._build_with_temp_dir(['bdist_wheel'], '.whl', - wheel_directory, config_settings) - - def build_sdist(self, sdist_directory, config_settings=None): - return self._build_with_temp_dir(['sdist', '--formats', 'gztar'], - '.tar.gz', sdist_directory, - config_settings) - - -class _BuildMetaLegacyBackend(_BuildMetaBackend): - """Compatibility backend for setuptools - - This is a version of setuptools.build_meta that endeavors to maintain backwards - compatibility with pre-PEP 517 modes of invocation. It exists as a temporary - bridge between the old packaging mechanism and the new packaging mechanism, - and will eventually be removed. - """ - def run_setup(self, setup_script='setup.py'): - # In order to maintain compatibility with scripts assuming that - # the setup.py script is in a directory on the PYTHONPATH, inject - # '' into sys.path. (pypa/setuptools#1642) - sys_path = list(sys.path) # Save the original path - - script_dir = os.path.dirname(os.path.abspath(setup_script)) - if script_dir not in sys.path: - sys.path.insert(0, script_dir) - - try: - super(_BuildMetaLegacyBackend, - self).run_setup(setup_script=setup_script) - finally: - # While PEP 517 frontends should be calling each hook in a fresh - # subprocess according to the standard (and thus it should not be - # strictly necessary to restore the old sys.path), we'll restore - # the original path so that the path manipulation does not persist - # within the hook after run_setup is called. - sys.path[:] = sys_path - -# The primary backend -_BACKEND = _BuildMetaBackend() - -get_requires_for_build_wheel = _BACKEND.get_requires_for_build_wheel -get_requires_for_build_sdist = _BACKEND.get_requires_for_build_sdist -prepare_metadata_for_build_wheel = _BACKEND.prepare_metadata_for_build_wheel -build_wheel = _BACKEND.build_wheel -build_sdist = _BACKEND.build_sdist - - -# The legacy backend -__legacy__ = _BuildMetaLegacyBackend() diff --git a/venv/lib/python3.8/site-packages/setuptools/cli-32.exe b/venv/lib/python3.8/site-packages/setuptools/cli-32.exe deleted file mode 100644 index b1487b7819e7286577a043c7726fbe0ca1543083..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 65536 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

@|$jDp4t7maBT@by!vG1&J_?=DS4W3Hu6w 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[c}iI#RErv3nvcIClH@!{vM)zJ_weD zu_-L8NU*GlC{d0L!!VW10^+~>qmNB~Y8H+F}!P8_d(PpvjzMJQmr z)FkX;2B~<|3JfJeWv@IXo~nTtp$}Gjie> zs8UDG*kid(%i5QCBp~MA;#I186PI-nZ&k7!k8BiLJSuR>h7ArSYHD~B0I z=T6L{zqglekt0JjG5z&|GWb4?+B5+{p^fgTufl_KesA{@I&g7rNq==^SGc5GcM%$N zDBG2)qExz*Z;jGN_-iD-y8i2BCq)p}2lKcspLg>w-;qwg(()HXrZa3jd!}spuwBVX zwmX!iwU?#7uoQnunw|OlU~+c z^L5Ak3zWhaA4B^FhMMboO0k*O2GL)lD9_<$5b>czbCvKcSt+u*gA*=%dH>Q-Bc11h zzO7jbXN)&5mBf=w2anK6P$YcJZQoWa2#E!v{hFKxxm7Fc)Fc9iC35{|Lp7bIDjrhC zgMiGf4r2yquH{U7WdMio;XS4Y%Ry{q7#kv#gZ07i`7eo#MMh_o68E*Fd_#nrri^4b zX+slbsv>+8pmck%oLDUL()8NRJ#Z z8DReF_eq2zsjEXGs)yS{k}ykS1B!ZrY0f6O65^lslJv3g&wfpDg-&EwF8wrc=hSwm zPlV&n%%yE_@onOwK?)`GNJ6MQ0drMuBYWCH5dkD)uErh@*k}#GcFl<-;;TN+5vb|b zctkCv;*zL7f)A;QuO%(81r0)&aUz4EQu;kA!k@7i8RZ)koMaWW`5cC6n@{w!!J$5d zx}l)4VP4xL=BKi&c^{n_Qi`q@G{vimblcVR53b#*X$FUOQFm!A8JKahNSiBdY+x3bJZfD8n{--FLUM4+Mx@{vM_ep zkk)U=K8R(rhU(X_faI*ZO}cn`5t*O}lx^j8|0rt-)o=Axn^DGcQTi!#7hxLTq?|HQ zB;T6(nrsCeYK0_o%)IO+CP{n#+|;w1ZmvD2c-J{i88bp63RjyKOE!B!D3U{RCs*Zh z&^%65VM(J34230U4bHS}M@SYS9TEK}c%)2<$h1|T;##zRtjRt@#1T%J=kAhOiw+Z% z7DpyWVK@6%9K^uVD9LDKj)dR^aZK6$@Lt)l;sj@`QSzBm{TlLG{JKM_^60Zr2w~nr zr>P-BaV8OjjWm?hQ3$ZCx+lyD%q`~4iNF9xWKi$t&pzBhwN9Dq-o^v9@=abLR#|

KZqkLal4YCRR9VNhIM|rBqmzzcImvcx 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 diff --git a/venv/lib/python3.8/site-packages/setuptools/cli-64.exe b/venv/lib/python3.8/site-packages/setuptools/cli-64.exe deleted file mode 100644 index 675e6bf3743f3d3011c238657e7128ee9960ef7f..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 74752 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 diff --git a/venv/lib/python3.8/site-packages/setuptools/cli.exe b/venv/lib/python3.8/site-packages/setuptools/cli.exe deleted file mode 100644 index b1487b7819e7286577a043c7726fbe0ca1543083..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 65536 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

@|$jDp4t7maBT@by!vG1&J_?=DS4W3Hu6w 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[c}iI#RErv3nvcIClH@!{vM)zJ_weD zu_-L8NU*GlC{d0L!!VW10^+~>qmNB~Y8H+F}!P8_d(PpvjzMJQmr z)FkX;2B~<|3JfJeWv@IXo~nTtp$}Gjie> zs8UDG*kid(%i5QCBp~MA;#I186PI-nZ&k7!k8BiLJSuR>h7ArSYHD~B0I z=T6L{zqglekt0JjG5z&|GWb4?+B5+{p^fgTufl_KesA{@I&g7rNq==^SGc5GcM%$N zDBG2)qExz*Z;jGN_-iD-y8i2BCq)p}2lKcspLg>w-;qwg(()HXrZa3jd!}spuwBVX zwmX!iwU?#7uoQnunw|OlU~+c z^L5Ak3zWhaA4B^FhMMboO0k*O2GL)lD9_<$5b>czbCvKcSt+u*gA*=%dH>Q-Bc11h zzO7jbXN)&5mBf=w2anK6P$YcJZQoWa2#E!v{hFKxxm7Fc)Fc9iC35{|Lp7bIDjrhC zgMiGf4r2yquH{U7WdMio;XS4Y%Ry{q7#kv#gZ07i`7eo#MMh_o68E*Fd_#nrri^4b zX+slbsv>+8pmck%oLDUL()8NRJ#Z z8DReF_eq2zsjEXGs)yS{k}ykS1B!ZrY0f6O65^lslJv3g&wfpDg-&EwF8wrc=hSwm zPlV&n%%yE_@onOwK?)`GNJ6MQ0drMuBYWCH5dkD)uErh@*k}#GcFl<-;;TN+5vb|b zctkCv;*zL7f)A;QuO%(81r0)&aUz4EQu;kA!k@7i8RZ)koMaWW`5cC6n@{w!!J$5d zx}l)4VP4xL=BKi&c^{n_Qi`q@G{vimblcVR53b#*X$FUOQFm!A8JKahNSiBdY+x3bJZfD8n{--FLUM4+Mx@{vM_ep zkk)U=K8R(rhU(X_faI*ZO}cn`5t*O}lx^j8|0rt-)o=Axn^DGcQTi!#7hxLTq?|HQ zB;T6(nrsCeYK0_o%)IO+CP{n#+|;w1ZmvD2c-J{i88bp63RjyKOE!B!D3U{RCs*Zh z&^%65VM(J34230U4bHS}M@SYS9TEK}c%)2<$h1|T;##zRtjRt@#1T%J=kAhOiw+Z% z7DpyWVK@6%9K^uVD9LDKj)dR^aZK6$@Lt)l;sj@`QSzBm{TlLG{JKM_^60Zr2w~nr zr>P-BaV8OjjWm?hQ3$ZCx+lyD%q`~4iNF9xWKi$t&pzBhwN9Dq-o^v9@=abLR#|

KZqkLal4YCRR9VNhIM|rBqmzzcImvcx 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 diff --git a/venv/lib/python3.8/site-packages/setuptools/command/__init__.py b/venv/lib/python3.8/site-packages/setuptools/command/__init__.py deleted file mode 100644 index 743f558..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/command/__init__.py +++ /dev/null @@ -1,17 +0,0 @@ -__all__ = [ - 'alias', 'bdist_egg', 'bdist_rpm', 'build_ext', 'build_py', 'develop', - 'easy_install', 'egg_info', 'install', 'install_lib', 'rotate', 'saveopts', - 'sdist', 'setopt', 'test', 'install_egg_info', 'install_scripts', - 'bdist_wininst', 'upload_docs', 'build_clib', 'dist_info', -] - -from distutils.command.bdist import bdist -import sys - -from setuptools.command import install_scripts - -if 'egg' not in bdist.format_commands: - bdist.format_command['egg'] = ('bdist_egg', "Python .egg file") - bdist.format_commands.append('egg') - -del bdist, sys diff --git a/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/__init__.cpython-38.pyc deleted file mode 100644 index 42affd9ea5691aa52c9c8b431a5214d1446eb442..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 712 zcmZuuO>@&Q5S8ROcD|a>5<=k83x^z%+@OaJ@Cz7b7%u8Tqh^)Xt!$~5oDhBu9QjMS za^f#A99ZXrzzp(u{r1W4?XL8(*J~48uU@{87mSeab@KNbV)7PWx55AfC@_ei0WmZo zffQQMh7NS02Pe>n0X%|JID^MGLr!1_Pc+RLXSBv69q|aiPjw@Yd5qjxvAgDdQWo$G zQ3B&jQZrvt7=NXdT(PSNMjy!Jd5ERXqzkQU$eb7I=H>uPnBc{2??l` z(#D3al5Qii!g;B6NKuQ)(uCwdb@o8$>^d|{vf$K^$zb;RvQTd%)*8CuFVBj?T7BJg7m1igok=rso3?3} F{RSTs)4Kow diff --git a/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/alias.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/alias.cpython-38.pyc deleted file mode 100644 index a97d6971e455a75aee69e2d486df4bd963e8245c..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2392 zcmZ`*O>^8d7?$LZb#^yRD53c%bPT1T1~%yo9pF%yLQBhq028=)%6J@0yK&-=jihZ8 z&xQkA?)-%I*gHRjv#*@`7jmGyue?b&E!ZPjdM(MXp7(hl`RDohHi7H2Pp`$*93g*W zXZEt8a~q2K0V+;7%}7o|O0mr{mRq4^+E!-gPUz%r=;p1k1vZ;Ik4fm=C*0+&$Aq_p zJF&t!?(sRWw|RS;1fA!wDhX)4bT?Icq|;1&Kh$Yid?RHk!EWX8FtF;5;Hi$1vgoIS zx>K4V(N3&H-D!+bKg~o!akc5i;Aug*14Vrf6{mN}FDu7%Ovhy3m9{2hGNFu6vP}-` zF?m9tf@MJWEqSwfw+(%8l2tc<9F-t{eCI^EY?E$!&s`c82CF!zS_;i z;f5M!slFZr_6dFOgnn>BADqyu0jq5(hO&0dYv@|AR!x&u|my+^x3WW58`KiE_KN1ICM(NLFVrZ$r@&*Oq`##tJxjp0$R@ms0rC?WpPo ze|=Ipo${YEegbm1Qsm`BQBzs1G)@2dr~tGA_#!xf7|Azbljrz>Tsh;%8gw);U`(DG zYL7|8I7C0PI5L241-5ixOnoseQk}w*m53S|s@jG?HXnFKYg>t|Zz9@Mi!e*R1=STO z%7u#1Hg##W(!}od_5R<>4`K34FUMq$$#reP)1FX{yj|B0XA}Axgc7{Aww~iAt9### zl=jt7Bx(Q17l(18vm=A%8Jn-40p%BQE&?B@SNJ2t>t3$`HE9Kd}9P9y55la)*;+ z>)=nE0YdTXtMkoli@RfX2?PYyZ<`eF;|jdBN{$)#p0u>5=ZwYSzh0R zrj`XL)u`Y`udYdnggBu-q-mFf;>vUfM7J#Jg@MphLPtDJw25Tx3}ssAx(i~L$2v0J z$;+@r6LNd6ObdxgWE4hXjA{>+7)eyOxIBvFsDRvA!7*=RbrHw3rV0NFL23&|e*^>6 zI#h&qnG5QL_eE+mR5BNCk1j&5OI_BcYpj}U$OALCf^O|a5q>+0>UI?6B_Czj?ncqU zD9)yDT2aKy1k4>SR3cMznuKdppYW7Xpz$g?%?{P@zB^Jvo+bUl4hXS`i&KNiafu9< z=={viOcEFwz`bKpm?j=F9h{Wr$Xr9`L#+Ouw!;? zjhTjXZ9;*58+*>ANYZ(;-DCiEd zawpEJ#a^#z^_m0LuWj6ab)nb8=b6>X$|TNeQqA{zr;+~xi1rS68c>OX7udCp&>I5O zt|~_|5%LiNsTYyE=5Jv`;E#ebniF1rc|vZ8 zLpYm@4V4~l;NhSQO~cih5z}~YfC-e`kk diff --git a/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/bdist_egg.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/bdist_egg.cpython-38.pyc deleted file mode 100644 index 85af1763f5e5c7b09953a6d573fe9fe39fe9b543..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 14182 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 diff --git a/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/bdist_rpm.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/bdist_rpm.cpython-38.pyc deleted file mode 100644 index da76680e033277cf097930c07e788a91a83d310f..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1784 zcma)6U2oh(6rCA+y_-!!DFqc;B<3Zw``}Gz3rJNI1%bp90kz^~C1iO$vm2+gwliZl z&DQ(WN-dB4gUw_Al3(GaKY$Mv330~W%?AOAvF5|$JNKSB_gsI!zTPEhpMSOy{?a1k zXZv!#xp>({H@7heBB&x0$_OPBHgG8Ung}MG=R`QtIbhG60Tc8g>AA0AP4*%?o^K2< zyXb~vkYqpwu_p#j<7MCqSG1m!K}&e>(yms9A~t!Tvq?CjgmgLDw~wXPv5-99mt4qE zSg4$z+VP>>4u36pRv1)|rEa5LOB94cvn86GG6!FS)-yxX8aAI14TFA@Q`Q3|X$X{lMlPm0M9pZExz3}ue^*6}iCluoiRkB6~}^W(;U1g1}$ zT|4MsqMI8SN-~EEPADZgJz#UEBz7$b^2PS5&XUxgTdjhT0RC}NQMsv($J*w<6SEQ}sW;UDcwsr*ATIy^9=qfI08BFocMnazdI&C{g! zvt#YS%@uTG6-!u`P1n!9BjSZySz~KwZ)OyRk{pmZJs~q%(m50<*a@4l+&OUPEqlY6 zBb<_6CqF{zCBsZ#kQa2sYQ1(!=PU9IHl;K7UVi*)iVmm&Myf7u%FnW zi$LD=qlamsBe`{-Z#=cap7|S37s8nJ^H5KF|6))iNEuWsf(xcs>lA=%D6CdFpMH92 z>;EWz>TT5LrXM#m_mgw*E=Px0+PYDEk5#O{Rk;eRyGw*e(wez)Gt&U~B9}%lojBJDK2sj7b#xelX!PQG>8eVL5)a2-Qv3d{PypMsv>ft2&|xjpy~#}Bo&3S>$M;_EJC&T(hdTVMnO;)XC1XcVoUxkS2YK= z8jV$Zhq~R4SMT-Q!A;8{etydI7ggUsMOC#ITeWdR=b7hvRZF3>-N4(iIWxAZ-f{j0 DO|I=S diff --git a/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/bdist_wininst.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/bdist_wininst.cpython-38.pyc deleted file mode 100644 index b024add4b0154e936c2614d8f66de235b53f043c..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 954 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 F{|8XCn7IG| diff --git a/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/build_py.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/build_py.cpython-38.pyc deleted file mode 100644 index fec2b09bcfabfbe0a8b4074dadc71401492a5629..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 8641 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 MW$pL1&+4oH10&LbC;$Ke diff --git a/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/develop.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/develop.cpython-38.pyc deleted file mode 100644 index ce7caf161a9dd384795942664926653fc7be47f0..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6501 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 HH(vcOcpSTW diff --git a/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/dist_info.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/dist_info.cpython-38.pyc deleted file mode 100644 index 59ad70156ad683f094716c9672469984afad603f..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1361 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 RY3QbHgSQ(f>;{j#{{!Ig?l=Gd diff --git a/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/install_lib.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/install_lib.cpython-38.pyc deleted file mode 100644 index 0c2e60328969c0106b385318ff1a8fff8206b93f..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 5083 zcmb7IO>^7E8Qujz0;DKec5TZ^os`K`wV7CSn|7LJ#?>@+{E?YN%|wZtvh`pfE=Yj_ z0cZhQ7Kgl4?nu65+Fp7~rK4~CH9hRLC;x@cH16{*NRX19=@c9+b{E*)_v3lL_~qha zmEn5-=d0e|zsK0WXfS_S82k!%dLNBof`_b?KY5E|Y=lPNY?*zlW$}Ez)Gr&1v%cMO zIJ?J$DXb?8nX=Q&lYK8~)0_FLprD6YpV6r; zL-3X<3}HTDElXIUgl9>Vg^g!fIHH25EvjMxPsgu_npk|o4tT37mc%*CEnse0oY!+T z@tU|OEFhB#nH8_?g>$E$NeM-eNpd(UN^00 zalM0K0$opBT zR|e9oKN+tvQQ9fV`_MEC?J*zmV@KF098#;0yc*7ivM0ne3|YbUx>2U^x1Q6{4dXdU zU!JFibfGGre)-84AAk7y?fZ?YB&KpnFL#3Iw45(NIPM@4KHm6ZD*nm->3*tek9?Uz zC2kOPVpYLZJB~U*S1on1GVi;OJSiQV0`eB>AU=F>BzD^m`l%S1Zy$UroH#_-%c;rQYdtwbjwf}ZKm&>XT3Clow! zjx^OD!E(nu1I-v4C+xr&8=09|N32&G83)Dzc@%T_w`zTIeGU}MsP4f~!_aSQGih$Z zX2^7BGq>X?^Po#fMw@uqwl?K0zu3or+ztnV>^zqBG>E#P?@o2>KhAs!goOJp%*5;B zs|k}{eqOQ5E1CT%G5a=}5qtRhm>6TEhL708>ev_=51^{u zp(UgF<5oFJ-DIb$Of-_e;rJO~1WSY(l0q$b7u@>zzRuo>|;1K2*F3?_WxjFvye*h^c&*VWmj3?K ziyQUn@LJxz_OSR;lGEF0a8;GWKZ0f)!DJl5A!&_3ny6BHoBZ4v_e&Vl_NhZ$*`g5l z+IJHBO37%5-O!ThA-<=zE}%rdmSjWTw`Y=>%j*Ce-fuE`52!sY7`W$W8eS=|=1)PC z)~}P~8uhI~R*$1_pFC5sDm zkyJP$b%`9qG#Uwt6qGl#-uj>9OnpHC<#u1Rtn`uJKdX_qAjx0i&Mn_@xMfs%**I-ejG;i` ztW01oDn+ka^cM0S?a-(VcM8qigCCY2Y@TAKb`g_MliU6@#1z7v(>F!mb}VK=sqMAN zaZvDW%+xhpaFKQdnd>4+8`kCq?Ng%|IbuHv{l1UbM=IS=SefkWU0rurDOL_G?9|q6 zJghd6ZLa-9&*c60sNb-az3ru5mPvUDVwKmaX;AYHHSeKOm3;5a>%ttZEid)Ys+Ypk zr?}ILXqa6#%1~|iYb|3ot~Wo=~P zF3IJL{gEG)C?9&tj##>moP&kN*gh&D2-rQ#EoJ4Nee4{SMhFon<|bf+dZ*H_j#1g5 zZ-xu~+Ee7JUG~(XRq`KtkHv9iR5@M})(L;gkNEL9dUwP{NifP`0VXd0EZ9>ss*5t_ zk=4@t>90EGWqfhS4*8*RXdYUJr4HaIoF~q>I&z4jQT4#&?8pMxDjS-22zWV9?OlWg zWInOn$DA3)T~)pF)fevOmv`@e{MGaSym;|qXs@PgtLbXmrcge;s80f<6f_;8p`>f4 zEUz3H3m!{ek4)~+{%`I62iqPixT-6rjP>i`4pr4Hs>!)xs8Sr$TA7uIO{zJO5#<~Gf=;LuCunx_>gEdGNOIqe z1E!&R zkEy4Hd53zsnA$*(T)xiun6-?0#DZX}eAz-_1<{uE=n7m;-MG9|LS)WT&6?;)@Ms=#Q$RK z!q8`)6P4JT_)ziAGcNCB@B8lRefM@d50wAZT3pPqVoRVYXx8yhmuU4F8wAx_t&9~JX z`uj#DcN`QJRV6^NsQ*^cb(1cRT5lA#(wyW>%{kF1dorna%M~%pQ)dptxs^*~og}7f LJgT{u`33X8$GsFN diff --git a/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/install_scripts.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/install_scripts.cpython-38.pyc deleted file mode 100644 index 614473e317cb520fc9c8ba47fc86b8f3cb165cbd..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2273 zcmZuy&5k2A5VqaF=_EU|v%f5h2%rT5?2G^jkU(e!t6gzmgoMzdmXOucb~2smzqK90 zL>&&yO5Avc%n=@eNAVF(yZ{FdKvgH1ogL_rYwU8RT(0`Q@>l(SMBsb>y*tT|9YTJ` z#re;L#XT7MYY>76nv;UYl;WJ_tZ*2iq;O+zt?^^O-3j6V{yTYCbmC4C#Zl3XyOca6 z!WG^VB0T9$+!H5u1^bc={Xf7v8B*)y)p&pC*xvn28o(=e|-LPU~vzIeglLgF%=|cg2s+u!g)gA&^CzJ6Ojl+_=G~x9SEaq zx3W^3B+t1{RaP54|L}e_C@WPY`Cz3QtS#Oe)cI5olJa;U$77zAqiQfyNnJ~|w$v$w z<2N79F|JQx=<6U1nb0L`$SEe1HiSEZKn!gE!O*pCrLwW|!OZStWoEJ@&*qX>HReNG zudKMNAz!YR`RHe&x?uU&gFRE!dv#XdotAZy9!YU`b|__j_pu&5p6JnRPfIhcO;zQ3 zFRh9qDaGD}3-8v)DgK74$4V_$tm1nL^t{*Y=YvYY6 zXv5`=Qv&*Maua9E=Nk0W0sXDUX*$d2Psu5}PrkXdh#=bAP4p8m;_+{7F+2MT>u$ph zL~Q?Hn&n~xFB{44WI8p;K`voS0O zZ5(DE0aRTUChC^QfXv#0B#avRNVWrCE6pE8L8qc zkFru!GksoZ9eu3T7CLheBqU~MeF3g(nesGGw6@VmRRymTl@vC_5EC`laVOFIP$ohu z+neDD>%0%U3cH?VGK+ng@w5=u#cag>fyPzb)@9`nbhDKX>ai}4^;>t!I_*#Ku$F== zf!t9yKy1U%AAlfqheb4`mzYm|=E9s&m-Jw`f4go36vN?D7yf)2IX(;NHoZ#cS1u9{ zOF~WBG7}xchgU(eJ%piu00CrUNVbJnu!T>Fah9%d8t5?-@6>_ynrIV%{3!z(kV$75 zH9<>8{{+EKCSCnK5G^nIoq>tb_`yPH(PftFR;x;4Bi)}2&Yscxd3 zkKMZzHW2C+X4A?+>YZ6&wr$ z8}c?R&TYgw1T@Vh%zK9lu4a!Vu1dg^gUbc*eH~JAlU5A*3z~ z-SCyRPYipugXDp?I@fK+43Ze{=g diff --git a/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/py36compat.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/py36compat.cpython-38.pyc deleted file mode 100644 index 9f2c0bf29927c68d7f677e16aa7796a9357fe879..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4610 zcmb_g&2JmW72nxiE|(M~%S!ANNziUwyA~aZ0-7Re+`x_N#6=Gwg2qJw!o_yAGnAHI z?yhErwnb1aP#Ng8r=F=}|Cas-d+n+JKo7mNzc?deqt}8?qi_)OS*Q==2=ZcT;y*>(xxZmU_c_ zug9c_#6@VC%z^0&e4jdI5@6GoheT=b(+s@3>k z%>cizl9&5Q78Ejnp710)3i`Qx5lOxu=R-)6942X^PiZ#jkFr=Nc@~+ONMUl6@gT{} zK_u-+C#eeZEcp6VAEWuG^GT;^R=>!DEZ2eHi4OF!2;!UzP@Kz$qK z5sLZ@)x?@w7Z#(I&02fbID@lcGUm>Xl5 z^AT}D%7Yav{h2cZ70aYpzl^9Wu8TY|+CDrDiYR^-9f=U;iGtn3QIhhoIBl;nv?PS^ z$?O^;2+eVo5#}<#z8NO2xKXd~d=#jBBxA@x+JgYtTtrd_c^~M}B2$nH_>;jS>^PK> zOoUotE~pR(M35$D_XN8<7b?4}gE-RhF-VVrA|cfWOSygg%@D9Y^_G69dg7iRMwWymVe_PydJ_f-J?i}eMK0{uIpqRx7X~!adRz*94_k#xyf;TW7#>!-f&=9KK(6~hy zF2VLhj>O{1|MQg2s3?ToZ7)xI906~O;~uxY(#}=s67Qu~@le*ILuDpvsz7Wn>*QWM zk!=^r%dE&7&|=xZoQQQUPfMSiIg5tEz@VzOY0tIG0%B5`?A>fJ*KV)Gj9*Y1a)Iq_EoM4IvioA`UGesDi;#oopn6QBd z@b5i!DX5*fXSGQU<9E+Iv$L-KL1WsSI1}%}IKs*OlY2&GcDM8wnSGnR}e|V*0m#nTSm%MC| zrFSt{C>LO!;!9`-@HJS^Av%Ku+_UXfTDeAA!FYki4{_uYka8cxwq0TDr?hklIvbc9 zp(qcPg`n1CNP9BMJjsfT$YObfPlLy)zz+0JpsQv z!8R+w=5NTE#Wu)dv$=1Ri@wV)%e9HQKVFh+_eyKcF6*|pNjdbm>9SGzX82f4OO@8$Ol-L zKc|Xz{!b?Uj73F$=(BdSiWxL2x0avP^hs|*N_l-bInM&*zPRrOPO_4^0G6; oXSk{|EXiBeVQu70`6gyc|FbHCJRsrB`=6o={_K{sHEG%Z1uq+{R{#J2 diff --git a/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/register.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/register.cpython-38.pyc deleted file mode 100644 index 3746fe9ed6785e70a61f1d799cc18beb95fef6c7..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 811 zcmYjP&5qMB5VoD9$u8Xk%K^kGLP8>fCO42)2v%Axh)Y=&xI{uxh}|~Dj#E3KYE>@m zJ_sCnA5Ok<;uW~SINNqR(v0WFnfbnnKO7w$B9LcKALhR>LceXWFD?Y9pxPRWDCS7u z6l3cXPJ}}cM#4?KF5~c?@KYb7*ND2*yF%1s-psvpQkRl?lk53{*b=L-ALWWs5#!%vJ=Q0YiMv1r0(QC47O*w$R;G%PEC4CkY1 z)71JTN$O=?#!^j^I_d64EB|~ndOJD^Bi96ZRmrw0n6glf*Hx4QengC`86O)*=*dr{ z4j}jUWzvW`smprMR+c%VgT<6FKA7wAe5S{XM6;%?8!5R?Hn@}RuHt%W9Mx9#h3Ehb zBIF)ROy8`8*U452SxnNml4zo;1+H&jnvuxhxd{gnWjLIU*)Gg@L!P_%-hO(RY zLA7-P?2;}M1?GUle{GwR>yCDMe;3Ca(D4?L@i&?7TjNSqPSV>qEMsQhnC@1#H{Whc WSr8_8evSWyeHXe1rjL(F-}w(VAkirR diff --git a/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/rotate.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/rotate.cpython-38.pyc deleted file mode 100644 index f30b7a2087943b1caa2ff514801d9e6d9a399e98..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2520 zcmZ`*UvC^W5VyU5Zg20>rXjQxg|di-dRiy^;L;zL%J5eo{v+uIW{)_FS z&Fb<(iqu!W!QEr|2z&-UfnRyzD^x;d#&;pPmhQ^q+40yjWlk!LB(oQ`98Cv`Kg<5}KK{f-agZd&Wqp!d=st9R;l z%umCt(P>cfIpH-PJRv*~jT5KSf|76a&(w-cp@ zI!V=+rA~_cGbszXgX1cB3|;Mhk!9VS_i&l>j{_g~ps7!R2-2aPbQq@{hqI2$9qw{( z;B>qJ0mpq_dqTkRfY+f9c*q;j*Lf2hTrj>YbXSY&?QM|?EutdjLPi|?lF2T(R^+Ps zguiy|W^^D#ndF0LC(6Ymp>)(wQlVN-p+q+|ER;@tTTF6{Qx`?beT9@K*m`K4} zpjtn>s5u%cR^G=4H2cAovEvAkvLP)j!-<{YRTh=wYdgB2}BcX?8cKDQK5RW+}-N zopjTr5^-T6q25C0d?1AS@K#r6+OKN95*r+VX>3n{8IgU6>>!X!nsRzVf1x0O_&{bziS}?!?eEu4n0$q-R{YT5@lBcEO~1Nm;V5? zF4}{3wAQYYat&v#wZ&kt)~c@0EqMk9i^kLJS64SSFl$kU_IE|p&7&mOVj$$)<{>CN zXb+&-1PmaIhl|HllMx-$3550=JA@N%lip$yCm0XUOxa?FwLdbnv}03p35Ub26rcm~ zm3MF8x>$;Q%1HI$ETjD-pUZrED=m86RNV#Ubmnt<(|EgxL9p6{6)b6mvVlA+&71LNu%5JE%BD0|_$Aq{|Aq!;Y#)9^*$R99XT?py{C@Yw9p{1X^}5mf65 zR%*tblxFl8cm(Sv*5r7j@@I=>INeZVGTML)l+M2 z5hPUpp)ZY>kfY=fA+ZWUt#=1$v1{m!xowyO;tD8QATA>i z_vsiyoX`>Nv-4nd3@emz@uD%oK-nEM{C(MV17KSaPmE{U?FOn=gYEnFwVP~knf|$bs)yw zFOuBC8cJ&+wW&z~cc&5(Z$0DUroja&@+s15Tpq<>%Xo>xvh1rpyiws|%d`~2_`^I+ z@`IKyFQN(b#MEZx#CWzm7^>w5IQSC89awe~X(UnF3 diff --git a/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/saveopts.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/saveopts.cpython-38.pyc deleted file mode 100644 index 7e274d04d8030952fa528411cc000ca16b468ea5..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 889 zcmYjP&2AGh5cbb*vZSdRK{G;_9jmEFSfT;qs^&( z0-m5f@=CsP;uSbC-fkh5W;7m;zxn2~zwYi15Uk^)xA6~x&@Z>yULI^dfawEp9C4hX z97i}O5y9vS;)K&%#Hk=RG@{%)Lu3CpRH8AlJAzBYlCntU-0qZ>k!8WoV=WR_u)U!1 zLz7n!2ozzCBEm5MlE~u#dy68U`vBgvfsQW)fa&#{Gl;^Z%=5V5lS~#Od}yLWQ-*Pv z%1o?}U3sYMs>-C`+XY&fx|$~GJS zm-sXK{&7Pa%JBtJuUDf6-;svi<2!nf;OyWV*?3_7rq}qKK+R#(Ysj6~P>JqI;>R+`<@H%(bOS&Mk!wmTHw) zdKqUwk$MIwf8NhbUd<|5P3oeGlMBHoR|_Gs$x5fIrB1JAt=Oh4Gd=6L&K}=!T3uTT zjh_ILehLoZ9`?w91elPQIKca4J^WV;g{STpFy>e@W(SPrC9g9V4;fq4an_ym8RKOF z=^ZX~qGbC4)pKajvfgt0F6VT1rhDK5VBnE9cRKc>7ytQBJN{Ehff%ifiar8tfjVWB SL$<-m1H*UjPid$7i2eoQFYhS; diff --git a/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/sdist.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/sdist.cpython-38.pyc deleted file mode 100644 index 2d8e5b6a68f0b10a751a3f770dc3fa5535179346..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 7859 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 diff --git a/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/setopt.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/setopt.cpython-38.pyc deleted file mode 100644 index 03803a133fff8237df9c8ac0e5ce9c448f4f70c0..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4537 zcmai2+j88-5yjxPSa5lHIViG4Cxt8G0a0wC% ztY)yHh+3w~ksk79e}ed^AIVd`V5;(zCs*YQY*(Dq1MKo5Rb^Q-m`it~r>FaLgMXNx z4=wy|yt^F#>#Sw{nXz^0L>Yt6Lhjs@|ZKIpOYP+^Vy*&$oE3fOOAJ+=SF_#CX!DnGq1im2EY5viZWLlNa$ zX3nQ}Sc#0rE72g$H{*0A%4IYXvNMJqqUxk!7~!|En`C?=8je*FZ9-0FWL+}cmsX-n z6+cE0aEZ7t88$hG6PHbxXFOW%Zw<6x5tj2a70j|rEZQ68DtV&WsuJ|)h2qHwZa^|5U8D~G7^h=l{HASdmyDtvo)<4Hc>()h-nw24N7qNms58z+ zaer6v&fc~VY3GsJdbFdq_O2UK6nUPi>;1~fXbH}yv*xv=7_^Z{l%#H;@m&=W}NQx#au7?Ne;gP{f%crMO5%AxtETtVpDYlrXF-M&8~w z!u_O9DFR-BsyYM7KoIx0<7@ympkO7D?O0&K8qI3{i+T&t#JdgzCdhtQL zcgG}#-c6LTn7=ZlKgilu)LQP+qLVNcvfxa%lRrfbm}b52IUV_{20m1WOL&PlrR;{ z-PubJ__O3ddCG`^lsU=>Ga2LZ#;auX$5J9ZBa?wtbSjtCqRQsoWyBTie7ELhx9%lodqZGS@~AA-lMx(eVP1(&ZIAu zmqzEu7!0ffq_7=JzJYYb3OEauIe>p_$B`@bnmt={xwYGrAJ94|kg7n*)bDFLr=lyo z38Zj$*Ofbk&uNBoX~G_Yrw0j03jUgG;q7vsIx1hjAZwP_e?z5@8i{_g1&q&9>fnF| z22R{ob>?~(Bc*y7QY~pKT9?y_3;CdG&ec_aE zuT#|5pwUSas%MWNAU4rizJoxE;;i1G^e~G&N}6$&11qL=@-(1>TIem!`sIasLJ8)i zFkn{ODQmC?ZC=h-3e=?748hScxQ%^Po;Aa1311N-eElkYXeP@ys$q0>oPibfF_6qK zNwWQkXd|B{NH)=S83QV_P(UGSrucw}aLgESfw4!?A%6T;xU4BF(x{g=chR*YMw3%(rArmjL^7Yy_r=$3#JEboObEnrZCXatQmGqB!f_u5N(;V8e;KL*TKp8OWQ zfuch%9c|+iFqf*j#MiLb{SNMAJTjkhtKvx^WVVX0*HxyFNE!!h_>a0+;99kW|>ie1aGRO+X9O5L(k=Dg7@0UzoR#jXv)VoDob9eTYu$Bcy}RLTbk8~Gy62tq+}7$`=w5U#B3}~a z&MVzlomW-G|Au4#ND&L7@>CHOf8khnzKQapsG?jw)|^WyEr}XRHUA>M{+>`DDD^YX zux4emuBFv`L7eoHpcB6%WhB$pN%@0b5=0@_*40$+L~Xpv5B)g#apVbKQe_-G0S&$D z^-{AHbQ08-(wg++s4tto+W~D6$aHB^<3B-FoL0j~cD+t8@ZFx5?4%2iBe@rZZ8!Fl zbj1z5t{?Y2P(ZThwf#6<@(;XD-%EVA>&ZP|rt6*%uGdV01CQp(WBDOI6s5o452T-# z-w6|Wcs~ll1amFkjk;Yg6wg$w9OatZ4}<-_@A?P6jD0_B(w5BrbQEsmiC;zHE5sCF z2vulL6)=P;3{iNhf+cipXfdrmXnJ9YHDtTfq+!NC$`iG_c;YoAi84}$%89BfiFT|E z6&DQlK>1SLtQ)d`@2TawK^P>ii#^7cSnfd(2Z=AfR8u4NJFPDjc@gct`r);t+q>2a zdRO})?UgUCKHl;D&ei?6wZ9v;9$!QEelLllPJFGI?ZCAJXV~Z+%5_jUhbJacP}H(I zSf5`+V?2w^CQX0*Gm)W(m-Fw)46&G9WzUpV;x5W#c`7ZhtsLn?eWWG&$QYvCiN=dA z46%*JntYGG4b_o(l5Gan>!|;Sq&QS}EnysM_moc_9T`JoR1$>~RsL#d2y;)zo4yy< z6_izB{X#pZtSd)_@KREyFQ_f8E1>l0v>kuf_CMt@mC?cw^k_EwpC*-|eyoZz=>F?a z87&U=6IzEZ7S7>VSYj$(5vRC?&6J_-*>NAIVMi_7>vU||&)9Byv5zzg6E6sTVF#g| z?D%#&IPgQe8;O3$FPH87_kN2%X4Q5OgJjO?SL_bNE2r6#Q8ya`l(NP#5e|~Z*O1!r zKr6H#J%V@yBp6=D<@r5&WViYuUkf5co(QrbGCM>fxlDPSH67f8l!gR>Z zw04?2aV&{4I93_x;I6^Kn0Zi0)yA{`d;a|SpmJ@dR<3||B+Fw}5+kNM$fl;(>-nL` z1Yw1C;~{PEyV#4L@HVDJtkO#oDM>PAiF#sq(i#}vLf`mtknBj(|IV2?0-I<9UFL^Q znUC;p$BW~-DK8KWGuz>`h=o9vg=vA;of=SWep-tA+gSq^y)1c!CIIWAP$qs2iBc@9 zhFZ}Kby+K`RXjCyS>4cTYE9EnS5eE_;L<5Mo10^{$U2lkLB0-xY1wtNfw8)Z>+bix zPPSH-U><&EN~9Mg&+9C5B;zdKmS!1}YMOZFemY9G@%(OjZfP?L?|F%LUq(G&CWlRJ zh8X4Pxl80|`$;pnu#OKDNqUdeSF7zOb&YpizJw0$TdbGXk6ptedDdk-CA z(s_z%;dlq@FHVZvO;1f;Lu2_SCA1>>T}r0ZCqu|@5>C1rk;H&eAccx?+Ky-u|*i}~xMG~=G%3|awHbJh|a7q}xgLBDwLhtw~I5${0t zp*LyD7f)_ys!6HU_@y}5o zTSyeu0_#15mx-j0%;!NSbh${SeI;Pu3nr!vgHvHsQ^v^w$erbrJKb~c+~z=O1=JGk`ba&2;OA-*(B2>j4+F$Z=gD^b zQf4YmK1Vb+;s`|>RCx}QPcIBk&6?Ey50Kzk0gV%NR}<=9L9Pky=ZZ?Ty1XRxJP&EAp$Ng4Sp8thKZ?$Puq)eQ31-J%|Mav+k4yC^w|>^3iW7JoX|}rdd>n zMOw{xG%yY6w8hQTf-P~slSFU5n_6r)UHEg1q*bRFgltfOgxhUqbub3!w_(iEQq~@< z!}$B9V)+2)$EF}--?2UbncU;{LDFEQ#z2M>wky_+j@R85-mSj{iT}Z)48Fy@^AZ+o z+~`E`MB-b>WSs`)<@n~!%W-`}64*-h`yag}ZzCuFh>EMypD{+c8cr8r=G<}NEWxm` z-V@_$xj^0Xm3M+|`5u)Gjy)7JYaXXYGlHj5Xm)&0re?n<052qoe+J-wN?pt#jDdRP z5>?lzhBubrIPesA2%DY0@Lk%#*eS7C(P28p z?cSl=>GbO z;IHGYRn>}~+FdB|f4^# zMu>^YjU!sNH>H7LfHHXojcJVF9uY)n0MOMNYx`^ngwv7;2@}j5^(eFvTbr>4X?Z$v zY2!3D5t=jM=D?1mS`??nd^M>KkxBJl)MLkYC-!@(v5TmgTtzQQfDqxW0?*DV0wV1I zA3IBt4B9ii?JPI@QetCf>QWORy%juhib>=W#ncM@$IQZ~`IL;s-{Hw{P1ywZRaFgU z7aR(V1Af&kIM8EGq_dirtvOC4vqfPvw!&n|NsYmT5QhPVa$f6gv=MZIDMC4m>XCsO z87IoUj2HC;oCyb3LpX@|M<4vfC)|jET0XPwN%<)cv?$z39|he$w1=bEDL5$4+hBD-Yzx&LRjK)S*)5>9=jrxyZ+JTuRKq{T4o zGb`Z0vT8lIjKT7Y3z|Cz;yKcO%yYj+CgUs8N~Diag8Q;-5C;lvL{1Gs4+2F+d5hcX zLx2V{_hjU`#u(QmfFGkW1wer!p*Qh$fr6A@Tw=-qD_>MO$IxLOVB}~scZUA{!#i7> z?{EI-y8RG)3Q4vP0x#1uxe29chkSg3F32CrfN42CgA z@G_!6KBHF8rgN4-lYMDuPlV&`9>wEHOneIRp^o(|<}!AaJrG4S9ybUG{6kB#-;CFj z##gF6SdaIDUXMn&bUD6+KmbU>{?`W;a(2h{sYS?woUM8lm?aD&Kwn?d8Knm8fILK& zL51v4Wx<7WbC4E6&IKV!whRUr0U-~XHZ7B<1~mx=lccKHuBIgd9?Y8HG>RZPOF1L? zB4hbfhvAl8>TwDu>FE1!sE?^$fr^7={$Im_8wUxhs)klY#1OGUbzm{$q4^xU5j-M+ zV|M!&WC&%$2+p8v`57@>hN^`DWDDj=OhoBFLsTBhAt~-!DBT-sqf!>Fr|A3l$zv0+j^yEKVzkJ%h^-p3Q2t-Qk7 zj^wP9LeVzmFHu)lmJdP!hE08ib7Ogv>Nd zm|dmJsI8eBkb(B(CL+jZFj2xrxIv_gM`i%J5yfyoKU96%*vP*`7bxpI)MnBt;S5$- z%IA4#v%bz30Mk%1#iK>k1P_8Y;-(BZa+g-%4a#wNNZ!H#@@+~ew49yHJ<9zANm`~G zDi~0BL1{J5<6acHR%TkQ0#ld-&8`o(MP%BJmE}_+L2Q;nn`r$x zB`l-Aq1GjkVNpAdMOx``R1l&3?;W%~XBB?Pk(EXVCb zx`>+|gaw;)E9JU;U6UOm%l%a3CwrV)H!?r)771#635f-PAOFdOkV&a&S9Ho5daYh9 F|384rfiwUB diff --git a/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/upload.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/command/__pycache__/upload.cpython-38.pyc deleted file mode 100644 index 9938b658e72c4ea25ba197870aa2c1462b08d42c..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 784 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 diff --git a/venv/lib/python3.8/site-packages/setuptools/command/alias.py b/venv/lib/python3.8/site-packages/setuptools/command/alias.py deleted file mode 100644 index 4532b1c..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/command/alias.py +++ /dev/null @@ -1,80 +0,0 @@ -from distutils.errors import DistutilsOptionError - -from setuptools.extern.six.moves import map - -from setuptools.command.setopt import edit_config, option_base, config_file - - -def shquote(arg): - """Quote an argument for later parsing by shlex.split()""" - for c in '"', "'", "\\", "#": - if c in arg: - return repr(arg) - if arg.split() != [arg]: - return repr(arg) - return arg - - -class alias(option_base): - """Define a shortcut that invokes one or more commands""" - - description = "define a shortcut to invoke one or more commands" - command_consumes_arguments = True - - user_options = [ - ('remove', 'r', 'remove (unset) the alias'), - ] + option_base.user_options - - boolean_options = option_base.boolean_options + ['remove'] - - def initialize_options(self): - option_base.initialize_options(self) - self.args = None - self.remove = None - - def finalize_options(self): - option_base.finalize_options(self) - if self.remove and len(self.args) != 1: - raise DistutilsOptionError( - "Must specify exactly one argument (the alias name) when " - "using --remove" - ) - - def run(self): - aliases = self.distribution.get_option_dict('aliases') - - if not self.args: - print("Command Aliases") - print("---------------") - for alias in aliases: - print("setup.py alias", format_alias(alias, aliases)) - return - - elif len(self.args) == 1: - alias, = self.args - if self.remove: - command = None - elif alias in aliases: - print("setup.py alias", format_alias(alias, aliases)) - return - else: - print("No alias definition found for %r" % alias) - return - else: - alias = self.args[0] - command = ' '.join(map(shquote, self.args[1:])) - - edit_config(self.filename, {'aliases': {alias: command}}, self.dry_run) - - -def format_alias(name, aliases): - source, command = aliases[name] - if source == config_file('global'): - source = '--global-config ' - elif source == config_file('user'): - source = '--user-config ' - elif source == config_file('local'): - source = '' - else: - source = '--filename=%r' % source - return source + name + ' ' + command diff --git a/venv/lib/python3.8/site-packages/setuptools/command/bdist_egg.py b/venv/lib/python3.8/site-packages/setuptools/command/bdist_egg.py deleted file mode 100644 index 98470f1..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/command/bdist_egg.py +++ /dev/null @@ -1,502 +0,0 @@ -"""setuptools.command.bdist_egg - -Build .egg distributions""" - -from distutils.errors import DistutilsSetupError -from distutils.dir_util import remove_tree, mkpath -from distutils import log -from types import CodeType -import sys -import os -import re -import textwrap -import marshal - -from setuptools.extern import six - -from pkg_resources import get_build_platform, Distribution, ensure_directory -from pkg_resources import EntryPoint -from setuptools.extension import Library -from setuptools import Command - -try: - # Python 2.7 or >=3.2 - from sysconfig import get_path, get_python_version - - def _get_purelib(): - return get_path("purelib") -except ImportError: - from distutils.sysconfig import get_python_lib, get_python_version - - def _get_purelib(): - return get_python_lib(False) - - -def strip_module(filename): - if '.' in filename: - filename = os.path.splitext(filename)[0] - if filename.endswith('module'): - filename = filename[:-6] - return filename - - -def sorted_walk(dir): - """Do os.walk in a reproducible way, - independent of indeterministic filesystem readdir order - """ - for base, dirs, files in os.walk(dir): - dirs.sort() - files.sort() - yield base, dirs, files - - -def write_stub(resource, pyfile): - _stub_template = textwrap.dedent(""" - def __bootstrap__(): - global __bootstrap__, __loader__, __file__ - import sys, pkg_resources, imp - __file__ = pkg_resources.resource_filename(__name__, %r) - __loader__ = None; del __bootstrap__, __loader__ - imp.load_dynamic(__name__,__file__) - __bootstrap__() - """).lstrip() - with open(pyfile, 'w') as f: - f.write(_stub_template % resource) - - -class bdist_egg(Command): - description = "create an \"egg\" distribution" - - user_options = [ - ('bdist-dir=', 'b', - "temporary directory for creating the distribution"), - ('plat-name=', 'p', "platform name to embed in generated filenames " - "(default: %s)" % get_build_platform()), - ('exclude-source-files', None, - "remove all .py files from the generated egg"), - ('keep-temp', 'k', - "keep the pseudo-installation tree around after " + - "creating the distribution archive"), - ('dist-dir=', 'd', - "directory to put final built distributions in"), - ('skip-build', None, - "skip rebuilding everything (for testing/debugging)"), - ] - - boolean_options = [ - 'keep-temp', 'skip-build', 'exclude-source-files' - ] - - def initialize_options(self): - self.bdist_dir = None - self.plat_name = None - self.keep_temp = 0 - self.dist_dir = None - self.skip_build = 0 - self.egg_output = None - self.exclude_source_files = None - - def finalize_options(self): - ei_cmd = self.ei_cmd = self.get_finalized_command("egg_info") - self.egg_info = ei_cmd.egg_info - - if self.bdist_dir is None: - bdist_base = self.get_finalized_command('bdist').bdist_base - self.bdist_dir = os.path.join(bdist_base, 'egg') - - if self.plat_name is None: - self.plat_name = get_build_platform() - - self.set_undefined_options('bdist', ('dist_dir', 'dist_dir')) - - if self.egg_output is None: - - # Compute filename of the output egg - basename = Distribution( - None, None, ei_cmd.egg_name, ei_cmd.egg_version, - get_python_version(), - self.distribution.has_ext_modules() and self.plat_name - ).egg_name() - - self.egg_output = os.path.join(self.dist_dir, basename + '.egg') - - def do_install_data(self): - # Hack for packages that install data to install's --install-lib - self.get_finalized_command('install').install_lib = self.bdist_dir - - site_packages = os.path.normcase(os.path.realpath(_get_purelib())) - old, self.distribution.data_files = self.distribution.data_files, [] - - for item in old: - if isinstance(item, tuple) and len(item) == 2: - if os.path.isabs(item[0]): - realpath = os.path.realpath(item[0]) - normalized = os.path.normcase(realpath) - if normalized == site_packages or normalized.startswith( - site_packages + os.sep - ): - item = realpath[len(site_packages) + 1:], item[1] - # XXX else: raise ??? - self.distribution.data_files.append(item) - - try: - log.info("installing package data to %s", self.bdist_dir) - self.call_command('install_data', force=0, root=None) - finally: - self.distribution.data_files = old - - def get_outputs(self): - return [self.egg_output] - - def call_command(self, cmdname, **kw): - """Invoke reinitialized command `cmdname` with keyword args""" - for dirname in INSTALL_DIRECTORY_ATTRS: - kw.setdefault(dirname, self.bdist_dir) - kw.setdefault('skip_build', self.skip_build) - kw.setdefault('dry_run', self.dry_run) - cmd = self.reinitialize_command(cmdname, **kw) - self.run_command(cmdname) - return cmd - - def run(self): - # Generate metadata first - self.run_command("egg_info") - # We run install_lib before install_data, because some data hacks - # pull their data path from the install_lib command. - log.info("installing library code to %s", self.bdist_dir) - instcmd = self.get_finalized_command('install') - old_root = instcmd.root - instcmd.root = None - if self.distribution.has_c_libraries() and not self.skip_build: - self.run_command('build_clib') - cmd = self.call_command('install_lib', warn_dir=0) - instcmd.root = old_root - - all_outputs, ext_outputs = self.get_ext_outputs() - self.stubs = [] - to_compile = [] - for (p, ext_name) in enumerate(ext_outputs): - filename, ext = os.path.splitext(ext_name) - pyfile = os.path.join(self.bdist_dir, strip_module(filename) + - '.py') - self.stubs.append(pyfile) - log.info("creating stub loader for %s", ext_name) - if not self.dry_run: - write_stub(os.path.basename(ext_name), pyfile) - to_compile.append(pyfile) - ext_outputs[p] = ext_name.replace(os.sep, '/') - - if to_compile: - cmd.byte_compile(to_compile) - if self.distribution.data_files: - self.do_install_data() - - # Make the EGG-INFO directory - archive_root = self.bdist_dir - egg_info = os.path.join(archive_root, 'EGG-INFO') - self.mkpath(egg_info) - if self.distribution.scripts: - script_dir = os.path.join(egg_info, 'scripts') - log.info("installing scripts to %s", script_dir) - self.call_command('install_scripts', install_dir=script_dir, - no_ep=1) - - self.copy_metadata_to(egg_info) - native_libs = os.path.join(egg_info, "native_libs.txt") - if all_outputs: - log.info("writing %s", native_libs) - if not self.dry_run: - ensure_directory(native_libs) - libs_file = open(native_libs, 'wt') - libs_file.write('\n'.join(all_outputs)) - libs_file.write('\n') - libs_file.close() - elif os.path.isfile(native_libs): - log.info("removing %s", native_libs) - if not self.dry_run: - os.unlink(native_libs) - - write_safety_flag( - os.path.join(archive_root, 'EGG-INFO'), self.zip_safe() - ) - - if os.path.exists(os.path.join(self.egg_info, 'depends.txt')): - log.warn( - "WARNING: 'depends.txt' will not be used by setuptools 0.6!\n" - "Use the install_requires/extras_require setup() args instead." - ) - - if self.exclude_source_files: - self.zap_pyfiles() - - # Make the archive - make_zipfile(self.egg_output, archive_root, verbose=self.verbose, - dry_run=self.dry_run, mode=self.gen_header()) - if not self.keep_temp: - remove_tree(self.bdist_dir, dry_run=self.dry_run) - - # Add to 'Distribution.dist_files' so that the "upload" command works - getattr(self.distribution, 'dist_files', []).append( - ('bdist_egg', get_python_version(), self.egg_output)) - - def zap_pyfiles(self): - log.info("Removing .py files from temporary directory") - for base, dirs, files in walk_egg(self.bdist_dir): - for name in files: - path = os.path.join(base, name) - - if name.endswith('.py'): - log.debug("Deleting %s", path) - os.unlink(path) - - if base.endswith('__pycache__'): - path_old = path - - pattern = r'(?P.+)\.(?P[^.]+)\.pyc' - m = re.match(pattern, name) - path_new = os.path.join( - base, os.pardir, m.group('name') + '.pyc') - log.info( - "Renaming file from [%s] to [%s]" - % (path_old, path_new)) - try: - os.remove(path_new) - except OSError: - pass - os.rename(path_old, path_new) - - def zip_safe(self): - safe = getattr(self.distribution, 'zip_safe', None) - if safe is not None: - return safe - log.warn("zip_safe flag not set; analyzing archive contents...") - return analyze_egg(self.bdist_dir, self.stubs) - - def gen_header(self): - epm = EntryPoint.parse_map(self.distribution.entry_points or '') - ep = epm.get('setuptools.installation', {}).get('eggsecutable') - if ep is None: - return 'w' # not an eggsecutable, do it the usual way. - - if not ep.attrs or ep.extras: - raise DistutilsSetupError( - "eggsecutable entry point (%r) cannot have 'extras' " - "or refer to a module" % (ep,) - ) - - pyver = '{}.{}'.format(*sys.version_info) - pkg = ep.module_name - full = '.'.join(ep.attrs) - base = ep.attrs[0] - basename = os.path.basename(self.egg_output) - - header = ( - "#!/bin/sh\n" - 'if [ `basename $0` = "%(basename)s" ]\n' - 'then exec python%(pyver)s -c "' - "import sys, os; sys.path.insert(0, os.path.abspath('$0')); " - "from %(pkg)s import %(base)s; sys.exit(%(full)s())" - '" "$@"\n' - 'else\n' - ' echo $0 is not the correct name for this egg file.\n' - ' echo Please rename it back to %(basename)s and try again.\n' - ' exec false\n' - 'fi\n' - ) % locals() - - if not self.dry_run: - mkpath(os.path.dirname(self.egg_output), dry_run=self.dry_run) - f = open(self.egg_output, 'w') - f.write(header) - f.close() - return 'a' - - def copy_metadata_to(self, target_dir): - "Copy metadata (egg info) to the target_dir" - # normalize the path (so that a forward-slash in egg_info will - # match using startswith below) - norm_egg_info = os.path.normpath(self.egg_info) - prefix = os.path.join(norm_egg_info, '') - for path in self.ei_cmd.filelist.files: - if path.startswith(prefix): - target = os.path.join(target_dir, path[len(prefix):]) - ensure_directory(target) - self.copy_file(path, target) - - def get_ext_outputs(self): - """Get a list of relative paths to C extensions in the output distro""" - - all_outputs = [] - ext_outputs = [] - - paths = {self.bdist_dir: ''} - for base, dirs, files in sorted_walk(self.bdist_dir): - for filename in files: - if os.path.splitext(filename)[1].lower() in NATIVE_EXTENSIONS: - all_outputs.append(paths[base] + filename) - for filename in dirs: - paths[os.path.join(base, filename)] = (paths[base] + - filename + '/') - - if self.distribution.has_ext_modules(): - build_cmd = self.get_finalized_command('build_ext') - for ext in build_cmd.extensions: - if isinstance(ext, Library): - continue - fullname = build_cmd.get_ext_fullname(ext.name) - filename = build_cmd.get_ext_filename(fullname) - if not os.path.basename(filename).startswith('dl-'): - if os.path.exists(os.path.join(self.bdist_dir, filename)): - ext_outputs.append(filename) - - return all_outputs, ext_outputs - - -NATIVE_EXTENSIONS = dict.fromkeys('.dll .so .dylib .pyd'.split()) - - -def walk_egg(egg_dir): - """Walk an unpacked egg's contents, skipping the metadata directory""" - walker = sorted_walk(egg_dir) - base, dirs, files = next(walker) - if 'EGG-INFO' in dirs: - dirs.remove('EGG-INFO') - yield base, dirs, files - for bdf in walker: - yield bdf - - -def analyze_egg(egg_dir, stubs): - # check for existing flag in EGG-INFO - for flag, fn in safety_flags.items(): - if os.path.exists(os.path.join(egg_dir, 'EGG-INFO', fn)): - return flag - if not can_scan(): - return False - safe = True - for base, dirs, files in walk_egg(egg_dir): - for name in files: - if name.endswith('.py') or name.endswith('.pyw'): - continue - elif name.endswith('.pyc') or name.endswith('.pyo'): - # always scan, even if we already know we're not safe - safe = scan_module(egg_dir, base, name, stubs) and safe - return safe - - -def write_safety_flag(egg_dir, safe): - # Write or remove zip safety flag file(s) - for flag, fn in safety_flags.items(): - fn = os.path.join(egg_dir, fn) - if os.path.exists(fn): - if safe is None or bool(safe) != flag: - os.unlink(fn) - elif safe is not None and bool(safe) == flag: - f = open(fn, 'wt') - f.write('\n') - f.close() - - -safety_flags = { - True: 'zip-safe', - False: 'not-zip-safe', -} - - -def scan_module(egg_dir, base, name, stubs): - """Check whether module possibly uses unsafe-for-zipfile stuff""" - - filename = os.path.join(base, name) - if filename[:-1] in stubs: - return True # Extension module - pkg = base[len(egg_dir) + 1:].replace(os.sep, '.') - module = pkg + (pkg and '.' or '') + os.path.splitext(name)[0] - if six.PY2: - skip = 8 # skip magic & date - elif sys.version_info < (3, 7): - skip = 12 # skip magic & date & file size - else: - skip = 16 # skip magic & reserved? & date & file size - f = open(filename, 'rb') - f.read(skip) - code = marshal.load(f) - f.close() - safe = True - symbols = dict.fromkeys(iter_symbols(code)) - for bad in ['__file__', '__path__']: - if bad in symbols: - log.warn("%s: module references %s", module, bad) - safe = False - if 'inspect' in symbols: - for bad in [ - 'getsource', 'getabsfile', 'getsourcefile', 'getfile' - 'getsourcelines', 'findsource', 'getcomments', 'getframeinfo', - 'getinnerframes', 'getouterframes', 'stack', 'trace' - ]: - if bad in symbols: - log.warn("%s: module MAY be using inspect.%s", module, bad) - safe = False - return safe - - -def iter_symbols(code): - """Yield names and strings used by `code` and its nested code objects""" - for name in code.co_names: - yield name - for const in code.co_consts: - if isinstance(const, six.string_types): - yield const - elif isinstance(const, CodeType): - for name in iter_symbols(const): - yield name - - -def can_scan(): - if not sys.platform.startswith('java') and sys.platform != 'cli': - # CPython, PyPy, etc. - return True - log.warn("Unable to analyze compiled code on this platform.") - log.warn("Please ask the author to include a 'zip_safe'" - " setting (either True or False) in the package's setup.py") - - -# Attribute names of options for commands that might need to be convinced to -# install to the egg build directory - -INSTALL_DIRECTORY_ATTRS = [ - 'install_lib', 'install_dir', 'install_data', 'install_base' -] - - -def make_zipfile(zip_filename, base_dir, verbose=0, dry_run=0, compress=True, - mode='w'): - """Create a zip file from all the files under 'base_dir'. The output - zip file will be named 'base_dir' + ".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 DistutilsExecError. Returns the name of the output zip file. - """ - import zipfile - - mkpath(os.path.dirname(zip_filename), dry_run=dry_run) - log.info("creating '%s' and adding '%s' to it", zip_filename, base_dir) - - def visit(z, dirname, names): - for name in names: - path = os.path.normpath(os.path.join(dirname, name)) - if os.path.isfile(path): - p = path[len(base_dir) + 1:] - if not dry_run: - z.write(path, p) - log.debug("adding '%s'", p) - - compression = zipfile.ZIP_DEFLATED if compress else zipfile.ZIP_STORED - if not dry_run: - z = zipfile.ZipFile(zip_filename, mode, compression=compression) - for dirname, dirs, files in sorted_walk(base_dir): - visit(z, dirname, files) - z.close() - else: - for dirname, dirs, files in sorted_walk(base_dir): - visit(None, dirname, files) - return zip_filename diff --git a/venv/lib/python3.8/site-packages/setuptools/command/bdist_rpm.py b/venv/lib/python3.8/site-packages/setuptools/command/bdist_rpm.py deleted file mode 100644 index 7073092..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/command/bdist_rpm.py +++ /dev/null @@ -1,43 +0,0 @@ -import distutils.command.bdist_rpm as orig - - -class bdist_rpm(orig.bdist_rpm): - """ - Override the default bdist_rpm behavior to do the following: - - 1. Run egg_info to ensure the name and version are properly calculated. - 2. Always run 'install' using --single-version-externally-managed to - disable eggs in RPM distributions. - 3. Replace dash with underscore in the version numbers for better RPM - compatibility. - """ - - def run(self): - # ensure distro name is up-to-date - self.run_command('egg_info') - - orig.bdist_rpm.run(self) - - def _make_spec_file(self): - version = self.distribution.get_version() - rpmversion = version.replace('-', '_') - spec = orig.bdist_rpm._make_spec_file(self) - line23 = '%define version ' + version - line24 = '%define version ' + rpmversion - spec = [ - line.replace( - "Source0: %{name}-%{version}.tar", - "Source0: %{name}-%{unmangled_version}.tar" - ).replace( - "setup.py install ", - "setup.py install --single-version-externally-managed " - ).replace( - "%setup", - "%setup -n %{name}-%{unmangled_version}" - ).replace(line23, line24) - for line in spec - ] - insert_loc = spec.index(line24) + 1 - unmangled_version = "%define unmangled_version " + version - spec.insert(insert_loc, unmangled_version) - return spec diff --git a/venv/lib/python3.8/site-packages/setuptools/command/bdist_wininst.py b/venv/lib/python3.8/site-packages/setuptools/command/bdist_wininst.py deleted file mode 100644 index 073de97..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/command/bdist_wininst.py +++ /dev/null @@ -1,21 +0,0 @@ -import distutils.command.bdist_wininst as orig - - -class bdist_wininst(orig.bdist_wininst): - def reinitialize_command(self, command, reinit_subcommands=0): - """ - Supplement reinitialize_command to work around - http://bugs.python.org/issue20819 - """ - cmd = self.distribution.reinitialize_command( - command, reinit_subcommands) - if command in ('install', 'install_lib'): - cmd.install_lib = None - return cmd - - def run(self): - self._is_running = True - try: - orig.bdist_wininst.run(self) - finally: - self._is_running = False diff --git a/venv/lib/python3.8/site-packages/setuptools/command/build_clib.py b/venv/lib/python3.8/site-packages/setuptools/command/build_clib.py deleted file mode 100644 index 09caff6..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/command/build_clib.py +++ /dev/null @@ -1,98 +0,0 @@ -import distutils.command.build_clib as orig -from distutils.errors import DistutilsSetupError -from distutils import log -from setuptools.dep_util import newer_pairwise_group - - -class build_clib(orig.build_clib): - """ - Override the default build_clib behaviour to do the following: - - 1. Implement a rudimentary timestamp-based dependency system - so 'compile()' doesn't run every time. - 2. Add more keys to the 'build_info' dictionary: - * obj_deps - specify dependencies for each object compiled. - this should be a dictionary mapping a key - with the source filename to a list of - dependencies. Use an empty string for global - dependencies. - * cflags - specify a list of additional flags to pass to - the compiler. - """ - - def build_libraries(self, libraries): - for (lib_name, build_info) in libraries: - sources = build_info.get('sources') - if sources is None or not isinstance(sources, (list, tuple)): - raise DistutilsSetupError( - "in 'libraries' option (library '%s'), " - "'sources' must be present and must be " - "a list of source filenames" % lib_name) - sources = list(sources) - - log.info("building '%s' library", lib_name) - - # Make sure everything is the correct type. - # obj_deps should be a dictionary of keys as sources - # and a list/tuple of files that are its dependencies. - obj_deps = build_info.get('obj_deps', dict()) - if not isinstance(obj_deps, dict): - raise DistutilsSetupError( - "in 'libraries' option (library '%s'), " - "'obj_deps' must be a dictionary of " - "type 'source: list'" % lib_name) - dependencies = [] - - # Get the global dependencies that are specified by the '' key. - # These will go into every source's dependency list. - global_deps = obj_deps.get('', list()) - if not isinstance(global_deps, (list, tuple)): - raise DistutilsSetupError( - "in 'libraries' option (library '%s'), " - "'obj_deps' must be a dictionary of " - "type 'source: list'" % lib_name) - - # Build the list to be used by newer_pairwise_group - # each source will be auto-added to its dependencies. - for source in sources: - src_deps = [source] - src_deps.extend(global_deps) - extra_deps = obj_deps.get(source, list()) - if not isinstance(extra_deps, (list, tuple)): - raise DistutilsSetupError( - "in 'libraries' option (library '%s'), " - "'obj_deps' must be a dictionary of " - "type 'source: list'" % lib_name) - src_deps.extend(extra_deps) - dependencies.append(src_deps) - - expected_objects = self.compiler.object_filenames( - sources, - output_dir=self.build_temp - ) - - if newer_pairwise_group(dependencies, expected_objects) != ([], []): - # First, compile the source code to object files in the library - # directory. (This should probably change to putting object - # files in a temporary build directory.) - macros = build_info.get('macros') - include_dirs = build_info.get('include_dirs') - cflags = build_info.get('cflags') - objects = self.compiler.compile( - sources, - output_dir=self.build_temp, - macros=macros, - include_dirs=include_dirs, - extra_postargs=cflags, - debug=self.debug - ) - - # Now "link" the object files together into a static library. - # (On Unix at least, this isn't really linking -- it just - # builds an archive. Whatever.) - self.compiler.create_static_lib( - expected_objects, - lib_name, - output_dir=self.build_clib, - debug=self.debug - ) diff --git a/venv/lib/python3.8/site-packages/setuptools/command/build_ext.py b/venv/lib/python3.8/site-packages/setuptools/command/build_ext.py deleted file mode 100644 index daa8e4f..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/command/build_ext.py +++ /dev/null @@ -1,327 +0,0 @@ -import os -import sys -import itertools -from distutils.command.build_ext import build_ext as _du_build_ext -from distutils.file_util import copy_file -from distutils.ccompiler import new_compiler -from distutils.sysconfig import customize_compiler, get_config_var -from distutils.errors import DistutilsError -from distutils import log - -from setuptools.extension import Library -from setuptools.extern import six - -if six.PY2: - import imp - - EXTENSION_SUFFIXES = [s for s, _, tp in imp.get_suffixes() if tp == imp.C_EXTENSION] -else: - from importlib.machinery import EXTENSION_SUFFIXES - -try: - # Attempt to use Cython for building extensions, if available - from Cython.Distutils.build_ext import build_ext as _build_ext - # Additionally, assert that the compiler module will load - # also. Ref #1229. - __import__('Cython.Compiler.Main') -except ImportError: - _build_ext = _du_build_ext - -# make sure _config_vars is initialized -get_config_var("LDSHARED") -from distutils.sysconfig import _config_vars as _CONFIG_VARS - - -def _customize_compiler_for_shlib(compiler): - if sys.platform == "darwin": - # building .dylib requires additional compiler flags on OSX; here we - # temporarily substitute the pyconfig.h variables so that distutils' - # 'customize_compiler' uses them before we build the shared libraries. - tmp = _CONFIG_VARS.copy() - try: - # XXX Help! I don't have any idea whether these are right... - _CONFIG_VARS['LDSHARED'] = ( - "gcc -Wl,-x -dynamiclib -undefined dynamic_lookup") - _CONFIG_VARS['CCSHARED'] = " -dynamiclib" - _CONFIG_VARS['SO'] = ".dylib" - customize_compiler(compiler) - finally: - _CONFIG_VARS.clear() - _CONFIG_VARS.update(tmp) - else: - customize_compiler(compiler) - - -have_rtld = False -use_stubs = False -libtype = 'shared' - -if sys.platform == "darwin": - use_stubs = True -elif os.name != 'nt': - try: - import dl - use_stubs = have_rtld = hasattr(dl, 'RTLD_NOW') - except ImportError: - pass - -if_dl = lambda s: s if have_rtld else '' - - -def get_abi3_suffix(): - """Return the file extension for an abi3-compliant Extension()""" - for suffix in EXTENSION_SUFFIXES: - if '.abi3' in suffix: # Unix - return suffix - elif suffix == '.pyd': # Windows - return suffix - - -class build_ext(_build_ext): - def run(self): - """Build extensions in build directory, then copy if --inplace""" - old_inplace, self.inplace = self.inplace, 0 - _build_ext.run(self) - self.inplace = old_inplace - if old_inplace: - self.copy_extensions_to_source() - - def copy_extensions_to_source(self): - build_py = self.get_finalized_command('build_py') - for ext in self.extensions: - fullname = self.get_ext_fullname(ext.name) - filename = self.get_ext_filename(fullname) - modpath = fullname.split('.') - package = '.'.join(modpath[:-1]) - package_dir = build_py.get_package_dir(package) - dest_filename = os.path.join(package_dir, - os.path.basename(filename)) - src_filename = os.path.join(self.build_lib, filename) - - # Always copy, even if source is older than destination, to ensure - # that the right extensions for the current Python/platform are - # used. - copy_file( - src_filename, dest_filename, verbose=self.verbose, - dry_run=self.dry_run - ) - if ext._needs_stub: - self.write_stub(package_dir or os.curdir, ext, True) - - def get_ext_filename(self, fullname): - filename = _build_ext.get_ext_filename(self, fullname) - if fullname in self.ext_map: - ext = self.ext_map[fullname] - use_abi3 = ( - six.PY3 - and getattr(ext, 'py_limited_api') - and get_abi3_suffix() - ) - if use_abi3: - so_ext = get_config_var('EXT_SUFFIX') - filename = filename[:-len(so_ext)] - filename = filename + get_abi3_suffix() - if isinstance(ext, Library): - fn, ext = os.path.splitext(filename) - return self.shlib_compiler.library_filename(fn, libtype) - elif use_stubs and ext._links_to_dynamic: - d, fn = os.path.split(filename) - return os.path.join(d, 'dl-' + fn) - return filename - - def initialize_options(self): - _build_ext.initialize_options(self) - self.shlib_compiler = None - self.shlibs = [] - self.ext_map = {} - - def finalize_options(self): - _build_ext.finalize_options(self) - self.extensions = self.extensions or [] - self.check_extensions_list(self.extensions) - self.shlibs = [ext for ext in self.extensions - if isinstance(ext, Library)] - if self.shlibs: - self.setup_shlib_compiler() - for ext in self.extensions: - ext._full_name = self.get_ext_fullname(ext.name) - for ext in self.extensions: - fullname = ext._full_name - self.ext_map[fullname] = ext - - # distutils 3.1 will also ask for module names - # XXX what to do with conflicts? - self.ext_map[fullname.split('.')[-1]] = ext - - ltd = self.shlibs and self.links_to_dynamic(ext) or False - ns = ltd and use_stubs and not isinstance(ext, Library) - ext._links_to_dynamic = ltd - ext._needs_stub = ns - filename = ext._file_name = self.get_ext_filename(fullname) - libdir = os.path.dirname(os.path.join(self.build_lib, filename)) - if ltd and libdir not in ext.library_dirs: - ext.library_dirs.append(libdir) - if ltd and use_stubs and os.curdir not in ext.runtime_library_dirs: - ext.runtime_library_dirs.append(os.curdir) - - def setup_shlib_compiler(self): - compiler = self.shlib_compiler = new_compiler( - compiler=self.compiler, dry_run=self.dry_run, force=self.force - ) - _customize_compiler_for_shlib(compiler) - - if self.include_dirs is not None: - compiler.set_include_dirs(self.include_dirs) - if self.define is not None: - # 'define' option is a list of (name,value) tuples - for (name, value) in self.define: - compiler.define_macro(name, value) - if self.undef is not None: - for macro in self.undef: - compiler.undefine_macro(macro) - if self.libraries is not None: - compiler.set_libraries(self.libraries) - if self.library_dirs is not None: - compiler.set_library_dirs(self.library_dirs) - if self.rpath is not None: - compiler.set_runtime_library_dirs(self.rpath) - if self.link_objects is not None: - compiler.set_link_objects(self.link_objects) - - # hack so distutils' build_extension() builds a library instead - compiler.link_shared_object = link_shared_object.__get__(compiler) - - def get_export_symbols(self, ext): - if isinstance(ext, Library): - return ext.export_symbols - return _build_ext.get_export_symbols(self, ext) - - def build_extension(self, ext): - ext._convert_pyx_sources_to_lang() - _compiler = self.compiler - try: - if isinstance(ext, Library): - self.compiler = self.shlib_compiler - _build_ext.build_extension(self, ext) - if ext._needs_stub: - cmd = self.get_finalized_command('build_py').build_lib - self.write_stub(cmd, ext) - finally: - self.compiler = _compiler - - def links_to_dynamic(self, ext): - """Return true if 'ext' links to a dynamic lib in the same package""" - # XXX this should check to ensure the lib is actually being built - # XXX as dynamic, and not just using a locally-found version or a - # XXX static-compiled version - libnames = dict.fromkeys([lib._full_name for lib in self.shlibs]) - pkg = '.'.join(ext._full_name.split('.')[:-1] + ['']) - return any(pkg + libname in libnames for libname in ext.libraries) - - def get_outputs(self): - return _build_ext.get_outputs(self) + self.__get_stubs_outputs() - - def __get_stubs_outputs(self): - # assemble the base name for each extension that needs a stub - ns_ext_bases = ( - os.path.join(self.build_lib, *ext._full_name.split('.')) - for ext in self.extensions - if ext._needs_stub - ) - # pair each base with the extension - pairs = itertools.product(ns_ext_bases, self.__get_output_extensions()) - return list(base + fnext for base, fnext in pairs) - - def __get_output_extensions(self): - yield '.py' - yield '.pyc' - if self.get_finalized_command('build_py').optimize: - yield '.pyo' - - def write_stub(self, output_dir, ext, compile=False): - log.info("writing stub loader for %s to %s", ext._full_name, - output_dir) - stub_file = (os.path.join(output_dir, *ext._full_name.split('.')) + - '.py') - if compile and os.path.exists(stub_file): - raise DistutilsError(stub_file + " already exists! Please delete.") - if not self.dry_run: - f = open(stub_file, 'w') - f.write( - '\n'.join([ - "def __bootstrap__():", - " global __bootstrap__, __file__, __loader__", - " import sys, os, pkg_resources, imp" + if_dl(", dl"), - " __file__ = pkg_resources.resource_filename" - "(__name__,%r)" - % os.path.basename(ext._file_name), - " del __bootstrap__", - " if '__loader__' in globals():", - " del __loader__", - if_dl(" old_flags = sys.getdlopenflags()"), - " old_dir = os.getcwd()", - " try:", - " os.chdir(os.path.dirname(__file__))", - if_dl(" sys.setdlopenflags(dl.RTLD_NOW)"), - " imp.load_dynamic(__name__,__file__)", - " finally:", - if_dl(" sys.setdlopenflags(old_flags)"), - " os.chdir(old_dir)", - "__bootstrap__()", - "" # terminal \n - ]) - ) - f.close() - if compile: - from distutils.util import byte_compile - - byte_compile([stub_file], optimize=0, - force=True, dry_run=self.dry_run) - optimize = self.get_finalized_command('install_lib').optimize - if optimize > 0: - byte_compile([stub_file], optimize=optimize, - force=True, dry_run=self.dry_run) - if os.path.exists(stub_file) and not self.dry_run: - os.unlink(stub_file) - - -if use_stubs or os.name == 'nt': - # Build shared libraries - # - def link_shared_object( - self, objects, output_libname, output_dir=None, libraries=None, - library_dirs=None, runtime_library_dirs=None, export_symbols=None, - debug=0, extra_preargs=None, extra_postargs=None, build_temp=None, - target_lang=None): - self.link( - self.SHARED_LIBRARY, objects, output_libname, - output_dir, libraries, library_dirs, runtime_library_dirs, - export_symbols, debug, extra_preargs, extra_postargs, - build_temp, target_lang - ) -else: - # Build static libraries everywhere else - libtype = 'static' - - def link_shared_object( - self, objects, output_libname, output_dir=None, libraries=None, - library_dirs=None, runtime_library_dirs=None, export_symbols=None, - debug=0, extra_preargs=None, extra_postargs=None, build_temp=None, - target_lang=None): - # XXX we need to either disallow these attrs on Library instances, - # or warn/abort here if set, or something... - # libraries=None, library_dirs=None, runtime_library_dirs=None, - # export_symbols=None, extra_preargs=None, extra_postargs=None, - # build_temp=None - - assert output_dir is None # distutils build_ext doesn't pass this - output_dir, filename = os.path.split(output_libname) - basename, ext = os.path.splitext(filename) - if self.library_filename("x").startswith('lib'): - # strip 'lib' prefix; this is kludgy if some platform uses - # a different prefix - basename = basename[3:] - - self.create_static_lib( - objects, basename, output_dir, debug, target_lang - ) diff --git a/venv/lib/python3.8/site-packages/setuptools/command/build_py.py b/venv/lib/python3.8/site-packages/setuptools/command/build_py.py deleted file mode 100644 index b0314fd..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/command/build_py.py +++ /dev/null @@ -1,270 +0,0 @@ -from glob import glob -from distutils.util import convert_path -import distutils.command.build_py as orig -import os -import fnmatch -import textwrap -import io -import distutils.errors -import itertools - -from setuptools.extern import six -from setuptools.extern.six.moves import map, filter, filterfalse - -try: - from setuptools.lib2to3_ex import Mixin2to3 -except ImportError: - - class Mixin2to3: - def run_2to3(self, files, doctests=True): - "do nothing" - - -class build_py(orig.build_py, Mixin2to3): - """Enhanced 'build_py' command that includes data files with packages - - The data files are specified via a 'package_data' argument to 'setup()'. - See 'setuptools.dist.Distribution' for more details. - - Also, this version of the 'build_py' command allows you to specify both - 'py_modules' and 'packages' in the same setup operation. - """ - - def finalize_options(self): - orig.build_py.finalize_options(self) - self.package_data = self.distribution.package_data - self.exclude_package_data = (self.distribution.exclude_package_data or - {}) - if 'data_files' in self.__dict__: - del self.__dict__['data_files'] - self.__updated_files = [] - self.__doctests_2to3 = [] - - def run(self): - """Build modules, packages, and copy data files to build directory""" - if not self.py_modules and not self.packages: - return - - if self.py_modules: - self.build_modules() - - if self.packages: - self.build_packages() - self.build_package_data() - - self.run_2to3(self.__updated_files, False) - self.run_2to3(self.__updated_files, True) - self.run_2to3(self.__doctests_2to3, True) - - # Only compile actual .py files, using our base class' idea of what our - # output files are. - self.byte_compile(orig.build_py.get_outputs(self, include_bytecode=0)) - - def __getattr__(self, attr): - "lazily compute data files" - if attr == 'data_files': - self.data_files = self._get_data_files() - return self.data_files - return orig.build_py.__getattr__(self, attr) - - def build_module(self, module, module_file, package): - if six.PY2 and isinstance(package, six.string_types): - # avoid errors on Python 2 when unicode is passed (#190) - package = package.split('.') - outfile, copied = orig.build_py.build_module(self, module, module_file, - package) - if copied: - self.__updated_files.append(outfile) - return outfile, copied - - def _get_data_files(self): - """Generate list of '(package,src_dir,build_dir,filenames)' tuples""" - self.analyze_manifest() - return list(map(self._get_pkg_data_files, self.packages or ())) - - def _get_pkg_data_files(self, package): - # Locate package source directory - src_dir = self.get_package_dir(package) - - # Compute package build directory - build_dir = os.path.join(*([self.build_lib] + package.split('.'))) - - # Strip directory from globbed filenames - filenames = [ - os.path.relpath(file, src_dir) - for file in self.find_data_files(package, src_dir) - ] - return package, src_dir, build_dir, filenames - - def find_data_files(self, package, src_dir): - """Return filenames for package's data files in 'src_dir'""" - patterns = self._get_platform_patterns( - self.package_data, - package, - src_dir, - ) - globs_expanded = map(glob, patterns) - # flatten the expanded globs into an iterable of matches - globs_matches = itertools.chain.from_iterable(globs_expanded) - glob_files = filter(os.path.isfile, globs_matches) - files = itertools.chain( - self.manifest_files.get(package, []), - glob_files, - ) - return self.exclude_data_files(package, src_dir, files) - - def build_package_data(self): - """Copy data files into build directory""" - for package, src_dir, build_dir, filenames in self.data_files: - for filename in filenames: - target = os.path.join(build_dir, filename) - self.mkpath(os.path.dirname(target)) - srcfile = os.path.join(src_dir, filename) - outf, copied = self.copy_file(srcfile, target) - srcfile = os.path.abspath(srcfile) - if (copied and - srcfile in self.distribution.convert_2to3_doctests): - self.__doctests_2to3.append(outf) - - def analyze_manifest(self): - self.manifest_files = mf = {} - if not self.distribution.include_package_data: - return - src_dirs = {} - for package in self.packages or (): - # Locate package source directory - src_dirs[assert_relative(self.get_package_dir(package))] = package - - self.run_command('egg_info') - ei_cmd = self.get_finalized_command('egg_info') - for path in ei_cmd.filelist.files: - d, f = os.path.split(assert_relative(path)) - prev = None - oldf = f - while d and d != prev and d not in src_dirs: - prev = d - d, df = os.path.split(d) - f = os.path.join(df, f) - if d in src_dirs: - if path.endswith('.py') and f == oldf: - continue # it's a module, not data - mf.setdefault(src_dirs[d], []).append(path) - - def get_data_files(self): - pass # Lazily compute data files in _get_data_files() function. - - def check_package(self, package, package_dir): - """Check namespace packages' __init__ for declare_namespace""" - try: - return self.packages_checked[package] - except KeyError: - pass - - init_py = orig.build_py.check_package(self, package, package_dir) - self.packages_checked[package] = init_py - - if not init_py or not self.distribution.namespace_packages: - return init_py - - for pkg in self.distribution.namespace_packages: - if pkg == package or pkg.startswith(package + '.'): - break - else: - return init_py - - with io.open(init_py, 'rb') as f: - contents = f.read() - if b'declare_namespace' not in contents: - raise distutils.errors.DistutilsError( - "Namespace package problem: %s is a namespace package, but " - "its\n__init__.py does not call declare_namespace()! Please " - 'fix it.\n(See the setuptools manual under ' - '"Namespace Packages" for details.)\n"' % (package,) - ) - return init_py - - def initialize_options(self): - self.packages_checked = {} - orig.build_py.initialize_options(self) - - def get_package_dir(self, package): - res = orig.build_py.get_package_dir(self, package) - if self.distribution.src_root is not None: - return os.path.join(self.distribution.src_root, res) - return res - - def exclude_data_files(self, package, src_dir, files): - """Filter filenames for package's data files in 'src_dir'""" - files = list(files) - patterns = self._get_platform_patterns( - self.exclude_package_data, - package, - src_dir, - ) - match_groups = ( - fnmatch.filter(files, pattern) - for pattern in patterns - ) - # flatten the groups of matches into an iterable of matches - matches = itertools.chain.from_iterable(match_groups) - bad = set(matches) - keepers = ( - fn - for fn in files - if fn not in bad - ) - # ditch dupes - return list(_unique_everseen(keepers)) - - @staticmethod - def _get_platform_patterns(spec, package, src_dir): - """ - yield platform-specific path patterns (suitable for glob - or fn_match) from a glob-based spec (such as - self.package_data or self.exclude_package_data) - matching package in src_dir. - """ - raw_patterns = itertools.chain( - spec.get('', []), - spec.get(package, []), - ) - return ( - # Each pattern has to be converted to a platform-specific path - os.path.join(src_dir, convert_path(pattern)) - for pattern in raw_patterns - ) - - -# from Python docs -def _unique_everseen(iterable, key=None): - "List unique elements, preserving order. Remember all elements ever seen." - # unique_everseen('AAAABBBCCDAABBB') --> A B C D - # unique_everseen('ABBCcAD', str.lower) --> A B C D - seen = set() - seen_add = seen.add - if key is None: - for element in filterfalse(seen.__contains__, iterable): - seen_add(element) - yield element - else: - for element in iterable: - k = key(element) - if k not in seen: - seen_add(k) - yield element - - -def assert_relative(path): - if not os.path.isabs(path): - return path - from distutils.errors import DistutilsSetupError - - msg = textwrap.dedent(""" - Error: setup script specifies an absolute path: - - %s - - setup() arguments must *always* be /-separated paths relative to the - setup.py directory, *never* absolute paths. - """).lstrip() % path - raise DistutilsSetupError(msg) diff --git a/venv/lib/python3.8/site-packages/setuptools/command/develop.py b/venv/lib/python3.8/site-packages/setuptools/command/develop.py deleted file mode 100644 index 009e4f9..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/command/develop.py +++ /dev/null @@ -1,221 +0,0 @@ -from distutils.util import convert_path -from distutils import log -from distutils.errors import DistutilsError, DistutilsOptionError -import os -import glob -import io - -from setuptools.extern import six - -import pkg_resources -from setuptools.command.easy_install import easy_install -from setuptools import namespaces -import setuptools - -__metaclass__ = type - - -class develop(namespaces.DevelopInstaller, easy_install): - """Set up package for development""" - - description = "install package in 'development mode'" - - user_options = easy_install.user_options + [ - ("uninstall", "u", "Uninstall this source package"), - ("egg-path=", None, "Set the path to be used in the .egg-link file"), - ] - - boolean_options = easy_install.boolean_options + ['uninstall'] - - command_consumes_arguments = False # override base - - def run(self): - if self.uninstall: - self.multi_version = True - self.uninstall_link() - self.uninstall_namespaces() - else: - self.install_for_development() - self.warn_deprecated_options() - - def initialize_options(self): - self.uninstall = None - self.egg_path = None - easy_install.initialize_options(self) - self.setup_path = None - self.always_copy_from = '.' # always copy eggs installed in curdir - - def finalize_options(self): - ei = self.get_finalized_command("egg_info") - if ei.broken_egg_info: - template = "Please rename %r to %r before using 'develop'" - args = ei.egg_info, ei.broken_egg_info - raise DistutilsError(template % args) - self.args = [ei.egg_name] - - easy_install.finalize_options(self) - self.expand_basedirs() - self.expand_dirs() - # pick up setup-dir .egg files only: no .egg-info - self.package_index.scan(glob.glob('*.egg')) - - egg_link_fn = ei.egg_name + '.egg-link' - self.egg_link = os.path.join(self.install_dir, egg_link_fn) - self.egg_base = ei.egg_base - if self.egg_path is None: - self.egg_path = os.path.abspath(ei.egg_base) - - target = pkg_resources.normalize_path(self.egg_base) - egg_path = pkg_resources.normalize_path( - os.path.join(self.install_dir, self.egg_path)) - if egg_path != target: - raise DistutilsOptionError( - "--egg-path must be a relative path from the install" - " directory to " + target - ) - - # Make a distribution for the package's source - self.dist = pkg_resources.Distribution( - target, - pkg_resources.PathMetadata(target, os.path.abspath(ei.egg_info)), - project_name=ei.egg_name - ) - - self.setup_path = self._resolve_setup_path( - self.egg_base, - self.install_dir, - self.egg_path, - ) - - @staticmethod - def _resolve_setup_path(egg_base, install_dir, egg_path): - """ - Generate a path from egg_base back to '.' where the - setup script resides and ensure that path points to the - setup path from $install_dir/$egg_path. - """ - path_to_setup = egg_base.replace(os.sep, '/').rstrip('/') - if path_to_setup != os.curdir: - path_to_setup = '../' * (path_to_setup.count('/') + 1) - resolved = pkg_resources.normalize_path( - os.path.join(install_dir, egg_path, path_to_setup) - ) - if resolved != pkg_resources.normalize_path(os.curdir): - raise DistutilsOptionError( - "Can't get a consistent path to setup script from" - " installation directory", resolved, - pkg_resources.normalize_path(os.curdir)) - return path_to_setup - - def install_for_development(self): - if six.PY3 and getattr(self.distribution, 'use_2to3', False): - # If we run 2to3 we can not do this inplace: - - # Ensure metadata is up-to-date - self.reinitialize_command('build_py', inplace=0) - self.run_command('build_py') - bpy_cmd = self.get_finalized_command("build_py") - build_path = pkg_resources.normalize_path(bpy_cmd.build_lib) - - # Build extensions - self.reinitialize_command('egg_info', egg_base=build_path) - self.run_command('egg_info') - - self.reinitialize_command('build_ext', inplace=0) - self.run_command('build_ext') - - # Fixup egg-link and easy-install.pth - ei_cmd = self.get_finalized_command("egg_info") - self.egg_path = build_path - self.dist.location = build_path - # XXX - self.dist._provider = pkg_resources.PathMetadata( - build_path, ei_cmd.egg_info) - else: - # Without 2to3 inplace works fine: - self.run_command('egg_info') - - # Build extensions in-place - self.reinitialize_command('build_ext', inplace=1) - self.run_command('build_ext') - - self.install_site_py() # ensure that target dir is site-safe - if setuptools.bootstrap_install_from: - self.easy_install(setuptools.bootstrap_install_from) - setuptools.bootstrap_install_from = None - - self.install_namespaces() - - # create an .egg-link in the installation dir, pointing to our egg - log.info("Creating %s (link to %s)", self.egg_link, self.egg_base) - if not self.dry_run: - with open(self.egg_link, "w") as f: - f.write(self.egg_path + "\n" + self.setup_path) - # postprocess the installed distro, fixing up .pth, installing scripts, - # and handling requirements - self.process_distribution(None, self.dist, not self.no_deps) - - def uninstall_link(self): - if os.path.exists(self.egg_link): - log.info("Removing %s (link to %s)", self.egg_link, self.egg_base) - egg_link_file = open(self.egg_link) - contents = [line.rstrip() for line in egg_link_file] - egg_link_file.close() - if contents not in ([self.egg_path], - [self.egg_path, self.setup_path]): - log.warn("Link points to %s: uninstall aborted", contents) - return - if not self.dry_run: - os.unlink(self.egg_link) - if not self.dry_run: - self.update_pth(self.dist) # remove any .pth link to us - if self.distribution.scripts: - # XXX should also check for entry point scripts! - log.warn("Note: you must uninstall or replace scripts manually!") - - def install_egg_scripts(self, dist): - if dist is not self.dist: - # Installing a dependency, so fall back to normal behavior - return easy_install.install_egg_scripts(self, dist) - - # create wrapper scripts in the script dir, pointing to dist.scripts - - # new-style... - self.install_wrapper_scripts(dist) - - # ...and old-style - for script_name in self.distribution.scripts or []: - script_path = os.path.abspath(convert_path(script_name)) - script_name = os.path.basename(script_path) - with io.open(script_path) as strm: - script_text = strm.read() - self.install_script(dist, script_name, script_text, script_path) - - def install_wrapper_scripts(self, dist): - dist = VersionlessRequirement(dist) - return easy_install.install_wrapper_scripts(self, dist) - - -class VersionlessRequirement: - """ - Adapt a pkg_resources.Distribution to simply return the project - name as the 'requirement' so that scripts will work across - multiple versions. - - >>> from pkg_resources import Distribution - >>> dist = Distribution(project_name='foo', version='1.0') - >>> str(dist.as_requirement()) - 'foo==1.0' - >>> adapted_dist = VersionlessRequirement(dist) - >>> str(adapted_dist.as_requirement()) - 'foo' - """ - - def __init__(self, dist): - self.__dist = dist - - def __getattr__(self, name): - return getattr(self.__dist, name) - - def as_requirement(self): - return self.project_name diff --git a/venv/lib/python3.8/site-packages/setuptools/command/dist_info.py b/venv/lib/python3.8/site-packages/setuptools/command/dist_info.py deleted file mode 100644 index c45258f..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/command/dist_info.py +++ /dev/null @@ -1,36 +0,0 @@ -""" -Create a dist_info directory -As defined in the wheel specification -""" - -import os - -from distutils.core import Command -from distutils import log - - -class dist_info(Command): - - description = 'create a .dist-info directory' - - user_options = [ - ('egg-base=', 'e', "directory containing .egg-info directories" - " (default: top of the source tree)"), - ] - - def initialize_options(self): - self.egg_base = None - - def finalize_options(self): - pass - - def run(self): - egg_info = self.get_finalized_command('egg_info') - egg_info.egg_base = self.egg_base - egg_info.finalize_options() - egg_info.run() - dist_info_dir = egg_info.egg_info[:-len('.egg-info')] + '.dist-info' - log.info("creating '{}'".format(os.path.abspath(dist_info_dir))) - - bdist_wheel = self.get_finalized_command('bdist_wheel') - bdist_wheel.egg2dist(egg_info.egg_info, dist_info_dir) diff --git a/venv/lib/python3.8/site-packages/setuptools/command/easy_install.py b/venv/lib/python3.8/site-packages/setuptools/command/easy_install.py deleted file mode 100644 index 1f6839c..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/command/easy_install.py +++ /dev/null @@ -1,2402 +0,0 @@ -#!/usr/bin/env python -""" -Easy Install ------------- - -A tool for doing automatic download/extract/build of distutils-based Python -packages. For detailed documentation, see the accompanying EasyInstall.txt -file, or visit the `EasyInstall home page`__. - -__ https://setuptools.readthedocs.io/en/latest/easy_install.html - -""" - -from glob import glob -from distutils.util import get_platform -from distutils.util import convert_path, subst_vars -from distutils.errors import ( - DistutilsArgError, DistutilsOptionError, - DistutilsError, DistutilsPlatformError, -) -from distutils.command.install import INSTALL_SCHEMES, SCHEME_KEYS -from distutils import log, dir_util -from distutils.command.build_scripts import first_line_re -from distutils.spawn import find_executable -import sys -import os -import zipimport -import shutil -import tempfile -import zipfile -import re -import stat -import random -import textwrap -import warnings -import site -import struct -import contextlib -import subprocess -import shlex -import io - - -from sysconfig import get_config_vars, get_path - -from setuptools import SetuptoolsDeprecationWarning - -from setuptools.extern import six -from setuptools.extern.six.moves import configparser, map - -from setuptools import Command -from setuptools.sandbox import run_setup -from setuptools.py27compat import rmtree_safe -from setuptools.command import setopt -from setuptools.archive_util import unpack_archive -from setuptools.package_index import ( - PackageIndex, parse_requirement_arg, URL_SCHEME, -) -from setuptools.command import bdist_egg, egg_info -from setuptools.wheel import Wheel -from pkg_resources import ( - yield_lines, normalize_path, resource_string, ensure_directory, - get_distribution, find_distributions, Environment, Requirement, - Distribution, PathMetadata, EggMetadata, WorkingSet, DistributionNotFound, - VersionConflict, DEVELOP_DIST, -) -import pkg_resources.py31compat - -__metaclass__ = type - -# Turn on PEP440Warnings -warnings.filterwarnings("default", category=pkg_resources.PEP440Warning) - -__all__ = [ - 'samefile', 'easy_install', 'PthDistributions', 'extract_wininst_cfg', - 'main', 'get_exe_prefixes', -] - - -def is_64bit(): - return struct.calcsize("P") == 8 - - -def samefile(p1, p2): - """ - Determine if two paths reference the same file. - - Augments os.path.samefile to work on Windows and - suppresses errors if the path doesn't exist. - """ - both_exist = os.path.exists(p1) and os.path.exists(p2) - use_samefile = hasattr(os.path, 'samefile') and both_exist - if use_samefile: - return os.path.samefile(p1, p2) - norm_p1 = os.path.normpath(os.path.normcase(p1)) - norm_p2 = os.path.normpath(os.path.normcase(p2)) - return norm_p1 == norm_p2 - - -if six.PY2: - - def _to_bytes(s): - return s - - def isascii(s): - try: - six.text_type(s, 'ascii') - return True - except UnicodeError: - return False -else: - - def _to_bytes(s): - return s.encode('utf8') - - def isascii(s): - try: - s.encode('ascii') - return True - except UnicodeError: - return False - - -_one_liner = lambda text: textwrap.dedent(text).strip().replace('\n', '; ') - - -class easy_install(Command): - """Manage a download/build/install process""" - description = "Find/get/install Python packages" - command_consumes_arguments = True - - user_options = [ - ('prefix=', None, "installation prefix"), - ("zip-ok", "z", "install package as a zipfile"), - ("multi-version", "m", "make apps have to require() a version"), - ("upgrade", "U", "force upgrade (searches PyPI for latest versions)"), - ("install-dir=", "d", "install package to DIR"), - ("script-dir=", "s", "install scripts to DIR"), - ("exclude-scripts", "x", "Don't install scripts"), - ("always-copy", "a", "Copy all needed packages to install dir"), - ("index-url=", "i", "base URL of Python Package Index"), - ("find-links=", "f", "additional URL(s) to search for packages"), - ("build-directory=", "b", - "download/extract/build in DIR; keep the results"), - ('optimize=', 'O', - "also compile with optimization: -O1 for \"python -O\", " - "-O2 for \"python -OO\", and -O0 to disable [default: -O0]"), - ('record=', None, - "filename in which to record list of installed files"), - ('always-unzip', 'Z', "don't install as a zipfile, no matter what"), - ('site-dirs=', 'S', "list of directories where .pth files work"), - ('editable', 'e', "Install specified packages in editable form"), - ('no-deps', 'N', "don't install dependencies"), - ('allow-hosts=', 'H', "pattern(s) that hostnames must match"), - ('local-snapshots-ok', 'l', - "allow building eggs from local checkouts"), - ('version', None, "print version information and exit"), - ('install-layout=', None, "installation layout to choose (known values: deb)"), - ('force-installation-into-system-dir', '0', "force installation into /usr"), - ('no-find-links', None, - "Don't load find-links defined in packages being installed") - ] - boolean_options = [ - 'zip-ok', 'multi-version', 'exclude-scripts', 'upgrade', 'always-copy', - 'editable', - 'no-deps', 'local-snapshots-ok', 'version', 'force-installation-into-system-dir' - ] - - if site.ENABLE_USER_SITE: - help_msg = "install in user site-package '%s'" % site.USER_SITE - user_options.append(('user', None, help_msg)) - boolean_options.append('user') - - negative_opt = {'always-unzip': 'zip-ok'} - create_index = PackageIndex - - def initialize_options(self): - # the --user option seems to be an opt-in one, - # so the default should be False. - self.user = 0 - self.zip_ok = self.local_snapshots_ok = None - self.install_dir = self.script_dir = self.exclude_scripts = None - self.index_url = None - self.find_links = None - self.build_directory = None - self.args = None - self.optimize = self.record = None - self.upgrade = self.always_copy = self.multi_version = None - self.editable = self.no_deps = self.allow_hosts = None - self.root = self.prefix = self.no_report = None - self.version = None - self.install_purelib = None # for pure module distributions - self.install_platlib = None # non-pure (dists w/ extensions) - self.install_headers = None # for C/C++ headers - self.install_lib = None # set to either purelib or platlib - self.install_scripts = None - self.install_data = None - self.install_base = None - self.install_platbase = None - if site.ENABLE_USER_SITE: - self.install_userbase = site.USER_BASE - self.install_usersite = site.USER_SITE - else: - self.install_userbase = None - self.install_usersite = None - self.no_find_links = None - - # Options not specifiable via command line - self.package_index = None - self.pth_file = self.always_copy_from = None - self.site_dirs = None - self.installed_projects = {} - self.sitepy_installed = False - # enable custom installation, known values: deb - self.install_layout = None - self.force_installation_into_system_dir = None - self.multiarch = None - - # Always read easy_install options, even if we are subclassed, or have - # an independent instance created. This ensures that defaults will - # always come from the standard configuration file(s)' "easy_install" - # section, even if this is a "develop" or "install" command, or some - # other embedding. - self._dry_run = None - self.verbose = self.distribution.verbose - self.distribution._set_command_options( - self, self.distribution.get_option_dict('easy_install') - ) - - def delete_blockers(self, blockers): - extant_blockers = ( - filename for filename in blockers - if os.path.exists(filename) or os.path.islink(filename) - ) - list(map(self._delete_path, extant_blockers)) - - def _delete_path(self, path): - log.info("Deleting %s", path) - if self.dry_run: - return - - is_tree = os.path.isdir(path) and not os.path.islink(path) - remover = rmtree if is_tree else os.unlink - remover(path) - - @staticmethod - def _render_version(): - """ - Render the Setuptools version and installation details, then exit. - """ - ver = '{}.{}'.format(*sys.version_info) - dist = get_distribution('setuptools') - tmpl = 'setuptools {dist.version} from {dist.location} (Python {ver})' - print(tmpl.format(**locals())) - raise SystemExit() - - def finalize_options(self): - self.version and self._render_version() - - py_version = sys.version.split()[0] - prefix, exec_prefix = get_config_vars('prefix', 'exec_prefix') - - self.config_vars = { - 'dist_name': self.distribution.get_name(), - 'dist_version': self.distribution.get_version(), - 'dist_fullname': self.distribution.get_fullname(), - 'py_version': py_version, - 'py_version_short': py_version[0:3], - 'py_version_nodot': py_version[0] + py_version[2], - 'sys_prefix': prefix, - 'prefix': prefix, - 'sys_exec_prefix': exec_prefix, - 'exec_prefix': exec_prefix, - # Only python 3.2+ has abiflags - 'abiflags': getattr(sys, 'abiflags', ''), - } - - if site.ENABLE_USER_SITE: - self.config_vars['userbase'] = self.install_userbase - self.config_vars['usersite'] = self.install_usersite - - self._fix_install_dir_for_user_site() - - self.expand_basedirs() - self.expand_dirs() - - if self.install_layout: - if not self.install_layout.lower() in ['deb']: - raise DistutilsOptionError("unknown value for --install-layout") - self.install_layout = self.install_layout.lower() - - import sysconfig - if sys.version_info[:2] >= (3, 3): - self.multiarch = sysconfig.get_config_var('MULTIARCH') - - self._expand( - 'install_dir', 'script_dir', 'build_directory', - 'site_dirs', - ) - # If a non-default installation directory was specified, default the - # script directory to match it. - if self.script_dir is None: - self.script_dir = self.install_dir - - if self.no_find_links is None: - self.no_find_links = False - - # Let install_dir get set by install_lib command, which in turn - # gets its info from the install command, and takes into account - # --prefix and --home and all that other crud. - self.set_undefined_options( - 'install_lib', ('install_dir', 'install_dir') - ) - # Likewise, set default script_dir from 'install_scripts.install_dir' - self.set_undefined_options( - 'install_scripts', ('install_dir', 'script_dir') - ) - - if self.user and self.install_purelib: - self.install_dir = self.install_purelib - self.script_dir = self.install_scripts - - if self.prefix == '/usr' and not self.force_installation_into_system_dir: - raise DistutilsOptionError("""installation into /usr - -Trying to install into the system managed parts of the file system. Please -consider to install to another location, or use the option ---force-installation-into-system-dir to overwrite this warning. -""") - - # default --record from the install command - self.set_undefined_options('install', ('record', 'record')) - # Should this be moved to the if statement below? It's not used - # elsewhere - normpath = map(normalize_path, sys.path) - self.all_site_dirs = get_site_dirs() - if self.site_dirs is not None: - site_dirs = [ - os.path.expanduser(s.strip()) for s in - self.site_dirs.split(',') - ] - for d in site_dirs: - if not os.path.isdir(d): - log.warn("%s (in --site-dirs) does not exist", d) - elif normalize_path(d) not in normpath: - raise DistutilsOptionError( - d + " (in --site-dirs) is not on sys.path" - ) - else: - self.all_site_dirs.append(normalize_path(d)) - if not self.editable: - self.check_site_dir() - self.index_url = self.index_url or "https://pypi.org/simple/" - self.shadow_path = self.all_site_dirs[:] - for path_item in self.install_dir, normalize_path(self.script_dir): - if path_item not in self.shadow_path: - self.shadow_path.insert(0, path_item) - - if self.allow_hosts is not None: - hosts = [s.strip() for s in self.allow_hosts.split(',')] - else: - hosts = ['*'] - if self.package_index is None: - self.package_index = self.create_index( - self.index_url, search_path=self.shadow_path, hosts=hosts, - ) - self.local_index = Environment(self.shadow_path + sys.path) - - if self.find_links is not None: - if isinstance(self.find_links, six.string_types): - self.find_links = self.find_links.split() - else: - self.find_links = [] - if self.local_snapshots_ok: - self.package_index.scan_egg_links(self.shadow_path + sys.path) - if not self.no_find_links: - self.package_index.add_find_links(self.find_links) - self.set_undefined_options('install_lib', ('optimize', 'optimize')) - if not isinstance(self.optimize, int): - try: - self.optimize = int(self.optimize) - if not (0 <= self.optimize <= 2): - raise ValueError - except ValueError: - raise DistutilsOptionError("--optimize must be 0, 1, or 2") - - if self.editable and not self.build_directory: - raise DistutilsArgError( - "Must specify a build directory (-b) when using --editable" - ) - if not self.args: - raise DistutilsArgError( - "No urls, filenames, or requirements specified (see --help)") - - self.outputs = [] - - def _fix_install_dir_for_user_site(self): - """ - Fix the install_dir if "--user" was used. - """ - if not self.user or not site.ENABLE_USER_SITE: - return - - self.create_home_path() - if self.install_userbase is None: - msg = "User base directory is not specified" - raise DistutilsPlatformError(msg) - self.install_base = self.install_platbase = self.install_userbase - scheme_name = os.name.replace('posix', 'unix') + '_user' - self.select_scheme(scheme_name) - - def _expand_attrs(self, attrs): - for attr in attrs: - val = getattr(self, attr) - if val is not None: - if os.name == 'posix' or os.name == 'nt': - val = os.path.expanduser(val) - val = subst_vars(val, self.config_vars) - setattr(self, attr, val) - - def expand_basedirs(self): - """Calls `os.path.expanduser` on install_base, install_platbase and - root.""" - self._expand_attrs(['install_base', 'install_platbase', 'root']) - - def expand_dirs(self): - """Calls `os.path.expanduser` on install dirs.""" - dirs = [ - 'install_purelib', - 'install_platlib', - 'install_lib', - 'install_headers', - 'install_scripts', - 'install_data', - ] - self._expand_attrs(dirs) - - def run(self, show_deprecation=True): - if show_deprecation: - self.announce( - "WARNING: The easy_install command is deprecated " - "and will be removed in a future version." - , log.WARN, - ) - if self.verbose != self.distribution.verbose: - log.set_verbosity(self.verbose) - try: - for spec in self.args: - self.easy_install(spec, not self.no_deps) - if self.record: - outputs = list(sorted(self.outputs)) - if self.root: # strip any package prefix - root_len = len(self.root) - for counter in range(len(outputs)): - outputs[counter] = outputs[counter][root_len:] - from distutils import file_util - - self.execute( - file_util.write_file, (self.record, outputs), - "writing list of installed files to '%s'" % - self.record - ) - self.warn_deprecated_options() - finally: - log.set_verbosity(self.distribution.verbose) - - def pseudo_tempname(self): - """Return a pseudo-tempname base in the install directory. - This code is intentionally naive; if a malicious party can write to - the target directory you're already in deep doodoo. - """ - try: - pid = os.getpid() - except Exception: - pid = random.randint(0, sys.maxsize) - return os.path.join(self.install_dir, "test-easy-install-%s" % pid) - - def warn_deprecated_options(self): - pass - - def check_site_dir(self): - """Verify that self.install_dir is .pth-capable dir, if needed""" - - instdir = normalize_path(self.install_dir) - pth_file = os.path.join(instdir, 'easy-install.pth') - - # Is it a configured, PYTHONPATH, implicit, or explicit site dir? - is_site_dir = instdir in self.all_site_dirs - - if not is_site_dir and not self.multi_version: - # No? Then directly test whether it does .pth file processing - is_site_dir = self.check_pth_processing() - else: - # make sure we can write to target dir - testfile = self.pseudo_tempname() + '.write-test' - test_exists = os.path.exists(testfile) - try: - if test_exists: - os.unlink(testfile) - open(testfile, 'w').close() - os.unlink(testfile) - except (OSError, IOError): - self.cant_write_to_target() - - if not is_site_dir and not self.multi_version: - # Can't install non-multi to non-site dir - raise DistutilsError(self.no_default_version_msg()) - - if is_site_dir: - if self.pth_file is None: - self.pth_file = PthDistributions(pth_file, self.all_site_dirs) - else: - self.pth_file = None - - if instdir not in map(normalize_path, _pythonpath()): - # only PYTHONPATH dirs need a site.py, so pretend it's there - self.sitepy_installed = True - elif self.multi_version and not os.path.exists(pth_file): - self.sitepy_installed = True # don't need site.py in this case - self.pth_file = None # and don't create a .pth file - self.install_dir = instdir - - __cant_write_msg = textwrap.dedent(""" - can't create or remove files in install directory - - The following error occurred while trying to add or remove files in the - installation directory: - - %s - - The installation directory you specified (via --install-dir, --prefix, or - the distutils default setting) was: - - %s - """).lstrip() - - __not_exists_id = textwrap.dedent(""" - This directory does not currently exist. Please create it and try again, or - choose a different installation directory (using the -d or --install-dir - option). - """).lstrip() - - __access_msg = textwrap.dedent(""" - Perhaps your account does not have write access to this directory? If the - installation directory is a system-owned directory, you may need to sign in - as the administrator or "root" account. If you do not have administrative - access to this machine, you may wish to choose a different installation - directory, preferably one that is listed in your PYTHONPATH environment - variable. - - For information on other options, you may wish to consult the - documentation at: - - https://setuptools.readthedocs.io/en/latest/easy_install.html - - Please make the appropriate changes for your system and try again. - """).lstrip() - - def cant_write_to_target(self): - msg = self.__cant_write_msg % (sys.exc_info()[1], self.install_dir,) - - if not os.path.exists(self.install_dir): - msg += '\n' + self.__not_exists_id - else: - msg += '\n' + self.__access_msg - raise DistutilsError(msg) - - def check_pth_processing(self): - """Empirically verify whether .pth files are supported in inst. dir""" - instdir = self.install_dir - log.info("Checking .pth file support in %s", instdir) - pth_file = self.pseudo_tempname() + ".pth" - ok_file = pth_file + '.ok' - ok_exists = os.path.exists(ok_file) - tmpl = _one_liner(""" - import os - f = open({ok_file!r}, 'w') - f.write('OK') - f.close() - """) + '\n' - try: - if ok_exists: - os.unlink(ok_file) - dirname = os.path.dirname(ok_file) - pkg_resources.py31compat.makedirs(dirname, exist_ok=True) - f = open(pth_file, 'w') - except (OSError, IOError): - self.cant_write_to_target() - else: - try: - f.write(tmpl.format(**locals())) - f.close() - f = None - executable = sys.executable - if os.name == 'nt': - dirname, basename = os.path.split(executable) - alt = os.path.join(dirname, 'pythonw.exe') - use_alt = ( - basename.lower() == 'python.exe' and - os.path.exists(alt) - ) - if use_alt: - # use pythonw.exe to avoid opening a console window - executable = alt - - from distutils.spawn import spawn - - spawn([executable, '-E', '-c', 'pass'], 0) - - if os.path.exists(ok_file): - log.info( - "TEST PASSED: %s appears to support .pth files", - instdir - ) - return True - finally: - if f: - f.close() - if os.path.exists(ok_file): - os.unlink(ok_file) - if os.path.exists(pth_file): - os.unlink(pth_file) - if not self.multi_version: - log.warn("TEST FAILED: %s does NOT support .pth files", instdir) - return False - - def install_egg_scripts(self, dist): - """Write all the scripts for `dist`, unless scripts are excluded""" - if not self.exclude_scripts and dist.metadata_isdir('scripts'): - for script_name in dist.metadata_listdir('scripts'): - if dist.metadata_isdir('scripts/' + script_name): - # The "script" is a directory, likely a Python 3 - # __pycache__ directory, so skip it. - continue - self.install_script( - dist, script_name, - dist.get_metadata('scripts/' + script_name) - ) - self.install_wrapper_scripts(dist) - - def add_output(self, path): - if os.path.isdir(path): - for base, dirs, files in os.walk(path): - for filename in files: - self.outputs.append(os.path.join(base, filename)) - else: - self.outputs.append(path) - - def not_editable(self, spec): - if self.editable: - raise DistutilsArgError( - "Invalid argument %r: you can't use filenames or URLs " - "with --editable (except via the --find-links option)." - % (spec,) - ) - - def check_editable(self, spec): - if not self.editable: - return - - if os.path.exists(os.path.join(self.build_directory, spec.key)): - raise DistutilsArgError( - "%r already exists in %s; can't do a checkout there" % - (spec.key, self.build_directory) - ) - - @contextlib.contextmanager - def _tmpdir(self): - tmpdir = tempfile.mkdtemp(prefix=u"easy_install-") - try: - # cast to str as workaround for #709 and #710 and #712 - yield str(tmpdir) - finally: - os.path.exists(tmpdir) and rmtree(rmtree_safe(tmpdir)) - - def easy_install(self, spec, deps=False): - if not self.editable: - self.install_site_py() - - with self._tmpdir() as tmpdir: - if not isinstance(spec, Requirement): - if URL_SCHEME(spec): - # It's a url, download it to tmpdir and process - self.not_editable(spec) - dl = self.package_index.download(spec, tmpdir) - return self.install_item(None, dl, tmpdir, deps, True) - - elif os.path.exists(spec): - # Existing file or directory, just process it directly - self.not_editable(spec) - return self.install_item(None, spec, tmpdir, deps, True) - else: - spec = parse_requirement_arg(spec) - - self.check_editable(spec) - dist = self.package_index.fetch_distribution( - spec, tmpdir, self.upgrade, self.editable, - not self.always_copy, self.local_index - ) - if dist is None: - msg = "Could not find suitable distribution for %r" % spec - if self.always_copy: - msg += " (--always-copy skips system and development eggs)" - raise DistutilsError(msg) - elif dist.precedence == DEVELOP_DIST: - # .egg-info dists don't need installing, just process deps - self.process_distribution(spec, dist, deps, "Using") - return dist - else: - return self.install_item(spec, dist.location, tmpdir, deps) - - def install_item(self, spec, download, tmpdir, deps, install_needed=False): - - # Installation is also needed if file in tmpdir or is not an egg - install_needed = install_needed or self.always_copy - install_needed = install_needed or os.path.dirname(download) == tmpdir - install_needed = install_needed or not download.endswith('.egg') - install_needed = install_needed or ( - self.always_copy_from is not None and - os.path.dirname(normalize_path(download)) == - normalize_path(self.always_copy_from) - ) - - if spec and not install_needed: - # at this point, we know it's a local .egg, we just don't know if - # it's already installed. - for dist in self.local_index[spec.project_name]: - if dist.location == download: - break - else: - install_needed = True # it's not in the local index - - log.info("Processing %s", os.path.basename(download)) - - if install_needed: - dists = self.install_eggs(spec, download, tmpdir) - for dist in dists: - self.process_distribution(spec, dist, deps) - else: - dists = [self.egg_distribution(download)] - self.process_distribution(spec, dists[0], deps, "Using") - - if spec is not None: - for dist in dists: - if dist in spec: - return dist - - def select_scheme(self, name): - """Sets the install directories by applying the install schemes.""" - # it's the caller's problem if they supply a bad name! - scheme = INSTALL_SCHEMES[name] - for key in SCHEME_KEYS: - attrname = 'install_' + key - if getattr(self, attrname) is None: - setattr(self, attrname, scheme[key]) - - def process_distribution(self, requirement, dist, deps=True, *info): - self.update_pth(dist) - self.package_index.add(dist) - if dist in self.local_index[dist.key]: - self.local_index.remove(dist) - self.local_index.add(dist) - self.install_egg_scripts(dist) - self.installed_projects[dist.key] = dist - log.info(self.installation_report(requirement, dist, *info)) - if (dist.has_metadata('dependency_links.txt') and - not self.no_find_links): - self.package_index.add_find_links( - dist.get_metadata_lines('dependency_links.txt') - ) - if not deps and not self.always_copy: - return - elif requirement is not None and dist.key != requirement.key: - log.warn("Skipping dependencies for %s", dist) - return # XXX this is not the distribution we were looking for - elif requirement is None or dist not in requirement: - # if we wound up with a different version, resolve what we've got - distreq = dist.as_requirement() - requirement = Requirement(str(distreq)) - log.info("Processing dependencies for %s", requirement) - try: - distros = WorkingSet([]).resolve( - [requirement], self.local_index, self.easy_install - ) - except DistributionNotFound as e: - raise DistutilsError(str(e)) - except VersionConflict as e: - raise DistutilsError(e.report()) - if self.always_copy or self.always_copy_from: - # Force all the relevant distros to be copied or activated - for dist in distros: - if dist.key not in self.installed_projects: - self.easy_install(dist.as_requirement()) - log.info("Finished processing dependencies for %s", requirement) - - def should_unzip(self, dist): - if self.zip_ok is not None: - return not self.zip_ok - if dist.has_metadata('not-zip-safe'): - return True - if not dist.has_metadata('zip-safe'): - return True - return False - - def maybe_move(self, spec, dist_filename, setup_base): - dst = os.path.join(self.build_directory, spec.key) - if os.path.exists(dst): - msg = ( - "%r already exists in %s; build directory %s will not be kept" - ) - log.warn(msg, spec.key, self.build_directory, setup_base) - return setup_base - if os.path.isdir(dist_filename): - setup_base = dist_filename - else: - if os.path.dirname(dist_filename) == setup_base: - os.unlink(dist_filename) # get it out of the tmp dir - contents = os.listdir(setup_base) - if len(contents) == 1: - dist_filename = os.path.join(setup_base, contents[0]) - if os.path.isdir(dist_filename): - # if the only thing there is a directory, move it instead - setup_base = dist_filename - ensure_directory(dst) - shutil.move(setup_base, dst) - return dst - - def install_wrapper_scripts(self, dist): - if self.exclude_scripts: - return - for args in ScriptWriter.best().get_args(dist): - self.write_script(*args) - - def install_script(self, dist, script_name, script_text, dev_path=None): - """Generate a legacy script wrapper and install it""" - spec = str(dist.as_requirement()) - is_script = is_python_script(script_text, script_name) - - if is_script: - body = self._load_template(dev_path) % locals() - script_text = ScriptWriter.get_header(script_text) + body - self.write_script(script_name, _to_bytes(script_text), 'b') - - @staticmethod - def _load_template(dev_path): - """ - There are a couple of template scripts in the package. This - function loads one of them and prepares it for use. - """ - # See https://github.com/pypa/setuptools/issues/134 for info - # on script file naming and downstream issues with SVR4 - name = 'script.tmpl' - if dev_path: - name = name.replace('.tmpl', ' (dev).tmpl') - - raw_bytes = resource_string('setuptools', name) - return raw_bytes.decode('utf-8') - - def write_script(self, script_name, contents, mode="t", blockers=()): - """Write an executable file to the scripts directory""" - self.delete_blockers( # clean up old .py/.pyw w/o a script - [os.path.join(self.script_dir, x) for x in blockers] - ) - log.info("Installing %s script to %s", script_name, self.script_dir) - target = os.path.join(self.script_dir, script_name) - self.add_output(target) - - if self.dry_run: - return - - mask = current_umask() - ensure_directory(target) - if os.path.exists(target): - os.unlink(target) - with open(target, "w" + mode) as f: - f.write(contents) - chmod(target, 0o777 - mask) - - def install_eggs(self, spec, dist_filename, tmpdir): - # .egg dirs or files are already built, so just return them - if dist_filename.lower().endswith('.egg'): - return [self.install_egg(dist_filename, tmpdir)] - elif dist_filename.lower().endswith('.exe'): - return [self.install_exe(dist_filename, tmpdir)] - elif dist_filename.lower().endswith('.whl'): - return [self.install_wheel(dist_filename, tmpdir)] - - # Anything else, try to extract and build - setup_base = tmpdir - if os.path.isfile(dist_filename) and not dist_filename.endswith('.py'): - unpack_archive(dist_filename, tmpdir, self.unpack_progress) - elif os.path.isdir(dist_filename): - setup_base = os.path.abspath(dist_filename) - - if (setup_base.startswith(tmpdir) # something we downloaded - and self.build_directory and spec is not None): - setup_base = self.maybe_move(spec, dist_filename, setup_base) - - # Find the setup.py file - setup_script = os.path.join(setup_base, 'setup.py') - - if not os.path.exists(setup_script): - setups = glob(os.path.join(setup_base, '*', 'setup.py')) - if not setups: - raise DistutilsError( - "Couldn't find a setup script in %s" % - os.path.abspath(dist_filename) - ) - if len(setups) > 1: - raise DistutilsError( - "Multiple setup scripts in %s" % - os.path.abspath(dist_filename) - ) - setup_script = setups[0] - - # Now run it, and return the result - if self.editable: - log.info(self.report_editable(spec, setup_script)) - return [] - else: - return self.build_and_install(setup_script, setup_base) - - def egg_distribution(self, egg_path): - if os.path.isdir(egg_path): - metadata = PathMetadata(egg_path, os.path.join(egg_path, - 'EGG-INFO')) - else: - metadata = EggMetadata(zipimport.zipimporter(egg_path)) - return Distribution.from_filename(egg_path, metadata=metadata) - - def install_egg(self, egg_path, tmpdir): - destination = os.path.join( - self.install_dir, - os.path.basename(egg_path), - ) - destination = os.path.abspath(destination) - if not self.dry_run: - ensure_directory(destination) - - dist = self.egg_distribution(egg_path) - if not samefile(egg_path, destination): - if os.path.isdir(destination) and not os.path.islink(destination): - dir_util.remove_tree(destination, dry_run=self.dry_run) - elif os.path.exists(destination): - self.execute( - os.unlink, - (destination,), - "Removing " + destination, - ) - try: - new_dist_is_zipped = False - if os.path.isdir(egg_path): - if egg_path.startswith(tmpdir): - f, m = shutil.move, "Moving" - else: - f, m = shutil.copytree, "Copying" - elif self.should_unzip(dist): - self.mkpath(destination) - f, m = self.unpack_and_compile, "Extracting" - else: - new_dist_is_zipped = True - if egg_path.startswith(tmpdir): - f, m = shutil.move, "Moving" - else: - f, m = shutil.copy2, "Copying" - self.execute( - f, - (egg_path, destination), - (m + " %s to %s") % ( - os.path.basename(egg_path), - os.path.dirname(destination) - ), - ) - update_dist_caches( - destination, - fix_zipimporter_caches=new_dist_is_zipped, - ) - except Exception: - update_dist_caches(destination, fix_zipimporter_caches=False) - raise - - self.add_output(destination) - return self.egg_distribution(destination) - - def install_exe(self, dist_filename, tmpdir): - # See if it's valid, get data - cfg = extract_wininst_cfg(dist_filename) - if cfg is None: - raise DistutilsError( - "%s is not a valid distutils Windows .exe" % dist_filename - ) - # Create a dummy distribution object until we build the real distro - dist = Distribution( - None, - project_name=cfg.get('metadata', 'name'), - version=cfg.get('metadata', 'version'), platform=get_platform(), - ) - - # Convert the .exe to an unpacked egg - egg_path = os.path.join(tmpdir, dist.egg_name() + '.egg') - dist.location = egg_path - egg_tmp = egg_path + '.tmp' - _egg_info = os.path.join(egg_tmp, 'EGG-INFO') - pkg_inf = os.path.join(_egg_info, 'PKG-INFO') - ensure_directory(pkg_inf) # make sure EGG-INFO dir exists - dist._provider = PathMetadata(egg_tmp, _egg_info) # XXX - self.exe_to_egg(dist_filename, egg_tmp) - - # Write EGG-INFO/PKG-INFO - if not os.path.exists(pkg_inf): - f = open(pkg_inf, 'w') - f.write('Metadata-Version: 1.0\n') - for k, v in cfg.items('metadata'): - if k != 'target_version': - f.write('%s: %s\n' % (k.replace('_', '-').title(), v)) - f.close() - script_dir = os.path.join(_egg_info, 'scripts') - # delete entry-point scripts to avoid duping - self.delete_blockers([ - os.path.join(script_dir, args[0]) - for args in ScriptWriter.get_args(dist) - ]) - # Build .egg file from tmpdir - bdist_egg.make_zipfile( - egg_path, egg_tmp, verbose=self.verbose, dry_run=self.dry_run, - ) - # install the .egg - return self.install_egg(egg_path, tmpdir) - - def exe_to_egg(self, dist_filename, egg_tmp): - """Extract a bdist_wininst to the directories an egg would use""" - # Check for .pth file and set up prefix translations - prefixes = get_exe_prefixes(dist_filename) - to_compile = [] - native_libs = [] - top_level = {} - - def process(src, dst): - s = src.lower() - for old, new in prefixes: - if s.startswith(old): - src = new + src[len(old):] - parts = src.split('/') - dst = os.path.join(egg_tmp, *parts) - dl = dst.lower() - if dl.endswith('.pyd') or dl.endswith('.dll'): - parts[-1] = bdist_egg.strip_module(parts[-1]) - top_level[os.path.splitext(parts[0])[0]] = 1 - native_libs.append(src) - elif dl.endswith('.py') and old != 'SCRIPTS/': - top_level[os.path.splitext(parts[0])[0]] = 1 - to_compile.append(dst) - return dst - if not src.endswith('.pth'): - log.warn("WARNING: can't process %s", src) - return None - - # extract, tracking .pyd/.dll->native_libs and .py -> to_compile - unpack_archive(dist_filename, egg_tmp, process) - stubs = [] - for res in native_libs: - if res.lower().endswith('.pyd'): # create stubs for .pyd's - parts = res.split('/') - resource = parts[-1] - parts[-1] = bdist_egg.strip_module(parts[-1]) + '.py' - pyfile = os.path.join(egg_tmp, *parts) - to_compile.append(pyfile) - stubs.append(pyfile) - bdist_egg.write_stub(resource, pyfile) - self.byte_compile(to_compile) # compile .py's - bdist_egg.write_safety_flag( - os.path.join(egg_tmp, 'EGG-INFO'), - bdist_egg.analyze_egg(egg_tmp, stubs)) # write zip-safety flag - - for name in 'top_level', 'native_libs': - if locals()[name]: - txt = os.path.join(egg_tmp, 'EGG-INFO', name + '.txt') - if not os.path.exists(txt): - f = open(txt, 'w') - f.write('\n'.join(locals()[name]) + '\n') - f.close() - - def install_wheel(self, wheel_path, tmpdir): - wheel = Wheel(wheel_path) - assert wheel.is_compatible() - destination = os.path.join(self.install_dir, wheel.egg_name()) - destination = os.path.abspath(destination) - if not self.dry_run: - ensure_directory(destination) - if os.path.isdir(destination) and not os.path.islink(destination): - dir_util.remove_tree(destination, dry_run=self.dry_run) - elif os.path.exists(destination): - self.execute( - os.unlink, - (destination,), - "Removing " + destination, - ) - try: - self.execute( - wheel.install_as_egg, - (destination,), - ("Installing %s to %s") % ( - os.path.basename(wheel_path), - os.path.dirname(destination) - ), - ) - finally: - update_dist_caches(destination, fix_zipimporter_caches=False) - self.add_output(destination) - return self.egg_distribution(destination) - - __mv_warning = textwrap.dedent(""" - Because this distribution was installed --multi-version, before you can - import modules from this package in an application, you will need to - 'import pkg_resources' and then use a 'require()' call similar to one of - these examples, in order to select the desired version: - - pkg_resources.require("%(name)s") # latest installed version - pkg_resources.require("%(name)s==%(version)s") # this exact version - pkg_resources.require("%(name)s>=%(version)s") # this version or higher - """).lstrip() - - __id_warning = textwrap.dedent(""" - Note also that the installation directory must be on sys.path at runtime for - this to work. (e.g. by being the application's script directory, by being on - PYTHONPATH, or by being added to sys.path by your code.) - """) - - def installation_report(self, req, dist, what="Installed"): - """Helpful installation message for display to package users""" - msg = "\n%(what)s %(eggloc)s%(extras)s" - if self.multi_version and not self.no_report: - msg += '\n' + self.__mv_warning - if self.install_dir not in map(normalize_path, sys.path): - msg += '\n' + self.__id_warning - - eggloc = dist.location - name = dist.project_name - version = dist.version - extras = '' # TODO: self.report_extras(req, dist) - return msg % locals() - - __editable_msg = textwrap.dedent(""" - Extracted editable version of %(spec)s to %(dirname)s - - If it uses setuptools in its setup script, you can activate it in - "development" mode by going to that directory and running:: - - %(python)s setup.py develop - - See the setuptools documentation for the "develop" command for more info. - """).lstrip() - - def report_editable(self, spec, setup_script): - dirname = os.path.dirname(setup_script) - python = sys.executable - return '\n' + self.__editable_msg % locals() - - def run_setup(self, setup_script, setup_base, args): - sys.modules.setdefault('distutils.command.bdist_egg', bdist_egg) - sys.modules.setdefault('distutils.command.egg_info', egg_info) - - args = list(args) - if self.verbose > 2: - v = 'v' * (self.verbose - 1) - args.insert(0, '-' + v) - elif self.verbose < 2: - args.insert(0, '-q') - if self.dry_run: - args.insert(0, '-n') - log.info( - "Running %s %s", setup_script[len(setup_base) + 1:], ' '.join(args) - ) - try: - run_setup(setup_script, args) - except SystemExit as v: - raise DistutilsError("Setup script exited with %s" % (v.args[0],)) - - def build_and_install(self, setup_script, setup_base): - args = ['bdist_egg', '--dist-dir'] - - dist_dir = tempfile.mkdtemp( - prefix='egg-dist-tmp-', dir=os.path.dirname(setup_script) - ) - try: - self._set_fetcher_options(os.path.dirname(setup_script)) - args.append(dist_dir) - - self.run_setup(setup_script, setup_base, args) - all_eggs = Environment([dist_dir]) - eggs = [] - for key in all_eggs: - for dist in all_eggs[key]: - eggs.append(self.install_egg(dist.location, setup_base)) - if not eggs and not self.dry_run: - log.warn("No eggs found in %s (setup script problem?)", - dist_dir) - return eggs - finally: - rmtree(dist_dir) - log.set_verbosity(self.verbose) # restore our log verbosity - - def _set_fetcher_options(self, base): - """ - When easy_install is about to run bdist_egg on a source dist, that - source dist might have 'setup_requires' directives, requiring - additional fetching. Ensure the fetcher options given to easy_install - are available to that command as well. - """ - # find the fetch options from easy_install and write them out - # to the setup.cfg file. - ei_opts = self.distribution.get_option_dict('easy_install').copy() - fetch_directives = ( - 'find_links', 'site_dirs', 'index_url', 'optimize', 'allow_hosts', - ) - fetch_options = {} - for key, val in ei_opts.items(): - if key not in fetch_directives: - continue - fetch_options[key.replace('_', '-')] = val[1] - # create a settings dictionary suitable for `edit_config` - settings = dict(easy_install=fetch_options) - cfg_filename = os.path.join(base, 'setup.cfg') - setopt.edit_config(cfg_filename, settings) - - def update_pth(self, dist): - if self.pth_file is None: - return - - for d in self.pth_file[dist.key]: # drop old entries - if self.multi_version or d.location != dist.location: - log.info("Removing %s from easy-install.pth file", d) - self.pth_file.remove(d) - if d.location in self.shadow_path: - self.shadow_path.remove(d.location) - - if not self.multi_version: - if dist.location in self.pth_file.paths: - log.info( - "%s is already the active version in easy-install.pth", - dist, - ) - else: - log.info("Adding %s to easy-install.pth file", dist) - self.pth_file.add(dist) # add new entry - if dist.location not in self.shadow_path: - self.shadow_path.append(dist.location) - - if not self.dry_run: - - self.pth_file.save() - - if dist.key == 'setuptools': - # Ensure that setuptools itself never becomes unavailable! - # XXX should this check for latest version? - filename = os.path.join(self.install_dir, 'setuptools.pth') - if os.path.islink(filename): - os.unlink(filename) - f = open(filename, 'wt') - f.write(self.pth_file.make_relative(dist.location) + '\n') - f.close() - - def unpack_progress(self, src, dst): - # Progress filter for unpacking - log.debug("Unpacking %s to %s", src, dst) - return dst # only unpack-and-compile skips files for dry run - - def unpack_and_compile(self, egg_path, destination): - to_compile = [] - to_chmod = [] - - def pf(src, dst): - if dst.endswith('.py') and not src.startswith('EGG-INFO/'): - to_compile.append(dst) - elif dst.endswith('.dll') or dst.endswith('.so'): - to_chmod.append(dst) - self.unpack_progress(src, dst) - return not self.dry_run and dst or None - - unpack_archive(egg_path, destination, pf) - self.byte_compile(to_compile) - if not self.dry_run: - for f in to_chmod: - mode = ((os.stat(f)[stat.ST_MODE]) | 0o555) & 0o7755 - chmod(f, mode) - - def byte_compile(self, to_compile): - if sys.dont_write_bytecode: - return - - from distutils.util import byte_compile - - try: - # try to make the byte compile messages quieter - log.set_verbosity(self.verbose - 1) - - byte_compile(to_compile, optimize=0, force=1, dry_run=self.dry_run) - if self.optimize: - byte_compile( - to_compile, optimize=self.optimize, force=1, - dry_run=self.dry_run, - ) - finally: - log.set_verbosity(self.verbose) # restore original verbosity - - __no_default_msg = textwrap.dedent(""" - bad install directory or PYTHONPATH - - You are attempting to install a package to a directory that is not - on PYTHONPATH and which Python does not read ".pth" files from. The - installation directory you specified (via --install-dir, --prefix, or - the distutils default setting) was: - - %s - - and your PYTHONPATH environment variable currently contains: - - %r - - Here are some of your options for correcting the problem: - - * You can choose a different installation directory, i.e., one that is - on PYTHONPATH or supports .pth files - - * You can add the installation directory to the PYTHONPATH environment - variable. (It must then also be on PYTHONPATH whenever you run - Python and want to use the package(s) you are installing.) - - * You can set up the installation directory to support ".pth" files by - using one of the approaches described here: - - https://setuptools.readthedocs.io/en/latest/easy_install.html#custom-installation-locations - - - Please make the appropriate changes for your system and try again.""").lstrip() - - def no_default_version_msg(self): - template = self.__no_default_msg - return template % (self.install_dir, os.environ.get('PYTHONPATH', '')) - - def install_site_py(self): - """Make sure there's a site.py in the target dir, if needed""" - - if self.sitepy_installed: - return # already did it, or don't need to - - sitepy = os.path.join(self.install_dir, "site.py") - source = resource_string("setuptools", "site-patch.py") - source = source.decode('utf-8') - current = "" - - if os.path.exists(sitepy): - log.debug("Checking existing site.py in %s", self.install_dir) - with io.open(sitepy) as strm: - current = strm.read() - - if not current.startswith('def __boot():'): - raise DistutilsError( - "%s is not a setuptools-generated site.py; please" - " remove it." % sitepy - ) - - if current != source: - log.info("Creating %s", sitepy) - if not self.dry_run: - ensure_directory(sitepy) - with io.open(sitepy, 'w', encoding='utf-8') as strm: - strm.write(source) - self.byte_compile([sitepy]) - - self.sitepy_installed = True - - def create_home_path(self): - """Create directories under ~.""" - if not self.user: - return - home = convert_path(os.path.expanduser("~")) - for name, path in six.iteritems(self.config_vars): - if path.startswith(home) and not os.path.isdir(path): - self.debug_print("os.makedirs('%s', 0o700)" % path) - os.makedirs(path, 0o700) - - if sys.version[:3] in ('2.3', '2.4', '2.5') or 'real_prefix' in sys.__dict__: - sitedir_name = 'site-packages' - else: - sitedir_name = 'dist-packages' - - INSTALL_SCHEMES = dict( - posix=dict( - install_dir='$base/lib/python$py_version_short/site-packages', - script_dir='$base/bin', - ), - unix_local = dict( - install_dir = '$base/local/lib/python$py_version_short/%s' % sitedir_name, - script_dir = '$base/local/bin', - ), - posix_local = dict( - install_dir = '$base/local/lib/python$py_version_short/%s' % sitedir_name, - script_dir = '$base/local/bin', - ), - deb_system = dict( - install_dir = '$base/lib/python3/%s' % sitedir_name, - script_dir = '$base/bin', - ), - ) - - DEFAULT_SCHEME = dict( - install_dir='$base/Lib/site-packages', - script_dir='$base/Scripts', - ) - - def _expand(self, *attrs): - config_vars = self.get_finalized_command('install').config_vars - - if self.prefix or self.install_layout: - if self.install_layout and self.install_layout in ['deb']: - scheme_name = "deb_system" - self.prefix = '/usr' - elif self.prefix or 'real_prefix' in sys.__dict__: - scheme_name = os.name - else: - scheme_name = "posix_local" - # Set default install_dir/scripts from --prefix - config_vars = config_vars.copy() - config_vars['base'] = self.prefix - scheme = self.INSTALL_SCHEMES.get(scheme_name,self.DEFAULT_SCHEME) - for attr, val in scheme.items(): - if getattr(self, attr, None) is None: - setattr(self, attr, val) - - from distutils.util import subst_vars - - for attr in attrs: - val = getattr(self, attr) - if val is not None: - val = subst_vars(val, config_vars) - if os.name == 'posix': - val = os.path.expanduser(val) - setattr(self, attr, val) - - -def _pythonpath(): - items = os.environ.get('PYTHONPATH', '').split(os.pathsep) - return filter(None, items) - - -def get_site_dirs(): - """ - Return a list of 'site' dirs - """ - - sitedirs = [] - - # start with PYTHONPATH - sitedirs.extend(_pythonpath()) - - prefixes = [sys.prefix] - if sys.exec_prefix != sys.prefix: - prefixes.append(sys.exec_prefix) - for prefix in prefixes: - if prefix: - if sys.platform in ('os2emx', 'riscos'): - sitedirs.append(os.path.join(prefix, "Lib", "site-packages")) - elif os.sep == '/': - sitedirs.extend([ - os.path.join( - prefix, - "local/lib", - "python" + sys.version[:3], - "dist-packages", - ), - os.path.join( - prefix, - "lib", - "python{}.{}".format(*sys.version_info), - "dist-packages", - ), - os.path.join(prefix, "lib", "site-python"), - ]) - else: - sitedirs.extend([ - prefix, - os.path.join(prefix, "lib", "site-packages"), - ]) - if sys.platform == 'darwin': - # for framework builds *only* we add the standard Apple - # locations. Currently only per-user, but /Library and - # /Network/Library could be added too - if 'Python.framework' in prefix: - home = os.environ.get('HOME') - if home: - home_sp = os.path.join( - home, - 'Library', - 'Python', - '{}.{}'.format(*sys.version_info), - 'site-packages', - ) - sitedirs.append(home_sp) - lib_paths = get_path('purelib'), get_path('platlib') - for site_lib in lib_paths: - if site_lib not in sitedirs: - sitedirs.append(site_lib) - - if site.ENABLE_USER_SITE: - sitedirs.append(site.USER_SITE) - - try: - sitedirs.extend(site.getsitepackages()) - except AttributeError: - pass - - sitedirs = list(map(normalize_path, sitedirs)) - - return sitedirs - - -def expand_paths(inputs): - """Yield sys.path directories that might contain "old-style" packages""" - - seen = {} - - for dirname in inputs: - dirname = normalize_path(dirname) - if dirname in seen: - continue - - seen[dirname] = 1 - if not os.path.isdir(dirname): - continue - - files = os.listdir(dirname) - yield dirname, files - - for name in files: - if not name.endswith('.pth'): - # We only care about the .pth files - continue - if name in ('easy-install.pth', 'setuptools.pth'): - # Ignore .pth files that we control - continue - - # Read the .pth file - f = open(os.path.join(dirname, name)) - lines = list(yield_lines(f)) - f.close() - - # Yield existing non-dupe, non-import directory lines from it - for line in lines: - if not line.startswith("import"): - line = normalize_path(line.rstrip()) - if line not in seen: - seen[line] = 1 - if not os.path.isdir(line): - continue - yield line, os.listdir(line) - - -def extract_wininst_cfg(dist_filename): - """Extract configuration data from a bdist_wininst .exe - - Returns a configparser.RawConfigParser, or None - """ - f = open(dist_filename, 'rb') - try: - endrec = zipfile._EndRecData(f) - if endrec is None: - return None - - prepended = (endrec[9] - endrec[5]) - endrec[6] - if prepended < 12: # no wininst data here - return None - f.seek(prepended - 12) - - tag, cfglen, bmlen = struct.unpack("egg path translations for a given .exe file""" - - prefixes = [ - ('PURELIB/', ''), - ('PLATLIB/pywin32_system32', ''), - ('PLATLIB/', ''), - ('SCRIPTS/', 'EGG-INFO/scripts/'), - ('DATA/lib/site-packages', ''), - ] - z = zipfile.ZipFile(exe_filename) - try: - for info in z.infolist(): - name = info.filename - parts = name.split('/') - if len(parts) == 3 and parts[2] == 'PKG-INFO': - if parts[1].endswith('.egg-info'): - prefixes.insert(0, ('/'.join(parts[:2]), 'EGG-INFO/')) - break - if len(parts) != 2 or not name.endswith('.pth'): - continue - if name.endswith('-nspkg.pth'): - continue - if parts[0].upper() in ('PURELIB', 'PLATLIB'): - contents = z.read(name) - if six.PY3: - contents = contents.decode() - for pth in yield_lines(contents): - pth = pth.strip().replace('\\', '/') - if not pth.startswith('import'): - prefixes.append((('%s/%s/' % (parts[0], pth)), '')) - finally: - z.close() - prefixes = [(x.lower(), y) for x, y in prefixes] - prefixes.sort() - prefixes.reverse() - return prefixes - - -class PthDistributions(Environment): - """A .pth file with Distribution paths in it""" - - dirty = False - - def __init__(self, filename, sitedirs=()): - self.filename = filename - self.sitedirs = list(map(normalize_path, sitedirs)) - self.basedir = normalize_path(os.path.dirname(self.filename)) - self._load() - Environment.__init__(self, [], None, None) - for path in yield_lines(self.paths): - list(map(self.add, find_distributions(path, True))) - - def _load(self): - self.paths = [] - saw_import = False - seen = dict.fromkeys(self.sitedirs) - if os.path.isfile(self.filename): - f = open(self.filename, 'rt') - for line in f: - if line.startswith('import'): - saw_import = True - continue - path = line.rstrip() - self.paths.append(path) - if not path.strip() or path.strip().startswith('#'): - continue - # skip non-existent paths, in case somebody deleted a package - # manually, and duplicate paths as well - path = self.paths[-1] = normalize_path( - os.path.join(self.basedir, path) - ) - if not os.path.exists(path) or path in seen: - self.paths.pop() # skip it - self.dirty = True # we cleaned up, so we're dirty now :) - continue - seen[path] = 1 - f.close() - - if self.paths and not saw_import: - self.dirty = True # ensure anything we touch has import wrappers - while self.paths and not self.paths[-1].strip(): - self.paths.pop() - - def save(self): - """Write changed .pth file back to disk""" - if not self.dirty: - return - - rel_paths = list(map(self.make_relative, self.paths)) - if rel_paths: - log.debug("Saving %s", self.filename) - lines = self._wrap_lines(rel_paths) - data = '\n'.join(lines) + '\n' - - if os.path.islink(self.filename): - os.unlink(self.filename) - with open(self.filename, 'wt') as f: - f.write(data) - - elif os.path.exists(self.filename): - log.debug("Deleting empty %s", self.filename) - os.unlink(self.filename) - - self.dirty = False - - @staticmethod - def _wrap_lines(lines): - return lines - - def add(self, dist): - """Add `dist` to the distribution map""" - new_path = ( - dist.location not in self.paths and ( - dist.location not in self.sitedirs or - # account for '.' being in PYTHONPATH - dist.location == os.getcwd() - ) - ) - if new_path: - self.paths.append(dist.location) - self.dirty = True - Environment.add(self, dist) - - def remove(self, dist): - """Remove `dist` from the distribution map""" - while dist.location in self.paths: - self.paths.remove(dist.location) - self.dirty = True - Environment.remove(self, dist) - - def make_relative(self, path): - npath, last = os.path.split(normalize_path(path)) - baselen = len(self.basedir) - parts = [last] - sep = os.altsep == '/' and '/' or os.sep - while len(npath) >= baselen: - if npath == self.basedir: - parts.append(os.curdir) - parts.reverse() - return sep.join(parts) - npath, last = os.path.split(npath) - parts.append(last) - else: - return path - - -class RewritePthDistributions(PthDistributions): - @classmethod - def _wrap_lines(cls, lines): - yield cls.prelude - for line in lines: - yield line - yield cls.postlude - - prelude = _one_liner(""" - import sys - sys.__plen = len(sys.path) - """) - postlude = _one_liner(""" - import sys - new = sys.path[sys.__plen:] - del sys.path[sys.__plen:] - p = getattr(sys, '__egginsert', 0) - sys.path[p:p] = new - sys.__egginsert = p + len(new) - """) - - -if os.environ.get('SETUPTOOLS_SYS_PATH_TECHNIQUE', 'raw') == 'rewrite': - PthDistributions = RewritePthDistributions - - -def _first_line_re(): - """ - Return a regular expression based on first_line_re suitable for matching - strings. - """ - if isinstance(first_line_re.pattern, str): - return first_line_re - - # first_line_re in Python >=3.1.4 and >=3.2.1 is a bytes pattern. - return re.compile(first_line_re.pattern.decode()) - - -def auto_chmod(func, arg, exc): - if func in [os.unlink, os.remove] and os.name == 'nt': - chmod(arg, stat.S_IWRITE) - return func(arg) - et, ev, _ = sys.exc_info() - six.reraise(et, (ev[0], ev[1] + (" %s %s" % (func, arg)))) - - -def update_dist_caches(dist_path, fix_zipimporter_caches): - """ - Fix any globally cached `dist_path` related data - - `dist_path` should be a path of a newly installed egg distribution (zipped - or unzipped). - - sys.path_importer_cache contains finder objects that have been cached when - importing data from the original distribution. Any such finders need to be - cleared since the replacement distribution might be packaged differently, - e.g. a zipped egg distribution might get replaced with an unzipped egg - folder or vice versa. Having the old finders cached may then cause Python - to attempt loading modules from the replacement distribution using an - incorrect loader. - - zipimport.zipimporter objects are Python loaders charged with importing - data packaged inside zip archives. If stale loaders referencing the - original distribution, are left behind, they can fail to load modules from - the replacement distribution. E.g. if an old zipimport.zipimporter instance - is used to load data from a new zipped egg archive, it may cause the - operation to attempt to locate the requested data in the wrong location - - one indicated by the original distribution's zip archive directory - information. Such an operation may then fail outright, e.g. report having - read a 'bad local file header', or even worse, it may fail silently & - return invalid data. - - zipimport._zip_directory_cache contains cached zip archive directory - information for all existing zipimport.zipimporter instances and all such - instances connected to the same archive share the same cached directory - information. - - If asked, and the underlying Python implementation allows it, we can fix - all existing zipimport.zipimporter instances instead of having to track - them down and remove them one by one, by updating their shared cached zip - archive directory information. This, of course, assumes that the - replacement distribution is packaged as a zipped egg. - - If not asked to fix existing zipimport.zipimporter instances, we still do - our best to clear any remaining zipimport.zipimporter related cached data - that might somehow later get used when attempting to load data from the new - distribution and thus cause such load operations to fail. Note that when - tracking down such remaining stale data, we can not catch every conceivable - usage from here, and we clear only those that we know of and have found to - cause problems if left alive. Any remaining caches should be updated by - whomever is in charge of maintaining them, i.e. they should be ready to - handle us replacing their zip archives with new distributions at runtime. - - """ - # There are several other known sources of stale zipimport.zipimporter - # instances that we do not clear here, but might if ever given a reason to - # do so: - # * Global setuptools pkg_resources.working_set (a.k.a. 'master working - # set') may contain distributions which may in turn contain their - # zipimport.zipimporter loaders. - # * Several zipimport.zipimporter loaders held by local variables further - # up the function call stack when running the setuptools installation. - # * Already loaded modules may have their __loader__ attribute set to the - # exact loader instance used when importing them. Python 3.4 docs state - # that this information is intended mostly for introspection and so is - # not expected to cause us problems. - normalized_path = normalize_path(dist_path) - _uncache(normalized_path, sys.path_importer_cache) - if fix_zipimporter_caches: - _replace_zip_directory_cache_data(normalized_path) - else: - # Here, even though we do not want to fix existing and now stale - # zipimporter cache information, we still want to remove it. Related to - # Python's zip archive directory information cache, we clear each of - # its stale entries in two phases: - # 1. Clear the entry so attempting to access zip archive information - # via any existing stale zipimport.zipimporter instances fails. - # 2. Remove the entry from the cache so any newly constructed - # zipimport.zipimporter instances do not end up using old stale - # zip archive directory information. - # This whole stale data removal step does not seem strictly necessary, - # but has been left in because it was done before we started replacing - # the zip archive directory information cache content if possible, and - # there are no relevant unit tests that we can depend on to tell us if - # this is really needed. - _remove_and_clear_zip_directory_cache_data(normalized_path) - - -def _collect_zipimporter_cache_entries(normalized_path, cache): - """ - Return zipimporter cache entry keys related to a given normalized path. - - Alternative path spellings (e.g. those using different character case or - those using alternative path separators) related to the same path are - included. Any sub-path entries are included as well, i.e. those - corresponding to zip archives embedded in other zip archives. - - """ - result = [] - prefix_len = len(normalized_path) - for p in cache: - np = normalize_path(p) - if (np.startswith(normalized_path) and - np[prefix_len:prefix_len + 1] in (os.sep, '')): - result.append(p) - return result - - -def _update_zipimporter_cache(normalized_path, cache, updater=None): - """ - Update zipimporter cache data for a given normalized path. - - Any sub-path entries are processed as well, i.e. those corresponding to zip - archives embedded in other zip archives. - - Given updater is a callable taking a cache entry key and the original entry - (after already removing the entry from the cache), and expected to update - the entry and possibly return a new one to be inserted in its place. - Returning None indicates that the entry should not be replaced with a new - one. If no updater is given, the cache entries are simply removed without - any additional processing, the same as if the updater simply returned None. - - """ - for p in _collect_zipimporter_cache_entries(normalized_path, cache): - # N.B. pypy's custom zipimport._zip_directory_cache implementation does - # not support the complete dict interface: - # * Does not support item assignment, thus not allowing this function - # to be used only for removing existing cache entries. - # * Does not support the dict.pop() method, forcing us to use the - # get/del patterns instead. For more detailed information see the - # following links: - # https://github.com/pypa/setuptools/issues/202#issuecomment-202913420 - # http://bit.ly/2h9itJX - old_entry = cache[p] - del cache[p] - new_entry = updater and updater(p, old_entry) - if new_entry is not None: - cache[p] = new_entry - - -def _uncache(normalized_path, cache): - _update_zipimporter_cache(normalized_path, cache) - - -def _remove_and_clear_zip_directory_cache_data(normalized_path): - def clear_and_remove_cached_zip_archive_directory_data(path, old_entry): - old_entry.clear() - - _update_zipimporter_cache( - normalized_path, zipimport._zip_directory_cache, - updater=clear_and_remove_cached_zip_archive_directory_data) - - -# PyPy Python implementation does not allow directly writing to the -# zipimport._zip_directory_cache and so prevents us from attempting to correct -# its content. The best we can do there is clear the problematic cache content -# and have PyPy repopulate it as needed. The downside is that if there are any -# stale zipimport.zipimporter instances laying around, attempting to use them -# will fail due to not having its zip archive directory information available -# instead of being automatically corrected to use the new correct zip archive -# directory information. -if '__pypy__' in sys.builtin_module_names: - _replace_zip_directory_cache_data = \ - _remove_and_clear_zip_directory_cache_data -else: - - def _replace_zip_directory_cache_data(normalized_path): - def replace_cached_zip_archive_directory_data(path, old_entry): - # N.B. In theory, we could load the zip directory information just - # once for all updated path spellings, and then copy it locally and - # update its contained path strings to contain the correct - # spelling, but that seems like a way too invasive move (this cache - # structure is not officially documented anywhere and could in - # theory change with new Python releases) for no significant - # benefit. - old_entry.clear() - zipimport.zipimporter(path) - old_entry.update(zipimport._zip_directory_cache[path]) - return old_entry - - _update_zipimporter_cache( - normalized_path, zipimport._zip_directory_cache, - updater=replace_cached_zip_archive_directory_data) - - -def is_python(text, filename=''): - "Is this string a valid Python script?" - try: - compile(text, filename, 'exec') - except (SyntaxError, TypeError): - return False - else: - return True - - -def is_sh(executable): - """Determine if the specified executable is a .sh (contains a #! line)""" - try: - with io.open(executable, encoding='latin-1') as fp: - magic = fp.read(2) - except (OSError, IOError): - return executable - return magic == '#!' - - -def nt_quote_arg(arg): - """Quote a command line argument according to Windows parsing rules""" - return subprocess.list2cmdline([arg]) - - -def is_python_script(script_text, filename): - """Is this text, as a whole, a Python script? (as opposed to shell/bat/etc. - """ - if filename.endswith('.py') or filename.endswith('.pyw'): - return True # extension says it's Python - if is_python(script_text, filename): - return True # it's syntactically valid Python - if script_text.startswith('#!'): - # It begins with a '#!' line, so check if 'python' is in it somewhere - return 'python' in script_text.splitlines()[0].lower() - - return False # Not any Python I can recognize - - -try: - from os import chmod as _chmod -except ImportError: - # Jython compatibility - def _chmod(*args): - pass - - -def chmod(path, mode): - log.debug("changing mode of %s to %o", path, mode) - try: - _chmod(path, mode) - except os.error as e: - log.debug("chmod failed: %s", e) - - -class CommandSpec(list): - """ - A command spec for a #! header, specified as a list of arguments akin to - those passed to Popen. - """ - - options = [] - split_args = dict() - - @classmethod - def best(cls): - """ - Choose the best CommandSpec class based on environmental conditions. - """ - return cls - - @classmethod - def _sys_executable(cls): - _default = os.path.normpath(sys.executable) - return os.environ.get('__PYVENV_LAUNCHER__', _default) - - @classmethod - def from_param(cls, param): - """ - Construct a CommandSpec from a parameter to build_scripts, which may - be None. - """ - if isinstance(param, cls): - return param - if isinstance(param, list): - return cls(param) - if param is None: - return cls.from_environment() - # otherwise, assume it's a string. - return cls.from_string(param) - - @classmethod - def from_environment(cls): - return cls([cls._sys_executable()]) - - @classmethod - def from_string(cls, string): - """ - Construct a command spec from a simple string representing a command - line parseable by shlex.split. - """ - items = shlex.split(string, **cls.split_args) - return cls(items) - - def install_options(self, script_text): - self.options = shlex.split(self._extract_options(script_text)) - cmdline = subprocess.list2cmdline(self) - if not isascii(cmdline): - self.options[:0] = ['-x'] - - @staticmethod - def _extract_options(orig_script): - """ - Extract any options from the first line of the script. - """ - first = (orig_script + '\n').splitlines()[0] - match = _first_line_re().match(first) - options = match.group(1) or '' if match else '' - return options.strip() - - def as_header(self): - return self._render(self + list(self.options)) - - @staticmethod - def _strip_quotes(item): - _QUOTES = '"\'' - for q in _QUOTES: - if item.startswith(q) and item.endswith(q): - return item[1:-1] - return item - - @staticmethod - def _render(items): - cmdline = subprocess.list2cmdline( - CommandSpec._strip_quotes(item.strip()) for item in items) - return '#!' + cmdline + '\n' - - -# For pbr compat; will be removed in a future version. -sys_executable = CommandSpec._sys_executable() - - -class WindowsCommandSpec(CommandSpec): - split_args = dict(posix=False) - - -class ScriptWriter: - """ - Encapsulates behavior around writing entry point scripts for console and - gui apps. - """ - - template = textwrap.dedent(r""" - # EASY-INSTALL-ENTRY-SCRIPT: %(spec)r,%(group)r,%(name)r - __requires__ = %(spec)r - import re - import sys - from pkg_resources import load_entry_point - - if __name__ == '__main__': - sys.argv[0] = re.sub(r'(-script\.pyw?|\.exe)?$', '', sys.argv[0]) - sys.exit( - load_entry_point(%(spec)r, %(group)r, %(name)r)() - ) - """).lstrip() - - command_spec_class = CommandSpec - - @classmethod - def get_script_args(cls, dist, executable=None, wininst=False): - # for backward compatibility - warnings.warn("Use get_args", EasyInstallDeprecationWarning) - writer = (WindowsScriptWriter if wininst else ScriptWriter).best() - header = cls.get_script_header("", executable, wininst) - return writer.get_args(dist, header) - - @classmethod - def get_script_header(cls, script_text, executable=None, wininst=False): - # for backward compatibility - warnings.warn("Use get_header", EasyInstallDeprecationWarning, stacklevel=2) - if wininst: - executable = "python.exe" - return cls.get_header(script_text, executable) - - @classmethod - def get_args(cls, dist, header=None): - """ - Yield write_script() argument tuples for a distribution's - console_scripts and gui_scripts entry points. - """ - if header is None: - header = cls.get_header() - spec = str(dist.as_requirement()) - for type_ in 'console', 'gui': - group = type_ + '_scripts' - for name, ep in dist.get_entry_map(group).items(): - cls._ensure_safe_name(name) - script_text = cls.template % locals() - args = cls._get_script_args(type_, name, header, script_text) - for res in args: - yield res - - @staticmethod - def _ensure_safe_name(name): - """ - Prevent paths in *_scripts entry point names. - """ - has_path_sep = re.search(r'[\\/]', name) - if has_path_sep: - raise ValueError("Path separators not allowed in script names") - - @classmethod - def get_writer(cls, force_windows): - # for backward compatibility - warnings.warn("Use best", EasyInstallDeprecationWarning) - return WindowsScriptWriter.best() if force_windows else cls.best() - - @classmethod - def best(cls): - """ - Select the best ScriptWriter for this environment. - """ - if sys.platform == 'win32' or (os.name == 'java' and os._name == 'nt'): - return WindowsScriptWriter.best() - else: - return cls - - @classmethod - def _get_script_args(cls, type_, name, header, script_text): - # Simply write the stub with no extension. - yield (name, header + script_text) - - @classmethod - def get_header(cls, script_text="", executable=None): - """Create a #! line, getting options (if any) from script_text""" - cmd = cls.command_spec_class.best().from_param(executable) - cmd.install_options(script_text) - return cmd.as_header() - - -class WindowsScriptWriter(ScriptWriter): - command_spec_class = WindowsCommandSpec - - @classmethod - def get_writer(cls): - # for backward compatibility - warnings.warn("Use best", EasyInstallDeprecationWarning) - return cls.best() - - @classmethod - def best(cls): - """ - Select the best ScriptWriter suitable for Windows - """ - writer_lookup = dict( - executable=WindowsExecutableLauncherWriter, - natural=cls, - ) - # for compatibility, use the executable launcher by default - launcher = os.environ.get('SETUPTOOLS_LAUNCHER', 'executable') - return writer_lookup[launcher] - - @classmethod - def _get_script_args(cls, type_, name, header, script_text): - "For Windows, add a .py extension" - ext = dict(console='.pya', gui='.pyw')[type_] - if ext not in os.environ['PATHEXT'].lower().split(';'): - msg = ( - "{ext} not listed in PATHEXT; scripts will not be " - "recognized as executables." - ).format(**locals()) - warnings.warn(msg, UserWarning) - old = ['.pya', '.py', '-script.py', '.pyc', '.pyo', '.pyw', '.exe'] - old.remove(ext) - header = cls._adjust_header(type_, header) - blockers = [name + x for x in old] - yield name + ext, header + script_text, 't', blockers - - @classmethod - def _adjust_header(cls, type_, orig_header): - """ - Make sure 'pythonw' is used for gui and and 'python' is used for - console (regardless of what sys.executable is). - """ - pattern = 'pythonw.exe' - repl = 'python.exe' - if type_ == 'gui': - pattern, repl = repl, pattern - pattern_ob = re.compile(re.escape(pattern), re.IGNORECASE) - new_header = pattern_ob.sub(string=orig_header, repl=repl) - return new_header if cls._use_header(new_header) else orig_header - - @staticmethod - def _use_header(new_header): - """ - Should _adjust_header use the replaced header? - - On non-windows systems, always use. On - Windows systems, only use the replaced header if it resolves - to an executable on the system. - """ - clean_header = new_header[2:-1].strip('"') - return sys.platform != 'win32' or find_executable(clean_header) - - -class WindowsExecutableLauncherWriter(WindowsScriptWriter): - @classmethod - def _get_script_args(cls, type_, name, header, script_text): - """ - For Windows, add a .py extension and an .exe launcher - """ - if type_ == 'gui': - launcher_type = 'gui' - ext = '-script.pyw' - old = ['.pyw'] - else: - launcher_type = 'cli' - ext = '-script.py' - old = ['.py', '.pyc', '.pyo'] - hdr = cls._adjust_header(type_, header) - blockers = [name + x for x in old] - yield (name + ext, hdr + script_text, 't', blockers) - yield ( - name + '.exe', get_win_launcher(launcher_type), - 'b' # write in binary mode - ) - if not is_64bit(): - # install a manifest for the launcher to prevent Windows - # from detecting it as an installer (which it will for - # launchers like easy_install.exe). Consider only - # adding a manifest for launchers detected as installers. - # See Distribute #143 for details. - m_name = name + '.exe.manifest' - yield (m_name, load_launcher_manifest(name), 't') - - -# for backward-compatibility -get_script_args = ScriptWriter.get_script_args -get_script_header = ScriptWriter.get_script_header - - -def get_win_launcher(type): - """ - Load the Windows launcher (executable) suitable for launching a script. - - `type` should be either 'cli' or 'gui' - - Returns the executable as a byte string. - """ - launcher_fn = '%s.exe' % type - if is_64bit(): - launcher_fn = launcher_fn.replace(".", "-64.") - else: - launcher_fn = launcher_fn.replace(".", "-32.") - return resource_string('setuptools', launcher_fn) - - -def load_launcher_manifest(name): - manifest = pkg_resources.resource_string(__name__, 'launcher manifest.xml') - if six.PY2: - return manifest % vars() - else: - return manifest.decode('utf-8') % vars() - - -def rmtree(path, ignore_errors=False, onerror=auto_chmod): - return shutil.rmtree(path, ignore_errors, onerror) - - -def current_umask(): - tmp = os.umask(0o022) - os.umask(tmp) - return tmp - - -def bootstrap(): - # This function is called when setuptools*.egg is run using /bin/sh - import setuptools - - argv0 = os.path.dirname(setuptools.__path__[0]) - sys.argv[0] = argv0 - sys.argv.append(argv0) - main() - - -def main(argv=None, **kw): - from setuptools import setup - from setuptools.dist import Distribution - - class DistributionWithoutHelpCommands(Distribution): - common_usage = "" - - def _show_help(self, *args, **kw): - with _patch_usage(): - Distribution._show_help(self, *args, **kw) - - if argv is None: - argv = sys.argv[1:] - - with _patch_usage(): - setup( - script_args=['-q', 'easy_install', '-v'] + argv, - script_name=sys.argv[0] or 'easy_install', - distclass=DistributionWithoutHelpCommands, - **kw - ) - - -@contextlib.contextmanager -def _patch_usage(): - import distutils.core - USAGE = textwrap.dedent(""" - usage: %(script)s [options] requirement_or_url ... - or: %(script)s --help - """).lstrip() - - def gen_usage(script_name): - return USAGE % dict( - script=os.path.basename(script_name), - ) - - saved = distutils.core.gen_usage - distutils.core.gen_usage = gen_usage - try: - yield - finally: - distutils.core.gen_usage = saved - -class EasyInstallDeprecationWarning(SetuptoolsDeprecationWarning): - """Class for warning about deprecations in EasyInstall in SetupTools. Not ignored by default, unlike DeprecationWarning.""" - diff --git a/venv/lib/python3.8/site-packages/setuptools/command/egg_info.py b/venv/lib/python3.8/site-packages/setuptools/command/egg_info.py deleted file mode 100644 index b767ef3..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/command/egg_info.py +++ /dev/null @@ -1,717 +0,0 @@ -"""setuptools.command.egg_info - -Create a distribution's .egg-info directory and contents""" - -from distutils.filelist import FileList as _FileList -from distutils.errors import DistutilsInternalError -from distutils.util import convert_path -from distutils import log -import distutils.errors -import distutils.filelist -import os -import re -import sys -import io -import warnings -import time -import collections - -from setuptools.extern import six -from setuptools.extern.six.moves import map - -from setuptools import Command -from setuptools.command.sdist import sdist -from setuptools.command.sdist import walk_revctrl -from setuptools.command.setopt import edit_config -from setuptools.command import bdist_egg -from pkg_resources import ( - parse_requirements, safe_name, parse_version, - safe_version, yield_lines, EntryPoint, iter_entry_points, to_filename) -import setuptools.unicode_utils as unicode_utils -from setuptools.glob import glob - -from setuptools.extern import packaging -from setuptools import SetuptoolsDeprecationWarning - -def translate_pattern(glob): - """ - Translate a file path glob like '*.txt' in to a regular expression. - This differs from fnmatch.translate which allows wildcards to match - directory separators. It also knows about '**/' which matches any number of - directories. - """ - pat = '' - - # This will split on '/' within [character classes]. This is deliberate. - chunks = glob.split(os.path.sep) - - sep = re.escape(os.sep) - valid_char = '[^%s]' % (sep,) - - for c, chunk in enumerate(chunks): - last_chunk = c == len(chunks) - 1 - - # Chunks that are a literal ** are globstars. They match anything. - if chunk == '**': - if last_chunk: - # Match anything if this is the last component - pat += '.*' - else: - # Match '(name/)*' - pat += '(?:%s+%s)*' % (valid_char, sep) - continue # Break here as the whole path component has been handled - - # Find any special characters in the remainder - i = 0 - chunk_len = len(chunk) - while i < chunk_len: - char = chunk[i] - if char == '*': - # Match any number of name characters - pat += valid_char + '*' - elif char == '?': - # Match a name character - pat += valid_char - elif char == '[': - # Character class - inner_i = i + 1 - # Skip initial !/] chars - if inner_i < chunk_len and chunk[inner_i] == '!': - inner_i = inner_i + 1 - if inner_i < chunk_len and chunk[inner_i] == ']': - inner_i = inner_i + 1 - - # Loop till the closing ] is found - while inner_i < chunk_len and chunk[inner_i] != ']': - inner_i = inner_i + 1 - - if inner_i >= chunk_len: - # Got to the end of the string without finding a closing ] - # Do not treat this as a matching group, but as a literal [ - pat += re.escape(char) - else: - # Grab the insides of the [brackets] - inner = chunk[i + 1:inner_i] - char_class = '' - - # Class negation - if inner[0] == '!': - char_class = '^' - inner = inner[1:] - - char_class += re.escape(inner) - pat += '[%s]' % (char_class,) - - # Skip to the end ] - i = inner_i - else: - pat += re.escape(char) - i += 1 - - # Join each chunk with the dir separator - if not last_chunk: - pat += sep - - pat += r'\Z' - return re.compile(pat, flags=re.MULTILINE|re.DOTALL) - - -class InfoCommon: - tag_build = None - tag_date = None - - @property - def name(self): - return safe_name(self.distribution.get_name()) - - def tagged_version(self): - version = self.distribution.get_version() - # egg_info may be called more than once for a distribution, - # in which case the version string already contains all tags. - if self.vtags and version.endswith(self.vtags): - return safe_version(version) - return safe_version(version + self.vtags) - - def tags(self): - version = '' - if self.tag_build: - version += self.tag_build - if self.tag_date: - version += time.strftime("-%Y%m%d") - return version - vtags = property(tags) - - -class egg_info(InfoCommon, Command): - description = "create a distribution's .egg-info directory" - - user_options = [ - ('egg-base=', 'e', "directory containing .egg-info directories" - " (default: top of the source tree)"), - ('tag-date', 'd', "Add date stamp (e.g. 20050528) to version number"), - ('tag-build=', 'b', "Specify explicit tag to add to version number"), - ('no-date', 'D', "Don't include date stamp [default]"), - ] - - boolean_options = ['tag-date'] - negative_opt = { - 'no-date': 'tag-date', - } - - def initialize_options(self): - self.egg_base = None - self.egg_name = None - self.egg_info = None - self.egg_version = None - self.broken_egg_info = False - - #################################### - # allow the 'tag_svn_revision' to be detected and - # set, supporting sdists built on older Setuptools. - @property - def tag_svn_revision(self): - pass - - @tag_svn_revision.setter - def tag_svn_revision(self, value): - pass - #################################### - - def save_version_info(self, filename): - """ - Materialize the value of date into the - build tag. Install build keys in a deterministic order - to avoid arbitrary reordering on subsequent builds. - """ - egg_info = collections.OrderedDict() - # follow the order these keys would have been added - # when PYTHONHASHSEED=0 - egg_info['tag_build'] = self.tags() - egg_info['tag_date'] = 0 - edit_config(filename, dict(egg_info=egg_info)) - - def finalize_options(self): - # Note: we need to capture the current value returned - # by `self.tagged_version()`, so we can later update - # `self.distribution.metadata.version` without - # repercussions. - self.egg_name = self.name - self.egg_version = self.tagged_version() - parsed_version = parse_version(self.egg_version) - - try: - is_version = isinstance(parsed_version, packaging.version.Version) - spec = ( - "%s==%s" if is_version else "%s===%s" - ) - list( - parse_requirements(spec % (self.egg_name, self.egg_version)) - ) - except ValueError: - raise distutils.errors.DistutilsOptionError( - "Invalid distribution name or version syntax: %s-%s" % - (self.egg_name, self.egg_version) - ) - - if self.egg_base is None: - dirs = self.distribution.package_dir - self.egg_base = (dirs or {}).get('', os.curdir) - - self.ensure_dirname('egg_base') - self.egg_info = to_filename(self.egg_name) + '.egg-info' - if self.egg_base != os.curdir: - self.egg_info = os.path.join(self.egg_base, self.egg_info) - if '-' in self.egg_name: - self.check_broken_egg_info() - - # Set package version for the benefit of dumber commands - # (e.g. sdist, bdist_wininst, etc.) - # - self.distribution.metadata.version = self.egg_version - - # If we bootstrapped around the lack of a PKG-INFO, as might be the - # case in a fresh checkout, make sure that any special tags get added - # to the version info - # - pd = self.distribution._patched_dist - if pd is not None and pd.key == self.egg_name.lower(): - pd._version = self.egg_version - pd._parsed_version = parse_version(self.egg_version) - self.distribution._patched_dist = None - - def write_or_delete_file(self, what, filename, data, force=False): - """Write `data` to `filename` or delete if empty - - If `data` is non-empty, this routine is the same as ``write_file()``. - If `data` is empty but not ``None``, this is the same as calling - ``delete_file(filename)`. If `data` is ``None``, then this is a no-op - unless `filename` exists, in which case a warning is issued about the - orphaned file (if `force` is false), or deleted (if `force` is true). - """ - if data: - self.write_file(what, filename, data) - elif os.path.exists(filename): - if data is None and not force: - log.warn( - "%s not set in setup(), but %s exists", what, filename - ) - return - else: - self.delete_file(filename) - - def write_file(self, what, filename, data): - """Write `data` to `filename` (if not a dry run) after announcing it - - `what` is used in a log message to identify what is being written - to the file. - """ - log.info("writing %s to %s", what, filename) - if six.PY3: - data = data.encode("utf-8") - if not self.dry_run: - f = open(filename, 'wb') - f.write(data) - f.close() - - def delete_file(self, filename): - """Delete `filename` (if not a dry run) after announcing it""" - log.info("deleting %s", filename) - if not self.dry_run: - os.unlink(filename) - - def run(self): - self.mkpath(self.egg_info) - os.utime(self.egg_info, None) - installer = self.distribution.fetch_build_egg - for ep in iter_entry_points('egg_info.writers'): - ep.require(installer=installer) - writer = ep.resolve() - writer(self, ep.name, os.path.join(self.egg_info, ep.name)) - - # Get rid of native_libs.txt if it was put there by older bdist_egg - nl = os.path.join(self.egg_info, "native_libs.txt") - if os.path.exists(nl): - self.delete_file(nl) - - self.find_sources() - - def find_sources(self): - """Generate SOURCES.txt manifest file""" - manifest_filename = os.path.join(self.egg_info, "SOURCES.txt") - mm = manifest_maker(self.distribution) - mm.manifest = manifest_filename - mm.run() - self.filelist = mm.filelist - - def check_broken_egg_info(self): - bei = self.egg_name + '.egg-info' - if self.egg_base != os.curdir: - bei = os.path.join(self.egg_base, bei) - if os.path.exists(bei): - log.warn( - "-" * 78 + '\n' - "Note: Your current .egg-info directory has a '-' in its name;" - '\nthis will not work correctly with "setup.py develop".\n\n' - 'Please rename %s to %s to correct this problem.\n' + '-' * 78, - bei, self.egg_info - ) - self.broken_egg_info = self.egg_info - self.egg_info = bei # make it work for now - - -class FileList(_FileList): - # Implementations of the various MANIFEST.in commands - - def process_template_line(self, line): - # Parse the line: split it up, make sure the right number of words - # is there, and return the relevant words. 'action' is always - # defined: it's the first word of the line. Which of the other - # three are defined depends on the action; it'll be either - # patterns, (dir and patterns), or (dir_pattern). - (action, patterns, dir, dir_pattern) = self._parse_template_line(line) - - # OK, now we know that the action is valid and we have the - # right number of words on the line for that action -- so we - # can proceed with minimal error-checking. - if action == 'include': - self.debug_print("include " + ' '.join(patterns)) - for pattern in patterns: - if not self.include(pattern): - log.warn("warning: no files found matching '%s'", pattern) - - elif action == 'exclude': - self.debug_print("exclude " + ' '.join(patterns)) - for pattern in patterns: - if not self.exclude(pattern): - log.warn(("warning: no previously-included files " - "found matching '%s'"), pattern) - - elif action == 'global-include': - self.debug_print("global-include " + ' '.join(patterns)) - for pattern in patterns: - if not self.global_include(pattern): - log.warn(("warning: no files found matching '%s' " - "anywhere in distribution"), pattern) - - elif action == 'global-exclude': - self.debug_print("global-exclude " + ' '.join(patterns)) - for pattern in patterns: - if not self.global_exclude(pattern): - log.warn(("warning: no previously-included files matching " - "'%s' found anywhere in distribution"), - pattern) - - elif action == 'recursive-include': - self.debug_print("recursive-include %s %s" % - (dir, ' '.join(patterns))) - for pattern in patterns: - if not self.recursive_include(dir, pattern): - log.warn(("warning: no files found matching '%s' " - "under directory '%s'"), - pattern, dir) - - elif action == 'recursive-exclude': - self.debug_print("recursive-exclude %s %s" % - (dir, ' '.join(patterns))) - for pattern in patterns: - if not self.recursive_exclude(dir, pattern): - log.warn(("warning: no previously-included files matching " - "'%s' found under directory '%s'"), - pattern, dir) - - elif action == 'graft': - self.debug_print("graft " + dir_pattern) - if not self.graft(dir_pattern): - log.warn("warning: no directories found matching '%s'", - dir_pattern) - - elif action == 'prune': - self.debug_print("prune " + dir_pattern) - if not self.prune(dir_pattern): - log.warn(("no previously-included directories found " - "matching '%s'"), dir_pattern) - - else: - raise DistutilsInternalError( - "this cannot happen: invalid action '%s'" % action) - - def _remove_files(self, predicate): - """ - Remove all files from the file list that match the predicate. - Return True if any matching files were removed - """ - found = False - for i in range(len(self.files) - 1, -1, -1): - if predicate(self.files[i]): - self.debug_print(" removing " + self.files[i]) - del self.files[i] - found = True - return found - - def include(self, pattern): - """Include files that match 'pattern'.""" - found = [f for f in glob(pattern) if not os.path.isdir(f)] - self.extend(found) - return bool(found) - - def exclude(self, pattern): - """Exclude files that match 'pattern'.""" - match = translate_pattern(pattern) - return self._remove_files(match.match) - - def recursive_include(self, dir, pattern): - """ - Include all files anywhere in 'dir/' that match the pattern. - """ - full_pattern = os.path.join(dir, '**', pattern) - found = [f for f in glob(full_pattern, recursive=True) - if not os.path.isdir(f)] - self.extend(found) - return bool(found) - - def recursive_exclude(self, dir, pattern): - """ - Exclude any file anywhere in 'dir/' that match the pattern. - """ - match = translate_pattern(os.path.join(dir, '**', pattern)) - return self._remove_files(match.match) - - def graft(self, dir): - """Include all files from 'dir/'.""" - found = [ - item - for match_dir in glob(dir) - for item in distutils.filelist.findall(match_dir) - ] - self.extend(found) - return bool(found) - - def prune(self, dir): - """Filter out files from 'dir/'.""" - match = translate_pattern(os.path.join(dir, '**')) - return self._remove_files(match.match) - - def global_include(self, pattern): - """ - Include all files anywhere in the current directory that match the - pattern. This is very inefficient on large file trees. - """ - if self.allfiles is None: - self.findall() - match = translate_pattern(os.path.join('**', pattern)) - found = [f for f in self.allfiles if match.match(f)] - self.extend(found) - return bool(found) - - def global_exclude(self, pattern): - """ - Exclude all files anywhere that match the pattern. - """ - match = translate_pattern(os.path.join('**', pattern)) - return self._remove_files(match.match) - - def append(self, item): - if item.endswith('\r'): # Fix older sdists built on Windows - item = item[:-1] - path = convert_path(item) - - if self._safe_path(path): - self.files.append(path) - - def extend(self, paths): - self.files.extend(filter(self._safe_path, paths)) - - def _repair(self): - """ - Replace self.files with only safe paths - - Because some owners of FileList manipulate the underlying - ``files`` attribute directly, this method must be called to - repair those paths. - """ - self.files = list(filter(self._safe_path, self.files)) - - def _safe_path(self, path): - enc_warn = "'%s' not %s encodable -- skipping" - - # To avoid accidental trans-codings errors, first to unicode - u_path = unicode_utils.filesys_decode(path) - if u_path is None: - log.warn("'%s' in unexpected encoding -- skipping" % path) - return False - - # Must ensure utf-8 encodability - utf8_path = unicode_utils.try_encode(u_path, "utf-8") - if utf8_path is None: - log.warn(enc_warn, path, 'utf-8') - return False - - try: - # accept is either way checks out - if os.path.exists(u_path) or os.path.exists(utf8_path): - return True - # this will catch any encode errors decoding u_path - except UnicodeEncodeError: - log.warn(enc_warn, path, sys.getfilesystemencoding()) - - -class manifest_maker(sdist): - template = "MANIFEST.in" - - def initialize_options(self): - self.use_defaults = 1 - self.prune = 1 - self.manifest_only = 1 - self.force_manifest = 1 - - def finalize_options(self): - pass - - def run(self): - self.filelist = FileList() - if not os.path.exists(self.manifest): - self.write_manifest() # it must exist so it'll get in the list - self.add_defaults() - if os.path.exists(self.template): - self.read_template() - self.prune_file_list() - self.filelist.sort() - self.filelist.remove_duplicates() - self.write_manifest() - - def _manifest_normalize(self, path): - path = unicode_utils.filesys_decode(path) - return path.replace(os.sep, '/') - - def write_manifest(self): - """ - Write the file list in 'self.filelist' to the manifest file - named by 'self.manifest'. - """ - self.filelist._repair() - - # Now _repairs should encodability, but not unicode - files = [self._manifest_normalize(f) for f in self.filelist.files] - msg = "writing manifest file '%s'" % self.manifest - self.execute(write_file, (self.manifest, files), msg) - - def warn(self, msg): - if not self._should_suppress_warning(msg): - sdist.warn(self, msg) - - @staticmethod - def _should_suppress_warning(msg): - """ - suppress missing-file warnings from sdist - """ - return re.match(r"standard file .*not found", msg) - - def add_defaults(self): - sdist.add_defaults(self) - self.check_license() - self.filelist.append(self.template) - self.filelist.append(self.manifest) - rcfiles = list(walk_revctrl()) - if rcfiles: - self.filelist.extend(rcfiles) - elif os.path.exists(self.manifest): - self.read_manifest() - - if os.path.exists("setup.py"): - # setup.py should be included by default, even if it's not - # the script called to create the sdist - self.filelist.append("setup.py") - - ei_cmd = self.get_finalized_command('egg_info') - self.filelist.graft(ei_cmd.egg_info) - - def prune_file_list(self): - build = self.get_finalized_command('build') - base_dir = self.distribution.get_fullname() - self.filelist.prune(build.build_base) - self.filelist.prune(base_dir) - sep = re.escape(os.sep) - self.filelist.exclude_pattern(r'(^|' + sep + r')(RCS|CVS|\.svn)' + sep, - is_regex=1) - - -def write_file(filename, contents): - """Create a file with the specified name and write 'contents' (a - sequence of strings without line terminators) to it. - """ - contents = "\n".join(contents) - - # assuming the contents has been vetted for utf-8 encoding - contents = contents.encode("utf-8") - - with open(filename, "wb") as f: # always write POSIX-style manifest - f.write(contents) - - -def write_pkg_info(cmd, basename, filename): - log.info("writing %s", filename) - if not cmd.dry_run: - metadata = cmd.distribution.metadata - metadata.version, oldver = cmd.egg_version, metadata.version - metadata.name, oldname = cmd.egg_name, metadata.name - - try: - # write unescaped data to PKG-INFO, so older pkg_resources - # can still parse it - metadata.write_pkg_info(cmd.egg_info) - finally: - metadata.name, metadata.version = oldname, oldver - - safe = getattr(cmd.distribution, 'zip_safe', None) - - bdist_egg.write_safety_flag(cmd.egg_info, safe) - - -def warn_depends_obsolete(cmd, basename, filename): - if os.path.exists(filename): - log.warn( - "WARNING: 'depends.txt' is not used by setuptools 0.6!\n" - "Use the install_requires/extras_require setup() args instead." - ) - - -def _write_requirements(stream, reqs): - lines = yield_lines(reqs or ()) - append_cr = lambda line: line + '\n' - lines = map(append_cr, sorted(lines)) - stream.writelines(lines) - - -def write_requirements(cmd, basename, filename): - dist = cmd.distribution - data = six.StringIO() - _write_requirements(data, dist.install_requires) - extras_require = dist.extras_require or {} - for extra in sorted(extras_require): - data.write('\n[{extra}]\n'.format(**vars())) - _write_requirements(data, extras_require[extra]) - cmd.write_or_delete_file("requirements", filename, data.getvalue()) - - -def write_setup_requirements(cmd, basename, filename): - data = io.StringIO() - _write_requirements(data, cmd.distribution.setup_requires) - cmd.write_or_delete_file("setup-requirements", filename, data.getvalue()) - - -def write_toplevel_names(cmd, basename, filename): - pkgs = dict.fromkeys( - [ - k.split('.', 1)[0] - for k in cmd.distribution.iter_distribution_names() - ] - ) - cmd.write_file("top-level names", filename, '\n'.join(sorted(pkgs)) + '\n') - - -def overwrite_arg(cmd, basename, filename): - write_arg(cmd, basename, filename, True) - - -def write_arg(cmd, basename, filename, force=False): - argname = os.path.splitext(basename)[0] - value = getattr(cmd.distribution, argname, None) - if value is not None: - value = '\n'.join(value) + '\n' - cmd.write_or_delete_file(argname, filename, value, force) - - -def write_entries(cmd, basename, filename): - ep = cmd.distribution.entry_points - - if isinstance(ep, six.string_types) or ep is None: - data = ep - elif ep is not None: - data = [] - for section, contents in sorted(ep.items()): - if not isinstance(contents, six.string_types): - contents = EntryPoint.parse_group(section, contents) - contents = '\n'.join(sorted(map(str, contents.values()))) - data.append('[%s]\n%s\n\n' % (section, contents)) - data = ''.join(data) - - cmd.write_or_delete_file('entry points', filename, data, True) - - -def get_pkg_info_revision(): - """ - Get a -r### off of PKG-INFO Version in case this is an sdist of - a subversion revision. - """ - warnings.warn("get_pkg_info_revision is deprecated.", EggInfoDeprecationWarning) - if os.path.exists('PKG-INFO'): - with io.open('PKG-INFO') as f: - for line in f: - match = re.match(r"Version:.*-r(\d+)\s*$", line) - if match: - return int(match.group(1)) - return 0 - - -class EggInfoDeprecationWarning(SetuptoolsDeprecationWarning): - """Class for warning about deprecations in eggInfo in setupTools. Not ignored by default, unlike DeprecationWarning.""" diff --git a/venv/lib/python3.8/site-packages/setuptools/command/install.py b/venv/lib/python3.8/site-packages/setuptools/command/install.py deleted file mode 100644 index 72b9a3e..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/command/install.py +++ /dev/null @@ -1,125 +0,0 @@ -from distutils.errors import DistutilsArgError -import inspect -import glob -import warnings -import platform -import distutils.command.install as orig - -import setuptools - -# Prior to numpy 1.9, NumPy relies on the '_install' name, so provide it for -# now. See https://github.com/pypa/setuptools/issues/199/ -_install = orig.install - - -class install(orig.install): - """Use easy_install to install the package, w/dependencies""" - - user_options = orig.install.user_options + [ - ('old-and-unmanageable', None, "Try not to use this!"), - ('single-version-externally-managed', None, - "used by system package builders to create 'flat' eggs"), - ] - boolean_options = orig.install.boolean_options + [ - 'old-and-unmanageable', 'single-version-externally-managed', - ] - new_commands = [ - ('install_egg_info', lambda self: True), - ('install_scripts', lambda self: True), - ] - _nc = dict(new_commands) - - def initialize_options(self): - orig.install.initialize_options(self) - self.old_and_unmanageable = None - self.single_version_externally_managed = None - - def finalize_options(self): - orig.install.finalize_options(self) - if self.root: - self.single_version_externally_managed = True - elif self.single_version_externally_managed: - if not self.root and not self.record: - raise DistutilsArgError( - "You must specify --record or --root when building system" - " packages" - ) - - def handle_extra_path(self): - if self.root or self.single_version_externally_managed: - # explicit backward-compatibility mode, allow extra_path to work - return orig.install.handle_extra_path(self) - - # Ignore extra_path when installing an egg (or being run by another - # command without --root or --single-version-externally-managed - self.path_file = None - self.extra_dirs = '' - - def run(self): - # Explicit request for old-style install? Just do it - if self.old_and_unmanageable or self.single_version_externally_managed: - return orig.install.run(self) - - if not self._called_from_setup(inspect.currentframe()): - # Run in backward-compatibility mode to support bdist_* commands. - orig.install.run(self) - else: - self.do_egg_install() - - @staticmethod - def _called_from_setup(run_frame): - """ - Attempt to detect whether run() was called from setup() or by another - command. If called by setup(), the parent caller will be the - 'run_command' method in 'distutils.dist', and *its* caller will be - the 'run_commands' method. If called any other way, the - immediate caller *might* be 'run_command', but it won't have been - called by 'run_commands'. Return True in that case or if a call stack - is unavailable. Return False otherwise. - """ - if run_frame is None: - msg = "Call stack not available. bdist_* commands may fail." - warnings.warn(msg) - if platform.python_implementation() == 'IronPython': - msg = "For best results, pass -X:Frames to enable call stack." - warnings.warn(msg) - return True - res = inspect.getouterframes(run_frame)[2] - caller, = res[:1] - info = inspect.getframeinfo(caller) - caller_module = caller.f_globals.get('__name__', '') - return ( - caller_module == 'distutils.dist' - and info.function == 'run_commands' - ) - - def do_egg_install(self): - - easy_install = self.distribution.get_command_class('easy_install') - - cmd = easy_install( - self.distribution, args="x", root=self.root, record=self.record, - ) - cmd.ensure_finalized() # finalize before bdist_egg munges install cmd - cmd.always_copy_from = '.' # make sure local-dir eggs get installed - - # pick up setup-dir .egg files only: no .egg-info - cmd.package_index.scan(glob.glob('*.egg')) - - self.run_command('bdist_egg') - args = [self.distribution.get_command_obj('bdist_egg').egg_output] - - if setuptools.bootstrap_install_from: - # Bootstrap self-installation of setuptools - args.insert(0, setuptools.bootstrap_install_from) - - cmd.args = args - cmd.run(show_deprecation=False) - setuptools.bootstrap_install_from = None - - -# XXX Python 3.1 doesn't see _nc if this is inside the class -install.sub_commands = ( - [cmd for cmd in orig.install.sub_commands if cmd[0] not in install._nc] + - install.new_commands -) diff --git a/venv/lib/python3.8/site-packages/setuptools/command/install_egg_info.py b/venv/lib/python3.8/site-packages/setuptools/command/install_egg_info.py deleted file mode 100644 index 5f405bc..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/command/install_egg_info.py +++ /dev/null @@ -1,82 +0,0 @@ -from distutils import log, dir_util -import os, sys - -from setuptools import Command -from setuptools import namespaces -from setuptools.archive_util import unpack_archive -import pkg_resources - - -class install_egg_info(namespaces.Installer, Command): - """Install an .egg-info directory for the package""" - - description = "Install an .egg-info directory for the package" - - user_options = [ - ('install-dir=', 'd', "directory to install to"), - ] - - def initialize_options(self): - self.install_dir = None - self.install_layout = None - self.prefix_option = None - - def finalize_options(self): - self.set_undefined_options('install_lib', - ('install_dir', 'install_dir')) - self.set_undefined_options('install',('install_layout','install_layout')) - if sys.hexversion > 0x2060000: - self.set_undefined_options('install',('prefix_option','prefix_option')) - ei_cmd = self.get_finalized_command("egg_info") - basename = pkg_resources.Distribution( - None, None, ei_cmd.egg_name, ei_cmd.egg_version - ).egg_name() + '.egg-info' - - if self.install_layout: - if not self.install_layout.lower() in ['deb']: - raise DistutilsOptionError("unknown value for --install-layout") - self.install_layout = self.install_layout.lower() - basename = basename.replace('-py%s' % pkg_resources.PY_MAJOR, '') - elif self.prefix_option or 'real_prefix' in sys.__dict__: - # don't modify for virtualenv - pass - else: - basename = basename.replace('-py%s' % pkg_resources.PY_MAJOR, '') - - self.source = ei_cmd.egg_info - self.target = os.path.join(self.install_dir, basename) - self.outputs = [] - - def run(self): - self.run_command('egg_info') - if os.path.isdir(self.target) and not os.path.islink(self.target): - dir_util.remove_tree(self.target, dry_run=self.dry_run) - elif os.path.exists(self.target): - self.execute(os.unlink, (self.target,), "Removing " + self.target) - if not self.dry_run: - pkg_resources.ensure_directory(self.target) - self.execute( - self.copytree, (), "Copying %s to %s" % (self.source, self.target) - ) - self.install_namespaces() - - def get_outputs(self): - return self.outputs - - def copytree(self): - # Copy the .egg-info tree to site-packages - def skimmer(src, dst): - # filter out source-control directories; note that 'src' is always - # a '/'-separated path, regardless of platform. 'dst' is a - # platform-specific path. - for skip in '.svn/', 'CVS/': - if src.startswith(skip) or '/' + skip in src: - return None - if self.install_layout and self.install_layout in ['deb'] and src.startswith('SOURCES.txt'): - log.info("Skipping SOURCES.txt") - return None - self.outputs.append(dst) - log.debug("Copying %s to %s", src, dst) - return dst - - unpack_archive(self.source, self.target, skimmer) diff --git a/venv/lib/python3.8/site-packages/setuptools/command/install_lib.py b/venv/lib/python3.8/site-packages/setuptools/command/install_lib.py deleted file mode 100644 index bf81519..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/command/install_lib.py +++ /dev/null @@ -1,147 +0,0 @@ -import os -import sys -from itertools import product, starmap -import distutils.command.install_lib as orig - - -class install_lib(orig.install_lib): - """Don't add compiled flags to filenames of non-Python files""" - - def initialize_options(self): - orig.install_lib.initialize_options(self) - self.multiarch = None - self.install_layout = None - - def finalize_options(self): - orig.install_lib.finalize_options(self) - self.set_undefined_options('install',('install_layout','install_layout')) - if self.install_layout == 'deb' and sys.version_info[:2] >= (3, 3): - import sysconfig - self.multiarch = sysconfig.get_config_var('MULTIARCH') - - def run(self): - self.build() - outfiles = self.install() - if outfiles is not None: - # always compile, in case we have any extension stubs to deal with - self.byte_compile(outfiles) - - def get_exclusions(self): - """ - Return a collections.Sized collections.Container of paths to be - excluded for single_version_externally_managed installations. - """ - all_packages = ( - pkg - for ns_pkg in self._get_SVEM_NSPs() - for pkg in self._all_packages(ns_pkg) - ) - - excl_specs = product(all_packages, self._gen_exclusion_paths()) - return set(starmap(self._exclude_pkg_path, excl_specs)) - - def _exclude_pkg_path(self, pkg, exclusion_path): - """ - Given a package name and exclusion path within that package, - compute the full exclusion path. - """ - parts = pkg.split('.') + [exclusion_path] - return os.path.join(self.install_dir, *parts) - - @staticmethod - def _all_packages(pkg_name): - """ - >>> list(install_lib._all_packages('foo.bar.baz')) - ['foo.bar.baz', 'foo.bar', 'foo'] - """ - while pkg_name: - yield pkg_name - pkg_name, sep, child = pkg_name.rpartition('.') - - def _get_SVEM_NSPs(self): - """ - Get namespace packages (list) but only for - single_version_externally_managed installations and empty otherwise. - """ - # TODO: is it necessary to short-circuit here? i.e. what's the cost - # if get_finalized_command is called even when namespace_packages is - # False? - if not self.distribution.namespace_packages: - return [] - - install_cmd = self.get_finalized_command('install') - svem = install_cmd.single_version_externally_managed - - return self.distribution.namespace_packages if svem else [] - - @staticmethod - def _gen_exclusion_paths(): - """ - Generate file paths to be excluded for namespace packages (bytecode - cache files). - """ - # always exclude the package module itself - yield '__init__.py' - - yield '__init__.pyc' - yield '__init__.pyo' - - if not hasattr(sys, 'implementation'): - return - - base = os.path.join('__pycache__', '__init__.' + sys.implementation.cache_tag) - yield base + '.pyc' - yield base + '.pyo' - yield base + '.opt-1.pyc' - yield base + '.opt-2.pyc' - - def copy_tree( - self, infile, outfile, - preserve_mode=1, preserve_times=1, preserve_symlinks=0, level=1 - ): - assert preserve_mode and preserve_times and not preserve_symlinks - exclude = self.get_exclusions() - - if not exclude: - import distutils.dir_util - distutils.dir_util._multiarch = self.multiarch - return orig.install_lib.copy_tree(self, infile, outfile) - - # Exclude namespace package __init__.py* files from the output - - from setuptools.archive_util import unpack_directory - from distutils import log - - outfiles = [] - - if self.multiarch: - import sysconfig - ext_suffix = sysconfig.get_config_var ('EXT_SUFFIX') - if ext_suffix.endswith(self.multiarch + ext_suffix[-3:]): - new_suffix = None - else: - new_suffix = "%s-%s%s" % (ext_suffix[:-3], self.multiarch, ext_suffix[-3:]) - - def pf(src, dst): - if dst in exclude: - log.warn("Skipping installation of %s (namespace package)", - dst) - return False - - if self.multiarch and new_suffix and dst.endswith(ext_suffix) and not dst.endswith(new_suffix): - dst = dst.replace(ext_suffix, new_suffix) - log.info("renaming extension to %s", os.path.basename(dst)) - - log.info("copying %s -> %s", src, os.path.dirname(dst)) - outfiles.append(dst) - return dst - - unpack_directory(infile, outfile, pf) - return outfiles - - def get_outputs(self): - outputs = orig.install_lib.get_outputs(self) - exclude = self.get_exclusions() - if exclude: - return [f for f in outputs if f not in exclude] - return outputs diff --git a/venv/lib/python3.8/site-packages/setuptools/command/install_scripts.py b/venv/lib/python3.8/site-packages/setuptools/command/install_scripts.py deleted file mode 100644 index 1623427..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/command/install_scripts.py +++ /dev/null @@ -1,65 +0,0 @@ -from distutils import log -import distutils.command.install_scripts as orig -import os -import sys - -from pkg_resources import Distribution, PathMetadata, ensure_directory - - -class install_scripts(orig.install_scripts): - """Do normal script install, plus any egg_info wrapper scripts""" - - def initialize_options(self): - orig.install_scripts.initialize_options(self) - self.no_ep = False - - def run(self): - import setuptools.command.easy_install as ei - - self.run_command("egg_info") - if self.distribution.scripts: - orig.install_scripts.run(self) # run first to set up self.outfiles - else: - self.outfiles = [] - if self.no_ep: - # don't install entry point scripts into .egg file! - return - - ei_cmd = self.get_finalized_command("egg_info") - dist = Distribution( - ei_cmd.egg_base, PathMetadata(ei_cmd.egg_base, ei_cmd.egg_info), - ei_cmd.egg_name, ei_cmd.egg_version, - ) - bs_cmd = self.get_finalized_command('build_scripts') - exec_param = getattr(bs_cmd, 'executable', None) - bw_cmd = self.get_finalized_command("bdist_wininst") - is_wininst = getattr(bw_cmd, '_is_running', False) - writer = ei.ScriptWriter - if is_wininst: - exec_param = "python.exe" - writer = ei.WindowsScriptWriter - if exec_param == sys.executable: - # In case the path to the Python executable contains a space, wrap - # it so it's not split up. - exec_param = [exec_param] - # resolve the writer to the environment - writer = writer.best() - cmd = writer.command_spec_class.best().from_param(exec_param) - for args in writer.get_args(dist, cmd.as_header()): - self.write_script(*args) - - def write_script(self, script_name, contents, mode="t", *ignored): - """Write an executable file to the scripts directory""" - from setuptools.command.easy_install import chmod, current_umask - - log.info("Installing %s script to %s", script_name, self.install_dir) - target = os.path.join(self.install_dir, script_name) - self.outfiles.append(target) - - mask = current_umask() - if not self.dry_run: - ensure_directory(target) - f = open(target, "w" + mode) - f.write(contents) - f.close() - chmod(target, 0o777 - mask) diff --git a/venv/lib/python3.8/site-packages/setuptools/command/launcher manifest.xml b/venv/lib/python3.8/site-packages/setuptools/command/launcher manifest.xml deleted file mode 100644 index 5972a96..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/command/launcher manifest.xml +++ /dev/null @@ -1,15 +0,0 @@ - - - - - - - - - - - - diff --git a/venv/lib/python3.8/site-packages/setuptools/command/py36compat.py b/venv/lib/python3.8/site-packages/setuptools/command/py36compat.py deleted file mode 100644 index 61063e7..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/command/py36compat.py +++ /dev/null @@ -1,136 +0,0 @@ -import os -from glob import glob -from distutils.util import convert_path -from distutils.command import sdist - -from setuptools.extern.six.moves import filter - - -class sdist_add_defaults: - """ - Mix-in providing forward-compatibility for functionality as found in - distutils on Python 3.7. - - Do not edit the code in this class except to update functionality - as implemented in distutils. Instead, override in the subclass. - """ - - def add_defaults(self): - """Add all the default files to self.filelist: - - README or README.txt - - setup.py - - test/test*.py - - all pure Python modules mentioned in setup script - - all files pointed by package_data (build_py) - - all files defined in data_files. - - all files defined as scripts. - - all C sources listed as part of extensions or C libraries - in the setup script (doesn't catch C headers!) - Warns if (README or README.txt) or setup.py are missing; everything - else is optional. - """ - self._add_defaults_standards() - self._add_defaults_optional() - self._add_defaults_python() - self._add_defaults_data_files() - self._add_defaults_ext() - self._add_defaults_c_libs() - self._add_defaults_scripts() - - @staticmethod - def _cs_path_exists(fspath): - """ - Case-sensitive path existence check - - >>> sdist_add_defaults._cs_path_exists(__file__) - True - >>> sdist_add_defaults._cs_path_exists(__file__.upper()) - False - """ - if not os.path.exists(fspath): - return False - # make absolute so we always have a directory - abspath = os.path.abspath(fspath) - directory, filename = os.path.split(abspath) - return filename in os.listdir(directory) - - def _add_defaults_standards(self): - standards = [self.READMES, self.distribution.script_name] - for fn in standards: - if isinstance(fn, tuple): - alts = fn - got_it = False - for fn in alts: - if self._cs_path_exists(fn): - got_it = True - self.filelist.append(fn) - break - - if not got_it: - self.warn("standard file not found: should have one of " + - ', '.join(alts)) - else: - if self._cs_path_exists(fn): - self.filelist.append(fn) - else: - self.warn("standard file '%s' not found" % fn) - - def _add_defaults_optional(self): - optional = ['test/test*.py', 'setup.cfg'] - for pattern in optional: - files = filter(os.path.isfile, glob(pattern)) - self.filelist.extend(files) - - def _add_defaults_python(self): - # build_py is used to get: - # - python modules - # - files defined in package_data - build_py = self.get_finalized_command('build_py') - - # getting python files - if self.distribution.has_pure_modules(): - self.filelist.extend(build_py.get_source_files()) - - # getting package_data files - # (computed in build_py.data_files by build_py.finalize_options) - for pkg, src_dir, build_dir, filenames in build_py.data_files: - for filename in filenames: - self.filelist.append(os.path.join(src_dir, filename)) - - def _add_defaults_data_files(self): - # getting distribution.data_files - if self.distribution.has_data_files(): - for item in self.distribution.data_files: - if isinstance(item, str): - # plain file - item = convert_path(item) - if os.path.isfile(item): - self.filelist.append(item) - else: - # a (dirname, filenames) tuple - dirname, filenames = item - for f in filenames: - f = convert_path(f) - if os.path.isfile(f): - self.filelist.append(f) - - def _add_defaults_ext(self): - if self.distribution.has_ext_modules(): - build_ext = self.get_finalized_command('build_ext') - self.filelist.extend(build_ext.get_source_files()) - - def _add_defaults_c_libs(self): - if self.distribution.has_c_libraries(): - build_clib = self.get_finalized_command('build_clib') - self.filelist.extend(build_clib.get_source_files()) - - def _add_defaults_scripts(self): - if self.distribution.has_scripts(): - build_scripts = self.get_finalized_command('build_scripts') - self.filelist.extend(build_scripts.get_source_files()) - - -if hasattr(sdist.sdist, '_add_defaults_standards'): - # disable the functionality already available upstream - class sdist_add_defaults: - pass diff --git a/venv/lib/python3.8/site-packages/setuptools/command/register.py b/venv/lib/python3.8/site-packages/setuptools/command/register.py deleted file mode 100644 index b8266b9..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/command/register.py +++ /dev/null @@ -1,18 +0,0 @@ -from distutils import log -import distutils.command.register as orig - -from setuptools.errors import RemovedCommandError - - -class register(orig.register): - """Formerly used to register packages on PyPI.""" - - def run(self): - msg = ( - "The register command has been removed, use twine to upload " - + "instead (https://pypi.org/p/twine)" - ) - - self.announce("ERROR: " + msg, log.ERROR) - - raise RemovedCommandError(msg) diff --git a/venv/lib/python3.8/site-packages/setuptools/command/rotate.py b/venv/lib/python3.8/site-packages/setuptools/command/rotate.py deleted file mode 100644 index b89353f..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/command/rotate.py +++ /dev/null @@ -1,66 +0,0 @@ -from distutils.util import convert_path -from distutils import log -from distutils.errors import DistutilsOptionError -import os -import shutil - -from setuptools.extern import six - -from setuptools import Command - - -class rotate(Command): - """Delete older distributions""" - - description = "delete older distributions, keeping N newest files" - user_options = [ - ('match=', 'm', "patterns to match (required)"), - ('dist-dir=', 'd', "directory where the distributions are"), - ('keep=', 'k', "number of matching distributions to keep"), - ] - - boolean_options = [] - - def initialize_options(self): - self.match = None - self.dist_dir = None - self.keep = None - - def finalize_options(self): - if self.match is None: - raise DistutilsOptionError( - "Must specify one or more (comma-separated) match patterns " - "(e.g. '.zip' or '.egg')" - ) - if self.keep is None: - raise DistutilsOptionError("Must specify number of files to keep") - try: - self.keep = int(self.keep) - except ValueError: - raise DistutilsOptionError("--keep must be an integer") - if isinstance(self.match, six.string_types): - self.match = [ - convert_path(p.strip()) for p in self.match.split(',') - ] - self.set_undefined_options('bdist', ('dist_dir', 'dist_dir')) - - def run(self): - self.run_command("egg_info") - from glob import glob - - for pattern in self.match: - pattern = self.distribution.get_name() + '*' + pattern - files = glob(os.path.join(self.dist_dir, pattern)) - files = [(os.path.getmtime(f), f) for f in files] - files.sort() - files.reverse() - - log.info("%d file(s) matching %s", len(files), pattern) - files = files[self.keep:] - for (t, f) in files: - log.info("Deleting %s", f) - if not self.dry_run: - if os.path.isdir(f): - shutil.rmtree(f) - else: - os.unlink(f) diff --git a/venv/lib/python3.8/site-packages/setuptools/command/saveopts.py b/venv/lib/python3.8/site-packages/setuptools/command/saveopts.py deleted file mode 100644 index 611cec5..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/command/saveopts.py +++ /dev/null @@ -1,22 +0,0 @@ -from setuptools.command.setopt import edit_config, option_base - - -class saveopts(option_base): - """Save command-line options to a file""" - - description = "save supplied options to setup.cfg or other config file" - - def run(self): - dist = self.distribution - settings = {} - - for cmd in dist.command_options: - - if cmd == 'saveopts': - continue # don't save our own options! - - for opt, (src, val) in dist.get_option_dict(cmd).items(): - if src == "command line": - settings.setdefault(cmd, {})[opt] = val - - edit_config(self.filename, settings, self.dry_run) diff --git a/venv/lib/python3.8/site-packages/setuptools/command/sdist.py b/venv/lib/python3.8/site-packages/setuptools/command/sdist.py deleted file mode 100644 index a851453..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/command/sdist.py +++ /dev/null @@ -1,252 +0,0 @@ -from distutils import log -import distutils.command.sdist as orig -import os -import sys -import io -import contextlib - -from setuptools.extern import six, ordered_set - -from .py36compat import sdist_add_defaults - -import pkg_resources - -_default_revctrl = list - - -def walk_revctrl(dirname=''): - """Find all files under revision control""" - for ep in pkg_resources.iter_entry_points('setuptools.file_finders'): - for item in ep.load()(dirname): - yield item - - -class sdist(sdist_add_defaults, orig.sdist): - """Smart sdist that finds anything supported by revision control""" - - user_options = [ - ('formats=', None, - "formats for source distribution (comma-separated list)"), - ('keep-temp', 'k', - "keep the distribution tree around after creating " + - "archive file(s)"), - ('dist-dir=', 'd', - "directory to put the source distribution archive(s) in " - "[default: dist]"), - ] - - negative_opt = {} - - README_EXTENSIONS = ['', '.rst', '.txt', '.md'] - READMES = tuple('README{0}'.format(ext) for ext in README_EXTENSIONS) - - def run(self): - self.run_command('egg_info') - ei_cmd = self.get_finalized_command('egg_info') - self.filelist = ei_cmd.filelist - self.filelist.append(os.path.join(ei_cmd.egg_info, 'SOURCES.txt')) - self.check_readme() - - # Run sub commands - for cmd_name in self.get_sub_commands(): - self.run_command(cmd_name) - - self.make_distribution() - - dist_files = getattr(self.distribution, 'dist_files', []) - for file in self.archive_files: - data = ('sdist', '', file) - if data not in dist_files: - dist_files.append(data) - - def initialize_options(self): - orig.sdist.initialize_options(self) - - self._default_to_gztar() - - def _default_to_gztar(self): - # only needed on Python prior to 3.6. - if sys.version_info >= (3, 6, 0, 'beta', 1): - return - self.formats = ['gztar'] - - def make_distribution(self): - """ - Workaround for #516 - """ - with self._remove_os_link(): - orig.sdist.make_distribution(self) - - @staticmethod - @contextlib.contextmanager - def _remove_os_link(): - """ - In a context, remove and restore os.link if it exists - """ - - class NoValue: - pass - - orig_val = getattr(os, 'link', NoValue) - try: - del os.link - except Exception: - pass - try: - yield - finally: - if orig_val is not NoValue: - setattr(os, 'link', orig_val) - - def __read_template_hack(self): - # This grody hack closes the template file (MANIFEST.in) if an - # exception occurs during read_template. - # Doing so prevents an error when easy_install attempts to delete the - # file. - try: - orig.sdist.read_template(self) - except Exception: - _, _, tb = sys.exc_info() - tb.tb_next.tb_frame.f_locals['template'].close() - raise - - # Beginning with Python 2.7.2, 3.1.4, and 3.2.1, this leaky file handle - # has been fixed, so only override the method if we're using an earlier - # Python. - has_leaky_handle = ( - sys.version_info < (2, 7, 2) - or (3, 0) <= sys.version_info < (3, 1, 4) - or (3, 2) <= sys.version_info < (3, 2, 1) - ) - if has_leaky_handle: - read_template = __read_template_hack - - def _add_defaults_optional(self): - if six.PY2: - sdist_add_defaults._add_defaults_optional(self) - else: - super()._add_defaults_optional() - if os.path.isfile('pyproject.toml'): - self.filelist.append('pyproject.toml') - - def _add_defaults_python(self): - """getting python files""" - if self.distribution.has_pure_modules(): - build_py = self.get_finalized_command('build_py') - self.filelist.extend(build_py.get_source_files()) - self._add_data_files(self._safe_data_files(build_py)) - - def _safe_data_files(self, build_py): - """ - Extracting data_files from build_py is known to cause - infinite recursion errors when `include_package_data` - is enabled, so suppress it in that case. - """ - if self.distribution.include_package_data: - return () - return build_py.data_files - - def _add_data_files(self, data_files): - """ - Add data files as found in build_py.data_files. - """ - self.filelist.extend( - os.path.join(src_dir, name) - for _, src_dir, _, filenames in data_files - for name in filenames - ) - - def _add_defaults_data_files(self): - try: - if six.PY2: - sdist_add_defaults._add_defaults_data_files(self) - else: - super()._add_defaults_data_files() - except TypeError: - log.warn("data_files contains unexpected objects") - - def check_readme(self): - for f in self.READMES: - if os.path.exists(f): - return - else: - self.warn( - "standard file not found: should have one of " + - ', '.join(self.READMES) - ) - - def make_release_tree(self, base_dir, files): - orig.sdist.make_release_tree(self, base_dir, files) - - # Save any egg_info command line options used to create this sdist - dest = os.path.join(base_dir, 'setup.cfg') - if hasattr(os, 'link') and os.path.exists(dest): - # unlink and re-copy, since it might be hard-linked, and - # we don't want to change the source version - os.unlink(dest) - self.copy_file('setup.cfg', dest) - - self.get_finalized_command('egg_info').save_version_info(dest) - - def _manifest_is_not_generated(self): - # check for special comment used in 2.7.1 and higher - if not os.path.isfile(self.manifest): - return False - - with io.open(self.manifest, 'rb') as fp: - first_line = fp.readline() - return (first_line != - '# file GENERATED by distutils, do NOT edit\n'.encode()) - - def read_manifest(self): - """Read the manifest file (named by 'self.manifest') and use it to - fill in 'self.filelist', the list of files to include in the source - distribution. - """ - log.info("reading manifest file '%s'", self.manifest) - manifest = open(self.manifest, 'rb') - for line in manifest: - # The manifest must contain UTF-8. See #303. - if six.PY3: - try: - line = line.decode('UTF-8') - except UnicodeDecodeError: - log.warn("%r not UTF-8 decodable -- skipping" % line) - continue - # ignore comments and blank lines - line = line.strip() - if line.startswith('#') or not line: - continue - self.filelist.append(line) - manifest.close() - - def check_license(self): - """Checks if license_file' or 'license_files' is configured and adds any - valid paths to 'self.filelist'. - """ - - files = ordered_set.OrderedSet() - - opts = self.distribution.get_option_dict('metadata') - - # ignore the source of the value - _, license_file = opts.get('license_file', (None, None)) - - if license_file is None: - log.debug("'license_file' option was not specified") - else: - files.add(license_file) - - try: - files.update(self.distribution.metadata.license_files) - except TypeError: - log.warn("warning: 'license_files' option is malformed") - - for f in files: - if not os.path.exists(f): - log.warn( - "warning: Failed to find the configured license file '%s'", - f) - files.remove(f) - - self.filelist.extend(files) diff --git a/venv/lib/python3.8/site-packages/setuptools/command/setopt.py b/venv/lib/python3.8/site-packages/setuptools/command/setopt.py deleted file mode 100644 index 7e57cc0..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/command/setopt.py +++ /dev/null @@ -1,149 +0,0 @@ -from distutils.util import convert_path -from distutils import log -from distutils.errors import DistutilsOptionError -import distutils -import os - -from setuptools.extern.six.moves import configparser - -from setuptools import Command - -__all__ = ['config_file', 'edit_config', 'option_base', 'setopt'] - - -def config_file(kind="local"): - """Get the filename of the distutils, local, global, or per-user config - - `kind` must be one of "local", "global", or "user" - """ - if kind == 'local': - return 'setup.cfg' - if kind == 'global': - return os.path.join( - os.path.dirname(distutils.__file__), 'distutils.cfg' - ) - if kind == 'user': - dot = os.name == 'posix' and '.' or '' - return os.path.expanduser(convert_path("~/%spydistutils.cfg" % dot)) - raise ValueError( - "config_file() type must be 'local', 'global', or 'user'", kind - ) - - -def edit_config(filename, settings, dry_run=False): - """Edit a configuration file to include `settings` - - `settings` is a dictionary of dictionaries or ``None`` values, keyed by - command/section name. A ``None`` value means to delete the entire section, - while a dictionary lists settings to be changed or deleted in that section. - A setting of ``None`` means to delete that setting. - """ - log.debug("Reading configuration from %s", filename) - opts = configparser.RawConfigParser() - opts.read([filename]) - for section, options in settings.items(): - if options is None: - log.info("Deleting section [%s] from %s", section, filename) - opts.remove_section(section) - else: - if not opts.has_section(section): - log.debug("Adding new section [%s] to %s", section, filename) - opts.add_section(section) - for option, value in options.items(): - if value is None: - log.debug( - "Deleting %s.%s from %s", - section, option, filename - ) - opts.remove_option(section, option) - if not opts.options(section): - log.info("Deleting empty [%s] section from %s", - section, filename) - opts.remove_section(section) - else: - log.debug( - "Setting %s.%s to %r in %s", - section, option, value, filename - ) - opts.set(section, option, value) - - log.info("Writing %s", filename) - if not dry_run: - with open(filename, 'w') as f: - opts.write(f) - - -class option_base(Command): - """Abstract base class for commands that mess with config files""" - - user_options = [ - ('global-config', 'g', - "save options to the site-wide distutils.cfg file"), - ('user-config', 'u', - "save options to the current user's pydistutils.cfg file"), - ('filename=', 'f', - "configuration file to use (default=setup.cfg)"), - ] - - boolean_options = [ - 'global-config', 'user-config', - ] - - def initialize_options(self): - self.global_config = None - self.user_config = None - self.filename = None - - def finalize_options(self): - filenames = [] - if self.global_config: - filenames.append(config_file('global')) - if self.user_config: - filenames.append(config_file('user')) - if self.filename is not None: - filenames.append(self.filename) - if not filenames: - filenames.append(config_file('local')) - if len(filenames) > 1: - raise DistutilsOptionError( - "Must specify only one configuration file option", - filenames - ) - self.filename, = filenames - - -class setopt(option_base): - """Save command-line options to a file""" - - description = "set an option in setup.cfg or another config file" - - user_options = [ - ('command=', 'c', 'command to set an option for'), - ('option=', 'o', 'option to set'), - ('set-value=', 's', 'value of the option'), - ('remove', 'r', 'remove (unset) the value'), - ] + option_base.user_options - - boolean_options = option_base.boolean_options + ['remove'] - - def initialize_options(self): - option_base.initialize_options(self) - self.command = None - self.option = None - self.set_value = None - self.remove = None - - def finalize_options(self): - option_base.finalize_options(self) - if self.command is None or self.option is None: - raise DistutilsOptionError("Must specify --command *and* --option") - if self.set_value is None and not self.remove: - raise DistutilsOptionError("Must specify --set-value or --remove") - - def run(self): - edit_config( - self.filename, { - self.command: {self.option.replace('-', '_'): self.set_value} - }, - self.dry_run - ) diff --git a/venv/lib/python3.8/site-packages/setuptools/command/test.py b/venv/lib/python3.8/site-packages/setuptools/command/test.py deleted file mode 100644 index c148b38..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/command/test.py +++ /dev/null @@ -1,279 +0,0 @@ -import os -import operator -import sys -import contextlib -import itertools -import unittest -from distutils.errors import DistutilsError, DistutilsOptionError -from distutils import log -from unittest import TestLoader - -from setuptools.extern import six -from setuptools.extern.six.moves import map, filter - -from pkg_resources import (resource_listdir, resource_exists, normalize_path, - working_set, _namespace_packages, evaluate_marker, - add_activation_listener, require, EntryPoint) -from setuptools import Command -from .build_py import _unique_everseen - -__metaclass__ = type - - -class ScanningLoader(TestLoader): - - def __init__(self): - TestLoader.__init__(self) - self._visited = set() - - def loadTestsFromModule(self, module, pattern=None): - """Return a suite of all tests cases contained in the given module - - If the module is a package, load tests from all the modules in it. - If the module has an ``additional_tests`` function, call it and add - the return value to the tests. - """ - if module in self._visited: - return None - self._visited.add(module) - - tests = [] - tests.append(TestLoader.loadTestsFromModule(self, module)) - - if hasattr(module, "additional_tests"): - tests.append(module.additional_tests()) - - if hasattr(module, '__path__'): - for file in resource_listdir(module.__name__, ''): - if file.endswith('.py') and file != '__init__.py': - submodule = module.__name__ + '.' + file[:-3] - else: - if resource_exists(module.__name__, file + '/__init__.py'): - submodule = module.__name__ + '.' + file - else: - continue - tests.append(self.loadTestsFromName(submodule)) - - if len(tests) != 1: - return self.suiteClass(tests) - else: - return tests[0] # don't create a nested suite for only one return - - -# adapted from jaraco.classes.properties:NonDataProperty -class NonDataProperty: - def __init__(self, fget): - self.fget = fget - - def __get__(self, obj, objtype=None): - if obj is None: - return self - return self.fget(obj) - - -class test(Command): - """Command to run unit tests after in-place build""" - - description = "run unit tests after in-place build (deprecated)" - - user_options = [ - ('test-module=', 'm', "Run 'test_suite' in specified module"), - ('test-suite=', 's', - "Run single test, case or suite (e.g. 'module.test_suite')"), - ('test-runner=', 'r', "Test runner to use"), - ] - - def initialize_options(self): - self.test_suite = None - self.test_module = None - self.test_loader = None - self.test_runner = None - - def finalize_options(self): - - if self.test_suite and self.test_module: - msg = "You may specify a module or a suite, but not both" - raise DistutilsOptionError(msg) - - if self.test_suite is None: - if self.test_module is None: - self.test_suite = self.distribution.test_suite - else: - self.test_suite = self.test_module + ".test_suite" - - if self.test_loader is None: - self.test_loader = getattr(self.distribution, 'test_loader', None) - if self.test_loader is None: - self.test_loader = "setuptools.command.test:ScanningLoader" - if self.test_runner is None: - self.test_runner = getattr(self.distribution, 'test_runner', None) - - @NonDataProperty - def test_args(self): - return list(self._test_args()) - - def _test_args(self): - if not self.test_suite and sys.version_info >= (2, 7): - yield 'discover' - if self.verbose: - yield '--verbose' - if self.test_suite: - yield self.test_suite - - def with_project_on_sys_path(self, func): - """ - Backward compatibility for project_on_sys_path context. - """ - with self.project_on_sys_path(): - func() - - @contextlib.contextmanager - def project_on_sys_path(self, include_dists=[]): - with_2to3 = six.PY3 and getattr(self.distribution, 'use_2to3', False) - - if with_2to3: - # If we run 2to3 we can not do this inplace: - - # Ensure metadata is up-to-date - self.reinitialize_command('build_py', inplace=0) - self.run_command('build_py') - bpy_cmd = self.get_finalized_command("build_py") - build_path = normalize_path(bpy_cmd.build_lib) - - # Build extensions - self.reinitialize_command('egg_info', egg_base=build_path) - self.run_command('egg_info') - - self.reinitialize_command('build_ext', inplace=0) - self.run_command('build_ext') - else: - # Without 2to3 inplace works fine: - self.run_command('egg_info') - - # Build extensions in-place - self.reinitialize_command('build_ext', inplace=1) - self.run_command('build_ext') - - ei_cmd = self.get_finalized_command("egg_info") - - old_path = sys.path[:] - old_modules = sys.modules.copy() - - try: - project_path = normalize_path(ei_cmd.egg_base) - sys.path.insert(0, project_path) - working_set.__init__() - add_activation_listener(lambda dist: dist.activate()) - require('%s==%s' % (ei_cmd.egg_name, ei_cmd.egg_version)) - with self.paths_on_pythonpath([project_path]): - yield - finally: - sys.path[:] = old_path - sys.modules.clear() - sys.modules.update(old_modules) - working_set.__init__() - - @staticmethod - @contextlib.contextmanager - def paths_on_pythonpath(paths): - """ - Add the indicated paths to the head of the PYTHONPATH environment - variable so that subprocesses will also see the packages at - these paths. - - Do this in a context that restores the value on exit. - """ - nothing = object() - orig_pythonpath = os.environ.get('PYTHONPATH', nothing) - current_pythonpath = os.environ.get('PYTHONPATH', '') - try: - prefix = os.pathsep.join(_unique_everseen(paths)) - to_join = filter(None, [prefix, current_pythonpath]) - new_path = os.pathsep.join(to_join) - if new_path: - os.environ['PYTHONPATH'] = new_path - yield - finally: - if orig_pythonpath is nothing: - os.environ.pop('PYTHONPATH', None) - else: - os.environ['PYTHONPATH'] = orig_pythonpath - - @staticmethod - def install_dists(dist): - """ - Install the requirements indicated by self.distribution and - return an iterable of the dists that were built. - """ - ir_d = dist.fetch_build_eggs(dist.install_requires) - tr_d = dist.fetch_build_eggs(dist.tests_require or []) - er_d = dist.fetch_build_eggs( - v for k, v in dist.extras_require.items() - if k.startswith(':') and evaluate_marker(k[1:]) - ) - return itertools.chain(ir_d, tr_d, er_d) - - def run(self): - self.announce( - "WARNING: Testing via this command is deprecated and will be " - "removed in a future version. Users looking for a generic test " - "entry point independent of test runner are encouraged to use " - "tox.", - log.WARN, - ) - - installed_dists = self.install_dists(self.distribution) - - cmd = ' '.join(self._argv) - if self.dry_run: - self.announce('skipping "%s" (dry run)' % cmd) - return - - self.announce('running "%s"' % cmd) - - paths = map(operator.attrgetter('location'), installed_dists) - with self.paths_on_pythonpath(paths): - with self.project_on_sys_path(): - self.run_tests() - - def run_tests(self): - # Purge modules under test from sys.modules. The test loader will - # re-import them from the build location. Required when 2to3 is used - # with namespace packages. - if six.PY3 and getattr(self.distribution, 'use_2to3', False): - module = self.test_suite.split('.')[0] - if module in _namespace_packages: - del_modules = [] - if module in sys.modules: - del_modules.append(module) - module += '.' - for name in sys.modules: - if name.startswith(module): - del_modules.append(name) - list(map(sys.modules.__delitem__, del_modules)) - - test = unittest.main( - None, None, self._argv, - testLoader=self._resolve_as_ep(self.test_loader), - testRunner=self._resolve_as_ep(self.test_runner), - exit=False, - ) - if not test.result.wasSuccessful(): - msg = 'Test failed: %s' % test.result - self.announce(msg, log.ERROR) - raise DistutilsError(msg) - - @property - def _argv(self): - return ['unittest'] + self.test_args - - @staticmethod - def _resolve_as_ep(val): - """ - Load the indicated attribute value, called, as a as if it were - specified as an entry point. - """ - if val is None: - return - parsed = EntryPoint.parse("x=" + val) - return parsed.resolve()() diff --git a/venv/lib/python3.8/site-packages/setuptools/command/upload.py b/venv/lib/python3.8/site-packages/setuptools/command/upload.py deleted file mode 100644 index ec7f81e..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/command/upload.py +++ /dev/null @@ -1,17 +0,0 @@ -from distutils import log -from distutils.command import upload as orig - -from setuptools.errors import RemovedCommandError - - -class upload(orig.upload): - """Formerly used to upload packages to PyPI.""" - - def run(self): - msg = ( - "The upload command has been removed, use twine to upload " - + "instead (https://pypi.org/p/twine)" - ) - - self.announce("ERROR: " + msg, log.ERROR) - raise RemovedCommandError(msg) diff --git a/venv/lib/python3.8/site-packages/setuptools/command/upload_docs.py b/venv/lib/python3.8/site-packages/setuptools/command/upload_docs.py deleted file mode 100644 index 07aa564..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/command/upload_docs.py +++ /dev/null @@ -1,206 +0,0 @@ -# -*- coding: utf-8 -*- -"""upload_docs - -Implements a Distutils 'upload_docs' subcommand (upload documentation to -PyPI's pythonhosted.org). -""" - -from base64 import standard_b64encode -from distutils import log -from distutils.errors import DistutilsOptionError -import os -import socket -import zipfile -import tempfile -import shutil -import itertools -import functools - -from setuptools.extern import six -from setuptools.extern.six.moves import http_client, urllib - -from pkg_resources import iter_entry_points -from .upload import upload - - -def _encode(s): - errors = 'surrogateescape' if six.PY3 else 'strict' - return s.encode('utf-8', errors) - - -class upload_docs(upload): - # override the default repository as upload_docs isn't - # supported by Warehouse (and won't be). - DEFAULT_REPOSITORY = 'https://pypi.python.org/pypi/' - - description = 'Upload documentation to PyPI' - - user_options = [ - ('repository=', 'r', - "url of repository [default: %s]" % upload.DEFAULT_REPOSITORY), - ('show-response', None, - 'display full response text from server'), - ('upload-dir=', None, 'directory to upload'), - ] - boolean_options = upload.boolean_options - - def has_sphinx(self): - if self.upload_dir is None: - for ep in iter_entry_points('distutils.commands', 'build_sphinx'): - return True - - sub_commands = [('build_sphinx', has_sphinx)] - - def initialize_options(self): - upload.initialize_options(self) - self.upload_dir = None - self.target_dir = None - - def finalize_options(self): - upload.finalize_options(self) - if self.upload_dir is None: - if self.has_sphinx(): - build_sphinx = self.get_finalized_command('build_sphinx') - self.target_dir = build_sphinx.builder_target_dir - else: - build = self.get_finalized_command('build') - self.target_dir = os.path.join(build.build_base, 'docs') - else: - self.ensure_dirname('upload_dir') - self.target_dir = self.upload_dir - if 'pypi.python.org' in self.repository: - log.warn("Upload_docs command is deprecated. Use RTD instead.") - self.announce('Using upload directory %s' % self.target_dir) - - def create_zipfile(self, filename): - zip_file = zipfile.ZipFile(filename, "w") - try: - self.mkpath(self.target_dir) # just in case - for root, dirs, files in os.walk(self.target_dir): - if root == self.target_dir and not files: - tmpl = "no files found in upload directory '%s'" - raise DistutilsOptionError(tmpl % self.target_dir) - for name in files: - full = os.path.join(root, name) - relative = root[len(self.target_dir):].lstrip(os.path.sep) - dest = os.path.join(relative, name) - zip_file.write(full, dest) - finally: - zip_file.close() - - def run(self): - # Run sub commands - for cmd_name in self.get_sub_commands(): - self.run_command(cmd_name) - - tmp_dir = tempfile.mkdtemp() - name = self.distribution.metadata.get_name() - zip_file = os.path.join(tmp_dir, "%s.zip" % name) - try: - self.create_zipfile(zip_file) - self.upload_file(zip_file) - finally: - shutil.rmtree(tmp_dir) - - @staticmethod - def _build_part(item, sep_boundary): - key, values = item - title = '\nContent-Disposition: form-data; name="%s"' % key - # handle multiple entries for the same name - if not isinstance(values, list): - values = [values] - for value in values: - if isinstance(value, tuple): - title += '; filename="%s"' % value[0] - value = value[1] - else: - value = _encode(value) - yield sep_boundary - yield _encode(title) - yield b"\n\n" - yield value - if value and value[-1:] == b'\r': - yield b'\n' # write an extra newline (lurve Macs) - - @classmethod - def _build_multipart(cls, data): - """ - Build up the MIME payload for the POST data - """ - boundary = b'--------------GHSKFJDLGDS7543FJKLFHRE75642756743254' - sep_boundary = b'\n--' + boundary - end_boundary = sep_boundary + b'--' - end_items = end_boundary, b"\n", - builder = functools.partial( - cls._build_part, - sep_boundary=sep_boundary, - ) - part_groups = map(builder, data.items()) - parts = itertools.chain.from_iterable(part_groups) - body_items = itertools.chain(parts, end_items) - content_type = 'multipart/form-data; boundary=%s' % boundary.decode('ascii') - return b''.join(body_items), content_type - - def upload_file(self, filename): - with open(filename, 'rb') as f: - content = f.read() - meta = self.distribution.metadata - data = { - ':action': 'doc_upload', - 'name': meta.get_name(), - 'content': (os.path.basename(filename), content), - } - # set up the authentication - credentials = _encode(self.username + ':' + self.password) - credentials = standard_b64encode(credentials) - if six.PY3: - credentials = credentials.decode('ascii') - auth = "Basic " + credentials - - body, ct = self._build_multipart(data) - - msg = "Submitting documentation to %s" % (self.repository) - self.announce(msg, log.INFO) - - # build the Request - # We can't use urllib2 since we need to send the Basic - # auth right with the first request - schema, netloc, url, params, query, fragments = \ - urllib.parse.urlparse(self.repository) - assert not params and not query and not fragments - if schema == 'http': - conn = http_client.HTTPConnection(netloc) - elif schema == 'https': - conn = http_client.HTTPSConnection(netloc) - else: - raise AssertionError("unsupported schema " + schema) - - data = '' - try: - conn.connect() - conn.putrequest("POST", url) - content_type = ct - conn.putheader('Content-type', content_type) - conn.putheader('Content-length', str(len(body))) - conn.putheader('Authorization', auth) - conn.endheaders() - conn.send(body) - except socket.error as e: - self.announce(str(e), log.ERROR) - return - - r = conn.getresponse() - if r.status == 200: - msg = 'Server response (%s): %s' % (r.status, r.reason) - self.announce(msg, log.INFO) - elif r.status == 301: - location = r.getheader('Location') - if location is None: - location = 'https://pythonhosted.org/%s/' % meta.get_name() - msg = 'Upload successful. Visit %s' % location - self.announce(msg, log.INFO) - else: - msg = 'Upload failed (%s): %s' % (r.status, r.reason) - self.announce(msg, log.ERROR) - if self.show_response: - print('-' * 75, r.read(), '-' * 75) diff --git a/venv/lib/python3.8/site-packages/setuptools/config.py b/venv/lib/python3.8/site-packages/setuptools/config.py deleted file mode 100644 index 9b9a0c4..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/config.py +++ /dev/null @@ -1,659 +0,0 @@ -from __future__ import absolute_import, unicode_literals -import io -import os -import sys - -import warnings -import functools -from collections import defaultdict -from functools import partial -from functools import wraps -from importlib import import_module - -from distutils.errors import DistutilsOptionError, DistutilsFileError -from setuptools.extern.packaging.version import LegacyVersion, parse -from setuptools.extern.packaging.specifiers import SpecifierSet -from setuptools.extern.six import string_types, PY3 - - -__metaclass__ = type - - -def read_configuration( - filepath, find_others=False, ignore_option_errors=False): - """Read given configuration file and returns options from it as a dict. - - :param str|unicode filepath: Path to configuration file - to get options from. - - :param bool find_others: Whether to search for other configuration files - which could be on in various places. - - :param bool ignore_option_errors: Whether to silently ignore - options, values of which could not be resolved (e.g. due to exceptions - in directives such as file:, attr:, etc.). - If False exceptions are propagated as expected. - - :rtype: dict - """ - from setuptools.dist import Distribution, _Distribution - - filepath = os.path.abspath(filepath) - - if not os.path.isfile(filepath): - raise DistutilsFileError( - 'Configuration file %s does not exist.' % filepath) - - current_directory = os.getcwd() - os.chdir(os.path.dirname(filepath)) - - try: - dist = Distribution() - - filenames = dist.find_config_files() if find_others else [] - if filepath not in filenames: - filenames.append(filepath) - - _Distribution.parse_config_files(dist, filenames=filenames) - - handlers = parse_configuration( - dist, dist.command_options, - ignore_option_errors=ignore_option_errors) - - finally: - os.chdir(current_directory) - - return configuration_to_dict(handlers) - - -def _get_option(target_obj, key): - """ - Given a target object and option key, get that option from - the target object, either through a get_{key} method or - from an attribute directly. - """ - getter_name = 'get_{key}'.format(**locals()) - by_attribute = functools.partial(getattr, target_obj, key) - getter = getattr(target_obj, getter_name, by_attribute) - return getter() - - -def configuration_to_dict(handlers): - """Returns configuration data gathered by given handlers as a dict. - - :param list[ConfigHandler] handlers: Handlers list, - usually from parse_configuration() - - :rtype: dict - """ - config_dict = defaultdict(dict) - - for handler in handlers: - for option in handler.set_options: - value = _get_option(handler.target_obj, option) - config_dict[handler.section_prefix][option] = value - - return config_dict - - -def parse_configuration( - distribution, command_options, ignore_option_errors=False): - """Performs additional parsing of configuration options - for a distribution. - - Returns a list of used option handlers. - - :param Distribution distribution: - :param dict command_options: - :param bool ignore_option_errors: Whether to silently ignore - options, values of which could not be resolved (e.g. due to exceptions - in directives such as file:, attr:, etc.). - If False exceptions are propagated as expected. - :rtype: list - """ - options = ConfigOptionsHandler( - distribution, command_options, ignore_option_errors) - options.parse() - - meta = ConfigMetadataHandler( - distribution.metadata, command_options, ignore_option_errors, - distribution.package_dir) - meta.parse() - - return meta, options - - -class ConfigHandler: - """Handles metadata supplied in configuration files.""" - - section_prefix = None - """Prefix for config sections handled by this handler. - Must be provided by class heirs. - - """ - - aliases = {} - """Options aliases. - For compatibility with various packages. E.g.: d2to1 and pbr. - Note: `-` in keys is replaced with `_` by config parser. - - """ - - def __init__(self, target_obj, options, ignore_option_errors=False): - sections = {} - - section_prefix = self.section_prefix - for section_name, section_options in options.items(): - if not section_name.startswith(section_prefix): - continue - - section_name = section_name.replace(section_prefix, '').strip('.') - sections[section_name] = section_options - - self.ignore_option_errors = ignore_option_errors - self.target_obj = target_obj - self.sections = sections - self.set_options = [] - - @property - def parsers(self): - """Metadata item name to parser function mapping.""" - raise NotImplementedError( - '%s must provide .parsers property' % self.__class__.__name__) - - def __setitem__(self, option_name, value): - unknown = tuple() - target_obj = self.target_obj - - # Translate alias into real name. - option_name = self.aliases.get(option_name, option_name) - - current_value = getattr(target_obj, option_name, unknown) - - if current_value is unknown: - raise KeyError(option_name) - - if current_value: - # Already inhabited. Skipping. - return - - skip_option = False - parser = self.parsers.get(option_name) - if parser: - try: - value = parser(value) - - except Exception: - skip_option = True - if not self.ignore_option_errors: - raise - - if skip_option: - return - - setter = getattr(target_obj, 'set_%s' % option_name, None) - if setter is None: - setattr(target_obj, option_name, value) - else: - setter(value) - - self.set_options.append(option_name) - - @classmethod - def _parse_list(cls, value, separator=','): - """Represents value as a list. - - Value is split either by separator (defaults to comma) or by lines. - - :param value: - :param separator: List items separator character. - :rtype: list - """ - if isinstance(value, list): # _get_parser_compound case - return value - - if '\n' in value: - value = value.splitlines() - else: - value = value.split(separator) - - return [chunk.strip() for chunk in value if chunk.strip()] - - @classmethod - def _parse_dict(cls, value): - """Represents value as a dict. - - :param value: - :rtype: dict - """ - separator = '=' - result = {} - for line in cls._parse_list(value): - key, sep, val = line.partition(separator) - if sep != separator: - raise DistutilsOptionError( - 'Unable to parse option value to dict: %s' % value) - result[key.strip()] = val.strip() - - return result - - @classmethod - def _parse_bool(cls, value): - """Represents value as boolean. - - :param value: - :rtype: bool - """ - value = value.lower() - return value in ('1', 'true', 'yes') - - @classmethod - def _exclude_files_parser(cls, key): - """Returns a parser function to make sure field inputs - are not files. - - Parses a value after getting the key so error messages are - more informative. - - :param key: - :rtype: callable - """ - def parser(value): - exclude_directive = 'file:' - if value.startswith(exclude_directive): - raise ValueError( - 'Only strings are accepted for the {0} field, ' - 'files are not accepted'.format(key)) - return value - return parser - - @classmethod - def _parse_file(cls, value): - """Represents value as a string, allowing including text - from nearest files using `file:` directive. - - Directive is sandboxed and won't reach anything outside - directory with setup.py. - - Examples: - file: README.rst, CHANGELOG.md, src/file.txt - - :param str value: - :rtype: str - """ - include_directive = 'file:' - - if not isinstance(value, string_types): - return value - - if not value.startswith(include_directive): - return value - - spec = value[len(include_directive):] - filepaths = (os.path.abspath(path.strip()) for path in spec.split(',')) - return '\n'.join( - cls._read_file(path) - for path in filepaths - if (cls._assert_local(path) or True) - and os.path.isfile(path) - ) - - @staticmethod - def _assert_local(filepath): - if not filepath.startswith(os.getcwd()): - raise DistutilsOptionError( - '`file:` directive can not access %s' % filepath) - - @staticmethod - def _read_file(filepath): - with io.open(filepath, encoding='utf-8') as f: - return f.read() - - @classmethod - def _parse_attr(cls, value, package_dir=None): - """Represents value as a module attribute. - - Examples: - attr: package.attr - attr: package.module.attr - - :param str value: - :rtype: str - """ - attr_directive = 'attr:' - if not value.startswith(attr_directive): - return value - - attrs_path = value.replace(attr_directive, '').strip().split('.') - attr_name = attrs_path.pop() - - module_name = '.'.join(attrs_path) - module_name = module_name or '__init__' - - parent_path = os.getcwd() - if package_dir: - if attrs_path[0] in package_dir: - # A custom path was specified for the module we want to import - custom_path = package_dir[attrs_path[0]] - parts = custom_path.rsplit('/', 1) - if len(parts) > 1: - parent_path = os.path.join(os.getcwd(), parts[0]) - module_name = parts[1] - else: - module_name = custom_path - elif '' in package_dir: - # A custom parent directory was specified for all root modules - parent_path = os.path.join(os.getcwd(), package_dir['']) - sys.path.insert(0, parent_path) - try: - module = import_module(module_name) - value = getattr(module, attr_name) - - finally: - sys.path = sys.path[1:] - - return value - - @classmethod - def _get_parser_compound(cls, *parse_methods): - """Returns parser function to represents value as a list. - - Parses a value applying given methods one after another. - - :param parse_methods: - :rtype: callable - """ - def parse(value): - parsed = value - - for method in parse_methods: - parsed = method(parsed) - - return parsed - - return parse - - @classmethod - def _parse_section_to_dict(cls, section_options, values_parser=None): - """Parses section options into a dictionary. - - Optionally applies a given parser to values. - - :param dict section_options: - :param callable values_parser: - :rtype: dict - """ - value = {} - values_parser = values_parser or (lambda val: val) - for key, (_, val) in section_options.items(): - value[key] = values_parser(val) - return value - - def parse_section(self, section_options): - """Parses configuration file section. - - :param dict section_options: - """ - for (name, (_, value)) in section_options.items(): - try: - self[name] = value - - except KeyError: - pass # Keep silent for a new option may appear anytime. - - def parse(self): - """Parses configuration file items from one - or more related sections. - - """ - for section_name, section_options in self.sections.items(): - - method_postfix = '' - if section_name: # [section.option] variant - method_postfix = '_%s' % section_name - - section_parser_method = getattr( - self, - # Dots in section names are translated into dunderscores. - ('parse_section%s' % method_postfix).replace('.', '__'), - None) - - if section_parser_method is None: - raise DistutilsOptionError( - 'Unsupported distribution option section: [%s.%s]' % ( - self.section_prefix, section_name)) - - section_parser_method(section_options) - - def _deprecated_config_handler(self, func, msg, warning_class): - """ this function will wrap around parameters that are deprecated - - :param msg: deprecation message - :param warning_class: class of warning exception to be raised - :param func: function to be wrapped around - """ - @wraps(func) - def config_handler(*args, **kwargs): - warnings.warn(msg, warning_class) - return func(*args, **kwargs) - - return config_handler - - -class ConfigMetadataHandler(ConfigHandler): - - section_prefix = 'metadata' - - aliases = { - 'home_page': 'url', - 'summary': 'description', - 'classifier': 'classifiers', - 'platform': 'platforms', - } - - strict_mode = False - """We need to keep it loose, to be partially compatible with - `pbr` and `d2to1` packages which also uses `metadata` section. - - """ - - def __init__(self, target_obj, options, ignore_option_errors=False, - package_dir=None): - super(ConfigMetadataHandler, self).__init__(target_obj, options, - ignore_option_errors) - self.package_dir = package_dir - - @property - def parsers(self): - """Metadata item name to parser function mapping.""" - parse_list = self._parse_list - parse_file = self._parse_file - parse_dict = self._parse_dict - exclude_files_parser = self._exclude_files_parser - - return { - 'platforms': parse_list, - 'keywords': parse_list, - 'provides': parse_list, - 'requires': self._deprecated_config_handler( - parse_list, - "The requires parameter is deprecated, please use " - "install_requires for runtime dependencies.", - DeprecationWarning), - 'obsoletes': parse_list, - 'classifiers': self._get_parser_compound(parse_file, parse_list), - 'license': exclude_files_parser('license'), - 'license_files': parse_list, - 'description': parse_file, - 'long_description': parse_file, - 'version': self._parse_version, - 'project_urls': parse_dict, - } - - def _parse_version(self, value): - """Parses `version` option value. - - :param value: - :rtype: str - - """ - version = self._parse_file(value) - - if version != value: - version = version.strip() - # Be strict about versions loaded from file because it's easy to - # accidentally include newlines and other unintended content - if isinstance(parse(version), LegacyVersion): - tmpl = ( - 'Version loaded from {value} does not ' - 'comply with PEP 440: {version}' - ) - raise DistutilsOptionError(tmpl.format(**locals())) - - return version - - version = self._parse_attr(value, self.package_dir) - - if callable(version): - version = version() - - if not isinstance(version, string_types): - if hasattr(version, '__iter__'): - version = '.'.join(map(str, version)) - else: - version = '%s' % version - - return version - - -class ConfigOptionsHandler(ConfigHandler): - - section_prefix = 'options' - - @property - def parsers(self): - """Metadata item name to parser function mapping.""" - parse_list = self._parse_list - parse_list_semicolon = partial(self._parse_list, separator=';') - parse_bool = self._parse_bool - parse_dict = self._parse_dict - - return { - 'zip_safe': parse_bool, - 'use_2to3': parse_bool, - 'include_package_data': parse_bool, - 'package_dir': parse_dict, - 'use_2to3_fixers': parse_list, - 'use_2to3_exclude_fixers': parse_list, - 'convert_2to3_doctests': parse_list, - 'scripts': parse_list, - 'eager_resources': parse_list, - 'dependency_links': parse_list, - 'namespace_packages': parse_list, - 'install_requires': parse_list_semicolon, - 'setup_requires': parse_list_semicolon, - 'tests_require': parse_list_semicolon, - 'packages': self._parse_packages, - 'entry_points': self._parse_file, - 'py_modules': parse_list, - 'python_requires': SpecifierSet, - } - - def _parse_packages(self, value): - """Parses `packages` option value. - - :param value: - :rtype: list - """ - find_directives = ['find:', 'find_namespace:'] - trimmed_value = value.strip() - - if trimmed_value not in find_directives: - return self._parse_list(value) - - findns = trimmed_value == find_directives[1] - if findns and not PY3: - raise DistutilsOptionError( - 'find_namespace: directive is unsupported on Python < 3.3') - - # Read function arguments from a dedicated section. - find_kwargs = self.parse_section_packages__find( - self.sections.get('packages.find', {})) - - if findns: - from setuptools import find_namespace_packages as find_packages - else: - from setuptools import find_packages - - return find_packages(**find_kwargs) - - def parse_section_packages__find(self, section_options): - """Parses `packages.find` configuration file section. - - To be used in conjunction with _parse_packages(). - - :param dict section_options: - """ - section_data = self._parse_section_to_dict( - section_options, self._parse_list) - - valid_keys = ['where', 'include', 'exclude'] - - find_kwargs = dict( - [(k, v) for k, v in section_data.items() if k in valid_keys and v]) - - where = find_kwargs.get('where') - if where is not None: - find_kwargs['where'] = where[0] # cast list to single val - - return find_kwargs - - def parse_section_entry_points(self, section_options): - """Parses `entry_points` configuration file section. - - :param dict section_options: - """ - parsed = self._parse_section_to_dict(section_options, self._parse_list) - self['entry_points'] = parsed - - def _parse_package_data(self, section_options): - parsed = self._parse_section_to_dict(section_options, self._parse_list) - - root = parsed.get('*') - if root: - parsed[''] = root - del parsed['*'] - - return parsed - - def parse_section_package_data(self, section_options): - """Parses `package_data` configuration file section. - - :param dict section_options: - """ - self['package_data'] = self._parse_package_data(section_options) - - def parse_section_exclude_package_data(self, section_options): - """Parses `exclude_package_data` configuration file section. - - :param dict section_options: - """ - self['exclude_package_data'] = self._parse_package_data( - section_options) - - def parse_section_extras_require(self, section_options): - """Parses `extras_require` configuration file section. - - :param dict section_options: - """ - parse_list = partial(self._parse_list, separator=';') - self['extras_require'] = self._parse_section_to_dict( - section_options, parse_list) - - def parse_section_data_files(self, section_options): - """Parses `data_files` configuration file section. - - :param dict section_options: - """ - parsed = self._parse_section_to_dict(section_options, self._parse_list) - self['data_files'] = [(k, v) for k, v in parsed.items()] diff --git a/venv/lib/python3.8/site-packages/setuptools/dep_util.py b/venv/lib/python3.8/site-packages/setuptools/dep_util.py deleted file mode 100644 index 2931c13..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/dep_util.py +++ /dev/null @@ -1,23 +0,0 @@ -from distutils.dep_util import newer_group - -# yes, this is was almost entirely copy-pasted from -# 'newer_pairwise()', this is just another convenience -# function. -def newer_pairwise_group(sources_groups, targets): - """Walk both arguments in parallel, testing if each source group is newer - than its corresponding target. Returns a pair of lists (sources_groups, - targets) where sources is newer than target, according to the semantics - of 'newer_group()'. - """ - if len(sources_groups) != len(targets): - raise ValueError("'sources_group' and 'targets' must be the same length") - - # build a pair of lists (sources_groups, targets) where source is newer - n_sources = [] - n_targets = [] - for i in range(len(sources_groups)): - if newer_group(sources_groups[i], targets[i]): - n_sources.append(sources_groups[i]) - n_targets.append(targets[i]) - - return n_sources, n_targets diff --git a/venv/lib/python3.8/site-packages/setuptools/depends.py b/venv/lib/python3.8/site-packages/setuptools/depends.py deleted file mode 100644 index a37675c..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/depends.py +++ /dev/null @@ -1,176 +0,0 @@ -import sys -import marshal -import contextlib -from distutils.version import StrictVersion - -from .py33compat import Bytecode - -from .py27compat import find_module, PY_COMPILED, PY_FROZEN, PY_SOURCE -from . import py27compat - - -__all__ = [ - 'Require', 'find_module', 'get_module_constant', 'extract_constant' -] - - -class Require: - """A prerequisite to building or installing a distribution""" - - def __init__( - self, name, requested_version, module, homepage='', - attribute=None, format=None): - - if format is None and requested_version is not None: - format = StrictVersion - - if format is not None: - requested_version = format(requested_version) - if attribute is None: - attribute = '__version__' - - self.__dict__.update(locals()) - del self.self - - def full_name(self): - """Return full package/distribution name, w/version""" - if self.requested_version is not None: - return '%s-%s' % (self.name, self.requested_version) - return self.name - - def version_ok(self, version): - """Is 'version' sufficiently up-to-date?""" - return self.attribute is None or self.format is None or \ - str(version) != "unknown" and version >= self.requested_version - - def get_version(self, paths=None, default="unknown"): - """Get version number of installed module, 'None', or 'default' - - Search 'paths' for module. If not found, return 'None'. If found, - return the extracted version attribute, or 'default' if no version - attribute was specified, or the value cannot be determined without - importing the module. The version is formatted according to the - requirement's version format (if any), unless it is 'None' or the - supplied 'default'. - """ - - if self.attribute is None: - try: - f, p, i = find_module(self.module, paths) - if f: - f.close() - return default - except ImportError: - return None - - v = get_module_constant(self.module, self.attribute, default, paths) - - if v is not None and v is not default and self.format is not None: - return self.format(v) - - return v - - def is_present(self, paths=None): - """Return true if dependency is present on 'paths'""" - return self.get_version(paths) is not None - - def is_current(self, paths=None): - """Return true if dependency is present and up-to-date on 'paths'""" - version = self.get_version(paths) - if version is None: - return False - return self.version_ok(version) - - -def maybe_close(f): - @contextlib.contextmanager - def empty(): - yield - return - if not f: - return empty() - - return contextlib.closing(f) - - -def get_module_constant(module, symbol, default=-1, paths=None): - """Find 'module' by searching 'paths', and extract 'symbol' - - Return 'None' if 'module' does not exist on 'paths', or it does not define - 'symbol'. If the module defines 'symbol' as a constant, return the - constant. Otherwise, return 'default'.""" - - try: - f, path, (suffix, mode, kind) = info = find_module(module, paths) - except ImportError: - # Module doesn't exist - return None - - with maybe_close(f): - if kind == PY_COMPILED: - f.read(8) # skip magic & date - code = marshal.load(f) - elif kind == PY_FROZEN: - code = py27compat.get_frozen_object(module, paths) - elif kind == PY_SOURCE: - code = compile(f.read(), path, 'exec') - else: - # Not something we can parse; we'll have to import it. :( - imported = py27compat.get_module(module, paths, info) - return getattr(imported, symbol, None) - - return extract_constant(code, symbol, default) - - -def extract_constant(code, symbol, default=-1): - """Extract the constant value of 'symbol' from 'code' - - If the name 'symbol' is bound to a constant value by the Python code - object 'code', return that value. If 'symbol' is bound to an expression, - return 'default'. Otherwise, return 'None'. - - Return value is based on the first assignment to 'symbol'. 'symbol' must - be a global, or at least a non-"fast" local in the code block. That is, - only 'STORE_NAME' and 'STORE_GLOBAL' opcodes are checked, and 'symbol' - must be present in 'code.co_names'. - """ - if symbol not in code.co_names: - # name's not there, can't possibly be an assignment - return None - - name_idx = list(code.co_names).index(symbol) - - STORE_NAME = 90 - STORE_GLOBAL = 97 - LOAD_CONST = 100 - - const = default - - for byte_code in Bytecode(code): - op = byte_code.opcode - arg = byte_code.arg - - if op == LOAD_CONST: - const = code.co_consts[arg] - elif arg == name_idx and (op == STORE_NAME or op == STORE_GLOBAL): - return const - else: - const = default - - -def _update_globals(): - """ - Patch the globals to remove the objects not available on some platforms. - - XXX it'd be better to test assertions about bytecode instead. - """ - - if not sys.platform.startswith('java') and sys.platform != 'cli': - return - incompatible = 'extract_constant', 'get_module_constant' - for name in incompatible: - del globals()[name] - __all__.remove(name) - - -_update_globals() diff --git a/venv/lib/python3.8/site-packages/setuptools/dist.py b/venv/lib/python3.8/site-packages/setuptools/dist.py deleted file mode 100644 index f22429e..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/dist.py +++ /dev/null @@ -1,1274 +0,0 @@ -# -*- coding: utf-8 -*- -__all__ = ['Distribution'] - -import io -import sys -import re -import os -import warnings -import numbers -import distutils.log -import distutils.core -import distutils.cmd -import distutils.dist -from distutils.util import strtobool -from distutils.debug import DEBUG -from distutils.fancy_getopt import translate_longopt -import itertools - -from collections import defaultdict -from email import message_from_file - -from distutils.errors import ( - DistutilsOptionError, DistutilsPlatformError, DistutilsSetupError, -) -from distutils.util import rfc822_escape -from distutils.version import StrictVersion - -from setuptools.extern import six -from setuptools.extern import packaging -from setuptools.extern import ordered_set -from setuptools.extern.six.moves import map, filter, filterfalse - -from . import SetuptoolsDeprecationWarning - -from setuptools.depends import Require -from setuptools import windows_support -from setuptools.monkey import get_unpatched -from setuptools.config import parse_configuration -import pkg_resources - -__import__('setuptools.extern.packaging.specifiers') -__import__('setuptools.extern.packaging.version') - - -def _get_unpatched(cls): - warnings.warn("Do not call this function", DistDeprecationWarning) - return get_unpatched(cls) - - -def get_metadata_version(self): - mv = getattr(self, 'metadata_version', None) - - if mv is None: - if self.long_description_content_type or self.provides_extras: - mv = StrictVersion('2.1') - elif (self.maintainer is not None or - self.maintainer_email is not None or - getattr(self, 'python_requires', None) is not None or - self.project_urls): - mv = StrictVersion('1.2') - elif (self.provides or self.requires or self.obsoletes or - self.classifiers or self.download_url): - mv = StrictVersion('1.1') - else: - mv = StrictVersion('1.0') - - self.metadata_version = mv - - return mv - - -def read_pkg_file(self, file): - """Reads the metadata values from a file object.""" - msg = message_from_file(file) - - def _read_field(name): - value = msg[name] - if value == 'UNKNOWN': - return None - return value - - def _read_list(name): - values = msg.get_all(name, None) - if values == []: - return None - return values - - self.metadata_version = StrictVersion(msg['metadata-version']) - self.name = _read_field('name') - self.version = _read_field('version') - self.description = _read_field('summary') - # we are filling author only. - self.author = _read_field('author') - self.maintainer = None - self.author_email = _read_field('author-email') - self.maintainer_email = None - self.url = _read_field('home-page') - self.license = _read_field('license') - - if 'download-url' in msg: - self.download_url = _read_field('download-url') - else: - self.download_url = None - - self.long_description = _read_field('description') - self.description = _read_field('summary') - - if 'keywords' in msg: - self.keywords = _read_field('keywords').split(',') - - self.platforms = _read_list('platform') - self.classifiers = _read_list('classifier') - - # PEP 314 - these fields only exist in 1.1 - if self.metadata_version == StrictVersion('1.1'): - self.requires = _read_list('requires') - self.provides = _read_list('provides') - self.obsoletes = _read_list('obsoletes') - else: - self.requires = None - self.provides = None - self.obsoletes = None - - -# Based on Python 3.5 version -def write_pkg_file(self, file): - """Write the PKG-INFO format data to a file object. - """ - version = self.get_metadata_version() - - if six.PY2: - def write_field(key, value): - file.write("%s: %s\n" % (key, self._encode_field(value))) - else: - def write_field(key, value): - file.write("%s: %s\n" % (key, value)) - - write_field('Metadata-Version', str(version)) - write_field('Name', self.get_name()) - write_field('Version', self.get_version()) - write_field('Summary', self.get_description()) - write_field('Home-page', self.get_url()) - - if version < StrictVersion('1.2'): - write_field('Author', self.get_contact()) - write_field('Author-email', self.get_contact_email()) - else: - optional_fields = ( - ('Author', 'author'), - ('Author-email', 'author_email'), - ('Maintainer', 'maintainer'), - ('Maintainer-email', 'maintainer_email'), - ) - - for field, attr in optional_fields: - attr_val = getattr(self, attr) - - if attr_val is not None: - write_field(field, attr_val) - - write_field('License', self.get_license()) - if self.download_url: - write_field('Download-URL', self.download_url) - for project_url in self.project_urls.items(): - write_field('Project-URL', '%s, %s' % project_url) - - long_desc = rfc822_escape(self.get_long_description()) - write_field('Description', long_desc) - - keywords = ','.join(self.get_keywords()) - if keywords: - write_field('Keywords', keywords) - - if version >= StrictVersion('1.2'): - for platform in self.get_platforms(): - write_field('Platform', platform) - else: - self._write_list(file, 'Platform', self.get_platforms()) - - self._write_list(file, 'Classifier', self.get_classifiers()) - - # PEP 314 - self._write_list(file, 'Requires', self.get_requires()) - self._write_list(file, 'Provides', self.get_provides()) - self._write_list(file, 'Obsoletes', self.get_obsoletes()) - - # Setuptools specific for PEP 345 - if hasattr(self, 'python_requires'): - write_field('Requires-Python', self.python_requires) - - # PEP 566 - if self.long_description_content_type: - write_field( - 'Description-Content-Type', - self.long_description_content_type - ) - if self.provides_extras: - for extra in sorted(self.provides_extras): - write_field('Provides-Extra', extra) - - -sequence = tuple, list - - -def check_importable(dist, attr, value): - try: - ep = pkg_resources.EntryPoint.parse('x=' + value) - assert not ep.extras - except (TypeError, ValueError, AttributeError, AssertionError): - raise DistutilsSetupError( - "%r must be importable 'module:attrs' string (got %r)" - % (attr, value) - ) - - -def assert_string_list(dist, attr, value): - """Verify that value is a string list""" - try: - # verify that value is a list or tuple to exclude unordered - # or single-use iterables - assert isinstance(value, (list, tuple)) - # verify that elements of value are strings - assert ''.join(value) != value - except (TypeError, ValueError, AttributeError, AssertionError): - raise DistutilsSetupError( - "%r must be a list of strings (got %r)" % (attr, value) - ) - - -def check_nsp(dist, attr, value): - """Verify that namespace packages are valid""" - ns_packages = value - assert_string_list(dist, attr, ns_packages) - for nsp in ns_packages: - if not dist.has_contents_for(nsp): - raise DistutilsSetupError( - "Distribution contains no modules or packages for " + - "namespace package %r" % nsp - ) - parent, sep, child = nsp.rpartition('.') - if parent and parent not in ns_packages: - distutils.log.warn( - "WARNING: %r is declared as a package namespace, but %r" - " is not: please correct this in setup.py", nsp, parent - ) - - -def check_extras(dist, attr, value): - """Verify that extras_require mapping is valid""" - try: - list(itertools.starmap(_check_extra, value.items())) - except (TypeError, ValueError, AttributeError): - raise DistutilsSetupError( - "'extras_require' must be a dictionary whose values are " - "strings or lists of strings containing valid project/version " - "requirement specifiers." - ) - - -def _check_extra(extra, reqs): - name, sep, marker = extra.partition(':') - if marker and pkg_resources.invalid_marker(marker): - raise DistutilsSetupError("Invalid environment marker: " + marker) - list(pkg_resources.parse_requirements(reqs)) - - -def assert_bool(dist, attr, value): - """Verify that value is True, False, 0, or 1""" - if bool(value) != value: - tmpl = "{attr!r} must be a boolean value (got {value!r})" - raise DistutilsSetupError(tmpl.format(attr=attr, value=value)) - - -def check_requirements(dist, attr, value): - """Verify that install_requires is a valid requirements list""" - try: - list(pkg_resources.parse_requirements(value)) - if isinstance(value, (dict, set)): - raise TypeError("Unordered types are not allowed") - except (TypeError, ValueError) as error: - tmpl = ( - "{attr!r} must be a string or list of strings " - "containing valid project/version requirement specifiers; {error}" - ) - raise DistutilsSetupError(tmpl.format(attr=attr, error=error)) - - -def check_specifier(dist, attr, value): - """Verify that value is a valid version specifier""" - try: - packaging.specifiers.SpecifierSet(value) - except packaging.specifiers.InvalidSpecifier as error: - tmpl = ( - "{attr!r} must be a string " - "containing valid version specifiers; {error}" - ) - raise DistutilsSetupError(tmpl.format(attr=attr, error=error)) - - -def check_entry_points(dist, attr, value): - """Verify that entry_points map is parseable""" - try: - pkg_resources.EntryPoint.parse_map(value) - except ValueError as e: - raise DistutilsSetupError(e) - - -def check_test_suite(dist, attr, value): - if not isinstance(value, six.string_types): - raise DistutilsSetupError("test_suite must be a string") - - -def check_package_data(dist, attr, value): - """Verify that value is a dictionary of package names to glob lists""" - if not isinstance(value, dict): - raise DistutilsSetupError( - "{!r} must be a dictionary mapping package names to lists of " - "string wildcard patterns".format(attr)) - for k, v in value.items(): - if not isinstance(k, six.string_types): - raise DistutilsSetupError( - "keys of {!r} dict must be strings (got {!r})" - .format(attr, k) - ) - assert_string_list(dist, 'values of {!r} dict'.format(attr), v) - - -def check_packages(dist, attr, value): - for pkgname in value: - if not re.match(r'\w+(\.\w+)*', pkgname): - distutils.log.warn( - "WARNING: %r not a valid package name; please use only " - ".-separated package names in setup.py", pkgname - ) - - -_Distribution = get_unpatched(distutils.core.Distribution) - - -class Distribution(_Distribution): - """Distribution with support for features, tests, and package data - - This is an enhanced version of 'distutils.dist.Distribution' that - effectively adds the following new optional keyword arguments to 'setup()': - - 'install_requires' -- a string or sequence of strings specifying project - versions that the distribution requires when installed, in the format - used by 'pkg_resources.require()'. They will be installed - automatically when the package is installed. If you wish to use - packages that are not available in PyPI, or want to give your users an - alternate download location, you can add a 'find_links' option to the - '[easy_install]' section of your project's 'setup.cfg' file, and then - setuptools will scan the listed web pages for links that satisfy the - requirements. - - 'extras_require' -- a dictionary mapping names of optional "extras" to the - additional requirement(s) that using those extras incurs. For example, - this:: - - extras_require = dict(reST = ["docutils>=0.3", "reSTedit"]) - - indicates that the distribution can optionally provide an extra - capability called "reST", but it can only be used if docutils and - reSTedit are installed. If the user installs your package using - EasyInstall and requests one of your extras, the corresponding - additional requirements will be installed if needed. - - 'features' **deprecated** -- a dictionary mapping option names to - 'setuptools.Feature' - objects. Features are a portion of the distribution that can be - included or excluded based on user options, inter-feature dependencies, - and availability on the current system. Excluded features are omitted - from all setup commands, including source and binary distributions, so - you can create multiple distributions from the same source tree. - Feature names should be valid Python identifiers, except that they may - contain the '-' (minus) sign. Features can be included or excluded - via the command line options '--with-X' and '--without-X', where 'X' is - the name of the feature. Whether a feature is included by default, and - whether you are allowed to control this from the command line, is - determined by the Feature object. See the 'Feature' class for more - information. - - 'test_suite' -- the name of a test suite to run for the 'test' command. - If the user runs 'python setup.py test', the package will be installed, - and the named test suite will be run. The format is the same as - would be used on a 'unittest.py' command line. That is, it is the - dotted name of an object to import and call to generate a test suite. - - 'package_data' -- a dictionary mapping package names to lists of filenames - or globs to use to find data files contained in the named packages. - If the dictionary has filenames or globs listed under '""' (the empty - string), those names will be searched for in every package, in addition - to any names for the specific package. Data files found using these - names/globs will be installed along with the package, in the same - location as the package. Note that globs are allowed to reference - the contents of non-package subdirectories, as long as you use '/' as - a path separator. (Globs are automatically converted to - platform-specific paths at runtime.) - - In addition to these new keywords, this class also has several new methods - for manipulating the distribution's contents. For example, the 'include()' - and 'exclude()' methods can be thought of as in-place add and subtract - commands that add or remove packages, modules, extensions, and so on from - the distribution. They are used by the feature subsystem to configure the - distribution for the included and excluded features. - """ - - _DISTUTILS_UNSUPPORTED_METADATA = { - 'long_description_content_type': None, - 'project_urls': dict, - 'provides_extras': ordered_set.OrderedSet, - 'license_files': ordered_set.OrderedSet, - } - - _patched_dist = None - - def patch_missing_pkg_info(self, attrs): - # Fake up a replacement for the data that would normally come from - # PKG-INFO, but which might not yet be built if this is a fresh - # checkout. - # - if not attrs or 'name' not in attrs or 'version' not in attrs: - return - key = pkg_resources.safe_name(str(attrs['name'])).lower() - dist = pkg_resources.working_set.by_key.get(key) - if dist is not None and not dist.has_metadata('PKG-INFO'): - dist._version = pkg_resources.safe_version(str(attrs['version'])) - self._patched_dist = dist - - def __init__(self, attrs=None): - have_package_data = hasattr(self, "package_data") - if not have_package_data: - self.package_data = {} - attrs = attrs or {} - if 'features' in attrs or 'require_features' in attrs: - Feature.warn_deprecated() - self.require_features = [] - self.features = {} - self.dist_files = [] - # Filter-out setuptools' specific options. - self.src_root = attrs.pop("src_root", None) - self.patch_missing_pkg_info(attrs) - self.dependency_links = attrs.pop('dependency_links', []) - self.setup_requires = attrs.pop('setup_requires', []) - for ep in pkg_resources.iter_entry_points('distutils.setup_keywords'): - vars(self).setdefault(ep.name, None) - _Distribution.__init__(self, { - k: v for k, v in attrs.items() - if k not in self._DISTUTILS_UNSUPPORTED_METADATA - }) - - # Fill-in missing metadata fields not supported by distutils. - # Note some fields may have been set by other tools (e.g. pbr) - # above; they are taken preferrentially to setup() arguments - for option, default in self._DISTUTILS_UNSUPPORTED_METADATA.items(): - for source in self.metadata.__dict__, attrs: - if option in source: - value = source[option] - break - else: - value = default() if default else None - setattr(self.metadata, option, value) - - if isinstance(self.metadata.version, numbers.Number): - # Some people apparently take "version number" too literally :) - self.metadata.version = str(self.metadata.version) - - if self.metadata.version is not None: - try: - ver = packaging.version.Version(self.metadata.version) - normalized_version = str(ver) - if self.metadata.version != normalized_version: - warnings.warn( - "Normalizing '%s' to '%s'" % ( - self.metadata.version, - normalized_version, - ) - ) - self.metadata.version = normalized_version - except (packaging.version.InvalidVersion, TypeError): - warnings.warn( - "The version specified (%r) is an invalid version, this " - "may not work as expected with newer versions of " - "setuptools, pip, and PyPI. Please see PEP 440 for more " - "details." % self.metadata.version - ) - self._finalize_requires() - - def _finalize_requires(self): - """ - Set `metadata.python_requires` and fix environment markers - in `install_requires` and `extras_require`. - """ - if getattr(self, 'python_requires', None): - self.metadata.python_requires = self.python_requires - - if getattr(self, 'extras_require', None): - for extra in self.extras_require.keys(): - # Since this gets called multiple times at points where the - # keys have become 'converted' extras, ensure that we are only - # truly adding extras we haven't seen before here. - extra = extra.split(':')[0] - if extra: - self.metadata.provides_extras.add(extra) - - self._convert_extras_requirements() - self._move_install_requirements_markers() - - def _convert_extras_requirements(self): - """ - Convert requirements in `extras_require` of the form - `"extra": ["barbazquux; {marker}"]` to - `"extra:{marker}": ["barbazquux"]`. - """ - spec_ext_reqs = getattr(self, 'extras_require', None) or {} - self._tmp_extras_require = defaultdict(list) - for section, v in spec_ext_reqs.items(): - # Do not strip empty sections. - self._tmp_extras_require[section] - for r in pkg_resources.parse_requirements(v): - suffix = self._suffix_for(r) - self._tmp_extras_require[section + suffix].append(r) - - @staticmethod - def _suffix_for(req): - """ - For a requirement, return the 'extras_require' suffix for - that requirement. - """ - return ':' + str(req.marker) if req.marker else '' - - def _move_install_requirements_markers(self): - """ - Move requirements in `install_requires` that are using environment - markers `extras_require`. - """ - - # divide the install_requires into two sets, simple ones still - # handled by install_requires and more complex ones handled - # by extras_require. - - def is_simple_req(req): - return not req.marker - - spec_inst_reqs = getattr(self, 'install_requires', None) or () - inst_reqs = list(pkg_resources.parse_requirements(spec_inst_reqs)) - simple_reqs = filter(is_simple_req, inst_reqs) - complex_reqs = filterfalse(is_simple_req, inst_reqs) - self.install_requires = list(map(str, simple_reqs)) - - for r in complex_reqs: - self._tmp_extras_require[':' + str(r.marker)].append(r) - self.extras_require = dict( - (k, [str(r) for r in map(self._clean_req, v)]) - for k, v in self._tmp_extras_require.items() - ) - - def _clean_req(self, req): - """ - Given a Requirement, remove environment markers and return it. - """ - req.marker = None - return req - - def _parse_config_files(self, filenames=None): - """ - Adapted from distutils.dist.Distribution.parse_config_files, - this method provides the same functionality in subtly-improved - ways. - """ - from setuptools.extern.six.moves.configparser import ConfigParser - - # Ignore install directory options if we have a venv - if six.PY3 and sys.prefix != sys.base_prefix: - ignore_options = [ - 'install-base', 'install-platbase', 'install-lib', - 'install-platlib', 'install-purelib', 'install-headers', - 'install-scripts', 'install-data', 'prefix', 'exec-prefix', - 'home', 'user', 'root'] - else: - ignore_options = [] - - ignore_options = frozenset(ignore_options) - - if filenames is None: - filenames = self.find_config_files() - - if DEBUG: - self.announce("Distribution.parse_config_files():") - - parser = ConfigParser() - for filename in filenames: - with io.open(filename, encoding='utf-8') as reader: - if DEBUG: - self.announce(" reading {filename}".format(**locals())) - (parser.read_file if six.PY3 else parser.readfp)(reader) - for section in parser.sections(): - options = parser.options(section) - opt_dict = self.get_option_dict(section) - - for opt in options: - if opt != '__name__' and opt not in ignore_options: - val = self._try_str(parser.get(section, opt)) - opt = opt.replace('-', '_') - opt_dict[opt] = (filename, val) - - # Make the ConfigParser forget everything (so we retain - # the original filenames that options come from) - parser.__init__() - - # If there was a "global" section in the config file, use it - # to set Distribution options. - - if 'global' in self.command_options: - for (opt, (src, val)) in self.command_options['global'].items(): - alias = self.negative_opt.get(opt) - try: - if alias: - setattr(self, alias, not strtobool(val)) - elif opt in ('verbose', 'dry_run'): # ugh! - setattr(self, opt, strtobool(val)) - else: - setattr(self, opt, val) - except ValueError as msg: - raise DistutilsOptionError(msg) - - @staticmethod - def _try_str(val): - """ - On Python 2, much of distutils relies on string values being of - type 'str' (bytes) and not unicode text. If the value can be safely - encoded to bytes using the default encoding, prefer that. - - Why the default encoding? Because that value can be implicitly - decoded back to text if needed. - - Ref #1653 - """ - if six.PY3: - return val - try: - return val.encode() - except UnicodeEncodeError: - pass - return val - - def _set_command_options(self, command_obj, option_dict=None): - """ - Set the options for 'command_obj' from 'option_dict'. Basically - this means copying elements of a dictionary ('option_dict') to - attributes of an instance ('command'). - - 'command_obj' must be a Command instance. If 'option_dict' is not - supplied, uses the standard option dictionary for this command - (from 'self.command_options'). - - (Adopted from distutils.dist.Distribution._set_command_options) - """ - command_name = command_obj.get_command_name() - if option_dict is None: - option_dict = self.get_option_dict(command_name) - - if DEBUG: - self.announce(" setting options for '%s' command:" % command_name) - for (option, (source, value)) in option_dict.items(): - if DEBUG: - self.announce(" %s = %s (from %s)" % (option, value, - source)) - try: - bool_opts = [translate_longopt(o) - for o in command_obj.boolean_options] - except AttributeError: - bool_opts = [] - try: - neg_opt = command_obj.negative_opt - except AttributeError: - neg_opt = {} - - try: - is_string = isinstance(value, six.string_types) - if option in neg_opt and is_string: - setattr(command_obj, neg_opt[option], not strtobool(value)) - elif option in bool_opts and is_string: - setattr(command_obj, option, strtobool(value)) - elif hasattr(command_obj, option): - setattr(command_obj, option, value) - else: - raise DistutilsOptionError( - "error in %s: command '%s' has no such option '%s'" - % (source, command_name, option)) - except ValueError as msg: - raise DistutilsOptionError(msg) - - def parse_config_files(self, filenames=None, ignore_option_errors=False): - """Parses configuration files from various levels - and loads configuration. - - """ - self._parse_config_files(filenames=filenames) - - parse_configuration(self, self.command_options, - ignore_option_errors=ignore_option_errors) - self._finalize_requires() - - def parse_command_line(self): - """Process features after parsing command line options""" - result = _Distribution.parse_command_line(self) - if self.features: - self._finalize_features() - return result - - def _feature_attrname(self, name): - """Convert feature name to corresponding option attribute name""" - return 'with_' + name.replace('-', '_') - - def fetch_build_eggs(self, requires): - """Resolve pre-setup requirements""" - resolved_dists = pkg_resources.working_set.resolve( - pkg_resources.parse_requirements(requires), - installer=self.fetch_build_egg, - replace_conflicting=True, - ) - for dist in resolved_dists: - pkg_resources.working_set.add(dist, replace=True) - return resolved_dists - - def finalize_options(self): - """ - Allow plugins to apply arbitrary operations to the - distribution. Each hook may optionally define a 'order' - to influence the order of execution. Smaller numbers - go first and the default is 0. - """ - hook_key = 'setuptools.finalize_distribution_options' - - def by_order(hook): - return getattr(hook, 'order', 0) - eps = pkg_resources.iter_entry_points(hook_key) - for ep in sorted(eps, key=by_order): - ep.load()(self) - - def _finalize_setup_keywords(self): - for ep in pkg_resources.iter_entry_points('distutils.setup_keywords'): - value = getattr(self, ep.name, None) - if value is not None: - ep.require(installer=self.fetch_build_egg) - ep.load()(self, ep.name, value) - - def _finalize_2to3_doctests(self): - if getattr(self, 'convert_2to3_doctests', None): - # XXX may convert to set here when we can rely on set being builtin - self.convert_2to3_doctests = [ - os.path.abspath(p) - for p in self.convert_2to3_doctests - ] - else: - self.convert_2to3_doctests = [] - - def get_egg_cache_dir(self): - egg_cache_dir = os.path.join(os.curdir, '.eggs') - if not os.path.exists(egg_cache_dir): - os.mkdir(egg_cache_dir) - windows_support.hide_file(egg_cache_dir) - readme_txt_filename = os.path.join(egg_cache_dir, 'README.txt') - with open(readme_txt_filename, 'w') as f: - f.write('This directory contains eggs that were downloaded ' - 'by setuptools to build, test, and run plug-ins.\n\n') - f.write('This directory caches those eggs to prevent ' - 'repeated downloads.\n\n') - f.write('However, it is safe to delete this directory.\n\n') - - return egg_cache_dir - - def fetch_build_egg(self, req): - """Fetch an egg needed for building""" - from setuptools.installer import fetch_build_egg - return fetch_build_egg(self, req) - - def _finalize_feature_opts(self): - """Add --with-X/--without-X options based on optional features""" - - if not self.features: - return - - go = [] - no = self.negative_opt.copy() - - for name, feature in self.features.items(): - self._set_feature(name, None) - feature.validate(self) - - if feature.optional: - descr = feature.description - incdef = ' (default)' - excdef = '' - if not feature.include_by_default(): - excdef, incdef = incdef, excdef - - new = ( - ('with-' + name, None, 'include ' + descr + incdef), - ('without-' + name, None, 'exclude ' + descr + excdef), - ) - go.extend(new) - no['without-' + name] = 'with-' + name - - self.global_options = self.feature_options = go + self.global_options - self.negative_opt = self.feature_negopt = no - - def _finalize_features(self): - """Add/remove features and resolve dependencies between them""" - - # First, flag all the enabled items (and thus their dependencies) - for name, feature in self.features.items(): - enabled = self.feature_is_included(name) - if enabled or (enabled is None and feature.include_by_default()): - feature.include_in(self) - self._set_feature(name, 1) - - # Then disable the rest, so that off-by-default features don't - # get flagged as errors when they're required by an enabled feature - for name, feature in self.features.items(): - if not self.feature_is_included(name): - feature.exclude_from(self) - self._set_feature(name, 0) - - def get_command_class(self, command): - """Pluggable version of get_command_class()""" - if command in self.cmdclass: - return self.cmdclass[command] - - eps = pkg_resources.iter_entry_points('distutils.commands', command) - for ep in eps: - ep.require(installer=self.fetch_build_egg) - self.cmdclass[command] = cmdclass = ep.load() - return cmdclass - else: - return _Distribution.get_command_class(self, command) - - def print_commands(self): - for ep in pkg_resources.iter_entry_points('distutils.commands'): - if ep.name not in self.cmdclass: - # don't require extras as the commands won't be invoked - cmdclass = ep.resolve() - self.cmdclass[ep.name] = cmdclass - return _Distribution.print_commands(self) - - def get_command_list(self): - for ep in pkg_resources.iter_entry_points('distutils.commands'): - if ep.name not in self.cmdclass: - # don't require extras as the commands won't be invoked - cmdclass = ep.resolve() - self.cmdclass[ep.name] = cmdclass - return _Distribution.get_command_list(self) - - def _set_feature(self, name, status): - """Set feature's inclusion status""" - setattr(self, self._feature_attrname(name), status) - - def feature_is_included(self, name): - """Return 1 if feature is included, 0 if excluded, 'None' if unknown""" - return getattr(self, self._feature_attrname(name)) - - def include_feature(self, name): - """Request inclusion of feature named 'name'""" - - if self.feature_is_included(name) == 0: - descr = self.features[name].description - raise DistutilsOptionError( - descr + " is required, but was excluded or is not available" - ) - self.features[name].include_in(self) - self._set_feature(name, 1) - - def include(self, **attrs): - """Add items to distribution that are named in keyword arguments - - For example, 'dist.include(py_modules=["x"])' would add 'x' to - the distribution's 'py_modules' attribute, if it was not already - there. - - Currently, this method only supports inclusion for attributes that are - lists or tuples. If you need to add support for adding to other - attributes in this or a subclass, you can add an '_include_X' method, - where 'X' is the name of the attribute. The method will be called with - the value passed to 'include()'. So, 'dist.include(foo={"bar":"baz"})' - will try to call 'dist._include_foo({"bar":"baz"})', which can then - handle whatever special inclusion logic is needed. - """ - for k, v in attrs.items(): - include = getattr(self, '_include_' + k, None) - if include: - include(v) - else: - self._include_misc(k, v) - - def exclude_package(self, package): - """Remove packages, modules, and extensions in named package""" - - pfx = package + '.' - if self.packages: - self.packages = [ - p for p in self.packages - if p != package and not p.startswith(pfx) - ] - - if self.py_modules: - self.py_modules = [ - p for p in self.py_modules - if p != package and not p.startswith(pfx) - ] - - if self.ext_modules: - self.ext_modules = [ - p for p in self.ext_modules - if p.name != package and not p.name.startswith(pfx) - ] - - def has_contents_for(self, package): - """Return true if 'exclude_package(package)' would do something""" - - pfx = package + '.' - - for p in self.iter_distribution_names(): - if p == package or p.startswith(pfx): - return True - - def _exclude_misc(self, name, value): - """Handle 'exclude()' for list/tuple attrs without a special handler""" - if not isinstance(value, sequence): - raise DistutilsSetupError( - "%s: setting must be a list or tuple (%r)" % (name, value) - ) - try: - old = getattr(self, name) - except AttributeError: - raise DistutilsSetupError( - "%s: No such distribution setting" % name - ) - if old is not None and not isinstance(old, sequence): - raise DistutilsSetupError( - name + ": this setting cannot be changed via include/exclude" - ) - elif old: - setattr(self, name, [item for item in old if item not in value]) - - def _include_misc(self, name, value): - """Handle 'include()' for list/tuple attrs without a special handler""" - - if not isinstance(value, sequence): - raise DistutilsSetupError( - "%s: setting must be a list (%r)" % (name, value) - ) - try: - old = getattr(self, name) - except AttributeError: - raise DistutilsSetupError( - "%s: No such distribution setting" % name - ) - if old is None: - setattr(self, name, value) - elif not isinstance(old, sequence): - raise DistutilsSetupError( - name + ": this setting cannot be changed via include/exclude" - ) - else: - new = [item for item in value if item not in old] - setattr(self, name, old + new) - - def exclude(self, **attrs): - """Remove items from distribution that are named in keyword arguments - - For example, 'dist.exclude(py_modules=["x"])' would remove 'x' from - the distribution's 'py_modules' attribute. Excluding packages uses - the 'exclude_package()' method, so all of the package's contained - packages, modules, and extensions are also excluded. - - Currently, this method only supports exclusion from attributes that are - lists or tuples. If you need to add support for excluding from other - attributes in this or a subclass, you can add an '_exclude_X' method, - where 'X' is the name of the attribute. The method will be called with - the value passed to 'exclude()'. So, 'dist.exclude(foo={"bar":"baz"})' - will try to call 'dist._exclude_foo({"bar":"baz"})', which can then - handle whatever special exclusion logic is needed. - """ - for k, v in attrs.items(): - exclude = getattr(self, '_exclude_' + k, None) - if exclude: - exclude(v) - else: - self._exclude_misc(k, v) - - def _exclude_packages(self, packages): - if not isinstance(packages, sequence): - raise DistutilsSetupError( - "packages: setting must be a list or tuple (%r)" % (packages,) - ) - list(map(self.exclude_package, packages)) - - def _parse_command_opts(self, parser, args): - # Remove --with-X/--without-X options when processing command args - self.global_options = self.__class__.global_options - self.negative_opt = self.__class__.negative_opt - - # First, expand any aliases - command = args[0] - aliases = self.get_option_dict('aliases') - while command in aliases: - src, alias = aliases[command] - del aliases[command] # ensure each alias can expand only once! - import shlex - args[:1] = shlex.split(alias, True) - command = args[0] - - nargs = _Distribution._parse_command_opts(self, parser, args) - - # Handle commands that want to consume all remaining arguments - cmd_class = self.get_command_class(command) - if getattr(cmd_class, 'command_consumes_arguments', None): - self.get_option_dict(command)['args'] = ("command line", nargs) - if nargs is not None: - return [] - - return nargs - - def get_cmdline_options(self): - """Return a '{cmd: {opt:val}}' map of all command-line options - - Option names are all long, but do not include the leading '--', and - contain dashes rather than underscores. If the option doesn't take - an argument (e.g. '--quiet'), the 'val' is 'None'. - - Note that options provided by config files are intentionally excluded. - """ - - d = {} - - for cmd, opts in self.command_options.items(): - - for opt, (src, val) in opts.items(): - - if src != "command line": - continue - - opt = opt.replace('_', '-') - - if val == 0: - cmdobj = self.get_command_obj(cmd) - neg_opt = self.negative_opt.copy() - neg_opt.update(getattr(cmdobj, 'negative_opt', {})) - for neg, pos in neg_opt.items(): - if pos == opt: - opt = neg - val = None - break - else: - raise AssertionError("Shouldn't be able to get here") - - elif val == 1: - val = None - - d.setdefault(cmd, {})[opt] = val - - return d - - def iter_distribution_names(self): - """Yield all packages, modules, and extension names in distribution""" - - for pkg in self.packages or (): - yield pkg - - for module in self.py_modules or (): - yield module - - for ext in self.ext_modules or (): - if isinstance(ext, tuple): - name, buildinfo = ext - else: - name = ext.name - if name.endswith('module'): - name = name[:-6] - yield name - - def handle_display_options(self, option_order): - """If there were any non-global "display-only" options - (--help-commands or the metadata display options) on the command - line, display the requested info and return true; else return - false. - """ - import sys - - if six.PY2 or self.help_commands: - return _Distribution.handle_display_options(self, option_order) - - # Stdout may be StringIO (e.g. in tests) - if not isinstance(sys.stdout, io.TextIOWrapper): - return _Distribution.handle_display_options(self, option_order) - - # Don't wrap stdout if utf-8 is already the encoding. Provides - # workaround for #334. - if sys.stdout.encoding.lower() in ('utf-8', 'utf8'): - return _Distribution.handle_display_options(self, option_order) - - # Print metadata in UTF-8 no matter the platform - encoding = sys.stdout.encoding - errors = sys.stdout.errors - newline = sys.platform != 'win32' and '\n' or None - line_buffering = sys.stdout.line_buffering - - sys.stdout = io.TextIOWrapper( - sys.stdout.detach(), 'utf-8', errors, newline, line_buffering) - try: - return _Distribution.handle_display_options(self, option_order) - finally: - sys.stdout = io.TextIOWrapper( - sys.stdout.detach(), encoding, errors, newline, line_buffering) - - -class Feature: - """ - **deprecated** -- The `Feature` facility was never completely implemented - or supported, `has reported issues - `_ and will be removed in - a future version. - - A subset of the distribution that can be excluded if unneeded/wanted - - Features are created using these keyword arguments: - - 'description' -- a short, human readable description of the feature, to - be used in error messages, and option help messages. - - 'standard' -- if true, the feature is included by default if it is - available on the current system. Otherwise, the feature is only - included if requested via a command line '--with-X' option, or if - another included feature requires it. The default setting is 'False'. - - 'available' -- if true, the feature is available for installation on the - current system. The default setting is 'True'. - - 'optional' -- if true, the feature's inclusion can be controlled from the - command line, using the '--with-X' or '--without-X' options. If - false, the feature's inclusion status is determined automatically, - based on 'availabile', 'standard', and whether any other feature - requires it. The default setting is 'True'. - - 'require_features' -- a string or sequence of strings naming features - that should also be included if this feature is included. Defaults to - empty list. May also contain 'Require' objects that should be - added/removed from the distribution. - - 'remove' -- a string or list of strings naming packages to be removed - from the distribution if this feature is *not* included. If the - feature *is* included, this argument is ignored. This argument exists - to support removing features that "crosscut" a distribution, such as - defining a 'tests' feature that removes all the 'tests' subpackages - provided by other features. The default for this argument is an empty - list. (Note: the named package(s) or modules must exist in the base - distribution when the 'setup()' function is initially called.) - - other keywords -- any other keyword arguments are saved, and passed to - the distribution's 'include()' and 'exclude()' methods when the - feature is included or excluded, respectively. So, for example, you - could pass 'packages=["a","b"]' to cause packages 'a' and 'b' to be - added or removed from the distribution as appropriate. - - A feature must include at least one 'requires', 'remove', or other - keyword argument. Otherwise, it can't affect the distribution in any way. - Note also that you can subclass 'Feature' to create your own specialized - feature types that modify the distribution in other ways when included or - excluded. See the docstrings for the various methods here for more detail. - Aside from the methods, the only feature attributes that distributions look - at are 'description' and 'optional'. - """ - - @staticmethod - def warn_deprecated(): - msg = ( - "Features are deprecated and will be removed in a future " - "version. See https://github.com/pypa/setuptools/issues/65." - ) - warnings.warn(msg, DistDeprecationWarning, stacklevel=3) - - def __init__( - self, description, standard=False, available=True, - optional=True, require_features=(), remove=(), **extras): - self.warn_deprecated() - - self.description = description - self.standard = standard - self.available = available - self.optional = optional - if isinstance(require_features, (str, Require)): - require_features = require_features, - - self.require_features = [ - r for r in require_features if isinstance(r, str) - ] - er = [r for r in require_features if not isinstance(r, str)] - if er: - extras['require_features'] = er - - if isinstance(remove, str): - remove = remove, - self.remove = remove - self.extras = extras - - if not remove and not require_features and not extras: - raise DistutilsSetupError( - "Feature %s: must define 'require_features', 'remove', or " - "at least one of 'packages', 'py_modules', etc." - ) - - def include_by_default(self): - """Should this feature be included by default?""" - return self.available and self.standard - - def include_in(self, dist): - """Ensure feature and its requirements are included in distribution - - You may override this in a subclass to perform additional operations on - the distribution. Note that this method may be called more than once - per feature, and so should be idempotent. - - """ - - if not self.available: - raise DistutilsPlatformError( - self.description + " is required, " - "but is not available on this platform" - ) - - dist.include(**self.extras) - - for f in self.require_features: - dist.include_feature(f) - - def exclude_from(self, dist): - """Ensure feature is excluded from distribution - - You may override this in a subclass to perform additional operations on - the distribution. This method will be called at most once per - feature, and only after all included features have been asked to - include themselves. - """ - - dist.exclude(**self.extras) - - if self.remove: - for item in self.remove: - dist.exclude_package(item) - - def validate(self, dist): - """Verify that feature makes sense in context of distribution - - This method is called by the distribution just before it parses its - command line. It checks to ensure that the 'remove' attribute, if any, - contains only valid package/module names that are present in the base - distribution when 'setup()' is called. You may override it in a - subclass to perform any other required validation of the feature - against a target distribution. - """ - - for item in self.remove: - if not dist.has_contents_for(item): - raise DistutilsSetupError( - "%s wants to be able to remove %s, but the distribution" - " doesn't contain any packages or modules under %s" - % (self.description, item, item) - ) - - -class DistDeprecationWarning(SetuptoolsDeprecationWarning): - """Class for warning about deprecations in dist in - setuptools. Not ignored by default, unlike DeprecationWarning.""" diff --git a/venv/lib/python3.8/site-packages/setuptools/errors.py b/venv/lib/python3.8/site-packages/setuptools/errors.py deleted file mode 100644 index 2701747..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/errors.py +++ /dev/null @@ -1,16 +0,0 @@ -"""setuptools.errors - -Provides exceptions used by setuptools modules. -""" - -from distutils.errors import DistutilsError - - -class RemovedCommandError(DistutilsError, RuntimeError): - """Error used for commands that have been removed in setuptools. - - Since ``setuptools`` is built on ``distutils``, simply removing a command - from ``setuptools`` will make the behavior fall back to ``distutils``; this - error is raised if a command exists in ``distutils`` but has been actively - removed in ``setuptools``. - """ diff --git a/venv/lib/python3.8/site-packages/setuptools/extension.py b/venv/lib/python3.8/site-packages/setuptools/extension.py deleted file mode 100644 index 2946889..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/extension.py +++ /dev/null @@ -1,57 +0,0 @@ -import re -import functools -import distutils.core -import distutils.errors -import distutils.extension - -from setuptools.extern.six.moves import map - -from .monkey import get_unpatched - - -def _have_cython(): - """ - Return True if Cython can be imported. - """ - cython_impl = 'Cython.Distutils.build_ext' - try: - # from (cython_impl) import build_ext - __import__(cython_impl, fromlist=['build_ext']).build_ext - return True - except Exception: - pass - return False - - -# for compatibility -have_pyrex = _have_cython - -_Extension = get_unpatched(distutils.core.Extension) - - -class Extension(_Extension): - """Extension that uses '.c' files in place of '.pyx' files""" - - def __init__(self, name, sources, *args, **kw): - # The *args is needed for compatibility as calls may use positional - # arguments. py_limited_api may be set only via keyword. - self.py_limited_api = kw.pop("py_limited_api", False) - _Extension.__init__(self, name, sources, *args, **kw) - - def _convert_pyx_sources_to_lang(self): - """ - Replace sources with .pyx extensions to sources with the target - language extension. This mechanism allows language authors to supply - pre-converted sources but to prefer the .pyx sources. - """ - if _have_cython(): - # the build has Cython, so allow it to compile the .pyx files - return - lang = self.language or '' - target_ext = '.cpp' if lang.lower() == 'c++' else '.c' - sub = functools.partial(re.sub, '.pyx$', target_ext) - self.sources = list(map(sub, self.sources)) - - -class Library(Extension): - """Just like a regular Extension, but built as a library instead""" diff --git a/venv/lib/python3.8/site-packages/setuptools/extern/__init__.py b/venv/lib/python3.8/site-packages/setuptools/extern/__init__.py deleted file mode 100644 index e8c616f..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/extern/__init__.py +++ /dev/null @@ -1,73 +0,0 @@ -import sys - - -class VendorImporter: - """ - A PEP 302 meta path importer for finding optionally-vendored - or otherwise naturally-installed packages from root_name. - """ - - def __init__(self, root_name, vendored_names=(), vendor_pkg=None): - self.root_name = root_name - self.vendored_names = set(vendored_names) - self.vendor_pkg = vendor_pkg or root_name.replace('extern', '_vendor') - - @property - def search_path(self): - """ - Search first the vendor package then as a natural package. - """ - yield self.vendor_pkg + '.' - yield '' - - def find_module(self, fullname, path=None): - """ - Return self when fullname starts with root_name and the - target module is one vendored through this importer. - """ - root, base, target = fullname.partition(self.root_name + '.') - if root: - return - if not any(map(target.startswith, self.vendored_names)): - return - return self - - def load_module(self, fullname): - """ - Iterate over the search path to locate and load fullname. - """ - root, base, target = fullname.partition(self.root_name + '.') - for prefix in self.search_path: - try: - extant = prefix + target - __import__(extant) - mod = sys.modules[extant] - sys.modules[fullname] = mod - # mysterious hack: - # Remove the reference to the extant package/module - # on later Python versions to cause relative imports - # in the vendor package to resolve the same modules - # as those going through this importer. - if sys.version_info >= (3, ): - del sys.modules[extant] - return mod - except ImportError: - pass - else: - raise ImportError( - "The '{target}' package is required; " - "normally this is bundled with this package so if you get " - "this warning, consult the packager of your " - "distribution.".format(**locals()) - ) - - def install(self): - """ - Install this importer into sys.meta_path if not already present. - """ - if self not in sys.meta_path: - sys.meta_path.append(self) - - -names = 'six', 'packaging', 'pyparsing', 'ordered_set', -VendorImporter(__name__, names, 'setuptools._vendor').install() diff --git a/venv/lib/python3.8/site-packages/setuptools/extern/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/setuptools/extern/__pycache__/__init__.cpython-38.pyc deleted file mode 100644 index 2fac5a78fc5ea5f5e9455a769d38085817f8cf87..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2420 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 diff --git a/venv/lib/python3.8/site-packages/setuptools/gui.exe b/venv/lib/python3.8/site-packages/setuptools/gui.exe deleted file mode 100644 index f8d3509653ba8f80ca7f3aa7f95616142ba83a94..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 65536 zcmeFae|%KMxj%k3yGc&SCTD>S1PQP}R5YmQ5=~qJi^+zl1UE)DtPsG8blp-*!#RLg z0>QIub24npZS_`f-)#|`^OhvIcH|hGc(UT^E}VYJoC(K^_@EDjE;rth;Yer@_4k$X3I);E0Tn+-Zb>&yT9Ew!oxAMfl)C z#Z+d`C?Ev=lGJ)}%Ksnx|0)G)SVf_n2-;d?f9!~MzIJJ-=wKb=iHfW2QCpC29wSNm zA=ztsPZ<@3t`2ENV!bW?>DIbrM&c*bCbqaRzr~R~Z-r)Gl=RG-p}ugUHp=<&@N<(0nQZ)pc;t^f@UfdU)Xs*a2q9hEj|W&QGS`}Q+V zaO>`-aSJ8yAtP2OBNk%M7Utt!$6gfgmQ40WtW_PKSW_r1oOg}p=vZj3XtBjwwJ#E} zLMNCsnAlP1f|%AM?kIHMo~S5v2kZEcbEs|ZrY(iCq{N>@V-R$%P-2fEhzyjmCh@Sy zXyr*PE_By~_)26%86IRFp9Ya zkBHB1hGv2=t60ZM@2flwcy2#L^lN{0=%0Q@MjzL)ErkWFb2Ro*N07ImOt!9YmgwvP zqh2yflmnST)@Q6JEa3kv=;e&Js^gRcx7ile@Me+Xh_`B=wJ3|47Z(=9j;P;M4jj9k ze|zYYnyGIobV=&smWsjxVw3XZ39!ke-gcWd&f8i_T!k-^@^CA0*s%-oQ>v?$_-7%o z(GNN8XT7J;F$I$PlNQv_oLiavAq4>E7I2dQhlE)vSn!y;BSSI+5(`L`#@q*i(+$dj ziMR82oKzstr3NgrEei6^p%m@2rUhVv>rK-H3%XZ<_rUh;c(a2dG)%uOg$_v@w_EZo zlu%GsR0^7TQkP%ahpqsf^)t)7t)|hz?tCY-06G}<$V~#?~heoED!!4L2akG@t z3k(cUbnpdgqwk%>`n0WAC7vv#rU2V~=4eiAwpse1#pRD3*UlGpF7&;UP%~^>-Uq9> zqqY#gDuX1JM-HRLrTl?xL1RW6Nzt8%&-UwXtnfuqbCmh#A4k1U7-%L3c7Zx(d zuhG+B-K2d4zoLVczO#ufnYJw*t5&k#)-NC8`0Z!%(?;tLH)1SS=)o%@p*m1Hza}bC zH<@{EP=$nZv|K=--J~^q2RFJ=UsK7|s*{A7>2riBOI3;B9VN6@g>xk)TvhhOKNMSeI?sb zNT@@qXG7GtAEH*Z*I7+?xX^=^+#cd{e*xu~c+oK%QC`k~8T1Fj`XSd4etuu)23Ly= znHbY_evF#lbUsH*M$@PjpbB6kZlDn4%Pfry7Wc9o2a;HxjOT7A9>$Ks0zkIpxF}-P z4%J+UwB{X!v+x4JvU3b1r4SD4dNJCLBe`P~a!!^eLzUU1z9JMV04G)5v%Ur4xPh4u|g#Tc-(r0PB00 z<2OM*Q-Cajywm3kTRsx?bLZ%s;?w6_FF__SF*1GDPvs6}`fAHZ`iq5gfrnJz3GS7o z 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 -1: - # For VC++ 9.0, if IA64 support is needed, redirect user - # to Windows SDK 7.0. - # Note: No download link available from Microsoft. - message += ' Get it with "Microsoft Windows SDK 7.0"' - else: - # For VC++ 9.0 redirect user to Vc++ for Python 2.7 : - # This redirection link is maintained by Microsoft. - # Contact vspython@microsoft.com if it needs updating. - message += ' Get it from http://aka.ms/vcpython27' - elif version == 10.0: - # For VC++ 10.0 Redirect user to Windows SDK 7.1 - message += ' Get it with "Microsoft Windows SDK 7.1": ' - message += msdownload % 8279 - elif version >= 14.0: - # For VC++ 14.X Redirect user to latest Visual C++ Build Tools - message += (' Get it with "Build Tools for Visual Studio": ' - r'https://visualstudio.microsoft.com/downloads/') - - exc.args = (message, ) - - -class PlatformInfo: - """ - Current and Target Architectures information. - - Parameters - ---------- - arch: str - Target architecture. - """ - current_cpu = environ.get('processor_architecture', '').lower() - - def __init__(self, arch): - self.arch = arch.lower().replace('x64', 'amd64') - - @property - def target_cpu(self): - """ - Return Target CPU architecture. - - Return - ------ - str - Target CPU - """ - return self.arch[self.arch.find('_') + 1:] - - def target_is_x86(self): - """ - Return True if target CPU is x86 32 bits.. - - Return - ------ - bool - CPU is x86 32 bits - """ - return self.target_cpu == 'x86' - - def current_is_x86(self): - """ - Return True if current CPU is x86 32 bits.. - - Return - ------ - bool - CPU is x86 32 bits - """ - return self.current_cpu == 'x86' - - def current_dir(self, hidex86=False, x64=False): - """ - Current platform specific subfolder. - - Parameters - ---------- - hidex86: bool - return '' and not '\x86' if architecture is x86. - x64: bool - return '\x64' and not '\amd64' if architecture is amd64. - - Return - ------ - str - subfolder: '\target', or '' (see hidex86 parameter) - """ - return ( - '' if (self.current_cpu == 'x86' and hidex86) else - r'\x64' if (self.current_cpu == 'amd64' and x64) else - r'\%s' % self.current_cpu - ) - - def target_dir(self, hidex86=False, x64=False): - r""" - Target platform specific subfolder. - - Parameters - ---------- - hidex86: bool - return '' and not '\x86' if architecture is x86. - x64: bool - return '\x64' and not '\amd64' if architecture is amd64. - - Return - ------ - str - subfolder: '\current', or '' (see hidex86 parameter) - """ - return ( - '' if (self.target_cpu == 'x86' and hidex86) else - r'\x64' if (self.target_cpu == 'amd64' and x64) else - r'\%s' % self.target_cpu - ) - - def cross_dir(self, forcex86=False): - r""" - Cross platform specific subfolder. - - Parameters - ---------- - forcex86: bool - Use 'x86' as current architecture even if current architecture is - not x86. - - Return - ------ - str - subfolder: '' if target architecture is current architecture, - '\current_target' if not. - """ - current = 'x86' if forcex86 else self.current_cpu - return ( - '' if self.target_cpu == current else - self.target_dir().replace('\\', '\\%s_' % current) - ) - - -class RegistryInfo: - """ - Microsoft Visual Studio related registry information. - - Parameters - ---------- - platform_info: PlatformInfo - "PlatformInfo" instance. - """ - HKEYS = (winreg.HKEY_USERS, - winreg.HKEY_CURRENT_USER, - winreg.HKEY_LOCAL_MACHINE, - winreg.HKEY_CLASSES_ROOT) - - def __init__(self, platform_info): - self.pi = platform_info - - @property - def visualstudio(self): - """ - Microsoft Visual Studio root registry key. - - Return - ------ - str - Registry key - """ - return 'VisualStudio' - - @property - def sxs(self): - """ - Microsoft Visual Studio SxS registry key. - - Return - ------ - str - Registry key - """ - return join(self.visualstudio, 'SxS') - - @property - def vc(self): - """ - Microsoft Visual C++ VC7 registry key. - - Return - ------ - str - Registry key - """ - return join(self.sxs, 'VC7') - - @property - def vs(self): - """ - Microsoft Visual Studio VS7 registry key. - - Return - ------ - str - Registry key - """ - return join(self.sxs, 'VS7') - - @property - def vc_for_python(self): - """ - Microsoft Visual C++ for Python registry key. - - Return - ------ - str - Registry key - """ - return r'DevDiv\VCForPython' - - @property - def microsoft_sdk(self): - """ - Microsoft SDK registry key. - - Return - ------ - str - Registry key - """ - return 'Microsoft SDKs' - - @property - def windows_sdk(self): - """ - Microsoft Windows/Platform SDK registry key. - - Return - ------ - str - Registry key - """ - return join(self.microsoft_sdk, 'Windows') - - @property - def netfx_sdk(self): - """ - Microsoft .NET Framework SDK registry key. - - Return - ------ - str - Registry key - """ - return join(self.microsoft_sdk, 'NETFXSDK') - - @property - def windows_kits_roots(self): - """ - Microsoft Windows Kits Roots registry key. - - Return - ------ - str - Registry key - """ - return r'Windows Kits\Installed Roots' - - def microsoft(self, key, x86=False): - """ - Return key in Microsoft software registry. - - Parameters - ---------- - key: str - Registry key path where look. - x86: str - Force x86 software registry. - - Return - ------ - str - Registry key - """ - node64 = '' if self.pi.current_is_x86() or x86 else 'Wow6432Node' - return join('Software', node64, 'Microsoft', key) - - def lookup(self, key, name): - """ - Look for values in registry in Microsoft software registry. - - Parameters - ---------- - key: str - Registry key path where look. - name: str - Value name to find. - - Return - ------ - str - value - """ - key_read = winreg.KEY_READ - openkey = winreg.OpenKey - ms = self.microsoft - for hkey in self.HKEYS: - try: - bkey = openkey(hkey, ms(key), 0, key_read) - except (OSError, IOError): - if not self.pi.current_is_x86(): - try: - bkey = openkey(hkey, ms(key, True), 0, key_read) - except (OSError, IOError): - continue - else: - continue - try: - return winreg.QueryValueEx(bkey, name)[0] - except (OSError, IOError): - pass - - -class SystemInfo: - """ - Microsoft Windows and Visual Studio related system information. - - Parameters - ---------- - registry_info: RegistryInfo - "RegistryInfo" instance. - vc_ver: float - Required Microsoft Visual C++ version. - """ - - # Variables and properties in this class use originals CamelCase variables - # names from Microsoft source files for more easy comparison. - WinDir = environ.get('WinDir', '') - ProgramFiles = environ.get('ProgramFiles', '') - ProgramFilesx86 = environ.get('ProgramFiles(x86)', ProgramFiles) - - def __init__(self, registry_info, vc_ver=None): - self.ri = registry_info - self.pi = self.ri.pi - - self.known_vs_paths = self.find_programdata_vs_vers() - - # Except for VS15+, VC version is aligned with VS version - self.vs_ver = self.vc_ver = ( - vc_ver or self._find_latest_available_vs_ver()) - - def _find_latest_available_vs_ver(self): - """ - Find the latest VC version - - Return - ------ - float - version - """ - reg_vc_vers = self.find_reg_vs_vers() - - if not (reg_vc_vers or self.known_vs_paths): - raise distutils.errors.DistutilsPlatformError( - 'No Microsoft Visual C++ version found') - - vc_vers = set(reg_vc_vers) - vc_vers.update(self.known_vs_paths) - return sorted(vc_vers)[-1] - - def find_reg_vs_vers(self): - """ - Find Microsoft Visual Studio versions available in registry. - - Return - ------ - list of float - Versions - """ - ms = self.ri.microsoft - vckeys = (self.ri.vc, self.ri.vc_for_python, self.ri.vs) - vs_vers = [] - for hkey in self.ri.HKEYS: - for key in vckeys: - try: - bkey = winreg.OpenKey(hkey, ms(key), 0, winreg.KEY_READ) - except (OSError, IOError): - continue - subkeys, values, _ = winreg.QueryInfoKey(bkey) - for i in range(values): - try: - ver = float(winreg.EnumValue(bkey, i)[0]) - if ver not in vs_vers: - vs_vers.append(ver) - except ValueError: - pass - for i in range(subkeys): - try: - ver = float(winreg.EnumKey(bkey, i)) - if ver not in vs_vers: - vs_vers.append(ver) - except ValueError: - pass - return sorted(vs_vers) - - def find_programdata_vs_vers(self): - r""" - Find Visual studio 2017+ versions from information in - "C:\ProgramData\Microsoft\VisualStudio\Packages\_Instances". - - Return - ------ - dict - float version as key, path as value. - """ - vs_versions = {} - instances_dir = \ - r'C:\ProgramData\Microsoft\VisualStudio\Packages\_Instances' - - try: - hashed_names = listdir(instances_dir) - - except (OSError, IOError): - # Directory not exists with all Visual Studio versions - return vs_versions - - for name in hashed_names: - try: - # Get VS installation path from "state.json" file - state_path = join(instances_dir, name, 'state.json') - with open(state_path, 'rt', encoding='utf-8') as state_file: - state = json.load(state_file) - vs_path = state['installationPath'] - - # Raises OSError if this VS installation does not contain VC - listdir(join(vs_path, r'VC\Tools\MSVC')) - - # Store version and path - vs_versions[self._as_float_version( - state['installationVersion'])] = vs_path - - except (OSError, IOError, KeyError): - # Skip if "state.json" file is missing or bad format - continue - - return vs_versions - - @staticmethod - def _as_float_version(version): - """ - Return a string version as a simplified float version (major.minor) - - Parameters - ---------- - version: str - Version. - - Return - ------ - float - version - """ - return float('.'.join(version.split('.')[:2])) - - @property - def VSInstallDir(self): - """ - Microsoft Visual Studio directory. - - Return - ------ - str - path - """ - # Default path - default = join(self.ProgramFilesx86, - 'Microsoft Visual Studio %0.1f' % self.vs_ver) - - # Try to get path from registry, if fail use default path - return self.ri.lookup(self.ri.vs, '%0.1f' % self.vs_ver) or default - - @property - def VCInstallDir(self): - """ - Microsoft Visual C++ directory. - - Return - ------ - str - path - """ - path = self._guess_vc() or self._guess_vc_legacy() - - if not isdir(path): - msg = 'Microsoft Visual C++ directory not found' - raise distutils.errors.DistutilsPlatformError(msg) - - return path - - def _guess_vc(self): - """ - Locate Visual C++ for VS2017+. - - Return - ------ - str - path - """ - if self.vs_ver <= 14.0: - return '' - - try: - # First search in known VS paths - vs_dir = self.known_vs_paths[self.vs_ver] - except KeyError: - # Else, search with path from registry - vs_dir = self.VSInstallDir - - guess_vc = join(vs_dir, r'VC\Tools\MSVC') - - # Subdir with VC exact version as name - try: - # Update the VC version with real one instead of VS version - vc_ver = listdir(guess_vc)[-1] - self.vc_ver = self._as_float_version(vc_ver) - return join(guess_vc, vc_ver) - except (OSError, IOError, IndexError): - return '' - - def _guess_vc_legacy(self): - """ - Locate Visual C++ for versions prior to 2017. - - Return - ------ - str - path - """ - default = join(self.ProgramFilesx86, - r'Microsoft Visual Studio %0.1f\VC' % self.vs_ver) - - # Try to get "VC++ for Python" path from registry as default path - reg_path = join(self.ri.vc_for_python, '%0.1f' % self.vs_ver) - python_vc = self.ri.lookup(reg_path, 'installdir') - default_vc = join(python_vc, 'VC') if python_vc else default - - # Try to get path from registry, if fail use default path - return self.ri.lookup(self.ri.vc, '%0.1f' % self.vs_ver) or default_vc - - @property - def WindowsSdkVersion(self): - """ - Microsoft Windows SDK versions for specified MSVC++ version. - - Return - ------ - tuple of str - versions - """ - if self.vs_ver <= 9.0: - return '7.0', '6.1', '6.0a' - elif self.vs_ver == 10.0: - return '7.1', '7.0a' - elif self.vs_ver == 11.0: - return '8.0', '8.0a' - elif self.vs_ver == 12.0: - return '8.1', '8.1a' - elif self.vs_ver >= 14.0: - return '10.0', '8.1' - - @property - def WindowsSdkLastVersion(self): - """ - Microsoft Windows SDK last version. - - Return - ------ - str - version - """ - return self._use_last_dir_name(join(self.WindowsSdkDir, 'lib')) - - @property - def WindowsSdkDir(self): - """ - Microsoft Windows SDK directory. - - Return - ------ - str - path - """ - sdkdir = '' - for ver in self.WindowsSdkVersion: - # Try to get it from registry - loc = join(self.ri.windows_sdk, 'v%s' % ver) - sdkdir = self.ri.lookup(loc, 'installationfolder') - if sdkdir: - break - if not sdkdir or not isdir(sdkdir): - # Try to get "VC++ for Python" version from registry - path = join(self.ri.vc_for_python, '%0.1f' % self.vc_ver) - install_base = self.ri.lookup(path, 'installdir') - if install_base: - sdkdir = join(install_base, 'WinSDK') - if not sdkdir or not isdir(sdkdir): - # If fail, use default new path - for ver in self.WindowsSdkVersion: - intver = ver[:ver.rfind('.')] - path = r'Microsoft SDKs\Windows Kits\%s' % intver - d = join(self.ProgramFiles, path) - if isdir(d): - sdkdir = d - if not sdkdir or not isdir(sdkdir): - # If fail, use default old path - for ver in self.WindowsSdkVersion: - path = r'Microsoft SDKs\Windows\v%s' % ver - d = join(self.ProgramFiles, path) - if isdir(d): - sdkdir = d - if not sdkdir: - # If fail, use Platform SDK - sdkdir = join(self.VCInstallDir, 'PlatformSDK') - return sdkdir - - @property - def WindowsSDKExecutablePath(self): - """ - Microsoft Windows SDK executable directory. - - Return - ------ - str - path - """ - # Find WinSDK NetFx Tools registry dir name - if self.vs_ver <= 11.0: - netfxver = 35 - arch = '' - else: - netfxver = 40 - hidex86 = True if self.vs_ver <= 12.0 else False - arch = self.pi.current_dir(x64=True, hidex86=hidex86) - fx = 'WinSDK-NetFx%dTools%s' % (netfxver, arch.replace('\\', '-')) - - # list all possibles registry paths - regpaths = [] - if self.vs_ver >= 14.0: - for ver in self.NetFxSdkVersion: - regpaths += [join(self.ri.netfx_sdk, ver, fx)] - - for ver in self.WindowsSdkVersion: - regpaths += [join(self.ri.windows_sdk, 'v%sA' % ver, fx)] - - # Return installation folder from the more recent path - for path in regpaths: - execpath = self.ri.lookup(path, 'installationfolder') - if execpath: - return execpath - - @property - def FSharpInstallDir(self): - """ - Microsoft Visual F# directory. - - Return - ------ - str - path - """ - path = join(self.ri.visualstudio, r'%0.1f\Setup\F#' % self.vs_ver) - return self.ri.lookup(path, 'productdir') or '' - - @property - def UniversalCRTSdkDir(self): - """ - Microsoft Universal CRT SDK directory. - - Return - ------ - str - path - """ - # Set Kit Roots versions for specified MSVC++ version - vers = ('10', '81') if self.vs_ver >= 14.0 else () - - # Find path of the more recent Kit - for ver in vers: - sdkdir = self.ri.lookup(self.ri.windows_kits_roots, - 'kitsroot%s' % ver) - if sdkdir: - return sdkdir or '' - - @property - def UniversalCRTSdkLastVersion(self): - """ - Microsoft Universal C Runtime SDK last version. - - Return - ------ - str - version - """ - return self._use_last_dir_name(join(self.UniversalCRTSdkDir, 'lib')) - - @property - def NetFxSdkVersion(self): - """ - Microsoft .NET Framework SDK versions. - - Return - ------ - tuple of str - versions - """ - # Set FxSdk versions for specified VS version - return (('4.7.2', '4.7.1', '4.7', - '4.6.2', '4.6.1', '4.6', - '4.5.2', '4.5.1', '4.5') - if self.vs_ver >= 14.0 else ()) - - @property - def NetFxSdkDir(self): - """ - Microsoft .NET Framework SDK directory. - - Return - ------ - str - path - """ - sdkdir = '' - for ver in self.NetFxSdkVersion: - loc = join(self.ri.netfx_sdk, ver) - sdkdir = self.ri.lookup(loc, 'kitsinstallationfolder') - if sdkdir: - break - return sdkdir - - @property - def FrameworkDir32(self): - """ - Microsoft .NET Framework 32bit directory. - - Return - ------ - str - path - """ - # Default path - guess_fw = join(self.WinDir, r'Microsoft.NET\Framework') - - # Try to get path from registry, if fail use default path - return self.ri.lookup(self.ri.vc, 'frameworkdir32') or guess_fw - - @property - def FrameworkDir64(self): - """ - Microsoft .NET Framework 64bit directory. - - Return - ------ - str - path - """ - # Default path - guess_fw = join(self.WinDir, r'Microsoft.NET\Framework64') - - # Try to get path from registry, if fail use default path - return self.ri.lookup(self.ri.vc, 'frameworkdir64') or guess_fw - - @property - def FrameworkVersion32(self): - """ - Microsoft .NET Framework 32bit versions. - - Return - ------ - tuple of str - versions - """ - return self._find_dot_net_versions(32) - - @property - def FrameworkVersion64(self): - """ - Microsoft .NET Framework 64bit versions. - - Return - ------ - tuple of str - versions - """ - return self._find_dot_net_versions(64) - - def _find_dot_net_versions(self, bits): - """ - Find Microsoft .NET Framework versions. - - Parameters - ---------- - bits: int - Platform number of bits: 32 or 64. - - Return - ------ - tuple of str - versions - """ - # Find actual .NET version in registry - reg_ver = self.ri.lookup(self.ri.vc, 'frameworkver%d' % bits) - dot_net_dir = getattr(self, 'FrameworkDir%d' % bits) - ver = reg_ver or self._use_last_dir_name(dot_net_dir, 'v') or '' - - # Set .NET versions for specified MSVC++ version - if self.vs_ver >= 12.0: - return ver, 'v4.0' - elif self.vs_ver >= 10.0: - return 'v4.0.30319' if ver.lower()[:2] != 'v4' else ver, 'v3.5' - elif self.vs_ver == 9.0: - return 'v3.5', 'v2.0.50727' - elif self.vs_ver == 8.0: - return 'v3.0', 'v2.0.50727' - - @staticmethod - def _use_last_dir_name(path, prefix=''): - """ - Return name of the last dir in path or '' if no dir found. - - Parameters - ---------- - path: str - Use dirs in this path - prefix: str - Use only dirs starting by this prefix - - Return - ------ - str - name - """ - matching_dirs = ( - dir_name - for dir_name in reversed(listdir(path)) - if isdir(join(path, dir_name)) and - dir_name.startswith(prefix) - ) - return next(matching_dirs, None) or '' - - -class EnvironmentInfo: - """ - Return environment variables for specified Microsoft Visual C++ version - and platform : Lib, Include, Path and libpath. - - This function is compatible with Microsoft Visual C++ 9.0 to 14.X. - - Script created by analysing Microsoft environment configuration files like - "vcvars[...].bat", "SetEnv.Cmd", "vcbuildtools.bat", ... - - Parameters - ---------- - arch: str - Target architecture. - vc_ver: float - Required Microsoft Visual C++ version. If not set, autodetect the last - version. - vc_min_ver: float - Minimum Microsoft Visual C++ version. - """ - - # Variables and properties in this class use originals CamelCase variables - # names from Microsoft source files for more easy comparison. - - def __init__(self, arch, vc_ver=None, vc_min_ver=0): - self.pi = PlatformInfo(arch) - self.ri = RegistryInfo(self.pi) - self.si = SystemInfo(self.ri, vc_ver) - - if self.vc_ver < vc_min_ver: - err = 'No suitable Microsoft Visual C++ version found' - raise distutils.errors.DistutilsPlatformError(err) - - @property - def vs_ver(self): - """ - Microsoft Visual Studio. - - Return - ------ - float - version - """ - return self.si.vs_ver - - @property - def vc_ver(self): - """ - Microsoft Visual C++ version. - - Return - ------ - float - version - """ - return self.si.vc_ver - - @property - def VSTools(self): - """ - Microsoft Visual Studio Tools. - - Return - ------ - list of str - paths - """ - paths = [r'Common7\IDE', r'Common7\Tools'] - - if self.vs_ver >= 14.0: - arch_subdir = self.pi.current_dir(hidex86=True, x64=True) - paths += [r'Common7\IDE\CommonExtensions\Microsoft\TestWindow'] - paths += [r'Team Tools\Performance Tools'] - paths += [r'Team Tools\Performance Tools%s' % arch_subdir] - - return [join(self.si.VSInstallDir, path) for path in paths] - - @property - def VCIncludes(self): - """ - Microsoft Visual C++ & Microsoft Foundation Class Includes. - - Return - ------ - list of str - paths - """ - return [join(self.si.VCInstallDir, 'Include'), - join(self.si.VCInstallDir, r'ATLMFC\Include')] - - @property - def VCLibraries(self): - """ - Microsoft Visual C++ & Microsoft Foundation Class Libraries. - - Return - ------ - list of str - paths - """ - if self.vs_ver >= 15.0: - arch_subdir = self.pi.target_dir(x64=True) - else: - arch_subdir = self.pi.target_dir(hidex86=True) - paths = ['Lib%s' % arch_subdir, r'ATLMFC\Lib%s' % arch_subdir] - - if self.vs_ver >= 14.0: - paths += [r'Lib\store%s' % arch_subdir] - - return [join(self.si.VCInstallDir, path) for path in paths] - - @property - def VCStoreRefs(self): - """ - Microsoft Visual C++ store references Libraries. - - Return - ------ - list of str - paths - """ - if self.vs_ver < 14.0: - return [] - return [join(self.si.VCInstallDir, r'Lib\store\references')] - - @property - def VCTools(self): - """ - Microsoft Visual C++ Tools. - - Return - ------ - list of str - paths - """ - si = self.si - tools = [join(si.VCInstallDir, 'VCPackages')] - - forcex86 = True if self.vs_ver <= 10.0 else False - arch_subdir = self.pi.cross_dir(forcex86) - if arch_subdir: - tools += [join(si.VCInstallDir, 'Bin%s' % arch_subdir)] - - if self.vs_ver == 14.0: - path = 'Bin%s' % self.pi.current_dir(hidex86=True) - tools += [join(si.VCInstallDir, path)] - - elif self.vs_ver >= 15.0: - host_dir = (r'bin\HostX86%s' if self.pi.current_is_x86() else - r'bin\HostX64%s') - tools += [join( - si.VCInstallDir, host_dir % self.pi.target_dir(x64=True))] - - if self.pi.current_cpu != self.pi.target_cpu: - tools += [join( - si.VCInstallDir, host_dir % self.pi.current_dir(x64=True))] - - else: - tools += [join(si.VCInstallDir, 'Bin')] - - return tools - - @property - def OSLibraries(self): - """ - Microsoft Windows SDK Libraries. - - Return - ------ - list of str - paths - """ - if self.vs_ver <= 10.0: - arch_subdir = self.pi.target_dir(hidex86=True, x64=True) - return [join(self.si.WindowsSdkDir, 'Lib%s' % arch_subdir)] - - else: - arch_subdir = self.pi.target_dir(x64=True) - lib = join(self.si.WindowsSdkDir, 'lib') - libver = self._sdk_subdir - return [join(lib, '%sum%s' % (libver , arch_subdir))] - - @property - def OSIncludes(self): - """ - Microsoft Windows SDK Include. - - Return - ------ - list of str - paths - """ - include = join(self.si.WindowsSdkDir, 'include') - - if self.vs_ver <= 10.0: - return [include, join(include, 'gl')] - - else: - if self.vs_ver >= 14.0: - sdkver = self._sdk_subdir - else: - sdkver = '' - return [join(include, '%sshared' % sdkver), - join(include, '%sum' % sdkver), - join(include, '%swinrt' % sdkver)] - - @property - def OSLibpath(self): - """ - Microsoft Windows SDK Libraries Paths. - - Return - ------ - list of str - paths - """ - ref = join(self.si.WindowsSdkDir, 'References') - libpath = [] - - if self.vs_ver <= 9.0: - libpath += self.OSLibraries - - if self.vs_ver >= 11.0: - libpath += [join(ref, r'CommonConfiguration\Neutral')] - - if self.vs_ver >= 14.0: - libpath += [ - ref, - join(self.si.WindowsSdkDir, 'UnionMetadata'), - join(ref, 'Windows.Foundation.UniversalApiContract', '1.0.0.0'), - join(ref, 'Windows.Foundation.FoundationContract', '1.0.0.0'), - join(ref,'Windows.Networking.Connectivity.WwanContract', - '1.0.0.0'), - join(self.si.WindowsSdkDir, 'ExtensionSDKs', 'Microsoft.VCLibs', - '%0.1f' % self.vs_ver, 'References', 'CommonConfiguration', - 'neutral'), - ] - return libpath - - @property - def SdkTools(self): - """ - Microsoft Windows SDK Tools. - - Return - ------ - list of str - paths - """ - return list(self._sdk_tools()) - - def _sdk_tools(self): - """ - Microsoft Windows SDK Tools paths generator. - - Return - ------ - generator of str - paths - """ - if self.vs_ver < 15.0: - bin_dir = 'Bin' if self.vs_ver <= 11.0 else r'Bin\x86' - yield join(self.si.WindowsSdkDir, bin_dir) - - if not self.pi.current_is_x86(): - arch_subdir = self.pi.current_dir(x64=True) - path = 'Bin%s' % arch_subdir - yield join(self.si.WindowsSdkDir, path) - - if self.vs_ver in (10.0, 11.0): - if self.pi.target_is_x86(): - arch_subdir = '' - else: - arch_subdir = self.pi.current_dir(hidex86=True, x64=True) - path = r'Bin\NETFX 4.0 Tools%s' % arch_subdir - yield join(self.si.WindowsSdkDir, path) - - elif self.vs_ver >= 15.0: - path = join(self.si.WindowsSdkDir, 'Bin') - arch_subdir = self.pi.current_dir(x64=True) - sdkver = self.si.WindowsSdkLastVersion - yield join(path, '%s%s' % (sdkver, arch_subdir)) - - if self.si.WindowsSDKExecutablePath: - yield self.si.WindowsSDKExecutablePath - - @property - def _sdk_subdir(self): - """ - Microsoft Windows SDK version subdir. - - Return - ------ - str - subdir - """ - ucrtver = self.si.WindowsSdkLastVersion - return ('%s\\' % ucrtver) if ucrtver else '' - - @property - def SdkSetup(self): - """ - Microsoft Windows SDK Setup. - - Return - ------ - list of str - paths - """ - if self.vs_ver > 9.0: - return [] - - return [join(self.si.WindowsSdkDir, 'Setup')] - - @property - def FxTools(self): - """ - Microsoft .NET Framework Tools. - - Return - ------ - list of str - paths - """ - pi = self.pi - si = self.si - - if self.vs_ver <= 10.0: - include32 = True - include64 = not pi.target_is_x86() and not pi.current_is_x86() - else: - include32 = pi.target_is_x86() or pi.current_is_x86() - include64 = pi.current_cpu == 'amd64' or pi.target_cpu == 'amd64' - - tools = [] - if include32: - tools += [join(si.FrameworkDir32, ver) - for ver in si.FrameworkVersion32] - if include64: - tools += [join(si.FrameworkDir64, ver) - for ver in si.FrameworkVersion64] - return tools - - @property - def NetFxSDKLibraries(self): - """ - Microsoft .Net Framework SDK Libraries. - - Return - ------ - list of str - paths - """ - if self.vs_ver < 14.0 or not self.si.NetFxSdkDir: - return [] - - arch_subdir = self.pi.target_dir(x64=True) - return [join(self.si.NetFxSdkDir, r'lib\um%s' % arch_subdir)] - - @property - def NetFxSDKIncludes(self): - """ - Microsoft .Net Framework SDK Includes. - - Return - ------ - list of str - paths - """ - if self.vs_ver < 14.0 or not self.si.NetFxSdkDir: - return [] - - return [join(self.si.NetFxSdkDir, r'include\um')] - - @property - def VsTDb(self): - """ - Microsoft Visual Studio Team System Database. - - Return - ------ - list of str - paths - """ - return [join(self.si.VSInstallDir, r'VSTSDB\Deploy')] - - @property - def MSBuild(self): - """ - Microsoft Build Engine. - - Return - ------ - list of str - paths - """ - if self.vs_ver < 12.0: - return [] - elif self.vs_ver < 15.0: - base_path = self.si.ProgramFilesx86 - arch_subdir = self.pi.current_dir(hidex86=True) - else: - base_path = self.si.VSInstallDir - arch_subdir = '' - - path = r'MSBuild\%0.1f\bin%s' % (self.vs_ver, arch_subdir) - build = [join(base_path, path)] - - if self.vs_ver >= 15.0: - # Add Roslyn C# & Visual Basic Compiler - build += [join(base_path, path, 'Roslyn')] - - return build - - @property - def HTMLHelpWorkshop(self): - """ - Microsoft HTML Help Workshop. - - Return - ------ - list of str - paths - """ - if self.vs_ver < 11.0: - return [] - - return [join(self.si.ProgramFilesx86, 'HTML Help Workshop')] - - @property - def UCRTLibraries(self): - """ - Microsoft Universal C Runtime SDK Libraries. - - Return - ------ - list of str - paths - """ - if self.vs_ver < 14.0: - return [] - - arch_subdir = self.pi.target_dir(x64=True) - lib = join(self.si.UniversalCRTSdkDir, 'lib') - ucrtver = self._ucrt_subdir - return [join(lib, '%sucrt%s' % (ucrtver, arch_subdir))] - - @property - def UCRTIncludes(self): - """ - Microsoft Universal C Runtime SDK Include. - - Return - ------ - list of str - paths - """ - if self.vs_ver < 14.0: - return [] - - include = join(self.si.UniversalCRTSdkDir, 'include') - return [join(include, '%sucrt' % self._ucrt_subdir)] - - @property - def _ucrt_subdir(self): - """ - Microsoft Universal C Runtime SDK version subdir. - - Return - ------ - str - subdir - """ - ucrtver = self.si.UniversalCRTSdkLastVersion - return ('%s\\' % ucrtver) if ucrtver else '' - - @property - def FSharp(self): - """ - Microsoft Visual F#. - - Return - ------ - list of str - paths - """ - if 11.0 > self.vs_ver > 12.0: - return [] - - return [self.si.FSharpInstallDir] - - @property - def VCRuntimeRedist(self): - """ - Microsoft Visual C++ runtime redistributable dll. - - Return - ------ - str - path - """ - vcruntime = 'vcruntime%d0.dll' % self.vc_ver - arch_subdir = self.pi.target_dir(x64=True).strip('\\') - - # Installation prefixes candidates - prefixes = [] - tools_path = self.si.VCInstallDir - redist_path = dirname(tools_path.replace(r'\Tools', r'\Redist')) - if isdir(redist_path): - # Redist version may not be exactly the same as tools - redist_path = join(redist_path, listdir(redist_path)[-1]) - prefixes += [redist_path, join(redist_path, 'onecore')] - - prefixes += [join(tools_path, 'redist')] # VS14 legacy path - - # CRT directory - crt_dirs = ('Microsoft.VC%d.CRT' % (self.vc_ver * 10), - # Sometime store in directory with VS version instead of VC - 'Microsoft.VC%d.CRT' % (int(self.vs_ver) * 10)) - - # vcruntime path - for prefix, crt_dir in itertools.product(prefixes, crt_dirs): - path = join(prefix, arch_subdir, crt_dir, vcruntime) - if isfile(path): - return path - - def return_env(self, exists=True): - """ - Return environment dict. - - Parameters - ---------- - exists: bool - It True, only return existing paths. - - Return - ------ - dict - environment - """ - env = dict( - include=self._build_paths('include', - [self.VCIncludes, - self.OSIncludes, - self.UCRTIncludes, - self.NetFxSDKIncludes], - exists), - lib=self._build_paths('lib', - [self.VCLibraries, - self.OSLibraries, - self.FxTools, - self.UCRTLibraries, - self.NetFxSDKLibraries], - exists), - libpath=self._build_paths('libpath', - [self.VCLibraries, - self.FxTools, - self.VCStoreRefs, - self.OSLibpath], - exists), - path=self._build_paths('path', - [self.VCTools, - self.VSTools, - self.VsTDb, - self.SdkTools, - self.SdkSetup, - self.FxTools, - self.MSBuild, - self.HTMLHelpWorkshop, - self.FSharp], - exists), - ) - if self.vs_ver >= 14 and isfile(self.VCRuntimeRedist): - env['py_vcruntime_redist'] = self.VCRuntimeRedist - return env - - def _build_paths(self, name, spec_path_lists, exists): - """ - Given an environment variable name and specified paths, - return a pathsep-separated string of paths containing - unique, extant, directories from those paths and from - the environment variable. Raise an error if no paths - are resolved. - - Parameters - ---------- - name: str - Environment variable name - spec_path_lists: list of str - Paths - exists: bool - It True, only return existing paths. - - Return - ------ - str - Pathsep-separated paths - """ - # flatten spec_path_lists - spec_paths = itertools.chain.from_iterable(spec_path_lists) - env_paths = environ.get(name, '').split(pathsep) - paths = itertools.chain(spec_paths, env_paths) - extant_paths = list(filter(isdir, paths)) if exists else paths - if not extant_paths: - msg = "%s environment variable is empty" % name.upper() - raise distutils.errors.DistutilsPlatformError(msg) - unique_paths = self._unique_everseen(extant_paths) - return pathsep.join(unique_paths) - - # from Python docs - @staticmethod - def _unique_everseen(iterable, key=None): - """ - List unique elements, preserving order. - Remember all elements ever seen. - - _unique_everseen('AAAABBBCCDAABBB') --> A B C D - - _unique_everseen('ABBCcAD', str.lower) --> A B C D - """ - seen = set() - seen_add = seen.add - if key is None: - for element in filterfalse(seen.__contains__, iterable): - seen_add(element) - yield element - else: - for element in iterable: - k = key(element) - if k not in seen: - seen_add(k) - yield element diff --git a/venv/lib/python3.8/site-packages/setuptools/namespaces.py b/venv/lib/python3.8/site-packages/setuptools/namespaces.py deleted file mode 100644 index dc16106..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/namespaces.py +++ /dev/null @@ -1,107 +0,0 @@ -import os -from distutils import log -import itertools - -from setuptools.extern.six.moves import map - - -flatten = itertools.chain.from_iterable - - -class Installer: - - nspkg_ext = '-nspkg.pth' - - def install_namespaces(self): - nsp = self._get_all_ns_packages() - if not nsp: - return - filename, ext = os.path.splitext(self._get_target()) - filename += self.nspkg_ext - self.outputs.append(filename) - log.info("Installing %s", filename) - lines = map(self._gen_nspkg_line, nsp) - - if self.dry_run: - # always generate the lines, even in dry run - list(lines) - return - - with open(filename, 'wt') as f: - f.writelines(lines) - - def uninstall_namespaces(self): - filename, ext = os.path.splitext(self._get_target()) - filename += self.nspkg_ext - if not os.path.exists(filename): - return - log.info("Removing %s", filename) - os.remove(filename) - - def _get_target(self): - return self.target - - _nspkg_tmpl = ( - "import sys, types, os", - "has_mfs = sys.version_info > (3, 5)", - "p = os.path.join(%(root)s, *%(pth)r)", - "importlib = has_mfs and __import__('importlib.util')", - "has_mfs and __import__('importlib.machinery')", - "m = has_mfs and " - "sys.modules.setdefault(%(pkg)r, " - "importlib.util.module_from_spec(" - "importlib.machinery.PathFinder.find_spec(%(pkg)r, " - "[os.path.dirname(p)])))", - "m = m or " - "sys.modules.setdefault(%(pkg)r, types.ModuleType(%(pkg)r))", - "mp = (m or []) and m.__dict__.setdefault('__path__',[])", - "(p not in mp) and mp.append(p)", - ) - "lines for the namespace installer" - - _nspkg_tmpl_multi = ( - 'm and setattr(sys.modules[%(parent)r], %(child)r, m)', - ) - "additional line(s) when a parent package is indicated" - - def _get_root(self): - return "sys._getframe(1).f_locals['sitedir']" - - def _gen_nspkg_line(self, pkg): - # ensure pkg is not a unicode string under Python 2.7 - pkg = str(pkg) - pth = tuple(pkg.split('.')) - root = self._get_root() - tmpl_lines = self._nspkg_tmpl - parent, sep, child = pkg.rpartition('.') - if parent: - tmpl_lines += self._nspkg_tmpl_multi - return ';'.join(tmpl_lines) % locals() + '\n' - - def _get_all_ns_packages(self): - """Return sorted list of all package namespaces""" - pkgs = self.distribution.namespace_packages or [] - return sorted(flatten(map(self._pkg_names, pkgs))) - - @staticmethod - def _pkg_names(pkg): - """ - Given a namespace package, yield the components of that - package. - - >>> names = Installer._pkg_names('a.b.c') - >>> set(names) == set(['a', 'a.b', 'a.b.c']) - True - """ - parts = pkg.split('.') - while parts: - yield '.'.join(parts) - parts.pop() - - -class DevelopInstaller(Installer): - def _get_root(self): - return repr(str(self.egg_path)) - - def _get_target(self): - return self.egg_link diff --git a/venv/lib/python3.8/site-packages/setuptools/package_index.py b/venv/lib/python3.8/site-packages/setuptools/package_index.py deleted file mode 100644 index f419d47..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/package_index.py +++ /dev/null @@ -1,1136 +0,0 @@ -"""PyPI and direct package downloading""" -import sys -import os -import re -import shutil -import socket -import base64 -import hashlib -import itertools -import warnings -from functools import wraps - -from setuptools.extern import six -from setuptools.extern.six.moves import urllib, http_client, configparser, map - -import setuptools -from pkg_resources import ( - CHECKOUT_DIST, Distribution, BINARY_DIST, normalize_path, SOURCE_DIST, - Environment, find_distributions, safe_name, safe_version, - to_filename, Requirement, DEVELOP_DIST, EGG_DIST, -) -from setuptools import ssl_support -from distutils import log -from distutils.errors import DistutilsError -from fnmatch import translate -from setuptools.py27compat import get_all_headers -from setuptools.py33compat import unescape -from setuptools.wheel import Wheel - -__metaclass__ = type - -EGG_FRAGMENT = re.compile(r'^egg=([-A-Za-z0-9_.+!]+)$') -HREF = re.compile(r"""href\s*=\s*['"]?([^'"> ]+)""", re.I) -PYPI_MD5 = re.compile( - r'([^<]+)\n\s+\(md5\)' -) -URL_SCHEME = re.compile('([-+.a-z0-9]{2,}):', re.I).match -EXTENSIONS = ".tar.gz .tar.bz2 .tar .zip .tgz".split() - -__all__ = [ - 'PackageIndex', 'distros_for_url', 'parse_bdist_wininst', - 'interpret_distro_name', -] - -_SOCKET_TIMEOUT = 15 - -_tmpl = "setuptools/{setuptools.__version__} Python-urllib/{py_major}" -user_agent = _tmpl.format(py_major='{}.{}'.format(*sys.version_info), setuptools=setuptools) - - -def parse_requirement_arg(spec): - try: - return Requirement.parse(spec) - except ValueError: - raise DistutilsError( - "Not a URL, existing file, or requirement spec: %r" % (spec,) - ) - - -def parse_bdist_wininst(name): - """Return (base,pyversion) or (None,None) for possible .exe name""" - - lower = name.lower() - base, py_ver, plat = None, None, None - - if lower.endswith('.exe'): - if lower.endswith('.win32.exe'): - base = name[:-10] - plat = 'win32' - elif lower.startswith('.win32-py', -16): - py_ver = name[-7:-4] - base = name[:-16] - plat = 'win32' - elif lower.endswith('.win-amd64.exe'): - base = name[:-14] - plat = 'win-amd64' - elif lower.startswith('.win-amd64-py', -20): - py_ver = name[-7:-4] - base = name[:-20] - plat = 'win-amd64' - return base, py_ver, plat - - -def egg_info_for_url(url): - parts = urllib.parse.urlparse(url) - scheme, server, path, parameters, query, fragment = parts - base = urllib.parse.unquote(path.split('/')[-1]) - if server == 'sourceforge.net' and base == 'download': # XXX Yuck - base = urllib.parse.unquote(path.split('/')[-2]) - if '#' in base: - base, fragment = base.split('#', 1) - return base, fragment - - -def distros_for_url(url, metadata=None): - """Yield egg or source distribution objects that might be found at a URL""" - base, fragment = egg_info_for_url(url) - for dist in distros_for_location(url, base, metadata): - yield dist - if fragment: - match = EGG_FRAGMENT.match(fragment) - if match: - for dist in interpret_distro_name( - url, match.group(1), metadata, precedence=CHECKOUT_DIST - ): - yield dist - - -def distros_for_location(location, basename, metadata=None): - """Yield egg or source distribution objects based on basename""" - if basename.endswith('.egg.zip'): - basename = basename[:-4] # strip the .zip - if basename.endswith('.egg') and '-' in basename: - # only one, unambiguous interpretation - return [Distribution.from_location(location, basename, metadata)] - if basename.endswith('.whl') and '-' in basename: - wheel = Wheel(basename) - if not wheel.is_compatible(): - return [] - return [Distribution( - location=location, - project_name=wheel.project_name, - version=wheel.version, - # Increase priority over eggs. - precedence=EGG_DIST + 1, - )] - if basename.endswith('.exe'): - win_base, py_ver, platform = parse_bdist_wininst(basename) - if win_base is not None: - return interpret_distro_name( - location, win_base, metadata, py_ver, BINARY_DIST, platform - ) - # Try source distro extensions (.zip, .tgz, etc.) - # - for ext in EXTENSIONS: - if basename.endswith(ext): - basename = basename[:-len(ext)] - return interpret_distro_name(location, basename, metadata) - return [] # no extension matched - - -def distros_for_filename(filename, metadata=None): - """Yield possible egg or source distribution objects based on a filename""" - return distros_for_location( - normalize_path(filename), os.path.basename(filename), metadata - ) - - -def interpret_distro_name( - location, basename, metadata, py_version=None, precedence=SOURCE_DIST, - platform=None -): - """Generate alternative interpretations of a source distro name - - Note: if `location` is a filesystem filename, you should call - ``pkg_resources.normalize_path()`` on it before passing it to this - routine! - """ - # Generate alternative interpretations of a source distro name - # Because some packages are ambiguous as to name/versions split - # e.g. "adns-python-1.1.0", "egenix-mx-commercial", etc. - # So, we generate each possible interepretation (e.g. "adns, python-1.1.0" - # "adns-python, 1.1.0", and "adns-python-1.1.0, no version"). In practice, - # the spurious interpretations should be ignored, because in the event - # there's also an "adns" package, the spurious "python-1.1.0" version will - # compare lower than any numeric version number, and is therefore unlikely - # to match a request for it. It's still a potential problem, though, and - # in the long run PyPI and the distutils should go for "safe" names and - # versions in distribution archive names (sdist and bdist). - - parts = basename.split('-') - if not py_version and any(re.match(r'py\d\.\d$', p) for p in parts[2:]): - # it is a bdist_dumb, not an sdist -- bail out - return - - for p in range(1, len(parts) + 1): - yield Distribution( - location, metadata, '-'.join(parts[:p]), '-'.join(parts[p:]), - py_version=py_version, precedence=precedence, - platform=platform - ) - - -# From Python 2.7 docs -def unique_everseen(iterable, key=None): - "List unique elements, preserving order. Remember all elements ever seen." - # unique_everseen('AAAABBBCCDAABBB') --> A B C D - # unique_everseen('ABBCcAD', str.lower) --> A B C D - seen = set() - seen_add = seen.add - if key is None: - for element in six.moves.filterfalse(seen.__contains__, iterable): - seen_add(element) - yield element - else: - for element in iterable: - k = key(element) - if k not in seen: - seen_add(k) - yield element - - -def unique_values(func): - """ - Wrap a function returning an iterable such that the resulting iterable - only ever yields unique items. - """ - - @wraps(func) - def wrapper(*args, **kwargs): - return unique_everseen(func(*args, **kwargs)) - - return wrapper - - -REL = re.compile(r"""<([^>]*\srel\s*=\s*['"]?([^'">]+)[^>]*)>""", re.I) -# this line is here to fix emacs' cruddy broken syntax highlighting - - -@unique_values -def find_external_links(url, page): - """Find rel="homepage" and rel="download" links in `page`, yielding URLs""" - - for match in REL.finditer(page): - tag, rel = match.groups() - rels = set(map(str.strip, rel.lower().split(','))) - if 'homepage' in rels or 'download' in rels: - for match in HREF.finditer(tag): - yield urllib.parse.urljoin(url, htmldecode(match.group(1))) - - for tag in ("Home Page", "Download URL"): - pos = page.find(tag) - if pos != -1: - match = HREF.search(page, pos) - if match: - yield urllib.parse.urljoin(url, htmldecode(match.group(1))) - - -class ContentChecker: - """ - A null content checker that defines the interface for checking content - """ - - def feed(self, block): - """ - Feed a block of data to the hash. - """ - return - - def is_valid(self): - """ - Check the hash. Return False if validation fails. - """ - return True - - def report(self, reporter, template): - """ - Call reporter with information about the checker (hash name) - substituted into the template. - """ - return - - -class HashChecker(ContentChecker): - pattern = re.compile( - r'(?Psha1|sha224|sha384|sha256|sha512|md5)=' - r'(?P[a-f0-9]+)' - ) - - def __init__(self, hash_name, expected): - self.hash_name = hash_name - self.hash = hashlib.new(hash_name) - self.expected = expected - - @classmethod - def from_url(cls, url): - "Construct a (possibly null) ContentChecker from a URL" - fragment = urllib.parse.urlparse(url)[-1] - if not fragment: - return ContentChecker() - match = cls.pattern.search(fragment) - if not match: - return ContentChecker() - return cls(**match.groupdict()) - - def feed(self, block): - self.hash.update(block) - - def is_valid(self): - return self.hash.hexdigest() == self.expected - - def report(self, reporter, template): - msg = template % self.hash_name - return reporter(msg) - - -class PackageIndex(Environment): - """A distribution index that scans web pages for download URLs""" - - def __init__( - self, index_url="https://pypi.org/simple/", hosts=('*',), - ca_bundle=None, verify_ssl=True, *args, **kw - ): - Environment.__init__(self, *args, **kw) - self.index_url = index_url + "/" [:not index_url.endswith('/')] - self.scanned_urls = {} - self.fetched_urls = {} - self.package_pages = {} - self.allows = re.compile('|'.join(map(translate, hosts))).match - self.to_scan = [] - use_ssl = ( - verify_ssl - and ssl_support.is_available - and (ca_bundle or ssl_support.find_ca_bundle()) - ) - if use_ssl: - self.opener = ssl_support.opener_for(ca_bundle) - else: - self.opener = urllib.request.urlopen - - def process_url(self, url, retrieve=False): - """Evaluate a URL as a possible download, and maybe retrieve it""" - if url in self.scanned_urls and not retrieve: - return - self.scanned_urls[url] = True - if not URL_SCHEME(url): - self.process_filename(url) - return - else: - dists = list(distros_for_url(url)) - if dists: - if not self.url_ok(url): - return - self.debug("Found link: %s", url) - - if dists or not retrieve or url in self.fetched_urls: - list(map(self.add, dists)) - return # don't need the actual page - - if not self.url_ok(url): - self.fetched_urls[url] = True - return - - self.info("Reading %s", url) - self.fetched_urls[url] = True # prevent multiple fetch attempts - tmpl = "Download error on %s: %%s -- Some packages may not be found!" - f = self.open_url(url, tmpl % url) - if f is None: - return - self.fetched_urls[f.url] = True - if 'html' not in f.headers.get('content-type', '').lower(): - f.close() # not html, we can't process it - return - - base = f.url # handle redirects - page = f.read() - if not isinstance(page, str): - # In Python 3 and got bytes but want str. - if isinstance(f, urllib.error.HTTPError): - # Errors have no charset, assume latin1: - charset = 'latin-1' - else: - charset = f.headers.get_param('charset') or 'latin-1' - page = page.decode(charset, "ignore") - f.close() - for match in HREF.finditer(page): - link = urllib.parse.urljoin(base, htmldecode(match.group(1))) - self.process_url(link) - if url.startswith(self.index_url) and getattr(f, 'code', None) != 404: - page = self.process_index(url, page) - - def process_filename(self, fn, nested=False): - # process filenames or directories - if not os.path.exists(fn): - self.warn("Not found: %s", fn) - return - - if os.path.isdir(fn) and not nested: - path = os.path.realpath(fn) - for item in os.listdir(path): - self.process_filename(os.path.join(path, item), True) - - dists = distros_for_filename(fn) - if dists: - self.debug("Found: %s", fn) - list(map(self.add, dists)) - - def url_ok(self, url, fatal=False): - s = URL_SCHEME(url) - is_file = s and s.group(1).lower() == 'file' - if is_file or self.allows(urllib.parse.urlparse(url)[1]): - return True - msg = ( - "\nNote: Bypassing %s (disallowed host; see " - "http://bit.ly/2hrImnY for details).\n") - if fatal: - raise DistutilsError(msg % url) - else: - self.warn(msg, url) - - def scan_egg_links(self, search_path): - dirs = filter(os.path.isdir, search_path) - egg_links = ( - (path, entry) - for path in dirs - for entry in os.listdir(path) - if entry.endswith('.egg-link') - ) - list(itertools.starmap(self.scan_egg_link, egg_links)) - - def scan_egg_link(self, path, entry): - with open(os.path.join(path, entry)) as raw_lines: - # filter non-empty lines - lines = list(filter(None, map(str.strip, raw_lines))) - - if len(lines) != 2: - # format is not recognized; punt - return - - egg_path, setup_path = lines - - for dist in find_distributions(os.path.join(path, egg_path)): - dist.location = os.path.join(path, *lines) - dist.precedence = SOURCE_DIST - self.add(dist) - - def process_index(self, url, page): - """Process the contents of a PyPI page""" - - def scan(link): - # Process a URL to see if it's for a package page - if link.startswith(self.index_url): - parts = list(map( - urllib.parse.unquote, link[len(self.index_url):].split('/') - )) - if len(parts) == 2 and '#' not in parts[1]: - # it's a package page, sanitize and index it - pkg = safe_name(parts[0]) - ver = safe_version(parts[1]) - self.package_pages.setdefault(pkg.lower(), {})[link] = True - return to_filename(pkg), to_filename(ver) - return None, None - - # process an index page into the package-page index - for match in HREF.finditer(page): - try: - scan(urllib.parse.urljoin(url, htmldecode(match.group(1)))) - except ValueError: - pass - - pkg, ver = scan(url) # ensure this page is in the page index - if pkg: - # process individual package page - for new_url in find_external_links(url, page): - # Process the found URL - base, frag = egg_info_for_url(new_url) - if base.endswith('.py') and not frag: - if ver: - new_url += '#egg=%s-%s' % (pkg, ver) - else: - self.need_version_info(url) - self.scan_url(new_url) - - return PYPI_MD5.sub( - lambda m: '%s' % m.group(1, 3, 2), page - ) - else: - return "" # no sense double-scanning non-package pages - - def need_version_info(self, url): - self.scan_all( - "Page at %s links to .py file(s) without version info; an index " - "scan is required.", url - ) - - def scan_all(self, msg=None, *args): - if self.index_url not in self.fetched_urls: - if msg: - self.warn(msg, *args) - self.info( - "Scanning index of all packages (this may take a while)" - ) - self.scan_url(self.index_url) - - def find_packages(self, requirement): - self.scan_url(self.index_url + requirement.unsafe_name + '/') - - if not self.package_pages.get(requirement.key): - # Fall back to safe version of the name - self.scan_url(self.index_url + requirement.project_name + '/') - - if not self.package_pages.get(requirement.key): - # We couldn't find the target package, so search the index page too - self.not_found_in_index(requirement) - - for url in list(self.package_pages.get(requirement.key, ())): - # scan each page that might be related to the desired package - self.scan_url(url) - - def obtain(self, requirement, installer=None): - self.prescan() - self.find_packages(requirement) - for dist in self[requirement.key]: - if dist in requirement: - return dist - self.debug("%s does not match %s", requirement, dist) - return super(PackageIndex, self).obtain(requirement, installer) - - def check_hash(self, checker, filename, tfp): - """ - checker is a ContentChecker - """ - checker.report( - self.debug, - "Validating %%s checksum for %s" % filename) - if not checker.is_valid(): - tfp.close() - os.unlink(filename) - raise DistutilsError( - "%s validation failed for %s; " - "possible download problem?" - % (checker.hash.name, os.path.basename(filename)) - ) - - def add_find_links(self, urls): - """Add `urls` to the list that will be prescanned for searches""" - for url in urls: - if ( - self.to_scan is None # if we have already "gone online" - or not URL_SCHEME(url) # or it's a local file/directory - or url.startswith('file:') - or list(distros_for_url(url)) # or a direct package link - ): - # then go ahead and process it now - self.scan_url(url) - else: - # otherwise, defer retrieval till later - self.to_scan.append(url) - - def prescan(self): - """Scan urls scheduled for prescanning (e.g. --find-links)""" - if self.to_scan: - list(map(self.scan_url, self.to_scan)) - self.to_scan = None # from now on, go ahead and process immediately - - def not_found_in_index(self, requirement): - if self[requirement.key]: # we've seen at least one distro - meth, msg = self.info, "Couldn't retrieve index page for %r" - else: # no distros seen for this name, might be misspelled - meth, msg = ( - self.warn, - "Couldn't find index page for %r (maybe misspelled?)") - meth(msg, requirement.unsafe_name) - self.scan_all() - - def download(self, spec, tmpdir): - """Locate and/or download `spec` to `tmpdir`, returning a local path - - `spec` may be a ``Requirement`` object, or a string containing a URL, - an existing local filename, or a project/version requirement spec - (i.e. the string form of a ``Requirement`` object). If it is the URL - of a .py file with an unambiguous ``#egg=name-version`` tag (i.e., one - that escapes ``-`` as ``_`` throughout), a trivial ``setup.py`` is - automatically created alongside the downloaded file. - - If `spec` is a ``Requirement`` object or a string containing a - project/version requirement spec, this method returns the location of - a matching distribution (possibly after downloading it to `tmpdir`). - If `spec` is a locally existing file or directory name, it is simply - returned unchanged. If `spec` is a URL, it is downloaded to a subpath - of `tmpdir`, and the local filename is returned. Various errors may be - raised if a problem occurs during downloading. - """ - if not isinstance(spec, Requirement): - scheme = URL_SCHEME(spec) - if scheme: - # It's a url, download it to tmpdir - found = self._download_url(scheme.group(1), spec, tmpdir) - base, fragment = egg_info_for_url(spec) - if base.endswith('.py'): - found = self.gen_setup(found, fragment, tmpdir) - return found - elif os.path.exists(spec): - # Existing file or directory, just return it - return spec - else: - spec = parse_requirement_arg(spec) - return getattr(self.fetch_distribution(spec, tmpdir), 'location', None) - - def fetch_distribution( - self, requirement, tmpdir, force_scan=False, source=False, - develop_ok=False, local_index=None): - """Obtain a distribution suitable for fulfilling `requirement` - - `requirement` must be a ``pkg_resources.Requirement`` instance. - If necessary, or if the `force_scan` flag is set, the requirement is - searched for in the (online) package index as well as the locally - installed packages. If a distribution matching `requirement` is found, - the returned distribution's ``location`` is the value you would have - gotten from calling the ``download()`` method with the matching - distribution's URL or filename. If no matching distribution is found, - ``None`` is returned. - - If the `source` flag is set, only source distributions and source - checkout links will be considered. Unless the `develop_ok` flag is - set, development and system eggs (i.e., those using the ``.egg-info`` - format) will be ignored. - """ - # process a Requirement - self.info("Searching for %s", requirement) - skipped = {} - dist = None - - def find(req, env=None): - if env is None: - env = self - # Find a matching distribution; may be called more than once - - for dist in env[req.key]: - - if dist.precedence == DEVELOP_DIST and not develop_ok: - if dist not in skipped: - self.warn( - "Skipping development or system egg: %s", dist, - ) - skipped[dist] = 1 - continue - - test = ( - dist in req - and (dist.precedence <= SOURCE_DIST or not source) - ) - if test: - loc = self.download(dist.location, tmpdir) - dist.download_location = loc - if os.path.exists(dist.download_location): - return dist - - if force_scan: - self.prescan() - self.find_packages(requirement) - dist = find(requirement) - - if not dist and local_index is not None: - dist = find(requirement, local_index) - - if dist is None: - if self.to_scan is not None: - self.prescan() - dist = find(requirement) - - if dist is None and not force_scan: - self.find_packages(requirement) - dist = find(requirement) - - if dist is None: - self.warn( - "No local packages or working download links found for %s%s", - (source and "a source distribution of " or ""), - requirement, - ) - else: - self.info("Best match: %s", dist) - return dist.clone(location=dist.download_location) - - def fetch(self, requirement, tmpdir, force_scan=False, source=False): - """Obtain a file suitable for fulfilling `requirement` - - DEPRECATED; use the ``fetch_distribution()`` method now instead. For - backward compatibility, this routine is identical but returns the - ``location`` of the downloaded distribution instead of a distribution - object. - """ - dist = self.fetch_distribution(requirement, tmpdir, force_scan, source) - if dist is not None: - return dist.location - return None - - def gen_setup(self, filename, fragment, tmpdir): - match = EGG_FRAGMENT.match(fragment) - dists = match and [ - d for d in - interpret_distro_name(filename, match.group(1), None) if d.version - ] or [] - - if len(dists) == 1: # unambiguous ``#egg`` fragment - basename = os.path.basename(filename) - - # Make sure the file has been downloaded to the temp dir. - if os.path.dirname(filename) != tmpdir: - dst = os.path.join(tmpdir, basename) - from setuptools.command.easy_install import samefile - if not samefile(filename, dst): - shutil.copy2(filename, dst) - filename = dst - - with open(os.path.join(tmpdir, 'setup.py'), 'w') as file: - file.write( - "from setuptools import setup\n" - "setup(name=%r, version=%r, py_modules=[%r])\n" - % ( - dists[0].project_name, dists[0].version, - os.path.splitext(basename)[0] - ) - ) - return filename - - elif match: - raise DistutilsError( - "Can't unambiguously interpret project/version identifier %r; " - "any dashes in the name or version should be escaped using " - "underscores. %r" % (fragment, dists) - ) - else: - raise DistutilsError( - "Can't process plain .py files without an '#egg=name-version'" - " suffix to enable automatic setup script generation." - ) - - dl_blocksize = 8192 - - def _download_to(self, url, filename): - self.info("Downloading %s", url) - # Download the file - fp = None - try: - checker = HashChecker.from_url(url) - fp = self.open_url(url) - if isinstance(fp, urllib.error.HTTPError): - raise DistutilsError( - "Can't download %s: %s %s" % (url, fp.code, fp.msg) - ) - headers = fp.info() - blocknum = 0 - bs = self.dl_blocksize - size = -1 - if "content-length" in headers: - # Some servers return multiple Content-Length headers :( - sizes = get_all_headers(headers, 'Content-Length') - size = max(map(int, sizes)) - self.reporthook(url, filename, blocknum, bs, size) - with open(filename, 'wb') as tfp: - while True: - block = fp.read(bs) - if block: - checker.feed(block) - tfp.write(block) - blocknum += 1 - self.reporthook(url, filename, blocknum, bs, size) - else: - break - self.check_hash(checker, filename, tfp) - return headers - finally: - if fp: - fp.close() - - def reporthook(self, url, filename, blocknum, blksize, size): - pass # no-op - - def open_url(self, url, warning=None): - if url.startswith('file:'): - return local_open(url) - try: - return open_with_auth(url, self.opener) - except (ValueError, http_client.InvalidURL) as v: - msg = ' '.join([str(arg) for arg in v.args]) - if warning: - self.warn(warning, msg) - else: - raise DistutilsError('%s %s' % (url, msg)) - except urllib.error.HTTPError as v: - return v - except urllib.error.URLError as v: - if warning: - self.warn(warning, v.reason) - else: - raise DistutilsError("Download error for %s: %s" - % (url, v.reason)) - except http_client.BadStatusLine as v: - if warning: - self.warn(warning, v.line) - else: - raise DistutilsError( - '%s returned a bad status line. The server might be ' - 'down, %s' % - (url, v.line) - ) - except (http_client.HTTPException, socket.error) as v: - if warning: - self.warn(warning, v) - else: - raise DistutilsError("Download error for %s: %s" - % (url, v)) - - def _download_url(self, scheme, url, tmpdir): - # Determine download filename - # - name, fragment = egg_info_for_url(url) - if name: - while '..' in name: - name = name.replace('..', '.').replace('\\', '_') - else: - name = "__downloaded__" # default if URL has no path contents - - if name.endswith('.egg.zip'): - name = name[:-4] # strip the extra .zip before download - - filename = os.path.join(tmpdir, name) - - # Download the file - # - if scheme == 'svn' or scheme.startswith('svn+'): - return self._download_svn(url, filename) - elif scheme == 'git' or scheme.startswith('git+'): - return self._download_git(url, filename) - elif scheme.startswith('hg+'): - return self._download_hg(url, filename) - elif scheme == 'file': - return urllib.request.url2pathname(urllib.parse.urlparse(url)[2]) - else: - self.url_ok(url, True) # raises error if not allowed - return self._attempt_download(url, filename) - - def scan_url(self, url): - self.process_url(url, True) - - def _attempt_download(self, url, filename): - headers = self._download_to(url, filename) - if 'html' in headers.get('content-type', '').lower(): - return self._download_html(url, headers, filename) - else: - return filename - - def _download_html(self, url, headers, filename): - file = open(filename) - for line in file: - if line.strip(): - # Check for a subversion index page - if re.search(r'([^- ]+ - )?Revision \d+:', line): - # it's a subversion index page: - file.close() - os.unlink(filename) - return self._download_svn(url, filename) - break # not an index page - file.close() - os.unlink(filename) - raise DistutilsError("Unexpected HTML page found at " + url) - - def _download_svn(self, url, filename): - warnings.warn("SVN download support is deprecated", UserWarning) - url = url.split('#', 1)[0] # remove any fragment for svn's sake - creds = '' - if url.lower().startswith('svn:') and '@' in url: - scheme, netloc, path, p, q, f = urllib.parse.urlparse(url) - if not netloc and path.startswith('//') and '/' in path[2:]: - netloc, path = path[2:].split('/', 1) - auth, host = _splituser(netloc) - if auth: - if ':' in auth: - user, pw = auth.split(':', 1) - creds = " --username=%s --password=%s" % (user, pw) - else: - creds = " --username=" + auth - netloc = host - parts = scheme, netloc, url, p, q, f - url = urllib.parse.urlunparse(parts) - self.info("Doing subversion checkout from %s to %s", url, filename) - os.system("svn checkout%s -q %s %s" % (creds, url, filename)) - return filename - - @staticmethod - def _vcs_split_rev_from_url(url, pop_prefix=False): - scheme, netloc, path, query, frag = urllib.parse.urlsplit(url) - - scheme = scheme.split('+', 1)[-1] - - # Some fragment identification fails - path = path.split('#', 1)[0] - - rev = None - if '@' in path: - path, rev = path.rsplit('@', 1) - - # Also, discard fragment - url = urllib.parse.urlunsplit((scheme, netloc, path, query, '')) - - return url, rev - - def _download_git(self, url, filename): - filename = filename.split('#', 1)[0] - url, rev = self._vcs_split_rev_from_url(url, pop_prefix=True) - - self.info("Doing git clone from %s to %s", url, filename) - os.system("git clone --quiet %s %s" % (url, filename)) - - if rev is not None: - self.info("Checking out %s", rev) - os.system("git -C %s checkout --quiet %s" % ( - filename, - rev, - )) - - return filename - - def _download_hg(self, url, filename): - filename = filename.split('#', 1)[0] - url, rev = self._vcs_split_rev_from_url(url, pop_prefix=True) - - self.info("Doing hg clone from %s to %s", url, filename) - os.system("hg clone --quiet %s %s" % (url, filename)) - - if rev is not None: - self.info("Updating to %s", rev) - os.system("hg --cwd %s up -C -r %s -q" % ( - filename, - rev, - )) - - return filename - - def debug(self, msg, *args): - log.debug(msg, *args) - - def info(self, msg, *args): - log.info(msg, *args) - - def warn(self, msg, *args): - log.warn(msg, *args) - - -# This pattern matches a character entity reference (a decimal numeric -# references, a hexadecimal numeric reference, or a named reference). -entity_sub = re.compile(r'&(#(\d+|x[\da-fA-F]+)|[\w.:-]+);?').sub - - -def decode_entity(match): - what = match.group(0) - return unescape(what) - - -def htmldecode(text): - """ - Decode HTML entities in the given text. - - >>> htmldecode( - ... 'https://../package_name-0.1.2.tar.gz' - ... '?tokena=A&tokenb=B">package_name-0.1.2.tar.gz') - 'https://../package_name-0.1.2.tar.gz?tokena=A&tokenb=B">package_name-0.1.2.tar.gz' - """ - return entity_sub(decode_entity, text) - - -def socket_timeout(timeout=15): - def _socket_timeout(func): - def _socket_timeout(*args, **kwargs): - old_timeout = socket.getdefaulttimeout() - socket.setdefaulttimeout(timeout) - try: - return func(*args, **kwargs) - finally: - socket.setdefaulttimeout(old_timeout) - - return _socket_timeout - - return _socket_timeout - - -def _encode_auth(auth): - """ - A function compatible with Python 2.3-3.3 that will encode - auth from a URL suitable for an HTTP header. - >>> str(_encode_auth('username%3Apassword')) - 'dXNlcm5hbWU6cGFzc3dvcmQ=' - - Long auth strings should not cause a newline to be inserted. - >>> long_auth = 'username:' + 'password'*10 - >>> chr(10) in str(_encode_auth(long_auth)) - False - """ - auth_s = urllib.parse.unquote(auth) - # convert to bytes - auth_bytes = auth_s.encode() - encoded_bytes = base64.b64encode(auth_bytes) - # convert back to a string - encoded = encoded_bytes.decode() - # strip the trailing carriage return - return encoded.replace('\n', '') - - -class Credential: - """ - A username/password pair. Use like a namedtuple. - """ - - def __init__(self, username, password): - self.username = username - self.password = password - - def __iter__(self): - yield self.username - yield self.password - - def __str__(self): - return '%(username)s:%(password)s' % vars(self) - - -class PyPIConfig(configparser.RawConfigParser): - def __init__(self): - """ - Load from ~/.pypirc - """ - defaults = dict.fromkeys(['username', 'password', 'repository'], '') - configparser.RawConfigParser.__init__(self, defaults) - - rc = os.path.join(os.path.expanduser('~'), '.pypirc') - if os.path.exists(rc): - self.read(rc) - - @property - def creds_by_repository(self): - sections_with_repositories = [ - section for section in self.sections() - if self.get(section, 'repository').strip() - ] - - return dict(map(self._get_repo_cred, sections_with_repositories)) - - def _get_repo_cred(self, section): - repo = self.get(section, 'repository').strip() - return repo, Credential( - self.get(section, 'username').strip(), - self.get(section, 'password').strip(), - ) - - def find_credential(self, url): - """ - If the URL indicated appears to be a repository defined in this - config, return the credential for that repository. - """ - for repository, cred in self.creds_by_repository.items(): - if url.startswith(repository): - return cred - - -def open_with_auth(url, opener=urllib.request.urlopen): - """Open a urllib2 request, handling HTTP authentication""" - - parsed = urllib.parse.urlparse(url) - scheme, netloc, path, params, query, frag = parsed - - # Double scheme does not raise on Mac OS X as revealed by a - # failing test. We would expect "nonnumeric port". Refs #20. - if netloc.endswith(':'): - raise http_client.InvalidURL("nonnumeric port: ''") - - if scheme in ('http', 'https'): - auth, address = _splituser(netloc) - else: - auth = None - - if not auth: - cred = PyPIConfig().find_credential(url) - if cred: - auth = str(cred) - info = cred.username, url - log.info('Authenticating as %s for %s (from .pypirc)', *info) - - if auth: - auth = "Basic " + _encode_auth(auth) - parts = scheme, address, path, params, query, frag - new_url = urllib.parse.urlunparse(parts) - request = urllib.request.Request(new_url) - request.add_header("Authorization", auth) - else: - request = urllib.request.Request(url) - - request.add_header('User-Agent', user_agent) - fp = opener(request) - - if auth: - # Put authentication info back into request URL if same host, - # so that links found on the page will work - s2, h2, path2, param2, query2, frag2 = urllib.parse.urlparse(fp.url) - if s2 == scheme and h2 == address: - parts = s2, netloc, path2, param2, query2, frag2 - fp.url = urllib.parse.urlunparse(parts) - - return fp - - -# copy of urllib.parse._splituser from Python 3.8 -def _splituser(host): - """splituser('user[:passwd]@host[:port]') --> 'user[:passwd]', 'host[:port]'.""" - user, delim, host = host.rpartition('@') - return (user if delim else None), host - - -# adding a timeout to avoid freezing package_index -open_with_auth = socket_timeout(_SOCKET_TIMEOUT)(open_with_auth) - - -def fix_sf_url(url): - return url # backward compatibility - - -def local_open(url): - """Read a local path, with special support for directories""" - scheme, server, path, param, query, frag = urllib.parse.urlparse(url) - filename = urllib.request.url2pathname(path) - if os.path.isfile(filename): - return urllib.request.urlopen(url) - elif path.endswith('/') and os.path.isdir(filename): - files = [] - for f in os.listdir(filename): - filepath = os.path.join(filename, f) - if f == 'index.html': - with open(filepath, 'r') as fp: - body = fp.read() - break - elif os.path.isdir(filepath): - f += '/' - files.append('<a href="{name}">{name}</a>'.format(name=f)) - else: - tmpl = ( - "<html><head><title>{url}" - "{files}") - body = tmpl.format(url=url, files='\n'.join(files)) - status, message = 200, "OK" - else: - status, message, body = 404, "Path not found", "Not found" - - headers = {'content-type': 'text/html'} - body_stream = six.StringIO(body) - return urllib.error.HTTPError(url, status, message, headers, body_stream) diff --git a/venv/lib/python3.8/site-packages/setuptools/py27compat.py b/venv/lib/python3.8/site-packages/setuptools/py27compat.py deleted file mode 100644 index 1d57360..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/py27compat.py +++ /dev/null @@ -1,60 +0,0 @@ -""" -Compatibility Support for Python 2.7 and earlier -""" - -import sys -import platform - -from setuptools.extern import six - - -def get_all_headers(message, key): - """ - Given an HTTPMessage, return all headers matching a given key. - """ - return message.get_all(key) - - -if six.PY2: - def get_all_headers(message, key): - return message.getheaders(key) - - -linux_py2_ascii = ( - platform.system() == 'Linux' and - six.PY2 -) - -rmtree_safe = str if linux_py2_ascii else lambda x: x -"""Workaround for http://bugs.python.org/issue24672""" - - -try: - from ._imp import find_module, PY_COMPILED, PY_FROZEN, PY_SOURCE - from ._imp import get_frozen_object, get_module -except ImportError: - import imp - from imp import PY_COMPILED, PY_FROZEN, PY_SOURCE # noqa - - def find_module(module, paths=None): - """Just like 'imp.find_module()', but with package support""" - parts = module.split('.') - while parts: - part = parts.pop(0) - f, path, (suffix, mode, kind) = info = imp.find_module(part, paths) - - if kind == imp.PKG_DIRECTORY: - parts = parts or ['__init__'] - paths = [path] - - elif parts: - raise ImportError("Can't find %r in %s" % (parts, module)) - - return info - - def get_frozen_object(module, paths): - return imp.get_frozen_object(module) - - def get_module(module, paths, info): - imp.load_module(module, *info) - return sys.modules[module] diff --git a/venv/lib/python3.8/site-packages/setuptools/py31compat.py b/venv/lib/python3.8/site-packages/setuptools/py31compat.py deleted file mode 100644 index e1da7ee..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/py31compat.py +++ /dev/null @@ -1,32 +0,0 @@ -__all__ = [] - -__metaclass__ = type - - -try: - # Python >=3.2 - from tempfile import TemporaryDirectory -except ImportError: - import shutil - import tempfile - - class TemporaryDirectory: - """ - Very simple temporary directory context manager. - Will try to delete afterward, but will also ignore OS and similar - errors on deletion. - """ - - def __init__(self, **kwargs): - self.name = None # Handle mkdtemp raising an exception - self.name = tempfile.mkdtemp(**kwargs) - - def __enter__(self): - return self.name - - def __exit__(self, exctype, excvalue, exctrace): - try: - shutil.rmtree(self.name, True) - except OSError: # removal errors are not the only possible - pass - self.name = None diff --git a/venv/lib/python3.8/site-packages/setuptools/py33compat.py b/venv/lib/python3.8/site-packages/setuptools/py33compat.py deleted file mode 100644 index cb69443..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/py33compat.py +++ /dev/null @@ -1,59 +0,0 @@ -import dis -import array -import collections - -try: - import html -except ImportError: - html = None - -from setuptools.extern import six -from setuptools.extern.six.moves import html_parser - -__metaclass__ = type - -OpArg = collections.namedtuple('OpArg', 'opcode arg') - - -class Bytecode_compat: - def __init__(self, code): - self.code = code - - def __iter__(self): - """Yield '(op,arg)' pair for each operation in code object 'code'""" - - bytes = array.array('b', self.code.co_code) - eof = len(self.code.co_code) - - ptr = 0 - extended_arg = 0 - - while ptr < eof: - - op = bytes[ptr] - - if op >= dis.HAVE_ARGUMENT: - - arg = bytes[ptr + 1] + bytes[ptr + 2] * 256 + extended_arg - ptr += 3 - - if op == dis.EXTENDED_ARG: - long_type = six.integer_types[-1] - extended_arg = arg * long_type(65536) - continue - - else: - arg = None - ptr += 1 - - yield OpArg(op, arg) - - -Bytecode = getattr(dis, 'Bytecode', Bytecode_compat) - - -unescape = getattr(html, 'unescape', None) -if unescape is None: - # HTMLParser.unescape is deprecated since Python 3.4, and will be removed - # from 3.9. - unescape = html_parser.HTMLParser().unescape diff --git a/venv/lib/python3.8/site-packages/setuptools/py34compat.py b/venv/lib/python3.8/site-packages/setuptools/py34compat.py deleted file mode 100644 index 3ad9172..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/py34compat.py +++ /dev/null @@ -1,13 +0,0 @@ -import importlib - -try: - import importlib.util -except ImportError: - pass - - -try: - module_from_spec = importlib.util.module_from_spec -except AttributeError: - def module_from_spec(spec): - return spec.loader.load_module(spec.name) diff --git a/venv/lib/python3.8/site-packages/setuptools/sandbox.py b/venv/lib/python3.8/site-packages/setuptools/sandbox.py deleted file mode 100644 index 685f3f7..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/sandbox.py +++ /dev/null @@ -1,491 +0,0 @@ -import os -import sys -import tempfile -import operator -import functools -import itertools -import re -import contextlib -import pickle -import textwrap - -from setuptools.extern import six -from setuptools.extern.six.moves import builtins, map - -import pkg_resources.py31compat - -if sys.platform.startswith('java'): - import org.python.modules.posix.PosixModule as _os -else: - _os = sys.modules[os.name] -try: - _file = file -except NameError: - _file = None -_open = open -from distutils.errors import DistutilsError -from pkg_resources import working_set - - -__all__ = [ - "AbstractSandbox", "DirectorySandbox", "SandboxViolation", "run_setup", -] - - -def _execfile(filename, globals, locals=None): - """ - Python 3 implementation of execfile. - """ - mode = 'rb' - with open(filename, mode) as stream: - script = stream.read() - if locals is None: - locals = globals - code = compile(script, filename, 'exec') - exec(code, globals, locals) - - -@contextlib.contextmanager -def save_argv(repl=None): - saved = sys.argv[:] - if repl is not None: - sys.argv[:] = repl - try: - yield saved - finally: - sys.argv[:] = saved - - -@contextlib.contextmanager -def save_path(): - saved = sys.path[:] - try: - yield saved - finally: - sys.path[:] = saved - - -@contextlib.contextmanager -def override_temp(replacement): - """ - Monkey-patch tempfile.tempdir with replacement, ensuring it exists - """ - pkg_resources.py31compat.makedirs(replacement, exist_ok=True) - - saved = tempfile.tempdir - - tempfile.tempdir = replacement - - try: - yield - finally: - tempfile.tempdir = saved - - -@contextlib.contextmanager -def pushd(target): - saved = os.getcwd() - os.chdir(target) - try: - yield saved - finally: - os.chdir(saved) - - -class UnpickleableException(Exception): - """ - An exception representing another Exception that could not be pickled. - """ - - @staticmethod - def dump(type, exc): - """ - Always return a dumped (pickled) type and exc. If exc can't be pickled, - wrap it in UnpickleableException first. - """ - try: - return pickle.dumps(type), pickle.dumps(exc) - except Exception: - # get UnpickleableException inside the sandbox - from setuptools.sandbox import UnpickleableException as cls - return cls.dump(cls, cls(repr(exc))) - - -class ExceptionSaver: - """ - A Context Manager that will save an exception, serialized, and restore it - later. - """ - - def __enter__(self): - return self - - def __exit__(self, type, exc, tb): - if not exc: - return - - # dump the exception - self._saved = UnpickleableException.dump(type, exc) - self._tb = tb - - # suppress the exception - return True - - def resume(self): - "restore and re-raise any exception" - - if '_saved' not in vars(self): - return - - type, exc = map(pickle.loads, self._saved) - six.reraise(type, exc, self._tb) - - -@contextlib.contextmanager -def save_modules(): - """ - Context in which imported modules are saved. - - Translates exceptions internal to the context into the equivalent exception - outside the context. - """ - saved = sys.modules.copy() - with ExceptionSaver() as saved_exc: - yield saved - - sys.modules.update(saved) - # remove any modules imported since - del_modules = ( - mod_name for mod_name in sys.modules - if mod_name not in saved - # exclude any encodings modules. See #285 - and not mod_name.startswith('encodings.') - ) - _clear_modules(del_modules) - - saved_exc.resume() - - -def _clear_modules(module_names): - for mod_name in list(module_names): - del sys.modules[mod_name] - - -@contextlib.contextmanager -def save_pkg_resources_state(): - saved = pkg_resources.__getstate__() - try: - yield saved - finally: - pkg_resources.__setstate__(saved) - - -@contextlib.contextmanager -def setup_context(setup_dir): - temp_dir = os.path.join(setup_dir, 'temp') - with save_pkg_resources_state(): - with save_modules(): - hide_setuptools() - with save_path(): - with save_argv(): - with override_temp(temp_dir): - with pushd(setup_dir): - # ensure setuptools commands are available - __import__('setuptools') - yield - - -def _needs_hiding(mod_name): - """ - >>> _needs_hiding('setuptools') - True - >>> _needs_hiding('pkg_resources') - True - >>> _needs_hiding('setuptools_plugin') - False - >>> _needs_hiding('setuptools.__init__') - True - >>> _needs_hiding('distutils') - True - >>> _needs_hiding('os') - False - >>> _needs_hiding('Cython') - True - """ - pattern = re.compile(r'(setuptools|pkg_resources|distutils|Cython)(\.|$)') - return bool(pattern.match(mod_name)) - - -def hide_setuptools(): - """ - Remove references to setuptools' modules from sys.modules to allow the - invocation to import the most appropriate setuptools. This technique is - necessary to avoid issues such as #315 where setuptools upgrading itself - would fail to find a function declared in the metadata. - """ - modules = filter(_needs_hiding, sys.modules) - _clear_modules(modules) - - -def run_setup(setup_script, args): - """Run a distutils setup script, sandboxed in its directory""" - setup_dir = os.path.abspath(os.path.dirname(setup_script)) - with setup_context(setup_dir): - try: - sys.argv[:] = [setup_script] + list(args) - sys.path.insert(0, setup_dir) - # reset to include setup dir, w/clean callback list - working_set.__init__() - working_set.callbacks.append(lambda dist: dist.activate()) - - # __file__ should be a byte string on Python 2 (#712) - dunder_file = ( - setup_script - if isinstance(setup_script, str) else - setup_script.encode(sys.getfilesystemencoding()) - ) - - with DirectorySandbox(setup_dir): - ns = dict(__file__=dunder_file, __name__='__main__') - _execfile(setup_script, ns) - except SystemExit as v: - if v.args and v.args[0]: - raise - # Normal exit, just return - - -class AbstractSandbox: - """Wrap 'os' module and 'open()' builtin for virtualizing setup scripts""" - - _active = False - - def __init__(self): - self._attrs = [ - name for name in dir(_os) - if not name.startswith('_') and hasattr(self, name) - ] - - def _copy(self, source): - for name in self._attrs: - setattr(os, name, getattr(source, name)) - - def __enter__(self): - self._copy(self) - if _file: - builtins.file = self._file - builtins.open = self._open - self._active = True - - def __exit__(self, exc_type, exc_value, traceback): - self._active = False - if _file: - builtins.file = _file - builtins.open = _open - self._copy(_os) - - def run(self, func): - """Run 'func' under os sandboxing""" - with self: - return func() - - def _mk_dual_path_wrapper(name): - original = getattr(_os, name) - - def wrap(self, src, dst, *args, **kw): - if self._active: - src, dst = self._remap_pair(name, src, dst, *args, **kw) - return original(src, dst, *args, **kw) - - return wrap - - for name in ["rename", "link", "symlink"]: - if hasattr(_os, name): - locals()[name] = _mk_dual_path_wrapper(name) - - def _mk_single_path_wrapper(name, original=None): - original = original or getattr(_os, name) - - def wrap(self, path, *args, **kw): - if self._active: - path = self._remap_input(name, path, *args, **kw) - return original(path, *args, **kw) - - return wrap - - if _file: - _file = _mk_single_path_wrapper('file', _file) - _open = _mk_single_path_wrapper('open', _open) - for name in [ - "stat", "listdir", "chdir", "open", "chmod", "chown", "mkdir", - "remove", "unlink", "rmdir", "utime", "lchown", "chroot", "lstat", - "startfile", "mkfifo", "mknod", "pathconf", "access" - ]: - if hasattr(_os, name): - locals()[name] = _mk_single_path_wrapper(name) - - def _mk_single_with_return(name): - original = getattr(_os, name) - - def wrap(self, path, *args, **kw): - if self._active: - path = self._remap_input(name, path, *args, **kw) - return self._remap_output(name, original(path, *args, **kw)) - return original(path, *args, **kw) - - return wrap - - for name in ['readlink', 'tempnam']: - if hasattr(_os, name): - locals()[name] = _mk_single_with_return(name) - - def _mk_query(name): - original = getattr(_os, name) - - def wrap(self, *args, **kw): - retval = original(*args, **kw) - if self._active: - return self._remap_output(name, retval) - return retval - - return wrap - - for name in ['getcwd', 'tmpnam']: - if hasattr(_os, name): - locals()[name] = _mk_query(name) - - def _validate_path(self, path): - """Called to remap or validate any path, whether input or output""" - return path - - def _remap_input(self, operation, path, *args, **kw): - """Called for path inputs""" - return self._validate_path(path) - - def _remap_output(self, operation, path): - """Called for path outputs""" - return self._validate_path(path) - - def _remap_pair(self, operation, src, dst, *args, **kw): - """Called for path pairs like rename, link, and symlink operations""" - return ( - self._remap_input(operation + '-from', src, *args, **kw), - self._remap_input(operation + '-to', dst, *args, **kw) - ) - - -if hasattr(os, 'devnull'): - _EXCEPTIONS = [os.devnull,] -else: - _EXCEPTIONS = [] - - -class DirectorySandbox(AbstractSandbox): - """Restrict operations to a single subdirectory - pseudo-chroot""" - - write_ops = dict.fromkeys([ - "open", "chmod", "chown", "mkdir", "remove", "unlink", "rmdir", - "utime", "lchown", "chroot", "mkfifo", "mknod", "tempnam", - ]) - - _exception_patterns = [ - # Allow lib2to3 to attempt to save a pickled grammar object (#121) - r'.*lib2to3.*\.pickle$', - ] - "exempt writing to paths that match the pattern" - - def __init__(self, sandbox, exceptions=_EXCEPTIONS): - self._sandbox = os.path.normcase(os.path.realpath(sandbox)) - self._prefix = os.path.join(self._sandbox, '') - self._exceptions = [ - os.path.normcase(os.path.realpath(path)) - for path in exceptions - ] - AbstractSandbox.__init__(self) - - def _violation(self, operation, *args, **kw): - from setuptools.sandbox import SandboxViolation - raise SandboxViolation(operation, args, kw) - - if _file: - - def _file(self, path, mode='r', *args, **kw): - if mode not in ('r', 'rt', 'rb', 'rU', 'U') and not self._ok(path): - self._violation("file", path, mode, *args, **kw) - return _file(path, mode, *args, **kw) - - def _open(self, path, mode='r', *args, **kw): - if mode not in ('r', 'rt', 'rb', 'rU', 'U') and not self._ok(path): - self._violation("open", path, mode, *args, **kw) - return _open(path, mode, *args, **kw) - - def tmpnam(self): - self._violation("tmpnam") - - def _ok(self, path): - active = self._active - try: - self._active = False - realpath = os.path.normcase(os.path.realpath(path)) - return ( - self._exempted(realpath) - or realpath == self._sandbox - or realpath.startswith(self._prefix) - ) - finally: - self._active = active - - def _exempted(self, filepath): - start_matches = ( - filepath.startswith(exception) - for exception in self._exceptions - ) - pattern_matches = ( - re.match(pattern, filepath) - for pattern in self._exception_patterns - ) - candidates = itertools.chain(start_matches, pattern_matches) - return any(candidates) - - def _remap_input(self, operation, path, *args, **kw): - """Called for path inputs""" - if operation in self.write_ops and not self._ok(path): - self._violation(operation, os.path.realpath(path), *args, **kw) - return path - - def _remap_pair(self, operation, src, dst, *args, **kw): - """Called for path pairs like rename, link, and symlink operations""" - if not self._ok(src) or not self._ok(dst): - self._violation(operation, src, dst, *args, **kw) - return (src, dst) - - def open(self, file, flags, mode=0o777, *args, **kw): - """Called for low-level os.open()""" - if flags & WRITE_FLAGS and not self._ok(file): - self._violation("os.open", file, flags, mode, *args, **kw) - return _os.open(file, flags, mode, *args, **kw) - - -WRITE_FLAGS = functools.reduce( - operator.or_, [getattr(_os, a, 0) for a in - "O_WRONLY O_RDWR O_APPEND O_CREAT O_TRUNC O_TEMPORARY".split()] -) - - -class SandboxViolation(DistutilsError): - """A setup script attempted to modify the filesystem outside the sandbox""" - - tmpl = textwrap.dedent(""" - SandboxViolation: {cmd}{args!r} {kwargs} - - The package setup script has attempted to modify files on your system - that are not within the EasyInstall build area, and has been aborted. - - This package cannot be safely installed by EasyInstall, and may not - support alternate installation locations even if you run its setup - script by hand. Please inform the package's author and the EasyInstall - maintainers to find out if a fix or workaround is available. - """).lstrip() - - def __str__(self): - cmd, args, kwargs = self.args - return self.tmpl.format(**locals()) diff --git a/venv/lib/python3.8/site-packages/setuptools/script (dev).tmpl b/venv/lib/python3.8/site-packages/setuptools/script (dev).tmpl deleted file mode 100644 index 39a24b0..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/script (dev).tmpl +++ /dev/null @@ -1,6 +0,0 @@ -# EASY-INSTALL-DEV-SCRIPT: %(spec)r,%(script_name)r -__requires__ = %(spec)r -__import__('pkg_resources').require(%(spec)r) -__file__ = %(dev_path)r -with open(__file__) as f: - exec(compile(f.read(), __file__, 'exec')) diff --git a/venv/lib/python3.8/site-packages/setuptools/script.tmpl b/venv/lib/python3.8/site-packages/setuptools/script.tmpl deleted file mode 100644 index ff5efbc..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/script.tmpl +++ /dev/null @@ -1,3 +0,0 @@ -# EASY-INSTALL-SCRIPT: %(spec)r,%(script_name)r -__requires__ = %(spec)r -__import__('pkg_resources').run_script(%(spec)r, %(script_name)r) diff --git a/venv/lib/python3.8/site-packages/setuptools/site-patch.py b/venv/lib/python3.8/site-packages/setuptools/site-patch.py deleted file mode 100644 index 40b00de..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/site-patch.py +++ /dev/null @@ -1,74 +0,0 @@ -def __boot(): - import sys - import os - PYTHONPATH = os.environ.get('PYTHONPATH') - if PYTHONPATH is None or (sys.platform == 'win32' and not PYTHONPATH): - PYTHONPATH = [] - else: - PYTHONPATH = PYTHONPATH.split(os.pathsep) - - pic = getattr(sys, 'path_importer_cache', {}) - stdpath = sys.path[len(PYTHONPATH):] - mydir = os.path.dirname(__file__) - - for item in stdpath: - if item == mydir or not item: - continue # skip if current dir. on Windows, or my own directory - importer = pic.get(item) - if importer is not None: - loader = importer.find_module('site') - if loader is not None: - # This should actually reload the current module - loader.load_module('site') - break - else: - try: - import imp # Avoid import loop in Python 3 - stream, path, descr = imp.find_module('site', [item]) - except ImportError: - continue - if stream is None: - continue - try: - # This should actually reload the current module - imp.load_module('site', stream, path, descr) - finally: - stream.close() - break - else: - raise ImportError("Couldn't find the real 'site' module") - - known_paths = dict([(makepath(item)[1], 1) for item in sys.path]) # 2.2 comp - - oldpos = getattr(sys, '__egginsert', 0) # save old insertion position - sys.__egginsert = 0 # and reset the current one - - for item in PYTHONPATH: - addsitedir(item) - - sys.__egginsert += oldpos # restore effective old position - - d, nd = makepath(stdpath[0]) - insert_at = None - new_path = [] - - for item in sys.path: - p, np = makepath(item) - - if np == nd and insert_at is None: - # We've hit the first 'system' path entry, so added entries go here - insert_at = len(new_path) - - if np in known_paths or insert_at is None: - new_path.append(item) - else: - # new path after the insert point, back-insert it - new_path.insert(insert_at, item) - insert_at += 1 - - sys.path[:] = new_path - - -if __name__ == 'site': - __boot() - del __boot diff --git a/venv/lib/python3.8/site-packages/setuptools/ssl_support.py b/venv/lib/python3.8/site-packages/setuptools/ssl_support.py deleted file mode 100644 index 226db69..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/ssl_support.py +++ /dev/null @@ -1,260 +0,0 @@ -import os -import socket -import atexit -import re -import functools - -from setuptools.extern.six.moves import urllib, http_client, map, filter - -from pkg_resources import ResolutionError, ExtractionError - -try: - import ssl -except ImportError: - ssl = None - -__all__ = [ - 'VerifyingHTTPSHandler', 'find_ca_bundle', 'is_available', 'cert_paths', - 'opener_for' -] - -cert_paths = """ -/etc/pki/tls/certs/ca-bundle.crt -/etc/ssl/certs/ca-certificates.crt -/usr/share/ssl/certs/ca-bundle.crt -/usr/local/share/certs/ca-root.crt -/etc/ssl/cert.pem -/System/Library/OpenSSL/certs/cert.pem -/usr/local/share/certs/ca-root-nss.crt -/etc/ssl/ca-bundle.pem -""".strip().split() - -try: - HTTPSHandler = urllib.request.HTTPSHandler - HTTPSConnection = http_client.HTTPSConnection -except AttributeError: - HTTPSHandler = HTTPSConnection = object - -is_available = ssl is not None and object not in (HTTPSHandler, HTTPSConnection) - - -try: - from ssl import CertificateError, match_hostname -except ImportError: - try: - from backports.ssl_match_hostname import CertificateError - from backports.ssl_match_hostname import match_hostname - except ImportError: - CertificateError = None - match_hostname = None - -if not CertificateError: - - class CertificateError(ValueError): - pass - - -if not match_hostname: - - def _dnsname_match(dn, hostname, max_wildcards=1): - """Matching according to RFC 6125, section 6.4.3 - - https://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 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") - dnsnames = [] - san = cert.get('subjectAltName', ()) - for key, value in san: - if key == 'DNS': - if _dnsname_match(value, hostname): - 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") - - -class VerifyingHTTPSHandler(HTTPSHandler): - """Simple verifying handler: no auth, subclasses, timeouts, etc.""" - - def __init__(self, ca_bundle): - self.ca_bundle = ca_bundle - HTTPSHandler.__init__(self) - - def https_open(self, req): - return self.do_open( - lambda host, **kw: VerifyingHTTPSConn(host, self.ca_bundle, **kw), req - ) - - -class VerifyingHTTPSConn(HTTPSConnection): - """Simple verifying connection: no auth, subclasses, timeouts, etc.""" - - def __init__(self, host, ca_bundle, **kw): - HTTPSConnection.__init__(self, host, **kw) - self.ca_bundle = ca_bundle - - def connect(self): - sock = socket.create_connection( - (self.host, self.port), getattr(self, 'source_address', None) - ) - - # Handle the socket if a (proxy) tunnel is present - if hasattr(self, '_tunnel') and getattr(self, '_tunnel_host', None): - self.sock = sock - self._tunnel() - # http://bugs.python.org/issue7776: Python>=3.4.1 and >=2.7.7 - # change self.host to mean the proxy server host when tunneling is - # being used. Adapt, since we are interested in the destination - # host for the match_hostname() comparison. - actual_host = self._tunnel_host - else: - actual_host = self.host - - if hasattr(ssl, 'create_default_context'): - ctx = ssl.create_default_context(cafile=self.ca_bundle) - self.sock = ctx.wrap_socket(sock, server_hostname=actual_host) - else: - # This is for python < 2.7.9 and < 3.4? - self.sock = ssl.wrap_socket( - sock, cert_reqs=ssl.CERT_REQUIRED, ca_certs=self.ca_bundle - ) - try: - match_hostname(self.sock.getpeercert(), actual_host) - except CertificateError: - self.sock.shutdown(socket.SHUT_RDWR) - self.sock.close() - raise - - -def opener_for(ca_bundle=None): - """Get a urlopen() replacement that uses ca_bundle for verification""" - return urllib.request.build_opener( - VerifyingHTTPSHandler(ca_bundle or find_ca_bundle()) - ).open - - -# from jaraco.functools -def once(func): - @functools.wraps(func) - def wrapper(*args, **kwargs): - if not hasattr(func, 'always_returns'): - func.always_returns = func(*args, **kwargs) - return func.always_returns - return wrapper - - -@once -def get_win_certfile(): - try: - import wincertstore - except ImportError: - return None - - class CertFile(wincertstore.CertFile): - def __init__(self): - super(CertFile, self).__init__() - atexit.register(self.close) - - def close(self): - try: - super(CertFile, self).close() - except OSError: - pass - - _wincerts = CertFile() - _wincerts.addstore('CA') - _wincerts.addstore('ROOT') - return _wincerts.name - - -def find_ca_bundle(): - """Return an existing CA bundle path, or None""" - extant_cert_paths = filter(os.path.isfile, cert_paths) - return ( - get_win_certfile() - or next(extant_cert_paths, None) - or _certifi_where() - ) - - -def _certifi_where(): - try: - return __import__('certifi').where() - except (ImportError, ResolutionError, ExtractionError): - pass diff --git a/venv/lib/python3.8/site-packages/setuptools/unicode_utils.py b/venv/lib/python3.8/site-packages/setuptools/unicode_utils.py deleted file mode 100644 index 7c63efd..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/unicode_utils.py +++ /dev/null @@ -1,44 +0,0 @@ -import unicodedata -import sys - -from setuptools.extern import six - - -# HFS Plus uses decomposed UTF-8 -def decompose(path): - if isinstance(path, six.text_type): - return unicodedata.normalize('NFD', path) - try: - path = path.decode('utf-8') - path = unicodedata.normalize('NFD', path) - path = path.encode('utf-8') - except UnicodeError: - pass # Not UTF-8 - return path - - -def filesys_decode(path): - """ - Ensure that the given path is decoded, - NONE when no expected encoding works - """ - - if isinstance(path, six.text_type): - return path - - fs_enc = sys.getfilesystemencoding() or 'utf-8' - candidates = fs_enc, 'utf-8' - - for enc in candidates: - try: - return path.decode(enc) - except UnicodeDecodeError: - continue - - -def try_encode(string, enc): - "turn unicode encoding into a functional routine" - try: - return string.encode(enc) - except UnicodeEncodeError: - return None diff --git a/venv/lib/python3.8/site-packages/setuptools/version.py b/venv/lib/python3.8/site-packages/setuptools/version.py deleted file mode 100644 index 95e1869..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/version.py +++ /dev/null @@ -1,6 +0,0 @@ -import pkg_resources - -try: - __version__ = pkg_resources.get_distribution('setuptools').version -except Exception: - __version__ = 'unknown' diff --git a/venv/lib/python3.8/site-packages/setuptools/wheel.py b/venv/lib/python3.8/site-packages/setuptools/wheel.py deleted file mode 100644 index 025aaa8..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/wheel.py +++ /dev/null @@ -1,220 +0,0 @@ -"""Wheels support.""" - -from distutils.util import get_platform -from distutils import log -import email -import itertools -import os -import posixpath -import re -import zipfile - -import pkg_resources -import setuptools -from pkg_resources import parse_version -from setuptools.extern.packaging.tags import sys_tags -from setuptools.extern.packaging.utils import canonicalize_name -from setuptools.extern.six import PY3 -from setuptools.command.egg_info import write_requirements - - -__metaclass__ = type - - -WHEEL_NAME = re.compile( - r"""^(?P.+?)-(?P\d.*?) - ((-(?P\d.*?))?-(?P.+?)-(?P.+?)-(?P.+?) - )\.whl$""", - re.VERBOSE).match - -NAMESPACE_PACKAGE_INIT = '''\ -try: - __import__('pkg_resources').declare_namespace(__name__) -except ImportError: - __path__ = __import__('pkgutil').extend_path(__path__, __name__) -''' - - -def unpack(src_dir, dst_dir): - '''Move everything under `src_dir` to `dst_dir`, and delete the former.''' - for dirpath, dirnames, filenames in os.walk(src_dir): - subdir = os.path.relpath(dirpath, src_dir) - for f in filenames: - src = os.path.join(dirpath, f) - dst = os.path.join(dst_dir, subdir, f) - os.renames(src, dst) - for n, d in reversed(list(enumerate(dirnames))): - src = os.path.join(dirpath, d) - dst = os.path.join(dst_dir, subdir, d) - if not os.path.exists(dst): - # Directory does not exist in destination, - # rename it and prune it from os.walk list. - os.renames(src, dst) - del dirnames[n] - # Cleanup. - for dirpath, dirnames, filenames in os.walk(src_dir, topdown=True): - assert not filenames - os.rmdir(dirpath) - - -class Wheel: - - def __init__(self, filename): - match = WHEEL_NAME(os.path.basename(filename)) - if match is None: - raise ValueError('invalid wheel name: %r' % filename) - self.filename = filename - for k, v in match.groupdict().items(): - setattr(self, k, v) - - def tags(self): - '''List tags (py_version, abi, platform) supported by this wheel.''' - return itertools.product( - self.py_version.split('.'), - self.abi.split('.'), - self.platform.split('.'), - ) - - def is_compatible(self): - '''Is the wheel is compatible with the current platform?''' - supported_tags = set((t.interpreter, t.abi, t.platform) for t in sys_tags()) - return next((True for t in self.tags() if t in supported_tags), False) - - def egg_name(self): - return pkg_resources.Distribution( - project_name=self.project_name, version=self.version, - platform=(None if self.platform == 'any' else get_platform()), - ).egg_name() + '.egg' - - def get_dist_info(self, zf): - # find the correct name of the .dist-info dir in the wheel file - for member in zf.namelist(): - dirname = posixpath.dirname(member) - if (dirname.endswith('.dist-info') and - canonicalize_name(dirname).startswith( - canonicalize_name(self.project_name))): - return dirname - raise ValueError("unsupported wheel format. .dist-info not found") - - def install_as_egg(self, destination_eggdir): - '''Install wheel as an egg directory.''' - with zipfile.ZipFile(self.filename) as zf: - self._install_as_egg(destination_eggdir, zf) - - def _install_as_egg(self, destination_eggdir, zf): - dist_basename = '%s-%s' % (self.project_name, self.version) - dist_info = self.get_dist_info(zf) - dist_data = '%s.data' % dist_basename - egg_info = os.path.join(destination_eggdir, 'EGG-INFO') - - self._convert_metadata(zf, destination_eggdir, dist_info, egg_info) - self._move_data_entries(destination_eggdir, dist_data) - self._fix_namespace_packages(egg_info, destination_eggdir) - - @staticmethod - def _convert_metadata(zf, destination_eggdir, dist_info, egg_info): - def get_metadata(name): - with zf.open(posixpath.join(dist_info, name)) as fp: - value = fp.read().decode('utf-8') if PY3 else fp.read() - return email.parser.Parser().parsestr(value) - - wheel_metadata = get_metadata('WHEEL') - # Check wheel format version is supported. - wheel_version = parse_version(wheel_metadata.get('Wheel-Version')) - wheel_v1 = ( - parse_version('1.0') <= wheel_version < parse_version('2.0dev0') - ) - if not wheel_v1: - raise ValueError( - 'unsupported wheel format version: %s' % wheel_version) - # Extract to target directory. - os.mkdir(destination_eggdir) - zf.extractall(destination_eggdir) - # Convert metadata. - dist_info = os.path.join(destination_eggdir, dist_info) - dist = pkg_resources.Distribution.from_location( - destination_eggdir, dist_info, - metadata=pkg_resources.PathMetadata(destination_eggdir, dist_info), - ) - - # Note: Evaluate and strip markers now, - # as it's difficult to convert back from the syntax: - # foobar; "linux" in sys_platform and extra == 'test' - def raw_req(req): - req.marker = None - return str(req) - install_requires = list(sorted(map(raw_req, dist.requires()))) - extras_require = { - extra: sorted( - req - for req in map(raw_req, dist.requires((extra,))) - if req not in install_requires - ) - for extra in dist.extras - } - os.rename(dist_info, egg_info) - os.rename( - os.path.join(egg_info, 'METADATA'), - os.path.join(egg_info, 'PKG-INFO'), - ) - setup_dist = setuptools.Distribution( - attrs=dict( - install_requires=install_requires, - extras_require=extras_require, - ), - ) - # Temporarily disable info traces. - log_threshold = log._global_log.threshold - log.set_threshold(log.WARN) - try: - write_requirements( - setup_dist.get_command_obj('egg_info'), - None, - os.path.join(egg_info, 'requires.txt'), - ) - finally: - log.set_threshold(log_threshold) - - @staticmethod - def _move_data_entries(destination_eggdir, dist_data): - """Move data entries to their correct location.""" - dist_data = os.path.join(destination_eggdir, dist_data) - dist_data_scripts = os.path.join(dist_data, 'scripts') - if os.path.exists(dist_data_scripts): - egg_info_scripts = os.path.join( - destination_eggdir, 'EGG-INFO', 'scripts') - os.mkdir(egg_info_scripts) - for entry in os.listdir(dist_data_scripts): - # Remove bytecode, as it's not properly handled - # during easy_install scripts install phase. - if entry.endswith('.pyc'): - os.unlink(os.path.join(dist_data_scripts, entry)) - else: - os.rename( - os.path.join(dist_data_scripts, entry), - os.path.join(egg_info_scripts, entry), - ) - os.rmdir(dist_data_scripts) - for subdir in filter(os.path.exists, ( - os.path.join(dist_data, d) - for d in ('data', 'headers', 'purelib', 'platlib') - )): - unpack(subdir, destination_eggdir) - if os.path.exists(dist_data): - os.rmdir(dist_data) - - @staticmethod - def _fix_namespace_packages(egg_info, destination_eggdir): - namespace_packages = os.path.join( - egg_info, 'namespace_packages.txt') - if os.path.exists(namespace_packages): - with open(namespace_packages) as fp: - namespace_packages = fp.read().split() - for mod in namespace_packages: - mod_dir = os.path.join(destination_eggdir, *mod.split('.')) - mod_init = os.path.join(mod_dir, '__init__.py') - if not os.path.exists(mod_dir): - os.mkdir(mod_dir) - if not os.path.exists(mod_init): - with open(mod_init, 'w') as fp: - fp.write(NAMESPACE_PACKAGE_INIT) diff --git a/venv/lib/python3.8/site-packages/setuptools/windows_support.py b/venv/lib/python3.8/site-packages/setuptools/windows_support.py deleted file mode 100644 index cb977cf..0000000 --- a/venv/lib/python3.8/site-packages/setuptools/windows_support.py +++ /dev/null @@ -1,29 +0,0 @@ -import platform -import ctypes - - -def windows_only(func): - if platform.system() != 'Windows': - return lambda *args, **kwargs: None - return func - - -@windows_only -def hide_file(path): - """ - Set the hidden attribute on a file or directory. - - From http://stackoverflow.com/questions/19622133/ - - `path` must be text. - """ - __import__('ctypes.wintypes') - SetFileAttributes = ctypes.windll.kernel32.SetFileAttributesW - SetFileAttributes.argtypes = ctypes.wintypes.LPWSTR, ctypes.wintypes.DWORD - SetFileAttributes.restype = ctypes.wintypes.BOOL - - FILE_ATTRIBUTE_HIDDEN = 0x02 - - ret = SetFileAttributes(path, FILE_ATTRIBUTE_HIDDEN) - if not ret: - raise ctypes.WinError() diff --git a/venv/lib/python3.8/site-packages/urllib3-1.26.6.dist-info/INSTALLER b/venv/lib/python3.8/site-packages/urllib3-1.26.6.dist-info/INSTALLER deleted file mode 100644 index a1b589e..0000000 --- a/venv/lib/python3.8/site-packages/urllib3-1.26.6.dist-info/INSTALLER +++ /dev/null @@ -1 +0,0 @@ -pip diff --git a/venv/lib/python3.8/site-packages/urllib3-1.26.6.dist-info/LICENSE.txt b/venv/lib/python3.8/site-packages/urllib3-1.26.6.dist-info/LICENSE.txt deleted file mode 100644 index 429a176..0000000 --- a/venv/lib/python3.8/site-packages/urllib3-1.26.6.dist-info/LICENSE.txt +++ /dev/null @@ -1,21 +0,0 @@ -MIT License - -Copyright (c) 2008-2020 Andrey Petrov and contributors (see CONTRIBUTORS.txt) - -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/venv/lib/python3.8/site-packages/urllib3-1.26.6.dist-info/METADATA b/venv/lib/python3.8/site-packages/urllib3-1.26.6.dist-info/METADATA deleted file mode 100644 index af99541..0000000 --- a/venv/lib/python3.8/site-packages/urllib3-1.26.6.dist-info/METADATA +++ /dev/null @@ -1,1388 +0,0 @@ -Metadata-Version: 2.1 -Name: urllib3 -Version: 1.26.6 -Summary: HTTP library with thread-safe connection pooling, file post, and more. -Home-page: https://urllib3.readthedocs.io/ -Author: Andrey Petrov -Author-email: andrey.petrov@shazow.net -License: MIT -Project-URL: Documentation, https://urllib3.readthedocs.io/ -Project-URL: Code, https://github.com/urllib3/urllib3 -Project-URL: Issue tracker, https://github.com/urllib3/urllib3/issues -Keywords: urllib httplib threadsafe filepost http https ssl pooling -Platform: UNKNOWN -Classifier: Environment :: Web Environment -Classifier: Intended Audience :: Developers -Classifier: License :: OSI Approved :: MIT License -Classifier: Operating System :: OS Independent -Classifier: Programming Language :: Python -Classifier: Programming Language :: Python :: 2 -Classifier: Programming Language :: Python :: 2.7 -Classifier: Programming Language :: Python :: 3 -Classifier: Programming Language :: Python :: 3.5 -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 :: 3.10 -Classifier: Programming Language :: Python :: Implementation :: CPython -Classifier: Programming Language :: Python :: Implementation :: PyPy -Classifier: Topic :: Internet :: WWW/HTTP -Classifier: Topic :: Software Development :: Libraries -Requires-Python: >=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*, !=3.4.*, <4 -Description-Content-Type: text/x-rst -License-File: LICENSE.txt -Provides-Extra: brotli -Requires-Dist: brotlipy (>=0.6.0) ; extra == 'brotli' -Provides-Extra: secure -Requires-Dist: pyOpenSSL (>=0.14) ; extra == 'secure' -Requires-Dist: cryptography (>=1.3.4) ; extra == 'secure' -Requires-Dist: idna (>=2.0.0) ; extra == 'secure' -Requires-Dist: certifi ; extra == 'secure' -Requires-Dist: ipaddress ; (python_version == "2.7") and extra == 'secure' -Provides-Extra: socks -Requires-Dist: PySocks (!=1.5.7,<2.0,>=1.5.6) ; extra == 'socks' - - -urllib3 is a powerful, *user-friendly* HTTP client for Python. Much of the -Python ecosystem already uses urllib3 and you should too. -urllib3 brings many critical features that are missing from the Python -standard libraries: - -- Thread safety. -- Connection pooling. -- Client-side SSL/TLS verification. -- File uploads with multipart encoding. -- Helpers for retrying requests and dealing with HTTP redirects. -- Support for gzip, deflate, and brotli encoding. -- Proxy support for HTTP and SOCKS. -- 100% test coverage. - -urllib3 is powerful and easy to use: - -.. code-block:: python - - >>> import urllib3 - >>> http = urllib3.PoolManager() - >>> r = http.request('GET', 'http://httpbin.org/robots.txt') - >>> r.status - 200 - >>> r.data - 'User-agent: *\nDisallow: /deny\n' - - -Installing ----------- - -urllib3 can be installed with `pip `_:: - - $ python -m pip install urllib3 - -Alternatively, you can grab the latest source code from `GitHub `_:: - - $ git clone git://github.com/urllib3/urllib3.git - $ python setup.py install - - -Documentation -------------- - -urllib3 has usage and reference documentation at `urllib3.readthedocs.io `_. - - -Contributing ------------- - -urllib3 happily accepts contributions. Please see our -`contributing documentation `_ -for some tips on getting started. - - -Security Disclosures --------------------- - -To report a security vulnerability, please use the -`Tidelift security contact `_. -Tidelift will coordinate the fix and disclosure with maintainers. - - -Maintainers ------------ - -- `@sethmlarson `__ (Seth M. Larson) -- `@pquentin `__ (Quentin Pradet) -- `@theacodes `__ (Thea Flowers) -- `@haikuginger `__ (Jess Shapiro) -- `@lukasa `__ (Cory Benfield) -- `@sigmavirus24 `__ (Ian Stapleton Cordasco) -- `@shazow `__ (Andrey Petrov) - -👋 - - -Sponsorship ------------ - -If your company benefits from this library, please consider `sponsoring its -development `_. - - -For Enterprise --------------- - -.. |tideliftlogo| image:: https://nedbatchelder.com/pix/Tidelift_Logos_RGB_Tidelift_Shorthand_On-White_small.png - :width: 75 - :alt: Tidelift - -.. list-table:: - :widths: 10 100 - - * - |tideliftlogo| - - Professional support for urllib3 is available as part of the `Tidelift - Subscription`_. Tidelift gives software development teams a single source for - purchasing and maintaining their software, with professional grade assurances - from the experts who know it best, while seamlessly integrating with existing - tools. - -.. _Tidelift Subscription: https://tidelift.com/subscription/pkg/pypi-urllib3?utm_source=pypi-urllib3&utm_medium=referral&utm_campaign=readme - - -Changes -======= - -1.26.6 (2021-06-25) -------------------- - -* Deprecated the ``urllib3.contrib.ntlmpool`` module. urllib3 is not able to support - it properly due to `reasons listed in this issue `_. - If you are a user of this module please leave a comment. -* Changed ``HTTPConnection.request_chunked()`` to not erroneously emit multiple - ``Transfer-Encoding`` headers in the case that one is already specified. -* Fixed typo in deprecation message to recommend ``Retry.DEFAULT_ALLOWED_METHODS``. - - -1.26.5 (2021-05-26) -------------------- - -* Fixed deprecation warnings emitted in Python 3.10. -* Updated vendored ``six`` library to 1.16.0. -* Improved performance of URL parser when splitting - the authority component. - - -1.26.4 (2021-03-15) -------------------- - -* Changed behavior of the default ``SSLContext`` when connecting to HTTPS proxy - during HTTPS requests. The default ``SSLContext`` now sets ``check_hostname=True``. - - -1.26.3 (2021-01-26) -------------------- - -* Fixed bytes and string comparison issue with headers (Pull #2141) - -* Changed ``ProxySchemeUnknown`` error message to be - more actionable if the user supplies a proxy URL without - a scheme. (Pull #2107) - - -1.26.2 (2020-11-12) -------------------- - -* Fixed an issue where ``wrap_socket`` and ``CERT_REQUIRED`` wouldn't - be imported properly on Python 2.7.8 and earlier (Pull #2052) - - -1.26.1 (2020-11-11) -------------------- - -* Fixed an issue where two ``User-Agent`` headers would be sent if a - ``User-Agent`` header key is passed as ``bytes`` (Pull #2047) - - -1.26.0 (2020-11-10) -------------------- - -* **NOTE: urllib3 v2.0 will drop support for Python 2**. - `Read more in the v2.0 Roadmap `_. - -* Added support for HTTPS proxies contacting HTTPS servers (Pull #1923, Pull #1806) - -* Deprecated negotiating TLSv1 and TLSv1.1 by default. Users that - still wish to use TLS earlier than 1.2 without a deprecation warning - should opt-in explicitly by setting ``ssl_version=ssl.PROTOCOL_TLSv1_1`` (Pull #2002) - **Starting in urllib3 v2.0: Connections that receive a ``DeprecationWarning`` will fail** - -* Deprecated ``Retry`` options ``Retry.DEFAULT_METHOD_WHITELIST``, ``Retry.DEFAULT_REDIRECT_HEADERS_BLACKLIST`` - and ``Retry(method_whitelist=...)`` in favor of ``Retry.DEFAULT_ALLOWED_METHODS``, - ``Retry.DEFAULT_REMOVE_HEADERS_ON_REDIRECT``, and ``Retry(allowed_methods=...)`` - (Pull #2000) **Starting in urllib3 v2.0: Deprecated options will be removed** - -* Added default ``User-Agent`` header to every request (Pull #1750) - -* Added ``urllib3.util.SKIP_HEADER`` for skipping ``User-Agent``, ``Accept-Encoding``, - and ``Host`` headers from being automatically emitted with requests (Pull #2018) - -* Collapse ``transfer-encoding: chunked`` request data and framing into - the same ``socket.send()`` call (Pull #1906) - -* Send ``http/1.1`` ALPN identifier with every TLS handshake by default (Pull #1894) - -* Properly terminate SecureTransport connections when CA verification fails (Pull #1977) - -* Don't emit an ``SNIMissingWarning`` when passing ``server_hostname=None`` - to SecureTransport (Pull #1903) - -* Disabled requesting TLSv1.2 session tickets as they weren't being used by urllib3 (Pull #1970) - -* Suppress ``BrokenPipeError`` when writing request body after the server - has closed the socket (Pull #1524) - -* Wrap ``ssl.SSLError`` that can be raised from reading a socket (e.g. "bad MAC") - into an ``urllib3.exceptions.SSLError`` (Pull #1939) - - -1.25.11 (2020-10-19) --------------------- - -* Fix retry backoff time parsed from ``Retry-After`` header when given - in the HTTP date format. The HTTP date was parsed as the local timezone - rather than accounting for the timezone in the HTTP date (typically - UTC) (Pull #1932, Pull #1935, Pull #1938, Pull #1949) - -* Fix issue where an error would be raised when the ``SSLKEYLOGFILE`` - environment variable was set to the empty string. Now ``SSLContext.keylog_file`` - is not set in this situation (Pull #2016) - - -1.25.10 (2020-07-22) --------------------- - -* Added support for ``SSLKEYLOGFILE`` environment variable for - logging TLS session keys with use with programs like - Wireshark for decrypting captured web traffic (Pull #1867) - -* Fixed loading of SecureTransport libraries on macOS Big Sur - due to the new dynamic linker cache (Pull #1905) - -* Collapse chunked request bodies data and framing into one - call to ``send()`` to reduce the number of TCP packets by 2-4x (Pull #1906) - -* Don't insert ``None`` into ``ConnectionPool`` if the pool - was empty when requesting a connection (Pull #1866) - -* Avoid ``hasattr`` call in ``BrotliDecoder.decompress()`` (Pull #1858) - - -1.25.9 (2020-04-16) -------------------- - -* Added ``InvalidProxyConfigurationWarning`` which is raised when - erroneously specifying an HTTPS proxy URL. urllib3 doesn't currently - support connecting to HTTPS proxies but will soon be able to - and we would like users to migrate properly without much breakage. - - See `this GitHub issue `_ - for more information on how to fix your proxy config. (Pull #1851) - -* Drain connection after ``PoolManager`` redirect (Pull #1817) - -* Ensure ``load_verify_locations`` raises ``SSLError`` for all backends (Pull #1812) - -* Rename ``VerifiedHTTPSConnection`` to ``HTTPSConnection`` (Pull #1805) - -* Allow the CA certificate data to be passed as a string (Pull #1804) - -* Raise ``ValueError`` if method contains control characters (Pull #1800) - -* Add ``__repr__`` to ``Timeout`` (Pull #1795) - - -1.25.8 (2020-01-20) -------------------- - -* Drop support for EOL Python 3.4 (Pull #1774) - -* Optimize _encode_invalid_chars (Pull #1787) - - -1.25.7 (2019-11-11) -------------------- - -* Preserve ``chunked`` parameter on retries (Pull #1715, Pull #1734) - -* Allow unset ``SERVER_SOFTWARE`` in App Engine (Pull #1704, Issue #1470) - -* Fix issue where URL fragment was sent within the request target. (Pull #1732) - -* Fix issue where an empty query section in a URL would fail to parse. (Pull #1732) - -* Remove TLS 1.3 support in SecureTransport due to Apple removing support (Pull #1703) - - -1.25.6 (2019-09-24) -------------------- - -* Fix issue where tilde (``~``) characters were incorrectly - percent-encoded in the path. (Pull #1692) - - -1.25.5 (2019-09-19) -------------------- - -* Add mitigation for BPO-37428 affecting Python <3.7.4 and OpenSSL 1.1.1+ which - caused certificate verification to be enabled when using ``cert_reqs=CERT_NONE``. - (Issue #1682) - - -1.25.4 (2019-09-19) -------------------- - -* Propagate Retry-After header settings to subsequent retries. (Pull #1607) - -* Fix edge case where Retry-After header was still respected even when - explicitly opted out of. (Pull #1607) - -* Remove dependency on ``rfc3986`` for URL parsing. - -* Fix issue where URLs containing invalid characters within ``Url.auth`` would - raise an exception instead of percent-encoding those characters. - -* Add support for ``HTTPResponse.auto_close = False`` which makes HTTP responses - work well with BufferedReaders and other ``io`` module features. (Pull #1652) - -* Percent-encode invalid characters in URL for ``HTTPConnectionPool.request()`` (Pull #1673) - - -1.25.3 (2019-05-23) -------------------- - -* Change ``HTTPSConnection`` to load system CA certificates - when ``ca_certs``, ``ca_cert_dir``, and ``ssl_context`` are - unspecified. (Pull #1608, Issue #1603) - -* Upgrade bundled rfc3986 to v1.3.2. (Pull #1609, Issue #1605) - - -1.25.2 (2019-04-28) -------------------- - -* Change ``is_ipaddress`` to not detect IPvFuture addresses. (Pull #1583) - -* Change ``parse_url`` to percent-encode invalid characters within the - path, query, and target components. (Pull #1586) - - -1.25.1 (2019-04-24) -------------------- - -* Add support for Google's ``Brotli`` package. (Pull #1572, Pull #1579) - -* Upgrade bundled rfc3986 to v1.3.1 (Pull #1578) - - -1.25 (2019-04-22) ------------------ - -* Require and validate certificates by default when using HTTPS (Pull #1507) - -* Upgraded ``urllib3.utils.parse_url()`` to be RFC 3986 compliant. (Pull #1487) - -* Added support for ``key_password`` for ``HTTPSConnectionPool`` to use - encrypted ``key_file`` without creating your own ``SSLContext`` object. (Pull #1489) - -* Add TLSv1.3 support to CPython, pyOpenSSL, and SecureTransport ``SSLContext`` - implementations. (Pull #1496) - -* Switched the default multipart header encoder from RFC 2231 to HTML 5 working draft. (Issue #303, Pull #1492) - -* Fixed issue where OpenSSL would block if an encrypted client private key was - given and no password was given. Instead an ``SSLError`` is raised. (Pull #1489) - -* Added support for Brotli content encoding. It is enabled automatically if - ``brotlipy`` package is installed which can be requested with - ``urllib3[brotli]`` extra. (Pull #1532) - -* Drop ciphers using DSS key exchange from default TLS cipher suites. - Improve default ciphers when using SecureTransport. (Pull #1496) - -* Implemented a more efficient ``HTTPResponse.__iter__()`` method. (Issue #1483) - -1.24.3 (2019-05-01) -------------------- - -* Apply fix for CVE-2019-9740. (Pull #1591) - -1.24.2 (2019-04-17) -------------------- - -* Don't load system certificates by default when any other ``ca_certs``, ``ca_certs_dir`` or - ``ssl_context`` parameters are specified. - -* Remove Authorization header regardless of case when redirecting to cross-site. (Issue #1510) - -* Add support for IPv6 addresses in subjectAltName section of certificates. (Issue #1269) - - -1.24.1 (2018-11-02) -------------------- - -* Remove quadratic behavior within ``GzipDecoder.decompress()`` (Issue #1467) - -* Restored functionality of ``ciphers`` parameter for ``create_urllib3_context()``. (Issue #1462) - - -1.24 (2018-10-16) ------------------ - -* Allow key_server_hostname to be specified when initializing a PoolManager to allow custom SNI to be overridden. (Pull #1449) - -* Test against Python 3.7 on AppVeyor. (Pull #1453) - -* Early-out ipv6 checks when running on App Engine. (Pull #1450) - -* Change ambiguous description of backoff_factor (Pull #1436) - -* Add ability to handle multiple Content-Encodings (Issue #1441 and Pull #1442) - -* Skip DNS names that can't be idna-decoded when using pyOpenSSL (Issue #1405). - -* Add a server_hostname parameter to HTTPSConnection which allows for - overriding the SNI hostname sent in the handshake. (Pull #1397) - -* Drop support for EOL Python 2.6 (Pull #1429 and Pull #1430) - -* Fixed bug where responses with header Content-Type: message/* erroneously - raised HeaderParsingError, resulting in a warning being logged. (Pull #1439) - -* Move urllib3 to src/urllib3 (Pull #1409) - - -1.23 (2018-06-04) ------------------ - -* Allow providing a list of headers to strip from requests when redirecting - to a different host. Defaults to the ``Authorization`` header. Different - headers can be set via ``Retry.remove_headers_on_redirect``. (Issue #1316) - -* Fix ``util.selectors._fileobj_to_fd`` to accept ``long`` (Issue #1247). - -* Dropped Python 3.3 support. (Pull #1242) - -* Put the connection back in the pool when calling stream() or read_chunked() on - a chunked HEAD response. (Issue #1234) - -* Fixed pyOpenSSL-specific ssl client authentication issue when clients - attempted to auth via certificate + chain (Issue #1060) - -* Add the port to the connectionpool connect print (Pull #1251) - -* Don't use the ``uuid`` module to create multipart data boundaries. (Pull #1380) - -* ``read_chunked()`` on a closed response returns no chunks. (Issue #1088) - -* Add Python 2.6 support to ``contrib.securetransport`` (Pull #1359) - -* Added support for auth info in url for SOCKS proxy (Pull #1363) - - -1.22 (2017-07-20) ------------------ - -* Fixed missing brackets in ``HTTP CONNECT`` when connecting to IPv6 address via - IPv6 proxy. (Issue #1222) - -* Made the connection pool retry on ``SSLError``. The original ``SSLError`` - is available on ``MaxRetryError.reason``. (Issue #1112) - -* Drain and release connection before recursing on retry/redirect. Fixes - deadlocks with a blocking connectionpool. (Issue #1167) - -* Fixed compatibility for cookiejar. (Issue #1229) - -* pyopenssl: Use vendored version of ``six``. (Issue #1231) - - -1.21.1 (2017-05-02) -------------------- - -* Fixed SecureTransport issue that would cause long delays in response body - delivery. (Pull #1154) - -* Fixed regression in 1.21 that threw exceptions when users passed the - ``socket_options`` flag to the ``PoolManager``. (Issue #1165) - -* Fixed regression in 1.21 that threw exceptions when users passed the - ``assert_hostname`` or ``assert_fingerprint`` flag to the ``PoolManager``. - (Pull #1157) - - -1.21 (2017-04-25) ------------------ - -* Improved performance of certain selector system calls on Python 3.5 and - later. (Pull #1095) - -* Resolved issue where the PyOpenSSL backend would not wrap SysCallError - exceptions appropriately when sending data. (Pull #1125) - -* Selectors now detects a monkey-patched select module after import for modules - that patch the select module like eventlet, greenlet. (Pull #1128) - -* Reduced memory consumption when streaming zlib-compressed responses - (as opposed to raw deflate streams). (Pull #1129) - -* Connection pools now use the entire request context when constructing the - pool key. (Pull #1016) - -* ``PoolManager.connection_from_*`` methods now accept a new keyword argument, - ``pool_kwargs``, which are merged with the existing ``connection_pool_kw``. - (Pull #1016) - -* Add retry counter for ``status_forcelist``. (Issue #1147) - -* Added ``contrib`` module for using SecureTransport on macOS: - ``urllib3.contrib.securetransport``. (Pull #1122) - -* urllib3 now only normalizes the case of ``http://`` and ``https://`` schemes: - for schemes it does not recognise, it assumes they are case-sensitive and - leaves them unchanged. - (Issue #1080) - - -1.20 (2017-01-19) ------------------ - -* Added support for waiting for I/O using selectors other than select, - improving urllib3's behaviour with large numbers of concurrent connections. - (Pull #1001) - -* Updated the date for the system clock check. (Issue #1005) - -* ConnectionPools now correctly consider hostnames to be case-insensitive. - (Issue #1032) - -* Outdated versions of PyOpenSSL now cause the PyOpenSSL contrib module - to fail when it is injected, rather than at first use. (Pull #1063) - -* Outdated versions of cryptography now cause the PyOpenSSL contrib module - to fail when it is injected, rather than at first use. (Issue #1044) - -* Automatically attempt to rewind a file-like body object when a request is - retried or redirected. (Pull #1039) - -* Fix some bugs that occur when modules incautiously patch the queue module. - (Pull #1061) - -* Prevent retries from occurring on read timeouts for which the request method - was not in the method whitelist. (Issue #1059) - -* Changed the PyOpenSSL contrib module to lazily load idna to avoid - unnecessarily bloating the memory of programs that don't need it. (Pull - #1076) - -* Add support for IPv6 literals with zone identifiers. (Pull #1013) - -* Added support for socks5h:// and socks4a:// schemes when working with SOCKS - proxies, and controlled remote DNS appropriately. (Issue #1035) - - -1.19.1 (2016-11-16) -------------------- - -* Fixed AppEngine import that didn't function on Python 3.5. (Pull #1025) - - -1.19 (2016-11-03) ------------------ - -* urllib3 now respects Retry-After headers on 413, 429, and 503 responses when - using the default retry logic. (Pull #955) - -* Remove markers from setup.py to assist ancient setuptools versions. (Issue - #986) - -* Disallow superscripts and other integerish things in URL ports. (Issue #989) - -* Allow urllib3's HTTPResponse.stream() method to continue to work with - non-httplib underlying FPs. (Pull #990) - -* Empty filenames in multipart headers are now emitted as such, rather than - being suppressed. (Issue #1015) - -* Prefer user-supplied Host headers on chunked uploads. (Issue #1009) - - -1.18.1 (2016-10-27) -------------------- - -* CVE-2016-9015. Users who are using urllib3 version 1.17 or 1.18 along with - PyOpenSSL injection and OpenSSL 1.1.0 *must* upgrade to this version. This - release fixes a vulnerability whereby urllib3 in the above configuration - would silently fail to validate TLS certificates due to erroneously setting - invalid flags in OpenSSL's ``SSL_CTX_set_verify`` function. These erroneous - flags do not cause a problem in OpenSSL versions before 1.1.0, which - interprets the presence of any flag as requesting certificate validation. - - There is no PR for this patch, as it was prepared for simultaneous disclosure - and release. The master branch received the same fix in Pull #1010. - - -1.18 (2016-09-26) ------------------ - -* Fixed incorrect message for IncompleteRead exception. (Pull #973) - -* Accept ``iPAddress`` subject alternative name fields in TLS certificates. - (Issue #258) - -* Fixed consistency of ``HTTPResponse.closed`` between Python 2 and 3. - (Issue #977) - -* Fixed handling of wildcard certificates when using PyOpenSSL. (Issue #979) - - -1.17 (2016-09-06) ------------------ - -* Accept ``SSLContext`` objects for use in SSL/TLS negotiation. (Issue #835) - -* ConnectionPool debug log now includes scheme, host, and port. (Issue #897) - -* Substantially refactored documentation. (Issue #887) - -* Used URLFetch default timeout on AppEngine, rather than hardcoding our own. - (Issue #858) - -* Normalize the scheme and host in the URL parser (Issue #833) - -* ``HTTPResponse`` contains the last ``Retry`` object, which now also - contains retries history. (Issue #848) - -* Timeout can no longer be set as boolean, and must be greater than zero. - (Pull #924) - -* Removed pyasn1 and ndg-httpsclient from dependencies used for PyOpenSSL. We - now use cryptography and idna, both of which are already dependencies of - PyOpenSSL. (Pull #930) - -* Fixed infinite loop in ``stream`` when amt=None. (Issue #928) - -* Try to use the operating system's certificates when we are using an - ``SSLContext``. (Pull #941) - -* Updated cipher suite list to allow ChaCha20+Poly1305. AES-GCM is preferred to - ChaCha20, but ChaCha20 is then preferred to everything else. (Pull #947) - -* Updated cipher suite list to remove 3DES-based cipher suites. (Pull #958) - -* Removed the cipher suite fallback to allow HIGH ciphers. (Pull #958) - -* Implemented ``length_remaining`` to determine remaining content - to be read. (Pull #949) - -* Implemented ``enforce_content_length`` to enable exceptions when - incomplete data chunks are received. (Pull #949) - -* Dropped connection start, dropped connection reset, redirect, forced retry, - and new HTTPS connection log levels to DEBUG, from INFO. (Pull #967) - - -1.16 (2016-06-11) ------------------ - -* Disable IPv6 DNS when IPv6 connections are not possible. (Issue #840) - -* Provide ``key_fn_by_scheme`` pool keying mechanism that can be - overridden. (Issue #830) - -* Normalize scheme and host to lowercase for pool keys, and include - ``source_address``. (Issue #830) - -* Cleaner exception chain in Python 3 for ``_make_request``. - (Issue #861) - -* Fixed installing ``urllib3[socks]`` extra. (Issue #864) - -* Fixed signature of ``ConnectionPool.close`` so it can actually safely be - called by subclasses. (Issue #873) - -* Retain ``release_conn`` state across retries. (Issues #651, #866) - -* Add customizable ``HTTPConnectionPool.ResponseCls``, which defaults to - ``HTTPResponse`` but can be replaced with a subclass. (Issue #879) - - -1.15.1 (2016-04-11) -------------------- - -* Fix packaging to include backports module. (Issue #841) - - -1.15 (2016-04-06) ------------------ - -* Added Retry(raise_on_status=False). (Issue #720) - -* Always use setuptools, no more distutils fallback. (Issue #785) - -* Dropped support for Python 3.2. (Issue #786) - -* Chunked transfer encoding when requesting with ``chunked=True``. - (Issue #790) - -* Fixed regression with IPv6 port parsing. (Issue #801) - -* Append SNIMissingWarning messages to allow users to specify it in - the PYTHONWARNINGS environment variable. (Issue #816) - -* Handle unicode headers in Py2. (Issue #818) - -* Log certificate when there is a hostname mismatch. (Issue #820) - -* Preserve order of request/response headers. (Issue #821) - - -1.14 (2015-12-29) ------------------ - -* contrib: SOCKS proxy support! (Issue #762) - -* Fixed AppEngine handling of transfer-encoding header and bug - in Timeout defaults checking. (Issue #763) - - -1.13.1 (2015-12-18) -------------------- - -* Fixed regression in IPv6 + SSL for match_hostname. (Issue #761) - - -1.13 (2015-12-14) ------------------ - -* Fixed ``pip install urllib3[secure]`` on modern pip. (Issue #706) - -* pyopenssl: Fixed SSL3_WRITE_PENDING error. (Issue #717) - -* pyopenssl: Support for TLSv1.1 and TLSv1.2. (Issue #696) - -* Close connections more defensively on exception. (Issue #734) - -* Adjusted ``read_chunked`` to handle gzipped, chunk-encoded bodies without - repeatedly flushing the decoder, to function better on Jython. (Issue #743) - -* Accept ``ca_cert_dir`` for SSL-related PoolManager configuration. (Issue #758) - - -1.12 (2015-09-03) ------------------ - -* Rely on ``six`` for importing ``httplib`` to work around - conflicts with other Python 3 shims. (Issue #688) - -* Add support for directories of certificate authorities, as supported by - OpenSSL. (Issue #701) - -* New exception: ``NewConnectionError``, raised when we fail to establish - a new connection, usually ``ECONNREFUSED`` socket error. - - -1.11 (2015-07-21) ------------------ - -* When ``ca_certs`` is given, ``cert_reqs`` defaults to - ``'CERT_REQUIRED'``. (Issue #650) - -* ``pip install urllib3[secure]`` will install Certifi and - PyOpenSSL as dependencies. (Issue #678) - -* Made ``HTTPHeaderDict`` usable as a ``headers`` input value - (Issues #632, #679) - -* Added `urllib3.contrib.appengine `_ - which has an ``AppEngineManager`` for using ``URLFetch`` in a - Google AppEngine environment. (Issue #664) - -* Dev: Added test suite for AppEngine. (Issue #631) - -* Fix performance regression when using PyOpenSSL. (Issue #626) - -* Passing incorrect scheme (e.g. ``foo://``) will raise - ``ValueError`` instead of ``AssertionError`` (backwards - compatible for now, but please migrate). (Issue #640) - -* Fix pools not getting replenished when an error occurs during a - request using ``release_conn=False``. (Issue #644) - -* Fix pool-default headers not applying for url-encoded requests - like GET. (Issue #657) - -* log.warning in Python 3 when headers are skipped due to parsing - errors. (Issue #642) - -* Close and discard connections if an error occurs during read. - (Issue #660) - -* Fix host parsing for IPv6 proxies. (Issue #668) - -* Separate warning type SubjectAltNameWarning, now issued once - per host. (Issue #671) - -* Fix ``httplib.IncompleteRead`` not getting converted to - ``ProtocolError`` when using ``HTTPResponse.stream()`` - (Issue #674) - -1.10.4 (2015-05-03) -------------------- - -* Migrate tests to Tornado 4. (Issue #594) - -* Append default warning configuration rather than overwrite. - (Issue #603) - -* Fix streaming decoding regression. (Issue #595) - -* Fix chunked requests losing state across keep-alive connections. - (Issue #599) - -* Fix hanging when chunked HEAD response has no body. (Issue #605) - - -1.10.3 (2015-04-21) -------------------- - -* Emit ``InsecurePlatformWarning`` when SSLContext object is missing. - (Issue #558) - -* Fix regression of duplicate header keys being discarded. - (Issue #563) - -* ``Response.stream()`` returns a generator for chunked responses. - (Issue #560) - -* Set upper-bound timeout when waiting for a socket in PyOpenSSL. - (Issue #585) - -* Work on platforms without `ssl` module for plain HTTP requests. - (Issue #587) - -* Stop relying on the stdlib's default cipher list. (Issue #588) - - -1.10.2 (2015-02-25) -------------------- - -* Fix file descriptor leakage on retries. (Issue #548) - -* Removed RC4 from default cipher list. (Issue #551) - -* Header performance improvements. (Issue #544) - -* Fix PoolManager not obeying redirect retry settings. (Issue #553) - - -1.10.1 (2015-02-10) -------------------- - -* Pools can be used as context managers. (Issue #545) - -* Don't re-use connections which experienced an SSLError. (Issue #529) - -* Don't fail when gzip decoding an empty stream. (Issue #535) - -* Add sha256 support for fingerprint verification. (Issue #540) - -* Fixed handling of header values containing commas. (Issue #533) - - -1.10 (2014-12-14) ------------------ - -* Disabled SSLv3. (Issue #473) - -* Add ``Url.url`` property to return the composed url string. (Issue #394) - -* Fixed PyOpenSSL + gevent ``WantWriteError``. (Issue #412) - -* ``MaxRetryError.reason`` will always be an exception, not string. - (Issue #481) - -* Fixed SSL-related timeouts not being detected as timeouts. (Issue #492) - -* Py3: Use ``ssl.create_default_context()`` when available. (Issue #473) - -* Emit ``InsecureRequestWarning`` for *every* insecure HTTPS request. - (Issue #496) - -* Emit ``SecurityWarning`` when certificate has no ``subjectAltName``. - (Issue #499) - -* Close and discard sockets which experienced SSL-related errors. - (Issue #501) - -* Handle ``body`` param in ``.request(...)``. (Issue #513) - -* Respect timeout with HTTPS proxy. (Issue #505) - -* PyOpenSSL: Handle ZeroReturnError exception. (Issue #520) - - -1.9.1 (2014-09-13) ------------------- - -* Apply socket arguments before binding. (Issue #427) - -* More careful checks if fp-like object is closed. (Issue #435) - -* Fixed packaging issues of some development-related files not - getting included. (Issue #440) - -* Allow performing *only* fingerprint verification. (Issue #444) - -* Emit ``SecurityWarning`` if system clock is waaay off. (Issue #445) - -* Fixed PyOpenSSL compatibility with PyPy. (Issue #450) - -* Fixed ``BrokenPipeError`` and ``ConnectionError`` handling in Py3. - (Issue #443) - - - -1.9 (2014-07-04) ----------------- - -* Shuffled around development-related files. If you're maintaining a distro - package of urllib3, you may need to tweak things. (Issue #415) - -* Unverified HTTPS requests will trigger a warning on the first request. See - our new `security documentation - `_ for details. - (Issue #426) - -* New retry logic and ``urllib3.util.retry.Retry`` configuration object. - (Issue #326) - -* All raised exceptions should now wrapped in a - ``urllib3.exceptions.HTTPException``-extending exception. (Issue #326) - -* All errors during a retry-enabled request should be wrapped in - ``urllib3.exceptions.MaxRetryError``, including timeout-related exceptions - which were previously exempt. Underlying error is accessible from the - ``.reason`` property. (Issue #326) - -* ``urllib3.exceptions.ConnectionError`` renamed to - ``urllib3.exceptions.ProtocolError``. (Issue #326) - -* Errors during response read (such as IncompleteRead) are now wrapped in - ``urllib3.exceptions.ProtocolError``. (Issue #418) - -* Requesting an empty host will raise ``urllib3.exceptions.LocationValueError``. - (Issue #417) - -* Catch read timeouts over SSL connections as - ``urllib3.exceptions.ReadTimeoutError``. (Issue #419) - -* Apply socket arguments before connecting. (Issue #427) - - -1.8.3 (2014-06-23) ------------------- - -* Fix TLS verification when using a proxy in Python 3.4.1. (Issue #385) - -* Add ``disable_cache`` option to ``urllib3.util.make_headers``. (Issue #393) - -* Wrap ``socket.timeout`` exception with - ``urllib3.exceptions.ReadTimeoutError``. (Issue #399) - -* Fixed proxy-related bug where connections were being reused incorrectly. - (Issues #366, #369) - -* Added ``socket_options`` keyword parameter which allows to define - ``setsockopt`` configuration of new sockets. (Issue #397) - -* Removed ``HTTPConnection.tcp_nodelay`` in favor of - ``HTTPConnection.default_socket_options``. (Issue #397) - -* Fixed ``TypeError`` bug in Python 2.6.4. (Issue #411) - - -1.8.2 (2014-04-17) ------------------- - -* Fix ``urllib3.util`` not being included in the package. - - -1.8.1 (2014-04-17) ------------------- - -* Fix AppEngine bug of HTTPS requests going out as HTTP. (Issue #356) - -* Don't install ``dummyserver`` into ``site-packages`` as it's only needed - for the test suite. (Issue #362) - -* Added support for specifying ``source_address``. (Issue #352) - - -1.8 (2014-03-04) ----------------- - -* Improved url parsing in ``urllib3.util.parse_url`` (properly parse '@' in - username, and blank ports like 'hostname:'). - -* New ``urllib3.connection`` module which contains all the HTTPConnection - objects. - -* Several ``urllib3.util.Timeout``-related fixes. Also changed constructor - signature to a more sensible order. [Backwards incompatible] - (Issues #252, #262, #263) - -* Use ``backports.ssl_match_hostname`` if it's installed. (Issue #274) - -* Added ``.tell()`` method to ``urllib3.response.HTTPResponse`` which - returns the number of bytes read so far. (Issue #277) - -* Support for platforms without threading. (Issue #289) - -* Expand default-port comparison in ``HTTPConnectionPool.is_same_host`` - to allow a pool with no specified port to be considered equal to to an - HTTP/HTTPS url with port 80/443 explicitly provided. (Issue #305) - -* Improved default SSL/TLS settings to avoid vulnerabilities. - (Issue #309) - -* Fixed ``urllib3.poolmanager.ProxyManager`` not retrying on connect errors. - (Issue #310) - -* Disable Nagle's Algorithm on the socket for non-proxies. A subset of requests - will send the entire HTTP request ~200 milliseconds faster; however, some of - the resulting TCP packets will be smaller. (Issue #254) - -* Increased maximum number of SubjectAltNames in ``urllib3.contrib.pyopenssl`` - from the default 64 to 1024 in a single certificate. (Issue #318) - -* Headers are now passed and stored as a custom - ``urllib3.collections_.HTTPHeaderDict`` object rather than a plain ``dict``. - (Issue #329, #333) - -* Headers no longer lose their case on Python 3. (Issue #236) - -* ``urllib3.contrib.pyopenssl`` now uses the operating system's default CA - certificates on inject. (Issue #332) - -* Requests with ``retries=False`` will immediately raise any exceptions without - wrapping them in ``MaxRetryError``. (Issue #348) - -* Fixed open socket leak with SSL-related failures. (Issue #344, #348) - - -1.7.1 (2013-09-25) ------------------- - -* Added granular timeout support with new ``urllib3.util.Timeout`` class. - (Issue #231) - -* Fixed Python 3.4 support. (Issue #238) - - -1.7 (2013-08-14) ----------------- - -* More exceptions are now pickle-able, with tests. (Issue #174) - -* Fixed redirecting with relative URLs in Location header. (Issue #178) - -* Support for relative urls in ``Location: ...`` header. (Issue #179) - -* ``urllib3.response.HTTPResponse`` now inherits from ``io.IOBase`` for bonus - file-like functionality. (Issue #187) - -* Passing ``assert_hostname=False`` when creating a HTTPSConnectionPool will - skip hostname verification for SSL connections. (Issue #194) - -* New method ``urllib3.response.HTTPResponse.stream(...)`` which acts as a - generator wrapped around ``.read(...)``. (Issue #198) - -* IPv6 url parsing enforces brackets around the hostname. (Issue #199) - -* Fixed thread race condition in - ``urllib3.poolmanager.PoolManager.connection_from_host(...)`` (Issue #204) - -* ``ProxyManager`` requests now include non-default port in ``Host: ...`` - header. (Issue #217) - -* Added HTTPS proxy support in ``ProxyManager``. (Issue #170 #139) - -* New ``RequestField`` object can be passed to the ``fields=...`` param which - can specify headers. (Issue #220) - -* Raise ``urllib3.exceptions.ProxyError`` when connecting to proxy fails. - (Issue #221) - -* Use international headers when posting file names. (Issue #119) - -* Improved IPv6 support. (Issue #203) - - -1.6 (2013-04-25) ----------------- - -* Contrib: Optional SNI support for Py2 using PyOpenSSL. (Issue #156) - -* ``ProxyManager`` automatically adds ``Host: ...`` header if not given. - -* Improved SSL-related code. ``cert_req`` now optionally takes a string like - "REQUIRED" or "NONE". Same with ``ssl_version`` takes strings like "SSLv23" - The string values reflect the suffix of the respective constant variable. - (Issue #130) - -* Vendored ``socksipy`` now based on Anorov's fork which handles unexpectedly - closed proxy connections and larger read buffers. (Issue #135) - -* Ensure the connection is closed if no data is received, fixes connection leak - on some platforms. (Issue #133) - -* Added SNI support for SSL/TLS connections on Py32+. (Issue #89) - -* Tests fixed to be compatible with Py26 again. (Issue #125) - -* Added ability to choose SSL version by passing an ``ssl.PROTOCOL_*`` constant - to the ``ssl_version`` parameter of ``HTTPSConnectionPool``. (Issue #109) - -* Allow an explicit content type to be specified when encoding file fields. - (Issue #126) - -* Exceptions are now pickleable, with tests. (Issue #101) - -* Fixed default headers not getting passed in some cases. (Issue #99) - -* Treat "content-encoding" header value as case-insensitive, per RFC 2616 - Section 3.5. (Issue #110) - -* "Connection Refused" SocketErrors will get retried rather than raised. - (Issue #92) - -* Updated vendored ``six``, no longer overrides the global ``six`` module - namespace. (Issue #113) - -* ``urllib3.exceptions.MaxRetryError`` contains a ``reason`` property holding - the exception that prompted the final retry. If ``reason is None`` then it - was due to a redirect. (Issue #92, #114) - -* Fixed ``PoolManager.urlopen()`` from not redirecting more than once. - (Issue #149) - -* Don't assume ``Content-Type: text/plain`` for multi-part encoding parameters - that are not files. (Issue #111) - -* Pass `strict` param down to ``httplib.HTTPConnection``. (Issue #122) - -* Added mechanism to verify SSL certificates by fingerprint (md5, sha1) or - against an arbitrary hostname (when connecting by IP or for misconfigured - servers). (Issue #140) - -* Streaming decompression support. (Issue #159) - - -1.5 (2012-08-02) ----------------- - -* Added ``urllib3.add_stderr_logger()`` for quickly enabling STDERR debug - logging in urllib3. - -* Native full URL parsing (including auth, path, query, fragment) available in - ``urllib3.util.parse_url(url)``. - -* Built-in redirect will switch method to 'GET' if status code is 303. - (Issue #11) - -* ``urllib3.PoolManager`` strips the scheme and host before sending the request - uri. (Issue #8) - -* New ``urllib3.exceptions.DecodeError`` exception for when automatic decoding, - based on the Content-Type header, fails. - -* Fixed bug with pool depletion and leaking connections (Issue #76). Added - explicit connection closing on pool eviction. Added - ``urllib3.PoolManager.clear()``. - -* 99% -> 100% unit test coverage. - - -1.4 (2012-06-16) ----------------- - -* Minor AppEngine-related fixes. - -* Switched from ``mimetools.choose_boundary`` to ``uuid.uuid4()``. - -* Improved url parsing. (Issue #73) - -* IPv6 url support. (Issue #72) - - -1.3 (2012-03-25) ----------------- - -* Removed pre-1.0 deprecated API. - -* Refactored helpers into a ``urllib3.util`` submodule. - -* Fixed multipart encoding to support list-of-tuples for keys with multiple - values. (Issue #48) - -* Fixed multiple Set-Cookie headers in response not getting merged properly in - Python 3. (Issue #53) - -* AppEngine support with Py27. (Issue #61) - -* Minor ``encode_multipart_formdata`` fixes related to Python 3 strings vs - bytes. - - -1.2.2 (2012-02-06) ------------------- - -* Fixed packaging bug of not shipping ``test-requirements.txt``. (Issue #47) - - -1.2.1 (2012-02-05) ------------------- - -* Fixed another bug related to when ``ssl`` module is not available. (Issue #41) - -* Location parsing errors now raise ``urllib3.exceptions.LocationParseError`` - which inherits from ``ValueError``. - - -1.2 (2012-01-29) ----------------- - -* Added Python 3 support (tested on 3.2.2) - -* Dropped Python 2.5 support (tested on 2.6.7, 2.7.2) - -* Use ``select.poll`` instead of ``select.select`` for platforms that support - it. - -* Use ``Queue.LifoQueue`` instead of ``Queue.Queue`` for more aggressive - connection reusing. Configurable by overriding ``ConnectionPool.QueueCls``. - -* Fixed ``ImportError`` during install when ``ssl`` module is not available. - (Issue #41) - -* Fixed ``PoolManager`` redirects between schemes (such as HTTP -> HTTPS) not - completing properly. (Issue #28, uncovered by Issue #10 in v1.1) - -* Ported ``dummyserver`` to use ``tornado`` instead of ``webob`` + - ``eventlet``. Removed extraneous unsupported dummyserver testing backends. - Added socket-level tests. - -* More tests. Achievement Unlocked: 99% Coverage. - - -1.1 (2012-01-07) ----------------- - -* Refactored ``dummyserver`` to its own root namespace module (used for - testing). - -* Added hostname verification for ``VerifiedHTTPSConnection`` by vendoring in - Py32's ``ssl_match_hostname``. (Issue #25) - -* Fixed cross-host HTTP redirects when using ``PoolManager``. (Issue #10) - -* Fixed ``decode_content`` being ignored when set through ``urlopen``. (Issue - #27) - -* Fixed timeout-related bugs. (Issues #17, #23) - - -1.0.2 (2011-11-04) ------------------- - -* Fixed typo in ``VerifiedHTTPSConnection`` which would only present as a bug if - you're using the object manually. (Thanks pyos) - -* Made RecentlyUsedContainer (and consequently PoolManager) more thread-safe by - wrapping the access log in a mutex. (Thanks @christer) - -* Made RecentlyUsedContainer more dict-like (corrected ``__delitem__`` and - ``__getitem__`` behaviour), with tests. Shouldn't affect core urllib3 code. - - -1.0.1 (2011-10-10) ------------------- - -* Fixed a bug where the same connection would get returned into the pool twice, - causing extraneous "HttpConnectionPool is full" log warnings. - - -1.0 (2011-10-08) ----------------- - -* Added ``PoolManager`` with LRU expiration of connections (tested and - documented). -* Added ``ProxyManager`` (needs tests, docs, and confirmation that it works - with HTTPS proxies). -* Added optional partial-read support for responses when - ``preload_content=False``. You can now make requests and just read the headers - without loading the content. -* Made response decoding optional (default on, same as before). -* Added optional explicit boundary string for ``encode_multipart_formdata``. -* Convenience request methods are now inherited from ``RequestMethods``. Old - helpers like ``get_url`` and ``post_url`` should be abandoned in favour of - the new ``request(method, url, ...)``. -* Refactored code to be even more decoupled, reusable, and extendable. -* License header added to ``.py`` files. -* Embiggened the documentation: Lots of Sphinx-friendly docstrings in the code - and docs in ``docs/`` and on https://urllib3.readthedocs.io/. -* Embettered all the things! -* Started writing this file. - - -0.4.1 (2011-07-17) ------------------- - -* Minor bug fixes, code cleanup. - - -0.4 (2011-03-01) ----------------- - -* Better unicode support. -* Added ``VerifiedHTTPSConnection``. -* Added ``NTLMConnectionPool`` in contrib. -* Minor improvements. - - -0.3.1 (2010-07-13) ------------------- - -* Added ``assert_host_name`` optional parameter. Now compatible with proxies. - - -0.3 (2009-12-10) ----------------- - -* Added HTTPS support. -* Minor bug fixes. -* Refactored, broken backwards compatibility with 0.2. -* API to be treated as stable from this version forward. - - -0.2 (2008-11-17) ----------------- - -* Added unit tests. -* Bug fixes. - - -0.1 (2008-11-16) ----------------- - -* First release. - - diff --git a/venv/lib/python3.8/site-packages/urllib3-1.26.6.dist-info/RECORD b/venv/lib/python3.8/site-packages/urllib3-1.26.6.dist-info/RECORD deleted file mode 100644 index 712b755..0000000 --- a/venv/lib/python3.8/site-packages/urllib3-1.26.6.dist-info/RECORD +++ /dev/null @@ -1,84 +0,0 @@ -urllib3-1.26.6.dist-info/INSTALLER,sha256=zuuue4knoyJ-UwPPXg8fezS7VCrXJQrAP7zeNuwvFQg,4 -urllib3-1.26.6.dist-info/LICENSE.txt,sha256=w3vxhuJ8-dvpYZ5V7f486nswCRzrPaY8fay-Dm13kHs,1115 -urllib3-1.26.6.dist-info/METADATA,sha256=GTqag0OUj9vLryU3xGQO2LJGvkatmJYgTZxnWYT8fpc,44267 -urllib3-1.26.6.dist-info/RECORD,, -urllib3-1.26.6.dist-info/WHEEL,sha256=Z-nyYpwrcSqxfdux5Mbn_DQ525iP7J2DG3JgGvOYyTQ,110 -urllib3-1.26.6.dist-info/top_level.txt,sha256=EMiXL2sKrTcmrMxIHTqdc3ET54pQI2Y072LexFEemvo,8 -urllib3/__init__.py,sha256=j3yzHIbmW7CS-IKQJ9-PPQf_YKO8EOAey_rMW0UR7us,2763 -urllib3/__pycache__/__init__.cpython-38.pyc,, -urllib3/__pycache__/_collections.cpython-38.pyc,, -urllib3/__pycache__/_version.cpython-38.pyc,, -urllib3/__pycache__/connection.cpython-38.pyc,, -urllib3/__pycache__/connectionpool.cpython-38.pyc,, -urllib3/__pycache__/exceptions.cpython-38.pyc,, -urllib3/__pycache__/fields.cpython-38.pyc,, -urllib3/__pycache__/filepost.cpython-38.pyc,, -urllib3/__pycache__/poolmanager.cpython-38.pyc,, -urllib3/__pycache__/request.cpython-38.pyc,, -urllib3/__pycache__/response.cpython-38.pyc,, -urllib3/_collections.py,sha256=Rp1mVyBgc_UlAcp6M3at1skJBXR5J43NawRTvW2g_XY,10811 -urllib3/_version.py,sha256=6fJAIPnJkT0m9wzVjHrFcq5wYt65dStDpaRcjj5ugoo,63 -urllib3/connection.py,sha256=kAlubwsW33FUSUroPSVHMF_Zzv-uzX_BwUFMXX9Pt8c,18754 -urllib3/connectionpool.py,sha256=jXNmm4y3LJWYgteNeGcYJx8-0k7bzKRU__AVTXzaIak,37131 -urllib3/contrib/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -urllib3/contrib/__pycache__/__init__.cpython-38.pyc,, -urllib3/contrib/__pycache__/_appengine_environ.cpython-38.pyc,, -urllib3/contrib/__pycache__/appengine.cpython-38.pyc,, -urllib3/contrib/__pycache__/ntlmpool.cpython-38.pyc,, -urllib3/contrib/__pycache__/pyopenssl.cpython-38.pyc,, -urllib3/contrib/__pycache__/securetransport.cpython-38.pyc,, -urllib3/contrib/__pycache__/socks.cpython-38.pyc,, -urllib3/contrib/_appengine_environ.py,sha256=bDbyOEhW2CKLJcQqAKAyrEHN-aklsyHFKq6vF8ZFsmk,957 -urllib3/contrib/_securetransport/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -urllib3/contrib/_securetransport/__pycache__/__init__.cpython-38.pyc,, -urllib3/contrib/_securetransport/__pycache__/bindings.cpython-38.pyc,, -urllib3/contrib/_securetransport/__pycache__/low_level.cpython-38.pyc,, -urllib3/contrib/_securetransport/bindings.py,sha256=E1_7ScsgOchfxneozbAueK7ziCwF35fna4DuDCYJ9_o,17637 -urllib3/contrib/_securetransport/low_level.py,sha256=lgIdsSycqfB0Xm5BiJzXGeIKT7ybCQMFPJAgkcwPa1s,13908 -urllib3/contrib/appengine.py,sha256=jz515jZYBDFTnhR4zqfeaCo6JdDgAQqYbqzHK9sDkfw,11010 -urllib3/contrib/ntlmpool.py,sha256=ej9gGvfAb2Gt00lafFp45SIoRz-QwrQ4WChm6gQmAlM,4538 -urllib3/contrib/pyopenssl.py,sha256=YIMyTiXiLPV_QfFw3PjZ31mGqJmM5EzxIjhSLxZ7VUM,16874 -urllib3/contrib/securetransport.py,sha256=izdx43gFoUGFSgxasZlOCL42FaM4vSsAVTmhO0EH1vM,34417 -urllib3/contrib/socks.py,sha256=aRi9eWXo9ZEb95XUxef4Z21CFlnnjbEiAo9HOseoMt4,7097 -urllib3/exceptions.py,sha256=0Mnno3KHTNfXRfY7638NufOPkUb6mXOm-Lqj-4x2w8A,8217 -urllib3/fields.py,sha256=kvLDCg_JmH1lLjUUEY_FLS8UhY7hBvDPuVETbY8mdrM,8579 -urllib3/filepost.py,sha256=5b_qqgRHVlL7uLtdAYBzBh-GHmU5AfJVt_2N0XS3PeY,2440 -urllib3/packages/__init__.py,sha256=h4BLhD4tLaBx1adaDtKXfupsgqY0wWLXb_f1_yVlV6A,108 -urllib3/packages/__pycache__/__init__.cpython-38.pyc,, -urllib3/packages/__pycache__/six.cpython-38.pyc,, -urllib3/packages/backports/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -urllib3/packages/backports/__pycache__/__init__.cpython-38.pyc,, -urllib3/packages/backports/__pycache__/makefile.cpython-38.pyc,, -urllib3/packages/backports/makefile.py,sha256=nbzt3i0agPVP07jqqgjhaYjMmuAi_W5E0EywZivVO8E,1417 -urllib3/packages/six.py,sha256=1LVW7ljqRirFlfExjwl-v1B7vSAUNTmzGMs-qays2zg,34666 -urllib3/packages/ssl_match_hostname/__init__.py,sha256=ZVMwCkHx-py8ERsxxM3Il-MiREZktV-8iLBmCfRRHI4,927 -urllib3/packages/ssl_match_hostname/__pycache__/__init__.cpython-38.pyc,, -urllib3/packages/ssl_match_hostname/__pycache__/_implementation.cpython-38.pyc,, -urllib3/packages/ssl_match_hostname/_implementation.py,sha256=6dZ-q074g7XhsJ27MFCgkct8iVNZB3sMZvKhf-KUVy0,5679 -urllib3/poolmanager.py,sha256=whzlX6UTEgODMOCy0ZDMUONRBCz5wyIM8Z9opXAY-Lk,19763 -urllib3/request.py,sha256=ZFSIqX0C6WizixecChZ3_okyu7BEv0lZu1VT0s6h4SM,5985 -urllib3/response.py,sha256=hGhGBh7TkEkh_IQg5C1W_xuPNrgIKv5BUXPyE-q0LuE,28203 -urllib3/util/__init__.py,sha256=JEmSmmqqLyaw8P51gUImZh8Gwg9i1zSe-DoqAitn2nc,1155 -urllib3/util/__pycache__/__init__.cpython-38.pyc,, -urllib3/util/__pycache__/connection.cpython-38.pyc,, -urllib3/util/__pycache__/proxy.cpython-38.pyc,, -urllib3/util/__pycache__/queue.cpython-38.pyc,, -urllib3/util/__pycache__/request.cpython-38.pyc,, -urllib3/util/__pycache__/response.cpython-38.pyc,, -urllib3/util/__pycache__/retry.cpython-38.pyc,, -urllib3/util/__pycache__/ssl_.cpython-38.pyc,, -urllib3/util/__pycache__/ssltransport.cpython-38.pyc,, -urllib3/util/__pycache__/timeout.cpython-38.pyc,, -urllib3/util/__pycache__/url.cpython-38.pyc,, -urllib3/util/__pycache__/wait.cpython-38.pyc,, -urllib3/util/connection.py,sha256=Z9JufD13VNcga6RTW1wRIULbWdxsPE0WCUi5VTebALA,4908 -urllib3/util/proxy.py,sha256=FGipAEnvZteyldXNjce4DEB7YzwU-a5lep8y5S0qHQg,1604 -urllib3/util/queue.py,sha256=nRgX8_eX-_VkvxoX096QWoz8Ps0QHUAExILCY_7PncM,498 -urllib3/util/request.py,sha256=NnzaEKQ1Pauw5MFMV6HmgEMHITf0Aua9fQuzi2uZzGc,4123 -urllib3/util/response.py,sha256=GJpg3Egi9qaJXRwBh5wv-MNuRWan5BIu40oReoxWP28,3510 -urllib3/util/retry.py,sha256=tOWfZpLsuc7Vbk5nWpMwkHdMoXCp90IAvH4xtjSDRqQ,21391 -urllib3/util/ssl_.py,sha256=c0sYiSC6272r6uPkxQpo5rYPP9QC1eR6oI7004gYqZo,17165 -urllib3/util/ssltransport.py,sha256=3bLBqYPryT9UMGbx5iRgMgb2sj7VEKp5pmRD1g8d6VI,6907 -urllib3/util/timeout.py,sha256=QSbBUNOB9yh6AnDn61SrLQ0hg5oz0I9-uXEG91AJuIg,10003 -urllib3/util/url.py,sha256=au9jkUMnVr9Qp_9kg4HfZx9q9ur6yXQ4u5M17In-UKY,14030 -urllib3/util/wait.py,sha256=3MUKRSAUJDB2tgco7qRUskW0zXGAWYvRRE4Q1_6xlLs,5404 diff --git a/venv/lib/python3.8/site-packages/urllib3-1.26.6.dist-info/WHEEL b/venv/lib/python3.8/site-packages/urllib3-1.26.6.dist-info/WHEEL deleted file mode 100644 index 01b8fc7..0000000 --- a/venv/lib/python3.8/site-packages/urllib3-1.26.6.dist-info/WHEEL +++ /dev/null @@ -1,6 +0,0 @@ -Wheel-Version: 1.0 -Generator: bdist_wheel (0.36.2) -Root-Is-Purelib: true -Tag: py2-none-any -Tag: py3-none-any - diff --git a/venv/lib/python3.8/site-packages/urllib3-1.26.6.dist-info/top_level.txt b/venv/lib/python3.8/site-packages/urllib3-1.26.6.dist-info/top_level.txt deleted file mode 100644 index a42590b..0000000 --- a/venv/lib/python3.8/site-packages/urllib3-1.26.6.dist-info/top_level.txt +++ /dev/null @@ -1 +0,0 @@ -urllib3 diff --git a/venv/lib/python3.8/site-packages/urllib3/__init__.py b/venv/lib/python3.8/site-packages/urllib3/__init__.py deleted file mode 100644 index fe86b59..0000000 --- a/venv/lib/python3.8/site-packages/urllib3/__init__.py +++ /dev/null @@ -1,85 +0,0 @@ -""" -Python HTTP library with thread-safe connection pooling, file post support, user friendly, and more -""" -from __future__ import absolute_import - -# Set default logging handler to avoid "No handler found" warnings. -import logging -import warnings -from logging import NullHandler - -from . import exceptions -from ._version import __version__ -from .connectionpool import HTTPConnectionPool, HTTPSConnectionPool, connection_from_url -from .filepost import encode_multipart_formdata -from .poolmanager import PoolManager, ProxyManager, proxy_from_url -from .response import HTTPResponse -from .util.request import make_headers -from .util.retry import Retry -from .util.timeout import Timeout -from .util.url import get_host - -__author__ = "Andrey Petrov (andrey.petrov@shazow.net)" -__license__ = "MIT" -__version__ = __version__ - -__all__ = ( - "HTTPConnectionPool", - "HTTPSConnectionPool", - "PoolManager", - "ProxyManager", - "HTTPResponse", - "Retry", - "Timeout", - "add_stderr_logger", - "connection_from_url", - "disable_warnings", - "encode_multipart_formdata", - "get_host", - "make_headers", - "proxy_from_url", -) - -logging.getLogger(__name__).addHandler(NullHandler()) - - -def add_stderr_logger(level=logging.DEBUG): - """ - Helper for quickly adding a StreamHandler to the logger. Useful for - debugging. - - Returns the handler after adding it. - """ - # This method needs to be in this __init__.py to get the __name__ correct - # even if urllib3 is vendored within another package. - logger = logging.getLogger(__name__) - handler = logging.StreamHandler() - handler.setFormatter(logging.Formatter("%(asctime)s %(levelname)s %(message)s")) - logger.addHandler(handler) - logger.setLevel(level) - logger.debug("Added a stderr logging handler to logger: %s", __name__) - return handler - - -# ... Clean up. -del NullHandler - - -# All warning filters *must* be appended unless you're really certain that they -# shouldn't be: otherwise, it's very hard for users to use most Python -# mechanisms to silence them. -# SecurityWarning's always go off by default. -warnings.simplefilter("always", exceptions.SecurityWarning, append=True) -# SubjectAltNameWarning's should go off once per host -warnings.simplefilter("default", exceptions.SubjectAltNameWarning, append=True) -# InsecurePlatformWarning's don't vary between requests, so we keep it default. -warnings.simplefilter("default", exceptions.InsecurePlatformWarning, append=True) -# SNIMissingWarnings should go off only once. -warnings.simplefilter("default", exceptions.SNIMissingWarning, append=True) - - -def disable_warnings(category=exceptions.HTTPWarning): - """ - Helper for quickly disabling all urllib3 warnings. - """ - warnings.simplefilter("ignore", category) diff --git a/venv/lib/python3.8/site-packages/urllib3/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/urllib3/__pycache__/__init__.cpython-38.pyc deleted file mode 100644 index 2e36c93d54fcc1d34d2116eda89cc327992f57e8..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2141 zcmZ`)&2HO95GF(*#HiH+E2fJrHZ{N}|0>GRtLb z8P2IiZ+!>**k|b*@Y+*ep{IVck`gCDx!`DKI6FH#^UdhR%uLh4b8>f`{SEFP5-vX# z2>0=3_g%-~PT+8tm!zvoLCGcFlV0H2-*QmKZ&`Y(5>)W5!mF~XYC+BNHCb1UpkevC zY^qk!QthCvW`Y^3YsgtO7tC3{Dd*Kfu%H%$MYR+xSzSvmtCe8I@@;uVtp=->pOIJ9 zTCisMS$R!e53XB&PTo*AgPY*zgHQNE@TtJ*d@=BacmA2Ub>W`h7M0(e3)gjocldeV z=b6xcUq>S5abm}?1lYa;F? zT!bo@CQ6w$VL#D|GsED#Med%lm<@z3+PgYA8BL|xl%&g^+H~r3k)?=Jz;j!%BM}af zHG~Vf@?01_0#n)KnfssQ!C!jhU_#s?#9A& z3h&vI{m!heAvwBEq(!7nWR}Q0kp+-qfpH#Y2IuQgCIehTH%LFvql_I$5gs!gqk5U9 zHq(nl=7`LI^eFq&#{)yn_7HFO2*fz&t|?u(uU&B7h4Z>}Ryr?(uWNEOiTlWOt>NkV`UcB@X(c+D zzrG>GDB!{{kRS5)k60n>_&wy2IzE^3ot{&Ms! zlm)ldCW%HK44sBX^Ji{YFzXg8tFak5RS@tEp`Z;gdOez5j3R7 zD7g23C>SHv0zpcD5~n}K?YMSDH5$YiEIXZ2QJ;Q7GBH)8z+6HysnvSSh(V%9HYsCr z8`0<$ke~5pB@m}<<<3@73qzjtP^4xU_H)1p1=D1ruMpWF;(-*7rp`cBCu2!hNt}H* zZfHhcYFFEWb()tnE^X@-EwWMLL362}sSk^~p3D^6-a$Jzk?d;mG8foQ?HV*EDvTG~ z{SzAkGscXa1wq}~Ac3~c=~67msMok4CaR2j0#geDuFa&xRafCzUnO#bqNx1vu{-71Z7PHE9&=D!gDFUBV=WFK+0a*s{^3zQXBAGp1j0kmC7zwsl2f0 N%`TN{izU0f{{Uw^UH||9 diff --git a/venv/lib/python3.8/site-packages/urllib3/__pycache__/_collections.cpython-38.pyc b/venv/lib/python3.8/site-packages/urllib3/__pycache__/_collections.cpython-38.pyc deleted file mode 100644 index e07a70540f53365fae9524afee545caa23694f2d..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 10654 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 adGjRj-~uq;V!jCMS2PzOfvmmo;r{`K54rCE diff --git a/venv/lib/python3.8/site-packages/urllib3/__pycache__/_version.cpython-38.pyc b/venv/lib/python3.8/site-packages/urllib3/__pycache__/_version.cpython-38.pyc deleted file mode 100644 index 2125a832767572077a1ab9808022778fd2d604af..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 165 zcmWIL<>g`kf(lF3M0+6p7{oyaj6jY95EpX*i4=w?h7`tN22G|aHbXrlGd(juO~zZ? z@$qG;Ma7x724V&PDK{tC diff --git a/venv/lib/python3.8/site-packages/urllib3/__pycache__/connection.cpython-38.pyc b/venv/lib/python3.8/site-packages/urllib3/__pycache__/connection.cpython-38.pyc deleted file mode 100644 index 2a382cc0eacd50afbe3284bdc6cfb77444cc416c..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 13332 zcmb7LX>1(VeV=Q0XAhpDsM{LZqNKIR)!{g{Y1uI)QMO{4QbhWi#2yZJX2~UIcUEs^ zMRB`y082%Bz($%j4VoGW*%oLG6lv2ILD3X#5fo^Fe(8q-Dds~zr2Sx{{ZRBn&^ocz z-~T_e2Pvn=67%NGn>X+H-^b(20|Pk;zdKJ&*cY!#(m&Hf|1XP&=Wqq1iX=IbBYRR! zHf5RWil>+g-&IrPyJl*9Pnjvcr_D6qGiC;N)l1iOGt1vM1Af6>0`Cw?GH^yet% z*z=N;bMp5jC+{A(tD57lOLgTnsinII&4c*rIKDcBFaACL0=)~)0D2F&htd0BxAzhA z2zsB0dw*3HMz{ZvY6u0g5O0_fQnc7+NZ0($Ru6Eu$ zUwh1aOqN`A>oe}-+p_stXWZH6?0-)&pKz6}C!GV%K_|7Xnoqf@t!d{FdOVFC9(Imk z#Yfy>_rhJx974-O&QY`+b%(I$XB@*hc26>&bslye!Toc1f83eC`w8?{&F9>)uPQ;# zea?Kwea4(|lzFLm;zOdAq8ts`OM&k-L)WU-8omhU(3WzA@C7QFuv&BdX855TcUFVy z9W)QVu&{9Bl3%a8<*@44(K0|Svvm zehybqK;cTJ>`0(a8EaIc!bLl9=jX4@(t76JS0mlB>UPbwtSDz$HQ#A^R4-W8t)}h8 zZ{C;05JuwSqtBiRYmGCFYGbNdZ`kEE*O^*hab0if&eB?V=c%U}XPUzEs!NZZ!Sa&r zlo}g?m}@^R3fv>dZyY|G&8|3V+S5->5d+ z|81^OjQwceT=d*Q=nJmxxZ-lP9KJ6{dCR)(iU8QPtfCg}Nw%{P(*sWvjn292yS5qa zoo_C!f-Gjda1Mxi)fV+?eK{JL-v~mtMxQ55!0zxRSA^9{wG2XuM;xr#VR^+`@q>_% zSyZF^{EJs_STD@ZT%Ns&QSfkM=Hj*4q-8$J_3&0qMWc2QU`(rmIbG2Z)p{6>CzO~V zxi0pm*n+kahK(pi zWl;T>j3j-COKKhZ;+s>)9yva7;^d>JOK)0>?YGWOJ!Ma|W~R(H9zd;zFX$J16Ge{! zOx4vK<$z?S-1KS&m+q()by+sEj%Maa{DRfWn&jaNpyMIeT#*a}Iq)s>mda?q$ur5IGP<_hfVYE0QLe`@oJz z1ntd!9P7;)_z`b9hF>?P%O2o9y+}|fmA$H44@)~G#G z@`6w_%b_oL$R)7ox-Fbws_fSqc354idev~l@azp&7)x%r?z(lu_dur@#4+mbI%+pI z!W9fu%JCR8j#DKeWP8S%yRq&I$7t9B)D(iA4O_TIlhz&jG<&7G+(e5VhN6lkVr_oK z2v=Ns*AWNtsAZCE_^xlPYQ5|=9d|mOcgk2?#Ad)gi;L67yzBBfj$dxp01)g2km>_g zLXM^0L=E5fcERlinihF}9^G$>vTNCn13C@jSwfyA;5SC{#;Eur-b7Of%>BS-;=zcR zEuRH;cd(%0mWd;cq@7kw;AqwXa&H4{WyD-iGOkvPx*rH>|nqmuIidyiPbiSH#*qfGY+_7pq1!06nc#K}0qY=ADg%d<^3Xpy%GP zYYoqxG^!P2!*3ev)nJ8&bL&`yOOqHcx^Bam@v667ERsOaR7af%U>yKVCd;KkYSrZx zZ~^g3OfrU1Dgil;JGJCNwoFeO4JPHzTQJ%G30lT!w3^yh@SNsnn6Lbl;U^fe{G^B3)m$4=tu22`X)Eu_ zFv=uIvh-Y(j#)Jtj9I6{RP@}>7g367BPzspOe`^qd6C94BlX7X=OeY@HzIY}4MmaK z#y_2&1u0!|nudJX-jtGZMM4XZ{uZ`oSt_>2u=gybH!(= zDcqV5nz!p421GdIGm!82;Jk3f4#5fz>vLv;jvgmw1ASci!sWRxml?*@y0PrmU158Z z25dZo^l)MgfZhH2Ng9nMEDzQ{S!Wt1yzWvfP0!nyB1;g%K;Srj%?4|dB{9kBB3x+( zET%S+@o%H61M7n%K!XGvq)u0c8Af@TMuxtV%1(*gra{t~=RZA{J z8)GJhA3-(Q8L5aMBt=E~Vx@`wlSG}79$OHR=H zGQXqu_)(p%OSl5^hT0^25l0}uto6e#66Ry^(6KlcX`sb~O2VE_HH=pwGJ*iM5WoUC z!GKR}ATr2e2I}soXOTT^kXZ>A4VWOg*qu2Zfxe6qgM5hOv4gu)_HjPhhh}g~1r5ARwCVE@+Br^!OUVg#o7TkgcT1 z2wV)eEmW$~CLp&ei7_hMkg^vf)MRm-N<1qUq}D^BvPvpV!I!rYdhFmdn>>NO zHBV!txniL=k$4EGh(;1uu*ZRn?MS1*hal8N1M{r^6F*msqmA(mN0eW%pDOmDxv0f7 zqO&Vwt*u8IjT_0k=>=?x)sf#>e-GaUq`#$<2F0CI=u%`&&Pm#RMONg$v0E&lz2FVy$rCXw$yE@ zqJZh;x8+bAE znEs=}%h!rOyv4UGv=ET*Fa)}`xn3o}>e=DBhc4#%YzW^P(HXJKQrE{}4rkQ9w0 zJgH?U;D$Jd#YeeDGfZ?_FgI<_+-6{;~CV`m9;(1)bmr#VnG0Hu-9hU*byK-ymzygBc{IY~Uz-fI4V;rVc_dsAG(%gLt3B=C-_x zGTv7iw!%VZv4{dP(!?#2*LDMk$o&IcJ!&ZKqK1S+KZO=P%Dqf0o}m>}EOg0tHlj?7 zi~!MC=)=ZFw9kTuu{v%s?a|^rMk&w=uuVb5DASPxDMqPSK%;n>3Xh5!3IwIImc^k) z%Zj(b;qzN~_aj{F$&x5dt2z*zdr+h%bL_w?`Ot({64?O~JHS;VO*rk!0LJ89h*;QM zskQWG8Wt7ZGqAo$+$!yKJCk5CjW-!_leC$W3DvuC@Iu?twx!EJ+Lx3~eG^vOmeSVS z*=+&$vhX?_OdPUwRZRWx(XeW195r5QHEAl49 zI>uhy%(wHwU)}m1-sVI7t`hu1JHM543Q!LD5VEM9CrRcEIQgGPPLmN;VluBaozNgiw*{zCY+ z2JEmitK=2*5mhR7Y3SSq@+~O@{p^3xU?iK0BVMlB~ath6^3Mw1E)0c#XbD^HQL8R@^(0>bdnOOK)u<>rcqE)`GH@I&#$aHBhO^X{SyW+Gi-W?=r&EW2?xl+auUC;x`gf{Q4m z6o~~Lf3OjNO#Iy^Q86eF92tjfN90f+qjvr)sI7nyY=>TxD`?)L z&R9z*3Y>{FDvYfx=SR6(phf}$W!0j5UsfOd%E8TU>K3{hG#UD3-$S_kF`8(aif5?! zRVsdsimy}ATgI=`<2R^yoQj=dnHP2(Dmo5)4<3g1octx;aUX(vk?($3Qk^U~*7hWE zpkZZLaTJSz&A*l5 z%C}RTrYN*^e5E!F8i--+6CE2qmBheXc7aql7?1Tc!f*oyB*f9K;J76Qp1lFW>L zC;&3F5+@!g2fBf54n&C0gA7!07Ej1G!NXQIVb~|60JhpnbFhMlfy_XC6K>%q1@E$O z3bNu&s=K!7!QR=su>9n>p)_$}c2tGi0kjq0T)8d2hFoZ%H2I2?p%+?WFY4{Kk z@#;}r2Ciec4&XY7>kx=J12)LKgG?DnI}LM_*1wllM0JdYpriwnGI^8QdU#uMvTNLv zcZ4rVB(3rriadmm#AfX3aeVVuNbHqboq%hUe~0=Vzl)vMopxq*e|Tc`kNu`FzLYNlEr+iamn%q%P-P2^zAix$#W$iZoVYiO}917jZB;m4nn5%x~T=#8Hw0c91YJI-&d9=SyetXLM96 zMg}a%`H$^+t|7og;w(;{J2V;OiB~PdnFo+@0-?SNuvT8OYoqhC$w~)fj_g2 z#n_FZgG`IuRQJ~t8mQoO8=V{hw3b}@K2D4B=4$pTju0#fe;x9YGM`9A_8^Mg-@J0k zIRE6iClTVNb0U0tX!^{VWu)DjOE?iy>z+zWzSDi+Vg zMjq={vh<=oJ#wH!P0gxsooJNfpGYkSLMFZUb=Ij?QSXqa(XO z`GwveJu5$k-F_c)eWIzkk2S6EQ!S0L)WLXcT}Ph+G7@Pmhh91K(m&Sp9NZ*L(P#xJ z<-fG-D2^QHpTtKF`c*IXOh>17M6Stz)p4=rCI1nU7)h$O3cahfHGu>e=~;xtq`)I;uNq^?`*(= zA`T|Y3eR*z&4~{r#K`N}RtPwfjE*f-qVfeqbGcmP$LVw*=0P!OjoM>MK<%T} z!@HcK(t}c>n4RnVihFi>wc;0OZNEsxFH!Mn`(fT^JMTNx<(E+)Ao%>X>lbIPS(j(8 z%)ESU!CJWb((Lt@7udcRzeWAnQ>D%Iu?%mWebKMs#Tf1S0xIxDQ#!b$?=QvsXDASd zC_l~}h7Gjy@5i}g`W-S3R0|SX&nsd zWDsI;x9*;L>A*nG|51=nL(*PpbjIkVedL!ohdHT*SqNG&(Zb?L39ii z2{5Ce2*VC^q-D~wpdMv<+5c1Uz>p%=b`X&sPj)#HpJSWqsIQ4Y(8zt$_OR*W#Q;W% z(~2_3qaK(EYm=VC#WDQ;$N?W_SEHfJ&01}vV}$ti))Ye1Y?eV)(jglgik|bvy*`(` z&XJMQ9Fn=@81zCmF>&|6)LZZ0qTdLum!g88K1EPV@gki_uQbUhKnR5(BmNKt0#^Pq z&Yvuc_vlFxE;E7n6Y8K+@i{7JEb%M~gmPerAV3~)0M2}<^H{>s`x2eJ3QA-zAP`RH zY-5l89DPkVFms%hVW}oq()<~Z**QYb=hzWm;*TZGo7=q@$>+PQ8=fmky zmMoz7b+-3vl!h)qX2411{{slb9-ggpbXx4CNBEA(zXb$wI(;8nSqrnZU>@r25C^Sy zs%55frgw^IRz1#d#rYvh=$l#IE@|A@nKWqVV^lm$#Um)9ENp{ozyZv0M)6&tdW0pD`!Md*V?WLUjLC=foRZT9m7F^IW$E+7Uxtr1gh*VP HqMG`HPz(L|bF=m{X6$F73I8I;ArxNZ1M6XeHW4#V~lBY$Yp6`At<)@@rO1`At{S@|&q-@SAFx?QA6{&zLx#sN`{+ zwll5CcA-*ePgSPc#Y(X~U72prRA$<ook=3oR{NbtK7a&xgf{WttZ=0 zRi2XLnbye_bIt#3GOr!?hHFSfd_V=s5RE!}zXN_)%O9-hy= z?bK{XE!ULW?5yj1X5Q|)-r`2Bv+mfs=Eyr8*QxiEbHn*&&vCu?YN~_V{kd!1dX0np za;?=1rZ@F&?d}c7Q``E{xh3b$aO}EnYFTx?Zao}R9;bJM+h=ZIJS!TW`sQ2&$wIsy z3y^Y~cexH2QqRG`%%Y<_00u+SV?kXp81cJ~x6!p-)D#G{8;-lx#hh?{xan5w(PC6> z)!o{1Y+QIKR;w`YrgGfshUaZny&l%CgRsEZdNsA~c(`M_+Ucrxt<~&1)eS5S z?#$te9QzY&(y8`Tt4>^ve^NMk17G(|6i%XI*a>hY0~{$?F`YCx(3G9B&F>hMEO`#F zK4)j`9DXP42|JJ9ygg|b@H;8gQ1pw#l_Uz)UIxbJEqsXaR=tJET8*xcO94a;u}EH!Z5cSRd+hxc@1z&1KhfG;~hOlG-Z|r8f?K4(v3Binbg}l!Qnys+5``ZgoA@r`>pqEMV7LVjg5{p^ zq2U<=W02TP+R2ZSgG4noFm}zo1dh@Jo`U8R=#b4y)|IAXb5PFKPQDCe(BI`Rw8auf26) ztGRW)*V(GoZ#(w+I~$JEI)8WVws-fXm$ohd_^syJGZ%(8WscQ8GPTVAlgwa2; zZ?tmDzQJ<9vaTHU00aBfSkg^jM8$Yd6IJj4&p}_ea5e1f*uK7ko9b*d{P38AlimtA z7$kNRdkKh9L%?yByr)j7P%>qje$KgDuL>-(JbJ&@@-tGkHa;%E%DKyh`wH51rB^K5 z0ZXRu`eG>P@qBhUqz+3&m9P#Xietw(h$}3?Zo0L#mScGvj<6I>M4(dZ{;*W9VW?l{ zaAn2J{`?peH7JawQbE0h+x&dB+V0vtaPg{Ns8+w(tF<(KaQ*FW9f(58QIGKEobdj| zmaAT1-ODUqWkHTBUB^I3x>3X=bsohl__{MFa)y~V4Kta~sflEO^)}fb__ZxhcpKo}>@p@Ctg}vey=PKziuG^19ZGPevn(2E&m>V)3UQ z5%^KF9vjnQ4Fhr^un&=-5uQ`^gH3b3{{x%yQ3DJ%B)pB1*G@O`45mDfA1ZR<`~-FC5T*77z~ypHvB*;?V6 z3u-vvqJ(a99fDt0H@xkcQ4|VP_~F{!>_VtvEwn1i_MriHJGNGEoEp`Fj@^8}X@f(= za5d;15Q`QLaI0C3R=4I6I9Nt!-GM05x&@R*SKuA?ME!{zPH>ibC-m)eQCqlJ>!1yQ zw^MhlZX?2oK;D*nUb9sWbjsDBllA8NSaWDDRvTc58f#!}&#zr#WD*&mbDU0qAm?x+p$_zD-KlL8OI8maUw3U2R?z5L zv}<===(@wTSn9Rc&^abMpih!Fwu7!*6QjSSi|krRX&RaVpmsdE!R0W3cvVh?lhtEVx{X~U>=%W z>*28t2l&YgR6TK#$U+yk%0^$fx!jiSy4R8Y-+ z29U$R4;q?qqM8?hp(e{)w%*&o!l9*xa^hSUs|Fy}-mf)V6uVqgastdo&y^sG+Uj+H zc39?Nzr+oV6Uu2hun({-LYTygP@i_2wqrSs25^AfI%*EY>ox1WR!!Y^rGVNF#z*!U zY4>+(ntfuXqbnt-5I`q3MsNw>6(sP#~loAalpdT1Ly-v%4Rn!IW(34n!8nC3vA&+qGZnc{Arq|jY?Nz~&ZaT4E#cbph z8qM{d5~StWIpei$%XS(yV74AeI0!N?p+`}`N6<@a{KGjd)0ngY3D^NJgs#D8+vxUM zc8I`&LN+YnI!1a<_z%im+*Ce7loJD zg@puDGP##B5?)fyvU^D*F-Xy@^vr?jrSB!(XT9`pW?=3aJLVu~CvNA|n_hM^x04%~ zxNl;RLz#zZF*!)@p~Y%pkU=>$m_S(^9&*+Wv!4+=OwjO#`9uTdV}Jz^)<6EZf`vBpllf>t+Ypj-=_N($ z$}hSiv8!G2nz?>jaK)m^$V;BN!HH>IOylW?*pnX6}4R&8RP0*G#iX3U~cLrd&-9W{;c$?sT`iAkwI0a zf^!WU^;O<$RAUy47%Q}Fehpu@j3O~zGz!T~GH>LQIU|$I;9HR2ypc&2jA9BkJU5G| z@1NMO>z5BS=xLl~@m<8%rGY(weZL8t^#vHS)r4p4!t;S;=kfzlH_fd_?bMzLv`uWL z8&NIJGMibHIotdMh`KrPSCZc|cHlc9qV!*icmud-Pjw)NMhSLwxX|sX*YG2x)jxX^ zE*uY%!Rk17w1PGyQ|s($yL8by?Or_X`bjA8=Fp=cYb2{x%B%M|1K#8vW6S1GR53V4sS|}1`5q_2=zVNpE z*vw|+2<4B>wD~8QZ2#ow{FmvkiJGa40nKLcN#UErSJrD62ez@3>>mNd6M+lHpr>jl z`Cg*)rkU_kxAW>n16~L)9juF;x|jUW_-dl_7_Ox^Gr0OSeHASv)mJ>Mp=}2DB)^gv zB-Jl@xk2)tf!~Q;7`V7^QdmQBw?OZPH#JDo%)OVgbGLCf$1_N7{R&uAagS_bqV~&R z6VZac1+6Zwtw0N+o(8Jcc(Km~LDyekszoYMAgYNVP|Tn~4Y6TNdD1RTklz+uo?5x2 zZn?TDYUS#xC|AJ8XnYzkhwbrhJviu5T8OgSKuZizV<@nA?Pg%FKsw#2HK~6>!*VR> z9mL??mW+uuA5NowrP07Q8wzkZgLEjuEssVIAc?fCNN90{4ucD9ceK3&=1ui=HAY}d zrKGSf!TJ6)QI8FZcg8OFUy}-`)(C9a7IRS_^)QPXi!~O)ujz;KvuLP>7SuY16*|l|4dVOuaPrmOfz{f8HY`ckTFR*BI9r1BqCwM76LXB?}1ovf*E^B z5b5KZNI|%dlBhRL)Lqkc)E8{BT+t?Q2g%k@6*#JMBvA4Gq-*~zPK3*_k>W&Xt-+HF z?FJZ2TZ34&AJ++wQAA%vjSi(*+MEm=Kd@GMN>QU14WEcY{|vnrAt^y;9!1qQ;zS_P zi0iG=WWN~JhCmFxKBN{^Ly~P$iMY(TNNN=G9LPp_rxq)3N0V`Gf{eFnV&MVf!S;(uB~R`Z6$5ZL$y& zGp_=sLRWtFj*dVMX-hf0ZyyCg)e;I?0N%NCxFu0c8l;?J(lln0^C{Cfm|nsM_t6U) z8oKfWC-$uf=8Le8v1qEfz7cWUTI5c_`nM5oJ!jP-Z;IAhh1Y4%!4QUlSNoue73rpL z+VC{U?4IZBL_VAShYu3sBX|FVDM4B)dZ#ro5AGeNG7KR^I%y~(ULW+HJh=CfyZ7}@ zT|)GTr*SYqAP2_A92g07K1yy6u`Um~fO-_HMAw+R>4C8aolb+lfAMXnMMGXZL4n6f zQ#j~xpEWk(AX_SB5CXca&1S7|F*?$5)Dl5JQ$Sru0r4a;Az{{ISXK}|9mwD}2n>m7 zK|#(#QO=qDhYng2@{-`0eE}TyA|N61BeI3?9{{l6K?R1IV+;`6x|c#w5TLP>xboV- z*o577JELA3zsF8_nE^tGw=?dSZ8JPpjeYl}p(JJcm)_CdNQb!#R;>=dSPM>8?J7c! z!|Q>bL{~9tZ-CdW1TIqCPapbc53^ESOK^4dys~u`h^;Gd`YOmU$f%lqn8cb6D5N_VA&@g( zwm~tyWh8cxRMbBPD$2oB$Nifo^l_N{AL8EUAdGi%ALPE0&|^}j6`P!HTifAdbx&PCeg#MM~VRZEuiLq1bv1DEF82RLV=c$hWy0+;Vv^rqQ$+`&ZKAU zK5WBTvUv*MNAP`=kcayuzj+$p$Mz;LucCJb$7k0jTq(Ox3{r5-6aa;(k6VmDx)peJ;qGUu#ZWa6h0q-;EnjH-d|~*8 zDorrIVZ4S8`k?^^&F;Q28}WaOA0F+v$Q}seB#edioDokp+hKQsoDXIrYE!J59P%7h z&C%dav@C38+(S4b$HH*ZXr#xAM|egW!#IY~9-Y#n*?8bnWQSr1!Aki6>`8r##kWx` zAteOB6$44#Ma2p-3MSTiaN;ZQUVlpGNWJfNm@d)JQ1)GTy?+9ZkqZ~ZJ7S$W?Ly1L z|0(^`fAlJX43Gp+{GnDrvV@NEvp_jY4ABY=ovP66G`gj8ia7}C4hnw?emkUC1)x|o>+L;oOlD@M1&hnMY#Fd+G z-&(nR{k^41{>t)=>nqn+zPfzHFL2dDL7`ggf?`Sg52pinVRhx5cduN(wW2;`^YrEg z;s>rr!BKw}nn2*;3olKg3Z7(1QS&EOkf$Pp@~4<*btN>%)k$em%NCN2KdFVJoxhA!W;3a_yRK$=_ZCm5s!_%xmY_7HwI5okeumai*VY(8 zIKx>Pz;cd`Xk`6_eoQ#g{mD?=!Zz~_NBwy|F*Cd|m}P-ARm2`$rbMPTpwEq|SyRG@P9Rm{W$Ib4== z$pVEp%;}kA(!jZS);Iz_K;sOfh7JyWy+}=5pCuFUx58)Je-JVl>ZzTA z42CaGJvc~e4d$BmWCZJo8^UXEFcGJaTP{$t2vCu74yp=Y`R_jL4}cP^A+InHH#uEM$oy zY{kNf$t02^s+BClF|_mx$ibx?mDI!k&9$0GdxjCriwfwolq>6JRQ z>F`6p0f#2q^)aj;C=FiZo#LRlY3xi7Ou^ohfN*lhggKR_rRl!tnVacBnjx*t4E492 z^dK*HUK>p9W|`Qum)yw@vZ?_+3x4T6!)on;9J5To}w$Pq1x_ed1%IoA*u*W{?DC z+)EV_J4Xgbps}7B%t@KpePA%dUU2_|1L)6~3;Qt#llH_%*`1>U=(q0W!AytaK8EX4 zc3#494{ch5qYcpf;MgE-PkxdbOi9$`xNYvtgVKKwl>V@2$A3vvI_oiy*$-)d{3foR z@*eRX^-g<_d1t({jjZUiSE0|sY199%%s4ezz}2%27`qtl??4Y;z$z|uUc;I#;Mr1e z<%gUt?)afc9e4pSTIehU_dFu^BvsKnZBOZIgY@PTGSh`Y!aKKnelKAck0=D-vZzWX%# zI59Z!aY}6rj&D9=&%stoD&Ib|gIv^THpdY?ng7V#Ndx-l0N-Z;(Udx=p^v+s!`VDq zd!FnjOQ@o!O6YU$EKS9iKG2j(P&@6XgT*U8f`f?+GBt&1KN75f?jz;_=p*0;vuL)y3@6BQq(_>x0YsiQ-IqXq@oFYb=oV;llmCM{%`AX|({ zG|cmYLPPIoEi^`u+0bR0))}S@!Tn2xSSNDB1=DIpt#KTxb_eMm9u#M&?9r8Bo?KJ~ zOo-~6Lg9Gza%s5!flUk*V6@E@%m?{AVqpb%D@ddl4{(m*P?&nwwYNtbxm@$$2n0$x z2&G6;QDjD2Yq%Su0ZibC4Uq!|AP^!vTif;=cXb$_AQ))xBC$~Nx?{53I#f2V)=&Y{#*o4-<-*M%Z&b_$opxGnmp4b#Gx~$N5X^K&8>qzSB6* zeBJZ!*1YAQiK8L%%2R9lrHe4Fp*0Y)hl( zgS{N}u=V|G1#kCgni$~$dqk4NK;Kw>q?ZIql)=qhNidb}9ngtHhJ#q}m=h#ig%5yJ z+|W^ug@fOXZ}nQ0n3ZJT#0JQLEOTGb>MFqm#T4Cg1lvfBW6mJ6Qjt&QARSH^p|%Ih z`k_&O%)X(B3q%?N8$y$a)(KJwbB+5xsNmAy5hqri>1sFWxL}ZwTOg3A*O1X6=WeJ3 zM{^MGjHK^|;EX1N4#FTLJk4E2_K&>OHW!f=usgc=ObWya*glkLu3-(LcKqP**hwDS*K->ny&?D#AY=gZ~ARr6Ty3}&JQHGy@ zMW+g2kw%uC4nm|>OHSa}BsGW8mvE0>*(iXBp(58}Bn)|xkO<*_F=8AM>g`+ab75X? z=sF8ii8-BskA;I9We9+sPN8MozYPvep}dWx)sBrVCgC%#byhn|fIv2|Mj_c!ROF#>dXuNd@9~H@Srp@uJ(N_RxTXHUWUz@=PfUp*Jyxi2C3}Z)SJ}Fb$J8Cf#gX){Ri*nk$sQnBIyP*Ck>-NsIGQ3cz z0X4U`0+A_v^G=sL#6oo9Ru{0T(Ef^pW28CC-t$}CEo}6l6$+r})hC5WW24%EB*9tPbf&l{K1MQP0*p2W+GQop@#cDKuWGwo*5FUOukSPB2 z7+$WZzX|{2RYl*i#DL(?m!OGBxT~+R`mdqzi-D-AYJLshHr?KSen?P?+1&kOi?xnU zln{lJ%PI1*+&{E9)In=&$aDkrzE4L#+Dfslv^dGJ&l{*$zYTP*JN>6_P;n-jpT)N5 zATep!r?n<;ub{<$=CnE^ak#XeKp`$P7z`USa6O|OXGnx>;_V=aFu`=yFw;O*f1lHt zzY*w;9KvbWI{zBVQcmWo{tibyGp^(4;NGv}n)(MU2tM@>QS>KeGUsKlT7N=LWW=wk zbG%2K&;s!#o<4@c&&le7d~}cE!v5R5%4mW5TP#lUzP!_++QgWqDzR4F+NXF#=d#Z5 zM`@y!JuJ;>q+3kH__3CZ?rLmnX;X4_T2z{<4Sa-1!lp(@e7EC_(9ul`}M zRz%pe%3kIESZ>2nf0^wa=A*Ns4ph6H=q|h@0(Bh`-2Sw*Tm{?0b>Nl6AAO)Ywnt2$ zZEYU=Ie6^lI>NEcBw~A7&n`Wng9g9M9tFgImq)T_M1MgE^^bTYusZ+?{K=4v8Gg)5 zK-uOCGAeUW|BwSLa|+&(A`v6ZDnMTHGMPzbUgDAZO&=Jmy#B+MP&h~unBI}C@ahwc z#Gl1O%(fRgl*iStuzo5U2nkC421otZ<$--5_NS4{q+wE(p`S%`7tgje^NfUbbx%k~t&~GmVK!O9dmJ z3S*l(!kPS0rdY&2bfgx4jv$%DH_deNPcjpDKLb)GP4pSu$!q-k(aa=LDe>-xV~Ek< z7k5ef=p&Cla;b$>CXJm3*c8I8Bhl5*&3%1iaAB)IG^dh3$jlazs)N1z~3X7{O zguyWRPt{piEPjiHHQLpDbp%vo+EJ^ktiXw=TCg&@ zNc~36YS)5g+H7pcH0QweB<`J{qgZ2jG_Z%@K$2(q#v`z4dUb4!Fqp~;)T!0g+s?MU zl!$vwR#)qE7Etwzor1Z!!D+3^8+aB>rLJqL5D5Af*KLJK8oGk*Q@6r4e48_caUxE8 zIzMS9Uc}opF0SG+tvO+cL)(yG;R6lcDsMNS?sJg=Z1FUTyN5mAQMIkAPL~n?VQ&k& z)@^O6Q)`UrEBY?o9Q+A*c~p>krQLacnta_2H%rdP5SsF>fUm@gDR4Z=$rz2$>1bDD zaxl*vN!i|*l#PpsdLrw=93U$b@8m&5x0*qmFHy}RmYS&M2D2z92FPo!=DBTAGOSCJ zLRi8R{9L$F{zSA&!68@3FT^43=Yo}S{mIxG`IE8r!Ar}6cTWX~=+EuP+R|YyZ=b|` zb!h%w9*J!IIUe0)F%-XF=jk_C{2La(%i`a%_&pZ?j>W%c@dqsa1B>5h@l_VWs)qbZ zI3e^>dDl_m*cgw}oXSZ4ABeOcn$xnakXs9bKb^E6BT&-waBm^C-tfa?^5jK)-8WD~ z3DvJ4LxsBvWk(@?xvMP9w!j8gN(UZzL*Ihbcc>p$(&dQ}}fJGP9-6obVhn*liazrh8iBAP&&l?b4C`Nx@j&d?ds z`<5==%1Gu7*N^xp>-RJcn0bShLB@ezy&y7;oDJkTB-LZsDQbZFjNL5b+p_Vct?=6Pb2!dJ#*U_A*E?d&A3OLnvN^hME);%r;FVm2snQ z8i`g&!`aLQ^|{~*w*@na1!Rmgc5D~L7irO(+<{)SGoNsq@U$eVfc$r7m@Ey_&i1cH zO9T7ypiRPD$N0;DVwfD;(5QC|mu`;l7`_=twfL6d)U(e%(_e&f4?jx4Mu-3cZwcLo z-W2i$iZ%V3DhhqN10tzf=9Y;eI~PtaJYBd$#4Jj)vJrWFo8mKABCWhm@JLKb!6Io# zY}NxB)BOEE;)!s(#iZUkqTeMKo)Ci%Owpr0{4a@XFXCW)n=A!?$}P$nRQFL4hUiriU*ycce*;pUo@%Y8>C zISHgi+I_{#Far$7xg!a0Vh@=n@^VB|DYPXXo~8ajxz*8%8Q6hdK++tT1XpX#p{s-Y zz_`9t?BH5)&miK4w@lF82o)@Ni{(D`4&H}uXC1tvX1@=fg7ET9#{s{fPJ{I7P;p{n zGSCFCD|5@u?ggiVH#0r`eEIGLJjVA1+2?yMUdK`1@Y=0Mpfa2fw$r(#Je&hPup{-` zoQ)VJlGyy8aq3UP&JE|~=fY=vlSdlm4)G~U3A}U=Z?Th&#CT)cQ0TM8KjKQy;~-(q zzy!@OMA=pk&N;`k(oya`U@Pb z|BWS&np-Ey7rE05X@*DzwUZEQ7lD!~*g;5VY9iT`oC|5ENHra=vza)Yu6;W+gx=zd zW-PpNM`1%Mye`7iIzzi?G16JYCW7h=0m+~U+`vtQF^Hj&Ndf%De~sHol~;%HL?ws( z2Pry4USPD&;74YRXfXQCljo!r?0bZULoOgZHi$W5Tww-+yhVl0Ky!~QvHOiLwAi#) z7_AIl!Iy%!^$Onv&B(|k9FN2gOi;hAhm2GY4-t0^iZj!152=Owj)UM7T+Z>=!7!hJ z%EN(gg#iTEFjzP`)^EuQCK}7Qie$|FW?8mw>6j1U8>E2gS)g?BR<>9gQxL?&%c=BU zUjQ5Qk4$=!9}1*ne6XY^z3XzmD1M^(r1~Q?w~y(AlC>gP#sTRLY1_#i{O*F? zBVqS(9D&~S5&ajxkUXB?b<$M-b(#KB^bT2)hJGQOq@Q#O@Qe6E`gc)9%WiiJ>;b|G~doH&T$aiH6K;^{n0(=C>;izv24C!>ye(>+I^@mve1`7*CWm;^o zAr8sg8Y+3I75!D6;%&MDXpJqRkFcU3cLbO&ZvDzsP!+^8P7j~c&Tj@7g69Gn6-Qtt zC(nV#^d1fgCp?aO)&F846mkwnep*lV7LVyYzlPO=XcpO5V`WCCJ85U(d8xT_>8(re zEcugH-n)M5+T}N|U0?i?8sLidGzhtoFk;9wq^#U4TBpQI*MU|`DBvy@rz^_>-u!bm k|H?Fe5B!@!?F>A)a5S4Ur9x`%TZ!=RgPCt7tlY`}4_i1lU;qFB diff --git a/venv/lib/python3.8/site-packages/urllib3/__pycache__/exceptions.cpython-38.pyc b/venv/lib/python3.8/site-packages/urllib3/__pycache__/exceptions.cpython-38.pyc deleted file mode 100644 index 371f166c3b719b60f7e9e1a1e7253981f8a1cc02..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 11598 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 diff --git a/venv/lib/python3.8/site-packages/urllib3/__pycache__/fields.cpython-38.pyc b/venv/lib/python3.8/site-packages/urllib3/__pycache__/fields.cpython-38.pyc deleted file mode 100644 index 51b2158050ae422a95b6061eea5e12aec8e6755b..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 8135 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 diff --git a/venv/lib/python3.8/site-packages/urllib3/__pycache__/filepost.cpython-38.pyc b/venv/lib/python3.8/site-packages/urllib3/__pycache__/filepost.cpython-38.pyc deleted file mode 100644 index ea50ac6d573043db9fa45a66cf1722fd801225ac..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2722 zcmbVOTW{P%6rQoYj^k`D-G)L@DWgJBSITa<3AIZo2wJ2dH3b4ltXl1QJ+oOSzIA4t zn;c$Rp+4~&lE?l7ev4mu%3t7#bL`zs8bB(HH8W>!XU?3o|~tt_^!EUJGX;r|Xoo9nMB> z*DdLpa4xEM>y!xdc%C~al+Ruz-39LQxo4!i$m@I_`X#==7ooqz8+?ghdPchqZfug~ z0k)^q^S0Am1Xe zQVul4TB0^}sayuyN4-r7D%FCDidEl0qd`lWJ~iYO)MQRTZ!~tam6NAH<@6qTeB;P~ zU52i~uG_is6QShE4PD!|bK^HsjW`8O8;8G^3R>4fdRnk#S4cKQ^QyL6u54y0x`Se2 zpfpQ{?AFc-+ifzPfgKbBg)tuZTCJ2MZc?zTJlgR?uv@49%UBWZG2`=I)E{570cLRn zFtXBK?2E!erj;RP0}u{sqzVg3i4IlF4P_GbDk+*~VOP8h8WgpXER9q(mvMgskM_!? zUNYDgAo5jI=mIpvacSLf3V%))5DU(lU`?p}0+*|jYZ zi~UsI?I1(6t3_;bc>V14s=XE_z89*y?dj(KE0Vkp7gRF5J*5ypB)X-12bwjgQ#qQJ zd<_?_V1qy;Ux%hiCBFRPTjtKm+=6w52T0we%Z5a>^$i@43$9@;z4&(^G zav2bX904{XiU5M7M`jM_qAdpL+xCw$3 z#E;>TReoZV6KpRCLpBf$JsR{SA2QQJe%mNPJ0*cDwYND*^@;SnH@kbviCgVNs% zGl(_(P-r;@eJ%ENPamYBaJGcr^}J&a>!E{__*=hU*Q0uj~ diff --git a/venv/lib/python3.8/site-packages/urllib3/__pycache__/poolmanager.cpython-38.pyc b/venv/lib/python3.8/site-packages/urllib3/__pycache__/poolmanager.cpython-38.pyc deleted file mode 100644 index 1e71b0ed326044e5fad7ced63985d334d29a40d0..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 15080 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 v#Ka^rSTU{R&sI{;G1&5cNHy-S`$VjJBCx! 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 diff --git a/venv/lib/python3.8/site-packages/urllib3/_collections.py b/venv/lib/python3.8/site-packages/urllib3/_collections.py deleted file mode 100644 index da9857e..0000000 --- a/venv/lib/python3.8/site-packages/urllib3/_collections.py +++ /dev/null @@ -1,337 +0,0 @@ -from __future__ import absolute_import - -try: - from collections.abc import Mapping, MutableMapping -except ImportError: - from collections import Mapping, MutableMapping -try: - from threading import RLock -except ImportError: # Platform-specific: No threads available - - class RLock: - def __enter__(self): - pass - - def __exit__(self, exc_type, exc_value, traceback): - pass - - -from collections import OrderedDict - -from .exceptions import InvalidHeader -from .packages import six -from .packages.six import iterkeys, itervalues - -__all__ = ["RecentlyUsedContainer", "HTTPHeaderDict"] - - -_Null = object() - - -class RecentlyUsedContainer(MutableMapping): - """ - Provides a thread-safe dict-like container which maintains up to - ``maxsize`` keys while throwing away the least-recently-used keys beyond - ``maxsize``. - - :param maxsize: - Maximum number of recent elements to retain. - - :param dispose_func: - Every time an item is evicted from the container, - ``dispose_func(value)`` is called. Callback which will get called - """ - - ContainerCls = OrderedDict - - def __init__(self, maxsize=10, dispose_func=None): - self._maxsize = maxsize - self.dispose_func = dispose_func - - self._container = self.ContainerCls() - self.lock = RLock() - - def __getitem__(self, key): - # Re-insert the item, moving it to the end of the eviction line. - with self.lock: - item = self._container.pop(key) - self._container[key] = item - return item - - def __setitem__(self, key, value): - evicted_value = _Null - with self.lock: - # Possibly evict the existing value of 'key' - evicted_value = self._container.get(key, _Null) - self._container[key] = value - - # If we didn't evict an existing value, we might have to evict the - # least recently used item from the beginning of the container. - if len(self._container) > self._maxsize: - _key, evicted_value = self._container.popitem(last=False) - - if self.dispose_func and evicted_value is not _Null: - self.dispose_func(evicted_value) - - def __delitem__(self, key): - with self.lock: - value = self._container.pop(key) - - if self.dispose_func: - self.dispose_func(value) - - def __len__(self): - with self.lock: - return len(self._container) - - def __iter__(self): - raise NotImplementedError( - "Iteration over this class is unlikely to be threadsafe." - ) - - def clear(self): - with self.lock: - # Copy pointers to all values, then wipe the mapping - values = list(itervalues(self._container)) - self._container.clear() - - if self.dispose_func: - for value in values: - self.dispose_func(value) - - def keys(self): - with self.lock: - return list(iterkeys(self._container)) - - -class HTTPHeaderDict(MutableMapping): - """ - :param headers: - An iterable of field-value pairs. Must not contain multiple field names - when compared case-insensitively. - - :param kwargs: - Additional field-value pairs to pass in to ``dict.update``. - - A ``dict`` like container for storing HTTP Headers. - - Field names are stored and compared case-insensitively in compliance with - RFC 7230. Iteration provides the first case-sensitive key seen for each - case-insensitive pair. - - Using ``__setitem__`` syntax overwrites fields that compare equal - case-insensitively in order to maintain ``dict``'s api. For fields that - compare equal, instead create a new ``HTTPHeaderDict`` and use ``.add`` - in a loop. - - If multiple fields that are equal case-insensitively are passed to the - constructor or ``.update``, the behavior is undefined and some will be - lost. - - >>> headers = HTTPHeaderDict() - >>> headers.add('Set-Cookie', 'foo=bar') - >>> headers.add('set-cookie', 'baz=quxx') - >>> headers['content-length'] = '7' - >>> headers['SET-cookie'] - 'foo=bar, baz=quxx' - >>> headers['Content-Length'] - '7' - """ - - def __init__(self, headers=None, **kwargs): - super(HTTPHeaderDict, self).__init__() - self._container = OrderedDict() - if headers is not None: - if isinstance(headers, HTTPHeaderDict): - self._copy_from(headers) - else: - self.extend(headers) - if kwargs: - self.extend(kwargs) - - def __setitem__(self, key, val): - self._container[key.lower()] = [key, val] - return self._container[key.lower()] - - def __getitem__(self, key): - val = self._container[key.lower()] - return ", ".join(val[1:]) - - def __delitem__(self, key): - del self._container[key.lower()] - - def __contains__(self, key): - return key.lower() in self._container - - def __eq__(self, other): - if not isinstance(other, Mapping) and not hasattr(other, "keys"): - return False - if not isinstance(other, type(self)): - other = type(self)(other) - return dict((k.lower(), v) for k, v in self.itermerged()) == dict( - (k.lower(), v) for k, v in other.itermerged() - ) - - def __ne__(self, other): - return not self.__eq__(other) - - if six.PY2: # Python 2 - iterkeys = MutableMapping.iterkeys - itervalues = MutableMapping.itervalues - - __marker = object() - - def __len__(self): - return len(self._container) - - def __iter__(self): - # Only provide the originally cased names - for vals in self._container.values(): - yield vals[0] - - def pop(self, key, default=__marker): - """D.pop(k[,d]) -> v, remove specified key and return the corresponding value. - If key is not found, d is returned if given, otherwise KeyError is raised. - """ - # Using the MutableMapping function directly fails due to the private marker. - # Using ordinary dict.pop would expose the internal structures. - # So let's reinvent the wheel. - try: - value = self[key] - except KeyError: - if default is self.__marker: - raise - return default - else: - del self[key] - return value - - def discard(self, key): - try: - del self[key] - except KeyError: - pass - - def add(self, key, val): - """Adds a (name, value) pair, doesn't overwrite the value if it already - exists. - - >>> headers = HTTPHeaderDict(foo='bar') - >>> headers.add('Foo', 'baz') - >>> headers['foo'] - 'bar, baz' - """ - key_lower = key.lower() - new_vals = [key, val] - # Keep the common case aka no item present as fast as possible - vals = self._container.setdefault(key_lower, new_vals) - if new_vals is not vals: - vals.append(val) - - def extend(self, *args, **kwargs): - """Generic import function for any type of header-like object. - Adapted version of MutableMapping.update in order to insert items - with self.add instead of self.__setitem__ - """ - if len(args) > 1: - raise TypeError( - "extend() takes at most 1 positional " - "arguments ({0} given)".format(len(args)) - ) - other = args[0] if len(args) >= 1 else () - - if isinstance(other, HTTPHeaderDict): - for key, val in other.iteritems(): - self.add(key, val) - elif isinstance(other, Mapping): - for key in other: - self.add(key, other[key]) - elif hasattr(other, "keys"): - for key in other.keys(): - self.add(key, other[key]) - else: - for key, value in other: - self.add(key, value) - - for key, value in kwargs.items(): - self.add(key, value) - - def getlist(self, key, default=__marker): - """Returns a list of all the values for the named field. Returns an - empty list if the key doesn't exist.""" - try: - vals = self._container[key.lower()] - except KeyError: - if default is self.__marker: - return [] - return default - else: - return vals[1:] - - # Backwards compatibility for httplib - getheaders = getlist - getallmatchingheaders = getlist - iget = getlist - - # Backwards compatibility for http.cookiejar - get_all = getlist - - def __repr__(self): - return "%s(%s)" % (type(self).__name__, dict(self.itermerged())) - - def _copy_from(self, other): - for key in other: - val = other.getlist(key) - if isinstance(val, list): - # Don't need to convert tuples - val = list(val) - self._container[key.lower()] = [key] + val - - def copy(self): - clone = type(self)() - clone._copy_from(self) - return clone - - def iteritems(self): - """Iterate over all header lines, including duplicate ones.""" - for key in self: - vals = self._container[key.lower()] - for val in vals[1:]: - yield vals[0], val - - def itermerged(self): - """Iterate over all headers, merging duplicate ones together.""" - for key in self: - val = self._container[key.lower()] - yield val[0], ", ".join(val[1:]) - - def items(self): - return list(self.iteritems()) - - @classmethod - def from_httplib(cls, message): # Python 2 - """Read headers from a Python 2 httplib message object.""" - # python2.7 does not expose a proper API for exporting multiheaders - # efficiently. This function re-reads raw lines from the message - # object and extracts the multiheaders properly. - obs_fold_continued_leaders = (" ", "\t") - headers = [] - - for line in message.headers: - if line.startswith(obs_fold_continued_leaders): - if not headers: - # We received a header line that starts with OWS as described - # in RFC-7230 S3.2.4. This indicates a multiline header, but - # there exists no previous header to which we can attach it. - raise InvalidHeader( - "Header continuation with no previous header: %s" % line - ) - else: - key, value = headers[-1] - headers[-1] = (key, value + " " + line.strip()) - continue - - key, value = line.split(":", 1) - headers.append((key, value.strip())) - - return cls(headers) diff --git a/venv/lib/python3.8/site-packages/urllib3/_version.py b/venv/lib/python3.8/site-packages/urllib3/_version.py deleted file mode 100644 index e8ebee9..0000000 --- a/venv/lib/python3.8/site-packages/urllib3/_version.py +++ /dev/null @@ -1,2 +0,0 @@ -# This file is protected via CODEOWNERS -__version__ = "1.26.6" diff --git a/venv/lib/python3.8/site-packages/urllib3/connection.py b/venv/lib/python3.8/site-packages/urllib3/connection.py deleted file mode 100644 index 4c99665..0000000 --- a/venv/lib/python3.8/site-packages/urllib3/connection.py +++ /dev/null @@ -1,539 +0,0 @@ -from __future__ import absolute_import - -import datetime -import logging -import os -import re -import socket -import warnings -from socket import error as SocketError -from socket import timeout as SocketTimeout - -from .packages import six -from .packages.six.moves.http_client import HTTPConnection as _HTTPConnection -from .packages.six.moves.http_client import HTTPException # noqa: F401 -from .util.proxy import create_proxy_ssl_context - -try: # Compiled with SSL? - import ssl - - BaseSSLError = ssl.SSLError -except (ImportError, AttributeError): # Platform-specific: No SSL. - ssl = None - - class BaseSSLError(BaseException): - pass - - -try: - # Python 3: not a no-op, we're adding this to the namespace so it can be imported. - ConnectionError = ConnectionError -except NameError: - # Python 2 - class ConnectionError(Exception): - pass - - -try: # Python 3: - # Not a no-op, we're adding this to the namespace so it can be imported. - BrokenPipeError = BrokenPipeError -except NameError: # Python 2: - - class BrokenPipeError(Exception): - pass - - -from ._collections import HTTPHeaderDict # noqa (historical, removed in v2) -from ._version import __version__ -from .exceptions import ( - ConnectTimeoutError, - NewConnectionError, - 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, - resolve_cert_reqs, - resolve_ssl_version, - ssl_wrap_socket, -) - -log = logging.getLogger(__name__) - -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) - -_CONTAINS_CONTROL_CHAR_RE = re.compile(r"[^-!#$%&'*+.^_`|~0-9a-zA-Z]") - - -class HTTPConnection(_HTTPConnection, object): - """ - Based on :class:`http.client.HTTPConnection` but provides an extra constructor - backwards-compatibility layer between older and newer Pythons. - - Additional keyword parameters are used to configure attributes of the connection. - Accepted parameters include: - - - ``strict``: See the documentation on :class:`urllib3.connectionpool.HTTPConnectionPool` - - ``source_address``: Set the source address for the current connection. - - ``socket_options``: Set specific options on the underlying socket. If not specified, then - defaults are loaded from ``HTTPConnection.default_socket_options`` which includes disabling - Nagle's algorithm (sets TCP_NODELAY to 1) unless the connection is behind a proxy. - - For example, if you wish to enable TCP Keep Alive in addition to the defaults, - you might pass: - - .. code-block:: python - - HTTPConnection.default_socket_options + [ - (socket.SOL_SOCKET, socket.SO_KEEPALIVE, 1), - ] - - Or you may want to disable the defaults by passing an empty list (e.g., ``[]``). - """ - - default_port = port_by_scheme["http"] - - #: Disable Nagle's algorithm by default. - #: ``[(socket.IPPROTO_TCP, socket.TCP_NODELAY, 1)]`` - default_socket_options = [(socket.IPPROTO_TCP, socket.TCP_NODELAY, 1)] - - #: Whether this connection verifies the host's certificate. - is_verified = False - - def __init__(self, *args, **kw): - if not six.PY2: - kw.pop("strict", None) - - # Pre-set source_address. - self.source_address = kw.get("source_address") - - #: The socket options provided by the user. If no options are - #: provided, we use the default options. - self.socket_options = kw.pop("socket_options", self.default_socket_options) - - # Proxy options provided by the user. - self.proxy = kw.pop("proxy", None) - self.proxy_config = kw.pop("proxy_config", None) - - _HTTPConnection.__init__(self, *args, **kw) - - @property - def host(self): - """ - Getter method to remove any trailing dots that indicate the hostname is an FQDN. - - In general, SSL certificates don't include the trailing dot indicating a - fully-qualified domain name, and thus, they don't validate properly when - checked against a domain name that includes the dot. In addition, some - servers may not expect to receive the trailing dot when provided. - - However, the hostname with trailing dot is critical to DNS resolution; doing a - lookup with the trailing dot will properly only resolve the appropriate FQDN, - whereas a lookup without a trailing dot will search the system's search domain - list. Thus, it's important to keep the original host around for use only in - those cases where it's appropriate (i.e., when doing DNS lookup to establish the - actual TCP connection across which we're going to send HTTP requests). - """ - return self._dns_host.rstrip(".") - - @host.setter - def host(self, value): - """ - Setter for the `host` property. - - We assume that only urllib3 uses the _dns_host attribute; httplib itself - only uses `host`, and it seems reasonable that other libraries follow suit. - """ - self._dns_host = value - - def _new_conn(self): - """Establish a socket connection and set nodelay settings on it. - - :return: New socket connection. - """ - extra_kw = {} - if self.source_address: - extra_kw["source_address"] = self.source_address - - if self.socket_options: - extra_kw["socket_options"] = self.socket_options - - try: - conn = connection.create_connection( - (self._dns_host, self.port), self.timeout, **extra_kw - ) - - except SocketTimeout: - raise ConnectTimeoutError( - self, - "Connection to %s timed out. (connect timeout=%s)" - % (self.host, self.timeout), - ) - - except SocketError as e: - raise NewConnectionError( - self, "Failed to establish a new connection: %s" % e - ) - - return conn - - def _is_using_tunnel(self): - # Google App Engine's httplib does not define _tunnel_host - return getattr(self, "_tunnel_host", None) - - def _prepare_conn(self, conn): - self.sock = conn - if self._is_using_tunnel(): - # TODO: Fix tunnel so it doesn't depend on self.sock state. - self._tunnel() - # Mark this connection as not reusable - self.auto_open = 0 - - def connect(self): - conn = self._new_conn() - 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) - if match: - raise ValueError( - "Method cannot contain non-token characters %r (found at least %r)" - % (method, match.group()) - ) - - 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: - raise ValueError( - "urllib3.util.SKIP_HEADER only supports '%s'" - % ("', '".join(map(str.title, sorted(SKIPPABLE_HEADERS))),) - ) - - def request(self, method, url, body=None, headers=None): - if headers is None: - headers = {} - else: - # Avoid modifying the headers passed into .request() - headers = headers.copy() - if "user-agent" not in (six.ensure_str(k.lower()) for k in headers): - headers["User-Agent"] = _get_default_user_agent() - super(HTTPConnection, self).request(method, url, body=body, headers=headers) - - def request_chunked(self, method, url, body=None, headers=None): - """ - Alternative to the common request method, which sends the - body with chunked encoding and not as one block - """ - headers = headers or {} - header_keys = set([six.ensure_str(k.lower()) for k in headers]) - skip_accept_encoding = "accept-encoding" in header_keys - skip_host = "host" in header_keys - self.putrequest( - method, url, skip_accept_encoding=skip_accept_encoding, skip_host=skip_host - ) - if "user-agent" not in header_keys: - self.putheader("User-Agent", _get_default_user_agent()) - for header, value in headers.items(): - self.putheader(header, value) - if "transfer-encoding" not in header_keys: - self.putheader("Transfer-Encoding", "chunked") - self.endheaders() - - if body is not None: - stringish_types = six.string_types + (bytes,) - if isinstance(body, stringish_types): - body = (body,) - for chunk in body: - if not chunk: - continue - if not isinstance(chunk, bytes): - chunk = chunk.encode("utf8") - len_str = hex(len(chunk))[2:] - to_send = bytearray(len_str.encode()) - to_send += b"\r\n" - to_send += chunk - to_send += b"\r\n" - self.send(to_send) - - # After the if clause, to always have a closed body - self.send(b"0\r\n\r\n") - - -class HTTPSConnection(HTTPConnection): - """ - Many of the parameters to this constructor are passed to the underlying SSL - socket by means of :py:func:`urllib3.util.ssl_wrap_socket`. - """ - - default_port = port_by_scheme["https"] - - cert_reqs = None - ca_certs = None - ca_cert_dir = None - ca_cert_data = None - ssl_version = None - assert_fingerprint = None - tls_in_tls_required = False - - def __init__( - self, - host, - port=None, - key_file=None, - cert_file=None, - key_password=None, - strict=None, - timeout=socket._GLOBAL_DEFAULT_TIMEOUT, - ssl_context=None, - server_hostname=None, - **kw - ): - - HTTPConnection.__init__(self, host, port, strict=strict, timeout=timeout, **kw) - - self.key_file = key_file - self.cert_file = cert_file - self.key_password = key_password - self.ssl_context = ssl_context - self.server_hostname = server_hostname - - # Required property for Google AppEngine 1.9.0 which otherwise causes - # HTTPS requests to go out as HTTP. (See Issue #356) - self._protocol = "https" - - def set_cert( - self, - key_file=None, - cert_file=None, - cert_reqs=None, - key_password=None, - ca_certs=None, - assert_hostname=None, - assert_fingerprint=None, - ca_cert_dir=None, - ca_cert_data=None, - ): - """ - This method should only be called once, before the connection is used. - """ - # If cert_reqs is not provided we'll assume CERT_REQUIRED unless we also - # have an SSLContext object in which case we'll use its verify_mode. - if cert_reqs is None: - if self.ssl_context is not None: - cert_reqs = self.ssl_context.verify_mode - else: - cert_reqs = resolve_cert_reqs(None) - - self.key_file = key_file - self.cert_file = cert_file - self.cert_reqs = cert_reqs - self.key_password = key_password - self.assert_hostname = assert_hostname - self.assert_fingerprint = assert_fingerprint - self.ca_certs = ca_certs and os.path.expanduser(ca_certs) - self.ca_cert_dir = ca_cert_dir and os.path.expanduser(ca_cert_dir) - self.ca_cert_data = ca_cert_data - - def connect(self): - # Add certificate verification - 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) - tls_in_tls = True - - self.sock = conn - - # Calls self._set_hostport(), so self.host is - # self._tunnel_host below. - self._tunnel() - # Mark this connection as not reusable - self.auto_open = 0 - - # Override the host with the one we're requesting data from. - hostname = self._tunnel_host - - server_hostname = hostname - if self.server_hostname is not None: - server_hostname = self.server_hostname - - is_time_off = datetime.date.today() < RECENT_DATE - if is_time_off: - warnings.warn( - ( - "System time is way off (before {0}). This will probably " - "lead to SSL verification errors" - ).format(RECENT_DATE), - SystemTimeWarning, - ) - - # Wrap socket using verification with the root certs in - # trusted_root_certs - default_ssl_context = False - if self.ssl_context is None: - default_ssl_context = True - self.ssl_context = create_urllib3_context( - ssl_version=resolve_ssl_version(self.ssl_version), - cert_reqs=resolve_cert_reqs(self.cert_reqs), - ) - - context = self.ssl_context - context.verify_mode = resolve_cert_reqs(self.cert_reqs) - - # Try to load OS default certs if none are given. - # Works well on Windows (requires Python3.4+) - if ( - not self.ca_certs - and not self.ca_cert_dir - and not self.ca_cert_data - and default_ssl_context - and hasattr(context, "load_default_certs") - ): - context.load_default_certs() - - self.sock = ssl_wrap_socket( - sock=conn, - keyfile=self.key_file, - certfile=self.cert_file, - key_password=self.key_password, - ca_certs=self.ca_certs, - ca_cert_dir=self.ca_cert_dir, - ca_cert_data=self.ca_cert_data, - server_hostname=server_hostname, - ssl_context=context, - tls_in_tls=tls_in_tls, - ) - - # If we're using all defaults and the connection - # is TLSv1 or TLSv1.1 we throw a DeprecationWarning - # for the host. - if ( - default_ssl_context - and self.ssl_version is None - and hasattr(self.sock, "version") - and self.sock.version() in {"TLSv1", "TLSv1.1"} - ): - warnings.warn( - "Negotiating TLSv1/TLSv1.1 by default is deprecated " - "and will be disabled in urllib3 v2.0.0. Connecting to " - "'%s' with '%s' can be enabled by explicitly opting-in " - "with 'ssl_version'" % (self.host, self.sock.version()), - DeprecationWarning, - ) - - if self.assert_fingerprint: - assert_fingerprint( - self.sock.getpeercert(binary_form=True), self.assert_fingerprint - ) - elif ( - context.verify_mode != ssl.CERT_NONE - and not getattr(context, "check_hostname", False) - and self.assert_hostname is not 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 = self.sock.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, self.assert_hostname or server_hostname) - - self.is_verified = ( - context.verify_mode == ssl.CERT_REQUIRED - or self.assert_fingerprint is not None - ) - - def _connect_tls_proxy(self, hostname, conn): - """ - Establish a TLS connection to the proxy using the provided SSL context. - """ - proxy_config = self.proxy_config - ssl_context = proxy_config.ssl_context - if ssl_context: - # If the user provided a proxy context, we assume CA and client - # certificates have already been set - return ssl_wrap_socket( - sock=conn, - server_hostname=hostname, - ssl_context=ssl_context, - ) - - ssl_context = create_proxy_ssl_context( - self.ssl_version, - self.cert_reqs, - self.ca_certs, - 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( - sock=conn, - ca_certs=self.ca_certs, - ca_cert_dir=self.ca_cert_dir, - ca_cert_data=self.ca_cert_data, - server_hostname=hostname, - ssl_context=ssl_context, - ) - - -def _match_hostname(cert, asserted_hostname): - try: - match_hostname(cert, asserted_hostname) - except CertificateError as e: - log.warning( - "Certificate did not match expected hostname: %s. Certificate: %s", - asserted_hostname, - cert, - ) - # Add cert to exception and reraise so client code can inspect - # the cert when catching the exception, if they want to - e._peer_cert = cert - raise - - -def _get_default_user_agent(): - return "python-urllib3/%s" % __version__ - - -class DummyConnection(object): - """Used to detect a failed ConnectionCls import.""" - - pass - - -if not ssl: - HTTPSConnection = DummyConnection # noqa: F811 - - -VerifiedHTTPSConnection = HTTPSConnection diff --git a/venv/lib/python3.8/site-packages/urllib3/connectionpool.py b/venv/lib/python3.8/site-packages/urllib3/connectionpool.py deleted file mode 100644 index 459bbe0..0000000 --- a/venv/lib/python3.8/site-packages/urllib3/connectionpool.py +++ /dev/null @@ -1,1067 +0,0 @@ -from __future__ import absolute_import - -import errno -import logging -import socket -import sys -import warnings -from socket import error as SocketError -from socket import timeout as SocketTimeout - -from .connection import ( - BaseSSLError, - BrokenPipeError, - DummyConnection, - HTTPConnection, - HTTPException, - HTTPSConnection, - VerifiedHTTPSConnection, - port_by_scheme, -) -from .exceptions import ( - ClosedPoolError, - EmptyPoolError, - HeaderParsingError, - HostChangedError, - InsecureRequestWarning, - LocationValueError, - MaxRetryError, - NewConnectionError, - ProtocolError, - ProxyError, - ReadTimeoutError, - SSLError, - TimeoutError, -) -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 -from .util.proxy import connection_requires_http_tunnel -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.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 - -xrange = six.moves.xrange - -log = logging.getLogger(__name__) - -_Default = object() - - -# Pool objects -class ConnectionPool(object): - """ - Base class for all connection pools, such as - :class:`.HTTPConnectionPool` and :class:`.HTTPSConnectionPool`. - - .. note:: - ConnectionPool.urlopen() does not normalize or percent-encode target URIs - which is useful if your target server doesn't support percent-encoded - target URIs. - """ - - scheme = None - QueueCls = LifoQueue - - def __init__(self, host, port=None): - if not host: - raise LocationValueError("No host specified.") - - self.host = _normalize_host(host, scheme=self.scheme) - self._proxy_host = host.lower() - self.port = port - - def __str__(self): - return "%s(host=%r, port=%r)" % (type(self).__name__, self.host, self.port) - - def __enter__(self): - return self - - def __exit__(self, exc_type, exc_val, exc_tb): - self.close() - # Return False to re-raise any potential exceptions - return False - - def close(self): - """ - Close all pooled connections and disable the pool. - """ - pass - - -# This is taken from http://hg.python.org/cpython/file/7aaba721ebc0/Lib/socket.py#l252 -_blocking_errnos = {errno.EAGAIN, errno.EWOULDBLOCK} - - -class HTTPConnectionPool(ConnectionPool, RequestMethods): - """ - Thread-safe connection pool for one host. - - :param host: - Host used for this HTTP Connection (e.g. "localhost"), passed into - :class:`http.client.HTTPConnection`. - - :param port: - Port used for this HTTP Connection (None is equivalent to 80), passed - into :class:`http.client.HTTPConnection`. - - :param strict: - Causes BadStatusLine to be raised if the status line can't be parsed - as a valid HTTP/1.0 or 1.1 status line, passed into - :class:`http.client.HTTPConnection`. - - .. note:: - Only works in Python 2. This parameter is ignored in Python 3. - - :param timeout: - Socket timeout in seconds for each individual connection. This can - be a float or integer, which sets the timeout for the HTTP request, - or an instance of :class:`urllib3.util.Timeout` which gives you more - fine-grained control over request timeouts. After the constructor has - been parsed, this is always a `urllib3.util.Timeout` object. - - :param maxsize: - Number of connections to save that can be reused. More than 1 is useful - in multithreaded situations. If ``block`` is set to False, more - connections will be created but they will not be saved once they've - been used. - - :param block: - If set to True, no more than ``maxsize`` connections will be used at - a time. When no free connections are available, the call will block - until a connection has been released. This is a useful side effect for - particular multithreaded situations where one does not want to use more - than maxsize connections per host to prevent flooding. - - :param headers: - Headers to include with all requests, unless other headers are given - explicitly. - - :param retries: - Retry configuration to use by default with requests in this pool. - - :param _proxy: - Parsed proxy URL, should not be used directly, instead, see - :class:`urllib3.ProxyManager` - - :param _proxy_headers: - A dictionary with proxy headers, should not be used directly, - instead, see :class:`urllib3.ProxyManager` - - :param \\**conn_kw: - Additional parameters are used to create fresh :class:`urllib3.connection.HTTPConnection`, - :class:`urllib3.connection.HTTPSConnection` instances. - """ - - scheme = "http" - ConnectionCls = HTTPConnection - ResponseCls = HTTPResponse - - def __init__( - self, - host, - port=None, - strict=False, - timeout=Timeout.DEFAULT_TIMEOUT, - maxsize=1, - block=False, - headers=None, - retries=None, - _proxy=None, - _proxy_headers=None, - _proxy_config=None, - **conn_kw - ): - ConnectionPool.__init__(self, host, port) - RequestMethods.__init__(self, headers) - - self.strict = strict - - if not isinstance(timeout, Timeout): - timeout = Timeout.from_float(timeout) - - if retries is None: - retries = Retry.DEFAULT - - self.timeout = timeout - self.retries = retries - - self.pool = self.QueueCls(maxsize) - self.block = block - - self.proxy = _proxy - self.proxy_headers = _proxy_headers or {} - self.proxy_config = _proxy_config - - # Fill the queue up so that doing get() on it will block properly - for _ in xrange(maxsize): - self.pool.put(None) - - # These are mostly for testing and debugging purposes. - self.num_connections = 0 - self.num_requests = 0 - self.conn_kw = conn_kw - - if self.proxy: - # Enable Nagle's algorithm for proxies, to avoid packet fragmentation. - # We cannot know if the user has added default socket options, so we cannot replace the - # list. - self.conn_kw.setdefault("socket_options", []) - - self.conn_kw["proxy"] = self.proxy - self.conn_kw["proxy_config"] = self.proxy_config - - def _new_conn(self): - """ - Return a fresh :class:`HTTPConnection`. - """ - self.num_connections += 1 - log.debug( - "Starting new HTTP connection (%d): %s:%s", - self.num_connections, - self.host, - self.port or "80", - ) - - conn = self.ConnectionCls( - host=self.host, - port=self.port, - timeout=self.timeout.connect_timeout, - strict=self.strict, - **self.conn_kw - ) - return conn - - def _get_conn(self, timeout=None): - """ - Get a connection. Will return a pooled connection if one is available. - - If no connections are available and :prop:`.block` is ``False``, then a - fresh connection is returned. - - :param timeout: - Seconds to wait before giving up and raising - :class:`urllib3.exceptions.EmptyPoolError` if the pool is empty and - :prop:`.block` is ``True``. - """ - conn = None - try: - conn = self.pool.get(block=self.block, timeout=timeout) - - except AttributeError: # self.pool is None - raise ClosedPoolError(self, "Pool is closed.") - - except queue.Empty: - if self.block: - raise EmptyPoolError( - self, - "Pool reached maximum size and no more connections are allowed.", - ) - pass # Oh well, we'll create a new connection then - - # If this is a persistent connection, check if it got disconnected - if conn and is_connection_dropped(conn): - log.debug("Resetting dropped connection: %s", self.host) - conn.close() - if getattr(conn, "auto_open", 1) == 0: - # This is a proxied connection that has been mutated by - # http.client._tunnel() and cannot be reused (since it would - # attempt to bypass the proxy) - conn = None - - return conn or self._new_conn() - - def _put_conn(self, conn): - """ - Put a connection back into the pool. - - :param conn: - Connection object for the current host and port as returned by - :meth:`._new_conn` or :meth:`._get_conn`. - - If the pool is already full, the connection is closed and discarded - because we exceeded maxsize. If connections are discarded frequently, - then maxsize should be increased. - - If the pool is closed, then the connection will be closed and discarded. - """ - try: - self.pool.put(conn, block=False) - return # Everything is dandy, done. - except AttributeError: - # self.pool is None. - pass - except queue.Full: - # This should never happen if self.block == True - log.warning("Connection pool is full, discarding connection: %s", self.host) - - # Connection never got put back into the pool, close it. - if conn: - conn.close() - - def _validate_conn(self, conn): - """ - Called right before a request is made, after the socket is created. - """ - pass - - def _prepare_proxy(self, conn): - # Nothing to do for HTTP connections. - pass - - def _get_timeout(self, timeout): - """Helper that always returns a :class:`urllib3.util.Timeout`""" - if timeout is _Default: - return self.timeout.clone() - - if isinstance(timeout, Timeout): - return timeout.clone() - else: - # User passed us an int/float. This is for backwards compatibility, - # can be removed later - return Timeout.from_float(timeout) - - def _raise_timeout(self, err, url, timeout_value): - """Is the error actually a timeout? Will raise a ReadTimeout or pass""" - - if isinstance(err, SocketTimeout): - raise ReadTimeoutError( - self, url, "Read timed out. (read timeout=%s)" % timeout_value - ) - - # See the above comment about EAGAIN in Python 3. In Python 2 we have - # to specifically catch it and throw the timeout error - if hasattr(err, "errno") and err.errno in _blocking_errnos: - raise ReadTimeoutError( - self, url, "Read timed out. (read timeout=%s)" % timeout_value - ) - - # Catch possible read timeouts thrown as SSL errors. If not the - # case, rethrow the original. We need to do this because of: - # http://bugs.python.org/issue10272 - if "timed out" in str(err) or "did not complete (read)" in str( - err - ): # Python < 2.7.4 - raise ReadTimeoutError( - self, url, "Read timed out. (read timeout=%s)" % timeout_value - ) - - def _make_request( - self, conn, method, url, timeout=_Default, chunked=False, **httplib_request_kw - ): - """ - Perform a request on a given urllib connection object taken from our - pool. - - :param conn: - a connection from one of our connection pools - - :param timeout: - Socket timeout in seconds for the request. This can be a - float or integer, which will set the same timeout value for - the socket connect and the socket read, or an instance of - :class:`urllib3.util.Timeout`, which gives you more fine-grained - control over your timeouts. - """ - self.num_requests += 1 - - timeout_obj = self._get_timeout(timeout) - timeout_obj.start_connect() - conn.timeout = timeout_obj.connect_timeout - - # Trigger any extra validation we need to do. - try: - self._validate_conn(conn) - except (SocketTimeout, BaseSSLError) as e: - # Py2 raises this as a BaseSSLError, Py3 raises it as socket timeout. - self._raise_timeout(err=e, url=url, timeout_value=conn.timeout) - raise - - # conn.request() calls http.client.*.request, not the method in - # urllib3.request. It also calls makefile (recv) on the socket. - try: - if chunked: - conn.request_chunked(method, url, **httplib_request_kw) - else: - conn.request(method, url, **httplib_request_kw) - - # We are swallowing BrokenPipeError (errno.EPIPE) since the server is - # legitimately able to close the connection after sending a valid response. - # With this behaviour, the received response is still readable. - except BrokenPipeError: - # Python 3 - pass - except IOError as e: - # Python 2 and macOS/Linux - # EPIPE and ESHUTDOWN are BrokenPipeError on Python 2, and EPROTOTYPE is needed on macOS - # https://erickt.github.io/blog/2014/11/19/adventures-in-debugging-a-potential-osx-kernel-bug/ - if e.errno not in { - errno.EPIPE, - errno.ESHUTDOWN, - errno.EPROTOTYPE, - }: - raise - - # Reset the timeout for the recv() on the socket - read_timeout = timeout_obj.read_timeout - - # App Engine doesn't have a sock attr - if getattr(conn, "sock", None): - # In Python 3 socket.py will catch EAGAIN and return None when you - # try and read into the file pointer created by http.client, which - # instead raises a BadStatusLine exception. Instead of catching - # the exception and assuming all BadStatusLine exceptions are read - # timeouts, check for a zero timeout before making the request. - if read_timeout == 0: - raise ReadTimeoutError( - self, url, "Read timed out. (read timeout=%s)" % read_timeout - ) - if read_timeout is Timeout.DEFAULT_TIMEOUT: - conn.sock.settimeout(socket.getdefaulttimeout()) - else: # None or a value - conn.sock.settimeout(read_timeout) - - # Receive the response from the server - try: - try: - # Python 2.7, use buffering of HTTP responses - httplib_response = conn.getresponse(buffering=True) - except TypeError: - # Python 3 - try: - httplib_response = conn.getresponse() - except BaseException as e: - # Remove the TypeError from the exception chain in - # Python 3 (including for exceptions like SystemExit). - # Otherwise it looks like a bug in the code. - six.raise_from(e, None) - except (SocketTimeout, BaseSSLError, SocketError) as e: - self._raise_timeout(err=e, url=url, timeout_value=read_timeout) - raise - - # AppEngine doesn't have a version attr. - http_version = getattr(conn, "_http_vsn_str", "HTTP/?") - log.debug( - '%s://%s:%s "%s %s %s" %s %s', - self.scheme, - self.host, - self.port, - method, - url, - http_version, - httplib_response.status, - httplib_response.length, - ) - - try: - assert_header_parsing(httplib_response.msg) - except (HeaderParsingError, TypeError) as hpe: # Platform-specific: Python 3 - log.warning( - "Failed to parse headers (url=%s): %s", - self._absolute_url(url), - hpe, - exc_info=True, - ) - - return httplib_response - - def _absolute_url(self, path): - return Url(scheme=self.scheme, host=self.host, port=self.port, path=path).url - - def close(self): - """ - Close all pooled connections and disable the pool. - """ - if self.pool is None: - return - # 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. - - def is_same_host(self, url): - """ - Check if the given ``url`` is a member of the same host as this - connection pool. - """ - if url.startswith("/"): - return True - - # TODO: Add optional support for socket.gethostbyname checking. - scheme, host, port = get_host(url) - if host is not None: - host = _normalize_host(host, scheme=scheme) - - # Use explicit default port for comparison when none is given - if self.port and not port: - port = port_by_scheme.get(scheme) - elif not self.port and port == port_by_scheme.get(scheme): - port = None - - return (scheme, host, port) == (self.scheme, self.host, self.port) - - def urlopen( - self, - method, - url, - body=None, - headers=None, - retries=None, - redirect=True, - assert_same_host=True, - timeout=_Default, - pool_timeout=None, - release_conn=None, - chunked=False, - body_pos=None, - **response_kw - ): - """ - Get a connection from the pool and perform an HTTP request. This is the - lowest level call for making a request, so you'll need to specify all - the raw details. - - .. note:: - - More commonly, it's appropriate to use a convenience method provided - by :class:`.RequestMethods`, such as :meth:`request`. - - .. note:: - - `release_conn` will only behave as expected if - `preload_content=False` because we want to make - `preload_content=False` the default behaviour someday soon without - breaking backwards compatibility. - - :param method: - HTTP request method (such as GET, POST, PUT, etc.) - - :param url: - The URL to perform the request on. - - :param body: - Data to send in the request body, either :class:`str`, :class:`bytes`, - an iterable of :class:`str`/:class:`bytes`, or a file-like object. - - :param headers: - Dictionary of custom headers to send, such as User-Agent, - If-None-Match, etc. If None, pool headers are used. If provided, - these headers completely replace any pool-specific headers. - - :param retries: - Configure the number of retries to allow before raising a - :class:`~urllib3.exceptions.MaxRetryError` exception. - - Pass ``None`` to retry until you receive a response. Pass a - :class:`~urllib3.util.retry.Retry` object for fine-grained control - over different types of retries. - Pass an integer number to retry connection errors that many times, - but no other types of errors. Pass zero to never retry. - - If ``False``, then retries are disabled and any exception is raised - immediately. Also, instead of raising a MaxRetryError on redirects, - the redirect response will be returned. - - :type retries: :class:`~urllib3.util.retry.Retry`, False, or an int. - - :param redirect: - If True, automatically handle redirects (status codes 301, 302, - 303, 307, 308). Each redirect counts as a retry. Disabling retries - will disable redirect, too. - - :param assert_same_host: - If ``True``, will make sure that the host of the pool requests is - consistent else will raise HostChangedError. When ``False``, you can - use the pool on an HTTP proxy and request foreign hosts. - - :param timeout: - If specified, overrides the default timeout for this one - request. It may be a float (in seconds) or an instance of - :class:`urllib3.util.Timeout`. - - :param pool_timeout: - If set and the pool is set to block=True, then this method will - block for ``pool_timeout`` seconds and raise EmptyPoolError if no - connection is available within the time period. - - :param release_conn: - If False, then the urlopen call will not release the connection - back into the pool once a response is received (but will release if - you read the entire contents of the response such as when - `preload_content=True`). This is useful if you're not preloading - the response's content immediately. You will need to call - ``r.release_conn()`` on the response ``r`` to return the connection - back into the pool. If None, it takes the value of - ``response_kw.get('preload_content', True)``. - - :param chunked: - If True, urllib3 will send the body using chunked transfer - encoding. Otherwise, urllib3 will send the body using the standard - content-length form. Defaults to False. - - :param int body_pos: - Position to seek to in file-like body in the event of a retry or - redirect. Typically this won't need to be set because urllib3 will - auto-populate the value when needed. - - :param \\**response_kw: - Additional parameters are passed to - :meth:`urllib3.response.HTTPResponse.from_httplib` - """ - - parsed_url = parse_url(url) - destination_scheme = parsed_url.scheme - - if headers is None: - headers = self.headers - - if not isinstance(retries, Retry): - retries = Retry.from_int(retries, redirect=redirect, default=self.retries) - - if release_conn is None: - release_conn = response_kw.get("preload_content", True) - - # Check host - if assert_same_host and not self.is_same_host(url): - raise HostChangedError(self, url, retries) - - # Ensure that the URL we're connecting to is properly encoded - if url.startswith("/"): - url = six.ensure_str(_encode_target(url)) - else: - url = six.ensure_str(parsed_url.url) - - conn = None - - # Track whether `conn` needs to be released before - # returning/raising/recursing. Update this variable if necessary, and - # leave `release_conn` constant throughout the function. That way, if - # the function recurses, the original value of `release_conn` will be - # passed down into the recursive call, and its value will be respected. - # - # See issue #651 [1] for details. - # - # [1] - release_this_conn = release_conn - - http_tunnel_required = connection_requires_http_tunnel( - self.proxy, self.proxy_config, destination_scheme - ) - - # Merge the proxy headers. Only done when not using HTTP CONNECT. We - # have to copy the headers dict so we can safely change it without those - # changes being reflected in anyone else's copy. - if not http_tunnel_required: - headers = headers.copy() - headers.update(self.proxy_headers) - - # Must keep the exception bound to a separate variable or else Python 3 - # complains about UnboundLocalError. - err = None - - # Keep track of whether we cleanly exited the except block. This - # ensures we do proper cleanup in finally. - clean_exit = False - - # Rewind body position, if needed. Record current position - # for future rewinds in the event of a redirect/retry. - body_pos = set_file_position(body, body_pos) - - try: - # Request a connection from the queue. - timeout_obj = self._get_timeout(timeout) - conn = self._get_conn(timeout=pool_timeout) - - conn.timeout = timeout_obj.connect_timeout - - is_new_proxy_conn = self.proxy is not None and not getattr( - conn, "sock", None - ) - if is_new_proxy_conn and http_tunnel_required: - self._prepare_proxy(conn) - - # Make the request on the httplib connection object. - httplib_response = self._make_request( - conn, - method, - url, - timeout=timeout_obj, - body=body, - headers=headers, - chunked=chunked, - ) - - # If we're going to release the connection in ``finally:``, then - # the response doesn't need to know about the connection. Otherwise - # it will also try to release it and we'll have a double-release - # mess. - response_conn = conn if not release_conn else None - - # Pass method to Response for length checking - response_kw["request_method"] = method - - # Import httplib's response into our own wrapper object - response = self.ResponseCls.from_httplib( - httplib_response, - pool=self, - connection=response_conn, - retries=retries, - **response_kw - ) - - # Everything went great! - clean_exit = True - - except EmptyPoolError: - # Didn't get a connection from the pool, no need to clean up - clean_exit = True - release_this_conn = False - raise - - except ( - TimeoutError, - HTTPException, - SocketError, - ProtocolError, - BaseSSLError, - SSLError, - CertificateError, - ) as e: - # Discard the connection for these exceptions. It will be - # replaced during the next _get_conn() call. - clean_exit = False - if isinstance(e, (BaseSSLError, CertificateError)): - e = SSLError(e) - elif isinstance(e, (SocketError, NewConnectionError)) and self.proxy: - e = ProxyError("Cannot connect to proxy.", e) - elif isinstance(e, (SocketError, HTTPException)): - e = ProtocolError("Connection aborted.", e) - - retries = retries.increment( - method, url, error=e, _pool=self, _stacktrace=sys.exc_info()[2] - ) - retries.sleep() - - # Keep track of the error for the retry warning. - err = e - - finally: - if not clean_exit: - # We hit some kind of exception, handled or otherwise. We need - # to throw the connection away unless explicitly told not to. - # Close the connection, set the variable to None, and make sure - # we put the None back in the pool to avoid leaking it. - conn = conn and conn.close() - release_this_conn = True - - if release_this_conn: - # Put the connection back to be reused. If the connection is - # expired then it will be None, which will get replaced with a - # fresh connection during _get_conn. - self._put_conn(conn) - - if not conn: - # Try again - log.warning( - "Retrying (%r) after connection broken by '%r': %s", retries, err, url - ) - return self.urlopen( - method, - url, - body, - headers, - retries, - redirect, - assert_same_host, - timeout=timeout, - pool_timeout=pool_timeout, - release_conn=release_conn, - chunked=chunked, - body_pos=body_pos, - **response_kw - ) - - # Handle redirect? - redirect_location = redirect and response.get_redirect_location() - if redirect_location: - if response.status == 303: - method = "GET" - - try: - retries = retries.increment(method, url, response=response, _pool=self) - except MaxRetryError: - if retries.raise_on_redirect: - response.drain_conn() - raise - return response - - response.drain_conn() - retries.sleep_for_retry(response) - log.debug("Redirecting %s -> %s", url, redirect_location) - return self.urlopen( - method, - redirect_location, - body, - headers, - retries=retries, - redirect=redirect, - assert_same_host=assert_same_host, - timeout=timeout, - pool_timeout=pool_timeout, - release_conn=release_conn, - chunked=chunked, - body_pos=body_pos, - **response_kw - ) - - # Check if we should retry the HTTP response. - has_retry_after = bool(response.getheader("Retry-After")) - if retries.is_retry(method, response.status, has_retry_after): - try: - retries = retries.increment(method, url, response=response, _pool=self) - except MaxRetryError: - if retries.raise_on_status: - response.drain_conn() - raise - return response - - response.drain_conn() - retries.sleep(response) - log.debug("Retry: %s", url) - return self.urlopen( - method, - url, - body, - headers, - retries=retries, - redirect=redirect, - assert_same_host=assert_same_host, - timeout=timeout, - pool_timeout=pool_timeout, - release_conn=release_conn, - chunked=chunked, - body_pos=body_pos, - **response_kw - ) - - return response - - -class HTTPSConnectionPool(HTTPConnectionPool): - """ - Same as :class:`.HTTPConnectionPool`, but HTTPS. - - :class:`.HTTPSConnection` uses one of ``assert_fingerprint``, - ``assert_hostname`` and ``host`` in this order to verify connections. - If ``assert_hostname`` is False, no verification is done. - - The ``key_file``, ``cert_file``, ``cert_reqs``, ``ca_certs``, - ``ca_cert_dir``, ``ssl_version``, ``key_password`` are only used if :mod:`ssl` - is available and are fed into :meth:`urllib3.util.ssl_wrap_socket` to upgrade - the connection socket into an SSL socket. - """ - - scheme = "https" - ConnectionCls = HTTPSConnection - - def __init__( - self, - host, - port=None, - strict=False, - timeout=Timeout.DEFAULT_TIMEOUT, - maxsize=1, - block=False, - headers=None, - retries=None, - _proxy=None, - _proxy_headers=None, - key_file=None, - cert_file=None, - cert_reqs=None, - key_password=None, - ca_certs=None, - ssl_version=None, - assert_hostname=None, - assert_fingerprint=None, - ca_cert_dir=None, - **conn_kw - ): - - HTTPConnectionPool.__init__( - self, - host, - port, - strict, - timeout, - maxsize, - block, - headers, - retries, - _proxy, - _proxy_headers, - **conn_kw - ) - - self.key_file = key_file - self.cert_file = cert_file - self.cert_reqs = cert_reqs - self.key_password = key_password - self.ca_certs = ca_certs - self.ca_cert_dir = ca_cert_dir - self.ssl_version = ssl_version - self.assert_hostname = assert_hostname - self.assert_fingerprint = assert_fingerprint - - def _prepare_conn(self, conn): - """ - Prepare the ``connection`` for :meth:`urllib3.util.ssl_wrap_socket` - and establish the tunnel if proxy is used. - """ - - if isinstance(conn, VerifiedHTTPSConnection): - conn.set_cert( - key_file=self.key_file, - key_password=self.key_password, - cert_file=self.cert_file, - cert_reqs=self.cert_reqs, - ca_certs=self.ca_certs, - ca_cert_dir=self.ca_cert_dir, - assert_hostname=self.assert_hostname, - assert_fingerprint=self.assert_fingerprint, - ) - conn.ssl_version = self.ssl_version - return conn - - def _prepare_proxy(self, conn): - """ - Establishes a tunnel connection through HTTP CONNECT. - - Tunnel connection is established early because otherwise httplib would - improperly set Host: header to proxy's IP:port. - """ - - conn.set_tunnel(self._proxy_host, self.port, self.proxy_headers) - - if self.proxy.scheme == "https": - conn.tls_in_tls_required = True - - conn.connect() - - def _new_conn(self): - """ - Return a fresh :class:`http.client.HTTPSConnection`. - """ - self.num_connections += 1 - log.debug( - "Starting new HTTPS connection (%d): %s:%s", - self.num_connections, - self.host, - self.port or "443", - ) - - if not self.ConnectionCls or self.ConnectionCls is DummyConnection: - raise SSLError( - "Can't connect to HTTPS URL because the SSL module is not available." - ) - - actual_host = self.host - actual_port = self.port - if self.proxy is not None: - actual_host = self.proxy.host - actual_port = self.proxy.port - - conn = self.ConnectionCls( - host=actual_host, - port=actual_port, - timeout=self.timeout.connect_timeout, - strict=self.strict, - cert_file=self.cert_file, - key_file=self.key_file, - key_password=self.key_password, - **self.conn_kw - ) - - return self._prepare_conn(conn) - - def _validate_conn(self, conn): - """ - Called right before a request is made, after the socket is created. - """ - super(HTTPSConnectionPool, self)._validate_conn(conn) - - # Force connect early to allow us to validate the connection. - if not getattr(conn, "sock", None): # AppEngine might not have `.sock` - conn.connect() - - if not conn.is_verified: - warnings.warn( - ( - "Unverified HTTPS request is being made to host '%s'. " - "Adding certificate verification is strongly advised. See: " - "https://urllib3.readthedocs.io/en/1.26.x/advanced-usage.html" - "#ssl-warnings" % conn.host - ), - InsecureRequestWarning, - ) - - -def connection_from_url(url, **kw): - """ - Given a url, return an :class:`.ConnectionPool` instance of its host. - - This is a shortcut for not having to parse out the scheme, host, and port - of the url before creating an :class:`.ConnectionPool` instance. - - :param url: - Absolute URL string that must include the scheme. Port is optional. - - :param \\**kw: - Passes additional parameters to the constructor of the appropriate - :class:`.ConnectionPool`. Useful for specifying things like - timeout, maxsize, headers, etc. - - Example:: - - >>> conn = connection_from_url('http://google.com/') - >>> r = conn.request('GET', '/') - """ - scheme, host, port = get_host(url) - port = port or port_by_scheme.get(scheme, 80) - if scheme == "https": - return HTTPSConnectionPool(host, port=port, **kw) - else: - return HTTPConnectionPool(host, port=port, **kw) - - -def _normalize_host(host, scheme): - """ - Normalize hosts for comparisons and use with sockets. - """ - - host = normalize_host(host, scheme) - - # httplib doesn't like it when we include brackets in IPv6 addresses - # Specifically, if we include brackets but also pass the port then - # httplib crazily doubles up the square brackets on the Host header. - # Instead, we need to make sure we never pass ``None`` as the port. - # However, for backward compatibility reasons we can't actually - # *assert* that. See http://bugs.python.org/issue28539 - if host.startswith("[") and host.endswith("]"): - host = host[1:-1] - return host diff --git a/venv/lib/python3.8/site-packages/urllib3/contrib/__init__.py b/venv/lib/python3.8/site-packages/urllib3/contrib/__init__.py deleted file mode 100644 index e69de29..0000000 diff --git a/venv/lib/python3.8/site-packages/urllib3/contrib/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/urllib3/contrib/__pycache__/__init__.cpython-38.pyc deleted file mode 100644 index 608fb1a665455acfe66f8136d1864b2cef785d68..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 151 zcmWIL<>g`kf(lF3L=gQLL?8o3AjbiSi&=m~3PUi1CZpdQUs{xtlbK|!pPZjpQk0pbA0MBYmst`YuUAlc Ui^C>2KczG$)edCpXCP((0OX4z{Qv*} diff --git a/venv/lib/python3.8/site-packages/urllib3/contrib/__pycache__/_appengine_environ.cpython-38.pyc b/venv/lib/python3.8/site-packages/urllib3/contrib/__pycache__/_appengine_environ.cpython-38.pyc deleted file mode 100644 index 4164d6578253ba1d97d15eba8e477be4c8480ef6..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1375 zcmb_cL2nc{6!v&FyTc?YO@xq;5VEK$6p8Fe?V$u!6#+Jg0}I*&D&;boo#*U0J8N6E zXGwB}9|A{y1b<|%J@qg2PRTgz#Xw8G$b_2g51i1S2iI@)lJeYs>GB?wi7J9pp zx+td{w%=Bq*V`xKsXN)((OF~aT8w|qN+q2UWJg>p<17rVPgc(rh`Rhs8JO!-*NHQW(xqj!FvTtv+SeiMsZ#i*J7JvvK2? zaKW3`wJ9rBbBjQ@MM_F1=KMah>cYSGa;h3;E7jB>?>Qzp2QPeC@p8(JltFL(;LdW+ zD(AF)m}O~VIcd4J$Pt0c3-_344*w84)W3K;lcA4 zgErBpu2S-s-?rkwe@m5Zdlzb5iGRLZK?&L$i}K|c1o|R7m$7G7ala&^FQXvi9o#_V z$Z<67s@s13K!HO1k$%9|`52*~D?`)6SMBxv!RXCkl<&XXJNR>VG-%1$+EYH~wbH)y zvrip!4c{5xs%<>su1zsevBxgUpkcj8*cs&(8e=i*3q18 zJ`4IRG;U^o@VA#Ob;YWQ@!~elWn}(l3E5?Ldtcy5qi3s6xi-8k9Ebki_d!C;px@1< zF3)H4nZ4_Sheo7k1NU3KwwLEvO?iIKvhU8IZQv>Z4iCSN6oMqbpZ}%(;em#nI-Mj= KI!T&zlkQh22uHO5 diff --git a/venv/lib/python3.8/site-packages/urllib3/contrib/__pycache__/appengine.cpython-38.pyc b/venv/lib/python3.8/site-packages/urllib3/contrib/__pycache__/appengine.cpython-38.pyc deleted file mode 100644 index 99e8b78238fbf741ef8562f42af788f5b902f1f8..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 8200 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 OhVL(>HB>6Z_kRI`S|Sbr diff --git a/venv/lib/python3.8/site-packages/urllib3/contrib/__pycache__/ntlmpool.cpython-38.pyc b/venv/lib/python3.8/site-packages/urllib3/contrib/__pycache__/ntlmpool.cpython-38.pyc deleted file mode 100644 index 44e528b9803053242fd09618db5aa7e49914ad2c..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3594 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 diff --git a/venv/lib/python3.8/site-packages/urllib3/contrib/__pycache__/socks.cpython-38.pyc b/venv/lib/python3.8/site-packages/urllib3/contrib/__pycache__/socks.cpython-38.pyc deleted file mode 100644 index df514ff7e17dae35555eff2cb5b700f73704d7aa..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 5589 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 diff --git a/venv/lib/python3.8/site-packages/urllib3/contrib/_appengine_environ.py b/venv/lib/python3.8/site-packages/urllib3/contrib/_appengine_environ.py deleted file mode 100644 index 8765b90..0000000 --- a/venv/lib/python3.8/site-packages/urllib3/contrib/_appengine_environ.py +++ /dev/null @@ -1,36 +0,0 @@ -""" -This module provides means to detect the App Engine environment. -""" - -import os - - -def is_appengine(): - return is_local_appengine() or is_prod_appengine() - - -def is_appengine_sandbox(): - """Reports if the app is running in the first generation sandbox. - - The second generation runtimes are technically still in a sandbox, but it - is much less restrictive, so generally you shouldn't need to check for it. - see https://cloud.google.com/appengine/docs/standard/runtimes - """ - return is_appengine() and os.environ["APPENGINE_RUNTIME"] == "python27" - - -def is_local_appengine(): - return "APPENGINE_RUNTIME" in os.environ and os.environ.get( - "SERVER_SOFTWARE", "" - ).startswith("Development/") - - -def is_prod_appengine(): - return "APPENGINE_RUNTIME" in os.environ and os.environ.get( - "SERVER_SOFTWARE", "" - ).startswith("Google App Engine/") - - -def is_prod_appengine_mvms(): - """Deprecated.""" - return False diff --git a/venv/lib/python3.8/site-packages/urllib3/contrib/_securetransport/__init__.py b/venv/lib/python3.8/site-packages/urllib3/contrib/_securetransport/__init__.py deleted file mode 100644 index e69de29..0000000 diff --git a/venv/lib/python3.8/site-packages/urllib3/contrib/_securetransport/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/urllib3/contrib/_securetransport/__pycache__/__init__.cpython-38.pyc deleted file mode 100644 index 420ef327274053181ece9475a37fd7c160ea4175..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 168 zcmWIL<>g`kf(lF3L=gQLL?8o3AjbiSi&=m~3PUi1CZpdQUs{xtlbK|!pPZjpQk0pbA77lBTw0V`Qk0li lT##Q>q8}fhnU`4-AFo$Xd5gm)H$SB`C)EyQ&1WEH006aEDi8nw diff --git a/venv/lib/python3.8/site-packages/urllib3/contrib/_securetransport/__pycache__/bindings.cpython-38.pyc b/venv/lib/python3.8/site-packages/urllib3/contrib/_securetransport/__pycache__/bindings.cpython-38.pyc deleted file mode 100644 index 5b77b875839981c0f977abc3511e54a1a5eefa90..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 10689 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 QKPcm#q$z0M*U{hoe+0Rd2LJ#7 diff --git a/venv/lib/python3.8/site-packages/urllib3/contrib/_securetransport/__pycache__/low_level.cpython-38.pyc b/venv/lib/python3.8/site-packages/urllib3/contrib/_securetransport/__pycache__/low_level.cpython-38.pyc deleted file mode 100644 index 7f08e1276fbd32c4b638892c0f08840074a835dc..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 9056 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àOJ2V_z$$92v)v(AgoIrp@)=+N(5&aXPxM_%+l?b`nU DV&P^- diff --git a/venv/lib/python3.8/site-packages/urllib3/contrib/_securetransport/bindings.py b/venv/lib/python3.8/site-packages/urllib3/contrib/_securetransport/bindings.py deleted file mode 100644 index 11524d4..0000000 --- a/venv/lib/python3.8/site-packages/urllib3/contrib/_securetransport/bindings.py +++ /dev/null @@ -1,519 +0,0 @@ -""" -This module uses ctypes to bind a whole bunch of functions and constants from -SecureTransport. The goal here is to provide the low-level API to -SecureTransport. These are essentially the C-level functions and constants, and -they're pretty gross to work with. - -This code is a bastardised version of the code found in Will Bond's oscrypto -library. An enormous debt is owed to him for blazing this trail for us. For -that reason, this code should be considered to be covered both by urllib3's -license and by oscrypto's: - - Copyright (c) 2015-2016 Will Bond - - 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 absolute_import - -import platform -from ctypes import ( - CDLL, - CFUNCTYPE, - POINTER, - c_bool, - c_byte, - c_char_p, - c_int32, - c_long, - c_size_t, - c_uint32, - c_ulong, - c_void_p, -) -from ctypes.util import find_library - -from urllib3.packages.six import raise_from - -if platform.system() != "Darwin": - raise ImportError("Only macOS is supported") - -version = platform.mac_ver()[0] -version_info = tuple(map(int, version.split("."))) -if version_info < (10, 8): - raise OSError( - "Only OS X 10.8 and newer are supported, not %s.%s" - % (version_info[0], version_info[1]) - ) - - -def load_cdll(name, macos10_16_path): - """Loads a CDLL by name, falling back to known path on 10.16+""" - try: - # Big Sur is technically 11 but we use 10.16 due to the Big Sur - # beta being labeled as 10.16. - if version_info >= (10, 16): - path = macos10_16_path - else: - path = find_library(name) - if not path: - raise OSError # Caught and reraised as 'ImportError' - return CDLL(path, use_errno=True) - except OSError: - raise_from(ImportError("The library %s failed to load" % name), None) - - -Security = load_cdll( - "Security", "/System/Library/Frameworks/Security.framework/Security" -) -CoreFoundation = load_cdll( - "CoreFoundation", - "/System/Library/Frameworks/CoreFoundation.framework/CoreFoundation", -) - - -Boolean = c_bool -CFIndex = c_long -CFStringEncoding = c_uint32 -CFData = c_void_p -CFString = c_void_p -CFArray = c_void_p -CFMutableArray = c_void_p -CFDictionary = c_void_p -CFError = c_void_p -CFType = c_void_p -CFTypeID = c_ulong - -CFTypeRef = POINTER(CFType) -CFAllocatorRef = c_void_p - -OSStatus = c_int32 - -CFDataRef = POINTER(CFData) -CFStringRef = POINTER(CFString) -CFArrayRef = POINTER(CFArray) -CFMutableArrayRef = POINTER(CFMutableArray) -CFDictionaryRef = POINTER(CFDictionary) -CFArrayCallBacks = c_void_p -CFDictionaryKeyCallBacks = c_void_p -CFDictionaryValueCallBacks = c_void_p - -SecCertificateRef = POINTER(c_void_p) -SecExternalFormat = c_uint32 -SecExternalItemType = c_uint32 -SecIdentityRef = POINTER(c_void_p) -SecItemImportExportFlags = c_uint32 -SecItemImportExportKeyParameters = c_void_p -SecKeychainRef = POINTER(c_void_p) -SSLProtocol = c_uint32 -SSLCipherSuite = c_uint32 -SSLContextRef = POINTER(c_void_p) -SecTrustRef = POINTER(c_void_p) -SSLConnectionRef = c_uint32 -SecTrustResultType = c_uint32 -SecTrustOptionFlags = c_uint32 -SSLProtocolSide = c_uint32 -SSLConnectionType = c_uint32 -SSLSessionOption = c_uint32 - - -try: - Security.SecItemImport.argtypes = [ - CFDataRef, - CFStringRef, - POINTER(SecExternalFormat), - POINTER(SecExternalItemType), - SecItemImportExportFlags, - POINTER(SecItemImportExportKeyParameters), - SecKeychainRef, - POINTER(CFArrayRef), - ] - Security.SecItemImport.restype = OSStatus - - Security.SecCertificateGetTypeID.argtypes = [] - Security.SecCertificateGetTypeID.restype = CFTypeID - - Security.SecIdentityGetTypeID.argtypes = [] - Security.SecIdentityGetTypeID.restype = CFTypeID - - Security.SecKeyGetTypeID.argtypes = [] - Security.SecKeyGetTypeID.restype = CFTypeID - - Security.SecCertificateCreateWithData.argtypes = [CFAllocatorRef, CFDataRef] - Security.SecCertificateCreateWithData.restype = SecCertificateRef - - Security.SecCertificateCopyData.argtypes = [SecCertificateRef] - Security.SecCertificateCopyData.restype = CFDataRef - - Security.SecCopyErrorMessageString.argtypes = [OSStatus, c_void_p] - Security.SecCopyErrorMessageString.restype = CFStringRef - - Security.SecIdentityCreateWithCertificate.argtypes = [ - CFTypeRef, - SecCertificateRef, - POINTER(SecIdentityRef), - ] - Security.SecIdentityCreateWithCertificate.restype = OSStatus - - Security.SecKeychainCreate.argtypes = [ - c_char_p, - c_uint32, - c_void_p, - Boolean, - c_void_p, - POINTER(SecKeychainRef), - ] - Security.SecKeychainCreate.restype = OSStatus - - Security.SecKeychainDelete.argtypes = [SecKeychainRef] - Security.SecKeychainDelete.restype = OSStatus - - Security.SecPKCS12Import.argtypes = [ - CFDataRef, - CFDictionaryRef, - POINTER(CFArrayRef), - ] - Security.SecPKCS12Import.restype = OSStatus - - SSLReadFunc = CFUNCTYPE(OSStatus, SSLConnectionRef, c_void_p, POINTER(c_size_t)) - SSLWriteFunc = CFUNCTYPE( - OSStatus, SSLConnectionRef, POINTER(c_byte), POINTER(c_size_t) - ) - - Security.SSLSetIOFuncs.argtypes = [SSLContextRef, SSLReadFunc, SSLWriteFunc] - Security.SSLSetIOFuncs.restype = OSStatus - - Security.SSLSetPeerID.argtypes = [SSLContextRef, c_char_p, c_size_t] - Security.SSLSetPeerID.restype = OSStatus - - Security.SSLSetCertificate.argtypes = [SSLContextRef, CFArrayRef] - Security.SSLSetCertificate.restype = OSStatus - - Security.SSLSetCertificateAuthorities.argtypes = [SSLContextRef, CFTypeRef, Boolean] - Security.SSLSetCertificateAuthorities.restype = OSStatus - - Security.SSLSetConnection.argtypes = [SSLContextRef, SSLConnectionRef] - Security.SSLSetConnection.restype = OSStatus - - Security.SSLSetPeerDomainName.argtypes = [SSLContextRef, c_char_p, c_size_t] - Security.SSLSetPeerDomainName.restype = OSStatus - - Security.SSLHandshake.argtypes = [SSLContextRef] - Security.SSLHandshake.restype = OSStatus - - Security.SSLRead.argtypes = [SSLContextRef, c_char_p, c_size_t, POINTER(c_size_t)] - Security.SSLRead.restype = OSStatus - - Security.SSLWrite.argtypes = [SSLContextRef, c_char_p, c_size_t, POINTER(c_size_t)] - Security.SSLWrite.restype = OSStatus - - Security.SSLClose.argtypes = [SSLContextRef] - Security.SSLClose.restype = OSStatus - - Security.SSLGetNumberSupportedCiphers.argtypes = [SSLContextRef, POINTER(c_size_t)] - Security.SSLGetNumberSupportedCiphers.restype = OSStatus - - Security.SSLGetSupportedCiphers.argtypes = [ - SSLContextRef, - POINTER(SSLCipherSuite), - POINTER(c_size_t), - ] - Security.SSLGetSupportedCiphers.restype = OSStatus - - Security.SSLSetEnabledCiphers.argtypes = [ - SSLContextRef, - POINTER(SSLCipherSuite), - c_size_t, - ] - Security.SSLSetEnabledCiphers.restype = OSStatus - - Security.SSLGetNumberEnabledCiphers.argtype = [SSLContextRef, POINTER(c_size_t)] - Security.SSLGetNumberEnabledCiphers.restype = OSStatus - - Security.SSLGetEnabledCiphers.argtypes = [ - SSLContextRef, - POINTER(SSLCipherSuite), - POINTER(c_size_t), - ] - Security.SSLGetEnabledCiphers.restype = OSStatus - - Security.SSLGetNegotiatedCipher.argtypes = [SSLContextRef, POINTER(SSLCipherSuite)] - Security.SSLGetNegotiatedCipher.restype = OSStatus - - Security.SSLGetNegotiatedProtocolVersion.argtypes = [ - SSLContextRef, - POINTER(SSLProtocol), - ] - Security.SSLGetNegotiatedProtocolVersion.restype = OSStatus - - Security.SSLCopyPeerTrust.argtypes = [SSLContextRef, POINTER(SecTrustRef)] - Security.SSLCopyPeerTrust.restype = OSStatus - - Security.SecTrustSetAnchorCertificates.argtypes = [SecTrustRef, CFArrayRef] - Security.SecTrustSetAnchorCertificates.restype = OSStatus - - Security.SecTrustSetAnchorCertificatesOnly.argstypes = [SecTrustRef, Boolean] - Security.SecTrustSetAnchorCertificatesOnly.restype = OSStatus - - Security.SecTrustEvaluate.argtypes = [SecTrustRef, POINTER(SecTrustResultType)] - Security.SecTrustEvaluate.restype = OSStatus - - Security.SecTrustGetCertificateCount.argtypes = [SecTrustRef] - Security.SecTrustGetCertificateCount.restype = CFIndex - - Security.SecTrustGetCertificateAtIndex.argtypes = [SecTrustRef, CFIndex] - Security.SecTrustGetCertificateAtIndex.restype = SecCertificateRef - - Security.SSLCreateContext.argtypes = [ - CFAllocatorRef, - SSLProtocolSide, - SSLConnectionType, - ] - Security.SSLCreateContext.restype = SSLContextRef - - Security.SSLSetSessionOption.argtypes = [SSLContextRef, SSLSessionOption, Boolean] - Security.SSLSetSessionOption.restype = OSStatus - - Security.SSLSetProtocolVersionMin.argtypes = [SSLContextRef, SSLProtocol] - Security.SSLSetProtocolVersionMin.restype = OSStatus - - Security.SSLSetProtocolVersionMax.argtypes = [SSLContextRef, SSLProtocol] - Security.SSLSetProtocolVersionMax.restype = OSStatus - - try: - Security.SSLSetALPNProtocols.argtypes = [SSLContextRef, CFArrayRef] - Security.SSLSetALPNProtocols.restype = OSStatus - except AttributeError: - # Supported only in 10.12+ - pass - - Security.SecCopyErrorMessageString.argtypes = [OSStatus, c_void_p] - Security.SecCopyErrorMessageString.restype = CFStringRef - - Security.SSLReadFunc = SSLReadFunc - Security.SSLWriteFunc = SSLWriteFunc - Security.SSLContextRef = SSLContextRef - Security.SSLProtocol = SSLProtocol - Security.SSLCipherSuite = SSLCipherSuite - Security.SecIdentityRef = SecIdentityRef - Security.SecKeychainRef = SecKeychainRef - Security.SecTrustRef = SecTrustRef - Security.SecTrustResultType = SecTrustResultType - Security.SecExternalFormat = SecExternalFormat - Security.OSStatus = OSStatus - - Security.kSecImportExportPassphrase = CFStringRef.in_dll( - Security, "kSecImportExportPassphrase" - ) - Security.kSecImportItemIdentity = CFStringRef.in_dll( - Security, "kSecImportItemIdentity" - ) - - # CoreFoundation time! - CoreFoundation.CFRetain.argtypes = [CFTypeRef] - CoreFoundation.CFRetain.restype = CFTypeRef - - CoreFoundation.CFRelease.argtypes = [CFTypeRef] - CoreFoundation.CFRelease.restype = None - - CoreFoundation.CFGetTypeID.argtypes = [CFTypeRef] - CoreFoundation.CFGetTypeID.restype = CFTypeID - - CoreFoundation.CFStringCreateWithCString.argtypes = [ - CFAllocatorRef, - c_char_p, - CFStringEncoding, - ] - CoreFoundation.CFStringCreateWithCString.restype = CFStringRef - - CoreFoundation.CFStringGetCStringPtr.argtypes = [CFStringRef, CFStringEncoding] - CoreFoundation.CFStringGetCStringPtr.restype = c_char_p - - CoreFoundation.CFStringGetCString.argtypes = [ - CFStringRef, - c_char_p, - CFIndex, - CFStringEncoding, - ] - CoreFoundation.CFStringGetCString.restype = c_bool - - CoreFoundation.CFDataCreate.argtypes = [CFAllocatorRef, c_char_p, CFIndex] - CoreFoundation.CFDataCreate.restype = CFDataRef - - CoreFoundation.CFDataGetLength.argtypes = [CFDataRef] - CoreFoundation.CFDataGetLength.restype = CFIndex - - CoreFoundation.CFDataGetBytePtr.argtypes = [CFDataRef] - CoreFoundation.CFDataGetBytePtr.restype = c_void_p - - CoreFoundation.CFDictionaryCreate.argtypes = [ - CFAllocatorRef, - POINTER(CFTypeRef), - POINTER(CFTypeRef), - CFIndex, - CFDictionaryKeyCallBacks, - CFDictionaryValueCallBacks, - ] - CoreFoundation.CFDictionaryCreate.restype = CFDictionaryRef - - CoreFoundation.CFDictionaryGetValue.argtypes = [CFDictionaryRef, CFTypeRef] - CoreFoundation.CFDictionaryGetValue.restype = CFTypeRef - - CoreFoundation.CFArrayCreate.argtypes = [ - CFAllocatorRef, - POINTER(CFTypeRef), - CFIndex, - CFArrayCallBacks, - ] - CoreFoundation.CFArrayCreate.restype = CFArrayRef - - CoreFoundation.CFArrayCreateMutable.argtypes = [ - CFAllocatorRef, - CFIndex, - CFArrayCallBacks, - ] - CoreFoundation.CFArrayCreateMutable.restype = CFMutableArrayRef - - CoreFoundation.CFArrayAppendValue.argtypes = [CFMutableArrayRef, c_void_p] - CoreFoundation.CFArrayAppendValue.restype = None - - CoreFoundation.CFArrayGetCount.argtypes = [CFArrayRef] - CoreFoundation.CFArrayGetCount.restype = CFIndex - - CoreFoundation.CFArrayGetValueAtIndex.argtypes = [CFArrayRef, CFIndex] - CoreFoundation.CFArrayGetValueAtIndex.restype = c_void_p - - CoreFoundation.kCFAllocatorDefault = CFAllocatorRef.in_dll( - CoreFoundation, "kCFAllocatorDefault" - ) - CoreFoundation.kCFTypeArrayCallBacks = c_void_p.in_dll( - CoreFoundation, "kCFTypeArrayCallBacks" - ) - CoreFoundation.kCFTypeDictionaryKeyCallBacks = c_void_p.in_dll( - CoreFoundation, "kCFTypeDictionaryKeyCallBacks" - ) - CoreFoundation.kCFTypeDictionaryValueCallBacks = c_void_p.in_dll( - CoreFoundation, "kCFTypeDictionaryValueCallBacks" - ) - - CoreFoundation.CFTypeRef = CFTypeRef - CoreFoundation.CFArrayRef = CFArrayRef - CoreFoundation.CFStringRef = CFStringRef - CoreFoundation.CFDictionaryRef = CFDictionaryRef - -except (AttributeError): - raise ImportError("Error initializing ctypes") - - -class CFConst(object): - """ - A class object that acts as essentially a namespace for CoreFoundation - constants. - """ - - kCFStringEncodingUTF8 = CFStringEncoding(0x08000100) - - -class SecurityConst(object): - """ - A class object that acts as essentially a namespace for Security constants. - """ - - kSSLSessionOptionBreakOnServerAuth = 0 - - kSSLProtocol2 = 1 - kSSLProtocol3 = 2 - kTLSProtocol1 = 4 - kTLSProtocol11 = 7 - kTLSProtocol12 = 8 - # SecureTransport does not support TLS 1.3 even if there's a constant for it - kTLSProtocol13 = 10 - kTLSProtocolMaxSupported = 999 - - kSSLClientSide = 1 - kSSLStreamType = 0 - - kSecFormatPEMSequence = 10 - - kSecTrustResultInvalid = 0 - kSecTrustResultProceed = 1 - # This gap is present on purpose: this was kSecTrustResultConfirm, which - # is deprecated. - kSecTrustResultDeny = 3 - kSecTrustResultUnspecified = 4 - kSecTrustResultRecoverableTrustFailure = 5 - kSecTrustResultFatalTrustFailure = 6 - kSecTrustResultOtherError = 7 - - errSSLProtocol = -9800 - errSSLWouldBlock = -9803 - errSSLClosedGraceful = -9805 - errSSLClosedNoNotify = -9816 - errSSLClosedAbort = -9806 - - errSSLXCertChainInvalid = -9807 - errSSLCrypto = -9809 - errSSLInternal = -9810 - errSSLCertExpired = -9814 - errSSLCertNotYetValid = -9815 - errSSLUnknownRootCert = -9812 - errSSLNoRootCert = -9813 - errSSLHostNameMismatch = -9843 - errSSLPeerHandshakeFail = -9824 - errSSLPeerUserCancelled = -9839 - errSSLWeakPeerEphemeralDHKey = -9850 - errSSLServerAuthCompleted = -9841 - errSSLRecordOverflow = -9847 - - errSecVerifyFailed = -67808 - errSecNoTrustSettings = -25263 - errSecItemNotFound = -25300 - errSecInvalidTrustSettings = -25262 - - # Cipher suites. We only pick the ones our default cipher string allows. - # Source: https://developer.apple.com/documentation/security/1550981-ssl_cipher_suite_values - TLS_ECDHE_ECDSA_WITH_AES_256_GCM_SHA384 = 0xC02C - TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384 = 0xC030 - TLS_ECDHE_ECDSA_WITH_AES_128_GCM_SHA256 = 0xC02B - TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256 = 0xC02F - TLS_ECDHE_ECDSA_WITH_CHACHA20_POLY1305_SHA256 = 0xCCA9 - TLS_ECDHE_RSA_WITH_CHACHA20_POLY1305_SHA256 = 0xCCA8 - TLS_DHE_RSA_WITH_AES_256_GCM_SHA384 = 0x009F - TLS_DHE_RSA_WITH_AES_128_GCM_SHA256 = 0x009E - TLS_ECDHE_ECDSA_WITH_AES_256_CBC_SHA384 = 0xC024 - TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384 = 0xC028 - TLS_ECDHE_ECDSA_WITH_AES_256_CBC_SHA = 0xC00A - TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA = 0xC014 - TLS_DHE_RSA_WITH_AES_256_CBC_SHA256 = 0x006B - TLS_DHE_RSA_WITH_AES_256_CBC_SHA = 0x0039 - TLS_ECDHE_ECDSA_WITH_AES_128_CBC_SHA256 = 0xC023 - TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256 = 0xC027 - TLS_ECDHE_ECDSA_WITH_AES_128_CBC_SHA = 0xC009 - TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA = 0xC013 - TLS_DHE_RSA_WITH_AES_128_CBC_SHA256 = 0x0067 - TLS_DHE_RSA_WITH_AES_128_CBC_SHA = 0x0033 - TLS_RSA_WITH_AES_256_GCM_SHA384 = 0x009D - TLS_RSA_WITH_AES_128_GCM_SHA256 = 0x009C - TLS_RSA_WITH_AES_256_CBC_SHA256 = 0x003D - TLS_RSA_WITH_AES_128_CBC_SHA256 = 0x003C - TLS_RSA_WITH_AES_256_CBC_SHA = 0x0035 - TLS_RSA_WITH_AES_128_CBC_SHA = 0x002F - TLS_AES_128_GCM_SHA256 = 0x1301 - TLS_AES_256_GCM_SHA384 = 0x1302 - TLS_AES_128_CCM_8_SHA256 = 0x1305 - TLS_AES_128_CCM_SHA256 = 0x1304 diff --git a/venv/lib/python3.8/site-packages/urllib3/contrib/_securetransport/low_level.py b/venv/lib/python3.8/site-packages/urllib3/contrib/_securetransport/low_level.py deleted file mode 100644 index ed81201..0000000 --- a/venv/lib/python3.8/site-packages/urllib3/contrib/_securetransport/low_level.py +++ /dev/null @@ -1,396 +0,0 @@ -""" -Low-level helpers for the SecureTransport bindings. - -These are Python functions that are not directly related to the high-level APIs -but are necessary to get them to work. They include a whole bunch of low-level -CoreFoundation messing about and memory management. The concerns in this module -are almost entirely about trying to avoid memory leaks and providing -appropriate and useful assistance to the higher-level code. -""" -import base64 -import ctypes -import itertools -import os -import re -import ssl -import struct -import tempfile - -from .bindings import CFConst, CoreFoundation, Security - -# This regular expression is used to grab PEM data out of a PEM bundle. -_PEM_CERTS_RE = re.compile( - b"-----BEGIN CERTIFICATE-----\n(.*?)\n-----END CERTIFICATE-----", re.DOTALL -) - - -def _cf_data_from_bytes(bytestring): - """ - Given a bytestring, create a CFData object from it. This CFData object must - be CFReleased by the caller. - """ - return CoreFoundation.CFDataCreate( - CoreFoundation.kCFAllocatorDefault, bytestring, len(bytestring) - ) - - -def _cf_dictionary_from_tuples(tuples): - """ - Given a list of Python tuples, create an associated CFDictionary. - """ - dictionary_size = len(tuples) - - # We need to get the dictionary keys and values out in the same order. - keys = (t[0] for t in tuples) - values = (t[1] for t in tuples) - cf_keys = (CoreFoundation.CFTypeRef * dictionary_size)(*keys) - cf_values = (CoreFoundation.CFTypeRef * dictionary_size)(*values) - - return CoreFoundation.CFDictionaryCreate( - CoreFoundation.kCFAllocatorDefault, - cf_keys, - cf_values, - dictionary_size, - CoreFoundation.kCFTypeDictionaryKeyCallBacks, - CoreFoundation.kCFTypeDictionaryValueCallBacks, - ) - - -def _cfstr(py_bstr): - """ - Given a Python binary data, create a CFString. - The string must be CFReleased by the caller. - """ - c_str = ctypes.c_char_p(py_bstr) - cf_str = CoreFoundation.CFStringCreateWithCString( - CoreFoundation.kCFAllocatorDefault, - c_str, - CFConst.kCFStringEncodingUTF8, - ) - return cf_str - - -def _create_cfstring_array(lst): - """ - Given a list of Python binary data, create an associated CFMutableArray. - The array must be CFReleased by the caller. - - Raises an ssl.SSLError on failure. - """ - cf_arr = None - try: - cf_arr = CoreFoundation.CFArrayCreateMutable( - CoreFoundation.kCFAllocatorDefault, - 0, - ctypes.byref(CoreFoundation.kCFTypeArrayCallBacks), - ) - if not cf_arr: - raise MemoryError("Unable to allocate memory!") - for item in lst: - cf_str = _cfstr(item) - if not cf_str: - raise MemoryError("Unable to allocate memory!") - try: - CoreFoundation.CFArrayAppendValue(cf_arr, cf_str) - finally: - CoreFoundation.CFRelease(cf_str) - except BaseException as e: - if cf_arr: - CoreFoundation.CFRelease(cf_arr) - raise ssl.SSLError("Unable to allocate array: %s" % (e,)) - return cf_arr - - -def _cf_string_to_unicode(value): - """ - Creates a Unicode string from a CFString object. Used entirely for error - reporting. - - Yes, it annoys me quite a lot that this function is this complex. - """ - value_as_void_p = ctypes.cast(value, ctypes.POINTER(ctypes.c_void_p)) - - string = CoreFoundation.CFStringGetCStringPtr( - value_as_void_p, CFConst.kCFStringEncodingUTF8 - ) - if string is None: - buffer = ctypes.create_string_buffer(1024) - result = CoreFoundation.CFStringGetCString( - value_as_void_p, buffer, 1024, CFConst.kCFStringEncodingUTF8 - ) - if not result: - raise OSError("Error copying C string from CFStringRef") - string = buffer.value - if string is not None: - string = string.decode("utf-8") - return string - - -def _assert_no_error(error, exception_class=None): - """ - Checks the return code and throws an exception if there is an error to - report - """ - if error == 0: - return - - cf_error_string = Security.SecCopyErrorMessageString(error, None) - output = _cf_string_to_unicode(cf_error_string) - CoreFoundation.CFRelease(cf_error_string) - - if output is None or output == u"": - output = u"OSStatus %s" % error - - if exception_class is None: - exception_class = ssl.SSLError - - raise exception_class(output) - - -def _cert_array_from_pem(pem_bundle): - """ - Given a bundle of certs in PEM format, turns them into a CFArray of certs - that can be used to validate a cert chain. - """ - # Normalize the PEM bundle's line endings. - pem_bundle = pem_bundle.replace(b"\r\n", b"\n") - - der_certs = [ - base64.b64decode(match.group(1)) for match in _PEM_CERTS_RE.finditer(pem_bundle) - ] - if not der_certs: - raise ssl.SSLError("No root certificates specified") - - cert_array = CoreFoundation.CFArrayCreateMutable( - CoreFoundation.kCFAllocatorDefault, - 0, - ctypes.byref(CoreFoundation.kCFTypeArrayCallBacks), - ) - if not cert_array: - raise ssl.SSLError("Unable to allocate memory!") - - try: - for der_bytes in der_certs: - certdata = _cf_data_from_bytes(der_bytes) - if not certdata: - raise ssl.SSLError("Unable to allocate memory!") - cert = Security.SecCertificateCreateWithData( - CoreFoundation.kCFAllocatorDefault, certdata - ) - CoreFoundation.CFRelease(certdata) - if not cert: - raise ssl.SSLError("Unable to build cert object!") - - CoreFoundation.CFArrayAppendValue(cert_array, cert) - CoreFoundation.CFRelease(cert) - except Exception: - # We need to free the array before the exception bubbles further. - # We only want to do that if an error occurs: otherwise, the caller - # should free. - CoreFoundation.CFRelease(cert_array) - - return cert_array - - -def _is_cert(item): - """ - Returns True if a given CFTypeRef is a certificate. - """ - expected = Security.SecCertificateGetTypeID() - return CoreFoundation.CFGetTypeID(item) == expected - - -def _is_identity(item): - """ - Returns True if a given CFTypeRef is an identity. - """ - expected = Security.SecIdentityGetTypeID() - return CoreFoundation.CFGetTypeID(item) == expected - - -def _temporary_keychain(): - """ - This function creates a temporary Mac keychain that we can use to work with - credentials. This keychain uses a one-time password and a temporary file to - store the data. We expect to have one keychain per socket. The returned - SecKeychainRef must be freed by the caller, including calling - SecKeychainDelete. - - Returns a tuple of the SecKeychainRef and the path to the temporary - directory that contains it. - """ - # Unfortunately, SecKeychainCreate requires a path to a keychain. This - # means we cannot use mkstemp to use a generic temporary file. Instead, - # we're going to create a temporary directory and a filename to use there. - # This filename will be 8 random bytes expanded into base64. We also need - # some random bytes to password-protect the keychain we're creating, so we - # ask for 40 random bytes. - random_bytes = os.urandom(40) - filename = base64.b16encode(random_bytes[:8]).decode("utf-8") - password = base64.b16encode(random_bytes[8:]) # Must be valid UTF-8 - tempdirectory = tempfile.mkdtemp() - - keychain_path = os.path.join(tempdirectory, filename).encode("utf-8") - - # We now want to create the keychain itself. - keychain = Security.SecKeychainRef() - status = Security.SecKeychainCreate( - keychain_path, len(password), password, False, None, ctypes.byref(keychain) - ) - _assert_no_error(status) - - # Having created the keychain, we want to pass it off to the caller. - return keychain, tempdirectory - - -def _load_items_from_file(keychain, path): - """ - Given a single file, loads all the trust objects from it into arrays and - the keychain. - Returns a tuple of lists: the first list is a list of identities, the - second a list of certs. - """ - certificates = [] - identities = [] - result_array = None - - with open(path, "rb") as f: - raw_filedata = f.read() - - try: - filedata = CoreFoundation.CFDataCreate( - CoreFoundation.kCFAllocatorDefault, raw_filedata, len(raw_filedata) - ) - result_array = CoreFoundation.CFArrayRef() - result = Security.SecItemImport( - filedata, # cert data - None, # Filename, leaving it out for now - None, # What the type of the file is, we don't care - None, # what's in the file, we don't care - 0, # import flags - None, # key params, can include passphrase in the future - keychain, # The keychain to insert into - ctypes.byref(result_array), # Results - ) - _assert_no_error(result) - - # A CFArray is not very useful to us as an intermediary - # representation, so we are going to extract the objects we want - # and then free the array. We don't need to keep hold of keys: the - # keychain already has them! - result_count = CoreFoundation.CFArrayGetCount(result_array) - for index in range(result_count): - item = CoreFoundation.CFArrayGetValueAtIndex(result_array, index) - item = ctypes.cast(item, CoreFoundation.CFTypeRef) - - if _is_cert(item): - CoreFoundation.CFRetain(item) - certificates.append(item) - elif _is_identity(item): - CoreFoundation.CFRetain(item) - identities.append(item) - finally: - if result_array: - CoreFoundation.CFRelease(result_array) - - CoreFoundation.CFRelease(filedata) - - return (identities, certificates) - - -def _load_client_cert_chain(keychain, *paths): - """ - Load certificates and maybe keys from a number of files. Has the end goal - of returning a CFArray containing one SecIdentityRef, and then zero or more - SecCertificateRef objects, suitable for use as a client certificate trust - chain. - """ - # Ok, the strategy. - # - # This relies on knowing that macOS will not give you a SecIdentityRef - # unless you have imported a key into a keychain. This is a somewhat - # artificial limitation of macOS (for example, it doesn't necessarily - # affect iOS), but there is nothing inside Security.framework that lets you - # get a SecIdentityRef without having a key in a keychain. - # - # So the policy here is we take all the files and iterate them in order. - # Each one will use SecItemImport to have one or more objects loaded from - # it. We will also point at a keychain that macOS can use to work with the - # private key. - # - # Once we have all the objects, we'll check what we actually have. If we - # already have a SecIdentityRef in hand, fab: we'll use that. Otherwise, - # we'll take the first certificate (which we assume to be our leaf) and - # ask the keychain to give us a SecIdentityRef with that cert's associated - # key. - # - # We'll then return a CFArray containing the trust chain: one - # SecIdentityRef and then zero-or-more SecCertificateRef objects. The - # responsibility for freeing this CFArray will be with the caller. This - # CFArray must remain alive for the entire connection, so in practice it - # will be stored with a single SSLSocket, along with the reference to the - # keychain. - certificates = [] - identities = [] - - # Filter out bad paths. - paths = (path for path in paths if path) - - try: - for file_path in paths: - new_identities, new_certs = _load_items_from_file(keychain, file_path) - identities.extend(new_identities) - certificates.extend(new_certs) - - # Ok, we have everything. The question is: do we have an identity? If - # not, we want to grab one from the first cert we have. - if not identities: - new_identity = Security.SecIdentityRef() - status = Security.SecIdentityCreateWithCertificate( - keychain, certificates[0], ctypes.byref(new_identity) - ) - _assert_no_error(status) - identities.append(new_identity) - - # We now want to release the original certificate, as we no longer - # need it. - CoreFoundation.CFRelease(certificates.pop(0)) - - # We now need to build a new CFArray that holds the trust chain. - trust_chain = CoreFoundation.CFArrayCreateMutable( - CoreFoundation.kCFAllocatorDefault, - 0, - ctypes.byref(CoreFoundation.kCFTypeArrayCallBacks), - ) - for item in itertools.chain(identities, certificates): - # ArrayAppendValue does a CFRetain on the item. That's fine, - # because the finally block will release our other refs to them. - CoreFoundation.CFArrayAppendValue(trust_chain, item) - - return trust_chain - finally: - for obj in itertools.chain(identities, certificates): - CoreFoundation.CFRelease(obj) - - -TLS_PROTOCOL_VERSIONS = { - "SSLv2": (0, 2), - "SSLv3": (3, 0), - "TLSv1": (3, 1), - "TLSv1.1": (3, 2), - "TLSv1.2": (3, 3), -} - - -def _build_tls_unknown_ca_alert(version): - """ - Builds a TLS alert record for an unknown CA. - """ - ver_maj, ver_min = TLS_PROTOCOL_VERSIONS[version] - severity_fatal = 0x02 - description_unknown_ca = 0x30 - msg = struct.pack(">BB", severity_fatal, description_unknown_ca) - msg_len = len(msg) - record_type_alert = 0x15 - record = struct.pack(">BBBH", record_type_alert, ver_maj, ver_min, msg_len) + msg - return record diff --git a/venv/lib/python3.8/site-packages/urllib3/contrib/appengine.py b/venv/lib/python3.8/site-packages/urllib3/contrib/appengine.py deleted file mode 100644 index f91bdd6..0000000 --- a/venv/lib/python3.8/site-packages/urllib3/contrib/appengine.py +++ /dev/null @@ -1,314 +0,0 @@ -""" -This module provides a pool manager that uses Google App Engine's -`URLFetch Service `_. - -Example usage:: - - from urllib3 import PoolManager - from urllib3.contrib.appengine import AppEngineManager, is_appengine_sandbox - - if is_appengine_sandbox(): - # AppEngineManager uses AppEngine's URLFetch API behind the scenes - http = AppEngineManager() - else: - # PoolManager uses a socket-level API behind the scenes - http = PoolManager() - - r = http.request('GET', 'https://google.com/') - -There are `limitations `_ to the URLFetch service and it may not be -the best choice for your application. There are three options for using -urllib3 on Google App Engine: - -1. You can use :class:`AppEngineManager` with URLFetch. URLFetch is - cost-effective in many circumstances as long as your usage is within the - limitations. -2. You can use a normal :class:`~urllib3.PoolManager` by enabling sockets. - Sockets also have `limitations and restrictions - `_ and have a lower free quota than URLFetch. - To use sockets, be sure to specify the following in your ``app.yaml``:: - - env_variables: - GAE_USE_SOCKETS_HTTPLIB : 'true' - -3. If you are using `App Engine Flexible -`_, you can use the standard -:class:`PoolManager` without any configuration or special environment variables. -""" - -from __future__ import absolute_import - -import io -import logging -import warnings - -from ..exceptions import ( - HTTPError, - HTTPWarning, - MaxRetryError, - ProtocolError, - SSLError, - TimeoutError, -) -from ..packages.six.moves.urllib.parse import urljoin -from ..request import RequestMethods -from ..response import HTTPResponse -from ..util.retry import Retry -from ..util.timeout import Timeout -from . import _appengine_environ - -try: - from google.appengine.api import urlfetch -except ImportError: - urlfetch = None - - -log = logging.getLogger(__name__) - - -class AppEnginePlatformWarning(HTTPWarning): - pass - - -class AppEnginePlatformError(HTTPError): - pass - - -class AppEngineManager(RequestMethods): - """ - Connection manager for Google App Engine sandbox applications. - - This manager uses the URLFetch service directly instead of using the - emulated httplib, and is subject to URLFetch limitations as described in - the App Engine documentation `here - `_. - - Notably it will raise an :class:`AppEnginePlatformError` if: - * URLFetch is not available. - * If you attempt to use this on App Engine Flexible, as full socket - support is available. - * If a request size is more than 10 megabytes. - * If a response size is more than 32 megabytes. - * If you use an unsupported request method such as OPTIONS. - - Beyond those cases, it will raise normal urllib3 errors. - """ - - def __init__( - self, - headers=None, - retries=None, - validate_certificate=True, - urlfetch_retries=True, - ): - if not urlfetch: - raise AppEnginePlatformError( - "URLFetch is not available in this environment." - ) - - 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/1.26.x/reference/urllib3.contrib.html.", - AppEnginePlatformWarning, - ) - - RequestMethods.__init__(self, headers) - self.validate_certificate = validate_certificate - self.urlfetch_retries = urlfetch_retries - - self.retries = retries or Retry.DEFAULT - - def __enter__(self): - return self - - def __exit__(self, exc_type, exc_val, exc_tb): - # Return False to re-raise any potential exceptions - return False - - def urlopen( - self, - method, - url, - body=None, - headers=None, - retries=None, - redirect=True, - timeout=Timeout.DEFAULT_TIMEOUT, - **response_kw - ): - - retries = self._get_retries(retries, redirect) - - try: - follow_redirects = redirect and retries.redirect != 0 and retries.total - response = urlfetch.fetch( - url, - payload=body, - method=method, - headers=headers or {}, - allow_truncated=False, - follow_redirects=self.urlfetch_retries and follow_redirects, - deadline=self._get_absolute_timeout(timeout), - validate_certificate=self.validate_certificate, - ) - except urlfetch.DeadlineExceededError as e: - raise TimeoutError(self, e) - - except urlfetch.InvalidURLError as e: - if "too large" in str(e): - raise AppEnginePlatformError( - "URLFetch request too large, URLFetch only " - "supports requests up to 10mb in size.", - e, - ) - raise ProtocolError(e) - - except urlfetch.DownloadError as e: - if "Too many redirects" in str(e): - raise MaxRetryError(self, url, reason=e) - raise ProtocolError(e) - - except urlfetch.ResponseTooLargeError as e: - raise AppEnginePlatformError( - "URLFetch response too large, URLFetch only supports" - "responses up to 32mb in size.", - e, - ) - - except urlfetch.SSLCertificateError as e: - raise SSLError(e) - - except urlfetch.InvalidMethodError as e: - raise AppEnginePlatformError( - "URLFetch does not support method: %s" % method, e - ) - - http_response = self._urlfetch_response_to_http_response( - response, retries=retries, **response_kw - ) - - # Handle redirect? - redirect_location = redirect and http_response.get_redirect_location() - if redirect_location: - # Check for redirect response - if self.urlfetch_retries and retries.raise_on_redirect: - raise MaxRetryError(self, url, "too many redirects") - else: - if http_response.status == 303: - method = "GET" - - try: - retries = retries.increment( - method, url, response=http_response, _pool=self - ) - except MaxRetryError: - if retries.raise_on_redirect: - raise MaxRetryError(self, url, "too many redirects") - return http_response - - retries.sleep_for_retry(http_response) - log.debug("Redirecting %s -> %s", url, redirect_location) - redirect_url = urljoin(url, redirect_location) - return self.urlopen( - method, - redirect_url, - body, - headers, - retries=retries, - redirect=redirect, - timeout=timeout, - **response_kw - ) - - # Check if we should retry the HTTP response. - has_retry_after = bool(http_response.getheader("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) - retries.sleep(http_response) - return self.urlopen( - method, - url, - body=body, - headers=headers, - retries=retries, - redirect=redirect, - timeout=timeout, - **response_kw - ) - - return http_response - - def _urlfetch_response_to_http_response(self, urlfetch_resp, **response_kw): - - if is_prod_appengine(): - # Production GAE handles deflate encoding automatically, but does - # not remove the encoding header. - content_encoding = urlfetch_resp.headers.get("content-encoding") - - if content_encoding == "deflate": - del urlfetch_resp.headers["content-encoding"] - - transfer_encoding = urlfetch_resp.headers.get("transfer-encoding") - # We have a full response's content, - # so let's make sure we don't report ourselves as chunked data. - if transfer_encoding == "chunked": - encodings = transfer_encoding.split(",") - encodings.remove("chunked") - urlfetch_resp.headers["transfer-encoding"] = ",".join(encodings) - - original_response = HTTPResponse( - # In order for decoding to work, we must present the content as - # a file-like object. - body=io.BytesIO(urlfetch_resp.content), - msg=urlfetch_resp.header_msg, - headers=urlfetch_resp.headers, - status=urlfetch_resp.status_code, - **response_kw - ) - - return HTTPResponse( - body=io.BytesIO(urlfetch_resp.content), - headers=urlfetch_resp.headers, - status=urlfetch_resp.status_code, - original_response=original_response, - **response_kw - ) - - def _get_absolute_timeout(self, timeout): - if timeout is Timeout.DEFAULT_TIMEOUT: - return None # Defer to URLFetch's default. - if isinstance(timeout, Timeout): - if timeout._read is not None or timeout._connect is not None: - warnings.warn( - "URLFetch does not support granular timeout settings, " - "reverting to total or default URLFetch timeout.", - AppEnginePlatformWarning, - ) - return timeout.total - return timeout - - def _get_retries(self, retries, redirect): - if not isinstance(retries, Retry): - retries = Retry.from_int(retries, redirect=redirect, default=self.retries) - - if retries.connect or retries.read or retries.redirect: - warnings.warn( - "URLFetch only supports total retries and does not " - "recognize connect, read, or redirect retry parameters.", - AppEnginePlatformWarning, - ) - - return retries - - -# Alias methods from _appengine_environ to maintain public API interface. - -is_appengine = _appengine_environ.is_appengine -is_appengine_sandbox = _appengine_environ.is_appengine_sandbox -is_local_appengine = _appengine_environ.is_local_appengine -is_prod_appengine = _appengine_environ.is_prod_appengine -is_prod_appengine_mvms = _appengine_environ.is_prod_appengine_mvms diff --git a/venv/lib/python3.8/site-packages/urllib3/contrib/ntlmpool.py b/venv/lib/python3.8/site-packages/urllib3/contrib/ntlmpool.py deleted file mode 100644 index 41a8fd1..0000000 --- a/venv/lib/python3.8/site-packages/urllib3/contrib/ntlmpool.py +++ /dev/null @@ -1,130 +0,0 @@ -""" -NTLM authenticating pool, contributed by erikcederstran - -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 - -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__) - - -class NTLMConnectionPool(HTTPSConnectionPool): - """ - Implements an NTLM authentication version of an urllib3 connection pool - """ - - scheme = "https" - - def __init__(self, user, pw, authurl, *args, **kwargs): - """ - authurl is a random URL on the server that is protected by NTLM. - user is the Windows user, probably in the DOMAIN\\username format. - pw is the password for the user. - """ - super(NTLMConnectionPool, self).__init__(*args, **kwargs) - self.authurl = authurl - self.rawuser = user - user_parts = user.split("\\", 1) - self.domain = user_parts[0].upper() - self.user = user_parts[1] - self.pw = pw - - def _new_conn(self): - # Performs the NTLM handshake that secures the connection. The socket - # must be kept open while requests are performed. - self.num_connections += 1 - log.debug( - "Starting NTLM HTTPS connection no. %d: https://%s%s", - self.num_connections, - self.host, - self.authurl, - ) - - headers = {"Connection": "Keep-Alive"} - req_header = "Authorization" - resp_header = "www-authenticate" - - conn = HTTPSConnection(host=self.host, port=self.port) - - # Send negotiation message - headers[req_header] = "NTLM %s" % ntlm.create_NTLM_NEGOTIATE_MESSAGE( - self.rawuser - ) - log.debug("Request headers: %s", headers) - conn.request("GET", self.authurl, None, headers) - res = conn.getresponse() - reshdr = dict(res.getheaders()) - log.debug("Response status: %s %s", res.status, res.reason) - log.debug("Response headers: %s", reshdr) - log.debug("Response data: %s [...]", res.read(100)) - - # Remove the reference to the socket, so that it can not be closed by - # the response object (we want to keep the socket open) - res.fp = None - - # Server should respond with a challenge message - auth_header_values = reshdr[resp_header].split(", ") - auth_header_value = None - for s in auth_header_values: - if s[:5] == "NTLM ": - auth_header_value = s[5:] - if auth_header_value is None: - raise Exception( - "Unexpected %s response header: %s" % (resp_header, reshdr[resp_header]) - ) - - # Send authentication message - ServerChallenge, NegotiateFlags = ntlm.parse_NTLM_CHALLENGE_MESSAGE( - auth_header_value - ) - auth_msg = ntlm.create_NTLM_AUTHENTICATE_MESSAGE( - ServerChallenge, self.user, self.domain, self.pw, NegotiateFlags - ) - headers[req_header] = "NTLM %s" % auth_msg - log.debug("Request headers: %s", headers) - 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 data: %s [...]", res.read()[:100]) - if res.status != 200: - if res.status == 401: - raise Exception("Server rejected request: wrong username or password") - raise Exception("Wrong server response: %s %s" % (res.status, res.reason)) - - res.fp = None - log.debug("Connection established") - return conn - - def urlopen( - self, - method, - url, - body=None, - headers=None, - retries=3, - redirect=True, - assert_same_host=True, - ): - if headers is None: - headers = {} - headers["Connection"] = "Keep-Alive" - return super(NTLMConnectionPool, self).urlopen( - method, url, body, headers, retries, redirect, assert_same_host - ) diff --git a/venv/lib/python3.8/site-packages/urllib3/contrib/pyopenssl.py b/venv/lib/python3.8/site-packages/urllib3/contrib/pyopenssl.py deleted file mode 100644 index def83af..0000000 --- a/venv/lib/python3.8/site-packages/urllib3/contrib/pyopenssl.py +++ /dev/null @@ -1,511 +0,0 @@ -""" -TLS with SNI_-support for Python 2. Follow these instructions if you would -like to verify TLS certificates in Python 2. Note, the default libraries do -*not* do certificate checking; you need to do additional work to validate -certificates yourself. - -This needs the following packages installed: - -* `pyOpenSSL`_ (tested with 16.0.0) -* `cryptography`_ (minimum 1.3.4, from pyopenssl) -* `idna`_ (minimum 2.0, from cryptography) - -However, pyopenssl depends on cryptography, which depends on idna, so while we -use all three directly here we end up having relatively few packages required. - -You can install them with the following command: - -.. code-block:: bash - - $ python -m pip install pyopenssl cryptography idna - -To activate certificate checking, call -:func:`~urllib3.contrib.pyopenssl.inject_into_urllib3` from your Python code -before you begin making HTTP requests. This can be done in a ``sitecustomize`` -module, or at any other time before your application begins using ``urllib3``, -like this: - -.. code-block:: python - - try: - import urllib3.contrib.pyopenssl - urllib3.contrib.pyopenssl.inject_into_urllib3() - except ImportError: - pass - -Now you can use :mod:`urllib3` as you normally would, and it will support SNI -when the required modules are installed. - -Activating this module also has the positive side effect of disabling SSL/TLS -compression in Python 2 (see `CRIME attack`_). - -.. _sni: https://en.wikipedia.org/wiki/Server_Name_Indication -.. _crime attack: https://en.wikipedia.org/wiki/CRIME_(security_exploit) -.. _pyopenssl: https://www.pyopenssl.org -.. _cryptography: https://cryptography.io -.. _idna: https://github.com/kjd/idna -""" -from __future__ import absolute_import - -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 -except ImportError: - # UnsupportedExtension is gone in cryptography >= 2.1.0 - class UnsupportedExtension(Exception): - pass - - -from io import BytesIO -from socket import error as SocketError -from socket import timeout - -try: # Platform-specific: Python 2 - from socket import _fileobject -except ImportError: # Platform-specific: Python 3 - _fileobject = None - from ..packages.backports.makefile import backport_makefile - -import logging -import ssl -import sys - -from .. import util -from ..packages import six -from ..util.ssl_ import PROTOCOL_TLS_CLIENT - -__all__ = ["inject_into_urllib3", "extract_from_urllib3"] - -# SNI always works. -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, -} - -if hasattr(ssl, "PROTOCOL_SSLv3") and hasattr(OpenSSL.SSL, "SSLv3_METHOD"): - _openssl_versions[ssl.PROTOCOL_SSLv3] = OpenSSL.SSL.SSLv3_METHOD - -if hasattr(ssl, "PROTOCOL_TLSv1_1") and hasattr(OpenSSL.SSL, "TLSv1_1_METHOD"): - _openssl_versions[ssl.PROTOCOL_TLSv1_1] = OpenSSL.SSL.TLSv1_1_METHOD - -if hasattr(ssl, "PROTOCOL_TLSv1_2") and hasattr(OpenSSL.SSL, "TLSv1_2_METHOD"): - _openssl_versions[ssl.PROTOCOL_TLSv1_2] = OpenSSL.SSL.TLSv1_2_METHOD - - -_stdlib_to_openssl_verify = { - ssl.CERT_NONE: OpenSSL.SSL.VERIFY_NONE, - ssl.CERT_OPTIONAL: OpenSSL.SSL.VERIFY_PEER, - ssl.CERT_REQUIRED: OpenSSL.SSL.VERIFY_PEER - + OpenSSL.SSL.VERIFY_FAIL_IF_NO_PEER_CERT, -} -_openssl_to_stdlib_verify = dict((v, k) for k, v in _stdlib_to_openssl_verify.items()) - -# OpenSSL will only write 16K at a time -SSL_WRITE_BLOCKSIZE = 16384 - -orig_util_HAS_SNI = util.HAS_SNI -orig_util_SSLContext = util.ssl_.SSLContext - - -log = logging.getLogger(__name__) - - -def inject_into_urllib3(): - "Monkey-patch urllib3 with PyOpenSSL-backed SSL-support." - - _validate_dependencies_met() - - util.SSLContext = PyOpenSSLContext - util.ssl_.SSLContext = PyOpenSSLContext - util.HAS_SNI = HAS_SNI - util.ssl_.HAS_SNI = HAS_SNI - util.IS_PYOPENSSL = True - util.ssl_.IS_PYOPENSSL = True - - -def extract_from_urllib3(): - "Undo monkey-patching by :func:`inject_into_urllib3`." - - util.SSLContext = orig_util_SSLContext - util.ssl_.SSLContext = orig_util_SSLContext - util.HAS_SNI = orig_util_HAS_SNI - util.ssl_.HAS_SNI = orig_util_HAS_SNI - util.IS_PYOPENSSL = False - util.ssl_.IS_PYOPENSSL = False - - -def _validate_dependencies_met(): - """ - Verifies that PyOpenSSL's package-level dependencies have been met. - Throws `ImportError` if they are not met. - """ - # Method added in `cryptography==1.1`; not available in older versions - from cryptography.x509.extensions import Extensions - - if getattr(Extensions, "get_extension_for_class", None) is None: - raise ImportError( - "'cryptography' module missing required functionality. " - "Try upgrading to v1.3.4 or newer." - ) - - # pyOpenSSL 0.14 and above use cryptography for OpenSSL bindings. The _x509 - # attribute is only present on those versions. - from OpenSSL.crypto import X509 - - x509 = X509() - if getattr(x509, "_x509", None) is None: - raise ImportError( - "'pyOpenSSL' module missing required functionality. " - "Try upgrading to v0.14 or newer." - ) - - -def _dnsname_to_stdlib(name): - """ - Converts a dNSName SubjectAlternativeName field to the form used by the - standard library on the given Python version. - - Cryptography produces a dNSName as a unicode string that was idna-decoded - from ASCII bytes. We need to idna-encode that string to get it back, and - then on Python 3 we also need to convert to unicode via UTF-8 (the stdlib - uses PyUnicode_FromStringAndSize on it, which decodes via UTF-8). - - If the name cannot be idna-encoded then we return None signalling that - the name given should be skipped. - """ - - def idna_encode(name): - """ - Borrowed wholesale from the Python Cryptography Project. It turns out - that we can't just safely call `idna.encode`: it can explode for - wildcard names. This avoids that problem. - """ - import idna - - try: - for prefix in [u"*.", u"."]: - if name.startswith(prefix): - name = name[len(prefix) :] - return prefix.encode("ascii") + idna.encode(name) - return idna.encode(name) - except idna.core.IDNAError: - return None - - # Don't send IPv6 addresses through the IDNA encoder. - if ":" in name: - return name - - name = idna_encode(name) - if name is None: - return None - elif sys.version_info >= (3, 0): - name = name.decode("utf-8") - return name - - -def get_subj_alt_name(peer_cert): - """ - Given an PyOpenSSL certificate, provides all the subject alternative names. - """ - # Pass the cert to cryptography, which has much better APIs for this. - 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) - - # We want to find the SAN extension. Ask Cryptography to locate it (it's - # faster than looping in Python) - try: - ext = cert.extensions.get_extension_for_class(x509.SubjectAlternativeName).value - except x509.ExtensionNotFound: - # No such extension, return the empty list. - return [] - except ( - x509.DuplicateExtension, - UnsupportedExtension, - x509.UnsupportedGeneralNameType, - UnicodeError, - ) as e: - # A problem has been found with the quality of the certificate. Assume - # no SAN field is present. - log.warning( - "A problem was encountered with the certificate that prevented " - "urllib3 from finding the SubjectAlternativeName field. This can " - "affect certificate validation. The error was %s", - e, - ) - return [] - - # We want to return dNSName and iPAddress fields. We need to cast the IPs - # back to strings because the match_hostname function wants them as - # strings. - # Sadly the DNS names need to be idna encoded and then, on Python 3, UTF-8 - # decoded. This is pretty frustrating, but that's what the standard library - # does with certificates, and so we need to attempt to do the same. - # We also want to skip over names which cannot be idna encoded. - names = [ - ("DNS", name) - for name in map(_dnsname_to_stdlib, ext.get_values_for_type(x509.DNSName)) - if name is not None - ] - names.extend( - ("IP Address", str(name)) for name in ext.get_values_for_type(x509.IPAddress) - ) - - return names - - -class WrappedSocket(object): - """API-compatibility wrapper for Python OpenSSL's Connection-class. - - Note: _makefile_refs, _drop() and _reuse() are needed for the garbage - collector of pypy. - """ - - def __init__(self, connection, socket, suppress_ragged_eofs=True): - self.connection = connection - self.socket = socket - self.suppress_ragged_eofs = suppress_ragged_eofs - self._makefile_refs = 0 - self._closed = False - - def fileno(self): - return self.socket.fileno() - - # Copy-pasted from Python 3.5 source code - def _decref_socketios(self): - if self._makefile_refs > 0: - self._makefile_refs -= 1 - if self._closed: - self.close() - - def recv(self, *args, **kwargs): - try: - data = self.connection.recv(*args, **kwargs) - except OpenSSL.SSL.SysCallError as e: - if self.suppress_ragged_eofs and e.args == (-1, "Unexpected EOF"): - return b"" - else: - raise SocketError(str(e)) - except OpenSSL.SSL.ZeroReturnError: - if self.connection.get_shutdown() == OpenSSL.SSL.RECEIVED_SHUTDOWN: - return b"" - else: - raise - except OpenSSL.SSL.WantReadError: - if not util.wait_for_read(self.socket, self.socket.gettimeout()): - raise timeout("The read operation timed out") - else: - return self.recv(*args, **kwargs) - - # TLS 1.3 post-handshake authentication - except OpenSSL.SSL.Error as e: - raise ssl.SSLError("read error: %r" % e) - else: - return data - - def recv_into(self, *args, **kwargs): - try: - return self.connection.recv_into(*args, **kwargs) - except OpenSSL.SSL.SysCallError as e: - if self.suppress_ragged_eofs and e.args == (-1, "Unexpected EOF"): - return 0 - else: - raise SocketError(str(e)) - except OpenSSL.SSL.ZeroReturnError: - if self.connection.get_shutdown() == OpenSSL.SSL.RECEIVED_SHUTDOWN: - return 0 - else: - raise - except OpenSSL.SSL.WantReadError: - if not util.wait_for_read(self.socket, self.socket.gettimeout()): - raise timeout("The read operation timed out") - else: - return self.recv_into(*args, **kwargs) - - # TLS 1.3 post-handshake authentication - except OpenSSL.SSL.Error as e: - raise ssl.SSLError("read error: %r" % e) - - def settimeout(self, timeout): - return self.socket.settimeout(timeout) - - def _send_until_done(self, data): - while True: - try: - return self.connection.send(data) - except OpenSSL.SSL.WantWriteError: - if not util.wait_for_write(self.socket, self.socket.gettimeout()): - raise timeout() - continue - except OpenSSL.SSL.SysCallError as e: - raise SocketError(str(e)) - - def sendall(self, data): - total_sent = 0 - while total_sent < len(data): - sent = self._send_until_done( - data[total_sent : total_sent + SSL_WRITE_BLOCKSIZE] - ) - total_sent += sent - - def shutdown(self): - # FIXME rethrow compatible exceptions should we ever use this - self.connection.shutdown() - - def close(self): - if self._makefile_refs < 1: - try: - self._closed = True - return self.connection.close() - except OpenSSL.SSL.Error: - return - else: - self._makefile_refs -= 1 - - def getpeercert(self, binary_form=False): - x509 = self.connection.get_peer_certificate() - - if not x509: - return x509 - - if binary_form: - return OpenSSL.crypto.dump_certificate(OpenSSL.crypto.FILETYPE_ASN1, x509) - - return { - "subject": ((("commonName", x509.get_subject().CN),),), - "subjectAltName": get_subj_alt_name(x509), - } - - def version(self): - return self.connection.get_protocol_version_name() - - def _reuse(self): - self._makefile_refs += 1 - - def _drop(self): - if self._makefile_refs < 1: - self.close() - else: - self._makefile_refs -= 1 - - -if _fileobject: # Platform-specific: Python 2 - - def makefile(self, mode, bufsize=-1): - self._makefile_refs += 1 - return _fileobject(self, mode, bufsize, close=True) - - -else: # Platform-specific: Python 3 - makefile = backport_makefile - -WrappedSocket.makefile = makefile - - -class PyOpenSSLContext(object): - """ - I am a wrapper class for the PyOpenSSL ``Context`` object. I am responsible - for translating the interface of the standard library ``SSLContext`` object - to calls into PyOpenSSL. - """ - - def __init__(self, protocol): - self.protocol = _openssl_versions[protocol] - self._ctx = OpenSSL.SSL.Context(self.protocol) - self._options = 0 - self.check_hostname = False - - @property - def options(self): - return self._options - - @options.setter - def options(self, value): - self._options = value - self._ctx.set_options(value) - - @property - def verify_mode(self): - return _openssl_to_stdlib_verify[self._ctx.get_verify_mode()] - - @verify_mode.setter - def verify_mode(self, value): - self._ctx.set_verify(_stdlib_to_openssl_verify[value], _verify_callback) - - def set_default_verify_paths(self): - self._ctx.set_default_verify_paths() - - def set_ciphers(self, ciphers): - if isinstance(ciphers, six.text_type): - ciphers = ciphers.encode("utf-8") - self._ctx.set_cipher_list(ciphers) - - def load_verify_locations(self, cafile=None, capath=None, cadata=None): - if cafile is not None: - cafile = cafile.encode("utf-8") - if capath is not None: - capath = capath.encode("utf-8") - try: - self._ctx.load_verify_locations(cafile, capath) - if cadata is not None: - self._ctx.load_verify_locations(BytesIO(cadata)) - except OpenSSL.SSL.Error as e: - raise ssl.SSLError("unable to load trusted certificates: %r" % e) - - def load_cert_chain(self, certfile, keyfile=None, password=None): - self._ctx.use_certificate_chain_file(certfile) - if password is not None: - if not isinstance(password, six.binary_type): - password = password.encode("utf-8") - self._ctx.set_passwd_cb(lambda *_: password) - self._ctx.use_privatekey_file(keyfile or certfile) - - def set_alpn_protocols(self, protocols): - protocols = [six.ensure_binary(p) for p in protocols] - return self._ctx.set_alpn_protos(protocols) - - def wrap_socket( - self, - sock, - server_side=False, - do_handshake_on_connect=True, - suppress_ragged_eofs=True, - server_hostname=None, - ): - cnx = OpenSSL.SSL.Connection(self._ctx, sock) - - if isinstance(server_hostname, six.text_type): # Platform-specific: Python 3 - server_hostname = server_hostname.encode("utf-8") - - if server_hostname is not None: - cnx.set_tlsext_host_name(server_hostname) - - cnx.set_connect_state() - - while True: - try: - cnx.do_handshake() - except OpenSSL.SSL.WantReadError: - if not util.wait_for_read(sock, sock.gettimeout()): - raise timeout("select timed out") - continue - except OpenSSL.SSL.Error as e: - raise ssl.SSLError("bad handshake: %r" % e) - break - - return WrappedSocket(cnx, sock) - - -def _verify_callback(cnx, x509, err_no, err_depth, return_code): - return err_no == 0 diff --git a/venv/lib/python3.8/site-packages/urllib3/contrib/securetransport.py b/venv/lib/python3.8/site-packages/urllib3/contrib/securetransport.py deleted file mode 100644 index 554c015..0000000 --- a/venv/lib/python3.8/site-packages/urllib3/contrib/securetransport.py +++ /dev/null @@ -1,922 +0,0 @@ -""" -SecureTranport support for urllib3 via ctypes. - -This makes platform-native TLS available to urllib3 users on macOS without the -use of a compiler. This is an important feature because the Python Package -Index is moving to become a TLSv1.2-or-higher server, and the default OpenSSL -that ships with macOS is not capable of doing TLSv1.2. The only way to resolve -this is to give macOS users an alternative solution to the problem, and that -solution is to use SecureTransport. - -We use ctypes here because this solution must not require a compiler. That's -because pip is not allowed to require a compiler either. - -This is not intended to be a seriously long-term solution to this problem. -The hope is that PEP 543 will eventually solve this issue for us, at which -point we can retire this contrib module. But in the short term, we need to -solve the impending tire fire that is Python on Mac without this kind of -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() - -Happy TLSing! - -This code is a bastardised version of the code found in Will Bond's oscrypto -library. An enormous debt is owed to him for blazing this trail for us. For -that reason, this code should be considered to be covered both by urllib3's -license and by oscrypto's: - -.. code-block:: - - Copyright (c) 2015-2016 Will Bond - - 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 absolute_import - -import contextlib -import ctypes -import errno -import os.path -import shutil -import socket -import ssl -import struct -import threading -import weakref - -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, - _build_tls_unknown_ca_alert, - _cert_array_from_pem, - _create_cfstring_array, - _load_client_cert_chain, - _temporary_keychain, -) - -try: # Platform-specific: Python 2 - from socket import _fileobject -except ImportError: # Platform-specific: Python 3 - _fileobject = None - from ..packages.backports.makefile import backport_makefile - -__all__ = ["inject_into_urllib3", "extract_from_urllib3"] - -# SNI always works -HAS_SNI = True - -orig_util_HAS_SNI = util.HAS_SNI -orig_util_SSLContext = util.ssl_.SSLContext - -# This dictionary is used by the read callback to obtain a handle to the -# calling wrapped socket. This is a pretty silly approach, but for now it'll -# do. I feel like I should be able to smuggle a handle to the wrapped socket -# directly in the SSLConnectionRef, but for now this approach will work I -# guess. -# -# We need to lock around this structure for inserts, but we don't do it for -# reads/writes in the callbacks. The reasoning here goes as follows: -# -# 1. It is not possible to call into the callbacks before the dictionary is -# populated, so once in the callback the id must be in the dictionary. -# 2. The callbacks don't mutate the dictionary, they only read from it, and -# so cannot conflict with any of the insertions. -# -# This is good: if we had to lock in the callbacks we'd drastically slow down -# the performance of this code. -_connection_refs = weakref.WeakValueDictionary() -_connection_ref_lock = threading.Lock() - -# Limit writes to 16kB. This is OpenSSL's limit, but we'll cargo-cult it over -# for no better reason than we need *a* limit, and this one is right there. -SSL_WRITE_BLOCKSIZE = 16384 - -# This is our equivalent of util.ssl_.DEFAULT_CIPHERS, but expanded out to -# individual cipher suites. We need to do this because this is how -# SecureTransport wants them. -CIPHER_SUITES = [ - SecurityConst.TLS_ECDHE_ECDSA_WITH_AES_256_GCM_SHA384, - SecurityConst.TLS_ECDHE_ECDSA_WITH_AES_128_GCM_SHA256, - SecurityConst.TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384, - SecurityConst.TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256, - SecurityConst.TLS_ECDHE_ECDSA_WITH_CHACHA20_POLY1305_SHA256, - SecurityConst.TLS_ECDHE_RSA_WITH_CHACHA20_POLY1305_SHA256, - SecurityConst.TLS_DHE_RSA_WITH_AES_256_GCM_SHA384, - SecurityConst.TLS_DHE_RSA_WITH_AES_128_GCM_SHA256, - SecurityConst.TLS_ECDHE_ECDSA_WITH_AES_256_CBC_SHA384, - SecurityConst.TLS_ECDHE_ECDSA_WITH_AES_256_CBC_SHA, - SecurityConst.TLS_ECDHE_ECDSA_WITH_AES_128_CBC_SHA256, - SecurityConst.TLS_ECDHE_ECDSA_WITH_AES_128_CBC_SHA, - SecurityConst.TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384, - SecurityConst.TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA, - SecurityConst.TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256, - SecurityConst.TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA, - SecurityConst.TLS_DHE_RSA_WITH_AES_256_CBC_SHA256, - SecurityConst.TLS_DHE_RSA_WITH_AES_256_CBC_SHA, - SecurityConst.TLS_DHE_RSA_WITH_AES_128_CBC_SHA256, - SecurityConst.TLS_DHE_RSA_WITH_AES_128_CBC_SHA, - SecurityConst.TLS_AES_256_GCM_SHA384, - SecurityConst.TLS_AES_128_GCM_SHA256, - SecurityConst.TLS_RSA_WITH_AES_256_GCM_SHA384, - SecurityConst.TLS_RSA_WITH_AES_128_GCM_SHA256, - SecurityConst.TLS_AES_128_CCM_8_SHA256, - SecurityConst.TLS_AES_128_CCM_SHA256, - SecurityConst.TLS_RSA_WITH_AES_256_CBC_SHA256, - SecurityConst.TLS_RSA_WITH_AES_128_CBC_SHA256, - SecurityConst.TLS_RSA_WITH_AES_256_CBC_SHA, - SecurityConst.TLS_RSA_WITH_AES_128_CBC_SHA, -] - -# Basically this is simple: for PROTOCOL_SSLv23 we turn it into a low of -# 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), - PROTOCOL_TLS_CLIENT: (SecurityConst.kTLSProtocol1, SecurityConst.kTLSProtocol12), -} - -if hasattr(ssl, "PROTOCOL_SSLv2"): - _protocol_to_min_max[ssl.PROTOCOL_SSLv2] = ( - SecurityConst.kSSLProtocol2, - SecurityConst.kSSLProtocol2, - ) -if hasattr(ssl, "PROTOCOL_SSLv3"): - _protocol_to_min_max[ssl.PROTOCOL_SSLv3] = ( - SecurityConst.kSSLProtocol3, - SecurityConst.kSSLProtocol3, - ) -if hasattr(ssl, "PROTOCOL_TLSv1"): - _protocol_to_min_max[ssl.PROTOCOL_TLSv1] = ( - SecurityConst.kTLSProtocol1, - SecurityConst.kTLSProtocol1, - ) -if hasattr(ssl, "PROTOCOL_TLSv1_1"): - _protocol_to_min_max[ssl.PROTOCOL_TLSv1_1] = ( - SecurityConst.kTLSProtocol11, - SecurityConst.kTLSProtocol11, - ) -if hasattr(ssl, "PROTOCOL_TLSv1_2"): - _protocol_to_min_max[ssl.PROTOCOL_TLSv1_2] = ( - SecurityConst.kTLSProtocol12, - SecurityConst.kTLSProtocol12, - ) - - -def inject_into_urllib3(): - """ - Monkey-patch urllib3 with SecureTransport-backed SSL-support. - """ - util.SSLContext = SecureTransportContext - util.ssl_.SSLContext = SecureTransportContext - util.HAS_SNI = HAS_SNI - util.ssl_.HAS_SNI = HAS_SNI - util.IS_SECURETRANSPORT = True - util.ssl_.IS_SECURETRANSPORT = True - - -def extract_from_urllib3(): - """ - Undo monkey-patching by :func:`inject_into_urllib3`. - """ - util.SSLContext = orig_util_SSLContext - util.ssl_.SSLContext = orig_util_SSLContext - util.HAS_SNI = orig_util_HAS_SNI - util.ssl_.HAS_SNI = orig_util_HAS_SNI - util.IS_SECURETRANSPORT = False - util.ssl_.IS_SECURETRANSPORT = False - - -def _read_callback(connection_id, data_buffer, data_length_pointer): - """ - SecureTransport read callback. This is called by ST to request that data - be returned from the socket. - """ - wrapped_socket = None - try: - wrapped_socket = _connection_refs.get(connection_id) - if wrapped_socket is None: - return SecurityConst.errSSLInternal - base_socket = wrapped_socket.socket - - requested_length = data_length_pointer[0] - - timeout = wrapped_socket.gettimeout() - error = None - read_count = 0 - - try: - while read_count < requested_length: - if timeout is None or timeout >= 0: - if not util.wait_for_read(base_socket, timeout): - raise socket.error(errno.EAGAIN, "timed out") - - remaining = requested_length - read_count - buffer = (ctypes.c_char * remaining).from_address( - data_buffer + read_count - ) - chunk_size = base_socket.recv_into(buffer, remaining) - read_count += chunk_size - if not chunk_size: - if not read_count: - return SecurityConst.errSSLClosedGraceful - break - except (socket.error) as e: - error = e.errno - - if error is not None and error != errno.EAGAIN: - data_length_pointer[0] = read_count - if error == errno.ECONNRESET or error == errno.EPIPE: - return SecurityConst.errSSLClosedAbort - raise - - data_length_pointer[0] = read_count - - if read_count != requested_length: - return SecurityConst.errSSLWouldBlock - - return 0 - except Exception as e: - if wrapped_socket is not None: - wrapped_socket._exception = e - return SecurityConst.errSSLInternal - - -def _write_callback(connection_id, data_buffer, data_length_pointer): - """ - SecureTransport write callback. This is called by ST to request that data - actually be sent on the network. - """ - wrapped_socket = None - try: - wrapped_socket = _connection_refs.get(connection_id) - if wrapped_socket is None: - return SecurityConst.errSSLInternal - base_socket = wrapped_socket.socket - - bytes_to_write = data_length_pointer[0] - data = ctypes.string_at(data_buffer, bytes_to_write) - - timeout = wrapped_socket.gettimeout() - error = None - sent = 0 - - try: - while sent < bytes_to_write: - if timeout is None or timeout >= 0: - if not util.wait_for_write(base_socket, timeout): - raise socket.error(errno.EAGAIN, "timed out") - chunk_sent = base_socket.send(data) - sent += chunk_sent - - # This has some needless copying here, but I'm not sure there's - # much value in optimising this data path. - data = data[chunk_sent:] - except (socket.error) as e: - error = e.errno - - if error is not None and error != errno.EAGAIN: - data_length_pointer[0] = sent - if error == errno.ECONNRESET or error == errno.EPIPE: - return SecurityConst.errSSLClosedAbort - raise - - data_length_pointer[0] = sent - - if sent != bytes_to_write: - return SecurityConst.errSSLWouldBlock - - return 0 - except Exception as e: - if wrapped_socket is not None: - wrapped_socket._exception = e - return SecurityConst.errSSLInternal - - -# We need to keep these two objects references alive: if they get GC'd while -# in use then SecureTransport could attempt to call a function that is in freed -# memory. That would be...uh...bad. Yeah, that's the word. Bad. -_read_callback_pointer = Security.SSLReadFunc(_read_callback) -_write_callback_pointer = Security.SSLWriteFunc(_write_callback) - - -class WrappedSocket(object): - """ - API-compatibility wrapper for Python's OpenSSL wrapped socket object. - - Note: _makefile_refs, _drop(), and _reuse() are needed for the garbage - collector of PyPy. - """ - - def __init__(self, socket): - self.socket = socket - self.context = None - self._makefile_refs = 0 - self._closed = False - self._exception = None - self._keychain = None - self._keychain_dir = None - self._client_cert_chain = None - - # We save off the previously-configured timeout and then set it to - # zero. This is done because we use select and friends to handle the - # timeouts, but if we leave the timeout set on the lower socket then - # Python will "kindly" call select on that socket again for us. Avoid - # that by forcing the timeout to zero. - self._timeout = self.socket.gettimeout() - self.socket.settimeout(0) - - @contextlib.contextmanager - def _raise_on_error(self): - """ - A context manager that can be used to wrap calls that do I/O from - SecureTransport. If any of the I/O callbacks hit an exception, this - context manager will correctly propagate the exception after the fact. - This avoids silently swallowing those exceptions. - - It also correctly forces the socket closed. - """ - self._exception = None - - # We explicitly don't catch around this yield because in the unlikely - # event that an exception was hit in the block we don't want to swallow - # it. - yield - if self._exception is not None: - exception, self._exception = self._exception, None - self.close() - raise exception - - def _set_ciphers(self): - """ - Sets up the allowed ciphers. By default this matches the set in - util.ssl_.DEFAULT_CIPHERS, at least as supported by macOS. This is done - custom and doesn't allow changing at this time, mostly because parsing - OpenSSL cipher strings is going to be a freaking nightmare. - """ - ciphers = (Security.SSLCipherSuite * len(CIPHER_SUITES))(*CIPHER_SUITES) - result = Security.SSLSetEnabledCiphers( - self.context, ciphers, len(CIPHER_SUITES) - ) - _assert_no_error(result) - - def _set_alpn_protocols(self, protocols): - """ - Sets up the ALPN protocols on the context. - """ - if not protocols: - return - protocols_arr = _create_cfstring_array(protocols) - try: - result = Security.SSLSetALPNProtocols(self.context, protocols_arr) - _assert_no_error(result) - finally: - CoreFoundation.CFRelease(protocols_arr) - - def _custom_validate(self, verify, trust_bundle): - """ - Called when we have set custom validation. We do this in two cases: - first, when cert validation is entirely disabled; and second, when - using a custom trust DB. - Raises an SSLError if the connection is not trusted. - """ - # If we disabled cert validation, just say: cool. - if not verify: - return - - successes = ( - SecurityConst.kSecTrustResultUnspecified, - SecurityConst.kSecTrustResultProceed, - ) - try: - trust_result = self._evaluate_trust(trust_bundle) - if trust_result in successes: - return - reason = "error code: %d" % (trust_result,) - except Exception as e: - # Do not trust on error - reason = "exception: %r" % (e,) - - # SecureTransport does not send an alert nor shuts down the connection. - rec = _build_tls_unknown_ca_alert(self.version()) - self.socket.sendall(rec) - # close the connection immediately - # l_onoff = 1, activate linger - # l_linger = 0, linger for 0 seoncds - opts = struct.pack("ii", 1, 0) - self.socket.setsockopt(socket.SOL_SOCKET, socket.SO_LINGER, opts) - self.close() - raise ssl.SSLError("certificate verify failed, %s" % reason) - - def _evaluate_trust(self, trust_bundle): - # We want data in memory, so load it up. - if os.path.isfile(trust_bundle): - with open(trust_bundle, "rb") as f: - trust_bundle = f.read() - - cert_array = None - trust = Security.SecTrustRef() - - try: - # Get a CFArray that contains the certs we want. - cert_array = _cert_array_from_pem(trust_bundle) - - # Ok, now the hard part. We want to get the SecTrustRef that ST has - # created for this connection, shove our CAs into it, tell ST to - # ignore everything else it knows, and then ask if it can build a - # chain. This is a buuuunch of code. - result = Security.SSLCopyPeerTrust(self.context, ctypes.byref(trust)) - _assert_no_error(result) - if not trust: - raise ssl.SSLError("Failed to copy trust reference") - - result = Security.SecTrustSetAnchorCertificates(trust, cert_array) - _assert_no_error(result) - - result = Security.SecTrustSetAnchorCertificatesOnly(trust, True) - _assert_no_error(result) - - trust_result = Security.SecTrustResultType() - result = Security.SecTrustEvaluate(trust, ctypes.byref(trust_result)) - _assert_no_error(result) - finally: - if trust: - CoreFoundation.CFRelease(trust) - - if cert_array is not None: - CoreFoundation.CFRelease(cert_array) - - return trust_result.value - - def handshake( - self, - server_hostname, - verify, - trust_bundle, - min_version, - max_version, - client_cert, - client_key, - client_key_passphrase, - alpn_protocols, - ): - """ - Actually performs the TLS handshake. This is run automatically by - wrapped socket, and shouldn't be needed in user code. - """ - # First, we do the initial bits of connection setup. We need to create - # a context, set its I/O funcs, and set the connection reference. - self.context = Security.SSLCreateContext( - None, SecurityConst.kSSLClientSide, SecurityConst.kSSLStreamType - ) - result = Security.SSLSetIOFuncs( - self.context, _read_callback_pointer, _write_callback_pointer - ) - _assert_no_error(result) - - # Here we need to compute the handle to use. We do this by taking the - # id of self modulo 2**31 - 1. If this is already in the dictionary, we - # just keep incrementing by one until we find a free space. - with _connection_ref_lock: - handle = id(self) % 2147483647 - while handle in _connection_refs: - handle = (handle + 1) % 2147483647 - _connection_refs[handle] = self - - result = Security.SSLSetConnection(self.context, handle) - _assert_no_error(result) - - # If we have a server hostname, we should set that too. - if server_hostname: - if not isinstance(server_hostname, bytes): - server_hostname = server_hostname.encode("utf-8") - - result = Security.SSLSetPeerDomainName( - self.context, server_hostname, len(server_hostname) - ) - _assert_no_error(result) - - # Setup the ciphers. - self._set_ciphers() - - # Setup the ALPN protocols. - self._set_alpn_protocols(alpn_protocols) - - # Set the minimum and maximum TLS versions. - result = Security.SSLSetProtocolVersionMin(self.context, min_version) - _assert_no_error(result) - - result = Security.SSLSetProtocolVersionMax(self.context, max_version) - _assert_no_error(result) - - # If there's a trust DB, we need to use it. We do that by telling - # SecureTransport to break on server auth. We also do that if we don't - # want to validate the certs at all: we just won't actually do any - # authing in that case. - if not verify or trust_bundle is not None: - result = Security.SSLSetSessionOption( - self.context, SecurityConst.kSSLSessionOptionBreakOnServerAuth, True - ) - _assert_no_error(result) - - # If there's a client cert, we need to use it. - if client_cert: - self._keychain, self._keychain_dir = _temporary_keychain() - self._client_cert_chain = _load_client_cert_chain( - self._keychain, client_cert, client_key - ) - result = Security.SSLSetCertificate(self.context, self._client_cert_chain) - _assert_no_error(result) - - while True: - with self._raise_on_error(): - result = Security.SSLHandshake(self.context) - - if result == SecurityConst.errSSLWouldBlock: - raise socket.timeout("handshake timed out") - elif result == SecurityConst.errSSLServerAuthCompleted: - self._custom_validate(verify, trust_bundle) - continue - else: - _assert_no_error(result) - break - - def fileno(self): - return self.socket.fileno() - - # Copy-pasted from Python 3.5 source code - def _decref_socketios(self): - if self._makefile_refs > 0: - self._makefile_refs -= 1 - if self._closed: - self.close() - - def recv(self, bufsiz): - buffer = ctypes.create_string_buffer(bufsiz) - bytes_read = self.recv_into(buffer, bufsiz) - data = buffer[:bytes_read] - return data - - def recv_into(self, buffer, nbytes=None): - # Read short on EOF. - if self._closed: - return 0 - - if nbytes is None: - nbytes = len(buffer) - - buffer = (ctypes.c_char * nbytes).from_buffer(buffer) - processed_bytes = ctypes.c_size_t(0) - - with self._raise_on_error(): - result = Security.SSLRead( - self.context, buffer, nbytes, ctypes.byref(processed_bytes) - ) - - # There are some result codes that we want to treat as "not always - # errors". Specifically, those are errSSLWouldBlock, - # errSSLClosedGraceful, and errSSLClosedNoNotify. - if result == SecurityConst.errSSLWouldBlock: - # If we didn't process any bytes, then this was just a time out. - # However, we can get errSSLWouldBlock in situations when we *did* - # read some data, and in those cases we should just read "short" - # and return. - if processed_bytes.value == 0: - # Timed out, no data read. - raise socket.timeout("recv timed out") - elif result in ( - SecurityConst.errSSLClosedGraceful, - SecurityConst.errSSLClosedNoNotify, - ): - # The remote peer has closed this connection. We should do so as - # well. Note that we don't actually return here because in - # principle this could actually be fired along with return data. - # It's unlikely though. - self.close() - else: - _assert_no_error(result) - - # Ok, we read and probably succeeded. We should return whatever data - # was actually read. - return processed_bytes.value - - def settimeout(self, timeout): - self._timeout = timeout - - def gettimeout(self): - return self._timeout - - def send(self, data): - processed_bytes = ctypes.c_size_t(0) - - with self._raise_on_error(): - result = Security.SSLWrite( - self.context, data, len(data), ctypes.byref(processed_bytes) - ) - - if result == SecurityConst.errSSLWouldBlock and processed_bytes.value == 0: - # Timed out - raise socket.timeout("send timed out") - else: - _assert_no_error(result) - - # We sent, and probably succeeded. Tell them how much we sent. - return processed_bytes.value - - def sendall(self, data): - total_sent = 0 - while total_sent < len(data): - sent = self.send(data[total_sent : total_sent + SSL_WRITE_BLOCKSIZE]) - total_sent += sent - - def shutdown(self): - with self._raise_on_error(): - Security.SSLClose(self.context) - - def close(self): - # TODO: should I do clean shutdown here? Do I have to? - if self._makefile_refs < 1: - self._closed = True - if self.context: - CoreFoundation.CFRelease(self.context) - self.context = None - if self._client_cert_chain: - CoreFoundation.CFRelease(self._client_cert_chain) - self._client_cert_chain = None - if self._keychain: - Security.SecKeychainDelete(self._keychain) - CoreFoundation.CFRelease(self._keychain) - shutil.rmtree(self._keychain_dir) - self._keychain = self._keychain_dir = None - return self.socket.close() - else: - self._makefile_refs -= 1 - - def getpeercert(self, binary_form=False): - # Urgh, annoying. - # - # Here's how we do this: - # - # 1. Call SSLCopyPeerTrust to get hold of the trust object for this - # connection. - # 2. Call SecTrustGetCertificateAtIndex for index 0 to get the leaf. - # 3. To get the CN, call SecCertificateCopyCommonName and process that - # string so that it's of the appropriate type. - # 4. To get the SAN, we need to do something a bit more complex: - # a. Call SecCertificateCopyValues to get the data, requesting - # kSecOIDSubjectAltName. - # b. Mess about with this dictionary to try to get the SANs out. - # - # This is gross. Really gross. It's going to be a few hundred LoC extra - # just to repeat something that SecureTransport can *already do*. So my - # operating assumption at this time is that what we want to do is - # instead to just flag to urllib3 that it shouldn't do its own hostname - # validation when using SecureTransport. - if not binary_form: - raise ValueError("SecureTransport only supports dumping binary certs") - trust = Security.SecTrustRef() - certdata = None - der_bytes = None - - try: - # Grab the trust store. - result = Security.SSLCopyPeerTrust(self.context, ctypes.byref(trust)) - _assert_no_error(result) - if not trust: - # Probably we haven't done the handshake yet. No biggie. - return None - - cert_count = Security.SecTrustGetCertificateCount(trust) - if not cert_count: - # Also a case that might happen if we haven't handshaked. - # Handshook? Handshaken? - return None - - leaf = Security.SecTrustGetCertificateAtIndex(trust, 0) - assert leaf - - # Ok, now we want the DER bytes. - certdata = Security.SecCertificateCopyData(leaf) - assert certdata - - data_length = CoreFoundation.CFDataGetLength(certdata) - data_buffer = CoreFoundation.CFDataGetBytePtr(certdata) - der_bytes = ctypes.string_at(data_buffer, data_length) - finally: - if certdata: - CoreFoundation.CFRelease(certdata) - if trust: - CoreFoundation.CFRelease(trust) - - return der_bytes - - def version(self): - protocol = Security.SSLProtocol() - result = Security.SSLGetNegotiatedProtocolVersion( - self.context, ctypes.byref(protocol) - ) - _assert_no_error(result) - if protocol.value == SecurityConst.kTLSProtocol13: - raise ssl.SSLError("SecureTransport does not support TLS 1.3") - elif protocol.value == SecurityConst.kTLSProtocol12: - return "TLSv1.2" - elif protocol.value == SecurityConst.kTLSProtocol11: - return "TLSv1.1" - elif protocol.value == SecurityConst.kTLSProtocol1: - return "TLSv1" - elif protocol.value == SecurityConst.kSSLProtocol3: - return "SSLv3" - elif protocol.value == SecurityConst.kSSLProtocol2: - return "SSLv2" - else: - raise ssl.SSLError("Unknown TLS version: %r" % protocol) - - def _reuse(self): - self._makefile_refs += 1 - - def _drop(self): - if self._makefile_refs < 1: - self.close() - else: - self._makefile_refs -= 1 - - -if _fileobject: # Platform-specific: Python 2 - - def makefile(self, mode, bufsize=-1): - 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): - # We disable buffering with SecureTransport because it conflicts with - # the buffering that ST does internally (see issue #1153 for more). - buffering = 0 - return backport_makefile(self, mode, buffering, *args, **kwargs) - - -WrappedSocket.makefile = makefile - - -class SecureTransportContext(object): - """ - I am a wrapper class for the SecureTransport library, to translate the - interface of the standard library ``SSLContext`` object to calls into - SecureTransport. - """ - - def __init__(self, protocol): - self._min_version, self._max_version = _protocol_to_min_max[protocol] - self._options = 0 - self._verify = False - self._trust_bundle = None - self._client_cert = None - self._client_key = None - self._client_key_passphrase = None - self._alpn_protocols = None - - @property - def check_hostname(self): - """ - SecureTransport cannot have its hostname checking disabled. For more, - see the comment on getpeercert() in this file. - """ - return True - - @check_hostname.setter - def check_hostname(self, value): - """ - SecureTransport cannot have its hostname checking disabled. For more, - see the comment on getpeercert() in this file. - """ - pass - - @property - def options(self): - # TODO: Well, crap. - # - # So this is the bit of the code that is the most likely to cause us - # trouble. Essentially we need to enumerate all of the SSL options that - # users might want to use and try to see if we can sensibly translate - # them, or whether we should just ignore them. - return self._options - - @options.setter - def options(self, value): - # TODO: Update in line with above. - self._options = value - - @property - def verify_mode(self): - return ssl.CERT_REQUIRED if self._verify else ssl.CERT_NONE - - @verify_mode.setter - def verify_mode(self, value): - self._verify = True if value == ssl.CERT_REQUIRED else False - - def set_default_verify_paths(self): - # So, this has to do something a bit weird. Specifically, what it does - # is nothing. - # - # This means that, if we had previously had load_verify_locations - # called, this does not undo that. We need to do that because it turns - # out that the rest of the urllib3 code will attempt to load the - # default verify paths if it hasn't been told about any paths, even if - # the context itself was sometime earlier. We resolve that by just - # ignoring it. - pass - - def load_default_certs(self): - return self.set_default_verify_paths() - - def set_ciphers(self, ciphers): - # For now, we just require the default cipher string. - if ciphers != util.ssl_.DEFAULT_CIPHERS: - raise ValueError("SecureTransport doesn't support custom cipher strings") - - def load_verify_locations(self, cafile=None, capath=None, cadata=None): - # OK, we only really support cadata and cafile. - if capath is not None: - raise ValueError("SecureTransport does not support cert directories") - - # Raise if cafile does not exist. - if cafile is not None: - with open(cafile): - pass - - self._trust_bundle = cafile or cadata - - def load_cert_chain(self, certfile, keyfile=None, password=None): - self._client_cert = certfile - self._client_key = keyfile - self._client_cert_passphrase = password - - def set_alpn_protocols(self, protocols): - """ - Sets the ALPN protocols that will later be set on the context. - - Raises a NotImplementedError if ALPN is not supported. - """ - if not hasattr(Security, "SSLSetALPNProtocols"): - raise NotImplementedError( - "SecureTransport supports ALPN only in macOS 10.12+" - ) - self._alpn_protocols = [six.ensure_binary(p) for p in protocols] - - def wrap_socket( - self, - sock, - server_side=False, - do_handshake_on_connect=True, - suppress_ragged_eofs=True, - server_hostname=None, - ): - # So, what do we do here? Firstly, we assert some properties. This is a - # stripped down shim, so there is some functionality we don't support. - # See PEP 543 for the real deal. - assert not server_side - assert do_handshake_on_connect - assert suppress_ragged_eofs - - # Ok, we're good to go. Now we want to create the wrapped socket object - # and store it in the appropriate place. - wrapped_socket = WrappedSocket(sock) - - # Now we can handshake - wrapped_socket.handshake( - server_hostname, - self._verify, - self._trust_bundle, - self._min_version, - self._max_version, - self._client_cert, - self._client_key, - self._client_key_passphrase, - self._alpn_protocols, - ) - return wrapped_socket diff --git a/venv/lib/python3.8/site-packages/urllib3/contrib/socks.py b/venv/lib/python3.8/site-packages/urllib3/contrib/socks.py deleted file mode 100644 index c326e80..0000000 --- a/venv/lib/python3.8/site-packages/urllib3/contrib/socks.py +++ /dev/null @@ -1,216 +0,0 @@ -# -*- coding: utf-8 -*- -""" -This module contains provisional support for SOCKS proxies from within -urllib3. This module supports SOCKS4, SOCKS4A (an extension of SOCKS4), and -SOCKS5. To enable its functionality, either install PySocks or install this -module with the ``socks`` extra. - -The SOCKS implementation supports the full range of urllib3 features. It also -supports the following SOCKS features: - -- SOCKS4A (``proxy_url='socks4a://...``) -- SOCKS4 (``proxy_url='socks4://...``) -- SOCKS5 with remote DNS (``proxy_url='socks5h://...``) -- SOCKS5 with local DNS (``proxy_url='socks5://...``) -- Usernames and passwords for the SOCKS proxy - -.. note:: - It is recommended to use ``socks5h://`` or ``socks4a://`` schemes in - your ``proxy_url`` to ensure that DNS resolution is done from the remote - server instead of client-side when connecting to a domain name. - -SOCKS4 supports IPv4 and domain names with the SOCKS4A extension. SOCKS5 -supports IPv4, IPv6, and domain names. - -When connecting to a SOCKS4 proxy the ``username`` portion of the ``proxy_url`` -will be sent as the ``userid`` section of the SOCKS request: - -.. code-block:: python - - proxy_url="socks4a://@proxy-host" - -When connecting to a SOCKS5 proxy the ``username`` and ``password`` portion -of the ``proxy_url`` will be sent as the username/password to authenticate -with the proxy: - -.. code-block:: python - - proxy_url="socks5h://:@proxy-host" - -""" -from __future__ import absolute_import - -try: - import socks -except ImportError: - import warnings - - from ..exceptions import DependencyWarning - - warnings.warn( - ( - "SOCKS support in urllib3 requires the installation of optional " - "dependencies: specifically, PySocks. For more information, see " - "https://urllib3.readthedocs.io/en/1.26.x/contrib.html#socks-proxies" - ), - DependencyWarning, - ) - raise - -from socket import error as SocketError -from socket import timeout as SocketTimeout - -from ..connection import HTTPConnection, HTTPSConnection -from ..connectionpool import HTTPConnectionPool, HTTPSConnectionPool -from ..exceptions import ConnectTimeoutError, NewConnectionError -from ..poolmanager import PoolManager -from ..util.url import parse_url - -try: - import ssl -except ImportError: - ssl = None - - -class SOCKSConnection(HTTPConnection): - """ - A plain-text HTTP connection that connects via a SOCKS proxy. - """ - - def __init__(self, *args, **kwargs): - self._socks_options = kwargs.pop("_socks_options") - super(SOCKSConnection, self).__init__(*args, **kwargs) - - def _new_conn(self): - """ - Establish a new connection via the SOCKS proxy. - """ - extra_kw = {} - if self.source_address: - extra_kw["source_address"] = self.source_address - - if self.socket_options: - extra_kw["socket_options"] = self.socket_options - - try: - conn = socks.create_connection( - (self.host, self.port), - proxy_type=self._socks_options["socks_version"], - proxy_addr=self._socks_options["proxy_host"], - proxy_port=self._socks_options["proxy_port"], - proxy_username=self._socks_options["username"], - proxy_password=self._socks_options["password"], - proxy_rdns=self._socks_options["rdns"], - timeout=self.timeout, - **extra_kw - ) - - except SocketTimeout: - raise ConnectTimeoutError( - self, - "Connection to %s timed out. (connect timeout=%s)" - % (self.host, self.timeout), - ) - - except socks.ProxyError as e: - # This is fragile as hell, but it seems to be the only way to raise - # useful errors here. - if e.socket_err: - error = e.socket_err - if isinstance(error, SocketTimeout): - raise ConnectTimeoutError( - self, - "Connection to %s timed out. (connect timeout=%s)" - % (self.host, self.timeout), - ) - else: - raise NewConnectionError( - self, "Failed to establish a new connection: %s" % error - ) - else: - raise NewConnectionError( - self, "Failed to establish a new connection: %s" % e - ) - - except SocketError as e: # Defensive: PySocks should catch all these. - raise NewConnectionError( - self, "Failed to establish a new connection: %s" % e - ) - - return conn - - -# We don't need to duplicate the Verified/Unverified distinction from -# urllib3/connection.py here because the HTTPSConnection will already have been -# correctly set to either the Verified or Unverified form by that module. This -# means the SOCKSHTTPSConnection will automatically be the correct type. -class SOCKSHTTPSConnection(SOCKSConnection, HTTPSConnection): - pass - - -class SOCKSHTTPConnectionPool(HTTPConnectionPool): - ConnectionCls = SOCKSConnection - - -class SOCKSHTTPSConnectionPool(HTTPSConnectionPool): - ConnectionCls = SOCKSHTTPSConnection - - -class SOCKSProxyManager(PoolManager): - """ - A version of the urllib3 ProxyManager that routes connections via the - defined SOCKS proxy. - """ - - pool_classes_by_scheme = { - "http": SOCKSHTTPConnectionPool, - "https": SOCKSHTTPSConnectionPool, - } - - def __init__( - self, - proxy_url, - username=None, - password=None, - num_pools=10, - headers=None, - **connection_pool_kw - ): - parsed = parse_url(proxy_url) - - if username is None and password is None and parsed.auth is not None: - split = parsed.auth.split(":") - if len(split) == 2: - username, password = split - if parsed.scheme == "socks5": - socks_version = socks.PROXY_TYPE_SOCKS5 - rdns = False - elif parsed.scheme == "socks5h": - socks_version = socks.PROXY_TYPE_SOCKS5 - rdns = True - elif parsed.scheme == "socks4": - socks_version = socks.PROXY_TYPE_SOCKS4 - rdns = False - elif parsed.scheme == "socks4a": - socks_version = socks.PROXY_TYPE_SOCKS4 - rdns = True - else: - raise ValueError("Unable to determine SOCKS version from %s" % proxy_url) - - self.proxy_url = proxy_url - - socks_options = { - "socks_version": socks_version, - "proxy_host": parsed.host, - "proxy_port": parsed.port, - "username": username, - "password": password, - "rdns": rdns, - } - connection_pool_kw["_socks_options"] = socks_options - - super(SOCKSProxyManager, self).__init__( - num_pools, headers, **connection_pool_kw - ) - - self.pool_classes_by_scheme = SOCKSProxyManager.pool_classes_by_scheme diff --git a/venv/lib/python3.8/site-packages/urllib3/exceptions.py b/venv/lib/python3.8/site-packages/urllib3/exceptions.py deleted file mode 100644 index cba6f3f..0000000 --- a/venv/lib/python3.8/site-packages/urllib3/exceptions.py +++ /dev/null @@ -1,323 +0,0 @@ -from __future__ import absolute_import - -from .packages.six.moves.http_client import IncompleteRead as httplib_IncompleteRead - -# Base Exceptions - - -class HTTPError(Exception): - """Base exception used by this module.""" - - pass - - -class HTTPWarning(Warning): - """Base warning used by this module.""" - - pass - - -class PoolError(HTTPError): - """Base exception for errors caused within a pool.""" - - def __init__(self, pool, message): - self.pool = pool - HTTPError.__init__(self, "%s: %s" % (pool, message)) - - def __reduce__(self): - # For pickling purposes. - return self.__class__, (None, None) - - -class RequestError(PoolError): - """Base exception for PoolErrors that have associated URLs.""" - - def __init__(self, pool, url, message): - self.url = url - PoolError.__init__(self, pool, message) - - def __reduce__(self): - # For pickling purposes. - return self.__class__, (None, self.url, None) - - -class SSLError(HTTPError): - """Raised when SSL certificate fails in an HTTPS connection.""" - - pass - - -class ProxyError(HTTPError): - """Raised when the connection to a proxy fails.""" - - def __init__(self, message, error, *args): - super(ProxyError, self).__init__(message, error, *args) - self.original_error = error - - -class DecodeError(HTTPError): - """Raised when automatic decoding based on Content-Type fails.""" - - pass - - -class ProtocolError(HTTPError): - """Raised when something unexpected happens mid-request/response.""" - - pass - - -#: Renamed to ProtocolError but aliased for backwards compatibility. -ConnectionError = ProtocolError - - -# Leaf Exceptions - - -class MaxRetryError(RequestError): - """Raised when the maximum number of retries is exceeded. - - :param pool: The connection pool - :type pool: :class:`~urllib3.connectionpool.HTTPConnectionPool` - :param string url: The requested Url - :param exceptions.Exception reason: The underlying error - - """ - - def __init__(self, pool, url, reason=None): - self.reason = reason - - message = "Max retries exceeded with url: %s (Caused by %r)" % (url, reason) - - RequestError.__init__(self, pool, url, message) - - -class HostChangedError(RequestError): - """Raised when an existing pool gets a request for a foreign host.""" - - def __init__(self, pool, url, retries=3): - message = "Tried to open a foreign host with url: %s" % url - RequestError.__init__(self, pool, url, message) - self.retries = retries - - -class TimeoutStateError(HTTPError): - """Raised when passing an invalid state to a timeout""" - - pass - - -class TimeoutError(HTTPError): - """Raised when a socket timeout error occurs. - - Catching this error will catch both :exc:`ReadTimeoutErrors - ` and :exc:`ConnectTimeoutErrors `. - """ - - pass - - -class ReadTimeoutError(TimeoutError, RequestError): - """Raised when a socket timeout occurs while receiving data from a server""" - - pass - - -# This timeout error does not have a URL attached and needs to inherit from the -# base HTTPError -class ConnectTimeoutError(TimeoutError): - """Raised when a socket timeout occurs while connecting to a server""" - - pass - - -class NewConnectionError(ConnectTimeoutError, PoolError): - """Raised when we fail to establish a new connection. Usually ECONNREFUSED.""" - - pass - - -class EmptyPoolError(PoolError): - """Raised when a pool runs out of connections and no more are allowed.""" - - pass - - -class ClosedPoolError(PoolError): - """Raised when a request enters a pool after the pool has been closed.""" - - pass - - -class LocationValueError(ValueError, HTTPError): - """Raised when there is something wrong with a given URL input.""" - - pass - - -class LocationParseError(LocationValueError): - """Raised when get_host or similar fails to parse the URL input.""" - - def __init__(self, location): - message = "Failed to parse: %s" % location - HTTPError.__init__(self, message) - - self.location = location - - -class URLSchemeUnknown(LocationValueError): - """Raised when a URL input has an unsupported scheme.""" - - def __init__(self, scheme): - message = "Not supported URL scheme %s" % scheme - super(URLSchemeUnknown, self).__init__(message) - - self.scheme = scheme - - -class ResponseError(HTTPError): - """Used as a container for an error reason supplied in a MaxRetryError.""" - - GENERIC_ERROR = "too many error responses" - SPECIFIC_ERROR = "too many {status_code} error responses" - - -class SecurityWarning(HTTPWarning): - """Warned when performing security reducing actions""" - - pass - - -class SubjectAltNameWarning(SecurityWarning): - """Warned when connecting to a host with a certificate missing a SAN.""" - - pass - - -class InsecureRequestWarning(SecurityWarning): - """Warned when making an unverified HTTPS request.""" - - pass - - -class SystemTimeWarning(SecurityWarning): - """Warned when system time is suspected to be wrong""" - - pass - - -class InsecurePlatformWarning(SecurityWarning): - """Warned when certain TLS/SSL configuration is not available on a platform.""" - - pass - - -class SNIMissingWarning(HTTPWarning): - """Warned when making a HTTPS request without SNI available.""" - - pass - - -class DependencyWarning(HTTPWarning): - """ - Warned when an attempt is made to import a module with missing optional - dependencies. - """ - - pass - - -class ResponseNotChunked(ProtocolError, ValueError): - """Response needs to be chunked in order to read it as chunks.""" - - pass - - -class BodyNotHttplibCompatible(HTTPError): - """ - Body should be :class:`http.client.HTTPResponse` like - (have an fp attribute which returns raw chunks) for read_chunked(). - """ - - pass - - -class IncompleteRead(HTTPError, httplib_IncompleteRead): - """ - Response length doesn't match expected Content-Length - - Subclass of :class:`http.client.IncompleteRead` to allow int value - for ``partial`` to avoid creating large objects on streamed reads. - """ - - def __init__(self, partial, expected): - super(IncompleteRead, self).__init__(partial, expected) - - def __repr__(self): - return "IncompleteRead(%i bytes read, %i more expected)" % ( - self.partial, - self.expected, - ) - - -class InvalidChunkLength(HTTPError, httplib_IncompleteRead): - """Invalid chunk length in a chunked response.""" - - def __init__(self, response, length): - super(InvalidChunkLength, self).__init__( - response.tell(), response.length_remaining - ) - self.response = response - self.length = length - - def __repr__(self): - return "InvalidChunkLength(got length %r, %i bytes read)" % ( - self.length, - self.partial, - ) - - -class InvalidHeader(HTTPError): - """The header provided was somehow invalid.""" - - pass - - -class ProxySchemeUnknown(AssertionError, URLSchemeUnknown): - """ProxyManager does not support the supplied scheme""" - - # TODO(t-8ch): Stop inheriting from AssertionError in v2.0. - - def __init__(self, scheme): - # 'localhost' is here because our URL parser parses - # localhost:8080 -> scheme=localhost, remove if we fix this. - if scheme == "localhost": - scheme = None - if scheme is None: - message = "Proxy URL had no scheme, should start with http:// or https://" - else: - message = ( - "Proxy URL had unsupported scheme %s, should use http:// or https://" - % scheme - ) - super(ProxySchemeUnknown, self).__init__(message) - - -class ProxySchemeUnsupported(ValueError): - """Fetching HTTPS resources through HTTPS proxies is unsupported""" - - pass - - -class HeaderParsingError(HTTPError): - """Raised by assert_header_parsing, but we convert it to a log.warning statement.""" - - def __init__(self, defects, unparsed_data): - message = "%s, unparsed data: %r" % (defects or "Unknown", unparsed_data) - super(HeaderParsingError, self).__init__(message) - - -class UnrewindableBodyError(HTTPError): - """urllib3 encountered an error when trying to rewind a body""" - - pass diff --git a/venv/lib/python3.8/site-packages/urllib3/fields.py b/venv/lib/python3.8/site-packages/urllib3/fields.py deleted file mode 100644 index 9d630f4..0000000 --- a/venv/lib/python3.8/site-packages/urllib3/fields.py +++ /dev/null @@ -1,274 +0,0 @@ -from __future__ import absolute_import - -import email.utils -import mimetypes -import re - -from .packages import six - - -def guess_content_type(filename, default="application/octet-stream"): - """ - Guess the "Content-Type" of a file. - - :param filename: - The filename to guess the "Content-Type" of using :mod:`mimetypes`. - :param default: - If no "Content-Type" can be guessed, default to `default`. - """ - if filename: - return mimetypes.guess_type(filename)[0] or default - return default - - -def format_header_param_rfc2231(name, value): - """ - Helper function to format and quote a single header parameter using the - strategy defined in RFC 2231. - - Particularly useful for header parameters which might contain - non-ASCII values, like file names. This follows - `RFC 2388 Section 4.4 `_. - - :param name: - The name of the parameter, a string expected to be ASCII only. - :param value: - The value of the parameter, provided as ``bytes`` or `str``. - :ret: - An RFC-2231-formatted unicode string. - """ - if isinstance(value, six.binary_type): - value = value.decode("utf-8") - - if not any(ch in value for ch in '"\\\r\n'): - result = u'%s="%s"' % (name, value) - try: - result.encode("ascii") - except (UnicodeEncodeError, UnicodeDecodeError): - pass - else: - return result - - if six.PY2: # Python 2: - value = value.encode("utf-8") - - # encode_rfc2231 accepts an encoded string and returns an ascii-encoded - # string in Python 2 but accepts and returns unicode strings in Python 3 - value = email.utils.encode_rfc2231(value, "utf-8") - value = "%s*=%s" % (name, value) - - if six.PY2: # Python 2: - value = value.decode("utf-8") - - return value - - -_HTML5_REPLACEMENTS = { - u"\u0022": u"%22", - # Replace "\" with "\\". - u"\u005C": u"\u005C\u005C", -} - -# All control characters from 0x00 to 0x1F *except* 0x1B. -_HTML5_REPLACEMENTS.update( - { - six.unichr(cc): u"%{:02X}".format(cc) - for cc in range(0x00, 0x1F + 1) - if cc not in (0x1B,) - } -) - - -def _replace_multiple(value, needles_and_replacements): - def replacer(match): - return needles_and_replacements[match.group(0)] - - pattern = re.compile( - r"|".join([re.escape(needle) for needle in needles_and_replacements.keys()]) - ) - - result = pattern.sub(replacer, value) - - return result - - -def format_header_param_html5(name, value): - """ - Helper function to format and quote a single header parameter using the - HTML5 strategy. - - Particularly useful for header parameters which might contain - non-ASCII values, like file names. This follows the `HTML5 Working Draft - Section 4.10.22.7`_ and matches the behavior of curl and modern browsers. - - .. _HTML5 Working Draft Section 4.10.22.7: - https://w3c.github.io/html/sec-forms.html#multipart-form-data - - :param name: - The name of the parameter, a string expected to be ASCII only. - :param value: - The value of the parameter, provided as ``bytes`` or `str``. - :ret: - A unicode string, stripped of troublesome characters. - """ - if isinstance(value, six.binary_type): - value = value.decode("utf-8") - - value = _replace_multiple(value, _HTML5_REPLACEMENTS) - - return u'%s="%s"' % (name, value) - - -# For backwards-compatibility. -format_header_param = format_header_param_html5 - - -class RequestField(object): - """ - A data container for request body parameters. - - :param name: - The name of this request field. Must be unicode. - :param data: - The data/value body. - :param filename: - An optional filename of the request field. Must be unicode. - :param headers: - An optional dict-like object of headers to initially use for the field. - :param header_formatter: - An optional callable that is used to encode and format the headers. By - default, this is :func:`format_header_param_html5`. - """ - - def __init__( - self, - name, - data, - filename=None, - headers=None, - header_formatter=format_header_param_html5, - ): - self._name = name - self._filename = filename - self.data = data - self.headers = {} - if headers: - self.headers = dict(headers) - self.header_formatter = header_formatter - - @classmethod - def from_tuples(cls, fieldname, value, header_formatter=format_header_param_html5): - """ - A :class:`~urllib3.fields.RequestField` factory from old-style tuple parameters. - - Supports constructing :class:`~urllib3.fields.RequestField` from - parameter of key/value strings AND key/filetuple. A filetuple is a - (filename, data, MIME type) tuple where the MIME type is optional. - For example:: - - 'foo': 'bar', - 'fakefile': ('foofile.txt', 'contents of foofile'), - 'realfile': ('barfile.txt', open('realfile').read()), - 'typedfile': ('bazfile.bin', open('bazfile').read(), 'image/jpeg'), - 'nonamefile': 'contents of nonamefile field', - - Field names and filenames must be unicode. - """ - if isinstance(value, tuple): - if len(value) == 3: - filename, data, content_type = value - else: - filename, data = value - content_type = guess_content_type(filename) - else: - filename = None - content_type = None - data = value - - request_param = cls( - fieldname, data, filename=filename, header_formatter=header_formatter - ) - request_param.make_multipart(content_type=content_type) - - return request_param - - def _render_part(self, name, value): - """ - Overridable helper function to format a single header parameter. By - default, this calls ``self.header_formatter``. - - :param name: - The name of the parameter, a string expected to be ASCII only. - :param value: - The value of the parameter, provided as a unicode string. - """ - - return self.header_formatter(name, value) - - def _render_parts(self, header_parts): - """ - Helper function to format and quote a single header. - - Useful for single headers that are composed of multiple items. E.g., - 'Content-Disposition' fields. - - :param header_parts: - A sequence of (k, v) tuples or a :class:`dict` of (k, v) to format - as `k1="v1"; k2="v2"; ...`. - """ - parts = [] - iterable = header_parts - if isinstance(header_parts, dict): - iterable = header_parts.items() - - for name, value in iterable: - if value is not None: - parts.append(self._render_part(name, value)) - - return u"; ".join(parts) - - def render_headers(self): - """ - Renders the headers for this request field. - """ - lines = [] - - sort_keys = ["Content-Disposition", "Content-Type", "Content-Location"] - for sort_key in sort_keys: - if self.headers.get(sort_key, False): - lines.append(u"%s: %s" % (sort_key, self.headers[sort_key])) - - for header_name, header_value in self.headers.items(): - if header_name not in sort_keys: - if header_value: - lines.append(u"%s: %s" % (header_name, header_value)) - - lines.append(u"\r\n") - return u"\r\n".join(lines) - - def make_multipart( - self, content_disposition=None, content_type=None, content_location=None - ): - """ - Makes this request field into a multipart request field. - - This method overrides "Content-Disposition", "Content-Type" and - "Content-Location" headers to the request parameter. - - :param content_type: - The 'Content-Type' of the request body. - :param content_location: - The 'Content-Location' of the request body. - - """ - self.headers["Content-Disposition"] = content_disposition or u"form-data" - self.headers["Content-Disposition"] += u"; ".join( - [ - u"", - self._render_parts( - ((u"name", self._name), (u"filename", self._filename)) - ), - ] - ) - self.headers["Content-Type"] = content_type - self.headers["Content-Location"] = content_location diff --git a/venv/lib/python3.8/site-packages/urllib3/filepost.py b/venv/lib/python3.8/site-packages/urllib3/filepost.py deleted file mode 100644 index 36c9252..0000000 --- a/venv/lib/python3.8/site-packages/urllib3/filepost.py +++ /dev/null @@ -1,98 +0,0 @@ -from __future__ import absolute_import - -import binascii -import codecs -import os -from io import BytesIO - -from .fields import RequestField -from .packages import six -from .packages.six import b - -writer = codecs.lookup("utf-8")[3] - - -def choose_boundary(): - """ - Our embarrassingly-simple replacement for mimetools.choose_boundary. - """ - boundary = binascii.hexlify(os.urandom(16)) - if not six.PY2: - boundary = boundary.decode("ascii") - return boundary - - -def iter_field_objects(fields): - """ - Iterate over fields. - - Supports list of (k, v) tuples and dicts, and lists of - :class:`~urllib3.fields.RequestField`. - - """ - if isinstance(fields, dict): - i = six.iteritems(fields) - else: - i = iter(fields) - - for field in i: - if isinstance(field, RequestField): - yield field - else: - yield RequestField.from_tuples(*field) - - -def iter_fields(fields): - """ - .. deprecated:: 1.6 - - Iterate over fields. - - The addition of :class:`~urllib3.fields.RequestField` makes this function - obsolete. Instead, use :func:`iter_field_objects`, which returns - :class:`~urllib3.fields.RequestField` objects. - - Supports list of (k, v) tuples and dicts. - """ - if isinstance(fields, dict): - return ((k, v) for k, v in six.iteritems(fields)) - - return ((k, v) for k, v in fields) - - -def encode_multipart_formdata(fields, boundary=None): - """ - Encode a dictionary of ``fields`` using the multipart/form-data MIME format. - - :param fields: - Dictionary of fields or list of (key, :class:`~urllib3.fields.RequestField`). - - :param boundary: - If not specified, then a random boundary will be generated using - :func:`urllib3.filepost.choose_boundary`. - """ - body = BytesIO() - if boundary is None: - boundary = choose_boundary() - - for field in iter_field_objects(fields): - body.write(b("--%s\r\n" % (boundary))) - - writer(body).write(field.render_headers()) - data = field.data - - if isinstance(data, int): - data = str(data) # Backwards compatibility - - if isinstance(data, six.text_type): - writer(body).write(data) - else: - body.write(data) - - body.write(b"\r\n") - - body.write(b("--%s--\r\n" % (boundary))) - - content_type = str("multipart/form-data; boundary=%s" % boundary) - - return body.getvalue(), content_type diff --git a/venv/lib/python3.8/site-packages/urllib3/packages/__init__.py b/venv/lib/python3.8/site-packages/urllib3/packages/__init__.py deleted file mode 100644 index fce4caa..0000000 --- a/venv/lib/python3.8/site-packages/urllib3/packages/__init__.py +++ /dev/null @@ -1,5 +0,0 @@ -from __future__ import absolute_import - -from . import ssl_match_hostname - -__all__ = ("ssl_match_hostname",) diff --git a/venv/lib/python3.8/site-packages/urllib3/packages/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/urllib3/packages/__pycache__/__init__.cpython-38.pyc deleted file mode 100644 index 0a536eb9b400fa760d601bea136ba3d546fc72b1..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 265 zcmYjLyKciU43uOC4T1y(`UPD&cyKgiGLQuQf-XfDFN7Q^u@K4@^g!KD>Mwcilwasn zsa<*i?|3AEmwb*{vo-qxQzAq; diff --git a/venv/lib/python3.8/site-packages/urllib3/packages/__pycache__/six.cpython-38.pyc b/venv/lib/python3.8/site-packages/urllib3/packages/__pycache__/six.cpython-38.pyc deleted file mode 100644 index 312612264fa9be437dc410814b52ca04f770cc0b..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 27547 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 TeQDY%wtzVvq;Wu4(Z_!Qh{kH; diff --git a/venv/lib/python3.8/site-packages/urllib3/packages/backports/makefile.py b/venv/lib/python3.8/site-packages/urllib3/packages/backports/makefile.py deleted file mode 100644 index b8fb215..0000000 --- a/venv/lib/python3.8/site-packages/urllib3/packages/backports/makefile.py +++ /dev/null @@ -1,51 +0,0 @@ -# -*- coding: utf-8 -*- -""" -backports.makefile -~~~~~~~~~~~~~~~~~~ - -Backports the Python 3 ``socket.makefile`` method for use with anything that -wants to create a "fake" socket object. -""" -import io -from socket import SocketIO - - -def backport_makefile( - self, mode="r", buffering=None, encoding=None, errors=None, newline=None -): - """ - Backport of ``socket.makefile`` from Python 3.5. - """ - if not set(mode) <= {"r", "w", "b"}: - raise ValueError("invalid mode %r (only r, w, b allowed)" % (mode,)) - writing = "w" in mode - reading = "r" in mode or not writing - assert reading or writing - binary = "b" in mode - rawmode = "" - if reading: - rawmode += "r" - if writing: - rawmode += "w" - raw = SocketIO(self, rawmode) - self._makefile_refs += 1 - if buffering is None: - buffering = -1 - if buffering < 0: - buffering = io.DEFAULT_BUFFER_SIZE - if buffering == 0: - if not binary: - raise ValueError("unbuffered streams must be binary") - return raw - if reading and writing: - buffer = io.BufferedRWPair(raw, raw, buffering) - elif reading: - buffer = io.BufferedReader(raw, buffering) - else: - assert writing - buffer = io.BufferedWriter(raw, buffering) - if binary: - return buffer - text = io.TextIOWrapper(buffer, encoding, errors, newline) - text.mode = mode - return text diff --git a/venv/lib/python3.8/site-packages/urllib3/packages/six.py b/venv/lib/python3.8/site-packages/urllib3/packages/six.py deleted file mode 100644 index ba50acb..0000000 --- a/venv/lib/python3.8/site-packages/urllib3/packages/six.py +++ /dev/null @@ -1,1077 +0,0 @@ -# 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 -# 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. - -"""Utilities for writing code that runs on Python 2 and 3""" - -from __future__ import absolute_import - -import functools -import itertools -import operator -import sys -import types - -__author__ = "Benjamin Peterson " -__version__ = "1.16.0" - - -# Useful for very coarse version differentiation. -PY2 = sys.version_info[0] == 2 -PY3 = sys.version_info[0] == 3 -PY34 = sys.version_info[0:2] >= (3, 4) - -if PY3: - string_types = (str,) - integer_types = (int,) - class_types = (type,) - text_type = str - binary_type = bytes - - MAXSIZE = sys.maxsize -else: - string_types = (basestring,) - integer_types = (int, long) - class_types = (type, types.ClassType) - text_type = unicode - binary_type = str - - if sys.platform.startswith("java"): - # Jython always uses 32 bits. - MAXSIZE = int((1 << 31) - 1) - else: - # It's possible to have sizeof(long) != sizeof(Py_ssize_t). - class X(object): - def __len__(self): - return 1 << 31 - - try: - len(X()) - except OverflowError: - # 32-bit - MAXSIZE = int((1 << 31) - 1) - else: - # 64-bit - 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.""" - func.__doc__ = doc - - -def _import_module(name): - """Import module, returning the module after the last dot.""" - __import__(name) - return sys.modules[name] - - -class _LazyDescr(object): - def __init__(self, name): - self.name = name - - def __get__(self, obj, tp): - result = self._resolve() - setattr(obj, self.name, result) # Invokes __set__. - try: - # This is a bit ugly, but it avoids running this again by - # removing this descriptor. - delattr(obj.__class__, self.name) - except AttributeError: - pass - return result - - -class MovedModule(_LazyDescr): - def __init__(self, name, old, new=None): - super(MovedModule, self).__init__(name) - if PY3: - if new is None: - new = name - self.mod = new - else: - self.mod = old - - def _resolve(self): - return _import_module(self.mod) - - def __getattr__(self, attr): - _module = self._resolve() - value = getattr(_module, attr) - setattr(self, attr, value) - return value - - -class _LazyModule(types.ModuleType): - def __init__(self, name): - super(_LazyModule, self).__init__(name) - self.__doc__ = self.__class__.__doc__ - - def __dir__(self): - attrs = ["__doc__", "__name__"] - attrs += [attr.name for attr in self._moved_attributes] - return attrs - - # Subclasses should override this - _moved_attributes = [] - - -class MovedAttribute(_LazyDescr): - def __init__(self, name, old_mod, new_mod, old_attr=None, new_attr=None): - super(MovedAttribute, self).__init__(name) - if PY3: - if new_mod is None: - new_mod = name - self.mod = new_mod - if new_attr is None: - if old_attr is None: - new_attr = name - else: - new_attr = old_attr - self.attr = new_attr - else: - self.mod = old_mod - if old_attr is None: - old_attr = name - self.attr = old_attr - - def _resolve(self): - module = _import_module(self.mod) - return getattr(module, self.attr) - - -class _SixMetaPathImporter(object): - - """ - A meta path importer to import six.moves and its submodules. - - This class implements a PEP302 finder and loader. It should be compatible - with Python 2.5 and all existing versions of Python3 - """ - - def __init__(self, six_module_name): - self.name = six_module_name - self.known_modules = {} - - def _add_module(self, mod, *fullnames): - for fullname in fullnames: - self.known_modules[self.name + "." + fullname] = mod - - def _get_module(self, fullname): - return self.known_modules[self.name + "." + fullname] - - def find_module(self, fullname, path=None): - if fullname in self.known_modules: - 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] - except KeyError: - raise ImportError("This loader does not know module " + fullname) - - def load_module(self, fullname): - try: - # in case of a reload - return sys.modules[fullname] - except KeyError: - pass - mod = self.__get_module(fullname) - if isinstance(mod, MovedModule): - mod = mod._resolve() - else: - mod.__loader__ = self - sys.modules[fullname] = mod - return mod - - def is_package(self, fullname): - """ - Return true, if the named module is a package. - - We need this method to get correct spec objects with - Python 3.4 (see PEP451) - """ - return hasattr(self.__get_module(fullname), "__path__") - - def get_code(self, fullname): - """Return None - - Required, if is_package is implemented""" - self.__get_module(fullname) # eventually raises ImportError - 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__) - - -class _MovedItems(_LazyModule): - - """Lazy loading of moved objects""" - - __path__ = [] # mark as package - - -_moved_attributes = [ - MovedAttribute("cStringIO", "cStringIO", "io", "StringIO"), - MovedAttribute("filter", "itertools", "builtins", "ifilter", "filter"), - MovedAttribute( - "filterfalse", "itertools", "itertools", "ifilterfalse", "filterfalse" - ), - MovedAttribute("input", "__builtin__", "builtins", "raw_input", "input"), - MovedAttribute("intern", "__builtin__", "sys"), - MovedAttribute("map", "itertools", "builtins", "imap", "map"), - MovedAttribute("getcwd", "os", "os", "getcwdu", "getcwd"), - MovedAttribute("getcwdb", "os", "os", "getcwd", "getcwdb"), - MovedAttribute("getoutput", "commands", "subprocess"), - MovedAttribute("range", "__builtin__", "builtins", "xrange", "range"), - MovedAttribute( - "reload_module", "__builtin__", "importlib" if PY34 else "imp", "reload" - ), - MovedAttribute("reduce", "__builtin__", "functools"), - MovedAttribute("shlex_quote", "pipes", "shlex", "quote"), - MovedAttribute("StringIO", "StringIO", "io"), - MovedAttribute("UserDict", "UserDict", "collections"), - MovedAttribute("UserList", "UserList", "collections"), - MovedAttribute("UserString", "UserString", "collections"), - MovedAttribute("xrange", "__builtin__", "builtins", "xrange", "range"), - MovedAttribute("zip", "itertools", "builtins", "izip", "zip"), - MovedAttribute( - "zip_longest", "itertools", "itertools", "izip_longest", "zip_longest" - ), - 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("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"), - MovedModule("html_parser", "HTMLParser", "html.parser"), - MovedModule("http_client", "httplib", "http.client"), - MovedModule("email_mime_base", "email.MIMEBase", "email.mime.base"), - MovedModule("email_mime_image", "email.MIMEImage", "email.mime.image"), - MovedModule("email_mime_multipart", "email.MIMEMultipart", "email.mime.multipart"), - MovedModule( - "email_mime_nonmultipart", "email.MIMENonMultipart", "email.mime.nonmultipart" - ), - MovedModule("email_mime_text", "email.MIMEText", "email.mime.text"), - MovedModule("BaseHTTPServer", "BaseHTTPServer", "http.server"), - MovedModule("CGIHTTPServer", "CGIHTTPServer", "http.server"), - MovedModule("SimpleHTTPServer", "SimpleHTTPServer", "http.server"), - MovedModule("cPickle", "cPickle", "pickle"), - MovedModule("queue", "Queue"), - MovedModule("reprlib", "repr"), - MovedModule("socketserver", "SocketServer"), - MovedModule("_thread", "thread", "_thread"), - MovedModule("tkinter", "Tkinter"), - MovedModule("tkinter_dialog", "Dialog", "tkinter.dialog"), - MovedModule("tkinter_filedialog", "FileDialog", "tkinter.filedialog"), - MovedModule("tkinter_scrolledtext", "ScrolledText", "tkinter.scrolledtext"), - MovedModule("tkinter_simpledialog", "SimpleDialog", "tkinter.simpledialog"), - MovedModule("tkinter_tix", "Tix", "tkinter.tix"), - MovedModule("tkinter_ttk", "ttk", "tkinter.ttk"), - MovedModule("tkinter_constants", "Tkconstants", "tkinter.constants"), - MovedModule("tkinter_dnd", "Tkdnd", "tkinter.dnd"), - MovedModule("tkinter_colorchooser", "tkColorChooser", "tkinter.colorchooser"), - MovedModule("tkinter_commondialog", "tkCommonDialog", "tkinter.commondialog"), - MovedModule("tkinter_tkfiledialog", "tkFileDialog", "tkinter.filedialog"), - MovedModule("tkinter_font", "tkFont", "tkinter.font"), - MovedModule("tkinter_messagebox", "tkMessageBox", "tkinter.messagebox"), - MovedModule("tkinter_tksimpledialog", "tkSimpleDialog", "tkinter.simpledialog"), - MovedModule("urllib_parse", __name__ + ".moves.urllib_parse", "urllib.parse"), - MovedModule("urllib_error", __name__ + ".moves.urllib_error", "urllib.error"), - MovedModule("urllib", __name__ + ".moves.urllib", __name__ + ".moves.urllib"), - MovedModule("urllib_robotparser", "robotparser", "urllib.robotparser"), - MovedModule("xmlrpc_client", "xmlrpclib", "xmlrpc.client"), - MovedModule("xmlrpc_server", "SimpleXMLRPCServer", "xmlrpc.server"), -] -# Add windows specific modules. -if sys.platform == "win32": - _moved_attributes += [ - MovedModule("winreg", "_winreg"), - ] - -for attr in _moved_attributes: - setattr(_MovedItems, attr.name, attr) - if isinstance(attr, MovedModule): - _importer._add_module(attr, "moves." + attr.name) -del attr - -_MovedItems._moved_attributes = _moved_attributes - -moves = _MovedItems(__name__ + ".moves") -_importer._add_module(moves, "moves") - - -class Module_six_moves_urllib_parse(_LazyModule): - - """Lazy loading of moved objects in six.moves.urllib_parse""" - - -_urllib_parse_moved_attributes = [ - MovedAttribute("ParseResult", "urlparse", "urllib.parse"), - MovedAttribute("SplitResult", "urlparse", "urllib.parse"), - MovedAttribute("parse_qs", "urlparse", "urllib.parse"), - MovedAttribute("parse_qsl", "urlparse", "urllib.parse"), - MovedAttribute("urldefrag", "urlparse", "urllib.parse"), - MovedAttribute("urljoin", "urlparse", "urllib.parse"), - MovedAttribute("urlparse", "urlparse", "urllib.parse"), - MovedAttribute("urlsplit", "urlparse", "urllib.parse"), - MovedAttribute("urlunparse", "urlparse", "urllib.parse"), - MovedAttribute("urlunsplit", "urlparse", "urllib.parse"), - MovedAttribute("quote", "urllib", "urllib.parse"), - MovedAttribute("quote_plus", "urllib", "urllib.parse"), - MovedAttribute("unquote", "urllib", "urllib.parse"), - MovedAttribute("unquote_plus", "urllib", "urllib.parse"), - MovedAttribute( - "unquote_to_bytes", "urllib", "urllib.parse", "unquote", "unquote_to_bytes" - ), - MovedAttribute("urlencode", "urllib", "urllib.parse"), - MovedAttribute("splitquery", "urllib", "urllib.parse"), - MovedAttribute("splittag", "urllib", "urllib.parse"), - MovedAttribute("splituser", "urllib", "urllib.parse"), - MovedAttribute("splitvalue", "urllib", "urllib.parse"), - MovedAttribute("uses_fragment", "urlparse", "urllib.parse"), - MovedAttribute("uses_netloc", "urlparse", "urllib.parse"), - MovedAttribute("uses_params", "urlparse", "urllib.parse"), - MovedAttribute("uses_query", "urlparse", "urllib.parse"), - MovedAttribute("uses_relative", "urlparse", "urllib.parse"), -] -for attr in _urllib_parse_moved_attributes: - setattr(Module_six_moves_urllib_parse, attr.name, attr) -del attr - -Module_six_moves_urllib_parse._moved_attributes = _urllib_parse_moved_attributes - -_importer._add_module( - Module_six_moves_urllib_parse(__name__ + ".moves.urllib_parse"), - "moves.urllib_parse", - "moves.urllib.parse", -) - - -class Module_six_moves_urllib_error(_LazyModule): - - """Lazy loading of moved objects in six.moves.urllib_error""" - - -_urllib_error_moved_attributes = [ - MovedAttribute("URLError", "urllib2", "urllib.error"), - MovedAttribute("HTTPError", "urllib2", "urllib.error"), - MovedAttribute("ContentTooShortError", "urllib", "urllib.error"), -] -for attr in _urllib_error_moved_attributes: - setattr(Module_six_moves_urllib_error, attr.name, attr) -del attr - -Module_six_moves_urllib_error._moved_attributes = _urllib_error_moved_attributes - -_importer._add_module( - Module_six_moves_urllib_error(__name__ + ".moves.urllib.error"), - "moves.urllib_error", - "moves.urllib.error", -) - - -class Module_six_moves_urllib_request(_LazyModule): - - """Lazy loading of moved objects in six.moves.urllib_request""" - - -_urllib_request_moved_attributes = [ - MovedAttribute("urlopen", "urllib2", "urllib.request"), - MovedAttribute("install_opener", "urllib2", "urllib.request"), - MovedAttribute("build_opener", "urllib2", "urllib.request"), - MovedAttribute("pathname2url", "urllib", "urllib.request"), - MovedAttribute("url2pathname", "urllib", "urllib.request"), - MovedAttribute("getproxies", "urllib", "urllib.request"), - MovedAttribute("Request", "urllib2", "urllib.request"), - MovedAttribute("OpenerDirector", "urllib2", "urllib.request"), - MovedAttribute("HTTPDefaultErrorHandler", "urllib2", "urllib.request"), - MovedAttribute("HTTPRedirectHandler", "urllib2", "urllib.request"), - MovedAttribute("HTTPCookieProcessor", "urllib2", "urllib.request"), - MovedAttribute("ProxyHandler", "urllib2", "urllib.request"), - MovedAttribute("BaseHandler", "urllib2", "urllib.request"), - MovedAttribute("HTTPPasswordMgr", "urllib2", "urllib.request"), - MovedAttribute("HTTPPasswordMgrWithDefaultRealm", "urllib2", "urllib.request"), - MovedAttribute("AbstractBasicAuthHandler", "urllib2", "urllib.request"), - MovedAttribute("HTTPBasicAuthHandler", "urllib2", "urllib.request"), - MovedAttribute("ProxyBasicAuthHandler", "urllib2", "urllib.request"), - MovedAttribute("AbstractDigestAuthHandler", "urllib2", "urllib.request"), - MovedAttribute("HTTPDigestAuthHandler", "urllib2", "urllib.request"), - MovedAttribute("ProxyDigestAuthHandler", "urllib2", "urllib.request"), - MovedAttribute("HTTPHandler", "urllib2", "urllib.request"), - MovedAttribute("HTTPSHandler", "urllib2", "urllib.request"), - MovedAttribute("FileHandler", "urllib2", "urllib.request"), - MovedAttribute("FTPHandler", "urllib2", "urllib.request"), - MovedAttribute("CacheFTPHandler", "urllib2", "urllib.request"), - MovedAttribute("UnknownHandler", "urllib2", "urllib.request"), - MovedAttribute("HTTPErrorProcessor", "urllib2", "urllib.request"), - MovedAttribute("urlretrieve", "urllib", "urllib.request"), - MovedAttribute("urlcleanup", "urllib", "urllib.request"), - MovedAttribute("URLopener", "urllib", "urllib.request"), - MovedAttribute("FancyURLopener", "urllib", "urllib.request"), - MovedAttribute("proxy_bypass", "urllib", "urllib.request"), - MovedAttribute("parse_http_list", "urllib2", "urllib.request"), - MovedAttribute("parse_keqv_list", "urllib2", "urllib.request"), -] -for attr in _urllib_request_moved_attributes: - setattr(Module_six_moves_urllib_request, attr.name, attr) -del attr - -Module_six_moves_urllib_request._moved_attributes = _urllib_request_moved_attributes - -_importer._add_module( - Module_six_moves_urllib_request(__name__ + ".moves.urllib.request"), - "moves.urllib_request", - "moves.urllib.request", -) - - -class Module_six_moves_urllib_response(_LazyModule): - - """Lazy loading of moved objects in six.moves.urllib_response""" - - -_urllib_response_moved_attributes = [ - MovedAttribute("addbase", "urllib", "urllib.response"), - MovedAttribute("addclosehook", "urllib", "urllib.response"), - MovedAttribute("addinfo", "urllib", "urllib.response"), - MovedAttribute("addinfourl", "urllib", "urllib.response"), -] -for attr in _urllib_response_moved_attributes: - setattr(Module_six_moves_urllib_response, attr.name, attr) -del attr - -Module_six_moves_urllib_response._moved_attributes = _urllib_response_moved_attributes - -_importer._add_module( - Module_six_moves_urllib_response(__name__ + ".moves.urllib.response"), - "moves.urllib_response", - "moves.urllib.response", -) - - -class Module_six_moves_urllib_robotparser(_LazyModule): - - """Lazy loading of moved objects in six.moves.urllib_robotparser""" - - -_urllib_robotparser_moved_attributes = [ - MovedAttribute("RobotFileParser", "robotparser", "urllib.robotparser"), -] -for attr in _urllib_robotparser_moved_attributes: - setattr(Module_six_moves_urllib_robotparser, attr.name, attr) -del attr - -Module_six_moves_urllib_robotparser._moved_attributes = ( - _urllib_robotparser_moved_attributes -) - -_importer._add_module( - Module_six_moves_urllib_robotparser(__name__ + ".moves.urllib.robotparser"), - "moves.urllib_robotparser", - "moves.urllib.robotparser", -) - - -class Module_six_moves_urllib(types.ModuleType): - - """Create a six.moves.urllib namespace that resembles the Python 3 namespace""" - - __path__ = [] # mark as package - parse = _importer._get_module("moves.urllib_parse") - error = _importer._get_module("moves.urllib_error") - request = _importer._get_module("moves.urllib_request") - response = _importer._get_module("moves.urllib_response") - robotparser = _importer._get_module("moves.urllib_robotparser") - - def __dir__(self): - return ["parse", "error", "request", "response", "robotparser"] - - -_importer._add_module( - Module_six_moves_urllib(__name__ + ".moves.urllib"), "moves.urllib" -) - - -def add_move(move): - """Add an item to six.moves.""" - setattr(_MovedItems, move.name, move) - - -def remove_move(name): - """Remove item from six.moves.""" - try: - delattr(_MovedItems, name) - except AttributeError: - try: - del moves.__dict__[name] - except KeyError: - raise AttributeError("no such move, %r" % (name,)) - - -if PY3: - _meth_func = "__func__" - _meth_self = "__self__" - - _func_closure = "__closure__" - _func_code = "__code__" - _func_defaults = "__defaults__" - _func_globals = "__globals__" -else: - _meth_func = "im_func" - _meth_self = "im_self" - - _func_closure = "func_closure" - _func_code = "func_code" - _func_defaults = "func_defaults" - _func_globals = "func_globals" - - -try: - advance_iterator = next -except NameError: - - def advance_iterator(it): - return it.next() - - -next = advance_iterator - - -try: - callable = callable -except NameError: - - def callable(obj): - return any("__call__" in klass.__dict__ for klass in type(obj).__mro__) - - -if PY3: - - def get_unbound_function(unbound): - return unbound - - create_bound_method = types.MethodType - - def create_unbound_method(func, cls): - return func - - Iterator = object -else: - - def get_unbound_function(unbound): - return unbound.im_func - - def create_bound_method(func, obj): - return types.MethodType(func, obj, obj.__class__) - - def create_unbound_method(func, cls): - return types.MethodType(func, None, cls) - - class Iterator(object): - def next(self): - return type(self).__next__(self) - - callable = callable -_add_doc( - get_unbound_function, """Get the function out of a possibly unbound function""" -) - - -get_method_function = operator.attrgetter(_meth_func) -get_method_self = operator.attrgetter(_meth_self) -get_function_closure = operator.attrgetter(_func_closure) -get_function_code = operator.attrgetter(_func_code) -get_function_defaults = operator.attrgetter(_func_defaults) -get_function_globals = operator.attrgetter(_func_globals) - - -if PY3: - - def iterkeys(d, **kw): - return iter(d.keys(**kw)) - - def itervalues(d, **kw): - return iter(d.values(**kw)) - - def iteritems(d, **kw): - return iter(d.items(**kw)) - - def iterlists(d, **kw): - return iter(d.lists(**kw)) - - viewkeys = operator.methodcaller("keys") - - viewvalues = operator.methodcaller("values") - - viewitems = operator.methodcaller("items") -else: - - def iterkeys(d, **kw): - return d.iterkeys(**kw) - - def itervalues(d, **kw): - return d.itervalues(**kw) - - def iteritems(d, **kw): - return d.iteritems(**kw) - - def iterlists(d, **kw): - return d.iterlists(**kw) - - viewkeys = operator.methodcaller("viewkeys") - - viewvalues = operator.methodcaller("viewvalues") - - viewitems = operator.methodcaller("viewitems") - -_add_doc(iterkeys, "Return an iterator over the keys of a dictionary.") -_add_doc(itervalues, "Return an iterator over the values of a dictionary.") -_add_doc(iteritems, "Return an iterator over the (key, value) pairs of a dictionary.") -_add_doc( - iterlists, "Return an iterator over the (key, [values]) pairs of a dictionary." -) - - -if PY3: - - def b(s): - return s.encode("latin-1") - - def u(s): - return s - - unichr = chr - import struct - - int2byte = struct.Struct(">B").pack - del struct - byte2int = operator.itemgetter(0) - indexbytes = operator.getitem - iterbytes = iter - import io - - StringIO = io.StringIO - BytesIO = io.BytesIO - del io - _assertCountEqual = "assertCountEqual" - if sys.version_info[1] <= 1: - _assertRaisesRegex = "assertRaisesRegexp" - _assertRegex = "assertRegexpMatches" - _assertNotRegex = "assertNotRegexpMatches" - else: - _assertRaisesRegex = "assertRaisesRegex" - _assertRegex = "assertRegex" - _assertNotRegex = "assertNotRegex" -else: - - def b(s): - return s - - # Workaround for standalone backslash - - def u(s): - return unicode(s.replace(r"\\", r"\\\\"), "unicode_escape") - - unichr = unichr - int2byte = chr - - def byte2int(bs): - return ord(bs[0]) - - def indexbytes(buf, i): - return ord(buf[i]) - - iterbytes = functools.partial(itertools.imap, ord) - import StringIO - - StringIO = BytesIO = StringIO.StringIO - _assertCountEqual = "assertItemsEqual" - _assertRaisesRegex = "assertRaisesRegexp" - _assertRegex = "assertRegexpMatches" - _assertNotRegex = "assertNotRegexpMatches" -_add_doc(b, """Byte literal""") -_add_doc(u, """Text literal""") - - -def assertCountEqual(self, *args, **kwargs): - return getattr(self, _assertCountEqual)(*args, **kwargs) - - -def assertRaisesRegex(self, *args, **kwargs): - return getattr(self, _assertRaisesRegex)(*args, **kwargs) - - -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") - - def reraise(tp, value, tb=None): - try: - if value is None: - value = tp() - if value.__traceback__ is not tb: - raise value.with_traceback(tb) - raise value - finally: - value = None - tb = None - - -else: - - def exec_(_code_, _globs_=None, _locs_=None): - """Execute code in a namespace.""" - if _globs_ is None: - frame = sys._getframe(1) - _globs_ = frame.f_globals - if _locs_ is None: - _locs_ = frame.f_locals - del frame - elif _locs_ is None: - _locs_ = _globs_ - exec ("""exec _code_ in _globs_, _locs_""") - - exec_( - """def reraise(tp, value, tb=None): - try: - raise tp, value, tb - finally: - tb = None -""" - ) - - -if sys.version_info[:2] > (3,): - exec_( - """def raise_from(value, from_value): - try: - raise value from from_value - finally: - value = None -""" - ) -else: - - def raise_from(value, from_value): - raise value - - -print_ = getattr(moves.builtins, "print", None) -if print_ is None: - - def print_(*args, **kwargs): - """The new-style print function for Python 2.4 and 2.5.""" - fp = kwargs.pop("file", sys.stdout) - if fp is None: - return - - def write(data): - if not isinstance(data, basestring): - data = str(data) - # If the file has an encoding, encode unicode with it. - if ( - isinstance(fp, file) - and isinstance(data, unicode) - and fp.encoding is not None - ): - errors = getattr(fp, "errors", None) - if errors is None: - errors = "strict" - data = data.encode(fp.encoding, errors) - fp.write(data) - - want_unicode = False - sep = kwargs.pop("sep", None) - if sep is not None: - if isinstance(sep, unicode): - want_unicode = True - elif not isinstance(sep, str): - raise TypeError("sep must be None or a string") - end = kwargs.pop("end", None) - if end is not None: - if isinstance(end, unicode): - want_unicode = True - elif not isinstance(end, str): - raise TypeError("end must be None or a string") - if kwargs: - raise TypeError("invalid keyword arguments to print()") - if not want_unicode: - for arg in args: - if isinstance(arg, unicode): - want_unicode = True - break - if want_unicode: - newline = unicode("\n") - space = unicode(" ") - else: - newline = "\n" - space = " " - if sep is None: - sep = space - if end is None: - end = newline - for i, arg in enumerate(args): - if i: - write(sep) - write(arg) - write(end) - - -if sys.version_info[:2] < (3, 3): - _print = print_ - - def print_(*args, **kwargs): - fp = kwargs.get("file", sys.stdout) - flush = kwargs.pop("flush", False) - _print(*args, **kwargs) - if flush and fp is not None: - fp.flush() - - -_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, - ): - return functools.partial( - _update_wrapper, wrapped=wrapped, assigned=assigned, updated=updated - ) - - wraps.__doc__ = functools.wraps.__doc__ - -else: - wraps = functools.wraps - - -def with_metaclass(meta, *bases): - """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(type): - def __new__(cls, name, this_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): - return meta.__prepare__(name, bases) - - return type.__new__(metaclass, "temporary_class", (), {}) - - -def add_metaclass(metaclass): - """Class decorator for creating a class with a metaclass.""" - - def wrapper(cls): - orig_vars = cls.__dict__.copy() - slots = orig_vars.get("__slots__") - if slots is not None: - if isinstance(slots, str): - slots = [slots] - for slots_var in slots: - orig_vars.pop(slots_var) - orig_vars.pop("__dict__", None) - orig_vars.pop("__weakref__", None) - if hasattr(cls, "__qualname__"): - orig_vars["__qualname__"] = cls.__qualname__ - return metaclass(cls.__name__, cls.__bases__, orig_vars) - - return wrapper - - -def ensure_binary(s, encoding="utf-8", errors="strict"): - """Coerce **s** to six.binary_type. - - For Python 2: - - `unicode` -> encoded to `str` - - `str` -> `str` - - For Python 3: - - `str` -> encoded to `bytes` - - `bytes` -> `bytes` - """ - if isinstance(s, binary_type): - return s - if isinstance(s, text_type): - return s.encode(encoding, errors) - raise TypeError("not expecting type '%s'" % type(s)) - - -def ensure_str(s, encoding="utf-8", errors="strict"): - """Coerce *s* to `str`. - - For Python 2: - - `unicode` -> encoded to `str` - - `str` -> `str` - - For Python 3: - - `str` -> `str` - - `bytes` -> decoded to `str` - """ - # Optimization: Fast return for the common case. - if type(s) is str: - return s - if PY2 and isinstance(s, text_type): - return s.encode(encoding, errors) - elif PY3 and isinstance(s, binary_type): - return s.decode(encoding, errors) - elif not isinstance(s, (text_type, binary_type)): - raise TypeError("not expecting type '%s'" % type(s)) - return s - - -def ensure_text(s, encoding="utf-8", errors="strict"): - """Coerce *s* to six.text_type. - - For Python 2: - - `unicode` -> `unicode` - - `str` -> `unicode` - - For Python 3: - - `str` -> `str` - - `bytes` -> decoded to `str` - """ - if isinstance(s, binary_type): - return s.decode(encoding, errors) - elif isinstance(s, text_type): - return s - else: - raise TypeError("not expecting type '%s'" % type(s)) - - -def python_2_unicode_compatible(klass): - """ - 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 - returning text and apply this decorator to the class. - """ - if PY2: - if "__str__" not in klass.__dict__: - raise ValueError( - "@python_2_unicode_compatible cannot be applied " - "to %s because it doesn't define __str__()." % klass.__name__ - ) - klass.__unicode__ = klass.__str__ - klass.__str__ = lambda self: self.__unicode__().encode("utf-8") - return klass - - -# Complete the moves implementation. -# This code is at the end of this module to speed up module loading. -# Turn this module into a package. -__path__ = [] # required for PEP 302 and PEP 451 -__package__ = __name__ # see PEP 366 @ReservedAssignment -if globals().get("__spec__") is not None: - __spec__.submodule_search_locations = [] # PEP 451 @UndefinedVariable -# Remove other six meta path importers, since they cause problems. This can -# happen if six is removed from sys.modules and then reloaded. (Setuptools does -# this for some reason.) -if sys.meta_path: - for i, importer in enumerate(sys.meta_path): - # Here's some real nastiness: Another "instance" of the six module might - # be floating around. Therefore, we can't use isinstance() to check for - # the six meta path importer, since the other six instance will have - # inserted an importer with different class. - if ( - type(importer).__name__ == "_SixMetaPathImporter" - and importer.name == __name__ - ): - del sys.meta_path[i] - break - del i, importer -# Finally, add the importer to the meta path import hook. -sys.meta_path.append(_importer) diff --git a/venv/lib/python3.8/site-packages/urllib3/packages/ssl_match_hostname/__init__.py b/venv/lib/python3.8/site-packages/urllib3/packages/ssl_match_hostname/__init__.py deleted file mode 100644 index ef3fde5..0000000 --- a/venv/lib/python3.8/site-packages/urllib3/packages/ssl_match_hostname/__init__.py +++ /dev/null @@ -1,24 +0,0 @@ -import sys - -try: - # Our match_hostname function is the same as 3.10's, so we only want to - # import the match_hostname function if it's at least that good. - # We also fallback on Python 3.10+ because our code doesn't emit - # deprecation warnings and is the same as Python 3.10 otherwise. - if sys.version_info < (3, 5) or sys.version_info >= (3, 10): - 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/venv/lib/python3.8/site-packages/urllib3/packages/ssl_match_hostname/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/urllib3/packages/ssl_match_hostname/__pycache__/__init__.cpython-38.pyc deleted file mode 100644 index 3cb3ca3d647fb28a753892c00a1026abe9704067..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 528 zcmZWk!D<^Z5FKfEZP#v`9QG10!G|{BgS~;A3?URk3%Qs=2u=4Q*48-QuC!VtIdyz0 zE%e+!=()eN*PiwldWsYmn$Qt?%rI}>yt&@n>w=5T^mX<#0Ql{Tr_po88~4o*2OKyN zkizx^;S=Gs0CV)11x2Kfk@D~x`AQrs5`hfUP)2D)-~*Ji5RevK{hfe++xU^wdd7M6 zm-A)E;Vq}q{>S(TCB1uQFn#jS3YU*=;*7opSCd52j6ho_q zcUW?zkq;M&S=w#-vXujl(`21P}F4i=O}h diff --git a/venv/lib/python3.8/site-packages/urllib3/packages/ssl_match_hostname/__pycache__/_implementation.cpython-38.pyc b/venv/lib/python3.8/site-packages/urllib3/packages/ssl_match_hostname/__pycache__/_implementation.cpython-38.pyc deleted file mode 100644 index b4e5b83f5e3209ea9eb2c28188fe6138ed1cce52..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3263 zcmZ`*&u`qg6&5LJMjnqRu90SwVh=>xY%{JslOIi*1npvt#95?B?KDoZt(#p{7C9cp z8c88J8+#xF#U=&z&;onz$vzg?^P+#sg4dpM?V*PrHvK4hyiU+cAVobsl8=w?eIFms z&9xjnyEiXH{WFg9Py2K73Gnj~iqfdKv*~ccX-YOp^`)D1(ym(Wru&JLo%I~y?X=_# z;@FqdP51XsMt|pUchmpa;U4#2IoubGm+oehpW;m(yds+cpW&@n&gKlCCR7n{b(rIDAMsT9Og=A(MVkEvcWiub&_XnAoCG>u&0M;U+v*tVnQjA=_E?o zi=oKaSS8su+t|3@dyQQ$)ZgLu*eMnpPN&az0LNyB&tl$5C4M{N0fa%vM$Z`J}H$MZZXj<#AR- z@s8ljFj1t-yIVVY_vX!_KbC2lY+dc!-e_B>zEWxU_U`*(GAdFr!X6{*f?lyFDVF%5 zwcIuWQvJWS+lgIN)5jjRHRd*o`WLEgXWuQcUAxE9Ilz$}l6|lAxO>jo_wmJ%{h6ZO zDE$M%8|ZD8&64hT^1i0LsWJK`c@O0aQa05eF^6~Pl*HCMIKI;7jU6g==^pqzI3&c$ zKEzB7K66Oam(Z(P@^7|ZHxGi+KO~jb*^`n31PGr!gl)tr8+V*fPwxlE{g~CtpMQh# zE#BsH2eYMn2%C84Jx4d6wGZk3OgVEfS3(abd1^BJjSVIn6Hy%JlG~Qf*~7cH+4aj; zt}QVo>d?C0`+4tbtHtmPwJvV;`#R54)k}mP^m4h~AL>!smxI_2`|;7J<$9DIbk~rc zw1*&V9<3R&I9b9B2E% zL#Q|^glR%Kjbb$7d{iWSv6Y{F5d6Y@+|*;B204l=cb z%JDsd*K3i0v?*$zlGYm!(s@5{+vK#r;GT5@vOwP_@;vlo>-_0s+dfJa{2!p95%QY6 zr1HF`&syp?tm=K68&Tag_mlhIK z*Eg*Ma05?gaHtDSRC~&_KNnIVSHmP5191u-yULLrI4lTVS48cuE8=L2@{ z0gE`77Bp3_j`nFPFtLl!iW8mgF`f&R{Zun921zDZl(8t?&Lx6r#0I%!dYGsxRW44` z=W_2Cy(?^)onIeoyU<3Q7vg-kS7~)UGm{iY3&Uwec+{?TXd2Qwxd6mAlEQ|9Y1*I* zlfuxXc-LX`kRJ`NvGOtepsZJ%V1dYM_`c;cn~t_rKKly-!(yNYxmg^WENF5-fo%A* z-UG2c@ZePt+x022?NbojEl4fh-G58^6G(kXvs$V_m^*2?*T)@nTi1c*CMOzP;m>1FZbrbj7cbMKzJXwd!}z|E*i4`;zdP9S=HB z^(=3dgwGzd^_=dY2S`1jXDU|6mX38PbpHh1c1cQ?&z*CQbpl8`*7p_VpNhITk|#nY zgFS>*q}igy$3=D#NXdmw9BxAn;J_lqq|jrTLA143MHYyDBL}tW-nP(%5Yi65*zMLq zFBGN}Y;g)1oF%496Nf5eXkrY@jwP?zh*cPJsWX@FGSq@v`SQNUp z?c@S=PQ815U|dN`TI_0&k{&XFN=SBl_2Hv%{lTMq>uW3b ztzsp3xcb}2_a3g^Su-6q-g*Y6TuJpB612)mwUd1qC@RF!FcOktm{-R zI=%`=m_j{4jH(m3&Lxbvh9!n8ddyckaw-q1G< zuS3pIJDa?VnY*OAz;xTD8HPNM!%+SJV!3E5>nbyQZ&c(`*Z!Fe!ztT^@|M-Hd{ukM vy0h|7HSvkPS&FOKKlo*Rk^ayUwmOT-^8*qzD9r4T7WLeDuXR0W1nvI 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/venv/lib/python3.8/site-packages/urllib3/poolmanager.py b/venv/lib/python3.8/site-packages/urllib3/poolmanager.py deleted file mode 100644 index 3a31a28..0000000 --- a/venv/lib/python3.8/site-packages/urllib3/poolmanager.py +++ /dev/null @@ -1,536 +0,0 @@ -from __future__ import absolute_import - -import collections -import functools -import logging - -from ._collections import RecentlyUsedContainer -from .connectionpool import HTTPConnectionPool, HTTPSConnectionPool, port_by_scheme -from .exceptions import ( - LocationValueError, - MaxRetryError, - ProxySchemeUnknown, - ProxySchemeUnsupported, - URLSchemeUnknown, -) -from .packages import six -from .packages.six.moves.urllib.parse import urljoin -from .request import RequestMethods -from .util.proxy import connection_requires_http_tunnel -from .util.retry import Retry -from .util.url import parse_url - -__all__ = ["PoolManager", "ProxyManager", "proxy_from_url"] - - -log = logging.getLogger(__name__) - -SSL_KEYWORDS = ( - "key_file", - "cert_file", - "cert_reqs", - "ca_certs", - "ssl_version", - "ca_cert_dir", - "ssl_context", - "key_password", -) - -# All known keyword arguments that could be provided to the pool manager, its -# pools, or the underlying connections. This is used to construct a pool key. -_key_fields = ( - "key_scheme", # str - "key_host", # str - "key_port", # int - "key_timeout", # int or float or Timeout - "key_retries", # int or Retry - "key_strict", # bool - "key_block", # bool - "key_source_address", # str - "key_key_file", # str - "key_key_password", # str - "key_cert_file", # str - "key_cert_reqs", # str - "key_ca_certs", # str - "key_ssl_version", # str - "key_ca_cert_dir", # str - "key_ssl_context", # instance of ssl.SSLContext or urllib3.util.ssl_.SSLContext - "key_maxsize", # int - "key_headers", # dict - "key__proxy", # parsed proxy url - "key__proxy_headers", # dict - "key__proxy_config", # class - "key_socket_options", # list of (level (int), optname (int), value (int or str)) tuples - "key__socks_options", # dict - "key_assert_hostname", # bool or string - "key_assert_fingerprint", # str - "key_server_hostname", # str -) - -#: The namedtuple class used to construct keys for the connection pool. -#: All custom key schemes should include the fields in this key at a minimum. -PoolKey = collections.namedtuple("PoolKey", _key_fields) - -_proxy_config_fields = ("ssl_context", "use_forwarding_for_https") -ProxyConfig = collections.namedtuple("ProxyConfig", _proxy_config_fields) - - -def _default_key_normalizer(key_class, request_context): - """ - Create a pool key out of a request context dictionary. - - According to RFC 3986, both the scheme and host are case-insensitive. - Therefore, this function normalizes both before constructing the pool - key for an HTTPS request. If you wish to change this behaviour, provide - alternate callables to ``key_fn_by_scheme``. - - :param key_class: - The class to use when constructing the key. This should be a namedtuple - with the ``scheme`` and ``host`` keys at a minimum. - :type key_class: namedtuple - :param request_context: - A dictionary-like object that contain the context for a request. - :type request_context: dict - - :return: A namedtuple that can be used as a connection pool key. - :rtype: PoolKey - """ - # Since we mutate the dictionary, make a copy first - context = request_context.copy() - context["scheme"] = context["scheme"].lower() - context["host"] = context["host"].lower() - - # These are both dictionaries and need to be transformed into frozensets - for key in ("headers", "_proxy_headers", "_socks_options"): - if key in context and context[key] is not None: - context[key] = frozenset(context[key].items()) - - # The socket_options key may be a list and needs to be transformed into a - # tuple. - socket_opts = context.get("socket_options") - if socket_opts is not None: - context["socket_options"] = tuple(socket_opts) - - # Map the kwargs to the names in the namedtuple - this is necessary since - # namedtuples can't have fields starting with '_'. - for key in list(context.keys()): - context["key_" + key] = context.pop(key) - - # Default to ``None`` for keys missing from the context - for field in key_class._fields: - if field not in context: - context[field] = None - - return key_class(**context) - - -#: A dictionary that maps a scheme to a callable that creates a pool key. -#: This can be used to alter the way pool keys are constructed, if desired. -#: Each PoolManager makes a copy of this dictionary so they can be configured -#: globally here, or individually on the instance. -key_fn_by_scheme = { - "http": functools.partial(_default_key_normalizer, PoolKey), - "https": functools.partial(_default_key_normalizer, PoolKey), -} - -pool_classes_by_scheme = {"http": HTTPConnectionPool, "https": HTTPSConnectionPool} - - -class PoolManager(RequestMethods): - """ - Allows for arbitrary requests while transparently keeping track of - necessary connection pools for you. - - :param num_pools: - Number of connection pools to cache before discarding the least - recently used pool. - - :param headers: - Headers to include with all requests, unless other headers are given - explicitly. - - :param \\**connection_pool_kw: - Additional parameters are used to create fresh - :class:`urllib3.connectionpool.ConnectionPool` instances. - - Example:: - - >>> manager = PoolManager(num_pools=2) - >>> r = manager.request('GET', 'http://google.com/') - >>> r = manager.request('GET', 'http://google.com/mail') - >>> r = manager.request('GET', 'http://yahoo.com/') - >>> len(manager.pools) - 2 - - """ - - proxy = None - proxy_config = None - - 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()) - - # Locally set the pool classes and keys so other PoolManagers can - # override them. - self.pool_classes_by_scheme = pool_classes_by_scheme - self.key_fn_by_scheme = key_fn_by_scheme.copy() - - def __enter__(self): - return self - - def __exit__(self, exc_type, exc_val, exc_tb): - self.clear() - # Return False to re-raise any potential exceptions - return False - - def _new_pool(self, scheme, host, port, request_context=None): - """ - Create a new :class:`urllib3.connectionpool.ConnectionPool` based on host, port, scheme, and - any additional pool keyword arguments. - - If ``request_context`` is provided, it is provided as keyword arguments - to the pool class used. This method is used to actually create the - connection pools handed out by :meth:`connection_from_url` and - companion methods. It is intended to be overridden for customization. - """ - pool_cls = self.pool_classes_by_scheme[scheme] - if request_context is None: - request_context = self.connection_pool_kw.copy() - - # Although the context has everything necessary to create the pool, - # this function has historically only used the scheme, host, and port - # in the positional args. When an API change is acceptable these can - # be removed. - for key in ("scheme", "host", "port"): - request_context.pop(key, None) - - if scheme == "http": - for kw in SSL_KEYWORDS: - request_context.pop(kw, None) - - return pool_cls(host, port, **request_context) - - def clear(self): - """ - Empty our store of pools and direct them all to close. - - This will not affect in-flight connections, but they will not be - re-used after completion. - """ - self.pools.clear() - - def connection_from_host(self, host, port=None, scheme="http", pool_kwargs=None): - """ - Get a :class:`urllib3.connectionpool.ConnectionPool` based on the host, port, and scheme. - - If ``port`` isn't given, it will be derived from the ``scheme`` using - ``urllib3.connectionpool.port_by_scheme``. If ``pool_kwargs`` is - provided, it is merged with the instance's ``connection_pool_kw`` - variable and used to create the new connection pool, if one is - needed. - """ - - if not host: - raise LocationValueError("No host specified.") - - request_context = self._merge_pool_kwargs(pool_kwargs) - request_context["scheme"] = scheme or "http" - if not port: - port = port_by_scheme.get(request_context["scheme"].lower(), 80) - request_context["port"] = port - request_context["host"] = host - - return self.connection_from_context(request_context) - - def connection_from_context(self, request_context): - """ - Get a :class:`urllib3.connectionpool.ConnectionPool` based on the request context. - - ``request_context`` must at least contain the ``scheme`` key and its - value must be a key in ``key_fn_by_scheme`` instance variable. - """ - scheme = request_context["scheme"].lower() - pool_key_constructor = self.key_fn_by_scheme.get(scheme) - if not pool_key_constructor: - raise URLSchemeUnknown(scheme) - pool_key = pool_key_constructor(request_context) - - return self.connection_from_pool_key(pool_key, request_context=request_context) - - def connection_from_pool_key(self, pool_key, request_context=None): - """ - Get a :class:`urllib3.connectionpool.ConnectionPool` based on the provided pool key. - - ``pool_key`` should be a namedtuple that only contains immutable - objects. At a minimum it must have the ``scheme``, ``host``, and - ``port`` fields. - """ - with self.pools.lock: - # If the scheme, host, or port doesn't match existing open - # connections, open a new ConnectionPool. - pool = self.pools.get(pool_key) - if pool: - return pool - - # Make a fresh ConnectionPool of the desired type - scheme = request_context["scheme"] - host = request_context["host"] - port = request_context["port"] - pool = self._new_pool(scheme, host, port, request_context=request_context) - self.pools[pool_key] = pool - - return pool - - def connection_from_url(self, url, pool_kwargs=None): - """ - Similar to :func:`urllib3.connectionpool.connection_from_url`. - - If ``pool_kwargs`` is not provided and a new pool needs to be - constructed, ``self.connection_pool_kw`` is used to initialize - the :class:`urllib3.connectionpool.ConnectionPool`. If ``pool_kwargs`` - is provided, it is used instead. Note that if a new pool does not - need to be created for the request, the provided ``pool_kwargs`` are - not used. - """ - u = parse_url(url) - return self.connection_from_host( - u.host, port=u.port, scheme=u.scheme, pool_kwargs=pool_kwargs - ) - - def _merge_pool_kwargs(self, override): - """ - Merge a dictionary of override values for self.connection_pool_kw. - - This does not modify self.connection_pool_kw and returns a new dict. - Any keys in the override dictionary with a value of ``None`` are - removed from the merged dictionary. - """ - base_pool_kwargs = self.connection_pool_kw.copy() - if override: - for key, value in override.items(): - if value is None: - try: - del base_pool_kwargs[key] - except KeyError: - pass - else: - base_pool_kwargs[key] = value - return base_pool_kwargs - - def _proxy_requires_url_absolute_form(self, parsed_url): - """ - Indicates if the proxy requires the complete destination URL in the - request. Normally this is only needed when not using an HTTP CONNECT - tunnel. - """ - if self.proxy is None: - return False - - return not connection_requires_http_tunnel( - self.proxy, self.proxy_config, parsed_url.scheme - ) - - def _validate_proxy_scheme_url_selection(self, url_scheme): - """ - Validates that were not attempting to do TLS in TLS connections on - Python2 or with unsupported SSL implementations. - """ - if self.proxy is None or url_scheme != "https": - return - - if self.proxy.scheme != "https": - return - - if six.PY2 and not self.proxy_config.use_forwarding_for_https: - raise ProxySchemeUnsupported( - "Contacting HTTPS destinations through HTTPS proxies " - "'via CONNECT tunnels' is not supported in Python 2" - ) - - def urlopen(self, method, url, redirect=True, **kw): - """ - Same as :meth:`urllib3.HTTPConnectionPool.urlopen` - with custom cross-host redirect logic and only sends the request-uri - portion of the ``url``. - - The given ``url`` parameter must be absolute, such that an appropriate - :class:`urllib3.connectionpool.ConnectionPool` can be chosen for it. - """ - u = parse_url(url) - self._validate_proxy_scheme_url_selection(u.scheme) - - conn = self.connection_from_host(u.host, port=u.port, scheme=u.scheme) - - kw["assert_same_host"] = False - kw["redirect"] = False - - if "headers" not in kw: - kw["headers"] = self.headers.copy() - - if self._proxy_requires_url_absolute_form(u): - response = conn.urlopen(method, url, **kw) - else: - response = conn.urlopen(method, u.request_uri, **kw) - - redirect_location = redirect and response.get_redirect_location() - if not redirect_location: - return response - - # Support relative URLs for redirecting. - redirect_location = urljoin(url, redirect_location) - - # RFC 7231, Section 6.4.4 - if response.status == 303: - method = "GET" - - retries = kw.get("retries") - if not isinstance(retries, Retry): - retries = Retry.from_int(retries, redirect=redirect) - - # Strip headers marked as unsafe to forward to the redirected location. - # Check remove_headers_on_redirect to avoid a potential network call within - # conn.is_same_host() which may use socket.gethostbyname() in the future. - if retries.remove_headers_on_redirect and not conn.is_same_host( - redirect_location - ): - headers = list(six.iterkeys(kw["headers"])) - for header in headers: - if header.lower() in retries.remove_headers_on_redirect: - kw["headers"].pop(header, None) - - try: - retries = retries.increment(method, url, response=response, _pool=conn) - except MaxRetryError: - if retries.raise_on_redirect: - response.drain_conn() - raise - return response - - kw["retries"] = retries - kw["redirect"] = redirect - - log.info("Redirecting %s -> %s", url, redirect_location) - - response.drain_conn() - return self.urlopen(method, redirect_location, **kw) - - -class ProxyManager(PoolManager): - """ - Behaves just like :class:`PoolManager`, but sends all requests through - the defined proxy, using the CONNECT method for HTTPS URLs. - - :param proxy_url: - The URL of the proxy to be used. - - :param proxy_headers: - A dictionary containing headers that will be sent to the proxy. In case - of HTTP they are being sent with each request, while in the - HTTPS/CONNECT case they are sent only once. Could be used for proxy - authentication. - - :param proxy_ssl_context: - The proxy SSL context is used to establish the TLS connection to the - proxy when using HTTPS proxies. - - :param use_forwarding_for_https: - (Defaults to False) If set to True will forward requests to the HTTPS - proxy to be made on behalf of the client instead of creating a TLS - tunnel via the CONNECT method. **Enabling this flag means that request - and response headers and content will be visible from the HTTPS proxy** - whereas tunneling keeps request and response headers and content - private. IP address, target hostname, SNI, and port are always visible - to an HTTPS proxy even when this flag is disabled. - - Example: - >>> proxy = urllib3.ProxyManager('http://localhost:3128/') - >>> r1 = proxy.request('GET', 'http://google.com/') - >>> r2 = proxy.request('GET', 'http://httpbin.org/') - >>> len(proxy.pools) - 1 - >>> r3 = proxy.request('GET', 'https://httpbin.org/') - >>> r4 = proxy.request('GET', 'https://twitter.com/') - >>> len(proxy.pools) - 3 - - """ - - def __init__( - self, - proxy_url, - num_pools=10, - headers=None, - proxy_headers=None, - proxy_ssl_context=None, - use_forwarding_for_https=False, - **connection_pool_kw - ): - - if isinstance(proxy_url, HTTPConnectionPool): - proxy_url = "%s://%s:%i" % ( - proxy_url.scheme, - proxy_url.host, - proxy_url.port, - ) - proxy = parse_url(proxy_url) - - if proxy.scheme not in ("http", "https"): - raise ProxySchemeUnknown(proxy.scheme) - - if not proxy.port: - port = port_by_scheme.get(proxy.scheme, 80) - proxy = proxy._replace(port=port) - - self.proxy = proxy - self.proxy_headers = proxy_headers or {} - self.proxy_ssl_context = proxy_ssl_context - self.proxy_config = ProxyConfig(proxy_ssl_context, use_forwarding_for_https) - - connection_pool_kw["_proxy"] = self.proxy - connection_pool_kw["_proxy_headers"] = self.proxy_headers - connection_pool_kw["_proxy_config"] = self.proxy_config - - super(ProxyManager, self).__init__(num_pools, headers, **connection_pool_kw) - - def connection_from_host(self, host, port=None, scheme="http", pool_kwargs=None): - if scheme == "https": - return super(ProxyManager, self).connection_from_host( - host, port, scheme, pool_kwargs=pool_kwargs - ) - - return super(ProxyManager, self).connection_from_host( - self.proxy.host, self.proxy.port, self.proxy.scheme, pool_kwargs=pool_kwargs - ) - - def _set_proxy_headers(self, url, headers=None): - """ - Sets headers needed by proxies: specifically, the Accept and Host - headers. Only sets headers not provided by the user. - """ - headers_ = {"Accept": "*/*"} - - netloc = parse_url(url).netloc - if netloc: - headers_["Host"] = netloc - - if headers: - headers_.update(headers) - return headers_ - - def urlopen(self, method, url, redirect=True, **kw): - "Same as HTTP(S)ConnectionPool.urlopen, ``url`` must be absolute." - u = parse_url(url) - if not connection_requires_http_tunnel(self.proxy, self.proxy_config, u.scheme): - # For connections using HTTP CONNECT, httplib sets the necessary - # headers on the CONNECT to the proxy. If we're not using CONNECT, - # we'll definitely need to set 'Host' at the very least. - headers = kw.get("headers", self.headers) - kw["headers"] = self._set_proxy_headers(url, headers) - - return super(ProxyManager, self).urlopen(method, url, redirect=redirect, **kw) - - -def proxy_from_url(url, **kw): - return ProxyManager(proxy_url=url, **kw) diff --git a/venv/lib/python3.8/site-packages/urllib3/request.py b/venv/lib/python3.8/site-packages/urllib3/request.py deleted file mode 100644 index 398386a..0000000 --- a/venv/lib/python3.8/site-packages/urllib3/request.py +++ /dev/null @@ -1,170 +0,0 @@ -from __future__ import absolute_import - -from .filepost import encode_multipart_formdata -from .packages.six.moves.urllib.parse import urlencode - -__all__ = ["RequestMethods"] - - -class RequestMethods(object): - """ - Convenience mixin for classes who implement a :meth:`urlopen` method, such - as :class:`urllib3.HTTPConnectionPool` and - :class:`urllib3.PoolManager`. - - Provides behavior for making common types of HTTP request methods and - decides which type of request field encoding to use. - - Specifically, - - :meth:`.request_encode_url` is for sending requests whose fields are - encoded in the URL (such as GET, HEAD, DELETE). - - :meth:`.request_encode_body` is for sending requests whose fields are - encoded in the *body* of the request using multipart or www-form-urlencoded - (such as for POST, PUT, PATCH). - - :meth:`.request` is for making any kind of request, it will look up the - appropriate encoding format and use one of the above two methods to make - the request. - - Initializer parameters: - - :param headers: - Headers to include with all requests, unless other headers are given - explicitly. - """ - - _encode_url_methods = {"DELETE", "GET", "HEAD", "OPTIONS"} - - def __init__(self, headers=None): - self.headers = headers or {} - - def urlopen( - self, - method, - url, - body=None, - headers=None, - encode_multipart=True, - multipart_boundary=None, - **kw - ): # Abstract - raise NotImplementedError( - "Classes extending RequestMethods must implement " - "their own ``urlopen`` method." - ) - - def request(self, method, url, fields=None, headers=None, **urlopen_kw): - """ - Make a request using :meth:`urlopen` with the appropriate encoding of - ``fields`` based on the ``method`` used. - - This is a convenience method that requires the least amount of manual - effort. It can be used in most situations, while still having the - option to drop down to more specific methods when necessary, such as - :meth:`request_encode_url`, :meth:`request_encode_body`, - or even the lowest level :meth:`urlopen`. - """ - method = method.upper() - - urlopen_kw["request_url"] = url - - if method in self._encode_url_methods: - return self.request_encode_url( - method, url, fields=fields, headers=headers, **urlopen_kw - ) - else: - return self.request_encode_body( - method, url, fields=fields, headers=headers, **urlopen_kw - ) - - def request_encode_url(self, method, url, fields=None, headers=None, **urlopen_kw): - """ - Make a request using :meth:`urlopen` with the ``fields`` encoded in - the url. This is useful for request methods like GET, HEAD, DELETE, etc. - """ - if headers is None: - headers = self.headers - - extra_kw = {"headers": headers} - extra_kw.update(urlopen_kw) - - if fields: - url += "?" + urlencode(fields) - - return self.urlopen(method, url, **extra_kw) - - def request_encode_body( - self, - method, - url, - fields=None, - headers=None, - encode_multipart=True, - multipart_boundary=None, - **urlopen_kw - ): - """ - Make a request using :meth:`urlopen` with the ``fields`` encoded in - the body. This is useful for request methods like POST, PUT, PATCH, etc. - - When ``encode_multipart=True`` (default), then - :func:`urllib3.encode_multipart_formdata` is used to encode - the payload with the appropriate content type. Otherwise - :func:`urllib.parse.urlencode` is used with the - 'application/x-www-form-urlencoded' content type. - - Multipart encoding must be used when posting files, and it's reasonably - safe to use it in other times too. However, it may break request - signing, such as with OAuth. - - Supports an optional ``fields`` parameter of key/value strings AND - key/filetuple. A filetuple is a (filename, data, MIME type) tuple where - the MIME type is optional. For example:: - - fields = { - 'foo': 'bar', - 'fakefile': ('foofile.txt', 'contents of foofile'), - 'realfile': ('barfile.txt', open('realfile').read()), - 'typedfile': ('bazfile.bin', open('bazfile').read(), - 'image/jpeg'), - 'nonamefile': 'contents of nonamefile field', - } - - When uploading a file, providing a filename (the first parameter of the - tuple) is optional but recommended to best mimic behavior of browsers. - - Note that if ``headers`` are supplied, the 'Content-Type' header will - be overwritten because it depends on the dynamic random boundary string - which is used to compose the body of the request. The random boundary - string can be explicitly set with the ``multipart_boundary`` parameter. - """ - if headers is None: - headers = self.headers - - extra_kw = {"headers": {}} - - if fields: - if "body" in urlopen_kw: - raise TypeError( - "request got values for both 'fields' and 'body', can only specify one." - ) - - if encode_multipart: - body, content_type = encode_multipart_formdata( - fields, boundary=multipart_boundary - ) - else: - body, content_type = ( - urlencode(fields), - "application/x-www-form-urlencoded", - ) - - extra_kw["body"] = body - extra_kw["headers"] = {"Content-Type": content_type} - - extra_kw["headers"].update(headers) - extra_kw.update(urlopen_kw) - - return self.urlopen(method, url, **extra_kw) diff --git a/venv/lib/python3.8/site-packages/urllib3/response.py b/venv/lib/python3.8/site-packages/urllib3/response.py deleted file mode 100644 index 38693f4..0000000 --- a/venv/lib/python3.8/site-packages/urllib3/response.py +++ /dev/null @@ -1,821 +0,0 @@ -from __future__ import absolute_import - -import io -import logging -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 - -from ._collections import HTTPHeaderDict -from .connection import BaseSSLError, HTTPException -from .exceptions import ( - BodyNotHttplibCompatible, - DecodeError, - HTTPError, - IncompleteRead, - InvalidChunkLength, - InvalidHeader, - ProtocolError, - ReadTimeoutError, - ResponseNotChunked, - SSLError, -) -from .packages import six -from .util.response import is_fp_closed, is_response_to_head - -log = logging.getLogger(__name__) - - -class DeflateDecoder(object): - def __init__(self): - self._first_try = True - self._data = b"" - self._obj = zlib.decompressobj() - - def __getattr__(self, name): - return getattr(self._obj, name) - - def decompress(self, data): - if not data: - return data - - if not self._first_try: - return self._obj.decompress(data) - - self._data += data - try: - decompressed = self._obj.decompress(data) - if decompressed: - self._first_try = False - self._data = None - return decompressed - except zlib.error: - self._first_try = False - self._obj = zlib.decompressobj(-zlib.MAX_WBITS) - try: - return self.decompress(self._data) - finally: - self._data = None - - -class GzipDecoderState(object): - - FIRST_MEMBER = 0 - OTHER_MEMBERS = 1 - SWALLOW_DATA = 2 - - -class GzipDecoder(object): - def __init__(self): - self._obj = zlib.decompressobj(16 + zlib.MAX_WBITS) - self._state = GzipDecoderState.FIRST_MEMBER - - def __getattr__(self, name): - return getattr(self._obj, name) - - def decompress(self, data): - ret = bytearray() - if self._state == GzipDecoderState.SWALLOW_DATA or not data: - return bytes(ret) - while True: - try: - ret += self._obj.decompress(data) - except zlib.error: - previous_state = self._state - # Ignore data after the first error - self._state = GzipDecoderState.SWALLOW_DATA - if previous_state == GzipDecoderState.OTHER_MEMBERS: - # Allow trailing garbage acceptable in other gzip clients - return bytes(ret) - raise - data = self._obj.unused_data - if not data: - return bytes(ret) - self._state = GzipDecoderState.OTHER_MEMBERS - self._obj = zlib.decompressobj(16 + zlib.MAX_WBITS) - - -if brotli is not None: - - class BrotliDecoder(object): - # Supports both 'brotlipy' and 'Brotli' packages - # since they share an import name. The top branches - # are for 'brotlipy' and bottom branches for 'Brotli' - def __init__(self): - self._obj = brotli.Decompressor() - if hasattr(self._obj, "decompress"): - self.decompress = self._obj.decompress - else: - self.decompress = self._obj.process - - def flush(self): - if hasattr(self._obj, "flush"): - return self._obj.flush() - return b"" - - -class MultiDecoder(object): - """ - From RFC7231: - If one or more encodings have been applied to a representation, the - sender that applied the encodings MUST generate a Content-Encoding - header field that lists the content codings in the order in which - they were applied. - """ - - def __init__(self, modes): - self._decoders = [_get_decoder(m.strip()) for m in modes.split(",")] - - def flush(self): - return self._decoders[0].flush() - - def decompress(self, data): - for d in reversed(self._decoders): - data = d.decompress(data) - return data - - -def _get_decoder(mode): - if "," in mode: - return MultiDecoder(mode) - - if mode == "gzip": - return GzipDecoder() - - if brotli is not None and mode == "br": - return BrotliDecoder() - - return DeflateDecoder() - - -class HTTPResponse(io.IOBase): - """ - HTTP Response container. - - Backwards-compatible with :class:`http.client.HTTPResponse` but the response ``body`` is - loaded and decoded on-demand when the ``data`` property is accessed. This - class is also compatible with the Python standard library's :mod:`io` - module, and can hence be treated as a readable object in the context of that - framework. - - Extra parameters for behaviour not present in :class:`http.client.HTTPResponse`: - - :param preload_content: - If True, the response's body will be preloaded during construction. - - :param decode_content: - If True, will attempt to decode the body based on the - 'content-encoding' header. - - :param original_response: - When this HTTPResponse wrapper is generated from an :class:`http.client.HTTPResponse` - object, it's convenient to include the original for debug purposes. It's - otherwise unused. - - :param retries: - The retries contains the last :class:`~urllib3.util.retry.Retry` that - was used during the request. - - :param enforce_content_length: - Enforce content length checking. Body returned by server must match - value of Content-Length header, if present. Otherwise, raise error. - """ - - CONTENT_DECODERS = ["gzip", "deflate"] - if brotli is not None: - CONTENT_DECODERS += ["br"] - REDIRECT_STATUSES = [301, 302, 303, 307, 308] - - def __init__( - self, - body="", - headers=None, - status=0, - version=0, - reason=None, - strict=0, - preload_content=True, - decode_content=True, - original_response=None, - pool=None, - connection=None, - msg=None, - retries=None, - enforce_content_length=False, - request_method=None, - request_url=None, - auto_close=True, - ): - - if isinstance(headers, HTTPHeaderDict): - self.headers = headers - else: - self.headers = HTTPHeaderDict(headers) - self.status = status - self.version = version - self.reason = reason - self.strict = strict - self.decode_content = decode_content - self.retries = retries - self.enforce_content_length = enforce_content_length - self.auto_close = auto_close - - self._decoder = None - self._body = None - self._fp = None - self._original_response = original_response - self._fp_bytes_read = 0 - self.msg = msg - self._request_url = request_url - - if body and isinstance(body, (six.string_types, bytes)): - self._body = body - - self._pool = pool - self._connection = connection - - if hasattr(body, "read"): - self._fp = body - - # Are we using the chunked-style of transfer encoding? - self.chunked = False - self.chunk_left = None - tr_enc = self.headers.get("transfer-encoding", "").lower() - # Don't incur the penalty of creating a list and then discarding it - encodings = (enc.strip() for enc in tr_enc.split(",")) - if "chunked" in encodings: - self.chunked = True - - # Determine length of response - self.length_remaining = self._init_length(request_method) - - # If requested, preload the body. - if preload_content and not self._body: - self._body = self.read(decode_content=decode_content) - - def get_redirect_location(self): - """ - Should we redirect and where to? - - :returns: Truthy redirect location string if we got a redirect status - code and valid location. ``None`` if redirect status and no - location. ``False`` if not a redirect status code. - """ - if self.status in self.REDIRECT_STATUSES: - return self.headers.get("location") - - return False - - def release_conn(self): - if not self._pool or not self._connection: - return - - self._pool._put_conn(self._connection) - self._connection = None - - def drain_conn(self): - """ - Read and discard any remaining HTTP response data in the response connection. - - Unread data in the HTTPResponse connection blocks the connection from being released back to the pool. - """ - try: - self.read() - except (HTTPError, SocketError, BaseSSLError, HTTPException): - pass - - @property - def data(self): - # For backwards-compat with earlier urllib3 0.4 and earlier. - if self._body: - return self._body - - if self._fp: - return self.read(cache_content=True) - - @property - def connection(self): - return self._connection - - def isclosed(self): - return is_fp_closed(self._fp) - - def tell(self): - """ - Obtain the number of bytes pulled over the wire so far. May differ from - the amount of content returned by :meth:``urllib3.response.HTTPResponse.read`` - if bytes are encoded on the wire (e.g, compressed). - """ - return self._fp_bytes_read - - def _init_length(self, request_method): - """ - Set initial length value for Response content if available. - """ - length = self.headers.get("content-length") - - if length is not None: - if self.chunked: - # This Response will fail with an IncompleteRead if it can't be - # received as chunked. This method falls back to attempt reading - # the response before raising an exception. - log.warning( - "Received response with both Content-Length and " - "Transfer-Encoding set. This is expressly forbidden " - "by RFC 7230 sec 3.3.2. Ignoring Content-Length and " - "attempting to process response as Transfer-Encoding: " - "chunked." - ) - return None - - try: - # RFC 7230 section 3.3.2 specifies multiple content lengths can - # be sent in a single Content-Length header - # (e.g. Content-Length: 42, 42). This line ensures the values - # are all valid ints and that as long as the `set` length is 1, - # all values are the same. Otherwise, the header is invalid. - lengths = set([int(val) for val in length.split(",")]) - if len(lengths) > 1: - raise InvalidHeader( - "Content-Length contained multiple " - "unmatching values (%s)" % length - ) - length = lengths.pop() - except ValueError: - length = None - else: - if length < 0: - length = None - - # Convert status to int for comparison - # In some cases, httplib returns a status of "_UNKNOWN" - try: - status = int(self.status) - except ValueError: - status = 0 - - # Check for responses that shouldn't include a body - if status in (204, 304) or 100 <= status < 200 or request_method == "HEAD": - length = 0 - - return length - - def _init_decoder(self): - """ - Set-up the _decoder attribute if necessary. - """ - # Note: content-encoding value should be case-insensitive, per RFC 7230 - # Section 3.2 - content_encoding = self.headers.get("content-encoding", "").lower() - if self._decoder is None: - if content_encoding in self.CONTENT_DECODERS: - self._decoder = _get_decoder(content_encoding) - elif "," in content_encoding: - encodings = [ - e.strip() - for e in content_encoding.split(",") - if e.strip() in self.CONTENT_DECODERS - ] - if len(encodings): - self._decoder = _get_decoder(content_encoding) - - DECODER_ERROR_CLASSES = (IOError, zlib.error) - if brotli is not None: - DECODER_ERROR_CLASSES += (brotli.error,) - - def _decode(self, data, decode_content, flush_decoder): - """ - Decode the data passed in and potentially flush the decoder. - """ - if not decode_content: - return data - - try: - if self._decoder: - data = self._decoder.decompress(data) - except self.DECODER_ERROR_CLASSES as e: - content_encoding = self.headers.get("content-encoding", "").lower() - raise DecodeError( - "Received response with content-encoding: %s, but " - "failed to decode it." % content_encoding, - e, - ) - if flush_decoder: - data += self._flush_decoder() - - return data - - def _flush_decoder(self): - """ - Flushes the decoder. Should only be called if the decoder is actually - being used. - """ - if self._decoder: - buf = self._decoder.decompress(b"") - return buf + self._decoder.flush() - - return b"" - - @contextmanager - def _error_catcher(self): - """ - Catch low-level python exceptions, instead re-raising urllib3 - variants, so that low-level exceptions are not leaked in the - high-level api. - - On exit, release the connection back to the pool. - """ - clean_exit = False - - try: - try: - yield - - except SocketTimeout: - # FIXME: Ideally we'd like to include the url in the ReadTimeoutError but - # there is yet no clean way to get at it from this context. - raise ReadTimeoutError(self._pool, None, "Read timed out.") - - except BaseSSLError as e: - # FIXME: Is there a better way to differentiate between SSLErrors? - if "read operation timed out" not in str(e): - # SSL errors related to framing/MAC get wrapped and reraised here - raise SSLError(e) - - raise ReadTimeoutError(self._pool, None, "Read timed out.") - - except (HTTPException, SocketError) as e: - # This includes IncompleteRead. - raise ProtocolError("Connection broken: %r" % e, e) - - # If no exception is thrown, we should avoid cleaning up - # unnecessarily. - clean_exit = True - finally: - # If we didn't terminate cleanly, we need to throw away our - # connection. - if not clean_exit: - # The response may not be closed but we're not going to use it - # anymore so close it now to ensure that the connection is - # released back to the pool. - if self._original_response: - self._original_response.close() - - # Closing the response may not actually be sufficient to close - # everything, so if we have a hold of the connection close that - # too. - if self._connection: - self._connection.close() - - # If we hold the original response but it's closed now, we should - # return the connection back to the pool. - if self._original_response and self._original_response.isclosed(): - self.release_conn() - - def read(self, amt=None, decode_content=None, cache_content=False): - """ - Similar to :meth:`http.client.HTTPResponse.read`, but with two additional - parameters: ``decode_content`` and ``cache_content``. - - :param amt: - How much of the content to read. If specified, caching is skipped - because it doesn't make sense to cache partial content as the full - response. - - :param decode_content: - If True, will attempt to decode the body based on the - 'content-encoding' header. - - :param cache_content: - If True, will save the returned data such that the same result is - returned despite of the state of the underlying file object. This - is useful if you want the ``.data`` property to continue working - after having ``.read()`` the file object. (Overridden if ``amt`` is - set.) - """ - self._init_decoder() - if decode_content is None: - decode_content = self.decode_content - - if self._fp is None: - return - - flush_decoder = False - fp_closed = getattr(self._fp, "closed", False) - - with self._error_catcher(): - 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. - # Close the connection when no data is returned - # - # This is redundant to what httplib/http.client _should_ - # already do. However, versions of python released before - # December 15, 2012 (http://bugs.python.org/issue16298) do - # not properly close the connection in all cases. There is - # no harm in redundantly calling close. - self._fp.close() - flush_decoder = True - if self.enforce_content_length and self.length_remaining not in ( - 0, - None, - ): - # This is an edge case that httplib failed to cover due - # to concerns of backward compatibility. We're - # addressing it here to make sure IncompleteRead is - # raised during streaming, so all calls with incorrect - # Content-Length are caught. - raise IncompleteRead(self._fp_bytes_read, self.length_remaining) - - if data: - self._fp_bytes_read += len(data) - if self.length_remaining is not None: - self.length_remaining -= len(data) - - data = self._decode(data, decode_content, flush_decoder) - - if cache_content: - self._body = data - - return data - - def stream(self, amt=2 ** 16, decode_content=None): - """ - A generator wrapper for the read() method. A call will block until - ``amt`` bytes have been read from the connection or until the - connection is closed. - - :param amt: - How much of the content to read. The generator will return up to - much data per iteration, but may return less. This is particularly - likely when using compressed data. However, the empty string will - never be returned. - - :param decode_content: - If True, will attempt to decode the body based on the - 'content-encoding' header. - """ - if self.chunked and self.supports_chunked_reads(): - for line in self.read_chunked(amt, decode_content=decode_content): - yield line - else: - while not is_fp_closed(self._fp): - data = self.read(amt=amt, decode_content=decode_content) - - if data: - yield data - - @classmethod - def from_httplib(ResponseCls, r, **response_kw): - """ - Given an :class:`http.client.HTTPResponse` instance ``r``, return a - corresponding :class:`urllib3.response.HTTPResponse` object. - - Remaining parameters are passed to the HTTPResponse constructor, along - with ``original_response=r``. - """ - headers = r.msg - - if not isinstance(headers, HTTPHeaderDict): - if six.PY2: - # Python 2.7 - headers = HTTPHeaderDict.from_httplib(headers) - else: - headers = HTTPHeaderDict(headers.items()) - - # HTTPResponse objects in Python 3 don't have a .strict attribute - strict = getattr(r, "strict", 0) - resp = ResponseCls( - body=r, - headers=headers, - status=r.status, - version=r.version, - reason=r.reason, - strict=strict, - original_response=r, - **response_kw - ) - return resp - - # Backwards-compatibility methods for http.client.HTTPResponse - def getheaders(self): - return self.headers - - def getheader(self, name, default=None): - return self.headers.get(name, default) - - # Backwards compatibility for http.cookiejar - def info(self): - return self.headers - - # Overrides from io.IOBase - def close(self): - if not self.closed: - self._fp.close() - - if self._connection: - self._connection.close() - - if not self.auto_close: - io.IOBase.close(self) - - @property - def closed(self): - if not self.auto_close: - return io.IOBase.closed.__get__(self) - elif self._fp is None: - return True - elif hasattr(self._fp, "isclosed"): - return self._fp.isclosed() - elif hasattr(self._fp, "closed"): - return self._fp.closed - else: - return True - - def fileno(self): - if self._fp is None: - raise IOError("HTTPResponse has no file to get a fileno from") - elif hasattr(self._fp, "fileno"): - return self._fp.fileno() - else: - raise IOError( - "The file-like object this HTTPResponse is wrapped " - "around has no file descriptor" - ) - - def flush(self): - if ( - self._fp is not None - and hasattr(self._fp, "flush") - and not getattr(self._fp, "closed", False) - ): - return self._fp.flush() - - def readable(self): - # This method is required for `io` module compatibility. - return True - - def readinto(self, b): - # This method is required for `io` module compatibility. - temp = self.read(len(b)) - if len(temp) == 0: - return 0 - else: - b[: len(temp)] = temp - return len(temp) - - def supports_chunked_reads(self): - """ - Checks if the underlying file-like object looks like a - :class:`http.client.HTTPResponse` object. We do this by testing for - the fp attribute. If it is present we assume it returns raw chunks as - processed by read_chunked(). - """ - return hasattr(self._fp, "fp") - - def _update_chunk_length(self): - # First, we'll figure out length of a chunk and then - # we'll try to read it from socket. - if self.chunk_left is not None: - return - line = self._fp.fp.readline() - line = line.split(b";", 1)[0] - try: - self.chunk_left = int(line, 16) - except ValueError: - # Invalid chunked protocol response, abort. - self.close() - raise InvalidChunkLength(self, line) - - def _handle_chunk(self, amt): - returned_chunk = None - if amt is None: - chunk = self._fp._safe_read(self.chunk_left) - returned_chunk = chunk - self._fp._safe_read(2) # Toss the CRLF at the end of the chunk. - self.chunk_left = None - elif amt < self.chunk_left: - value = self._fp._safe_read(amt) - self.chunk_left = self.chunk_left - amt - returned_chunk = value - elif amt == self.chunk_left: - value = self._fp._safe_read(amt) - self._fp._safe_read(2) # Toss the CRLF at the end of the chunk. - self.chunk_left = None - returned_chunk = value - else: # amt > self.chunk_left - returned_chunk = self._fp._safe_read(self.chunk_left) - self._fp._safe_read(2) # Toss the CRLF at the end of the chunk. - self.chunk_left = None - return returned_chunk - - def read_chunked(self, amt=None, decode_content=None): - """ - Similar to :meth:`HTTPResponse.read`, but with an additional - parameter: ``decode_content``. - - :param amt: - How much of the content to read. If specified, caching is skipped - because it doesn't make sense to cache partial content as the full - response. - - :param decode_content: - If True, will attempt to decode the body based on the - 'content-encoding' header. - """ - self._init_decoder() - # FIXME: Rewrite this method and make it a class with a better structured logic. - if not self.chunked: - raise ResponseNotChunked( - "Response is not chunked. " - "Header 'transfer-encoding: chunked' is missing." - ) - if not self.supports_chunked_reads(): - raise BodyNotHttplibCompatible( - "Body should be http.client.HTTPResponse like. " - "It should have have an fp attribute which returns raw chunks." - ) - - with self._error_catcher(): - # Don't bother reading the body of a HEAD request. - if self._original_response and is_response_to_head(self._original_response): - self._original_response.close() - return - - # If a response is already read and closed - # then return immediately. - if self._fp.fp is None: - return - - while True: - self._update_chunk_length() - if self.chunk_left == 0: - break - chunk = self._handle_chunk(amt) - decoded = self._decode( - chunk, decode_content=decode_content, flush_decoder=False - ) - if decoded: - yield decoded - - if decode_content: - # On CPython and PyPy, we should never need to flush the - # decoder. However, on Jython we *might* need to, so - # lets defensively do it anyway. - decoded = self._flush_decoder() - if decoded: # Platform-specific: Jython. - yield decoded - - # Chunk content ends with \r\n: discard it. - while True: - line = self._fp.fp.readline() - if not line: - # Some sites may not end with '\r\n'. - break - if line == b"\r\n": - break - - # We read everything; close the "file". - if self._original_response: - self._original_response.close() - - def geturl(self): - """ - Returns the URL that was the source of this response. - If the request that generated this response redirected, this method - will return the final redirect location. - """ - if self.retries is not None and len(self.retries.history): - return self.retries.history[-1].redirect_location - else: - return self._request_url - - def __iter__(self): - buffer = [] - for chunk in self.stream(decode_content=True): - if b"\n" in chunk: - chunk = chunk.split(b"\n") - yield b"".join(buffer) + chunk[0] + b"\n" - for x in chunk[1:-1]: - yield x + b"\n" - if chunk[-1]: - buffer = [chunk[-1]] - else: - buffer = [] - else: - buffer.append(chunk) - if buffer: - yield b"".join(buffer) diff --git a/venv/lib/python3.8/site-packages/urllib3/util/__init__.py b/venv/lib/python3.8/site-packages/urllib3/util/__init__.py deleted file mode 100644 index 4547fc5..0000000 --- a/venv/lib/python3.8/site-packages/urllib3/util/__init__.py +++ /dev/null @@ -1,49 +0,0 @@ -from __future__ import absolute_import - -# For backwards compatibility, provide imports that used to be here. -from .connection import is_connection_dropped -from .request import SKIP_HEADER, SKIPPABLE_HEADERS, make_headers -from .response import is_fp_closed -from .retry import Retry -from .ssl_ import ( - ALPN_PROTOCOLS, - HAS_SNI, - IS_PYOPENSSL, - IS_SECURETRANSPORT, - PROTOCOL_TLS, - SSLContext, - assert_fingerprint, - resolve_cert_reqs, - resolve_ssl_version, - ssl_wrap_socket, -) -from .timeout import Timeout, current_time -from .url import Url, get_host, parse_url, split_first -from .wait import wait_for_read, wait_for_write - -__all__ = ( - "HAS_SNI", - "IS_PYOPENSSL", - "IS_SECURETRANSPORT", - "SSLContext", - "PROTOCOL_TLS", - "ALPN_PROTOCOLS", - "Retry", - "Timeout", - "Url", - "assert_fingerprint", - "current_time", - "is_connection_dropped", - "is_fp_closed", - "get_host", - "parse_url", - "make_headers", - "resolve_cert_reqs", - "resolve_ssl_version", - "split_first", - "ssl_wrap_socket", - "wait_for_read", - "wait_for_write", - "SKIP_HEADER", - "SKIPPABLE_HEADERS", -) diff --git a/venv/lib/python3.8/site-packages/urllib3/util/__pycache__/__init__.cpython-38.pyc b/venv/lib/python3.8/site-packages/urllib3/util/__pycache__/__init__.cpython-38.pyc deleted file mode 100644 index 04312453008190153bd7de4922afda33857ae2f8..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1061 zcmZ9L%Wl&^6o&2GoQrc$+w@8c0?CUKBvz3SB9ut2h>|Ey7tChl#?#j7jBRGdO}gf3 z*z+{AWz|<;#T5d8aObnroc;)jNB_$D=& ziA>Y*Gk%t4SQcf|c8=y)9_3j96_|yrG?%AERzjt;U7%%FL6x*^QJYm!mDNy<)lr=_ zP=hs5leJKbwNaaOP={@yEw+ue)A2>R!@8);cF}Gcm*^hbNBism9k4@m$d1ranlIC5 z>=+%h6Lg~E3VQC_uHjT4b>)U*s=9Y2BAQ5o0~SYIKAP+NRv_>q3PZAxK@?)2M{!Ji zC#x#%=Zh&m9}YeZXQ~OobntOB{F8B&&AdB;Z;9stSb6D9K8ymL~+^5?=@54dF2lLaCaZXo>d(FQA8$uR^t-QbJICuM5>0RULvQ z_hKxf#T}7OMp^TKktmVMUL>58P-3YQPEKVnIaS3QBJph`q$a|+XsIuD6weF2Z5T$b9;zpISF!m_L z_`AVh>HZYI`aQ|wUL3@yNf>+jK>gF@Eg|%Db#*6K{eIlj%hTZMZ7-1l?O_~*`lRsd g_(2ulvB*y-c@IB>05k2ZZFWpszi;e@*)I z-OLOviCFd`4tm$3k09Ly=ym%9eT=>Bm0uw!(0((!`f(6+iCNB^ojG&lzhWA>YLkv8#Vi7wG){4di> zbOryH*d==TmDyjRR@Z2)zJ@GD%gmR8p-7^sWPUhF6D~WTtvpUffee#)E8v1{aGvnj zR57LyyJ7LUx7QYO6661g^!o%05+F|AIc9LhoQ4gi0RU+cloUw$Qg4T*Y;Dg6AodQyvS_<5Nb$F_F8BjFLEJBc(D41))5F zl9U87C1N+3MwAS(CrSjP?Yd^NmIgeS=yPkDpg6CMqCkkX!LF2PdlZE%mhFeV-q!sy z?gNqx_i$0krISduMqnk9MuCK3CW1uaJ|pXCx}lAH6XHRlgD{Fn5FG?Zf^aQA84Naq zNU*_x$V5vJF{yPqWkq%&fAofKoQ;kkSG+?c4`KlwAYybxa5I^Twq}z%0xsL^^mgC{ z{lLLh8BSO-l`T83?l2ih$$1SQx$+sD?kEFt1%tmEyotZ>etBC?(%Wg6-kQc~fEb{+ z4t5!fZXFKy<>9@1>Fp_xqHy^0+fx}vx6d8WPLJ}pLgAlN{L&u{@D(d~8TE$gnT{To z)ij$XUj}vLsBh(?2n!fGpzgr;neoD!JM&8B93!w!OnwD31lEZ;cc?vgrS-~~S7%L7 zZR(turt!>(uOp-!gw%^7q-5pTl~oEJZyT==h$ohdFjGM$z2jQuWR z+qsu{FDmoeygpx;H|C4Dr8(3 z|MwBH1?1_#hAc^{kQ_vs!HqI>Zx9VxCK)f_Buc!L-wCjPL6I;PGJxQk$B+Rbj3DgU z1iTe~lGB_4g&vJb4AY!l1i*@Enj!&Eh2Mh5PLvFTh)^~TrV)@@0E$2g&9E>flFsmm ztSMuy4GNRCfw%Hdd1jzx!X;CckM#97L^91p=oE&ZOiFPTCZcVE@$G=RhqI$a+ka`v@+&c8#dq1{ac_63L=S z=xd&ImHi;SUX{ufhrctwm|0(Z*~y)d#=-2pYafbhH%Sx>SwxiWj}$|hBqU1Wo!L)R zEY9UGJRext(sSuD!+L}SD)5$ zUM(HLRdUOlZ~9%W6%5aAbd)D@M|mK(!6|o3ZEb)!w}Nr*sT1-jWqBp#iA?g^D2S2F zg9*zm5$K$rn@lJ5;(mV9Ny0xlyAe+Afs$=nw!DFNvg40LYT#fq};woM!`UaYS21N$UOyt_;+{%nS zL0+)%!H}>E42ga3==Nfq;XA?~|}dJ20eVhYB?s zkrx8%CPCpu_9;B~tHQ(W^-X`f)7{#*ub3+Ao+cI)ea%6)3@PJ)>x2a4L8pt15b)8i zuJ*%3?vh7aFYoHSipd?|XOwU%+AW8_3ytzBu6Weh=;hwS^{)SD>koJH+S#owlee(x z`{sKKvI(Y=<(EBMb>(VCpMzyj7DCWnQ=yxlsn?5K=LqLP!XP= z;QP#8Tl=_mIj{Tvc!~y>`94<|(xUZO%4Vz0P9+gVCR2F^DREdR=c!ID*kPi`dyeYY zb&FRtd#b16@2Qu9s78hMtrmdaRkU+W^i1ap?~_SFrxE+LGNjg~VR=@=YCw-=+q>eJ QmTCQ`{u|Hp7QFZW2Z`#QjsO4v diff --git a/venv/lib/python3.8/site-packages/urllib3/util/__pycache__/proxy.cpython-38.pyc b/venv/lib/python3.8/site-packages/urllib3/util/__pycache__/proxy.cpython-38.pyc deleted file mode 100644 index c982450e4ecb6f00c1ee39e59801297e037dff51..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1305 zcmYjROKTKC5bo)DWb+bVNDhLH5Og8gl_)|)REV#GtRb$KMHo8Mz1d0TWp_`qk?|C- z{s%q!m*(opzaU1f>X{_l&^6Wd{JN`Z-Y+jN5LnaARsK960xmkWnyu=N@cL4=c# z)EPM`9nsVsxegI?!WG^ZXXJ^F@I?TeFX%hco&V*4OV_P$L`rfa!%`(lyn8>4^32Go zsjn!h^W;#5kyIvB@}sV=or$zg!b7QaoM(dwF`O;rDeNuS`T>v%FdcN%66UO^a1W?j zu{_x)!h_Sj%E7%46y?GPYyp1?;1(FH9cfCHX*N`)Wbv4piDZB-+9BV7_a@vYA_p$^Cn5_gwob$ z8^dhn**M;7eE|p@F5ImJ!UJikxJ5WtdCH1BPg0)oJ*j%d@hlK+6cbXLIJ4%VjwUjd z7a@mm-$r%@Y{t6B?#4aICdL$c&3@LHG*Q=pr92+66;G(9JgBLtqRsPDM@}Lo4UR5zbfo*{`VHs9e~d-Y{+j193vtM&*C= zz7vO3*n;k-5B3#b$xK2evBRKFV_qhvDL#W4z*6I^U}NSP6oTvQj$yk}W@vO63n|#{ zF*czM2G6c~mV;s}&J0mKe=%fNlbnmN&1HvAcYTFJrSM`3N35QMRNNS)F2SiAs3p`a zqoxz_#;IOxxlqJvv~+&phBvue@V0~v!GBG?(*6&c;v>k`a22%rCJ-`5oxlnH20m@8 zK~JgI`9p&aRo6h@bq9k%LxS4F5Dk8W-dqCfW=&_ZV=E~Oq4PM+MVZJa_>0n)fn3L{ L6Y_82cJuuY>8Whi diff --git a/venv/lib/python3.8/site-packages/urllib3/util/__pycache__/queue.cpython-38.pyc b/venv/lib/python3.8/site-packages/urllib3/util/__pycache__/queue.cpython-38.pyc deleted file mode 100644 index 2abe015b65960f5249113ad265c51ee538b3d31d..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1016 zcmZ`&O>fgc5Zw>kanhu%3j72PJ|saPAw@!{5=dN71gbdT%PP%oiqo~@tZfKYZp{yA zj`>S_<>Vq-bJFwyyTuJWemaK_jl3b7-9Y@?AO&40LX_+jt!unDHL*v7@5wl*Q z^vqJRBc=i~X-LAv-31t%&0^!26n-3yMNiYluLC2NW<>$?7ngbm;9M|q1X7N}mxy0psz G7V^K1kMP%YbXJ{Y3#_B!FxA2j`bjJ` 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 L9CQ7T{IC84dq;Qa diff --git a/venv/lib/python3.8/site-packages/urllib3/util/__pycache__/retry.cpython-38.pyc b/venv/lib/python3.8/site-packages/urllib3/util/__pycache__/retry.cpython-38.pyc deleted file mode 100644 index d7fce50e7a542216f221ef41ee482a2e1ba34b0b..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 15804 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 Q8AA4#|6bfShK-^B0m(irS^xk5 diff --git a/venv/lib/python3.8/site-packages/urllib3/util/__pycache__/ssltransport.cpython-38.pyc b/venv/lib/python3.8/site-packages/urllib3/util/__pycache__/ssltransport.cpython-38.pyc deleted file mode 100644 index 1b717b3a6816f0420501619b92b688bb6a62c0bb..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 7406 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 MS|x0JMKkpO0zu~ToB#j- diff --git a/venv/lib/python3.8/site-packages/urllib3/util/__pycache__/timeout.cpython-38.pyc b/venv/lib/python3.8/site-packages/urllib3/util/__pycache__/timeout.cpython-38.pyc deleted file mode 100644 index 768d79ee4e377fd8ae44231114125a721c88ed85..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 8903 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 KVfL9x)BZou2Azli diff --git a/venv/lib/python3.8/site-packages/urllib3/util/__pycache__/wait.cpython-38.pyc b/venv/lib/python3.8/site-packages/urllib3/util/__pycache__/wait.cpython-38.pyc deleted file mode 100644 index 2625f220e75d3c83c2b54c662c4e2984c5ecc118..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3063 zcmc&$OK%iM5bo}I?y|NQW6aATlSq(Egl$3~kt2eL5JpI79brd?Rg}qiyVoA??99^B z>z8H|30rv_f^vzJBhHO~lk;4234ei8s(NgLSDbRm*!`&P-tMZezN+r8M@FgyzOA`S z;nZnD{zl==&jsN&lxV&9bFUs%6$>(6ZR*noX0EojOQHY<2CXP02DzJd+5g zQ^ zf^N$DG4^Xg@T4Ec<;)8rPrzzjy}B{0y1m(6)SK=ny%1F6)0=BT#M4_V9kn$#*PHFj zIF436neD46o<$93dfWQAQB;LNDjw_(v zE*-F>s^~6^o*@IaQ!O=FCX2)*iYa5=Y%`$RZm;tPENCW&a!%G z?Nho+1|}3Mr}A=cKBqa^rS`7G?%vSeQEOEWJ$$qb*x&0%q(@-D-dfTjIKH7(8gV zbUOrdF8v3R_|e@qsHupSw~($S*JwIFJzPa zb|kp9X4EYCG0eB19DRrBZvjSh);P-8B$uqD+VRtq$4Ga@+BIyIjL%=0?l?%<-EQ0<&m33pDLD< zbqWa+NCP+Uc}R|iDpTXN@)mv!H})cdyVqC*K0rD%8=5=wOTJZx8hW9Ox6v<^lF>?E zm0>9-a7LqibOn`oj|Xevh6pxO*@==>%@2vnA!CTi0O2|vr!JG9f_%&tw9$Z~F~+SG z*###m8nR>pbw^v|l(IlJl^rs)FsIK-)@p@)M{leBSBwn-SvYH97J?b2Z5XZ+0hQOV zI&Oyi490$dQtEBn)P_*EnMw7`vFi%;K1#26mnw`eeX;xs$oj_4kIQh|W*)o`bkYM{ zJe7JY;x#`YCwif`8f}QgE3?f^)r0S$P<@$X9;QhzYI|x;9L#%BrZ+=&UGZS&c?hnf zH3zq_C$@T#6ujJQ37!`o=%+*GMQI5zQpXcU(J%%W($Aoj>@)wn(U_P2Pot0Wgq%Y& zKYxp@4vhW&+E(9~pNCf%R#g8_$g}t>ynqTL+s=wgyPvcaTtZoSHDRJJZ~hbayS-E% zybPTn2qC6}qH=euC3-4K6P*c)+J=xBNbnp2USMj|7l@{ANlOe6%{GaSkf`As9@2c( vY1qA4J`ZnUGRQ7Nh1U~gGR7d*M(H>_66)vSsbITjs;8>> make_headers(keep_alive=True, user_agent="Batman/1.0") - {'connection': 'keep-alive', 'user-agent': 'Batman/1.0'} - >>> make_headers(accept_encoding=True) - {'accept-encoding': 'gzip,deflate'} - """ - headers = {} - if accept_encoding: - if isinstance(accept_encoding, str): - pass - elif isinstance(accept_encoding, list): - accept_encoding = ",".join(accept_encoding) - else: - accept_encoding = ACCEPT_ENCODING - headers["accept-encoding"] = accept_encoding - - if user_agent: - headers["user-agent"] = user_agent - - if keep_alive: - headers["connection"] = "keep-alive" - - if basic_auth: - headers["authorization"] = "Basic " + b64encode(b(basic_auth)).decode("utf-8") - - if proxy_basic_auth: - headers["proxy-authorization"] = "Basic " + b64encode( - b(proxy_basic_auth) - ).decode("utf-8") - - if disable_cache: - headers["cache-control"] = "no-cache" - - return headers - - -def set_file_position(body, pos): - """ - If a position is provided, move file to that point. - Otherwise, we'll attempt to record a position for future use. - """ - if pos is not None: - rewind_body(body, pos) - elif getattr(body, "tell", None) is not None: - try: - pos = body.tell() - except (IOError, OSError): - # This differentiates from None, allowing us to catch - # a failed `tell()` later when trying to rewind the body. - pos = _FAILEDTELL - - return pos - - -def rewind_body(body, body_pos): - """ - Attempt to rewind body to a certain position. - Primarily used for request redirects and retries. - - :param body: - File-like object that supports seek. - - :param int pos: - Position to seek to in file. - """ - body_seek = getattr(body, "seek", None) - if body_seek is not None and isinstance(body_pos, integer_types): - try: - body_seek(body_pos) - except (IOError, OSError): - raise UnrewindableBodyError( - "An error occurred when rewinding request body for redirect/retry." - ) - elif body_pos is _FAILEDTELL: - raise UnrewindableBodyError( - "Unable to record file position for rewinding " - "request body during a redirect/retry." - ) - else: - raise ValueError( - "body_pos must be of type integer, instead it was %s." % type(body_pos) - ) diff --git a/venv/lib/python3.8/site-packages/urllib3/util/response.py b/venv/lib/python3.8/site-packages/urllib3/util/response.py deleted file mode 100644 index 5ea609c..0000000 --- a/venv/lib/python3.8/site-packages/urllib3/util/response.py +++ /dev/null @@ -1,107 +0,0 @@ -from __future__ import absolute_import - -from email.errors import MultipartInvariantViolationDefect, StartBoundaryNotFoundDefect - -from ..exceptions import HeaderParsingError -from ..packages.six.moves import http_client as httplib - - -def is_fp_closed(obj): - """ - Checks whether a given file-like object is closed. - - :param obj: - The file-like object to check. - """ - - try: - # Check `isclosed()` first, in case Python3 doesn't set `closed`. - # GH Issue #928 - return obj.isclosed() - except AttributeError: - pass - - try: - # Check via the official file-like-object way. - return obj.closed - except AttributeError: - pass - - try: - # Check if the object is a container for another file-like object that - # gets released on exhaustion (e.g. HTTPResponse). - return obj.fp is None - except AttributeError: - pass - - raise ValueError("Unable to determine whether fp is closed.") - - -def assert_header_parsing(headers): - """ - Asserts whether all headers have been successfully parsed. - Extracts encountered errors from the result of parsing headers. - - Only works on Python 3. - - :param http.client.HTTPMessage headers: Headers to verify. - - :raises urllib3.exceptions.HeaderParsingError: - If parsing errors are found. - """ - - # This will fail silently if we pass in the wrong kind of parameter. - # To make debugging easier add an explicit check. - if not isinstance(headers, httplib.HTTPMessage): - raise TypeError("expected httplib.Message, got {0}.".format(type(headers))) - - defects = getattr(headers, "defects", None) - get_payload = getattr(headers, "get_payload", None) - - unparsed_data = None - if get_payload: - # get_payload is actually email.message.Message.get_payload; - # we're only interested in the result if it's not a multipart message - if not headers.is_multipart(): - payload = get_payload() - - if isinstance(payload, (bytes, str)): - unparsed_data = payload - if defects: - # httplib is assuming a response body is available - # when parsing headers even when httplib only sends - # header data to parse_headers() This results in - # defects on multipart responses in particular. - # See: https://github.com/urllib3/urllib3/issues/800 - - # So we ignore the following defects: - # - StartBoundaryNotFoundDefect: - # The claimed start boundary was never found. - # - MultipartInvariantViolationDefect: - # A message claimed to be a multipart but no subparts were found. - defects = [ - defect - for defect in defects - if not isinstance( - defect, (StartBoundaryNotFoundDefect, MultipartInvariantViolationDefect) - ) - ] - - if defects or unparsed_data: - raise HeaderParsingError(defects=defects, unparsed_data=unparsed_data) - - -def is_response_to_head(response): - """ - Checks whether the request of a response has been a HEAD-request. - Handles the quirks of AppEngine. - - :param http.client.HTTPResponse response: - Response to check if the originating request - used 'HEAD' as a method. - """ - # FIXME: Can we do this somehow without accessing private httplib _method? - method = response._method - if isinstance(method, int): # Platform-specific: Appengine - return method == 3 - return method.upper() == "HEAD" diff --git a/venv/lib/python3.8/site-packages/urllib3/util/retry.py b/venv/lib/python3.8/site-packages/urllib3/util/retry.py deleted file mode 100644 index c7dc42f..0000000 --- a/venv/lib/python3.8/site-packages/urllib3/util/retry.py +++ /dev/null @@ -1,602 +0,0 @@ -from __future__ import absolute_import - -import email -import logging -import re -import time -import warnings -from collections import namedtuple -from itertools import takewhile - -from ..exceptions import ( - ConnectTimeoutError, - InvalidHeader, - MaxRetryError, - ProtocolError, - ProxyError, - ReadTimeoutError, - ResponseError, -) -from ..packages import six - -log = logging.getLogger(__name__) - - -# Data structure for representing the metadata of requests that result in a retry. -RequestHistory = namedtuple( - "RequestHistory", ["method", "url", "error", "status", "redirect_location"] -) - - -# TODO: In v2 we can remove this sentinel and metaclass with deprecated options. -_Default = object() - - -class _RetryMeta(type): - @property - def DEFAULT_METHOD_WHITELIST(cls): - warnings.warn( - "Using 'Retry.DEFAULT_METHOD_WHITELIST' is deprecated and " - "will be removed in v2.0. Use 'Retry.DEFAULT_ALLOWED_METHODS' instead", - DeprecationWarning, - ) - return cls.DEFAULT_ALLOWED_METHODS - - @DEFAULT_METHOD_WHITELIST.setter - def DEFAULT_METHOD_WHITELIST(cls, value): - warnings.warn( - "Using 'Retry.DEFAULT_METHOD_WHITELIST' is deprecated and " - "will be removed in v2.0. Use 'Retry.DEFAULT_ALLOWED_METHODS' instead", - DeprecationWarning, - ) - cls.DEFAULT_ALLOWED_METHODS = value - - @property - def DEFAULT_REDIRECT_HEADERS_BLACKLIST(cls): - warnings.warn( - "Using 'Retry.DEFAULT_REDIRECT_HEADERS_BLACKLIST' is deprecated and " - "will be removed in v2.0. Use 'Retry.DEFAULT_REMOVE_HEADERS_ON_REDIRECT' instead", - DeprecationWarning, - ) - return cls.DEFAULT_REMOVE_HEADERS_ON_REDIRECT - - @DEFAULT_REDIRECT_HEADERS_BLACKLIST.setter - def DEFAULT_REDIRECT_HEADERS_BLACKLIST(cls, value): - warnings.warn( - "Using 'Retry.DEFAULT_REDIRECT_HEADERS_BLACKLIST' is deprecated and " - "will be removed in v2.0. Use 'Retry.DEFAULT_REMOVE_HEADERS_ON_REDIRECT' instead", - DeprecationWarning, - ) - cls.DEFAULT_REMOVE_HEADERS_ON_REDIRECT = value - - -@six.add_metaclass(_RetryMeta) -class Retry(object): - """Retry configuration. - - Each retry attempt will create a new Retry object with updated values, so - they can be safely reused. - - Retries can be defined as a default for a pool:: - - retries = Retry(connect=5, read=2, redirect=5) - http = PoolManager(retries=retries) - response = http.request('GET', 'http://example.com/') - - Or per-request (which overrides the default for the pool):: - - response = http.request('GET', 'http://example.com/', retries=Retry(10)) - - Retries can be disabled by passing ``False``:: - - response = http.request('GET', 'http://example.com/', retries=False) - - Errors will be wrapped in :class:`~urllib3.exceptions.MaxRetryError` unless - retries are disabled, in which case the causing exception will be raised. - - :param int total: - Total number of retries to allow. Takes precedence over other counts. - - Set to ``None`` to remove this constraint and fall back on other - counts. - - Set to ``0`` to fail on the first retry. - - Set to ``False`` to disable and imply ``raise_on_redirect=False``. - - :param int connect: - How many connection-related errors to retry on. - - These are errors raised before the request is sent to the remote server, - which we assume has not triggered the server to process the request. - - Set to ``0`` to fail on the first retry of this type. - - :param int read: - How many times to retry on read errors. - - These errors are raised after the request was sent to the server, so the - request may have side-effects. - - Set to ``0`` to fail on the first retry of this type. - - :param int redirect: - How many redirects to perform. Limit this to avoid infinite redirect - loops. - - A redirect is a HTTP response with a status code 301, 302, 303, 307 or - 308. - - Set to ``0`` to fail on the first retry of this type. - - Set to ``False`` to disable and imply ``raise_on_redirect=False``. - - :param int status: - How many times to retry on bad status codes. - - These are retries made on responses, where status code matches - ``status_forcelist``. - - Set to ``0`` to fail on the first retry of this type. - - :param int other: - How many times to retry on other errors. - - Other errors are errors that are not connect, read, redirect or status errors. - These errors might be raised after the request was sent to the server, so the - request might have side-effects. - - Set to ``0`` to fail on the first retry of this type. - - If ``total`` is not set, it's a good idea to set this to 0 to account - for unexpected edge cases and avoid infinite retry loops. - - :param iterable allowed_methods: - Set of uppercased HTTP method verbs that we should retry on. - - By default, we only retry on methods which are considered to be - idempotent (multiple requests with the same parameters end with the - same state). See :attr:`Retry.DEFAULT_ALLOWED_METHODS`. - - Set to a ``False`` value to retry on any verb. - - .. warning:: - - Previously this parameter was named ``method_whitelist``, that - usage is deprecated in v1.26.0 and will be removed in v2.0. - - :param iterable status_forcelist: - A set of integer HTTP status codes that we should force a retry on. - A retry is initiated if the request method is in ``allowed_methods`` - and the response status code is in ``status_forcelist``. - - By default, this is disabled with ``None``. - - :param float backoff_factor: - A backoff factor to apply between attempts after the second try - (most errors are resolved immediately by a second try without a - delay). urllib3 will sleep for:: - - {backoff factor} * (2 ** ({number of total retries} - 1)) - - 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`. - - By default, backoff is disabled (set to 0). - - :param bool raise_on_redirect: Whether, if the number of redirects is - exhausted, to raise a MaxRetryError, or to return a response with a - response code in the 3xx range. - - :param bool raise_on_status: Similar meaning to ``raise_on_redirect``: - whether we should raise an exception, or return a response, - if status falls in ``status_forcelist`` range and retries have - been exhausted. - - :param tuple history: The history of the request encountered during - each call to :meth:`~Retry.increment`. The list is in the order - the requests occurred. Each list item is of class :class:`RequestHistory`. - - :param bool respect_retry_after_header: - Whether to respect Retry-After header on status codes defined as - :attr:`Retry.RETRY_AFTER_STATUS_CODES` or not. - - :param iterable remove_headers_on_redirect: - Sequence of headers to remove from the request when a response - indicating a redirect is returned before firing off the redirected - request. - """ - - #: Default methods to be used for ``allowed_methods`` - DEFAULT_ALLOWED_METHODS = frozenset( - ["HEAD", "GET", "PUT", "DELETE", "OPTIONS", "TRACE"] - ) - - #: Default status codes to be used for ``status_forcelist`` - RETRY_AFTER_STATUS_CODES = frozenset([413, 429, 503]) - - #: Default headers to be used for ``remove_headers_on_redirect`` - DEFAULT_REMOVE_HEADERS_ON_REDIRECT = frozenset(["Authorization"]) - - #: Maximum backoff time. - BACKOFF_MAX = 120 - - def __init__( - self, - total=10, - connect=None, - read=None, - redirect=None, - status=None, - other=None, - allowed_methods=_Default, - status_forcelist=None, - backoff_factor=0, - raise_on_redirect=True, - raise_on_status=True, - history=None, - respect_retry_after_header=True, - remove_headers_on_redirect=_Default, - # TODO: Deprecated, remove in v2.0 - method_whitelist=_Default, - ): - - if method_whitelist is not _Default: - if allowed_methods is not _Default: - raise ValueError( - "Using both 'allowed_methods' and " - "'method_whitelist' together is not allowed. " - "Instead only use 'allowed_methods'" - ) - warnings.warn( - "Using 'method_whitelist' with Retry is deprecated and " - "will be removed in v2.0. Use 'allowed_methods' instead", - DeprecationWarning, - stacklevel=2, - ) - allowed_methods = method_whitelist - if allowed_methods is _Default: - allowed_methods = self.DEFAULT_ALLOWED_METHODS - if remove_headers_on_redirect is _Default: - remove_headers_on_redirect = self.DEFAULT_REMOVE_HEADERS_ON_REDIRECT - - self.total = total - self.connect = connect - self.read = read - self.status = status - self.other = other - - if redirect is False or total is False: - redirect = 0 - raise_on_redirect = False - - self.redirect = redirect - self.status_forcelist = status_forcelist or set() - self.allowed_methods = allowed_methods - self.backoff_factor = backoff_factor - self.raise_on_redirect = raise_on_redirect - self.raise_on_status = raise_on_status - self.history = history or tuple() - self.respect_retry_after_header = respect_retry_after_header - self.remove_headers_on_redirect = frozenset( - [h.lower() for h in remove_headers_on_redirect] - ) - - def new(self, **kw): - params = dict( - total=self.total, - connect=self.connect, - read=self.read, - redirect=self.redirect, - status=self.status, - other=self.other, - status_forcelist=self.status_forcelist, - backoff_factor=self.backoff_factor, - raise_on_redirect=self.raise_on_redirect, - raise_on_status=self.raise_on_status, - history=self.history, - remove_headers_on_redirect=self.remove_headers_on_redirect, - respect_retry_after_header=self.respect_retry_after_header, - ) - - # TODO: If already given in **kw we use what's given to us - # If not given we need to figure out what to pass. We decide - # based on whether our class has the 'method_whitelist' property - # and if so we pass the deprecated 'method_whitelist' otherwise - # we use 'allowed_methods'. Remove in v2.0 - if "method_whitelist" not in kw and "allowed_methods" not in kw: - if "method_whitelist" in self.__dict__: - warnings.warn( - "Using 'method_whitelist' with Retry is deprecated and " - "will be removed in v2.0. Use 'allowed_methods' instead", - DeprecationWarning, - ) - params["method_whitelist"] = self.allowed_methods - else: - params["allowed_methods"] = self.allowed_methods - - params.update(kw) - return type(self)(**params) - - @classmethod - def from_int(cls, retries, redirect=True, default=None): - """Backwards-compatibility for the old retries format.""" - if retries is None: - retries = default if default is not None else cls.DEFAULT - - if isinstance(retries, Retry): - return retries - - redirect = bool(redirect) and None - new_retries = cls(retries, redirect=redirect) - log.debug("Converted retries value: %r -> %r", retries, new_retries) - return new_retries - - def get_backoff_time(self): - """Formula for computing the current backoff - - :rtype: float - """ - # We want to consider only the last consecutive errors sequence (Ignore redirects). - consecutive_errors_len = len( - list( - takewhile(lambda x: x.redirect_location is None, reversed(self.history)) - ) - ) - if consecutive_errors_len <= 1: - return 0 - - backoff_value = self.backoff_factor * (2 ** (consecutive_errors_len - 1)) - return min(self.BACKOFF_MAX, backoff_value) - - def parse_retry_after(self, retry_after): - # Whitespace: https://tools.ietf.org/html/rfc7230#section-3.2.4 - if re.match(r"^\s*[0-9]+\s*$", retry_after): - seconds = int(retry_after) - else: - retry_date_tuple = email.utils.parsedate_tz(retry_after) - if retry_date_tuple is None: - raise InvalidHeader("Invalid Retry-After header: %s" % retry_after) - if retry_date_tuple[9] is None: # Python 2 - # Assume UTC if no timezone was specified - # On Python2.7, parsedate_tz returns None for a timezone offset - # instead of 0 if no timezone is given, where mktime_tz treats - # a None timezone offset as local time. - retry_date_tuple = retry_date_tuple[:9] + (0,) + retry_date_tuple[10:] - - retry_date = email.utils.mktime_tz(retry_date_tuple) - seconds = retry_date - time.time() - - if seconds < 0: - seconds = 0 - - return seconds - - def get_retry_after(self, response): - """Get the value of Retry-After in seconds.""" - - retry_after = response.getheader("Retry-After") - - if retry_after is None: - return None - - return self.parse_retry_after(retry_after) - - def sleep_for_retry(self, response=None): - retry_after = self.get_retry_after(response) - if retry_after: - time.sleep(retry_after) - return True - - return False - - def _sleep_backoff(self): - backoff = self.get_backoff_time() - if backoff <= 0: - return - time.sleep(backoff) - - def sleep(self, response=None): - """Sleep between retry attempts. - - This method will respect a server's ``Retry-After`` response header - and sleep the duration of the time requested. If that is not present, it - will use an exponential backoff. By default, the backoff factor is 0 and - this method will return immediately. - """ - - if self.respect_retry_after_header and response: - slept = self.sleep_for_retry(response) - if slept: - return - - self._sleep_backoff() - - def _is_connection_error(self, err): - """Errors when we're fairly sure that the server did not receive the - request, so it should be safe to retry. - """ - if isinstance(err, ProxyError): - err = err.original_error - return isinstance(err, ConnectTimeoutError) - - def _is_read_error(self, err): - """Errors that occur after the request has been started, so we should - assume that the server began processing it. - """ - return isinstance(err, (ReadTimeoutError, ProtocolError)) - - def _is_method_retryable(self, method): - """Checks if a given HTTP method should be retried upon, depending if - it is included in the allowed_methods - """ - # TODO: For now favor if the Retry implementation sets its own method_whitelist - # property outside of our constructor to avoid breaking custom implementations. - if "method_whitelist" in self.__dict__: - warnings.warn( - "Using 'method_whitelist' with Retry is deprecated and " - "will be removed in v2.0. Use 'allowed_methods' instead", - DeprecationWarning, - ) - allowed_methods = self.method_whitelist - else: - allowed_methods = self.allowed_methods - - if allowed_methods and method.upper() not in allowed_methods: - return False - return True - - def is_retry(self, method, status_code, has_retry_after=False): - """Is this method/status code retryable? (Based on allowlists and control - variables such as the number of total retries to allow, whether to - respect the Retry-After header, whether this header is present, and - whether the returned status code is on the list of status codes to - be retried upon on the presence of the aforementioned header) - """ - if not self._is_method_retryable(method): - return False - - if self.status_forcelist and status_code in self.status_forcelist: - return True - - return ( - self.total - and self.respect_retry_after_header - and has_retry_after - and (status_code in self.RETRY_AFTER_STATUS_CODES) - ) - - def is_exhausted(self): - """Are we out of retries?""" - retry_counts = ( - self.total, - self.connect, - self.read, - self.redirect, - self.status, - self.other, - ) - retry_counts = list(filter(None, retry_counts)) - if not retry_counts: - return False - - return min(retry_counts) < 0 - - def increment( - self, - method=None, - url=None, - response=None, - error=None, - _pool=None, - _stacktrace=None, - ): - """Return a new Retry object with incremented retry counters. - - :param response: A response object, or None, if the server did not - return a response. - :type response: :class:`~urllib3.response.HTTPResponse` - :param Exception error: An error encountered during the request, or - None if the response was received successfully. - - :return: A new ``Retry`` object. - """ - if self.total is False and error: - # Disabled, indicate to re-raise the error. - raise six.reraise(type(error), error, _stacktrace) - - total = self.total - if total is not None: - total -= 1 - - connect = self.connect - read = self.read - redirect = self.redirect - status_count = self.status - other = self.other - cause = "unknown" - status = None - redirect_location = None - - if error and self._is_connection_error(error): - # Connect retry? - if connect is False: - raise six.reraise(type(error), error, _stacktrace) - elif connect is not None: - connect -= 1 - - elif error and self._is_read_error(error): - # Read retry? - if read is False or not self._is_method_retryable(method): - raise six.reraise(type(error), error, _stacktrace) - elif read is not None: - read -= 1 - - elif error: - # Other retry? - if other is not None: - other -= 1 - - elif response and response.get_redirect_location(): - # Redirect retry? - if redirect is not None: - redirect -= 1 - cause = "too many redirects" - redirect_location = response.get_redirect_location() - status = response.status - - else: - # Incrementing because of a server error like a 500 in - # status_forcelist and the given method is in the allowed_methods - cause = ResponseError.GENERIC_ERROR - if response and response.status: - if status_count is not None: - status_count -= 1 - cause = ResponseError.SPECIFIC_ERROR.format(status_code=response.status) - status = response.status - - history = self.history + ( - RequestHistory(method, url, error, status, redirect_location), - ) - - new_retry = self.new( - total=total, - connect=connect, - read=read, - redirect=redirect, - status=status_count, - other=other, - history=history, - ) - - if new_retry.is_exhausted(): - raise MaxRetryError(_pool, url, error or ResponseError(cause)) - - log.debug("Incremented Retry for (url='%s'): %r", url, new_retry) - - return new_retry - - def __repr__(self): - return ( - "{cls.__name__}(total={self.total}, connect={self.connect}, " - "read={self.read}, redirect={self.redirect}, status={self.status})" - ).format(cls=type(self), self=self) - - def __getattr__(self, item): - if item == "method_whitelist": - # TODO: Remove this deprecated alias in v2.0 - warnings.warn( - "Using 'method_whitelist' with Retry is deprecated and " - "will be removed in v2.0. Use 'allowed_methods' instead", - DeprecationWarning, - ) - return self.allowed_methods - try: - return getattr(super(Retry, self), item) - except AttributeError: - return getattr(Retry, item) - - -# For backwards compatibility (equivalent to pre-v1.9): -Retry.DEFAULT = Retry(3) diff --git a/venv/lib/python3.8/site-packages/urllib3/util/ssl_.py b/venv/lib/python3.8/site-packages/urllib3/util/ssl_.py deleted file mode 100644 index 8f86781..0000000 --- a/venv/lib/python3.8/site-packages/urllib3/util/ssl_.py +++ /dev/null @@ -1,495 +0,0 @@ -from __future__ import absolute_import - -import hmac -import os -import sys -import warnings -from binascii import hexlify, unhexlify -from hashlib import md5, sha1, sha256 - -from ..exceptions import ( - InsecurePlatformWarning, - ProxySchemeUnsupported, - SNIMissingWarning, - SSLError, -) -from ..packages import six -from .url import BRACELESS_IPV6_ADDRZ_RE, IPV4_RE - -SSLContext = None -SSLTransport = None -HAS_SNI = False -IS_PYOPENSSL = False -IS_SECURETRANSPORT = False -ALPN_PROTOCOLS = ["http/1.1"] - -# Maps the length of a digest to a possible hash function producing this digest -HASHFUNC_MAP = {32: md5, 40: sha1, 64: sha256} - - -def _const_compare_digest_backport(a, b): - """ - Compare two digests of equal length in constant time. - - The digests must be of type str/bytes. - Returns True if the digests match, and False otherwise. - """ - result = abs(len(a) - len(b)) - for left, right in zip(bytearray(a), bytearray(b)): - result |= left ^ right - return result == 0 - - -_const_compare_digest = getattr(hmac, "compare_digest", _const_compare_digest_backport) - -try: # Test for SSL features - import ssl - from ssl import CERT_REQUIRED, wrap_socket -except ImportError: - pass - -try: - from ssl import HAS_SNI # Has SNI? -except ImportError: - pass - -try: - from .ssltransport import SSLTransport -except ImportError: - pass - - -try: # Platform-specific: Python 3.6 - from ssl import PROTOCOL_TLS - - PROTOCOL_SSLv23 = PROTOCOL_TLS -except ImportError: - try: - from ssl import PROTOCOL_SSLv23 as PROTOCOL_TLS - - PROTOCOL_SSLv23 = PROTOCOL_TLS - 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 -except ImportError: - OP_NO_SSLv2, OP_NO_SSLv3 = 0x1000000, 0x2000000 - OP_NO_COMPRESSION = 0x20000 - - -try: # OP_NO_TICKET was added in Python 3.6 - from ssl import OP_NO_TICKET -except ImportError: - OP_NO_TICKET = 0x4000 - - -# A secure default. -# Sources for more information on TLS ciphers: -# -# - https://wiki.mozilla.org/Security/Server_Side_TLS -# - https://www.ssllabs.com/projects/best-practices/index.html -# - https://hynek.me/articles/hardening-your-web-servers-ssl-ciphers/ -# -# The general intent is: -# - prefer cipher suites that offer perfect forward secrecy (DHE/ECDHE), -# - prefer ECDHE over DHE for better performance, -# - prefer any AES-GCM and ChaCha20 over any AES-CBC for better performance and -# security, -# - prefer AES-GCM over ChaCha20 because hardware-accelerated AES is common, -# - disable NULL authentication, MD5 MACs, DSS, and other -# insecure ciphers for security reasons. -# - NOTE: TLS 1.3 cipher suites are managed through a different interface -# not exposed by CPython (yet!) and are enabled by default if they're available. -DEFAULT_CIPHERS = ":".join( - [ - "ECDHE+AESGCM", - "ECDHE+CHACHA20", - "DHE+AESGCM", - "DHE+CHACHA20", - "ECDH+AESGCM", - "DH+AESGCM", - "ECDH+AES", - "DH+AES", - "RSA+AESGCM", - "RSA+AES", - "!aNULL", - "!eNULL", - "!MD5", - "!DSS", - ] -) - -try: - from ssl import SSLContext # Modern SSL? -except ImportError: - - class SSLContext(object): # Platform-specific: Python 2 - def __init__(self, protocol_version): - self.protocol = protocol_version - # Use default values from a real SSLContext - self.check_hostname = False - self.verify_mode = ssl.CERT_NONE - self.ca_certs = None - self.options = 0 - self.certfile = None - self.keyfile = None - self.ciphers = None - - def load_cert_chain(self, certfile, keyfile): - self.certfile = certfile - self.keyfile = keyfile - - def load_verify_locations(self, cafile=None, capath=None, cadata=None): - self.ca_certs = cafile - - if capath is not None: - raise SSLError("CA directories not supported in older Pythons") - - if cadata is not None: - raise SSLError("CA data not supported in older Pythons") - - def set_ciphers(self, cipher_suite): - self.ciphers = cipher_suite - - def wrap_socket(self, socket, server_hostname=None, server_side=False): - warnings.warn( - "A true SSLContext object is not available. This prevents " - "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/1.26.x/advanced-usage.html" - "#ssl-warnings", - InsecurePlatformWarning, - ) - kwargs = { - "keyfile": self.keyfile, - "certfile": self.certfile, - "ca_certs": self.ca_certs, - "cert_reqs": self.verify_mode, - "ssl_version": self.protocol, - "server_side": server_side, - } - return wrap_socket(socket, ciphers=self.ciphers, **kwargs) - - -def assert_fingerprint(cert, fingerprint): - """ - Checks if given fingerprint matches the supplied certificate. - - :param cert: - Certificate as bytes object. - :param fingerprint: - Fingerprint as string of hexdigits, can be interspersed by colons. - """ - - fingerprint = fingerprint.replace(":", "").lower() - digest_length = len(fingerprint) - hashfunc = HASHFUNC_MAP.get(digest_length) - if not hashfunc: - raise SSLError("Fingerprint of invalid length: {0}".format(fingerprint)) - - # We need encode() here for py32; works on py2 and p33. - fingerprint_bytes = unhexlify(fingerprint.encode()) - - cert_digest = hashfunc(cert).digest() - - if not _const_compare_digest(cert_digest, fingerprint_bytes): - raise SSLError( - 'Fingerprints did not match. Expected "{0}", got "{1}".'.format( - fingerprint, hexlify(cert_digest) - ) - ) - - -def resolve_cert_reqs(candidate): - """ - Resolves the argument to a numeric constant, which can be passed to - the wrap_socket function/method from the ssl module. - Defaults to :data:`ssl.CERT_REQUIRED`. - If given a string it is assumed to be the name of the constant in the - :mod:`ssl` module or its abbreviation. - (So you can specify `REQUIRED` instead of `CERT_REQUIRED`. - If it's neither `None` nor a string we assume it is already the numeric - constant which can directly be passed to wrap_socket. - """ - if candidate is None: - return CERT_REQUIRED - - if isinstance(candidate, str): - res = getattr(ssl, candidate, None) - if res is None: - res = getattr(ssl, "CERT_" + candidate) - return res - - return candidate - - -def resolve_ssl_version(candidate): - """ - like resolve_cert_reqs - """ - if candidate is None: - return PROTOCOL_TLS - - if isinstance(candidate, str): - res = getattr(ssl, candidate, None) - if res is None: - res = getattr(ssl, "PROTOCOL_" + candidate) - return res - - return candidate - - -def create_urllib3_context( - ssl_version=None, cert_reqs=None, options=None, ciphers=None -): - """All arguments have the same meaning as ``ssl_wrap_socket``. - - By default, this function does a lot of the same work that - ``ssl.create_default_context`` does on Python 3.4+. It: - - - Disables SSLv2, SSLv3, and compression - - Sets a restricted set of server ciphers - - If you wish to enable SSLv3, you can do:: - - from urllib3.util import ssl_ - context = ssl_.create_urllib3_context() - context.options &= ~ssl_.OP_NO_SSLv3 - - You can do the same to enable compression (substituting ``COMPRESSION`` - for ``SSLv3`` in the last line above). - - :param ssl_version: - The desired protocol version to use. This will default to - PROTOCOL_SSLv23 which will negotiate the highest protocol that both - the server and your installation of OpenSSL support. - :param cert_reqs: - Whether to require the certificate verification. This defaults to - ``ssl.CERT_REQUIRED``. - :param options: - Specific OpenSSL options. These default to ``ssl.OP_NO_SSLv2``, - ``ssl.OP_NO_SSLv3``, ``ssl.OP_NO_COMPRESSION``, and ``ssl.OP_NO_TICKET``. - :param ciphers: - Which cipher suites to allow the server to select. - :returns: - Constructed SSLContext object with specified options - :rtype: SSLContext - """ - # 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) - - # Setting the default here, as we may have no ssl module on import - cert_reqs = ssl.CERT_REQUIRED if cert_reqs is None else cert_reqs - - if options is None: - options = 0 - # SSLv2 is easily broken and is considered harmful and dangerous - options |= OP_NO_SSLv2 - # SSLv3 has several problems and is now dangerous - options |= OP_NO_SSLv3 - # Disable compression to prevent CRIME attacks for OpenSSL 1.0+ - # (issue #309) - options |= OP_NO_COMPRESSION - # TLSv1.2 only. Unless set explicitly, do not request tickets. - # This may save some bandwidth on wire, and although the ticket is encrypted, - # there is a risk associated with it being on wire, - # if the server is not rotating its ticketing keys properly. - options |= OP_NO_TICKET - - context.options |= options - - # Enable post-handshake authentication for TLS 1.3, see GH #1634. PHA is - # necessary for conditional client cert authentication with TLS 1.3. - # The attribute is None for OpenSSL <= 1.1.0 or does not exist in older - # versions of Python. We only enable on Python 3.7.4+ or if certificate - # verification is enabled to work around Python issue #37428 - # See: https://bugs.python.org/issue37428 - if (cert_reqs == ssl.CERT_REQUIRED or sys.version_info >= (3, 7, 4)) and getattr( - context, "post_handshake_auth", None - ) is not None: - context.post_handshake_auth = True - - 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. - if hasattr(context, "keylog_filename"): - sslkeylogfile = os.environ.get("SSLKEYLOGFILE") - if sslkeylogfile: - context.keylog_filename = sslkeylogfile - - return context - - -def ssl_wrap_socket( - sock, - keyfile=None, - certfile=None, - cert_reqs=None, - ca_certs=None, - server_hostname=None, - ssl_version=None, - ciphers=None, - ssl_context=None, - ca_cert_dir=None, - key_password=None, - ca_cert_data=None, - tls_in_tls=False, -): - """ - All arguments except for server_hostname, ssl_context, and ca_cert_dir have - the same meaning as they do when using :func:`ssl.wrap_socket`. - - :param server_hostname: - When SNI is supported, the expected hostname of the certificate - :param ssl_context: - A pre-made :class:`SSLContext` object. If none is provided, one will - be created using :func:`create_urllib3_context`. - :param ciphers: - A string of ciphers we wish the client to support. - :param ca_cert_dir: - A directory containing CA certificates in multiple separate files, as - supported by OpenSSL's -CApath flag or the capath argument to - SSLContext.load_verify_locations(). - :param key_password: - Optional password if the keyfile is encrypted. - :param ca_cert_data: - Optional string containing CA certificates in PEM format suitable for - passing as the cadata parameter to SSLContext.load_verify_locations() - :param tls_in_tls: - Use SSLTransport to wrap the existing socket. - """ - context = ssl_context - if context is None: - # Note: This branch of code and all the variables in it are no longer - # used by urllib3 itself. We should consider deprecating and removing - # this code. - context = create_urllib3_context(ssl_version, cert_reqs, ciphers=ciphers) - - if ca_certs or ca_cert_dir or ca_cert_data: - try: - context.load_verify_locations(ca_certs, ca_cert_dir, ca_cert_data) - except (IOError, OSError) as e: - raise SSLError(e) - - elif ssl_context is None and hasattr(context, "load_default_certs"): - # try to load OS default certs; works well on Windows (require Python3.4+) - context.load_default_certs() - - # Attempt to detect if we get the goofy behavior of the - # keyfile being encrypted and OpenSSL asking for the - # passphrase via the terminal and instead error out. - if keyfile and key_password is None and _is_key_file_encrypted(keyfile): - raise SSLError("Client private key is encrypted, password is required") - - if certfile: - if key_password is None: - context.load_cert_chain(certfile, keyfile) - else: - context.load_cert_chain(certfile, keyfile, key_password) - - try: - if hasattr(context, "set_alpn_protocols"): - context.set_alpn_protocols(ALPN_PROTOCOLS) - except NotImplementedError: # Defensive: in CI, we always have set_alpn_protocols - pass - - # If we detect server_hostname is an IP address then the SNI - # extension should not be used according to RFC3546 Section 3.1 - use_sni_hostname = server_hostname and not is_ipaddress(server_hostname) - # SecureTransport uses server_hostname in certificate verification. - send_sni = (use_sni_hostname and HAS_SNI) or ( - IS_SECURETRANSPORT and server_hostname - ) - # Do not warn the user if server_hostname is an invalid SNI hostname. - if not HAS_SNI and use_sni_hostname: - warnings.warn( - "An HTTPS request has been made, but the SNI (Server Name " - "Indication) extension to TLS is not available on this platform. " - "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/1.26.x/advanced-usage.html" - "#ssl-warnings", - SNIMissingWarning, - ) - - if send_sni: - ssl_sock = _ssl_wrap_socket_impl( - sock, context, tls_in_tls, server_hostname=server_hostname - ) - else: - ssl_sock = _ssl_wrap_socket_impl(sock, context, tls_in_tls) - return ssl_sock - - -def is_ipaddress(hostname): - """Detects whether the hostname given is an IPv4 or IPv6 address. - Also detects IPv6 addresses with Zone IDs. - - :param str hostname: Hostname to examine. - :return: True if the hostname is an IP address, False otherwise. - """ - if not six.PY2 and isinstance(hostname, bytes): - # IDN A-label bytes are ASCII compatible. - hostname = hostname.decode("ascii") - return bool(IPV4_RE.match(hostname) or BRACELESS_IPV6_ADDRZ_RE.match(hostname)) - - -def _is_key_file_encrypted(key_file): - """Detects if a key file is encrypted or not.""" - with open(key_file, "r") as f: - for line in f: - # Look for Proc-Type: 4,ENCRYPTED - if "ENCRYPTED" in line: - return True - - return False - - -def _ssl_wrap_socket_impl(sock, ssl_context, tls_in_tls, server_hostname=None): - if tls_in_tls: - if not SSLTransport: - # Import error, ssl is not available. - raise ProxySchemeUnsupported( - "TLS in TLS requires support for the 'ssl' module" - ) - - SSLTransport._validate_ssl_context_for_tls_in_tls(ssl_context) - return SSLTransport(sock, ssl_context, server_hostname) - - if server_hostname: - return ssl_context.wrap_socket(sock, server_hostname=server_hostname) - else: - return ssl_context.wrap_socket(sock) diff --git a/venv/lib/python3.8/site-packages/urllib3/util/ssltransport.py b/venv/lib/python3.8/site-packages/urllib3/util/ssltransport.py deleted file mode 100644 index c2186bc..0000000 --- a/venv/lib/python3.8/site-packages/urllib3/util/ssltransport.py +++ /dev/null @@ -1,221 +0,0 @@ -import io -import socket -import ssl - -from urllib3.exceptions import ProxySchemeUnsupported -from urllib3.packages import six - -SSL_BLOCKSIZE = 16384 - - -class SSLTransport: - """ - The SSLTransport wraps an existing socket and establishes an SSL connection. - - Contrary to Python's implementation of SSLSocket, it allows you to chain - multiple TLS connections together. It's particularly useful if you need to - implement TLS within TLS. - - The class supports most of the socket API operations. - """ - - @staticmethod - def _validate_ssl_context_for_tls_in_tls(ssl_context): - """ - Raises a ProxySchemeUnsupported if the provided ssl_context can't be used - for TLS in TLS. - - The only requirement is that the ssl_context provides the 'wrap_bio' - methods. - """ - - if not hasattr(ssl_context, "wrap_bio"): - if six.PY2: - raise ProxySchemeUnsupported( - "TLS in TLS requires SSLContext.wrap_bio() which isn't " - "supported on Python 2" - ) - else: - raise ProxySchemeUnsupported( - "TLS in TLS requires SSLContext.wrap_bio() which isn't " - "available on non-native SSLContext" - ) - - def __init__( - self, socket, ssl_context, server_hostname=None, suppress_ragged_eofs=True - ): - """ - Create an SSLTransport around socket using the provided ssl_context. - """ - self.incoming = ssl.MemoryBIO() - self.outgoing = ssl.MemoryBIO() - - self.suppress_ragged_eofs = suppress_ragged_eofs - self.socket = socket - - self.sslobj = ssl_context.wrap_bio( - self.incoming, self.outgoing, server_hostname=server_hostname - ) - - # Perform initial handshake. - self._ssl_io_loop(self.sslobj.do_handshake) - - def __enter__(self): - return self - - def __exit__(self, *_): - self.close() - - def fileno(self): - return self.socket.fileno() - - def read(self, len=1024, buffer=None): - return self._wrap_ssl_read(len, buffer) - - def recv(self, len=1024, flags=0): - if flags != 0: - raise ValueError("non-zero flags not allowed in calls to recv") - return self._wrap_ssl_read(len) - - def recv_into(self, buffer, nbytes=None, flags=0): - if flags != 0: - raise ValueError("non-zero flags not allowed in calls to recv_into") - if buffer and (nbytes is None): - nbytes = len(buffer) - elif nbytes is None: - nbytes = 1024 - return self.read(nbytes, buffer) - - def sendall(self, data, flags=0): - if flags != 0: - raise ValueError("non-zero flags not allowed in calls to sendall") - count = 0 - with memoryview(data) as view, view.cast("B") as byte_view: - amount = len(byte_view) - while count < amount: - v = self.send(byte_view[count:]) - count += v - - def send(self, data, flags=0): - if flags != 0: - raise ValueError("non-zero flags not allowed in calls to send") - response = self._ssl_io_loop(self.sslobj.write, data) - return response - - def makefile( - self, mode="r", buffering=None, encoding=None, errors=None, newline=None - ): - """ - Python's httpclient uses makefile and buffered io when reading HTTP - messages and we need to support it. - - This is unfortunately a copy and paste of socket.py makefile with small - changes to point to the socket directly. - """ - if not set(mode) <= {"r", "w", "b"}: - raise ValueError("invalid mode %r (only r, w, b allowed)" % (mode,)) - - writing = "w" in mode - reading = "r" in mode or not writing - assert reading or writing - binary = "b" in mode - rawmode = "" - if reading: - rawmode += "r" - if writing: - rawmode += "w" - raw = socket.SocketIO(self, rawmode) - self.socket._io_refs += 1 - if buffering is None: - buffering = -1 - if buffering < 0: - buffering = io.DEFAULT_BUFFER_SIZE - if buffering == 0: - if not binary: - raise ValueError("unbuffered streams must be binary") - return raw - if reading and writing: - buffer = io.BufferedRWPair(raw, raw, buffering) - elif reading: - buffer = io.BufferedReader(raw, buffering) - else: - assert writing - buffer = io.BufferedWriter(raw, buffering) - if binary: - return buffer - text = io.TextIOWrapper(buffer, encoding, errors, newline) - text.mode = mode - return text - - def unwrap(self): - self._ssl_io_loop(self.sslobj.unwrap) - - def close(self): - self.socket.close() - - def getpeercert(self, binary_form=False): - return self.sslobj.getpeercert(binary_form) - - def version(self): - return self.sslobj.version() - - def cipher(self): - return self.sslobj.cipher() - - def selected_alpn_protocol(self): - return self.sslobj.selected_alpn_protocol() - - def selected_npn_protocol(self): - return self.sslobj.selected_npn_protocol() - - def shared_ciphers(self): - return self.sslobj.shared_ciphers() - - def compression(self): - return self.sslobj.compression() - - def settimeout(self, value): - self.socket.settimeout(value) - - def gettimeout(self): - return self.socket.gettimeout() - - def _decref_socketios(self): - self.socket._decref_socketios() - - def _wrap_ssl_read(self, len, buffer=None): - try: - return self._ssl_io_loop(self.sslobj.read, len, buffer) - except ssl.SSLError as e: - if e.errno == ssl.SSL_ERROR_EOF and self.suppress_ragged_eofs: - return 0 # eof, return 0. - else: - raise - - def _ssl_io_loop(self, func, *args): - """Performs an I/O loop between incoming/outgoing and the socket.""" - should_loop = True - ret = None - - while should_loop: - errno = None - try: - ret = func(*args) - except ssl.SSLError as e: - if e.errno not in (ssl.SSL_ERROR_WANT_READ, ssl.SSL_ERROR_WANT_WRITE): - # WANT_READ, and WANT_WRITE are expected, others are not. - raise e - errno = e.errno - - buf = self.outgoing.read() - self.socket.sendall(buf) - - if errno is None: - should_loop = False - elif errno == ssl.SSL_ERROR_WANT_READ: - buf = self.socket.recv(SSL_BLOCKSIZE) - if buf: - self.incoming.write(buf) - else: - self.incoming.write_eof() - return ret diff --git a/venv/lib/python3.8/site-packages/urllib3/util/timeout.py b/venv/lib/python3.8/site-packages/urllib3/util/timeout.py deleted file mode 100644 index ff69593..0000000 --- a/venv/lib/python3.8/site-packages/urllib3/util/timeout.py +++ /dev/null @@ -1,268 +0,0 @@ -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 - -from ..exceptions import TimeoutStateError - -# A sentinel value to indicate that no timeout was specified by the user in -# urllib3 -_Default = object() - - -# Use time.monotonic if available. -current_time = getattr(time, "monotonic", time.time) - - -class Timeout(object): - """Timeout configuration. - - Timeouts can be defined as a default for a pool: - - .. code-block:: python - - timeout = Timeout(connect=2.0, read=7.0) - http = PoolManager(timeout=timeout) - response = http.request('GET', 'http://example.com/') - - Or per-request (which overrides the default for the pool): - - .. code-block:: python - - response = http.request('GET', 'http://example.com/', timeout=Timeout(10)) - - Timeouts can be disabled by setting all the parameters to ``None``: - - .. code-block:: python - - no_timeout = Timeout(connect=None, read=None) - response = http.request('GET', 'http://example.com/, timeout=no_timeout) - - - :param total: - This combines the connect and read timeouts into one; the read timeout - will be set to the time leftover from the connect attempt. In the - event that both a connect timeout and a total are specified, or a read - timeout and a total are specified, the shorter timeout will be applied. - - Defaults to None. - - :type total: int, float, or None - - :param connect: - The maximum amount of time (in seconds) to wait for a connection - attempt to a server to succeed. Omitting the parameter will default the - connect timeout to the system default, probably `the global default - timeout in socket.py - `_. - None will set an infinite timeout for connection attempts. - - :type connect: int, float, or None - - :param read: - The maximum amount of time (in seconds) to wait between consecutive - read operations for a response from the server. Omitting the parameter - will default the read timeout to the system default, probably `the - global default timeout in socket.py - `_. - None will set an infinite timeout. - - :type read: int, float, or None - - .. note:: - - Many factors can affect the total amount of time for urllib3 to return - an HTTP response. - - For example, Python's DNS resolver does not obey the timeout specified - on the socket. Other factors that can affect total request time include - high CPU load, high swap, the program running at a low priority level, - or other behaviors. - - In addition, the read and total timeouts only measure the time between - read operations on the socket connecting the client and the server, - not the total amount of time for the request to return a complete - response. For most requests, the timeout is raised because the server - has not sent the first byte in the specified time. This is not always - the case; if a server streams one byte every fifteen seconds, a timeout - of 20 seconds will not trigger, even though the request will take - several minutes to complete. - - If your goal is to cut off any request after a set amount of wall clock - time, consider having a second "watcher" thread to cut off a slow - request. - """ - - #: A sentinel object representing the default timeout value - DEFAULT_TIMEOUT = _GLOBAL_DEFAULT_TIMEOUT - - def __init__(self, total=None, connect=_Default, read=_Default): - self._connect = self._validate_timeout(connect, "connect") - self._read = self._validate_timeout(read, "read") - self.total = self._validate_timeout(total, "total") - self._start_connect = None - - def __repr__(self): - return "%s(connect=%r, read=%r, total=%r)" % ( - type(self).__name__, - self._connect, - self._read, - self.total, - ) - - # __str__ provided for backwards compatibility - __str__ = __repr__ - - @classmethod - def _validate_timeout(cls, value, name): - """Check that a timeout attribute is valid. - - :param value: The timeout value to validate - :param name: The name of the timeout attribute to validate. This is - used to specify in error messages. - :return: The validated and casted version of the given value. - :raises ValueError: If it is a numeric value less than or equal to - zero, or the type is not an integer, float, or None. - """ - if value is _Default: - return cls.DEFAULT_TIMEOUT - - if value is None or value is cls.DEFAULT_TIMEOUT: - return value - - if isinstance(value, bool): - raise ValueError( - "Timeout cannot be a boolean value. It must " - "be an int, float or None." - ) - try: - float(value) - except (TypeError, ValueError): - raise ValueError( - "Timeout value %s was %s, but it must be an " - "int, float or None." % (name, value) - ) - - try: - if value <= 0: - raise ValueError( - "Attempted to set %s timeout to %s, but the " - "timeout cannot be set to a value less " - "than or equal to 0." % (name, value) - ) - except TypeError: - # Python 3 - raise ValueError( - "Timeout value %s was %s, but it must be an " - "int, float or None." % (name, value) - ) - - return value - - @classmethod - def from_float(cls, timeout): - """Create a new Timeout from a legacy timeout value. - - The timeout value used by httplib.py sets the same timeout on the - connect(), and recv() socket requests. This creates a :class:`Timeout` - object that sets the individual timeouts to the ``timeout`` value - passed to this function. - - :param timeout: The legacy timeout value. - :type timeout: integer, float, sentinel default object, or None - :return: Timeout object - :rtype: :class:`Timeout` - """ - return Timeout(read=timeout, connect=timeout) - - def clone(self): - """Create a copy of the timeout object - - Timeout properties are stored per-pool but each request needs a fresh - Timeout object to ensure each one has its own start/stop configured. - - :return: a copy of the timeout object - :rtype: :class:`Timeout` - """ - # We can't use copy.deepcopy because that will also create a new object - # for _GLOBAL_DEFAULT_TIMEOUT, which socket.py uses as a sentinel to - # detect the user default. - return Timeout(connect=self._connect, read=self._read, total=self.total) - - def start_connect(self): - """Start the timeout clock, used during a connect() attempt - - :raises urllib3.exceptions.TimeoutStateError: if you attempt - to start a timer that has been started already. - """ - if self._start_connect is not None: - raise TimeoutStateError("Timeout timer has already been started.") - self._start_connect = current_time() - return self._start_connect - - def get_connect_duration(self): - """Gets the time elapsed since the call to :meth:`start_connect`. - - :return: Elapsed time in seconds. - :rtype: float - :raises urllib3.exceptions.TimeoutStateError: if you attempt - to get duration for a timer that hasn't been started. - """ - if self._start_connect is None: - raise TimeoutStateError( - "Can't get connect duration for timer that has not started." - ) - return current_time() - self._start_connect - - @property - def connect_timeout(self): - """Get the value to use when setting a connection timeout. - - This will be a positive float or integer, the value None - (never timeout), or the default system timeout. - - :return: Connect timeout. - :rtype: int, float, :attr:`Timeout.DEFAULT_TIMEOUT` or None - """ - if self.total is None: - return self._connect - - if self._connect is None or self._connect is self.DEFAULT_TIMEOUT: - return self.total - - return min(self._connect, self.total) - - @property - def read_timeout(self): - """Get the value for the read timeout. - - This assumes some time has elapsed in the connection timeout and - computes the read timeout appropriately. - - If self.total is set, the read timeout is dependent on the amount of - time taken by the connect timeout. If the connection time has not been - established, a :exc:`~urllib3.exceptions.TimeoutStateError` will be - raised. - - :return: Value to use for the read timeout. - :rtype: int, float, :attr:`Timeout.DEFAULT_TIMEOUT` or None - :raises urllib3.exceptions.TimeoutStateError: If :meth:`start_connect` - has not yet been called on this object. - """ - if ( - self.total is not None - and self.total is not self.DEFAULT_TIMEOUT - and self._read is not None - and self._read is not self.DEFAULT_TIMEOUT - ): - # In case the connect timeout has not yet been established. - if self._start_connect is None: - return self._read - return max(0, min(self.total - self.get_connect_duration(), self._read)) - elif self.total is not None and self.total is not self.DEFAULT_TIMEOUT: - return max(0, self.total - self.get_connect_duration()) - else: - return self._read diff --git a/venv/lib/python3.8/site-packages/urllib3/util/url.py b/venv/lib/python3.8/site-packages/urllib3/util/url.py deleted file mode 100644 index 81a03da..0000000 --- a/venv/lib/python3.8/site-packages/urllib3/util/url.py +++ /dev/null @@ -1,432 +0,0 @@ -from __future__ import absolute_import - -import re -from collections import namedtuple - -from ..exceptions import LocationParseError -from ..packages import six - -url_attrs = ["scheme", "auth", "host", "port", "path", "query", "fragment"] - -# We only want to normalize urls with an HTTP(S) scheme. -# urllib3 infers URLs without a scheme (None) to be http. -NORMALIZABLE_SCHEMES = ("http", "https", None) - -# Almost all of these patterns were derived from the -# 'rfc3986' module: https://github.com/python-hyper/rfc3986 -PERCENT_RE = re.compile(r"%[a-fA-F0-9]{2}") -SCHEME_RE = re.compile(r"^(?:[a-zA-Z][a-zA-Z0-9+-]*:|/)") -URI_RE = re.compile( - r"^(?:([a-zA-Z][a-zA-Z0-9+.-]*):)?" - r"(?://([^\\/?#]*))?" - r"([^?#]*)" - r"(?:\?([^#]*))?" - r"(?:#(.*))?$", - re.UNICODE | re.DOTALL, -) - -IPV4_PAT = r"(?:[0-9]{1,3}\.){3}[0-9]{1,3}" -HEX_PAT = "[0-9A-Fa-f]{1,4}" -LS32_PAT = "(?:{hex}:{hex}|{ipv4})".format(hex=HEX_PAT, ipv4=IPV4_PAT) -_subs = {"hex": HEX_PAT, "ls32": LS32_PAT} -_variations = [ - # 6( h16 ":" ) ls32 - "(?:%(hex)s:){6}%(ls32)s", - # "::" 5( h16 ":" ) ls32 - "::(?:%(hex)s:){5}%(ls32)s", - # [ h16 ] "::" 4( h16 ":" ) ls32 - "(?:%(hex)s)?::(?:%(hex)s:){4}%(ls32)s", - # [ *1( h16 ":" ) h16 ] "::" 3( h16 ":" ) ls32 - "(?:(?:%(hex)s:)?%(hex)s)?::(?:%(hex)s:){3}%(ls32)s", - # [ *2( h16 ":" ) h16 ] "::" 2( h16 ":" ) ls32 - "(?:(?:%(hex)s:){0,2}%(hex)s)?::(?:%(hex)s:){2}%(ls32)s", - # [ *3( h16 ":" ) h16 ] "::" h16 ":" ls32 - "(?:(?:%(hex)s:){0,3}%(hex)s)?::%(hex)s:%(ls32)s", - # [ *4( h16 ":" ) h16 ] "::" ls32 - "(?:(?:%(hex)s:){0,4}%(hex)s)?::%(ls32)s", - # [ *5( h16 ":" ) h16 ] "::" h16 - "(?:(?:%(hex)s:){0,5}%(hex)s)?::%(hex)s", - # [ *6( h16 ":" ) h16 ] "::" - "(?:(?:%(hex)s:){0,6}%(hex)s)?::", -] - -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")?\]" -REG_NAME_PAT = r"(?:[^\[\]%:/?#]|%[a-fA-F0-9]{2})*" -TARGET_RE = re.compile(r"^(/[^?#]*)(?:\?([^#]*))?(?:#.*)?$") - -IPV4_RE = re.compile("^" + IPV4_PAT + "$") -IPV6_RE = re.compile("^" + IPV6_PAT + "$") -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")\]$") - -_HOST_PORT_PAT = ("^(%s|%s|%s)(?::([0-9]{0,5}))?$") % ( - REG_NAME_PAT, - IPV4_PAT, - IPV6_ADDRZ_PAT, -) -_HOST_PORT_RE = re.compile(_HOST_PORT_PAT, re.UNICODE | re.DOTALL) - -UNRESERVED_CHARS = set( - "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789._-~" -) -SUB_DELIM_CHARS = set("!$&'()*+,;=") -USERINFO_CHARS = UNRESERVED_CHARS | SUB_DELIM_CHARS | {":"} -PATH_CHARS = USERINFO_CHARS | {"@", "/"} -QUERY_CHARS = FRAGMENT_CHARS = PATH_CHARS | {"?"} - - -class Url(namedtuple("Url", url_attrs)): - """ - Data structure for representing an HTTP URL. Used as a return value for - :func:`parse_url`. Both the scheme and host are normalized as they are - both case-insensitive according to RFC 3986. - """ - - __slots__ = () - - def __new__( - cls, - scheme=None, - auth=None, - host=None, - port=None, - path=None, - query=None, - fragment=None, - ): - if path and not path.startswith("/"): - path = "/" + path - if scheme is not None: - scheme = scheme.lower() - return super(Url, cls).__new__( - cls, scheme, auth, host, port, path, query, fragment - ) - - @property - def hostname(self): - """For backwards-compatibility with urlparse. We're nice like that.""" - return self.host - - @property - def request_uri(self): - """Absolute path including the query string.""" - uri = self.path or "/" - - if self.query is not None: - uri += "?" + self.query - - return uri - - @property - def netloc(self): - """Network location including host and port""" - if self.port: - return "%s:%d" % (self.host, self.port) - return self.host - - @property - def url(self): - """ - Convert self into a url - - This function should more or less round-trip with :func:`.parse_url`. The - returned url may not be exactly the same as the url inputted to - :func:`.parse_url`, but it should be equivalent by the RFC (e.g., urls - with a blank port will have : removed). - - Example: :: - - >>> U = parse_url('http://google.com/mail/') - >>> U.url - 'http://google.com/mail/' - >>> Url('http', 'username:password', 'host.com', 80, - ... '/path', 'query', 'fragment').url - 'http://username:password@host.com:80/path?query#fragment' - """ - scheme, auth, host, port, path, query, fragment = self - url = u"" - - # We use "is not None" we want things to happen with empty strings (or 0 port) - if scheme is not None: - url += scheme + u"://" - if auth is not None: - url += auth + u"@" - if host is not None: - url += host - if port is not None: - url += u":" + str(port) - if path is not None: - url += path - if query is not None: - url += u"?" + query - if fragment is not None: - url += u"#" + fragment - - return url - - def __str__(self): - return self.url - - -def split_first(s, delims): - """ - .. deprecated:: 1.25 - - Given a string and an iterable of delimiters, split on the first found - delimiter. Return two split parts and the matched delimiter. - - If not found, then the first part is the full input string. - - Example:: - - >>> split_first('foo/bar?baz', '?/=') - ('foo', 'bar?baz', '/') - >>> split_first('foo/bar?baz', '123') - ('foo/bar?baz', '', None) - - Scales linearly with number of delims. Not ideal for large number of delims. - """ - min_idx = None - min_delim = None - for d in delims: - idx = s.find(d) - if idx < 0: - continue - - if min_idx is None or idx < min_idx: - min_idx = idx - min_delim = d - - if min_idx is None or min_idx < 0: - return s, "", None - - return s[:min_idx], s[min_idx + 1 :], min_delim - - -def _encode_invalid_chars(component, allowed_chars, encoding="utf-8"): - """Percent-encodes a URI component without reapplying - onto an already percent-encoded component. - """ - if component is None: - return component - - component = six.ensure_text(component) - - # Normalize existing percent-encoded bytes. - # Try to see if the component we're encoding is already percent-encoded - # so we can skip all '%' characters but still encode all others. - component, percent_encodings = PERCENT_RE.subn( - lambda match: match.group(0).upper(), component - ) - - uri_bytes = component.encode("utf-8", "surrogatepass") - is_percent_encoded = percent_encodings == uri_bytes.count(b"%") - encoded_component = bytearray() - - for i in range(0, len(uri_bytes)): - # Will return a single character bytestring on both Python 2 & 3 - byte = uri_bytes[i : i + 1] - byte_ord = ord(byte) - if (is_percent_encoded and byte == b"%") or ( - byte_ord < 128 and byte.decode() in allowed_chars - ): - encoded_component += byte - continue - encoded_component.extend(b"%" + (hex(byte_ord)[2:].encode().zfill(2).upper())) - - return encoded_component.decode(encoding) - - -def _remove_path_dot_segments(path): - # See http://tools.ietf.org/html/rfc3986#section-5.2.4 for pseudo-code - segments = path.split("/") # Turn the path into a list of segments - output = [] # Initialize the variable to use to store output - - for segment in segments: - # '.' is the current directory, so ignore it, it is superfluous - if segment == ".": - continue - # Anything other than '..', should be appended to the output - elif segment != "..": - output.append(segment) - # In this case segment == '..', if we can, we should pop the last - # element - elif output: - output.pop() - - # If the path starts with '/' and the output is empty or the first string - # is non-empty - if path.startswith("/") and (not output or output[0]): - output.insert(0, "") - - # If the path starts with '/.' or '/..' ensure we add one more empty - # string to add a trailing '/' - if path.endswith(("/.", "/..")): - output.append("") - - return "/".join(output) - - -def _normalize_host(host, scheme): - if host: - if isinstance(host, six.binary_type): - host = six.ensure_str(host) - - if scheme in NORMALIZABLE_SCHEMES: - is_ipv6 = IPV6_ADDRZ_RE.match(host) - if is_ipv6: - match = ZONE_ID_RE.search(host) - if match: - start, end = match.span(1) - zone_id = host[start:end] - - if zone_id.startswith("%25") and zone_id != "%25": - zone_id = zone_id[3:] - else: - zone_id = zone_id[1:] - zone_id = "%" + _encode_invalid_chars(zone_id, UNRESERVED_CHARS) - return host[:start].lower() + zone_id + host[end:] - else: - return host.lower() - elif not IPV4_RE.match(host): - return six.ensure_str( - b".".join([_idna_encode(label) for label in host.split(".")]) - ) - return host - - -def _idna_encode(name): - if name and any([ord(x) > 128 for x in name]): - try: - import idna - except ImportError: - six.raise_from( - LocationParseError("Unable to parse URL without the 'idna' module"), - None, - ) - try: - return idna.encode(name.lower(), strict=True, std3_rules=True) - except idna.IDNAError: - six.raise_from( - LocationParseError(u"Name '%s' is not a valid IDNA label" % name), None - ) - return name.lower().encode("ascii") - - -def _encode_target(target): - """Percent-encodes a request target so that there are no invalid characters""" - path, query = TARGET_RE.match(target).groups() - target = _encode_invalid_chars(path, PATH_CHARS) - query = _encode_invalid_chars(query, QUERY_CHARS) - if query is not None: - target += "?" + query - return target - - -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. - - The parser logic and helper functions are based heavily on - work done in the ``rfc3986`` module. - - :param str url: URL to parse into a :class:`.Url` namedtuple. - - Partly backwards-compatible with :mod:`urlparse`. - - Example:: - - >>> parse_url('http://google.com/mail/') - Url(scheme='http', host='google.com', port=None, path='/mail/', ...) - >>> parse_url('google.com:80') - Url(scheme=None, host='google.com', port=80, path=None, ...) - >>> parse_url('/foo?bar') - Url(scheme=None, host=None, port=None, path='/foo', query='bar', ...) - """ - if not url: - # Empty - return Url() - - source_url = url - if not SCHEME_RE.search(url): - url = "//" + url - - try: - scheme, authority, path, query, fragment = URI_RE.match(url).groups() - normalize_uri = scheme is None or scheme.lower() in NORMALIZABLE_SCHEMES - - if scheme: - scheme = scheme.lower() - - if authority: - 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 == "": - port = None - else: - auth, host, port = None, None, None - - if port is not None: - port = int(port) - if not (0 <= port <= 65535): - raise LocationParseError(url) - - host = _normalize_host(host, scheme) - - if normalize_uri and path: - path = _remove_path_dot_segments(path) - path = _encode_invalid_chars(path, PATH_CHARS) - if normalize_uri and query: - query = _encode_invalid_chars(query, QUERY_CHARS) - if normalize_uri and fragment: - fragment = _encode_invalid_chars(fragment, FRAGMENT_CHARS) - - except (ValueError, AttributeError): - return six.raise_from(LocationParseError(source_url), None) - - # For the sake of backwards compatibility we put empty - # string values for path if there are any defined values - # beyond the path in the URL. - # TODO: Remove this when we break backwards compatibility. - if not path: - if query is not None or fragment is not None: - path = "" - else: - path = None - - # Ensure that each part of the URL is a `str` for - # backwards compatibility. - if isinstance(url, six.text_type): - ensure_func = six.ensure_text - else: - ensure_func = six.ensure_str - - def ensure_type(x): - return x if x is None else ensure_func(x) - - return Url( - scheme=ensure_type(scheme), - auth=ensure_type(auth), - host=ensure_type(host), - port=port, - path=ensure_type(path), - query=ensure_type(query), - fragment=ensure_type(fragment), - ) - - -def get_host(url): - """ - Deprecated. Use :func:`parse_url` instead. - """ - p = parse_url(url) - return p.scheme or "http", p.hostname, p.port diff --git a/venv/lib/python3.8/site-packages/urllib3/util/wait.py b/venv/lib/python3.8/site-packages/urllib3/util/wait.py deleted file mode 100644 index c280646..0000000 --- a/venv/lib/python3.8/site-packages/urllib3/util/wait.py +++ /dev/null @@ -1,153 +0,0 @@ -import errno -import select -import sys -from functools import partial - -try: - from time import monotonic -except ImportError: - from time import time as monotonic - -__all__ = ["NoWayToWaitForSocketError", "wait_for_read", "wait_for_write"] - - -class NoWayToWaitForSocketError(Exception): - pass - - -# How should we wait on sockets? -# -# There are two types of APIs you can use for waiting on sockets: the fancy -# modern stateful APIs like epoll/kqueue, and the older stateless APIs like -# select/poll. The stateful APIs are more efficient when you have a lots of -# sockets to keep track of, because you can set them up once and then use them -# lots of times. But we only ever want to wait on a single socket at a time -# and don't want to keep track of state, so the stateless APIs are actually -# more efficient. So we want to use select() or poll(). -# -# Now, how do we choose between select() and poll()? On traditional Unixes, -# select() has a strange calling convention that makes it slow, or fail -# altogether, for high-numbered file descriptors. The point of poll() is to fix -# that, so on Unixes, we prefer poll(). -# -# On Windows, there is no poll() (or at least Python doesn't provide a wrapper -# for it), but that's OK, because on Windows, select() doesn't have this -# strange calling convention; plain select() works fine. -# -# So: on Windows we use select(), and everywhere else we use poll(). We also -# fall back to select() in case poll() is somehow broken or missing. - -if sys.version_info >= (3, 5): - # Modern Python, that retries syscalls by default - def _retry_on_intr(fn, timeout): - return fn(timeout) - - -else: - # Old and broken Pythons. - def _retry_on_intr(fn, timeout): - if timeout is None: - deadline = float("inf") - else: - deadline = monotonic() + timeout - - while True: - try: - return fn(timeout) - # OSError for 3 <= pyver < 3.5, select.error for pyver <= 2.7 - except (OSError, select.error) as e: - # 'e.args[0]' incantation works for both OSError and select.error - if e.args[0] != errno.EINTR: - raise - else: - timeout = deadline - monotonic() - if timeout < 0: - timeout = 0 - if timeout == float("inf"): - timeout = None - continue - - -def select_wait_for_socket(sock, read=False, write=False, timeout=None): - if not read and not write: - raise RuntimeError("must specify at least one of read=True, write=True") - rcheck = [] - wcheck = [] - if read: - rcheck.append(sock) - if write: - wcheck.append(sock) - # When doing a non-blocking connect, most systems signal success by - # marking the socket writable. Windows, though, signals success by marked - # it as "exceptional". We paper over the difference by checking the write - # sockets for both conditions. (The stdlib selectors module does the same - # thing.) - fn = partial(select.select, rcheck, wcheck, wcheck) - rready, wready, xready = _retry_on_intr(fn, timeout) - return bool(rready or wready or xready) - - -def poll_wait_for_socket(sock, read=False, write=False, timeout=None): - if not read and not write: - raise RuntimeError("must specify at least one of read=True, write=True") - mask = 0 - if read: - mask |= select.POLLIN - if write: - mask |= select.POLLOUT - poll_obj = select.poll() - poll_obj.register(sock, mask) - - # For some reason, poll() takes timeout in milliseconds - def do_poll(t): - if t is not None: - t *= 1000 - return poll_obj.poll(t) - - return bool(_retry_on_intr(do_poll, timeout)) - - -def null_wait_for_socket(*args, **kwargs): - raise NoWayToWaitForSocketError("no select-equivalent available") - - -def _have_working_poll(): - # Apparently some systems have a select.poll that fails as soon as you try - # to use it, either due to strange configuration or broken monkeypatching - # from libraries like eventlet/greenlet. - try: - poll_obj = select.poll() - _retry_on_intr(poll_obj.poll, 0) - except (AttributeError, OSError): - return False - else: - return True - - -def wait_for_socket(*args, **kwargs): - # We delay choosing which implementation to use until the first time we're - # called. We could do it at import time, but then we might make the wrong - # decision if someone goes wild with monkeypatching select.poll after - # we're imported. - global wait_for_socket - if _have_working_poll(): - wait_for_socket = poll_wait_for_socket - elif hasattr(select, "select"): - wait_for_socket = select_wait_for_socket - else: # Platform-specific: Appengine. - wait_for_socket = null_wait_for_socket - return wait_for_socket(*args, **kwargs) - - -def wait_for_read(sock, timeout=None): - """Waits for reading to be available on a given socket. - Returns True if the socket is readable, or False if the timeout expired. - """ - return wait_for_socket(sock, read=True, timeout=timeout) - - -def wait_for_write(sock, timeout=None): - """Waits for writing to be available on a given socket. - Returns True if the socket is readable, or False if the timeout expired. - """ - return wait_for_socket(sock, write=True, timeout=timeout) diff --git a/venv/lib64 b/venv/lib64 deleted file mode 120000 index 7951405..0000000 --- a/venv/lib64 +++ /dev/null @@ -1 +0,0 @@ -lib \ No newline at end of file diff --git a/venv/pyvenv.cfg b/venv/pyvenv.cfg deleted file mode 100644 index 853404e..0000000 --- a/venv/pyvenv.cfg +++ /dev/null @@ -1,3 +0,0 @@ -home = /usr/bin -include-system-site-packages = false -version = 3.8.10 diff --git a/venv/share/python-wheels/CacheControl-0.12.6-py2.py3-none-any.whl b/venv/share/python-wheels/CacheControl-0.12.6-py2.py3-none-any.whl deleted file mode 100644 index 69e46f489d3d286241a238ef91f81582a1210907..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 28023 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%0A_-uQ2C75bZ}x=BDA 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 diff --git a/venv/share/python-wheels/contextlib2-0.6.0-py2.py3-none-any.whl b/venv/share/python-wheels/contextlib2-0.6.0-py2.py3-none-any.whl deleted file mode 100644 index 5d08a03a6ce658e25d62fa7d96a631da53faef14..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 17188 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%0D(-|d4ev*;#QfHo;5)Q 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 QTvUN}@a=;gcQUCw| diff --git a/venv/share/python-wheels/distro-1.4.0-py2.py3-none-any.whl b/venv/share/python-wheels/distro-1.4.0-py2.py3-none-any.whl deleted file mode 100644 index e94a3a498b11426479171ecac558e7eaa2b9ee40..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 23898 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 P&oKYvEAJToXZC*p%F?U3 diff --git a/venv/share/python-wheels/html5lib-1.0.1-py2.py3-none-any.whl b/venv/share/python-wheels/html5lib-1.0.1-py2.py3-none-any.whl deleted file mode 100644 index f56e2979af697043882883ee1af06b30bb6edf83..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 120020 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

d;h|Tyf2BJx$F58r)qn+s_Wb7PG~VS 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 diff --git a/venv/share/python-wheels/lockfile-0.12.2-py2.py3-none-any.whl b/venv/share/python-wheels/lockfile-0.12.2-py2.py3-none-any.whl deleted file mode 100644 index 4d2a1c63aaf03c39583a76ca58a604b198d2ed89..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 21972 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�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 WreC%X;pQn(48qG^m>{b_1qOI>gfV6 zN_VbjtY1BAw0deel4&Eop8cVEJ=I!&uEC3PHkj%ePxW-7df4?S)^~vZzA0vo#7=H8 zeH2W_E#{CS54y!fri+lQZxSQY_Dv`FMv9TiK}^4 zvm}w*`8$m3SF|ad!Bv;qwW_=R&#G5zRVNr#$8puaimESbRo~53zoA#%=zmr{U90+^ z7JAjOT=i~Ib-7mc4Wd(Rse09=&Hq=`4z239vFagouBLL;--)U%R#ElWT=kg{t?I$j z|EjuMxTrd&k>2ZQu6jE`27r^(`~9Xh7QVv}#=IPCq-e_v67yiYn{jy4!PEFF3M~Kf_Www<0E(5AB>)y$pQ{oAfquK@IQ=sX)wRX;rQ$Edo0Rs8}NH-ZC(VRigcj?-GG_IKTJ!qI6r+;TQq0J}M)jO`rc6Do*C zKN`VAjiTIXo=ZwE&P+NhEj!(SsOY>#&IQ#Njv}o9pPABq*E8i0QLP#XwM=;n!%q@23rN6sFD;QZ66oGAyyCF%PpnDstXKZDIdL& z@pz6kgD0k|L#eritHi;<+C#S2-0Pn+?yd;b_WGod|Ao6-G!^hNlW_M8#@!yYWp|eS4M!<_>_L(6Q2+uWQMxon z*x5zI#%IWK!k&mjH3LN|MrS;0NhyX;Nuc9KTD63OB4G_DjMWpY6%-YEJW+gIDl|SD zp6CyR;cov84)yF!=0jZ%3GJqamC;o-Y$YKVMk9s&i2V*kI}@ZeYLmuq}yaoQju&CXAt>v9E;>9Th7&{Ot`lyZ%p)l=$M za*9P<1yl7DS0xkb(d<;J(#)^L`^3BD#(j?CW4ST>vXh0e2RpMk&?Jm4Ysz6fb`rn6 zqA6bHzh6hY7j>7^Y_JmcU3lg5UQU-+}lYX?$O+fbVnV zhCSl=m}tUxo&WwYK8&LACat)7_s^hPi_NP}I z?Ak%pu3W^?A(QPf!i;=)1yA>ONX z4}w*O*rT#mqfTSh)}%kF&9__P`F7xZzgpis-<>LINCb`!NYHQ=7VV9?6kGC^4c5@oT24!j?(nEAJWuM!10?rDU2YxjyW?x)!l_M`6rU%iR= zY82tC&UacZqZnT`zZ3CQ1UxZa&9ZWRaRLZDt+Bq!Qc+(r*Ea&|dk5WKT%(-hIa47`aag`vvGZ)Slm->zhIK<-rrv)z8IvQ~7Ek zd3s`f4{P=9=K$rKw?cjEvA(fXUmqwwR`9>5z7Fuj^pbHx|1?XSWvSvU%W`?g#;R{$ z$Mq$4*e`HEsI}Fa{sT5}Hy+kcQUkwtuv(tv26lBI{RenrI_o8b#coB+nDWO8*af~J znhVQ_YQaw)&+EqbdN5#Pe_hqr^_&*k-p?#&hJA4BU8 zPfS;l>!!>qGib`s%b8V}qa3qJ?<&U<*@`vGx=@ijpxy#$ZT8f4}H^hBF^Hif2U!?t`kz(o_?62LMa3zWe=9cY< zV6M8uAejGbzy$NFee^~6gjlmtzX4`0I0VG=mQ1`R*@i>mOhW5X_fW4=;dzLN>#%j3 zX#ahT+L>Xl+S&pK-iBAu7^0d|?q={@LBq47b~fII2UL?|7?^>W&3Hs#M(=!^iN{;n2Q@p<^s1>@3olP-q|ZQ2@_wim951?z!&%z`$<8=D#d zKL~xUXbqou2eoz-7PoQ8+tKw$=yqaYsp%K$#5=qEFZmBR%8oMR9=)#HA3H9>o;@k- zs-C=D!}6VP7+<3Q8%!TWZUVPoOzo$b1hkAB&=#>WL{#jq4?LC7)%Za)Q1 zM3&ivO$ws)J-$8)5zR;N#B}vE6Dtj{K%P;+XB2pj3e1EjrmJ6-@&4*^**H)Cyus&b zxZ*j_=V>@O1jEyG!wvK|_Yds6Pj2|dFTP}yKOo9SD;c7Ev?1v8e1J7f#v0x<=0jO; zDqpOZx0%bwnR?Jw>wzBc&{Y1iUVdkZsXU7~J-e{{c@@fUHI?sTDsL&(%6rV^Q@Q+M zEdL3X|It*w6<|}P<9UHI=Uk^{@O%l&kbuX+OSBBZ0Ie_aGF+o*OjqEE>1x+f%}*Ad z>ji=0T=%>eNIb&U=$NkXY#V3jF7?yXs84sBeBOsJo1^e#8$iHL`8V~-8Ixacq8If1 zZw3+$MkxlO;n3Z*KsS>iK`XUH({gj(`4zdj83`%b%*Q)AMTr zbk%)EJMT%)K;5r@v&_2XS?xQOz9*a&^uR9>L=V(!N%TNT3xgi$Zex02QBR#7xSNQw zs2zZT3x-DGJ|cP`0}5v|JNEkXu5F-UzZR;YF`$fn}=U ziRo(Z>n3_M;STQK6D_EJgH8QIOJ?E+#OwY0iCkw#;R#Xj6ZUT$_3wQsJdXSK61BA) zo|vu<7X5>HXiDt_a66|=YVnIjJM)Zo{=@BT{R~6&VLL;qofIfMl-ub{?O-q_Ojl2_ zeV9^GQbVec))H-AW?~(wc)yuU^HLFMwM^!DIZL6CPQw$^)wb8n^U{d>dw(SLx0k8E zp`yS0~7COk1+?NzGN8%NK;p8n4@5&!3$pf@tE zk^ZbVH^zZVIuD!{k{PL*obnEgR!3e2gz(5YzK!=)sC=D0+g{P=@m}YcOEUE``;|5C zSx4C)xNRT6`s$x!T0T*I20oYj?+qrF64gg8>wJ)7XE}eIy7J%h$EmZ7{Od*jR5kd@ zzvNF@ljw0;Cz4)=#)T>FPew zwQJB3^@PG7XYu1Fa~tDLZ4A3gZEX7l+W5@4n58w-FJ|4Tjjr&-bam2Y(*7xa4*l(( zVNTIO_)WbZZ>*tb1=A&+HM%PlI`0oYM`XRy8OPg+o$IW|8l0krmWvt`9L->=A*w!h`WNFOvm`>l$UGZ?ot^n)y;LJv%9H|biSbiU%?a8)u~*d85US#?D|)m>bu@e1)hf|rmHEuv}Zns z0wWFi$i$|)eB=QtFchAct}cOFrZVYdjfR&r|6R3kJCjRw?HgvWnpAF(Sd8E1wVlRT z8*nB$2&utK7QT>b27F{|zmC;jaSY`b^{d$TFZf?i|nsI@enL|1bYp{p&{X`93TW<^nLvBM+sIIRv$%12v>pvqB$LXNZ zxy?e5%{(aFL6MZu28~#SIMBnGgkI2!$bTy$B9e2+lVK_hea!tK785X$Bp-Q8o5)8F z)e~$2GFFoRD%doKPWh56IVJoIg9u83B~LM+!A!Z#>6;g+sUn;}`-S^kAR13NbsC)j z?=a#qppr4`<}j3-ObXlHZ9%yLR-EqV+}7;>A>xa06arS}CK`daH23gNhvQ5w{hsvI zO2YAcCO?F`gkCcSO({*DQQbXz5YH7brR4PFh;el$qwh&KLt-svxcw>{oUOTZ!AvxE888(-FBX`pjAZl zUdgkCM(2n`AA-NT&;zPBH9SrJjkUlKdf&IOy#kv75ko^bU!Z+z+Bb)q*MxjWaWvKgjR-+WvQWxeRB0n5Kj+LSc;S1!d$F#EXzNiaO*VN!q|QFHV;N zoHBGyhR(@PMI#iGyQ+)IXAumylT7h1_Z{bX-AV2;=h!07pe~Eo_TULr?gDhTVw<#K zn>yEs(+cMf83%b&USd_}H)d1tu93&}G-LkA2r2R6W-!^wPr69_#f|m?O2l6@OY&u6 z|Jq94_3y%c4bX`CLXj;KUUm>o(I4J28=yNXKm91$R~ul`-mhjA0K&}xM6k#&;>0gN z13jxANC8#2?c}2j4+8YQ*G>|5VfSu4ATj4Tc##&PH$OB7sz6Lc$Ky8*5V4+uYlIlK zyvrrOM{tc$;apJ70J{;Tl<r`upw) zppaLKqH!vHVI5ak(3#)@hjn+q+G3&C;`Bafr(h4LV3_oeTbIU zFe!OEcEMU$%_zPUeH=M_pU{+vDcq|}J`C`T=Zek3c&$}q-jlzw99fxlq=qanm<9-| zWgCPnHB6*Gazq;!N}iYFwblVYsY?X^I~hO9N)3M~DM_fu>rHsfM)%@Yp|$=8#bZEw zDc{_|D)Nl?-5tXS%!AfwWP?sb$hOBq$p&z3Pls4_Mv1Vlrz&J!cTY;8o*D=xt?TBTPMEuvD{#C-yUN&S7LX~FjH@#@2I7Q z9sxj69L#meL5yUKgp+n5Y+@l-72)Wv#IC$~v_^QU73eiFo-kD|h0=<1B-Kcsxd|2v zn}qy)1argWlU<1D-Kh>HY)8JLL(14!vkfcr?za8jB)*}piHW*=aUNFJv zjyyDDn+hL_Gp<(fdVMZ{ZQn3dkOinzirGec@#@w{xQ~y?BG)ox!$QtmV9Bb(V-p=JuuJu>u`D+K+1SE%Xc zV7h`e2o)=iG)ts$XVpwX6VYJSA;-GBV}Z;;xBm{aabk+i&tkU?ML>XlleGQmYg+tF z&%|pio6I~2yJN()y5~FWWH{@T9*1g75=lG}546N-whasdGG)oo)_e{^&YkTE3nPNK z7x^4TT!_!+(Qq}4>U9)vEU$JT)bEmSC@&qTL3LR6eF#%MlU(D#4a`v&=S5+oKGIPf z8RH=T^#^Hj5btEl)h_uEhJOH18i{AyaZTa_r=m;77%cMfO!=ZgEXY6cy&fkRAuLla zcgg?Yp)pgbUc|;^OCtHO7NMU2RB|Mlzg=+RliHoO(nYL> zXQi3G3M&A!yTl@*)rcrHAGG2dQ(!FDgJDo9ijAr8ZHnbYSxD(A+aVvp;+O6upDqsh zFN)x))8)3QuaW&6s5dGfB0_n4VzX?6!Jm^xMX>i{?b%7|$q z2T;=*O{CHNY@ao^9v{vf^>ZbS0x&vO@w^rU`x96?btUg20xQ3|c+TT!Auu0W^w z%mn~n`FaKGRKc%K=|`Qm3ZE9XsX$}4H zrbapoPq%S~?oc1CrTBH<NCr8NymoL>jnkk`uV3-I8Zeh{>On z9{#LfM+E;=bVn>`&>b9taf588K}C3nSY_N#OsK@Fy(;U(M{+=tdPwL!CgaCuoM|Lg zUl(kR41oQKK&Os+4e8Y8ZOwFQ9U66?a&(`dQ9}idIwOPuqQ^yjAL700&x?qJ&nk<5 z;w$9ta^wuv80a6dl6*1#7-GB&4(}!eROR6&g49%BB;5nsI|qrg^86$^AC!BcHpRAI zaIiD*;#kC58RYnl_8ILt-eRnjDEhu%{Tih$2!wFL4arbb4_Lyq8fw$G}^XgaVTr{{CugKfml>KK`blSL5`; z?cgmQ3opH)`SHIH?5Uyty|GX1w5&#^S#uO^r-^`x`@7sP{;Tw(x~%$Ee#(rjOz%_K6m=0UW6?;q zqIq_i^6j1)e{Ruttu(H1Swl0c**hiNk<{&zO292kq9{*MBw&wBBpqs%9nm_0_K}Js z)!1{FlqAil2rAENON5T(8QC0x?xH$d)z5nz7MYSGZK$`a?A^s3oGExFjfp~xp?;tV zmY@*Vw$M9pM?LQMOrC%;WzjCy{>aXhuW9rqQiDjnWtj-U0ZlbR5XrqdgrG~l0JI>{ zfOxT(iG?xr8c>0m@?oF>f$sAY2)WpGF4JNaL;-$HO)F({gexHl12w>)ehX)6Fw0B? zu4~{&!UN%IA_7-6xGfRr_M=X@U1rgpNPP5&HRbLBT+gL7{*Q*Fcj-D)aMVP z&@UX9hP=|H+SS#h(w$Jb6y*^?wR!+QRP|OrWPVb)!<+DPDaiuFH9;w>1EPBx@fofk z)-Si^*wcbrrJdN>#3qS|eBNRTL6PPi6K`1id>D>T?O$_i8YT3mgp5dz+tI1!7JP_Kv4FNqvi*4jXRNlNMFx-cP1Uec-URFc-R+}g*$5e<6(~m1j!*Z|C}g~vNFFP z>Xsjh7A{#!_EL0uD;`&Mp>{~9Ps2lOe=&Gt=FfT=L+J-@3ps`Dt^36=S2(S*! zPKlGD{vsMIYN!J52}|gxUqM^hw4=o?Zf+A$gnLhEL~=xA`g*3JPB$`My@+qUVFULd zvK<1%`TJNT>44<>j!+d`IJ{lA<83;NBQ@ni0V{dNL^_HcFpd?j-5lHDe0)ITrNefOL+|!V;(^|5cd6PABlcRcIBqvzlnbNWmjr`<1PYF3saEM9H zlWsT3dDg;*e6#=sJucs)hL{H+c%uBZkkSCOWFqtq0q7Nyo{P#y+iPn5Bs^`}qGSj1 zP82Gq|69z%ppD31zr@OaC_hxuaFKr8v<>EG`bi=`<6jWGOeEB0+bh>d{{f!g5@9C8 z+XA!!58B3C%6_Z10XkLG6b_h?G=hZWiwH%*(KQWuVmTUU+P~n#M+Rk33BM`OUf4$1=msqx+ zaeBXJy5JX=ychR*iEslm78Wua5Y^aB@1z{fKrctL%A1DPc&3wjMUbB-qtWzvT6Zk> zNRY))!|)2_44NF-cHdRTJ^CEUw%%8nDF(Ertv$S}zh4y&iI0>Tvht7|0B)5WBM zeD4L43ben1J49)4MVt-Vnet3aJ{#7CGJPygf(zuc#ddX(nYP!td$P@S1;OV&cpfG| zN`<$iFfgazi^H#1=#$K+` zJbE%k1Kq5)3vA$iGl+VawTNVZQ0RMZ;LFSS!{_k)F9LR#?`mrQH%zPXWN4dEZy{u# zUCzhEUB^*8It(}IL1}5TE9eWTM1uPn@sGDl?tBEkqS^UkZ^tJoiwChfcR94q*)&N;TSsdkS2Rp%H}?;<}=my{=< z59%+aqFQVIzU8;pJF#xP{h;2(t$X-Ycna;iT4Qav>#n9r;RD0fzNevL6wKR-7{~6i z(3SWaLV~pSUj*}|TW=$n-wSk(kjs0yE`hGEF}e=&o9qe2dLPDJWcOn8zlFZNBCKwv zODi>4~Eeiw`6pMWKx^RSp zaOD-}9K|%H0EN(^va)UudRw;#m6@3-rls~I(=@fDr{|=mmig}NZ>=?J_St)L4%of- z|9$`8_lqBMX78CbYi8E0S+i#L%o=?WX~bT$hi-{=58f?yLhfFLUuNBsFYh`_$Crn@ zB46U@r}1Um(eCZHO>7w#>5nbNz~=tT36ZrGvmX1asPII5x$###Z@Nl+ldEu#{|zmp zX4E@AiX>wui9cdOw5LdBgJ{}6x3jQq(i7wAF%EBM;Kjgo(3L-Mu5k}NpkHtH++keL zu9233!=eHHU_VT*Ii+F zVe@w+coS|%pcf!?xfmKAq*V9AZ+9q#``x`P3j(S>XvE&r-_Y}GvFD#&=~2U1n7jU` zphwmkdk<}E#$Cacm`4KS@utZ1FO;bTe*cP@j)P2H3*H1)`0@v=<1ZSSVAgU#Bh&Ei z1~To-tlI|kaPMlROm3_+vgjH&v*av$FKJjW>^054)6N#EOR{3nus#eWY11&zmxd*{eD7YYjvIat60LW^)ALxD z(Si*o&NH^nn|ry^E8sy`I9~=&t*DosCz4z`kGl({6WLT!Hg~}9uaw3CPx~>OR#JjS zPtDjkn)N=?t4E{Fj2szI009LMP#^=!+*ckUx~%+`=<@uJM3;MiG|}ZlK5ZMLdh~R8 zrz_E=;x_+u`SeFD=4bF5L<-b;c={5Tm;bhhDtYB?M!Gys@K3<+398_I@H86X)vxjT z@ohB8ZAE^S%o<)b=XWvs62rR3(27&S(Ql|mxE~m5)ck`|__6Rb5#iq? z_=NH~qW&8Xc{lOBLfhAhl>lc54(f|u^Qf*1-rzOp`+2=7gg*7qE~k%Z$sobeN|Y}C zo+v%}dlT=B?=EsWaN0oW`$LG*SI+UzJNJE0V*vby5}g*p(>$cpue-&ult?xq6MXbm zjGqDVE+H3Tu`v8_)G6GcJ>yO8$*Xa4=WfN3jaJc6r@3LDm?7Qe z5?|Y)-Whc++zu!V0DJe6W1#!{okE+ttO*N{u;goM*ZaSvcAfXFsa+>?59)Es(5__B zb8&FqZ2#^0_P0oycW|4r;D2~}mH2;`sa<=|CK&+nKZ$m&q@?rUcLKNT-kqe72u1A6 zS6C5qcixFZ2r5+mw5N}od}vQs`4~Z1RT}a$ar*;b5mn}YLsTjF#zd9DT?JLt69%gE z6;!#V!ar4>`39@@9Q^)Htn&~&%|+G;-buW6PKA+Eo!_t^aeO10H6NaGG0B!MVQNsf zAH-zmpYP znV^9H{-Ab{&+w0YKzE6JV`^;yAP>|dCtGVbe+nA%k8Yj4wwmv7VitZjw)Ffa+~66J zO7lu!XE9{{Jkv;{>spycS@5ulXfzU@oTvo7yhHoGxzW}5lK8H!|8(iD{|fsR?r?P1 zo*?{p%|sMIt=bC4p*pofmCh;!$G?V)XH^Z<%4BS^>TPkRr8<_@Gtk_5-5%GlSG*?z zt|l-%ZjpqG>I(pcBO<+iKo7#@3a@!7RD1&5`U(r}t+c^4@tpvced4BBT(~9!U$ong zGQtgnXa-=+%kt=WO>+iH&BwbaIx~55yBc><@1%R6gZDS#rW(Avvid5@aljp~$_w^&7uUpC2aRq0z5{^-MjTkma67} zx{;PEg2L~PJBv1o&=o&u$ENd3KJD1(Z?d`!DTiGQR|R<4^j~Ccl&+b}#DY~<(jlGT zp-uQ=r>(39U2h>lu(H6);nmfh#hQFNEl2bhB5sD=$Qz&RX5RRCx0nHL3|0Gm8Gr3M?izjAE|##FE^!netihe#%28J;f!%N!!u>(J}zrh1=zR!Kbru3Rv+k=Itki06cJuDd%e`=j-72 zYodJ$JUxcp|CP_hSW8OgR2cqYqLxv&(;aY#$6yNjDWmQycaOsi>V?_`g3fg@l-qUm z1y&Hp?V&A0SG|mEkZ?W~B++#N)@>j}xjvSFt9B7!4*__fOaT6jb$T44T<77_r^j`w zz*KKp>hNIoIRKGd^%1n(W~%kEG9%C3u#X&b^X6!1&D@M0QplrC91{-vA-`~*)&kg$`t&=+s9HEjhM2lj4FdzQ8b(;`%y z+CmG3QuV0sB)>$^mbed5Pp=;>KXf}TBdc*R?@6yZ*(rSC?X&>aJu?@)-1F{95BT6J z^;<$K7Sk>{#_N!}&2&3=@+zg+9rfa~8VD|gt%g|MLAmc!JR7dxS-9^VL&(0D0dn8- zy8P5-LR3Z*#(j5b6v*prq`<_^v^9h;xP*Wd0_ZjGMHJgpq2})@LKJDA`1g>_y-B(= zA!|kLr%h9I`|;#QU%nqKrd4RO?>z(T6hR+Y(iCx=h3@iB1G%<}tVWQAf)kokz^A4y z0)%P{gztO3{^p)-KSb}_Z49Pw(6`clvV^b_G0x|H=RJ^)cLBMd{Y4b*gXee=ZQld< z{jbExl1sKDUp=s0DulK0RDmpc-}!}{GR%dim#}WGPXsCVfV^~< zp5R@@)!PHbDdTS_WG;wN#{fJmL?<=Hc%in?U_s+L-d98B9Y^496g=uQu5Lel1-y!^ zOichW6nx})5?IbOESk8e7Vp1BY4wOu4@--TrQSj}7;W7q#s2%-=!!1IJ@6Bqa4+~w zCopCO7`w}KG4hfLVlnLsko{!HAz`>!N{DD5+hAU&LvcOEWh=UEFi7mX`Qsv=l&LxA zchLwBJ_*$c<^`2#SL8DuZKqmz&GlcBYv%^i1)ZiqgLgZxN0bs#=qa5) z^+MWKG$L*oo_~1?H@iAkFJ=`z)c^_a-Dz6CuG1PqF1y820yVcK!8f z9-)rWR4>^69MyB|KSVtgaS?$6)X?>=etu}MX4V5#=Efn|nA zw8TqK$rbkN@ivp*SljQ=s^t+t>%Ih<$n_IG-TIq={|aAdyA>$PWlxGjk?$Vi`@TuD zMg8J|Ey8$7_uqxSvEpg*(Up~9phkCEKuaXWxEb%6KHzRWBJ!Axd0dF~?#<}z$5bQ4i%IM?EbSjTK>@&tS2zdLVF)^R;@ zsyNU@ZMdXI$$ujspw_7>awARfSq^MF1s$jfu{}dJhx18w`=<~a(Th+x(}#SR>4+d_DxWP-$oa6pugvtxWU0WuuD97r?2ZMN z0`d|Yw>d!W7u(sEofkxP#PC%iHN8!>}EYm{_-wF?K|{+=)4X`#8Y6t=Rf#7p@v?GD2qWY4b~OTzahB zc9=4>QjUg&<0x*p)knO((J?7F^6w$j^T00Fq_@QDg*LWJ1NiXdOS`1E7&ZEz4vG^S z*~{47%izD;EOIG*8v&dZc~u)ohp_`~mIW}MeU>U1MEv=GH^_rRPh;eqnh?xB551Hm zjA}c@*K^3Ec>IE+G30{P zc6?KQ;_BzF>^`6F7A$~@(by6-1h;Auo@Fa7Ytt@`%eLV-_Y4k42q(&f4W8+1vlEeO zdl88S_=T<~G+L-ySWDd;2t)fhJAJXQQ7<}VrBzy^S&YarUC=t2$9bj*WJ2^6MFK2RoXft6*2iT;Zb4*9uU77IMmI$JM7WZ=9?LVkzDxwNheT z&3l>TjD~@Yd(|ip# zxUeWB!mZoI#@ELwtcP9aCs3$6=zdOp=tLODJBD!w5!@FMh{x$q%t!h}85K43Bz#Vy z?N?f+81h^!)Aphp$6D95^PJ^5#mNc8Z4hC)eBsl0$aI)4G(MRni}^HxxA8dcIN`6c zVRVi0k6S5NV~@lYh~;E)6)xc=_ILRSu=)X$^5=1Qj%S1mSnnHN! zUYcU(8o0kAmHK(BP@E!TvM`tB2)d|LxA(JnLaCr+OOFJ{@e|_!gALVphR)|*Q*K%v zh>8vBqiAQlxY{cL3Q}mUeaN9o-jl2E1&2qj6?@KwB8P~t;zal9Vs>L1%b{CF(% zsg_nP+{y5Wj~OqdEQHyq7#$8QB;CAhzH!vNgaW!KifKD1rdOCrktJVVOQ!5~-T($#-3 zu+zTNZzuA!T{Y8O-M=Ec3icHU;=LnfAH;16r4EdYmk-Z7GO}sZqjnzxQ(I&2uhNjV z7o3>CT^(e>kt9Uk3d4~YcO`uj?|0_g1R3Rbm{10|)D-g<5{c2OB*tQ1NCjodBlW;u zh-t z>NL`ZgL-|m)I7q6L-1|iOM414aWDg?0)_v!q~Or=6K)?0xMA670uraSZV2@1l-~k@GtM(QoM_EoVF%sfX--?Z-qbh+FQeHkr|+-k3ke1T z{S)QyoS+}n&`uVWQJ`As)`wN{ozzQOTlFrGYB;Vg2oKM9s-FzP(kj?DT+|;iNWfmb z)o8014#=ulN(w%=N!ey7U%yZoJSL?sG&}>cd{npOs*WQ|pYlRzkX7ASF zEt743>7UG=ppJHXJh_S|a`hinmh-78yP)!~|@z)Ra0yK|Pf- z0@r;}qr$g@kK+O#lo73R@A^5xJ6M++Q8cqFR~M@oZvHK64je>3@3cnSmk=)VN_akT zcOEe4SCCzu2v@p*WLhBG)mwM=E66@o2ueOX zt^xvmQ8?Umxykvq1?T8{f4K@-P`-w6uCY`MXE>Ik9hzL;tn!Rju3a$qK2Sf2aWT(+ zdSbt(#bMd@ycSl zV};dV1~ni7@m~+Nqi%@Vfbp%~YvlDw zb9Qg zW1OdA-@Mwy9{ZbUMVi6q1Ov1ACacoGUxe3-29`YZok9tf%U}f0^=0kEdnpT%V@bEd zdc&TDxq`SaO3e>XXQBeDHKFbf*Ny(fY~?0cBDcn<-7(c@=-nyClLN^;AKkKxK_137b)?hp zD70k88E+^P+ad2(vFwgwlwN?lNu|Y ze|jaeuZi8d{;<}q8#_DAt)3#DV;p-}hRhhZ;$SzRZQ7*WQ_I3Zb{m%n}L+Mv$?R^E0C+P4&Q^KK_=5Z z{KfUPSSG5SbT>Lu9n_@?Qo&UY$Ap z(%*9QeUVdv&1K3bYwNSR1Ass685CU0kwN#ylIQUc+Y)|DH8;%{_R?g0Y8Y4Z& zj{%rj35wWaS@b(UU?WfRM>?VLc!dy;c}-4LoETfz9v-w`tL04bO+R9acyb{fmnkcp zyH8ZX5gmwBWVQTzy{`}VzT9v&_VYk6N+V1Skl9_54qAmYi-<3=FrbY3k!V3!iHCcj z+q|;!`WT$K7Wn@YrRG^@RaD?$_4B~){aNU2$@8O0(@Ph9aR-G+WlzSWhd=b*3z$n4 zz2gePefg3AXZ(UsWKLG)WVFB^>ntA3*zeFB;>0|TjkvQr3$<~N{f}-FwMQC@<$IM( z!aju=Zu69YEycGCz-`xSku6@gciHoTY2p1hG;0>@Prub;F6n9NKG*z8y$f;uV>a@N z^K)}XFVgY4;Y%W79EM0`*N3Sz=XRFj=-|RtFQumHar3Sg-{i}Ldw`nS**XL?v%eK~ zwUje^#lKkFrK;oWy{-_%OJWm_sF8eV7 z*ft^wzE~GK)MCX*6O;tyNU8~?>uczrT6Z_S=zjsz_ayr6onZSn4H8-h>XBcHK&*Y& zZ{d8;0X-r2Vgr|_U3<&XIBa`x!zQ-shhGuAW50OE+w|y_wUeTNyv5gW;=@`34DzKe z3K62PvxkXP=Q#}X?HJHUYe+$VWgx-QMc>n=@kB(cL21vvv%i;fk5dliKFio2M2&eE z{~c@`=nB779(nF{rb%XuY;I0m?j%h<43IOQhR|=|@KO_U1Fc+^;pB&ibTebOQlq2V z10nFoP|k?sB%v+6b17Z5mjPIefAact1U%gXchN}0HcNIA9$!8QO!z`;E}cP#gvGq( z_P+Kw=kIjX;4Z^yXjrNjuMc zZuKr~CvP7poE`O=6r0G|Dhdc0aOwawsS3?c|Nd4vQ~AEVze@Oi=ZdLCI4Zf` zs!OamA&x_^cv?E9>YrTz1Dla2X!Lx`SM7AE&+C047Fm6nk3t4=-)QL-_Bc{u-8=;o z3XV6;a_Tl4k{mc0Pr`UHiPu9^}&C0?X>&Yd3)OP zlvs<50dpk*pQ_mxL`uf7ANWZPB>We#nf|2O($1<@SjK>7ETT5EOc)^V9)EE!d*^)3 zV?;}b>LGM3(*11aCoYqOVLrDW@q(8{drem_NZdB`mzc}CNOl*Z(F`oAq5A*?xWx&? zYuca`bh4hYE@XbugUtjM$-ehdiAw3t6+^idL*$;{Tv^+^69Pm%UvVBToM@*XVm^VE zPzS}HgmsL<5f>>l01Fo+u{SUWMi-i#Vh4WvrLE4}RY31OjNN08HTt3@$WPD1SsdC^@{Tf+b63xaCyW>9%6&RGl3i|e-YulGS*)_uyWI{X z25tTpA|vm<(*5~(JJOkaK?BnI7DIJv>#1xFL9PFX5f!^k|GwYK?lly|Z$F5Kbfsr3 zeSfVbtv}!(x1G>!))RZ_+*^Me+^6Fc$%#h_6RP350e?ul#L(h~xEf6Xw|AL~&fD=| zZaVB2#b6Ah>5*s~6=^aQRD2bCeUS(pGYn9q#pP<4q>18)L1-xFUM;PY&5Re%LT)C{ z5vwYpjyMbAqUbTi0OVm{Ma4W!oNw-It8Mx%*W1ET88Cl$ER%DqQr-+5UW02c!X!|! z6Xt54BX0M*JK994=}wux=6CF_5li7{Bp^vWd788pV(q0ETxl0GC1>;upDO#ZEJnG( zq119vt!(18b8_2`F}u5^n)pQ7bz&*;xS_6SvBnSOyq(6!d(%U}%3ZqljCqQs&w_lB zZ&qbfN#rr%t!QDr(Gm2C=fEiVjxYMI6WH0~z*`6jnc-7xbVh7+sGwclCtmd+(pXku z{#L?zW*L2NAu?K+c28Mo#56OBYg_7I8@M#xomF>1o3|ll+k)5_nDU{aR+-}X>Ki21 zSZC1jY-xBK>0r6wra?J%7r1#FN#t9}NEJ{Z);3`wjoTdiCKTffyyyo~>6hv3;uqdVb)`dC^D!-e)^mI0 zLF-BeAES>O><_jZzBPZ&NS3xsJd|eRn+1@ZCYF~g!xQ(f(r_=rdr}6nm|j0>@3kFSAtqaThFO5>Gh9?X!9?AuoBYf_#Dv~lNmEYMQ5Wp{uG--&o2KQS|^x}ssI-2#ZbPDhot&#Act+4Hr;Mop_Ush~M;&b7lHEK9EFM9Ff=nc#L zX-OhtMhJS37%u0p#HRS!{?7IRh<_Y3-emb(KHmA@A}t2naJ}>%4LBwAOP=h7yXyqj z6KS19Ma1=`Dp_7*4=!4E(MVAvB;z|py2b&&WP&oRxMgP$bm2C^?uOg6ijy>RJ=5mp z;;Qg&<-uzNY9m$5>&j^nr&=GX&t?^U1ZoY)n9)8wbJrnr7m~WGKE*N$p&mY;(uVxk zfK9pg^R0f;7XSAxq4CQx)C%3wl+|v3wz*-OmlL?{g+kd$gqlBNAzX(DjECGKN6<!|M%nQ_~iGme5as2&SOjJ?b7^Bm`CH+(iycIyIA{gR_o0`1l`wo zI-l=KH#Ao}p#`+L90Ng9V1nJhs3m$2S4(&AT*JtB&)ejvg2)wjQl zUUKU&00w>s((aE_wD0oVed1N*d(dS-JJo&vwXZ`o@Y|W%?{i;IJe05ag${|0SZR5D z+mu-l9*Ao*Ks*tr8VO#c4Q5I?>d=lOM~@>X7HKN{KT%!c5S|&G$`|+ABu6_Q=BO-J zUo3D4PMiXi7zY`XQor&#y8fa`&H0|3vhEj=o?yQD8Mx^&+&*ad5_Q za3mu58`+hWFPL8R>MP76DcO}~B)WGoxpzzJ_ERs;$7&aKT^oIk_=;uIW9^ZR(-q-PvP-t0){ww zWAt<&Mc{kIbeiD$UA^#hNn>QMJr5&sG1r|5ZaIAybKerJgh%+Mq_yZ9qKs z3Au=!84U9%QN+|zYZRQIJ;`Blra76uW!@+9lM+vuxy!HSA8V90(Z9&v7pm0!a_;$@ z{O5DBgIW~U@A$p=Zw92vokYp#M(T}3r$^+UbuYQiw7TQHH?|?h=hAuTcV86*EyHx> zua^(}@)$dZOkB1W{={7U@r%!zm?8U;1v2e`l)Uo;2926)KdWkQAqmn(j4Qge3O(cGui}@-KteG1acJ}P? zR(QyP2lR79cK%D`g(CFSd+#1HD)%Em^KAUgr?(;GHLn@q(^>WWwY*y=IDccV6SBcT zA!2;uXBwXFo*OvM5J=FZ3iIuRU4U6_%qn_n-s3VldR0+G2wQtc(~c~*ai;=}>NHLK z{q6PT-{n+K!u#`bp#|%lGFiI0O;TZP<%snUJ2uzVv-H2`dv8=A&?+#61RoZ0FGl)vFwH5*2RaPUrOuhvrDaH)p(sP$>%)wx z1@BS6pPlt%%X{+Cx(JLZQywPICPQOdMthF4H++@(WNyxu9u3DA>!EL^nQzfNq&a$} zchZmDF`%F9(2#l{?NaO6h90{i$ksAq-(o>&&eCXb^UZ3%*^p(vTAX&Q0oTBWMsU<| zsF;V!gfV9!`4YBL!rY*(3zH>nY9Th<^*);H8$SW=Kpb7#IbZpp5ZVze9UCi?JFb2# zvUAhdQDiq8%$3^fXAK<7RDo~%8k~+EF!eJNH<{$ zG;7UlzsMZuV$eRz#^9&#;ZY~C%^@pS?my-j=o?yl;Kr21HWmHdxo!J2m26_H|4ngQ z>W)EdK7_78K`j3KU*IS4l|a%(qUp8gLHbps#>#p0iLd(RY_rdDxy#q&Ti7u#j?Jc5<=NryRA$;$9ki4&f+Zz)W=VwJclylC5nz z8~*|*C8=dJOi1qj$ggIHbk#VZWuApz^y9A-Y}?#dbB8{GEiim-3L?bo4`xZim01Ve7>W2>xI3Iv4)<*ycR zTu;9l#dw0xd636eW4&fWXU)1-R;D8*@g1W_#G-r%$+d)s4BG{?#80@$b0ox^AN zvf2?iE2>~4BEI3S+sx)_+*%z<$9fLhtgN&>hq#AjtgIuDx~HCr{2pMgPY);|^MB$q z$O%a#}0?S0|K_QdGsre z_+PQn;A>+K?J}Vv_`$IFqY?mv}@$FR!s-v2l&=qGB%8o`1{28=Y* zL|O^6&O=}M$QTBWHO|gb$Id0xe#BEo@2inSnpJt!NVyc_M=oOB9!>e!5TvG0g8c=; zTBRrwj_xj#!LKK*OkrLIe8)TY%~tHqUpNu$=;Z0?!tC(S_a6DKH1^J@4gN+!Ups2z zr9Z}ETcqVGRCebwvL-~u918`z>sm6D?!{Cav0Y`13;hUa^`!!#bw6pc$qXHrV7fVp!d0gpo1$Fz5PCrgXAh>J?t#jL;{&%^4qS28G!qIL z?+0REX2fA0Wh{K>I#af1DnVUD$c~|`1%tEJO-~=gsRtc?U-@>)=5v(RShMcs!u<( z8;MIPtk(Ay|C$d<*W#KA@)5Ijgtv1Hj&}9&F(XIs5#Yl6Ugu~q%{b=IOFvsHs9j#D(?oml{`HsbI zTvMM}(!sTm;91pVDvU;f2R1bDpP}Yac`DeP8oHhi1gns+Uo>7PI2Z) zPab+j&(A09-M}1Bt2|Dw0YMzKC`|AB>?i< zqa7L7-ur_xeAIhGvK_HJNi~2BBw+1tuNf)Dte`wFb1qE;UWeEK3nBhcHXutyRAo3 zGfz{cH17v)*-5t#lVz*6fiye2&&R9kI|KS)t)_@&1Dn^~yS<~? zOmQt}KPJ3{I`_FbkFJ@+9N~l^BN@YKP zin3L(lv#vc@YhsJU=!plXKpD8xs5cIu#ghx`to5tppL{7g7+MD{cWi!z2lIb;P5Yi zzC;u0E|;3nQKeiiEuFxCY;d4^mdeQVmVJDV{{GJ%4k_k=aMKq{!xE;tZANbDH|-o%WgW z7RaQ1wGYI3Uo(b)9Z}$PQiKWnY^Q+`eHlC1RvhU&m6|${rN3j+UuJyFZPEyYzRg%| zhUeNkjQ@~Ojoq$C9M4;jkcMjHS&}qIp3j~&H^@r#DfwGh!lV?vpFMPCPlqW#@+tM# z+^=xiJfmyB;Dx@nu_p8EiVNw6Q0{}Y11&Cp71Hr@>r7|^nK-!N6e)dadO}UivzXfo zijLcf;wiaZD2})5M|-UP$h$9Dc=QtHlPGT9Z{R3tdRJk)lWCSRuY<-P3&aFyMfi-R zULx39`i7W6SI2yj1RR!;W0>C)EZky&*o;btk>8Si;%T$!NsxIXZ?p_EN;tAzfifFg z+?;%BD!H8@5y%&qjy8oHKRnM6qmA|5wj6kN7w9d`$)VB?h+lHAcTzQ^0pUELu=r2R z^W7z#Z#H@J4v{T(v06D1T8-5Te5uxhyL=MP6L8i_;Z$hi7<2r5SsTKpvrr7f!q-(x zvGEavSs+!!wN##2plOR|R5+PU^nJ1HG~sseq(C;Fta-aHQqHf8VH0XIc2x(KH=dR` zT-BvkoFuYs3IT?#ue3#Nh5mfV7O$3Uy1_0=7p%imzp+WGP)Oz@xQ#dZR^K~*;_l3( zf2MUfeomdwo0Qp(yJy!M^rj=Mxi(#!^#x2AmTN1aM!fz?c!iD*uxQ*KxinENmJc9Z z_XBssKJc`XxA@HmgKv7nryRG6pMV$=?KOvf^DI!h3_$JP_^^k_Lz1~oeuSG2)yE@G ziDhEos0bsV6$Gw^=f6fZD*w9ycfkbA-8xu91N9bKhpYwm$ctjUG6K;seCMrfuTc$& zT9tsZ9DegO;OCw_P2JEe#Hnif#8sFJ0TKRSikk{~RiBAMbifjVA$hAJ*fkx%Dlm2m zg}_dh<5hE2M$&s8d05&fj^=cvlqdwX9u6)E8G~xsp-F6q;3N{Gy`|$Pwi6lhwDR|L zp42tjr!n%gx`M1iy~fdMTrya$OmPiUywx^AicGKJ>|;n%_(%c zuna9tbjV}`k?u;>2UX?4&QN#6v3!23r< zH5@JBsrP~NpXc=ZveUzO>0YE7tBZZVTAlf;QvThvF;Ak?z0LaLBFUW6jRhO z0f@-|fpP3ThhKtm0<@-qjbWD%ose4ffo^?i!3`lK80>KCra)<^sq>&i*vAa@FAGRu z=DsdiCx%vbZ7B3#c;VECr+ZeAZcz|Lh^$O6c8)yoF(Lh5|* z)6xkHl+qEm{k)KKC4y|Yi%{YF4_?Qp!C0qfxvYXBbPejl5m*!ChrAvNKIxl4utDG_ zTmK9s0zXSX-+?Js;ueo|?hJq?Ar8L7_jts$MXbhNR|b2AoX*1V!rH)j5wx}#TqT&wM#sj6`g~c>YwdGEa*^JN_(S&x zEjBSWF_D5$oDl@{mwNsFn13C8Jplg)EsjC}2+j)*MW9C|H#1kMag32jGX%5-3D~S9yJ*2n?v?+}=mv!M*|P9qb((czRSN!e8INbJCjG zN}2c9QhgAO{AkX01Wbh_9f3+DMC&qAo9`mM8;MRTWP1e8N0N?2B@^OxIjS9O9ef-N zjt<2}V4$Z(S0w$JnJMs%5Z8s!QXEwSBh+$$awON^t6`hZ!Rd0?^K&T&uSd;B4vF?OgK5~aRyB)`Av?DI z+0285=Uc}wksb!Ijd)B;E?XD;yUM-5qjrVCr1GJ*e`V1 zm$P#Qi}J^4qncZ2wF|q#*L``Xz@%HUGV&@>eu^Cu|)vw^S-z#Pb zX%^i@8*#NHE}sbZ7mRHsQQ6=$i_AWwo#z^S)-xab)8-&JGHk(y619!QYlywFww%@E&VJz6Bera z-L-T1OX&WEL)2&E9?vu*k}E(kWDWJ$gDx@(Y+ zrK7TQUh}7cl5j_xp?>J;b6dK2;MnZu(`oemq={gsJGM#YQ2^<6S4OV8L)I;O_lD0_ zLql*)gN;zF4K-G$a&icHN?qW|@?6Jq`O(#Oi^NK`imn0N%x98F5C7src~zC0j%L`Q z%ho=*E#XEyW6)B1tcQQ3kAhgT`6j}aRqVrYgcs8TZRanzF|Rfejx8UPj8re=E7m5s zOSBzt*|pCXWaD^s3YFkepYvttiM)xc zO^wsVaBz)9npliIBJh94ShK)}tj+8Zq87ogWJVep=b!JG(*`fQPM;wMcN-s9orA{M zShSzPp6)MKVm@4;!4CWil+zRf6k;ig4vb%f6FZ?^*HYJ3s^5`!WRL=y=;h+revfDa z$<+Kb25XHZpgDd9PrLBr&ohwL#vlD%NVu6j&|aStH@I`08x8|?*+6W z&d`DToQXf9y>!qX%4`{)hFC=Hc^(PkuFBZ2E)m2lVhet?juw(5h@aah3Vo8%L=WnL zeceida&9fC9J?>GeQ~!-kXM!I1lxr4Aia_{x>~`#f;pOe=Ftc--q5cy_WkCM)UL!f z3OBxGj;ULEp|uz|&Mg%|KWp6T+kFGFy6 z-ziev5FVBLOa#{on}bYTSmp^v{YYQGT%jEJ&eJw-dXS`|yoUIY-`QQ2PDc8MP<%zY zGRp64k$wZqZ*FU%T#>!*gCjo!$ggJ9tXnij0)yq*0D=2biL0<61+xF16&5{7+n|I{ zCq5%SvJglMT@{ju*iT((eWFSrA(&qF!MJW` zbwxHc97FCfDH-t8n=X%<8oc9VBt;B^ONZR=8{%++!W+c*rJq_ZTs8p-BO6bv+%RC~ z3KUxKMm<*=68oAZAAjYEiQI!^2pgvBc^yH6%FLwgd|#H-&dF<+gkZMeZk8A{7R=ek zFN!k;xS&B)hJMqLi;!I>6X0gOsm@C>OCQSqD03jIp~V_Z3ktH@Yc>M~sQqqjsi$Dico@7y6aWh;&0tUbNBIpQZ2Md9I=aBD%peTIA4i$5#>rp^W${E%h?U{$YhaU%;TE8}IGnsmE{Rw9 zpM1lN+1Frg{~aZCo$9bX7s^9VK()=M)gmfKxu3RfvC(`o&M2+ijV8|+iN0(r78tR5 zm;yqq?6!&$OSMsZwcls*5gTB4m}5kkvyar}GJA`v36a92eo~Js1wE0QDgoTRVFIyj zxuw!%5I4~{T_{gIc{T_vz7kMv5SV`b9g^QHX#|idq#G+pKq8BKMZIxj85zdleVw+} z$>g(TEQ(UekDHa|X*|SL%78nLk;o~C|7_9T%Z$dWlkx2v<6V=!LI(dxp_(SD2n-y` zcxq*^;|eVB0eZbK*l~?}VuYYvqeC#*EV|rrRSOG3;>ZEY1#8;a`dFLhFnvF~<5n-S zz`bqimKHe?vB)a5$YS_7w6oNC_}Zi#zXR-0sMzkI_bdWTlI=qOz-Fc}D~!q4CIZ;( zuz5z8onhvJLJEJhG)~gYI)=MPe|O5Nap$l*=Ds`rPQGDU=@9PD(so_}bBMjR?QCyb zF2_&Gqb`xnjR*L^4VhT7587`<0@s_Wbm4|fsjZSkJhu*N<*dK??mYg_WqAvZ@DuVY|pG+@dXr+TV3;6ly zljADxgcUiAVF&aQ>V}>r5-UvGkBHABm>4wDSj`Ny_2Uku zRlk5}VU9{H?v9<)Bn19MaUuGMW8cm*PMeh4L!ut(rBCGr*5|XL#DsXKaHTrKsLF-1 zp{{i)LDR8WagSXPT;W~_{kP+Mw?@prExW2zG}39b5^aDhVTmnJ(Z+r6c6T$2$CTx+ zUZQIm!x5M*?{@}Va~hrNE2_w9#Pv~neEIigZM>t6zVp8cpHs;SB?5i^lujm*3$3Vo zPge%jhD4iL{WZg*8DIt^57_s83Nk>h##-kFszMW)jbxP#x95qJH;F9vjf7KE)A0gP zJyGK@py|KDTze+;z#Cqv&|F_QP3!5=jw2$zB^9C2#bbgmKGz zc)U0p&BB8uM-h1)9BWf6oGCpg73z!7h!$Zei9J}{XeP`&jLjJNd;8r{5QrY+HbQ>Q zS$e@Xntxe1{*D$bIk9b~45&eI2ph2qF6{r=TNM^uNwiK6WCMRFPP9(=yfJ7`(%yvG zz66+MO(9|4sk_V|L0 zySBI5e1e!3ekvK*Mk{Pz0KN4l=k4KylkngzE9Ys~PV*u|a`kP>XP!%+OztT&wip@G z#YJfgv=MKp%L{}L`VJsR4Eiy}o$QOF`3`s$HF+rG35BGhS;tDcNqDOvv4mElBoDZb zs?dFe7u=jn^g^DXSi?$d@F2Rwck6Px%No<6=*l-ZFwn&iqaTYC^O&?Me^ zD06Gig|3!{mK61;8IynjhWDs@mu}kRo8X^ky>?x1$DqpdgHg5vQu!WG@SX#3zye(p zg$XC#hT&qEkH6F}6j5}p8W!w&i_dP#N;{f$#sBCKVK#n(idbRd9EaHjdm9jGT;M=5 zr}MJ=P=8K+*SjxpGxdLl_U4&a2Nm8q5KCG~iv9he_I#k!+qC^%KH!tWj*^3Oz+O@=#FL}(!-qYoewW8EZhseKv5v|76Ej3I;9TVz2qe?O_z55o2V=U zEPbDG6pnGOs8Z!uN0{|3FWrSd4U>6n`IQ#0Nb-wx)KdUKui%PfWE}T)*wH$fsG5k! zm5jfye;!L!l})GfICGzZE6dMdq$dRkU7Y}dti4(R=`e4lk-twSXwc5H4sZh9Of|f= z#<}rNLtSU!9@D3E7Qo7@_ar#ow;xFYvH&%w=uugV2=G-$dpJDf@-7qH?k33a;#`TORFsSIz5 zq!NNK?GMmoctsq==2>k;e>vRB4GesPJU#r6lXvk~SyoJta{Sd3PAoUu=SNox=m6M| zo{QIZyWF78?_1K<7_{%^Pm^!5+!P6yb}{c0h3N%>3NkExq~tycSHfctl-pkW4?~9C z8bniKp-jWhn21DG$%8?zxe@D1F3>O4xE9{Gbbnm=?!hsX&40{A$0z4|dq#o>u~&fV`^-#QNS~+1ctH z^TnNq=~cGY*-ShE^1sv?^`6WPKzVUFW2nm=0-?WHo$1zZ^@3<#RL}Suw)#OVFOkc- z^uV_>gXKgE@n{I^z1uQ}MNcvW{+?vT*}Ufm1pnS(MSM_9b%!hPp6zV7E_V=w{~~yn zQD^cO1bB%*9#Sel8=Ot9!vUujch+V8mT0=zMoTp(b%@YAudR$K9dv)E>YjOqf_jDB${APDBlQ=?0 ztOthQfAsD1aB=NV!Tx(U5B)o6Fy0iBxB_v+>UQW zJT`ujieS+qQ>3KetaZl|zYpgX>?ifTx%V!qV~jtCu1YUb%;NKUpM&H1V5hz14u1~e ziGdOZ-F$0I=VyP;+7=S&OJjF#T_1zcdN}{kT^C|8xh1s|JF+0HZTByR;;FJG{k1R` zseuS43!Z;$Kl2!F&MB$*`X*dktCSo)Yubue7Ei8M*D94aJdA4?7h-XKTXu3;eH0^J z^ybY{8h6VyNvKtqvo3iturBzE97C8>IB?L#Pg?@HUN98Tz5o<-;XV^UzHi?o%(l$r zOhScToanp|xAyAxgHFXy{H3Uo(4G-+5@UKE$vc&>LnZx6L7bav6+irgj zb}(x_LO-gH-u}tKSAF?oY-t>rLTA;F?GbaN+B$Vegq&_66%!K~>#J zJA5kR{|(_0o$FUIpxc$}SO1go5khs^_8$+4Lo!tUC#~J*9s-In@rc;tJn}5U>ikeo z2kX{9vGH4i<9B+0foY(<^1&tAZSPlsVT^7oRNZOGcU#NWa+$@%ybZT``k+wLiUZ>?sc{gp40D74SIoCpuGnAcft#XKTBW#6RsTfK@wqC z9)FjPwOtsh84HZrG*+ENa9{xs&#VIL@B@)wwnezY_Qj5kc&23@hGxLdc5L3%%N z8|ow68I1z7g$W5hUTXjXq%(bcmgAbug!hBUU$WGikZl+tMw1_V840)IE95FYupi%u zV12+>bfY~4C*}{)BrdG~g62B{#1w2=i!&NIB9jT7WDstZEn5fC|0D`TI9Q9_@xMn| zx9SRk0Vo4ZWa9v8s{rAnLo8IU&QKSjuZ z-L+uQ!YELX)dU-|*CD-g8U$iPC0Kzr;^Q);ncM#+4xB*M^$EWE{hI1bH$Yb3xE1(5 z*TXZk^QQcv(H4nI9vr)Or+D9u+xj!~>~G%neE)6DG9J9hS$GdZ0`q|H6Fr})?1mJ;+j$TK8A=x!3trMf3%i67?_Aga=Z)VErd3hhaPAhq&PY@ru zj$cAH44x{n$*5 z0Y}MCvHHxCy%W7tJg+|HxZR5Xzq-x>sBWg+;|Hg>Td|_W-QC?Cio4svrMN?JcbDQ` z+=}bLDSB`yF2yhJ-22%(_e*AHca!WdPqLd#W}km{MLm9grD=Gf#(U^74ujA0%(!Uu zj__<}VhIO_yYRJimf_9maSH~6KQ0k~_1-@9*B<<#k7oHA3P$AK=)aN#Pm7|zqNE8q zRI_aKUs7gwTgS3=HwWx7l}$g6;ccoL?Y@=j|Gd(|$=2~1cY~@J9=p^%9#zdtyvF3I zjlZ^OXC%8N;CV|v`RHQs`JmRNo9-aRg_!oOIG6gZ_}Qjyb-9~?ev?3cFKO>e3)R)j z-0yY$ic|XGsifXFD)v(5N9NpUkMTs0%oCQ_V{s6hT+gTypR}K>o?(i2dSrKd%V67| zkUySlb$wzxU>ETB0T(z*l*sAW@##ig%<%pFRhKeKq`1jO1=mFTh04?Lpk!^Iz;%_g zIz=@TIa#8Xq;g$ZTUjEXj~Pr%6XPHWM#ByXz_Y3@p_?5LgA2v-Et>Jq|d`s8!`SUhEvKw#(VH`5HdkETb5#*CK z=ZL`mxPNPS{Y+2%OGSer2pGsvWDZ})*G($!A_p{5iE}y3!#t&SC{7BG9GXj(7voCtZU>_e;9?o`9NZF zC8REnn|8G4l@!4y-=mM-^q%I4lvdmv+eP9mN%|czYzdj%a-bCVZTndP)6ey_y7XrC zb(ek-N`XY2zVz{Vq|NM6GPj3|SBHe%ua3EFv+VtO7`X{n*xtY6O4h$`O#$WIK-9iH z2`S4#L1O^`0C<1{{%=)B)L2-Y_uOAwFyDi{tEH2%sV$SCySa<2wW9;0lNX&F1MSqr zv|63U4D*Z%Gf0JbZWj{ppBO&A98fg`0Kfwc0AT+c#@y4?+zI&3aeW8Hs*NiSFr#%I z&}r@^%9fA>48oun8+^tHwKd=2sCPOY`hq8fMs(zfMyI*!UnMXi-?D?uPQTkiZklK%VlDwxbGWCVs-9xOsPcV_ zsU2QZ*GOsn1@mb}5W3_zT7F;wbue>zZL4)B*XxetD!5+YT7g}ohZVbS^wl4gQthLk znXJpVyQru-CNXfv_41_^$eFQGG|hIghj7A<7pbh_tUD%QDvpTT3*8!-@i43~Y|>pH>Snssh7(C00g8w)h0m4Zkt3fBof8UHn-T)G;CIA4U;c zDnar+Ok%NeGZi>j$gdhipDcSJmE|9EHFT)NjLMnn`UsIXHcDCx68!X)gU4izT(@At zI;6)>%kV$zx8I{|mV*cYP)z*KW@2G%XJ_)>UfyeWPr%l7jXQDknyyZEkKW6yn&M#l zP;#Zg)N3nG&AQAwe8FOLG5YVK=8I>&Rn6(0e zXYJSt96KL;PZerbT(Dj5wi$CIJ|W_a^B7(*-_8LXifHsGwB!P8*a^N7_pN~Rxn+>XD6`-b<0#Q%5Wr;Z4%Y=>ZG zq7o0e+};7IUrj6g2(`L5QwM7Ma7jR{V*aqN(Zxrt&^VnYxivfS4>`|nC+K<9Uuxmo z6izd@xCHb<`zWq>_#wg$N9|8Twf+RWI>^E%Y$ZZGC2-uYoo3MAr~CcL+^olkZv!38 z6uAoOpg+qHO0l3hbt8a``i|}r$jq=PinyWn{?v@xo9y%3UB%%VQZiuqee)`q4x)fh znn$Gm(j6RTO%7)8e(?x}W`dawBy-OE1%33rz45{!c*v#?3q}~kn#1DHxBctjHEsiN zJ4$IUTtC@4C#Xw;ZkD? zuyHFp>a5x-hPJ!D7wZ zyT`p)qkumlofA_8en9Q&*c+H=Dsd~Pjwk0}@HhMG|KhAsB2n6Wal5(PA$%qD;}zf& z_(DJ=D#&Z(tvSXexkd&XOV0)$_WuLR+&#Vpa-euN;??&mc41SN_K>ta`B5;Yqyc%*h)NwtK_uJ!XXMOgF?`d7_@@zK^@oBwL>RX)B2BAN1 z2SC%{EAN{pD=(j)k9T0Lw?O_ch-YBQ}78R)y}VId#^b^u7Oek=n0^)M)PeB&87Nx{RP@L7KBR0?F}f%XOUTu^#m zOH{(^e+nzHa(Kmf~TbeHfQ z8O;YL`3XTAP|>WTZtw)?cO9x`M6>}Q)| zw)ov_AOFNO(N1;)YO{@lKIl9EVcmIBk8S_-h-jIVLpJpVz{&lOJ9+vkZU=q zlVJ^eq?r7s(TGR@C*Kie;K8>oPi~kP$E6Pn?z850K_G|8*Pz!D8XU-mH*rka*bO`R zPUe_7`2aH+oGLGZ(}G9~lWe<)A0?V({uR-M>X?sk_c-<~9X@_yx#{IIb|MmDU~YgA zjXCDUl+0Y17z%OppsX&cA}+v(=KTeL8PDi<8y5rtr}|863V|1t@5~qbWn>rwBHul- znd!yxP^q5-R+9H3ZJ9=ib0~P9-_s9*IL|%`vMxWN8|@~!h-8t zsu3x}X?6%>Xdl>##IEQ*Kq_R5aBT*rp(uXypi?-6?-)nx;t+9_bF?Iqu|$9nhBeFj zGJ{tx3Gt0pVIj7L;H=8KR6VT%ccNWrh5*^0QA?*R84r;KyNxb05`IyVng_<~V`j1W zBBkXit*lgW;4)2SH5r}k*DTV67K6Btdolj7UwBr10u_+(EK^@+|4ZctIrOG`@gB%An$lg}0 z2;o_hp-s8rImHKCa7arocx=s6pJ$a0^HhL`u1-6%Xdcc{&@O)b9QE(sTS8V64#WP@pIK0K`C`^VRheUG@GG5tI`I6wvQHLooM zZ_Fl;GHL@Lv_J$x0kN%JuE`)h=uNDz+=}9p4t=6?ht?J=otGH`(SnkL=o$XjXP1s8fD>RDSx|6ibrz^%k2-`vD_fe!b4jg( zTZ{+2CUjEwBZ2w5hp+%zSLQFxCgdd1$C`|*pvWU_pbVG=V^&2`pY5EJ!MJ<;GnVKC zpOMsX0{#urY>7KU%g6BOAg^f|ZbTfB%$X2GPLx<#E`xZRfl^eQ5=3w|oFZi#CK{T^ zCa<3di?`38=<#d|2RlJ7*Nmr<{v2#pSS}plUa~;RgQ2f5X>+;5(zEtB_wSZ1)y1)u?|`cHpUcvP)f9DLWh!pPG3yyVyWIrniy)c$M`_W5+5Mj z$B^r5tvb8j&7%X0j_JJ)u$^xG7MNrUuD~A^{e-zfP|;3t&)kSZOaGdd)zmB6)Ey&4 zXsaMQ8g8O1IwUyYpf|)cfOy5E(m2Qj!cIB1P-3!q%@KEOSGa1|o>RW(th6IdyC@B2 z1}aqm^*tTT1zhU;AqtUw2D%JB1Q7a-LCljXqmWg*^8~Or0%lnE)zz~pnvqtxI%G$Y ztlT+(NJANl=E7eZGgq4Z-PNdbOkfPHB z{1~dW_LI3LBLTx0h3Uqsa=4R{#%EiqgYlU~n@;o``|?PxVYClu;~@yUm%>wc`5mGO z8_Bj}Ri7Es=)xW{%UgUA@cc`)f%uex7i@w1^xZg(OenrZ0jcvY>}0DdEHS#B(oQY- zT(0>@q^t)=$Z*0)YZBQ>g~lBUS*s0$rrtT#4e$#N0W|WYA=e-28~gEI!P0#tbTJ_7 zjby(||2`{@!~g_V3E?c4Pt%UK#RIKJpZq*x6PRO72(Y}s--X<=HLwZp$inp`0v{D~AB z0Dcx@3#xFCb`GB~m_Akdc_PbI8=+3H$y$7TD=D4Q$0$|>q3(4k(K$DkW~@RU` z$-|!fS5iXRYMShOBk-$-M^Eb#=!2>vl+WJJ-OTePEkYOQj0brfBT8jM%lr)(yG$AE z=DneC0tW7N><|TN5qm0X7Y21=Moh5pN8Y)i*3!)+h)ktu^Lb@Hb+9``Kf%KUoP^a; z@~7-)odD%2tTWV6e_SK>C8Yc&KCUlkb$c@pjby{E2+nt)0xOH9G!Mp5cAv&J*Iw+7 zvL7D3nK_CZJX;eE6z6t10Ri?{3S}Q!?Tt2YGHWHral^m`z1ec6?LGCb6{HJMQekFg zC0gIPoXi&pwpPbDmc18jz16}a2s;^RydoKPRb=cqJ|TB}4^#OyY_&Lt9q*>qUIg`W zwKnRT0&NKVs0CDQ6l|6hj~z#vNt7>284kvZd{?u))T6g25!f)va63pY5~<#*o>e-Z zBhAembw>C_W`?ht_>_h}K>e;Rc?mFwib}fw6$m0y|0U2m@hgu7ZW>)HEEz9Qv!q)C~$uuV6-I9*u7?K0OZ9k+#~@r$oq06*wC?(0{%tIKP^( zc}vh4`(6aj%7-eMbw(9DNFOOn;M0;&Vi2RyTHzo&jMP77$$<{2xu-=%WvE5)e#MPD zRR8*UY^q{h4Cfh5la&Aou+u0~Qa(Pk(I3oWDBdonw;=(p9~SKr>J(Wp@IJDO&j`RD zEL~Y`;gY)ib@Z}ce!ft*JPX71%?|OCLXj=6Xr#G4Dz3Y{gzMYa$z`64gz42Znt@#Z z+JHgdmX$aONsv{t2krI-2V%YWn(!>G6$HRs?>+{fs6Kd5_&l3g3-4GyYn(-U?WiVd z{6#oUrqu5BAl%qMC-8%Us869SjkN3Q)R~)*D9K}=)syVID6q)l8vR7WK&NIF=@rUQ zbQ#8foVqF*^_F2bvm&4Xsq8tXdh6I+nl^Pk@GI>7;YJExmjUB!z3~l##iMJ1?|%Q* zzKcSD>7CP!%7MPcR~;_BE_b3nzOe^Ep+23{WQwT_;|n-5kq6n#gAQxU5(y z0byDKofF+j(GSlTmU8XLX_LBwoLTyLP@ah+zz7Vlg z2kI$eqZ=!z&U46VrA_UNC&oYhE7S6L6QM>6gnwD+`PE$Dt@Pblo%cs$nPj!oq>o(SRZxM68{z}$@ z`gD_^-^C9%-#$;`LIHK1l*U9dw3YnZ%WI1*?e!Y?q`*0{qYkCTmSNh}`n=6Uv~sld zxy|-XCxhOaWQ$OgiyPNZqi#K6UkqQGVvX+KB7*!XpgT5u@{IBp&`*yzgZ%EKu)ZH4 z*vs0L3G3G7g2EeeVRgW?4JbD8dyZ0zfmz>WuywkwsFwS;S&r|kj?b6S#)G|3V0ETq zX|q1h1|#>u>VWK14jm1}BA?HG%9F13(*)L-@6JQ=?B z4bXq$NZa}1{T`8b`n6uz?+!k;}JP&2;T!qkyyg(rq z_JqqqI5!vACbA>%Omo;K!sD!UU)Hd=$rTD&@ae92_GYqK?K)VKuDkDN=uazgr5lpD zaAfbh*H>sp%<#HT&JgIeKQ4A;YrQ8zaPd_V!J)n*4ElnpX~$Om*A`V;X&;&cpSe-T zx+n_h{Y^ciP0jo6j9yys^ZWSAZ(Pwp7>?OA6l4*NDSltQy$2NNJ^7}R1MmR5z>+Z# zleJ#L1i&IVkgWmWQ;2CM{`*yws%W!!Wrzgu^Y?k!Mx`xGhVP?Ds-Hxf~EugU>u9 zD=MRfVLejZDrTNrCNU>N-Jyn#A2Jk_WWb52Uyec&AhCB#ubgPx(X1pF!0U0rSEVc< zhTVsxPNhquAg{v)CQHfZD!BGoLFe%c7jmHNnNall(s205#OT&viQRte3BQV#Kr~WZ zm@k~F`W5k3#36|Rt4y$1Y$*AVlN**)r2?llYSq%=vT~+7@ifM5fuo~NM^dtJe)N=1 z`{De}x#g-{k}evgyf?^;NYjTKr%|w|wkXT5Ab|{kX5T9)w;L$RLNWQtAw8Z7Z658= z^hH`33ME5WSZzU@OecQU@#68?!WSpSwo7;Kw=s6pWMpcWVwJQ08v`&XNFpG9t^qzM z`SxJy5;hyXFxPSO-p~ z=9Q(K<9XQYr<{-%y&6Gw5FZ_-ouL2W#N{%$!oaaf8c95T47Xs+$CG8j1Iu2T1!v1nQu_i!;7FCVabKX>AZ10#eV+*yZD)2>Ex z^z7O^Fer_q?6Ntqpc$QaYpKY7d!~AzCJ{IIm(g8G?t7(1T&On@p{np;0NYVqbmT1a z`A;bQG%SoFKP6T$4M|yE4dxMEe@^h;c9xE)<2_9uhA5RO%Pl9u#i(d*kk>12C*YKI z7`nbEW9s-W%{HH{>gAm-_Jx)aSCPICDmqrhqsgf6c$1LKD-nEg82WDFrXF z*w@kW(sL0g6}Z#z*a!3o;6yS2g035$GW&SiQAxt!&{+X2{T@OBNxhC&?Ep(SNnIeV_@!jmJaK#-)@@Nj%c-B;EV zH(m4dXk$_L`q+x9?RWL|;{H8^ryw@}^)0`LefRtPC|orHXxaBmE(Skepk%fkMG-*W zs)wmE1A<*0ER=6(7%R2;&~W~ye+IUO2pg8B^iSjl8{!3|vh+ji7r70q4DrTc3&17v zB!B`qPa7_mXWr1>djwz71P&ox6#_rq-twjc1qAIIM|fT&pU+A0+&UP1AHtH!r|Ua- zsFw|LdgXgunP4$)9o^j|i)QpLW=Cq|q|@ES^DSx0dixcAa!13d5zkEmzd77R2@knQ z_Nf3Nw--Er8@rJ8k7<0)h$rVOAIVvOCnqOUH8gZWdUy~GDBmX@$Mh8FB!>UGJ|8+} z5x#X|%kHyx!0pzu!WhZ&w6iuKyQtFYhW?nK?Q7^4s^RDI8Sj?7Sk?K-w)ZdrwX(vt323F~C7`LT1V_%RZTBhHkreSLhKQ?-&w0}2?AB(``pbcp{HJytiv>6v}R1S3GJM>TE=uW z**43xHG2xUoN)qkcRE`Xog! zK3snYRS+PYJR}(RM`_ga2v?57sCs7j^L_fEPGGSEF1VYg#55I@(YqkF+6Sqmn5v2jhI4AN#&627O=IoIB))=ZTl*cNX?S7^U1iiDb&vOuEvI8&F*ez zt{HKWrBP-$v(Ph0kMdSVdniP}`9Qmx+{%F}EQGPN`$4}Yqs=Z;W2aFw7LkB@Q2c!k zVrY~-tN@+B^KUG+9|JN*>ia*^dj~S=B<5#66jOHp7lllhtu~ zu<~RrLBpRiK#AHYkYmn79}5_Ig!J==P?MU&EjslbWe+cm>OD7jlW5*;Cb&YqbGy&a zj_n#W)*paqpW?YS3B;mXpmpkKW7Uvd+0C9DlfdCoA!kQOx1(;4bNzCRwd5Qom$St? z>_)ljsTc^Hi*l8>uscjJ@dE9KMv{WEo2pzfmkaa8on&6n}`uBL<> zocL;I&B&_n)9Sb&m#9jOZe4O%nQ}e#d)-UsgrzRO6&OJ=S4<0Sst07tn-`f5$XlF4 z3AF7eD({Xgk~zx&1U5<-mRgdG7Tl}8B`nsrAELQ6m{%X>tMj$;_EzZ#as7$UgYN%Ji~EsewcRRC~pig@5+Nkhzl*yYvo zLE{Wo!3nY8f^Ue?>?IhHF|H{>nkeQjEPhV!;*?=FiRL&AOo!3DeZ}^lTZZ5uD`u zTr(eT7%h_Bo5_?Dp+VVB+1fC>&YE`9O8mm4EC&IJ1@$j?e1&O$L^3%5fT9inyhs0B ziUa>j{-1N6ftit$k(JTR+7-xP?O@@^B%+}%t)!~P2=oO09e5&tJ0AoI0EoUj=KmA8 z@Sgo|KzSK42}L!D{|^Yas3b3s3IM3k0sy4{v=0C%4os)|??43!brEq9b&75_V{w+y6h_|9;65AUw(e=fy=@!bENr6nyPA^&&O zZC_g*!aD%|Jy8A=^w&kw^89xc(9y}z&fMMH?*F@QH0v!3j_+6c2J^oj^nXx`13mtQ zWHL0gcCZE-8ov9}|85h)o6%uAA_O4b4-&xqkJ9gPaUd@LKW$<%H2uFiWi)m20$Mpb zFtBkmcyetJYXZD?+3XHLt+K*vmHV(IKcYiVa@ zPcNvdA|bD&Oy}a^66+%yzs1$LC~YK3 z_HRTi^1~(A43!!zQUmtvpg$$zYTA%uUoX(WVCH=wav9$$=2YjuBja+zBHAOo6o}u z43)b2(>0d7D)~&k?NYWd|BeKi&7F+>`8E#{!Wfx{I?0mFAOQJGW3&x#dfS61K66>J z!W|ze8#W?M}W+YOSjAH|(GYq(G%N;wDFvYPXW~(kO1%EQgQt-H&Mt zmFv0qq+QiIHc;9Z?J_1289d@Orvco+eXc|ntJc=5pu4U<7+TNxS8y3nqT6Qgw zdRX~rEe;a4N$&!%bvqScH2yU*V;2&dJvqIu#a!Ao#jjknTr?^$ChTP8?J+ryrQKr7 z)iExaOJ&#`S-_<}Pi40`rk*3idZ=>QXQ^tGq-8PHkos(|XjHWRh!c2q;!gwx5uH_D6;)?BB4zo8obACtZH)8Bb!h>yj=pJv zhrFtJ(qt`}dWCGPXfpb<0vkQ*6#=?ni0&j{g%n6lfYLfIG;VwoHvG!dZwxHs9i z=qgDMgsD$0lF^B#T-I2)y01ING0@{m4nW|bhZs@WXWLAnLZIxEgP^Z!(${hE@@2ZD z4`Qx%DP`9gKTu{iE{e3MX-%KV(zPEpRVdXK3GQW=ndBbu@tlqRR)1QlhArcZS4mo7uk+|kzw zd4oRY42Spz{)R%}kR32770cxw<)=2qK=?B*$$S22XN6Dzbl0893qX;Q-&xgryqE(M z_B`6{ydqV_ZB+Wwpp<1n7e>DLtA)>@MEu(U{5fmxO@!2zt0~xm3-*rqDvva1)Dnj6o!;`p#C9O~(J%~{Kk8M5%ewgmx%wA`7hNe+NSnAGiRxoLJ4il>=ncDmG9 zE$5w+NQoPS#So6=Eg^rO7Uk#PGr0P%sy}ZQj^;N0xs{2XjgV=5*mp9 zeVIw+o-EF;<{B17-1^)VKZ| zPi=@BO5v~oeNSow24?;imRzx|lQI8y%I#CmkX06;*EzFJ+Ra)_(>UK_DPDz4XIY_ ztAU5j{tD=mcjjnH7Z!g^#5spQl0yJ5#@0%HU3?&cD`8=I*t&(As4MO2Zp_!r1o*iV z&~oq*sU_qHh8A4K*biXL2ToHNM&Li~!Fo0p=HwaI@QeG0F7>ABRi<~HWu5UzvFxh`ou2IK*6S&lL~LOxeu}NH5d+s*=Neg zl#Rc+G>x*_f}vjFLR{=tFTjq)DiMlO89R>kMq>+ zyDaEJ_q%03vVQQ|U|)~^xCo8JRy{+!K>!oS)Xr0v^;Heg$!f*e9%Cgl?u$!&E(_v5 z>v(TJXPT7^a*p2z;z`BM(1OcO8_YT#WhBNu9ZHI*_4lDce?kyFsFpHC2AT+sc@~gM zXb+LJH~N3`4+@pcO_*N6{-uB}>Z;A3A49a|W+V9v^9 z6M3=N8e(c(kjWS3?^+Z#+jo9dqK-iDLN^Mm{6Ia7_^^!U_v2FMUGYHvo;!*Q(=kh$ z8fIA<_oZ&Jb9q8B2#aAROoqb?t5YFwWZJ3N{W%dGt!OZq!Nc?ay*mn=v6|qRo5&4+ z0;s(P>%rxjMhEi~aY>AnsV-3QDasTzp8$=Z6J4Jh5AG^c>d}y);n5Yeu-x#s5ME%6 zJm;H@o)mGnYzP{Fgx2~bd^c%KeuOR%>1gf`y1f0D+!cq8hY9Q}dTbUen}e&^mt!=A zWka@Ht;ah`O@}=Jx8?a$eiNHS8t???#;UPv08p zSxW7Q_ao7s$!vzzVeOlhaR&B29dFyS-s?pGUs;k?&O{@sY~J~L-u+m(6EqnqHDMjk zd@61{h>jMA3r4JMb#tb&N|hfNdgQoet+t!G zY(retpxdC{@Vy!!D{CnC z7US+Ff$je)K`mql6}lE-XV|1Dc2aVsUZSId4~uCBKq%~7xo0z1%5Ht+Y*X4fJ9x~; zw8djel0v`B40hTsy1~k2d=X~mem|f1;m7m4i}8b5t|FRp>l4a%oJlE z5h`ryrU{`W8jmfw(sEg#*_O>}vM=2tMH~z#6j&4%Nj}e~5BwhVWW}^-4Jyf8o~#Lq zSevce{-o1#Zz>m^kXR8_qySGRUD`ec6&j=nqClz*_v_@EGvqJdDIekw9lYo+$O~8= zg$+uJN}QXaqAS8pG94o5CTbihNfA=l&FwM{KwlZO^{8w?0d)&fbkAL6PyFKNzc>V+ zWKT{bVj^H{M~BY@Ri@Dn504Dc&Y?t9(HMH{xBxg9mqCY4Y~&3E@r$38i+hc}0sJ>C`A z`Pu#b8X;l=S*pyThS;-q;9WEOoazub;L2T+zUgSlmTB@PuptUw!|?84Gr^7 zmLL{)HoGxwZGfz@6>%t$hG?Jt6$&9)MIHqXDNJVHFwuHJmJmu$jFDw-!*MXr zu1;FVSUBWR(A^o;Aa2d`t0)Agjx>40B~*=tGC*Wo z`8m#4Og16e7dL`|-p=?$rjX$Xbv7qA`eCJ+@RBvNHbFY^P0lviKJ6Hxfu)5wB4ap(@YN&G&HTpY`EWgA2rkKtuDW;MBigN)|RSn&!7 zd#V$_!9ZmBMB!V~i3tVW81gUdP2s;av>)hCdf>pWn9!Lp1cy=XCn*Dr&emidhEjyN z{i-pIC_xT+kS%zzQsntSjO~2)v9oPB$)}Wo(E;N_9fFGXKwJf89hnF7v36loPR00` zX5$_4+(uKFRq>Cm&H{r|)aw6elg%K|7){#xQ&0eWHdOHmMC}MFhRqo${&9u-ttuMLqlf#_#R&kerd-HyV`q0?I_xg4kki?ED`Vwu0i7m`(LOl{Lo+dHX3QZ_WfLi8IpP z*8C(mr(20-MMHxsnaI)S!Qr*ER;7k210NQC+hvajC~<_@`kW!8)M%b5h&RJ=6gnA3 zvoT&xXvuO7RsnGHs04EQyW85eFX<4JbfO*Z2u0mfB1>BA)AK4p;beFugISdQ495dF zXUDeUOzNmQd0jwWvCYDT*r*qVGY+#4idgzg%GvzElAbXUi7edGjARr`gX;>uF{9AE z5UC%_q#Amp3MU~y?6gao~DQ3qZ`BV3emUP{NiHK*PVo?aKbK(5DVC%J!5n-zl zDW`m|04|j5s#X~@2pTy80An%sgk%hsCb-d5=cK!t7UpVxxHm|H5(~9wGl5lNEtZRK zC@XhL41OJ3w|q4wtUkTO5O-NfKH*YoOG_ToS1%}PQ{cLY!ly$oCFIMk(j&;b_^Yh3 zzM`AIGssimg+_3=6v2`7c#(WhfCZNrYKx{yqw9#IiSQJ9=IjjjP^58(dP1T*5dM#; zgURhtZ0lCVJrgG?1pWE>d+=-Mrj&F=aR^(Yc)I9FdC zFmNv;Z7~3C_O&_GFYOpqJD9R^iAoCznc6D$+3TuUbgJ?*o1O&M`;%qH+74ZB3S4MkHU1wz zV7Xlc7;{%=fcKL}e8%PcUri4}B6^=6;-SW)uzr|NZkN6{5rJPP$^q9*42%(mYB*>gMxqmBnvDQPdww2)|P^`@gasSm9jQQLPXi{-GPb4xgQ`^z~ z^Ue_eIH$Qyxd9ZVM#N=K;Eu@WUCuLeew4wTF%89~zmJzP=^2sL^4!K_x=fr}!FKuZ zktNOu@I2mawjm?*GRhJH<*i`Mo)35XL+3Q08N(CDB*O~0Z^TDF(BHts!#aO+>5Q0p zq4W+O1pdlMCn|oSrOjq8#4F;C$Exd1TbMo@| zJim@U#o@zpglF#n#9aKozSon($KdZl&V@bJLiE(F8^1Ghx{+zPNwvQS9bG7pScB;K zo>^FzUMN{jeEyuEJGzwW{4tew?H@Z%c&q`hrCQfUwMY%gPx4e=qfiY|m#Ivio}6io z`#Xm)P2Og!R?$Ny{ruji+WbI^(&3@svWq0SxNFUA^q6;hqXKV?Zw4`2vYdoTJyF71 z#J>13a6OOvns;<298(w?wd6sK;&Bo$pcU>D3)ETW&fSsTIdRl|+%{>ruj|YCaPd;s z%BgZ@;{q9fM*lmI#4bPvI-b%c#Bf&YX&Q^z)L%$!d~-gK^@-)|wFKVE+Wy`UMy9Rq zqGol;G_ISG7xkJ9cK(S*lqD!C3gIJ}J9Tro0&nzF!;$U;MS_>A+jJ*sZSL0Y_M{dp zU9>tczNa8z)e!ZUDI0`w*UHXNC_A!Y@ebgSMj^gzex?n>;fb7nm}I0v;(~fu7u_W! zXObpa)v$u%FYd6na{7=VAjEB!d$E`Q! zEK@PhiR&l2>`|rNX;)3_Jo7Q14fj(~AA@iw;H*-P-Dpw(?E++6(tYJ9u8Zw*JUHpudsWChU%5OLp(D-A}1@Qg*Dl zIe9sGg1I)2a29|&v4qzAx8^fJ+#51Ti&elND=L&@gBuBn9@$u`$1}B^LGD8ayK7r9 zhza)%>{g^kJvF_JJz-H?+E%=$fZ07UeXI6b?Y0w&_R^9vG5y#($XyE#ySUaje=w?~ z#?LnaU2SP?1K9G$Vmi<20PIuUp{7>YlHRJma`o>~Vp)tyzfnUFrSS-ThbnZKb$SVU zwV#9uQaQW;6f}LwS2U;)(@h>x0hDE@7OzOP*FZk`8lIn)r4i4V!LbkD zgY*#O`J@sT+ZH6h{3Y$fZkulj`@LdI+nm8NUQDrF00>;@rGn+1V&!MQ`#vN$uQ|GM z`*P(ALG)d$F!$z&-Mnm0gP~tg*arby!f$i}%_wADVX-&$cG2 zv6s!76s@yPRUa**Jc$aA-cG<@?Rxi?pUkb>7pUV#bGonhWVw&EqkRRphw_zgOFnO% zd-aB}>$ZV6>cV_I%9M+81L}~|&s>lBSYEcAIby%?#Q(+3N#2%#jnu7>h;Sg3VKOq2 zp+084B*eN9m{YDO2Yaq5Rq?3dfURs=H=^3_Q}r>Jai1$<#brk0S(_Pgw_Z;!XFyg& zc0udN)V#lvRvSDF*ooKA?kDDbW~JA1ENmAbw*(Y++!V(H>dO?KdbsE=lu7UQV28JN z#c$7EMXg;lZ(KhVAQ>PL5?^pd`0d7?Kn~ROCgCi(iR4-(PvB%AQKsW@i~YKG}YU zYl!X$=CmyOvqvbnVEi49Ki}wHr9}kGe6hj;V8xZ>Hzl)`!MV~B!r^Iay`K4OWhgI) zpNGr8Zae#!0Mmvn)UP7J{2VtpdY!tD7Ew=39NK$$qBV|bpcNX6pywLLxKp5sBt*}$;>BYH$XyUoZq;K4x4R+gkW`!huiLv!TF z#g}kt`m`WXvXso>$aSCe|0W-S9m8`^j#;XAFU&V2 z?>T`!wn14X^%I18D6g3nSZ3+-#rm|S+jkq@1c>V zE_ZwVui|DZ(t8;xq*O009h||sybssCKT^?ZSaJcevpA_!_^T?jvf~lt1khRi)STf5 z(IMt9&O1L5*{)Dq3j!bSQToAJ<}m$PFHIpscZ;`mbbNaCZDnlPy()hoSKXPr;kI8M8B@=|i1+r5 z1=nB#KVL&N-_ClNJ702fmWJ9LxSN!i9p!fap0*UFcdi@kg~!`YOUinoDb#rwOY_++ zRO;B-`vNZtV@Iy89Sbv^n`IZHIoG3r@&M>BvO#p!-x*}}Rw2E+sTlgUf$FM$dr_uB z=B5P3S<{kJfh{5AJbj%%lt`NMFsqEkQXXv41v0xn`Ct#@kTo+uC-M+w^WPp5D376r z2XUA)F}h@jtqOC#N!+9jN}bN{RJJ1psMYYyPC_F%?EsyR<6B^5jXr;OpC%KsR<5qh zOJABTFh^(E^0uY$`B6A$#mNkkK^_79T?0fX?DD)!eaxYEx)Zfyz3dvDI2;AkQ*jpwcyR@%kWLEMxJIU>WmO?p?^ z7a{))Kq2Ca&b8L!9t5OaRNJQfS*^4RzHd!uL@m6fRZBl+LqTKWmt2q(V+wZ&0l&Nw zDj!lEdWB0v(15+Z)OkT~%00Bf44Y#y9}{lL{;4Q^f37~W3@Q95dtIcr@ln_(qRNo^ zOS^iUfQX*d(4x+t(R`?>jS>mih{E*}xKqQFLPOfjdH}>~xt5}|3l@~3pM}hHkIf)8 z7mqKadVW@`XO$?t)*2rMs9%G1dRB0d~+6mI!s zkNhA`L=9cE-#0d$EyJc+H!=S@d96_jEW&YeWprd{^k3%T@ov0ick{A zXfnGfF6Rfo^v)QzwDw^)A z2ZR1cozOZ(XNXVB<(tf_nAdpobV$xm2NKtPn*@uA@1GO^-OY;oTwCePRl?Sgrl(a2 zKk3ob$>%|rLPt=fAH}X@EWuGmZlivg=d{CDBi^KCSzyr*pH^!sNj%L zHXQGdOa6Ok!0a>FH8I#-=rt15%J$Hn`$v5LAAJ7b+rIDe{9n?K_r9;M-QSnG-#&w^XqjJph5u0XT*^Ez1pxs72!Z@RR6R11!lH7@qW`1n z(N&hW-(W!LJ5}a!v?`5p<+bg~97eGwjKfhLWh4pnfO161ZuI-?K|kA&6%uOQy}b<{ zhOH~+Z3Vo!@b>WWc>6fN-~Y=#R}(k@Hb;3y3}w|Ulw2r^ zbqlwz6blxPUD55{Qj-9WrJgTe2CquM>l835WL>1`DLi#Uo;a$4yN0(8)6F|D61I{H z95Wg|zcP$?sIZ-j{c!hhf1KPyiQscFhJ3zm4D^6GG{O2Juxl2@n)90bY>UI1R`Gfo zke)|py@(9u?Bho4vFJK%F#nqJyuHm5Of@eM8m29pd{gRL?w@QR8veLeTw+<)4o97h z;-ATd03D03v)TbICOpyGkTUKcPxMb);!bZi>7?s_3#8SfRR9WetKGx<-YRtKjjRhT ztXtjofnZMJiSKZa)`h>tasG|(9QQ#DSE_SCtBfN88JaXpbWAy=5qYW!qaDcK6bqK4 zK(or7AZ_pt=NG{fOZ?NM&`l#qg>XrP%o8hkB-tt{`U3(ze5@o)wjxAanI;g#PBnno z7PF#5O3l+4Iv%n!Qjfw#K0}(sM3J#Tv~D6J*q|6n!#P>5NavhLk6LxdI{S>HstEPQ zj8~x3K$Bf!=a2M|K5kS#yeKs!Wkxyn7c`z}01dNG%CLgO*a%m6a^)&go+6S4%Hrz8 zuIpeC^@8z>L~ER9P!1{6I&=&}nd%$86O}YRkWx{JP?|I`??NObM*<=Jks4YR_SXhP z{H&Yuy(>MX38q5|$R8(9+#ldSeb}x}x=s}i0DzMU0D$m+Q>Mv^stAe*stA^9X*+MS zq4}NG^~>S2-Dfn5Or(2U%y7kRdSr3nZAzNw(?o=ju%HwIm7qQw`hWU?1K2mFX4T*$ zMGYQvx83FdpA}PhOhV)NA#O;d<~MR+fvx&b%B@F{>%Z%qJQln=A;boCIdvR)IZx81 zpjFeDkU>+zWK&Mtv5g2F`&BUvc(s?0Q{Y@;6As4?V~%bZmDq*zWcr&V;%IccFuVe=ECNYgbbr)_xtGP>!JsNM;Z z5wWj*UT<@Qxty+96K44L%y#P}cp_|>bO(U^RepK@SiO|*(*;MzWEYz$A&@vwG_h(y z@dVWArhw(}(RWir~_FBC^Vjd`xO7%uOk z4$!rHj;MUQ3f!&KY&hvm+bdm^{5mZI_|$nkMw&Fo_u!*9q`uB$#Y!t7PIdtPR?VlP5UF0(B$MK{^E){g3*q6CfHnOJ^R z&aB~_|9xqL0$arU%217WaAAmY4SE|Q*{n0~v>#e@Mltv~4aKMxVLvj^rjShpfhEWB z=O<{d?wkxN$U9`hL}@l(24ir~JrQLufrMIFhK9kUtWl8|I z4^b0-zcV(m$NsC(hrRVeKtfYEnyCaP8-@V&NrX0vHgu957)j(jzA-@)~0A zeL6L@9-0keFspgTyW7K69e6Z69*!~3PCMcL9xvm5_Y}$nLFc$^PxA%E3BiX=E#3(f z77YsFS|Z3;ON;}QD2zYmPdG~}^p0e5%BYL_SSxd@BI%-OoTP@2Rua>>>Yy`Qa%O>V z+FMekQd1;L*)Vl%XlNdf!20jAv8Nfzr>^0i$pf${azUt---^%?6>3OMcHLFH5=PRz z0#XL_L#TLaAWnk{g6NguUpCpss?bOa*P|3*_Fm|7(248*nSh!7QGhbD@jOn_xY|Dn zUUd73*s0J;as6J_Vhwmx>jFd0#m?Lb`C0z+pfg3tritRl@HXeN_cIFri) zb}`9%2V9{{AT1_4GPliw82HV#C2CG2KTdmXRO%`3ZR6 zMC^RuEZb%1_;h!7^?JU2{9V7LL9_yFYwRl;0}vvzK?_x7MGdZXX$aI%AGbiP0rQWZ z4QSP*4xw9>hIx@tLlGq_O&c6HqA{*_?!oaR7C@dmkK7}PF3!YmQTEnKu+rF6fe&(F z7%JKRq`qJ6-EtZfFRsAcrafQKYZqX_S#Nou-0ova+2?s3%aZLG&+QhY>`0QK-_F+g zcYNJdTH}dpB|{@z;JlsKWWN>E2}FljRSv^3sj;ULp}`52=IdT|%M6!f$>OQ=g41?X zl!#)Y!ygE8V1xz_?fGx|3)YYMrR{3;q`5-K#1M1y`|bP4$$%d_j897kR~*`)gez+n z7&+e#M22C+G!-{|AAG$KJH48}NQpc~@P)>cf9~nbxc*BgeLMD?td+hss0Y~0hy&Ach*1J z(K!{GD)luLD%#$Jb z$TS1_Aj|n3Gxt>1=AH zm9Ok`GVPN!+WXqQfh&aB^UT8Sh6JC=i~5E-Pw6H4GgUL@;k;ydtT}dN#TOhqhC|AK zV89k%n$8Pq)spUa9=*7WTy>UQuZ^#yvw@NUT=);TioU9tl8RAXX#ZnPld>i4-M&+aoNa({$QzU&Qr8% z{9#DdD85LnTr0iC?c!_2G~>8J#TlaFka!cM<$+4U9aQ!-QaA}#Q@FNpDO7cY%ihx2 zsUI4ElqQAj=iBu=YreFB<(YDSK&*LDLm8)c{VQ*+;WsEFjC;+?ikP!Oc&b=hsF(~1 z8{`A-W2F)n2AqTnU3Bs+L+4Rmh9u?i_qb?Wg(*{H z_FA&X1$I(3JXx}`iAmqlmLeLxG)&Sa)$r4TCeAe_Y{Kb@wFK;<7Svm$w!Y`)u0-ht zGSQ;D_@W9&-$GUuib|48w-BK?Zo76xl_6JhhE&9r4&(J9wEaHxkP0DgNDya~n4*)d+hEAuASVlMf{hMH0|)my z*vu$B>pb9Z92#?TIfFA@Is>p|P0hfcWHJoWxC+~VS})b6-i+8RCcsetMhDX%v{qqf z{5_8wKwcwduId!qMGDLfzsx9bk13M{6ll9WaK_V#GG(Ed4~I>QZrG)|=L=VoX<&h6 zi~P;|OhvS_B!5&3evBPkiD;22FUiTYGsO&i*;B0UZ8>%Q<~^TP&oi0AXIWeJF@Beb z=28~#r&RJm)4+ChqiE}Fupwd-n#)-6eFub5d$+DWa%OSp7mgcw!)WsY#>pNqTm|TG zCW)q!gO`e%XD95P4ghsVt5nL&_bE?r#mXrUoiWtf0gf2)u195ViHJ+3gNqPk;1$o} z%_N1F#z7VwscYMr$?l6+#`TCI9aJg8q0jko5fw8uz5oK+fvGVQ$aW=RK{d#NFyKNv=(|qkEP@LH&Ac9w`M( zz3Na0TeKY8iNIlqsZz0?AO<_(h+o1G89&naY|0V6+}v3GO&YPTn2j!&-wT#u*P`pB zvYx+|mk`++xbLZO+ZC5WG(^kDv)V=!Nuj)J%`6Lo7ltFW8o{?5K;q2FT~@PViq|za z2LW0OY}{|aLN#fo)4(p*Dnnh-rSBqUGmjY?F()ZXHlivf%$eb8 zjYY-}`FwcnO4mktW<`IHH*wTz{W0Ja^sXJgt+{AgU1Zles-4hc@=V#f5P%D9c;@tk z92l^=6!UxSOg6c~DQg*V!-jCDwkN?i#7R1UR+Tj!dMtU6E<$t-GFI8poK;yeLp3&c zl@TAL8mnw*u3+4C1Wuz9`3aRqZC9=Y(Q0TQ4>$W4t8(bS&U1UdoyDct;8)x9kLX=W z$aNC^?dq7fEK6x0@I(2t?8>$x2T6T8Q4b(1mhdVRu3`Ip?ZUZM+g=KuERCb95;h=X zdouSZm?cld>vzZ4F+SJ~ zD4!NRNn_i6E!6O>v$nW8+`4N_?J~KIuQeO+tZ#Eow^zmPojP)CB~oMWRHuZ}lmBLU5GXST0&3NzQg9A9rQmtTfwKYo7x-L%d&v5`UltbL$lu01zut_r9+ z7zB&3_WL8O2JXKV)_3@G%EVq;s=C7^TiD83cO)ek$NUjF<1we^{Q^~u%~^G64CuInE@{z3<1(@AD>3S6AQX10q+q z=i8w}oOCpXT%#tmf~xROmN42&+|HfO+SQ(Xs!!xfm6JiwMOv%V?aAgDeSl9%aFiWT zWq?A7X1wo-&sOK;%DiWj<#ncGDJhrJ&rAnSPU*~%>Q8%CJU11 z0hv!{couKLK8s%f`KufqAt3v(taUd`}*um8eT7zXEBWq|x>b@gAZ?PXmIbwf3l z^;-gnVmBedyJgz7jBpf#Uz#__1pCL%nA`WHjblC{4zqK5KPoc3v$`sYHzg9$E{#Es zu=i!#<|0ZzBbx;g+&iX>G$GC^ZXPQLA<9&gH7L=nB0o;mtiOHwZ_vOrEh7i5H$u$~ zK3hH`?~xIOD4_~`K-=u^O)QUEuKl0K^9te|1x%DXsA5SheIsHlGK^VaCR+j5TDUwr z2g+6H5|t6>-iD0xBs&W>rBU8YyY7(Sm7#Pu7@`XN7jp}~Gq7mO&QNu}a4XMKd6Qe9 zI>wbfQ#+>9bsDpeo0@5u;qw?VCKh(V%litXL##G6_-Lo$L zy7=YB!HL=A5T2JCNnDf&ZZ_uf|AqfTGcQ{wt4k{%Pjt3Y;RnU_dYVEBE{c2??S!I_ z+4oP0)kQ+LymwYIJ}y341LSI5Dhq4u0~mbBvl1+ndU`^UdmwTrE){|-mdx7fWk)g7 zzVO1(^YAQiHmV%TYT=m&_RF7USc&C}phXP0T3ZWvW{N4|G?JFB@UW}FY)7Sc$aE&N zY$t2o@VjgmIi2;G>n|FwME9%1=iMT70+}!mZQ=_~42;Di;4zF-`D{r>7 zbE;+PZr^2oGtvhkM^7+KALBt$FV%Ijb7F`BA^COxuErxdq_TBQS6w`Ru6E!Sp>(NW zKGIQIJQSrDtWOXF{S#d>4U0k=L*n);u}bPqe{=oarc;bQHWekdYBX4;*h39$#gH#H z40nI}(qcAY59(mZ`%C{gd~@6UM`Gc9v&JObc;*HO*PnyA?JB29P)y0n$s4T8@^ts% zj?pCVR^oM*{XX7c$!&l+Gx^jF|MI>NreibX&>0sx8BicIf%T=Ve`feR07hIK4l7B; z$MAQs(4}1fameo*{6Ep5{_;f){eKZ?_iy0+Z;_}jAu1{ZJu4wQJr65QOEoh!+oZ&> z#JuMuKP^owMKeL)s3ajZK|>cw4_>J_$1umtHqX3p1T{HJKmSa#0!u+FH9aBIs6;_Y zC3_4dDbuDzQNgk>{dZP+S$67ANF)ZaNc(>QSBxK>buj;y1odx_{clTiv3Jn7F?BPw z`5*X|T0&+?;8yeZWy6EfEIe5A%4a6-m z!1TOQSJ%F%aSio@l8_je@|IkBN?-1Qe+bxQb8|e8!8PMbZ=60J z(w2ua8v*9`@$mTa@?XQ+4)8SDv?K$?#{olrvMy(@4fRJeQ$P?$ks*JWJ#+^sDW{w% zQWlIfpwFfElR;I{-WZgiPY!Z97ZS& zVnyX$+?i%~g}J0;`o``hiLCbD*ulbHsmZTuLcLL6ZXT0_+B$u<^(OVS%9c|7dK$zd zgu*}?QrP)wCj&rZgA13TEOYvzIqrY&JCJ4`mdcOfZCyMSTFt2_n@*mu^--SL*2C~M zE}Mlk4O=EXY?(BzntFn@9-JdBLZ{t)er2+w?TjgS@H$d{t;Xdfs*}Oq=Y#&eOqEu1 zv!%Nt%!#Yp?UfqiZilDc8scA{{;zsrij63O^3QZk|4fJaU#7FPv;6-oCz~K^J;VSL zcKeQ6)MJA%xaJ$~`@}%e<#NRo=7?O1xTcnHEcE-mMG|`%?SVg0$Jctts}PchBNV6G z2#3>xLFASo6b{5iKoJ$+|4pJNzIjrg|JUkGFmkwXW6=3gB^Y*F<;Cr-eVN5UAZPFA z(f8GLjTUxjI7HL@mM3s;JTc`s>Dvp*uV7&oj)#D#J?IGwdx%cT0PvzZyEB(16jiU?AIolecG+HQ) zSBf*ccbMNQ|Njhj!Qx{r$$!7l=^vf(KdsCEf0Ob*Cdl5_!O-P@{9jqodXoXcZ?%pi zDc!`Qtc0F8K`=e6rW)Gx9E=d8aN|@&CQV0D&V2OeQ!Xi)m3T3_WO3VlciR_h@KBGd zqC}{m$0ihr6nY6x+QKyw?F(<9xCS?aO3w~Uan3D&i|H+HMY4Duf$UusOelT+dg$Wi zEO`iu5$pE$B>LEDo_uNEEcPBU8$-h;CV6Kq?vBd1kioThjyUBkRE5qwm6g>&ucfzT zoO8UBaV6Np>0djeXQ#QsWH8JylSTDX9+1mEu;Pk%`%FVfn)5EJ(ruiE{tCP`-*0n< z|A~GdZMys4coY>~26@0R5PG+kj3Bn*mw+_Dnh5VWui`EkJ5#|eJZ-9|)>^^QwIMH{ zCINE(5ZXp3K^rh+uil^EM^@-qr33I@XqY@v6Dh()i6PG_U-U^~aRTB_bK|hd z{o_~ieTMb%*ajqOk3_#&>kGfa5a(it$vs&Y9P$K13Y2mNsArpsDO>&hlT^al$7_t8 zUU=IG#oz&g8|Ubt6KVnhAsHm+q~jD;{%8!cWi21OQqmn1s^XA4^WqRR!^y=8+MpEB zaU{`%Hg*N&;_*J4%g)ONImx1(7%>G80o1!BO{>$;7p4QG>N~+QDU=i~uW+j8vo$Cw zYAAfa1^y@G4Nvm1#lGugZd)3$)q0^@&egZU_X-6%U|OpMnKv>Xw|tTv_`P;ISR$G3 zd@&{vP`e_up>G?KG1J7Kv^W)U%1cT@<2oFn*01q<6%8=pc)^E3Hy$l8%$QNkuMb|c z|7IaBbiY>f{zdQ!H~;{~f4ZKti<7Idi>s5V^FQ~yPMNS8Vn7hM{fQ#%7~Tt6FfItC zqXZG6gY1DC!P}&YI+8jR_~|t^A8-`zmTi z1}c@D13ZQZvAZ59d)_NdV03TN)c~nG>uw}F8@fIt1F}rwx^letiNG8HYRJox%_n;t zG3hI;Jk4ooHg*PsgT6%7Y%|rf!X0+gwIB%rk)*m77reN_3Xzbe!i55~($x?rP~W*o zQn(sLB(W;48YZI1VH$>(kx?xYM6f>Rm65HADY|yj-s`X3VJLIJ0cZnJ-U)Pe6oTQo zaN*Z);X@dUH$)h`!{g~V#179%4BQFagvP4Z`S_y7FkcT-{R^f_)Rk(8Txkg()Bhma z>AdybK=m=HwLRJ=aeW^WxoUpkZBB;1;E_ajBBUAtLA4_h(U~NavlV^r2R4*{6#p{S zxoUJinQZ;H6Tdi?B}4ZO47;AwENKZWJF0pA8sp{S4#K_MDOCJ)Ca~^&=MH{iwRQ$| z%bNIi`E#5866(g+$WOahdV$r%`p@t}ZVNRG-+vXFO8_34H)XD*kR>Dm_jPlLLNy4I7S`>(HgNi1?X zpC$JxlgSP#TZxPKV#jgMGy^10luKrvw&#ki7OzU3W{ul9KxM#{o2c<{2UsyB`&Z+Z zr}hhBYPcCkP^@_)V;`MISUc++wKpT{jFS<^PbZB5qpZQ~D2Bq^QrN~r*i9H|KX6OK z*<0br0VRD>>X&nM{6Cm;+^HdztyMQboIKgh*l99KvmHh{JbmSK!kpVBy0h+1`Em7#SyMl7t>0)sk} z)!cfE0@7A%vRD!ES)VUc?Ng!)7Lq6lMLFC^;;82BtJjh0jAVC}&m1iUYS8bAz~0&Y z%Vy5LyxTlgwSRuvKbpMX9bH{LU6gIpuR%pz__zXc36+r_|K?jm*+vPMr%q;v*=(q6 z*B!@ewIUT#$%2IqJUkvwsxoIxC4cfDdQlrvKGVVbG26i0cvr2}TIuEF3V1c>n5k1( zFo=#)Y9v)7F*=tW*>3W}aNaJQa%o!UCYI+6k_vewH#eMqgV?%0Ni7>wOs zemHu-q?zjfm9|M45;=rDJwt5IJ`$_iv)DirI^0>pd0iv<)RGS>%MFbAx+kg?23P$5 zLhCHraELoJ0Kmt8;vfI>E!Y@1TA4WhZ{OB}W%XZS^|8wrl*o^PQ-^ek7Dg-M_iW$-D2z^?`_AL6+|3B1jnMYtXQP-aJmbj!7a_V;16@ z&N4HJC#y-Y5ws!-6uDTFQIWABHJE;7s=e6hopV7S*l{R$+I?Y*xGrf3uwX!elu||rHO3;pU?kck6(}y2z!zVNlR-Cf25GdGCw;-Q4Xh4dLqTcatkuQa_ z#{XlpcPi%EqW7e zJ5Z&rYdlt=dr7{V6&DDjLEIf+YQNY61SuwZ79eM#hpe5G{B+y~jzyV+X+=?r%H?SE|X_ zW^ZHzA78%xNR}$9R+@eh2pC0&7?6GOz$sexgdu)(E!|3}=?XJbbMkvML9zb_nw9z~ z?a&K7)~dcfszF}AKEGoIZTf>zWMmucmSD~UXw>`7owY9JDFKOlZuNL2OAN_W8gP$1 zb4(sDiyj*Z;<}BrZZ9Yms8dsTlKDvMqlmTsA<%7`8M6F!cxf7k>JZG?ToV zOEeyS8^|=E+pf(xtU5W~F@)RbR-&B&+9lnqyFbz&7uc7Nyoul5n!(Uj_xE4*v8lHQ zkFOgOAa)eWw#4#Wwc<*G%$>{p?U>~+v*3DuT56UhC;?$8{6=AjD+0pe`xF+=m6JEf z6lO}b(=BH=>oNX5HP;z|Vi5Crd}$Cte<|7m{+Xkdgf^Kcgc}gg#Z=$VPnW;^BEls| z!%{@jkq1ND=-Gg)wF>*9tvUp@x9$}&IGg&43Fv`BV)o9$M=9X|pGqLxF=6)e;qLpf zyEkhGkdfCi-7=Mxcs7;HGc*b-$pIWjI;{-sM5{)#K~1N(I`?Ym&1z8G2CTt_H}hu_ zcRJ*`I%%X)N`fe-&K?~_Kro_XhUGd3SJBpStcn6FZ*VtgpV4zOd(u?Z(Noj&`Sakv zv!VqEw(}<6W;wf^CG5B7LEfLT04II@@BSla?~kivCSEZ(zJH)W4y@EPV0^6idYT08 zd_4$bN2cD7c(|!~=b}G8B77KIcXwlei)kqlcsq?=Zoa;StH4Y`6^0{cg?Ceq5zwu= z&&&@SoaIMX6O{fH(!7rh@Zv?SL0~UTuZVpl&LNOB$e+iC-kh9Ef?_`$1Im&Nltt}s z7cwIU$tUa|XP~uX%SZ`HM&3TL(D!Li8#H4K&WF@U;KIyNz=L+X2zk2!YNNuU8-SSP z==HCYMYOsyEz4IG)~2%==}jnAcwh~{)YamD;>Z*_@yag!EHoqa#_58JY*`fum%6BA z$&~WcXpMy<*&3AwjAx)m$c|+>L?#WDTFf+du!J)~Cy6!-3<$0=*uL@-Z}qJXIm$yHociz_L5 ztee_)aoP{8RgJ79oAA-q=e$AJ_ykv+sb?f}d`wI^g%r$>^^>R6*USJQ@`GpqAXb6W zFb!d-$el|2zyPAE29Ci0z7p@l1P@5$X)k#E;4DBI{qjMVG4Y!gEg`p{rP*#kw}1%} zt)%%i?W<+`hmcTrp+>DDJkaR1GwQ|MbqsFe)vY47MP18bL!xj2*n}Nb(>KziMUPb& zIz$9GJ@wuiN?UCLbHIXRi`EQQ1KeRNswps1Cls>MS-bNn)N5NWSv6ZU#D(-L0I?Hu zgMAj|e9trxDcN8Z-Lbrb%i+uVLPCih_Hc@BRV+koEXENtYm>;jb~R^cc6~%yL0+M( z$HdttWJ4SF-0!?W`Gl&E5%QKl!T@1S15e=Od9MQc0L7J;hDdQ zFz9HWxAfm~A1WM}*PRx6khfGaG{Q#m&p}#*EqS|@tt`1IgDP;sA9>D$P{c{u zVphOcY%Jd2TD0Z!Eh($O|uM6UKxnMi)pcDz!Ue#@6nW+aGaK z>}o1GO-*@CJ1At90c>3K25rL>an*fpiZML$8(0D7VOpDr>e86xXEIuGSxk$K5?R5u zW;T1n_mTx#h-&~XhVN18j`9jGNU~f$_(ZmVBi(F8yMR$|!*|1KdXWa43g?u zOX6_53_tm20)Pak-3=_hv8^-2+G;e?reVa(kMG-e3~a-Ct++zWujf%)KNTke7V;e9 zJKN5?i>;eq%@RXzZZ;4zu?ouQ^=6PXQ>)d5yPQ!f$KhG^&>8QKz8K|`U4Hn)#ia?? zJ!?d!5u|Gj-0)HT>ub8$8t>ynK%w(nhs?7qb|cnGcWE=tg}*X+83PDd!)D4A`bOtM ze2t`II%HIA*a+0qW;Qq3_2b13o?kCpoK+hyXn1Uz*M(W;h^J{}Dr+652lqAlOcM$F zqCh9c6YWIWVx(#KD*=G=O3C?$_PG*Se{zE6M$4-0<(vlcvWw(VP%g)+`QxI1BP>!* zu5(XTyDC1=`7yT9W_WqkbHRy0fiLpu%1~^O2M+rIGq8Dj?qjJV%X`dQM(0=58&s7S zp|TRNIWT@)+a~VJ@%94X?n}X!p5e>K5I%!?yY=m-m-z_onDiPx#Dq2Xe}LY`YuHaj zIZetrSyaaF5?CUWc2?cP%xj6Vw|eDkupYTS@TB4fi^whmd5l*iq2C@&Iy`=Uz#FG8 zbQa(1y;4Y>H6~vzt^Z9$>0(mlbEe_is8lDkQC4KoQ5{S$9lpSS>FEc!;pKAjaNWXXYZjS6}2aBN`*cPp{O^mNpa?Z!8I`NTuG_HX4jg4>059?0~q1FsS9%+F|U z>P#Z^76INC1mj-V%64@|&$%&n72j``M@W>ri6>r`D)Hd<=6(bR(%r#{e9aQRzV_|f7W$qu@F)Be5^&`wuS!(bxn^%iV?BI(e>0KLl!DhAgQ}<-^fGx z3QWlp$>uti9}B<4SVWv`V%i?FuX_jN5+36scxd@p;iOC&7}io4Xu|1 zV|(JdRMz*KZz2O4+roAfXuv{cnD#N^#skYr7c{g-2>hn-?T#Kgz$@7blk`f&@8kXpeV;N5YFA zjF(-~hZ*x_{GOWk*5tofiZyS8Z@S2&^E8QVLLr$djFDK{B^S#Fxb;xFywa~HI18_A zrik)tEtvC4>|2f&<`Sp!V4&q9Fu7-?^q2RHlB(lxA9~Qg^&F zl4uUP_I*{1+G{I+2C>G=*Wy8$c|89OyA>)o(1mm+wNp<@KUAw2pco^`jI*Qffw86^ z1qV&U9h{qr)44eFCeZ_;PO-?uk1HNzt688_#|tRF$1=O)hV{5Dz!(D0<#hQHOzy-o z6Y}guU=NEVaij-3urQI_iO&*!$SB(J;Dm-QS}2w-)bC-#kEU!_k+D`szZZC1OWTU} zY{+n2S#kO}y?G$D_b&CtiZ=ab^-88Mu!gsU@gd&H!{mnS4+(hDVFL`RSh%x}cc{qg zDy6}9i5@Tnt_SRQaPBazqy8{O4S`KK*dFr9I-`1S=lqGHoz>oTP+&uB4+ES0z)%gG zVfb4xoy(=j!DtU*9UVCdRielaT&@i8)miN|%`d;a5r(-sqsxNA*zbxxpxjEtyVC3F zE~l=VppaD3=8CawKvJ!$JGN36x;q5 z*npLSafO^TO{NwZ9J1a!#C0}x_CEC~&*{8sZ0V-3t5SXW0^VatmQFF>w!@CL#4!icR&&@S88t5}2z ztT`$1qq;-q-4d=z;QTl*#T5~Dg1WotaZ>83bnGJD5<0c_-vtIN{Wk0R%z_w1Eb7>3S;7NGT2iiWZIFw^(X_ju^74$0ah$>u(hX8sdS@72 z8N$qnsTLJeZ}$lLo0zI#!o)+UG02toQh;f|~yRv_g&SIusZg z6c*l9@DQnev6}SDb$S;yiQZUF=?(IGxk`DMimYkytpbrklB>7gX{gJ>&{KspSk{*^(kWCW z%;WjXjfT2z^{PCU16O?kPQ?<}8y`lKX<=E)dRsuNpjfdq5HTRIWr58B-I`7WOP-tAc5jbs{_P)`LA*YNrf$4JM8h zumHPwR{XmV6fcRIyX8xHZ7|=J6Wa-{Gvp}dY0bV(OUHI8os+3kehS4jQF$sB^x^XO zF z2;8Lo%Lgv?kU3>5ZhdUM{w_$6^Md>Oe)vt z6wA#LWKR}g*7c7X_|<=J1GKEG_3vjOeR8S(*zSLZ*yiP&&N3_j07Xv#0QCP6Vx8iYp)#~-FkYeXrt@KT#;jvd#b@gD(Fr$O6{+nr{@)G_S{-@h}?I9A9lDU3Hn zqK%3uFZ3iU)KqrDOi6n_xge4_m}9TpVEB|(W}=Sj`8ikcW{FNT6rAaG|0%IR7OM-% z58KP;^ZGq}apKh%n5%58Mz!wGM~YH3bn!H6re?xm>WlB6@vptoXF-3wbF>6%4oFla7sEDVJc(IhVPY8A8mmAIQ^N;?$* zBjJXpYA6$p9Sc`f%yKY+oi97`>_KqEsA=?M%LT5q$Q8Hn?3Xe(^8CIDQ~MX4_w(}6 z^oQ;D^@dI_tLI&_r9&;7>6+OvbdJp^v)J;}DNY5sZkz@vKBmwN|4g>z;fRAuS`Y7k zD{@~zs4e{Y4D@f$xDjvDPS2F`>-7yttVK^QfO$fMuA7{}WF{#M+SoafT`rf@7sy>*MJvtR>G~&2g`xH68OG-P~U_?RFOrsm`5rw2Wv09q;8kGss7#ON z3!4W+^kgKCs0JJu2?=HWh$0J(G@Nbl8@e?_MOjTk6F69dv)~Nb0dfi!FK*0-@=;0# z))yxEmw<~$pmv=-RQ21NTE7G>5skZffK?ZgGLlPxvO#KZ5diC4(%jfcQ64SXbTY)= zUmLn83kyRdrhODnP%EBO>iC+COCZC#m^lJL(mCcyj>{U@qwA3Tx1=Fx10=8tA<;7v zQ3Yi|%YKB6h!QKbFi?F4L@*BE1E`sK!(ZiMK|i1Z5Kx_z=z+eTkUL2we2+t8-J5z5 zO$8FFSXb*%|6LM*N^yL~&?NaZW05**{OR1E5N-xTA#l0Ql%JOnj;dNafU!?K34@J# zVjhPm`~XKvVQn)wcpQ_86J8<28Nq~pQV`?<(B*Fmxk=!D5$Rb>6+^QBd@d||5YZ5i z2sR(K2Xc!hT@UKHpb^M?GPyD{aFfbh{JEQjj31lI{xN$0Vr&ug78Pbqz69n~H5v2C z_Y`ySiJ&K^CP>;nN&6rh4UJTJYaCEQw`ef)dYC7X^c$4EisrG!wkgx(Vj4)uqdmkb zcG{SudQ8klV5|(3E9(4*Ep(Z&s-N$V1U>CuiyZ?Q`(FK^;n)^B^6b}CI!2Y z?egW8%y`x@liY<1*m!(1hME!ePJe<-h3o1_A9xF47%mOH#SUypF2z`}`6q3+;;tA+ z>}?OTfjxY|OZORk=yr6I60QZ8 zWtzxtF%Mv5W{n}yyvlcs#Hx=-LaCwr#A`{q0?Mx4^Ud z{7AVCz!vDa7z~YTyh_27s!=h5vD!^;M!m~Rm2MV$lo@(HB803b1csQCRwN~|fsJ*v zPGwIp*=rZhVE_{GT{TVSv;~srxko%0@Koly1=e^zz4WiYOzvMBUUwU;gQ+w6$yWIE z#)1dB^K3^P$ZtLJyN;XutU7JhPn4~zpe}I0e&+18V0EvMo7+;LlQVAF?5!DuAoHl$ zofD71-R@I;t!q`#;GBe*T{j)0yOFo!N%V+!i@Pi|(P=GsT1GGRFrr5Q6v><~l4TmG z5V>i>!T9bYaa=q?(t@Jlm4+iNMmtE)aHVV-E2zuw$J}nwdwJLw)G2dbG~P>Qi3SD? znUUZC2D02<{RULMJ*oP-6dgK7=ZJpj5T)PMkUu3EJZrgx1eC;(gMYtoRX-W!H=$w? zOVy%@Dzm-^=Zs=YNXUV8KUUj?H*Ux0oPl7rL@R;$QCZthsoQ+LPs*{PJsz)&)q35) zslDQ&ujWRqG!Peq8}h8cU`xxAY5n_c!v@OxA|{iWC7%`jF zmmOgpbAp_{Mci|A#u>`iE6V}qm0Qaou1g&2Ic^ux?jo$IP!SuWU1iDpJ_JPhBd5DD z0qk&+rm#Ckpj9?V=yN?wnLHaw01%`R=?E7UJ?9Vul>qlr0a0S^aCCpA2E0u8kdp3j zi-XZp&}V;+L2I%$=^YTZC^)!UmB7~CcAV_MH+@y@N@eV|{!U#moO2*5iA}^L13;_{ zaHULuZ!Qs{98}QBUxqkfi+%CV)2M%(5i%eIM)0_q@t@WdmMX zmb$vLr3Ty#7f36@zi=~2*$ZyA6B>epEa9n;F5`*(8m9PJN{DA^668Qb^n0)>6|GTu z`^7xhw6xvJz7iMz5-yaA?8MOmh!8RxhQvZ245fgID);=BzvC4nBU#zcqJ^2Bg_)y; z8OZOy)8HGey-DD*xY5&Lf!AyNp+6sL@H21>sUT3=Y8-L}dU9{CnMxZZfZCp#_^*w% zFNa6A{)P_+$_L?I?L!vq0u76uev%60>|MVj;c8QYFvo=A@-6*>xu&7!>8U{7*`!M- zV&6$XEZ0G)LKb?`8Wwx)0b-&>R)xiUS}1FggA-YCb8-|dq-Vv`h|rXkw}dcJ>tg=^ z`%x@TYtzZlpOxaH;3y28T$u0R$~XA*3EgM^s9|6PNcYdOU4$&(x9=@_-Cke3o&B_> zI=$}i*N>*Mx;%J6gB#QN1&C<-xY-_0*fP(zbH?g;hpQDM&lG6Nv2)p0>}>fU3(|Q$ z=Vp)VetXZaoR=whx6NrIU;h2zJZ(I)wECIW-HZ8-G&fBJ=?VRI52HFtWdkI`Y%&Db znRc)T25nsCU~!u>KIdCxh4nwIyCi4U0eU2Vj+x#qrLF!*=j23|JaU?g&U zsWEv$0r+!$a|0bQ>o5FcD-Y=PpJHT}^RdUYSVH1hGcs6kVhQ zs8CH7_79bkXpMdqJsKoHc{Ibu=&`mqoER-{$(78K>LpwUfOiKbZ{O4%3pXqltB_yK zw`+4n*mJ-^cf_S<+`M(aN%OY1u(zt@=?jW=MWgmhwlO?7_tL@ANuZvS=RA~uINtjJ z^%4>@d!!W;#>;qVvgJ%@RyuTm!PyJ8SY_mMTUyaRDKe6`Y_lZqVwQcOkl0*)GaL{5 z{|u13Xd!M~`bWUeXaOac%;}J}*UD>TOP>a5K9ajLCs0~DCX#I^vGmdR)dSa3=obpa zP6Nz(OTUrQv}`Ir_LT7^okl~;G13;x<)j$fC$0H!euUf}gFNCz$ zfemJ)A**5uCC+uyT`o^NS`0W23z$W&Cdfk?GPWDJKf+Dv)u`Kd)C$miJ$$yG} zWX>QUfuc_Phv_-?=S{|o;_vZwxLe=prpGTg(4kbp7*jwhCZzFAk~js;B>?cDUT}t~ z%cn*?2_)?gpWg8C6}s)-5Y~JRK|A?j`50DM6-^e0a7{^p5Cj#Ls_` zvww5|@#~k*{>!5fHpJKw_ZeMjUsp@jWinSu@?;{&e_m-EV|La*U`1&3h__O!i3x#- z3IqdVD=n3y4Md|=n%z3z&uDh~rrE{L?H8%4--m;%kkX-e?>-%`$zmE{B**@lEGS^x zG(vqN(Z@!{3RS=u8up5z<7n?Lu2OsbpxnQv5{iOmOn*D_FID3px9=>YdW-z=HPA*o zNJMK!o)-jFFL#=rOyc<#LnoBW6Mc%S!ZKp3$QQoi`oCoq+dh!VZ(u?9ka;@)90B3N zBUf9sIyIf`UA^D$voCl?OUsfVov08nNnctdWsyKXrqV+S3a$B`@Ce@EJaHkrWPK4W z^91^OG9#c1UWu*m{F`*w-T!f^Ku10*O-kWo=#hGgP?9sZFFCg6|SU44V|SE4y**QQ#Cv^^tt62k4Po8|_x58QL+O07{7Lfwz_{8Ye6-;dxG zhoOaZj3cX4)g$2LDDgjQG1Awq?D#UMX~b3s*?5uXWGj)ic7tx<@uWfG3$%jU0V8i$ zym%<6d8dL0p&g`)Qbx)yuE>Uf5M%^}M;Jyb;9HmsiZ!!ruqFHNn{Yz8zRZw#6v$Iw zodrP62B$rUTg#J#M~p?HdCkTm{`nGf2RY^8*3B=|O%y7+i~QF~p;CNB4j514)2z}3 zP*ovVohpRKGeU1iOO^yl5Cs7#dl{5by-zuvTOFBfg6g}*M`Y8V_gTn988RucM2IK0umRJTT2+vLFrZ*a z-x3;3HDQ8@XOyK<4iCy1!02K-M%KDEIKcUYgtzX`tu-7c>A!v&u6$IP$g)zw+%}+d zmd%~-8}=QJ3vvHQ4D{FuJn1Ht{w`iEcN_UqgNf44*}H@`vqUue1MW1;*GwLoK48U@ ztD>Qkpy|p6bjjAM5&W9sip;?d;R2qKAzp{jh+>#j3s4o}t)Pae$u^&hG+I7vZWc&Q z=xh=o&6iX82m)x{dq~2Xa4ivmrP>WlPNs==?s{0_s4qlKxjZEu;AiWmcMv0EyQ&~S zlB&&R^Bl@hPqxc=tUNwEkSW_x!uqh9)|4f5M4Vn<(X+b!=(j#l#TmxnB*4AjD6e*= zll@7QJGyZ67mI(HZ2~r@%M`co0^?Or+@i5EF>|_t*n`!)E|u%WU6W+rF-5ntbJhuJRSO>qw^Dboy43;gL+e)nS#||k1%>8Xgf)ulbAARfaoK8Fvm{EwOAe*~6pl`lvr0HojbA?&XI8LD2J;$EKB`mU zH?XT7%)$kq@$u2zz5B<>1_=QCb1lc4m3ar|tWz{k)$MPhIA=XFFF9_ayTp51TC)Yh z8pYYmd{`uUIil?>jY=OzqBJIz0cPEP{&hiJJtOX! zxnea$jmJJSLfY=5!j`kb*G2;!3dsZ|6t^__zsr}R`UA-E)>WxFKw*uL&Gt` zvtogTf#H}(-=EMODIA#F+EYEqZUBnPKVSA<84H4eb<1a{!wV~bF1etJgdj@!PH$zB zr3K-QZv!XY90W9_l4@5tJ)bWK}!yQVRlK zOCws~Y|3!G0a(}kJ zl7cv9+PaG>qZ$csVNS>l+f->K@xHQ?LEn9+M5Uv_CH(_mdtgC9KX~FROqOy?PPf6K zoH>95FJE>UKpT@Kk;y*vi-i=Y1Q_}F^;I$O5{<(Qr3+*h-$~56j3}ryH=h|33jZ|U zMfLA!$F=Hbje^?lUZ6|D{NvHYXDA9xlFUknNea|c-s#*|%O(+%>(PsVZ)l= z2pnaT`%Q}hBV_&;B&bE(gX(DO`;wo#rQl6kM@`WpV-OK6Co~|7_b>^Ht4S$c7aIr7 zqknh%FK z=JZ6kYg@)WISdS$Qf5_Eg|6&05E8jZ4hNriB?aa|GKv;#rMs1SgM|7Ku^@w#Vd)A5PUBO?YU#iYy7Cmy$tPq{(_z9@xv zp>MwrCGfLicu&gVM9k;BEJIclOVlwzw8>F~2uQqI8c`R(U{jkv>tG^5*6dL&R_O-= z-c9qxu1%`{9Zv?4L)ePOu~A+`N7C;<6?);boLydpJEYs*R`hH8&KDu7&+`RZhs%2J z3faN}LJn*esw|LalG7+p8#*BN(uxtsO0=ZoDq~t5VB;znraF*UtPPZre>2<0ct*(p z*cX?EYFm%#Q)EFSlb2ksr4KlnTwSVWO^@xkom~!}-pKv^Ad~4~Fu@hi%`@eG=R4e& zI;RX@v!!YHax2BrGb*GZJ&%ZAp`4d$S;_{O(N0Mi%dNqQvNdwcBV{CUxxMd9lBXt& zE=%V8Ups(uOT+cN2XDe5+PO+QwKXEpuw?1jRejd;UUmwh+z?8`^El zvOSx26vgiR=}2+m5t%EUwdF==9;=$9&vV@ZVMGU8S*5HS6$Hk636Z6R07M!Isjls! zE@e+4s~-<&pF%T+<)yE$^_oNmv6Vw3RjB{Es~MY15Z%#|Bh5MTV`r*037Xc>YPvkq zPM4@EW`1P)9NZ9((J(*|sJ@<3sO5*5vd&B66wFsbsl%8qJqoz%lHW>+3jb5;prdxT z6%8up(zQ4`<1&`XvF$;i=%EFmo1jjRUX|Rpr;o7;-osh~9SdBk5GuA)8TB&yFoq3} zPSlk+5PiR>-sq`HPA}O0l~qb5FJD(l-b^uF+16$qo<3@J>6=`w*1dEl++EwT>$rwU zt6@W@VaFEzPA7`w3*Nt>WIo^h1OA`2t*vI%FOUCfTj|;W0Eqviw&iSK_Ww-0@ch>m z&XKtHLtXDY6PlS~!HdJ~AhO|t<8`PxHaj}YGkbO@PeSS-oq)qyR}v#kCzx=DhxfmxrY;U7Try{RxuwJ- zFsMfcsi<=4C)E9{63(Y36SOds@xc1$!ghN$HdBvI<67>jNh)}qG?6Kq8L3m5D3;pE z`I9wl>_cA!R1+0LrSIK!il>!dupsz@1AYew^Yvhz9Ua(Oi+s0n zcmUT^gA243YqXt^ke#m5RsjrTq5x*uvnPs-sj24pzQ%QGzzs#+vx0AxWRH`ymzBzS z-%kssC`;=$-CTf2L559-DHX6aN1i*skNYUE_uKRPyxTE3Gc$6tf6p0rsN;7UV?!_B zgx6%YS$O+rHpgi{pO+kRf4F4m1+G`e+F!7b7cxin4&cS&JDi}D|E0hhkVID_m$M@8 zUZ`Zfp+}9A&dGU5<^%Lz-h%(CCq*(L9>O}3DQXLgkC$F|pH_?p!{$D#!QKHu?(pJc zV6!dc2P3i_lVg=S&AMz4X$5`*GLxF7isJD3@CMqv9&W#nO1xa}bC0i}U5reGD_i3F zs`+Fm;0eP$kGa1)>Hxl{FQ-HSqGc|*6>`a-m@4o7RQJAM=k2^l;Pg$0d@{$V<9qm^ z2;jzX718PERWFidQLPnyhGq`Cy8Cf%a8$o534uk@MfN6NIK*#7`jl5S?rQTR!0Y>dd%7 z_aIe-ET@Q*OoY2?;}I@H#R8&Xl5D=n73>vTdVAT*GwdIb z;mH;Hzx-#}#m{@XA$E|awKbwrY@N!FHlcL`t{wgW=Rq^)>QO|6u$=@>tL0x|2nzy~ zj2)CWS5rr_^zRFzAVUeU&>(NsvBc_OBMJHq@pBlEWL@uwoMomq$sE;V(Lva-eqX>g zZypfCHPR9N;?dW28&^l%M|&XE+AQ$e`_1h$%~8!%4wJxdny>)^z-(IISpPy)4>p_O zQ%x5B*mL730u7;yRO+Hj5uONT3qitT-qbUg=)s0&CV4<8!o6|{9p=*27zFlJ zGl!|i`srv8$Q}DAJ;!vl?f;NR0WiZNXhVl|n+Sn_wbsK%YSb46hw5@@W~|}X$>U0| zfq1|=BnG<{W8>`#0q3C?EaV1Gbd`gzk=(@`8Z1uvMFc!f`2*AVbrE+>^sNa;5Q;`+ zshZQSr}P|4MmJFa{cS5*!0bJ1IUd#=7a7A(4QjqNrfgzC1jvT#XFEncN+3(+?b;(?}B`EzU3$N-urUE=5D?xW%Lid*mK$n1i4?E~Qfr%Ef-*)T@VimUAZVIG zN~u!EMY0?ai*_>9qA}?iC8zUS1~xCt>)piFdJV<|(imlTY8w9I`>y`}Z*dIE^T2)t)3rUjAny?jJbRS1az7YL$Q8V?kq@6m>U58$;xYxPnA)G$yg zV##e55J*YN9A}X0LYgK+KQAvhp_)=S{moG2$*tK!Yi_DYDw@`@BlIJgPgpsH=hjfK zqlMeu+bIQJ<8!2qQ!v?9D4OKySWrj<3zphJed`;=Hon#Y2>_IxXBKptvQa3@yCR7d z>cnGoEFPDV8CNSwKduh%GvD`4fSE^ba9Kd)om?C&*&D8q%g2-88=@P``lQGlg0LF4X2PD6}sSn#oX zMtf%vF~vM8sSck^R$hG{sU?n@LJo>_cvjm*E$nl}QDhl$aicBSG2vt65psmLydPC7oaHV}9C! z^YY&L_&(o+VDFzmZv|cqYb)oqv+vA#w?4cn;oo!QIP&)r?Q-qU0lNdJcwK{~5{a?# zCA3!cHz4Hf_gKgZxhFxmsM(gFz+eC zUS0SIx?crN z0fc+Yi=R?XBYl$K@qAz{ja=VYAP7le%mckOyEwc!G8Vf`#(*b*L9r!FHmyHd^6eLLS2f<`++75ptNpUz1PHW*3%C{rBC8 zxOCt98sw#tptKE!n+%-HPC%AbX!h;Z*JYy6Rsw@sW#>Bn^qr*Xrm$7)ViF#rxP+Xd zP$Fura#B0gSFi9J7X|2YcD&or(%Xxja=KoF`S_#~kD9D`p!ZEZ z`vq#ToAC0Qy&C_b6|jGc?CjS3Nz(%^dpPoSYl3UNO``dmO|_{s=3-zS*6cg=7eQCv zadtS>I??rXvjZaPyfeP6XKg(I{9IEKi6|BMqS%w0`a)&5f8IF6>i5kYrzv1Nh=a>B z9hQq!vCciZ{;}w%R8$rrK)m^;Z6@OPEaX*lMr}ze5UV)YJH?G3K2uiL=BltO{6X^(i&0UXWEfmA8^ww$4>kaeO|~tpfS>K0TgQlC}=R2YHFtd=o`H8$#cN z?DFBBa7eVx&m?*n64ZG2ym)eCs=l;?^PzFC25t#8y?RN>nX$q8-NqqD0Rj2T-<5#h zk*D*{2w1k}Ys(@3a&>&F3|7$d1Pa$MtGs}w%P^-mcbkI@CZc8G+v!4))oJuAU(BM< z@gzm?2P^4$?=3p|>K~x9jSgbPmddl8l~=a=Mo8HmFCW2T%UgQFf6Bkn>9Px-9~=1_ z+G=Q?UW(;!LyvA?eF~-{N9kQ@eGrx?9v)MsXcY=VZ_H3(>m_iza|GaVjX%-bs^V3;vU93 z(WbzgrLE=#cs}rpfw<28-4+0vPU?@4b^Yg2d*@~a!v&|3Kg@5sEi_ZCc{YIn4eV8%CU;D_vjnm6`bGZal=uN2f02r>cf&@c}FE;u|p91Cy3n z_Ng-eMqRZ8@l1zDZMRedq5pAPXzxW0^X^U&wtks1oqVrA1LvUEa4`L>Lk|wM+xgz^WIPt~4q4Qzh33Ht;xfR`lX? zJhIbA=2lq(Z}#4dW>N_mV}{TbssytVSD4vG!4{3$!bWO_EgWxeOvf`r1{D&ER1+2! z{-2j1W2Ef%VVdm>HxmUP#fgPw)OLUtKvGhCwszBVQQ%4}f6ADWZPfDXqSVf?GeP2E zs21acBk$G4q-~*qr3_3?1B-JqnpS!hhSQPnEi+eq)Dx|Jvb3=(#z$iR*K?Z(CscaNdmymk# ztu2gM{_{t(%w#Dqn1_KuK z;M~fL4FeARXTspli8X6_q;H1+7gof(hb{XSx>dH|-1Ta(Vfp0T{^ot<{BF3tDwdf(OzYyUdI%j@Cvzxq1Mpt!beZDUPv40hgVjAzZNRkNyl%r)L;_qW>xHmYh_Ml4C>%N{iHfaG3) z!zS7_V?Je6Q|j*ScZCZSwJ)eWbRWR0TC;v$pYIJhIOKF_K5_=C&uAK?i^KL5r&P<)01xZY63mNWHH3*3X_gKu8x z>n{)_^D$6UE|!uhnIbOujGA0DA{oi(jYoF=J>|LQqLjH)3xgJysapmRSdfp3jJPa+ zs6dd#j9mcUD{%p7DNHmnkV1-~;ta*9eLF}#OJ z80wGwAe`WJ%y0r7TOJ5Y2Q8|mUF!O*ZP`wbXv5^7`q{Q_mSEjvOoiHXUnjqQ1HIeM zQTBS-*tseXSgRd0drg%>8 zsz?s^b*$ASb}S-1TRnZ=`h)nE06DTd59Tpju#G6|h5^Gt52h&kiWqI|h&D?$BX=kY z85MHVVoTVb2F&8G@(;E>h%y}d2|VS#?aRq)EvPCD_4SQ!ogjd6CnRU{_*R@g9BcSe zJG=)8oBkB^)ZHpoIk9oGpmu77F~HlbR&((J38vHBu4!}DMTcOq(*79CF#_$49Tq)% zt~KRGfxt*2T9DK5@4FBUj!%`9h}tZbkJEQ{A+~E-n@q#f=}}8#`RYIDF*^8ea+TwK zs1=!#ML3}_k7W7wVXv|{Hm%_I4qB5ndK1k> z-DKt6CgfkQ##6+qO3xC@@R`r$UbueW)JU~i6Wa?yT3+<%hdOC52WmQ}bm^OxD(pAho51dO z)opY^`wHRTG0L1GULmOgMd&PKWaeN{d8<=$~=SFwC*6bDU#|8Z zi1@|?8W;GN-P@fSYZxdn6fv2Z`>5QwIBcPYOxM!O9$)O;S^3)Basz(0T{|mwwz>AR zd|q>8WMS!Jd2!R|?R|18sB?_Ac{x_Q1KaQ!F!0X5@r9kjGMUbOJd%(QDWvd}7&l@E zfz@pp-QLr~+kUT||K=tsV9o4BCsM^mCueotf&JFt?UXa%=vT8>8R1iUyY?OTmGwt1 z^;7MTgo}XU8;dD=M+GH+FxjlLnYm_;kl+l1UQnT9}|SP(`NsJ}t6UDi5xB zU>=;tEORI|{hm^K@q2{^=kK#YVH>%?QWNJ3PUk_0ukv>(XW@{TMGq#~-V=DqI`|tF zT<-?Dvna1byX^Vhs8SFmbW||GK~p*6Tq2I~xAJnAR3Bi(#<=%CA&)1Yx8tp_j;`Ahe!ltjgHQs%%>IkEg- zeVt3Say5O^!|qOdHA2G6J_*HE8krn3>@PXv-Yc)2c`>u-Gn+2m|HQckY))v`@C2=r zFt|8CZ9Y`yt`8cJa2gHJ2HON5ILZX|k4F_XbV?|#AggrP`;uz?h{4AWRN`Maw;6*! z>!+eYH6^l{=AzLu6(gK9ilacohDo=a;*y$YH%YkI_JLZnl;_Ur%n#hn&(sfD%YC)U zO-GqSLt7NRpE9=UxJ&2aOUB#H&xlaXI9{U2CGSnMhuGLxxF3&_O)(OQ9>$HLWx{Jnh3h@Bb zm%dOq%JvnZJst|fcBL4M^hp+*{bK(ibr}kEUZ*@(Qw5h&e8uBAmD~o7-UHzc3I;MT z)pkfF*|aJX=I?UQYQXiI!3cB!ipa5&v|;wQ*;+VJom%n; zWK4LJ(1-Jv*v0-_xQB4`^d{l1)xy4pb65 zA%y46B?|M++2u_Wp1#GbRZ->S^Jt5xveNBBX|hrqM)0saj{B~o4UYra zV;!_pO1?|1kcc12n%EII{JOlMt*A!f{vzIODdMw|GL+e6YSNHNLAPlp$*kP$JXUSS zf$*G3*YtJt+^?S@H?>Bj1|rb0#uRSilL>lrjRn#yBzBL3*r|7frz378_=_9;Tp-~T zuF**f3k80(MD3;*`KAxWjJn>0{nf$}xoG+W)WePZfbc4VI^J~Igldi4oa=&@A5#sA zJyDup=hrgzXJ0lGZ;)ec{T{B(D!=BrxEb#06m&nc;fZ-^I7lt;Sa(Fq6QE6|k7MtQ zs8`cDe+L_RJxMFmaSVkkKr?TQ+*q?xw&tKSPa`|@-0FND(Dszmn>Fzi=9PyC1M|%R`FqJYPLB?CSjb*%5BSx$%tMtLDSSJi)F7#203dFl=+A3EiXCPn7m&(A)# z$6M3Lf3FIrt{*!-5)>3{fnV7M3p1l2@R_3O2~(&fAhK%?pmEOf`b+2%Dm8W7Xr3lu zPs`dk%s39Be&s|wOhXd) zHt2)N5>vS;+k}q|SC`y?%ZeduXIWGDB_cDFA4mBnbtTz6ZH@4U43ATNY{*v(G7sc0 z0;n70NNgjYDn-t4sICbx1(f?it1y&CE@*9-!u{L9W3XOKk3rSy9Iq8ty&g%D4bIhNM30&QKM+H2;!$ zbORYtCYkY|Juo;;)%gwFU~NLP+$OJO0^KiVhEF>}!3^!NYY;XD$mC!TTvN6}S|Tme zg5?Q~x}D|i(Zt)0)~PD(-2PR*-hFq&&rp(AYmtTDKR^AUm+@dOkXHVg-@vi}UKrJ^ z_jBqEx3ZG%>^6cl@|6Mku6OVT5QiZz*EWfN@q4Tcxv6E3A0&0$J}wr9?N*`PGBL!_6T&fZq8%es$&t zX@Y2TlDlu<`8IwnlTqegeh1vBwt`=tmx)&_d}h#OQHK%#N2T!u8tb9iTxaKFPES(l z_KvEhDOaFIV~?oX4+kD_^4ghNU?6{w)E3E-^iQXjsH=%`Z&6J*2m|dH#_8=*5-7~& zpxrJe;8}(jSe;?(3KIs#P2hQk*XO4JL<>9Hr%kY=ZS$1jh4Z^Y-w(o#3;OE*dA`L; z&|#e8^in{cL@}*kLfMm1T!hUs+!%JKUgf%DiJ`;O8(#NPEG8$Wf6{nu&hDzaxAn=#du0xi?IbyY8^ z6hBp84c%8S*R%1T;)mi$mYyy*>#Mt)oopjT@>}i}RU&Y2!gYq(G#EO+Z-u|P&5@R% zn*}E56z~y_0NV{51fC|`->fGON_;JiI}Q6WVM1qk{-vkjOf<)UN}V<(5kevR0ngds z3$=SHisg8PjDLYiMxj~&4tzIjxJz*o^4Vnc)~6@+4xd~8C$RZH;!BrevYUIiFvk8WjEq#ywjDo#mSE{Jfu>+)@%@-m zp+twLqiu@C*C3q!CT9I`RBJ0&?kx4gcLO~BDXJN%6*R+xr2=bv1<^Q(!QKT@-_lY~ zCur7+JS=ZC-k(nF9}CH6OQshh_UBUUO)Fo0*g7?Lv3ZEhDYC5^i=@+I3@7VBIfSUl ztJfII`M`nqia0-TKUVZu*?R(-sY~%!5cvspjm-wit=wUSd>M+*52chdwp4fb-g+@z z%%TN%k-DcTK#h-mkQ8aEHp>$Nco5C)8Sbo!VKkWhu~Ey&ZwmJo%y~wb-RKLWl3bsD z0%Pct_4bdgva*N?$Athweyvh>u7FNIJGW6khvz@&Y03=aK}=TD?uunyOO zBGJ*Qoph6)1M*WwDl0JTlRjGu>O#3j`hrRlGHWDO)7qIR^1CX9t(8bnF# ze!x4@6Zz2~tzkC|vcmwIL1iQgmuQ#%`i;U;Wv%&jT>3ucQo3f7ezIl zKRgld!5S0iCkM%Gv;G(ThozODOZt1L-dNAzyYnSl)@h8AGPEV;un`LqXoS&12)O#2 zCZ<$#5nrK6kE$Q9@nE6;&3>JwATO&b2Haz>bkp|vJ;-{{6j_y&8$*t%Ph1RtsuJFq6A0KaUn z-mi+tB|O%BR$NXtg4>W+Aya6!fVn3}s}`LUQHa8aA~=xKkWOE&AgxOw_W0dsM%AJj z^Y0JacT7j?*Wa5KzP4blJaDbt>K9*5U|e@Nc4pQmn>8ps;3nUT$XZA(tqK^T&O@eU zS+yEoa1ryMAg!tCks21YVtu45D7-Wk3P8f4)MjGWJ!35HxjfWHg+Rtbh-;$^j4Qv@ zstqyO9RzrG%yv(rp#*bHRp~hA?H}syHkA}g21Zzh04P_2X2koBdrgf(<0W9x#VR|v zHDLDMYP_I+nCM>TTqAG0ebu@eX4m`v^KZ0FMC?r|R6PuAJgDK*OS+E@K|`nmrs^;6 z40-()k5p+VdNVq!_)^EZ{S34D?f4d24ot6r-ZZcIe(4&Q0s)&wsx>P6;cyl@d zr?Pu%L6INb71uzREp&Wum$4r;YcM&6h;h}%a@E;H(?V^20OMrxh6n3J?}PX(C544j z*U7^Lc8jS|`@+pS$^a#4lRy(vcU)z2s0cPS2IFo`T}C5aH3 zMIM&?eu%qAnP?IeNw#0VvNu&N!a=ZwB_lOSQFhJW5`+^O4+mF5j&g6qK3Jn-D!XjEJS+)dyg-S;THv7H5B$+9je2D%G zf12-H&5Rg{Cw7(8q?tiE6I&ZF8FCtTTFbNHlNlQKDCj4ypx{pT3W465Qkb;MJnMx# zhb8i2<1g(!bUHKkVtepCBRRLy1a&6d$_S4KBa-bg8xoCpPljt8KNj8@*cm{=k`=#a zw6^`h7g4iuGXW630xCha7*{YZN&jZR_12Vqq>BZ?7jJkRNYf@a3)an$!FqwiBF~Y< zrU-*(R7@w0PP|DBh2^QnNSZYUED%y(0p*=FV+TIw!g*=a*_?6b{`RhOvU#2D;)n>* z%wxLcHSPjdGyK?Ljc{oPhC#kIbP_Itey14an4cQoDzOWV7W3_vGy@cW+!CKdfeLsU z3{>b$s%1fG(*a?V{Z`f$&H&%31wU;kErBebod#lzc1!QD< zO~MQA$$=H4O2`G+!(oEUFcxs0@* zS8+ZFvZSOBqY>H^sX=5RD`ainPABWUy`WIf7=MwCQ~olLVNpQFuubapn&pLVvch&* zEZo&}3EAdCE&um~L||m?DvHX4LRVLC)MUPz{u+*E?FaA?c^7g`KdETOW7UUq67Si` z^}Lb9DxyZP*aETPYpR;_A=_1*!q1?dbRIN8>_MZW0OVk59}bP%>R0o)VXWd?zettP zhCbip(()f)k8%Yhv*n?S7(!ON8Uvys!KYY8A=xpA7}hI@gvGQJnq6~gt46q9vWMht z;^Mi5@3t!ukvVXoomH`>hDPCqG;l`7@!(w@5mFAjQ66pg8h3x1bnZ7)xCz$eRq@8S z$dTuL{j6x;GXk)=1>Z8b$T^SUtmuY+AyZ2$GrHZ5C3VZjX0%e7GN!=1nu|VeYIS3S zQ6>Y%O+R=NT$;*nZi-2WTxc`1t6UDbg)m%T1X{jW>=!%=%SpRoy-%jkzLV(akO`6Z zge~aB-5&KQcm=-{$ABGh>v`}gckCqJ7mbqzVxNA}b=nJAuebKA?|vD87PD8n9lY|I zyMHSlL&YIW9RN-(3~Xh!ut7s;`jn5}MJk%=Rngf{(* z-ddTMJzH}aNOFiMV*Drr(s&(?KB!exkv6MNu@t$M$22KeveaNYad~Z2)-~!unw-3) z$9W!uhid;NANMZ-{Sityff7F*>QdDXPx5Z<~(YEb#Z^D(N6!6HT;VLv?9Zf&t zl=iupRkexGy44Y66%VRgH2JK5)N;`DzWwW$oU=OzpVo}KZ!fR6*Hraw&E_RJ?HcxL zwhY$=SsR!J8Wh#vEHm2ZlnRp6#t0acwtuoC_ZWwfFxOf$^9zyDnn#@t56{QtBkdAH zOc{uSuA=OW8s@aoNLiJ@N?vNKIt2ShS*6p&ZM+7kFQzb3RT_$DZEQk=ov-HFi6%cx zqor%ozt8ezD2=YqH!Oao_WPqhPEJedFGA5ycArLE|1LtYT~CTxlZt}*k5oZ=uM2XU zvFOwni+4pDlo%<-3eY*49Wnx5(MFhlgXyQJLafz-r#IHHKcUs9=Qxw2eUoYsJ;0u+ zYLN*5=G#o|F+{reaeT{m zE(&|EZ7C4ZfVlwovd`)_9Ydy0vbEEC z+Zn0;<6O5p4kT^wVTRdcbE{EUt1X-Tg*EYA4B+yaQ}XTN(xUtpZ?aRIc#E<-or-{5 z?=`ouvu>hr2rQNX5Wo(`0%ZFns?VF(z9*_JFkf{1Ovd+6Q`+u6L@Fbg=oGqbEr?xi zg;AN>_CN${g=XCiRu3e+iu~G?H&diA*9}te*d0>*j>}Odyu>A#<2Y#(2I6wj)>19f zl7+U3S9!m%BAMBkZ^pawhf9K65^c739UzLHQtmR&fg)nI%YT|bJ;Rh8#op&Iq~Yxp zK-kac62Mw&+(}rrO%W9rv7b%Y`i74wo-%DeT$WIrn8c;LDBk%FMkL8hoTGXfPLXlX zi#l62LPEQA4fRaX&CymJA?^+D;R|Fvq!g`hregvknyLGf^^=JiZZmL&j7K!}qTv$2 znmEE<-)TM&oLorJWtE2ro#^FWnVb1>x*k*nf_c~fqv%Mr_xDvNll5ZLKp^iA^iEvr z9lyDoG97{R9h6`zKLj^HxJ63DI{qUBQg5d(Ys6jlX$4KEjqxve66SXdL+xt54f*uD zxl&bZhe9oW5{g8k>tgv=oX0QJ8({P2+4$S~Dk;3H`Oc4FX5vhc1}rHyp+6*vWq*|o zd{s=x2Qo^X7x@b0cL2rm5?9NJPgT|5n99C|Hn{F@ZFR610qP|T-B%{%^__}u&a zhnV_g)A>J%|F%Fs$30he{lPJF{ukW81YXZ!&#gm$V2wQg1@`|PM9*2zH9>z^s=WV& z^$%&#bLMkZ&>v>*-x2=<)w;T~Cbv7;K&+p8HzT4{CTVXPkC45-^>5qxPM;%ywCZkz9;7I^?$maO0s~bV}ZX82A+-vo@^h7nSXuz EfAWYk_W%F@ diff --git a/venv/share/python-wheels/pep517-0.8.2-py2.py3-none-any.whl b/venv/share/python-wheels/pep517-0.8.2-py2.py3-none-any.whl deleted file mode 100644 index 9a41c2531755f2c65292bd62af636d08517778d8..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 26686 zcmaHRLzHO2wq)71ZQHi3TefZ6wySR0wr$(CZT9_>?tZ`5??DdE8SIReD^F{rhWgV$aIRPRl^YLB~XAY~kcgYhi0@M=z+V zA|bD&Oy}(G9OEq;x5d@5UW8?JD0oI>VU-C~YW77;oZl4VE!YkOhDa*)TRe!Yq(#_9NsgnR{BSLYLxW84KukPl}&_^8WBm zR362@wZX%so>6gFQ`h`Z-`MWD!zQUqtvp;_?f01lty)p?6cS12SgKYLITII$&+F^x z>G;t{xw|n^Bzb$Uy`@pQX^DGULjAFR_g2LaqbcS_rB27i@AI}jC_WmO%cDTJ%ltWa zC{OSA_5B!yUzoKS^@`3uzYTAvr&F-lXt-@=xy`j)&Q|ZE{zofRd}-=0?q42GV5pSU zpU%;wRmo@SZRe7O`FAA9Ebb)i&$oGyV8)1C)Cra>1_8)l8pCaPliO}Q@tMn_74EnY zB2#>KY9Rgs7q#94y9HD%VvDSO+=dMnYe4>puV?X9Dxb(So(>1L8tV$GmBVP;0;@|H z(-`*!2i&u5cBK$a?&S;H>hMpY91><29o|K{IPC5GnE@3mQ5e6tUaz-1NyFĦr+ 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

1tp;3{lr;Rx+*P*B%e4R2bVHtZE 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

f@GaF7t$vor#pW{{Fc8P-yihf!_Qn}Yhfgi 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

$T~JHC!0Jhp@iU9grz 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

;p_)?2m=;|Cc!t|?w(ih-|8-5b>UZDW04 zumQ2g^t7wQr!Yt~cs`<>YYkwhVE8f&u5{ifeejG&FG`Xlsak{*9l1}G~ks1>6; z@_FtkfCB3wQ~2=QtQEC$bRvFK;SnB(PpNcYd7sRCemDb&{;Z*PVpUMEqJOgpiJ+M8 z1;+A`354#ykOT3fD2YiYP>OHoE|1BDK3ZXMK%TpO=H(W80c;NiL7;jNhM0!RQ z=8{E$RT7lu2sPLb#Qw_VC5C_dW7EsUxH9EMPBAnulV3ko+117$5I}Z6r(Nxn)U)G8 z_9i1BZ{cHuj9mDtU2cOTAm|9x1TmcCSs;fiqSmHLLOdOId*f^wV zZ-AIf5k8WD8%rh!R#S3EY(3w(tYx%@P>TDX-Oz0GI>|mx-i=_U?m-6ESx#|IxNBy{ z9D-1-hCb&P>{mS19Gdmq##{Trvf7FQ^7lH$g5J_SF5*u3Po;ZkC%55FQ;F`4fDT5^ zz`)@JX49`D*O)~(_y+s}>^Wgc2YJuLUm}PY(Mh`dG$LkOO)&nJlwVgj(TM5hM6?Sf zMrThlPf26ye(=ZiI05WO2iQ#o^Dw1*=rYlXenwB)ypGP)c9A&5hAOI_nQx%yBWZT4 ztU92e`~@@prPISWWqTl_6e#T&YoOZTA0=@JC(*@L%E^eV7qt1;+>W7yt%J`l<>rJ1 zf<|9gB!u1Byu#sZ7&4=}wD=<)K2q*@SFCO?z`G1(@G!ArRc~a3rui(?^(FGtVd06o zJbs5B&;A0yogAI;(N5EX3@!Vsg9VA{2yh1YyH&PA4A}>Ke7(o6plHn#3>sg!WqfYgX5d>`X6yH?0-2tZ35IBuYzE&ypKlTcLnfBve{ed)EnRfuUL*{F*_e0|&$9 zp&x-dKKWVJAuu*MwOLX3)-1F{Hf& zipj^NP_^%Zx=aW6lBNk!9qftlouNFd&YEgZ4bw)z|w+_(jOBD#qr-Fi^f^if5FlW?NkH7rf|x}EeDkafOFM6^)BW?SLt1Ohv@eXA& z%|%r3(Q#h^Q{2i}>aht0;v~s>=hKk`#cTtB&FDmoZ~FHKdJCt|ML=#CK`VTQ-8%91 z7so1HR@Df}?aCr=x>#O3%gbJWl$vXnqBGMWZ@>C(g5Cu+{He4XbAkd%4;^YM?ZhJl zu`k(cZew7q@EN~Vzn5a!K`lK*&z@4MIZcDf%}puF)*GLb&N`%9MN*~_1w;%eZLcv8 zl4pdvVl|}uKQO;Y4DDn-I(nwg3C0eAiYf3M`miu)2m{y%7= zm~bf|nQ`m=$bbiD!LS!0H|5M)b#4NFJK*a5q9CR~QhxlSmXA^#?1Qjl0^X{vXx0{T zXeYr%r4hfD%?X;1+X3&_6MEK`sG{xFs6`sXXH<(x^{k5NG)ql?>8fF;&fVmiQ)<1f zrhr|yy_@@{(BIEl;xiRgNg`vN8aYmolb3^izN$$@NGf`JtA_2lK#$-6-C?41G3Iiv zI81L)`b>=w&v}Lx3a*_ZxY`3FQ!Nv1+ay@d=1xQRX0w@D;zur=)pDLBHC@su5L=_n zv5;y%+FG=#HUb^kkqW2ds_)d7G-1*SQ8c}#e{$96$U7dMqS7t+C&a}lwxX}k zH=Y8+5dX31jIZgYhh&xWjw?)13|QWo0QfjHzOx)YLR(DI20&V9j;byO&_DLMv=Jqx z$Mkq-^FYPbc?zTwg7yuUVZpxPaLG(c8L8~jrtKGdd{0ZpVb?fGRqS)PV=0B0x(Tg3_y_ld=#v&W(zc$K9-j`E8oi6!DAIs#-}%p=}Kl2pqV#jpQ~@{n547| zr{4_&AA5J=IZ6j>BMqP>1jY{-#J6EE7NH7FG{nM1gj==YQTA%d*`xR!`^@dq)q}>a zQY6!-H<6h8!W?KE?Z~jAAs5D7OtN;4aYyS71V5(Cv(VgvICrm|~K0B$8pU{9#8Mj`rSx`n%hS50~{ z`CALPZH2_TQ!%=~@JF^RH;H92lS-n0z^1G$sEWZ3@95~BzQ>B(wIzrd7Xx$%O^P&T zj&dIG%`>7ad7L&&wF%dD{T(_raK%K%Z~6|dh`H7BG6S^k^yNUgJldcE57u-^pMLF?}v-vmH3(tQr&b zGAdLzV)1A&U)N@9Rfta}B+bQ_@*cavk6}-I%lmOd&s~McquRG zk1xRBhq$8eDa2rbv~~ogJM7J2|j$o#8#grm+^>yk&4WXppB*`fkz z1ij`r55cHx`6qxuN|n52Td=?I<$ibWs2+omcN*)X#lnje`f6SF<&w`zSo*A10 zhPgKu%7&Ray4Zd>+STUel)Y<#mS=9!nE%}-;#wbj4Lj7<>6}3rR9{l5)-W>>Tg7Ya zKD;w%a*3+Y1~0Q*EgkowV(Tj$7;Ydx$d&!J`xyd=pAH&YpUPR_Ha9#H$Ew zhSoV<9`v2mp33-)-=35w#Y zog>?K-F=ji54L*nlSrS}_gR6T42b5uvH>A~jV}1I)fLiB778@<&qK^o#%oJ6$LEUw zrDW$DX2=81+E`ZGkT}c~ShfdEhm%Gq(KzAW$*>Ej(;44zTu1>HZh3lC*671Fd?=pV zO5xsFScV$2TU7njen9?j2B3~aDUv|qH2SpqVvol` zURaWO*`W73A9Fp|_dHCv3*71ArpqCyzif5}uv}sD%o>}Z-oo^DA)S8@m0KmLi8smd zXp#^2_hF+ME^B-a65jZ*kmgqz>jfjXjO?nnqM1Z~rLQ%h%cTz+w}!YKPC2H(nH3My z+go3w#M5DM3G-&MN~5KcYhBo++u-r3-7RNed~!FJ9i?t}T7o7(=dCwn zqP{}eg|g)tCrci#`qspYa)eGhDtYO~Ps-78uYkfx%8HVg^>ClmG{F&oF6!U}Kk^6H zsnD9wdkJlEfm33NpW1>rcf7bzTkAsta;I0RV3WQWxqe@tDT^5+1GkJsPfC6O1;v=LCn+s z*<3SqruBw(Dv7t6a80gQBDt)-qot|aNb%g9pSelcE64P*Ss3EeQAj@unbvQ(JUL#-`6EeSL?u(C!a#&yw=3IaM_q0DYE|Z_sPO$dId#6jYbIRthpCbTA zDIPYngG2a=3*=Me5f+>+u`Bd-+T`zp;2|)uC~+hAKjVjxl|V%#$nDfV4u5;$u)7XQ!dOrnuAm#qI!rOUddSWTlVgK@=u~Z zD=K5ev;a2Ry&jAFT*chtf*s_cRl5>+Kq2H+z(n0cH8-GIbA&{obpzrp52{WDBT zE=4~qQ$v|W|5u@@B(*AWl*8P2lU|dIs%uM=!hJuPR}6X34u?YbsMTXFiHi|K3D}H% zDEcrt#gH6dc6ayt*Y^7Hn~9gbySLB%^F?WH5H0BFwHsU%HMj#>Y7;U}BITZ#Xb;zI zJ5u*ie)_Tgm`DPf%_oS>>pL^cVc#q2Pbul!Uflwhm%7&<4&g8@I!qG1|Z`m5N!ND(I8sY5W!WAs$9i{|*XBPtoP zM;w4&n$RA}M!kNkT|hJBR}0dxg+O!|IA2MB?0oF`6_#MGPo^9@cMBgKva%?CKTyI*yS%N--Oyu z+?4)K9RAVIy`TP@!KB5gq%lskt(NUB(aK!OBzsrCUV!I)`sK7|GG7RcHt^xHW<*t) zmvtvXHXE#~(=4kS@_dp!F?WXi9E}jFPT-x`v_Kq@#ah1l1u0k8D0Y9 z+ErG+(^$%beB!T1gyDN{L>shvPD1GuYA~|Vz5Q80YP%%hOfEyokY3xrIH!<#{P1Dm zbZ%h}TrPony04Nqu~1ICUdGRqSqe-TNLX!@^W=zq{P47wj}!hXy+`y@pJ_E+1} zLR?nOj)Zhu5(9w~zF}%F^L7yU3`8v9b%=VPuIPJ4%V+D(Y0^q#ir^s5&?$A+s5(WO z=}V_Yx#7BVU`~h9cfvK(aLYm9!Q&y;$E9O!17c8pHjV6q$*>uOXIxZrs$c4|D!3FZ zd}jP>$z~7X@8>X+5Vo-@0JfRQhrOSTsQB(dg1NQWUH^Q!h#6McS@m#^QTC-T0!6%! zetF&5frSUY952KW#gj(P3-r%VMmRAr1V1`{G17mClJh)6!i3lGk|DJfl?0%>-7lwV z*G6>v+`RU^HI=VUgWx{r){333*QE;G3g-o2-5=k((z-V1bB*m$KJ&JMUd;38^ zl90g7w7ECe$+S^L6CWEJd;7sN^Y-?ZDZ1RCpebHI7Ew8bZfNr$g{hvI`RlF2QcYfQjgDT=_wuIOJgRB&k$2I1j!U5P z*cow=VH{a!13t{MwY%=v8$(fxKD4g+w>!|tQArzpDKJCp7+ zqq9}M=#ldeD9_iAs664v&QtMf=|XWbJOSWN|E9YN#Lu!&}5{`4tsC3s0_ykj@L0=DeJp?3`VfV zUi+1BKL6*(Sq8E+PD+Q0qgVNi{!vvCE4Lu?B~g7^daVz&Y>VlV?{Ay4IQS+J(tTCc zr9F6Fbm!zVq07ovAps@Dbvt)Nlhs9u`fn7=4p_2=>D#WTN5XRbM)3(MMvduQm9g{u z&mM)4y82B*i&UfcRNBC+ zdqh(;}W(zH0N~@8gHWN ziP#Msi1Dx#wETA~G$aV$$AkNzT<-iJ2hayJJF*)$o$Xau>YcZZTlt32@)q&sg*=-f=|eH3-oYVizaUy7GdQ-LOhTf#cUWu~(Q7LdWvriaOVB{XR~xo~ zr(4b?HoR#ra`LBv@VXm%BpOt%r99A!Eht_nWek?qHLZoAYZo%QE1OTTV4Wa(VuRg+ zu%&cn#-p&z!G_Z5iHKeelJ}!urbthK zRJ%fMXDo%E!{KT))u&iIW`p#F0@7>D%|mc5mgAy?yg}0%7b-$moP5uUompz-~y!wSK4QpIq2*@ zSeW~tx*6yc$gNs_I>jLnnDALWPy}(|Bsz)jq2HX;57^(GnhCw&yGM#OeULQB>|}PO zh4GXQJnc|8-S<*@3?h+UNRh*UZ;gFEhkDqj-u&UZek%FYNGXJvd~OKs=X}Zmi%@;+ z%U)1wVW$r`FW^qy6b*0FYyc80_|*ba;77d%*gf#jiyQZu z!J4sR!*$ZiBm2cZ4d1`7!yu|palaO=vwcv0I`R1%OYR5;Rr|Ixe$3q2((*uRt9DWY zx5Xk4LT;gJuZI_jY>^}6XHoYLs@!!jv`Fs6_SW`fBVw+{hHQ$ViL7nFRvpf4ZAOr1(}fx z+nK{VZ@4=ahJpT1EcSsT`!ybHWM%#)bT8l^%Oje3^59Jv5N?}l*LWcEJ85n3fOIP9 zcDSFv_J^?ctvn?b&PGfHe|-{7TeDa^AhSiX%y^QvuEsB?S|oU}$XV$Vw+W={5?kHf z+Bx`^xiz}5Hk&zJ2=l~X0#Y;jE9T`3cBPOR*JjD+ejaED8>N$R)$Z;xMm*m^nKY=n zzu^xKL7Rszwhu^k@L`tO0fB~+39@;_t|alff5ONhYn#KCYIuf!?;7X1 z&fjOx*Dok8JqKwFfeY5{gf)@975WHT@O>QRvxo+U3lbq%3~>YT30$fe(II#pPZUa^ zwL{77tfL&d1^}kkbFw^1%vawRoM5ZkG}fV7SMRs1+)#RMtsvOOl7K9f*8p~iPG+lP2FGAA>hhFR!fP)s$2jWxb;1P5N}i;`_WOva&ZlRj=&?&gv7#}S{369~c% zye)MPN*(Z*x$q8|w@x{@U`RQCc^gE(8`6%Okl+nOGn3`Zn}EdjLMTr8U7U9qim30G zebzD*ZOrhk&*&bA8495nn%P5t%#rOK(dbyH+GORY{W7ntjsKn*n}I-*#XDF&Cp)^h$~7w8w2k$Nr62M!-@pYvn)CZ zDuJTtj}2csr=FjpH(8|T%lC}vBd3O|vb0xdFA^p(sI$)974dnR6utNFt=_%=JyKt= zb?lL3#v3GJn#{G@pJ)Rp+3c$_*s^b>@_^9t z*EN`R^25P^1p0m2eZ-@khOF1b^6>CK!Sy0h+CQFp|14@bbc4B`#cDfEz#Yiny=TbB zs2P8O+Y`Q9l6gp8acG%7Je1KNJZ_}Or4w0gL=aH{tU287?>|jHtTu%MI=NlKgFc^7 zogBD%9x-?okft~p_$(>$@VqB|2~B|lzA$4()St>&KvJdi4l=yD1NhED{(9hP;NwpG zIiE@4*y|&V{J;#Ye=Y4`d;aJF9g8(h%`2aG0uYaqs|-))RQQ!}oCwRMryOp3h8M3B z^IB}^t#BG+B5Qi$+XrNeOqKK*Sm1~)qW&Ku%!=HU{;LJ*p)-Scf)}iQ_-H)v&sL6z zJXKU_^_eT4bSg8WA)pqOeojY&dgHaiY)n+?GE-ImgcuJ@buD$8lr*%ui8V8E>LZiR zn5KE4)SR=rA^It~GAYsmgTRNsK#u13FjWJ7F0m0ZUSwRsNd*%cP4r{hd*KFI&6tLJ z^<1pC{?jS92S}+?KYec0)WyYl$lXg`!M^2bnEYm^Ws~KQ=aq9BOWbOux?4=XCIkD~w`zk(?bW#{9f2sXLU+ z-9(4_wYS+fr;i~J;yFeh6fH_Q?12ef7XcDVjg?>v_JBISIs34_%qSmmPB zW6Jqf(&G3Mq*JQ4r+M0n1-I7_2eLM<-VtQ)eqo!LX%IHMe4t8u@}t!MGE_g@x)g%@ zMNsyT#oo#Si^;-Pynk}G**A>m za@*#(o;TqfgmYRancp3!;8pOOw_k{@FIN-AU3^w~b!K6o0woH!6LW7<>tA{lgLztZ z8FbQl#zqvSp4ijGYZPJmW4R~d0Vv73KG6#f>c%FwSlgPJ&oeKcc19+ZeNkg@!es@w ztAq@k|iMuYWb>;`8`I@{2~qlE2uAmtDx-fA1=gEF$V_jPI%J% zHy^T6l(SGvA{Zt1st|KL!C-yeyRaWzc7y(<8;AOK?}f&yatb%U6{S!vqMb5JNumRp z6WR#yC!QCz{p?P_W0oPM)6`7ZmlT$J>3hV$145@TXmXIx5owf_bsLfvyJ5&Yip4#a z-tbYofy2_cCK(}(N%bR#Pw65ZZ9A@$uy1WR)O|KX)x&(1l;7o*X7-KQJ8>m$6%9fzEkYyC zhWIcpV#jO=d*=k62Jg?=84y7S?Zv;|aBWpNW)A%UWlSC`aZ)nEmA-u7%ab8)j1`WC z`L|k-Pf>psZ|_W%rfH(FYCe;#IF4Ba2MoM!h$?FhBumMfwrOUVtvPx3jGNpgBQli4 zG`3@L^$Td@QN0tYaVYS>E(KxCaquosNV%MArTv_q^Dl0Ni66;me%XHiQX21gTBW3p zJ3ksQDnATO3tGo-V5-)QWU>&DOt6&T^(?lMhu@?cFmt?Hahn0E20BC!h5QGd{H1=RXuw-y=HqwtDL7&T+jH(B^Vb^le z!@x1km5JC+c6}>O+(pr3blTBIlK-*_+h>VwnnWeQf~+ea_PC&h&+pRE80EteOBsrg~$)i3pP7eMoR z9HC4XyH$R!i+gG|9Rp3DSNl*Jxib1})TG|`gFF&dp@41wm$p{vmTnKqN+|jyibjhg zV`lxDsC}OkSyt?a2DPR%O9;$CUV8**L!?9QLTwe9o@ptKxbM|TjvoJ~w}gwwj@Y2? zp$kudq7r?8_6Dm;=n@$U5V{_&DFIeya7Sq+hsdfWk8(Y78^%AsE*?fLb(%C?qQx9C01C)E<&6pDGYq^nW!B_sN1 zTUA!n2LGp$VjiN)m1Ph4pENSLiWQd<`EA)kmBKS@IdFj5IJ? z=HrKdk=LM-T&HKioHpfs1_Pcx`YH^!%vY~Kv+UzV!Jq>3!G@G@y1Hr`QnM$wzEtv0 zd4L#R)~CP3Z0q&)m(y0;14b0J*4X$Z%d0@|pTA&vuB*@HU)~ECFT(#GFfi?)S_iVPDx3L z(y!W`f1mXYfpoiCP7g*kCIa(@ux+xO7JjIuJoc2Ky?mCCCg2@;Ri0E;b|=%2(fERD z(J!ja6exL&)*Xtm@oi+ub-4E24pH-4dQ)KocjIyfpsqo;j=dW`;zt92sxh~2n zr42j$#g=T%vg8pQ5=qHaUWrY+vLF10q8;#6

TU?^Y|i!I>iIF3xB+l@0HjQ%vHO0 zmgmT4J@2@pri8(KO>L|w8 zEdjD9tylQMPrKuRv_vARFwf?J6(lo5YQ%6aF=!bW~S7!HHUR`_Yf10Fx>q`YgQp9z6tuLGs(svlvRCto6^un2qNM?&SU zvU4J%;*er?#@shFP-R+L;|h4VL#F}~A301RLpwameUJ3|U@NEp`Y+%UYq+*2=m+?8 zK>N|&|BtbJ$M}04Ei!#;z^nna=a4;6WCjH?K!h+d3mi~KeAo`^K;ot?j-B?=pNA9s<}kic z+&z8X=QgH(0%4gU%KgHGtczlDETui{@d)mRukBhyH-IcF4Pv4KZ>rUPU}0oj9$;u- z6jYpWq9J?FB`zW8Dz?gu5mkC3AUHq}8LoZDEr2jcs>?$`Qm-eD4x?wo1ZsW%b$|R< z>h8JK)z%k*_tV+l-sc`qLj4g|?vZoDa&r)Z^azsI6uCdn4Kz2BTC|7qGL)lp$?2c< z0TwLk8*^y+bU<&>-$1+v;As&=eJ=n88(@4;#SgU5Ue;TLHL^UlGw0h1)9qXMi4DGu z-4bygENP060R~STuZa6#!7>J3rU`;lnG+y4$}IF-Z13aC3o_J}f2@o7J#9pb95nbh z$hbfaIkh@1@fcialX%TsW34rVqexD`<@+wXRCkauUI$h);xsAQLw+!J6Y^!bTj$!G z|489q`oTxi)3|Y8IS-BS@+Picdm<8gc5L0Yt_Yx3&xEH;1Lgj#^x3^B=q zek>I}4EqtrlQ1O#M~Y53=M8%V)W&^S0PF#@30tAR;y5AIjQ*ALztWAeCTvGz!}07^ zY1ZJr?pPubhnH22`kGEL34%Z$VnH@13Jyi@f+mtT*cduX(ACu;#}oVR_kW6eT5Sb& zN8E~>6BYxjI?QK+KuGd?KG2at2Rku9LXqUauqryniu?1wmzHO2-R*2|12(x<)w+<* z)14}frwlVZY6Q^Q2FJbDGD^=Df%$i>Wmu7S6C`c4uir5OuQ{_?k}(*6|s!)U}{RQ zBA^?poOY%UW97%c2-AQ}1Yc?p4@2qY9n$0WscB6nF^pmtjz)JNZozg`&VPRj_lED3 zm%%Yzr>1CX=-||}Zsq03{LZb1C*tItG%sCNJ7@&z;#6k_f?uJJpfv|S&A3d-ieNGz zKio>o<>`D9)7S0pjGo2gdP_<({EOn1SV`Hvx(c`Ru1ZnRxts?9|JdkX90)caLDnJ9 zfV(*5s48VLKekN{d2;IEN0CD=d!C%ATF7g4cs+=bCud6_d8x;C`ygIAGp9Sk=3ZJwVOH6cES;NV zWs3Z+vryx7i>my#=jEoVZA5%aHi!$tgb`fFgICAH$-W9>GQX%f5TrdGGD5oQos_{ zpimy8T-1 z;LFM#7Q!aQs-$NMUUYvpTcg_?7^|%!{}L!ycM=#KEe2?G+s+V2q^KcyQ7yNe4f%Sm zhj+`n$omw+cf~)2-Y*A;Al%0&YRpsYpdOSXTN@rkGp4Y?jpFaRWZ#seJgKsl)QzHB zLBV`Ky*)d=Ez;TgzBm87+x&Q8yZweT*pU9`pllPlCRIgyCaGg-c=^C`wYk* z;5e+nBksH9PDoI_!bpn+eg@@|+M1YJ2TugMO;d)Y$$xURy~yDUYv5_g{sJDS)3R}O zucdb^ppCxiluTkNDr)H9%Hafj#G%~rb@we>feowdwH`#KTr@O*Wx{=+tMfC}jhFZG zY-FqM8kkIiUv6AE?Jh}MOs)hxNvd|B6T?yn#oF@uhUSL{hLE<|soxt@VD5a4DK{vQ zE2j#Pp=ue}OTGT7hu(LEH0FItdBfTN4Y?cJZFLb#{MJ~9BMFNdLz6f=17-^2B9>v= zLv)wAjtx@u=bz@a@Dt*vC{()6cBm6e#;QUGy;Y5&2Z#mgwchu?*5R}~`7Bp;lb0XI z#)dfS(VSl_jTOT^v=!}q@8h(E0;-6B2!oXm9=MrgipgysuIW!iFS(B%A~^Dm=2lS zvnHal$RuK_E;|y9=)jaBhayq`E2|bHByF3ebn`SN-Og491^6xjMyBK^*We^J9_RIE z_kNNh8ZwCmo}hsSodh7491tM#8&C}V8hfkw=2yWF#vcreejyh$5}Y$%6}57AHeQpR zdddyS?G%H$<#0?SHXlcUNr2iX;0|B^9S@%qLi}N)p{>fXAxSgBE-c)!4j3L_lh?;I zcKV=Z^p={bu8&EVhgi1|A)-Xbwu{CI)m$);ozpbSd!T-ilS;~>n|ZzjooNi@$5p_p zleOeZ+2v+N`b0qEIuH!%U(g>uvZ$U3B~ey8J;*2Z2IH?m`81;7mh@97huMZs&NYcxaFOny=vXcS~g7EPaR_GojyV`39-9@W;< zl-99pgw`?%4jJn+br=Ck5Ql-zF;-VM~#7#$&qSp}9X;6XwvHo!|oOOg1%&1dpTH zFtX+34<%cuCHhpTI`OJxN1vxpC78z=LE(5hY`D-P&cWkwT1}qyu{(|!WTiWHG z)8|6M(oa|PYPG9sCyJN^H#}eLc*#aLZ4u5WE=M{0?6UpZEt<6;FnODQI&^vZsxqZDKXK88ANDtgFd%scmkQhQ2HUsHYXNoMJgah z&{Iescy_{woiR&mF{=yNh}^E&5;bnfDz_~or1!$`mD0@PP?%K)5bW4)GdSx)E@?d? z;3v6V;a}SJ5peSNdWk2qKLBc{sq1>#`^U1LE{1Ky>Uw~Qv4TskVjD^v;NLF{3>zu- zxx32-Clj5N^|HM;L5x>cP0*%$bF4o~9FRrfG{#$yD9YGUaPWy;wslb}ViP1!=z5nz zY16fNTh(L?|EjL@tLqZWK6s#`Y2?@OLPi{5pr2q^@AK@Y%v+*fb1?n5jBoqLQjnaS zblIP+$g5&$ZP;BBzDUU66Qe5jAo!Ai_WZOhUNv6hX^jt=P4u_e`+ER;FZB+YeXgp1ZX^~Us6m_Za7LE4?(~zsEPMdO z?{DdiJ3(Kfe*NX<%WCJF?mz~Sp&IW8iW0XC68|)NR<5p zm?2(QWvA7K2u*JU1c`2+gvuB{%z9+@i9lAy%-N{?9Vx#! zMFlw?4!x#U*DighltM*>4t+8)$$VKkzPbA7F))nC;!Z>Y$R8?q|7%z=pl=7{@Y9#I zg$4q`{U85(4kq^hrq(HDqPPpyOcY#WDIc@eZDS(Q!VkOj4n(rg zUT#ScjowC!YR_BeTn)(3iF;qeSsmgef__nFlQkbcJ^@QbZ>VDIAdLcJHWFTnW{tV4 zUT$#i8}LjSb}x73q9z?-DaeO)3=k0A;3TAp4$BcQLyk0M|M)<3wMqzc&E54ioz>;> zeGbv_?db6EequB&1n;Sr6hDiHV?)QBX#paL0`N;uk_1)KD)2y zXhDIH_dzpj+@yXu2<(@($2f!E+O(lHlfK7xbxSwVAZ%~$Cf@pWfNe#kQ`4%KXE!;g z2ZhEdM81zXNi+6Ggj+=W>2RPG!7`z+J>}>g#i1AtwvspK9kObauOVoe-{|)xj-FUZ z(O?ANhZPEvw0vI5#7CH#Jq}RaSlT)kGTp6`V_&AaEz7>~Zs0U|`EX_0j^Cs$F#7?w zb3zTK0j-H1lMrj9dZc4J*kq4HHZBwx@8nZ_?;fYABUB3Y0yL5qWa^r31@hwc>eL-( z+GKV>j!qvlUHcfaxC%079Zt@C9!PV{MfW(D!@m4qxQ$|5&=M0QyN@M zi!BaNJ7^a&jarCU?07cjSKBj{rlN=Cwh&NTyP~$1n{V??PRb+>}V!ilunB~ zt=jBu!M!H>YvCUP!^MiWho81fdHqcT_2TRNr4}tW5p?mTo9Z`vXu@*$#6FP;uADyW zg-g~dd=!Si4JZZ_9UV>_ijb&oHmk+%-M_}!rj3?iOdGBcq(v7VC3 zQnz7uMr9#GwbRmNpp*OnUQ+wlNhL|7vs5&12%A>xXDdmYfd)P$eqg|byIM2Laae=Q zz(ZHkN6xZ`Zo^ukzN4&OM`j#a+c3F*%aG?+EnCj?>BIU}Q2y&m0rfCX4F?LBm5BpY z2jggaUT2#S)__?3VHG-9)1cGXaff9m_$#+Tr*}7>SsjhY3NJE?jj<+eZgJm{75J~H zzf{AfAc<*egwskO-Yd~-`^X1JF>3ARKO8dA@Yg-9wT*zW^vf4nH{P$g$IGTd+RDx* zY6me;BuCwt_(Yc327xn~(fKOI+vRZ#IB2wJ}I+ zU;Y&e7j)Nc+qP}nwr$(CZQHhuvu)e9t$cq~ZjwsgU|n|4HG2%#eq4DyU7r5$ z1Ix$fJ^Q>q58scS=(TY0JE+V|$50lVlIkRKPe5-9>juN$+wo_H)>o&JUjDvs#!ipl z=R^F7>O1|O4xfj&VdCzx7M^0CBsG$ITdM(GGF-Ys<$wFg8M|IaqfeN@_(g}z=t{u9 zJe9AAU)UJV|N53zaT?cf^!8l#Yl&ZdLGg(%`_CsnWK1o?W;YgMpud^2XOcidGDvJD z>MZVcrch%E1*IT6Hqc6W;>oZCxeEnjRm4oX=j_awU0C)l(?^f~Vek4$?+uYuF5=23 zjmRwbNHT^9@LSJ08u5>{`_K=AGGsroLb2L5**cCPtCS;D(xl+XD@1(fgzo>KT`#QJ zkcw1#WY6h4-Y1}XFS!szuzq2V{lq9zl`?=i77Lz1-JvcaGvpA6y~VHyv<3(kn_BHw zkFhgy*l5Hd@gj`c?Wc@o`P#L&Txe!;-ffC6Q6anRy8`{oQVFYY3SX7basajO_1oW? zfpy&joI*f%v&^;~CVQuhnL|5xSy_=^V`n#CV~^egN2GinqCqSRCZrb`nF(^^Ju3N3 zm9Xj8?XeV5506K0o2$5imc>SM4?*(8Rmbv+msnak48-j|lC?fA_Jbuojtn*dH4~;c zvrM&M-B~!5*uCUk!N&ndpS@z5c~?s*U~zUUv&4|q_=i{Drx|hzXnX#i=k+Z)K|!_4(aAr)JtU;=jl8eH&uWHf1hUvv_Ki`s?)szEL|+>?}k5CcSPBiA-`? zT#Bl1h*W|y5G6o~@UEjkp+3t@dpgBRgB_dI0v)?&g2H)XH%)=9iGOTO1-iUt9TDG( zRQ3dm=0$5JHWd=%*wvBH5HL^Na2{H`vfy%h2emOd-_sXrLXR_z8xZHl`tQl$V4ko# z9ovBNx$i*!9%hY?{pghCNK1eSM>t{u$y`(G;4M{7cM7QlImQw-uE-F`X?FJy?O(=u zdF=_euH-kb#>-IgY5zwg#Al+T7Zbr*>>G$2;t)PJLMr0gMoN!G?waa5NKiH*QoE7* zY%1DLxl$y(QFYzT2xA(Wq7Y?cjWrfSw3B@d2ywy&Vw+TBk%p^i=2$c%rhlcZmVhji zl%TLi{3_pf;3N<+3StALecF zg2!F6V>DyKMhnsn4UB@%+29Z?M8>hR6qEtdv*2~O9}QQW9|)}mjhC))8-Ma z>sh2&ZC_|?7C#@D2sq15d>Gsqp1-iYu%YIOhe9RR9K>LQtw^LMxJg!?c;G|wA%E%_ zAUCcOMn>3U@%-DhiqW0JeD3-as}pFKi}eZt2lV(bfbskiWFz?VDlux$A1p3QoIIv# zOtK>_9)`AqrL`HH^ohm|FyJGpLUMURq?zS}3?zt=%mzGqJ>xbkWhgZqr*&wU@F3u@ z`ad>N=s$b*dwe0tem3*y^)6oe4sEMVhTA5PBc5@T_E4k=1QC?RvFPf#FP=qNIRk!1 zQ#rK)RE3qWtdM3!9Mbgbj+6q{4&AwcYVmj&;wj|`5ztvM_W2Vyme);vIuI08v$|&+ z#*ITv8)67@h4DzMg(|cwb;ymC2pl`TyDJu_;ir8;+IzK<5yt^;nRgIc4)+0Zs@?CP z7VygB9#K+EGARcTj4Wl$+6 zr;VF+&K}b4NEbQXa>}n0>9QO5?UU-y(Z~a?NXzu&7t;gtk<^zcZ%Shx?c&lV`4`bwO_+LxX&#P?K%feOZ$2K z(ohKz&V83`2j4=K^_wg#7TX&36MW7T0Mx89zs)5Tt45Kj-zurrZ!wQ{Sp)1P>q^eF zcwvFA$X>h}$Z8Ug(urn4g^YG(1 z5k=0t^E)xli(bo*epGv6D9XNO)$G$@9`Gnwn!ueVrG*kkB%&g)@&x!^&k`RqH8%ub z&U3ZTnb0qc2uFkvDw!GG@NuM>|5*gbbuG4)8vk2Fs+ae%le5pwla0vy)=mIGTiC?w&#d2Qv zRu!FkF8EawhZmdvt$Q0}Cm7e9^AkHy<<0dCB0B!9vvWr+@xRWfsZI;;nYf5#1lP2F zl$bpJw)fRnW6w4>Q#G;m0<<5pTKFnKIZ`J#b*OGV4*n-7FS9}7EFgkQ1{7H@K+8s! z3?n%!YeN1+L1|OFHJx(jLiBA0owE?GlLFRFQa}>+EZqT0p`<#9QJHvdn<^|(3TM_1 zjjMuzl6QUqA&a(qX%y1BnHg;KPSYN|rM9fDlLGK(xt5NDWcDDoAs2`Y?eb!+WN;Y_ z**df`h1N&Y*W~K7$Q^v!BH9X4T7ykb8Jm}Es~XK1QA2M`59N+zp9Pa#E%3s^(dPI; z<+j5p>hWIx21IELhE|fbQ73X;g=SLz1jSvQ+}gq#eV$+H zGFNRVfP2j~i@a+u{ZECWIj@STdpU27iFBFl&6~evSY7C!af^*K?yHzqFpe`7pf>aN zcp?3IlAe#8aCmA~0q&Lk*$TUCw<+yGRWk4d7@%E4E*BJ@i^JK?W_HNA)DI9LLjMq9ul3@p)tE{>uT)}+|ytHy^^s7aXqhT#-U;;&f{Byp9 zR_f%+k~$5Gclnq7EQFIN^3pW{ZMyvqfG5mklwbiLk+l@EplM-C^cUeOPpKoinD{13sT_1P>B9L`QnLr*Ruj5q7%*YnIW>y*xG}6AeHe$ z*}@^i9&yFADwxCE8r+{>gf`c*z~ZP@)ZD5DWJ4#GDS;hdeo)>L$Ju8h)NJh z#S!z4X@sOl7XyFl)JY|YPE1*3D!szoC&=YG=O*N-`X|~M{ihYhQ8p~|7zpEoexR<#cbBh8s425D=^P$G6;VrTYDpN9evcuA{l?2N!W~dt1-)m^^8b@q=49@;Eqw+h8 zC-&$I%Q7x8XxTCsUWiBZM07v+EL01ZLcz`Ogo&T%+8x;5Jq~>d(dCalw6{VS@6WwS zZ*>2@yl5K_6+WzEtTbW#F2;xa6VC!Ta(Zn(7((jDAfovcusMhFHT4U??T`Ux%(~DV zQ&xB-@v;?u)PvADiL`I~+D%xxB-oTToV@9bK#x$;QXt4~f|&nX`bWS+VeMxL@ZYzp zuM4Xi3tNT=&fZ_$1$_|?;_>-zgxSeHXySgCm)<-KuP^T@F`ZeA=>JUm0M{)T-MwCn zu{uh07RZtE!qgW*l|is$@9Q&vs0o}S(MKh5z+L!&-bVZ&ozM8BCCcN)LU~GNhxkNX z-A2u&N2|*ufxH-&jNr;Vg}!g07RSrP2G0pq9^tKd_TZIFPvyX1Zd0ApSw^Dmgy-?N z40Vf$7AzuFBq2m!2VrTv)P zS5FI)`!D`r9ee=L{1IbuI3Ro#xNx?*g}eMSnlc^{|0RO*jeCJxoae55i!8n0MqKUp zQ61sQQS#i(&g4p*IqQT}Ndn&^-d~4#XRoJxzx#Vh70d{bc>wmY6^OlI8T}lb+f%!7 zqpn80MRf}6wfH?%$g75@j27|KyF!7Xat20_dT5`|xF~O$f$3q7LQ3#G$Xd_tfakA* zv(`NkBvi|upTyubtH;4WZwnpiVP^hIsc8{NOzGO6nKamj z0`b2N6|2PmFPi)>@z6K3wE3UI+*Tfc_wBaCzq|5*=)?BykRlpx-nA`?HzaX8S9I;F z(vlfTD%r$@G*nS007^^iukO8R00KZHoh_@bxj8MQ0Rx79bAW4feIG{eVSj7qL3@u4 z3Aar2oR!D~Pfyk_AT4w4Ym<=;Q&p4|+#VB4*I?aD9aY=JM(9}s8`ml3w1KHhurPJb zmNQao2ZODaAaQ_GGu`@h88#yM?3*gP$10hq-gHUA4;weiDr~f|DtDab@3K0P;Us8H zRNG{3xXuu}HSqQGa@<2Oq6+A@Cz<9kjD(_|FU zAlWY=6{3t=%Dc5QzH5gkSN<^;IJN7Wtcm1TI zlO}ujMy2PWxwjK86Z(W|334|82vUKKgrAftGL!mhcAS(Vn2o~K%!J%~ZwpRKYvJ{g zntbzr^vtDbc+whWV5N{X8!%s6QBQ}UeVLbe>6rcTmn6M%bsj#E@k23uO7{ATQzEVYh#x)(-E9fZ}J2zNjI)3T%NUQ)U& zFLHu$!ZVaOY|+Lka~NPbvys^p)wy;vg;R|8e=C09X84~0hQQ7mz;b~Zf5aNBvOjo# z$#)BJbZJir-8eL6^lmTWNdOuiyk3ZSLcmD5|{JTF4=I)-&LQ~KM(+p~425E}cf<+2o z)zWIIBU!DkGoo1m(`Y?_R+9;)AF6PE1xO~nXAe00Ahb;IH6i=a5Zi)ut^5hg7w7ly z`*#NG$xPBBqfBr}0Ji}1-0ORL=3}y>ZutCuST|t+R})7&>=Kn|=~H~qh$jc*Gl z{qcRE-~HTQkJq?^jsV4U*m)z>P&9K5jFh)Ytub4V`kuHyMh*Ji$LeY z;~AzFt3j8C`8>90lRp8Yg4ZeOp2%ap`iVUqFx})V5*5OR{bB+|)?(s1YHG%Hy}*c2 zMO>0_-bOA&b;lye3Nv<1IYmJ>%j1{MimIWHR#SDwme2vH&}~1s9V1EH(y`M}fqkdd zTY|NSSu5!6jrznc=lI)l9dZ_<{C2=~NLcrC2sN4nfvoTYN+z4@!xXQ!25D}IYSAa8 zD;g}T-V*rL$&t8nxc)wT&KumEP-g1BtwS`g2`@4+NRMJ51W2>CuI2JrQqFts? zok3BeX#%OoWyaS?d$^?gm4YvW4+Y|QGYA{Rtb3LPBae1Pm!RhUrnO zIGhe(Z-)Q?aG?KyNi{GsqjD;^L{>1XM}%i$HsTl?Zb8Iw3ibv`f$M>^gkLpp^(tO$m9VdCCySexxinK~*arec(5?phqx z@GxpWcq_b(vBYx5B{XH2V{}5^!|pikxqpi`RrkLLv?t^%*@BEZFSp#D%)*A;5H@nO zl6l5=pPz*Xritl->=~B z*44@jPp&uTU+)jQy@Z+B?yI&z&%e-d=+B@$QFJ!X(@Q|5Z+WUp*<_?m6YYXOwZ!Os zNV92f6Xbbb&Iw%4JFa57s?EwBN?1S0+JBBNy0DbQ8hwBuIHH{%>F|bos!q{>U`Ofc z2&c#`A`Yrt4`h&&d;krst|d`;rOL5x4y!eY+$7;vX3xT=>=Ri`%momcJ<)A~>ryik zu*`o#%~3E{z^l^p%USF-?2A45Lpe?&19=6WYV(HiskSw~2$vl?!H=*J0(!v%>uwAZ zQD&;G>IluPKxmmtr3mUmQ-Z-XnKsrmx(_ym96&*mJFUlq)FU#jV%jD#l`D&K64Ban zv#4KyaR6zCC&&e?)qF$_O6ecO6Z`m@1n*55&EjeROnY)?7Q~G!v$7PM8TQegP#{IS z#!JPsaJKpVtPWyE3aTv026fBXyE+6N~RJlyMyH2QUcAx-N@X*f$*`8bJ+Z8A5ZB)pvXb z*Y~%>JVB&8B(et4!PHdH(KI9&yGH%ko32PmUDwyhi-7^%KQ#D@{;u5^7n{ub+h#|2 zv_YM?Hfv_$8Nfc>-);pO2Ns=KL*A=zeM=JU1Hk8A2NHuGhAJ@`R-Zq9lWZem%*o-Y zbY$i6bHjVd>Dc4njC}G9jxruK;m81Cq=U9iWGam6o%Y&$q(n~(d$nz^GWY7nxV|pg zFl0&Wo9rBV5oIeMy{g;Ht;SS-iNY6qFF=Nu+iLB$6c?1txbZtUS0WLgPB2G zpOeVrU+jXp0E`tIQr0C6aLcGPTWs#z$#`FDU2aozpxEal}?sGK{MXgA|p{EQam zOXx4$Q;lW{6A~E zT))rzCPh$i z;v*{byTOR_6<|DGR1 zv(KL!F4jYdc_y;;itC+s@XUy{mQ3Z$SGx+)*`0mI1oOrv z_VNnZ9gJ>7DYzJ)N{W6rc5@)UJBi`|?V z<}~`T!Z6R;z^%V2Srg{xk+FL?y4LY{Yh~-Sgid%sVhrdS;23l0$sa6rAzn3JEM||0 zH2MS>p*ST_zN0GP!mcLHCvLTtG1q;7s0;7ch6xgf5TqxZ7nkQlg8tqfr-sphml_9g z8vCW+Aof(_OHz?g-D2hmx;3T-WCG+f`J}NEDCU{nga z#*M^rC#QNP@j~N;T}kxb788z7cXUX1!D^*--fRO%Mc{OYl69gbhCrFm5WIBNY_!+B zCo!25dUau}>6@R}Jei$E9k8Ll|FOvq?#0BzXi@?S_ zZX1B6e)(T-J=+mLczIrwCaC>>!cRrr^?sc*3Lsh~kx&Rg^D6HJA%6NoYjXVo?CZ2E zsy?OYko?*A*TJ%gsgQ^1+y37wV?D4TDMm1GR~j|rwx4ku4K2CBY_2AqJ}Bet`0S)N zIb;J*>!D~Zs}!#Da-Uvr6g_eeeX{b6f6vBmtABn2G6VQH7O5?STgS=#1{d?V6VoOU z;c8XjB(tAyFM|&3>K9PHWlt z%RQ0UKsIS;-Nf@@k;cZBU{o(p(T1p%_Vvrb#BWkvVIxg?WY+)y66~Yw89T#X*MY$b zGp~Rz-^?rj$LR#Kv{Hmp?oIj0M{I{}X(*cOpJ7Gd_|{n^*<8vGyg-s!wBA_1hwX7q zKY5VlfUREZB?%0)%YOrLSx5Ja`2BQYHE4!@4|0UXWfF#UlC@k=Ai@fqeESMv3EfQx z7O4}%#??BM@r?wy5NoPv(GPCU)ZNa!c_|?mGPz0s+U99qE~WLh{z9bPJ=842{xSkz zX*S|7j{U>98h|Ox%{XOcHcHGWF(Bb43Ne7!gF*TrM~oAiPITG4huxA9&M-&#Q2Zn> zj}3r%fo~un3*L3ZS#y$2xGFYJ_UY;~)en#fFDJ1NOC$qbWh#VA8N5$U5+bsugd1Bn z$%i?j;+%ui`_X|C{*Q5!9Kn+Wogjz;EwL>STaL3&1a3k9ScjH2%9Kn#o9TC%-Kv}8 zR?G(t=n{}&WrPiVP$!>C3&v}+2E%4#ZdGLWVzC9QV@R{yy_9xmq+YLZCK(n$JA8ZM zqE)x%&MD@3eV#<)o9oJbDW7dLH+EMdRT0LA5eBea>oWJS8I~z@h&S|Xje%LjYN}n0 z_oQIrwvGv8uqG>lvf*)g_gVBjR>ud;pg}{d0>h=Mp zltU1L5n{+rgbJiy2RJw23H@GCApMz&1i%5s!})X;Ah~Gr(OM`Ob6&29hCESQec8eq zGa-5COKDM%1h&Q6J`!oILqx}QCDBW%_laK0{Q{%f{U9V5w`H~4M@z6@wGpOTyXXQU zD15#x@6Yfp`?a?HxH37ntKQvy2JZFi&X$JpJ@m@-qAC%=;&G5&8JD~KjISbVr?-9z z!F&vZ;f~&T1rV?=X;oVsm18R~3^1P)E5l2|0($C-vExTTz+3c;%V=O#6^Qfm7xsUb8b06NRPiJRUK4|iB?eG}C^JZ~SxV zXLsHC%^v>#&*qqjNK2g+J^;X_8vp>o|Fh=#KUwPkHjw@or;hMiJ8y|4?Y&SpxKu)< z5t6u(W>b?+*BMV?uW`jq#m}7h&|!dxlc*5{3N?M?D#F2M<3?|mg}j;KzN|Z* zhsTwYzZLED?c|I1+)WnoTW|K+T=r=3%}~$E$ZSTO)XchHE6iE1I%=@4 zyx|{S;d-@rj%lViKM;23fedWgfM>JRFFw zvFcW6ub^};Sr324plhGfblCM-uhtw|s;;V64LiT%SZxjfLCzZ~UBtb7aNRjGE5*`k zl<93lN~tx<>RqEY{P9HYj{!%Lyx>jNiHA{-JeJz%zJ6304FZ}L%dieTjLzM%<#0#& zSOxbYw`9{AuRv&s!3zUy`fjoQnTX!ylye@AJ;Z}sej1q2cd_-`mw zOG*^juLP&hKe0kPF-Hcu%xuO%{;K4z5Vz&sw#|H`S%&>)_Q|%VAuZ7?V!3I6$(MIu zKi)>UVn)gG%E)}*KW4Z<0X$AU$8 zxG$yNb3D5_0;DFP(?N0e6J?oP8&7!C8Pp5h!`imdaX|TGy;pXM1t+)AbkuZp~ z=iOMeRjpya|AMF}EU@c3+>P6PtzuoK@9F>M@&0}sKI}EC+w1puydK&w@d~oN3F~PF zbz@r@Jj34qVL@2#h8yUhXT|RmQ#?%#?4PxmEpLq|&*S>zt$dMq0hx&)@&3nF^hH9L z$Laf{x``t3g5Atm0qqIQt&nJA7>K7Jk;jyEp>digs#>zAaKbxEt~~9y2s^xGawD5_*Mkpjht zodRwyT{UQBSfW28nEc#lc$bND?l#O5)HdhfbloHu09$tIuP8-LmL;Jc%&xG1wkliT zeKfHVF~-N0 zG@5I`-YO!7c7gX9*@WTnUOKwmqn<&t0#2GGCl>`JQAVRRl^Zbv!Wgy)$FMu5_eTpRksdNcSW33AQ03A)ILD`j7|IMEZs_@G+8I510t zhMdC8`ez(qPC`)bl@)8L3{RmHxa<=C2sFEQ>Vruy<82a$A*AtN#VWOBR+64z$>`KaHW0%o|Yow!zQRB?q zu;NxMC{G<@>~TvG!-`96V3~mV|6L099X{{0=+SI@T9!Ljx{pV05jAswYH99WPe9x2 zB!Qj4)3tr`gBow;4)va&j7*(x)&J3YeO-3adgZ8rI7`m@(hSBlq|=@|FQppn9Pj5u zg}>*I=+c)KOU~~B@`kP30xBGWDy8#j*nsvLD8jpb9QO?4t8+emCz&pDmF+<{ zU7QnxVI-OqD?Xe(F|Mv2Ij@dEd#7yPrHeI6OD+ldaW%dl&!839XIssL zx^meLNEIXAUpC4|MBfosCG{75bJ0_88=TQ`;VkojWBcdU{zrZ?h5y;b0x)6OrMc0vmk}j9z$LmK= z1M5-C*998`+y?^|Y)gChak?6kALK(Y@weX{!lCwMx7gNe$Ra-KeS*D+w={?b48^0m zZ+kwuYWa*EZB>w_L87sMM(g^nzb{Kg4frF&zz74{mj+rjP^<6+Xlu5j;CD1weXo+}+sn=z_%AR@N5VPCM&T(Ei zmYn`wbRJeLl?aB`O4c+(SNxGYlUsS4?2LaVk0XKyxr@UAB^a6*VbHPlNbg3zxk%^8 z@CoIVx{}Bs@Q=;n(h6Vq4E5dc9(z4s4f!Mp6s{HbW|!qt62c4w5aK^Wb3gX`skFdfoB+sK*rxb_dNe>FRSA; ze1ZDTGvS%24B9joqbj!tzPE#ml>Gs$IZn;fgO>K~b_J!Wk8+F5rEHkUDRe$w96tN& zbzH{9fhrFeE9uZYl1B_PtGqR%@dOvN&V0ZT<*?Sana})_`=Jk{@$WEYI@lFwj71S) z`A$5C*ELeMOhXKio@QDVg=0}Wl*d}!TL%M0)PII+vuZUtVyMg zOo?VNi5ipXB`MfQ{JsWp3wAAm93hGA*O4%4@db%dwa;CHMwo9ru$%%M+=;-MOb-?}|J204PE(CuV zz)nKBMC9OdMq0ljrj>Vx!IGWw5Cqh9M$%alBAB&MceeP=ka_>74Y9r*;E*6$Mbf6B zPkOKmBs9Yj-2~O04kB7G;jE+01|!}Guy3(85Gs{vdOMlLTiRWhV=(0!B?A@+vQ+-2 zZ?>S+)M{#~FUavoFNL?Py^of*bpHn1hUKO>0V#wKH03na@D2We(~U}2+KB#7CQYH& zF(roV-IWCBPmxypMY`*qdd8ykPc}3}QLjsX=QIy(`Rbwkgiu+kghIKH<%O=+ClN&do}!8YV8(##eoqS3OZq9ByX-0ATb#s%)N&9SET zDyzfQ;9$}0@%fczim@EFAw)#2d+~wSSQFlGQuBNzAI7~_4dnpKR_2L+QzyaC zgmpatPrXl%;vaBq_8N5>p6(N6W~arikM=VqQPTJtYzF&c#wu!^d^BS z!fAu$A5M@su>I*zbIB+#P&$1ff~22=L75u%ep4_62lUbb9VwYaOxY6Gz0 zt$*SY1uyLR3MYRS>_>-sD+V4pwpnJiFeoWgR`>}|^x;ixZ`c;#By^vTSQnmdWT3B^ zAc3y=d(<9qHEd%{#thi3G&0n+*o{ZQ+In?Rv!rdp?IluYMhNR!`F!*>yo7jDGxP4i zsU?Ot2v_MHeTAe;Wc4+G&**gI9p?K0MiA}DUNFir0}lhH-Mu>1%uNCYX672J1|V@v zfY>eeGn3lLf0~;mtgol$<^v7;K(}f(v1x@hpzep>Do^6uv9{zllI!tpoStrCf&*4- z4mFHo*N%6HG2@Q5j1>QrNjTR}Q8?DWK;luQ18e=0l?{`9>J11UP4pR-oDEh#e zwUustu9&nU?1tbG43M`4tAEDtv_slq<0V`R0$YG_xn7?@FELi1 zDLJ1TzOI@G>S1sT!Xluz-HM}p8A7;<_Yq<_pp#Cbr{^x#&-&Ta-soW`bALGEZ};dh z$Zg#cjg}CJ!Is+8PmR3NGlv;dFEZNHP%p@;2fXK)wUW7P|9ZZ~g$G zjs-MjdU|%pov0qm#y;K~`C+s>j^oL(b9P~zoO+Adnx(mX7o{pYD!Xr(%#^f^ zDld!b`iysAyEkUsTr~UtogDIbiET)$Oc~%krzBK81|gY)mKupDsT_QzQ|#JF^ws?~ zFlTf1UP?eRA(+%AQoO_q=fv~ZMgL)hiz#oLh)i^{_wF=6<+*nRsa{+<^pX-tyy-DcGhpD|!Z3d^J1L#lhegQU>!Gg??nVq-!*q;Hj z3A#+{FxPsBhxhY7-^9DocFW_ z^fC1)nXqDG58kE%7=aG@Sy4%JD~&)FYQ-}dHT}s1Pbv)HMhyAY`SH#m#b^dKLqGWt zz$HttvLJ<$V-r(=aVzbn_kR7`s9-5V;G95_hMFZ!w?rZ4inEt$`2M=9>{e<)#`R$m z{e4DFs)Bg&^0q;`!VB`~C3PnwzylJrdBFz9k%8dk)sJi+Ix~o)`;3d7;>q;*DiW&N z;=R)$GaAjlNfh8AAyr+wk?SfPPpR%ySyuX zxU#{#0%EuJ$E6ux&&z1x3&-mE;qphI)DF7rAIj4|a7dgGqLo+UiDo(gRbFWgJaK*- zA`08fo|kVmbN|n}YOY$d-1u1BYaqN1!XW+TE0ny83!_0L9@ioiH(?6MBEKMVZ*dMe zf{hbW^IuV*U$3hC4f_t-g(_9%OVJbZI@u76^J#7{w8jS;EDR25_4A3O>HtnV2C(~M zDj?nyq2%eJB}sr=66LRN&BG>z0*lFC$NaD(qIRN+J=g2BtYD~DxSyeeZOd6RVyAjGZya!3Tgyc3LWXqf#t;}>VE~R2ULpeqA!)oQ`sWU zml-J^#H5!;6<% zBkvia5m`%*s`86@JBzH8%c6ALvf+GPW90pHQg>)2unH2nL-d6kQ z?%9GOzGXfNwiFmp^5za?Yor;m8C_13>^ZIj1{b67LW;81$u#jd*q4TJ7x;y>cMcU; zu48O3TNloc%W}R?TNA^YWy^>o%P~Xh`7)yIs(KdgZEiiXNr>Ly#TUxY4v>!AMB{;J zfrG;%+lM;)v>U$)s;}=9c&Q@QM|x>Z-qPu(=fZxVANr^3x-Fr(^5V}RX0r=jE+C?p z2*r;iJf+G+uJ}_A+mVLs!Bn;y&TDGdnu^NeZz2@4FN^W0O@5xl@@e+xBD5@s~dy zSz9^9f<(s2&b@t42!YeA-qL4!bd8BGzG8w`tG9NqF}KbL_IGah&`zfT5cdhK!tnIB zH|<+Gp;muK^Q4ox6@e)Y9BfVkT%92Y|jxLa+p_XM+n#Li^Z4pS2$XLZyEjeK4! z0V+#yDTYdNB+HEGGXYI8pv^R3_?>SGLTf*bTxr5q#Q3_=L2{A0kD5-NVH(Rs$BO)2 z_yM1~SRWL*r3x%P#~6EMP~#SNF~nCF(=M|Y7LJ`|R*6lmyXW2$FuQiEO2-J)2zW0?IrD5iBr`cjvtPS@MP@P9r{JFE!m`^;+2eci zq3vRxLhOkK&_=$ca_6Q2_pgBED%%0kny;K-D5rX{sU4^QBarExxbxgjnyc*sj(+}i zBOP2SIU>!feR21rdFL(4hUh<==gC1p@{nyVx8;F%k7^tM`6BRWYUp+!f%ma3%|1xd z0dk;0E5pzl+}FVmN*34R6@pa`i(UsVgE1foTE7(PzYp&(@AG?6iit^m_b)g)q08na zqW2zUpOEzhx7Y$%QY{eSig+_x0SifQo@-NI!0e{}_`g4{Y^jQl`}h(i1O>Kx?cd+k z^#}z#Ucn=2`lXgxIFs21`m^o&^UVwC8x24&5jk=gN*HndWnm$W`;q_j!bmm;sLTmQ z&EWA%^yiQYc=6XCyY2gbMnhX^*Y@d6g05C@o0ZQVAHd-U6GNUY4IAC5He+UhHua>L zPi>t9*i>E-<1cscs^Ar)qUw_Y@~8J!82~g|rZd7kW}B_4l71Cs(w2hYZasVDiJNUA zlgOc+E9x!hsN80#TuO9UOX?VspeXPev{shWP1}{-7Xi7d!=|Qw%a)T|@izMW<~uPq zDL2}-m2Mt*Fjxq(mtc5vJ1oZ$ogIn zf_b0d@s~4=q2H;=tgI=MqET7EYC<+(c=MPAAKngtOF6mSH2pv<%(0+w5mu||o++iW zkml;fQ5Z53KS%MQh>m*ku!3-sXodv9J#mDxJYQKy&DzGvh{$>?vrwPMMC!N>#>nM9 zVyehzVn$CO+NBS=U+m4+d^7=v#(A@P`>3?LlrVE(d2SY~9g;X5`I;w(gv27MX~=$X zVKV7!R|N;_PY>hv=;Z+l&wp#nZFR7}*rY z4tN!sMvGSNZYdoC8M*9j7ffx6NADpsxVG*3e*%{OulC zs&4>0csl(0Rhd$?TG||Bi#*kz3bK_(q5lY(QRIkJi!%6}>+J%@j=3P1sI|a`c~zYG z{)6_PT2y-;V-DK z+Vp#Gswls2Sy970OTNYpafir#Y*x-2Vw!6mYMWG+{kdMsd zd=f~FM_zJ72=RMDf_LBBuSfm;Uwpk|kS0*GrTdm`SC_3W8(p?-+qP}nwrzFUwr$(D zzloR|bI!z>{XhThh@H9DlWUEiz|62RrwtgSI__jWj2@N39%<*G=Vb!&;ycoL^P#mA z*aQ}3r3PDz{b?m^HsE4+o1k}_Ou9-FAk$Lc9uOh=z{!xE0LQ#Q%vqbWMCs)!)QAbh zI3@pP=`_>2$=D-zM)e1&P^$#`w6Td z7BB8?8H<19TV(6E*OxTlp9c>*c)s4^OK0%A+uahvK$-#jGdprYqcZ>UF^eiDXAK9e zy!!3q9gk7AI`3Y^kVcvF%Q(9)NwmjfuB|1+48kG{C8#1h#wsgUYq?UXc_H|{OBxhW zjpgJ1(zbh4vZieCdj0adbfn%D^Zlqwv;8goet_I!EcpBBUd+4mk;rJTSecj4ieEKy zR?MCs7w6WO93KoVN zbTWu)PN1^-R918VjV@^A*J-WhKu-3zC->g<~JLq#qq_t zJDe&@8cCU8-0H5G>~exl40&M7%6l8$!f{RnzL}Yggzy#+jcki1+h(SugtF#dl*x$A zo~rMSh)zv~$AQJp^$dnp=GG(6myD!-%}&klVn6q}Wb4{Q5CIw4&GQ@70{m|fz!jct z6W|=FkFQWu_q!H&Z+RyeMhWgMRh6(n62kC>r<(HH0Ut&FHud9`)tJoTYRFfIKV*iE zo%{u8H0BQF0-CV{e=j??0xp+4=aty5#|V?DYo$+^(k@xeZCex_+gB@ulaJ<;!$WZ` zdm_seGnCz;sjQ~536~1F85P}e+o(8I>cb*aAhzb&8vOkK>^B4cY4!gcI01I%c69$_c_(8B z8+|Lf|2Vw-N2hl*{*M7?^M4FDS&_f5b^9Ib>R`({Fq(8X9sP->wtlZ~;3S|5*F%D8 zU~f#07YHb9x3z!1Ovfb%OEfidJi^i}qjLOD?*Ucuz$?O2ut+T>%5hUU^#kP`)oH8}sK?Z6n1q%()j$2zaE)s! zV;~cbtz0wd?92*S!)zKV)&84bIa3`c$(vVln4&6qR&t2ETMOMvq!bjseTAIc(Pj;w zkj|9K%eVXfDBjE1^4a0gIujbGUC6!sIu9VPMPn*a(pOa zPMVejl@SXA7!u-W#9X7uRM|Y&K+_Ok0=x#9)tBm~;XbWpl1?%)vUG`QiU;zaA1gnf z8N5F$kte*zwLU$ao!uYg8t%W`yD}I))oKVK8XU%L?qGY$353if#*Q`W30t_y;zt-RP#U6`c<7-DN_7!mZm8K`!sV9Y zqd?l(#82y04|PQaZ#Hcyg-T$t6_BzXKcbajoc`p01#?a3?|gojU86(grl!?PC%Hp= zsy+PmsVDM$v9`O9rV)Za{H(rqywagF^E`q7LN`FqEu;nSnS7r6;HWveghNZJDTl7egYZ%8;o3 zGp2NsnjA){pDyV+#1*sMSBF(JI;q-qtryM8YL}Y}e|j?%OLg55r7SbFlf;fVNK9)q z>g5>~(3ZIo1tU1QV_DrFJ@SBGAk;;dVV;(ctLUgM!mwB-hPBZkPR5iSW+XH1aMM6$ z{COP%)lrCIfG2qhbRHV;5?_kb3m8bcKQo&Zyo$EZ3nYutjo{2~%)dyof8J=`>w zDDpMw=3$ZVUWeJ>vnO3t_>j;hQlvl56Wtmfi%;mZz=&QM#|o(SXq7iavjH!1nx|(x~m@InCa_ z2%X%d$DH_>OoMXI$MIRv0%p-d{9uZsSPM@21}pGOm~@Me6x^z`&2;9;FsE^ZqK1JS zaI{al=<9m)Tnm~j*|8?9Rtp;1H*qrq!&->tulIVuP~F3;ea1q%O&;O~N_?t8WV+x- zXV1@MB!zZ(Y_2c%bqXPoa zT)DNkUnN{az7Jz&V=)q=Ram{CBZWr}X7UVSalq)lj^S286e?RNWR=FTgsm!j-zvpwUSsGycI zI-?$u&Sg7}tWO@O^ccXAn@(?icSP!2JANQ66~P?m23JIdRhCf8{2<%B-4f!y@Oogw ze{%)E`wfg}NBG(e3TNkKMKazH8n%Mir(E_SS1Sp=NxTC?DD4UrH&|m<8?_`$R2AzR^eW)N5>T9?F73mwOB;&U zxXi= z4x9q&_z_Qh&QnyaGHx9A>ThgL#%RRmDUl>U}%MQ2p3=tceVc_&;J6L^~QLLqV%Dpx-%y?=)}i^}xjD@Rd6S4Da3Pz2Fgeg%{}Yr|Nvzh``dlT9t=u5$D5Pu^@Mc zyT40kQ)?N%iA0Cbkhmn`3zy7nKDx_ebmri)naVDFtxNAIWKu2YCT~#yBgy_@lnc$|kmi4Xw+tVn<{&DDVUWypp{rUeK~pYg`XM6` z8w@Tk%oAywZWxMVSJ~WCwq(peCZ_ZEI*pA=YOyEDcK~?=PO4O_F|LH}(|>mTudNrC zqJx>xzt|2(ExhqXld;5ul=f4)3n`SMfF*!-9-jXfl);m%7HdgOZCv6rM=pG z%!dT_Z;7#HWh_rnLUvvC-Qgf{&L=G$q6gw9y4UJ;RF+wLLSNNLF7`ll7*Mfj1u;)w ztLUIvMNSLJ?g$OA=T_pC3By&lgPq{0WH?}5xxe-U6R+Z3jYbsV_CC_VCnwm(-w7#iP%7n|5p2cipe9{wZFeL*tVV)-h;>!wFTHz9Ic?5o|kg3VK!#7?GH3e9&TNqB>O?E31O zAg9IG_&~Gkyo8^Tars;a1Kt z0K$V7<~VuojMkAxVGIW^xIPRXyZ9!n)#43|i8PxNIgl}u8pGxp?5sG+XzL4t(=YT#;r|zvrQ@riGgpzww&p z>P)lBJH%iV`wrH;B7afz6W-bAWVc_#?KbpeNrS8NIJzFaM_&^9uMX=1l#E!_#AaAr z9XLScUv)1j3uax2jLKoAaGZ zPugpN8=}jG?ai8d*FnzTwJ6LdKdst(+NZ2wAYby;QPCn}My|e7N zp*PSiU%XBD6qXt0%C;>LQ9)c;rxK9fnXzf}s=uxyRer|Z;Eo;c1$FyWet@q7*l*Pr>~<$SZFe>-C>>gyNw zD_gHUh~vua-7Txd{UYx0t3is|l7p12FUQ@Z;i<8@3kjAAshzs2IWJ}s*hdx>-67@` zs-b~-ubl(K+PdaCG}8Nn3D4wYO0V0Uql7?%Mk~c8DjxGRcUB;~v`dyjSSOo-Kl7@pr(qt-D%gOsv0^ddpC*=$)5m0; z3!d?PFz0F)e z0PI#+9q={m8MTs&QNMB>@g4hvcci&(6(9swQ^FF>f}=)6bg^oX#Ma4(Av0^u&G-V=7XF4%h3F)n^Tf>&+fh*U{3%eigI*+ zd1n_ZYg*OMfe zHDi8{24B%`G*oZde))(o#iDk#UU;I>jVM`v;ZE$GnO6Fc*gUVj@a{g(EJ5zbw_wd| z*gnmTb|;9rUQt%8otRo%!#1^F8cF!o`^C(X`)lp}xp*b=E2Vv>Dpy zv9ib?`BX}6K7FVduYWWC2f176Emb+#ZZ=dkKC_qpc=i_tK6|T&J1t$VcdZ=w_#dkVIJX=vyy3*Aax@My*=j#iS|#~O8eDQ?oUB)H%c--A>L-NkAXJYNkWjG0<|v(FbBm*U=);%y49vG4c+m4-hMn_*sja}|@tnwHDi41q zI-}DXO=oQ2;We>H#5DWxGiEdYKBD2ceIkE9H4esrTJO0ErUSsY{o(X3JdAX@!&hr< zW_1wVdINKqry>nPv=jRe496-1`r5b%QelIBMC8Aukp41M7y$)Qo5&aMFAOY^J^o;1 z;Oix%eK3iM5P0m;Sf#_vlFxoWA3fac^r+#C`)pi(fYHw`RkZ(c1dPXf8xlxnE1lO< zdV(+PC-bw~$*U1yWV61Z%J6IezeF7Q>T9DUJmILL% zozq-J_)XSv0Y4IixgJXVaG*KL&{RzT?b<0$q+iy2EeGB@hu$&E*o$9EM1Q1_jV<-; zwH^7axO4}CB%%l`*vw)AYkJyRtQ?pZos=QqAk5L*KpH8b>So-*`ZQLijS8yAeL{4- z@dkNP|B1?=&c6`t&jlm%Jc)`-a1xYw4{xduk%dNY*Qp7<$znvy zpQTE1rX9jzPXUKAb>ZGMY8I-?q^~Mf+cznC55L4s%ug)fX#++(3%MZGHSgO^B=k6* zJ*K7~9IbdoYl`08#bDO@PPM51dr(b6{4LfFHnHGizA&GXO<}xs2vF zB)48a-!DHWXAst$!Ai#ohohFY+XVDD9`a{!D{!WCrXy zcN>Wb1YmP53SL>=TP2W$U|-i!r%`O{`i3TxjiP;qoL#My#tx z(lJh(Dd4E6Bq_M`YvzC=C>Z%kkZs-WOysVwjfbt^!y&-Qv>c9J zFeKi-+J1vYZykve3|FjUs0gOy0T484-(Y zHj%kRrDz0II_k>x#HI*4?l7Mwxg&7h842UoyGJ8O-+r5_e>e#Mmm+& zg#DQk91;M5cBew>BQ=frin9sM9}1orrw9TuV<)jEy`#5dM`T=6uWbR>~+W#YiPUdEw07h}!G0x`|}d|UVY>?*Htr0S#! zXfIEF>x>rAWa(c7rR*Y+cvN&@NsH<07Z`j4@Hk>M`N+kP)ULElQS1Nm%I(H*xVgJ; zI=@jK`^o)JF_pRh&`kIZe9#2$C4%Arvx+kyswX{lq?<`z2`(K9tj&jrn$w?Asp}_c z%)HA*h*_`D@FUxG_V+RKRsB<|_xC@&K*X+6)8=_>V-XdXPdW`fx#@xdmfqh_y}ta2 zjMgX6Gc|c6p(%3efrIr#eHPLqGXYn#^1&7iZ3%Ef)IY`cYB%D*!qcU6DAtQYM2FHKq{{0U4zO)>G>a{WsShs!1KGQwV@!gG*u-Q%1&xbRCMt>Zx z{WcA07Y2o0s2KN$*?DSTy(gLsn9Mk;%_~5Y=9}}rcn6}2(36hDBI1nTABxIrlB^H* zW&8!Af%WdU&buxZA0h8j4i7`2TJ{LzcD2NLOq@vQ1;W|q{-{mM7OVxIo}x-oKnYP* z^C&*l?8~apk4Oq-dF$^+9!$R94{cRoM9jRc?*qq6mlc*EB+iI?%GS;z;Ws`VlFr!))?llsAB{+gdq7Z6 z)gP`l^j2Xm$+#>5KUWHr3W%*j#LfIB@VSiPhpc5q6~o|JOn4qmAea`pXHN9~iHZ3w zYI;k!ljLmA!Jxn(KJ0d7fk{fNuwpi)gx@J}RaXH~J{junDMNKCyJj;V=yJVsS}nOI zs2h_-Nx#=hirK)CZmYyUI{02>zWc6;P!w}jVnAEX9!B>ml`l)YUUD7 z2|u=}NVaE;n$5K7+ODh#~dPy|QU;>XAZT+D?%TUQD$W1ER4Rmaq;z93Q_YJjwHio8XB2z6P5=kl~ zWfs}g(JXRgn^dR2-!`xgjOdI)&qC8{?T6q3C$uJ-ZKH&%p6i;YFLb_tAWo%1H@ekA zi~Ff!fgUdi-Z+D3(Z@o?Dj)Y5?YCrP(MlRRXqAOvGkPjd5Hs&2fI1Ojb!n*xZBwN% z)o<2N-*!O|k~eHj??c{*!N4XS16=yH!sEAMu`P$H#Y})92i^4#8^wmzsX)X-i$uVL zT)N`M=9nj`qyYXKI$wgX#vf>Bqxu|s%Xu_53vWEa^K9~uV zSIygUMT-67BI${VvINZ}@rFcBueWsH`}fvosR5(ujD{!xscd_-ohKhVlh7hN? znyv9nb6e#Ny3~j2v1-AcUYuD04p@00jKbVsg=uC#pZsxq#b<<{SI1q^qW~$CDzf_; z=q-+5t|_N8a@c<-Iw8q0ckNIa{*gd>-XGn9FLF*KhIs#K^su-Fqbu&+$Hl7$-D~-lCS%c^-r9W4PEVC5EK=Z{lCXogW#nn+ z-z?2oV@721XLE+V^@+rO#ZRhO1g+m>jaQc=HZ$_a)+||zJdBF&apA;F<(BD3!?}|9 z7SlRMW`V!_7H}o@M3kzNx#j=7c1j)BzH*w1mA;@Lgh_BhlGE(M<0;~GKSU_H}I16h=gP|P6 zMO&H0m+X&~JnZy7QjRRS12d@Mf%YEjN#Sm{wQ`QhhUiA0j0g0ZH zk9B*NaluKv!RjealRs%!70Lc-pBJQ8i8kwn6uH|I5*CjXWrzi`-Qt@Uj+lPyv1P2d zzHvz{N;$qvah(vcdt(xDUrdyNb2w$_Nd^jATqI3_)kJ!|_1|*`R#cQ2U<2t5<>H7! zz}IThgS`EHzCAc|b!LGJ;YG6~Vi>ydo5`A7!uJnlxQ}~N!JQME4nI7UJOBx;J)e@f?U^)=4?I7jrp!gs= zH01P0=AQqT5L5;TrnMWmTP=ZBHsx`ITje}U2ad+aXnjI? zvBHU?esJ$7q$>)w5M80eOJH-R3Qu+&6q&>bbTtS2`KjVz(Tn7ZfChn z1o4VOL*yVA@XUdq>j&C0^*9%BNUuH!WFdnIK`T{5r9wLF%d#StJpM&6l}sE9jKpie zI0z#n{Sv$ZB1uFgH}}k##J_0Gb37BS`gEq&TLVAb^aOphkkZxLLS`AEwOw-5i@0My zQMG7?S~V=Zu!jn*IY{!h2k^^c^nBI}qCN^2FHC54xrKe`OmNf*vfi4fqBN;PN5!=L z74k6&1i9W!kt1MmaVqV2#*j{EWrMKvoB?dOPt20^Zz-v=aq1FB3@^rYT&PO9w6Q?% z-F# zEC+k0e~%g(AQN}y;;T6`F{o?s;4#)DZ@WT%khs!X$JS30u(Hvx2BXCf zUo{A&(?QViBIaW;f;}&m>^vLHC>b`x)a@=|FG?TX$AhfX9?!#!LqbF?Q*^ z1rWFB@_{fYnThPaioNX2Wi7~>j(OQAp=Vc23n zJ&~1ggqS1B=J6>8k2|}I8k4|33Ll0IuN%K~K5KBG6Um$_ow6>k(VWQ}3X9YIB_97& zMmJ81-sb&I5t_F=$1bBrp6Y#fI?VHp6>M;pm!Okb$uj07zhu-1Tl5H7k*U!WP|C=o z1JUa8u05e@tTT56a2$!gW@fse?<}tK_*E9$siD`{b;HG>Tw+1eca}wjr>GvXOX?m) zn?D971gBP|#H@E!Hp2IJP82Lp?1oOhs6p_l;=3=}~ggua5zC;Fui)f<94 z7W4&cDHTVeE9y3hh=6D7_^%dnmN1G7F_8aR#+hV%pk$~ZPZ953xKV`cwh|5uZKyLF z$$cRc936v&$7CSsVBo2nWz^~b-zSvk)4Okvr#s=ysN*fEP;Epk-_|_CI&##xG<})6 zKL8Rd?KisGq~={PvL9G)qAg2V42<0we?r8=5HPSiqO`S)pq*tBOKp5fjFm3}j>yry z;V*oA5mQ%!)l=y>r&vaKA1T{Hbe`j597TiUq8N#Cmlib~Ck7^-z(dGB) z1I10~;A5I64yskkB=hNGjrPQoI1y53^+okltlgtv_Y&#as7W?GRacScK7CjGMbKx2 zu=fE*R^B10TIFb^?!JEthGKneu5+%!a|U+_w@qZRY#*7R*}cwq&NXi}$stZL&rN%S z%e_lTW|)QpESf~cWWQ80#42c9+rxigNl!{dp69U|{H`VfWfD=mF* z{vS7knq9Sde!!HY{iKrQ?2oA+vl>uUdwF$xG52Lc?R_^5O~FDLbR#}r_{L`WT~gh6 zQfZp&TI(Zc=n%%4u8OWtyIHJmu`j>hr3z>)*Ug)Giz}ugQh63BQ6&5{-&eh=u1+k1 zZRlV86yEn)8CaP`(}=|1%rAXL{!t<-G7x5jF}p@3CyH^ac2|TDJmcj|uKohs4ooQs z-O>B`(XfoE2{RzBG>2ACS;0{Ptlj4BJa&-&e7Nr=0oBCh?u;$wr^zDq4F^vtIzax* z#vvG%cLE;!H%hdiBP-}{d9><%xK?FYC3O9+WThwpA{7G-L}tP(N;8Vrq0*sxCa88~ ziqDH926%H^mw0#XaUc+b-J+i|@wtfWKdF#l% zV4g7;?Q|5u7;v{BN`K{c!r#iwHn7E?I7=nJNGF>?V~Wp74O!RvyJm&ZbJl1D!3glN zZYJH)B2I69UF6q$j7k=6&a|~+d#5LTgx9}%+onl`_$XZpEBKm0JM^Tu^WxgH zdiblNU)S5*>be69=>O5|hbsPm+E&7_@?e&f51&u^tKML_n=_@tlR> z7J>jP(=eY(AUu(jsz~nZ3lr+T7hNN*5x#>3sX8g!x?d7Dbv;|;p$^?tdSEAHdW>Wx z=INb6ee{^{26iz+FjPefrgwvh3YYzQ^)B7P+6D9tV93t}Cn|NzgIA7cz*A!%c8dtp zxz{HUv(dG?bCiQfphI$)W|o~}a6S-FLptjuSdfD42RPzf8IIT=&QZL zsdqy|14AaaE4h=lerY|_Z=r?icq199F^ewv+SS!_=gySe>>RA!zcGhLlxY&18jVxB za$Nx&id-PNm1TEE8z>8TX(U+Z=@A$P)rJkD$Y*mw6UHgl9=%_BawIUX?k;{&f}h8G z-zs~YcxFp%vCoO6T|}6Zzu#PA_Ar^1+xdA{AAV4Az6rAg88hphoZb}+eB+(0UY$F6 z73g3J)k@?QAk;xQsi-`Fz}v|uwOOVV=&DB2)mqzCkokuwE8ead?bKrUW(SFao8*y! zc>iQYM?GIQ9m;r9)U@rpYH`X}3GWuo%m7DU=~r5IlEi9iCH5+EEt?__MGYiMR{X!(ywi2e@{`Y)0F9}wzMuh!liOvK*g z=Sk}!&Dy=2&`r>JMkoz}`+JVHF`+DB(IZ;$+tW0pKuBU+3$#kLfPG-Eie3_2adB zEH_^5`)Q?gbtBol6ZrTopWd|hyo*0I<`l`+Al?Wek0J4~l=p=!iUCV zJ10agpt(#0TVA6X-!7kT#pmm$Z@#0S1k+*jKEdV`CVR zvz?L3Z@Ju*%izhYgspJVS8v_INQ4E$eoOsWiJd?$%m{=V--dQ);>NYh=l3T`^4m!K z>zc+?+w0YkDLURN+R7zkd)K#v_xq{$`)6Lqv`9iYo36Y1?0|Ef1+@fYmRbNGIz8NN zu=1yl5vh>)@<*B zLI=L&JhOJ)(vGNpq~h@d$Cqv(n%hyaCJL~t0z;)540?cX8})75k3aiz5z?Mo9m~fN z0U(BDe$2bNiNHyx+M>AtYfB~^MrS0j4CtaC#TiB(TBVgl2>({fnm6#!oP@nzpp;E7 zH8%Tx-schJBXPwH8n4iu6_Nd2`)50H+D*GoV~r{EJlMG=4&7kmI?)HUwoId99nEo%K_ZS8c zB-}w&(y##fR=zkkJgbN@b&4g>+HZCCFL0qu9l?Hru#=StI}a2Mnk%>G26$N3fh)$< zzb0+Yp4x3J`*H!wM5;2Jy<3lSXyZ*#_?$i(e1B_2tvXky5Rrfos`;Es`(&<%%yE>0 zc<}o*aWTCMAOl4+z#bZ}#-JBIH z#UK)nNz>pJ*RMHDax|0J?2+chCH|QLB(qNN2_D&uIl!AkKa3mL9r*|na9!<*EEV`h zI#E)B7=2w$(BtZ_Ug62TEu_B{aZiTwiO~e2-8@2R*C=)6QDDUGCZ2{0akM?##JS-L z&%POV5KRoJFyq(eEG10E=P*8dxi4=I_OdN8pWZgSH|5YcBoRQps%K{*+53}f@G_I; zP~gCfqc$f!D%Hd8Gho0a!Tp1;mo@sQDb$@_c*9Y)ewR>d*IkU1B(*mkm5*>R`x%}x zBElX9;DS*rc^j|A3&vY7Vd(&?>Q^+IF*K2vXXLj*ay0nt7Sqf_kru={M*1>iCzV{4 zzi7$*DW^y5fdNpAD^y(^9#rL8zXqOqb@?ac*T$=DTSyOKD_zO5e>KouDEcx*2f{pC zoG9^^?*T4=k`i_ZUFLmAt4@@fm6P82sAy0Gd`r3*pZ>+s*c9sb$wj?Trs-|r<$VE# z=dF`u2O6S8WDie7Q!fmLLdn5S|G8frx)FCOjL`|Ao(%?RCrSa0j+GQx0KfC`Bc~wY z+u>74v8n}j`6K|q&_BeuKpIoJrCg^=^eMs9XG$TZSurWKL;O95b&mwRODh2^Y^`^&wHYQ2OR$_@aQV>BfwTH8EB&jnNQ(t~Ui zKbG{HdGo-dN(9)=6Z3?Jbgs_0oXJay8QD(@?fqpT8};nB;Zb=TCGk^B7ddnwf0!O# ztl6u|TDf$zybOy3MvDjNsigh*NmueGS`btcK7w_$IS?kt5Cw5|8>JRZ{GI`O18m`1 z{dh^fa&J%Y5}q*C2LewGTe5c*5gm<6&m!B%V!7$fZ{Cb3N64NpV#JwFo`8~p!`KK= z<_Wk|nTF0mUuN~(&|7IAc2r=t=!$`4^2qBoP3bs7CO{)YIz81yjo1o$M1q^8 zQ5ND&x&HJJfl%T;MB23>UVUZAe=qqhHtrP`5mphLPHZ9X00}p?wL8W$zJR20oi2~i zSE#JT=_Ls5cM+G0UqG=8?I~prLD%w$Y@8o@nGdE!Q0dNlTwG2oV_EgxSuwM6AP-{< z8WLn;WRsf;gdHMFHiuPzrlKsKduX;^SuM-vAx2>y0JmvMH0G8M8n}u5b9AdP`oT3u zzvVCh9(dh+Z@cpl^B+aK@CyhTNn}o7lqDzZjZr3pVyt$Y)C@rif@@X^7~nX(A@^Py zG9@xhd#Y3}t2)S(4rrroV%5M00&T|?v{DUvJB_^!ybY#1{WH4XQoIWS9!BqC_hO2< zfA`O{^?+n?HX!$*9#D$n>z`t@R`UCapa{(7K8CT5n(Kmg@7Aat1i#ZR#FCH)Ls%Hl zAwufKN4#GXA++OpxM(uFPPw-|zn%U*_C;32#Yc;FdPin6WWSk`>+D4S%}&t&T4rM^ z*)p`;Dz3eT42s3%u&9k>$B3OtV>69SE$v7fXW44b1nC{s1kr@YhK+guyDcpz;=*x4 zt#KB!%T^B|1#k9=rs;&jo5P@36*YD0ZdH40PE8L0Qa9S$ofAKw&e%`I?I^uFW&bM* zJ0k+BgZmyTn5efbKKc7f-}jJm)i>k{kwkH{AI+!G!JYLPHxzlb(Wh7wce(FITg6Mz z2f7{Xv3MM4)eDM9xp(hxxYG5vn zz-3eewo8a1plB*ObN7MjwVUh(;~cf@d`RbpkEiz5e!)vCi&%{8514F>3xEM;r~z z56Bd0Sk*RWs@5%p2v2xhgXG8AkCoX{2kjNzWBXFcS26KN%{*b zL&)&^kSMcMV_{KCrIUBm3%cf9d)vcZQV2&?H4B}bL%@4_l6Q?c_k0QcuDNkx>`&@5 z`GaIo_Em?FIW4i{4s?#iV@0n@iVizH+;GaOD~u!oO8*BL=!mMj&c*DYGuc*ZXZ3(q z#P5~K`Q*1u*VNRN0Vr<6179>@U1`bmsu1h&xIdvo+b>K#z3jGyP#W98CNzHjvQ(Zk zO-FpcomfXB0TWJzofEBRI10f!-wR7+c1qzUfto3ebqGA1rE<^vWw7%v^RB-bO(1fw zEl_jonK-r7ragX3*?`yTxo!TKif{?^d!|QJL@DutEXI)2RKxdB#s3 zFB_emfLEfm_RiWRBZF|jGhFA)AHc}LU9xpVz#3^QO{y?qlYYa!uCVdi(J-y@(6v5a z#W=mrQ59|b?GZ~SJ&mfx z?oli=W(!iaYLcixg-DoR8)or-X-g&BIDv#Ag=O6(4VfB;p6wKqW1c$L4A^KI)oK|X zEau~f6)NkDf7mLls>HT#FoQNFn|zq>nHZBJCxdj0$K5D9bR)qq@q8*=GSmZdjXx|6 zyMUUj5+8Mx+ULXL5&9!0W<(hp_xnrC+(cuQ@6T;8AY z&q8HSP8uI>`p@^{M@ERj@e??c?BowzZW&GR`MExK7K_8yN+XE$o`$O*8;z$Pv|tQH z_6bp%jhQ@rDw^m2?P?Y*tvtAi!Wz!Z;@M9g7AR=Uj+YAEtoFCP!O1s~Oo|z0hm4VT zk2FrO`3ebd=ke3enC^sg}~Vm2&y$Y0wZ8W%ACM z-i8g^ssZr&=DiuUnjrn;23P^Grwha665S==8mc|1D+o+*7jjARY!yhph=Y+7@5Sg- ziP2yX7rzKbAyd&uGt5C#D;2OHZV8AHJot9ZDBL)3DD^4XZxS4Za5Bjd~5Is~s za-6b_oN*n+>MxQ+)+A`G?SLL8s5sY=-lVD!L}kT%=SAy=;|r&rdf*G>P-K=LaieFE z?F6TAw_5jRL}oJ@(X8QGKPvgfiDX3WmfaU%8q>7|%N%tpCC^iIO!IW*Dhm~XiKzJH zkt;dQ+-YJ)y=&Opz-)ovd8tZOSh0z@d34g5cd@*GxP37jPiP8**X;BynZ@nAN#_jw z>zB*>CUaZrbh7y|p`z}ICS(0Ci5zrGel=n#JTFU`)1w%thDC}?Jwquy_$eK8w& z`WibHk88u;ktSg)?gvPGW#Tu!?BL++(}ki}l@p*nTiq*sNP^ppl681TAEh8M$Rv?e1gsB;lroF=wZC0#>RIu`JLK_Gx_Gvo$F^(9Dc zRH&rjG}1~JIy-2$K9yOZH{cLxde13m;i|znS0dR}F8SM%Ch!U8PwkoNdbSH!2x`b5&PF<5><-rs%ai z|9=S|adO1eeu_?g|=LI18!~nZ094qa)Vhzj44&dlup4y{4uc2MRqd>_ucHU%O)=ea> zu|KpK?D~f=$H1@)mgatuA#v8^Y>N{Fo`Q5v9~nmQ_z4_`N@> zmY_zP*17!F4cGY&VcPwqS;!$+BbA6Oz0eBhY^=&;ft8zil2Z;k=FBY&9VpAwG|e}ap{Ju z;b?lFNqP+*9FgKqnEk;oh&iElK6+ZiHt*f0>OH0@!+11azT!BA=>;#}UryTiV0ko{x$;B1XxH$NXyz@w0#KU?}Y}h|Okuh!fNO*E8 zklg4{X4UC+vk`a`YtwUm#ep~-fj;@Zp7fww-mjW5!v*x_o@aqN9*X{NG z=Oyz;-3O|g8)R&{V!N-ME1=GtTr^LRG7sOC)C>vcoNb_S?Z*Kmiu=0wn0TrCYM{1U#HGVZ- z5IX6QGxK<6U%j>r&KfY-PAeR!&h+WbY-;-fc$TF=Mi^BVtQg%VgA7kFk6~Cm7-@gy&rOTkG-zf zmv`=D3dJv)0<)DC-c&f)1=rL8zBF0?g&c7WGXzHL<>do(X%V@18wYRa85kos{#I5J zb_;lB@@js53y?csV<0hgAr4O4^vnaK9`o7(Et&u)0d*O8yhxf)!ld3{KRwbXi2+|QmS>xoC?1;ZWzi5uXiSlV`+e4cEq9MhlaibSH;EDFk_@$Z ze2#c1_6OyMJEr114v(@nBNWQIZkOPQzNIsrlTlo6A)5>)%leM*BN)g=b%hS$<9g2b z(E?gh$2}v&HF+!fyY;l-3itbk?)LJ&UOiDlDbXIx6*3R|^8)1QI^=F|{zlgWZKw{-mCIs>1Wj)bzI!+@n#>bt9*q$J33O9AvykLSToetv~!|rtB+N}BlW|-dh1B; zBFx@1XJg4l5v>l^MLCmuy{CkeB7t| z;f7Hee0yw8fP4NNhL8_*@dI6Nd|B`)k32_W{?de#MT`D!cjB*h>p*pTf42ztpNEZ& z5PYw$du&9);5lf;E#o|q_Wo}_KQGqEwR!22e+IW#BWq>&GmfuM19S|)P%_NE&K}q! zdmjU~EbsXLv)YQ(B{^aHE%BdW{@<3X{x3&hV(Q>zYHa9YX>a#ia^XmSo!lwc0Y*11G9w)hfD^yg!S^l5EffRQ+YR;l~tcGH>v zx7@F_H2*6meXqSId1XcG-gqC^&8Ve{?UP(R3}r8|7w3Y|I@n0uz!Y1iw5*0UNUhvK zBWcLsDHg9SX%L@8j%;E*3-`#AC;231M+4qw=5%zDhmTyctM=C@MPkd? zJ$+fO=A33{vXX_ZO7u?iwrfpKD}2MX)Y{N{jAM@W#Pb7B076{UnD%;;HtzDEbU{tX zJXU?(v>nO$pO)vx-PhRX@zd2b{@alL%ZvL<9e}T|(Hj+^Pta0D=*4+^zB}uf@F|I; z-e#|Vdrya7x3_y<-`9g`Tv@ui|6r1>m20COZ3Sj8CcMD|L7=~I^@2Tv2;_8i=542 zP=Kgi%*gbzlyD4pwP1E5lcVVb-htBV+8~H?xAb2{Q=b4-_Vww-SNY!QyyUuBvbx)o zGR3j7k>P$G9!Xf2za3_%Moic=IWaRn{g7Ftta3>N>XSl*&T+%Flli`uXZ5NhX>d~3 z>rs^;ydL3GSWlfFeW>q-Npm4 zM7PM7KlaBb2ozQFsx!f{-7UG|E=_4Wa&t|bf&yk)2|KT72tZ)gaQ?wrWCo$HZqY{%Y&Wnt7AEfLG&g?x+9AW@H>e z_`32Zoy_KWWLgBy>RKp-qBZBh3DXJ6nzHVbSZ_Ure4Z|{BIH9`aowQns+=a6>0O267tK3Le~(kbxKG19 z1!QYmCOnbbEwwtCc<)TAvZjQB7vTIJXsj!Z`09I!eN+!}#_uHR?4BSkkqY`7z5Yh_ zHVSuqSg;sav-_unYLoU}dt^~?+v)l|Rs5^*p5u5w&;B|%6 z_Jrfp+f79lIsnm};`OW^Do2ICPN3{HTD4DtIJ&11#;5YId+P73oldbjZu#)Gtk*7^0(PQgXB^NW!EdyTRw2a5u*7cRip3W(Yg2D zqy!ui#`W=9dGs@YF`{%2TRhR0+1F-~TzUlYeFc z9;!?A`AMG$!{$DX1aO124j`1@na-_>*y7R3KVI^T-wk-@-PJBNBgCpoDs4`(7KHc$uh9t zn4l`L9ZI4;q{$1AlbG)VbYe zbW!}gI`Zk{S{9z3kC@ZGDAD_8lmG8AhLFp948C7-RqQwOlKvNt%f!;z<^SYgeM2X6 z=ikH|s-kGUApqm|Qim`zgyhf@9y-c6sr#c6o3~7UkkO?1L9rO?P1! zMxEmflozUrBAV%=t$kn!^#I2Z=NSB!Nlf!(hDH9X6pkEmAldk&?iMSKyY8Xp>f5UF z?IKX1kpok%fGY8AB2$x2{#C2?X(J>2suMFS$;~%&6e49pi|@*UcQ)6Xz!xKwJg2T9 zU^t(R4g+UdgW1bkJKAB6#o(kf9tTl-^fxOV*y-{7DZ9-wg%@s%!EW(O5*wa258zRs z7rcilO~C?1BS`tskv_686+hf|A^sl#RyZQmFd8z4_e!j)Jab0pI7ghlFq4DHjVob` zWR_WMm@iPsW&)&h1)58R0TM5dU zK)yH9dnp{(=i9~(lr$h%r|?H_ZGFc2mb8ZEf-}OUe`o1e(V`hwx-X;W@IINi`(c|y zhA#-e!aHtf4*0#5B{mwbR(&DBK&vt&kBSyY1Z1cjw6sqWSvm!x1{As`gmV|udt0}M ztrN%wOhrDLP(Cllq`cB@sZy-DZ~R%{80C$-=@K5i^l6DKHhDVMSdN+{nbOf8)8v}h zg87a9)BpACPcmw_+5H9}#cu%qx7L8Eow2=%rJebIMrc$N?XwvWenXGr*JV8|pDnSH zO6hryW~;Qs@?Q%)s_1zCyap@AnwjSJ*G$5kn^f@|=&f(>&2`r-%&uXu0tMxgnhJeF zMdR?_ptW+b;{+lLnkD17qx1LTrJKDtBcDwdkoh72D9t_CH$= zmI;iC%Tn4>xyEL2zpzbbe^2_w-pm|>x|yl~%{2o7+v+bWo0?%T!SXwc4Jq8}MzV=OEIy!lxqzh4atP&5bHlOh1GKb_lJQmD6k#0u0(K1ZP-+vbv z#sPuJFl99=id8Bp*ECsjbsT0k4Ou(Bq^ZdtppfEW1lUVLg?U!-91_O-|sPT3(h{QL5^&)(;7srhh5n2e_HT=q;>cK^N9O0iLyy!3jpFgDM;D zfAzGg-Q9{RAyF4KqsNt1;k@D8MgJss`fU;!cftu9ceI*OUyha`4`BDx#<~<$qG3qx zTOm5OtDh$DtVTDBSQA)}Skx8Gg>h{u@fQ*qwmYg;qhH(|71u3VyA{7<5^RoSrG5J2!a97Bi2Bsc@S1^fU@d=GE$)sT#ci#tx zHi_f(fnhg5U3+5C=z2WkiyRt)RtcCjb7fLZFEbt3oOH>ULTlMFmoN}(CVnTRRGMXI z1uz-{-^KDN5%&-YT&i(M>s7-)r>=eq*U6XQc{~GwG9tJ_K!OK($KcPvOHjbLYBi1| zx@?a2tE6~~8Z}cAtc+CNyt6t*@&`+v&w-fXL3<1Xt8!t1VY%x2^U9B z;tf}Arbk_-7{QuWvrbw?M@L6XOU(^W0#?~Uxp1XB;6(-Qm5XtjqE^0~EF;_=mGJY8 zJ6h9bkGv{WE=j%`BC6=x99`op-!ygT=kHZ1$UN7&aeN)@pmt+@$R}^fiZu>zlu30r z-LJs^GgKd39?$N<0RX~L000R8%d>7~X=Cc_>Fi=^`=7k3VQY`gj`Z8U8gN#y2vufl zbgu9QbCI~1HBpy9N$pLoBZMho zmC0KZTmp{w^?Wpxe)zc3wD>ZyG!`BG5UqbqbF?f=#7rQ01|4?x(#q6{G-}&Lo;i+L!qZqd1)lV1EsQz6I_dAK z7b8OD!H_94E~ORmNH;8DpTdBs%ZA1+y^LvZQ{uYT%{fc?m8qsY2IWVOVUFEvDhD2o zhe$LldQPH8^eJ-!h_xz1Rh^R@VO4EA+)T5!vJRBEylgFm(inldo6?pl39P+tV_X-c zk}tJic}TZnHk~HzR-btOG!M8qO5C-Z#%)d%n+g{I42Ta0RseKsRkRvgAvz9?hUPmx zx^SNgI}dR~O?+KaORL=oT{BFg0=R?=+0aMJ9qEVIzP3(165Kokcd%i8`ELwnVH+i= znQ`F`)uyhMrY08gZv)o%2=RzP?;6g1ECtPIY4F>HRB=*zMC4zoAPS?=nB@Vo)Lu4B zx&&T&A`JnZjxA%D7J^*^LWP%NyR*DCu0*Y_nKR`sniA3!~ zS+@H>8d^NXg-)0E?^77I&)PQkA93kwmk=!UAF7D$i3tJAwOeAaj3<@=`|Aoo;d6JCRoY+qsTM+TnwsX(G!do?dS! zPdTfpJ&PL$4+qDGsmIDp`J5I|hU(NYYAk5j>IWzkzjT)4&fh z(Jwre#(^@|B9Kl&%W$k?DzDe0wbZuygO;J#z}8kr@=T$Jk57;0c(G&x&Pt5_VJipL z9)V?$|Dg9CE!cy2?=19rlXH!KpmH@*-YmK5x=()9=#Ow@?BfTWO}`pX1(KqL0%Qa- z+bUDmJJp0y$BJaFg-O-KQ2mmzuTpM-Yz=cC)1T7}v|ReTz&w zN~-E7F>VYX0`Bi;{zJ0j37i4^j60cawqC)$dNuTxek`wyE0VQ;arpWEe*ehJ<*T!h zY(UgXr+Fb`Ffg$p-W;iRxTc<4SVLx~`^L-H<-|Sc?{8)IGf(u4KE*8>S->SOeAFwa zaGvTfV=~Qe2nClI0J4WH(M!?B7cHc@8A5rouDP2JvnI37J?bppgEg{a1HHGK(P^Ly zCtB9%_@tn`EzDjBm`TAXnAW>A^-;D!^U_+T2O@5ZHpXlP z|K@<945O$f(p-3^ESNj9mcQ->oM+Y1as^gMc{U#igaesC1(4Y~(?R+Mrt%uj6IrY0g6bXyh zgR7kt5^`AW*||85U*s&$yn~H>IUaJ!bDsI=U2E<+($b4QuW=$-l-yg!k}cpd+7;7X z=r1rZ?3bU}{D&NH(}$FVJ097AXB3vOFNvevWBsc(#SV@b?^Fe?dsKo^*(Fz-csQ#a z8I>qDcNacnxmr!c(*ZBQfN~zHI>Og{Rr9ItiR7QQ_<_f)dbmw3W(a;QM>bbs>Iv<6x6rPGfnWmEpk^`e0Aac80( zzF!}1m$P*XXLgB)$TA6e#^NG&aekJx_X_?eo!$?$TUcoE@MvTE!mG82W0u!LcQmm< zt$f=xpo;#vX33}nOm|L zxr6jlv@F$JRy*zNUn_^kkM;_L=?VCYtcOUI14;*nF-jkYGD+3kLoh8iM+-R|fi6z> z>Ih&^bPxR?OfSIygj+@aS-&(E0Kncacm4mb3jTk&YjYb*Bjewbt5LW8Wvvl@mp~j9 zz%+nt-btw!%*F#)r#lUDwMlFP3o$^X3T=o|%9B)>eAn!E?nL7@%XPtN@R1_9_`13I zX19(&wy!W#lpx;vFK`bVD>ZBdZcM46#xW?=CcM=EMnp9kEl9?0y1|Uueo|Y}4x~+tu@Yf$dl{oTz`tWaoyOv z2`O`@Q1+9S9SS1Pur8eIzYY#I;?Iuk)zkaR*l*f4F0QOWXvEWI$piS|o-p=g9lXJA z*2VI7l7mv~k$EN;y-QjAWNbs8=;V0DBSj5P5Xc#R-s*plvA)iF#o1wmYg@nr0f6vK zz?25mmSN_mwXiH&Tt_pL#;?@vKFXmj=`N7)?<_(v+v;b|INrnv;wg48=d?$tE4i|n z253~vSphlW@P(4HLY#$k$b(6DvH03H8S)bxfk~G#g5v|a*KHtlvMaz2lR*ZW z!3J(JPQA)XN~}r`ajR^(sA{hUK-OYUJs?7$OK zpDJnOqnk*zYnIJ9bxqByM#9XazbO`6$g`K$n%>NwKL6!}rwH692h*dYBNPb9uOz;h z_rpmOwwbBCygFv=b98pg>f7&>WnZMHpM_UtZ(Oi%P(T7?EcHvIt3>c%4&*?B&pB}xwyjKO zL54AG5lT}Cx~V-Lf^ffN6Z(SikDV3CqEFgI`T zX=g|hw3_lIbUAI8ry0Aar>D4rUHPF92Xt}cmy3WfA)C}SN=;$@68QQ6uyC1GN{1sy z(2BbT0@T?yUU6rW7yTPtHsts+NOL&v?8|OBwYI6Fvo<+G@^PtaL8pwjSjcR}lP)`p z`S>}xrI#0KSEsD|RPm7aaE|=kc*frCd0Y#F$(OCVsggmv%!+dGvkvwo3ydD43_Wpw06HU8hnEJ@{S-PC!fo$7*yJ1&Uag8^0KlC%`=Hh-E#FZPU_JO5Ft=8nS*FOJ)w2w z%#|Qi{z^EPeX1)T=KwB%{|`WKQ}qPqlygRy&>Z$pNVhQInEYmRvdKBZeg(HbS1_fK zOtSH+^8KZMfUlvULkbcXAAA=s@?L%n^kH% zc-ztv@J6Hc<6txE^DSoU+aDu%a2ymWF>CFj(*l`#URy=Ze+t>V^h`Ij`1RFS8q=2| z0S~t3;L;v)Y9?1vcthMrGNF5;#BdS`PKd81(Y|Pra zxJ)#U@6+j6VAGa*nTR z5L}e4G=*W*z|-{gqd+-_6rWA;+S9vnE= z9U5D22-i#To|!tL7`8kp29xT&=;=$y@iEtIgp5`&6fep|i#R zdFFclf5}>~n1Ti{Dxl?p!Q-@^W*W=5O1s!HoCv~1tJHQTr94pur|#5$XDczOL_|yx zCL>@N$+bKEB$qo^O$?o8Qmv&bcASYU`nN)U9kf#APJBC=r>M4X-=gTih*fK^OH$3+ zigc=wwL0=`(&RGSt*eLJvK!&s+;UWf-q@m%)}ZT<8u6v0B6qdKrk#%%aD@chkgY_va^9*EeIjv}q+^+RDIFs5f!B7YrX=ug>He={dal_D5aQsVT2lc2!0nQbH`V zp7M1dhpm~A@01(pqf35P5^OVYL()3zIb@i%5wlPNNl5b!Rny08GfcK<9@(u25kRjt z8mJpV`k3^e7ITjgoE{q1c6&;Wy+;RHJqhiGtqA3H2qB zi$@r%YD4!yCmXoz(qP9_68Az>XU}J+ZB6m^b)_rlYe#Dz($7h;S7H3#cS9LCf9`}d zTuLKBbAXlXprG5NZu-wga%J*zlU}k`$2>Yr9ykePxKEttT=lSl2g-ec?$-;Og51uL zY#hc?c9#hSI@F}J6r8O>LYwcC(t3=~PQRX(HrA}~U-o%Dd=}gPBs|RefAVeiyk4)p zqV12PwxvPP+Z3bwM{bVrsgskFo74i~0bS!ya$lT(w9``+ZzISV=-VJF(t zcIq+o9wVKHrPxaMP|L4q(Q7If41j&njX-gQ(3DIzjzhIb1>L7J3lQ)noIo<^%4mcP z_cqLUI2~+V*-pv%o3$69+CLt!R+dxt=_}gx4NK)3Yq>!s6FT&KjEki4c zY1?|(4)am~@^NxoAOcG^g+bG=ozQD=0J0iTcS?;QF7uG}sfYm|+U*b>*qU_IN{gSu z016ERA6#Jzlg`-aib$m>II zqy-1G&vtJeHuNiqSY|0HK-Z|E>+f{cF9(|S{#!xvQYFWautQd2Ck9LorjAF{fJS#U z>gc!<5WJiLsuNa+cX@&rHe{iFHfwMngiC(JL1m_jFD>sz+ySV+{bT>fWArX`uoun7 zDBN0ww&UQe+_!rlX?%%yCn11zAugAzP&Z{6t31$!_t9oo1{%s}8K+YbzFY3qgR|*| zp5?E-mTsE?`QvOeN*D0GqkR#7r{*K#*%`cn8|>|Z?dNJlK|g-Z`uwY~WX^aVnT7da z?mDCQU#>83MdVS82JkNX%D@sq5*7F`j$IU~Qddw;Bt%PZgUTVUxw+F~N^=QP6C^d| z-NrH|mw<4S>s_7z#HGPtGtqueYw-1ORryEoTo@J;t|9DP{im7?@t8|yic@|yC+Z3; z{#&>4c(cE6qg)5Yw<;5~DQLLCKOHeyU@>>FZgDd<7>XR?2Vn&!$or!k1?_>~>-=`X$vZToj5E*{wepb%+eoK}`r$~JAwTg9Tz^)?<%{cBZYX8J7`QIGh=XRQ z6;8xl;l1QmD1E+U@m!0pM^V~}6kp*WkduDSWF^*ZIOoBvSNqIcLV@wa6 zKs3azfJix4zq``Jc2O>jGq|t>_Oi#{BU#;9)%~O~ytutBwhO(0(A@boKc}{QF8eLY z-5+gt9r6W9cXK5Bm;!J^Zww`S3K_NP)b=QHXMLZKox_-)I@3qUFL8}3t%uY;;mYXd z*%Tb?U>Cav3UZo|Pl4rL#e9<*`4h+Udy6DdQa2U@(&jkmQ;qyyU-X@(tO6n+Z9czg z)wz4y@R}ayUac}(3-z*)iA4UiMuZqXI^P5v01XYK{}jj;>i^2x+!fw2v zW_nfys5mxi1fZ*h;Xt{(%bWCIM+(hr8V?nn7P`MIRwg+6>fdfuAGEOn%mXsa_5f= zEy+DOHBhzXd41Z$M5wti(z_$%qI<-gjAn>&e^BHC24=KhH+K>C?6$WMJiYV}fO=h4 zc|Z*&A9$9T(l3~m>l;5?DccqJ?eHqQ8q1?^^zGT<9h_m`9=K+mzc+piY$je9G6a{s zUDlIvCbXJ9NU(2+GPgP+`@-Kl3m#R)sVS;B$G2bnh>6q5nd#oW9Oan(X8d_eUSa>| zorjvTq$>Ts>}O2>eObuH-rW5Eb`z(yyzMtQkbZXZf)o%$taM9cZyKy^(9*3Jb%8CF zNY*ZBgM_4|U8ZVitVAi}ZsuI41ZUG|(+<5^> zN4%z^vc^*_?qg^$Dps{N8)6hZD3)VVf`&NgC1RnoJ1aDJ)`%}`J8}|Zq@#-USVVhh zHJ^!$r9D66j+11`CZ(z+lTKMBgGr!Vg-Lt#8d~{lS;R@q@HgSHKZ|G;N9z>lT|FOa zGtsl)y%L#6$wxw$rx5U(nh|z^1N7U^{Xl`nnnNb!8CXpuaBDe6p=`oT`wQR}IK-L9HQ(|MR-Fk((WjKmZOv8$p z$n=_{25VAeoAs1yEWP+Xjj?3k-AAu)9d5fOGs1?it#vDysXbReO|; zd#0_p5Q2CWuf4!BiYjai9mXJ- zyaB~n$DD#w`jkjUxXvmH$e)tk8qLSrA>To<|GcyI6^MrtGQs8+#KR%}LwAlLqu$FG z1#5-CNok?-*fLp}K{{&LZU~YVr$A^KU&@L^>RQDrcM8?Zkm>6 zgCbn6Qo0F1!ic?)V&PEs@Zg{G$93xdap-fXg4AT7$->UG+7LPVT&?JMX~o~$^)V%~ zPXGI8Nu4W=j!|*$-yN_gf@Hf4OEhF-2E}9;L;{&qn{o`1V%PBa=idN+WXe;pX<*jl zi4m!{7B~8arQ|OanERTbX6%BUT>WOggcu(Kr|Jb-6^ZiR5v?#~Bfo-IBHUoD@Yf8j z%U|WndqX0E$1Y2z_&yo-a%DRf>vkmaE7&NS}+O_<}h1 zhR@i;Pu`+W7|q>7IQZ`EH^U0Qs|+%&6vrrB1z4s4#FC%fGv~efR=w=hrJI0c9?QO! z#ihWSrOLo~4$G}m&MvJHd`ct=huoxm_|fE<~hMK#$*52!x0Bb{I+ zrNW3|IrSFHW8ysyjz*JoMrej466y%o4>*T)OwXxMFd&7ZkbuCA5unT_gmW~h$F5}Y zP0I)a0dXWY)7F0g%#Sf?%DWUz#hZQnWCCPahfuLz*PPOl1Wl% z^yMa)p*({4XZh@JH{gbI698pnj1+e0R@JC-JhEcnwH|l5ga5$*@rdjfALr*})lOp0 z>Ho^G!Nwg~?ETAr0D2HufeUalow(6l@vJaG@Yqc#XQG&E1U8sJ!Ut!^?$`@4;Bi=rtzn=-M(YiKC~xyB#Mzc;n1q;iU=OD-%~R#6l2L!@}ey zU=aIOaDk{`+#;2e5}2eRNfA$FgW^|HUgHj7Kf*Fw+hzc)z{iS8b^ELRg~tUISfLULeM9~_hVe9> z&9erL)Qedt{gk~)Dur~Npjgf^Jc+v|*B@3o)}@qW_2+Kn`+daEt>@><=06`*1Xr~7 z^~;gV&(TE;PJ%DevK)`~gc9bHJTxL*fd6b5qoqoWAi@ug2jX_j)t8Q78FQnGZ%#=6PAUJz8$A%IQB;hsFvEOg`lu+o?fCADu>;L(wzMC_+=u*#aJz zX{FsaFf#d#v~ks*X-ywbFITUeKYwyC<6t0#cR+X8+oOKMP1P&yzVzJvbpftkE`R(au=;-PM1lfVZAvLj|wTq=w z^XidTCAn0u?I5~tcM=x_=e)bv)x<*ub>jvHz=~=>KJS7O_t)z%+1m9 zze4lG{&qfx2-@Y$l_3<0`N+cVlGA0?4Q;f2N#94i9r6SDG@@S&y0qpKw7D z+uF^qkf#scWw&L58>@)^Dwkl@L%-Il_%BLK_F)CRprn2s`3M z5F<7cB3Ljs7iPIc&^uFi3_^7Fju;mbqv<$Ct!VI$0Jc(=eiN8%9AP9ut3`{8B(iWe)V)nC8|PlHvuk?+yt1gl?2|2LvoLEGx2q-!eiyh;c`8e21(6>Phe z@IZc(@YK#7tcliv@HGKl8c~eBsYsr8$z6-F(o{Dvd*SK~<=*1ZP5CY>v=X;%3cF*l zPPA-r{i3B!5cs%Up+Za6IGiY^w7s4H^?6zqC~hV6&oN$2YalV`Afjm@e0(U}oSyQy z6VcLk;5q~{H1#T-axh!+-E&4Qd+nVa!QNBg;|LX3mz+YBSl6$i%dlM9a_?l3Oh)V)~GZ3 z(4Vez+=HgVob4rBBmnV;hOTa`%G5M6u@}Vu9~^vdB7z z7hukK+Z|%Z7aHF`;?av|_WEEQHQT~zVO%(F1sZwvuw+Z-tSA}TwF({Ol1dJkFqfMY zwcfl8H(9KNP&IyFQTKlcL6*k7)WBa|DV{s-MM4EfirqyB=!{fj+Rj%g;Sng1iLvbA zR-p;qdu@>QD|d(0sjwqL)VChJi=jySL60|+!8#3k6))l`*msnpay9+44U76(5b(|S zma#oz7@4GV4c7k$BkCaj5cVVj=ZP_N8*5syKD>+*%?6~9%p7#!NIuB$_;>OEmLa&U z?B{c@t3L%M2NdC4Kcn&jTI18d$~RYdJ*^&6tFZ+Qa~SEIfJwaL=`$p%>KLe`r?MSh6FfnAl|?- z-)_W2d#!I^TrvzCvzxmHizi+T@?$qvKT?vC&pap+ANVln&*V3N|N7^5p|u=#)pKE(VwXgEE(0Vp+<=fuE7pssYqjE= zRh9xEb0)&nUfpIL!m?1s;wL(@%|R9kVL^=v7Jrw5%>2&2VF>7!P$NhxLg}BuGhEVD zxG@J{pv~a610o%F4c)4nb4ULQ-(yAI`s38;`%G`RJx1KS*1ZH0$FN+7Ge5z3?0(HP zuM%VO&`3BdN38H|qi*~JBC~1EIY>F4G8KVi4Qp*Q5triaN1Y5 zeX@kXB(DuHr60nYbGl!2d}Ci+kBzs+?VG_|Eh5GkBOd=JR>piLB;%nbQr$S*tcD)dKxlBz~Cdj|if3Hn3;jJti z$KA?De3n^Qi?6;JCtN#)gfrGQb?Or{ry^f*U@<3}kci`HCN%u96URNMWq#3pOWv%Y z(gmyiCzUU|;0^THUH`=;*Eb#RrR_n##aA6_=(f$P?!Q4#R@G#SUH2#Z6aIfz<69lb z^p?L2%+YUGnfSjjFt&zHzkYrC|7RNQmv_lYnztHcK>1H&8Qgsy%?4j!RX~H?NYLwLxt?h)Gk{R&?B$Z??^|A){9R-nC(z zJ^RcV?gc?~o_kGgvp*Laq-`aLiKaj(w*Dgjm{kK*C+&}7v;j3p5!N(<*7?6!(!OF$ z!n!2SRB}bPe0)GFtkJm)Ut*CHjZr1SO;SO(QbtuS5_BLp2`Lnd90I#y2iLg@Fc!R} z70jz?GEB$o39DAB+C|>!<2R>Hh`T>!&EX}z4743$W~tXq-i?Ta*QLBF|4@3$Ih1?_ zbUpk&i)6__HamegmN)`eHF5;r0k}&R zRMqU3k6I)ccjMP7-RD-orgh1UN=4cH;kdjytD0uP=b30awb>p$Q_3;FsMVr1RR@Rm zQ0a^fe6n*hg2XUFlBiKubvahTUL~_FR_66%AkdGGK3c5T{{C{5C(%_m<#%R zty6Ak-8yT{&9g&mpnG~{;kjHYwWn^u%oeZQb;G3NYq>b~t6MeZ3um0-gu~TzPJi6J zCQ~O>)zOJOT2wQ8W$B8lqJ(P0iwE&q=e zv2Y3n^xf&<<3>@keY{*>PQ-^Ro4znPz%c*IMNNA;kv6I+ZKUBUb{Ff#)Go$LeKamm z44E(bKA>x!mB*Kz0OR7p(ri2#5N3)&`amh;-&9f+H5J>YGTqH(PKP-px|&oGq}zj# zUjI(-sV|mmhM;K;VjN?Nqpi_YqB zufroASS}IpamIuVljLu$DrHxc3`14{)u2*-zc(Jr~`KQVM_D151oko{;Dt|o~(Px4U? z#baWfWTP44EA;&st#MJOm1HnJQtyt4WazJegM&)~kzr5W$>_wM%PLEAWbPo6EkdEEivsQIw!*figbp5+@}mUJjSGO+gsldz43XGoy9TAm z_q)U-D7B}IV?mUxq+keqip&<02>wd~8NLHp=2>tu$N#Kp5_Y${& z<@YhM4DM5Gv0biD@_FUJ8<`p(FUz-QBLBWk))k|};zo;U@nP=4*?}F02|;6k=yk6+ zm2|-wTM_vuNI9k#9v=RP{)l8Sm_?0cL-m)mRZ$=wN(D-XSmjEkdw=3$PgHrZP%3r+ zsHWdiKw%oInbgcl&Tvoi*TOTVtj`uh9PgGuZ$E&cw(^ii+b&S7R8xizcPOU}l!M>B zeiT(ZHhUm~6DPkP7Q+$H>^dE;x36AY31@G&VdNNxC;FXF+2Bv}>LYjSh))h0^{sXx zO&VhXe;n|Fd5A!K)js!~ht=45H>&=O$fE`h>@!YuI1yK7JR$T4j>mS4LIyowiLtBhph>N ztIhRVd$!8_UxdIsyt1eB>+?ge%OaVpfu=Yy$cz%0OI01)`G5G+;si9zz8MAI9$+&w-tU)&{|{Z~z#K}{ zrrX%I?VQ-QZ96BnZQHiZ6Wg|J+fHs~?yb5tQ}z9Z?%uoiexGM8!T4x!1ephj(RKiH(+R9(96ceYoJ}33=lRD zC4b{5)=$@ZE6pI$AW)D=38Lua9p3^K?pB!nhSfLQW$Rel)rb0>n?0 zX^Y$6p`47SOK5DVouSPICnMqHS|O^49$RH2(O?2vxUZSIo+Y(4^Ikls*a;-Au+l=? z18xL(q<_qxep-i_y?wg#hLtV0y*sw-6PFaO*ePoc58%BRV1bO0C$JIk)wB|;EgqB`9L-M*rXKldQPlsr%Ru*A{7d4?i-&{y*u5i;Qz-QW zOCt`%2@;^X0hAaJ=g-(wQu#PN9H^?HVVRZM1%Gn>O3LJ5G)iZ~KWrxiKjPM1(1{+{ zCR_mG+^}d7lBTWjh2<;KU|`gtENuv|OadNxLF|9sj_|bo0A-qk2eNAU#rJq1<^o-P zvXbiCgL_kil%tv!uOVOhExi@nNmK2>6G({d>UW@HwVKjoDJ?`Z{VlOiTK%2y(tRG_ ztm4G}m>9Z<>;fkwG)40412Ja7Z5d`x4}0)WV%UZ8clKaaH^tlt=mcS9v0-z2k$k+I zsA-NGCZKLNrxFJ0d@~Jm`Rd2~k$e_kGX-4m*N-<{JE@kIuAX zh64%8%0U5@Wi~q37WA|Xok-3_^MwMK0&4i7ci&T8`XyBl@RkeRKxA$wP{GV~XYL-? zPnt*mraBvnAz^S}`}g>AVL6E=$5eB(_Kd0`#N~$|)k?Gy!pZtyuwXnRMd8vTj}X3K zX3$?SL>6pyK}bVE0mN|S@5BNmn((q-((1dEuDbz$QRvYR%sgKDWE))KvWu}}6NFe_ zD^&LSy)2sBLLhSX9TphkREPmcFVL#A6yb*BIS?mHs?`nNZAW7j<&7y9><3W^dE~2o z0F@F)c2t20folJLQPaAlC}6rIa=AJ=**$}&79cTXC7{H%9t1*oD8t6|A^WP|%m#vA z5~pKi4^3G+hK6a)n9?2o9M1taD=1)v*mA721I8$}s&TjjSAW{Vcx;W$uIXkH8&hky zwcqzhMpkBI>=2HpMd_vpUN8!KYWXo3obPRUnZph!;d3~WGe`>}@18}~2lmpd^tmZwR@B2~ajswPr=AosKp=d` zwb0`mJr-4%;SkU0SHBcbvx@PVre3PBOwt>pFkGB8RO1GnLdOvqV+YJ@2owbz6=eS? zN4@ukg%dGG^DFG;%Dz~LMhEJCEIU+VgQb;zJ}zg&b@G07yHs}FjHl-bu%cQ zcUPhJ0GBGKP5%HGdW^6y`*u)xXrUsy8|!?gxTmuMh7hP;c6igt%E`(O3cW8xGK=aB zmP*~V;D=pp?xkrClfMV1_BsK$22KoGsr8iIV6nMp~6{nz%%WqADeViUel2(OaZ--_!?1xyLkRK_$xvZ)KxE~6G^RUk zH3F?e#}NTw@w;v#{)JJtQy!G!1;?Bioj-On7!kN)!yI22x4Y|%X*ZFE zoeYyudJCLZ*E;sMbFCPSklXAh!GB<4g7_s#J^Yhmp@l{K>A;DF1|k@ur(Vj0|y})G`iK z%+mL>+DO}g3~Gm&fxGPYniT4n_Z1Ay{sj_yk(siTF))}Uu>e8Wro|PXR)i-cAj^AB zx!NRSeyg5oW!a-_x^}!J^S%>j%X?$qVD}1aNU(^~UuX@f$?N{f_CkwVHXIJ2(lP*7 zs*y>|Ye>fN)>N2AYSll|zQK@N2H*5Xd@rAZr$jBzlEieBqq_QJ#ra714GEX1b#_VE z?y*_~1%t}eWW7+nK#1tgQ!)~URLY(Q+yM?_@>bxpV{WLC2dYaW%v%gc-!O&%kJ zt(+)}aR6s9h3ZLZO{~`)*{XjE8U>9acuO;GL$Kq8Nge}scbOC97zC;N8vh+(&`xFr zN;hL?hY^8NIJaX$8Dmk#Ggb>_UmC}WZV z_u-!1Ax?E(;hf3#T_;y;>5vI#4R11gt+t%|9Iu;Uw8okF*osOGC7VH!akqfYGKycb z2AGm3lYT^$g{j5-vZrq(5+H|^BKY~62yK##npHf4ctE%aPQOiz*zDKHR-L#0@MCE+ zoY1fqQ~n-s|00pIC4Au99~5ZrOjeDg-c%m3ug9S$eSBsxxjEpTPnfq!k=HH|lIR=& zp0m)ZNqXuF4{E(=EvOXn3;Inzq8p+Ji4j}1M*(5U)}Q9bui;%o9}oT;32l2kPFk}H zm7mEEI5QZ(ij*|C%UWsTLt1BPTB%lBB_zkR7cDj+(uCe^JybT!?9xQa^5(>}&XA*E zo@K4yGF{)Ea@)mwDyfPyLL$F7n3{S)cqb_WC(~*&Q#S3#qC7qEeuOUepjQ?VBg{PC zLA9G3w_xIEoW(%cjH@1lIbyrL%z~x@(!Jhr(R0@4`v$rOVN~)|QCx^y1(+^-sknwe zEG~wz0ZCK)5804fvz6pzM$ky=JChuJ`;RA3Z{iZSR?-ke%h+pci21$}B?@G$VhVr9 zhbH3M8ckj$M}NT9>N%i^aNl%mP3xKi<_=S+U&#y^ATNUMZ&P&Tnr3^>bMI8 zn&(w|CKEXeL9^q#Qb0JP2aPWVpmRFG=_OcFM>hbU7T2_V!e^r|OnzWPO%^+uGlgE> z6Xq+7Etj{)wD&$#HOz#-L+F$pwu>;)S`tIVo$=~$(K)*(O{es>Mgj2_T_)dvzDP@@ z%E}e}XHDJ-+y(%t#Ou2c`I-4Z*bi1%IXEAMCnLOILLOjYp z@fj0D)s2dk6K8G|QEZNuZq%OXsDp&}x;xtPvM={p=kKz#kWpV zPqvU1jBI?cqvT|I-*^8JSsKXu z-|!rIEKs&~ul&*5YIyJC`^Oa4N+^0|$6)TKl@$KWFCUqn_u9g$wIZ6hU&SrT_nmf7O2d9e=E2yQq{ z;o7f6CyGsf>|(G|>w#G*yJ=z65V&OxWRX6bQjvsA3lzm_!GZ|ihmKF%a%v5Co8OQY z!{zP`_{c4X>apB%4+=#Wieuw=ZJn*En+KHU$m40@$RaGbX*A%fJ~*8m4YG?F{8M{d z_ou|Za{Q`Ti3ipVK_ig_kxY&pX0t{1mRVL6sWPD;>%oGZwS}ur|8jS=?_y`->;>=j zPp>yVmtkv)<(My|i9W%>4PgD35zxv8L#x?%grot51eYEz7lK;l2;HT>ysY^k1}4Nk&xR+YanF^2a8r@Yc;{95DvT;7ZAcl zIM*ZoMQr9j07sR?g0+Ke%@qs)Iv`a#D~Q@(`2-+3qa9dtfur~%#)8Ox;o>w2CI{O09d?ahp zp?n$5dAKRUF_|;3u(>O{M3)Itf7{BJ3G&%QJ^XG#vdquUn9)6=mlD)6}YH()Y6qzXlZP<-y~^sDa|dscyRrE>|A=3|%)MZT zD$1Yln?3E8WdH!1%xrKVK+|oV4|jm|o5uQkTfBw_pnzJ5i9d(vF5`?ZUp*kwGYXvH zAB>^aN0!vF=_*cXroUK@_S)FsvGONNjt0G)LQ4BcCC03N$OaBBId~RqSgKc^bRDwP zfni5gHAjz*1$xf>DN%xkebHDttv0K6tj4g2LD-V%~ZEgsG5dA#FVMIy(#!W|5td3=tY3N^Z-#1&!Sqq z@qRd`;ZnR=;b?9b7Fe+bL?jUWH!RPX$^)Jdt5;F6mR+Mf=Ndwi5$C8F98>1WwaN}# zE8BAhkL?;k zbauWI5dro_(YMS}uUqb+WMiFe=pRu=k}_VH;`~kV&SnupPVDYZ*smJF2y!!kNxZ`H zs6bbOJ*RO2+RlSU_{Wq$Ufew|qg&CTNWa_)@vbt;v#&SH@?{2P}v zv(mhe7}{O?CrsrY03~nR6ciVVey;O^7cY;Wu5xk7%O-+7R9R6~9c-oQPH_gYZ;p^M z%LP5hxM56qZZ+`}-7^4y8}$0cI0+sv2)@uneMf4S4aR%#h@puXGqHUHh2MOk+@luE zDBM#}l25FD;0rHEj7bJk!3{2bNXLdyW_RCh6le&Q=T+()L-?B79V{)=pjDqz=~W8z0#5 zq}OXT07jxlYaJP^TQ!vZ04i*1Nw{5X`^7}DdtoXXni)+i$shp#ggH9YigSmj&?^Lc zHi3%|{sE`j=AF)sbjc+GeB-*?ctx%)s@;rqzcsJ%a22>OaGsf(!b(`hRf11LAIJ z8t`sG@`iflc(YdxDnqB(@6rZ=mqi@y8M33Acb&0F(k4WQP3i6|Abxx9-E_w;mpK!&(Z_+O9&f05i zN^K8~{8+t5o!qjZ)H|?IKTXhAzG>n=C@yH~w&6hWthG7!qb8M0O-gpl&b#Dp=;O?t zrME$KxJO$~cU@&)%ASXHby{oghS596jf$B;j3p{!gBKliYoOMHSWq3E@rw9)MYw0% zXOCXJmF@9DUDsE1hYiAmpfxtf%-{_%D8fV&lyZEh(4aMTy9f+SxJEC**4DybtaXi| z^Vo2iphY3Thd#A#obCKoOKF#`!7~Ak@Io0&UkSa;Me~iJd>y@I>|*j<`}0MH=_lZvl|WG9Yw1i{rYT4cx@f$1TCX5^jk4NmCoo|5b*$-7CxQp%p8u*MoRV zb!R5JY-hfC>OTDN%yN61cx97m61h|K& zX`{byJO5DR`^uXbNM{|sm-H<-pYzmXF&VXZUcx^>dM;rX6ovq&*n-m<7yKbR4wNBW+MSwt zgEI&a6*Fh7;gZcnBKupXT@YsppS8+30*2{qxtWmTY?!n=_eSg;p{*oOa-oHA{Bu46z$=q=&u7k#f42gDK=Sup?Ef>aP%o zg~v}gs9)N*?cJV{+d#zLbw2xHfq*UJb`zE83}f={vP}BKV28T#E7kh+5^CqlaQ2s$ zM1Lmbq~QoCw1&a=2)N`sf&Wz|yOQ}YB*ijDu}Svz7#!-aO>cNxu_d-=d1@;e%?P^ls?fnszK18vg!YHp~)` zl3j)0C$$0npYaiP21b?!|F3vctg0neZ`Q_FsCwj@mDling(rOZID1d9T)6^bYr zE+MNaWN2!Qp5n_lGF>dIsY-2)w?539dgFDnELaJZP_(+yHB17iuq3IqJ0qIx87c9= zoBr>lc-W;1QngMvW>NjYlwRAb2?WVD_?W*kGoKMrEZDO78zFb`UT8XJPPKd zZrj8BSSA*e0>q*Tob4lJ5==C-xq_4~<0tvR`h4{n^NQp?tY(hm1YMKrd(!%L#C)A( zT9wj7aJkfX{Nm;{?@ArMGr;}v%2w^+{>ahL%;9(KlSk9HY!NDX3_5b&h!(D9>(i<` zN9a^H?H$4Lt#&?xS7cYu@e=_{9=&nv!Yf(S(!RSbk1ukn#Fv4qq-fy_FWaC}{yy0x9j&M~|03v%I7ZGo1b+A|2mNr4 zA^Qh%PBK;3yc6fs4*E0=Lbyw49V!a;rn_1;d08u|6&SnpjTWKHVwuKf| zTOx7UzggCnwoS@TO6E}&b+|YNVe}EB z5dOIr`*}LFvq%w~&@tnUecOn61K_Ry2|I6+x~qU$=Q2TBe#%N;f;`?v?$+0*PqU`p z*0k*E^}to|cc>@wqZpIl8rMpKi43z&WniD+)!*y!3wWk%_~&@?lw_)hs|D2)h)FBf zGsXE_yr$CHvV#B%WH!N_D$MmOiH_@;KpFg@M4=w^ia$#o*g3^<5T{mH^2!!L$2zOo z*vr!wA>+PK*9#xT7t4}U(S4m_c0Of;0053Xo-yD&SdxE>3(#T%b#ZL#m1x|xn*zab zFB=3RH`ySx`S9q92--5lA+TNGoDTOd=gCmNWGtR%>mYHN*-{gx z#8Z3-X37T_AD~V8Qn+HmwS5>LHWV?qxRU&HmHvjm_e>dkT(xpA@Ty*fPTl_ksCcvR zX(zft%OYb-g!XMF$uoW(-TgQ*oLD+wh#`Uohs;1e|BGgW3qHZW_q%x<|1L=+{~^t0 zXKAYE@Ym7S*}>?)tNz7F{|&Vr+4-Ure&4T~#Lt`U`nQGF9K?7k1i9DxdZ@f{G%bFj z$n?DBdNL@Bqj;KzZ)GL%lUtOiUB4qBQD18GnUY9?#B5<-)MmpgyH__|_yI7-MVG}R4piI8=Bqi-Ao%S8t!j*A$N zK?~+5LIQXe8@NSm2Kmxn^`5~!d2wZd5KK?13YeRds;iGn`o+^^CJ)rE${Q3~k}Q16 zez=5^p}w-bb50+9VtD;~F)|(m?e24k>(vf85#{wmjtwZW;J$N#@FoIZtw`e5Vc=Qn zVY>N=DT~a=+eez5tJQY(RGahcj3Lxt&M@r9h?CdSQ*%Q?2Wh)D%jMosrSeH36T7s? zxMD!S`KKV^6_2oqc4vPwFEskOEXLRWlJ0*79dzUU8yK5E)B? z!#?cC4Oc|MpD~+#=d)#Q;fU8Q+?(r<7{%9i`SpOc41&=nO`*O>_PzOn6zRd@qy9k` zExR_5>-rl$@7JWPZXT{L(zmCBp`o{-OoH7v|B*(3)6)C(m)jU@uHcD&2N8i1yWpNw z3MH5TXOu8t-AKWR)uaR00)1ytB)iho_1#~$=qXx$t)vE$7X;R63|Q#nq9po zVWR#r8gV|9M-@1MC~7!Jo`u-QX=m&Be%g7vzg<(cd3b)~9n;smBi%PYEy&(0jUVHY z{s8N}oO6Wo>3Ns_c)&{R1Cfqx{@{9;zIlbGXjG0wzoCd$@N;AYbVv_JZxt~}sD%7B zj7J;pf@p*FDPzQ1THc?R)1xooR*fB-WAJ0k;5z4EsxP94Z)WXUPE?W zQFSYdn9CBC$Fk^7_?QgZ!JyZLf~k)RCLI^kNGtw{nDaRKWw}wZ%naM($Pv8PBhAyA zV7$+F+AFTsr&|bTjrk?etWZ>!lO6^gE34`s@8t+^l@AFV*{IS_Eq_5xg^h7Bzy!&2 zMRzQJy-)3y{yEV7enMK5;;HmOHMPqbXre8TE0SwQFw5h&rlNxb$5T7^_`sF(biQUc z!YrSI4+8@Uu}ET-ti@@10v1q-^+a{$CJNqU?_)nsUcQ=k4HiA{vAe0S|ICpdD1*5P z=qqFOwE;*;a>z@;38~SB@VLHt()-tuTkyRLz?yv)ThQ z7ZgGqLXW(X$fl8`Z77VxoRX%cHX*@W39K8Tyaf4eF3p(OH51|`Nrzpb;Mpb3Ws&J3 zXoz<}6;vJvje-`wSC>63oEzKeM>kR1B;{R+bArlBRgV=qj?nxuBiY7&t!tv@ylE{G z67DdgU`yHuQWEth(7zHZ+${nLz_O`NF_@OP6ZTf@82^G?%t8*JV_wiApu);Akh)Ej z&1#jpFcm%V5!)CEEay12gxm);O>XC(?ZFuo7~i@>Z9v^<4g1_du3>g6cOx>MeD2 zjxV0aa+a&`;pCaINXKmXPKT-Y-Aqp)o@m@^Da>{=fCq_4lV;Cz84znDI?(##jbkpI zJY8XnI_4o%3|W=jAjkTX<}R|MvRHUx_INYA9>3tMf>-kNUKMoud*S%NJpp z^X7gSF8l&4dgU!99HPqvDvJHCS%540div8t+>Gdr)j(>3OWMxK!zY6~E>a@J73xiw z)8gI7@eO3OY28V9YOvr@?{g>c&iivYxgoGoq=}2iTET_oo@Jljgf^0uzSZ}__CFV2 zgk6e|j9*q-KiPlA(>gjE+Bw+%?#=&oz^m5$vE67z{n_#b-OH={$I;KKkD)&a+|GIh zdch(<+ciK4t*lvKt!u16F6k0o@bj_lNkXcal88qSY;AaUcjtX@;%z{?`lVXeL zcNFs1q6PWyz@uuD$h2y}l40pHktq&dMYeu&!mVyfRbR06!ZK01cHLGzCvBRIMLJ7r zg+&pSd%f2PG!0pzbG6GK8Cd5G#Z7nLO{ zWKFG{Xvsbh$A7@zIZ`^PpKdvkOG(+Msr%S>liytBOf8q- z=_du9=z19(!1>KPP0o&0o!P#hPtPllQ}AlG--+Aa@2_|72OkgAT4$=|l1b%Yyrf~A z@fV1!k&uD#cTlcTr=UK%sUsYofi8NehSN0$Ob;922+!!774E>^-e6mTbNBR~8nz4?^9^vrZ~p1asgGCobZOqrPPrZ3AFr?H zbGR_m)Sb8VzIpAcwHUr|W+rS=-~GD3R#r~_U`Wuvv}B%_V6UjPqn=OjL4D3_ENhEC z>^`@=6wNQP1~N#9Y7|N~4?gZ^K^XU1l_@`%86HJC&J&$FHm!IbL;=7MV5lvK9Hu6? z=aq&@;ag#g*l?;yVo$22d}DVlqqIDnRLuJjTM02J0Wy~BK7T!shDq~{)>N}H%&Z46 z1R(Q+7;ymFU@6*FSOQJ&I4q)A6f&hdzB&=Yx;t*w%XKJY>yF@X5QhFbq0foXsMU=b%G|up^ zxU_nWd+ee)JfJRR)ciL3i2Zu?n`qQwhh9K6c)6-z31q*fRcPH$KA<{JbdaU&xrLXI zX41eajVXA?TTuiB19?p@9w#cGRN+XNoF07?BbY@`=^rutz%Jv;^%9FrWqonXQe!To z6pjbj`zoHvb|KyuhM_9Q^vV_#9Nhd9AGWZv|7*7xB@Hiiihal#5Id|KoRh)uxD|$A;BFil(YVmz-MKg7W{)0)BVB&pAFFcS#E9I!&s>FgusIS3 z@@?R7j0p8Xau786_5rMVBkf!e%TP>F5-MAP=wv?&4*zjXgovBu$)+PF9+5K8OvLs{ z4Bl}&Bfr=z2msMOw%v|$x`HE6ds-3`l0UTAv=ff{s6`IoYZC&HSQRBD^C> z+BtVnKEG8vNXN9O@=1x_hpEXo6TPm1Z|l3A1~tRutPXuWaGP(mc@1)+tvwjnQAJds zg6Vgn_Xu9U#^sbLHb-Nl)vrqTuPaO17e@3awgDp9D02@scSSny)^i9jBs%aNp8h~F zCk(<9Hr^zEXa+S4Rc%zQb0T%MB2C|q>?*|>&sj7%nA9Wc9wtxm2M(gL5{DuL% zs9vS{P*0plhcD0PJGt8f2Q7wE8$c6gLlm7j>ro{H(vj>NXO&meT< zG|ypW-~9svh*Vb9xS72~r56J$Tm8__g#i^%01U`U8q^vJ;#mYT{XPO}iZ8~UgilAs z28J3shTkCt1%tGp2aFrzM4@p`9DtXN1x4EO_inrS-1?X-m;TqO#EEFCIr9j2c+Eixx^o z-0y;+Cpq`U&CYh_R6yscxWX_ri&tPN?d=^MZH+1Yv}Jwwf$Nt*GCo1=D2w&($X4?h zESFXd2ag5iSqeseSQYm0@(3W*>g!KCOe`Y?Q&H;`mwz>DNHi@Is) z&{$mL@)~WD;o7!uivcl!%QZoD;ar-$2%bY5JT~@FeX@4+fA*Nyn&>tVgt_;R&a7DD zk2Iga(dmgbM>Q*Gx5gcRqk1hGR z(C)}(^P>!fCW(_Uf4&L-I@VjT%~)Dy9cl(u=NE09!n0%k zg<<0AS34Ol$R(7YV+zSjOn+G}C|FLA;yhl>?WsB#*Z3V2dVE-CkVXWOfN zL@QT2pwYi32Mg4Mo%ftXJ*tF}a z*EKMK0_E(`_%F+%hrDU<^3cqpw2q$nf*=&4G9W@NX)#?lnH z)soS3uP{TeEbGvkM`Qmr`~IJ>U}r3>Tsn?`&Z%6 zIq;6%=Rx2~0UUM1Pt0tNfHD7x;cjgyv#bas1k)TEq2uoOuic@Ovy>B)XDn$yGYLIW zWIwpve52kaBbAnw!`y{+sLdNb8w7dfb8BYOgfmB1@c~rzA!#nm=_}CM0M=ZZ)Jd0j zLQm{)(}W2}(@o*wF6!paADGR}s zH20HB+wDV{C3c+nHJ75ULe*kWfG_zN++T%Zqf{rkL30?qx9wS7Nmg+X1#g&4GK8i4 zUYeeBy+BL|Ss!X1F6T`IH!z5Sj8|<|PNJ}FlzlS5B2+a`Oyc^|FHFbeMvZIEkZY31 zWTrG=fjsg-U0ATIIfZ5C6zZsVc2gyleSa?a zOft6S>G&v~f(&9&n)|y*8{d6P7us+x2ImCz zoj~vqq5vN??BJGQy0eiwFl)a!xXXQdv3sPy!T;yMW;0fK*AWr`KppQt+l+pN8+Lle z<_^EdnjwuV+s$UoA0J;(OQTjU>E#rcEvY(c3w9gBKlOowT57E!y@_R9!<-5Plp8Aq zZyPV%Uh(1*Cuo-SXF>&qc)T}seDlR9TnT^wR%(qkMBVBT7m+zt3oluutnDNYDrue+rVaV(Z#|%H_|8oLB#puhmex51EjTPl{Bp71q42PdHI?X)eGfGD$7p zl1*J}=s=`DYjr<*PUE-v)SCOCCpZ!$vQ*EjK1ddG)i}t}xoR@Hq^aIu)AuU%yzO1V zudP)+H2NCfeE-sZ?cb1a6lDMK(GOOL7)wgIF=wr#Ur z>Y-Q-U9GWbyd@8DcjS;8)2z3vPu2E0(zP0MSnbTDHm1PWFl=T-rTIG>5e<|b6drY(M$F_iR-CFz z!gZH{ksuqAEdsV2p{hg(_x0O#8)4V*-wIao^;SHr&dtqXH!7v~69n%FE?Y_6w8iC2 znt%@z1UemYPM}4o95t*kKJ#*ReFP<$moyiECPS+-O!5E3=Dy3MWwYhsn`D;Rc$!C; zw+xI*jpEiu25l}>{8j4b!ZV`jjfiaD`!*}|-Z$J;z zT{X%}ryo(C@KFIETf6KYN&GZKSMjcmrVwwODqudEJabz}R)fyqQ8FC~oOA~ak;1&& z3S4GFDhqaVR&V0Mpi)vOcAo?5xkw2-u0HR%q|$uJV)nH}A@5^^3M~6{0v20jC>9YA zX_{J8|F2NaE3P9BrO3I9s%goo>uB5>9$1*6f;K$NHb)(KG*eqgzzTZ|rIIitE_M~L z>}gU!qEu6=8%)2z!xke-AmF5FltyS2!HTlYIF4ipWg`!afscrFrz1!Z&D#~P7==t% z1|y0th?g)h_>Iva_+fBf^ARj4jEH`uwbNQV;q@dKu_TI7$z?KY82MhD4Z6*`zD7*p zMha+d;5Z&Z0h@OkxF@E6*{8|%p+ntUj2hM9y4{-|Nf|o0A*_OufsAHhS{Yr17xOk4qS*|NJCwuS}S(+#L%z=g$nr={@84IDrvdk|O^WVja|KRLC137;(FkpQVzP zHIJjSIC>VKLi#ElLzBVUOxbo~O|vg%5}YFt*>L(AS2Tl_Rv?>QscOx_qPM0r(6P}y zPhi->c${thPmPAG0V@)z%k7M=KZVF{(U9Fgz}ZI%ZERPttVJKSyZ7lOq(LU(^pC|p z{Hb$6LeLxt`RVqfzA>cL!vr=>0YT`?9e^ZZSn`61A7kdakZQma$yo`ite$9qnv4aD zs%S>hr>{+CIoG2EkA;KgU0eP6Egkh3fD!2ecgSf^Hh9m!tI+?*;N2plNfNHGyw=^mTfRI)^vse1)~VUGSC~1 zQ*_D7I@94N1KYHMoO6X&^E>}zgjtMev7Q{Dqh&1TGD#fA#3HgMz^Qt2eWt89R=2va ze?4Gw@9=<*(ie5YfpQ4@?9jwMrNyGe`pbsA9ccA~LVo7Eb!iwu67JUZ)@!QuqGa{B zak<>+Zv8*l0WTU(R-LJ~B30o579o^PfN?>MeOS*b z6%Z-uz4vq?TpEX1PMN@f+rLl_XPt+tFis^&bqPwYEgf6N5X_p9ZUN#^;z+PmZX1Gh z6*D(~#ph-O^*6*S=hi!xME1 zaWS1X;1UmY%XkMbNEcm$1Gjb%%z+KsS84=L1d0oNm~p)KWXvta2dPERW|dMGj==u@ zboqxnEI+arnVgS3(L1tD=DvRC?<97EAS1wDFD6ex%&l-=@f)X6hk|k? zqyUQ>FoNK%!@VU*jeG?OhtDciFC1I?aAeZZ4`~=-2sCm4b4*^Ld0_K5tK=j=}& z`K27TYGmFI9OUm+DbSz+>cIG)0uGHIm7??o)J0oj1ZeL75V<_d#Mv?h!W?9>1c#KkJkdAG;N)dw7# zZNvd`T8*9)72kHXBN&ZmkM=bh^R5t=oAu1*${6TdT`nVh?OMuOc;~O1s*zb{N|Gt; zG)LiGWuOv2YIGYnpg(q$i2-uiV*ktz+;{|-z~w~-Ff$e}9@jReD!j&Zc_P$0u7Y2AX>J)AjCZY&&@97J;hH;h)#VDAB#kKwvYbz!PX2pqn#L z@hvJyWbL&jE81dv(KU?v>0Xe_YW(X?%^&V}R*EV>H3B);7*yOrgb(ZBO+bW4MOtmZ zn~Tt02fL25u5^r3RKivL5Yn6)$ zOS3WCumW|#zludam_jpH4>i_gJ6JPk?on33a&swAw z!yV+FXp)CtA@!V=vFIM$A<{DTSEe`9uYg*2S95)!d1<%j+fphh^*-<3na^1%Z1up! z8{+mzcSIB35S!C?%u04lR+RX6C+=__mkeI2(t&2o#5sp>L@#{Oia!6X6X7L@p?nDe z06>KW008rUFvFe9et%e&G=6M0S(5+b!_f2Z$}=WsId-&|WJXA9wJc8>qQ_V^S z(VwAGNg`b70yO=|X1~!$6ppTPr5&7?G@eTv&rxv}d&$f9aDPIKY-)OXy4?bn2IEUP`bJ#p$!e=4)l7nBpXZ#?`1NM-Xm7s&sI|uGQK-8#UYNI$o2kq% z8Lc9z9HAykb%DJ6mx*))E1TJ~kO%~od4=rAm>>V9J z3XC17q2kiq=tA9;ZL3O@sC%8M?=dy{RnWOQWHZ5eqC}LncXqSSml~QzN!`kMak0I(ALyoev&jL=s^~pqd8+2$WkLXjXO{H-AE1! zLxkl?v>3nFVltn-zdt9ZDw)klQs9(~&_nwO(VLhaR) z&TxAu$WUA{922Xh@7g0Qdy{>bK!&o}N2u3f z)NX0wY(Q0F$GcD0#tHG5W@)W0<`k`s0-bZjRyPyonp+RTmHPN8Hgwd?2$49d|AaM zL7nK9#12Gg$;?e6xzc>5LI03xPn;uo8#O2VSE`N$Wx!nV=0~v11CUoksc!K8Qldzj z8X3_UL^4%tDz~l?%x>2_;0Y%B4&PA2})9*YZjod(1#Zob}TWkH4j^FzuH8@i1q=hKmV>>AJFJ zyc`tYXk9BYJ= zYg_QsPsU{WmCzk6Y*CW{xxUAZu>0Cy10$3=l2VdG&4t8StcK7@)MSw7Sp5LAWpzc{ zI3#lUExkZkwT=;`f{B*Agp_O#ZiAXknc&_^c{Z^0gMP82yoAhAvYH4(2gP^E7CD0? zKlWjRi^MRCO!VfxPp(p&v@bj2Rh5q@of!xMuW6NVMY136tFr|`GM;H4U&yeaQI^Kz zkSEbWE+nOeVvm#s_1zYhk!rBD(1_H44-v0~yFc=c`;UCF7k(q(9vW977@xj`?tUk- zq2f`fhoE95T}jr5^jv5~)4TBeBM%E?qGN;RxM=Fv;TcN!%q`DY4v&)t09ghyfIYD4 zOKrvxE=OuO_=55M-qmka_QOs0`#mq9#&4ke+|T=xAw1Lja!FcF=PdZ?=>u{&2Y%h3Bv~(IaE_Zt6GXBt&MaRYy>)yfDwA0YIr1jI68k!*fNc(#GVSuzmXVu>7}g{DXg1k;&KSnOlbL^dZ8)%$k{G zC=mnuQi50Jz$8pL^*=trYG77Z=4mkP+7kEv?B;`G65M-KLPT=~w}Lnl^|0DO!nPi! zucT%LJRYv=Vt8K$#vmUV+yujz1@H=Q@F_soA8P~WwIxMhrkWL&dHMb3HSWbjlxBdL zA@cls(&ca-{j_>dch-oQHW;X-N-I>f=V6hX1 z1d&~Zrz3MtV*We_sfZ~V2h&N;)J_A#Vrip=Ov$08z84Y@kZir0%}#+D6-@xLj8bX6 zcp~s01Ey=H&4n7@Nv$ENAL1_3#lHWWh&5+_I8$@$OmBzm>XAgQkjuyMtio0z@m-WI z;^p+fw36?M6|ZI0eK7)kE6n|aRbaY`6mydWhuWK1g9?J*WhlVqXT-Fj4p3^h{O-*J z`hqjxe8!1p2{USimx@vlMJjURP>vc1i`=Bx6k=wvpgBm!!PJYZSgON)v)ZxIP?nO~ z4c6>|+cvU@O-(lBIo~r!+v-MAFymHbJU@_(b;TZf7Mx#4mZuxZ9;*)-4Rh^Cu-GF19nq z{3q}wNmXkyS_9wz%(o!C-uGo^I2Vt{i|OZXgqGeB8-#%A>Tm1B4Vnq#|EK|Fwkt>J%f_(Da-hyKCsVEO*ouKpVLs#1so zT?4Hy<%h@H!8KsV%sOtv$U53~n&E-N_D17IJ4#F~KD?irSb1RO{c&`P!1;`^ur5Ec zx1TQNv@>nSPX8R65lV6%-j-wEIDzv6SV>E~EB_fMO5xmBBOF=D$;BTH@_>#3iT?T* z{e1?{8v=a$0VtOY*Yznr?tfbOb`Zop;#e#p(u*sI8sCl@-o9K zlaQD>CWFC!vBvszd64+p$14l?_Tu6l>)eBm5IHFa+qk8)k&s`Ei*v}}Bg=<7cj}S{ zQn!>|*7D6|<643Dgk-|fLn}0V<|&hIARSd6obH!fOw4?Cr6)ywx$}G;))5uAv}x!V zIW8Fig^G_31XJ&PDxd85T6$`@8^$RM)?0E;^YvxV{%+w?M)c%U?FRW$Q}xw~OsexH zMLq1|4wGi){&oH}VgEs|N2=430=b>A=J|N=9sBNf9H!>PCAM9Y^-*pv+v{bvfSGMY zw%5!tpk#u-E8&0#pS6qV;s!p^RG5 zVq=NZQFrFv`6DP>Y2pY7kBCEc)i>L!e>MgJ@-Uyykvdo;^U|I^vd#K+1wCimWwH|O zn6814;3|T^xXY@kW7e$hINn5Gz+NTh0TsK1 zoE{y^ne7EYMj1UEA{spK%aOHb z#|N{TU2M*fR=WTmKKaiRCM;Zl4B4_#Z?ln`xb9w4EC`hSFaEF(X;ao2u!~%Hc+f&J zPuAp1d94TRf2U5mkYRtlS;kyVuIk0MujD)CHeZtsjkEsUQ;I$^$-7D)_e%X-?Dek@Pj%ogeGKn zYJiR>@1D{PbB1{e2n%+aP2&5ki(t;opo+f5`#gf#dtZ#S3hDTRF*bbP6 zK^CSb5HableEu8CMyTx=6$AwUu>A{;;Qdcpi1mM9w*R9FUa4FCN+L+#-97#%!ZPa< z>d^@VfSxBPZHr@=R#|w>eoWPQro`7Y*j0su!fHfscNIh`on9G` zNxK3cPI)V+GtZ1XD$diUG!v*11_SibX{t&^i&SZ43^mL#QxB$wBMTd$) z6`zOO`xCWpIbFM{cI}w3^1fOPN22fxKv#C=R53<`>w(ZydmA4nT5NVYJJ{Za*LV@$ zp!DE5!~aAzYGNZ+sW!~SU}87qf4T?^1bE{9b%|tR@a~lfgG}49Wu6zs%vp+{<2$Zk zsBoAL^k?q1utAC|!150xoJj2=zh@T8Ftk~5S3|oLe>}{iH2!u=x+E$&A>s@dpS+24 z0NERzSCpb=p zO8bscA_^+*zvdK`OmBsdASc9?&fq;jJcwyT8k9i`jaOlUMI)7T*YTQz$X&nBE%hf`!~wHmjr;(__6OlCfevZO)ccu z>@#%p)PGy`_txr22d;-xef$ zOXF$Jx#C1FQFW$TnW_OYSLhN-cBzLY;7)46j1`+>jkKik;Ttv-j@Jf>GP)cgl@ho+ zHw?rZCJo> z)$$xk&M1uLD|}1x_kl_g+QtOq#=+TnDFv+t8pzafP0sw8CAb zF!P)+Jl>P+3X{vlJ4U(=;S&*QQU%*!@uTOmmoYWW|3#4<6Bo;8#=IDJ=LE#UQ~A{t z7!z&>x&hXB6vSdx3h{I#=jUX`jU1lew$F4y?&aiOL1w*DkZfz}?n?!e9%49~tX1+R zvT-kawW(;98U9wDc--7V)kXVb-_Rft0grl6C6lWY!!+b zE|jD_iWm~0+_*^PZ3%%q>kzNsO}W*LX(eQj9}5pgNac;gI0C)g4I^+rDX|#Sa)j-4 zW!|2tkBM>vgWN9cJf?anq5%RJ1aUjW2POVZ$WSmu5pCs^C!xUBORfVR{i0^)%};z8lARyG9vaEt{XKqi-mC3ury?cwC| z_6%9pcpA?-qwcv|E`%z~%v4T?X_?Ke;ZyiCrqnH^ZLSb*F^471|gIm3P9&*GJ=os4kS z-A|i=v2R_GAYW3%1$3B?Zsi-nds`!``6hXeB6LbYJ@!RfJmQ;%<#F?e2$|&H5*#Ez z^T_ozqMEO>``*6Xu@Zt0Z`nC4VmZ-~9d+}7ZAFvRaE(dxA#@TUPBCT)lOn+*SPil* z9k@Gq@CN1hLcX(4Tt(83Se7{zMZ>|N={C6sSMB&g`U7);@cO3ydOvJjp3h6wyC}Di zd<)Xo$PxL8-D1xm7NWK7$S_WD%bwVm076a){oQhS956J^d5R9(Mt zV2-DUJU{JHTo0%CG_JQzkn3<$wIi4*>fh$PN_)>+%t z(9V-cNpqU<6yQY%)>$#+9E21#Ce~LwUT}qz!!@C97RDPXm#C%=(oq5G7Eok|w}~Md z^Lc^IHfbN_zZM3^9eP2|clj$i_%FIY0t?Tu#PuR)QEd~ojYgAcSsNV{_DSpK-SbK@ zQn3;E$S-ytFbd*KD3j*V07h9_NySb;Ea@z!Gkhl3kh>ONf&y6615@$MB>ZeV`*u;&Hf%iFKR0@(SYNj|+izqv(RWnV3uOejQ{y$A8!92nWv#F$?Jwd94*soG zHr~_^UBHzxJw0I#zr|KuZM_2)n0sjq<75iVi2T0b-pN_KiSp42SYdG)w(_>|2$8s9 zaZ!r*X4u*Si*M3fPzP4$03Tw}HN0)&1_`^HqHp${?mTW_^#0fS*C}I!Ec~;(4sozg zE}oPf=Zf_Pj0dnCX_w!N4<{M%9YB4v_p7i4XX8Vsq3gzXs*g&S*<&Ma1Q2|h6cBgv z`L?4()2I5&+V`~oIPQsLxdKU$(~L&x!H{t?QbC*W0MQ`%=6?(+vk7oIcc zQLp#M`TAx^@x*Hc5mEQfdgTm=x z-88I=B}wqQI;y}wbhk9aRPH-o`oDY?)=fP&Twi|apIrgf0gembMeT3TV=(7eiLH6G zlGSb@9Q|2zEP|{HbM@r@jwdp=>*bR2 zg)6uw{IvA12hr(;_$N{Hsb0d(I2I5nYyn^-_C6(G`>3IgW5rr;u1d z%SDT~5wB}&p^+*MynM=Rn}@?Oh9O`~KA&6$?czF-_XXHmH1VSE7m(G-vvNfIn zYaDpsLhK1ibTQIZi%PX6j)oS$sAe(g3Eyk)0?{*lsxo7QQ^-h~CuVp5a$gWIJ3K-K z^Ma(3zd5g7Ca7su#M&2MdM!BJej$Jmi+aF+wU=FGypwll!lla>m0`kkeBrM2rp9h{ z_M;z7M?9ns96?ncLCvby8Mk-muBDjkng z2Y;K4*JOmJDnB`L_>Ab_#u7*PP?hGUN6u55VM>w&_ijChWf%MYZjZ?5;KToRT>~hF zhIZ+f=@)|ipSeM2GkZrTJxe2N=U=}%OZore+HLU3;G$at?+R2n{*zb!&1SKMtNzux zW@m;DN#cHmmslI$AJ<|N@!Z6c7I>lJxV+n2FIza07Rq=+Yp=uk2)W8lb$<^x)5`D2 z_Bq6zKa$j_615v857uqaHf&_xu0NKE#m7_@%cle9|5ha{ExRhUP1;!Wo7Z@HxHyqc z`($PHpsn1{($doC%vBxrK0kn*BFn)eZj+sq+*Uu2&k~FGPv-|MEMHjqeM_%O2F=0w#75Eea@ zlivmkJhpP|mCBl@`6NR-`n2B2p3#22otHFKVtMXa1^A@Y+p}R3ClHB4QSq;eSlCN4 zwewLfm#&->h$nMwRtHn=*0e=zp&P5(m>vAJ6BNQYW87i)jURZP^oh zbx+3IUOSil#`Nb3fU7i6zTSnH^xplGFo(A=@*fAcEft`ME|R z%b54bn7>95;Z_k@$UfqpQ`cllDl9$N+Ck_LR%@zLbcOqpYZR>Gmoec+tCjbLd}>ZU z=)zya3H~O+;JWe-&Lp@pF(TJW39*~0vcvvBoYO(Pck0|vejKo~iM`celUpwX;(zwc z>6cW-#OM*~kcR_z`}6NF#s@~cI!Bn7yvvKui=IZj$*l7QwH8w*)wfejr7GR@Qs(F2*h~?Es#Ah2!|3w)oB6S_M2iA4@ofnu`U@;pdQ+ZA9s5dd&CU!p3rp}$;G=(yfo6ng zNoffjJ?%TaB_3q&AjD-P&3tU8ehBXcg!_c-Rx5VQ$L0SJ{E2Y80GYlU%^2k27{T7-hkO^SN zESm`DUrHN>%?nLx^0b((^ThPd70j9Tk(2YSgWfpP*}N+~6}iM}GgQa^&p zV1knC9TpBFRthTG1_z#`qt=re3Xe3c9d&`*4f0VXClZX(&oXbz!oQ2;$4d)?%%Sv( zH;05NvThvVbI-n?dg{b*K6(=)7FLV}>B;ChLNJR?S59`R8-V@txHdvjxDj(t*D&ks zK+x@Y7295FCJgM=l-DEjK$SklfeGCuB?ZJ%dL++3I+$v;(wMm&F=8U&Ed+>0p$$tzafGr~>$x8&JdhrGic~mE8s(a38&jpzY1$O^T6(?c`?Qt7|idO;4yv_`xDmkZ> zw^4;%Xx;C6oChSi|&knHCT_?MQxv+U+f-lCvOuy^)9&8)il-G0Vc&7$+Ds_ zJixTnfeN0-UUp`GKeY1xELu%&yTG9(_QiOp)Jw?2r_w=xvm{9TjZ7_lC6mA4!n)ze7kTz>$N<9rBrxv_% zA5S?n8ZwQ4H_I6&54Jy4Ra;zjV+7dwlxfkt8>J8ZQjOrIl}isEJI4&Hh=_f%`^}7{ zQz!%WMLmd;ub`}8qE;!yj^pudfIL*#vjoEnK6sQEcg(sQLZ4CDDA!^D1`o;UK3#n- z@%rVfMJH%$x(XQ|zXp+~6fLgeYd+xrKEv z3QUz&A|2NVGIS8gpKYN~G6fciCD8stKX4zJ@PDLVj1b{?=m*8ivp z;0CWBJ++I%_Opv`CqBIuWMo2`Z#P^&3kj5A5cRhD?`=b#KY`-2H{3eERgL+nQZ9=h z4?DPi4N9j$r{;ZsG=zhpcO|`(?`e}NwDQYTNi7{fGf}PR$zR{i zKcjt%_3a^O6?E^BA>t!K-0Sj0*lvcV&}=TMJivsoNFn$QXPz24%NFOR)0-*VZYEyT zfdZexhv}0(BEqBPCi9!Xc0YV@1&_j8F_1zV)LZQ^4&O>GTq}u&vvR4eQs|&~EmeLk zqVqDZub?zlF#KFc z{k`5FK0l*a1=G=rC7a6i^CrkNx7_m9If? z0cU%Z4>2rHK>|>QOXtTw&!ymZ_b~^`%kZ67btx+qxC+nUAtYs;vHl>ilwvFG4SNb< zWJt1M{GuSJo!qmf2)Y|eJR8{74GF87cz(^E(>@f|AY90xli=D>_}7go2k9{#?Sr%o zeJVs;SZEbJJT3!-dySdbD14Tp4#&JEZ?`N3h4w_W8+lt)QH1^A{>K>j$D5Tu$8K4Z zza~UWd6eo++`!st<3(p3H_#?ts$QzbkJeeEDdtD6B!s#H4Qmk*mXi^rW_T|ba8UoP zRN4eoEjhgnmD%0gGL77HPL7v}IM9qkN-n^=)Fo70p0firrKHqv{r4rmMa5)o&UhD| zzx-Yo&_^e`$AO$=s>d{a(R_ua`1pfFnNVXpAV48pz^tyzr5iYOtEFPrhVXR_cKmL% zg(e!C&%}mlkMcA*5RUvp@mN0$SaaC(FR$}@+}}44oOM-TuLM7R7H^gi8}S7IT( zYehAwfh9wu8-PA7ayonG zbOMw9hYn(vVo`qV!Q_7XiH>H_gG5RalUUcuTns~;0<+9i=>6?V(`$soYQn}Z1)qas zKPx+~(+ML`1L5@IZc-mGaySBqWOJ`Wp^7#UbKIyWfPgoB=Oi z;T_GKvo5fg%G&#}wLK@=0fSgD&71c6{ftpHZMgmMP^s0Wh=BxJ`q=~bG70|3uxBQ) z1cR4Y_6g~VGB!gfHk6LA|7M92=?Vjh9LYT)kRb-w(JK#tu$lA+PE=vcg?PZpcB}n# z=Sk4cBC`r-YK5g@5_U=(^R`19$62(A(CPcQ0nVZP?eOt2zT)FVU}6@KC+J{p9iaZm zL_@&X))u2e<*(Dh&7kP)tLdVNK!RbNCM)trrS2q`p6}PN8{!4Te&=V%p3B^HEDjj( zTq46jwUfcre0t{Ywcci0eX{^u@Tv{vlnORkhmy{AOD1@(c$M6lPpI)isriLrtqEO1 zHY|{Wq?rxVL!4#zfe+Q<zUivps&g@rJ`F}Y9X9EXXo!_0y%uz?@cgu2;mzD+k$7JRMlZO2$+&-LkRuj#kb8P zMl(gwFg!|!cvx;Sy2{5BJ&;_QmV7$vDUH)rs5fX7=)6Jt^Jg(f{87yc-NV)0$Gav3 zzF^OQ+pDTv+zGz#a)~(X;rr*2SaCL;mt0X>6DJ`#WjyB(hI(ZHF!P#)(-K3q=6s~@ zaP^)Q8!&oDy$#Eh{l=K-U0&SyKHEv5Y8#!-@U5HY(IFQ`td+6Jr(5{)+L?$WKLB@V zBeM%#cUL!g`*_JG;hF*p$}Ne?5nbphA3=UscNq{{N?J{pTF?_1yLJ{=?QbsaXAI*Zozt_?gIv zSfj(?Fu*`2W@%2B^|e?)u6+9;Ak;b3gvb?$$vLlUc5ukY;&s-&%X(A^Zl2l>1{Od) zbO0%%6pSgK(vOO(`8|#)7RvpreARv#tkHzbrs)8(?`_8o*I*fxH z{iU>;)^D)Ls-eiXrf>z=Q>P>>%!l0;_cF)Y>6aPn>_wXXx_ahJwL2LtTfmh0FjqIs zj*=W;&j!_{CB$F`ozyQ=5UX@eiKv20v7x27x#C_J!09&0sa+J=t5IuhU+BX{A#pC= zE%~plYxq8-S8FjZAMR?_=tRi&LW<@^Jh(%^?`@rZe%-bZxcFqR z3?^>!$m-bHuvKR%tRB*A_&Uv>ZkpOeoumFlRJ7PR^~oXm(aM6@a~r%u50}vYEVwq} z$-Q}PkgY~|LGQBGlkxS0i2BH!cy89H>vSy@snvR{4nok~Vm?8sIxnzFH-r7qR2F4g z$QyJ_$y2EST|9QY5(G+@AWRx$6Ga%uFQI1y1_`WtQ)8o1GX=xvE1!0TW7E{+f`v?& zxt8eEHbMBLB)v?%u07FCD-9U5r9j3YOQw|T^aTp|%I)XHtGiDtf|qO7n)FxWd~<&^ z7M0L6A?R%25h4155}vuSkl~iYs-ue`A$d&G7c51a`2s=aF(or|>R?WJf02I>f4C9( zz+0Tvrb;neF72l=NMXe8IF|J0ditKeskBngCnc=W$tJjfK z3shc52FoWuVp|v@zrkR`uMujIKpY8%>`R738)^d|E5fwqdvqhgwFbeGN-20^u-E(k zD_&!0%ZEDH9_S`Xta#EAP88wi{aq>q%mq9>v?}TcKgYZ z3J3B>5)*4)+~zXcHJxP^UQaRxl#SNumKVf+o@Oa(mC5ue-Y|#^cES+cr)^ftU&_6c zsWND@Vyo40*l18Dl*QR!(!&AVDEzT~CkwVCmCrXZ!*%>l3NhKSKJ5C{G-BOgr;2~P zx&367-3=WFvE(5Aq5s-c~i3|F!Cm zGeked6dWtmty=4;u{jtSjJHvY@YmZiwxC{Wz(T#KTRZrM?~|-5WzU}-FVq!-TxB@ro}O+e^8KGP5>N@a|iT3U9&5-my0uPJ#Zpc^p1OAV$9t<42qM`RXVz+!`iY< zYL&R_ueJhd{yW%tB1`m9DaIWS|DGONSDqyasy4|W6{LWdRD9m4NB0f&98+E)*n2%* z1?GJ4W265R(-d>)Rv@p?@VK#%WmlPKeF6!49VUGmxf)T7g)^VghmQXMkk`WSB}ymj9MQsCCSe0{%A}8VAxzxadF{LHvfG$mW2@E}*Kj|c z&%FP29ugp+ae5eGT(5pz%npw)rvWQ= zpR!SQN=T(@L*b^ia9-MaqEdE!k*vm}s&%_HXC86WsDo@ff`FPBM(mnhCj42Typn1Yi<2fvS2K;a&TE4-w>|`-r6OPA z*sb|;iZ#aI{p)R^=(QV3!UNW*cT|lXRS%nH-vWVsi@qSG`!#EmrTO ze7dNon3p7%WG_PBNf)P`B6_e)LM4YJT{fx=tahfSfmB~hs-u#$3hql^m;-^aXYM`R zloOEI_;8bLKX^;r`q!b!G>|>Nu9RGy---zTzL>cn;3|JMwV|&h!;j!G;D;3@lIv6( zDAgc5VNdw-2mIeq8U8cuEWZv4Qm|@C9&99snF)ZKsM|wqKi7>w2L10I5hL(jx(M zGt~r_C4{I(H8LZNI1xK|fmgy=ZIy{6uo|$kzf&==JHYUHw(ygnLWf7@p%MP1Lz3m7 zGMTHnB@C~Sxx|l0^PKyMkIHq30`|)ib~lhb$Z$Q$;|=Bq-q7DYw7NzG0kH5e{hYCS zJd|yRv^yg>s#yA1oXS8U15QKtfMxoYMANUgH+HJVvShNihb_C28NE@rVie!0x1k}G z88fC+rPEcKzz*o`&aN<>t}YRoy9<|_njfqkO&x8pV0k%|8hadvHZa_^g4AjnolYo` z$7fmzhb&@^JXWLgVaD26*D*j#Js_EX_?~s1NZM)Arjq-A#7Po6Q>8#n9h*1DwXlTCFp7tZB4P3Ako>cg*~}aKsEr|5=>g^- ziMM%rDo$kDjbm8mwCon|acm7!N@A}(MDBhyw~>~cogrN9p8B znfWLn+1>m!2pzP6^PY(55}%O zD>|~{8sn8%&Gh+G2zCID)iY~ZP)XX-1!ASy#>W>{T)C=ybTW=S6X_dDPBVXDseE$0 z{eazB_P&kGiDe-H#45sFfr5czCU+!Q8kgYm^s)nIwPQ7ggx*%y(MAS(SOqaJ!(lwT zHF^cCf?-$bEka>Uaj_#TShjJzVWq)U4cFviLrTTeDuvpu{LkIyQf&O|Wh; zI+U625g+n-mT4gUHKo)lKVuE;EqlB|_8=?Mv4eXa7OBF!b&EmxQz+1Dd|`l|r8h8;;^}}f-P%Az5TvX;mx5~ATvQeS^1pN! zP3-(r494K35B?+_#gD$HZp&`sDB?=7(h3p~uRumHSe!*B45CMSDuW-Dxy%hx?VSQ0~i|gKA!@8P;01N}lMyT7s=G4O?5C@RSN!3Ueilm1%P*f3utON|g z_?9Mq`{yydW{R(Eu$lraz<&pU)5uGFqQ<6s4^=RETt3<|o=Y=pyU-%4#AW@oDgPiJ zF44c)O%4bE5!wPC(+!1M%E5jf0E7~xzO3`j%CRJ*0UW00mIIGSl#5f#5hMzJM0+s^7s;BmYY@fy$ZYw(9Fy?yAY68ng;Ax;2q3}byArSby&TR~Lys)M?JmZi= z9$KeDDDX`+01etKrl5vN!^0;crz@a?2&vzerpYQ920lvgT^`{XGdKMP5vD59g+8gp zCnb%?wBqe?fq{wvV%)@8FgTW^inLPJf*+y;h+!*OsndP`i|jD7MYlf}QN2)?s|NBAMcVB{bXU08&f-TDr0sm-mXXIhD(5k<4--)#7cc#c4 zV4HcUL@~N4fgl^FuP?(nu$pS+cYhASm4vF?ol(EIsHp}!o4-qGOAO}JXlMlV77^}F zNG$4N@d_1C4)6#f3Ixlc$bw|R`zi5_A(Wd%y@Jn^?n)mW>PIcG)ZRX@=su8& zlv8oL-zY1i-8d{bD)hP8jn{|yS`50l)gzl0V+-RbY2~ub-fMlHGjnO;`!9RF*RyrDH@M*Kh60DX!OtzB&OSt)g+*?2KdZ zG}nrIUMIHnJ@Q8KmS_~dA|JsubXZUPMvU6;kPeH% z-h*b{jiYoIQiCcqpcstgf$qG3;WY)itZE&@Z0%t%`pp-56;sQhY<(T*g9O+Z?j-11YBQDhn--1wp(yzdO!J`Z8rB zK|Rh{X_Zsv)QE$WX+D1;T0GaKx(TLhua?yY#uBM%VdB+`0fG0UZsGFL3(!e2{4Iv^ zKk+nuJ27`d%nAw%(>nHGFM8grsmMTK2Sp+hJgNZ?X zu)qsAnHS%M{m4D%OfLrDz2Nn#a=^eJ~lIIeb$dEK8wx(ZHeh&6V<{Ibkk80&r^A8lvT$ z)LwQLyHH;bdOttcL6vLaNdPoJ^?$K-P7Q(u4U#R}>auOywr$(CUDajVwr$(CZFBqE z-G`mo`3v_YZ$?I(nUC6>d0a@)4zJPZQMMJd+Df z73ZwUB-FuQ9|Fa& z;{w9X%iyjo!Ix^;TGESLg-}x2F-ZFisL%9{6tI$?6ROWEef}o=>y&=A z$qoC0zN-Yo<+QUC%9d7gRY&eZ&e90JxnGm$G8Mi3KI2j@fm2Yh#Eic7@>9;-P!W2a z2~}9t3ly`0yhl0Tq~Z_>w$he)o85wXUgj~$ny%Z^$)6YXkOtG0^olw%P-0dxr%M^@ z<3>N1$3*@Ky?~DVubI?+7I)C}}*B7^W^d;CuU7xbq9;Ahj+TYW{bne*E&vVj~JodHtlM2IT&SR-zAm@O!E z$=y{eJMv>oB0ff_0DMx8YY^-x1>YZA-h-2aH!Y7-x^AKoxq4qOuf1MBTa%;axk_s- zV9=S2PW^z9hLCIZ3Enbp7U!Og0`Du`;KI;^dpe7GnH@Nz6HsHF9=KF>ORyrE+NZ9( zgO^lC#O)4RT}KQStHmMg2o>*tBIM?MRa?^$1y-L^Rv+Q4knf6Q!mr48j!}<^Mf<`L4DP7Y>ddYT^);BTTz96r zgW_?Sy8mk4*k)opcFyWQ*C$2-Y_Dz27WM760C~NMpfSFN!AjLDfan6e)`T4r@{B7L z^y)!nPvCGO zA|m+~tGE*$&8zrHA$mKV^_5FB;KJXrSdmK%)<8a=jhtW=@u2#z=q?pI)Q&SIIc29r z4)daRTEt2eS62KS1$g8P+%fi@dm4~~J~ZY8bn0%;-u=k=e3UOFDuv!6@$k^mt=>ll z>6J2|JZ*Q*z1`o~vJot!iBIR6!{!W>01@i5v;J9(=cfdyZ%LO>>y`fpdf!4xsA1^j zyTQmc^}KqBXl|d0W`4(A8|}?P_gZ0S0`|IN9_S?tOkf$zf!>%he$xA|VGOW6o)7{U z0Km&XrO7}3y3QT*+ae0NLO|W*n z_A*OqN}6J`iU2Ohe3z<~E&^Ck#YvF@&`Ag}8mQK$WsXQ{(GKe-l_JC-g5{26r;R%U z-P;1SuSxR0Leo+OX_6;~WJDQOF^xg2s7m$mlAo9Yn{N3sl=1~%@;L(Lys`7NNxrk` zkW%PHIxe-EBZVsLV(6tk&)HP7vC2rU%%83~&2u4y zYSiR$OM?eopeb9*mSWh(V+Y7ZURKTHEf}rUE8x=h-LJN+V;3Rle6Mn@w;vJn9IfJ3 zvY{4O&n9Hg@1JWg&+muf=i8^3+00BewqBf6YZsQXa8iXz@@O0+^;1$UCmVmdyd6uG z=RgVJz4yskozM2AzceA#=CM|7Hdv8k%8#N7)k)8j0GxkK5#T0)C-gjuW*ugv6i~Ex z?#aBQPudV$y}w7qq)p9(#SiC+&%={#Twde7KLzylP&KDQN>yS!+sZ35L6yRnpB z?9d2#az9<*pkey_X1}GUZOWl)@%51EQh6B%`<1LFo+gOz7BG%bL#I-Xa7FP71S0te zk|Xw)89^@`Q?)4q{Go*DAXlQO63{Cb`%IV^f8)3O&j%->qN4u5&7VrrGGd}wAQcq>tpX3Ex?5`9Y9 zJ|;-^oMZb3vx6!H>MHYg@C_nc#KC;(3RKlV32K9lVH~-$#ZQGE^CmMAq*_i0dc!)z zm{e-Vo1LT!@bNO~*uTJA@?k)@=E??#a0o1#9e$Nf=NJuiWI30EV=(1PEwh3){#+Vu zA)foo^~oq_7~b|>Bb+)~vu17t*SP7zP-AS_;O9L)XnkT{B=DK{uTHeRP5y-T;NNp` z0(C^5K>eLLjL#8Zpi;FfjW|7KoYsg3>6n6}2|Of;P~cPh@+VkP zUHODPaV%3;Vo-xu9yAGuNyuDN0s57xAJM%wv1>gRg`P~*KW+=M;}w56$+n_hpa5mN zz)8yMd9?ow=yT4cbzqe?O1V;td)s)nQCz1*83`h%PNJ=>(Kda5^Z&b$jl@U}3u-nB z=&~<}?EQv1@7+QAvUZMeD&Xw(Wrwxxg}FT{qotCq0H3e>%Y>IZJM6S-gw38^uMsAT zDK7Ca5gjJp2Zb9G=QT%+L!R}(#AT~eholmdFcq66eBFIxr&y#2b@J*beMO*h|6yqZnhuCMz{sHx z^ktbC0fC(Z-HDxG^;n&o_>C zlVwL0jO5Jjkou5_9fWN`|2U$1VlJW2;kp?}WznJzbD!6J>`@yu zVD@*l4AGKqVrHiiejp1X;KuRlvV|x4`mC}gfYtVlSJBu#jY;tIr-Z5g7d!5>9g^(W=E@l_}TMB9tW-7bl}e24};mpc{~r9njHHa*V=Vuqep}L z{d37+r9(UBE(~^BZD4HInJ?LRUpbyoe9^%O0H2G~Kv zqIC`8_q@{@GSHbF<-*LHW|^N4KS?CzN5YmnN6$VK2_A$g4_8__5)7F%m4<@{>a`I@ zDYg>@6&SrKA}dRTE3=L17_*VfP}J+Af*X3t#VRExC_z{X$J|jFoYTg}su~9tIeY93 zqHc8SMUDoipG={A*o9MXKH3kSI2G~ABT;PQj7vezt6@<%W@Ldx)Q4{_!tmv$=|_+p%T0@xC)(J;Vo zZ!@igwr;UR@`i;U1tx-kxDRQPaiTW*C6h#~!~R&+w^3wh_9nP*K}7uNAw;6oj4jsQ z%)RWO-QI1;4m#gUD*KXf=tO+(5NF0Rv=~sGN+b@AOVUV6Rxfe;AxzAVG=X47XEmG8 zBE&tuDzFUBr?%29jRLd?r|vmXB&Rx_D~rW5VocrXdN41&UIz9?Vz64uU=fCty>KMI zxxQ}h-L<$tabo+T-DbuzT_y5VgHcGOF?dd333qolr5Y;jBH@y7&g~9im(}>|o@gbM zxK>&f1;lCrBu}hLb!5xr9Y86w&o{4J#?5mnWD; zSg)xrvK&LrhiZ9NEmU^;ooADD42d)s`n(&8KxEbCE}6?_(@Qr^p=n83a>Mescwp!~~CirhOdSV+URlmW<%Z&+FSdIvFtHuchke(p+2 z84x9Ysft4c98q3Po1{>69Rz2pet>8kc;_XX2@6Ll8(zDjIazSsJMl%kC`yA6S?oM= ztA1pp42>yY&sQJjaV+I>4>GBH@|0K9mRkRl(pT-ft;&e^Q1#IWFlFfyd{KN>jXErX z2@3-B=nbQFg;ZBmb1QrSY$+xF*2gdaCi^?l)}ULaqUJ7_Rdnb7ce+EK*6AxQCz}kEU9QDQg$!$T&lS36Gy8Q zf<`nBlJ9`B%~7}p9g1rh2fXinli_7kN_`jQQqn|q7%?9Pc4gdL#5HrA3Fu7{HCi06 z9J%@W$1YhAH6o$g6d$B5^`d6vovX%2>>JtuB-_=3g$O}3nPvp?)-kX4@kK+0Kg&L4 z1?;nt-Xw^>*ql&J!pA(t!_AT$psduk>Pj2<`mf+H0DC17Qc0m}fM7W?ah73`lsd!L z7mW;g9Xh~g(j-r~oOP2BqZu?^`uYb5Cf|FimWr=Cw)%IX;B}#pU0O~nyT(xFUxeHV z`orVNh=Bw`;f*o}qyd!9Zm~~w21m_(FUUpWLzE3LAsaZMmj6O)n3MOy*QeH3O#)n` zIz^32YoM%ZhdQx@caS_J(2&;>2|yrur@scR;K@q|Pq3+jp}WE^c%Ypg~D6zz-~4#g$l;k+B7B{_hMh z*teaqufgs91K^8;JiFwGu_fWPKR@yQ`jRkn^B?rGjPZuo38g;Lu!~9&&?CoWsk8B? zNx$Wqf7^=bfkj9Gy~cB>?Ei^T<0{5`xO5D5#DVB~dNz#*gW(Zc@rAIT@(3y1o7JhB zrBhTax7R!=a|%S?)6M?Mhu(Va-VrM)fKXWu!4|kr;Huzy4UH@{+oRl@tDwr9R+R5mFQFqw-VfQ*fffZNW0ha?x=e@0)Ss!_)><(avK=JCI8R^$8<<5 z#<@1IUSv|+Mgd$4wC9bWjRI1r$<1}5LBjzI@G4dd(0>upbfXD(TE+}J{=v(>z6&4zkF-ZnX>$ezbkcpROSaFqP8jqh;rUj zO8Ip)4@6l2r*c%6fn)#_=a+qr6w#?j`$1AvZdMulXcff=iGhc3VkKcGHsb1DJilEa z(op=h;w7UyH~d|8K1sMdU`=rWk~kmvJT<1X*;e9FxwJ!v)V$0d^W7LDu7 z0W}{*?DmykfV9n89^o~J0zOD^bQb3UW}8{;T+BaoZSIA^y%Xel)K7Z7E`cv{bE)O; zzGs&)T!UtF=Lpyju2|l<1?`%!eeV_yO_~-pV?I1vV2_TJw>7YJXKjCEvcsy zX;DrN@~U+ZCCs4ouZbd5LX8>Vh^`GVk+xhHho>7pA3nwf1$k`>P( zmR1a;Vk{xy4@iN`7^j%riozus*}+HKZp^swr~su|0aZ?}b}a1SR<_%0sJ(7qRM1Mg zKm#m7X&{fR!FIw^yA);(*DQqK6jEsKTbIL_O0rG=mTATl zlEksAe$vt`-6)V-r=nq5z7Vp_N056enp7=x3Qjm^!)<#lnT`QyaD zabnvuk(m;{KC-oyRwLKi$(AMlP38#AmZ~T=*!5B~;GlS=LS2M5c0@{-^nNNe+?JfOZ7{AvOmXg7 zY);&C8%1jZw(l>gc*aT~$qDoh@~T2AW2F-ytp^G-d(7@aw_FiXn8fZ+74&qKfOEyQ z;V{SR0$m@5V_6Zg#gSNj{L~y5C~W+bS2Kd0Di509uqjfF)liY*Q1xX|7hnK!n9E~$u|$wGQL70DWcLE()3Oow+m<;y{jj^=iul>dV-ay{%xzm`N^ zJY1Amp%3lG?9E_Vv&UZ<+T)+F;av2wi)~n{7dI?Ju$(V7b?Om6t3zJtLCR+N9oP?w z*3ItXZ;gcm|2>?32So86Tw%S;inlU!^^pS;#iqey@ts5k?(IRVDICvw=WkHu2H3}T zZJIw>a3SQ(4R@UPCY=h0V|>~4mo7_3`wO%FRg!T+^d5*K8#4#LmBu#M_}0%i3L=q< zIqBCq_xMeq49yx-!)klxv~DfrtRBcGDk}rJrm{MDQ`woPoUqE0Agv;|l_yAEEuoji z;#gEcP((lGJ{S|UxdR;Mwo)fDSjdTh+DSJoI$Rae>vcQxHn%G@;^!^rA9eFb01H8$ zhXb_vY8hvAzJH#9Ah#*0V)0^y&N9eM6Z0f7@MR#YCW?iEi;l1q+?#?jKjn#7TBP(y zDxgnVEyS7A3n|fFU`XQ6hN{n4^|;-`0V{lgZlpsMEbAd&=#??1XZ(6h(b?bID(if? zdX-UFr6*UN>+RI){6~(JwmT7Y_d@au`S$5;QT)}yB~6Au?K97=PHYKlz5<(G zPFvHug&Wp+whEicCxjt=!M7GEQ^_@x^F*jqxbv&Z*Qfa3&_v7ew>{}kqq`R{9iLph z7YwE=?R+i=P1%-H`dNEuo7e>=KZYEJOhIZ!LcJ!m!9CBC*e_Ww5B-i`fUQf>GE1-Sev0-rZGwqSv`9J@$>ESFOED zpL7#_;vf?vxD&FE;W8ig@tK=GU-jDbo<5x2#aM9oa*Ka&tVAs*eqQW0`h-5zB-8b+ zN@s9Dt?=)6mv2rZ#GD>1>aP%n#ru1us4;)O>B2>v9!A5D`Qpc-doXK;pcGnGzo1S3 zdjp)xdT|&24*-C;IsgFC{}`_R-`lW}ovpK@-G36+Zf+~5P1cs(Zz}ujd(`Im^GsJW z*AXSNMVAGelNO6oiO$Bv=Q$Kei8c8mpg7m2^siT*(|^pV9^zJu=l&FNZn&9Gk(`_y z-^>(`epIQbz;DOz3=ubNN`++V$_Y)?;jD7g)=Fa^Pft(BhJ@u5lJSaitntL)2$~(k zb43*qrAOgkUJi!U_9PP%Ka^!pnu+Fb4T?`0n+#2q>)LL{&#NI?*&FwCwFTQIuU1)N zH5DSJ8qY#Q65gTBi>n3H&8O7nJ<6z&<&hUnl2I;6Yzp=NP&_^n+S33(| z9h+AFlKgv!_Q*!dPAMxcp<=BbBv3rOUR27)!a`)QT;*=yvJ063J_wacP#x`(^-j~& zBf*Q^cKJ@i?L~ec6C%f)zWgpdH;Z}uZ!KG^@%>M4Y@}ssw+0~NmeXl}WF$9_{+4sD z9OE!~`CB)B?ar~+->>`J@#j{$nqR*6^Ha52-JXxnH)(+0ZSQF-ZrOqc*j=EIAxr&o zDNgL_KQ|Q$5xKRK-+?@TG`jWa3>uv^>>sOZjskta*>&q~7jb5E>+r%4Eb8^`-oV@L zOV&}rLf$+Ycl-bO*wBSmPi%ktA0eP;t<-yt9!PfdiZOC?PML;V31>Yb=A>uO6KC%( zRvlpth0Dw@rY9X$>ZyEcT3?#%RA}tB_RmkJ$HyfS@WF}cf3B}+m6*Ch8zxD#83nO{ z^Lq-d6cUp9ZY3DQ3^?={^5X&#b+fD_c?22nrO*(e9Ps|0WpZ%&O{A!(%+V{;zx|TI zO%xk9TeAaytYXdBGpu!ZmZ}r%1Q0jo`hC#CnOejELI|NP*v~T%#?PJpfE*D852Ols1K|Q%S%Ypclc?MZ zpkV0&*3_%l-{~w!qpL1wl^{;N7VOkDZ8au5W}P}4kqKP;=p)9iGH~fcecYdOvsS*3 zE>elgjH{&FxbwEUMa&RrynAN9IR*3uz=mH^3JC6XkKwViIeWu1nd0&Be7>C{R=GUi zFH(cSSTA-+`QOOKScIeTHg=iC8qEJLv*~-2y#5S)e0&X^5~mrX8R^t-(syr#r^%P?=Wm_GU(deZ8*-M$eFMXf@)fy zryn9-+s&|Ro@j5*+ZxeP#Z*^#00P@}=-3Lxl@*B*E%IFC#}w%6f`nmbmYQs+SVz*Y z$Y6v|KR_giUne=!BpK$c-%BW1&^tf*27?>1@0T2g@Ti)$Hun4JL@Ew@P1o^c&E*>S zQ(hs~ng@83ql1nfpuV`1(HaB@Y5S$p*0!mH_loBoYMxBNX@+kjUL!ea5)!8AQXY1o z!Qx_uF@&ke#h(R?yX@heJApJJ+|MKUhjG`< zzu&|JqV~8bVyDhObN9miMuMZ4-GpR?T~~HoE)sR=A$QqXeiB%WbI0_9mn4R80wZ4H zU#q~-Q*mJzC#NT_F@6@}LO5;8g?=W}wg?2h)hcWQ90YXZs}QKF3_FI@aa^V`yBuR? zNW!?J9N6WA-%I|_@T3b+K!tBv8E+6M8r(BW*`29yPj_z#nW5wa3y}*ZWfR^dWy}Pp zb$Uh%OgrqlxpciHQ3$57)E>~M&9 z6eFF()>FHA2RsuborqGkeC9q2zwpRC&}zvXW3-Sr1Vj^-!&&nTTi{n9MJ#O(#fW?g5`uhQL3E5zWq3S&{mH(+akjmk1>zhP)OjPu4v`nu zdB@gejR^dDwQAp|2()Tb1xv<6FK8Uw&A&rj_lK5VxTkM>{*4qc$LBaW+ULtzBKrB> z@2IqNM)Z?^bmW}zlquyC!yTB5_RR?^L`4JiWvi^bD&Dv(gaIA8#oE%yr0=qK z6vxOdw5B9W)#r?9PDWi!tKUEsGYN{5V_~gqQ2g_DhSZt-D*Bl&-Ltw;W9H?6wQd6w zg{F;8&EGYQcMAW^-DS);oj(@Hq?i>QT5wK?;Q;fO_Lt~BSM$72VLQ1o6Y!8@Ts6SN z6U11Uod9W9HK7#%K>vWXIJ%hx{bGRq`7wOldzbCra*kf3QqjDV#TU9iw+PFhBd4CdO%t~{W@u3xr z8}ty+K^K7=t_p__w#Je_Un~Z?X(o4+hUNs&2Vg$z%*aVHzvXqk<+!@-U!$~7e*iv@ zFRzEei)CMEe&vi!IQyG|sjT4r?1faF!}K%%u!m)DGcSyNUV9Kh?i27NoUKrFrC1&p zDvT^H=lVQ0Gmy%dxv}7w(yI^G2=twB)>E9QR#d_)1e0?nPH8LE*GPr6oUlBgnO_}Y zwlT)pnXrAmIi{F~I;oOl5Cx4IvGXarH<&lJmnDXz;6SlpaucTt^mS*WoQ)s-4R<;$ zZ~DCfP`x^kiGn2PP71tMcDf0|b^S(=_H3`>YEUfpac?24x-17-bs2`#ihZ z8vQotP|@dSbgYrhp4*CE*e}t0g*wmgO92KzS#XV)3s#4AODuQZ-Dlz(3 zPi7d+xvV*SV;Ai@p1H5n>i%QVR~wa_1p^#)-rtM@a>YN~FU!AGV^# zY44a~#mY*R$lA3xK&BneA?`;g8IkS~tPh|XK&^aKO*LpXiKYiYzRfX0Ggg=lR*GE+ z0OM!rWfyna(E%nty9zZFe*WsPbdq(;8ur>7D3QG07gCt$PT+<1ZbFn1p=D10aXKn* zCa-WpM0~UuG*UH@+?>s(UVeWZgGBn_qKCSI*-a(R z6)|y`{3ZY2MO!>)l__J&UHrKr`y~`$RTbecrRNPl2?|5WkSa=f6Lwbx6oLf%%5g+1 zl@T6J7I|xKj!zRa)3P*Pog5MKs*3Ej7gmRs$ezMZOzBc)I%9H~bAo~C{>9<)J!Kw`0vkkmN;N_N$jN0({`W zBWxk80L@@dnVUV`UOpx**EC9*>)ft+Di1c=>$xuIUkd0>WU!GmgGC9`>&te|Y``KN zNWcTiIVt?rjDRghkotB0KruoNjR&AF=5Aci#C1}d)g43tOHR#>fu_LW2Oz32uKGu3 zI?EnKsw-+13Q1<8L{mw(!)UD{UCgyKA}ygS6v(h}o)xI$Kk%^v(axR{mXve6# zppvLnC#ib$d3N-isb_eiOVlYkKbLy?`c60HE`Cm!o%$}6P_+(1*H8+JG>Q-1;qY`H zKaJqK*n<+>R>F_n)~LVyi27+5gdxlok=kT?&cz>~|EB#dBkc^b@S5s}mU(@VimlmC znCik)MtvmW*1N@;Yb8hv9|cRU8NvnGe(h2w9VWV~>d=raIfxy?o0WSZqP>!;Ej#4E?y1ih&D*WuFqnXW6z0z1UaE$Q52Ji0V6MTCe!#$<5E7=_ReT&H0)GnDa#)+2W>P1n(i zp%Mwp_99U@Que5DcJ>f?m=Q$#e;0>f6-&m ze{ClMv>kIS#(dXb_Z6&8;S3d7op}S$vdD4a2*AEv`3xTW_SZE*gc4M7Oa#IR3p+?m zYErR!aa&OlYeo*ZhcR!^p~GFM*6VuPe{>|YQMFX&y%pi}gE}Uahv#LoFR8wU4u~6b zXFa2aA1#jR1*9#hsG`dK15fn?rpx^iQlg+LzL^+Z+khcz^&(yd)oy?D{e89-%O~~W zYM$4yxBhw~F|dy4Jmi^1AjHz*JBw;*Ld3W2&zaigb+9%r4{(-t?Pwnhwb4P{oxkxd zGFJ=%OwO5(6BIv*zHSg!x|p9Q=9@Ns%wgMaYvH+4?pp2W zLAivzdk6N`Io03dZsHhwbd_uVvjG-f$|?YCUX!w?l|0{s>$O>4qCsMk{mJT##i=za zvCuK0qwOAt8||*Zmfv#T{s2r?5HRpASFv#cA*P{bCp(X@Mh-G=LFQG(;4{Qj?l5-@ zwaLIzHmbmOR*qZRGG%~f1ACY}Y8CUlnMri+6074KaY4(w(Q$mehpQIJxrp;7AV-+} zg@60mV0XWj$-Tn41RcPQ)(o#D62txIpP@vkRd7H(VUhu>Zu8lnZuW$3>HbR*^Ow znF5%E3p;XnzDLXZVcA{Ai_&dOJ; z(D-Z%(Jf9D4`1 z`q^a6%ZaNvJ#(L|I#<&T2rl>mmkENm{O2qRta(%e_sUH$VE8HL*~>7|tEM%pO85h_ z4P|n==B&1dEr2-H^fW@lDB#)=iN-()*W5m~d$j^5O|=hxHO*UEUsJOsbNiAskDOd@ z2I?SVgdHRL0O8n~CGR4uY38p?(p+@zj6flJ2KE&{8h_sFyS5h|z@O6H&lA3G`n)e@ zytgJ8tG~eE16kAbIS^{bgmJHcI%bv)@waP*2V}zgZ|t!WVc^dSOSE=X=L`)2c)H}i z=t_;Nw;Rn2DhLm!_!MVbgXlcL z_eN!Z!uQ1^A^EuOWZYO-W2OmN$a<~%2^qvn@e2CSd};5hVdouX>E`tdrBSEPEPMm} zZqDmr`S=z~*94+@Uvop6lOC7-BmOE)-`)cl56R_1KN9TVGI$2`9}f>>j%`sZKE&((v#!#(51XD> z8Ckx*g$I-sK9V6f-k2q3v3t!x+dh%&H`7_;XvxrpVbsOs_TRV>=(*yLvLJ7V9qu?V z0Za&Jd}2+p-qNuXg`#tO6l^<6vOYzHpTP>Athuh3jm{ChbP3Y%+vy>^oU;cp?p-T6 zV8#|G!7>fhrDvb#H8s~_N*z{wvt8T@kQprv!R;*%T^WhH1XxG#{@f}`_0qDNrIwkfNsLzGc{B}-`TiE82m>OwgR*x! z3JeL8SzkKgZ9{nr|56pCWoR#Y0)+4x5Ocm^f|04xS~gzGKIt1;Y8HIwLFFcCN4OAq z{CIdF4Xo_V24~0`_L;zx84+3ko7(#J7>$=S-GVw~BImCj zd)vMt4qn@XKb-nU&UDy=4-L$wLG zF2c5`g8wD@H+-U`&83%Eb>Vg|OT1RVeE+Fse)XZrO5g{1%SE!`)jRLH@|OEtaO<}I z5y<1EEM_mxBuGze8qfGJKT50`jlSvk5U@`D1kM+Sh0k6749WsYo5K>83h(4s!HF{g z@#hIT>8%FuWzfpTNin>j)6TA-Reyv|_xtW(8OuASYT>U?Sz-F`P0>tKYO#gLKn3X< z%;dxu@T_!YZC>fsXY^k@Zyaf9t-{%}LHfHoTnoR~lF9g@l=In=RX&Y+uEZLKSRsyPxrSZ4=gjdJL&?YQlcLhJKfDI%VG8jd#Rzn|F#R}((#j?v!b0Y!;v z&Ddvmr|cWGY5AJh10dHGHCq1>6gFf2aMZpW-S?>zjMY?2J@gG9QN$*WgMiDqOBI_V-t1ZQ7qrT}C< ztYOnZhz~G%=&~iOqSCP5niH%U_D`1Bl2BZHZcCf-FSTp7|%AZT5nORpP$!z?9<0-EZ(l)*Cw~gDw?b$OsDb+MU@O9x3Mjm zcgWqgOqO#!{++^7zI?o=e=c67ku+^Tp>ve3C;ZiOE4=ntnm3~cQX&=Q{aKp#4W@ey zdextAz(?M2r8#dtryT=YisoZ2GTQNzXMd8SUy7hx~~coj@dF}<3p78 zZk)uOVPj|or&11mbseU8RHU&a$=0%a=IyP-&S9X$kmkNYW0?lChakZQyj|=E}2_oZpYp$KImxZMVzEpViwQ zuCNdln7X7cz1rs1*}3JbKw*EU8LQU2LtB}d-wNrx7r>?-gS)CDR3Ut@GHX;_LSDfl z6c-;l@%~$keAM~|k`2H=ur?MFLm`2tLIhS28>)4|T{16_0IohiJ`WSPB|kObQBT8jR@#SbtxRBO=}jA`mv0;EQq{B`=%!8CtpC1?1%!A+saZybw} zxWR{GTcVSyOorp1jt1hfE-wR5aZK{t`5IvlA|&??3|K5JJ#L)tZ(0V6$K}d~LY~@1whv z_T2Xb*P&y%deY~kNlqUuS0A{Wa5G=`swAS&|zw!cJOg>hR|Ed<>7z^$!Vcu$g zRfmVR7{S; z30`tAo^ad@4TgGovD6TliSL&od(ny5x+>~#P*xFrms5F;49?zcrMIM|$=!av4s?Rn_5%HlAm`h&7Xl@Yoy<_M^lx?i@BDf*y18$O}I%%IC6 zc~XVw8GQNJI6HNAagFNneKDJ{Pm~JolIO};i7Q&S433hbk;Alw3QH0bgpL_3jgFNg zI~a$PedmYKJyF(QtnEBo>D{ROqgTV=dWEA)zZpuTq24&h%Kc~vVN(*O zVe&^uei?3hU}f!oCqW`ZNkZw5Xry%)w?nkukIY&0yeYF}Pko63+m@4(JH)UYrg&@_ z9cx_2tW0L1VfhOv6*5T8wtQ!2#Xr`SMK7;e5&Z{ikp9;R>$A{YV?p{3qIn5*b)1{g zt}yZ1xP793a1ULT^bOR>hdv0>I8Wz7_zh8)-6GE`>?+3WL#$TONzmI~s z%rVPvW)r*OqrRRKZ+J@4OS7j=2d6w}tt#bzKXRkg(!=(mFsx}G@2cOx^_*pSzzn2R z<=g;d&+MKe?q{G+4wHv;vsJ}B`U(*PAo8ATsF3)AM%=9O6HcxX zRJnqrE5<@3_>^v@eZDDRz?LnwIS+eULU>GmU!WE&ewJ0~jb{xGA;(Pb$RK(zYXont zU}Q52Q^w!cI}3GUx!U@*n#%sLldc!mxb5h(a}>#hT$ZgGt$~SFx>24r`I9%C|GV~( zRlB9}?T65zY?)N-ey6$VE7^I=W4q3y}6JgE<|^Iszj&?j*P0Jh4NR4 zgUAGdN~_v$E{zS31U|4Hv6^Q>g`<3QENd7gxoAHG|@llH)iA1 z3`_?WVt*{%>!%3`B%vc849v&Vml2-mU%K#n!pS-Iys*!=Irw$lhRxxiYg1oQNC0YpkUQ~=&q+Kht;mpKwDxZ93T1OCx(*ok_AF<}|=yTx);!%M+7z7C>^XBynkWV1UPH%`znc{~W+ zm|)NEQs0;RDA{N(8#`cXE+(X#lI&9lA*v!;1DQusu}(>8G^UZJ>arkT>Jn)U(57<9 zF|kV){nyb@QNXiyYp9herK%@Z$S~h4L#nXoz)#Hx7GB#KYVw5ctZGb#p%>(2JL(F| zROeU>pZVAmXZ2w1e?CxDsOp&GpoAJ~8UZCp-8rL`kMA+l=@>aWK;Xnt9s!#-6P3H6fHUSCLqu`Pw9JmQlT_q;f-Io1`dl03} z?t4P~xO%vl=JV6->Fq$N9R|l9YxQarX`xy_r~k8&W|c%`qDCP`Qq%qyCLZWj=%CE7 zr@UExc!3mv6~#%E-gqL+X+cV}vc*KO4^&*#xIR)}oE*f`dQT?}9@Vn-o)QvF_>fo{ z3-KZQFYB@aO%66H(avu|ieyVXj~yg)qIkT*F1eoA&>ki_qoOQ+%9}d!`4R|ONKm&j zD)53@YU1P^6qO4!$SR6GJlpW`iD5%hPGl2XdMWfMU88ih@JHGwzRn#M>c#nR!J}>d zvZFz(s~3Y;GUV5l;plbL)ghjm+HKUNo1Z~BnHe16$0ccsELGsnzuNNsT;w09lA zVv`)}z3-n!4YYC?Dgeq5J7RIw#Fo7^sALo0VQ4GR7J8I&If1hg<_#@Ic*1&CcKk6b%YVVYBu?OSEm{#A* z>W>!tM=KHD*MO@gT~6=YwF%s@#&t|~35?ddeC%PJ(j8`9rnlDz&+p6CC$U&Q7DkE4 z7DZ$```vVbo&6?CuwSGuZREjToCgZ*)1&hUj}lxie*DMtqK0$HW`Z@sZNY1@)5vuY zFA`q9XWsehjF8EkgpL1DKA|ZS^B`0=^mk;L);W*mF+Rer>RC$=zZC$^C6G2vI6^Q~ z0Rf~1Of$^EWGe4Yz*B+WJaF6`ogN(FeL$K1l1|V`?Msi>r}kI%2GX_cpRx`GV0TTY(y76lc_`ou$o5y z+ZdPIjwNbIBDUtUbqk*@okiyu_OTNbQ}69q5p8^yGz_pxd_4M;f6#jPTXr_n1tihB zsAg4vbQ)=6ZLT->zWWP<(FcWNkz|}KnUO+&8LYtcT`D*_RxJ{l`g*#HO7aN_IJ)Tk zew~a{5~{;o*@E(*aZ27fa?t6_N(EyAV5A9ayzO$g9I&mO{@|iov8ebhHr^XXbG-TM z0>&)i#Hl6?uvFr#hxXNpGvNTyz1QrZfgn75#kV(qP29_cJv&pH1ODpL)4_I_)b=`2 z2QV=f#ON+>w_#}g%s*X?`^Htw@RrvUnXD<({p1W=XQqqgC+=<`CGO1Tmv~1hvIWf! zzAt0v|7z?^;G(MbIDWxg%3a)jCKj5hpeVS28!F_U3q8qg8fGpqG8=R6ut-Wns1XDy z(Q~(Ql&4mjSz_k$Od|m?4b5FJHId3CpXJ`~&N#q1bI#P&`@xT&&;9a0|NWeqd(P)` zinn!tqry%+FuebZ%s%%w>C+g;tlMZS9oPSA9eb&AyvD@K#Xd-O9AR6TdpTJY!Ptd68)kQ%b%Tb_eATU%tPr z>Dlx0H~C#>9h_ZvUIc{zKhUcd7}>g6fti$Vf@zPvJV}c}2Hm zY?}V+(YuEq&br%W@^~-r*7aJWTs0Dm9e$l!J>mc5>DYXBBu+o^#s9i4yG{8Q_Wbwn z*EgVVK)(R3PLlm~#u!td31dfvPns4UAScT-ZQK`LnnNJ9$2ls>cDAm|Zrg|7!K6(L zj|>|f78ypP49z+Pz1UU|e(UMnk+l|epdkk}HGI^|Q%BRFeFZ;6sqnNBcSjcmKkc^e zSRZ1_G<{5X_yn5sNyVszL-5>u+}#MyZXQR(H#SpLW)n_LkXY&}>hhocXdnb=On8n! z4(Y-XO*WZTdNC2FE-=)em0y1IdF&=!gc}>#)?9X5x|3J8FQLabGxVdbrzI!~(Yw(Q=b-{G}+P>u2(U)N=~wGLsS)K=M~F&WHyQFgutOUqVy zc2m|8EOIu1S-ZMu_-VI|8OZ`ht0hqdqCsucGKSiy{`BL0;Kaua&X;msM7yp1L>5kC z(3;GOXc7a~`T95W65$F*>Is6Mi{y|kBc2I!iUsj-wn(zFsV63C%ufn0OhZ9Cp|!#NE}Y*|ig?cCJN8Qs0HI*+}!;kz}L-F7;k z%R_u>;u!`#)-dx_YY4X%X7H;)DViI)j1Th^SN}fz{odCb2|@@Cym^5j=0Ty9r@4j; z$Bog&S}kf$u; z`-`+_i%)QIdNfcB)-y{3%3Gl}{0lvquS;L}X}7(2k;{@qwMD~H+8bXMjBE!7ehY&o zm6lS)r^T6)7?Nd-Z06G+$}hl3$*NU)lgqLi`D#0PdfA6fA)Gg&iwyn|cep^;5mU4c zdY@Q2Z5bjeXCOV&w;#E~JV&Uo!sq>1FG1J~*CoS#PIE6R?3F&)qKn4)S15m;ivHLI z|EoU({<{RxN~-UfmY$(XwPx7E(6ocW04e_jvwP=}pO{2sC4i4BMz!>Vh|SJ!z26s1=hv893%*&d$Yc1>sUS9k~s9v0)mMUN357lk&+k?a#Mc zj_s?0pKMr4PcKTs*fg_R6R(aHRWXXBEM)8{@9J@_1R;MoJz9fEBlTjeT9cx(h>}U4 z$nw4o&CUk3MgukpnFW7qF1zh^k{isVaTG&VN0BhGgMVvy@fWz;)KHXsHzJ+pa2mPP zLp>ga;!zAs@Fft7-*iKuvB5!g9_Ab)+dkJ|EreNsRM(ZD2^k!k25q!XtCm@MnjP9| zOFr^Q0(8}#z@1;n!Nr&?2DR*HfSoV+(Y_IJu~)ldi0B6q$*IVWOb*lGy$m-C-@Ry2 z9?H#T*br&B=Ca$q&f=i-IwPz5y1Xi}TAA_{Ak@iHlbOdMN$BJZETtJ=C_f&DbP?i~ zgdV@gV>wEoO469jEaDHdUpRRUlF1k=nbJ3|;1ZSKL|RvwEn*DIcRSYCFD`=(endCi ztwwc<@19)Efy!!2tSGC@DRP`+LnGR>OD`u(90+6?+=Vo4)khp8FH1J-VjI^FQYkm- z$TJIQlu?wEOqO_0anV-ppPPz#iK!PYSt%EXi7TrsDQtE7(FVlC3{34wS4rQ_lZ-bl z4<4t_eg;j1jAJ3lQECf$EG@tPy?5n6WF>lOBj)tJgh@Zy$HPgY^kjP~+M0!vAHPx` z11*5pkpnF)=g}M|X)+?!U(lQ{ga;2rFHP2}rYCu0Rq%6#~ zLGKel$XtBopF#Nozgzrl`UbdG73Lje97R=oVDskU<;x$x-4GLn0~q{sgs4MrdBAaJ zl9lILrv`)5A9rtpm+{a8?@6cY$-$yl7WNE*rM`!y6uRrO+v+{~2V_yJlhx6Bk*`_3 z_|u+d(CmqpvTdY;n5&jS`U5=&aF(%a$SmOU95zXk0b*{!ER@8lwiSu_Xr3zpTfta5vBPRYDN zl#HtwG}&?v33CIbm@THcsNam(-2a+cupld&+-hv^@iYgkYo46vr7%W$ zPEBH=ur`G0qE+enStHyoWFKk?H3g5MYiyB`cj?O|>*=kvWshCV5VWIqv5%!aAWX049tYgZ3mvGzwHS&#HgcA5pHY?ks7 zgqmg3%-McF4?z07gZ7Y2_H9nHQCboC!Z|5q1Zc)Dx7rWGFeAY1Mpz;10*8mC2Z#1l z=&xCkRT3DLXauqckfa%!Tx26fBNoARM%JS1gT%C1N^yS!wU`|5j!QfkKKXm{!JqqF z|9AOz)h)D$i`{B(^v`Ub67*7vB#Stg&TZ-7=M^cP1usDeg@|N`3T6tGyJueijTmB2 zq;Y@3Lt-DWQ97ei4OEhdjmbqM6r*G|Sy;}zPz=hS3JI$)Zz5xC<|8&*Z;Fj&JIcA8 zK7Di$^D->)JRxRP(|T0ta|XXbZ9%4UBz2Y>=V`O%M8T$)MY@*eVV#|^WJDzdy8@yg zp)&OV4lO>`u})>RXqdk8+itsU5ZtZ|(>k&h<oeqHg&*A5RKWbevosF{U7!o}{M}B7^%IbMolys5RaU6_MaT2yr z(?X7J{Q%=Tgz=FL?wuRZ=Q#XqG|FIC!q)~TvO$SDi)>Zv+21mVur@l` z3r1XoG)ZR4iK%QHuLq}(fp*Dew{6RyNy;AC9$E(aB;#6C$RZZ1=3HZXErULSvldjG z#R54G8n|kx+h7{EPC(oTGqOCEEchoI1QusU8{v{-^PNu?ZQR_=@-vx vfln3FK!+dHc@2$b(O)gDWf{w#u-w0BJb8S5^w~)9_;aQkRyod~SPFjuPi5Z> diff --git a/venv/share/python-wheels/pkg_resources-0.0.0-py2.py3-none-any.whl b/venv/share/python-wheels/pkg_resources-0.0.0-py2.py3-none-any.whl deleted file mode 100644 index e066bc741edc8d6dfade490f18ec62ea7ffffc1f..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 127312 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 aG)_=gLU=BO0092;vHE;wwEt{Zz<&W9Ieei2 diff --git a/venv/share/python-wheels/progress-1.5-py2.py3-none-any.whl b/venv/share/python-wheels/progress-1.5-py2.py3-none-any.whl deleted file mode 100644 index ec396717939731c24396ffbf5f5dec912b0e2147..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 17547 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 F{{U6inlu0a diff --git a/venv/share/python-wheels/retrying-1.3.3-py2.py3-none-any.whl b/venv/share/python-wheels/retrying-1.3.3-py2.py3-none-any.whl deleted file mode 100644 index 48b9fc004da63c7ae3dac0749dafed6ba66cacda..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 16358 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 diff --git a/venv/share/python-wheels/setuptools-44.0.0-py2.py3-none-any.whl b/venv/share/python-wheels/setuptools-44.0.0-py2.py3-none-any.whl deleted file mode 100644 index b352c67e0fc367c841b8dbb6f76f8788bf8effe6..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 477446 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
aWIfsh#V;nI8v;f3CNN51*q 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 diff --git a/venv/share/python-wheels/six-1.14.0-py2.py3-none-any.whl b/venv/share/python-wheels/six-1.14.0-py2.py3-none-any.whl deleted file mode 100644 index 0e572b2e940857d726d5e3006096e74247c60dff..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 20256 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 oikgX!$LIBP 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 diff --git a/venv/share/python-wheels/urllib3-1.25.8-py2.py3-none-any.whl b/venv/share/python-wheels/urllib3-1.25.8-py2.py3-none-any.whl deleted file mode 100644 index e0851877d07e201e15640b32bab46edabbafdfe6..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 127041 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 diff --git a/venv/share/python-wheels/webencodings-0.5.1-py2.py3-none-any.whl b/venv/share/python-wheels/webencodings-0.5.1-py2.py3-none-any.whl deleted file mode 100644 index 4fd5bfeb72c76d85a4433f322423ddc499fb43ac..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 20484 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 Q=va3PWLLyOnf`eD4?P}r4gdfE diff --git a/venv/share/python-wheels/wheel-0.34.2-py2.py3-none-any.whl b/venv/share/python-wheels/wheel-0.34.2-py2.py3-none-any.whl deleted file mode 100644 index 2fcda361e67827f696f6255a1b2cb5f90443dc8c..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 35611 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�f``%?xk`|lba~?R#7s-f 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 KGB8B7f_MO;o(lH> From af8654176404ca0abc1d8ed42b7b808f096d29d2 Mon Sep 17 00:00:00 2001 From: javim24 Date: Tue, 24 Aug 2021 16:39:41 -0300 Subject: [PATCH 05/11] Agregamos descripcion del punto 1 --- telebot/telegram.py | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/telebot/telegram.py b/telebot/telegram.py index 9e283d9..5f41881 100644 --- a/telebot/telegram.py +++ b/telebot/telegram.py @@ -69,6 +69,14 @@ def get_updates(token): return rsp.json()["result"] +""" + Para refactorizar la función register_message creamos dos nuevas funciones: + register_db --> se encarga de guardar el mensaje en la base de datos + send_txt --> envía el mensaje de bienvenida + +""" + + def register_db(sql:SQL, data): msg = Message(sql) msg.add(data["chat"]["id"], data["message_id"], data["text"]) From 426d4d19a84bb3627101ad1ca5c515b0e9bb5a82 Mon Sep 17 00:00:00 2001 From: javim24 Date: Tue, 24 Aug 2021 17:25:20 -0300 Subject: [PATCH 06/11] Resuelto ejercicio 3 --- telebot/telegram.py | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-) diff --git a/telebot/telegram.py b/telebot/telegram.py index 5f41881..2f70fd9 100644 --- a/telebot/telegram.py +++ b/telebot/telegram.py @@ -65,7 +65,7 @@ def get_updates(token): BASE_URL = f"https://api.telegram.org/bot{token}" rsp = requests.get(f"{BASE_URL}/getUpdates") - # pprint(rsp.json()["result"]) # debug + #pprint(rsp.json()["result"]) # debug return rsp.json()["result"] @@ -87,5 +87,10 @@ def send_txt(data, tkn): data["chat"]["id"], tkn) def register_message(sql: SQL, data, tkn): - register_db(sql, data) - send_txt(data, tkn) \ No newline at end of file + + try: + register_db(sql, data) + send_txt(data, tkn) + except KeyError: + send_message("No se admiten imagenes, tratá mandando un texto", data["chat"]["id"], tkn) + \ No newline at end of file From 8c0a37de3469cc38074595d0af3213e7344b5ca2 Mon Sep 17 00:00:00 2001 From: Gebexe Date: Tue, 24 Aug 2021 17:29:50 -0300 Subject: [PATCH 07/11] comentarios sobre punto 3 --- telebot/telegram.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/telebot/telegram.py b/telebot/telegram.py index 2f70fd9..521c0ff 100644 --- a/telebot/telegram.py +++ b/telebot/telegram.py @@ -87,7 +87,7 @@ def send_txt(data, tkn): data["chat"]["id"], tkn) def register_message(sql: SQL, data, tkn): - + """Tomamos la excepción del error Key error para mandar el mensaje de al usuario """ try: register_db(sql, data) send_txt(data, tkn) From d2956c37139ec64f916221339610ec6f3f2feef3 Mon Sep 17 00:00:00 2001 From: Gebexe Date: Tue, 24 Aug 2021 17:32:42 -0300 Subject: [PATCH 08/11] correcciones de tipeo --- telebot/telegram.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/telebot/telegram.py b/telebot/telegram.py index 521c0ff..5ed78c1 100644 --- a/telebot/telegram.py +++ b/telebot/telegram.py @@ -87,7 +87,7 @@ def send_txt(data, tkn): data["chat"]["id"], tkn) def register_message(sql: SQL, data, tkn): - """Tomamos la excepción del error Key error para mandar el mensaje de al usuario """ + """Tomamos la excepción del error Key error para mandar el mensaje al usuario """ try: register_db(sql, data) send_txt(data, tkn) From d4a7fc450bdf62d25d512608b6b152b91b8ad90e Mon Sep 17 00:00:00 2001 From: GACB-Ar Date: Tue, 24 Aug 2021 17:40:40 -0300 Subject: [PATCH 09/11] identation of documentation fixed --- telebot/telegram.py | 18 +++++++++--------- 1 file changed, 9 insertions(+), 9 deletions(-) diff --git a/telebot/telegram.py b/telebot/telegram.py index 5ed78c1..0c6e801 100644 --- a/telebot/telegram.py +++ b/telebot/telegram.py @@ -69,14 +69,6 @@ def get_updates(token): return rsp.json()["result"] -""" - Para refactorizar la función register_message creamos dos nuevas funciones: - register_db --> se encarga de guardar el mensaje en la base de datos - send_txt --> envía el mensaje de bienvenida - -""" - - def register_db(sql:SQL, data): msg = Message(sql) msg.add(data["chat"]["id"], data["message_id"], data["text"]) @@ -87,7 +79,15 @@ def send_txt(data, tkn): data["chat"]["id"], tkn) def register_message(sql: SQL, data, tkn): - """Tomamos la excepción del error Key error para mandar el mensaje al usuario """ + """ + Para refactorizar la función register_message creamos dos nuevas funciones: + register_db --> se encarga de guardar el mensaje en la base de datos + send_txt --> envía el mensaje de bienvenida + """ + """ + Tomamos la excepción del error Key error para mandar el mensaje al usuario + """ + try: register_db(sql, data) send_txt(data, tkn) From 821f71348fd1fb903e431826dd91ec73030a3fc3 Mon Sep 17 00:00:00 2001 From: javim24 Date: Thu, 26 Aug 2021 17:08:32 -0300 Subject: [PATCH 10/11] =?UTF-8?q?Implementaci=C3=B3n=20de=20offset=20para?= =?UTF-8?q?=20leer=20mensajes?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- cli.py | 4 +++- telebot/telegram.py | 4 ++-- 2 files changed, 5 insertions(+), 3 deletions(-) diff --git a/cli.py b/cli.py index 2292960..a313a79 100644 --- a/cli.py +++ b/cli.py @@ -16,7 +16,9 @@ def get_updates(): """ A wrapper que envuelve la funcionalidad de obtener updates desde telegram """ - updates = telegram.get_updates(token) + offset = db.one('SELECT update_id FROM tlg_update order by update_id desc') + #print(*offset) + updates = telegram.get_updates(token, *offset) for _upt in updates: update = Update(db) try: diff --git a/telebot/telegram.py b/telebot/telegram.py index 0c6e801..eb771dd 100644 --- a/telebot/telegram.py +++ b/telebot/telegram.py @@ -38,7 +38,7 @@ def get_chat_id(username, token): return -def get_updates(token): +def get_updates(token, offset=None): """ Obtiene todos los mensajes desde telegram API information: https://core.telegram.org/bots/api#getupdates Ejemplo de rsp.json()["result"]: @@ -63,7 +63,7 @@ def get_updates(token): ] """ BASE_URL = f"https://api.telegram.org/bot{token}" - rsp = requests.get(f"{BASE_URL}/getUpdates") + rsp = requests.get(f"{BASE_URL}/getUpdates", params={'offset': offset+1}) #pprint(rsp.json()["result"]) # debug From ea20c6d15c4b5fc4549fee49f303d747fb31ce6e Mon Sep 17 00:00:00 2001 From: GACB-Ar Date: Thu, 26 Aug 2021 17:20:42 -0300 Subject: [PATCH 11/11] Agregada fucionalidad a 'get_updates' (ahora devuelve los mensajes sin ver) --- cli.py | 2 ++ main.py | 5 ++++- telebot/telegram.py | 2 ++ 3 files changed, 8 insertions(+), 1 deletion(-) diff --git a/cli.py b/cli.py index a313a79..572e81a 100644 --- a/cli.py +++ b/cli.py @@ -16,6 +16,8 @@ def get_updates(): """ A wrapper que envuelve la funcionalidad de obtener updates desde telegram """ + """Agregada variable de offset y pasada por parametro en update + """ offset = db.one('SELECT update_id FROM tlg_update order by update_id desc') #print(*offset) updates = telegram.get_updates(token, *offset) diff --git a/main.py b/main.py index a59b0d9..7280ae0 100644 --- a/main.py +++ b/main.py @@ -17,7 +17,10 @@ def get_updates(): """ A wrapper que envuelve la funcionalidad de obtener updates desde telegram """ - updates = telegram.get_updates(token) + """Agregada variable de offset y pasada por parametro en update + """ + offset = db.one('SELECT update_id FROM tlg_update order by update_id desc') + updates = telegram.get_updates(token, *offset) for _upt in updates: update = Update(db) try: diff --git a/telebot/telegram.py b/telebot/telegram.py index eb771dd..ff89898 100644 --- a/telebot/telegram.py +++ b/telebot/telegram.py @@ -62,6 +62,8 @@ def get_updates(token, offset=None): ... ] """ + """agregado parametro de 'offset+1', updates ahora devuelve los mensajes sin ver + """ BASE_URL = f"https://api.telegram.org/bot{token}" rsp = requests.get(f"{BASE_URL}/getUpdates", params={'offset': offset+1})