From 751ae12b06e0300b8abde6add2b4c85d95a06a31 Mon Sep 17 00:00:00 2001 From: radinpirouz Date: Fri, 13 Feb 2026 22:47:16 +0330 Subject: [PATCH] Removed venv --- venv/bin/Activate.ps1 | 247 - venv/bin/activate | 70 - venv/bin/activate.csh | 27 - venv/bin/activate.fish | 69 - venv/bin/normalizer | 8 - venv/bin/pip | 8 - venv/bin/pip3 | 8 - venv/bin/pip3.12 | 8 - venv/bin/python | 1 - venv/bin/python3 | 1 - venv/bin/python3.12 | 1 - .../certifi-2026.1.4.dist-info/INSTALLER | 1 - .../certifi-2026.1.4.dist-info/METADATA | 78 - .../certifi-2026.1.4.dist-info/RECORD | 14 - .../certifi-2026.1.4.dist-info/WHEEL | 5 - .../licenses/LICENSE | 20 - .../certifi-2026.1.4.dist-info/top_level.txt | 1 - .../site-packages/certifi/__init__.py | 4 - .../site-packages/certifi/__main__.py | 12 - .../__pycache__/__init__.cpython-312.pyc | Bin 317 -> 0 bytes .../__pycache__/__main__.cpython-312.pyc | Bin 632 -> 0 bytes .../certifi/__pycache__/core.cpython-312.pyc | Bin 2064 -> 0 bytes .../site-packages/certifi/cacert.pem | 4468 --------- .../python3.12/site-packages/certifi/core.py | 83 - .../python3.12/site-packages/certifi/py.typed | 0 .../INSTALLER | 1 - .../METADATA | 764 -- .../charset_normalizer-3.4.4.dist-info/RECORD | 35 - .../charset_normalizer-3.4.4.dist-info/WHEEL | 7 - .../entry_points.txt | 2 - .../licenses/LICENSE | 21 - .../top_level.txt | 1 - .../charset_normalizer/__init__.py | 48 - .../charset_normalizer/__main__.py | 6 - .../__pycache__/__init__.cpython-312.pyc | Bin 1783 -> 0 bytes .../__pycache__/__main__.cpython-312.pyc | Bin 358 -> 0 bytes .../__pycache__/api.cpython-312.pyc | Bin 18194 -> 0 bytes .../__pycache__/cd.cpython-312.pyc | Bin 13299 -> 0 bytes .../__pycache__/constant.cpython-312.pyc | Bin 40813 -> 0 bytes .../__pycache__/legacy.cpython-312.pyc | Bin 3013 -> 0 bytes .../__pycache__/md.cpython-312.pyc | Bin 24350 -> 0 bytes .../__pycache__/models.cpython-312.pyc | Bin 17130 -> 0 bytes .../__pycache__/utils.cpython-312.pyc | Bin 13759 -> 0 bytes .../__pycache__/version.cpython-312.pyc | Bin 385 -> 0 bytes .../site-packages/charset_normalizer/api.py | 669 -- .../site-packages/charset_normalizer/cd.py | 395 - .../charset_normalizer/cli/__init__.py | 8 - .../charset_normalizer/cli/__main__.py | 381 - .../cli/__pycache__/__init__.cpython-312.pyc | Bin 346 -> 0 bytes .../cli/__pycache__/__main__.cpython-312.pyc | Bin 14407 -> 0 bytes .../charset_normalizer/constant.py | 2015 ---- .../charset_normalizer/legacy.py | 80 - .../md.cpython-312-x86_64-linux-gnu.so | Bin 15912 -> 0 bytes .../site-packages/charset_normalizer/md.py | 635 -- .../md__mypyc.cpython-312-x86_64-linux-gnu.so | Bin 290584 -> 0 bytes .../charset_normalizer/models.py | 360 - .../site-packages/charset_normalizer/py.typed | 0 .../site-packages/charset_normalizer/utils.py | 414 - .../charset_normalizer/version.py | 8 - .../idna-3.11.dist-info/INSTALLER | 1 - .../idna-3.11.dist-info/METADATA | 209 - .../site-packages/idna-3.11.dist-info/RECORD | 22 - .../site-packages/idna-3.11.dist-info/WHEEL | 4 - .../idna-3.11.dist-info/licenses/LICENSE.md | 31 - .../python3.12/site-packages/idna/__init__.py | 45 - .../idna/__pycache__/__init__.cpython-312.pyc | Bin 885 -> 0 bytes .../idna/__pycache__/codec.cpython-312.pyc | Bin 4985 -> 0 bytes .../idna/__pycache__/compat.cpython-312.pyc | Bin 889 -> 0 bytes .../idna/__pycache__/core.cpython-312.pyc | Bin 16197 -> 0 bytes .../idna/__pycache__/idnadata.cpython-312.pyc | Bin 100914 -> 0 bytes .../__pycache__/intranges.cpython-312.pyc | Bin 2637 -> 0 bytes .../__pycache__/package_data.cpython-312.pyc | Bin 216 -> 0 bytes .../__pycache__/uts46data.cpython-312.pyc | Bin 161844 -> 0 bytes .../python3.12/site-packages/idna/codec.py | 122 - .../python3.12/site-packages/idna/compat.py | 15 - .../lib/python3.12/site-packages/idna/core.py | 437 - .../python3.12/site-packages/idna/idnadata.py | 4309 -------- .../site-packages/idna/intranges.py | 57 - .../site-packages/idna/package_data.py | 1 - .../python3.12/site-packages/idna/py.typed | 0 .../site-packages/idna/uts46data.py | 8841 ----------------- .../pip-24.0.dist-info/AUTHORS.txt | 760 -- .../pip-24.0.dist-info/INSTALLER | 1 - .../pip-24.0.dist-info/LICENSE.txt | 20 - .../site-packages/pip-24.0.dist-info/METADATA | 88 - .../site-packages/pip-24.0.dist-info/RECORD | 1005 -- .../pip-24.0.dist-info/REQUESTED | 0 .../site-packages/pip-24.0.dist-info/WHEEL | 5 - .../pip-24.0.dist-info/entry_points.txt | 4 - .../pip-24.0.dist-info/top_level.txt | 1 - .../python3.12/site-packages/pip/__init__.py | 13 - .../python3.12/site-packages/pip/__main__.py | 24 - .../site-packages/pip/__pip-runner__.py | 50 - .../pip/__pycache__/__init__.cpython-312.pyc | Bin 695 -> 0 bytes .../pip/__pycache__/__main__.cpython-312.pyc | Bin 851 -> 0 bytes .../__pip-runner__.cpython-312.pyc | Bin 2214 -> 0 bytes .../site-packages/pip/_internal/__init__.py | 18 - .../__pycache__/__init__.cpython-312.pyc | Bin 797 -> 0 bytes .../__pycache__/build_env.cpython-312.pyc | Bin 14304 -> 0 bytes .../__pycache__/cache.cpython-312.pyc | Bin 12675 -> 0 bytes .../__pycache__/configuration.cpython-312.pyc | Bin 17676 -> 0 bytes .../__pycache__/exceptions.cpython-312.pyc | Bin 33294 -> 0 bytes .../__pycache__/main.cpython-312.pyc | Bin 680 -> 0 bytes .../__pycache__/pyproject.cpython-312.pyc | Bin 4981 -> 0 bytes .../self_outdated_check.cpython-312.pyc | Bin 10562 -> 0 bytes .../__pycache__/wheel_builder.cpython-312.pyc | Bin 13659 -> 0 bytes .../site-packages/pip/_internal/build_env.py | 311 - .../site-packages/pip/_internal/cache.py | 290 - .../pip/_internal/cli/__init__.py | 4 - .../cli/__pycache__/__init__.cpython-312.pyc | Bin 288 -> 0 bytes .../autocompletion.cpython-312.pyc | Bin 8475 -> 0 bytes .../__pycache__/base_command.cpython-312.pyc | Bin 10465 -> 0 bytes .../__pycache__/cmdoptions.cpython-312.pyc | Bin 30384 -> 0 bytes .../command_context.cpython-312.pyc | Bin 1791 -> 0 bytes .../cli/__pycache__/main.cpython-312.pyc | Bin 2308 -> 0 bytes .../__pycache__/main_parser.cpython-312.pyc | Bin 4915 -> 0 bytes .../cli/__pycache__/parser.cpython-312.pyc | Bin 15032 -> 0 bytes .../__pycache__/progress_bars.cpython-312.pyc | Bin 2630 -> 0 bytes .../__pycache__/req_command.cpython-312.pyc | Bin 18862 -> 0 bytes .../cli/__pycache__/spinners.cpython-312.pyc | Bin 7850 -> 0 bytes .../__pycache__/status_codes.cpython-312.pyc | Bin 385 -> 0 bytes .../pip/_internal/cli/autocompletion.py | 172 - .../pip/_internal/cli/base_command.py | 236 - .../pip/_internal/cli/cmdoptions.py | 1074 -- .../pip/_internal/cli/command_context.py | 27 - .../site-packages/pip/_internal/cli/main.py | 79 - .../pip/_internal/cli/main_parser.py | 134 - .../site-packages/pip/_internal/cli/parser.py | 294 - .../pip/_internal/cli/progress_bars.py | 68 - .../pip/_internal/cli/req_command.py | 505 - .../pip/_internal/cli/spinners.py | 159 - .../pip/_internal/cli/status_codes.py | 6 - .../pip/_internal/commands/__init__.py | 132 - .../__pycache__/__init__.cpython-312.pyc | Bin 4012 -> 0 bytes .../__pycache__/cache.cpython-312.pyc | Bin 9721 -> 0 bytes .../__pycache__/check.cpython-312.pyc | Bin 2100 -> 0 bytes .../__pycache__/completion.cpython-312.pyc | Bin 5202 -> 0 bytes .../__pycache__/configuration.cpython-312.pyc | Bin 13222 -> 0 bytes .../__pycache__/debug.cpython-312.pyc | Bin 10171 -> 0 bytes .../__pycache__/download.cpython-312.pyc | Bin 7599 -> 0 bytes .../__pycache__/freeze.cpython-312.pyc | Bin 4426 -> 0 bytes .../commands/__pycache__/hash.cpython-312.pyc | Bin 2993 -> 0 bytes .../commands/__pycache__/help.cpython-312.pyc | Bin 1683 -> 0 bytes .../__pycache__/index.cpython-312.pyc | Bin 6730 -> 0 bytes .../__pycache__/inspect.cpython-312.pyc | Bin 3985 -> 0 bytes .../__pycache__/install.cpython-312.pyc | Bin 28923 -> 0 bytes .../commands/__pycache__/list.cpython-312.pyc | Bin 15666 -> 0 bytes .../__pycache__/search.cpython-312.pyc | Bin 7631 -> 0 bytes .../commands/__pycache__/show.cpython-312.pyc | Bin 9738 -> 0 bytes .../__pycache__/uninstall.cpython-312.pyc | Bin 4736 -> 0 bytes .../__pycache__/wheel.cpython-312.pyc | Bin 8966 -> 0 bytes .../pip/_internal/commands/cache.py | 225 - .../pip/_internal/commands/check.py | 54 - .../pip/_internal/commands/completion.py | 130 - .../pip/_internal/commands/configuration.py | 280 - .../pip/_internal/commands/debug.py | 201 - .../pip/_internal/commands/download.py | 147 - .../pip/_internal/commands/freeze.py | 109 - .../pip/_internal/commands/hash.py | 59 - .../pip/_internal/commands/help.py | 41 - .../pip/_internal/commands/index.py | 139 - .../pip/_internal/commands/inspect.py | 92 - .../pip/_internal/commands/install.py | 774 -- .../pip/_internal/commands/list.py | 370 - .../pip/_internal/commands/search.py | 174 - .../pip/_internal/commands/show.py | 189 - .../pip/_internal/commands/uninstall.py | 113 - .../pip/_internal/commands/wheel.py | 183 - .../pip/_internal/configuration.py | 383 - .../pip/_internal/distributions/__init__.py | 21 - .../__pycache__/__init__.cpython-312.pyc | Bin 951 -> 0 bytes .../__pycache__/base.cpython-312.pyc | Bin 2872 -> 0 bytes .../__pycache__/installed.cpython-312.pyc | Bin 1710 -> 0 bytes .../__pycache__/sdist.cpython-312.pyc | Bin 8498 -> 0 bytes .../__pycache__/wheel.cpython-312.pyc | Bin 2258 -> 0 bytes .../pip/_internal/distributions/base.py | 51 - .../pip/_internal/distributions/installed.py | 29 - .../pip/_internal/distributions/sdist.py | 156 - .../pip/_internal/distributions/wheel.py | 40 - .../site-packages/pip/_internal/exceptions.py | 728 -- .../pip/_internal/index/__init__.py | 2 - .../__pycache__/__init__.cpython-312.pyc | Bin 242 -> 0 bytes .../__pycache__/collector.cpython-312.pyc | Bin 21896 -> 0 bytes .../package_finder.cpython-312.pyc | Bin 40745 -> 0 bytes .../index/__pycache__/sources.cpython-312.pyc | Bin 12614 -> 0 bytes .../pip/_internal/index/collector.py | 507 - .../pip/_internal/index/package_finder.py | 1027 -- .../pip/_internal/index/sources.py | 285 - .../pip/_internal/locations/__init__.py | 467 - .../__pycache__/__init__.cpython-312.pyc | Bin 16786 -> 0 bytes .../__pycache__/_distutils.cpython-312.pyc | Bin 6866 -> 0 bytes .../__pycache__/_sysconfig.cpython-312.pyc | Bin 8021 -> 0 bytes .../__pycache__/base.cpython-312.pyc | Bin 3791 -> 0 bytes .../pip/_internal/locations/_distutils.py | 172 - .../pip/_internal/locations/_sysconfig.py | 213 - .../pip/_internal/locations/base.py | 81 - .../site-packages/pip/_internal/main.py | 12 - .../pip/_internal/metadata/__init__.py | 128 - .../__pycache__/__init__.cpython-312.pyc | Bin 5892 -> 0 bytes .../__pycache__/_json.cpython-312.pyc | Bin 2885 -> 0 bytes .../metadata/__pycache__/base.cpython-312.pyc | Bin 35722 -> 0 bytes .../__pycache__/pkg_resources.cpython-312.pyc | Bin 15800 -> 0 bytes .../pip/_internal/metadata/_json.py | 84 - .../pip/_internal/metadata/base.py | 702 -- .../_internal/metadata/importlib/__init__.py | 6 - .../__pycache__/__init__.cpython-312.pyc | Bin 368 -> 0 bytes .../__pycache__/_compat.cpython-312.pyc | Bin 3343 -> 0 bytes .../__pycache__/_dists.cpython-312.pyc | Bin 13435 -> 0 bytes .../__pycache__/_envs.cpython-312.pyc | Bin 11190 -> 0 bytes .../_internal/metadata/importlib/_compat.py | 55 - .../_internal/metadata/importlib/_dists.py | 227 - .../pip/_internal/metadata/importlib/_envs.py | 189 - .../pip/_internal/metadata/pkg_resources.py | 278 - .../pip/_internal/models/__init__.py | 2 - .../__pycache__/__init__.cpython-312.pyc | Bin 276 -> 0 bytes .../__pycache__/candidate.cpython-312.pyc | Bin 1915 -> 0 bytes .../__pycache__/direct_url.cpython-312.pyc | Bin 11209 -> 0 bytes .../format_control.cpython-312.pyc | Bin 4237 -> 0 bytes .../models/__pycache__/index.cpython-312.pyc | Bin 1704 -> 0 bytes .../installation_report.cpython-312.pyc | Bin 2282 -> 0 bytes .../models/__pycache__/link.cpython-312.pyc | Bin 26012 -> 0 bytes .../models/__pycache__/scheme.cpython-312.pyc | Bin 1179 -> 0 bytes .../__pycache__/search_scope.cpython-312.pyc | Bin 5098 -> 0 bytes .../selection_prefs.cpython-312.pyc | Bin 1861 -> 0 bytes .../__pycache__/target_python.cpython-312.pyc | Bin 4964 -> 0 bytes .../models/__pycache__/wheel.cpython-312.pyc | Bin 5790 -> 0 bytes .../pip/_internal/models/candidate.py | 30 - .../pip/_internal/models/direct_url.py | 235 - .../pip/_internal/models/format_control.py | 78 - .../pip/_internal/models/index.py | 28 - .../_internal/models/installation_report.py | 56 - .../pip/_internal/models/link.py | 579 -- .../pip/_internal/models/scheme.py | 31 - .../pip/_internal/models/search_scope.py | 132 - .../pip/_internal/models/selection_prefs.py | 51 - .../pip/_internal/models/target_python.py | 122 - .../pip/_internal/models/wheel.py | 92 - .../pip/_internal/network/__init__.py | 2 - .../__pycache__/__init__.cpython-312.pyc | Bin 264 -> 0 bytes .../network/__pycache__/auth.cpython-312.pyc | Bin 22006 -> 0 bytes .../network/__pycache__/cache.cpython-312.pyc | Bin 6528 -> 0 bytes .../__pycache__/download.cpython-312.pyc | Bin 8563 -> 0 bytes .../__pycache__/lazy_wheel.cpython-312.pyc | Bin 11673 -> 0 bytes .../__pycache__/session.cpython-312.pyc | Bin 18784 -> 0 bytes .../network/__pycache__/utils.cpython-312.pyc | Bin 2263 -> 0 bytes .../__pycache__/xmlrpc.cpython-312.pyc | Bin 2959 -> 0 bytes .../pip/_internal/network/auth.py | 561 -- .../pip/_internal/network/cache.py | 106 - .../pip/_internal/network/download.py | 186 - .../pip/_internal/network/lazy_wheel.py | 210 - .../pip/_internal/network/session.py | 520 - .../pip/_internal/network/utils.py | 96 - .../pip/_internal/network/xmlrpc.py | 62 - .../pip/_internal/operations/__init__.py | 0 .../__pycache__/__init__.cpython-312.pyc | Bin 207 -> 0 bytes .../__pycache__/check.cpython-312.pyc | Bin 7589 -> 0 bytes .../__pycache__/freeze.cpython-312.pyc | Bin 10127 -> 0 bytes .../__pycache__/prepare.cpython-312.pyc | Bin 25757 -> 0 bytes .../_internal/operations/build/__init__.py | 0 .../__pycache__/__init__.cpython-312.pyc | Bin 213 -> 0 bytes .../__pycache__/build_tracker.cpython-312.pyc | Bin 7833 -> 0 bytes .../__pycache__/metadata.cpython-312.pyc | Bin 1890 -> 0 bytes .../metadata_editable.cpython-312.pyc | Bin 1924 -> 0 bytes .../metadata_legacy.cpython-312.pyc | Bin 3075 -> 0 bytes .../build/__pycache__/wheel.cpython-312.pyc | Bin 1694 -> 0 bytes .../wheel_editable.cpython-312.pyc | Bin 2035 -> 0 bytes .../__pycache__/wheel_legacy.cpython-312.pyc | Bin 3939 -> 0 bytes .../operations/build/build_tracker.py | 139 - .../_internal/operations/build/metadata.py | 39 - .../operations/build/metadata_editable.py | 41 - .../operations/build/metadata_legacy.py | 74 - .../pip/_internal/operations/build/wheel.py | 37 - .../operations/build/wheel_editable.py | 46 - .../operations/build/wheel_legacy.py | 102 - .../pip/_internal/operations/check.py | 187 - .../pip/_internal/operations/freeze.py | 255 - .../_internal/operations/install/__init__.py | 2 - .../__pycache__/__init__.cpython-312.pyc | Bin 276 -> 0 bytes .../editable_legacy.cpython-312.pyc | Bin 1827 -> 0 bytes .../install/__pycache__/wheel.cpython-312.pyc | Bin 33869 -> 0 bytes .../operations/install/editable_legacy.py | 46 - .../pip/_internal/operations/install/wheel.py | 734 -- .../pip/_internal/operations/prepare.py | 730 -- .../site-packages/pip/_internal/pyproject.py | 179 - .../pip/_internal/req/__init__.py | 92 - .../req/__pycache__/__init__.cpython-312.pyc | Bin 3753 -> 0 bytes .../__pycache__/constructors.cpython-312.pyc | Bin 21592 -> 0 bytes .../req/__pycache__/req_file.cpython-312.pyc | Bin 21471 -> 0 bytes .../__pycache__/req_install.cpython-312.pyc | Bin 38424 -> 0 bytes .../req/__pycache__/req_set.cpython-312.pyc | Bin 7228 -> 0 bytes .../__pycache__/req_uninstall.cpython-312.pyc | Bin 32987 -> 0 bytes .../pip/_internal/req/constructors.py | 576 -- .../pip/_internal/req/req_file.py | 554 -- .../pip/_internal/req/req_install.py | 923 -- .../pip/_internal/req/req_set.py | 119 - .../pip/_internal/req/req_uninstall.py | 649 -- .../pip/_internal/resolution/__init__.py | 0 .../__pycache__/__init__.cpython-312.pyc | Bin 207 -> 0 bytes .../__pycache__/base.cpython-312.pyc | Bin 1195 -> 0 bytes .../pip/_internal/resolution/base.py | 20 - .../_internal/resolution/legacy/__init__.py | 0 .../__pycache__/__init__.cpython-312.pyc | Bin 214 -> 0 bytes .../__pycache__/resolver.cpython-312.pyc | Bin 22449 -> 0 bytes .../_internal/resolution/legacy/resolver.py | 598 -- .../resolution/resolvelib/__init__.py | 0 .../__pycache__/__init__.cpython-312.pyc | Bin 218 -> 0 bytes .../__pycache__/base.cpython-312.pyc | Bin 8347 -> 0 bytes .../__pycache__/candidates.cpython-312.pyc | Bin 30408 -> 0 bytes .../__pycache__/factory.cpython-312.pyc | Bin 32124 -> 0 bytes .../found_candidates.cpython-312.pyc | Bin 6218 -> 0 bytes .../__pycache__/provider.cpython-312.pyc | Bin 10388 -> 0 bytes .../__pycache__/reporter.cpython-312.pyc | Bin 4945 -> 0 bytes .../__pycache__/requirements.cpython-312.pyc | Bin 11439 -> 0 bytes .../__pycache__/resolver.cpython-312.pyc | Bin 12361 -> 0 bytes .../_internal/resolution/resolvelib/base.py | 141 - .../resolution/resolvelib/candidates.py | 597 -- .../resolution/resolvelib/factory.py | 812 -- .../resolution/resolvelib/found_candidates.py | 155 - .../resolution/resolvelib/provider.py | 255 - .../resolution/resolvelib/reporter.py | 80 - .../resolution/resolvelib/requirements.py | 166 - .../resolution/resolvelib/resolver.py | 317 - .../pip/_internal/self_outdated_check.py | 248 - .../pip/_internal/utils/__init__.py | 0 .../__pycache__/__init__.cpython-312.pyc | Bin 202 -> 0 bytes .../__pycache__/_jaraco_text.cpython-312.pyc | Bin 4543 -> 0 bytes .../utils/__pycache__/_log.cpython-312.pyc | Bin 1873 -> 0 bytes .../utils/__pycache__/appdirs.cpython-312.pyc | Bin 2417 -> 0 bytes .../utils/__pycache__/compat.cpython-312.pyc | Bin 2220 -> 0 bytes .../compatibility_tags.cpython-312.pyc | Bin 5568 -> 0 bytes .../__pycache__/datetime.cpython-312.pyc | Bin 691 -> 0 bytes .../__pycache__/deprecation.cpython-312.pyc | Bin 4193 -> 0 bytes .../direct_url_helpers.cpython-312.pyc | Bin 3570 -> 0 bytes .../__pycache__/egg_link.cpython-312.pyc | Bin 3233 -> 0 bytes .../__pycache__/encoding.cpython-312.pyc | Bin 2165 -> 0 bytes .../__pycache__/entrypoints.cpython-312.pyc | Bin 4000 -> 0 bytes .../__pycache__/filesystem.cpython-312.pyc | Bin 7465 -> 0 bytes .../__pycache__/filetypes.cpython-312.pyc | Bin 1171 -> 0 bytes .../utils/__pycache__/glibc.cpython-312.pyc | Bin 2349 -> 0 bytes .../utils/__pycache__/hashes.cpython-312.pyc | Bin 7561 -> 0 bytes .../utils/__pycache__/logging.cpython-312.pyc | Bin 13564 -> 0 bytes .../utils/__pycache__/misc.cpython-312.pyc | Bin 34128 -> 0 bytes .../utils/__pycache__/models.cpython-312.pyc | Bin 2719 -> 0 bytes .../__pycache__/packaging.cpython-312.pyc | Bin 2590 -> 0 bytes .../setuptools_build.cpython-312.pyc | Bin 4557 -> 0 bytes .../__pycache__/subprocess.cpython-312.pyc | Bin 8725 -> 0 bytes .../__pycache__/temp_dir.cpython-312.pyc | Bin 12069 -> 0 bytes .../__pycache__/unpacking.cpython-312.pyc | Bin 11115 -> 0 bytes .../utils/__pycache__/urls.cpython-312.pyc | Bin 2412 -> 0 bytes .../__pycache__/virtualenv.cpython-312.pyc | Bin 4487 -> 0 bytes .../utils/__pycache__/wheel.cpython-312.pyc | Bin 5933 -> 0 bytes .../pip/_internal/utils/_jaraco_text.py | 109 - .../site-packages/pip/_internal/utils/_log.py | 38 - .../pip/_internal/utils/appdirs.py | 52 - .../pip/_internal/utils/compat.py | 63 - .../pip/_internal/utils/compatibility_tags.py | 165 - .../pip/_internal/utils/datetime.py | 11 - .../pip/_internal/utils/deprecation.py | 120 - .../pip/_internal/utils/direct_url_helpers.py | 87 - .../pip/_internal/utils/egg_link.py | 80 - .../pip/_internal/utils/encoding.py | 36 - .../pip/_internal/utils/entrypoints.py | 84 - .../pip/_internal/utils/filesystem.py | 153 - .../pip/_internal/utils/filetypes.py | 27 - .../pip/_internal/utils/glibc.py | 88 - .../pip/_internal/utils/hashes.py | 151 - .../pip/_internal/utils/logging.py | 348 - .../site-packages/pip/_internal/utils/misc.py | 783 -- .../pip/_internal/utils/models.py | 39 - .../pip/_internal/utils/packaging.py | 57 - .../pip/_internal/utils/setuptools_build.py | 146 - .../pip/_internal/utils/subprocess.py | 260 - .../pip/_internal/utils/temp_dir.py | 296 - .../pip/_internal/utils/unpacking.py | 257 - .../site-packages/pip/_internal/utils/urls.py | 62 - .../pip/_internal/utils/virtualenv.py | 104 - .../pip/_internal/utils/wheel.py | 134 - .../pip/_internal/vcs/__init__.py | 15 - .../vcs/__pycache__/__init__.cpython-312.pyc | Bin 541 -> 0 bytes .../vcs/__pycache__/bazaar.cpython-312.pyc | Bin 5033 -> 0 bytes .../vcs/__pycache__/git.cpython-312.pyc | Bin 19002 -> 0 bytes .../vcs/__pycache__/mercurial.cpython-312.pyc | Bin 7622 -> 0 bytes .../__pycache__/subversion.cpython-312.pyc | Bin 12494 -> 0 bytes .../versioncontrol.cpython-312.pyc | Bin 29020 -> 0 bytes .../site-packages/pip/_internal/vcs/bazaar.py | 112 - .../site-packages/pip/_internal/vcs/git.py | 526 - .../pip/_internal/vcs/mercurial.py | 163 - .../pip/_internal/vcs/subversion.py | 324 - .../pip/_internal/vcs/versioncontrol.py | 705 -- .../pip/_internal/wheel_builder.py | 354 - .../site-packages/pip/_vendor/__init__.py | 121 - .../__pycache__/__init__.cpython-312.pyc | Bin 4703 -> 0 bytes .../_vendor/__pycache__/six.cpython-312.pyc | Bin 41280 -> 0 bytes .../typing_extensions.cpython-312.pyc | Bin 122060 -> 0 bytes .../pip/_vendor/cachecontrol/__init__.py | 28 - .../__pycache__/__init__.cpython-312.pyc | Bin 913 -> 0 bytes .../__pycache__/_cmd.cpython-312.pyc | Bin 2657 -> 0 bytes .../__pycache__/adapter.cpython-312.pyc | Bin 6475 -> 0 bytes .../__pycache__/cache.cpython-312.pyc | Bin 3820 -> 0 bytes .../__pycache__/controller.cpython-312.pyc | Bin 16178 -> 0 bytes .../__pycache__/filewrapper.cpython-312.pyc | Bin 4358 -> 0 bytes .../__pycache__/heuristics.cpython-312.pyc | Bin 6705 -> 0 bytes .../__pycache__/serialize.cpython-312.pyc | Bin 6416 -> 0 bytes .../__pycache__/wrapper.cpython-312.pyc | Bin 1685 -> 0 bytes .../pip/_vendor/cachecontrol/_cmd.py | 70 - .../pip/_vendor/cachecontrol/adapter.py | 161 - .../pip/_vendor/cachecontrol/cache.py | 74 - .../_vendor/cachecontrol/caches/__init__.py | 8 - .../__pycache__/__init__.cpython-312.pyc | Bin 446 -> 0 bytes .../__pycache__/file_cache.cpython-312.pyc | Bin 7721 -> 0 bytes .../__pycache__/redis_cache.cpython-312.pyc | Bin 2749 -> 0 bytes .../_vendor/cachecontrol/caches/file_cache.py | 181 - .../cachecontrol/caches/redis_cache.py | 48 - .../pip/_vendor/cachecontrol/controller.py | 494 - .../pip/_vendor/cachecontrol/filewrapper.py | 119 - .../pip/_vendor/cachecontrol/heuristics.py | 154 - .../pip/_vendor/cachecontrol/serialize.py | 206 - .../pip/_vendor/cachecontrol/wrapper.py | 43 - .../pip/_vendor/certifi/__init__.py | 4 - .../pip/_vendor/certifi/__main__.py | 12 - .../__pycache__/__init__.cpython-312.pyc | Bin 329 -> 0 bytes .../__pycache__/__main__.cpython-312.pyc | Bin 656 -> 0 bytes .../certifi/__pycache__/core.cpython-312.pyc | Bin 3338 -> 0 bytes .../pip/_vendor/certifi/cacert.pem | 4635 --------- .../site-packages/pip/_vendor/certifi/core.py | 119 - .../pip/_vendor/chardet/__init__.py | 115 - .../__pycache__/__init__.cpython-312.pyc | Bin 4579 -> 0 bytes .../__pycache__/big5freq.cpython-312.pyc | Bin 27210 -> 0 bytes .../__pycache__/big5prober.cpython-312.pyc | Bin 1398 -> 0 bytes .../chardistribution.cpython-312.pyc | Bin 9649 -> 0 bytes .../charsetgroupprober.cpython-312.pyc | Bin 4133 -> 0 bytes .../__pycache__/charsetprober.cpython-312.pyc | Bin 5029 -> 0 bytes .../codingstatemachine.cpython-312.pyc | Bin 3889 -> 0 bytes .../codingstatemachinedict.cpython-312.pyc | Bin 800 -> 0 bytes .../__pycache__/cp949prober.cpython-312.pyc | Bin 1407 -> 0 bytes .../chardet/__pycache__/enums.cpython-312.pyc | Bin 3007 -> 0 bytes .../__pycache__/escprober.cpython-312.pyc | Bin 4577 -> 0 bytes .../chardet/__pycache__/escsm.cpython-312.pyc | Bin 15321 -> 0 bytes .../__pycache__/eucjpprober.cpython-312.pyc | Bin 4394 -> 0 bytes .../__pycache__/euckrfreq.cpython-312.pyc | Bin 12093 -> 0 bytes .../__pycache__/euckrprober.cpython-312.pyc | Bin 1401 -> 0 bytes .../__pycache__/euctwfreq.cpython-312.pyc | Bin 27215 -> 0 bytes .../__pycache__/euctwprober.cpython-312.pyc | Bin 1401 -> 0 bytes .../__pycache__/gb2312freq.cpython-312.pyc | Bin 19137 -> 0 bytes .../__pycache__/gb2312prober.cpython-312.pyc | Bin 1414 -> 0 bytes .../__pycache__/hebrewprober.cpython-312.pyc | Bin 5833 -> 0 bytes .../__pycache__/jisfreq.cpython-312.pyc | Bin 22166 -> 0 bytes .../__pycache__/johabfreq.cpython-312.pyc | Bin 83014 -> 0 bytes .../__pycache__/johabprober.cpython-312.pyc | Bin 1405 -> 0 bytes .../__pycache__/jpcntx.cpython-312.pyc | Bin 39560 -> 0 bytes .../langbulgarianmodel.cpython-312.pyc | Bin 83133 -> 0 bytes .../langgreekmodel.cpython-312.pyc | Bin 76999 -> 0 bytes .../langhebrewmodel.cpython-312.pyc | Bin 77510 -> 0 bytes .../langhungarianmodel.cpython-312.pyc | Bin 83087 -> 0 bytes .../langrussianmodel.cpython-312.pyc | Bin 105262 -> 0 bytes .../__pycache__/langthaimodel.cpython-312.pyc | Bin 77688 -> 0 bytes .../langturkishmodel.cpython-312.pyc | Bin 77527 -> 0 bytes .../__pycache__/latin1prober.cpython-312.pyc | Bin 7013 -> 0 bytes .../macromanprober.cpython-312.pyc | Bin 7193 -> 0 bytes .../mbcharsetprober.cpython-312.pyc | Bin 3914 -> 0 bytes .../mbcsgroupprober.cpython-312.pyc | Bin 1599 -> 0 bytes .../__pycache__/mbcssm.cpython-312.pyc | Bin 38656 -> 0 bytes .../__pycache__/resultdict.cpython-312.pyc | Bin 643 -> 0 bytes .../sbcharsetprober.cpython-312.pyc | Bin 6398 -> 0 bytes .../sbcsgroupprober.cpython-312.pyc | Bin 2368 -> 0 bytes .../__pycache__/sjisprober.cpython-312.pyc | Bin 4506 -> 0 bytes .../universaldetector.cpython-312.pyc | Bin 12280 -> 0 bytes .../__pycache__/utf1632prober.cpython-312.pyc | Bin 9990 -> 0 bytes .../__pycache__/utf8prober.cpython-312.pyc | Bin 3186 -> 0 bytes .../__pycache__/version.cpython-312.pyc | Bin 499 -> 0 bytes .../pip/_vendor/chardet/big5freq.py | 386 - .../pip/_vendor/chardet/big5prober.py | 47 - .../pip/_vendor/chardet/chardistribution.py | 261 - .../pip/_vendor/chardet/charsetgroupprober.py | 106 - .../pip/_vendor/chardet/charsetprober.py | 147 - .../pip/_vendor/chardet/cli/__init__.py | 0 .../cli/__pycache__/__init__.cpython-312.pyc | Bin 206 -> 0 bytes .../__pycache__/chardetect.cpython-312.pyc | Bin 4023 -> 0 bytes .../pip/_vendor/chardet/cli/chardetect.py | 112 - .../pip/_vendor/chardet/codingstatemachine.py | 90 - .../_vendor/chardet/codingstatemachinedict.py | 19 - .../pip/_vendor/chardet/cp949prober.py | 49 - .../pip/_vendor/chardet/enums.py | 85 - .../pip/_vendor/chardet/escprober.py | 102 - .../pip/_vendor/chardet/escsm.py | 261 - .../pip/_vendor/chardet/eucjpprober.py | 102 - .../pip/_vendor/chardet/euckrfreq.py | 196 - .../pip/_vendor/chardet/euckrprober.py | 47 - .../pip/_vendor/chardet/euctwfreq.py | 388 - .../pip/_vendor/chardet/euctwprober.py | 47 - .../pip/_vendor/chardet/gb2312freq.py | 284 - .../pip/_vendor/chardet/gb2312prober.py | 47 - .../pip/_vendor/chardet/hebrewprober.py | 316 - .../pip/_vendor/chardet/jisfreq.py | 325 - .../pip/_vendor/chardet/johabfreq.py | 2382 ----- .../pip/_vendor/chardet/johabprober.py | 47 - .../pip/_vendor/chardet/jpcntx.py | 238 - .../pip/_vendor/chardet/langbulgarianmodel.py | 4649 --------- .../pip/_vendor/chardet/langgreekmodel.py | 4397 -------- .../pip/_vendor/chardet/langhebrewmodel.py | 4380 -------- .../pip/_vendor/chardet/langhungarianmodel.py | 4649 --------- .../pip/_vendor/chardet/langrussianmodel.py | 5725 ----------- .../pip/_vendor/chardet/langthaimodel.py | 4380 -------- .../pip/_vendor/chardet/langturkishmodel.py | 4380 -------- .../pip/_vendor/chardet/latin1prober.py | 147 - .../pip/_vendor/chardet/macromanprober.py | 162 - .../pip/_vendor/chardet/mbcharsetprober.py | 95 - .../pip/_vendor/chardet/mbcsgroupprober.py | 57 - .../pip/_vendor/chardet/mbcssm.py | 661 -- .../pip/_vendor/chardet/metadata/__init__.py | 0 .../__pycache__/__init__.cpython-312.pyc | Bin 211 -> 0 bytes .../__pycache__/languages.cpython-312.pyc | Bin 9766 -> 0 bytes .../pip/_vendor/chardet/metadata/languages.py | 352 - .../pip/_vendor/chardet/resultdict.py | 16 - .../pip/_vendor/chardet/sbcharsetprober.py | 162 - .../pip/_vendor/chardet/sbcsgroupprober.py | 88 - .../pip/_vendor/chardet/sjisprober.py | 105 - .../pip/_vendor/chardet/universaldetector.py | 362 - .../pip/_vendor/chardet/utf1632prober.py | 225 - .../pip/_vendor/chardet/utf8prober.py | 82 - .../pip/_vendor/chardet/version.py | 9 - .../pip/_vendor/colorama/__init__.py | 7 - .../__pycache__/__init__.cpython-312.pyc | Bin 503 -> 0 bytes .../colorama/__pycache__/ansi.cpython-312.pyc | Bin 3961 -> 0 bytes .../__pycache__/ansitowin32.cpython-312.pyc | Bin 16432 -> 0 bytes .../__pycache__/initialise.cpython-312.pyc | Bin 3561 -> 0 bytes .../__pycache__/win32.cpython-312.pyc | Bin 8137 -> 0 bytes .../__pycache__/winterm.cpython-312.pyc | Bin 9099 -> 0 bytes .../pip/_vendor/colorama/ansi.py | 102 - .../pip/_vendor/colorama/ansitowin32.py | 277 - .../pip/_vendor/colorama/initialise.py | 121 - .../pip/_vendor/colorama/tests/__init__.py | 1 - .../__pycache__/__init__.cpython-312.pyc | Bin 209 -> 0 bytes .../__pycache__/ansi_test.cpython-312.pyc | Bin 5478 -> 0 bytes .../ansitowin32_test.cpython-312.pyc | Bin 18114 -> 0 bytes .../initialise_test.cpython-312.pyc | Bin 11759 -> 0 bytes .../__pycache__/isatty_test.cpython-312.pyc | Bin 4915 -> 0 bytes .../tests/__pycache__/utils.cpython-312.pyc | Bin 2499 -> 0 bytes .../__pycache__/winterm_test.cpython-312.pyc | Bin 6623 -> 0 bytes .../pip/_vendor/colorama/tests/ansi_test.py | 76 - .../colorama/tests/ansitowin32_test.py | 294 - .../_vendor/colorama/tests/initialise_test.py | 189 - .../pip/_vendor/colorama/tests/isatty_test.py | 57 - .../pip/_vendor/colorama/tests/utils.py | 49 - .../_vendor/colorama/tests/winterm_test.py | 131 - .../pip/_vendor/colorama/win32.py | 180 - .../pip/_vendor/colorama/winterm.py | 195 - .../pip/_vendor/distlib/__init__.py | 33 - .../__pycache__/__init__.cpython-312.pyc | Bin 1280 -> 0 bytes .../__pycache__/compat.cpython-312.pyc | Bin 45616 -> 0 bytes .../__pycache__/database.cpython-312.pyc | Bin 66038 -> 0 bytes .../distlib/__pycache__/index.cpython-312.pyc | Bin 24377 -> 0 bytes .../__pycache__/locators.cpython-312.pyc | Bin 60169 -> 0 bytes .../__pycache__/manifest.cpython-312.pyc | Bin 15136 -> 0 bytes .../__pycache__/markers.cpython-312.pyc | Bin 7693 -> 0 bytes .../__pycache__/metadata.cpython-312.pyc | Bin 41810 -> 0 bytes .../__pycache__/resources.cpython-312.pyc | Bin 17336 -> 0 bytes .../__pycache__/scripts.cpython-312.pyc | Bin 19591 -> 0 bytes .../distlib/__pycache__/util.cpython-312.pyc | Bin 88267 -> 0 bytes .../__pycache__/version.cpython-312.pyc | Bin 30377 -> 0 bytes .../distlib/__pycache__/wheel.cpython-312.pyc | Bin 51872 -> 0 bytes .../pip/_vendor/distlib/compat.py | 1138 --- .../pip/_vendor/distlib/database.py | 1359 --- .../pip/_vendor/distlib/index.py | 508 - .../pip/_vendor/distlib/locators.py | 1303 --- .../pip/_vendor/distlib/manifest.py | 384 - .../pip/_vendor/distlib/markers.py | 167 - .../pip/_vendor/distlib/metadata.py | 1068 -- .../pip/_vendor/distlib/resources.py | 358 - .../pip/_vendor/distlib/scripts.py | 452 - .../site-packages/pip/_vendor/distlib/util.py | 2025 ---- .../pip/_vendor/distlib/version.py | 751 -- .../pip/_vendor/distlib/wheel.py | 1099 -- .../pip/_vendor/distro/__init__.py | 54 - .../pip/_vendor/distro/__main__.py | 4 - .../__pycache__/__init__.cpython-312.pyc | Bin 971 -> 0 bytes .../__pycache__/__main__.cpython-312.pyc | Bin 303 -> 0 bytes .../distro/__pycache__/distro.cpython-312.pyc | Bin 53765 -> 0 bytes .../pip/_vendor/distro/distro.py | 1399 --- .../pip/_vendor/idna/__init__.py | 44 - .../idna/__pycache__/__init__.cpython-312.pyc | Bin 892 -> 0 bytes .../idna/__pycache__/codec.cpython-312.pyc | Bin 4644 -> 0 bytes .../idna/__pycache__/compat.cpython-312.pyc | Bin 898 -> 0 bytes .../idna/__pycache__/core.cpython-312.pyc | Bin 16034 -> 0 bytes .../idna/__pycache__/idnadata.cpython-312.pyc | Bin 99508 -> 0 bytes .../__pycache__/intranges.cpython-312.pyc | Bin 2649 -> 0 bytes .../__pycache__/package_data.cpython-312.pyc | Bin 227 -> 0 bytes .../__pycache__/uts46data.cpython-312.pyc | Bin 158881 -> 0 bytes .../site-packages/pip/_vendor/idna/codec.py | 112 - .../site-packages/pip/_vendor/idna/compat.py | 13 - .../site-packages/pip/_vendor/idna/core.py | 400 - .../pip/_vendor/idna/idnadata.py | 4246 -------- .../pip/_vendor/idna/intranges.py | 54 - .../pip/_vendor/idna/package_data.py | 2 - .../pip/_vendor/idna/uts46data.py | 8600 ---------------- .../pip/_vendor/msgpack/__init__.py | 57 - .../__pycache__/__init__.cpython-312.pyc | Bin 1842 -> 0 bytes .../__pycache__/exceptions.cpython-312.pyc | Bin 2036 -> 0 bytes .../msgpack/__pycache__/ext.cpython-312.pyc | Bin 8679 -> 0 bytes .../__pycache__/fallback.cpython-312.pyc | Bin 43587 -> 0 bytes .../pip/_vendor/msgpack/exceptions.py | 48 - .../site-packages/pip/_vendor/msgpack/ext.py | 193 - .../pip/_vendor/msgpack/fallback.py | 1010 -- .../pip/_vendor/packaging/__about__.py | 26 - .../pip/_vendor/packaging/__init__.py | 25 - .../__pycache__/__about__.cpython-312.pyc | Bin 641 -> 0 bytes .../__pycache__/__init__.cpython-312.pyc | Bin 477 -> 0 bytes .../__pycache__/_manylinux.cpython-312.pyc | Bin 12087 -> 0 bytes .../__pycache__/_musllinux.cpython-312.pyc | Bin 6921 -> 0 bytes .../__pycache__/_structures.cpython-312.pyc | Bin 3252 -> 0 bytes .../__pycache__/markers.cpython-312.pyc | Bin 14069 -> 0 bytes .../__pycache__/requirements.cpython-312.pyc | Bin 6957 -> 0 bytes .../__pycache__/specifiers.cpython-312.pyc | Bin 31258 -> 0 bytes .../__pycache__/tags.cpython-312.pyc | Bin 18967 -> 0 bytes .../__pycache__/utils.cpython-312.pyc | Bin 5879 -> 0 bytes .../__pycache__/version.cpython-312.pyc | Bin 19950 -> 0 bytes .../pip/_vendor/packaging/_manylinux.py | 301 - .../pip/_vendor/packaging/_musllinux.py | 136 - .../pip/_vendor/packaging/_structures.py | 61 - .../pip/_vendor/packaging/markers.py | 304 - .../pip/_vendor/packaging/requirements.py | 146 - .../pip/_vendor/packaging/specifiers.py | 802 -- .../pip/_vendor/packaging/tags.py | 487 - .../pip/_vendor/packaging/utils.py | 136 - .../pip/_vendor/packaging/version.py | 504 - .../pip/_vendor/pkg_resources/__init__.py | 3361 ------- .../__pycache__/__init__.cpython-312.pyc | Bin 146485 -> 0 bytes .../pip/_vendor/platformdirs/__init__.py | 566 -- .../pip/_vendor/platformdirs/__main__.py | 53 - .../__pycache__/__init__.cpython-312.pyc | Bin 18040 -> 0 bytes .../__pycache__/__main__.cpython-312.pyc | Bin 1957 -> 0 bytes .../__pycache__/android.cpython-312.pyc | Bin 9455 -> 0 bytes .../__pycache__/api.cpython-312.pyc | Bin 9683 -> 0 bytes .../__pycache__/macos.cpython-312.pyc | Bin 5648 -> 0 bytes .../__pycache__/unix.cpython-312.pyc | Bin 12452 -> 0 bytes .../__pycache__/version.cpython-312.pyc | Bin 322 -> 0 bytes .../__pycache__/windows.cpython-312.pyc | Bin 13010 -> 0 bytes .../pip/_vendor/platformdirs/android.py | 210 - .../pip/_vendor/platformdirs/api.py | 223 - .../pip/_vendor/platformdirs/macos.py | 91 - .../pip/_vendor/platformdirs/unix.py | 223 - .../pip/_vendor/platformdirs/version.py | 4 - .../pip/_vendor/platformdirs/windows.py | 255 - .../pip/_vendor/pygments/__init__.py | 82 - .../pip/_vendor/pygments/__main__.py | 17 - .../__pycache__/__init__.cpython-312.pyc | Bin 3500 -> 0 bytes .../__pycache__/__main__.cpython-312.pyc | Bin 746 -> 0 bytes .../__pycache__/cmdline.cpython-312.pyc | Bin 26617 -> 0 bytes .../__pycache__/console.cpython-312.pyc | Bin 2638 -> 0 bytes .../__pycache__/filter.cpython-312.pyc | Bin 3244 -> 0 bytes .../__pycache__/formatter.cpython-312.pyc | Bin 4581 -> 0 bytes .../__pycache__/lexer.cpython-312.pyc | Bin 38341 -> 0 bytes .../__pycache__/modeline.cpython-312.pyc | Bin 1580 -> 0 bytes .../__pycache__/plugin.cpython-312.pyc | Bin 3408 -> 0 bytes .../__pycache__/regexopt.cpython-312.pyc | Bin 4093 -> 0 bytes .../__pycache__/scanner.cpython-312.pyc | Bin 4768 -> 0 bytes .../__pycache__/sphinxext.cpython-312.pyc | Bin 11058 -> 0 bytes .../__pycache__/style.cpython-312.pyc | Bin 6686 -> 0 bytes .../__pycache__/token.cpython-312.pyc | Bin 8154 -> 0 bytes .../__pycache__/unistring.cpython-312.pyc | Bin 33000 -> 0 bytes .../pygments/__pycache__/util.cpython-312.pyc | Bin 13993 -> 0 bytes .../pip/_vendor/pygments/cmdline.py | 668 -- .../pip/_vendor/pygments/console.py | 70 - .../pip/_vendor/pygments/filter.py | 71 - .../pip/_vendor/pygments/filters/__init__.py | 940 -- .../__pycache__/__init__.cpython-312.pyc | Bin 37948 -> 0 bytes .../pip/_vendor/pygments/formatter.py | 124 - .../_vendor/pygments/formatters/__init__.py | 158 - .../__pycache__/__init__.cpython-312.pyc | Bin 6938 -> 0 bytes .../__pycache__/_mapping.cpython-312.pyc | Bin 4227 -> 0 bytes .../__pycache__/bbcode.cpython-312.pyc | Bin 4206 -> 0 bytes .../__pycache__/groff.cpython-312.pyc | Bin 7276 -> 0 bytes .../__pycache__/html.cpython-312.pyc | Bin 40584 -> 0 bytes .../__pycache__/img.cpython-312.pyc | Bin 27055 -> 0 bytes .../__pycache__/irc.cpython-312.pyc | Bin 6077 -> 0 bytes .../__pycache__/latex.cpython-312.pyc | Bin 19966 -> 0 bytes .../__pycache__/other.cpython-312.pyc | Bin 6896 -> 0 bytes .../__pycache__/pangomarkup.cpython-312.pyc | Bin 2942 -> 0 bytes .../__pycache__/rtf.cpython-312.pyc | Bin 6138 -> 0 bytes .../__pycache__/svg.cpython-312.pyc | Bin 9078 -> 0 bytes .../__pycache__/terminal.cpython-312.pyc | Bin 5841 -> 0 bytes .../__pycache__/terminal256.cpython-312.pyc | Bin 15169 -> 0 bytes .../_vendor/pygments/formatters/_mapping.py | 23 - .../pip/_vendor/pygments/formatters/bbcode.py | 108 - .../pip/_vendor/pygments/formatters/groff.py | 170 - .../pip/_vendor/pygments/formatters/html.py | 989 -- .../pip/_vendor/pygments/formatters/img.py | 645 -- .../pip/_vendor/pygments/formatters/irc.py | 154 - .../pip/_vendor/pygments/formatters/latex.py | 521 - .../pip/_vendor/pygments/formatters/other.py | 161 - .../pygments/formatters/pangomarkup.py | 83 - .../pip/_vendor/pygments/formatters/rtf.py | 146 - .../pip/_vendor/pygments/formatters/svg.py | 188 - .../_vendor/pygments/formatters/terminal.py | 127 - .../pygments/formatters/terminal256.py | 338 - .../pip/_vendor/pygments/lexer.py | 943 -- .../pip/_vendor/pygments/lexers/__init__.py | 362 - .../__pycache__/__init__.cpython-312.pyc | Bin 14664 -> 0 bytes .../__pycache__/_mapping.cpython-312.pyc | Bin 64416 -> 0 bytes .../lexers/__pycache__/python.cpython-312.pyc | Bin 42651 -> 0 bytes .../pip/_vendor/pygments/lexers/_mapping.py | 559 -- .../pip/_vendor/pygments/lexers/python.py | 1198 --- .../pip/_vendor/pygments/modeline.py | 43 - .../pip/_vendor/pygments/plugin.py | 88 - .../pip/_vendor/pygments/regexopt.py | 91 - .../pip/_vendor/pygments/scanner.py | 104 - .../pip/_vendor/pygments/sphinxext.py | 217 - .../pip/_vendor/pygments/style.py | 197 - .../pip/_vendor/pygments/styles/__init__.py | 103 - .../__pycache__/__init__.cpython-312.pyc | Bin 4460 -> 0 bytes .../pip/_vendor/pygments/token.py | 213 - .../pip/_vendor/pygments/unistring.py | 153 - .../pip/_vendor/pygments/util.py | 330 - .../pip/_vendor/pyparsing/__init__.py | 322 - .../__pycache__/__init__.cpython-312.pyc | Bin 7923 -> 0 bytes .../__pycache__/actions.cpython-312.pyc | Bin 8407 -> 0 bytes .../__pycache__/common.cpython-312.pyc | Bin 13426 -> 0 bytes .../__pycache__/core.cpython-312.pyc | Bin 267720 -> 0 bytes .../__pycache__/exceptions.cpython-312.pyc | Bin 13006 -> 0 bytes .../__pycache__/helpers.cpython-312.pyc | Bin 48513 -> 0 bytes .../__pycache__/results.cpython-312.pyc | Bin 34122 -> 0 bytes .../__pycache__/testing.cpython-312.pyc | Bin 17200 -> 0 bytes .../__pycache__/unicode.cpython-312.pyc | Bin 13196 -> 0 bytes .../__pycache__/util.cpython-312.pyc | Bin 14916 -> 0 bytes .../pip/_vendor/pyparsing/actions.py | 217 - .../pip/_vendor/pyparsing/common.py | 432 - .../pip/_vendor/pyparsing/core.py | 6115 ------------ .../pip/_vendor/pyparsing/diagram/__init__.py | 656 -- .../__pycache__/__init__.cpython-312.pyc | Bin 26825 -> 0 bytes .../pip/_vendor/pyparsing/exceptions.py | 299 - .../pip/_vendor/pyparsing/helpers.py | 1100 -- .../pip/_vendor/pyparsing/results.py | 796 -- .../pip/_vendor/pyparsing/testing.py | 331 - .../pip/_vendor/pyparsing/unicode.py | 361 - .../pip/_vendor/pyparsing/util.py | 284 - .../pip/_vendor/pyproject_hooks/__init__.py | 23 - .../__pycache__/__init__.cpython-312.pyc | Bin 625 -> 0 bytes .../__pycache__/_compat.cpython-312.pyc | Bin 386 -> 0 bytes .../__pycache__/_impl.cpython-312.pyc | Bin 14737 -> 0 bytes .../pip/_vendor/pyproject_hooks/_compat.py | 8 - .../pip/_vendor/pyproject_hooks/_impl.py | 330 - .../pyproject_hooks/_in_process/__init__.py | 18 - .../__pycache__/__init__.cpython-312.pyc | Bin 1092 -> 0 bytes .../__pycache__/_in_process.cpython-312.pyc | Bin 14409 -> 0 bytes .../_in_process/_in_process.py | 353 - .../pip/_vendor/requests/__init__.py | 182 - .../__pycache__/__init__.cpython-312.pyc | Bin 5465 -> 0 bytes .../__pycache__/__version__.cpython-312.pyc | Bin 596 -> 0 bytes .../_internal_utils.cpython-312.pyc | Bin 2036 -> 0 bytes .../__pycache__/adapters.cpython-312.pyc | Bin 21292 -> 0 bytes .../requests/__pycache__/api.cpython-312.pyc | Bin 7216 -> 0 bytes .../requests/__pycache__/auth.cpython-312.pyc | Bin 13935 -> 0 bytes .../__pycache__/certs.cpython-312.pyc | Bin 934 -> 0 bytes .../__pycache__/compat.cpython-312.pyc | Bin 1519 -> 0 bytes .../__pycache__/cookies.cpython-312.pyc | Bin 25258 -> 0 bytes .../__pycache__/exceptions.cpython-312.pyc | Bin 7059 -> 0 bytes .../requests/__pycache__/help.cpython-312.pyc | Bin 4324 -> 0 bytes .../__pycache__/hooks.cpython-312.pyc | Bin 1064 -> 0 bytes .../__pycache__/models.cpython-312.pyc | Bin 35460 -> 0 bytes .../__pycache__/packages.cpython-312.pyc | Bin 784 -> 0 bytes .../__pycache__/sessions.cpython-312.pyc | Bin 27769 -> 0 bytes .../__pycache__/status_codes.cpython-312.pyc | Bin 5971 -> 0 bytes .../__pycache__/structures.cpython-312.pyc | Bin 5629 -> 0 bytes .../__pycache__/utils.cpython-312.pyc | Bin 36087 -> 0 bytes .../pip/_vendor/requests/__version__.py | 14 - .../pip/_vendor/requests/_internal_utils.py | 50 - .../pip/_vendor/requests/adapters.py | 538 - .../site-packages/pip/_vendor/requests/api.py | 157 - .../pip/_vendor/requests/auth.py | 315 - .../pip/_vendor/requests/certs.py | 24 - .../pip/_vendor/requests/compat.py | 67 - .../pip/_vendor/requests/cookies.py | 561 -- .../pip/_vendor/requests/exceptions.py | 141 - .../pip/_vendor/requests/help.py | 131 - .../pip/_vendor/requests/hooks.py | 33 - .../pip/_vendor/requests/models.py | 1034 -- .../pip/_vendor/requests/packages.py | 16 - .../pip/_vendor/requests/sessions.py | 833 -- .../pip/_vendor/requests/status_codes.py | 128 - .../pip/_vendor/requests/structures.py | 99 - .../pip/_vendor/requests/utils.py | 1088 -- .../pip/_vendor/resolvelib/__init__.py | 26 - .../__pycache__/__init__.cpython-312.pyc | Bin 646 -> 0 bytes .../__pycache__/providers.cpython-312.pyc | Bin 6863 -> 0 bytes .../__pycache__/reporters.cpython-312.pyc | Bin 2666 -> 0 bytes .../__pycache__/resolvers.cpython-312.pyc | Bin 25909 -> 0 bytes .../__pycache__/structs.cpython-312.pyc | Bin 10518 -> 0 bytes .../pip/_vendor/resolvelib/compat/__init__.py | 0 .../__pycache__/__init__.cpython-312.pyc | Bin 212 -> 0 bytes .../collections_abc.cpython-312.pyc | Bin 432 -> 0 bytes .../resolvelib/compat/collections_abc.py | 6 - .../pip/_vendor/resolvelib/providers.py | 133 - .../pip/_vendor/resolvelib/reporters.py | 43 - .../pip/_vendor/resolvelib/resolvers.py | 547 - .../pip/_vendor/resolvelib/structs.py | 170 - .../pip/_vendor/rich/__init__.py | 177 - .../pip/_vendor/rich/__main__.py | 274 - .../rich/__pycache__/__init__.cpython-312.pyc | Bin 7027 -> 0 bytes .../rich/__pycache__/__main__.cpython-312.pyc | Bin 10316 -> 0 bytes .../__pycache__/_cell_widths.cpython-312.pyc | Bin 7833 -> 0 bytes .../__pycache__/_emoji_codes.cpython-312.pyc | Bin 205988 -> 0 bytes .../_emoji_replace.cpython-312.pyc | Bin 1741 -> 0 bytes .../_export_format.cpython-312.pyc | Bin 2333 -> 0 bytes .../__pycache__/_extension.cpython-312.pyc | Bin 549 -> 0 bytes .../rich/__pycache__/_fileno.cpython-312.pyc | Bin 867 -> 0 bytes .../rich/__pycache__/_inspect.cpython-312.pyc | Bin 12089 -> 0 bytes .../__pycache__/_log_render.cpython-312.pyc | Bin 4159 -> 0 bytes .../rich/__pycache__/_loop.cpython-312.pyc | Bin 1897 -> 0 bytes .../__pycache__/_null_file.cpython-312.pyc | Bin 3632 -> 0 bytes .../__pycache__/_palettes.cpython-312.pyc | Bin 5172 -> 0 bytes .../rich/__pycache__/_pick.cpython-312.pyc | Bin 738 -> 0 bytes .../rich/__pycache__/_ratio.cpython-312.pyc | Bin 6591 -> 0 bytes .../__pycache__/_spinners.cpython-312.pyc | Bin 13191 -> 0 bytes .../rich/__pycache__/_stack.cpython-312.pyc | Bin 977 -> 0 bytes .../rich/__pycache__/_timer.cpython-312.pyc | Bin 877 -> 0 bytes .../_win32_console.cpython-312.pyc | Bin 28988 -> 0 bytes .../rich/__pycache__/_windows.cpython-312.pyc | Bin 2502 -> 0 bytes .../_windows_renderer.cpython-312.pyc | Bin 3585 -> 0 bytes .../rich/__pycache__/_wrap.cpython-312.pyc | Bin 2372 -> 0 bytes .../rich/__pycache__/abc.cpython-312.pyc | Bin 1620 -> 0 bytes .../rich/__pycache__/align.cpython-312.pyc | Bin 12334 -> 0 bytes .../rich/__pycache__/ansi.cpython-312.pyc | Bin 9118 -> 0 bytes .../rich/__pycache__/bar.cpython-312.pyc | Bin 4284 -> 0 bytes .../rich/__pycache__/box.cpython-312.pyc | Bin 11870 -> 0 bytes .../rich/__pycache__/cells.cpython-312.pyc | Bin 5630 -> 0 bytes .../rich/__pycache__/color.cpython-312.pyc | Bin 26582 -> 0 bytes .../__pycache__/color_triplet.cpython-312.pyc | Bin 1713 -> 0 bytes .../rich/__pycache__/columns.cpython-312.pyc | Bin 8599 -> 0 bytes .../rich/__pycache__/console.cpython-312.pyc | Bin 113805 -> 0 bytes .../__pycache__/constrain.cpython-312.pyc | Bin 2270 -> 0 bytes .../__pycache__/containers.cpython-312.pyc | Bin 9238 -> 0 bytes .../rich/__pycache__/control.cpython-312.pyc | Bin 10941 -> 0 bytes .../default_styles.cpython-312.pyc | Bin 10385 -> 0 bytes .../rich/__pycache__/diagnose.cpython-312.pyc | Bin 1499 -> 0 bytes .../rich/__pycache__/emoji.cpython-312.pyc | Bin 4221 -> 0 bytes .../rich/__pycache__/errors.cpython-312.pyc | Bin 1857 -> 0 bytes .../__pycache__/file_proxy.cpython-312.pyc | Bin 3589 -> 0 bytes .../rich/__pycache__/filesize.cpython-312.pyc | Bin 3094 -> 0 bytes .../__pycache__/highlighter.cpython-312.pyc | Bin 9910 -> 0 bytes .../rich/__pycache__/json.cpython-312.pyc | Bin 6047 -> 0 bytes .../rich/__pycache__/jupyter.cpython-312.pyc | Bin 5221 -> 0 bytes .../rich/__pycache__/layout.cpython-312.pyc | Bin 20232 -> 0 bytes .../rich/__pycache__/live.cpython-312.pyc | Bin 19155 -> 0 bytes .../__pycache__/live_render.cpython-312.pyc | Bin 4906 -> 0 bytes .../rich/__pycache__/logging.cpython-312.pyc | Bin 13566 -> 0 bytes .../rich/__pycache__/markup.cpython-312.pyc | Bin 9310 -> 0 bytes .../rich/__pycache__/measure.cpython-312.pyc | Bin 6388 -> 0 bytes .../rich/__pycache__/padding.cpython-312.pyc | Bin 7146 -> 0 bytes .../rich/__pycache__/pager.cpython-312.pyc | Bin 1832 -> 0 bytes .../rich/__pycache__/palette.cpython-312.pyc | Bin 5326 -> 0 bytes .../rich/__pycache__/panel.cpython-312.pyc | Bin 12109 -> 0 bytes .../rich/__pycache__/pretty.cpython-312.pyc | Bin 40068 -> 0 bytes .../rich/__pycache__/progress.cpython-312.pyc | Bin 75090 -> 0 bytes .../__pycache__/progress_bar.cpython-312.pyc | Bin 10401 -> 0 bytes .../rich/__pycache__/prompt.cpython-312.pyc | Bin 14793 -> 0 bytes .../rich/__pycache__/protocol.cpython-312.pyc | Bin 1804 -> 0 bytes .../rich/__pycache__/region.cpython-312.pyc | Bin 579 -> 0 bytes .../rich/__pycache__/repr.cpython-312.pyc | Bin 6638 -> 0 bytes .../rich/__pycache__/rule.cpython-312.pyc | Bin 6580 -> 0 bytes .../rich/__pycache__/scope.cpython-312.pyc | Bin 3842 -> 0 bytes .../rich/__pycache__/screen.cpython-312.pyc | Bin 2496 -> 0 bytes .../rich/__pycache__/segment.cpython-312.pyc | Bin 28173 -> 0 bytes .../rich/__pycache__/spinner.cpython-312.pyc | Bin 6076 -> 0 bytes .../rich/__pycache__/status.cpython-312.pyc | Bin 6080 -> 0 bytes .../rich/__pycache__/style.cpython-312.pyc | Bin 33526 -> 0 bytes .../rich/__pycache__/styled.cpython-312.pyc | Bin 2151 -> 0 bytes .../rich/__pycache__/syntax.cpython-312.pyc | Bin 39624 -> 0 bytes .../rich/__pycache__/table.cpython-312.pyc | Bin 43596 -> 0 bytes .../terminal_theme.cpython-312.pyc | Bin 3360 -> 0 bytes .../rich/__pycache__/text.cpython-312.pyc | Bin 58975 -> 0 bytes .../rich/__pycache__/theme.cpython-312.pyc | Bin 6352 -> 0 bytes .../rich/__pycache__/themes.cpython-312.pyc | Bin 326 -> 0 bytes .../__pycache__/traceback.cpython-312.pyc | Bin 31560 -> 0 bytes .../rich/__pycache__/tree.cpython-312.pyc | Bin 11451 -> 0 bytes .../pip/_vendor/rich/_cell_widths.py | 451 - .../pip/_vendor/rich/_emoji_codes.py | 3610 ------- .../pip/_vendor/rich/_emoji_replace.py | 32 - .../pip/_vendor/rich/_export_format.py | 76 - .../pip/_vendor/rich/_extension.py | 10 - .../site-packages/pip/_vendor/rich/_fileno.py | 24 - .../pip/_vendor/rich/_inspect.py | 270 - .../pip/_vendor/rich/_log_render.py | 94 - .../site-packages/pip/_vendor/rich/_loop.py | 43 - .../pip/_vendor/rich/_null_file.py | 69 - .../pip/_vendor/rich/_palettes.py | 309 - .../site-packages/pip/_vendor/rich/_pick.py | 17 - .../site-packages/pip/_vendor/rich/_ratio.py | 160 - .../pip/_vendor/rich/_spinners.py | 482 - .../site-packages/pip/_vendor/rich/_stack.py | 16 - .../site-packages/pip/_vendor/rich/_timer.py | 19 - .../pip/_vendor/rich/_win32_console.py | 662 -- .../pip/_vendor/rich/_windows.py | 72 - .../pip/_vendor/rich/_windows_renderer.py | 56 - .../site-packages/pip/_vendor/rich/_wrap.py | 56 - .../site-packages/pip/_vendor/rich/abc.py | 33 - .../site-packages/pip/_vendor/rich/align.py | 311 - .../site-packages/pip/_vendor/rich/ansi.py | 240 - .../site-packages/pip/_vendor/rich/bar.py | 94 - .../site-packages/pip/_vendor/rich/box.py | 517 - .../site-packages/pip/_vendor/rich/cells.py | 154 - .../site-packages/pip/_vendor/rich/color.py | 622 -- .../pip/_vendor/rich/color_triplet.py | 38 - .../site-packages/pip/_vendor/rich/columns.py | 187 - .../site-packages/pip/_vendor/rich/console.py | 2633 ----- .../pip/_vendor/rich/constrain.py | 37 - .../pip/_vendor/rich/containers.py | 167 - .../site-packages/pip/_vendor/rich/control.py | 225 - .../pip/_vendor/rich/default_styles.py | 190 - .../pip/_vendor/rich/diagnose.py | 37 - .../site-packages/pip/_vendor/rich/emoji.py | 96 - .../site-packages/pip/_vendor/rich/errors.py | 34 - .../pip/_vendor/rich/file_proxy.py | 57 - .../pip/_vendor/rich/filesize.py | 89 - .../pip/_vendor/rich/highlighter.py | 232 - .../site-packages/pip/_vendor/rich/json.py | 140 - .../site-packages/pip/_vendor/rich/jupyter.py | 101 - .../site-packages/pip/_vendor/rich/layout.py | 443 - .../site-packages/pip/_vendor/rich/live.py | 375 - .../pip/_vendor/rich/live_render.py | 113 - .../site-packages/pip/_vendor/rich/logging.py | 289 - .../site-packages/pip/_vendor/rich/markup.py | 246 - .../site-packages/pip/_vendor/rich/measure.py | 151 - .../site-packages/pip/_vendor/rich/padding.py | 141 - .../site-packages/pip/_vendor/rich/pager.py | 34 - .../site-packages/pip/_vendor/rich/palette.py | 100 - .../site-packages/pip/_vendor/rich/panel.py | 308 - .../site-packages/pip/_vendor/rich/pretty.py | 994 -- .../pip/_vendor/rich/progress.py | 1702 ---- .../pip/_vendor/rich/progress_bar.py | 224 - .../site-packages/pip/_vendor/rich/prompt.py | 376 - .../pip/_vendor/rich/protocol.py | 42 - .../site-packages/pip/_vendor/rich/region.py | 10 - .../site-packages/pip/_vendor/rich/repr.py | 149 - .../site-packages/pip/_vendor/rich/rule.py | 130 - .../site-packages/pip/_vendor/rich/scope.py | 86 - .../site-packages/pip/_vendor/rich/screen.py | 54 - .../site-packages/pip/_vendor/rich/segment.py | 739 -- .../site-packages/pip/_vendor/rich/spinner.py | 137 - .../site-packages/pip/_vendor/rich/status.py | 132 - .../site-packages/pip/_vendor/rich/style.py | 796 -- .../site-packages/pip/_vendor/rich/styled.py | 42 - .../site-packages/pip/_vendor/rich/syntax.py | 948 -- .../site-packages/pip/_vendor/rich/table.py | 1002 -- .../pip/_vendor/rich/terminal_theme.py | 153 - .../site-packages/pip/_vendor/rich/text.py | 1307 --- .../site-packages/pip/_vendor/rich/theme.py | 115 - .../site-packages/pip/_vendor/rich/themes.py | 5 - .../pip/_vendor/rich/traceback.py | 756 -- .../site-packages/pip/_vendor/rich/tree.py | 251 - .../site-packages/pip/_vendor/six.py | 998 -- .../pip/_vendor/tenacity/__init__.py | 608 -- .../__pycache__/__init__.cpython-312.pyc | Bin 27098 -> 0 bytes .../__pycache__/_asyncio.cpython-312.pyc | Bin 4818 -> 0 bytes .../__pycache__/_utils.cpython-312.pyc | Bin 2327 -> 0 bytes .../__pycache__/after.cpython-312.pyc | Bin 1636 -> 0 bytes .../__pycache__/before.cpython-312.pyc | Bin 1476 -> 0 bytes .../__pycache__/before_sleep.cpython-312.pyc | Bin 2314 -> 0 bytes .../tenacity/__pycache__/nap.cpython-312.pyc | Bin 1424 -> 0 bytes .../__pycache__/retry.cpython-312.pyc | Bin 14293 -> 0 bytes .../tenacity/__pycache__/stop.cpython-312.pyc | Bin 5580 -> 0 bytes .../__pycache__/tornadoweb.cpython-312.pyc | Bin 2598 -> 0 bytes .../tenacity/__pycache__/wait.cpython-312.pyc | Bin 12425 -> 0 bytes .../pip/_vendor/tenacity/_asyncio.py | 94 - .../pip/_vendor/tenacity/_utils.py | 76 - .../pip/_vendor/tenacity/after.py | 51 - .../pip/_vendor/tenacity/before.py | 46 - .../pip/_vendor/tenacity/before_sleep.py | 71 - .../site-packages/pip/_vendor/tenacity/nap.py | 43 - .../pip/_vendor/tenacity/retry.py | 272 - .../pip/_vendor/tenacity/stop.py | 103 - .../pip/_vendor/tenacity/tornadoweb.py | 59 - .../pip/_vendor/tenacity/wait.py | 228 - .../pip/_vendor/tomli/__init__.py | 11 - .../__pycache__/__init__.cpython-312.pyc | Bin 396 -> 0 bytes .../tomli/__pycache__/_parser.cpython-312.pyc | Bin 26939 -> 0 bytes .../tomli/__pycache__/_re.cpython-312.pyc | Bin 3920 -> 0 bytes .../tomli/__pycache__/_types.cpython-312.pyc | Bin 378 -> 0 bytes .../pip/_vendor/tomli/_parser.py | 691 -- .../site-packages/pip/_vendor/tomli/_re.py | 107 - .../site-packages/pip/_vendor/tomli/_types.py | 10 - .../pip/_vendor/truststore/__init__.py | 13 - .../__pycache__/__init__.cpython-312.pyc | Bin 630 -> 0 bytes .../__pycache__/_api.cpython-312.pyc | Bin 15809 -> 0 bytes .../__pycache__/_macos.cpython-312.pyc | Bin 16674 -> 0 bytes .../__pycache__/_openssl.cpython-312.pyc | Bin 2227 -> 0 bytes .../_ssl_constants.cpython-312.pyc | Bin 1111 -> 0 bytes .../__pycache__/_windows.cpython-312.pyc | Bin 15518 -> 0 bytes .../pip/_vendor/truststore/_api.py | 302 - .../pip/_vendor/truststore/_macos.py | 501 - .../pip/_vendor/truststore/_openssl.py | 66 - .../pip/_vendor/truststore/_ssl_constants.py | 31 - .../pip/_vendor/truststore/_windows.py | 554 -- .../pip/_vendor/typing_extensions.py | 3072 ------ .../pip/_vendor/urllib3/__init__.py | 102 - .../__pycache__/__init__.cpython-312.pyc | Bin 3417 -> 0 bytes .../__pycache__/_collections.cpython-312.pyc | Bin 16500 -> 0 bytes .../__pycache__/_version.cpython-312.pyc | Bin 230 -> 0 bytes .../__pycache__/connection.cpython-312.pyc | Bin 20419 -> 0 bytes .../connectionpool.cpython-312.pyc | Bin 36454 -> 0 bytes .../__pycache__/exceptions.cpython-312.pyc | Bin 13505 -> 0 bytes .../__pycache__/fields.cpython-312.pyc | Bin 10425 -> 0 bytes .../__pycache__/filepost.cpython-312.pyc | Bin 4030 -> 0 bytes .../__pycache__/poolmanager.cpython-312.pyc | Bin 20812 -> 0 bytes .../__pycache__/request.cpython-312.pyc | Bin 7306 -> 0 bytes .../__pycache__/response.cpython-312.pyc | Bin 33980 -> 0 bytes .../pip/_vendor/urllib3/_collections.py | 355 - .../pip/_vendor/urllib3/_version.py | 2 - .../pip/_vendor/urllib3/connection.py | 572 -- .../pip/_vendor/urllib3/connectionpool.py | 1137 --- .../pip/_vendor/urllib3/contrib/__init__.py | 0 .../__pycache__/__init__.cpython-312.pyc | Bin 210 -> 0 bytes .../_appengine_environ.cpython-312.pyc | Bin 1860 -> 0 bytes .../__pycache__/appengine.cpython-312.pyc | Bin 11576 -> 0 bytes .../__pycache__/ntlmpool.cpython-312.pyc | Bin 5731 -> 0 bytes .../__pycache__/pyopenssl.cpython-312.pyc | Bin 24462 -> 0 bytes .../securetransport.cpython-312.pyc | Bin 35568 -> 0 bytes .../contrib/__pycache__/socks.cpython-312.pyc | Bin 7523 -> 0 bytes .../urllib3/contrib/_appengine_environ.py | 36 - .../contrib/_securetransport/__init__.py | 0 .../__pycache__/__init__.cpython-312.pyc | Bin 227 -> 0 bytes .../__pycache__/bindings.cpython-312.pyc | Bin 17439 -> 0 bytes .../__pycache__/low_level.cpython-312.pyc | Bin 14813 -> 0 bytes .../contrib/_securetransport/bindings.py | 519 - .../contrib/_securetransport/low_level.py | 397 - .../pip/_vendor/urllib3/contrib/appengine.py | 314 - .../pip/_vendor/urllib3/contrib/ntlmpool.py | 130 - .../pip/_vendor/urllib3/contrib/pyopenssl.py | 518 - .../urllib3/contrib/securetransport.py | 921 -- .../pip/_vendor/urllib3/contrib/socks.py | 216 - .../pip/_vendor/urllib3/exceptions.py | 323 - .../pip/_vendor/urllib3/fields.py | 274 - .../pip/_vendor/urllib3/filepost.py | 98 - .../pip/_vendor/urllib3/packages/__init__.py | 0 .../__pycache__/__init__.cpython-312.pyc | Bin 211 -> 0 bytes .../packages/__pycache__/six.cpython-312.pyc | Bin 41331 -> 0 bytes .../urllib3/packages/backports/__init__.py | 0 .../__pycache__/__init__.cpython-312.pyc | Bin 221 -> 0 bytes .../__pycache__/makefile.cpython-312.pyc | Bin 1837 -> 0 bytes .../weakref_finalize.cpython-312.pyc | Bin 7343 -> 0 bytes .../urllib3/packages/backports/makefile.py | 51 - .../packages/backports/weakref_finalize.py | 155 - .../pip/_vendor/urllib3/packages/six.py | 1076 -- .../pip/_vendor/urllib3/poolmanager.py | 556 -- .../pip/_vendor/urllib3/request.py | 191 - .../pip/_vendor/urllib3/response.py | 879 -- .../pip/_vendor/urllib3/util/__init__.py | 49 - .../util/__pycache__/__init__.cpython-312.pyc | Bin 1158 -> 0 bytes .../__pycache__/connection.cpython-312.pyc | Bin 4768 -> 0 bytes .../util/__pycache__/proxy.cpython-312.pyc | Bin 1564 -> 0 bytes .../util/__pycache__/queue.cpython-312.pyc | Bin 1364 -> 0 bytes .../util/__pycache__/request.cpython-312.pyc | Bin 4195 -> 0 bytes .../util/__pycache__/response.cpython-312.pyc | Bin 3001 -> 0 bytes .../util/__pycache__/retry.cpython-312.pyc | Bin 21730 -> 0 bytes .../util/__pycache__/ssl_.cpython-312.pyc | Bin 15115 -> 0 bytes .../ssl_match_hostname.cpython-312.pyc | Bin 5083 -> 0 bytes .../__pycache__/ssltransport.cpython-312.pyc | Bin 10784 -> 0 bytes .../util/__pycache__/timeout.cpython-312.pyc | Bin 11151 -> 0 bytes .../util/__pycache__/url.cpython-312.pyc | Bin 15807 -> 0 bytes .../util/__pycache__/wait.cpython-312.pyc | Bin 4415 -> 0 bytes .../pip/_vendor/urllib3/util/connection.py | 149 - .../pip/_vendor/urllib3/util/proxy.py | 57 - .../pip/_vendor/urllib3/util/queue.py | 22 - .../pip/_vendor/urllib3/util/request.py | 137 - .../pip/_vendor/urllib3/util/response.py | 107 - .../pip/_vendor/urllib3/util/retry.py | 622 -- .../pip/_vendor/urllib3/util/ssl_.py | 495 - .../urllib3/util/ssl_match_hostname.py | 159 - .../pip/_vendor/urllib3/util/ssltransport.py | 221 - .../pip/_vendor/urllib3/util/timeout.py | 271 - .../pip/_vendor/urllib3/util/url.py | 435 - .../pip/_vendor/urllib3/util/wait.py | 152 - .../site-packages/pip/_vendor/vendor.txt | 24 - .../pip/_vendor/webencodings/__init__.py | 342 - .../__pycache__/__init__.cpython-312.pyc | Bin 12013 -> 0 bytes .../__pycache__/labels.cpython-312.pyc | Bin 7144 -> 0 bytes .../__pycache__/mklabels.cpython-312.pyc | Bin 2711 -> 0 bytes .../__pycache__/tests.cpython-312.pyc | Bin 9263 -> 0 bytes .../x_user_defined.cpython-312.pyc | Bin 3307 -> 0 bytes .../pip/_vendor/webencodings/labels.py | 231 - .../pip/_vendor/webencodings/mklabels.py | 59 - .../pip/_vendor/webencodings/tests.py | 153 - .../_vendor/webencodings/x_user_defined.py | 325 - .../lib/python3.12/site-packages/pip/py.typed | 4 - .../requests-2.32.5.dist-info/INSTALLER | 1 - .../requests-2.32.5.dist-info/METADATA | 133 - .../requests-2.32.5.dist-info/RECORD | 43 - .../requests-2.32.5.dist-info/REQUESTED | 0 .../requests-2.32.5.dist-info/WHEEL | 5 - .../licenses/LICENSE | 175 - .../requests-2.32.5.dist-info/top_level.txt | 1 - .../site-packages/requests/__init__.py | 184 - .../__pycache__/__init__.cpython-312.pyc | Bin 5420 -> 0 bytes .../__pycache__/__version__.cpython-312.pyc | Bin 584 -> 0 bytes .../_internal_utils.cpython-312.pyc | Bin 2024 -> 0 bytes .../__pycache__/adapters.cpython-312.pyc | Bin 27811 -> 0 bytes .../requests/__pycache__/api.cpython-312.pyc | Bin 7204 -> 0 bytes .../requests/__pycache__/auth.cpython-312.pyc | Bin 13923 -> 0 bytes .../__pycache__/certs.cpython-312.pyc | Bin 666 -> 0 bytes .../__pycache__/compat.cpython-312.pyc | Bin 2380 -> 0 bytes .../__pycache__/cookies.cpython-312.pyc | Bin 25276 -> 0 bytes .../__pycache__/exceptions.cpython-312.pyc | Bin 7585 -> 0 bytes .../requests/__pycache__/help.cpython-312.pyc | Bin 4327 -> 0 bytes .../__pycache__/hooks.cpython-312.pyc | Bin 1052 -> 0 bytes .../__pycache__/models.cpython-312.pyc | Bin 35501 -> 0 bytes .../__pycache__/packages.cpython-312.pyc | Bin 1139 -> 0 bytes .../__pycache__/sessions.cpython-312.pyc | Bin 27890 -> 0 bytes .../__pycache__/status_codes.cpython-312.pyc | Bin 6031 -> 0 bytes .../__pycache__/structures.cpython-312.pyc | Bin 5617 -> 0 bytes .../__pycache__/utils.cpython-312.pyc | Bin 36178 -> 0 bytes .../site-packages/requests/__version__.py | 14 - .../site-packages/requests/_internal_utils.py | 50 - .../site-packages/requests/adapters.py | 696 -- .../python3.12/site-packages/requests/api.py | 157 - .../python3.12/site-packages/requests/auth.py | 314 - .../site-packages/requests/certs.py | 17 - .../site-packages/requests/compat.py | 106 - .../site-packages/requests/cookies.py | 561 -- .../site-packages/requests/exceptions.py | 151 - .../python3.12/site-packages/requests/help.py | 134 - .../site-packages/requests/hooks.py | 33 - .../site-packages/requests/models.py | 1039 -- .../site-packages/requests/packages.py | 23 - .../site-packages/requests/sessions.py | 831 -- .../site-packages/requests/status_codes.py | 128 - .../site-packages/requests/structures.py | 99 - .../site-packages/requests/utils.py | 1086 -- .../urllib3-2.6.3.dist-info/INSTALLER | 1 - .../urllib3-2.6.3.dist-info/METADATA | 164 - .../urllib3-2.6.3.dist-info/RECORD | 79 - .../urllib3-2.6.3.dist-info/WHEEL | 4 - .../licenses/LICENSE.txt | 21 - .../site-packages/urllib3/__init__.py | 211 - .../__pycache__/__init__.cpython-312.pyc | Bin 7315 -> 0 bytes .../_base_connection.cpython-312.pyc | Bin 6853 -> 0 bytes .../__pycache__/_collections.cpython-312.pyc | Bin 23004 -> 0 bytes .../_request_methods.cpython-312.pyc | Bin 10607 -> 0 bytes .../__pycache__/_version.cpython-312.pyc | Bin 798 -> 0 bytes .../__pycache__/connection.cpython-312.pyc | Bin 38925 -> 0 bytes .../connectionpool.cpython-312.pyc | Bin 39740 -> 0 bytes .../__pycache__/exceptions.cpython-312.pyc | Bin 16616 -> 0 bytes .../__pycache__/fields.cpython-312.pyc | Bin 12027 -> 0 bytes .../__pycache__/filepost.cpython-312.pyc | Bin 3494 -> 0 bytes .../__pycache__/poolmanager.cpython-312.pyc | Bin 24343 -> 0 bytes .../__pycache__/response.cpython-312.pyc | Bin 57495 -> 0 bytes .../site-packages/urllib3/_base_connection.py | 165 - .../site-packages/urllib3/_collections.py | 487 - .../site-packages/urllib3/_request_methods.py | 278 - .../site-packages/urllib3/_version.py | 34 - .../site-packages/urllib3/connection.py | 1099 -- .../site-packages/urllib3/connectionpool.py | 1178 --- .../site-packages/urllib3/contrib/__init__.py | 0 .../__pycache__/__init__.cpython-312.pyc | Bin 198 -> 0 bytes .../__pycache__/pyopenssl.cpython-312.pyc | Bin 28221 -> 0 bytes .../contrib/__pycache__/socks.cpython-312.pyc | Bin 8176 -> 0 bytes .../urllib3/contrib/emscripten/__init__.py | 17 - .../__pycache__/__init__.cpython-312.pyc | Bin 995 -> 0 bytes .../__pycache__/connection.cpython-312.pyc | Bin 10392 -> 0 bytes .../__pycache__/fetch.cpython-312.pyc | Bin 28643 -> 0 bytes .../__pycache__/request.cpython-312.pyc | Bin 1426 -> 0 bytes .../__pycache__/response.cpython-312.pyc | Bin 12220 -> 0 bytes .../urllib3/contrib/emscripten/connection.py | 260 - .../emscripten/emscripten_fetch_worker.js | 110 - .../urllib3/contrib/emscripten/fetch.py | 726 -- .../urllib3/contrib/emscripten/request.py | 22 - .../urllib3/contrib/emscripten/response.py | 277 - .../urllib3/contrib/pyopenssl.py | 564 -- .../site-packages/urllib3/contrib/socks.py | 228 - .../site-packages/urllib3/exceptions.py | 335 - .../site-packages/urllib3/fields.py | 341 - .../site-packages/urllib3/filepost.py | 89 - .../site-packages/urllib3/http2/__init__.py | 53 - .../__pycache__/__init__.cpython-312.pyc | Bin 1751 -> 0 bytes .../__pycache__/connection.cpython-312.pyc | Bin 17058 -> 0 bytes .../http2/__pycache__/probe.cpython-312.pyc | Bin 3702 -> 0 bytes .../site-packages/urllib3/http2/connection.py | 356 - .../site-packages/urllib3/http2/probe.py | 87 - .../site-packages/urllib3/poolmanager.py | 651 -- .../python3.12/site-packages/urllib3/py.typed | 2 - .../site-packages/urllib3/response.py | 1480 --- .../site-packages/urllib3/util/__init__.py | 42 - .../util/__pycache__/__init__.cpython-312.pyc | Bin 1011 -> 0 bytes .../__pycache__/connection.cpython-312.pyc | Bin 4701 -> 0 bytes .../util/__pycache__/proxy.cpython-312.pyc | Bin 1223 -> 0 bytes .../util/__pycache__/request.cpython-312.pyc | Bin 8347 -> 0 bytes .../util/__pycache__/response.cpython-312.pyc | Bin 2879 -> 0 bytes .../util/__pycache__/retry.cpython-312.pyc | Bin 20839 -> 0 bytes .../util/__pycache__/ssl_.cpython-312.pyc | Bin 17325 -> 0 bytes .../ssl_match_hostname.cpython-312.pyc | Bin 5563 -> 0 bytes .../__pycache__/ssltransport.cpython-312.pyc | Bin 13330 -> 0 bytes .../util/__pycache__/timeout.cpython-312.pyc | Bin 11695 -> 0 bytes .../util/__pycache__/url.cpython-312.pyc | Bin 16232 -> 0 bytes .../util/__pycache__/util.cpython-312.pyc | Bin 2000 -> 0 bytes .../util/__pycache__/wait.cpython-312.pyc | Bin 3446 -> 0 bytes .../site-packages/urllib3/util/connection.py | 137 - .../site-packages/urllib3/util/proxy.py | 43 - .../site-packages/urllib3/util/request.py | 263 - .../site-packages/urllib3/util/response.py | 101 - .../site-packages/urllib3/util/retry.py | 549 - .../site-packages/urllib3/util/ssl_.py | 527 - .../urllib3/util/ssl_match_hostname.py | 159 - .../urllib3/util/ssltransport.py | 271 - .../site-packages/urllib3/util/timeout.py | 275 - .../site-packages/urllib3/util/url.py | 469 - .../site-packages/urllib3/util/util.py | 42 - .../site-packages/urllib3/util/wait.py | 124 - venv/lib64 | 1 - venv/pyvenv.cfg | 5 - 1207 files changed, 235034 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/normalizer delete mode 100755 venv/bin/pip delete mode 100755 venv/bin/pip3 delete mode 100755 venv/bin/pip3.12 delete mode 120000 venv/bin/python delete mode 120000 venv/bin/python3 delete mode 120000 venv/bin/python3.12 delete mode 100644 venv/lib/python3.12/site-packages/certifi-2026.1.4.dist-info/INSTALLER delete mode 100644 venv/lib/python3.12/site-packages/certifi-2026.1.4.dist-info/METADATA delete mode 100644 venv/lib/python3.12/site-packages/certifi-2026.1.4.dist-info/RECORD delete mode 100644 venv/lib/python3.12/site-packages/certifi-2026.1.4.dist-info/WHEEL delete mode 100644 venv/lib/python3.12/site-packages/certifi-2026.1.4.dist-info/licenses/LICENSE delete mode 100644 venv/lib/python3.12/site-packages/certifi-2026.1.4.dist-info/top_level.txt delete mode 100644 venv/lib/python3.12/site-packages/certifi/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/certifi/__main__.py delete mode 100644 venv/lib/python3.12/site-packages/certifi/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/certifi/__pycache__/__main__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/certifi/__pycache__/core.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/certifi/cacert.pem delete mode 100644 venv/lib/python3.12/site-packages/certifi/core.py delete mode 100644 venv/lib/python3.12/site-packages/certifi/py.typed delete mode 100644 venv/lib/python3.12/site-packages/charset_normalizer-3.4.4.dist-info/INSTALLER delete mode 100644 venv/lib/python3.12/site-packages/charset_normalizer-3.4.4.dist-info/METADATA delete mode 100644 venv/lib/python3.12/site-packages/charset_normalizer-3.4.4.dist-info/RECORD delete mode 100644 venv/lib/python3.12/site-packages/charset_normalizer-3.4.4.dist-info/WHEEL delete mode 100644 venv/lib/python3.12/site-packages/charset_normalizer-3.4.4.dist-info/entry_points.txt delete mode 100644 venv/lib/python3.12/site-packages/charset_normalizer-3.4.4.dist-info/licenses/LICENSE delete mode 100644 venv/lib/python3.12/site-packages/charset_normalizer-3.4.4.dist-info/top_level.txt delete mode 100644 venv/lib/python3.12/site-packages/charset_normalizer/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/charset_normalizer/__main__.py delete mode 100644 venv/lib/python3.12/site-packages/charset_normalizer/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/charset_normalizer/__pycache__/__main__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/charset_normalizer/__pycache__/api.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/charset_normalizer/__pycache__/cd.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/charset_normalizer/__pycache__/constant.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/charset_normalizer/__pycache__/legacy.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/charset_normalizer/__pycache__/md.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/charset_normalizer/__pycache__/models.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/charset_normalizer/__pycache__/utils.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/charset_normalizer/__pycache__/version.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/charset_normalizer/api.py delete mode 100644 venv/lib/python3.12/site-packages/charset_normalizer/cd.py delete mode 100644 venv/lib/python3.12/site-packages/charset_normalizer/cli/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/charset_normalizer/cli/__main__.py delete mode 100644 venv/lib/python3.12/site-packages/charset_normalizer/cli/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/charset_normalizer/cli/__pycache__/__main__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/charset_normalizer/constant.py delete mode 100644 venv/lib/python3.12/site-packages/charset_normalizer/legacy.py delete mode 100755 venv/lib/python3.12/site-packages/charset_normalizer/md.cpython-312-x86_64-linux-gnu.so delete mode 100644 venv/lib/python3.12/site-packages/charset_normalizer/md.py delete mode 100755 venv/lib/python3.12/site-packages/charset_normalizer/md__mypyc.cpython-312-x86_64-linux-gnu.so delete mode 100644 venv/lib/python3.12/site-packages/charset_normalizer/models.py delete mode 100644 venv/lib/python3.12/site-packages/charset_normalizer/py.typed delete mode 100644 venv/lib/python3.12/site-packages/charset_normalizer/utils.py delete mode 100644 venv/lib/python3.12/site-packages/charset_normalizer/version.py delete mode 100644 venv/lib/python3.12/site-packages/idna-3.11.dist-info/INSTALLER delete mode 100644 venv/lib/python3.12/site-packages/idna-3.11.dist-info/METADATA delete mode 100644 venv/lib/python3.12/site-packages/idna-3.11.dist-info/RECORD delete mode 100644 venv/lib/python3.12/site-packages/idna-3.11.dist-info/WHEEL delete mode 100644 venv/lib/python3.12/site-packages/idna-3.11.dist-info/licenses/LICENSE.md delete mode 100644 venv/lib/python3.12/site-packages/idna/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/idna/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/idna/__pycache__/codec.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/idna/__pycache__/compat.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/idna/__pycache__/core.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/idna/__pycache__/idnadata.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/idna/__pycache__/intranges.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/idna/__pycache__/package_data.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/idna/__pycache__/uts46data.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/idna/codec.py delete mode 100644 venv/lib/python3.12/site-packages/idna/compat.py delete mode 100644 venv/lib/python3.12/site-packages/idna/core.py delete mode 100644 venv/lib/python3.12/site-packages/idna/idnadata.py delete mode 100644 venv/lib/python3.12/site-packages/idna/intranges.py delete mode 100644 venv/lib/python3.12/site-packages/idna/package_data.py delete mode 100644 venv/lib/python3.12/site-packages/idna/py.typed delete mode 100644 venv/lib/python3.12/site-packages/idna/uts46data.py delete mode 100644 venv/lib/python3.12/site-packages/pip-24.0.dist-info/AUTHORS.txt delete mode 100644 venv/lib/python3.12/site-packages/pip-24.0.dist-info/INSTALLER delete mode 100644 venv/lib/python3.12/site-packages/pip-24.0.dist-info/LICENSE.txt delete mode 100644 venv/lib/python3.12/site-packages/pip-24.0.dist-info/METADATA delete mode 100644 venv/lib/python3.12/site-packages/pip-24.0.dist-info/RECORD delete mode 100644 venv/lib/python3.12/site-packages/pip-24.0.dist-info/REQUESTED delete mode 100644 venv/lib/python3.12/site-packages/pip-24.0.dist-info/WHEEL delete mode 100644 venv/lib/python3.12/site-packages/pip-24.0.dist-info/entry_points.txt delete mode 100644 venv/lib/python3.12/site-packages/pip-24.0.dist-info/top_level.txt delete mode 100644 venv/lib/python3.12/site-packages/pip/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/__main__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/__pip-runner__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/__pycache__/__main__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/__pycache__/__pip-runner__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/__pycache__/build_env.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/__pycache__/cache.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/__pycache__/configuration.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/__pycache__/exceptions.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/__pycache__/main.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/__pycache__/pyproject.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/__pycache__/self_outdated_check.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/__pycache__/wheel_builder.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/build_env.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/cache.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/cli/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/cli/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/cli/__pycache__/autocompletion.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/cli/__pycache__/base_command.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/cli/__pycache__/cmdoptions.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/cli/__pycache__/command_context.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/cli/__pycache__/main.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/cli/__pycache__/main_parser.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/cli/__pycache__/parser.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/cli/__pycache__/progress_bars.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/cli/__pycache__/req_command.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/cli/__pycache__/spinners.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/cli/__pycache__/status_codes.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/cli/autocompletion.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/cli/base_command.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/cli/cmdoptions.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/cli/command_context.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/cli/main.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/cli/main_parser.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/cli/parser.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/cli/progress_bars.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/cli/req_command.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/cli/spinners.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/cli/status_codes.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/commands/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/commands/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/commands/__pycache__/cache.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/commands/__pycache__/check.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/commands/__pycache__/completion.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/commands/__pycache__/configuration.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/commands/__pycache__/debug.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/commands/__pycache__/download.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/commands/__pycache__/freeze.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/commands/__pycache__/hash.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/commands/__pycache__/help.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/commands/__pycache__/index.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/commands/__pycache__/inspect.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/commands/__pycache__/install.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/commands/__pycache__/list.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/commands/__pycache__/search.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/commands/__pycache__/show.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/commands/__pycache__/uninstall.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/commands/__pycache__/wheel.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/commands/cache.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/commands/check.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/commands/completion.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/commands/configuration.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/commands/debug.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/commands/download.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/commands/freeze.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/commands/hash.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/commands/help.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/commands/index.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/commands/inspect.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/commands/install.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/commands/list.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/commands/search.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/commands/show.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/commands/uninstall.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/commands/wheel.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/configuration.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/distributions/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/distributions/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/distributions/__pycache__/base.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/distributions/__pycache__/installed.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/distributions/__pycache__/sdist.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/distributions/__pycache__/wheel.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/distributions/base.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/distributions/installed.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/distributions/sdist.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/distributions/wheel.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/exceptions.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/index/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/index/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/index/__pycache__/collector.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/index/__pycache__/package_finder.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/index/__pycache__/sources.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/index/collector.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/index/package_finder.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/index/sources.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/locations/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/locations/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/locations/__pycache__/_distutils.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/locations/__pycache__/_sysconfig.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/locations/__pycache__/base.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/locations/_distutils.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/locations/_sysconfig.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/locations/base.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/main.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/metadata/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/metadata/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/metadata/__pycache__/_json.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/metadata/__pycache__/base.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/metadata/__pycache__/pkg_resources.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/metadata/_json.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/metadata/base.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/metadata/importlib/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/metadata/importlib/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/metadata/importlib/__pycache__/_compat.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/metadata/importlib/__pycache__/_dists.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/metadata/importlib/__pycache__/_envs.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/metadata/importlib/_compat.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/metadata/importlib/_dists.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/metadata/importlib/_envs.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/metadata/pkg_resources.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/models/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/models/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/models/__pycache__/candidate.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/models/__pycache__/direct_url.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/models/__pycache__/format_control.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/models/__pycache__/index.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/models/__pycache__/installation_report.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/models/__pycache__/link.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/models/__pycache__/scheme.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/models/__pycache__/search_scope.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/models/__pycache__/selection_prefs.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/models/__pycache__/target_python.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/models/__pycache__/wheel.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/models/candidate.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/models/direct_url.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/models/format_control.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/models/index.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/models/installation_report.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/models/link.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/models/scheme.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/models/search_scope.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/models/selection_prefs.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/models/target_python.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/models/wheel.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/network/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/network/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/network/__pycache__/auth.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/network/__pycache__/cache.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/network/__pycache__/download.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/network/__pycache__/lazy_wheel.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/network/__pycache__/session.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/network/__pycache__/utils.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/network/__pycache__/xmlrpc.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/network/auth.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/network/cache.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/network/download.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/network/lazy_wheel.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/network/session.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/network/utils.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/network/xmlrpc.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/operations/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/operations/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/operations/__pycache__/check.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/operations/__pycache__/freeze.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/operations/__pycache__/prepare.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/operations/build/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/operations/build/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/operations/build/__pycache__/build_tracker.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/operations/build/__pycache__/metadata.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/operations/build/__pycache__/metadata_editable.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/operations/build/__pycache__/metadata_legacy.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/operations/build/__pycache__/wheel.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/operations/build/__pycache__/wheel_editable.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/operations/build/__pycache__/wheel_legacy.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/operations/build/build_tracker.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/operations/build/metadata.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/operations/build/metadata_editable.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/operations/build/metadata_legacy.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/operations/build/wheel.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/operations/build/wheel_editable.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/operations/build/wheel_legacy.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/operations/check.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/operations/freeze.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/operations/install/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/operations/install/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/operations/install/__pycache__/editable_legacy.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/operations/install/__pycache__/wheel.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/operations/install/editable_legacy.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/operations/install/wheel.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/operations/prepare.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/pyproject.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/req/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/req/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/req/__pycache__/constructors.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/req/__pycache__/req_file.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/req/__pycache__/req_install.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/req/__pycache__/req_set.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/req/__pycache__/req_uninstall.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/req/constructors.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/req/req_file.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/req/req_install.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/req/req_set.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/req/req_uninstall.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/resolution/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/resolution/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/resolution/__pycache__/base.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/resolution/base.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/resolution/legacy/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/resolution/legacy/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/resolution/legacy/__pycache__/resolver.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/resolution/legacy/resolver.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/resolution/resolvelib/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/resolution/resolvelib/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/resolution/resolvelib/__pycache__/base.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/resolution/resolvelib/__pycache__/candidates.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/resolution/resolvelib/__pycache__/factory.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/resolution/resolvelib/__pycache__/found_candidates.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/resolution/resolvelib/__pycache__/provider.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/resolution/resolvelib/__pycache__/reporter.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/resolution/resolvelib/__pycache__/requirements.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/resolution/resolvelib/__pycache__/resolver.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/resolution/resolvelib/base.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/resolution/resolvelib/candidates.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/resolution/resolvelib/factory.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/resolution/resolvelib/found_candidates.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/resolution/resolvelib/provider.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/resolution/resolvelib/reporter.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/resolution/resolvelib/requirements.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/resolution/resolvelib/resolver.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/self_outdated_check.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/utils/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/_jaraco_text.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/_log.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/appdirs.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/compat.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/compatibility_tags.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/datetime.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/deprecation.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/direct_url_helpers.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/egg_link.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/encoding.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/entrypoints.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/filesystem.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/filetypes.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/glibc.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/hashes.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/logging.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/misc.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/models.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/packaging.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/setuptools_build.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/subprocess.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/temp_dir.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/unpacking.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/urls.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/virtualenv.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/wheel.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/utils/_jaraco_text.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/utils/_log.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/utils/appdirs.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/utils/compat.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/utils/compatibility_tags.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/utils/datetime.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/utils/deprecation.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/utils/direct_url_helpers.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/utils/egg_link.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/utils/encoding.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/utils/entrypoints.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/utils/filesystem.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/utils/filetypes.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/utils/glibc.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/utils/hashes.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/utils/logging.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/utils/misc.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/utils/models.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/utils/packaging.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/utils/setuptools_build.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/utils/subprocess.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/utils/temp_dir.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/utils/unpacking.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/utils/urls.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/utils/virtualenv.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/utils/wheel.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/vcs/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/vcs/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/vcs/__pycache__/bazaar.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/vcs/__pycache__/git.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/vcs/__pycache__/mercurial.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/vcs/__pycache__/subversion.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/vcs/__pycache__/versioncontrol.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/vcs/bazaar.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/vcs/git.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/vcs/mercurial.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/vcs/subversion.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/vcs/versioncontrol.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_internal/wheel_builder.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/__pycache__/six.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/__pycache__/typing_extensions.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/__pycache__/_cmd.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/__pycache__/adapter.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/__pycache__/cache.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/__pycache__/controller.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/__pycache__/filewrapper.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/__pycache__/heuristics.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/__pycache__/serialize.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/__pycache__/wrapper.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/_cmd.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/adapter.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/cache.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/caches/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/caches/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/caches/__pycache__/file_cache.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/caches/__pycache__/redis_cache.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/caches/file_cache.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/caches/redis_cache.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/controller.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/filewrapper.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/heuristics.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/serialize.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/wrapper.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/certifi/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/certifi/__main__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/certifi/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/certifi/__pycache__/__main__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/certifi/__pycache__/core.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/certifi/cacert.pem delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/certifi/core.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/big5freq.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/big5prober.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/chardistribution.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/charsetgroupprober.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/charsetprober.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/codingstatemachine.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/codingstatemachinedict.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/cp949prober.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/enums.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/escprober.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/escsm.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/eucjpprober.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/euckrfreq.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/euckrprober.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/euctwfreq.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/euctwprober.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/gb2312freq.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/gb2312prober.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/hebrewprober.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/jisfreq.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/johabfreq.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/johabprober.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/jpcntx.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/langbulgarianmodel.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/langgreekmodel.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/langhebrewmodel.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/langhungarianmodel.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/langrussianmodel.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/langthaimodel.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/langturkishmodel.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/latin1prober.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/macromanprober.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/mbcharsetprober.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/mbcsgroupprober.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/mbcssm.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/resultdict.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/sbcharsetprober.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/sbcsgroupprober.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/sjisprober.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/universaldetector.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/utf1632prober.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/utf8prober.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/version.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/big5freq.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/big5prober.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/chardistribution.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/charsetgroupprober.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/charsetprober.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/cli/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/cli/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/cli/__pycache__/chardetect.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/cli/chardetect.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/codingstatemachine.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/codingstatemachinedict.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/cp949prober.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/enums.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/escprober.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/escsm.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/eucjpprober.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/euckrfreq.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/euckrprober.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/euctwfreq.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/euctwprober.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/gb2312freq.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/gb2312prober.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/hebrewprober.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/jisfreq.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/johabfreq.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/johabprober.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/jpcntx.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/langbulgarianmodel.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/langgreekmodel.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/langhebrewmodel.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/langhungarianmodel.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/langrussianmodel.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/langthaimodel.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/langturkishmodel.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/latin1prober.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/macromanprober.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/mbcharsetprober.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/mbcsgroupprober.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/mbcssm.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/metadata/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/metadata/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/metadata/__pycache__/languages.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/metadata/languages.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/resultdict.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/sbcharsetprober.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/sbcsgroupprober.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/sjisprober.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/universaldetector.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/utf1632prober.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/utf8prober.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/chardet/version.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/colorama/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/colorama/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/colorama/__pycache__/ansi.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/colorama/__pycache__/ansitowin32.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/colorama/__pycache__/initialise.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/colorama/__pycache__/win32.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/colorama/__pycache__/winterm.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/colorama/ansi.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/colorama/ansitowin32.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/colorama/initialise.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/colorama/tests/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/colorama/tests/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/colorama/tests/__pycache__/ansi_test.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/colorama/tests/__pycache__/ansitowin32_test.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/colorama/tests/__pycache__/initialise_test.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/colorama/tests/__pycache__/isatty_test.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/colorama/tests/__pycache__/utils.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/colorama/tests/__pycache__/winterm_test.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/colorama/tests/ansi_test.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/colorama/tests/ansitowin32_test.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/colorama/tests/initialise_test.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/colorama/tests/isatty_test.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/colorama/tests/utils.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/colorama/tests/winterm_test.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/colorama/win32.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/colorama/winterm.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/distlib/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/distlib/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/distlib/__pycache__/compat.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/distlib/__pycache__/database.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/distlib/__pycache__/index.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/distlib/__pycache__/locators.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/distlib/__pycache__/manifest.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/distlib/__pycache__/markers.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/distlib/__pycache__/metadata.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/distlib/__pycache__/resources.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/distlib/__pycache__/scripts.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/distlib/__pycache__/util.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/distlib/__pycache__/version.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/distlib/__pycache__/wheel.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/distlib/compat.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/distlib/database.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/distlib/index.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/distlib/locators.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/distlib/manifest.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/distlib/markers.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/distlib/metadata.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/distlib/resources.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/distlib/scripts.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/distlib/util.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/distlib/version.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/distlib/wheel.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/distro/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/distro/__main__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/distro/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/distro/__pycache__/__main__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/distro/__pycache__/distro.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/distro/distro.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/idna/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/idna/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/idna/__pycache__/codec.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/idna/__pycache__/compat.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/idna/__pycache__/core.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/idna/__pycache__/idnadata.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/idna/__pycache__/intranges.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/idna/__pycache__/package_data.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/idna/__pycache__/uts46data.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/idna/codec.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/idna/compat.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/idna/core.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/idna/idnadata.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/idna/intranges.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/idna/package_data.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/idna/uts46data.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/msgpack/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/msgpack/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/msgpack/__pycache__/exceptions.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/msgpack/__pycache__/ext.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/msgpack/__pycache__/fallback.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/msgpack/exceptions.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/msgpack/ext.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/msgpack/fallback.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/packaging/__about__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/packaging/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/packaging/__pycache__/__about__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/packaging/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/packaging/__pycache__/_manylinux.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/packaging/__pycache__/_musllinux.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/packaging/__pycache__/_structures.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/packaging/__pycache__/markers.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/packaging/__pycache__/requirements.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/packaging/__pycache__/specifiers.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/packaging/__pycache__/tags.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/packaging/__pycache__/utils.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/packaging/__pycache__/version.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/packaging/_manylinux.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/packaging/_musllinux.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/packaging/_structures.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/packaging/markers.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/packaging/requirements.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/packaging/specifiers.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/packaging/tags.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/packaging/utils.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/packaging/version.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pkg_resources/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pkg_resources/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/platformdirs/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/platformdirs/__main__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/platformdirs/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/platformdirs/__pycache__/__main__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/platformdirs/__pycache__/android.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/platformdirs/__pycache__/api.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/platformdirs/__pycache__/macos.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/platformdirs/__pycache__/unix.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/platformdirs/__pycache__/version.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/platformdirs/__pycache__/windows.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/platformdirs/android.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/platformdirs/api.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/platformdirs/macos.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/platformdirs/unix.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/platformdirs/version.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/platformdirs/windows.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/__main__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/__pycache__/__main__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/__pycache__/cmdline.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/__pycache__/console.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/__pycache__/filter.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/__pycache__/formatter.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/__pycache__/lexer.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/__pycache__/modeline.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/__pycache__/plugin.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/__pycache__/regexopt.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/__pycache__/scanner.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/__pycache__/sphinxext.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/__pycache__/style.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/__pycache__/token.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/__pycache__/unistring.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/__pycache__/util.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/cmdline.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/console.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/filter.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/filters/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/filters/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/formatter.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/formatters/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/formatters/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/formatters/__pycache__/_mapping.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/formatters/__pycache__/bbcode.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/formatters/__pycache__/groff.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/formatters/__pycache__/html.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/formatters/__pycache__/img.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/formatters/__pycache__/irc.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/formatters/__pycache__/latex.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/formatters/__pycache__/other.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/formatters/__pycache__/pangomarkup.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/formatters/__pycache__/rtf.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/formatters/__pycache__/svg.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/formatters/__pycache__/terminal.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/formatters/__pycache__/terminal256.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/formatters/_mapping.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/formatters/bbcode.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/formatters/groff.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/formatters/html.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/formatters/img.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/formatters/irc.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/formatters/latex.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/formatters/other.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/formatters/pangomarkup.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/formatters/rtf.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/formatters/svg.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/formatters/terminal.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/formatters/terminal256.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/lexer.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/lexers/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/lexers/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/lexers/__pycache__/_mapping.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/lexers/__pycache__/python.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/lexers/_mapping.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/lexers/python.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/modeline.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/plugin.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/regexopt.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/scanner.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/sphinxext.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/style.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/styles/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/styles/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/token.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/unistring.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pygments/util.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pyparsing/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pyparsing/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pyparsing/__pycache__/actions.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pyparsing/__pycache__/common.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pyparsing/__pycache__/core.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pyparsing/__pycache__/exceptions.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pyparsing/__pycache__/helpers.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pyparsing/__pycache__/results.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pyparsing/__pycache__/testing.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pyparsing/__pycache__/unicode.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pyparsing/__pycache__/util.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pyparsing/actions.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pyparsing/common.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pyparsing/core.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pyparsing/diagram/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pyparsing/diagram/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pyparsing/exceptions.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pyparsing/helpers.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pyparsing/results.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pyparsing/testing.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pyparsing/unicode.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pyparsing/util.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pyproject_hooks/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pyproject_hooks/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pyproject_hooks/__pycache__/_compat.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pyproject_hooks/__pycache__/_impl.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pyproject_hooks/_compat.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pyproject_hooks/_impl.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pyproject_hooks/_in_process/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pyproject_hooks/_in_process/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pyproject_hooks/_in_process/__pycache__/_in_process.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/pyproject_hooks/_in_process/_in_process.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/requests/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/requests/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/requests/__pycache__/__version__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/requests/__pycache__/_internal_utils.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/requests/__pycache__/adapters.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/requests/__pycache__/api.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/requests/__pycache__/auth.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/requests/__pycache__/certs.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/requests/__pycache__/compat.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/requests/__pycache__/cookies.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/requests/__pycache__/exceptions.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/requests/__pycache__/help.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/requests/__pycache__/hooks.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/requests/__pycache__/models.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/requests/__pycache__/packages.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/requests/__pycache__/sessions.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/requests/__pycache__/status_codes.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/requests/__pycache__/structures.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/requests/__pycache__/utils.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/requests/__version__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/requests/_internal_utils.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/requests/adapters.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/requests/api.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/requests/auth.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/requests/certs.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/requests/compat.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/requests/cookies.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/requests/exceptions.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/requests/help.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/requests/hooks.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/requests/models.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/requests/packages.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/requests/sessions.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/requests/status_codes.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/requests/structures.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/requests/utils.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/resolvelib/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/resolvelib/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/resolvelib/__pycache__/providers.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/resolvelib/__pycache__/reporters.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/resolvelib/__pycache__/resolvers.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/resolvelib/__pycache__/structs.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/resolvelib/compat/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/resolvelib/compat/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/resolvelib/compat/__pycache__/collections_abc.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/resolvelib/compat/collections_abc.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/resolvelib/providers.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/resolvelib/reporters.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/resolvelib/resolvers.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/resolvelib/structs.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__main__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/__main__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/_cell_widths.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/_emoji_codes.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/_emoji_replace.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/_export_format.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/_extension.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/_fileno.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/_inspect.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/_log_render.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/_loop.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/_null_file.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/_palettes.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/_pick.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/_ratio.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/_spinners.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/_stack.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/_timer.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/_win32_console.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/_windows.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/_windows_renderer.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/_wrap.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/abc.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/align.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/ansi.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/bar.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/box.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/cells.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/color.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/color_triplet.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/columns.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/console.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/constrain.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/containers.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/control.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/default_styles.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/diagnose.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/emoji.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/errors.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/file_proxy.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/filesize.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/highlighter.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/json.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/jupyter.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/layout.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/live.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/live_render.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/logging.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/markup.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/measure.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/padding.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/pager.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/palette.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/panel.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/pretty.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/progress.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/progress_bar.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/prompt.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/protocol.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/region.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/repr.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/rule.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/scope.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/screen.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/segment.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/spinner.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/status.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/style.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/styled.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/syntax.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/table.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/terminal_theme.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/text.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/theme.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/themes.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/traceback.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/__pycache__/tree.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/_cell_widths.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/_emoji_codes.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/_emoji_replace.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/_export_format.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/_extension.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/_fileno.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/_inspect.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/_log_render.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/_loop.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/_null_file.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/_palettes.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/_pick.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/_ratio.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/_spinners.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/_stack.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/_timer.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/_win32_console.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/_windows.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/_windows_renderer.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/_wrap.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/abc.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/align.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/ansi.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/bar.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/box.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/cells.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/color.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/color_triplet.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/columns.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/console.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/constrain.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/containers.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/control.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/default_styles.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/diagnose.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/emoji.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/errors.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/file_proxy.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/filesize.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/highlighter.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/json.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/jupyter.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/layout.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/live.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/live_render.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/logging.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/markup.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/measure.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/padding.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/pager.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/palette.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/panel.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/pretty.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/progress.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/progress_bar.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/prompt.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/protocol.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/region.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/repr.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/rule.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/scope.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/screen.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/segment.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/spinner.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/status.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/style.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/styled.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/syntax.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/table.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/terminal_theme.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/text.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/theme.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/themes.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/traceback.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/rich/tree.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/six.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/tenacity/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/tenacity/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/tenacity/__pycache__/_asyncio.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/tenacity/__pycache__/_utils.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/tenacity/__pycache__/after.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/tenacity/__pycache__/before.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/tenacity/__pycache__/before_sleep.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/tenacity/__pycache__/nap.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/tenacity/__pycache__/retry.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/tenacity/__pycache__/stop.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/tenacity/__pycache__/tornadoweb.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/tenacity/__pycache__/wait.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/tenacity/_asyncio.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/tenacity/_utils.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/tenacity/after.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/tenacity/before.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/tenacity/before_sleep.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/tenacity/nap.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/tenacity/retry.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/tenacity/stop.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/tenacity/tornadoweb.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/tenacity/wait.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/tomli/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/tomli/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/tomli/__pycache__/_parser.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/tomli/__pycache__/_re.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/tomli/__pycache__/_types.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/tomli/_parser.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/tomli/_re.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/tomli/_types.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/truststore/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/truststore/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/truststore/__pycache__/_api.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/truststore/__pycache__/_macos.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/truststore/__pycache__/_openssl.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/truststore/__pycache__/_ssl_constants.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/truststore/__pycache__/_windows.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/truststore/_api.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/truststore/_macos.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/truststore/_openssl.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/truststore/_ssl_constants.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/truststore/_windows.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/typing_extensions.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/__pycache__/_collections.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/__pycache__/_version.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/__pycache__/connection.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/__pycache__/connectionpool.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/__pycache__/exceptions.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/__pycache__/fields.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/__pycache__/filepost.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/__pycache__/poolmanager.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/__pycache__/request.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/__pycache__/response.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/_collections.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/_version.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/connection.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/connectionpool.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/contrib/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/contrib/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/contrib/__pycache__/_appengine_environ.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/contrib/__pycache__/appengine.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/contrib/__pycache__/ntlmpool.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/contrib/__pycache__/pyopenssl.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/contrib/__pycache__/securetransport.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/contrib/__pycache__/socks.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/contrib/_appengine_environ.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/contrib/_securetransport/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/contrib/_securetransport/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/contrib/_securetransport/__pycache__/bindings.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/contrib/_securetransport/__pycache__/low_level.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/contrib/_securetransport/bindings.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/contrib/_securetransport/low_level.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/contrib/appengine.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/contrib/ntlmpool.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/contrib/pyopenssl.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/contrib/securetransport.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/contrib/socks.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/exceptions.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/fields.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/filepost.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/packages/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/packages/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/packages/__pycache__/six.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/packages/backports/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/packages/backports/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/packages/backports/__pycache__/makefile.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/packages/backports/__pycache__/weakref_finalize.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/packages/backports/makefile.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/packages/backports/weakref_finalize.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/packages/six.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/poolmanager.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/request.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/response.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/util/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/util/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/util/__pycache__/connection.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/util/__pycache__/proxy.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/util/__pycache__/queue.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/util/__pycache__/request.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/util/__pycache__/response.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/util/__pycache__/retry.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/util/__pycache__/ssl_.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/util/__pycache__/ssl_match_hostname.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/util/__pycache__/ssltransport.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/util/__pycache__/timeout.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/util/__pycache__/url.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/util/__pycache__/wait.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/util/connection.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/util/proxy.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/util/queue.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/util/request.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/util/response.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/util/retry.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/util/ssl_.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/util/ssl_match_hostname.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/util/ssltransport.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/util/timeout.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/util/url.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/urllib3/util/wait.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/vendor.txt delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/webencodings/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/webencodings/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/webencodings/__pycache__/labels.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/webencodings/__pycache__/mklabels.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/webencodings/__pycache__/tests.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/webencodings/__pycache__/x_user_defined.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/webencodings/labels.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/webencodings/mklabels.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/webencodings/tests.py delete mode 100644 venv/lib/python3.12/site-packages/pip/_vendor/webencodings/x_user_defined.py delete mode 100644 venv/lib/python3.12/site-packages/pip/py.typed delete mode 100644 venv/lib/python3.12/site-packages/requests-2.32.5.dist-info/INSTALLER delete mode 100644 venv/lib/python3.12/site-packages/requests-2.32.5.dist-info/METADATA delete mode 100644 venv/lib/python3.12/site-packages/requests-2.32.5.dist-info/RECORD delete mode 100644 venv/lib/python3.12/site-packages/requests-2.32.5.dist-info/REQUESTED delete mode 100644 venv/lib/python3.12/site-packages/requests-2.32.5.dist-info/WHEEL delete mode 100644 venv/lib/python3.12/site-packages/requests-2.32.5.dist-info/licenses/LICENSE delete mode 100644 venv/lib/python3.12/site-packages/requests-2.32.5.dist-info/top_level.txt delete mode 100644 venv/lib/python3.12/site-packages/requests/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/requests/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/requests/__pycache__/__version__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/requests/__pycache__/_internal_utils.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/requests/__pycache__/adapters.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/requests/__pycache__/api.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/requests/__pycache__/auth.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/requests/__pycache__/certs.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/requests/__pycache__/compat.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/requests/__pycache__/cookies.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/requests/__pycache__/exceptions.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/requests/__pycache__/help.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/requests/__pycache__/hooks.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/requests/__pycache__/models.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/requests/__pycache__/packages.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/requests/__pycache__/sessions.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/requests/__pycache__/status_codes.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/requests/__pycache__/structures.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/requests/__pycache__/utils.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/requests/__version__.py delete mode 100644 venv/lib/python3.12/site-packages/requests/_internal_utils.py delete mode 100644 venv/lib/python3.12/site-packages/requests/adapters.py delete mode 100644 venv/lib/python3.12/site-packages/requests/api.py delete mode 100644 venv/lib/python3.12/site-packages/requests/auth.py delete mode 100644 venv/lib/python3.12/site-packages/requests/certs.py delete mode 100644 venv/lib/python3.12/site-packages/requests/compat.py delete mode 100644 venv/lib/python3.12/site-packages/requests/cookies.py delete mode 100644 venv/lib/python3.12/site-packages/requests/exceptions.py delete mode 100644 venv/lib/python3.12/site-packages/requests/help.py delete mode 100644 venv/lib/python3.12/site-packages/requests/hooks.py delete mode 100644 venv/lib/python3.12/site-packages/requests/models.py delete mode 100644 venv/lib/python3.12/site-packages/requests/packages.py delete mode 100644 venv/lib/python3.12/site-packages/requests/sessions.py delete mode 100644 venv/lib/python3.12/site-packages/requests/status_codes.py delete mode 100644 venv/lib/python3.12/site-packages/requests/structures.py delete mode 100644 venv/lib/python3.12/site-packages/requests/utils.py delete mode 100644 venv/lib/python3.12/site-packages/urllib3-2.6.3.dist-info/INSTALLER delete mode 100644 venv/lib/python3.12/site-packages/urllib3-2.6.3.dist-info/METADATA delete mode 100644 venv/lib/python3.12/site-packages/urllib3-2.6.3.dist-info/RECORD delete mode 100644 venv/lib/python3.12/site-packages/urllib3-2.6.3.dist-info/WHEEL delete mode 100644 venv/lib/python3.12/site-packages/urllib3-2.6.3.dist-info/licenses/LICENSE.txt delete mode 100644 venv/lib/python3.12/site-packages/urllib3/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/urllib3/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/urllib3/__pycache__/_base_connection.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/urllib3/__pycache__/_collections.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/urllib3/__pycache__/_request_methods.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/urllib3/__pycache__/_version.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/urllib3/__pycache__/connection.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/urllib3/__pycache__/connectionpool.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/urllib3/__pycache__/exceptions.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/urllib3/__pycache__/fields.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/urllib3/__pycache__/filepost.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/urllib3/__pycache__/poolmanager.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/urllib3/__pycache__/response.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/urllib3/_base_connection.py delete mode 100644 venv/lib/python3.12/site-packages/urllib3/_collections.py delete mode 100644 venv/lib/python3.12/site-packages/urllib3/_request_methods.py delete mode 100644 venv/lib/python3.12/site-packages/urllib3/_version.py delete mode 100644 venv/lib/python3.12/site-packages/urllib3/connection.py delete mode 100644 venv/lib/python3.12/site-packages/urllib3/connectionpool.py delete mode 100644 venv/lib/python3.12/site-packages/urllib3/contrib/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/urllib3/contrib/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/urllib3/contrib/__pycache__/pyopenssl.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/urllib3/contrib/__pycache__/socks.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/urllib3/contrib/emscripten/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/urllib3/contrib/emscripten/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/urllib3/contrib/emscripten/__pycache__/connection.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/urllib3/contrib/emscripten/__pycache__/fetch.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/urllib3/contrib/emscripten/__pycache__/request.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/urllib3/contrib/emscripten/__pycache__/response.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/urllib3/contrib/emscripten/connection.py delete mode 100644 venv/lib/python3.12/site-packages/urllib3/contrib/emscripten/emscripten_fetch_worker.js delete mode 100644 venv/lib/python3.12/site-packages/urllib3/contrib/emscripten/fetch.py delete mode 100644 venv/lib/python3.12/site-packages/urllib3/contrib/emscripten/request.py delete mode 100644 venv/lib/python3.12/site-packages/urllib3/contrib/emscripten/response.py delete mode 100644 venv/lib/python3.12/site-packages/urllib3/contrib/pyopenssl.py delete mode 100644 venv/lib/python3.12/site-packages/urllib3/contrib/socks.py delete mode 100644 venv/lib/python3.12/site-packages/urllib3/exceptions.py delete mode 100644 venv/lib/python3.12/site-packages/urllib3/fields.py delete mode 100644 venv/lib/python3.12/site-packages/urllib3/filepost.py delete mode 100644 venv/lib/python3.12/site-packages/urllib3/http2/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/urllib3/http2/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/urllib3/http2/__pycache__/connection.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/urllib3/http2/__pycache__/probe.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/urllib3/http2/connection.py delete mode 100644 venv/lib/python3.12/site-packages/urllib3/http2/probe.py delete mode 100644 venv/lib/python3.12/site-packages/urllib3/poolmanager.py delete mode 100644 venv/lib/python3.12/site-packages/urllib3/py.typed delete mode 100644 venv/lib/python3.12/site-packages/urllib3/response.py delete mode 100644 venv/lib/python3.12/site-packages/urllib3/util/__init__.py delete mode 100644 venv/lib/python3.12/site-packages/urllib3/util/__pycache__/__init__.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/urllib3/util/__pycache__/connection.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/urllib3/util/__pycache__/proxy.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/urllib3/util/__pycache__/request.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/urllib3/util/__pycache__/response.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/urllib3/util/__pycache__/retry.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/urllib3/util/__pycache__/ssl_.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/urllib3/util/__pycache__/ssl_match_hostname.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/urllib3/util/__pycache__/ssltransport.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/urllib3/util/__pycache__/timeout.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/urllib3/util/__pycache__/url.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/urllib3/util/__pycache__/util.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/urllib3/util/__pycache__/wait.cpython-312.pyc delete mode 100644 venv/lib/python3.12/site-packages/urllib3/util/connection.py delete mode 100644 venv/lib/python3.12/site-packages/urllib3/util/proxy.py delete mode 100644 venv/lib/python3.12/site-packages/urllib3/util/request.py delete mode 100644 venv/lib/python3.12/site-packages/urllib3/util/response.py delete mode 100644 venv/lib/python3.12/site-packages/urllib3/util/retry.py delete mode 100644 venv/lib/python3.12/site-packages/urllib3/util/ssl_.py delete mode 100644 venv/lib/python3.12/site-packages/urllib3/util/ssl_match_hostname.py delete mode 100644 venv/lib/python3.12/site-packages/urllib3/util/ssltransport.py delete mode 100644 venv/lib/python3.12/site-packages/urllib3/util/timeout.py delete mode 100644 venv/lib/python3.12/site-packages/urllib3/util/url.py delete mode 100644 venv/lib/python3.12/site-packages/urllib3/util/util.py delete mode 100644 venv/lib/python3.12/site-packages/urllib3/util/wait.py delete mode 120000 venv/lib64 delete mode 100644 venv/pyvenv.cfg diff --git a/venv/bin/Activate.ps1 b/venv/bin/Activate.ps1 deleted file mode 100644 index b49d77b..0000000 --- a/venv/bin/Activate.ps1 +++ /dev/null @@ -1,247 +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 VIRTUAL_ENV_PROMPT altogether. - if (Test-Path -Path Env:VIRTUAL_ENV_PROMPT) { - Remove-Item -Path env:VIRTUAL_ENV_PROMPT - } - - # Just remove the _PYTHON_VENV_PROMPT_PREFIX altogether: - if (Get-Variable -Name "_PYTHON_VENV_PROMPT_PREFIX" -ErrorAction SilentlyContinue) { - Remove-Variable -Name _PYTHON_VENV_PROMPT_PREFIX -Scope Global -Force - } - - # 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 virtual 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 - } - $env:VIRTUAL_ENV_PROMPT = $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 4f2acb7..0000000 --- a/venv/bin/activate +++ /dev/null @@ -1,70 +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 - - # Call hash to forget past commands. Without forgetting - # past commands the $PATH changes we made may not be respected - hash -r 2> /dev/null - - if [ -n "${_OLD_VIRTUAL_PS1:-}" ] ; then - PS1="${_OLD_VIRTUAL_PS1:-}" - export PS1 - unset _OLD_VIRTUAL_PS1 - fi - - unset VIRTUAL_ENV - unset VIRTUAL_ENV_PROMPT - if [ ! "${1:-}" = "nondestructive" ] ; then - # Self destruct! - unset -f deactivate - fi -} - -# unset irrelevant variables -deactivate nondestructive - -# on Windows, a path can contain colons and backslashes and has to be converted: -if [ "${OSTYPE:-}" = "cygwin" ] || [ "${OSTYPE:-}" = "msys" ] ; then - # transform D:\path\to\venv to /d/path/to/venv on MSYS - # and to /cygdrive/d/path/to/venv on Cygwin - export VIRTUAL_ENV=$(cygpath /home/radinpirouz/Desktop/Arvan-API-Cli/venv) -else - # use the path as-is - export VIRTUAL_ENV=/home/radinpirouz/Desktop/Arvan-API-Cli/venv -fi - -_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:-}" - PS1='(venv) '"${PS1:-}" - export PS1 - VIRTUAL_ENV_PROMPT='(venv) ' - export VIRTUAL_ENV_PROMPT -fi - -# Call hash to forget past commands. Without forgetting -# past commands the $PATH changes we made may not be respected -hash -r 2> /dev/null diff --git a/venv/bin/activate.csh b/venv/bin/activate.csh deleted file mode 100644 index 9a447bf..0000000 --- a/venv/bin/activate.csh +++ /dev/null @@ -1,27 +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; unsetenv VIRTUAL_ENV_PROMPT; test "\!:*" != "nondestructive" && unalias deactivate' - -# Unset irrelevant variables. -deactivate nondestructive - -setenv VIRTUAL_ENV /home/radinpirouz/Desktop/Arvan-API-Cli/venv - -set _OLD_VIRTUAL_PATH="$PATH" -setenv PATH "$VIRTUAL_ENV/"bin":$PATH" - - -set _OLD_VIRTUAL_PROMPT="$prompt" - -if (! "$?VIRTUAL_ENV_DISABLE_PROMPT") then - set prompt = '(venv) '"$prompt" - setenv VIRTUAL_ENV_PROMPT '(venv) ' -endif - -alias pydoc python -m pydoc - -rehash diff --git a/venv/bin/activate.fish b/venv/bin/activate.fish deleted file mode 100644 index ae94d28..0000000 --- a/venv/bin/activate.fish +++ /dev/null @@ -1,69 +0,0 @@ -# This file must be used with "source /bin/activate.fish" *from fish* -# (https://fishshell.com/). You cannot run it directly. - -function deactivate -d "Exit virtual environment 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" - set -e _OLD_FISH_PROMPT_OVERRIDE - # prevents error when using nested fish instances (Issue #93858) - if functions -q _old_fish_prompt - functions -e fish_prompt - functions -c _old_fish_prompt fish_prompt - functions -e _old_fish_prompt - end - end - - set -e VIRTUAL_ENV - set -e VIRTUAL_ENV_PROMPT - if test "$argv[1]" != "nondestructive" - # Self-destruct! - functions -e deactivate - end -end - -# Unset irrelevant variables. -deactivate nondestructive - -set -gx VIRTUAL_ENV /home/radinpirouz/Desktop/Arvan-API-Cli/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 - - # Output the venv prompt; color taken from the blue of the Python logo. - printf "%s%s%s" (set_color 4B8BBE) '(venv) ' (set_color normal) - - # Restore the return status of the previous command. - echo "exit $old_status" | . - # Output the original/"old" prompt. - _old_fish_prompt - end - - set -gx _OLD_FISH_PROMPT_OVERRIDE "$VIRTUAL_ENV" - set -gx VIRTUAL_ENV_PROMPT '(venv) ' -end diff --git a/venv/bin/normalizer b/venv/bin/normalizer deleted file mode 100755 index 8df30fc..0000000 --- a/venv/bin/normalizer +++ /dev/null @@ -1,8 +0,0 @@ -#!/home/radinpirouz/Desktop/Arvan-API-Cli/venv/bin/python3 -# -*- coding: utf-8 -*- -import re -import sys -from charset_normalizer.cli 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 14794fa..0000000 --- a/venv/bin/pip +++ /dev/null @@ -1,8 +0,0 @@ -#!/home/radinpirouz/Desktop/Arvan-API-Cli/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 14794fa..0000000 --- a/venv/bin/pip3 +++ /dev/null @@ -1,8 +0,0 @@ -#!/home/radinpirouz/Desktop/Arvan-API-Cli/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.12 b/venv/bin/pip3.12 deleted file mode 100755 index 14794fa..0000000 --- a/venv/bin/pip3.12 +++ /dev/null @@ -1,8 +0,0 @@ -#!/home/radinpirouz/Desktop/Arvan-API-Cli/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/bin/python3.12 b/venv/bin/python3.12 deleted file mode 120000 index b8a0adb..0000000 --- a/venv/bin/python3.12 +++ /dev/null @@ -1 +0,0 @@ -python3 \ No newline at end of file diff --git a/venv/lib/python3.12/site-packages/certifi-2026.1.4.dist-info/INSTALLER b/venv/lib/python3.12/site-packages/certifi-2026.1.4.dist-info/INSTALLER deleted file mode 100644 index a1b589e..0000000 --- a/venv/lib/python3.12/site-packages/certifi-2026.1.4.dist-info/INSTALLER +++ /dev/null @@ -1 +0,0 @@ -pip diff --git a/venv/lib/python3.12/site-packages/certifi-2026.1.4.dist-info/METADATA b/venv/lib/python3.12/site-packages/certifi-2026.1.4.dist-info/METADATA deleted file mode 100644 index d1bc526..0000000 --- a/venv/lib/python3.12/site-packages/certifi-2026.1.4.dist-info/METADATA +++ /dev/null @@ -1,78 +0,0 @@ -Metadata-Version: 2.4 -Name: certifi -Version: 2026.1.4 -Summary: Python package for providing Mozilla's CA Bundle. -Home-page: https://github.com/certifi/python-certifi -Author: Kenneth Reitz -Author-email: me@kennethreitz.com -License: MPL-2.0 -Project-URL: Source, https://github.com/certifi/python-certifi -Classifier: Development Status :: 5 - Production/Stable -Classifier: Intended Audience :: Developers -Classifier: License :: OSI Approved :: Mozilla Public License 2.0 (MPL 2.0) -Classifier: Natural Language :: English -Classifier: Programming Language :: Python -Classifier: Programming Language :: Python :: 3 -Classifier: Programming Language :: Python :: 3 :: Only -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 :: 3.11 -Classifier: Programming Language :: Python :: 3.12 -Classifier: Programming Language :: Python :: 3.13 -Classifier: Programming Language :: Python :: 3.14 -Requires-Python: >=3.7 -License-File: LICENSE -Dynamic: author -Dynamic: author-email -Dynamic: classifier -Dynamic: description -Dynamic: home-page -Dynamic: license -Dynamic: license-file -Dynamic: project-url -Dynamic: requires-python -Dynamic: summary - -Certifi: Python SSL Certificates -================================ - -Certifi provides Mozilla's carefully curated collection of Root Certificates for -validating the trustworthiness of SSL certificates while verifying the identity -of TLS hosts. It has been extracted from the `Requests`_ project. - -Installation ------------- - -``certifi`` is available on PyPI. Simply install it with ``pip``:: - - $ pip install certifi - -Usage ------ - -To reference the installed certificate authority (CA) bundle, you can use the -built-in function:: - - >>> 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! - -.. _`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.12/site-packages/certifi-2026.1.4.dist-info/RECORD b/venv/lib/python3.12/site-packages/certifi-2026.1.4.dist-info/RECORD deleted file mode 100644 index abef4a1..0000000 --- a/venv/lib/python3.12/site-packages/certifi-2026.1.4.dist-info/RECORD +++ /dev/null @@ -1,14 +0,0 @@ -certifi-2026.1.4.dist-info/INSTALLER,sha256=zuuue4knoyJ-UwPPXg8fezS7VCrXJQrAP7zeNuwvFQg,4 -certifi-2026.1.4.dist-info/METADATA,sha256=FSfJEfKuMo6bJlofUrtRpn4PFTYtbYyXpHN_A3ZFpIY,2473 -certifi-2026.1.4.dist-info/RECORD,, -certifi-2026.1.4.dist-info/WHEEL,sha256=_zCd3N1l69ArxyTb8rzEoP9TpbYXkqRFSNOD5OuxnTs,91 -certifi-2026.1.4.dist-info/licenses/LICENSE,sha256=6TcW2mucDVpKHfYP5pWzcPBpVgPSH2-D8FPkLPwQyvc,989 -certifi-2026.1.4.dist-info/top_level.txt,sha256=KMu4vUCfsjLrkPbSNdgdekS-pVJzBAJFO__nI8NF6-U,8 -certifi/__init__.py,sha256=969deMMS7Uchipr0oO4dbRBUvRi0uNYCn07VmG1aTrg,94 -certifi/__main__.py,sha256=xBBoj905TUWBLRGANOcf7oi6e-3dMP4cEoG9OyMs11g,243 -certifi/__pycache__/__init__.cpython-312.pyc,, -certifi/__pycache__/__main__.cpython-312.pyc,, -certifi/__pycache__/core.cpython-312.pyc,, -certifi/cacert.pem,sha256=Tzl1_zCrvzVEO0hgZK6Ly0Hf9wf_31dsdtKS-0WKoKk,270954 -certifi/core.py,sha256=XFXycndG5pf37ayeF8N32HUuDafsyhkVMbO4BAPWHa0,3394 -certifi/py.typed,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 diff --git a/venv/lib/python3.12/site-packages/certifi-2026.1.4.dist-info/WHEEL b/venv/lib/python3.12/site-packages/certifi-2026.1.4.dist-info/WHEEL deleted file mode 100644 index e7fa31b..0000000 --- a/venv/lib/python3.12/site-packages/certifi-2026.1.4.dist-info/WHEEL +++ /dev/null @@ -1,5 +0,0 @@ -Wheel-Version: 1.0 -Generator: setuptools (80.9.0) -Root-Is-Purelib: true -Tag: py3-none-any - diff --git a/venv/lib/python3.12/site-packages/certifi-2026.1.4.dist-info/licenses/LICENSE b/venv/lib/python3.12/site-packages/certifi-2026.1.4.dist-info/licenses/LICENSE deleted file mode 100644 index 62b076c..0000000 --- a/venv/lib/python3.12/site-packages/certifi-2026.1.4.dist-info/licenses/LICENSE +++ /dev/null @@ -1,20 +0,0 @@ -This package contains a modified version of ca-bundle.crt: - -ca-bundle.crt -- Bundle of CA Root Certificates - -This is a bundle of X.509 certificates of public Certificate Authorities -(CA). These were automatically extracted from Mozilla's root certificates -file (certdata.txt). This file can be found in the mozilla source tree: -https://hg.mozilla.org/mozilla-central/file/tip/security/nss/lib/ckfw/builtins/certdata.txt -It contains the certificates in PEM format and therefore -can be directly used with curl / libcurl / php_curl, or with -an Apache+mod_ssl webserver for SSL client authentication. -Just configure this file as the SSLCACertificateFile.# - -***** BEGIN LICENSE BLOCK ***** -This Source Code Form is subject to the terms of the Mozilla Public License, -v. 2.0. If a copy of the MPL was not distributed with this file, You can obtain -one at http://mozilla.org/MPL/2.0/. - -***** END LICENSE BLOCK ***** -@(#) $RCSfile: certdata.txt,v $ $Revision: 1.80 $ $Date: 2011/11/03 15:11:58 $ diff --git a/venv/lib/python3.12/site-packages/certifi-2026.1.4.dist-info/top_level.txt b/venv/lib/python3.12/site-packages/certifi-2026.1.4.dist-info/top_level.txt deleted file mode 100644 index 963eac5..0000000 --- a/venv/lib/python3.12/site-packages/certifi-2026.1.4.dist-info/top_level.txt +++ /dev/null @@ -1 +0,0 @@ -certifi diff --git a/venv/lib/python3.12/site-packages/certifi/__init__.py b/venv/lib/python3.12/site-packages/certifi/__init__.py deleted file mode 100644 index 090fd58..0000000 --- a/venv/lib/python3.12/site-packages/certifi/__init__.py +++ /dev/null @@ -1,4 +0,0 @@ -from .core import contents, where - -__all__ = ["contents", "where"] -__version__ = "2026.01.04" diff --git a/venv/lib/python3.12/site-packages/certifi/__main__.py b/venv/lib/python3.12/site-packages/certifi/__main__.py deleted file mode 100644 index 8945b5d..0000000 --- a/venv/lib/python3.12/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.12/site-packages/certifi/__pycache__/__init__.cpython-312.pyc b/venv/lib/python3.12/site-packages/certifi/__pycache__/__init__.cpython-312.pyc deleted file mode 100644 index 9574f76234d15f21b1ead55e772d4087f13f1257..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 317 zcmYjMJx{|h5Vi9`OQNz>NG!mZA#oZI6GEzBVL{B1zzVTxtU7k&xT(?!egSO!27U_* zBgz626B|;uPPh_Cyy4xud+&6*m%+dT21E3~u1)=1H-E5x#d6PxCqMv!9F#DHrIlI` z5R2FoE47J}I;|UQd_fZntgfF+p{dYy=gteNsItvmIffQq5+_GdJc{DOi@@!iT>iJa z9>y8x7a&>5|#T2^SRnoNY_%k%J*Gt^Mg zAkJ=3)#^fugJ_hXnrRwVSw77sv_?5qn%y#lF%wK<998YAe_Tp3a`UXd+}0wlm!{$B<^NAUu3c?yLc#qsPv#W z{RztYPrSIavNc{R9>kl_TTdq2o$kdz@;-T<=Y8`g`BJL|K#g_umYu5jOK+-SFTm-M z0`CC<1SX)PqmjVW=oqQlF(EJj1%0ndTE@u&c5G_*YfHXD#3UB6KRXlioPj|3Rx5QG zFY0*I>sw2{LVQJa;Hzm=&Ivr%AQ-`gX8uoWxqq~Ar)5Yl&ND$XQA+z+k8(OT!gw5n z;RPL(BIh&`d_Y@JIye?A&su@>Fz*(amsGkj<$^tBT;GT5M&(MIcL%8|yQ>{sI&&wN zmoOobN}Ovln6r9cN^8E_1!tM~1oW4Hv&X2HrxbBaSXMBe55{PlmU|*EP@4~N7PfaE zh7S^khBOiqV<3ndW4W(EI$d zI!!-a`A98)O$gx+u=*QZJMo*Z8#BK-^_z$O)qUp}I5SY6g8IAd54S%){|f3yVDs3m q&D_S+Z5+B+_N^1seYN#s>$~N@xp{Ewo3;K^q3Z`XUheQURs0_Sgqn8% diff --git a/venv/lib/python3.12/site-packages/certifi/__pycache__/core.cpython-312.pyc b/venv/lib/python3.12/site-packages/certifi/__pycache__/core.cpython-312.pyc deleted file mode 100644 index 94e45a603c151f320cf210194f27053450dd3d07..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2064 zcmbVN&rcgi6rTNIy#AG?K)}Qiwp_KvZLw8?l2)`8#HrL21QDRBSd~`W-2tz$z1HkN zAeAZ(J*1~_3x}xU&;t?u1M(+SY7e+h&R9A4w~AgmB^V+rEu4i6O}sE8G=Rpf&F zpNeo-MWkJki9Nz$4HIgt8QI!S_$%MS;gzCcr7EVrS;i@X=_aXKDO$uSqiRvLTvn-J zR#RnDYX|09N>kZN*&42-Op-FFmD0>A#Z_u$!>8)-lwWCtd9qQ_I-kbG$Ritba zj!|EZC6INm9k~O3C8DyIQ|kAkPEQBC*sI{W*j+}?g#|n4;&~D7s3#M)qaK|PW>-EY zY%k;*I9n>2z@SQtgq_zGEK2MUunjUJiemSvl+j^J1g{$wj5%x&hJ%AT39+ic!y+b_ zj6!@Jnl%S*7oGQ`X#6;mJRe4h^mnfvh8pR~W_r4wo_;akNZ)VV_~h~2Nn-5Tm(Ao< zJvr4#-fkrBJf1&^4m?@>X7SnL%jnyG%86qs;r!Ai1{q7NwLS$047&Uvco;lnuGG5E zRmo=;7H~}$z8Ae}z%sBvUV$0HFt-D$r5Q$svn5>BOc4EgMsNTmOq6zrU{zNDD%uN; zveD-V|i$AwIL^)@_1byKfKwHZ#U(cx;*p48^`iYLtZ+TmRw=mqC?Oa z)LlYBgaHSIZy~s(-sP4%^QG^8rq5MG+VI4aHg_$GvqX zAu-q#2J6D$-ou}TvA@L0-v@?w=YAa=*_}TVM*=tZZnY3}XOmoDncLIO5$pd6qreQ; Vof&UuLU%UB1@5_-_c#Zde*ux#pL75K diff --git a/venv/lib/python3.12/site-packages/certifi/cacert.pem b/venv/lib/python3.12/site-packages/certifi/cacert.pem deleted file mode 100644 index 132db0d..0000000 --- a/venv/lib/python3.12/site-packages/certifi/cacert.pem +++ /dev/null @@ -1,4468 +0,0 @@ - -# Issuer: CN=QuoVadis Root CA 2 O=QuoVadis Limited -# Subject: CN=QuoVadis Root CA 2 O=QuoVadis Limited -# Label: "QuoVadis Root CA 2" -# Serial: 1289 -# MD5 Fingerprint: 5e:39:7b:dd:f8:ba:ec:82:e9:ac:62:ba:0c:54:00:2b -# SHA1 Fingerprint: ca:3a:fb:cf:12:40:36:4b:44:b2:16:20:88:80:48:39:19:93:7c:f7 -# SHA256 Fingerprint: 85:a0:dd:7d:d7:20:ad:b7:ff:05:f8:3d:54:2b:20:9d:c7:ff:45:28:f7:d6:77:b1:83:89:fe:a5:e5:c4:9e:86 ------BEGIN CERTIFICATE----- -MIIFtzCCA5+gAwIBAgICBQkwDQYJKoZIhvcNAQEFBQAwRTELMAkGA1UEBhMCQk0x -GTAXBgNVBAoTEFF1b1ZhZGlzIExpbWl0ZWQxGzAZBgNVBAMTElF1b1ZhZGlzIFJv -b3QgQ0EgMjAeFw0wNjExMjQxODI3MDBaFw0zMTExMjQxODIzMzNaMEUxCzAJBgNV -BAYTAkJNMRkwFwYDVQQKExBRdW9WYWRpcyBMaW1pdGVkMRswGQYDVQQDExJRdW9W -YWRpcyBSb290IENBIDIwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQCa -GMpLlA0ALa8DKYrwD4HIrkwZhR0In6spRIXzL4GtMh6QRr+jhiYaHv5+HBg6XJxg -Fyo6dIMzMH1hVBHL7avg5tKifvVrbxi3Cgst/ek+7wrGsxDp3MJGF/hd/aTa/55J -WpzmM+Yklvc/ulsrHHo1wtZn/qtmUIttKGAr79dgw8eTvI02kfN/+NsRE8Scd3bB -rrcCaoF6qUWD4gXmuVbBlDePSHFjIuwXZQeVikvfj8ZaCuWw419eaxGrDPmF60Tp -+ARz8un+XJiM9XOva7R+zdRcAitMOeGylZUtQofX1bOQQ7dsE/He3fbE+Ik/0XX1 -ksOR1YqI0JDs3G3eicJlcZaLDQP9nL9bFqyS2+r+eXyt66/3FsvbzSUr5R/7mp/i -Ucw6UwxI5g69ybR2BlLmEROFcmMDBOAENisgGQLodKcftslWZvB1JdxnwQ5hYIiz -PtGo/KPaHbDRsSNU30R2be1B2MGyIrZTHN81Hdyhdyox5C315eXbyOD/5YDXC2Og -/zOhD7osFRXql7PSorW+8oyWHhqPHWykYTe5hnMz15eWniN9gqRMgeKh0bpnX5UH -oycR7hYQe7xFSkyyBNKr79X9DFHOUGoIMfmR2gyPZFwDwzqLID9ujWc9Otb+fVuI -yV77zGHcizN300QyNQliBJIWENieJ0f7OyHj+OsdWwIDAQABo4GwMIGtMA8GA1Ud -EwEB/wQFMAMBAf8wCwYDVR0PBAQDAgEGMB0GA1UdDgQWBBQahGK8SEwzJQTU7tD2 -A8QZRtGUazBuBgNVHSMEZzBlgBQahGK8SEwzJQTU7tD2A8QZRtGUa6FJpEcwRTEL -MAkGA1UEBhMCQk0xGTAXBgNVBAoTEFF1b1ZhZGlzIExpbWl0ZWQxGzAZBgNVBAMT -ElF1b1ZhZGlzIFJvb3QgQ0EgMoICBQkwDQYJKoZIhvcNAQEFBQADggIBAD4KFk2f -BluornFdLwUvZ+YTRYPENvbzwCYMDbVHZF34tHLJRqUDGCdViXh9duqWNIAXINzn -g/iN/Ae42l9NLmeyhP3ZRPx3UIHmfLTJDQtyU/h2BwdBR5YM++CCJpNVjP4iH2Bl -fF/nJrP3MpCYUNQ3cVX2kiF495V5+vgtJodmVjB3pjd4M1IQWK4/YY7yarHvGH5K -WWPKjaJW1acvvFYfzznB4vsKqBUsfU16Y8Zsl0Q80m/DShcK+JDSV6IZUaUtl0Ha -B0+pUNqQjZRG4T7wlP0QADj1O+hA4bRuVhogzG9Yje0uRY/W6ZM/57Es3zrWIozc -hLsib9D45MY56QSIPMO661V6bYCZJPVsAfv4l7CUW+v90m/xd2gNNWQjrLhVoQPR -TUIZ3Ph1WVaj+ahJefivDrkRoHy3au000LYmYjgahwz46P0u05B/B5EqHdZ+XIWD -mbA4CD/pXvk1B+TJYm5Xf6dQlfe6yJvmjqIBxdZmv3lh8zwc4bmCXF2gw+nYSL0Z -ohEUGW6yhhtoPkg3Goi3XZZenMfvJ2II4pEZXNLxId26F0KCl3GBUzGpn/Z9Yr9y -4aOTHcyKJloJONDO1w2AFrR4pTqHTI2KpdVGl/IsELm8VCLAAVBpQ570su9t+Oza -8eOx79+Rj1QqCyXBJhnEUhAFZdWCEOrCMc0u ------END CERTIFICATE----- - -# Issuer: CN=QuoVadis Root CA 3 O=QuoVadis Limited -# Subject: CN=QuoVadis Root CA 3 O=QuoVadis Limited -# Label: "QuoVadis Root CA 3" -# Serial: 1478 -# MD5 Fingerprint: 31:85:3c:62:94:97:63:b9:aa:fd:89:4e:af:6f:e0:cf -# SHA1 Fingerprint: 1f:49:14:f7:d8:74:95:1d:dd:ae:02:c0:be:fd:3a:2d:82:75:51:85 -# SHA256 Fingerprint: 18:f1:fc:7f:20:5d:f8:ad:dd:eb:7f:e0:07:dd:57:e3:af:37:5a:9c:4d:8d:73:54:6b:f4:f1:fe:d1:e1:8d:35 ------BEGIN CERTIFICATE----- -MIIGnTCCBIWgAwIBAgICBcYwDQYJKoZIhvcNAQEFBQAwRTELMAkGA1UEBhMCQk0x -GTAXBgNVBAoTEFF1b1ZhZGlzIExpbWl0ZWQxGzAZBgNVBAMTElF1b1ZhZGlzIFJv -b3QgQ0EgMzAeFw0wNjExMjQxOTExMjNaFw0zMTExMjQxOTA2NDRaMEUxCzAJBgNV -BAYTAkJNMRkwFwYDVQQKExBRdW9WYWRpcyBMaW1pdGVkMRswGQYDVQQDExJRdW9W -YWRpcyBSb290IENBIDMwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQDM -V0IWVJzmmNPTTe7+7cefQzlKZbPoFog02w1ZkXTPkrgEQK0CSzGrvI2RaNggDhoB -4hp7Thdd4oq3P5kazethq8Jlph+3t723j/z9cI8LoGe+AaJZz3HmDyl2/7FWeUUr -H556VOijKTVopAFPD6QuN+8bv+OPEKhyq1hX51SGyMnzW9os2l2ObjyjPtr7guXd -8lyyBTNvijbO0BNO/79KDDRMpsMhvVAEVeuxu537RR5kFd5VAYwCdrXLoT9Cabwv -vWhDFlaJKjdhkf2mrk7AyxRllDdLkgbvBNDInIjbC3uBr7E9KsRlOni27tyAsdLT -mZw67mtaa7ONt9XOnMK+pUsvFrGeaDsGb659n/je7Mwpp5ijJUMv7/FfJuGITfhe -btfZFG4ZM2mnO4SJk8RTVROhUXhA+LjJou57ulJCg54U7QVSWllWp5f8nT8KKdjc -T5EOE7zelaTfi5m+rJsziO+1ga8bxiJTyPbH7pcUsMV8eFLI8M5ud2CEpukqdiDt -WAEXMJPpGovgc2PZapKUSU60rUqFxKMiMPwJ7Wgic6aIDFUhWMXhOp8q3crhkODZ -c6tsgLjoC2SToJyMGf+z0gzskSaHirOi4XCPLArlzW1oUevaPwV/izLmE1xr/l9A -4iLItLRkT9a6fUg+qGkM17uGcclzuD87nSVL2v9A6wIDAQABo4IBlTCCAZEwDwYD -VR0TAQH/BAUwAwEB/zCB4QYDVR0gBIHZMIHWMIHTBgkrBgEEAb5YAAMwgcUwgZMG -CCsGAQUFBwICMIGGGoGDQW55IHVzZSBvZiB0aGlzIENlcnRpZmljYXRlIGNvbnN0 -aXR1dGVzIGFjY2VwdGFuY2Ugb2YgdGhlIFF1b1ZhZGlzIFJvb3QgQ0EgMyBDZXJ0 -aWZpY2F0ZSBQb2xpY3kgLyBDZXJ0aWZpY2F0aW9uIFByYWN0aWNlIFN0YXRlbWVu -dC4wLQYIKwYBBQUHAgEWIWh0dHA6Ly93d3cucXVvdmFkaXNnbG9iYWwuY29tL2Nw -czALBgNVHQ8EBAMCAQYwHQYDVR0OBBYEFPLAE+CCQz777i9nMpY1XNu4ywLQMG4G -A1UdIwRnMGWAFPLAE+CCQz777i9nMpY1XNu4ywLQoUmkRzBFMQswCQYDVQQGEwJC -TTEZMBcGA1UEChMQUXVvVmFkaXMgTGltaXRlZDEbMBkGA1UEAxMSUXVvVmFkaXMg -Um9vdCBDQSAzggIFxjANBgkqhkiG9w0BAQUFAAOCAgEAT62gLEz6wPJv92ZVqyM0 -7ucp2sNbtrCD2dDQ4iH782CnO11gUyeim/YIIirnv6By5ZwkajGxkHon24QRiSem -d1o417+shvzuXYO8BsbRd2sPbSQvS3pspweWyuOEn62Iix2rFo1bZhfZFvSLgNLd -+LJ2w/w4E6oM3kJpK27zPOuAJ9v1pkQNn1pVWQvVDVJIxa6f8i+AxeoyUDUSly7B -4f/xI4hROJ/yZlZ25w9Rl6VSDE1JUZU2Pb+iSwwQHYaZTKrzchGT5Or2m9qoXadN -t54CrnMAyNojA+j56hl0YgCUyyIgvpSnWbWCar6ZeXqp8kokUvd0/bpO5qgdAm6x -DYBEwa7TIzdfu4V8K5Iu6H6li92Z4b8nby1dqnuH/grdS/yO9SbkbnBCbjPsMZ57 -k8HkyWkaPcBrTiJt7qtYTcbQQcEr6k8Sh17rRdhs9ZgC06DYVYoGmRmioHfRMJ6s -zHXug/WwYjnPbFfiTNKRCw51KBuav/0aQ/HKd/s7j2G4aSgWQgRecCocIdiP4b0j -Wy10QJLZYxkNc91pvGJHvOB0K7Lrfb5BG7XARsWhIstfTsEokt4YutUqKLsRixeT -mJlglFwjz1onl14LBQaTNx47aTbrqZ5hHY8y2o4M1nQ+ewkk2gF3R8Q7zTSMmfXK -4SVhM7JZG+Ju1zdXtg2pEto= ------END CERTIFICATE----- - -# Issuer: CN=DigiCert Assured ID Root CA O=DigiCert Inc OU=www.digicert.com -# Subject: CN=DigiCert Assured ID Root CA O=DigiCert Inc OU=www.digicert.com -# Label: "DigiCert Assured ID Root CA" -# Serial: 17154717934120587862167794914071425081 -# MD5 Fingerprint: 87:ce:0b:7b:2a:0e:49:00:e1:58:71:9b:37:a8:93:72 -# SHA1 Fingerprint: 05:63:b8:63:0d:62:d7:5a:bb:c8:ab:1e:4b:df:b5:a8:99:b2:4d:43 -# SHA256 Fingerprint: 3e:90:99:b5:01:5e:8f:48:6c:00:bc:ea:9d:11:1e:e7:21:fa:ba:35:5a:89:bc:f1:df:69:56:1e:3d:c6:32:5c ------BEGIN CERTIFICATE----- -MIIDtzCCAp+gAwIBAgIQDOfg5RfYRv6P5WD8G/AwOTANBgkqhkiG9w0BAQUFADBl -MQswCQYDVQQGEwJVUzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3 -d3cuZGlnaWNlcnQuY29tMSQwIgYDVQQDExtEaWdpQ2VydCBBc3N1cmVkIElEIFJv -b3QgQ0EwHhcNMDYxMTEwMDAwMDAwWhcNMzExMTEwMDAwMDAwWjBlMQswCQYDVQQG -EwJVUzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3d3cuZGlnaWNl -cnQuY29tMSQwIgYDVQQDExtEaWdpQ2VydCBBc3N1cmVkIElEIFJvb3QgQ0EwggEi -MA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQCtDhXO5EOAXLGH87dg+XESpa7c -JpSIqvTO9SA5KFhgDPiA2qkVlTJhPLWxKISKityfCgyDF3qPkKyK53lTXDGEKvYP -mDI2dsze3Tyoou9q+yHyUmHfnyDXH+Kx2f4YZNISW1/5WBg1vEfNoTb5a3/UsDg+ -wRvDjDPZ2C8Y/igPs6eD1sNuRMBhNZYW/lmci3Zt1/GiSw0r/wty2p5g0I6QNcZ4 -VYcgoc/lbQrISXwxmDNsIumH0DJaoroTghHtORedmTpyoeb6pNnVFzF1roV9Iq4/ -AUaG9ih5yLHa5FcXxH4cDrC0kqZWs72yl+2qp/C3xag/lRbQ/6GW6whfGHdPAgMB -AAGjYzBhMA4GA1UdDwEB/wQEAwIBhjAPBgNVHRMBAf8EBTADAQH/MB0GA1UdDgQW -BBRF66Kv9JLLgjEtUYunpyGd823IDzAfBgNVHSMEGDAWgBRF66Kv9JLLgjEtUYun -pyGd823IDzANBgkqhkiG9w0BAQUFAAOCAQEAog683+Lt8ONyc3pklL/3cmbYMuRC -dWKuh+vy1dneVrOfzM4UKLkNl2BcEkxY5NM9g0lFWJc1aRqoR+pWxnmrEthngYTf -fwk8lOa4JiwgvT2zKIn3X/8i4peEH+ll74fg38FnSbNd67IJKusm7Xi+fT8r87cm -NW1fiQG2SVufAQWbqz0lwcy2f8Lxb4bG+mRo64EtlOtCt/qMHt1i8b5QZ7dsvfPx -H2sMNgcWfzd8qVttevESRmCD1ycEvkvOl77DZypoEd+A5wwzZr8TDRRu838fYxAe -+o0bJW1sj6W3YQGx0qMmoRBxna3iw/nDmVG3KwcIzi7mULKn+gpFL6Lw8g== ------END CERTIFICATE----- - -# Issuer: CN=DigiCert Global Root CA O=DigiCert Inc OU=www.digicert.com -# Subject: CN=DigiCert Global Root CA O=DigiCert Inc OU=www.digicert.com -# Label: "DigiCert Global Root CA" -# Serial: 10944719598952040374951832963794454346 -# MD5 Fingerprint: 79:e4:a9:84:0d:7d:3a:96:d7:c0:4f:e2:43:4c:89:2e -# SHA1 Fingerprint: a8:98:5d:3a:65:e5:e5:c4:b2:d7:d6:6d:40:c6:dd:2f:b1:9c:54:36 -# SHA256 Fingerprint: 43:48:a0:e9:44:4c:78:cb:26:5e:05:8d:5e:89:44:b4:d8:4f:96:62:bd:26:db:25:7f:89:34:a4:43:c7:01:61 ------BEGIN CERTIFICATE----- -MIIDrzCCApegAwIBAgIQCDvgVpBCRrGhdWrJWZHHSjANBgkqhkiG9w0BAQUFADBh -MQswCQYDVQQGEwJVUzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3 -d3cuZGlnaWNlcnQuY29tMSAwHgYDVQQDExdEaWdpQ2VydCBHbG9iYWwgUm9vdCBD -QTAeFw0wNjExMTAwMDAwMDBaFw0zMTExMTAwMDAwMDBaMGExCzAJBgNVBAYTAlVT -MRUwEwYDVQQKEwxEaWdpQ2VydCBJbmMxGTAXBgNVBAsTEHd3dy5kaWdpY2VydC5j -b20xIDAeBgNVBAMTF0RpZ2lDZXJ0IEdsb2JhbCBSb290IENBMIIBIjANBgkqhkiG -9w0BAQEFAAOCAQ8AMIIBCgKCAQEA4jvhEXLeqKTTo1eqUKKPC3eQyaKl7hLOllsB -CSDMAZOnTjC3U/dDxGkAV53ijSLdhwZAAIEJzs4bg7/fzTtxRuLWZscFs3YnFo97 -nh6Vfe63SKMI2tavegw5BmV/Sl0fvBf4q77uKNd0f3p4mVmFaG5cIzJLv07A6Fpt -43C/dxC//AH2hdmoRBBYMql1GNXRor5H4idq9Joz+EkIYIvUX7Q6hL+hqkpMfT7P -T19sdl6gSzeRntwi5m3OFBqOasv+zbMUZBfHWymeMr/y7vrTC0LUq7dBMtoM1O/4 -gdW7jVg/tRvoSSiicNoxBN33shbyTApOB6jtSj1etX+jkMOvJwIDAQABo2MwYTAO -BgNVHQ8BAf8EBAMCAYYwDwYDVR0TAQH/BAUwAwEB/zAdBgNVHQ4EFgQUA95QNVbR -TLtm8KPiGxvDl7I90VUwHwYDVR0jBBgwFoAUA95QNVbRTLtm8KPiGxvDl7I90VUw -DQYJKoZIhvcNAQEFBQADggEBAMucN6pIExIK+t1EnE9SsPTfrgT1eXkIoyQY/Esr -hMAtudXH/vTBH1jLuG2cenTnmCmrEbXjcKChzUyImZOMkXDiqw8cvpOp/2PV5Adg -06O/nVsJ8dWO41P0jmP6P6fbtGbfYmbW0W5BjfIttep3Sp+dWOIrWcBAI+0tKIJF -PnlUkiaY4IBIqDfv8NZ5YBberOgOzW6sRBc4L0na4UU+Krk2U886UAb3LujEV0ls -YSEY1QSteDwsOoBrp+uvFRTp2InBuThs4pFsiv9kuXclVzDAGySj4dzp30d8tbQk -CAUw7C29C79Fv1C5qfPrmAESrciIxpg0X40KPMbp1ZWVbd4= ------END CERTIFICATE----- - -# Issuer: CN=DigiCert High Assurance EV Root CA O=DigiCert Inc OU=www.digicert.com -# Subject: CN=DigiCert High Assurance EV Root CA O=DigiCert Inc OU=www.digicert.com -# Label: "DigiCert High Assurance EV Root CA" -# Serial: 3553400076410547919724730734378100087 -# MD5 Fingerprint: d4:74:de:57:5c:39:b2:d3:9c:85:83:c5:c0:65:49:8a -# SHA1 Fingerprint: 5f:b7:ee:06:33:e2:59:db:ad:0c:4c:9a:e6:d3:8f:1a:61:c7:dc:25 -# SHA256 Fingerprint: 74:31:e5:f4:c3:c1:ce:46:90:77:4f:0b:61:e0:54:40:88:3b:a9:a0:1e:d0:0b:a6:ab:d7:80:6e:d3:b1:18:cf ------BEGIN CERTIFICATE----- -MIIDxTCCAq2gAwIBAgIQAqxcJmoLQJuPC3nyrkYldzANBgkqhkiG9w0BAQUFADBs -MQswCQYDVQQGEwJVUzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3 -d3cuZGlnaWNlcnQuY29tMSswKQYDVQQDEyJEaWdpQ2VydCBIaWdoIEFzc3VyYW5j -ZSBFViBSb290IENBMB4XDTA2MTExMDAwMDAwMFoXDTMxMTExMDAwMDAwMFowbDEL -MAkGA1UEBhMCVVMxFTATBgNVBAoTDERpZ2lDZXJ0IEluYzEZMBcGA1UECxMQd3d3 -LmRpZ2ljZXJ0LmNvbTErMCkGA1UEAxMiRGlnaUNlcnQgSGlnaCBBc3N1cmFuY2Ug -RVYgUm9vdCBDQTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAMbM5XPm -+9S75S0tMqbf5YE/yc0lSbZxKsPVlDRnogocsF9ppkCxxLeyj9CYpKlBWTrT3JTW -PNt0OKRKzE0lgvdKpVMSOO7zSW1xkX5jtqumX8OkhPhPYlG++MXs2ziS4wblCJEM -xChBVfvLWokVfnHoNb9Ncgk9vjo4UFt3MRuNs8ckRZqnrG0AFFoEt7oT61EKmEFB -Ik5lYYeBQVCmeVyJ3hlKV9Uu5l0cUyx+mM0aBhakaHPQNAQTXKFx01p8VdteZOE3 -hzBWBOURtCmAEvF5OYiiAhF8J2a3iLd48soKqDirCmTCv2ZdlYTBoSUeh10aUAsg -EsxBu24LUTi4S8sCAwEAAaNjMGEwDgYDVR0PAQH/BAQDAgGGMA8GA1UdEwEB/wQF -MAMBAf8wHQYDVR0OBBYEFLE+w2kD+L9HAdSYJhoIAu9jZCvDMB8GA1UdIwQYMBaA -FLE+w2kD+L9HAdSYJhoIAu9jZCvDMA0GCSqGSIb3DQEBBQUAA4IBAQAcGgaX3Nec -nzyIZgYIVyHbIUf4KmeqvxgydkAQV8GK83rZEWWONfqe/EW1ntlMMUu4kehDLI6z -eM7b41N5cdblIZQB2lWHmiRk9opmzN6cN82oNLFpmyPInngiK3BD41VHMWEZ71jF -hS9OMPagMRYjyOfiZRYzy78aG6A9+MpeizGLYAiJLQwGXFK3xPkKmNEVX58Svnw2 -Yzi9RKR/5CYrCsSXaQ3pjOLAEFe4yHYSkVXySGnYvCoCWw9E1CAx2/S6cCZdkGCe -vEsXCS+0yx5DaMkHJ8HSXPfqIbloEpw8nL+e/IBcm2PN7EeqJSdnoDfzAIJ9VNep -+OkuE6N36B9K ------END CERTIFICATE----- - -# Issuer: CN=SwissSign Gold CA - G2 O=SwissSign AG -# Subject: CN=SwissSign Gold CA - G2 O=SwissSign AG -# Label: "SwissSign Gold CA - G2" -# Serial: 13492815561806991280 -# MD5 Fingerprint: 24:77:d9:a8:91:d1:3b:fa:88:2d:c2:ff:f8:cd:33:93 -# SHA1 Fingerprint: d8:c5:38:8a:b7:30:1b:1b:6e:d4:7a:e6:45:25:3a:6f:9f:1a:27:61 -# SHA256 Fingerprint: 62:dd:0b:e9:b9:f5:0a:16:3e:a0:f8:e7:5c:05:3b:1e:ca:57:ea:55:c8:68:8f:64:7c:68:81:f2:c8:35:7b:95 ------BEGIN CERTIFICATE----- -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 ------END CERTIFICATE----- - -# Issuer: CN=SecureTrust CA O=SecureTrust Corporation -# Subject: CN=SecureTrust CA O=SecureTrust Corporation -# Label: "SecureTrust CA" -# Serial: 17199774589125277788362757014266862032 -# MD5 Fingerprint: dc:32:c3:a7:6d:25:57:c7:68:09:9d:ea:2d:a9:a2:d1 -# SHA1 Fingerprint: 87:82:c6:c3:04:35:3b:cf:d2:96:92:d2:59:3e:7d:44:d9:34:ff:11 -# SHA256 Fingerprint: f1:c1:b5:0a:e5:a2:0d:d8:03:0e:c9:f6:bc:24:82:3d:d3:67:b5:25:57:59:b4:e7:1b:61:fc:e9:f7:37:5d:73 ------BEGIN CERTIFICATE----- -MIIDuDCCAqCgAwIBAgIQDPCOXAgWpa1Cf/DrJxhZ0DANBgkqhkiG9w0BAQUFADBI -MQswCQYDVQQGEwJVUzEgMB4GA1UEChMXU2VjdXJlVHJ1c3QgQ29ycG9yYXRpb24x -FzAVBgNVBAMTDlNlY3VyZVRydXN0IENBMB4XDTA2MTEwNzE5MzExOFoXDTI5MTIz -MTE5NDA1NVowSDELMAkGA1UEBhMCVVMxIDAeBgNVBAoTF1NlY3VyZVRydXN0IENv -cnBvcmF0aW9uMRcwFQYDVQQDEw5TZWN1cmVUcnVzdCBDQTCCASIwDQYJKoZIhvcN -AQEBBQADggEPADCCAQoCggEBAKukgeWVzfX2FI7CT8rU4niVWJxB4Q2ZQCQXOZEz -Zum+4YOvYlyJ0fwkW2Gz4BERQRwdbvC4u/jep4G6pkjGnx29vo6pQT64lO0pGtSO -0gMdA+9tDWccV9cGrcrI9f4Or2YlSASWC12juhbDCE/RRvgUXPLIXgGZbf2IzIao -wW8xQmxSPmjL8xk037uHGFaAJsTQ3MBv396gwpEWoGQRS0S8Hvbn+mPeZqx2pHGj -7DaUaHp3pLHnDi+BeuK1cobvomuL8A/b01k/unK8RCSc43Oz969XL0Imnal0ugBS -8kvNU3xHCzaFDmapCJcWNFfBZveA4+1wVMeT4C4oFVmHursCAwEAAaOBnTCBmjAT -BgkrBgEEAYI3FAIEBh4EAEMAQTALBgNVHQ8EBAMCAYYwDwYDVR0TAQH/BAUwAwEB -/zAdBgNVHQ4EFgQUQjK2FvoE/f5dS3rD/fdMQB1aQ68wNAYDVR0fBC0wKzApoCeg -JYYjaHR0cDovL2NybC5zZWN1cmV0cnVzdC5jb20vU1RDQS5jcmwwEAYJKwYBBAGC -NxUBBAMCAQAwDQYJKoZIhvcNAQEFBQADggEBADDtT0rhWDpSclu1pqNlGKa7UTt3 -6Z3q059c4EVlew3KW+JwULKUBRSuSceNQQcSc5R+DCMh/bwQf2AQWnL1mA6s7Ll/ -3XpvXdMc9P+IBWlCqQVxyLesJugutIxq/3HcuLHfmbx8IVQr5Fiiu1cprp6poxkm -D5kuCLDv/WnPmRoJjeOnnyvJNjR7JLN4TJUXpAYmHrZkUjZfYGfZnMUFdAvnZyPS -CPyI6a6Lf+Ew9Dd+/cYy2i2eRDAwbO4H3tI0/NL/QPZL9GZGBlSm8jIKYyYwa5vR -3ItHuuG51WLQoqD0ZwV4KWMabwTW+MZMo5qxN7SN5ShLHZ4swrhovO0C7jE= ------END CERTIFICATE----- - -# Issuer: CN=Secure Global CA O=SecureTrust Corporation -# Subject: CN=Secure Global CA O=SecureTrust Corporation -# Label: "Secure Global CA" -# Serial: 9751836167731051554232119481456978597 -# MD5 Fingerprint: cf:f4:27:0d:d4:ed:dc:65:16:49:6d:3d:da:bf:6e:de -# SHA1 Fingerprint: 3a:44:73:5a:e5:81:90:1f:24:86:61:46:1e:3b:9c:c4:5f:f5:3a:1b -# SHA256 Fingerprint: 42:00:f5:04:3a:c8:59:0e:bb:52:7d:20:9e:d1:50:30:29:fb:cb:d4:1c:a1:b5:06:ec:27:f1:5a:de:7d:ac:69 ------BEGIN CERTIFICATE----- -MIIDvDCCAqSgAwIBAgIQB1YipOjUiolN9BPI8PjqpTANBgkqhkiG9w0BAQUFADBK -MQswCQYDVQQGEwJVUzEgMB4GA1UEChMXU2VjdXJlVHJ1c3QgQ29ycG9yYXRpb24x -GTAXBgNVBAMTEFNlY3VyZSBHbG9iYWwgQ0EwHhcNMDYxMTA3MTk0MjI4WhcNMjkx -MjMxMTk1MjA2WjBKMQswCQYDVQQGEwJVUzEgMB4GA1UEChMXU2VjdXJlVHJ1c3Qg -Q29ycG9yYXRpb24xGTAXBgNVBAMTEFNlY3VyZSBHbG9iYWwgQ0EwggEiMA0GCSqG -SIb3DQEBAQUAA4IBDwAwggEKAoIBAQCvNS7YrGxVaQZx5RNoJLNP2MwhR/jxYDiJ -iQPpvepeRlMJ3Fz1Wuj3RSoC6zFh1ykzTM7HfAo3fg+6MpjhHZevj8fcyTiW89sa -/FHtaMbQbqR8JNGuQsiWUGMu4P51/pinX0kuleM5M2SOHqRfkNJnPLLZ/kG5VacJ -jnIFHovdRIWCQtBJwB1g8NEXLJXr9qXBkqPFwqcIYA1gBBCWeZ4WNOaptvolRTnI -HmX5k/Wq8VLcmZg9pYYaDDUz+kulBAYVHDGA76oYa8J719rO+TMg1fW9ajMtgQT7 -sFzUnKPiXB3jqUJ1XnvUd+85VLrJChgbEplJL4hL/VBi0XPnj3pDAgMBAAGjgZ0w -gZowEwYJKwYBBAGCNxQCBAYeBABDAEEwCwYDVR0PBAQDAgGGMA8GA1UdEwEB/wQF -MAMBAf8wHQYDVR0OBBYEFK9EBMJBfkiD2045AuzshHrmzsmkMDQGA1UdHwQtMCsw -KaAnoCWGI2h0dHA6Ly9jcmwuc2VjdXJldHJ1c3QuY29tL1NHQ0EuY3JsMBAGCSsG -AQQBgjcVAQQDAgEAMA0GCSqGSIb3DQEBBQUAA4IBAQBjGghAfaReUw132HquHw0L -URYD7xh8yOOvaliTFGCRsoTciE6+OYo68+aCiV0BN7OrJKQVDpI1WkpEXk5X+nXO -H0jOZvQ8QCaSmGwb7iRGDBezUqXbpZGRzzfTb+cnCDpOGR86p1hcF895P4vkp9Mm -I50mD1hp/Ed+stCNi5O/KU9DaXR2Z0vPB4zmAve14bRDtUstFJ/53CYNv6ZHdAbY -iNE6KTCEztI5gGIbqMdXSbxqVVFnFUq+NQfk1XWYN3kwFNspnWzFacxHVaIw98xc -f8LDmBxrThaA63p4ZUWiABqvDA1VZDRIuJK58bRQKfJPIx/abKwfROHdI3hRW8cW ------END CERTIFICATE----- - -# Issuer: CN=COMODO Certification Authority O=COMODO CA Limited -# Subject: CN=COMODO Certification Authority O=COMODO CA Limited -# Label: "COMODO Certification Authority" -# Serial: 104350513648249232941998508985834464573 -# MD5 Fingerprint: 5c:48:dc:f7:42:72:ec:56:94:6d:1c:cc:71:35:80:75 -# SHA1 Fingerprint: 66:31:bf:9e:f7:4f:9e:b6:c9:d5:a6:0c:ba:6a:be:d1:f7:bd:ef:7b -# SHA256 Fingerprint: 0c:2c:d6:3d:f7:80:6f:a3:99:ed:e8:09:11:6b:57:5b:f8:79:89:f0:65:18:f9:80:8c:86:05:03:17:8b:af:66 ------BEGIN CERTIFICATE----- -MIIEHTCCAwWgAwIBAgIQToEtioJl4AsC7j41AkblPTANBgkqhkiG9w0BAQUFADCB -gTELMAkGA1UEBhMCR0IxGzAZBgNVBAgTEkdyZWF0ZXIgTWFuY2hlc3RlcjEQMA4G -A1UEBxMHU2FsZm9yZDEaMBgGA1UEChMRQ09NT0RPIENBIExpbWl0ZWQxJzAlBgNV -BAMTHkNPTU9ETyBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTAeFw0wNjEyMDEwMDAw -MDBaFw0yOTEyMzEyMzU5NTlaMIGBMQswCQYDVQQGEwJHQjEbMBkGA1UECBMSR3Jl -YXRlciBNYW5jaGVzdGVyMRAwDgYDVQQHEwdTYWxmb3JkMRowGAYDVQQKExFDT01P -RE8gQ0EgTGltaXRlZDEnMCUGA1UEAxMeQ09NT0RPIENlcnRpZmljYXRpb24gQXV0 -aG9yaXR5MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA0ECLi3LjkRv3 -UcEbVASY06m/weaKXTuH+7uIzg3jLz8GlvCiKVCZrts7oVewdFFxze1CkU1B/qnI -2GqGd0S7WWaXUF601CxwRM/aN5VCaTwwxHGzUvAhTaHYujl8HJ6jJJ3ygxaYqhZ8 -Q5sVW7euNJH+1GImGEaaP+vB+fGQV+useg2L23IwambV4EajcNxo2f8ESIl33rXp -+2dtQem8Ob0y2WIC8bGoPW43nOIv4tOiJovGuFVDiOEjPqXSJDlqR6sA1KGzqSX+ -DT+nHbrTUcELpNqsOO9VUCQFZUaTNE8tja3G1CEZ0o7KBWFxB3NH5YoZEr0ETc5O -nKVIrLsm9wIDAQABo4GOMIGLMB0GA1UdDgQWBBQLWOWLxkwVN6RAqTCpIb5HNlpW -/zAOBgNVHQ8BAf8EBAMCAQYwDwYDVR0TAQH/BAUwAwEB/zBJBgNVHR8EQjBAMD6g -PKA6hjhodHRwOi8vY3JsLmNvbW9kb2NhLmNvbS9DT01PRE9DZXJ0aWZpY2F0aW9u -QXV0aG9yaXR5LmNybDANBgkqhkiG9w0BAQUFAAOCAQEAPpiem/Yb6dc5t3iuHXIY -SdOH5EOC6z/JqvWote9VfCFSZfnVDeFs9D6Mk3ORLgLETgdxb8CPOGEIqB6BCsAv -IC9Bi5HcSEW88cbeunZrM8gALTFGTO3nnc+IlP8zwFboJIYmuNg4ON8qa90SzMc/ -RxdMosIGlgnW2/4/PEZB31jiVg88O8EckzXZOFKs7sjsLjBOlDW0JB9LeGna8gI4 -zJVSk/BwJVmcIGfE7vmLV2H0knZ9P4SNVbfo5azV8fUZVqZa+5Acr5Pr5RzUZ5dd -BA6+C4OmF4O5MBKgxTMVBbkN+8cFduPYSo38NBejxiEovjBFMR7HeL5YYTisO+IB -ZQ== ------END CERTIFICATE----- - -# Issuer: CN=COMODO ECC Certification Authority O=COMODO CA Limited -# Subject: CN=COMODO ECC Certification Authority O=COMODO CA Limited -# Label: "COMODO ECC Certification Authority" -# Serial: 41578283867086692638256921589707938090 -# MD5 Fingerprint: 7c:62:ff:74:9d:31:53:5e:68:4a:d5:78:aa:1e:bf:23 -# SHA1 Fingerprint: 9f:74:4e:9f:2b:4d:ba:ec:0f:31:2c:50:b6:56:3b:8e:2d:93:c3:11 -# SHA256 Fingerprint: 17:93:92:7a:06:14:54:97:89:ad:ce:2f:8f:34:f7:f0:b6:6d:0f:3a:e3:a3:b8:4d:21:ec:15:db:ba:4f:ad:c7 ------BEGIN CERTIFICATE----- -MIICiTCCAg+gAwIBAgIQH0evqmIAcFBUTAGem2OZKjAKBggqhkjOPQQDAzCBhTEL -MAkGA1UEBhMCR0IxGzAZBgNVBAgTEkdyZWF0ZXIgTWFuY2hlc3RlcjEQMA4GA1UE -BxMHU2FsZm9yZDEaMBgGA1UEChMRQ09NT0RPIENBIExpbWl0ZWQxKzApBgNVBAMT -IkNPTU9ETyBFQ0MgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkwHhcNMDgwMzA2MDAw -MDAwWhcNMzgwMTE4MjM1OTU5WjCBhTELMAkGA1UEBhMCR0IxGzAZBgNVBAgTEkdy -ZWF0ZXIgTWFuY2hlc3RlcjEQMA4GA1UEBxMHU2FsZm9yZDEaMBgGA1UEChMRQ09N -T0RPIENBIExpbWl0ZWQxKzApBgNVBAMTIkNPTU9ETyBFQ0MgQ2VydGlmaWNhdGlv -biBBdXRob3JpdHkwdjAQBgcqhkjOPQIBBgUrgQQAIgNiAAQDR3svdcmCFYX7deSR -FtSrYpn1PlILBs5BAH+X4QokPB0BBO490o0JlwzgdeT6+3eKKvUDYEs2ixYjFq0J -cfRK9ChQtP6IHG4/bC8vCVlbpVsLM5niwz2J+Wos77LTBumjQjBAMB0GA1UdDgQW -BBR1cacZSBm8nZ3qQUfflMRId5nTeTAOBgNVHQ8BAf8EBAMCAQYwDwYDVR0TAQH/ -BAUwAwEB/zAKBggqhkjOPQQDAwNoADBlAjEA7wNbeqy3eApyt4jf/7VGFAkK+qDm -fQjGGoe9GKhzvSbKYAydzpmfz1wPMOG+FDHqAjAU9JM8SaczepBGR7NjfRObTrdv -GDeAU/7dIOA1mjbRxwG55tzd8/8dLDoWV9mSOdY= ------END CERTIFICATE----- - -# Issuer: CN=Certigna O=Dhimyotis -# Subject: CN=Certigna O=Dhimyotis -# Label: "Certigna" -# Serial: 18364802974209362175 -# MD5 Fingerprint: ab:57:a6:5b:7d:42:82:19:b5:d8:58:26:28:5e:fd:ff -# SHA1 Fingerprint: b1:2e:13:63:45:86:a4:6f:1a:b2:60:68:37:58:2d:c4:ac:fd:94:97 -# SHA256 Fingerprint: e3:b6:a2:db:2e:d7:ce:48:84:2f:7a:c5:32:41:c7:b7:1d:54:14:4b:fb:40:c1:1f:3f:1d:0b:42:f5:ee:a1:2d ------BEGIN CERTIFICATE----- -MIIDqDCCApCgAwIBAgIJAP7c4wEPyUj/MA0GCSqGSIb3DQEBBQUAMDQxCzAJBgNV -BAYTAkZSMRIwEAYDVQQKDAlEaGlteW90aXMxETAPBgNVBAMMCENlcnRpZ25hMB4X -DTA3MDYyOTE1MTMwNVoXDTI3MDYyOTE1MTMwNVowNDELMAkGA1UEBhMCRlIxEjAQ -BgNVBAoMCURoaW15b3RpczERMA8GA1UEAwwIQ2VydGlnbmEwggEiMA0GCSqGSIb3 -DQEBAQUAA4IBDwAwggEKAoIBAQDIaPHJ1tazNHUmgh7stL7qXOEm7RFHYeGifBZ4 -QCHkYJ5ayGPhxLGWkv8YbWkj4Sti993iNi+RB7lIzw7sebYs5zRLcAglozyHGxny -gQcPOJAZ0xH+hrTy0V4eHpbNgGzOOzGTtvKg0KmVEn2lmsxryIRWijOp5yIVUxbw -zBfsV1/pogqYCd7jX5xv3EjjhQsVWqa6n6xI4wmy9/Qy3l40vhx4XUJbzg4ij02Q -130yGLMLLGq/jj8UEYkgDncUtT2UCIf3JR7VsmAA7G8qKCVuKj4YYxclPz5EIBb2 -JsglrgVKtOdjLPOMFlN+XPsRGgjBRmKfIrjxwo1p3Po6WAbfAgMBAAGjgbwwgbkw -DwYDVR0TAQH/BAUwAwEB/zAdBgNVHQ4EFgQUGu3+QTmQtCRZvgHyUtVF9lo53BEw -ZAYDVR0jBF0wW4AUGu3+QTmQtCRZvgHyUtVF9lo53BGhOKQ2MDQxCzAJBgNVBAYT -AkZSMRIwEAYDVQQKDAlEaGlteW90aXMxETAPBgNVBAMMCENlcnRpZ25hggkA/tzj -AQ/JSP8wDgYDVR0PAQH/BAQDAgEGMBEGCWCGSAGG+EIBAQQEAwIABzANBgkqhkiG -9w0BAQUFAAOCAQEAhQMeknH2Qq/ho2Ge6/PAD/Kl1NqV5ta+aDY9fm4fTIrv0Q8h -bV6lUmPOEvjvKtpv6zf+EwLHyzs+ImvaYS5/1HI93TDhHkxAGYwP15zRgzB7mFnc -fca5DClMoTOi62c6ZYTTluLtdkVwj7Ur3vkj1kluPBS1xp81HlDQwY9qcEQCYsuu -HWhBp6pX6FOqB9IG9tUUBguRA3UsbHK1YZWaDYu5Def131TN3ubY1gkIl2PlwS6w -t0QmwCbAr1UwnjvVNioZBPRcHv/PLLf/0P2HQBHVESO7SMAhqaQoLf0V+LBOK/Qw -WyH8EZE0vkHve52Xdf+XlcCWWC/qu0bXu+TZLg== ------END CERTIFICATE----- - -# Issuer: O=Chunghwa Telecom Co., Ltd. OU=ePKI Root Certification Authority -# Subject: O=Chunghwa Telecom Co., Ltd. OU=ePKI Root Certification Authority -# Label: "ePKI Root Certification Authority" -# Serial: 28956088682735189655030529057352760477 -# MD5 Fingerprint: 1b:2e:00:ca:26:06:90:3d:ad:fe:6f:15:68:d3:6b:b3 -# SHA1 Fingerprint: 67:65:0d:f1:7e:8e:7e:5b:82:40:a4:f4:56:4b:cf:e2:3d:69:c6:f0 -# SHA256 Fingerprint: c0:a6:f4:dc:63:a2:4b:fd:cf:54:ef:2a:6a:08:2a:0a:72:de:35:80:3e:2f:f5:ff:52:7a:e5:d8:72:06:df:d5 ------BEGIN CERTIFICATE----- -MIIFsDCCA5igAwIBAgIQFci9ZUdcr7iXAF7kBtK8nTANBgkqhkiG9w0BAQUFADBe -MQswCQYDVQQGEwJUVzEjMCEGA1UECgwaQ2h1bmdod2EgVGVsZWNvbSBDby4sIEx0 -ZC4xKjAoBgNVBAsMIWVQS0kgUm9vdCBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTAe -Fw0wNDEyMjAwMjMxMjdaFw0zNDEyMjAwMjMxMjdaMF4xCzAJBgNVBAYTAlRXMSMw -IQYDVQQKDBpDaHVuZ2h3YSBUZWxlY29tIENvLiwgTHRkLjEqMCgGA1UECwwhZVBL -SSBSb290IENlcnRpZmljYXRpb24gQXV0aG9yaXR5MIICIjANBgkqhkiG9w0BAQEF -AAOCAg8AMIICCgKCAgEA4SUP7o3biDN1Z82tH306Tm2d0y8U82N0ywEhajfqhFAH -SyZbCUNsIZ5qyNUD9WBpj8zwIuQf5/dqIjG3LBXy4P4AakP/h2XGtRrBp0xtInAh -ijHyl3SJCRImHJ7K2RKilTza6We/CKBk49ZCt0Xvl/T29de1ShUCWH2YWEtgvM3X -DZoTM1PRYfl61dd4s5oz9wCGzh1NlDivqOx4UXCKXBCDUSH3ET00hl7lSM2XgYI1 -TBnsZfZrxQWh7kcT1rMhJ5QQCtkkO7q+RBNGMD+XPNjX12ruOzjjK9SXDrkb5wdJ -fzcq+Xd4z1TtW0ado4AOkUPB1ltfFLqfpo0kR0BZv3I4sjZsN/+Z0V0OWQqraffA -sgRFelQArr5T9rXn4fg8ozHSqf4hUmTFpmfwdQcGlBSBVcYn5AGPF8Fqcde+S/uU -WH1+ETOxQvdibBjWzwloPn9s9h6PYq2lY9sJpx8iQkEeb5mKPtf5P0B6ebClAZLS -nT0IFaUQAS2zMnaolQ2zepr7BxB4EW/hj8e6DyUadCrlHJhBmd8hh+iVBmoKs2pH -dmX2Os+PYhcZewoozRrSgx4hxyy/vv9haLdnG7t4TY3OZ+XkwY63I2binZB1NJip -NiuKmpS5nezMirH4JYlcWrYvjB9teSSnUmjDhDXiZo1jDiVN1Rmy5nk3pyKdVDEC -AwEAAaNqMGgwHQYDVR0OBBYEFB4M97Zn8uGSJglFwFU5Lnc/QkqiMAwGA1UdEwQF -MAMBAf8wOQYEZyoHAAQxMC8wLQIBADAJBgUrDgMCGgUAMAcGBWcqAwAABBRFsMLH -ClZ87lt4DJX5GFPBphzYEDANBgkqhkiG9w0BAQUFAAOCAgEACbODU1kBPpVJufGB -uvl2ICO1J2B01GqZNF5sAFPZn/KmsSQHRGoqxqWOeBLoR9lYGxMqXnmbnwoqZ6Yl -PwZpVnPDimZI+ymBV3QGypzqKOg4ZyYr8dW1P2WT+DZdjo2NQCCHGervJ8A9tDkP -JXtoUHRVnAxZfVo9QZQlUgjgRywVMRnVvwdVxrsStZf0X4OFunHB2WyBEXYKCrC/ -gpf36j36+uwtqSiUO1bd0lEursC9CBWMd1I0ltabrNMdjmEPNXubrjlpC2JgQCA2 -j6/7Nu4tCEoduL+bXPjqpRugc6bY+G7gMwRfaKonh+3ZwZCc7b3jajWvY9+rGNm6 -5ulK6lCKD2GTHuItGeIwlDWSXQ62B68ZgI9HkFFLLk3dheLSClIKF5r8GrBQAuUB -o2M3IUxExJtRmREOc5wGj1QupyheRDmHVi03vYVElOEMSyycw5KFNGHLD7ibSkNS -/jQ6fbjpKdx2qcgw+BRxgMYeNkh0IkFch4LoGHGLQYlE535YW6i4jRPpp2zDR+2z -Gp1iro2C6pSe3VkQw63d4k3jMdXH7OjysP6SHhYKGvzZ8/gntsm+HbRsZJB/9OTE -W9c3rkIO3aQab3yIVMUWbuF6aC74Or8NpDyJO3inTmODBCEIZ43ygknQW/2xzQ+D -hNQ+IIX3Sj0rnP0qCglN6oH4EZw= ------END CERTIFICATE----- - -# Issuer: O=certSIGN OU=certSIGN ROOT CA -# Subject: O=certSIGN OU=certSIGN ROOT CA -# Label: "certSIGN ROOT CA" -# Serial: 35210227249154 -# MD5 Fingerprint: 18:98:c0:d6:e9:3a:fc:f9:b0:f5:0c:f7:4b:01:44:17 -# SHA1 Fingerprint: fa:b7:ee:36:97:26:62:fb:2d:b0:2a:f6:bf:03:fd:e8:7c:4b:2f:9b -# SHA256 Fingerprint: ea:a9:62:c4:fa:4a:6b:af:eb:e4:15:19:6d:35:1c:cd:88:8d:4f:53:f3:fa:8a:e6:d7:c4:66:a9:4e:60:42:bb ------BEGIN CERTIFICATE----- -MIIDODCCAiCgAwIBAgIGIAYFFnACMA0GCSqGSIb3DQEBBQUAMDsxCzAJBgNVBAYT -AlJPMREwDwYDVQQKEwhjZXJ0U0lHTjEZMBcGA1UECxMQY2VydFNJR04gUk9PVCBD -QTAeFw0wNjA3MDQxNzIwMDRaFw0zMTA3MDQxNzIwMDRaMDsxCzAJBgNVBAYTAlJP -MREwDwYDVQQKEwhjZXJ0U0lHTjEZMBcGA1UECxMQY2VydFNJR04gUk9PVCBDQTCC -ASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBALczuX7IJUqOtdu0KBuqV5Do -0SLTZLrTk+jUrIZhQGpgV2hUhE28alQCBf/fm5oqrl0Hj0rDKH/v+yv6efHHrfAQ -UySQi2bJqIirr1qjAOm+ukbuW3N7LBeCgV5iLKECZbO9xSsAfsT8AzNXDe3i+s5d -RdY4zTW2ssHQnIFKquSyAVwdj1+ZxLGt24gh65AIgoDzMKND5pCCrlUoSe1b16kQ -OA7+j0xbm0bqQfWwCHTD0IgztnzXdN/chNFDDnU5oSVAKOp4yw4sLjmdjItuFhwv -JoIQ4uNllAoEwF73XVv4EOLQunpL+943AAAaWyjj0pxzPjKHmKHJUS/X3qwzs08C -AwEAAaNCMEAwDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAcYwHQYDVR0O -BBYEFOCMm9slSbPxfIbWskKHC9BroNnkMA0GCSqGSIb3DQEBBQUAA4IBAQA+0hyJ -LjX8+HXd5n9liPRyTMks1zJO890ZeUe9jjtbkw9QSSQTaxQGcu8J06Gh40CEyecY -MnQ8SG4Pn0vU9x7Tk4ZkVJdjclDVVc/6IJMCopvDI5NOFlV2oHB5bc0hH88vLbwZ -44gx+FkagQnIl6Z0x2DEW8xXjrJ1/RsCCdtZb3KTafcxQdaIOL+Hsr0Wefmq5L6I -Jd1hJyMctTEHBDa0GpC9oHRxUIltvBTjD4au8as+x6AJzKNI0eDbZOeStc+vckNw -i/nDhDwTqn6Sm1dTk/pwwpEOMfmbZ13pljheX7NzTogVZ96edhBiIL5VaZVDADlN -9u6wWk5JRFRYX0KD ------END CERTIFICATE----- - -# Issuer: CN=NetLock Arany (Class Gold) F\u0151tan\xfas\xedtv\xe1ny O=NetLock Kft. OU=Tan\xfas\xedtv\xe1nykiad\xf3k (Certification Services) -# Subject: CN=NetLock Arany (Class Gold) F\u0151tan\xfas\xedtv\xe1ny O=NetLock Kft. OU=Tan\xfas\xedtv\xe1nykiad\xf3k (Certification Services) -# Label: "NetLock Arany (Class Gold) F\u0151tan\xfas\xedtv\xe1ny" -# Serial: 80544274841616 -# MD5 Fingerprint: c5:a1:b7:ff:73:dd:d6:d7:34:32:18:df:fc:3c:ad:88 -# SHA1 Fingerprint: 06:08:3f:59:3f:15:a1:04:a0:69:a4:6b:a9:03:d0:06:b7:97:09:91 -# SHA256 Fingerprint: 6c:61:da:c3:a2:de:f0:31:50:6b:e0:36:d2:a6:fe:40:19:94:fb:d1:3d:f9:c8:d4:66:59:92:74:c4:46:ec:98 ------BEGIN CERTIFICATE----- -MIIEFTCCAv2gAwIBAgIGSUEs5AAQMA0GCSqGSIb3DQEBCwUAMIGnMQswCQYDVQQG -EwJIVTERMA8GA1UEBwwIQnVkYXBlc3QxFTATBgNVBAoMDE5ldExvY2sgS2Z0LjE3 -MDUGA1UECwwuVGFuw7pzw610dsOhbnlraWFkw7NrIChDZXJ0aWZpY2F0aW9uIFNl -cnZpY2VzKTE1MDMGA1UEAwwsTmV0TG9jayBBcmFueSAoQ2xhc3MgR29sZCkgRsWR -dGFuw7pzw610dsOhbnkwHhcNMDgxMjExMTUwODIxWhcNMjgxMjA2MTUwODIxWjCB -pzELMAkGA1UEBhMCSFUxETAPBgNVBAcMCEJ1ZGFwZXN0MRUwEwYDVQQKDAxOZXRM -b2NrIEtmdC4xNzA1BgNVBAsMLlRhbsO6c8OtdHbDoW55a2lhZMOzayAoQ2VydGlm -aWNhdGlvbiBTZXJ2aWNlcykxNTAzBgNVBAMMLE5ldExvY2sgQXJhbnkgKENsYXNz -IEdvbGQpIEbFkXRhbsO6c8OtdHbDoW55MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8A -MIIBCgKCAQEAxCRec75LbRTDofTjl5Bu0jBFHjzuZ9lk4BqKf8owyoPjIMHj9DrT -lF8afFttvzBPhCf2nx9JvMaZCpDyD/V/Q4Q3Y1GLeqVw/HpYzY6b7cNGbIRwXdrz -AZAj/E4wqX7hJ2Pn7WQ8oLjJM2P+FpD/sLj916jAwJRDC7bVWaaeVtAkH3B5r9s5 -VA1lddkVQZQBr17s9o3x/61k/iCa11zr/qYfCGSji3ZVrR47KGAuhyXoqq8fxmRG -ILdwfzzeSNuWU7c5d+Qa4scWhHaXWy+7GRWF+GmF9ZmnqfI0p6m2pgP8b4Y9VHx2 -BJtr+UBdADTHLpl1neWIA6pN+APSQnbAGwIDAKiLo0UwQzASBgNVHRMBAf8ECDAG -AQH/AgEEMA4GA1UdDwEB/wQEAwIBBjAdBgNVHQ4EFgQUzPpnk/C2uNClwB7zU/2M -U9+D15YwDQYJKoZIhvcNAQELBQADggEBAKt/7hwWqZw8UQCgwBEIBaeZ5m8BiFRh -bvG5GK1Krf6BQCOUL/t1fC8oS2IkgYIL9WHxHG64YTjrgfpioTtaYtOUZcTh5m2C -+C8lcLIhJsFyUR+MLMOEkMNaj7rP9KdlpeuY0fsFskZ1FSNqb4VjMIDw1Z4fKRzC -bLBQWV2QWzuoDTDPv31/zvGdg73JRm4gpvlhUbohL3u+pRVjodSVh/GeufOJ8z2F -uLjbvrW5KfnaNwUASZQDhETnv0Mxz3WLJdH0pmT1kvarBes96aULNmLazAZfNou2 -XjG4Kvte9nHfRCaexOYNkbQudZWAUWpLMKawYqGT8ZvYzsRjdT9ZR7E= ------END CERTIFICATE----- - -# Issuer: CN=Microsec e-Szigno Root CA 2009 O=Microsec Ltd. -# Subject: CN=Microsec e-Szigno Root CA 2009 O=Microsec Ltd. -# Label: "Microsec e-Szigno Root CA 2009" -# Serial: 14014712776195784473 -# MD5 Fingerprint: f8:49:f4:03:bc:44:2d:83:be:48:69:7d:29:64:fc:b1 -# SHA1 Fingerprint: 89:df:74:fe:5c:f4:0f:4a:80:f9:e3:37:7d:54:da:91:e1:01:31:8e -# SHA256 Fingerprint: 3c:5f:81:fe:a5:fa:b8:2c:64:bf:a2:ea:ec:af:cd:e8:e0:77:fc:86:20:a7:ca:e5:37:16:3d:f3:6e:db:f3:78 ------BEGIN CERTIFICATE----- -MIIECjCCAvKgAwIBAgIJAMJ+QwRORz8ZMA0GCSqGSIb3DQEBCwUAMIGCMQswCQYD -VQQGEwJIVTERMA8GA1UEBwwIQnVkYXBlc3QxFjAUBgNVBAoMDU1pY3Jvc2VjIEx0 -ZC4xJzAlBgNVBAMMHk1pY3Jvc2VjIGUtU3ppZ25vIFJvb3QgQ0EgMjAwOTEfMB0G -CSqGSIb3DQEJARYQaW5mb0BlLXN6aWduby5odTAeFw0wOTA2MTYxMTMwMThaFw0y -OTEyMzAxMTMwMThaMIGCMQswCQYDVQQGEwJIVTERMA8GA1UEBwwIQnVkYXBlc3Qx -FjAUBgNVBAoMDU1pY3Jvc2VjIEx0ZC4xJzAlBgNVBAMMHk1pY3Jvc2VjIGUtU3pp -Z25vIFJvb3QgQ0EgMjAwOTEfMB0GCSqGSIb3DQEJARYQaW5mb0BlLXN6aWduby5o -dTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAOn4j/NjrdqG2KfgQvvP -kd6mJviZpWNwrZuuyjNAfW2WbqEORO7hE52UQlKavXWFdCyoDh2Tthi3jCyoz/tc -cbna7P7ofo/kLx2yqHWH2Leh5TvPmUpG0IMZfcChEhyVbUr02MelTTMuhTlAdX4U -fIASmFDHQWe4oIBhVKZsTh/gnQ4H6cm6M+f+wFUoLAKApxn1ntxVUwOXewdI/5n7 -N4okxFnMUBBjjqqpGrCEGob5X7uxUG6k0QrM1XF+H6cbfPVTbiJfyyvm1HxdrtbC -xkzlBQHZ7Vf8wSN5/PrIJIOV87VqUQHQd9bpEqH5GoP7ghu5sJf0dgYzQ0mg/wu1 -+rUCAwEAAaOBgDB+MA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgEGMB0G -A1UdDgQWBBTLD8bfQkPMPcu1SCOhGnqmKrs0aDAfBgNVHSMEGDAWgBTLD8bfQkPM -Pcu1SCOhGnqmKrs0aDAbBgNVHREEFDASgRBpbmZvQGUtc3ppZ25vLmh1MA0GCSqG -SIb3DQEBCwUAA4IBAQDJ0Q5eLtXMs3w+y/w9/w0olZMEyL/azXm4Q5DwpL7v8u8h -mLzU1F0G9u5C7DBsoKqpyvGvivo/C3NqPuouQH4frlRheesuCDfXI/OMn74dseGk -ddug4lQUsbocKaQY9hK6ohQU4zE1yED/t+AFdlfBHFny+L/k7SViXITwfn4fs775 -tyERzAMBVnCnEJIeGzSBHq2cGsMEPO0CYdYeBvNfOofyK/FFh+U9rNHHV4S9a67c -2Pm2G2JwCz02yULyMtd6YebS2z3PyKnJm9zbWETXbzivf3jTo60adbocwTZ8jx5t -HMN1Rq41Bab2XD0h7lbwyYIiLXpUq3DDfSJlgnCW ------END CERTIFICATE----- - -# Issuer: CN=GlobalSign O=GlobalSign OU=GlobalSign Root CA - R3 -# Subject: CN=GlobalSign O=GlobalSign OU=GlobalSign Root CA - R3 -# Label: "GlobalSign Root CA - R3" -# Serial: 4835703278459759426209954 -# MD5 Fingerprint: c5:df:b8:49:ca:05:13:55:ee:2d:ba:1a:c3:3e:b0:28 -# SHA1 Fingerprint: d6:9b:56:11:48:f0:1c:77:c5:45:78:c1:09:26:df:5b:85:69:76:ad -# SHA256 Fingerprint: cb:b5:22:d7:b7:f1:27:ad:6a:01:13:86:5b:df:1c:d4:10:2e:7d:07:59:af:63:5a:7c:f4:72:0d:c9:63:c5:3b ------BEGIN CERTIFICATE----- -MIIDXzCCAkegAwIBAgILBAAAAAABIVhTCKIwDQYJKoZIhvcNAQELBQAwTDEgMB4G -A1UECxMXR2xvYmFsU2lnbiBSb290IENBIC0gUjMxEzARBgNVBAoTCkdsb2JhbFNp -Z24xEzARBgNVBAMTCkdsb2JhbFNpZ24wHhcNMDkwMzE4MTAwMDAwWhcNMjkwMzE4 -MTAwMDAwWjBMMSAwHgYDVQQLExdHbG9iYWxTaWduIFJvb3QgQ0EgLSBSMzETMBEG -A1UEChMKR2xvYmFsU2lnbjETMBEGA1UEAxMKR2xvYmFsU2lnbjCCASIwDQYJKoZI -hvcNAQEBBQADggEPADCCAQoCggEBAMwldpB5BngiFvXAg7aEyiie/QV2EcWtiHL8 -RgJDx7KKnQRfJMsuS+FggkbhUqsMgUdwbN1k0ev1LKMPgj0MK66X17YUhhB5uzsT -gHeMCOFJ0mpiLx9e+pZo34knlTifBtc+ycsmWQ1z3rDI6SYOgxXG71uL0gRgykmm -KPZpO/bLyCiR5Z2KYVc3rHQU3HTgOu5yLy6c+9C7v/U9AOEGM+iCK65TpjoWc4zd -QQ4gOsC0p6Hpsk+QLjJg6VfLuQSSaGjlOCZgdbKfd/+RFO+uIEn8rUAVSNECMWEZ -XriX7613t2Saer9fwRPvm2L7DWzgVGkWqQPabumDk3F2xmmFghcCAwEAAaNCMEAw -DgYDVR0PAQH/BAQDAgEGMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYEFI/wS3+o -LkUkrk1Q+mOai97i3Ru8MA0GCSqGSIb3DQEBCwUAA4IBAQBLQNvAUKr+yAzv95ZU -RUm7lgAJQayzE4aGKAczymvmdLm6AC2upArT9fHxD4q/c2dKg8dEe3jgr25sbwMp -jjM5RcOO5LlXbKr8EpbsU8Yt5CRsuZRj+9xTaGdWPoO4zzUhw8lo/s7awlOqzJCK -6fBdRoyV3XpYKBovHd7NADdBj+1EbddTKJd+82cEHhXXipa0095MJ6RMG3NzdvQX -mcIfeg7jLQitChws/zyrVQ4PkX4268NXSb7hLi18YIvDQVETI53O9zJrlAGomecs -Mx86OyXShkDOOyyGeMlhLxS67ttVb9+E7gUJTb0o2HLO02JQZR7rkpeDMdmztcpH -WD9f ------END CERTIFICATE----- - -# Issuer: CN=Izenpe.com O=IZENPE S.A. -# Subject: CN=Izenpe.com O=IZENPE S.A. -# Label: "Izenpe.com" -# Serial: 917563065490389241595536686991402621 -# MD5 Fingerprint: a6:b0:cd:85:80:da:5c:50:34:a3:39:90:2f:55:67:73 -# SHA1 Fingerprint: 2f:78:3d:25:52:18:a7:4a:65:39:71:b5:2c:a2:9c:45:15:6f:e9:19 -# SHA256 Fingerprint: 25:30:cc:8e:98:32:15:02:ba:d9:6f:9b:1f:ba:1b:09:9e:2d:29:9e:0f:45:48:bb:91:4f:36:3b:c0:d4:53:1f ------BEGIN CERTIFICATE----- -MIIF8TCCA9mgAwIBAgIQALC3WhZIX7/hy/WL1xnmfTANBgkqhkiG9w0BAQsFADA4 -MQswCQYDVQQGEwJFUzEUMBIGA1UECgwLSVpFTlBFIFMuQS4xEzARBgNVBAMMCkl6 -ZW5wZS5jb20wHhcNMDcxMjEzMTMwODI4WhcNMzcxMjEzMDgyNzI1WjA4MQswCQYD -VQQGEwJFUzEUMBIGA1UECgwLSVpFTlBFIFMuQS4xEzARBgNVBAMMCkl6ZW5wZS5j -b20wggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQDJ03rKDx6sp4boFmVq -scIbRTJxldn+EFvMr+eleQGPicPK8lVx93e+d5TzcqQsRNiekpsUOqHnJJAKClaO -xdgmlOHZSOEtPtoKct2jmRXagaKH9HtuJneJWK3W6wyyQXpzbm3benhB6QiIEn6H -LmYRY2xU+zydcsC8Lv/Ct90NduM61/e0aL6i9eOBbsFGb12N4E3GVFWJGjMxCrFX -uaOKmMPsOzTFlUFpfnXCPCDFYbpRR6AgkJOhkEvzTnyFRVSa0QUmQbC1TR0zvsQD -yCV8wXDbO/QJLVQnSKwv4cSsPsjLkkxTOTcj7NMB+eAJRE1NZMDhDVqHIrytG6P+ -JrUV86f8hBnp7KGItERphIPzidF0BqnMC9bC3ieFUCbKF7jJeodWLBoBHmy+E60Q -rLUk9TiRodZL2vG70t5HtfG8gfZZa88ZU+mNFctKy6lvROUbQc/hhqfK0GqfvEyN -BjNaooXlkDWgYlwWTvDjovoDGrQscbNYLN57C9saD+veIR8GdwYDsMnvmfzAuU8L -hij+0rnq49qlw0dpEuDb8PYZi+17cNcC1u2HGCgsBCRMd+RIihrGO5rUD8r6ddIB -QFqNeb+Lz0vPqhbBleStTIo+F5HUsWLlguWABKQDfo2/2n+iD5dPDNMN+9fR5XJ+ -HMh3/1uaD7euBUbl8agW7EekFwIDAQABo4H2MIHzMIGwBgNVHREEgagwgaWBD2lu -Zm9AaXplbnBlLmNvbaSBkTCBjjFHMEUGA1UECgw+SVpFTlBFIFMuQS4gLSBDSUYg -QTAxMzM3MjYwLVJNZXJjLlZpdG9yaWEtR2FzdGVpeiBUMTA1NSBGNjIgUzgxQzBB -BgNVBAkMOkF2ZGEgZGVsIE1lZGl0ZXJyYW5lbyBFdG9yYmlkZWEgMTQgLSAwMTAx -MCBWaXRvcmlhLUdhc3RlaXowDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMC -AQYwHQYDVR0OBBYEFB0cZQ6o8iV7tJHP5LGx5r1VdGwFMA0GCSqGSIb3DQEBCwUA -A4ICAQB4pgwWSp9MiDrAyw6lFn2fuUhfGI8NYjb2zRlrrKvV9pF9rnHzP7MOeIWb -laQnIUdCSnxIOvVFfLMMjlF4rJUT3sb9fbgakEyrkgPH7UIBzg/YsfqikuFgba56 -awmqxinuaElnMIAkejEWOVt+8Rwu3WwJrfIxwYJOubv5vr8qhT/AQKM6WfxZSzwo -JNu0FXWuDYi6LnPAvViH5ULy617uHjAimcs30cQhbIHsvm0m5hzkQiCeR7Csg1lw -LDXWrzY0tM07+DKo7+N4ifuNRSzanLh+QBxh5z6ikixL8s36mLYp//Pye6kfLqCT -VyvehQP5aTfLnnhqBbTFMXiJ7HqnheG5ezzevh55hM6fcA5ZwjUukCox2eRFekGk -LhObNA5me0mrZJfQRsN5nXJQY6aYWwa9SG3YOYNw6DXwBdGqvOPbyALqfP2C2sJb -UjWumDqtujWTI6cfSN01RpiyEGjkpTHCClguGYEQyVB1/OpaFs4R1+7vUIgtYf8/ -QnMFlEPVjjxOAToZpR9GTnfQXeWBIiGH/pR9hNiTrdZoQ0iy2+tzJOeRf1SktoA+ -naM8THLCV8Sg1Mw4J87VBp6iSNnpn86CcDaTmjvfliHjWbcM2pE38P1ZWrOZyGls -QyYBNWNgVYkDOnXYukrZVP/u3oDYLdE41V4tC5h9Pmzb/CaIxw== ------END CERTIFICATE----- - -# Issuer: CN=Go Daddy Root Certificate Authority - G2 O=GoDaddy.com, Inc. -# Subject: CN=Go Daddy Root Certificate Authority - G2 O=GoDaddy.com, Inc. -# Label: "Go Daddy Root Certificate Authority - G2" -# Serial: 0 -# MD5 Fingerprint: 80:3a:bc:22:c1:e6:fb:8d:9b:3b:27:4a:32:1b:9a:01 -# SHA1 Fingerprint: 47:be:ab:c9:22:ea:e8:0e:78:78:34:62:a7:9f:45:c2:54:fd:e6:8b -# SHA256 Fingerprint: 45:14:0b:32:47:eb:9c:c8:c5:b4:f0:d7:b5:30:91:f7:32:92:08:9e:6e:5a:63:e2:74:9d:d3:ac:a9:19:8e:da ------BEGIN CERTIFICATE----- -MIIDxTCCAq2gAwIBAgIBADANBgkqhkiG9w0BAQsFADCBgzELMAkGA1UEBhMCVVMx -EDAOBgNVBAgTB0FyaXpvbmExEzARBgNVBAcTClNjb3R0c2RhbGUxGjAYBgNVBAoT -EUdvRGFkZHkuY29tLCBJbmMuMTEwLwYDVQQDEyhHbyBEYWRkeSBSb290IENlcnRp -ZmljYXRlIEF1dGhvcml0eSAtIEcyMB4XDTA5MDkwMTAwMDAwMFoXDTM3MTIzMTIz -NTk1OVowgYMxCzAJBgNVBAYTAlVTMRAwDgYDVQQIEwdBcml6b25hMRMwEQYDVQQH -EwpTY290dHNkYWxlMRowGAYDVQQKExFHb0RhZGR5LmNvbSwgSW5jLjExMC8GA1UE -AxMoR28gRGFkZHkgUm9vdCBDZXJ0aWZpY2F0ZSBBdXRob3JpdHkgLSBHMjCCASIw -DQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAL9xYgjx+lk09xvJGKP3gElY6SKD -E6bFIEMBO4Tx5oVJnyfq9oQbTqC023CYxzIBsQU+B07u9PpPL1kwIuerGVZr4oAH -/PMWdYA5UXvl+TW2dE6pjYIT5LY/qQOD+qK+ihVqf94Lw7YZFAXK6sOoBJQ7Rnwy -DfMAZiLIjWltNowRGLfTshxgtDj6AozO091GB94KPutdfMh8+7ArU6SSYmlRJQVh -GkSBjCypQ5Yj36w6gZoOKcUcqeldHraenjAKOc7xiID7S13MMuyFYkMlNAJWJwGR -tDtwKj9useiciAF9n9T521NtYJ2/LOdYq7hfRvzOxBsDPAnrSTFcaUaz4EcCAwEA -AaNCMEAwDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwHQYDVR0OBBYE -FDqahQcQZyi27/a9BUFuIMGU2g/eMA0GCSqGSIb3DQEBCwUAA4IBAQCZ21151fmX -WWcDYfF+OwYxdS2hII5PZYe096acvNjpL9DbWu7PdIxztDhC2gV7+AJ1uP2lsdeu -9tfeE8tTEH6KRtGX+rcuKxGrkLAngPnon1rpN5+r5N9ss4UXnT3ZJE95kTXWXwTr -gIOrmgIttRD02JDHBHNA7XIloKmf7J6raBKZV8aPEjoJpL1E/QYVN8Gb5DKj7Tjo -2GTzLH4U/ALqn83/B2gX2yKQOC16jdFU8WnjXzPKej17CuPKf1855eJ1usV2GDPO -LPAvTK33sefOT6jEm0pUBsV/fdUID+Ic/n4XuKxe9tQWskMJDE32p2u0mYRlynqI -4uJEvlz36hz1 ------END CERTIFICATE----- - -# Issuer: CN=Starfield Root Certificate Authority - G2 O=Starfield Technologies, Inc. -# Subject: CN=Starfield Root Certificate Authority - G2 O=Starfield Technologies, Inc. -# Label: "Starfield Root Certificate Authority - G2" -# Serial: 0 -# MD5 Fingerprint: d6:39:81:c6:52:7e:96:69:fc:fc:ca:66:ed:05:f2:96 -# SHA1 Fingerprint: b5:1c:06:7c:ee:2b:0c:3d:f8:55:ab:2d:92:f4:fe:39:d4:e7:0f:0e -# SHA256 Fingerprint: 2c:e1:cb:0b:f9:d2:f9:e1:02:99:3f:be:21:51:52:c3:b2:dd:0c:ab:de:1c:68:e5:31:9b:83:91:54:db:b7:f5 ------BEGIN CERTIFICATE----- -MIID3TCCAsWgAwIBAgIBADANBgkqhkiG9w0BAQsFADCBjzELMAkGA1UEBhMCVVMx -EDAOBgNVBAgTB0FyaXpvbmExEzARBgNVBAcTClNjb3R0c2RhbGUxJTAjBgNVBAoT -HFN0YXJmaWVsZCBUZWNobm9sb2dpZXMsIEluYy4xMjAwBgNVBAMTKVN0YXJmaWVs -ZCBSb290IENlcnRpZmljYXRlIEF1dGhvcml0eSAtIEcyMB4XDTA5MDkwMTAwMDAw -MFoXDTM3MTIzMTIzNTk1OVowgY8xCzAJBgNVBAYTAlVTMRAwDgYDVQQIEwdBcml6 -b25hMRMwEQYDVQQHEwpTY290dHNkYWxlMSUwIwYDVQQKExxTdGFyZmllbGQgVGVj -aG5vbG9naWVzLCBJbmMuMTIwMAYDVQQDEylTdGFyZmllbGQgUm9vdCBDZXJ0aWZp -Y2F0ZSBBdXRob3JpdHkgLSBHMjCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoC -ggEBAL3twQP89o/8ArFvW59I2Z154qK3A2FWGMNHttfKPTUuiUP3oWmb3ooa/RMg -nLRJdzIpVv257IzdIvpy3Cdhl+72WoTsbhm5iSzchFvVdPtrX8WJpRBSiUZV9Lh1 -HOZ/5FSuS/hVclcCGfgXcVnrHigHdMWdSL5stPSksPNkN3mSwOxGXn/hbVNMYq/N -Hwtjuzqd+/x5AJhhdM8mgkBj87JyahkNmcrUDnXMN/uLicFZ8WJ/X7NfZTD4p7dN -dloedl40wOiWVpmKs/B/pM293DIxfJHP4F8R+GuqSVzRmZTRouNjWwl2tVZi4Ut0 -HZbUJtQIBFnQmA4O5t78w+wfkPECAwEAAaNCMEAwDwYDVR0TAQH/BAUwAwEB/zAO -BgNVHQ8BAf8EBAMCAQYwHQYDVR0OBBYEFHwMMh+n2TB/xH1oo2Kooc6rB1snMA0G -CSqGSIb3DQEBCwUAA4IBAQARWfolTwNvlJk7mh+ChTnUdgWUXuEok21iXQnCoKjU -sHU48TRqneSfioYmUeYs0cYtbpUgSpIB7LiKZ3sx4mcujJUDJi5DnUox9g61DLu3 -4jd/IroAow57UvtruzvE03lRTs2Q9GcHGcg8RnoNAX3FWOdt5oUwF5okxBDgBPfg -8n/Uqgr/Qh037ZTlZFkSIHc40zI+OIF1lnP6aI+xy84fxez6nH7PfrHxBy22/L/K -pL/QlwVKvOoYKAKQvVR4CSFx09F9HdkWsKlhPdAKACL8x3vLCWRFCztAgfd9fDL1 -mMpYjn0q7pBZc2T5NnReJaH1ZgUufzkVqSr7UIuOhWn0 ------END CERTIFICATE----- - -# Issuer: CN=Starfield Services Root Certificate Authority - G2 O=Starfield Technologies, Inc. -# Subject: CN=Starfield Services Root Certificate Authority - G2 O=Starfield Technologies, Inc. -# Label: "Starfield Services Root Certificate Authority - G2" -# Serial: 0 -# MD5 Fingerprint: 17:35:74:af:7b:61:1c:eb:f4:f9:3c:e2:ee:40:f9:a2 -# SHA1 Fingerprint: 92:5a:8f:8d:2c:6d:04:e0:66:5f:59:6a:ff:22:d8:63:e8:25:6f:3f -# SHA256 Fingerprint: 56:8d:69:05:a2:c8:87:08:a4:b3:02:51:90:ed:cf:ed:b1:97:4a:60:6a:13:c6:e5:29:0f:cb:2a:e6:3e:da:b5 ------BEGIN CERTIFICATE----- -MIID7zCCAtegAwIBAgIBADANBgkqhkiG9w0BAQsFADCBmDELMAkGA1UEBhMCVVMx -EDAOBgNVBAgTB0FyaXpvbmExEzARBgNVBAcTClNjb3R0c2RhbGUxJTAjBgNVBAoT -HFN0YXJmaWVsZCBUZWNobm9sb2dpZXMsIEluYy4xOzA5BgNVBAMTMlN0YXJmaWVs -ZCBTZXJ2aWNlcyBSb290IENlcnRpZmljYXRlIEF1dGhvcml0eSAtIEcyMB4XDTA5 -MDkwMTAwMDAwMFoXDTM3MTIzMTIzNTk1OVowgZgxCzAJBgNVBAYTAlVTMRAwDgYD -VQQIEwdBcml6b25hMRMwEQYDVQQHEwpTY290dHNkYWxlMSUwIwYDVQQKExxTdGFy -ZmllbGQgVGVjaG5vbG9naWVzLCBJbmMuMTswOQYDVQQDEzJTdGFyZmllbGQgU2Vy -dmljZXMgUm9vdCBDZXJ0aWZpY2F0ZSBBdXRob3JpdHkgLSBHMjCCASIwDQYJKoZI -hvcNAQEBBQADggEPADCCAQoCggEBANUMOsQq+U7i9b4Zl1+OiFOxHz/Lz58gE20p -OsgPfTz3a3Y4Y9k2YKibXlwAgLIvWX/2h/klQ4bnaRtSmpDhcePYLQ1Ob/bISdm2 -8xpWriu2dBTrz/sm4xq6HZYuajtYlIlHVv8loJNwU4PahHQUw2eeBGg6345AWh1K -Ts9DkTvnVtYAcMtS7nt9rjrnvDH5RfbCYM8TWQIrgMw0R9+53pBlbQLPLJGmpufe -hRhJfGZOozptqbXuNC66DQO4M99H67FrjSXZm86B0UVGMpZwh94CDklDhbZsc7tk -6mFBrMnUVN+HL8cisibMn1lUaJ/8viovxFUcdUBgF4UCVTmLfwUCAwEAAaNCMEAw -DwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwHQYDVR0OBBYEFJxfAN+q -AdcwKziIorhtSpzyEZGDMA0GCSqGSIb3DQEBCwUAA4IBAQBLNqaEd2ndOxmfZyMI -bw5hyf2E3F/YNoHN2BtBLZ9g3ccaaNnRbobhiCPPE95Dz+I0swSdHynVv/heyNXB -ve6SbzJ08pGCL72CQnqtKrcgfU28elUSwhXqvfdqlS5sdJ/PHLTyxQGjhdByPq1z -qwubdQxtRbeOlKyWN7Wg0I8VRw7j6IPdj/3vQQF3zCepYoUz8jcI73HPdwbeyBkd -iEDPfUYd/x7H4c7/I9vG+o1VTqkC50cRRj70/b17KSa7qWFiNyi2LSr2EIZkyXCn -0q23KXB56jzaYyWf/Wi3MOxw+3WKt21gZ7IeyLnp2KhvAotnDU0mV3HaIPzBSlCN -sSi6 ------END CERTIFICATE----- - -# Issuer: CN=Certum Trusted Network CA O=Unizeto Technologies S.A. OU=Certum Certification Authority -# Subject: CN=Certum Trusted Network CA O=Unizeto Technologies S.A. OU=Certum Certification Authority -# Label: "Certum Trusted Network CA" -# Serial: 279744 -# MD5 Fingerprint: d5:e9:81:40:c5:18:69:fc:46:2c:89:75:62:0f:aa:78 -# SHA1 Fingerprint: 07:e0:32:e0:20:b7:2c:3f:19:2f:06:28:a2:59:3a:19:a7:0f:06:9e -# SHA256 Fingerprint: 5c:58:46:8d:55:f5:8e:49:7e:74:39:82:d2:b5:00:10:b6:d1:65:37:4a:cf:83:a7:d4:a3:2d:b7:68:c4:40:8e ------BEGIN CERTIFICATE----- -MIIDuzCCAqOgAwIBAgIDBETAMA0GCSqGSIb3DQEBBQUAMH4xCzAJBgNVBAYTAlBM -MSIwIAYDVQQKExlVbml6ZXRvIFRlY2hub2xvZ2llcyBTLkEuMScwJQYDVQQLEx5D -ZXJ0dW0gQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkxIjAgBgNVBAMTGUNlcnR1bSBU -cnVzdGVkIE5ldHdvcmsgQ0EwHhcNMDgxMDIyMTIwNzM3WhcNMjkxMjMxMTIwNzM3 -WjB+MQswCQYDVQQGEwJQTDEiMCAGA1UEChMZVW5pemV0byBUZWNobm9sb2dpZXMg -Uy5BLjEnMCUGA1UECxMeQ2VydHVtIENlcnRpZmljYXRpb24gQXV0aG9yaXR5MSIw -IAYDVQQDExlDZXJ0dW0gVHJ1c3RlZCBOZXR3b3JrIENBMIIBIjANBgkqhkiG9w0B -AQEFAAOCAQ8AMIIBCgKCAQEA4/t9o3K6wvDJFIf1awFO4W5AB7ptJ11/91sts1rH -UV+rpDKmYYe2bg+G0jACl/jXaVehGDldamR5xgFZrDwxSjh80gTSSyjoIF87B6LM -TXPb865Px1bVWqeWifrzq2jUI4ZZJ88JJ7ysbnKDHDBy3+Ci6dLhdHUZvSqeexVU -BBvXQzmtVSjF4hq79MDkrjhJM8x2hZ85RdKknvISjFH4fOQtf/WsX+sWn7Et0brM -kUJ3TCXJkDhv2/DM+44el1k+1WBO5gUo7Ul5E0u6SNsv+XLTOcr+H9g0cvW0QM8x -AcPs3hEtF10fuFDRXhmnad4HMyjKUJX5p1TLVIZQRan5SQIDAQABo0IwQDAPBgNV -HRMBAf8EBTADAQH/MB0GA1UdDgQWBBQIds3LB/8k9sXN7buQvOKEN0Z19zAOBgNV -HQ8BAf8EBAMCAQYwDQYJKoZIhvcNAQEFBQADggEBAKaorSLOAT2mo/9i0Eidi15y -sHhE49wcrwn9I0j6vSrEuVUEtRCjjSfeC4Jj0O7eDDd5QVsisrCaQVymcODU0HfL -I9MA4GxWL+FpDQ3Zqr8hgVDZBqWo/5U30Kr+4rP1mS1FhIrlQgnXdAIv94nYmem8 -J9RHjboNRhx3zxSkHLmkMcScKHQDNP8zGSal6Q10tz6XxnboJ5ajZt3hrvJBW8qY -VoNzcOSGGtIxQbovvi0TWnZvTuhOgQ4/WwMioBK+ZlgRSssDxLQqKi2WF+A5VLxI -03YnnZotBqbJ7DnSq9ufmgsnAjUpsUCV5/nonFWIGUbWtzT1fs45mtk48VH3Tyw= ------END CERTIFICATE----- - -# Issuer: CN=TWCA Root Certification Authority O=TAIWAN-CA OU=Root CA -# Subject: CN=TWCA Root Certification Authority O=TAIWAN-CA OU=Root CA -# Label: "TWCA Root Certification Authority" -# Serial: 1 -# MD5 Fingerprint: aa:08:8f:f6:f9:7b:b7:f2:b1:a7:1e:9b:ea:ea:bd:79 -# SHA1 Fingerprint: cf:9e:87:6d:d3:eb:fc:42:26:97:a3:b5:a3:7a:a0:76:a9:06:23:48 -# SHA256 Fingerprint: bf:d8:8f:e1:10:1c:41:ae:3e:80:1b:f8:be:56:35:0e:e9:ba:d1:a6:b9:bd:51:5e:dc:5c:6d:5b:87:11:ac:44 ------BEGIN CERTIFICATE----- -MIIDezCCAmOgAwIBAgIBATANBgkqhkiG9w0BAQUFADBfMQswCQYDVQQGEwJUVzES -MBAGA1UECgwJVEFJV0FOLUNBMRAwDgYDVQQLDAdSb290IENBMSowKAYDVQQDDCFU -V0NBIFJvb3QgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkwHhcNMDgwODI4MDcyNDMz -WhcNMzAxMjMxMTU1OTU5WjBfMQswCQYDVQQGEwJUVzESMBAGA1UECgwJVEFJV0FO -LUNBMRAwDgYDVQQLDAdSb290IENBMSowKAYDVQQDDCFUV0NBIFJvb3QgQ2VydGlm -aWNhdGlvbiBBdXRob3JpdHkwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIB -AQCwfnK4pAOU5qfeCTiRShFAh6d8WWQUe7UREN3+v9XAu1bihSX0NXIP+FPQQeFE -AcK0HMMxQhZHhTMidrIKbw/lJVBPhYa+v5guEGcevhEFhgWQxFnQfHgQsIBct+HH -K3XLfJ+utdGdIzdjp9xCoi2SBBtQwXu4PhvJVgSLL1KbralW6cH/ralYhzC2gfeX -RfwZVzsrb+RH9JlF/h3x+JejiB03HFyP4HYlmlD4oFT/RJB2I9IyxsOrBr/8+7/z -rX2SYgJbKdM1o5OaQ2RgXbL6Mv87BK9NQGr5x+PvI/1ry+UPizgN7gr8/g+YnzAx -3WxSZfmLgb4i4RxYA7qRG4kHAgMBAAGjQjBAMA4GA1UdDwEB/wQEAwIBBjAPBgNV -HRMBAf8EBTADAQH/MB0GA1UdDgQWBBRqOFsmjd6LWvJPelSDGRjjCDWmujANBgkq -hkiG9w0BAQUFAAOCAQEAPNV3PdrfibqHDAhUaiBQkr6wQT25JmSDCi/oQMCXKCeC -MErJk/9q56YAf4lCmtYR5VPOL8zy2gXE/uJQxDqGfczafhAJO5I1KlOy/usrBdls -XebQ79NqZp4VKIV66IIArB6nCWlWQtNoURi+VJq/REG6Sb4gumlc7rh3zc5sH62D -lhh9DrUUOYTxKOkto557HnpyWoOzeW/vtPzQCqVYT0bf+215WfKEIlKuD8z7fDvn -aspHYcN6+NOSBB+4IIThNlQWx0DeO4pz3N/GCUzf7Nr/1FNCocnyYh0igzyXxfkZ -YiesZSLX0zzG5Y6yU8xJzrww/nsOM5D77dIUkR8Hrw== ------END CERTIFICATE----- - -# Issuer: O=SECOM Trust Systems CO.,LTD. OU=Security Communication RootCA2 -# Subject: O=SECOM Trust Systems CO.,LTD. OU=Security Communication RootCA2 -# Label: "Security Communication RootCA2" -# Serial: 0 -# MD5 Fingerprint: 6c:39:7d:a4:0e:55:59:b2:3f:d6:41:b1:12:50:de:43 -# SHA1 Fingerprint: 5f:3b:8c:f2:f8:10:b3:7d:78:b4:ce:ec:19:19:c3:73:34:b9:c7:74 -# SHA256 Fingerprint: 51:3b:2c:ec:b8:10:d4:cd:e5:dd:85:39:1a:df:c6:c2:dd:60:d8:7b:b7:36:d2:b5:21:48:4a:a4:7a:0e:be:f6 ------BEGIN CERTIFICATE----- -MIIDdzCCAl+gAwIBAgIBADANBgkqhkiG9w0BAQsFADBdMQswCQYDVQQGEwJKUDEl -MCMGA1UEChMcU0VDT00gVHJ1c3QgU3lzdGVtcyBDTy4sTFRELjEnMCUGA1UECxMe -U2VjdXJpdHkgQ29tbXVuaWNhdGlvbiBSb290Q0EyMB4XDTA5MDUyOTA1MDAzOVoX -DTI5MDUyOTA1MDAzOVowXTELMAkGA1UEBhMCSlAxJTAjBgNVBAoTHFNFQ09NIFRy -dXN0IFN5c3RlbXMgQ08uLExURC4xJzAlBgNVBAsTHlNlY3VyaXR5IENvbW11bmlj -YXRpb24gUm9vdENBMjCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBANAV -OVKxUrO6xVmCxF1SrjpDZYBLx/KWvNs2l9amZIyoXvDjChz335c9S672XewhtUGr -zbl+dp+++T42NKA7wfYxEUV0kz1XgMX5iZnK5atq1LXaQZAQwdbWQonCv/Q4EpVM -VAX3NuRFg3sUZdbcDE3R3n4MqzvEFb46VqZab3ZpUql6ucjrappdUtAtCms1FgkQ -hNBqyjoGADdH5H5XTz+L62e4iKrFvlNVspHEfbmwhRkGeC7bYRr6hfVKkaHnFtWO -ojnflLhwHyg/i/xAXmODPIMqGplrz95Zajv8bxbXH/1KEOtOghY6rCcMU/Gt1SSw -awNQwS08Ft1ENCcadfsCAwEAAaNCMEAwHQYDVR0OBBYEFAqFqXdlBZh8QIH4D5cs -OPEK7DzPMA4GA1UdDwEB/wQEAwIBBjAPBgNVHRMBAf8EBTADAQH/MA0GCSqGSIb3 -DQEBCwUAA4IBAQBMOqNErLlFsceTfsgLCkLfZOoc7llsCLqJX2rKSpWeeo8HxdpF -coJxDjrSzG+ntKEju/Ykn8sX/oymzsLS28yN/HH8AynBbF0zX2S2ZTuJbxh2ePXc -okgfGT+Ok+vx+hfuzU7jBBJV1uXk3fs+BXziHV7Gp7yXT2g69ekuCkO2r1dcYmh8 -t/2jioSgrGK+KwmHNPBqAbubKVY8/gA3zyNs8U6qtnRGEmyR7jTV7JqR50S+kDFy -1UkC9gLl9B/rfNmWVan/7Ir5mUf/NVoCqgTLiluHcSmRvaS0eg29mvVXIwAHIRc/ -SjnRBUkLp7Y3gaVdjKozXoEofKd9J+sAro03 ------END CERTIFICATE----- - -# Issuer: CN=Actalis Authentication Root CA O=Actalis S.p.A./03358520967 -# Subject: CN=Actalis Authentication Root CA O=Actalis S.p.A./03358520967 -# Label: "Actalis Authentication Root CA" -# Serial: 6271844772424770508 -# MD5 Fingerprint: 69:c1:0d:4f:07:a3:1b:c3:fe:56:3d:04:bc:11:f6:a6 -# SHA1 Fingerprint: f3:73:b3:87:06:5a:28:84:8a:f2:f3:4a:ce:19:2b:dd:c7:8e:9c:ac -# SHA256 Fingerprint: 55:92:60:84:ec:96:3a:64:b9:6e:2a:be:01:ce:0b:a8:6a:64:fb:fe:bc:c7:aa:b5:af:c1:55:b3:7f:d7:60:66 ------BEGIN CERTIFICATE----- -MIIFuzCCA6OgAwIBAgIIVwoRl0LE48wwDQYJKoZIhvcNAQELBQAwazELMAkGA1UE -BhMCSVQxDjAMBgNVBAcMBU1pbGFuMSMwIQYDVQQKDBpBY3RhbGlzIFMucC5BLi8w -MzM1ODUyMDk2NzEnMCUGA1UEAwweQWN0YWxpcyBBdXRoZW50aWNhdGlvbiBSb290 -IENBMB4XDTExMDkyMjExMjIwMloXDTMwMDkyMjExMjIwMlowazELMAkGA1UEBhMC -SVQxDjAMBgNVBAcMBU1pbGFuMSMwIQYDVQQKDBpBY3RhbGlzIFMucC5BLi8wMzM1 -ODUyMDk2NzEnMCUGA1UEAwweQWN0YWxpcyBBdXRoZW50aWNhdGlvbiBSb290IENB -MIICIjANBgkqhkiG9w0BAQEFAAOCAg8AMIICCgKCAgEAp8bEpSmkLO/lGMWwUKNv -UTufClrJwkg4CsIcoBh/kbWHuUA/3R1oHwiD1S0eiKD4j1aPbZkCkpAW1V8IbInX -4ay8IMKx4INRimlNAJZaby/ARH6jDuSRzVju3PvHHkVH3Se5CAGfpiEd9UEtL0z9 -KK3giq0itFZljoZUj5NDKd45RnijMCO6zfB9E1fAXdKDa0hMxKufgFpbOr3JpyI/ -gCczWw63igxdBzcIy2zSekciRDXFzMwujt0q7bd9Zg1fYVEiVRvjRuPjPdA1Yprb -rxTIW6HMiRvhMCb8oJsfgadHHwTrozmSBp+Z07/T6k9QnBn+locePGX2oxgkg4YQ -51Q+qDp2JE+BIcXjDwL4k5RHILv+1A7TaLndxHqEguNTVHnd25zS8gebLra8Pu2F -be8lEfKXGkJh90qX6IuxEAf6ZYGyojnP9zz/GPvG8VqLWeICrHuS0E4UT1lF9gxe -KF+w6D9Fz8+vm2/7hNN3WpVvrJSEnu68wEqPSpP4RCHiMUVhUE4Q2OM1fEwZtN4F -v6MGn8i1zeQf1xcGDXqVdFUNaBr8EBtiZJ1t4JWgw5QHVw0U5r0F+7if5t+L4sbn -fpb2U8WANFAoWPASUHEXMLrmeGO89LKtmyuy/uE5jF66CyCU3nuDuP/jVo23Eek7 -jPKxwV2dpAtMK9myGPW1n0sCAwEAAaNjMGEwHQYDVR0OBBYEFFLYiDrIn3hm7Ynz -ezhwlMkCAjbQMA8GA1UdEwEB/wQFMAMBAf8wHwYDVR0jBBgwFoAUUtiIOsifeGbt -ifN7OHCUyQICNtAwDgYDVR0PAQH/BAQDAgEGMA0GCSqGSIb3DQEBCwUAA4ICAQAL -e3KHwGCmSUyIWOYdiPcUZEim2FgKDk8TNd81HdTtBjHIgT5q1d07GjLukD0R0i70 -jsNjLiNmsGe+b7bAEzlgqqI0JZN1Ut6nna0Oh4lScWoWPBkdg/iaKWW+9D+a2fDz -WochcYBNy+A4mz+7+uAwTc+G02UQGRjRlwKxK3JCaKygvU5a2hi/a5iB0P2avl4V -SM0RFbnAKVy06Ij3Pjaut2L9HmLecHgQHEhb2rykOLpn7VU+Xlff1ANATIGk0k9j -pwlCCRT8AKnCgHNPLsBA2RF7SOp6AsDT6ygBJlh0wcBzIm2Tlf05fbsq4/aC4yyX -X04fkZT6/iyj2HYauE2yOE+b+h1IYHkm4vP9qdCa6HCPSXrW5b0KDtst842/6+Ok -fcvHlXHo2qN8xcL4dJIEG4aspCJTQLas/kx2z/uUMsA1n3Y/buWQbqCmJqK4LL7R -K4X9p2jIugErsWx0Hbhzlefut8cl8ABMALJ+tguLHPPAUJ4lueAI3jZm/zel0btU -ZCzJJ7VLkn5l/9Mt4blOvH+kQSGQQXemOR/qnuOf0GZvBeyqdn6/axag67XH/JJU -LysRJyU3eExRarDzzFhdFPFqSBX/wge2sY0PjlxQRrM9vwGYT7JZVEc+NHt4bVaT -LnPqZih4zR0Uv6CPLy64Lo7yFIrM6bV8+2ydDKXhlg== ------END CERTIFICATE----- - -# Issuer: CN=Buypass Class 2 Root CA O=Buypass AS-983163327 -# Subject: CN=Buypass Class 2 Root CA O=Buypass AS-983163327 -# Label: "Buypass Class 2 Root CA" -# Serial: 2 -# MD5 Fingerprint: 46:a7:d2:fe:45:fb:64:5a:a8:59:90:9b:78:44:9b:29 -# SHA1 Fingerprint: 49:0a:75:74:de:87:0a:47:fe:58:ee:f6:c7:6b:eb:c6:0b:12:40:99 -# SHA256 Fingerprint: 9a:11:40:25:19:7c:5b:b9:5d:94:e6:3d:55:cd:43:79:08:47:b6:46:b2:3c:df:11:ad:a4:a0:0e:ff:15:fb:48 ------BEGIN CERTIFICATE----- -MIIFWTCCA0GgAwIBAgIBAjANBgkqhkiG9w0BAQsFADBOMQswCQYDVQQGEwJOTzEd -MBsGA1UECgwUQnV5cGFzcyBBUy05ODMxNjMzMjcxIDAeBgNVBAMMF0J1eXBhc3Mg -Q2xhc3MgMiBSb290IENBMB4XDTEwMTAyNjA4MzgwM1oXDTQwMTAyNjA4MzgwM1ow -TjELMAkGA1UEBhMCTk8xHTAbBgNVBAoMFEJ1eXBhc3MgQVMtOTgzMTYzMzI3MSAw -HgYDVQQDDBdCdXlwYXNzIENsYXNzIDIgUm9vdCBDQTCCAiIwDQYJKoZIhvcNAQEB -BQADggIPADCCAgoCggIBANfHXvfBB9R3+0Mh9PT1aeTuMgHbo4Yf5FkNuud1g1Lr -6hxhFUi7HQfKjK6w3Jad6sNgkoaCKHOcVgb/S2TwDCo3SbXlzwx87vFKu3MwZfPV -L4O2fuPn9Z6rYPnT8Z2SdIrkHJasW4DptfQxh6NR/Md+oW+OU3fUl8FVM5I+GC91 -1K2GScuVr1QGbNgGE41b/+EmGVnAJLqBcXmQRFBoJJRfuLMR8SlBYaNByyM21cHx -MlAQTn/0hpPshNOOvEu/XAFOBz3cFIqUCqTqc/sLUegTBxj6DvEr0VQVfTzh97QZ -QmdiXnfgolXsttlpF9U6r0TtSsWe5HonfOV116rLJeffawrbD02TTqigzXsu8lkB -arcNuAeBfos4GzjmCleZPe4h6KP1DBbdi+w0jpwqHAAVF41og9JwnxgIzRFo1clr -Us3ERo/ctfPYV3Me6ZQ5BL/T3jjetFPsaRyifsSP5BtwrfKi+fv3FmRmaZ9JUaLi -FRhnBkp/1Wy1TbMz4GHrXb7pmA8y1x1LPC5aAVKRCfLf6o3YBkBjqhHk/sM3nhRS -P/TizPJhk9H9Z2vXUq6/aKtAQ6BXNVN48FP4YUIHZMbXb5tMOA1jrGKvNouicwoN -9SG9dKpN6nIDSdvHXx1iY8f93ZHsM+71bbRuMGjeyNYmsHVee7QHIJihdjK4TWxP -AgMBAAGjQjBAMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYEFMmAd+BikoL1Rpzz -uvdMw964o605MA4GA1UdDwEB/wQEAwIBBjANBgkqhkiG9w0BAQsFAAOCAgEAU18h -9bqwOlI5LJKwbADJ784g7wbylp7ppHR/ehb8t/W2+xUbP6umwHJdELFx7rxP462s -A20ucS6vxOOto70MEae0/0qyexAQH6dXQbLArvQsWdZHEIjzIVEpMMpghq9Gqx3t -OluwlN5E40EIosHsHdb9T7bWR9AUC8rmyrV7d35BH16Dx7aMOZawP5aBQW9gkOLo -+fsicdl9sz1Gv7SEr5AcD48Saq/v7h56rgJKihcrdv6sVIkkLE8/trKnToyokZf7 -KcZ7XC25y2a2t6hbElGFtQl+Ynhw/qlqYLYdDnkM/crqJIByw5c/8nerQyIKx+u2 -DISCLIBrQYoIwOula9+ZEsuK1V6ADJHgJgg2SMX6OBE1/yWDLfJ6v9r9jv6ly0Us -H8SIU653DtmadsWOLB2jutXsMq7Aqqz30XpN69QH4kj3Io6wpJ9qzo6ysmD0oyLQ -I+uUWnpp3Q+/QFesa1lQ2aOZ4W7+jQF5JyMV3pKdewlNWudLSDBaGOYKbeaP4NK7 -5t98biGCwWg5TbSYWGZizEqQXsP6JwSxeRV0mcy+rSDeJmAc61ZRpqPq5KM/p/9h -3PFaTWwyI0PurKju7koSCTxdccK+efrCh2gdC/1cacwG0Jp9VJkqyTkaGa9LKkPz -Y11aWOIv4x3kqdbQCtCev9eBCfHJxyYNrJgWVqA= ------END CERTIFICATE----- - -# Issuer: CN=Buypass Class 3 Root CA O=Buypass AS-983163327 -# Subject: CN=Buypass Class 3 Root CA O=Buypass AS-983163327 -# Label: "Buypass Class 3 Root CA" -# Serial: 2 -# MD5 Fingerprint: 3d:3b:18:9e:2c:64:5a:e8:d5:88:ce:0e:f9:37:c2:ec -# SHA1 Fingerprint: da:fa:f7:fa:66:84:ec:06:8f:14:50:bd:c7:c2:81:a5:bc:a9:64:57 -# SHA256 Fingerprint: ed:f7:eb:bc:a2:7a:2a:38:4d:38:7b:7d:40:10:c6:66:e2:ed:b4:84:3e:4c:29:b4:ae:1d:5b:93:32:e6:b2:4d ------BEGIN CERTIFICATE----- -MIIFWTCCA0GgAwIBAgIBAjANBgkqhkiG9w0BAQsFADBOMQswCQYDVQQGEwJOTzEd -MBsGA1UECgwUQnV5cGFzcyBBUy05ODMxNjMzMjcxIDAeBgNVBAMMF0J1eXBhc3Mg -Q2xhc3MgMyBSb290IENBMB4XDTEwMTAyNjA4Mjg1OFoXDTQwMTAyNjA4Mjg1OFow -TjELMAkGA1UEBhMCTk8xHTAbBgNVBAoMFEJ1eXBhc3MgQVMtOTgzMTYzMzI3MSAw -HgYDVQQDDBdCdXlwYXNzIENsYXNzIDMgUm9vdCBDQTCCAiIwDQYJKoZIhvcNAQEB -BQADggIPADCCAgoCggIBAKXaCpUWUOOV8l6ddjEGMnqb8RB2uACatVI2zSRHsJ8Y -ZLya9vrVediQYkwiL944PdbgqOkcLNt4EemOaFEVcsfzM4fkoF0LXOBXByow9c3E -N3coTRiR5r/VUv1xLXA+58bEiuPwKAv0dpihi4dVsjoT/Lc+JzeOIuOoTyrvYLs9 -tznDDgFHmV0ST9tD+leh7fmdvhFHJlsTmKtdFoqwNxxXnUX/iJY2v7vKB3tvh2PX -0DJq1l1sDPGzbjniazEuOQAnFN44wOwZZoYS6J1yFhNkUsepNxz9gjDthBgd9K5c -/3ATAOux9TN6S9ZV+AWNS2mw9bMoNlwUxFFzTWsL8TQH2xc519woe2v1n/MuwU8X -KhDzzMro6/1rqy6any2CbgTUUgGTLT2G/H783+9CHaZr77kgxve9oKeV/afmiSTY -zIw0bOIjL9kSGiG5VZFvC5F5GQytQIgLcOJ60g7YaEi7ghM5EFjp2CoHxhLbWNvS -O1UQRwUVZ2J+GGOmRj8JDlQyXr8NYnon74Do29lLBlo3WiXQCBJ31G8JUJc9yB3D -34xFMFbG02SrZvPAXpacw8Tvw3xrizp5f7NJzz3iiZ+gMEuFuZyUJHmPfWupRWgP -K9Dx2hzLabjKSWJtyNBjYt1gD1iqj6G8BaVmos8bdrKEZLFMOVLAMLrwjEsCsLa3 -AgMBAAGjQjBAMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYEFEe4zf/lb+74suwv -Tg75JbCOPGvDMA4GA1UdDwEB/wQEAwIBBjANBgkqhkiG9w0BAQsFAAOCAgEAACAj -QTUEkMJAYmDv4jVM1z+s4jSQuKFvdvoWFqRINyzpkMLyPPgKn9iB5btb2iUspKdV -cSQy9sgL8rxq+JOssgfCX5/bzMiKqr5qb+FJEMwx14C7u8jYog5kV+qi9cKpMRXS -IGrs/CIBKM+GuIAeqcwRpTzyFrNHnfzSgCHEy9BHcEGhyoMZCCxt8l13nIoUE9Q2 -HJLw5QY33KbmkJs4j1xrG0aGQ0JfPgEHU1RdZX33inOhmlRaHylDFCfChQ+1iHsa -O5S3HWCntZznKWlXWpuTekMwGwPXYshApqr8ZORK15FTAaggiG6cX0S5y2CBNOxv -033aSF/rtJC8LakcC6wc1aJoIIAE1vyxjy+7SjENSoYc6+I2KSb12tjE8nVhz36u -dmNKekBlk4f4HoCMhuWG1o8O/FMsYOgWYRqiPkN7zTlgVGr18okmAWiDSKIz6MkE -kbIRNBE+6tBDGR8Dk5AM/1E9V/RBbuHLoL7ryWPNbczk+DaqaJ3tvV2XcEQNtg41 -3OEMXbugUZTLfhbrES+jkkXITHHZvMmZUldGL1DPvTVp9D0VzgalLA8+9oG6lLvD -u79leNKGef9JOxqDDPDeeOzI8k1MGt6CKfjBWtrt7uYnXuhF0J0cUahoq0Tj0Itq -4/g7u9xN12TyUb7mqqta6THuBrxzvxNiCp/HuZc= ------END CERTIFICATE----- - -# Issuer: CN=T-TeleSec GlobalRoot Class 3 O=T-Systems Enterprise Services GmbH OU=T-Systems Trust Center -# Subject: CN=T-TeleSec GlobalRoot Class 3 O=T-Systems Enterprise Services GmbH OU=T-Systems Trust Center -# Label: "T-TeleSec GlobalRoot Class 3" -# Serial: 1 -# MD5 Fingerprint: ca:fb:40:a8:4e:39:92:8a:1d:fe:8e:2f:c4:27:ea:ef -# SHA1 Fingerprint: 55:a6:72:3e:cb:f2:ec:cd:c3:23:74:70:19:9d:2a:be:11:e3:81:d1 -# SHA256 Fingerprint: fd:73:da:d3:1c:64:4f:f1:b4:3b:ef:0c:cd:da:96:71:0b:9c:d9:87:5e:ca:7e:31:70:7a:f3:e9:6d:52:2b:bd ------BEGIN CERTIFICATE----- -MIIDwzCCAqugAwIBAgIBATANBgkqhkiG9w0BAQsFADCBgjELMAkGA1UEBhMCREUx -KzApBgNVBAoMIlQtU3lzdGVtcyBFbnRlcnByaXNlIFNlcnZpY2VzIEdtYkgxHzAd -BgNVBAsMFlQtU3lzdGVtcyBUcnVzdCBDZW50ZXIxJTAjBgNVBAMMHFQtVGVsZVNl -YyBHbG9iYWxSb290IENsYXNzIDMwHhcNMDgxMDAxMTAyOTU2WhcNMzMxMDAxMjM1 -OTU5WjCBgjELMAkGA1UEBhMCREUxKzApBgNVBAoMIlQtU3lzdGVtcyBFbnRlcnBy -aXNlIFNlcnZpY2VzIEdtYkgxHzAdBgNVBAsMFlQtU3lzdGVtcyBUcnVzdCBDZW50 -ZXIxJTAjBgNVBAMMHFQtVGVsZVNlYyBHbG9iYWxSb290IENsYXNzIDMwggEiMA0G -CSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQC9dZPwYiJvJK7genasfb3ZJNW4t/zN -8ELg63iIVl6bmlQdTQyK9tPPcPRStdiTBONGhnFBSivwKixVA9ZIw+A5OO3yXDw/ -RLyTPWGrTs0NvvAgJ1gORH8EGoel15YUNpDQSXuhdfsaa3Ox+M6pCSzyU9XDFES4 -hqX2iys52qMzVNn6chr3IhUciJFrf2blw2qAsCTz34ZFiP0Zf3WHHx+xGwpzJFu5 -ZeAsVMhg02YXP+HMVDNzkQI6pn97djmiH5a2OK61yJN0HZ65tOVgnS9W0eDrXltM -EnAMbEQgqxHY9Bn20pxSN+f6tsIxO0rUFJmtxxr1XV/6B7h8DR/Wgx6zAgMBAAGj -QjBAMA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgEGMB0GA1UdDgQWBBS1 -A/d2O2GCahKqGFPrAyGUv/7OyjANBgkqhkiG9w0BAQsFAAOCAQEAVj3vlNW92nOy -WL6ukK2YJ5f+AbGwUgC4TeQbIXQbfsDuXmkqJa9c1h3a0nnJ85cp4IaH3gRZD/FZ -1GSFS5mvJQQeyUapl96Cshtwn5z2r3Ex3XsFpSzTucpH9sry9uetuUg/vBa3wW30 -6gmv7PO15wWeph6KU1HWk4HMdJP2udqmJQV0eVp+QD6CSyYRMG7hP0HHRwA11fXT -91Q+gT3aSWqas+8QPebrb9HIIkfLzM8BMZLZGOMivgkeGj5asuRrDFR6fUNOuIml -e9eiPZaGzPImNC1qkp2aGtAw4l1OBLBfiyB+d8E9lYLRRpo7PHi4b6HQDWSieB4p -TpPDpFQUWw== ------END CERTIFICATE----- - -# Issuer: CN=D-TRUST Root Class 3 CA 2 2009 O=D-Trust GmbH -# Subject: CN=D-TRUST Root Class 3 CA 2 2009 O=D-Trust GmbH -# Label: "D-TRUST Root Class 3 CA 2 2009" -# Serial: 623603 -# MD5 Fingerprint: cd:e0:25:69:8d:47:ac:9c:89:35:90:f7:fd:51:3d:2f -# SHA1 Fingerprint: 58:e8:ab:b0:36:15:33:fb:80:f7:9b:1b:6d:29:d3:ff:8d:5f:00:f0 -# SHA256 Fingerprint: 49:e7:a4:42:ac:f0:ea:62:87:05:00:54:b5:25:64:b6:50:e4:f4:9e:42:e3:48:d6:aa:38:e0:39:e9:57:b1:c1 ------BEGIN CERTIFICATE----- -MIIEMzCCAxugAwIBAgIDCYPzMA0GCSqGSIb3DQEBCwUAME0xCzAJBgNVBAYTAkRF -MRUwEwYDVQQKDAxELVRydXN0IEdtYkgxJzAlBgNVBAMMHkQtVFJVU1QgUm9vdCBD -bGFzcyAzIENBIDIgMjAwOTAeFw0wOTExMDUwODM1NThaFw0yOTExMDUwODM1NTha -ME0xCzAJBgNVBAYTAkRFMRUwEwYDVQQKDAxELVRydXN0IEdtYkgxJzAlBgNVBAMM -HkQtVFJVU1QgUm9vdCBDbGFzcyAzIENBIDIgMjAwOTCCASIwDQYJKoZIhvcNAQEB -BQADggEPADCCAQoCggEBANOySs96R+91myP6Oi/WUEWJNTrGa9v+2wBoqOADER03 -UAifTUpolDWzU9GUY6cgVq/eUXjsKj3zSEhQPgrfRlWLJ23DEE0NkVJD2IfgXU42 -tSHKXzlABF9bfsyjxiupQB7ZNoTWSPOSHjRGICTBpFGOShrvUD9pXRl/RcPHAY9R -ySPocq60vFYJfxLLHLGvKZAKyVXMD9O0Gu1HNVpK7ZxzBCHQqr0ME7UAyiZsxGsM -lFqVlNpQmvH/pStmMaTJOKDfHR+4CS7zp+hnUquVH+BGPtikw8paxTGA6Eian5Rp -/hnd2HN8gcqW3o7tszIFZYQ05ub9VxC1X3a/L7AQDcUCAwEAAaOCARowggEWMA8G -A1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYEFP3aFMSfMN4hvR5COfyrYyNJ4PGEMA4G -A1UdDwEB/wQEAwIBBjCB0wYDVR0fBIHLMIHIMIGAoH6gfIZ6bGRhcDovL2RpcmVj -dG9yeS5kLXRydXN0Lm5ldC9DTj1ELVRSVVNUJTIwUm9vdCUyMENsYXNzJTIwMyUy -MENBJTIwMiUyMDIwMDksTz1ELVRydXN0JTIwR21iSCxDPURFP2NlcnRpZmljYXRl -cmV2b2NhdGlvbmxpc3QwQ6BBoD+GPWh0dHA6Ly93d3cuZC10cnVzdC5uZXQvY3Js -L2QtdHJ1c3Rfcm9vdF9jbGFzc18zX2NhXzJfMjAwOS5jcmwwDQYJKoZIhvcNAQEL -BQADggEBAH+X2zDI36ScfSF6gHDOFBJpiBSVYEQBrLLpME+bUMJm2H6NMLVwMeni -acfzcNsgFYbQDfC+rAF1hM5+n02/t2A7nPPKHeJeaNijnZflQGDSNiH+0LS4F9p0 -o3/U37CYAqxva2ssJSRyoWXuJVrl5jLn8t+rSfrzkGkj2wTZ51xY/GXUl77M/C4K -zCUqNQT4YJEVdT1B/yMfGchs64JTBKbkTCJNjYy6zltz7GRUUG3RnFX7acM2w4y8 -PIWmawomDeCTmGCufsYkl4phX5GOZpIJhzbNi5stPvZR1FDUWSi9g/LMKHtThm3Y -Johw1+qRzT65ysCQblrGXnRl11z+o+I= ------END CERTIFICATE----- - -# Issuer: CN=D-TRUST Root Class 3 CA 2 EV 2009 O=D-Trust GmbH -# Subject: CN=D-TRUST Root Class 3 CA 2 EV 2009 O=D-Trust GmbH -# Label: "D-TRUST Root Class 3 CA 2 EV 2009" -# Serial: 623604 -# MD5 Fingerprint: aa:c6:43:2c:5e:2d:cd:c4:34:c0:50:4f:11:02:4f:b6 -# SHA1 Fingerprint: 96:c9:1b:0b:95:b4:10:98:42:fa:d0:d8:22:79:fe:60:fa:b9:16:83 -# SHA256 Fingerprint: ee:c5:49:6b:98:8c:e9:86:25:b9:34:09:2e:ec:29:08:be:d0:b0:f3:16:c2:d4:73:0c:84:ea:f1:f3:d3:48:81 ------BEGIN CERTIFICATE----- -MIIEQzCCAyugAwIBAgIDCYP0MA0GCSqGSIb3DQEBCwUAMFAxCzAJBgNVBAYTAkRF -MRUwEwYDVQQKDAxELVRydXN0IEdtYkgxKjAoBgNVBAMMIUQtVFJVU1QgUm9vdCBD -bGFzcyAzIENBIDIgRVYgMjAwOTAeFw0wOTExMDUwODUwNDZaFw0yOTExMDUwODUw -NDZaMFAxCzAJBgNVBAYTAkRFMRUwEwYDVQQKDAxELVRydXN0IEdtYkgxKjAoBgNV -BAMMIUQtVFJVU1QgUm9vdCBDbGFzcyAzIENBIDIgRVYgMjAwOTCCASIwDQYJKoZI -hvcNAQEBBQADggEPADCCAQoCggEBAJnxhDRwui+3MKCOvXwEz75ivJn9gpfSegpn -ljgJ9hBOlSJzmY3aFS3nBfwZcyK3jpgAvDw9rKFs+9Z5JUut8Mxk2og+KbgPCdM0 -3TP1YtHhzRnp7hhPTFiu4h7WDFsVWtg6uMQYZB7jM7K1iXdODL/ZlGsTl28So/6Z -qQTMFexgaDbtCHu39b+T7WYxg4zGcTSHThfqr4uRjRxWQa4iN1438h3Z0S0NL2lR -p75mpoo6Kr3HGrHhFPC+Oh25z1uxav60sUYgovseO3Dvk5h9jHOW8sXvhXCtKSb8 -HgQ+HKDYD8tSg2J87otTlZCpV6LqYQXY+U3EJ/pure3511H3a6UCAwEAAaOCASQw -ggEgMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYEFNOUikxiEyoZLsyvcop9Ntea -HNxnMA4GA1UdDwEB/wQEAwIBBjCB3QYDVR0fBIHVMIHSMIGHoIGEoIGBhn9sZGFw -Oi8vZGlyZWN0b3J5LmQtdHJ1c3QubmV0L0NOPUQtVFJVU1QlMjBSb290JTIwQ2xh -c3MlMjAzJTIwQ0ElMjAyJTIwRVYlMjAyMDA5LE89RC1UcnVzdCUyMEdtYkgsQz1E -RT9jZXJ0aWZpY2F0ZXJldm9jYXRpb25saXN0MEagRKBChkBodHRwOi8vd3d3LmQt -dHJ1c3QubmV0L2NybC9kLXRydXN0X3Jvb3RfY2xhc3NfM19jYV8yX2V2XzIwMDku -Y3JsMA0GCSqGSIb3DQEBCwUAA4IBAQA07XtaPKSUiO8aEXUHL7P+PPoeUSbrh/Yp -3uDx1MYkCenBz1UbtDDZzhr+BlGmFaQt77JLvyAoJUnRpjZ3NOhk31KxEcdzes05 -nsKtjHEh8lprr988TlWvsoRlFIm5d8sqMb7Po23Pb0iUMkZv53GMoKaEGTcH8gNF -CSuGdXzfX2lXANtu2KZyIktQ1HWYVt+3GP9DQ1CuekR78HlR10M9p9OB0/DJT7na -xpeG0ILD5EJt/rDiZE4OJudANCa1CInXCGNjOCd1HjPqbqjdn5lPdE2BiYBL3ZqX -KVwvvoFBuYz/6n1gBp7N1z3TLqMVvKjmJuVvw9y4AyHqnxbxLFS1 ------END CERTIFICATE----- - -# Issuer: CN=CA Disig Root R2 O=Disig a.s. -# Subject: CN=CA Disig Root R2 O=Disig a.s. -# Label: "CA Disig Root R2" -# Serial: 10572350602393338211 -# MD5 Fingerprint: 26:01:fb:d8:27:a7:17:9a:45:54:38:1a:43:01:3b:03 -# SHA1 Fingerprint: b5:61:eb:ea:a4:de:e4:25:4b:69:1a:98:a5:57:47:c2:34:c7:d9:71 -# SHA256 Fingerprint: e2:3d:4a:03:6d:7b:70:e9:f5:95:b1:42:20:79:d2:b9:1e:df:bb:1f:b6:51:a0:63:3e:aa:8a:9d:c5:f8:07:03 ------BEGIN CERTIFICATE----- -MIIFaTCCA1GgAwIBAgIJAJK4iNuwisFjMA0GCSqGSIb3DQEBCwUAMFIxCzAJBgNV -BAYTAlNLMRMwEQYDVQQHEwpCcmF0aXNsYXZhMRMwEQYDVQQKEwpEaXNpZyBhLnMu -MRkwFwYDVQQDExBDQSBEaXNpZyBSb290IFIyMB4XDTEyMDcxOTA5MTUzMFoXDTQy -MDcxOTA5MTUzMFowUjELMAkGA1UEBhMCU0sxEzARBgNVBAcTCkJyYXRpc2xhdmEx -EzARBgNVBAoTCkRpc2lnIGEucy4xGTAXBgNVBAMTEENBIERpc2lnIFJvb3QgUjIw -ggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQCio8QACdaFXS1tFPbCw3Oe -NcJxVX6B+6tGUODBfEl45qt5WDza/3wcn9iXAng+a0EE6UG9vgMsRfYvZNSrXaNH -PWSb6WiaxswbP7q+sos0Ai6YVRn8jG+qX9pMzk0DIaPY0jSTVpbLTAwAFjxfGs3I -x2ymrdMxp7zo5eFm1tL7A7RBZckQrg4FY8aAamkw/dLukO8NJ9+flXP04SXabBbe -QTg06ov80egEFGEtQX6sx3dOy1FU+16SGBsEWmjGycT6txOgmLcRK7fWV8x8nhfR -yyX+hk4kLlYMeE2eARKmK6cBZW58Yh2EhN/qwGu1pSqVg8NTEQxzHQuyRpDRQjrO -QG6Vrf/GlK1ul4SOfW+eioANSW1z4nuSHsPzwfPrLgVv2RvPN3YEyLRa5Beny912 -H9AZdugsBbPWnDTYltxhh5EF5EQIM8HauQhl1K6yNg3ruji6DOWbnuuNZt2Zz9aJ -QfYEkoopKW1rOhzndX0CcQ7zwOe9yxndnWCywmZgtrEE7snmhrmaZkCo5xHtgUUD -i/ZnWejBBhG93c+AAk9lQHhcR1DIm+YfgXvkRKhbhZri3lrVx/k6RGZL5DJUfORs -nLMOPReisjQS1n6yqEm70XooQL6iFh/f5DcfEXP7kAplQ6INfPgGAVUzfbANuPT1 -rqVCV3w2EYx7XsQDnYx5nQIDAQABo0IwQDAPBgNVHRMBAf8EBTADAQH/MA4GA1Ud -DwEB/wQEAwIBBjAdBgNVHQ4EFgQUtZn4r7CU9eMg1gqtzk5WpC5uQu0wDQYJKoZI -hvcNAQELBQADggIBACYGXnDnZTPIgm7ZnBc6G3pmsgH2eDtpXi/q/075KMOYKmFM -tCQSin1tERT3nLXK5ryeJ45MGcipvXrA1zYObYVybqjGom32+nNjf7xueQgcnYqf -GopTpti72TVVsRHFqQOzVju5hJMiXn7B9hJSi+osZ7z+Nkz1uM/Rs0mSO9MpDpkb -lvdhuDvEK7Z4bLQjb/D907JedR+Zlais9trhxTF7+9FGs9K8Z7RiVLoJ92Owk6Ka -+elSLotgEqv89WBW7xBci8QaQtyDW2QOy7W81k/BfDxujRNt+3vrMNDcTa/F1bal -TFtxyegxvug4BkihGuLq0t4SOVga/4AOgnXmt8kHbA7v/zjxmHHEt38OFdAlab0i -nSvtBfZGR6ztwPDUO+Ls7pZbkBNOHlY667DvlruWIxG68kOGdGSVyCh13x01utI3 -gzhTODY7z2zp+WsO0PsE6E9312UBeIYMej4hYvF/Y3EMyZ9E26gnonW+boE+18Dr -G5gPcFw0sorMwIUY6256s/daoQe/qUKS82Ail+QUoQebTnbAjn39pCXHR+3/H3Os -zMOl6W8KjptlwlCFtaOgUxLMVYdh84GuEEZhvUQhuMI9dM9+JDX6HAcOmz0iyu8x -L4ysEr3vQCj8KWefshNPZiTEUxnpHikV7+ZtsH8tZ/3zbBt1RqPlShfppNcL ------END CERTIFICATE----- - -# Issuer: CN=ACCVRAIZ1 O=ACCV OU=PKIACCV -# Subject: CN=ACCVRAIZ1 O=ACCV OU=PKIACCV -# Label: "ACCVRAIZ1" -# Serial: 6828503384748696800 -# MD5 Fingerprint: d0:a0:5a:ee:05:b6:09:94:21:a1:7d:f1:b2:29:82:02 -# SHA1 Fingerprint: 93:05:7a:88:15:c6:4f:ce:88:2f:fa:91:16:52:28:78:bc:53:64:17 -# SHA256 Fingerprint: 9a:6e:c0:12:e1:a7:da:9d:be:34:19:4d:47:8a:d7:c0:db:18:22:fb:07:1d:f1:29:81:49:6e:d1:04:38:41:13 ------BEGIN CERTIFICATE----- -MIIH0zCCBbugAwIBAgIIXsO3pkN/pOAwDQYJKoZIhvcNAQEFBQAwQjESMBAGA1UE -AwwJQUNDVlJBSVoxMRAwDgYDVQQLDAdQS0lBQ0NWMQ0wCwYDVQQKDARBQ0NWMQsw -CQYDVQQGEwJFUzAeFw0xMTA1MDUwOTM3MzdaFw0zMDEyMzEwOTM3MzdaMEIxEjAQ -BgNVBAMMCUFDQ1ZSQUlaMTEQMA4GA1UECwwHUEtJQUNDVjENMAsGA1UECgwEQUND -VjELMAkGA1UEBhMCRVMwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQCb -qau/YUqXry+XZpp0X9DZlv3P4uRm7x8fRzPCRKPfmt4ftVTdFXxpNRFvu8gMjmoY -HtiP2Ra8EEg2XPBjs5BaXCQ316PWywlxufEBcoSwfdtNgM3802/J+Nq2DoLSRYWo -G2ioPej0RGy9ocLLA76MPhMAhN9KSMDjIgro6TenGEyxCQ0jVn8ETdkXhBilyNpA -lHPrzg5XPAOBOp0KoVdDaaxXbXmQeOW1tDvYvEyNKKGno6e6Ak4l0Squ7a4DIrhr -IA8wKFSVf+DuzgpmndFALW4ir50awQUZ0m/A8p/4e7MCQvtQqR0tkw8jq8bBD5L/ -0KIV9VMJcRz/RROE5iZe+OCIHAr8Fraocwa48GOEAqDGWuzndN9wrqODJerWx5eH -k6fGioozl2A3ED6XPm4pFdahD9GILBKfb6qkxkLrQaLjlUPTAYVtjrs78yM2x/47 -4KElB0iryYl0/wiPgL/AlmXz7uxLaL2diMMxs0Dx6M/2OLuc5NF/1OVYm3z61PMO -m3WR5LpSLhl+0fXNWhn8ugb2+1KoS5kE3fj5tItQo05iifCHJPqDQsGH+tUtKSpa -cXpkatcnYGMN285J9Y0fkIkyF/hzQ7jSWpOGYdbhdQrqeWZ2iE9x6wQl1gpaepPl -uUsXQA+xtrn13k/c4LOsOxFwYIRKQ26ZIMApcQrAZQIDAQABo4ICyzCCAscwfQYI -KwYBBQUHAQEEcTBvMEwGCCsGAQUFBzAChkBodHRwOi8vd3d3LmFjY3YuZXMvZmls -ZWFkbWluL0FyY2hpdm9zL2NlcnRpZmljYWRvcy9yYWl6YWNjdjEuY3J0MB8GCCsG -AQUFBzABhhNodHRwOi8vb2NzcC5hY2N2LmVzMB0GA1UdDgQWBBTSh7Tj3zcnk1X2 -VuqB5TbMjB4/vTAPBgNVHRMBAf8EBTADAQH/MB8GA1UdIwQYMBaAFNKHtOPfNyeT -VfZW6oHlNsyMHj+9MIIBcwYDVR0gBIIBajCCAWYwggFiBgRVHSAAMIIBWDCCASIG -CCsGAQUFBwICMIIBFB6CARAAQQB1AHQAbwByAGkAZABhAGQAIABkAGUAIABDAGUA -cgB0AGkAZgBpAGMAYQBjAGkA8wBuACAAUgBhAO0AegAgAGQAZQAgAGwAYQAgAEEA -QwBDAFYAIAAoAEEAZwBlAG4AYwBpAGEAIABkAGUAIABUAGUAYwBuAG8AbABvAGcA -7QBhACAAeQAgAEMAZQByAHQAaQBmAGkAYwBhAGMAaQDzAG4AIABFAGwAZQBjAHQA -cgDzAG4AaQBjAGEALAAgAEMASQBGACAAUQA0ADYAMAAxADEANQA2AEUAKQAuACAA -QwBQAFMAIABlAG4AIABoAHQAdABwADoALwAvAHcAdwB3AC4AYQBjAGMAdgAuAGUA -czAwBggrBgEFBQcCARYkaHR0cDovL3d3dy5hY2N2LmVzL2xlZ2lzbGFjaW9uX2Mu -aHRtMFUGA1UdHwROMEwwSqBIoEaGRGh0dHA6Ly93d3cuYWNjdi5lcy9maWxlYWRt -aW4vQXJjaGl2b3MvY2VydGlmaWNhZG9zL3JhaXphY2N2MV9kZXIuY3JsMA4GA1Ud -DwEB/wQEAwIBBjAXBgNVHREEEDAOgQxhY2N2QGFjY3YuZXMwDQYJKoZIhvcNAQEF -BQADggIBAJcxAp/n/UNnSEQU5CmH7UwoZtCPNdpNYbdKl02125DgBS4OxnnQ8pdp -D70ER9m+27Up2pvZrqmZ1dM8MJP1jaGo/AaNRPTKFpV8M9xii6g3+CfYCS0b78gU -JyCpZET/LtZ1qmxNYEAZSUNUY9rizLpm5U9EelvZaoErQNV/+QEnWCzI7UiRfD+m -AM/EKXMRNt6GGT6d7hmKG9Ww7Y49nCrADdg9ZuM8Db3VlFzi4qc1GwQA9j9ajepD -vV+JHanBsMyZ4k0ACtrJJ1vnE5Bc5PUzolVt3OAJTS+xJlsndQAJxGJ3KQhfnlms -tn6tn1QwIgPBHnFk/vk4CpYY3QIUrCPLBhwepH2NDd4nQeit2hW3sCPdK6jT2iWH -7ehVRE2I9DZ+hJp4rPcOVkkO1jMl1oRQQmwgEh0q1b688nCBpHBgvgW1m54ERL5h -I6zppSSMEYCUWqKiuUnSwdzRp+0xESyeGabu4VXhwOrPDYTkF7eifKXeVSUG7szA -h1xA2syVP1XgNce4hL60Xc16gwFy7ofmXx2utYXGJt/mwZrpHgJHnyqobalbz+xF -d3+YJ5oyXSrjhO7FmGYvliAd3djDJ9ew+f7Zfc3Qn48LFFhRny+Lwzgt3uiP1o2H -pPVWQxaZLPSkVrQ0uGE3ycJYgBugl6H8WY3pEfbRD0tVNEYqi4Y7 ------END CERTIFICATE----- - -# Issuer: CN=TWCA Global Root CA O=TAIWAN-CA OU=Root CA -# Subject: CN=TWCA Global Root CA O=TAIWAN-CA OU=Root CA -# Label: "TWCA Global Root CA" -# Serial: 3262 -# MD5 Fingerprint: f9:03:7e:cf:e6:9e:3c:73:7a:2a:90:07:69:ff:2b:96 -# SHA1 Fingerprint: 9c:bb:48:53:f6:a4:f6:d3:52:a4:e8:32:52:55:60:13:f5:ad:af:65 -# SHA256 Fingerprint: 59:76:90:07:f7:68:5d:0f:cd:50:87:2f:9f:95:d5:75:5a:5b:2b:45:7d:81:f3:69:2b:61:0a:98:67:2f:0e:1b ------BEGIN CERTIFICATE----- -MIIFQTCCAymgAwIBAgICDL4wDQYJKoZIhvcNAQELBQAwUTELMAkGA1UEBhMCVFcx -EjAQBgNVBAoTCVRBSVdBTi1DQTEQMA4GA1UECxMHUm9vdCBDQTEcMBoGA1UEAxMT -VFdDQSBHbG9iYWwgUm9vdCBDQTAeFw0xMjA2MjcwNjI4MzNaFw0zMDEyMzExNTU5 -NTlaMFExCzAJBgNVBAYTAlRXMRIwEAYDVQQKEwlUQUlXQU4tQ0ExEDAOBgNVBAsT -B1Jvb3QgQ0ExHDAaBgNVBAMTE1RXQ0EgR2xvYmFsIFJvb3QgQ0EwggIiMA0GCSqG -SIb3DQEBAQUAA4ICDwAwggIKAoICAQCwBdvI64zEbooh745NnHEKH1Jw7W2CnJfF -10xORUnLQEK1EjRsGcJ0pDFfhQKX7EMzClPSnIyOt7h52yvVavKOZsTuKwEHktSz -0ALfUPZVr2YOy+BHYC8rMjk1Ujoog/h7FsYYuGLWRyWRzvAZEk2tY/XTP3VfKfCh -MBwqoJimFb3u/Rk28OKRQ4/6ytYQJ0lM793B8YVwm8rqqFpD/G2Gb3PpN0Wp8DbH -zIh1HrtsBv+baz4X7GGqcXzGHaL3SekVtTzWoWH1EfcFbx39Eb7QMAfCKbAJTibc -46KokWofwpFFiFzlmLhxpRUZyXx1EcxwdE8tmx2RRP1WKKD+u4ZqyPpcC1jcxkt2 -yKsi2XMPpfRaAok/T54igu6idFMqPVMnaR1sjjIsZAAmY2E2TqNGtz99sy2sbZCi -laLOz9qC5wc0GZbpuCGqKX6mOL6OKUohZnkfs8O1CWfe1tQHRvMq2uYiN2DLgbYP -oA/pyJV/v1WRBXrPPRXAb94JlAGD1zQbzECl8LibZ9WYkTunhHiVJqRaCPgrdLQA -BDzfuBSO6N+pjWxnkjMdwLfS7JLIvgm/LCkFbwJrnu+8vyq8W8BQj0FwcYeyTbcE -qYSjMq+u7msXi7Kx/mzhkIyIqJdIzshNy/MGz19qCkKxHh53L46g5pIOBvwFItIm -4TFRfTLcDwIDAQABoyMwITAOBgNVHQ8BAf8EBAMCAQYwDwYDVR0TAQH/BAUwAwEB -/zANBgkqhkiG9w0BAQsFAAOCAgEAXzSBdu+WHdXltdkCY4QWwa6gcFGn90xHNcgL -1yg9iXHZqjNB6hQbbCEAwGxCGX6faVsgQt+i0trEfJdLjbDorMjupWkEmQqSpqsn -LhpNgb+E1HAerUf+/UqdM+DyucRFCCEK2mlpc3INvjT+lIutwx4116KD7+U4x6WF -H6vPNOw/KP4M8VeGTslV9xzU2KV9Bnpv1d8Q34FOIWWxtuEXeZVFBs5fzNxGiWNo -RI2T9GRwoD2dKAXDOXC4Ynsg/eTb6QihuJ49CcdP+yz4k3ZB3lLg4VfSnQO8d57+ -nile98FRYB/e2guyLXW3Q0iT5/Z5xoRdgFlglPx4mI88k1HtQJAH32RjJMtOcQWh -15QaiDLxInQirqWm2BJpTGCjAu4r7NRjkgtevi92a6O2JryPA9gK8kxkRr05YuWW -6zRjESjMlfGt7+/cgFhI6Uu46mWs6fyAtbXIRfmswZ/ZuepiiI7E8UuDEq3mi4TW -nsLrgxifarsbJGAzcMzs9zLzXNl5fe+epP7JI8Mk7hWSsT2RTyaGvWZzJBPqpK5j -wa19hAM8EHiGG3njxPPyBJUgriOCxLM6AGK/5jYk4Ve6xx6QddVfP5VhK8E7zeWz -aGHQRiapIVJpLesux+t3zqY6tQMzT3bR51xUAV3LePTJDL/PEo4XLSNolOer/qmy -KwbQBM0= ------END CERTIFICATE----- - -# Issuer: CN=TeliaSonera Root CA v1 O=TeliaSonera -# Subject: CN=TeliaSonera Root CA v1 O=TeliaSonera -# Label: "TeliaSonera Root CA v1" -# Serial: 199041966741090107964904287217786801558 -# MD5 Fingerprint: 37:41:49:1b:18:56:9a:26:f5:ad:c2:66:fb:40:a5:4c -# SHA1 Fingerprint: 43:13:bb:96:f1:d5:86:9b:c1:4e:6a:92:f6:cf:f6:34:69:87:82:37 -# SHA256 Fingerprint: dd:69:36:fe:21:f8:f0:77:c1:23:a1:a5:21:c1:22:24:f7:22:55:b7:3e:03:a7:26:06:93:e8:a2:4b:0f:a3:89 ------BEGIN CERTIFICATE----- -MIIFODCCAyCgAwIBAgIRAJW+FqD3LkbxezmCcvqLzZYwDQYJKoZIhvcNAQEFBQAw -NzEUMBIGA1UECgwLVGVsaWFTb25lcmExHzAdBgNVBAMMFlRlbGlhU29uZXJhIFJv -b3QgQ0EgdjEwHhcNMDcxMDE4MTIwMDUwWhcNMzIxMDE4MTIwMDUwWjA3MRQwEgYD -VQQKDAtUZWxpYVNvbmVyYTEfMB0GA1UEAwwWVGVsaWFTb25lcmEgUm9vdCBDQSB2 -MTCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAMK+6yfwIaPzaSZVfp3F -VRaRXP3vIb9TgHot0pGMYzHw7CTww6XScnwQbfQ3t+XmfHnqjLWCi65ItqwA3GV1 -7CpNX8GH9SBlK4GoRz6JI5UwFpB/6FcHSOcZrr9FZ7E3GwYq/t75rH2D+1665I+X -Z75Ljo1kB1c4VWk0Nj0TSO9P4tNmHqTPGrdeNjPUtAa9GAH9d4RQAEX1jF3oI7x+ -/jXh7VB7qTCNGdMJjmhnXb88lxhTuylixcpecsHHltTbLaC0H2kD7OriUPEMPPCs -81Mt8Bz17Ww5OXOAFshSsCPN4D7c3TxHoLs1iuKYaIu+5b9y7tL6pe0S7fyYGKkm -dtwoSxAgHNN/Fnct7W+A90m7UwW7XWjH1Mh1Fj+JWov3F0fUTPHSiXk+TT2YqGHe -Oh7S+F4D4MHJHIzTjU3TlTazN19jY5szFPAtJmtTfImMMsJu7D0hADnJoWjiUIMu -sDor8zagrC/kb2HCUQk5PotTubtn2txTuXZZNp1D5SDgPTJghSJRt8czu90VL6R4 -pgd7gUY2BIbdeTXHlSw7sKMXNeVzH7RcWe/a6hBle3rQf5+ztCo3O3CLm1u5K7fs -slESl1MpWtTwEhDcTwK7EpIvYtQ/aUN8Ddb8WHUBiJ1YFkveupD/RwGJBmr2X7KQ -arMCpgKIv7NHfirZ1fpoeDVNAgMBAAGjPzA9MA8GA1UdEwEB/wQFMAMBAf8wCwYD -VR0PBAQDAgEGMB0GA1UdDgQWBBTwj1k4ALP1j5qWDNXr+nuqF+gTEjANBgkqhkiG -9w0BAQUFAAOCAgEAvuRcYk4k9AwI//DTDGjkk0kiP0Qnb7tt3oNmzqjMDfz1mgbl -dxSR651Be5kqhOX//CHBXfDkH1e3damhXwIm/9fH907eT/j3HEbAek9ALCI18Bmx -0GtnLLCo4MBANzX2hFxc469CeP6nyQ1Q6g2EdvZR74NTxnr/DlZJLo961gzmJ1Tj -TQpgcmLNkQfWpb/ImWvtxBnmq0wROMVvMeJuScg/doAmAyYp4Db29iBT4xdwNBed -Y2gea+zDTYa4EzAvXUYNR0PVG6pZDrlcjQZIrXSHX8f8MVRBE+LHIQ6e4B4N4cB7 -Q4WQxYpYxmUKeFfyxiMPAdkgS94P+5KFdSpcc41teyWRyu5FrgZLAMzTsVlQ2jqI -OylDRl6XK1TOU2+NSueW+r9xDkKLfP0ooNBIytrEgUy7onOTJsjrDNYmiLbAJM+7 -vVvrdX3pCI6GMyx5dwlppYn8s3CQh3aP0yK7Qs69cwsgJirQmz1wHiRszYd2qReW -t88NkvuOGKmYSdGe/mBEciG5Ge3C9THxOUiIkCR1VBatzvT4aRRkOfujuLpwQMcn -HL/EVlP6Y2XQ8xwOFvVrhlhNGNTkDY6lnVuR3HYkUD/GKvvZt5y11ubQ2egZixVx -SK236thZiNSQvxaz2emsWWFUyBy6ysHK4bkgTI86k4mloMy/0/Z1pHWWbVY= ------END CERTIFICATE----- - -# Issuer: CN=T-TeleSec GlobalRoot Class 2 O=T-Systems Enterprise Services GmbH OU=T-Systems Trust Center -# Subject: CN=T-TeleSec GlobalRoot Class 2 O=T-Systems Enterprise Services GmbH OU=T-Systems Trust Center -# Label: "T-TeleSec GlobalRoot Class 2" -# Serial: 1 -# MD5 Fingerprint: 2b:9b:9e:e4:7b:6c:1f:00:72:1a:cc:c1:77:79:df:6a -# SHA1 Fingerprint: 59:0d:2d:7d:88:4f:40:2e:61:7e:a5:62:32:17:65:cf:17:d8:94:e9 -# SHA256 Fingerprint: 91:e2:f5:78:8d:58:10:eb:a7:ba:58:73:7d:e1:54:8a:8e:ca:cd:01:45:98:bc:0b:14:3e:04:1b:17:05:25:52 ------BEGIN CERTIFICATE----- -MIIDwzCCAqugAwIBAgIBATANBgkqhkiG9w0BAQsFADCBgjELMAkGA1UEBhMCREUx -KzApBgNVBAoMIlQtU3lzdGVtcyBFbnRlcnByaXNlIFNlcnZpY2VzIEdtYkgxHzAd -BgNVBAsMFlQtU3lzdGVtcyBUcnVzdCBDZW50ZXIxJTAjBgNVBAMMHFQtVGVsZVNl -YyBHbG9iYWxSb290IENsYXNzIDIwHhcNMDgxMDAxMTA0MDE0WhcNMzMxMDAxMjM1 -OTU5WjCBgjELMAkGA1UEBhMCREUxKzApBgNVBAoMIlQtU3lzdGVtcyBFbnRlcnBy -aXNlIFNlcnZpY2VzIEdtYkgxHzAdBgNVBAsMFlQtU3lzdGVtcyBUcnVzdCBDZW50 -ZXIxJTAjBgNVBAMMHFQtVGVsZVNlYyBHbG9iYWxSb290IENsYXNzIDIwggEiMA0G -CSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQCqX9obX+hzkeXaXPSi5kfl82hVYAUd -AqSzm1nzHoqvNK38DcLZSBnuaY/JIPwhqgcZ7bBcrGXHX+0CfHt8LRvWurmAwhiC -FoT6ZrAIxlQjgeTNuUk/9k9uN0goOA/FvudocP05l03Sx5iRUKrERLMjfTlH6VJi -1hKTXrcxlkIF+3anHqP1wvzpesVsqXFP6st4vGCvx9702cu+fjOlbpSD8DT6Iavq -jnKgP6TeMFvvhk1qlVtDRKgQFRzlAVfFmPHmBiiRqiDFt1MmUUOyCxGVWOHAD3bZ -wI18gfNycJ5v/hqO2V81xrJvNHy+SE/iWjnX2J14np+GPgNeGYtEotXHAgMBAAGj -QjBAMA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgEGMB0GA1UdDgQWBBS/ -WSA2AHmgoCJrjNXyYdK4LMuCSjANBgkqhkiG9w0BAQsFAAOCAQEAMQOiYQsfdOhy -NsZt+U2e+iKo4YFWz827n+qrkRk4r6p8FU3ztqONpfSO9kSpp+ghla0+AGIWiPAC -uvxhI+YzmzB6azZie60EI4RYZeLbK4rnJVM3YlNfvNoBYimipidx5joifsFvHZVw -IEoHNN/q/xWA5brXethbdXwFeilHfkCoMRN3zUA7tFFHei4R40cR3p1m0IvVVGb6 -g1XqfMIpiRvpb7PO4gWEyS8+eIVibslfwXhjdFjASBgMmTnrpMwatXlajRWc2BQN -9noHV8cigwUtPJslJj0Ys6lDfMjIq2SPDqO/nBudMNva0Bkuqjzx+zOAduTNrRlP -BSeOE6Fuwg== ------END CERTIFICATE----- - -# Issuer: CN=Atos TrustedRoot 2011 O=Atos -# Subject: CN=Atos TrustedRoot 2011 O=Atos -# Label: "Atos TrustedRoot 2011" -# Serial: 6643877497813316402 -# MD5 Fingerprint: ae:b9:c4:32:4b:ac:7f:5d:66:cc:77:94:bb:2a:77:56 -# SHA1 Fingerprint: 2b:b1:f5:3e:55:0c:1d:c5:f1:d4:e6:b7:6a:46:4b:55:06:02:ac:21 -# SHA256 Fingerprint: f3:56:be:a2:44:b7:a9:1e:b3:5d:53:ca:9a:d7:86:4a:ce:01:8e:2d:35:d5:f8:f9:6d:df:68:a6:f4:1a:a4:74 ------BEGIN CERTIFICATE----- -MIIDdzCCAl+gAwIBAgIIXDPLYixfszIwDQYJKoZIhvcNAQELBQAwPDEeMBwGA1UE -AwwVQXRvcyBUcnVzdGVkUm9vdCAyMDExMQ0wCwYDVQQKDARBdG9zMQswCQYDVQQG -EwJERTAeFw0xMTA3MDcxNDU4MzBaFw0zMDEyMzEyMzU5NTlaMDwxHjAcBgNVBAMM -FUF0b3MgVHJ1c3RlZFJvb3QgMjAxMTENMAsGA1UECgwEQXRvczELMAkGA1UEBhMC -REUwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQCVhTuXbyo7LjvPpvMp -Nb7PGKw+qtn4TaA+Gke5vJrf8v7MPkfoepbCJI419KkM/IL9bcFyYie96mvr54rM -VD6QUM+A1JX76LWC1BTFtqlVJVfbsVD2sGBkWXppzwO3bw2+yj5vdHLqqjAqc2K+ -SZFhyBH+DgMq92og3AIVDV4VavzjgsG1xZ1kCWyjWZgHJ8cblithdHFsQ/H3NYkQ -4J7sVaE3IqKHBAUsR320HLliKWYoyrfhk/WklAOZuXCFteZI6o1Q/NnezG8HDt0L -cp2AMBYHlT8oDv3FdU9T1nSatCQujgKRz3bFmx5VdJx4IbHwLfELn8LVlhgf8FQi -eowHAgMBAAGjfTB7MB0GA1UdDgQWBBSnpQaxLKYJYO7Rl+lwrrw7GWzbITAPBgNV -HRMBAf8EBTADAQH/MB8GA1UdIwQYMBaAFKelBrEspglg7tGX6XCuvDsZbNshMBgG -A1UdIAQRMA8wDQYLKwYBBAGwLQMEAQEwDgYDVR0PAQH/BAQDAgGGMA0GCSqGSIb3 -DQEBCwUAA4IBAQAmdzTblEiGKkGdLD4GkGDEjKwLVLgfuXvTBznk+j57sj1O7Z8j -vZfza1zv7v1Apt+hk6EKhqzvINB5Ab149xnYJDE0BAGmuhWawyfc2E8PzBhj/5kP -DpFrdRbhIfzYJsdHt6bPWHJxfrrhTZVHO8mvbaG0weyJ9rQPOLXiZNwlz6bb65pc -maHFCN795trV1lpFDMS3wrUU77QR/w4VtfX128a961qn8FYiqTxlVMYVqL2Gns2D -lmh6cYGJ4Qvh6hEbaAjMaZ7snkGeRDImeuKHCnE96+RapNLbxc3G3mB/ufNPRJLv -KrcYPqcZ2Qt9sTdBQrC6YB3y/gkRsPCHe6ed ------END CERTIFICATE----- - -# Issuer: CN=QuoVadis Root CA 1 G3 O=QuoVadis Limited -# Subject: CN=QuoVadis Root CA 1 G3 O=QuoVadis Limited -# Label: "QuoVadis Root CA 1 G3" -# Serial: 687049649626669250736271037606554624078720034195 -# MD5 Fingerprint: a4:bc:5b:3f:fe:37:9a:fa:64:f0:e2:fa:05:3d:0b:ab -# SHA1 Fingerprint: 1b:8e:ea:57:96:29:1a:c9:39:ea:b8:0a:81:1a:73:73:c0:93:79:67 -# SHA256 Fingerprint: 8a:86:6f:d1:b2:76:b5:7e:57:8e:92:1c:65:82:8a:2b:ed:58:e9:f2:f2:88:05:41:34:b7:f1:f4:bf:c9:cc:74 ------BEGIN CERTIFICATE----- -MIIFYDCCA0igAwIBAgIUeFhfLq0sGUvjNwc1NBMotZbUZZMwDQYJKoZIhvcNAQEL -BQAwSDELMAkGA1UEBhMCQk0xGTAXBgNVBAoTEFF1b1ZhZGlzIExpbWl0ZWQxHjAc -BgNVBAMTFVF1b1ZhZGlzIFJvb3QgQ0EgMSBHMzAeFw0xMjAxMTIxNzI3NDRaFw00 -MjAxMTIxNzI3NDRaMEgxCzAJBgNVBAYTAkJNMRkwFwYDVQQKExBRdW9WYWRpcyBM -aW1pdGVkMR4wHAYDVQQDExVRdW9WYWRpcyBSb290IENBIDEgRzMwggIiMA0GCSqG -SIb3DQEBAQUAA4ICDwAwggIKAoICAQCgvlAQjunybEC0BJyFuTHK3C3kEakEPBtV -wedYMB0ktMPvhd6MLOHBPd+C5k+tR4ds7FtJwUrVu4/sh6x/gpqG7D0DmVIB0jWe -rNrwU8lmPNSsAgHaJNM7qAJGr6Qc4/hzWHa39g6QDbXwz8z6+cZM5cOGMAqNF341 -68Xfuw6cwI2H44g4hWf6Pser4BOcBRiYz5P1sZK0/CPTz9XEJ0ngnjybCKOLXSoh -4Pw5qlPafX7PGglTvF0FBM+hSo+LdoINofjSxxR3W5A2B4GbPgb6Ul5jxaYA/qXp -UhtStZI5cgMJYr2wYBZupt0lwgNm3fME0UDiTouG9G/lg6AnhF4EwfWQvTA9xO+o -abw4m6SkltFi2mnAAZauy8RRNOoMqv8hjlmPSlzkYZqn0ukqeI1RPToV7qJZjqlc -3sX5kCLliEVx3ZGZbHqfPT2YfF72vhZooF6uCyP8Wg+qInYtyaEQHeTTRCOQiJ/G -KubX9ZqzWB4vMIkIG1SitZgj7Ah3HJVdYdHLiZxfokqRmu8hqkkWCKi9YSgxyXSt -hfbZxbGL0eUQMk1fiyA6PEkfM4VZDdvLCXVDaXP7a3F98N/ETH3Goy7IlXnLc6KO -Tk0k+17kBL5yG6YnLUlamXrXXAkgt3+UuU/xDRxeiEIbEbfnkduebPRq34wGmAOt -zCjvpUfzUwIDAQABo0IwQDAPBgNVHRMBAf8EBTADAQH/MA4GA1UdDwEB/wQEAwIB -BjAdBgNVHQ4EFgQUo5fW816iEOGrRZ88F2Q87gFwnMwwDQYJKoZIhvcNAQELBQAD -ggIBABj6W3X8PnrHX3fHyt/PX8MSxEBd1DKquGrX1RUVRpgjpeaQWxiZTOOtQqOC -MTaIzen7xASWSIsBx40Bz1szBpZGZnQdT+3Btrm0DWHMY37XLneMlhwqI2hrhVd2 -cDMT/uFPpiN3GPoajOi9ZcnPP/TJF9zrx7zABC4tRi9pZsMbj/7sPtPKlL92CiUN -qXsCHKnQO18LwIE6PWThv6ctTr1NxNgpxiIY0MWscgKCP6o6ojoilzHdCGPDdRS5 -YCgtW2jgFqlmgiNR9etT2DGbe+m3nUvriBbP+V04ikkwj+3x6xn0dxoxGE1nVGwv -b2X52z3sIexe9PSLymBlVNFxZPT5pqOBMzYzcfCkeF9OrYMh3jRJjehZrJ3ydlo2 -8hP0r+AJx2EqbPfgna67hkooby7utHnNkDPDs3b69fBsnQGQ+p6Q9pxyz0fawx/k -NSBT8lTR32GDpgLiJTjehTItXnOQUl1CxM49S+H5GYQd1aJQzEH7QRTDvdbJWqNj -ZgKAvQU6O0ec7AAmTPWIUb+oI38YB7AL7YsmoWTTYUrrXJ/es69nA7Mf3W1daWhp -q1467HxpvMc7hU6eFbm0FU/DlXpY18ls6Wy58yljXrQs8C097Vpl4KlbQMJImYFt -nh8GKjwStIsPm6Ik8KaN1nrgS7ZklmOVhMJKzRwuJIczYOXD ------END CERTIFICATE----- - -# Issuer: CN=QuoVadis Root CA 2 G3 O=QuoVadis Limited -# Subject: CN=QuoVadis Root CA 2 G3 O=QuoVadis Limited -# Label: "QuoVadis Root CA 2 G3" -# Serial: 390156079458959257446133169266079962026824725800 -# MD5 Fingerprint: af:0c:86:6e:bf:40:2d:7f:0b:3e:12:50:ba:12:3d:06 -# SHA1 Fingerprint: 09:3c:61:f3:8b:8b:dc:7d:55:df:75:38:02:05:00:e1:25:f5:c8:36 -# SHA256 Fingerprint: 8f:e4:fb:0a:f9:3a:4d:0d:67:db:0b:eb:b2:3e:37:c7:1b:f3:25:dc:bc:dd:24:0e:a0:4d:af:58:b4:7e:18:40 ------BEGIN CERTIFICATE----- -MIIFYDCCA0igAwIBAgIURFc0JFuBiZs18s64KztbpybwdSgwDQYJKoZIhvcNAQEL -BQAwSDELMAkGA1UEBhMCQk0xGTAXBgNVBAoTEFF1b1ZhZGlzIExpbWl0ZWQxHjAc -BgNVBAMTFVF1b1ZhZGlzIFJvb3QgQ0EgMiBHMzAeFw0xMjAxMTIxODU5MzJaFw00 -MjAxMTIxODU5MzJaMEgxCzAJBgNVBAYTAkJNMRkwFwYDVQQKExBRdW9WYWRpcyBM -aW1pdGVkMR4wHAYDVQQDExVRdW9WYWRpcyBSb290IENBIDIgRzMwggIiMA0GCSqG -SIb3DQEBAQUAA4ICDwAwggIKAoICAQChriWyARjcV4g/Ruv5r+LrI3HimtFhZiFf -qq8nUeVuGxbULX1QsFN3vXg6YOJkApt8hpvWGo6t/x8Vf9WVHhLL5hSEBMHfNrMW -n4rjyduYNM7YMxcoRvynyfDStNVNCXJJ+fKH46nafaF9a7I6JaltUkSs+L5u+9ym -c5GQYaYDFCDy54ejiK2toIz/pgslUiXnFgHVy7g1gQyjO/Dh4fxaXc6AcW34Sas+ -O7q414AB+6XrW7PFXmAqMaCvN+ggOp+oMiwMzAkd056OXbxMmO7FGmh77FOm6RQ1 -o9/NgJ8MSPsc9PG/Srj61YxxSscfrf5BmrODXfKEVu+lV0POKa2Mq1W/xPtbAd0j -IaFYAI7D0GoT7RPjEiuA3GfmlbLNHiJuKvhB1PLKFAeNilUSxmn1uIZoL1NesNKq -IcGY5jDjZ1XHm26sGahVpkUG0CM62+tlXSoREfA7T8pt9DTEceT/AFr2XK4jYIVz -8eQQsSWu1ZK7E8EM4DnatDlXtas1qnIhO4M15zHfeiFuuDIIfR0ykRVKYnLP43eh -vNURG3YBZwjgQQvD6xVu+KQZ2aKrr+InUlYrAoosFCT5v0ICvybIxo/gbjh9Uy3l -7ZizlWNof/k19N+IxWA1ksB8aRxhlRbQ694Lrz4EEEVlWFA4r0jyWbYW8jwNkALG -cC4BrTwV1wIDAQABo0IwQDAPBgNVHRMBAf8EBTADAQH/MA4GA1UdDwEB/wQEAwIB -BjAdBgNVHQ4EFgQU7edvdlq/YOxJW8ald7tyFnGbxD0wDQYJKoZIhvcNAQELBQAD -ggIBAJHfgD9DCX5xwvfrs4iP4VGyvD11+ShdyLyZm3tdquXK4Qr36LLTn91nMX66 -AarHakE7kNQIXLJgapDwyM4DYvmL7ftuKtwGTTwpD4kWilhMSA/ohGHqPHKmd+RC -roijQ1h5fq7KpVMNqT1wvSAZYaRsOPxDMuHBR//47PERIjKWnML2W2mWeyAMQ0Ga -W/ZZGYjeVYg3UQt4XAoeo0L9x52ID8DyeAIkVJOviYeIyUqAHerQbj5hLja7NQ4n -lv1mNDthcnPxFlxHBlRJAHpYErAK74X9sbgzdWqTHBLmYF5vHX/JHyPLhGGfHoJE -+V+tYlUkmlKY7VHnoX6XOuYvHxHaU4AshZ6rNRDbIl9qxV6XU/IyAgkwo1jwDQHV -csaxfGl7w/U2Rcxhbl5MlMVerugOXou/983g7aEOGzPuVBj+D77vfoRrQ+NwmNtd -dbINWQeFFSM51vHfqSYP1kjHs6Yi9TM3WpVHn3u6GBVv/9YUZINJ0gpnIdsPNWNg -KCLjsZWDzYWm3S8P52dSbrsvhXz1SnPnxT7AvSESBT/8twNJAlvIJebiVDj1eYeM -HVOyToV7BjjHLPj4sHKNJeV3UvQDHEimUF+IIDBu8oJDqz2XhOdT+yHBTw8imoa4 -WSr2Rz0ZiC3oheGe7IUIarFsNMkd7EgrO3jtZsSOeWmD3n+M ------END CERTIFICATE----- - -# Issuer: CN=QuoVadis Root CA 3 G3 O=QuoVadis Limited -# Subject: CN=QuoVadis Root CA 3 G3 O=QuoVadis Limited -# Label: "QuoVadis Root CA 3 G3" -# Serial: 268090761170461462463995952157327242137089239581 -# MD5 Fingerprint: df:7d:b9:ad:54:6f:68:a1:df:89:57:03:97:43:b0:d7 -# SHA1 Fingerprint: 48:12:bd:92:3c:a8:c4:39:06:e7:30:6d:27:96:e6:a4:cf:22:2e:7d -# SHA256 Fingerprint: 88:ef:81:de:20:2e:b0:18:45:2e:43:f8:64:72:5c:ea:5f:bd:1f:c2:d9:d2:05:73:07:09:c5:d8:b8:69:0f:46 ------BEGIN CERTIFICATE----- -MIIFYDCCA0igAwIBAgIULvWbAiin23r/1aOp7r0DoM8Sah0wDQYJKoZIhvcNAQEL -BQAwSDELMAkGA1UEBhMCQk0xGTAXBgNVBAoTEFF1b1ZhZGlzIExpbWl0ZWQxHjAc -BgNVBAMTFVF1b1ZhZGlzIFJvb3QgQ0EgMyBHMzAeFw0xMjAxMTIyMDI2MzJaFw00 -MjAxMTIyMDI2MzJaMEgxCzAJBgNVBAYTAkJNMRkwFwYDVQQKExBRdW9WYWRpcyBM -aW1pdGVkMR4wHAYDVQQDExVRdW9WYWRpcyBSb290IENBIDMgRzMwggIiMA0GCSqG -SIb3DQEBAQUAA4ICDwAwggIKAoICAQCzyw4QZ47qFJenMioKVjZ/aEzHs286IxSR -/xl/pcqs7rN2nXrpixurazHb+gtTTK/FpRp5PIpM/6zfJd5O2YIyC0TeytuMrKNu -FoM7pmRLMon7FhY4futD4tN0SsJiCnMK3UmzV9KwCoWdcTzeo8vAMvMBOSBDGzXR -U7Ox7sWTaYI+FrUoRqHe6okJ7UO4BUaKhvVZR74bbwEhELn9qdIoyhA5CcoTNs+c -ra1AdHkrAj80//ogaX3T7mH1urPnMNA3I4ZyYUUpSFlob3emLoG+B01vr87ERROR -FHAGjx+f+IdpsQ7vw4kZ6+ocYfx6bIrc1gMLnia6Et3UVDmrJqMz6nWB2i3ND0/k -A9HvFZcba5DFApCTZgIhsUfei5pKgLlVj7WiL8DWM2fafsSntARE60f75li59wzw -eyuxwHApw0BiLTtIadwjPEjrewl5qW3aqDCYz4ByA4imW0aucnl8CAMhZa634Ryl -sSqiMd5mBPfAdOhx3v89WcyWJhKLhZVXGqtrdQtEPREoPHtht+KPZ0/l7DxMYIBp -VzgeAVuNVejH38DMdyM0SXV89pgR6y3e7UEuFAUCf+D+IOs15xGsIs5XPd7JMG0Q -A4XN8f+MFrXBsj6IbGB/kE+V9/YtrQE5BwT6dYB9v0lQ7e/JxHwc64B+27bQ3RP+ -ydOc17KXqQIDAQABo0IwQDAPBgNVHRMBAf8EBTADAQH/MA4GA1UdDwEB/wQEAwIB -BjAdBgNVHQ4EFgQUxhfQvKjqAkPyGwaZXSuQILnXnOQwDQYJKoZIhvcNAQELBQAD -ggIBADRh2Va1EodVTd2jNTFGu6QHcrxfYWLopfsLN7E8trP6KZ1/AvWkyaiTt3px -KGmPc+FSkNrVvjrlt3ZqVoAh313m6Tqe5T72omnHKgqwGEfcIHB9UqM+WXzBusnI -FUBhynLWcKzSt/Ac5IYp8M7vaGPQtSCKFWGafoaYtMnCdvvMujAWzKNhxnQT5Wvv -oxXqA/4Ti2Tk08HS6IT7SdEQTXlm66r99I0xHnAUrdzeZxNMgRVhvLfZkXdxGYFg -u/BYpbWcC/ePIlUnwEsBbTuZDdQdm2NnL9DuDcpmvJRPpq3t/O5jrFc/ZSXPsoaP -0Aj/uHYUbt7lJ+yreLVTubY/6CD50qi+YUbKh4yE8/nxoGibIh6BJpsQBJFxwAYf -3KDTuVan45gtf4Od34wrnDKOMpTwATwiKp9Dwi7DmDkHOHv8XgBCH/MyJnmDhPbl -8MFREsALHgQjDFSlTC9JxUrRtm5gDWv8a4uFJGS3iQ6rJUdbPM9+Sb3H6QrG2vd+ -DhcI00iX0HGS8A85PjRqHH3Y8iKuu2n0M7SmSFXRDw4m6Oy2Cy2nhTXN/VnIn9HN -PlopNLk9hM6xZdRZkZFWdSHBd575euFgndOtBBj0fOtek49TSiIp+EgrPk2GrFt/ -ywaZWWDYWGWVjUTR939+J399roD1B0y2PpxxVJkES/1Y+Zj0 ------END CERTIFICATE----- - -# Issuer: CN=DigiCert Assured ID Root G2 O=DigiCert Inc OU=www.digicert.com -# Subject: CN=DigiCert Assured ID Root G2 O=DigiCert Inc OU=www.digicert.com -# Label: "DigiCert Assured ID Root G2" -# Serial: 15385348160840213938643033620894905419 -# MD5 Fingerprint: 92:38:b9:f8:63:24:82:65:2c:57:33:e6:fe:81:8f:9d -# SHA1 Fingerprint: a1:4b:48:d9:43:ee:0a:0e:40:90:4f:3c:e0:a4:c0:91:93:51:5d:3f -# SHA256 Fingerprint: 7d:05:eb:b6:82:33:9f:8c:94:51:ee:09:4e:eb:fe:fa:79:53:a1:14:ed:b2:f4:49:49:45:2f:ab:7d:2f:c1:85 ------BEGIN CERTIFICATE----- -MIIDljCCAn6gAwIBAgIQC5McOtY5Z+pnI7/Dr5r0SzANBgkqhkiG9w0BAQsFADBl -MQswCQYDVQQGEwJVUzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3 -d3cuZGlnaWNlcnQuY29tMSQwIgYDVQQDExtEaWdpQ2VydCBBc3N1cmVkIElEIFJv -b3QgRzIwHhcNMTMwODAxMTIwMDAwWhcNMzgwMTE1MTIwMDAwWjBlMQswCQYDVQQG -EwJVUzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3d3cuZGlnaWNl -cnQuY29tMSQwIgYDVQQDExtEaWdpQ2VydCBBc3N1cmVkIElEIFJvb3QgRzIwggEi -MA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQDZ5ygvUj82ckmIkzTz+GoeMVSA -n61UQbVH35ao1K+ALbkKz3X9iaV9JPrjIgwrvJUXCzO/GU1BBpAAvQxNEP4Htecc -biJVMWWXvdMX0h5i89vqbFCMP4QMls+3ywPgym2hFEwbid3tALBSfK+RbLE4E9Hp -EgjAALAcKxHad3A2m67OeYfcgnDmCXRwVWmvo2ifv922ebPynXApVfSr/5Vh88lA -bx3RvpO704gqu52/clpWcTs/1PPRCv4o76Pu2ZmvA9OPYLfykqGxvYmJHzDNw6Yu -YjOuFgJ3RFrngQo8p0Quebg/BLxcoIfhG69Rjs3sLPr4/m3wOnyqi+RnlTGNAgMB -AAGjQjBAMA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgGGMB0GA1UdDgQW -BBTOw0q5mVXyuNtgv6l+vVa1lzan1jANBgkqhkiG9w0BAQsFAAOCAQEAyqVVjOPI -QW5pJ6d1Ee88hjZv0p3GeDgdaZaikmkuOGybfQTUiaWxMTeKySHMq2zNixya1r9I -0jJmwYrA8y8678Dj1JGG0VDjA9tzd29KOVPt3ibHtX2vK0LRdWLjSisCx1BL4Gni -lmwORGYQRI+tBev4eaymG+g3NJ1TyWGqolKvSnAWhsI6yLETcDbYz+70CjTVW0z9 -B5yiutkBclzzTcHdDrEcDcRjvq30FPuJ7KJBDkzMyFdA0G4Dqs0MjomZmWzwPDCv -ON9vvKO+KSAnq3T/EyJ43pdSVR6DtVQgA+6uwE9W3jfMw3+qBCe703e4YtsXfJwo -IhNzbM8m9Yop5w== ------END CERTIFICATE----- - -# Issuer: CN=DigiCert Assured ID Root G3 O=DigiCert Inc OU=www.digicert.com -# Subject: CN=DigiCert Assured ID Root G3 O=DigiCert Inc OU=www.digicert.com -# Label: "DigiCert Assured ID Root G3" -# Serial: 15459312981008553731928384953135426796 -# MD5 Fingerprint: 7c:7f:65:31:0c:81:df:8d:ba:3e:99:e2:5c:ad:6e:fb -# SHA1 Fingerprint: f5:17:a2:4f:9a:48:c6:c9:f8:a2:00:26:9f:dc:0f:48:2c:ab:30:89 -# SHA256 Fingerprint: 7e:37:cb:8b:4c:47:09:0c:ab:36:55:1b:a6:f4:5d:b8:40:68:0f:ba:16:6a:95:2d:b1:00:71:7f:43:05:3f:c2 ------BEGIN CERTIFICATE----- -MIICRjCCAc2gAwIBAgIQC6Fa+h3foLVJRK/NJKBs7DAKBggqhkjOPQQDAzBlMQsw -CQYDVQQGEwJVUzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3d3cu -ZGlnaWNlcnQuY29tMSQwIgYDVQQDExtEaWdpQ2VydCBBc3N1cmVkIElEIFJvb3Qg -RzMwHhcNMTMwODAxMTIwMDAwWhcNMzgwMTE1MTIwMDAwWjBlMQswCQYDVQQGEwJV -UzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3d3cuZGlnaWNlcnQu -Y29tMSQwIgYDVQQDExtEaWdpQ2VydCBBc3N1cmVkIElEIFJvb3QgRzMwdjAQBgcq -hkjOPQIBBgUrgQQAIgNiAAQZ57ysRGXtzbg/WPuNsVepRC0FFfLvC/8QdJ+1YlJf -Zn4f5dwbRXkLzMZTCp2NXQLZqVneAlr2lSoOjThKiknGvMYDOAdfVdp+CW7if17Q -RSAPWXYQ1qAk8C3eNvJsKTmjQjBAMA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/ -BAQDAgGGMB0GA1UdDgQWBBTL0L2p4ZgFUaFNN6KDec6NHSrkhDAKBggqhkjOPQQD -AwNnADBkAjAlpIFFAmsSS3V0T8gj43DydXLefInwz5FyYZ5eEJJZVrmDxxDnOOlY -JjZ91eQ0hjkCMHw2U/Aw5WJjOpnitqM7mzT6HtoQknFekROn3aRukswy1vUhZscv -6pZjamVFkpUBtA== ------END CERTIFICATE----- - -# Issuer: CN=DigiCert Global Root G2 O=DigiCert Inc OU=www.digicert.com -# Subject: CN=DigiCert Global Root G2 O=DigiCert Inc OU=www.digicert.com -# Label: "DigiCert Global Root G2" -# Serial: 4293743540046975378534879503202253541 -# MD5 Fingerprint: e4:a6:8a:c8:54:ac:52:42:46:0a:fd:72:48:1b:2a:44 -# SHA1 Fingerprint: df:3c:24:f9:bf:d6:66:76:1b:26:80:73:fe:06:d1:cc:8d:4f:82:a4 -# SHA256 Fingerprint: cb:3c:cb:b7:60:31:e5:e0:13:8f:8d:d3:9a:23:f9:de:47:ff:c3:5e:43:c1:14:4c:ea:27:d4:6a:5a:b1:cb:5f ------BEGIN CERTIFICATE----- -MIIDjjCCAnagAwIBAgIQAzrx5qcRqaC7KGSxHQn65TANBgkqhkiG9w0BAQsFADBh -MQswCQYDVQQGEwJVUzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3 -d3cuZGlnaWNlcnQuY29tMSAwHgYDVQQDExdEaWdpQ2VydCBHbG9iYWwgUm9vdCBH -MjAeFw0xMzA4MDExMjAwMDBaFw0zODAxMTUxMjAwMDBaMGExCzAJBgNVBAYTAlVT -MRUwEwYDVQQKEwxEaWdpQ2VydCBJbmMxGTAXBgNVBAsTEHd3dy5kaWdpY2VydC5j -b20xIDAeBgNVBAMTF0RpZ2lDZXJ0IEdsb2JhbCBSb290IEcyMIIBIjANBgkqhkiG -9w0BAQEFAAOCAQ8AMIIBCgKCAQEAuzfNNNx7a8myaJCtSnX/RrohCgiN9RlUyfuI -2/Ou8jqJkTx65qsGGmvPrC3oXgkkRLpimn7Wo6h+4FR1IAWsULecYxpsMNzaHxmx -1x7e/dfgy5SDN67sH0NO3Xss0r0upS/kqbitOtSZpLYl6ZtrAGCSYP9PIUkY92eQ -q2EGnI/yuum06ZIya7XzV+hdG82MHauVBJVJ8zUtluNJbd134/tJS7SsVQepj5Wz -tCO7TG1F8PapspUwtP1MVYwnSlcUfIKdzXOS0xZKBgyMUNGPHgm+F6HmIcr9g+UQ -vIOlCsRnKPZzFBQ9RnbDhxSJITRNrw9FDKZJobq7nMWxM4MphQIDAQABo0IwQDAP -BgNVHRMBAf8EBTADAQH/MA4GA1UdDwEB/wQEAwIBhjAdBgNVHQ4EFgQUTiJUIBiV -5uNu5g/6+rkS7QYXjzkwDQYJKoZIhvcNAQELBQADggEBAGBnKJRvDkhj6zHd6mcY -1Yl9PMWLSn/pvtsrF9+wX3N3KjITOYFnQoQj8kVnNeyIv/iPsGEMNKSuIEyExtv4 -NeF22d+mQrvHRAiGfzZ0JFrabA0UWTW98kndth/Jsw1HKj2ZL7tcu7XUIOGZX1NG -Fdtom/DzMNU+MeKNhJ7jitralj41E6Vf8PlwUHBHQRFXGU7Aj64GxJUTFy8bJZ91 -8rGOmaFvE7FBcf6IKshPECBV1/MUReXgRPTqh5Uykw7+U0b6LJ3/iyK5S9kJRaTe -pLiaWN0bfVKfjllDiIGknibVb63dDcY3fe0Dkhvld1927jyNxF1WW6LZZm6zNTfl -MrY= ------END CERTIFICATE----- - -# Issuer: CN=DigiCert Global Root G3 O=DigiCert Inc OU=www.digicert.com -# Subject: CN=DigiCert Global Root G3 O=DigiCert Inc OU=www.digicert.com -# Label: "DigiCert Global Root G3" -# Serial: 7089244469030293291760083333884364146 -# MD5 Fingerprint: f5:5d:a4:50:a5:fb:28:7e:1e:0f:0d:cc:96:57:56:ca -# SHA1 Fingerprint: 7e:04:de:89:6a:3e:66:6d:00:e6:87:d3:3f:fa:d9:3b:e8:3d:34:9e -# SHA256 Fingerprint: 31:ad:66:48:f8:10:41:38:c7:38:f3:9e:a4:32:01:33:39:3e:3a:18:cc:02:29:6e:f9:7c:2a:c9:ef:67:31:d0 ------BEGIN CERTIFICATE----- -MIICPzCCAcWgAwIBAgIQBVVWvPJepDU1w6QP1atFcjAKBggqhkjOPQQDAzBhMQsw -CQYDVQQGEwJVUzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3d3cu -ZGlnaWNlcnQuY29tMSAwHgYDVQQDExdEaWdpQ2VydCBHbG9iYWwgUm9vdCBHMzAe -Fw0xMzA4MDExMjAwMDBaFw0zODAxMTUxMjAwMDBaMGExCzAJBgNVBAYTAlVTMRUw -EwYDVQQKEwxEaWdpQ2VydCBJbmMxGTAXBgNVBAsTEHd3dy5kaWdpY2VydC5jb20x -IDAeBgNVBAMTF0RpZ2lDZXJ0IEdsb2JhbCBSb290IEczMHYwEAYHKoZIzj0CAQYF -K4EEACIDYgAE3afZu4q4C/sLfyHS8L6+c/MzXRq8NOrexpu80JX28MzQC7phW1FG -fp4tn+6OYwwX7Adw9c+ELkCDnOg/QW07rdOkFFk2eJ0DQ+4QE2xy3q6Ip6FrtUPO -Z9wj/wMco+I+o0IwQDAPBgNVHRMBAf8EBTADAQH/MA4GA1UdDwEB/wQEAwIBhjAd -BgNVHQ4EFgQUs9tIpPmhxdiuNkHMEWNpYim8S8YwCgYIKoZIzj0EAwMDaAAwZQIx -AK288mw/EkrRLTnDCgmXc/SINoyIJ7vmiI1Qhadj+Z4y3maTD/HMsQmP3Wyr+mt/ -oAIwOWZbwmSNuJ5Q3KjVSaLtx9zRSX8XAbjIho9OjIgrqJqpisXRAL34VOKa5Vt8 -sycX ------END CERTIFICATE----- - -# Issuer: CN=DigiCert Trusted Root G4 O=DigiCert Inc OU=www.digicert.com -# Subject: CN=DigiCert Trusted Root G4 O=DigiCert Inc OU=www.digicert.com -# Label: "DigiCert Trusted Root G4" -# Serial: 7451500558977370777930084869016614236 -# MD5 Fingerprint: 78:f2:fc:aa:60:1f:2f:b4:eb:c9:37:ba:53:2e:75:49 -# SHA1 Fingerprint: dd:fb:16:cd:49:31:c9:73:a2:03:7d:3f:c8:3a:4d:7d:77:5d:05:e4 -# SHA256 Fingerprint: 55:2f:7b:dc:f1:a7:af:9e:6c:e6:72:01:7f:4f:12:ab:f7:72:40:c7:8e:76:1a:c2:03:d1:d9:d2:0a:c8:99:88 ------BEGIN CERTIFICATE----- -MIIFkDCCA3igAwIBAgIQBZsbV56OITLiOQe9p3d1XDANBgkqhkiG9w0BAQwFADBi -MQswCQYDVQQGEwJVUzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3 -d3cuZGlnaWNlcnQuY29tMSEwHwYDVQQDExhEaWdpQ2VydCBUcnVzdGVkIFJvb3Qg -RzQwHhcNMTMwODAxMTIwMDAwWhcNMzgwMTE1MTIwMDAwWjBiMQswCQYDVQQGEwJV -UzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3d3cuZGlnaWNlcnQu -Y29tMSEwHwYDVQQDExhEaWdpQ2VydCBUcnVzdGVkIFJvb3QgRzQwggIiMA0GCSqG -SIb3DQEBAQUAA4ICDwAwggIKAoICAQC/5pBzaN675F1KPDAiMGkz7MKnJS7JIT3y -ithZwuEppz1Yq3aaza57G4QNxDAf8xukOBbrVsaXbR2rsnnyyhHS5F/WBTxSD1If -xp4VpX6+n6lXFllVcq9ok3DCsrp1mWpzMpTREEQQLt+C8weE5nQ7bXHiLQwb7iDV -ySAdYyktzuxeTsiT+CFhmzTrBcZe7FsavOvJz82sNEBfsXpm7nfISKhmV1efVFiO -DCu3T6cw2Vbuyntd463JT17lNecxy9qTXtyOj4DatpGYQJB5w3jHtrHEtWoYOAMQ -jdjUN6QuBX2I9YI+EJFwq1WCQTLX2wRzKm6RAXwhTNS8rhsDdV14Ztk6MUSaM0C/ -CNdaSaTC5qmgZ92kJ7yhTzm1EVgX9yRcRo9k98FpiHaYdj1ZXUJ2h4mXaXpI8OCi -EhtmmnTK3kse5w5jrubU75KSOp493ADkRSWJtppEGSt+wJS00mFt6zPZxd9LBADM -fRyVw4/3IbKyEbe7f/LVjHAsQWCqsWMYRJUadmJ+9oCw++hkpjPRiQfhvbfmQ6QY -uKZ3AeEPlAwhHbJUKSWJbOUOUlFHdL4mrLZBdd56rF+NP8m800ERElvlEFDrMcXK -chYiCd98THU/Y+whX8QgUWtvsauGi0/C1kVfnSD8oR7FwI+isX4KJpn15GkvmB0t -9dmpsh3lGwIDAQABo0IwQDAPBgNVHRMBAf8EBTADAQH/MA4GA1UdDwEB/wQEAwIB -hjAdBgNVHQ4EFgQU7NfjgtJxXWRM3y5nP+e6mK4cD08wDQYJKoZIhvcNAQEMBQAD -ggIBALth2X2pbL4XxJEbw6GiAI3jZGgPVs93rnD5/ZpKmbnJeFwMDF/k5hQpVgs2 -SV1EY+CtnJYYZhsjDT156W1r1lT40jzBQ0CuHVD1UvyQO7uYmWlrx8GnqGikJ9yd -+SeuMIW59mdNOj6PWTkiU0TryF0Dyu1Qen1iIQqAyHNm0aAFYF/opbSnr6j3bTWc -fFqK1qI4mfN4i/RN0iAL3gTujJtHgXINwBQy7zBZLq7gcfJW5GqXb5JQbZaNaHqa -sjYUegbyJLkJEVDXCLG4iXqEI2FCKeWjzaIgQdfRnGTZ6iahixTXTBmyUEFxPT9N -cCOGDErcgdLMMpSEDQgJlxxPwO5rIHQw0uA5NBCFIRUBCOhVMt5xSdkoF1BN5r5N -0XWs0Mr7QbhDparTwwVETyw2m+L64kW4I1NsBm9nVX9GtUw/bihaeSbSpKhil9Ie -4u1Ki7wb/UdKDd9nZn6yW0HQO+T0O/QEY+nvwlQAUaCKKsnOeMzV6ocEGLPOr0mI -r/OSmbaz5mEP0oUA51Aa5BuVnRmhuZyxm7EAHu/QD09CbMkKvO5D+jpxpchNJqU1 -/YldvIViHTLSoCtU7ZpXwdv6EM8Zt4tKG48BtieVU+i2iW1bvGjUI+iLUaJW+fCm -gKDWHrO8Dw9TdSmq6hN35N6MgSGtBxBHEa2HPQfRdbzP82Z+ ------END CERTIFICATE----- - -# Issuer: CN=COMODO RSA Certification Authority O=COMODO CA Limited -# Subject: CN=COMODO RSA Certification Authority O=COMODO CA Limited -# Label: "COMODO RSA Certification Authority" -# Serial: 101909084537582093308941363524873193117 -# MD5 Fingerprint: 1b:31:b0:71:40:36:cc:14:36:91:ad:c4:3e:fd:ec:18 -# SHA1 Fingerprint: af:e5:d2:44:a8:d1:19:42:30:ff:47:9f:e2:f8:97:bb:cd:7a:8c:b4 -# SHA256 Fingerprint: 52:f0:e1:c4:e5:8e:c6:29:29:1b:60:31:7f:07:46:71:b8:5d:7e:a8:0d:5b:07:27:34:63:53:4b:32:b4:02:34 ------BEGIN CERTIFICATE----- -MIIF2DCCA8CgAwIBAgIQTKr5yttjb+Af907YWwOGnTANBgkqhkiG9w0BAQwFADCB -hTELMAkGA1UEBhMCR0IxGzAZBgNVBAgTEkdyZWF0ZXIgTWFuY2hlc3RlcjEQMA4G -A1UEBxMHU2FsZm9yZDEaMBgGA1UEChMRQ09NT0RPIENBIExpbWl0ZWQxKzApBgNV -BAMTIkNPTU9ETyBSU0EgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkwHhcNMTAwMTE5 -MDAwMDAwWhcNMzgwMTE4MjM1OTU5WjCBhTELMAkGA1UEBhMCR0IxGzAZBgNVBAgT -EkdyZWF0ZXIgTWFuY2hlc3RlcjEQMA4GA1UEBxMHU2FsZm9yZDEaMBgGA1UEChMR -Q09NT0RPIENBIExpbWl0ZWQxKzApBgNVBAMTIkNPTU9ETyBSU0EgQ2VydGlmaWNh -dGlvbiBBdXRob3JpdHkwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQCR -6FSS0gpWsawNJN3Fz0RndJkrN6N9I3AAcbxT38T6KhKPS38QVr2fcHK3YX/JSw8X -pz3jsARh7v8Rl8f0hj4K+j5c+ZPmNHrZFGvnnLOFoIJ6dq9xkNfs/Q36nGz637CC -9BR++b7Epi9Pf5l/tfxnQ3K9DADWietrLNPtj5gcFKt+5eNu/Nio5JIk2kNrYrhV -/erBvGy2i/MOjZrkm2xpmfh4SDBF1a3hDTxFYPwyllEnvGfDyi62a+pGx8cgoLEf -Zd5ICLqkTqnyg0Y3hOvozIFIQ2dOciqbXL1MGyiKXCJ7tKuY2e7gUYPDCUZObT6Z -+pUX2nwzV0E8jVHtC7ZcryxjGt9XyD+86V3Em69FmeKjWiS0uqlWPc9vqv9JWL7w -qP/0uK3pN/u6uPQLOvnoQ0IeidiEyxPx2bvhiWC4jChWrBQdnArncevPDt09qZah -SL0896+1DSJMwBGB7FY79tOi4lu3sgQiUpWAk2nojkxl8ZEDLXB0AuqLZxUpaVIC -u9ffUGpVRr+goyhhf3DQw6KqLCGqR84onAZFdr+CGCe01a60y1Dma/RMhnEw6abf -Fobg2P9A3fvQQoh/ozM6LlweQRGBY84YcWsr7KaKtzFcOmpH4MN5WdYgGq/yapiq -crxXStJLnbsQ/LBMQeXtHT1eKJ2czL+zUdqnR+WEUwIDAQABo0IwQDAdBgNVHQ4E -FgQUu69+Aj36pvE8hI6t7jiY7NkyMtQwDgYDVR0PAQH/BAQDAgEGMA8GA1UdEwEB -/wQFMAMBAf8wDQYJKoZIhvcNAQEMBQADggIBAArx1UaEt65Ru2yyTUEUAJNMnMvl -wFTPoCWOAvn9sKIN9SCYPBMtrFaisNZ+EZLpLrqeLppysb0ZRGxhNaKatBYSaVqM -4dc+pBroLwP0rmEdEBsqpIt6xf4FpuHA1sj+nq6PK7o9mfjYcwlYRm6mnPTXJ9OV -2jeDchzTc+CiR5kDOF3VSXkAKRzH7JsgHAckaVd4sjn8OoSgtZx8jb8uk2Intzna -FxiuvTwJaP+EmzzV1gsD41eeFPfR60/IvYcjt7ZJQ3mFXLrrkguhxuhoqEwWsRqZ -CuhTLJK7oQkYdQxlqHvLI7cawiiFwxv/0Cti76R7CZGYZ4wUAc1oBmpjIXUDgIiK -boHGhfKppC3n9KUkEEeDys30jXlYsQab5xoq2Z0B15R97QNKyvDb6KkBPvVWmcke -jkk9u+UJueBPSZI9FoJAzMxZxuY67RIuaTxslbH9qh17f4a+Hg4yRvv7E491f0yL -S0Zj/gA0QHDBw7mh3aZw4gSzQbzpgJHqZJx64SIDqZxubw5lT2yHh17zbqD5daWb -QOhTsiedSrnAdyGN/4fy3ryM7xfft0kL0fJuMAsaDk527RH89elWsn2/x20Kk4yl -0MC2Hb46TpSi125sC8KKfPog88Tk5c0NqMuRkrF8hey1FGlmDoLnzc7ILaZRfyHB -NVOFBkpdn627G190 ------END CERTIFICATE----- - -# Issuer: CN=USERTrust RSA Certification Authority O=The USERTRUST Network -# Subject: CN=USERTrust RSA Certification Authority O=The USERTRUST Network -# Label: "USERTrust RSA Certification Authority" -# Serial: 2645093764781058787591871645665788717 -# MD5 Fingerprint: 1b:fe:69:d1:91:b7:19:33:a3:72:a8:0f:e1:55:e5:b5 -# SHA1 Fingerprint: 2b:8f:1b:57:33:0d:bb:a2:d0:7a:6c:51:f7:0e:e9:0d:da:b9:ad:8e -# SHA256 Fingerprint: e7:93:c9:b0:2f:d8:aa:13:e2:1c:31:22:8a:cc:b0:81:19:64:3b:74:9c:89:89:64:b1:74:6d:46:c3:d4:cb:d2 ------BEGIN CERTIFICATE----- -MIIF3jCCA8agAwIBAgIQAf1tMPyjylGoG7xkDjUDLTANBgkqhkiG9w0BAQwFADCB -iDELMAkGA1UEBhMCVVMxEzARBgNVBAgTCk5ldyBKZXJzZXkxFDASBgNVBAcTC0pl -cnNleSBDaXR5MR4wHAYDVQQKExVUaGUgVVNFUlRSVVNUIE5ldHdvcmsxLjAsBgNV -BAMTJVVTRVJUcnVzdCBSU0EgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkwHhcNMTAw -MjAxMDAwMDAwWhcNMzgwMTE4MjM1OTU5WjCBiDELMAkGA1UEBhMCVVMxEzARBgNV -BAgTCk5ldyBKZXJzZXkxFDASBgNVBAcTC0plcnNleSBDaXR5MR4wHAYDVQQKExVU -aGUgVVNFUlRSVVNUIE5ldHdvcmsxLjAsBgNVBAMTJVVTRVJUcnVzdCBSU0EgQ2Vy -dGlmaWNhdGlvbiBBdXRob3JpdHkwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIK -AoICAQCAEmUXNg7D2wiz0KxXDXbtzSfTTK1Qg2HiqiBNCS1kCdzOiZ/MPans9s/B -3PHTsdZ7NygRK0faOca8Ohm0X6a9fZ2jY0K2dvKpOyuR+OJv0OwWIJAJPuLodMkY -tJHUYmTbf6MG8YgYapAiPLz+E/CHFHv25B+O1ORRxhFnRghRy4YUVD+8M/5+bJz/ -Fp0YvVGONaanZshyZ9shZrHUm3gDwFA66Mzw3LyeTP6vBZY1H1dat//O+T23LLb2 -VN3I5xI6Ta5MirdcmrS3ID3KfyI0rn47aGYBROcBTkZTmzNg95S+UzeQc0PzMsNT -79uq/nROacdrjGCT3sTHDN/hMq7MkztReJVni+49Vv4M0GkPGw/zJSZrM233bkf6 -c0Plfg6lZrEpfDKEY1WJxA3Bk1QwGROs0303p+tdOmw1XNtB1xLaqUkL39iAigmT -Yo61Zs8liM2EuLE/pDkP2QKe6xJMlXzzawWpXhaDzLhn4ugTncxbgtNMs+1b/97l -c6wjOy0AvzVVdAlJ2ElYGn+SNuZRkg7zJn0cTRe8yexDJtC/QV9AqURE9JnnV4ee -UB9XVKg+/XRjL7FQZQnmWEIuQxpMtPAlR1n6BB6T1CZGSlCBst6+eLf8ZxXhyVeE -Hg9j1uliutZfVS7qXMYoCAQlObgOK6nyTJccBz8NUvXt7y+CDwIDAQABo0IwQDAd -BgNVHQ4EFgQUU3m/WqorSs9UgOHYm8Cd8rIDZsswDgYDVR0PAQH/BAQDAgEGMA8G -A1UdEwEB/wQFMAMBAf8wDQYJKoZIhvcNAQEMBQADggIBAFzUfA3P9wF9QZllDHPF -Up/L+M+ZBn8b2kMVn54CVVeWFPFSPCeHlCjtHzoBN6J2/FNQwISbxmtOuowhT6KO -VWKR82kV2LyI48SqC/3vqOlLVSoGIG1VeCkZ7l8wXEskEVX/JJpuXior7gtNn3/3 -ATiUFJVDBwn7YKnuHKsSjKCaXqeYalltiz8I+8jRRa8YFWSQEg9zKC7F4iRO/Fjs -8PRF/iKz6y+O0tlFYQXBl2+odnKPi4w2r78NBc5xjeambx9spnFixdjQg3IM8WcR -iQycE0xyNN+81XHfqnHd4blsjDwSXWXavVcStkNr/+XeTWYRUc+ZruwXtuhxkYze -Sf7dNXGiFSeUHM9h4ya7b6NnJSFd5t0dCy5oGzuCr+yDZ4XUmFF0sbmZgIn/f3gZ -XHlKYC6SQK5MNyosycdiyA5d9zZbyuAlJQG03RoHnHcAP9Dc1ew91Pq7P8yF1m9/ -qS3fuQL39ZeatTXaw2ewh0qpKJ4jjv9cJ2vhsE/zB+4ALtRZh8tSQZXq9EfX7mRB -VXyNWQKV3WKdwrnuWih0hKWbt5DHDAff9Yk2dDLWKMGwsAvgnEzDHNb842m1R0aB -L6KCq9NjRHDEjf8tM7qtj3u1cIiuPhnPQCjY/MiQu12ZIvVS5ljFH4gxQ+6IHdfG -jjxDah2nGN59PRbxYvnKkKj9 ------END CERTIFICATE----- - -# Issuer: CN=USERTrust ECC Certification Authority O=The USERTRUST Network -# Subject: CN=USERTrust ECC Certification Authority O=The USERTRUST Network -# Label: "USERTrust ECC Certification Authority" -# Serial: 123013823720199481456569720443997572134 -# MD5 Fingerprint: fa:68:bc:d9:b5:7f:ad:fd:c9:1d:06:83:28:cc:24:c1 -# SHA1 Fingerprint: d1:cb:ca:5d:b2:d5:2a:7f:69:3b:67:4d:e5:f0:5a:1d:0c:95:7d:f0 -# SHA256 Fingerprint: 4f:f4:60:d5:4b:9c:86:da:bf:bc:fc:57:12:e0:40:0d:2b:ed:3f:bc:4d:4f:bd:aa:86:e0:6a:dc:d2:a9:ad:7a ------BEGIN CERTIFICATE----- -MIICjzCCAhWgAwIBAgIQXIuZxVqUxdJxVt7NiYDMJjAKBggqhkjOPQQDAzCBiDEL -MAkGA1UEBhMCVVMxEzARBgNVBAgTCk5ldyBKZXJzZXkxFDASBgNVBAcTC0plcnNl -eSBDaXR5MR4wHAYDVQQKExVUaGUgVVNFUlRSVVNUIE5ldHdvcmsxLjAsBgNVBAMT -JVVTRVJUcnVzdCBFQ0MgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkwHhcNMTAwMjAx -MDAwMDAwWhcNMzgwMTE4MjM1OTU5WjCBiDELMAkGA1UEBhMCVVMxEzARBgNVBAgT -Ck5ldyBKZXJzZXkxFDASBgNVBAcTC0plcnNleSBDaXR5MR4wHAYDVQQKExVUaGUg -VVNFUlRSVVNUIE5ldHdvcmsxLjAsBgNVBAMTJVVTRVJUcnVzdCBFQ0MgQ2VydGlm -aWNhdGlvbiBBdXRob3JpdHkwdjAQBgcqhkjOPQIBBgUrgQQAIgNiAAQarFRaqflo -I+d61SRvU8Za2EurxtW20eZzca7dnNYMYf3boIkDuAUU7FfO7l0/4iGzzvfUinng -o4N+LZfQYcTxmdwlkWOrfzCjtHDix6EznPO/LlxTsV+zfTJ/ijTjeXmjQjBAMB0G -A1UdDgQWBBQ64QmG1M8ZwpZ2dEl23OA1xmNjmjAOBgNVHQ8BAf8EBAMCAQYwDwYD -VR0TAQH/BAUwAwEB/zAKBggqhkjOPQQDAwNoADBlAjA2Z6EWCNzklwBBHU6+4WMB -zzuqQhFkoJ2UOQIReVx7Hfpkue4WQrO/isIJxOzksU0CMQDpKmFHjFJKS04YcPbW -RNZu9YO6bVi9JNlWSOrvxKJGgYhqOkbRqZtNyWHa0V1Xahg= ------END CERTIFICATE----- - -# Issuer: CN=GlobalSign O=GlobalSign OU=GlobalSign ECC Root CA - R5 -# Subject: CN=GlobalSign O=GlobalSign OU=GlobalSign ECC Root CA - R5 -# Label: "GlobalSign ECC Root CA - R5" -# Serial: 32785792099990507226680698011560947931244 -# MD5 Fingerprint: 9f:ad:3b:1c:02:1e:8a:ba:17:74:38:81:0c:a2:bc:08 -# SHA1 Fingerprint: 1f:24:c6:30:cd:a4:18:ef:20:69:ff:ad:4f:dd:5f:46:3a:1b:69:aa -# SHA256 Fingerprint: 17:9f:bc:14:8a:3d:d0:0f:d2:4e:a1:34:58:cc:43:bf:a7:f5:9c:81:82:d7:83:a5:13:f6:eb:ec:10:0c:89:24 ------BEGIN CERTIFICATE----- -MIICHjCCAaSgAwIBAgIRYFlJ4CYuu1X5CneKcflK2GwwCgYIKoZIzj0EAwMwUDEk -MCIGA1UECxMbR2xvYmFsU2lnbiBFQ0MgUm9vdCBDQSAtIFI1MRMwEQYDVQQKEwpH -bG9iYWxTaWduMRMwEQYDVQQDEwpHbG9iYWxTaWduMB4XDTEyMTExMzAwMDAwMFoX -DTM4MDExOTAzMTQwN1owUDEkMCIGA1UECxMbR2xvYmFsU2lnbiBFQ0MgUm9vdCBD -QSAtIFI1MRMwEQYDVQQKEwpHbG9iYWxTaWduMRMwEQYDVQQDEwpHbG9iYWxTaWdu -MHYwEAYHKoZIzj0CAQYFK4EEACIDYgAER0UOlvt9Xb/pOdEh+J8LttV7HpI6SFkc -8GIxLcB6KP4ap1yztsyX50XUWPrRd21DosCHZTQKH3rd6zwzocWdTaRvQZU4f8ke -hOvRnkmSh5SHDDqFSmafnVmTTZdhBoZKo0IwQDAOBgNVHQ8BAf8EBAMCAQYwDwYD -VR0TAQH/BAUwAwEB/zAdBgNVHQ4EFgQUPeYpSJvqB8ohREom3m7e0oPQn1kwCgYI -KoZIzj0EAwMDaAAwZQIxAOVpEslu28YxuglB4Zf4+/2a4n0Sye18ZNPLBSWLVtmg -515dTguDnFt2KaAJJiFqYgIwcdK1j1zqO+F4CYWodZI7yFz9SO8NdCKoCOJuxUnO -xwy8p2Fp8fc74SrL+SvzZpA3 ------END CERTIFICATE----- - -# Issuer: CN=IdenTrust Commercial Root CA 1 O=IdenTrust -# Subject: CN=IdenTrust Commercial Root CA 1 O=IdenTrust -# Label: "IdenTrust Commercial Root CA 1" -# Serial: 13298821034946342390520003877796839426 -# MD5 Fingerprint: b3:3e:77:73:75:ee:a0:d3:e3:7e:49:63:49:59:bb:c7 -# SHA1 Fingerprint: df:71:7e:aa:4a:d9:4e:c9:55:84:99:60:2d:48:de:5f:bc:f0:3a:25 -# SHA256 Fingerprint: 5d:56:49:9b:e4:d2:e0:8b:cf:ca:d0:8a:3e:38:72:3d:50:50:3b:de:70:69:48:e4:2f:55:60:30:19:e5:28:ae ------BEGIN CERTIFICATE----- -MIIFYDCCA0igAwIBAgIQCgFCgAAAAUUjyES1AAAAAjANBgkqhkiG9w0BAQsFADBK -MQswCQYDVQQGEwJVUzESMBAGA1UEChMJSWRlblRydXN0MScwJQYDVQQDEx5JZGVu -VHJ1c3QgQ29tbWVyY2lhbCBSb290IENBIDEwHhcNMTQwMTE2MTgxMjIzWhcNMzQw -MTE2MTgxMjIzWjBKMQswCQYDVQQGEwJVUzESMBAGA1UEChMJSWRlblRydXN0MScw -JQYDVQQDEx5JZGVuVHJ1c3QgQ29tbWVyY2lhbCBSb290IENBIDEwggIiMA0GCSqG -SIb3DQEBAQUAA4ICDwAwggIKAoICAQCnUBneP5k91DNG8W9RYYKyqU+PZ4ldhNlT -3Qwo2dfw/66VQ3KZ+bVdfIrBQuExUHTRgQ18zZshq0PirK1ehm7zCYofWjK9ouuU -+ehcCuz/mNKvcbO0U59Oh++SvL3sTzIwiEsXXlfEU8L2ApeN2WIrvyQfYo3fw7gp -S0l4PJNgiCL8mdo2yMKi1CxUAGc1bnO/AljwpN3lsKImesrgNqUZFvX9t++uP0D1 -bVoE/c40yiTcdCMbXTMTEl3EASX2MN0CXZ/g1Ue9tOsbobtJSdifWwLziuQkkORi -T0/Br4sOdBeo0XKIanoBScy0RnnGF7HamB4HWfp1IYVl3ZBWzvurpWCdxJ35UrCL -vYf5jysjCiN2O/cz4ckA82n5S6LgTrx+kzmEB/dEcH7+B1rlsazRGMzyNeVJSQjK -Vsk9+w8YfYs7wRPCTY/JTw436R+hDmrfYi7LNQZReSzIJTj0+kuniVyc0uMNOYZK -dHzVWYfCP04MXFL0PfdSgvHqo6z9STQaKPNBiDoT7uje/5kdX7rL6B7yuVBgwDHT -c+XvvqDtMwt0viAgxGds8AgDelWAf0ZOlqf0Hj7h9tgJ4TNkK2PXMl6f+cB7D3hv -l7yTmvmcEpB4eoCHFddydJxVdHixuuFucAS6T6C6aMN7/zHwcz09lCqxC0EOoP5N -iGVreTO01wIDAQABo0IwQDAOBgNVHQ8BAf8EBAMCAQYwDwYDVR0TAQH/BAUwAwEB -/zAdBgNVHQ4EFgQU7UQZwNPwBovupHu+QucmVMiONnYwDQYJKoZIhvcNAQELBQAD -ggIBAA2ukDL2pkt8RHYZYR4nKM1eVO8lvOMIkPkp165oCOGUAFjvLi5+U1KMtlwH -6oi6mYtQlNeCgN9hCQCTrQ0U5s7B8jeUeLBfnLOic7iPBZM4zY0+sLj7wM+x8uwt -LRvM7Kqas6pgghstO8OEPVeKlh6cdbjTMM1gCIOQ045U8U1mwF10A0Cj7oV+wh93 -nAbowacYXVKV7cndJZ5t+qntozo00Fl72u1Q8zW/7esUTTHHYPTa8Yec4kjixsU3 -+wYQ+nVZZjFHKdp2mhzpgq7vmrlR94gjmmmVYjzlVYA211QC//G5Xc7UI2/YRYRK -W2XviQzdFKcgyxilJbQN+QHwotL0AMh0jqEqSI5l2xPE4iUXfeu+h1sXIFRRk0pT -AwvsXcoz7WL9RccvW9xYoIA55vrX/hMUpu09lEpCdNTDd1lzzY9GvlU47/rokTLq -l1gEIt44w8y8bckzOmoKaT+gyOpyj4xjhiO9bTyWnpXgSUyqorkqG5w2gXjtw+hG -4iZZRHUe2XWJUc0QhJ1hYMtd+ZciTY6Y5uN/9lu7rs3KSoFrXgvzUeF0K+l+J6fZ -mUlO+KWA2yUPHGNiiskzZ2s8EIPGrd6ozRaOjfAHN3Gf8qv8QfXBi+wAN10J5U6A -7/qxXDgGpRtK4dw4LTzcqx+QGtVKnO7RcGzM7vRX+Bi6hG6H ------END CERTIFICATE----- - -# Issuer: CN=IdenTrust Public Sector Root CA 1 O=IdenTrust -# Subject: CN=IdenTrust Public Sector Root CA 1 O=IdenTrust -# Label: "IdenTrust Public Sector Root CA 1" -# Serial: 13298821034946342390521976156843933698 -# MD5 Fingerprint: 37:06:a5:b0:fc:89:9d:ba:f4:6b:8c:1a:64:cd:d5:ba -# SHA1 Fingerprint: ba:29:41:60:77:98:3f:f4:f3:ef:f2:31:05:3b:2e:ea:6d:4d:45:fd -# SHA256 Fingerprint: 30:d0:89:5a:9a:44:8a:26:20:91:63:55:22:d1:f5:20:10:b5:86:7a:ca:e1:2c:78:ef:95:8f:d4:f4:38:9f:2f ------BEGIN CERTIFICATE----- -MIIFZjCCA06gAwIBAgIQCgFCgAAAAUUjz0Z8AAAAAjANBgkqhkiG9w0BAQsFADBN -MQswCQYDVQQGEwJVUzESMBAGA1UEChMJSWRlblRydXN0MSowKAYDVQQDEyFJZGVu -VHJ1c3QgUHVibGljIFNlY3RvciBSb290IENBIDEwHhcNMTQwMTE2MTc1MzMyWhcN -MzQwMTE2MTc1MzMyWjBNMQswCQYDVQQGEwJVUzESMBAGA1UEChMJSWRlblRydXN0 -MSowKAYDVQQDEyFJZGVuVHJ1c3QgUHVibGljIFNlY3RvciBSb290IENBIDEwggIi -MA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQC2IpT8pEiv6EdrCvsnduTyP4o7 -ekosMSqMjbCpwzFrqHd2hCa2rIFCDQjrVVi7evi8ZX3yoG2LqEfpYnYeEe4IFNGy -RBb06tD6Hi9e28tzQa68ALBKK0CyrOE7S8ItneShm+waOh7wCLPQ5CQ1B5+ctMlS -bdsHyo+1W/CD80/HLaXIrcuVIKQxKFdYWuSNG5qrng0M8gozOSI5Cpcu81N3uURF -/YTLNiCBWS2ab21ISGHKTN9T0a9SvESfqy9rg3LvdYDaBjMbXcjaY8ZNzaxmMc3R -3j6HEDbhuaR672BQssvKplbgN6+rNBM5Jeg5ZuSYeqoSmJxZZoY+rfGwyj4GD3vw -EUs3oERte8uojHH01bWRNszwFcYr3lEXsZdMUD2xlVl8BX0tIdUAvwFnol57plzy -9yLxkA2T26pEUWbMfXYD62qoKjgZl3YNa4ph+bz27nb9cCvdKTz4Ch5bQhyLVi9V -GxyhLrXHFub4qjySjmm2AcG1hp2JDws4lFTo6tyePSW8Uybt1as5qsVATFSrsrTZ -2fjXctscvG29ZV/viDUqZi/u9rNl8DONfJhBaUYPQxxp+pu10GFqzcpL2UyQRqsV -WaFHVCkugyhfHMKiq3IXAAaOReyL4jM9f9oZRORicsPfIsbyVtTdX5Vy7W1f90gD -W/3FKqD2cyOEEBsB5wIDAQABo0IwQDAOBgNVHQ8BAf8EBAMCAQYwDwYDVR0TAQH/ -BAUwAwEB/zAdBgNVHQ4EFgQU43HgntinQtnbcZFrlJPrw6PRFKMwDQYJKoZIhvcN -AQELBQADggIBAEf63QqwEZE4rU1d9+UOl1QZgkiHVIyqZJnYWv6IAcVYpZmxI1Qj -t2odIFflAWJBF9MJ23XLblSQdf4an4EKwt3X9wnQW3IV5B4Jaj0z8yGa5hV+rVHV -DRDtfULAj+7AmgjVQdZcDiFpboBhDhXAuM/FSRJSzL46zNQuOAXeNf0fb7iAaJg9 -TaDKQGXSc3z1i9kKlT/YPyNtGtEqJBnZhbMX73huqVjRI9PHE+1yJX9dsXNw0H8G -lwmEKYBhHfpe/3OsoOOJuBxxFcbeMX8S3OFtm6/n6J91eEyrRjuazr8FGF1NFTwW -mhlQBJqymm9li1JfPFgEKCXAZmExfrngdbkaqIHWchezxQMxNRF4eKLg6TCMf4Df -WN88uieW4oA0beOY02QnrEh+KHdcxiVhJfiFDGX6xDIvpZgF5PgLZxYWxoK4Mhn5 -+bl53B/N66+rDt0b20XkeucC4pVd/GnwU2lhlXV5C15V5jgclKlZM57IcXR5f1GJ -tshquDDIajjDbp7hNxbqBWJMWxJH7ae0s1hWx0nzfxJoCTFx8G34Tkf71oXuxVhA -GaQdp/lLQzfcaFpPz+vCZHTetBXZ9FRUGi8c15dxVJCO2SCdUyt/q4/i6jC8UDfv -8Ue1fXwsBOxonbRJRBD0ckscZOf85muQ3Wl9af0AVqW3rLatt8o+Ae+c ------END CERTIFICATE----- - -# Issuer: CN=CFCA EV ROOT O=China Financial Certification Authority -# Subject: CN=CFCA EV ROOT O=China Financial Certification Authority -# Label: "CFCA EV ROOT" -# Serial: 407555286 -# MD5 Fingerprint: 74:e1:b6:ed:26:7a:7a:44:30:33:94:ab:7b:27:81:30 -# SHA1 Fingerprint: e2:b8:29:4b:55:84:ab:6b:58:c2:90:46:6c:ac:3f:b8:39:8f:84:83 -# SHA256 Fingerprint: 5c:c3:d7:8e:4e:1d:5e:45:54:7a:04:e6:87:3e:64:f9:0c:f9:53:6d:1c:cc:2e:f8:00:f3:55:c4:c5:fd:70:fd ------BEGIN CERTIFICATE----- -MIIFjTCCA3WgAwIBAgIEGErM1jANBgkqhkiG9w0BAQsFADBWMQswCQYDVQQGEwJD -TjEwMC4GA1UECgwnQ2hpbmEgRmluYW5jaWFsIENlcnRpZmljYXRpb24gQXV0aG9y -aXR5MRUwEwYDVQQDDAxDRkNBIEVWIFJPT1QwHhcNMTIwODA4MDMwNzAxWhcNMjkx -MjMxMDMwNzAxWjBWMQswCQYDVQQGEwJDTjEwMC4GA1UECgwnQ2hpbmEgRmluYW5j -aWFsIENlcnRpZmljYXRpb24gQXV0aG9yaXR5MRUwEwYDVQQDDAxDRkNBIEVWIFJP -T1QwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQDXXWvNED8fBVnVBU03 -sQ7smCuOFR36k0sXgiFxEFLXUWRwFsJVaU2OFW2fvwwbwuCjZ9YMrM8irq93VCpL -TIpTUnrD7i7es3ElweldPe6hL6P3KjzJIx1qqx2hp/Hz7KDVRM8Vz3IvHWOX6Jn5 -/ZOkVIBMUtRSqy5J35DNuF++P96hyk0g1CXohClTt7GIH//62pCfCqktQT+x8Rgp -7hZZLDRJGqgG16iI0gNyejLi6mhNbiyWZXvKWfry4t3uMCz7zEasxGPrb382KzRz -EpR/38wmnvFyXVBlWY9ps4deMm/DGIq1lY+wejfeWkU7xzbh72fROdOXW3NiGUgt -hxwG+3SYIElz8AXSG7Ggo7cbcNOIabla1jj0Ytwli3i/+Oh+uFzJlU9fpy25IGvP -a931DfSCt/SyZi4QKPaXWnuWFo8BGS1sbn85WAZkgwGDg8NNkt0yxoekN+kWzqot -aK8KgWU6cMGbrU1tVMoqLUuFG7OA5nBFDWteNfB/O7ic5ARwiRIlk9oKmSJgamNg -TnYGmE69g60dWIolhdLHZR4tjsbftsbhf4oEIRUpdPA+nJCdDC7xij5aqgwJHsfV -PKPtl8MeNPo4+QgO48BdK4PRVmrJtqhUUy54Mmc9gn900PvhtgVguXDbjgv5E1hv -cWAQUhC5wUEJ73IfZzF4/5YFjQIDAQABo2MwYTAfBgNVHSMEGDAWgBTj/i39KNAL -tbq2osS/BqoFjJP7LzAPBgNVHRMBAf8EBTADAQH/MA4GA1UdDwEB/wQEAwIBBjAd -BgNVHQ4EFgQU4/4t/SjQC7W6tqLEvwaqBYyT+y8wDQYJKoZIhvcNAQELBQADggIB -ACXGumvrh8vegjmWPfBEp2uEcwPenStPuiB/vHiyz5ewG5zz13ku9Ui20vsXiObT -ej/tUxPQ4i9qecsAIyjmHjdXNYmEwnZPNDatZ8POQQaIxffu2Bq41gt/UP+TqhdL -jOztUmCypAbqTuv0axn96/Ua4CUqmtzHQTb3yHQFhDmVOdYLO6Qn+gjYXB74BGBS -ESgoA//vU2YApUo0FmZ8/Qmkrp5nGm9BC2sGE5uPhnEFtC+NiWYzKXZUmhH4J/qy -P5Hgzg0b8zAarb8iXRvTvyUFTeGSGn+ZnzxEk8rUQElsgIfXBDrDMlI1Dlb4pd19 -xIsNER9Tyx6yF7Zod1rg1MvIB671Oi6ON7fQAUtDKXeMOZePglr4UeWJoBjnaH9d -Ci77o0cOPaYjesYBx4/IXr9tgFa+iiS6M+qf4TIRnvHST4D2G0CvOJ4RUHlzEhLN -5mydLIhyPDCBBpEi6lmt2hkuIsKNuYyH4Ga8cyNfIWRjgEj1oDwYPZTISEEdQLpe -/v5WOaHIz16eGWRGENoXkbcFgKyLmZJ956LYBws2J+dIeWCKw9cTXPhyQN9Ky8+Z -AAoACxGV2lZFA4gKn2fQ1XmxqI1AbQ3CekD6819kR5LLU7m7Wc5P/dAVUwHY3+vZ -5nbv0CO7O6l5s9UCKc2Jo5YPSjXnTkLAdc0Hz+Ys63su ------END CERTIFICATE----- - -# Issuer: CN=OISTE WISeKey Global Root GB CA O=WISeKey OU=OISTE Foundation Endorsed -# Subject: CN=OISTE WISeKey Global Root GB CA O=WISeKey OU=OISTE Foundation Endorsed -# Label: "OISTE WISeKey Global Root GB CA" -# Serial: 157768595616588414422159278966750757568 -# MD5 Fingerprint: a4:eb:b9:61:28:2e:b7:2f:98:b0:35:26:90:99:51:1d -# SHA1 Fingerprint: 0f:f9:40:76:18:d3:d7:6a:4b:98:f0:a8:35:9e:0c:fd:27:ac:cc:ed -# SHA256 Fingerprint: 6b:9c:08:e8:6e:b0:f7:67:cf:ad:65:cd:98:b6:21:49:e5:49:4a:67:f5:84:5e:7b:d1:ed:01:9f:27:b8:6b:d6 ------BEGIN CERTIFICATE----- -MIIDtTCCAp2gAwIBAgIQdrEgUnTwhYdGs/gjGvbCwDANBgkqhkiG9w0BAQsFADBt -MQswCQYDVQQGEwJDSDEQMA4GA1UEChMHV0lTZUtleTEiMCAGA1UECxMZT0lTVEUg -Rm91bmRhdGlvbiBFbmRvcnNlZDEoMCYGA1UEAxMfT0lTVEUgV0lTZUtleSBHbG9i -YWwgUm9vdCBHQiBDQTAeFw0xNDEyMDExNTAwMzJaFw0zOTEyMDExNTEwMzFaMG0x -CzAJBgNVBAYTAkNIMRAwDgYDVQQKEwdXSVNlS2V5MSIwIAYDVQQLExlPSVNURSBG -b3VuZGF0aW9uIEVuZG9yc2VkMSgwJgYDVQQDEx9PSVNURSBXSVNlS2V5IEdsb2Jh -bCBSb290IEdCIENBMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA2Be3 -HEokKtaXscriHvt9OO+Y9bI5mE4nuBFde9IllIiCFSZqGzG7qFshISvYD06fWvGx -WuR51jIjK+FTzJlFXHtPrby/h0oLS5daqPZI7H17Dc0hBt+eFf1Biki3IPShehtX -1F1Q/7pn2COZH8g/497/b1t3sWtuuMlk9+HKQUYOKXHQuSP8yYFfTvdv37+ErXNk -u7dCjmn21HYdfp2nuFeKUWdy19SouJVUQHMD9ur06/4oQnc/nSMbsrY9gBQHTC5P -99UKFg29ZkM3fiNDecNAhvVMKdqOmq0NpQSHiB6F4+lT1ZvIiwNjeOvgGUpuuy9r -M2RYk61pv48b74JIxwIDAQABo1EwTzALBgNVHQ8EBAMCAYYwDwYDVR0TAQH/BAUw -AwEB/zAdBgNVHQ4EFgQUNQ/INmNe4qPs+TtmFc5RUuORmj0wEAYJKwYBBAGCNxUB -BAMCAQAwDQYJKoZIhvcNAQELBQADggEBAEBM+4eymYGQfp3FsLAmzYh7KzKNbrgh -cViXfa43FK8+5/ea4n32cZiZBKpDdHij40lhPnOMTZTg+XHEthYOU3gf1qKHLwI5 -gSk8rxWYITD+KJAAjNHhy/peyP34EEY7onhCkRd0VQreUGdNZtGn//3ZwLWoo4rO -ZvUPQ82nK1d7Y0Zqqi5S2PTt4W2tKZB4SLrhI6qjiey1q5bAtEuiHZeeevJuQHHf -aPFlTc58Bd9TZaml8LGXBHAVRgOY1NK/VLSgWH1Sb9pWJmLU2NuJMW8c8CLC02Ic -Nc1MaRVUGpCY3useX8p3x8uOPUNpnJpY0CQ73xtAln41rYHHTnG6iBM= ------END CERTIFICATE----- - -# Issuer: CN=SZAFIR ROOT CA2 O=Krajowa Izba Rozliczeniowa S.A. -# Subject: CN=SZAFIR ROOT CA2 O=Krajowa Izba Rozliczeniowa S.A. -# Label: "SZAFIR ROOT CA2" -# Serial: 357043034767186914217277344587386743377558296292 -# MD5 Fingerprint: 11:64:c1:89:b0:24:b1:8c:b1:07:7e:89:9e:51:9e:99 -# SHA1 Fingerprint: e2:52:fa:95:3f:ed:db:24:60:bd:6e:28:f3:9c:cc:cf:5e:b3:3f:de -# SHA256 Fingerprint: a1:33:9d:33:28:1a:0b:56:e5:57:d3:d3:2b:1c:e7:f9:36:7e:b0:94:bd:5f:a7:2a:7e:50:04:c8:de:d7:ca:fe ------BEGIN CERTIFICATE----- -MIIDcjCCAlqgAwIBAgIUPopdB+xV0jLVt+O2XwHrLdzk1uQwDQYJKoZIhvcNAQEL -BQAwUTELMAkGA1UEBhMCUEwxKDAmBgNVBAoMH0tyYWpvd2EgSXpiYSBSb3psaWN6 -ZW5pb3dhIFMuQS4xGDAWBgNVBAMMD1NaQUZJUiBST09UIENBMjAeFw0xNTEwMTkw -NzQzMzBaFw0zNTEwMTkwNzQzMzBaMFExCzAJBgNVBAYTAlBMMSgwJgYDVQQKDB9L -cmFqb3dhIEl6YmEgUm96bGljemVuaW93YSBTLkEuMRgwFgYDVQQDDA9TWkFGSVIg -Uk9PVCBDQTIwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQC3vD5QqEvN -QLXOYeeWyrSh2gwisPq1e3YAd4wLz32ohswmUeQgPYUM1ljj5/QqGJ3a0a4m7utT -3PSQ1hNKDJA8w/Ta0o4NkjrcsbH/ON7Dui1fgLkCvUqdGw+0w8LBZwPd3BucPbOw -3gAeqDRHu5rr/gsUvTaE2g0gv/pby6kWIK05YO4vdbbnl5z5Pv1+TW9NL++IDWr6 -3fE9biCloBK0TXC5ztdyO4mTp4CEHCdJckm1/zuVnsHMyAHs6A6KCpbns6aH5db5 -BSsNl0BwPLqsdVqc1U2dAgrSS5tmS0YHF2Wtn2yIANwiieDhZNRnvDF5YTy7ykHN -XGoAyDw4jlivAgMBAAGjQjBAMA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQD -AgEGMB0GA1UdDgQWBBQuFqlKGLXLzPVvUPMjX/hd56zwyDANBgkqhkiG9w0BAQsF -AAOCAQEAtXP4A9xZWx126aMqe5Aosk3AM0+qmrHUuOQn/6mWmc5G4G18TKI4pAZw -8PRBEew/R40/cof5O/2kbytTAOD/OblqBw7rHRz2onKQy4I9EYKL0rufKq8h5mOG -nXkZ7/e7DDWQw4rtTw/1zBLZpD67oPwglV9PJi8RI4NOdQcPv5vRtB3pEAT+ymCP -oky4rc/hkA/NrgrHXXu3UNLUYfrVFdvXn4dRVOul4+vJhaAlIDf7js4MNIThPIGy -d05DpYhfhmehPea0XGG2Ptv+tyjFogeutcrKjSoS75ftwjCkySp6+/NNIxuZMzSg -LvWpCz/UXeHPhJ/iGcJfitYgHuNztw== ------END CERTIFICATE----- - -# Issuer: CN=Certum Trusted Network CA 2 O=Unizeto Technologies S.A. OU=Certum Certification Authority -# Subject: CN=Certum Trusted Network CA 2 O=Unizeto Technologies S.A. OU=Certum Certification Authority -# Label: "Certum Trusted Network CA 2" -# Serial: 44979900017204383099463764357512596969 -# MD5 Fingerprint: 6d:46:9e:d9:25:6d:08:23:5b:5e:74:7d:1e:27:db:f2 -# SHA1 Fingerprint: d3:dd:48:3e:2b:bf:4c:05:e8:af:10:f5:fa:76:26:cf:d3:dc:30:92 -# SHA256 Fingerprint: b6:76:f2:ed:da:e8:77:5c:d3:6c:b0:f6:3c:d1:d4:60:39:61:f4:9e:62:65:ba:01:3a:2f:03:07:b6:d0:b8:04 ------BEGIN CERTIFICATE----- -MIIF0jCCA7qgAwIBAgIQIdbQSk8lD8kyN/yqXhKN6TANBgkqhkiG9w0BAQ0FADCB -gDELMAkGA1UEBhMCUEwxIjAgBgNVBAoTGVVuaXpldG8gVGVjaG5vbG9naWVzIFMu -QS4xJzAlBgNVBAsTHkNlcnR1bSBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTEkMCIG -A1UEAxMbQ2VydHVtIFRydXN0ZWQgTmV0d29yayBDQSAyMCIYDzIwMTExMDA2MDgz -OTU2WhgPMjA0NjEwMDYwODM5NTZaMIGAMQswCQYDVQQGEwJQTDEiMCAGA1UEChMZ -VW5pemV0byBUZWNobm9sb2dpZXMgUy5BLjEnMCUGA1UECxMeQ2VydHVtIENlcnRp -ZmljYXRpb24gQXV0aG9yaXR5MSQwIgYDVQQDExtDZXJ0dW0gVHJ1c3RlZCBOZXR3 -b3JrIENBIDIwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQC9+Xj45tWA -DGSdhhuWZGc/IjoedQF97/tcZ4zJzFxrqZHmuULlIEub2pt7uZld2ZuAS9eEQCsn -0+i6MLs+CRqnSZXvK0AkwpfHp+6bJe+oCgCXhVqqndwpyeI1B+twTUrWwbNWuKFB -OJvR+zF/j+Bf4bE/D44WSWDXBo0Y+aomEKsq09DRZ40bRr5HMNUuctHFY9rnY3lE -fktjJImGLjQ/KUxSiyqnwOKRKIm5wFv5HdnnJ63/mgKXwcZQkpsCLL2puTRZCr+E -Sv/f/rOf69me4Jgj7KZrdxYq28ytOxykh9xGc14ZYmhFV+SQgkK7QtbwYeDBoz1m -o130GO6IyY0XRSmZMnUCMe4pJshrAua1YkV/NxVaI2iJ1D7eTiew8EAMvE0Xy02i -sx7QBlrd9pPPV3WZ9fqGGmd4s7+W/jTcvedSVuWz5XV710GRBdxdaeOVDUO5/IOW -OZV7bIBaTxNyxtd9KXpEulKkKtVBRgkg/iKgtlswjbyJDNXXcPiHUv3a76xRLgez -Tv7QCdpw75j6VuZt27VXS9zlLCUVyJ4ueE742pyehizKV/Ma5ciSixqClnrDvFAS -adgOWkaLOusm+iPJtrCBvkIApPjW/jAux9JG9uWOdf3yzLnQh1vMBhBgu4M1t15n -3kfsmUjxpKEV/q2MYo45VU85FrmxY53/twIDAQABo0IwQDAPBgNVHRMBAf8EBTAD -AQH/MB0GA1UdDgQWBBS2oVQ5AsOgP46KvPrU+Bym0ToO/TAOBgNVHQ8BAf8EBAMC -AQYwDQYJKoZIhvcNAQENBQADggIBAHGlDs7k6b8/ONWJWsQCYftMxRQXLYtPU2sQ -F/xlhMcQSZDe28cmk4gmb3DWAl45oPePq5a1pRNcgRRtDoGCERuKTsZPpd1iHkTf -CVn0W3cLN+mLIMb4Ck4uWBzrM9DPhmDJ2vuAL55MYIR4PSFk1vtBHxgP58l1cb29 -XN40hz5BsA72udY/CROWFC/emh1auVbONTqwX3BNXuMp8SMoclm2q8KMZiYcdywm -djWLKKdpoPk79SPdhRB0yZADVpHnr7pH1BKXESLjokmUbOe3lEu6LaTaM4tMpkT/ -WjzGHWTYtTHkpjx6qFcL2+1hGsvxznN3Y6SHb0xRONbkX8eftoEq5IVIeVheO/jb -AoJnwTnbw3RLPTYe+SmTiGhbqEQZIfCn6IENLOiTNrQ3ssqwGyZ6miUfmpqAnksq -P/ujmv5zMnHCnsZy4YpoJ/HkD7TETKVhk/iXEAcqMCWpuchxuO9ozC1+9eB+D4Ko -b7a6bINDd82Kkhehnlt4Fj1F4jNy3eFmypnTycUm/Q1oBEauttmbjL4ZvrHG8hnj -XALKLNhvSgfZyTXaQHXyxKcZb55CEJh15pWLYLztxRLXis7VmFxWlgPF7ncGNf/P -5O4/E2Hu29othfDNrp2yGAlFw5Khchf8R7agCyzxxN5DaAhqXzvwdmP7zAYspsbi -DrW5viSP ------END CERTIFICATE----- - -# Issuer: CN=Hellenic Academic and Research Institutions RootCA 2015 O=Hellenic Academic and Research Institutions Cert. Authority -# Subject: CN=Hellenic Academic and Research Institutions RootCA 2015 O=Hellenic Academic and Research Institutions Cert. Authority -# Label: "Hellenic Academic and Research Institutions RootCA 2015" -# Serial: 0 -# MD5 Fingerprint: ca:ff:e2:db:03:d9:cb:4b:e9:0f:ad:84:fd:7b:18:ce -# SHA1 Fingerprint: 01:0c:06:95:a6:98:19:14:ff:bf:5f:c6:b0:b6:95:ea:29:e9:12:a6 -# SHA256 Fingerprint: a0:40:92:9a:02:ce:53:b4:ac:f4:f2:ff:c6:98:1c:e4:49:6f:75:5e:6d:45:fe:0b:2a:69:2b:cd:52:52:3f:36 ------BEGIN CERTIFICATE----- -MIIGCzCCA/OgAwIBAgIBADANBgkqhkiG9w0BAQsFADCBpjELMAkGA1UEBhMCR1Ix -DzANBgNVBAcTBkF0aGVuczFEMEIGA1UEChM7SGVsbGVuaWMgQWNhZGVtaWMgYW5k -IFJlc2VhcmNoIEluc3RpdHV0aW9ucyBDZXJ0LiBBdXRob3JpdHkxQDA+BgNVBAMT -N0hlbGxlbmljIEFjYWRlbWljIGFuZCBSZXNlYXJjaCBJbnN0aXR1dGlvbnMgUm9v -dENBIDIwMTUwHhcNMTUwNzA3MTAxMTIxWhcNNDAwNjMwMTAxMTIxWjCBpjELMAkG -A1UEBhMCR1IxDzANBgNVBAcTBkF0aGVuczFEMEIGA1UEChM7SGVsbGVuaWMgQWNh -ZGVtaWMgYW5kIFJlc2VhcmNoIEluc3RpdHV0aW9ucyBDZXJ0LiBBdXRob3JpdHkx -QDA+BgNVBAMTN0hlbGxlbmljIEFjYWRlbWljIGFuZCBSZXNlYXJjaCBJbnN0aXR1 -dGlvbnMgUm9vdENBIDIwMTUwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoIC -AQDC+Kk/G4n8PDwEXT2QNrCROnk8ZlrvbTkBSRq0t89/TSNTt5AA4xMqKKYx8ZEA -4yjsriFBzh/a/X0SWwGDD7mwX5nh8hKDgE0GPt+sr+ehiGsxr/CL0BgzuNtFajT0 -AoAkKAoCFZVedioNmToUW/bLy1O8E00BiDeUJRtCvCLYjqOWXjrZMts+6PAQZe10 -4S+nfK8nNLspfZu2zwnI5dMK/IhlZXQK3HMcXM1AsRzUtoSMTFDPaI6oWa7CJ06C -ojXdFPQf/7J31Ycvqm59JCfnxssm5uX+Zwdj2EUN3TpZZTlYepKZcj2chF6IIbjV -9Cz82XBST3i4vTwri5WY9bPRaM8gFH5MXF/ni+X1NYEZN9cRCLdmvtNKzoNXADrD -gfgXy5I2XdGj2HUb4Ysn6npIQf1FGQatJ5lOwXBH3bWfgVMS5bGMSF0xQxfjjMZ6 -Y5ZLKTBOhE5iGV48zpeQpX8B653g+IuJ3SWYPZK2fu/Z8VFRfS0myGlZYeCsargq -NhEEelC9MoS+L9xy1dcdFkfkR2YgP/SWxa+OAXqlD3pk9Q0Yh9muiNX6hME6wGko -LfINaFGq46V3xqSQDqE3izEjR8EJCOtu93ib14L8hCCZSRm2Ekax+0VVFqmjZayc -Bw/qa9wfLgZy7IaIEuQt218FL+TwA9MmM+eAws1CoRc0CwIDAQABo0IwQDAPBgNV -HRMBAf8EBTADAQH/MA4GA1UdDwEB/wQEAwIBBjAdBgNVHQ4EFgQUcRVnyMjJvXVd -ctA4GGqd83EkVAswDQYJKoZIhvcNAQELBQADggIBAHW7bVRLqhBYRjTyYtcWNl0I -XtVsyIe9tC5G8jH4fOpCtZMWVdyhDBKg2mF+D1hYc2Ryx+hFjtyp8iY/xnmMsVMI -M4GwVhO+5lFc2JsKT0ucVlMC6U/2DWDqTUJV6HwbISHTGzrMd/K4kPFox/la/vot -9L/J9UUbzjgQKjeKeaO04wlshYaT/4mWJ3iBj2fjRnRUjtkNaeJK9E10A/+yd+2V -Z5fkscWrv2oj6NSU4kQoYsRL4vDY4ilrGnB+JGGTe08DMiUNRSQrlrRGar9KC/ea -j8GsGsVn82800vpzY4zvFrCopEYq+OsS7HK07/grfoxSwIuEVPkvPuNVqNxmsdnh -X9izjFk0WaSrT2y7HxjbdavYy5LNlDhhDgcGH0tGEPEVvo2FXDtKK4F5D7Rpn0lQ -l033DlZdwJVqwjbDG2jJ9SrcR5q+ss7FJej6A7na+RZukYT1HCjI/CbM1xyQVqdf -bzoEvM14iQuODy+jqk+iGxI9FghAD/FGTNeqewjBCvVtJ94Cj8rDtSvK6evIIVM4 -pcw72Hc3MKJP2W/R8kCtQXoXxdZKNYm3QdV8hn9VTYNKpXMgwDqvkPGaJI7ZjnHK -e7iG2rKPmT4dEw0SEe7Uq/DpFXYC5ODfqiAeW2GFZECpkJcNrVPSWh2HagCXZWK0 -vm9qp/UsQu0yrbYhnr68 ------END CERTIFICATE----- - -# Issuer: CN=Hellenic Academic and Research Institutions ECC RootCA 2015 O=Hellenic Academic and Research Institutions Cert. Authority -# Subject: CN=Hellenic Academic and Research Institutions ECC RootCA 2015 O=Hellenic Academic and Research Institutions Cert. Authority -# Label: "Hellenic Academic and Research Institutions ECC RootCA 2015" -# Serial: 0 -# MD5 Fingerprint: 81:e5:b4:17:eb:c2:f5:e1:4b:0d:41:7b:49:92:fe:ef -# SHA1 Fingerprint: 9f:f1:71:8d:92:d5:9a:f3:7d:74:97:b4:bc:6f:84:68:0b:ba:b6:66 -# SHA256 Fingerprint: 44:b5:45:aa:8a:25:e6:5a:73:ca:15:dc:27:fc:36:d2:4c:1c:b9:95:3a:06:65:39:b1:15:82:dc:48:7b:48:33 ------BEGIN CERTIFICATE----- -MIICwzCCAkqgAwIBAgIBADAKBggqhkjOPQQDAjCBqjELMAkGA1UEBhMCR1IxDzAN -BgNVBAcTBkF0aGVuczFEMEIGA1UEChM7SGVsbGVuaWMgQWNhZGVtaWMgYW5kIFJl -c2VhcmNoIEluc3RpdHV0aW9ucyBDZXJ0LiBBdXRob3JpdHkxRDBCBgNVBAMTO0hl -bGxlbmljIEFjYWRlbWljIGFuZCBSZXNlYXJjaCBJbnN0aXR1dGlvbnMgRUNDIFJv -b3RDQSAyMDE1MB4XDTE1MDcwNzEwMzcxMloXDTQwMDYzMDEwMzcxMlowgaoxCzAJ -BgNVBAYTAkdSMQ8wDQYDVQQHEwZBdGhlbnMxRDBCBgNVBAoTO0hlbGxlbmljIEFj -YWRlbWljIGFuZCBSZXNlYXJjaCBJbnN0aXR1dGlvbnMgQ2VydC4gQXV0aG9yaXR5 -MUQwQgYDVQQDEztIZWxsZW5pYyBBY2FkZW1pYyBhbmQgUmVzZWFyY2ggSW5zdGl0 -dXRpb25zIEVDQyBSb290Q0EgMjAxNTB2MBAGByqGSM49AgEGBSuBBAAiA2IABJKg -QehLgoRc4vgxEZmGZE4JJS+dQS8KrjVPdJWyUWRrjWvmP3CV8AVER6ZyOFB2lQJa -jq4onvktTpnvLEhvTCUp6NFxW98dwXU3tNf6e3pCnGoKVlp8aQuqgAkkbH7BRqNC -MEAwDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwHQYDVR0OBBYEFLQi -C4KZJAEOnLvkDv2/+5cgk5kqMAoGCCqGSM49BAMCA2cAMGQCMGfOFmI4oqxiRaep -lSTAGiecMjvAwNW6qef4BENThe5SId6d9SWDPp5YSy/XZxMOIQIwBeF1Ad5o7Sof -TUwJCA3sS61kFyjndc5FZXIhF8siQQ6ME5g4mlRtm8rifOoCWCKR ------END CERTIFICATE----- - -# Issuer: CN=ISRG Root X1 O=Internet Security Research Group -# Subject: CN=ISRG Root X1 O=Internet Security Research Group -# Label: "ISRG Root X1" -# Serial: 172886928669790476064670243504169061120 -# MD5 Fingerprint: 0c:d2:f9:e0:da:17:73:e9:ed:86:4d:a5:e3:70:e7:4e -# SHA1 Fingerprint: ca:bd:2a:79:a1:07:6a:31:f2:1d:25:36:35:cb:03:9d:43:29:a5:e8 -# SHA256 Fingerprint: 96:bc:ec:06:26:49:76:f3:74:60:77:9a:cf:28:c5:a7:cf:e8:a3:c0:aa:e1:1a:8f:fc:ee:05:c0:bd:df:08:c6 ------BEGIN CERTIFICATE----- -MIIFazCCA1OgAwIBAgIRAIIQz7DSQONZRGPgu2OCiwAwDQYJKoZIhvcNAQELBQAw -TzELMAkGA1UEBhMCVVMxKTAnBgNVBAoTIEludGVybmV0IFNlY3VyaXR5IFJlc2Vh -cmNoIEdyb3VwMRUwEwYDVQQDEwxJU1JHIFJvb3QgWDEwHhcNMTUwNjA0MTEwNDM4 -WhcNMzUwNjA0MTEwNDM4WjBPMQswCQYDVQQGEwJVUzEpMCcGA1UEChMgSW50ZXJu -ZXQgU2VjdXJpdHkgUmVzZWFyY2ggR3JvdXAxFTATBgNVBAMTDElTUkcgUm9vdCBY -MTCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAK3oJHP0FDfzm54rVygc -h77ct984kIxuPOZXoHj3dcKi/vVqbvYATyjb3miGbESTtrFj/RQSa78f0uoxmyF+ -0TM8ukj13Xnfs7j/EvEhmkvBioZxaUpmZmyPfjxwv60pIgbz5MDmgK7iS4+3mX6U -A5/TR5d8mUgjU+g4rk8Kb4Mu0UlXjIB0ttov0DiNewNwIRt18jA8+o+u3dpjq+sW -T8KOEUt+zwvo/7V3LvSye0rgTBIlDHCNAymg4VMk7BPZ7hm/ELNKjD+Jo2FR3qyH -B5T0Y3HsLuJvW5iB4YlcNHlsdu87kGJ55tukmi8mxdAQ4Q7e2RCOFvu396j3x+UC -B5iPNgiV5+I3lg02dZ77DnKxHZu8A/lJBdiB3QW0KtZB6awBdpUKD9jf1b0SHzUv -KBds0pjBqAlkd25HN7rOrFleaJ1/ctaJxQZBKT5ZPt0m9STJEadao0xAH0ahmbWn -OlFuhjuefXKnEgV4We0+UXgVCwOPjdAvBbI+e0ocS3MFEvzG6uBQE3xDk3SzynTn -jh8BCNAw1FtxNrQHusEwMFxIt4I7mKZ9YIqioymCzLq9gwQbooMDQaHWBfEbwrbw -qHyGO0aoSCqI3Haadr8faqU9GY/rOPNk3sgrDQoo//fb4hVC1CLQJ13hef4Y53CI -rU7m2Ys6xt0nUW7/vGT1M0NPAgMBAAGjQjBAMA4GA1UdDwEB/wQEAwIBBjAPBgNV -HRMBAf8EBTADAQH/MB0GA1UdDgQWBBR5tFnme7bl5AFzgAiIyBpY9umbbjANBgkq -hkiG9w0BAQsFAAOCAgEAVR9YqbyyqFDQDLHYGmkgJykIrGF1XIpu+ILlaS/V9lZL -ubhzEFnTIZd+50xx+7LSYK05qAvqFyFWhfFQDlnrzuBZ6brJFe+GnY+EgPbk6ZGQ -3BebYhtF8GaV0nxvwuo77x/Py9auJ/GpsMiu/X1+mvoiBOv/2X/qkSsisRcOj/KK -NFtY2PwByVS5uCbMiogziUwthDyC3+6WVwW6LLv3xLfHTjuCvjHIInNzktHCgKQ5 -ORAzI4JMPJ+GslWYHb4phowim57iaztXOoJwTdwJx4nLCgdNbOhdjsnvzqvHu7Ur -TkXWStAmzOVyyghqpZXjFaH3pO3JLF+l+/+sKAIuvtd7u+Nxe5AW0wdeRlN8NwdC -jNPElpzVmbUq4JUagEiuTDkHzsxHpFKVK7q4+63SM1N95R1NbdWhscdCb+ZAJzVc -oyi3B43njTOQ5yOf+1CceWxG1bQVs5ZufpsMljq4Ui0/1lvh+wjChP4kqKOJ2qxq -4RgqsahDYVvTH9w7jXbyLeiNdd8XM2w9U/t7y0Ff/9yi0GE44Za4rF2LN9d11TPA -mRGunUHBcnWEvgJBQl9nJEiU0Zsnvgc/ubhPgXRR4Xq37Z0j4r7g1SgEEzwxA57d -emyPxgcYxn/eR44/KJ4EBs+lVDR3veyJm+kXQ99b21/+jh5Xos1AnX5iItreGCc= ------END CERTIFICATE----- - -# Issuer: O=FNMT-RCM OU=AC RAIZ FNMT-RCM -# Subject: O=FNMT-RCM OU=AC RAIZ FNMT-RCM -# Label: "AC RAIZ FNMT-RCM" -# Serial: 485876308206448804701554682760554759 -# MD5 Fingerprint: e2:09:04:b4:d3:bd:d1:a0:14:fd:1a:d2:47:c4:57:1d -# SHA1 Fingerprint: ec:50:35:07:b2:15:c4:95:62:19:e2:a8:9a:5b:42:99:2c:4c:2c:20 -# SHA256 Fingerprint: eb:c5:57:0c:29:01:8c:4d:67:b1:aa:12:7b:af:12:f7:03:b4:61:1e:bc:17:b7:da:b5:57:38:94:17:9b:93:fa ------BEGIN CERTIFICATE----- -MIIFgzCCA2ugAwIBAgIPXZONMGc2yAYdGsdUhGkHMA0GCSqGSIb3DQEBCwUAMDsx -CzAJBgNVBAYTAkVTMREwDwYDVQQKDAhGTk1ULVJDTTEZMBcGA1UECwwQQUMgUkFJ -WiBGTk1ULVJDTTAeFw0wODEwMjkxNTU5NTZaFw0zMDAxMDEwMDAwMDBaMDsxCzAJ -BgNVBAYTAkVTMREwDwYDVQQKDAhGTk1ULVJDTTEZMBcGA1UECwwQQUMgUkFJWiBG -Tk1ULVJDTTCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBALpxgHpMhm5/ -yBNtwMZ9HACXjywMI7sQmkCpGreHiPibVmr75nuOi5KOpyVdWRHbNi63URcfqQgf -BBckWKo3Shjf5TnUV/3XwSyRAZHiItQDwFj8d0fsjz50Q7qsNI1NOHZnjrDIbzAz -WHFctPVrbtQBULgTfmxKo0nRIBnuvMApGGWn3v7v3QqQIecaZ5JCEJhfTzC8PhxF -tBDXaEAUwED653cXeuYLj2VbPNmaUtu1vZ5Gzz3rkQUCwJaydkxNEJY7kvqcfw+Z -374jNUUeAlz+taibmSXaXvMiwzn15Cou08YfxGyqxRxqAQVKL9LFwag0Jl1mpdIC -IfkYtwb1TplvqKtMUejPUBjFd8g5CSxJkjKZqLsXF3mwWsXmo8RZZUc1g16p6DUL -mbvkzSDGm0oGObVo/CK67lWMK07q87Hj/LaZmtVC+nFNCM+HHmpxffnTtOmlcYF7 -wk5HlqX2doWjKI/pgG6BU6VtX7hI+cL5NqYuSf+4lsKMB7ObiFj86xsc3i1w4peS -MKGJ47xVqCfWS+2QrYv6YyVZLag13cqXM7zlzced0ezvXg5KkAYmY6252TUtB7p2 -ZSysV4999AeU14ECll2jB0nVetBX+RvnU0Z1qrB5QstocQjpYL05ac70r8NWQMet -UqIJ5G+GR4of6ygnXYMgrwTJbFaai0b1AgMBAAGjgYMwgYAwDwYDVR0TAQH/BAUw -AwEB/zAOBgNVHQ8BAf8EBAMCAQYwHQYDVR0OBBYEFPd9xf3E6Jobd2Sn9R2gzL+H -YJptMD4GA1UdIAQ3MDUwMwYEVR0gADArMCkGCCsGAQUFBwIBFh1odHRwOi8vd3d3 -LmNlcnQuZm5tdC5lcy9kcGNzLzANBgkqhkiG9w0BAQsFAAOCAgEAB5BK3/MjTvDD -nFFlm5wioooMhfNzKWtN/gHiqQxjAb8EZ6WdmF/9ARP67Jpi6Yb+tmLSbkyU+8B1 -RXxlDPiyN8+sD8+Nb/kZ94/sHvJwnvDKuO+3/3Y3dlv2bojzr2IyIpMNOmqOFGYM -LVN0V2Ue1bLdI4E7pWYjJ2cJj+F3qkPNZVEI7VFY/uY5+ctHhKQV8Xa7pO6kO8Rf -77IzlhEYt8llvhjho6Tc+hj507wTmzl6NLrTQfv6MooqtyuGC2mDOL7Nii4LcK2N -JpLuHvUBKwrZ1pebbuCoGRw6IYsMHkCtA+fdZn71uSANA+iW+YJF1DngoABd15jm -fZ5nc8OaKveri6E6FO80vFIOiZiaBECEHX5FaZNXzuvO+FB8TxxuBEOb+dY7Ixjp -6o7RTUaN8Tvkasq6+yO3m/qZASlaWFot4/nUbQ4mrcFuNLwy+AwF+mWj2zs3gyLp -1txyM/1d8iC9djwj2ij3+RvrWWTV3F9yfiD8zYm1kGdNYno/Tq0dwzn+evQoFt9B -9kiABdcPUXmsEKvU7ANm5mqwujGSQkBqvjrTcuFqN1W8rB2Vt2lh8kORdOag0wok -RqEIr9baRRmW1FMdW4R58MD3R++Lj8UGrp1MYp3/RgT408m2ECVAdf4WqslKYIYv -uu8wd+RU4riEmViAqhOLUTpPSPaLtrM= ------END CERTIFICATE----- - -# Issuer: CN=Amazon Root CA 1 O=Amazon -# Subject: CN=Amazon Root CA 1 O=Amazon -# Label: "Amazon Root CA 1" -# Serial: 143266978916655856878034712317230054538369994 -# MD5 Fingerprint: 43:c6:bf:ae:ec:fe:ad:2f:18:c6:88:68:30:fc:c8:e6 -# SHA1 Fingerprint: 8d:a7:f9:65:ec:5e:fc:37:91:0f:1c:6e:59:fd:c1:cc:6a:6e:de:16 -# SHA256 Fingerprint: 8e:cd:e6:88:4f:3d:87:b1:12:5b:a3:1a:c3:fc:b1:3d:70:16:de:7f:57:cc:90:4f:e1:cb:97:c6:ae:98:19:6e ------BEGIN CERTIFICATE----- -MIIDQTCCAimgAwIBAgITBmyfz5m/jAo54vB4ikPmljZbyjANBgkqhkiG9w0BAQsF -ADA5MQswCQYDVQQGEwJVUzEPMA0GA1UEChMGQW1hem9uMRkwFwYDVQQDExBBbWF6 -b24gUm9vdCBDQSAxMB4XDTE1MDUyNjAwMDAwMFoXDTM4MDExNzAwMDAwMFowOTEL -MAkGA1UEBhMCVVMxDzANBgNVBAoTBkFtYXpvbjEZMBcGA1UEAxMQQW1hem9uIFJv -b3QgQ0EgMTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBALJ4gHHKeNXj -ca9HgFB0fW7Y14h29Jlo91ghYPl0hAEvrAIthtOgQ3pOsqTQNroBvo3bSMgHFzZM -9O6II8c+6zf1tRn4SWiw3te5djgdYZ6k/oI2peVKVuRF4fn9tBb6dNqcmzU5L/qw -IFAGbHrQgLKm+a/sRxmPUDgH3KKHOVj4utWp+UhnMJbulHheb4mjUcAwhmahRWa6 -VOujw5H5SNz/0egwLX0tdHA114gk957EWW67c4cX8jJGKLhD+rcdqsq08p8kDi1L -93FcXmn/6pUCyziKrlA4b9v7LWIbxcceVOF34GfID5yHI9Y/QCB/IIDEgEw+OyQm -jgSubJrIqg0CAwEAAaNCMEAwDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMC -AYYwHQYDVR0OBBYEFIQYzIU07LwMlJQuCFmcx7IQTgoIMA0GCSqGSIb3DQEBCwUA -A4IBAQCY8jdaQZChGsV2USggNiMOruYou6r4lK5IpDB/G/wkjUu0yKGX9rbxenDI -U5PMCCjjmCXPI6T53iHTfIUJrU6adTrCC2qJeHZERxhlbI1Bjjt/msv0tadQ1wUs -N+gDS63pYaACbvXy8MWy7Vu33PqUXHeeE6V/Uq2V8viTO96LXFvKWlJbYK8U90vv -o/ufQJVtMVT8QtPHRh8jrdkPSHCa2XV4cdFyQzR1bldZwgJcJmApzyMZFo6IQ6XU -5MsI+yMRQ+hDKXJioaldXgjUkK642M4UwtBV8ob2xJNDd2ZhwLnoQdeXeGADbkpy -rqXRfboQnoZsG4q5WTP468SQvvG5 ------END CERTIFICATE----- - -# Issuer: CN=Amazon Root CA 2 O=Amazon -# Subject: CN=Amazon Root CA 2 O=Amazon -# Label: "Amazon Root CA 2" -# Serial: 143266982885963551818349160658925006970653239 -# MD5 Fingerprint: c8:e5:8d:ce:a8:42:e2:7a:c0:2a:5c:7c:9e:26:bf:66 -# SHA1 Fingerprint: 5a:8c:ef:45:d7:a6:98:59:76:7a:8c:8b:44:96:b5:78:cf:47:4b:1a -# SHA256 Fingerprint: 1b:a5:b2:aa:8c:65:40:1a:82:96:01:18:f8:0b:ec:4f:62:30:4d:83:ce:c4:71:3a:19:c3:9c:01:1e:a4:6d:b4 ------BEGIN CERTIFICATE----- -MIIFQTCCAymgAwIBAgITBmyf0pY1hp8KD+WGePhbJruKNzANBgkqhkiG9w0BAQwF -ADA5MQswCQYDVQQGEwJVUzEPMA0GA1UEChMGQW1hem9uMRkwFwYDVQQDExBBbWF6 -b24gUm9vdCBDQSAyMB4XDTE1MDUyNjAwMDAwMFoXDTQwMDUyNjAwMDAwMFowOTEL -MAkGA1UEBhMCVVMxDzANBgNVBAoTBkFtYXpvbjEZMBcGA1UEAxMQQW1hem9uIFJv -b3QgQ0EgMjCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAK2Wny2cSkxK -gXlRmeyKy2tgURO8TW0G/LAIjd0ZEGrHJgw12MBvIITplLGbhQPDW9tK6Mj4kHbZ -W0/jTOgGNk3Mmqw9DJArktQGGWCsN0R5hYGCrVo34A3MnaZMUnbqQ523BNFQ9lXg -1dKmSYXpN+nKfq5clU1Imj+uIFptiJXZNLhSGkOQsL9sBbm2eLfq0OQ6PBJTYv9K -8nu+NQWpEjTj82R0Yiw9AElaKP4yRLuH3WUnAnE72kr3H9rN9yFVkE8P7K6C4Z9r -2UXTu/Bfh+08LDmG2j/e7HJV63mjrdvdfLC6HM783k81ds8P+HgfajZRRidhW+me -z/CiVX18JYpvL7TFz4QuK/0NURBs+18bvBt+xa47mAExkv8LV/SasrlX6avvDXbR -8O70zoan4G7ptGmh32n2M8ZpLpcTnqWHsFcQgTfJU7O7f/aS0ZzQGPSSbtqDT6Zj -mUyl+17vIWR6IF9sZIUVyzfpYgwLKhbcAS4y2j5L9Z469hdAlO+ekQiG+r5jqFoz -7Mt0Q5X5bGlSNscpb/xVA1wf+5+9R+vnSUeVC06JIglJ4PVhHvG/LopyboBZ/1c6 -+XUyo05f7O0oYtlNc/LMgRdg7c3r3NunysV+Ar3yVAhU/bQtCSwXVEqY0VThUWcI -0u1ufm8/0i2BWSlmy5A5lREedCf+3euvAgMBAAGjQjBAMA8GA1UdEwEB/wQFMAMB -Af8wDgYDVR0PAQH/BAQDAgGGMB0GA1UdDgQWBBSwDPBMMPQFWAJI/TPlUq9LhONm -UjANBgkqhkiG9w0BAQwFAAOCAgEAqqiAjw54o+Ci1M3m9Zh6O+oAA7CXDpO8Wqj2 -LIxyh6mx/H9z/WNxeKWHWc8w4Q0QshNabYL1auaAn6AFC2jkR2vHat+2/XcycuUY -+gn0oJMsXdKMdYV2ZZAMA3m3MSNjrXiDCYZohMr/+c8mmpJ5581LxedhpxfL86kS -k5Nrp+gvU5LEYFiwzAJRGFuFjWJZY7attN6a+yb3ACfAXVU3dJnJUH/jWS5E4ywl -7uxMMne0nxrpS10gxdr9HIcWxkPo1LsmmkVwXqkLN1PiRnsn/eBG8om3zEK2yygm -btmlyTrIQRNg91CMFa6ybRoVGld45pIq2WWQgj9sAq+uEjonljYE1x2igGOpm/Hl -urR8FLBOybEfdF849lHqm/osohHUqS0nGkWxr7JOcQ3AWEbWaQbLU8uz/mtBzUF+ -fUwPfHJ5elnNXkoOrJupmHN5fLT0zLm4BwyydFy4x2+IoZCn9Kr5v2c69BoVYh63 -n749sSmvZ6ES8lgQGVMDMBu4Gon2nL2XA46jCfMdiyHxtN/kHNGfZQIG6lzWE7OE -76KlXIx3KadowGuuQNKotOrN8I1LOJwZmhsoVLiJkO/KdYE+HvJkJMcYr07/R54H -9jVlpNMKVv/1F2Rs76giJUmTtt8AF9pYfl3uxRuw0dFfIRDH+fO6AgonB8Xx1sfT -4PsJYGw= ------END CERTIFICATE----- - -# Issuer: CN=Amazon Root CA 3 O=Amazon -# Subject: CN=Amazon Root CA 3 O=Amazon -# Label: "Amazon Root CA 3" -# Serial: 143266986699090766294700635381230934788665930 -# MD5 Fingerprint: a0:d4:ef:0b:f7:b5:d8:49:95:2a:ec:f5:c4:fc:81:87 -# SHA1 Fingerprint: 0d:44:dd:8c:3c:8c:1a:1a:58:75:64:81:e9:0f:2e:2a:ff:b3:d2:6e -# SHA256 Fingerprint: 18:ce:6c:fe:7b:f1:4e:60:b2:e3:47:b8:df:e8:68:cb:31:d0:2e:bb:3a:da:27:15:69:f5:03:43:b4:6d:b3:a4 ------BEGIN CERTIFICATE----- -MIIBtjCCAVugAwIBAgITBmyf1XSXNmY/Owua2eiedgPySjAKBggqhkjOPQQDAjA5 -MQswCQYDVQQGEwJVUzEPMA0GA1UEChMGQW1hem9uMRkwFwYDVQQDExBBbWF6b24g -Um9vdCBDQSAzMB4XDTE1MDUyNjAwMDAwMFoXDTQwMDUyNjAwMDAwMFowOTELMAkG -A1UEBhMCVVMxDzANBgNVBAoTBkFtYXpvbjEZMBcGA1UEAxMQQW1hem9uIFJvb3Qg -Q0EgMzBZMBMGByqGSM49AgEGCCqGSM49AwEHA0IABCmXp8ZBf8ANm+gBG1bG8lKl -ui2yEujSLtf6ycXYqm0fc4E7O5hrOXwzpcVOho6AF2hiRVd9RFgdszflZwjrZt6j -QjBAMA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgGGMB0GA1UdDgQWBBSr -ttvXBp43rDCGB5Fwx5zEGbF4wDAKBggqhkjOPQQDAgNJADBGAiEA4IWSoxe3jfkr -BqWTrBqYaGFy+uGh0PsceGCmQ5nFuMQCIQCcAu/xlJyzlvnrxir4tiz+OpAUFteM -YyRIHN8wfdVoOw== ------END CERTIFICATE----- - -# Issuer: CN=Amazon Root CA 4 O=Amazon -# Subject: CN=Amazon Root CA 4 O=Amazon -# Label: "Amazon Root CA 4" -# Serial: 143266989758080763974105200630763877849284878 -# MD5 Fingerprint: 89:bc:27:d5:eb:17:8d:06:6a:69:d5:fd:89:47:b4:cd -# SHA1 Fingerprint: f6:10:84:07:d6:f8:bb:67:98:0c:c2:e2:44:c2:eb:ae:1c:ef:63:be -# SHA256 Fingerprint: e3:5d:28:41:9e:d0:20:25:cf:a6:90:38:cd:62:39:62:45:8d:a5:c6:95:fb:de:a3:c2:2b:0b:fb:25:89:70:92 ------BEGIN CERTIFICATE----- -MIIB8jCCAXigAwIBAgITBmyf18G7EEwpQ+Vxe3ssyBrBDjAKBggqhkjOPQQDAzA5 -MQswCQYDVQQGEwJVUzEPMA0GA1UEChMGQW1hem9uMRkwFwYDVQQDExBBbWF6b24g -Um9vdCBDQSA0MB4XDTE1MDUyNjAwMDAwMFoXDTQwMDUyNjAwMDAwMFowOTELMAkG -A1UEBhMCVVMxDzANBgNVBAoTBkFtYXpvbjEZMBcGA1UEAxMQQW1hem9uIFJvb3Qg -Q0EgNDB2MBAGByqGSM49AgEGBSuBBAAiA2IABNKrijdPo1MN/sGKe0uoe0ZLY7Bi -9i0b2whxIdIA6GO9mif78DluXeo9pcmBqqNbIJhFXRbb/egQbeOc4OO9X4Ri83Bk -M6DLJC9wuoihKqB1+IGuYgbEgds5bimwHvouXKNCMEAwDwYDVR0TAQH/BAUwAwEB -/zAOBgNVHQ8BAf8EBAMCAYYwHQYDVR0OBBYEFNPsxzplbszh2naaVvuc84ZtV+WB -MAoGCCqGSM49BAMDA2gAMGUCMDqLIfG9fhGt0O9Yli/W651+kI0rz2ZVwyzjKKlw -CkcO8DdZEv8tmZQoTipPNU0zWgIxAOp1AE47xDqUEpHJWEadIRNyp4iciuRMStuW -1KyLa2tJElMzrdfkviT8tQp21KW8EA== ------END CERTIFICATE----- - -# Issuer: CN=TUBITAK Kamu SM SSL Kok Sertifikasi - Surum 1 O=Turkiye Bilimsel ve Teknolojik Arastirma Kurumu - TUBITAK OU=Kamu Sertifikasyon Merkezi - Kamu SM -# Subject: CN=TUBITAK Kamu SM SSL Kok Sertifikasi - Surum 1 O=Turkiye Bilimsel ve Teknolojik Arastirma Kurumu - TUBITAK OU=Kamu Sertifikasyon Merkezi - Kamu SM -# Label: "TUBITAK Kamu SM SSL Kok Sertifikasi - Surum 1" -# Serial: 1 -# MD5 Fingerprint: dc:00:81:dc:69:2f:3e:2f:b0:3b:f6:3d:5a:91:8e:49 -# SHA1 Fingerprint: 31:43:64:9b:ec:ce:27:ec:ed:3a:3f:0b:8f:0d:e4:e8:91:dd:ee:ca -# SHA256 Fingerprint: 46:ed:c3:68:90:46:d5:3a:45:3f:b3:10:4a:b8:0d:ca:ec:65:8b:26:60:ea:16:29:dd:7e:86:79:90:64:87:16 ------BEGIN CERTIFICATE----- -MIIEYzCCA0ugAwIBAgIBATANBgkqhkiG9w0BAQsFADCB0jELMAkGA1UEBhMCVFIx -GDAWBgNVBAcTD0dlYnplIC0gS29jYWVsaTFCMEAGA1UEChM5VHVya2l5ZSBCaWxp -bXNlbCB2ZSBUZWtub2xvamlrIEFyYXN0aXJtYSBLdXJ1bXUgLSBUVUJJVEFLMS0w -KwYDVQQLEyRLYW11IFNlcnRpZmlrYXN5b24gTWVya2V6aSAtIEthbXUgU00xNjA0 -BgNVBAMTLVRVQklUQUsgS2FtdSBTTSBTU0wgS29rIFNlcnRpZmlrYXNpIC0gU3Vy -dW0gMTAeFw0xMzExMjUwODI1NTVaFw00MzEwMjUwODI1NTVaMIHSMQswCQYDVQQG -EwJUUjEYMBYGA1UEBxMPR2ViemUgLSBLb2NhZWxpMUIwQAYDVQQKEzlUdXJraXll -IEJpbGltc2VsIHZlIFRla25vbG9qaWsgQXJhc3Rpcm1hIEt1cnVtdSAtIFRVQklU -QUsxLTArBgNVBAsTJEthbXUgU2VydGlmaWthc3lvbiBNZXJrZXppIC0gS2FtdSBT -TTE2MDQGA1UEAxMtVFVCSVRBSyBLYW11IFNNIFNTTCBLb2sgU2VydGlmaWthc2kg -LSBTdXJ1bSAxMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAr3UwM6q7 -a9OZLBI3hNmNe5eA027n/5tQlT6QlVZC1xl8JoSNkvoBHToP4mQ4t4y86Ij5iySr -LqP1N+RAjhgleYN1Hzv/bKjFxlb4tO2KRKOrbEz8HdDc72i9z+SqzvBV96I01INr -N3wcwv61A+xXzry0tcXtAA9TNypN9E8Mg/uGz8v+jE69h/mniyFXnHrfA2eJLJ2X -YacQuFWQfw4tJzh03+f92k4S400VIgLI4OD8D62K18lUUMw7D8oWgITQUVbDjlZ/ -iSIzL+aFCr2lqBs23tPcLG07xxO9WSMs5uWk99gL7eqQQESolbuT1dCANLZGeA4f -AJNG4e7p+exPFwIDAQABo0IwQDAdBgNVHQ4EFgQUZT/HiobGPN08VFw1+DrtUgxH -V8gwDgYDVR0PAQH/BAQDAgEGMA8GA1UdEwEB/wQFMAMBAf8wDQYJKoZIhvcNAQEL -BQADggEBACo/4fEyjq7hmFxLXs9rHmoJ0iKpEsdeV31zVmSAhHqT5Am5EM2fKifh -AHe+SMg1qIGf5LgsyX8OsNJLN13qudULXjS99HMpw+0mFZx+CFOKWI3QSyjfwbPf -IPP54+M638yclNhOT8NrF7f3cuitZjO1JVOr4PhMqZ398g26rrnZqsZr+ZO7rqu4 -lzwDGrpDxpa5RXI4s6ehlj2Re37AIVNMh+3yC1SVUZPVIqUNivGTDj5UDrDYyU7c -8jEyVupk+eq1nRZmQnLzf9OxMUP8pI4X8W0jq5Rm+K37DwhuJi1/FwcJsoz7UMCf -lo3Ptv0AnVoUmr8CRPXBwp8iXqIPoeM= ------END CERTIFICATE----- - -# Issuer: CN=GDCA TrustAUTH R5 ROOT O=GUANG DONG CERTIFICATE AUTHORITY CO.,LTD. -# Subject: CN=GDCA TrustAUTH R5 ROOT O=GUANG DONG CERTIFICATE AUTHORITY CO.,LTD. -# Label: "GDCA TrustAUTH R5 ROOT" -# Serial: 9009899650740120186 -# MD5 Fingerprint: 63:cc:d9:3d:34:35:5c:6f:53:a3:e2:08:70:48:1f:b4 -# SHA1 Fingerprint: 0f:36:38:5b:81:1a:25:c3:9b:31:4e:83:ca:e9:34:66:70:cc:74:b4 -# SHA256 Fingerprint: bf:ff:8f:d0:44:33:48:7d:6a:8a:a6:0c:1a:29:76:7a:9f:c2:bb:b0:5e:42:0f:71:3a:13:b9:92:89:1d:38:93 ------BEGIN CERTIFICATE----- -MIIFiDCCA3CgAwIBAgIIfQmX/vBH6nowDQYJKoZIhvcNAQELBQAwYjELMAkGA1UE -BhMCQ04xMjAwBgNVBAoMKUdVQU5HIERPTkcgQ0VSVElGSUNBVEUgQVVUSE9SSVRZ -IENPLixMVEQuMR8wHQYDVQQDDBZHRENBIFRydXN0QVVUSCBSNSBST09UMB4XDTE0 -MTEyNjA1MTMxNVoXDTQwMTIzMTE1NTk1OVowYjELMAkGA1UEBhMCQ04xMjAwBgNV -BAoMKUdVQU5HIERPTkcgQ0VSVElGSUNBVEUgQVVUSE9SSVRZIENPLixMVEQuMR8w -HQYDVQQDDBZHRENBIFRydXN0QVVUSCBSNSBST09UMIICIjANBgkqhkiG9w0BAQEF -AAOCAg8AMIICCgKCAgEA2aMW8Mh0dHeb7zMNOwZ+Vfy1YI92hhJCfVZmPoiC7XJj -Dp6L3TQsAlFRwxn9WVSEyfFrs0yw6ehGXTjGoqcuEVe6ghWinI9tsJlKCvLriXBj -TnnEt1u9ol2x8kECK62pOqPseQrsXzrj/e+APK00mxqriCZ7VqKChh/rNYmDf1+u -KU49tm7srsHwJ5uu4/Ts765/94Y9cnrrpftZTqfrlYwiOXnhLQiPzLyRuEH3FMEj -qcOtmkVEs7LXLM3GKeJQEK5cy4KOFxg2fZfmiJqwTTQJ9Cy5WmYqsBebnh52nUpm -MUHfP/vFBu8btn4aRjb3ZGM74zkYI+dndRTVdVeSN72+ahsmUPI2JgaQxXABZG12 -ZuGR224HwGGALrIuL4xwp9E7PLOR5G62xDtw8mySlwnNR30YwPO7ng/Wi64HtloP -zgsMR6flPri9fcebNaBhlzpBdRfMK5Z3KpIhHtmVdiBnaM8Nvd/WHwlqmuLMc3Gk -L30SgLdTMEZeS1SZD2fJpcjyIMGC7J0R38IC+xo70e0gmu9lZJIQDSri3nDxGGeC -jGHeuLzRL5z7D9Ar7Rt2ueQ5Vfj4oR24qoAATILnsn8JuLwwoC8N9VKejveSswoA -HQBUlwbgsQfZxw9cZX08bVlX5O2ljelAU58VS6Bx9hoh49pwBiFYFIeFd3mqgnkC -AwEAAaNCMEAwHQYDVR0OBBYEFOLJQJ9NzuiaoXzPDj9lxSmIahlRMA8GA1UdEwEB -/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgGGMA0GCSqGSIb3DQEBCwUAA4ICAQDRSVfg -p8xoWLoBDysZzY2wYUWsEe1jUGn4H3++Fo/9nesLqjJHdtJnJO29fDMylyrHBYZm -DRd9FBUb1Ov9H5r2XpdptxolpAqzkT9fNqyL7FeoPueBihhXOYV0GkLH6VsTX4/5 -COmSdI31R9KrO9b7eGZONn356ZLpBN79SWP8bfsUcZNnL0dKt7n/HipzcEYwv1ry -L3ml4Y0M2fmyYzeMN2WFcGpcWwlyua1jPLHd+PwyvzeG5LuOmCd+uh8W4XAR8gPf -JWIyJyYYMoSf/wA6E7qaTfRPuBRwIrHKK5DOKcFw9C+df/KQHtZa37dG/OaG+svg -IHZ6uqbL9XzeYqWxi+7egmaKTjowHz+Ay60nugxe19CxVsp3cbK1daFQqUBDF8Io -2c9Si1vIY9RCPqAzekYu9wogRlR+ak8x8YF+QnQ4ZXMn7sZ8uI7XpTrXmKGcjBBV -09tL7ECQ8s1uV9JiDnxXk7Gnbc2dg7sq5+W2O3FYrf3RRbxake5TFW/TRQl1brqQ -XR4EzzffHqhmsYzmIGrv/EhOdJhCrylvLmrH+33RZjEizIYAfmaDDEL0vTSSwxrq -T8p+ck0LcIymSLumoRT2+1hEmRSuqguTaaApJUqlyyvdimYHFngVV3Eb7PVHhPOe -MTd61X8kreS8/f3MboPoDKi3QWwH3b08hpcv0g== ------END CERTIFICATE----- - -# Issuer: CN=SSL.com Root Certification Authority RSA O=SSL Corporation -# Subject: CN=SSL.com Root Certification Authority RSA O=SSL Corporation -# Label: "SSL.com Root Certification Authority RSA" -# Serial: 8875640296558310041 -# MD5 Fingerprint: 86:69:12:c0:70:f1:ec:ac:ac:c2:d5:bc:a5:5b:a1:29 -# SHA1 Fingerprint: b7:ab:33:08:d1:ea:44:77:ba:14:80:12:5a:6f:bd:a9:36:49:0c:bb -# SHA256 Fingerprint: 85:66:6a:56:2e:e0:be:5c:e9:25:c1:d8:89:0a:6f:76:a8:7e:c1:6d:4d:7d:5f:29:ea:74:19:cf:20:12:3b:69 ------BEGIN CERTIFICATE----- -MIIF3TCCA8WgAwIBAgIIeyyb0xaAMpkwDQYJKoZIhvcNAQELBQAwfDELMAkGA1UE -BhMCVVMxDjAMBgNVBAgMBVRleGFzMRAwDgYDVQQHDAdIb3VzdG9uMRgwFgYDVQQK -DA9TU0wgQ29ycG9yYXRpb24xMTAvBgNVBAMMKFNTTC5jb20gUm9vdCBDZXJ0aWZp -Y2F0aW9uIEF1dGhvcml0eSBSU0EwHhcNMTYwMjEyMTczOTM5WhcNNDEwMjEyMTcz -OTM5WjB8MQswCQYDVQQGEwJVUzEOMAwGA1UECAwFVGV4YXMxEDAOBgNVBAcMB0hv -dXN0b24xGDAWBgNVBAoMD1NTTCBDb3Jwb3JhdGlvbjExMC8GA1UEAwwoU1NMLmNv -bSBSb290IENlcnRpZmljYXRpb24gQXV0aG9yaXR5IFJTQTCCAiIwDQYJKoZIhvcN -AQEBBQADggIPADCCAgoCggIBAPkP3aMrfcvQKv7sZ4Wm5y4bunfh4/WvpOz6Sl2R -xFdHaxh3a3by/ZPkPQ/CFp4LZsNWlJ4Xg4XOVu/yFv0AYvUiCVToZRdOQbngT0aX -qhvIuG5iXmmxX9sqAn78bMrzQdjt0Oj8P2FI7bADFB0QDksZ4LtO7IZl/zbzXmcC -C52GVWH9ejjt/uIZALdvoVBidXQ8oPrIJZK0bnoix/geoeOy3ZExqysdBP+lSgQ3 -6YWkMyv94tZVNHwZpEpox7Ko07fKoZOI68GXvIz5HdkihCR0xwQ9aqkpk8zruFvh -/l8lqjRYyMEjVJ0bmBHDOJx+PYZspQ9AhnwC9FwCTyjLrnGfDzrIM/4RJTXq/LrF -YD3ZfBjVsqnTdXgDciLKOsMf7yzlLqn6niy2UUb9rwPW6mBo6oUWNmuF6R7As93E -JNyAKoFBbZQ+yODJgUEAnl6/f8UImKIYLEJAs/lvOCdLToD0PYFH4Ih86hzOtXVc -US4cK38acijnALXRdMbX5J+tB5O2UzU1/Dfkw/ZdFr4hc96SCvigY2q8lpJqPvi8 -ZVWb3vUNiSYE/CUapiVpy8JtynziWV+XrOvvLsi81xtZPCvM8hnIk2snYxnP/Okm -+Mpxm3+T/jRnhE6Z6/yzeAkzcLpmpnbtG3PrGqUNxCITIJRWCk4sbE6x/c+cCbqi -M+2HAgMBAAGjYzBhMB0GA1UdDgQWBBTdBAkHovV6fVJTEpKV7jiAJQ2mWTAPBgNV -HRMBAf8EBTADAQH/MB8GA1UdIwQYMBaAFN0ECQei9Xp9UlMSkpXuOIAlDaZZMA4G -A1UdDwEB/wQEAwIBhjANBgkqhkiG9w0BAQsFAAOCAgEAIBgRlCn7Jp0cHh5wYfGV -cpNxJK1ok1iOMq8bs3AD/CUrdIWQPXhq9LmLpZc7tRiRux6n+UBbkflVma8eEdBc -Hadm47GUBwwyOabqG7B52B2ccETjit3E+ZUfijhDPwGFpUenPUayvOUiaPd7nNgs -PgohyC0zrL/FgZkxdMF1ccW+sfAjRfSda/wZY52jvATGGAslu1OJD7OAUN5F7kR/ -q5R4ZJjT9ijdh9hwZXT7DrkT66cPYakylszeu+1jTBi7qUD3oFRuIIhxdRjqerQ0 -cuAjJ3dctpDqhiVAq+8zD8ufgr6iIPv2tS0a5sKFsXQP+8hlAqRSAUfdSSLBv9jr -a6x+3uxjMxW3IwiPxg+NQVrdjsW5j+VFP3jbutIbQLH+cU0/4IGiul607BXgk90I -H37hVZkLId6Tngr75qNJvTYw/ud3sqB1l7UtgYgXZSD32pAAn8lSzDLKNXz1PQ/Y -K9f1JmzJBjSWFupwWRoyeXkLtoh/D1JIPb9s2KJELtFOt3JY04kTlf5Eq/jXixtu -nLwsoFvVagCvXzfh1foQC5ichucmj87w7G6KVwuA406ywKBjYZC6VWg3dGq2ktuf -oYYitmUnDuy2n0Jg5GfCtdpBC8TTi2EbvPofkSvXRAdeuims2cXp71NIWuuA8ShY -Ic2wBlX7Jz9TkHCpBB5XJ7k= ------END CERTIFICATE----- - -# Issuer: CN=SSL.com Root Certification Authority ECC O=SSL Corporation -# Subject: CN=SSL.com Root Certification Authority ECC O=SSL Corporation -# Label: "SSL.com Root Certification Authority ECC" -# Serial: 8495723813297216424 -# MD5 Fingerprint: 2e:da:e4:39:7f:9c:8f:37:d1:70:9f:26:17:51:3a:8e -# SHA1 Fingerprint: c3:19:7c:39:24:e6:54:af:1b:c4:ab:20:95:7a:e2:c3:0e:13:02:6a -# SHA256 Fingerprint: 34:17:bb:06:cc:60:07:da:1b:96:1c:92:0b:8a:b4:ce:3f:ad:82:0e:4a:a3:0b:9a:cb:c4:a7:4e:bd:ce:bc:65 ------BEGIN CERTIFICATE----- -MIICjTCCAhSgAwIBAgIIdebfy8FoW6gwCgYIKoZIzj0EAwIwfDELMAkGA1UEBhMC -VVMxDjAMBgNVBAgMBVRleGFzMRAwDgYDVQQHDAdIb3VzdG9uMRgwFgYDVQQKDA9T -U0wgQ29ycG9yYXRpb24xMTAvBgNVBAMMKFNTTC5jb20gUm9vdCBDZXJ0aWZpY2F0 -aW9uIEF1dGhvcml0eSBFQ0MwHhcNMTYwMjEyMTgxNDAzWhcNNDEwMjEyMTgxNDAz -WjB8MQswCQYDVQQGEwJVUzEOMAwGA1UECAwFVGV4YXMxEDAOBgNVBAcMB0hvdXN0 -b24xGDAWBgNVBAoMD1NTTCBDb3Jwb3JhdGlvbjExMC8GA1UEAwwoU1NMLmNvbSBS -b290IENlcnRpZmljYXRpb24gQXV0aG9yaXR5IEVDQzB2MBAGByqGSM49AgEGBSuB -BAAiA2IABEVuqVDEpiM2nl8ojRfLliJkP9x6jh3MCLOicSS6jkm5BBtHllirLZXI -7Z4INcgn64mMU1jrYor+8FsPazFSY0E7ic3s7LaNGdM0B9y7xgZ/wkWV7Mt/qCPg -CemB+vNH06NjMGEwHQYDVR0OBBYEFILRhXMw5zUE044CkvvlpNHEIejNMA8GA1Ud -EwEB/wQFMAMBAf8wHwYDVR0jBBgwFoAUgtGFczDnNQTTjgKS++Wk0cQh6M0wDgYD -VR0PAQH/BAQDAgGGMAoGCCqGSM49BAMCA2cAMGQCMG/n61kRpGDPYbCWe+0F+S8T -kdzt5fxQaxFGRrMcIQBiu77D5+jNB5n5DQtdcj7EqgIwH7y6C+IwJPt8bYBVCpk+ -gA0z5Wajs6O7pdWLjwkspl1+4vAHCGht0nxpbl/f5Wpl ------END CERTIFICATE----- - -# Issuer: CN=SSL.com EV Root Certification Authority RSA R2 O=SSL Corporation -# Subject: CN=SSL.com EV Root Certification Authority RSA R2 O=SSL Corporation -# Label: "SSL.com EV Root Certification Authority RSA R2" -# Serial: 6248227494352943350 -# MD5 Fingerprint: e1:1e:31:58:1a:ae:54:53:02:f6:17:6a:11:7b:4d:95 -# SHA1 Fingerprint: 74:3a:f0:52:9b:d0:32:a0:f4:4a:83:cd:d4:ba:a9:7b:7c:2e:c4:9a -# SHA256 Fingerprint: 2e:7b:f1:6c:c2:24:85:a7:bb:e2:aa:86:96:75:07:61:b0:ae:39:be:3b:2f:e9:d0:cc:6d:4e:f7:34:91:42:5c ------BEGIN CERTIFICATE----- -MIIF6zCCA9OgAwIBAgIIVrYpzTS8ePYwDQYJKoZIhvcNAQELBQAwgYIxCzAJBgNV -BAYTAlVTMQ4wDAYDVQQIDAVUZXhhczEQMA4GA1UEBwwHSG91c3RvbjEYMBYGA1UE -CgwPU1NMIENvcnBvcmF0aW9uMTcwNQYDVQQDDC5TU0wuY29tIEVWIFJvb3QgQ2Vy -dGlmaWNhdGlvbiBBdXRob3JpdHkgUlNBIFIyMB4XDTE3MDUzMTE4MTQzN1oXDTQy -MDUzMDE4MTQzN1owgYIxCzAJBgNVBAYTAlVTMQ4wDAYDVQQIDAVUZXhhczEQMA4G -A1UEBwwHSG91c3RvbjEYMBYGA1UECgwPU1NMIENvcnBvcmF0aW9uMTcwNQYDVQQD -DC5TU0wuY29tIEVWIFJvb3QgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkgUlNBIFIy -MIICIjANBgkqhkiG9w0BAQEFAAOCAg8AMIICCgKCAgEAjzZlQOHWTcDXtOlG2mvq -M0fNTPl9fb69LT3w23jhhqXZuglXaO1XPqDQCEGD5yhBJB/jchXQARr7XnAjssuf -OePPxU7Gkm0mxnu7s9onnQqG6YE3Bf7wcXHswxzpY6IXFJ3vG2fThVUCAtZJycxa -4bH3bzKfydQ7iEGonL3Lq9ttewkfokxykNorCPzPPFTOZw+oz12WGQvE43LrrdF9 -HSfvkusQv1vrO6/PgN3B0pYEW3p+pKk8OHakYo6gOV7qd89dAFmPZiw+B6KjBSYR -aZfqhbcPlgtLyEDhULouisv3D5oi53+aNxPN8k0TayHRwMwi8qFG9kRpnMphNQcA -b9ZhCBHqurj26bNg5U257J8UZslXWNvNh2n4ioYSA0e/ZhN2rHd9NCSFg83XqpyQ -Gp8hLH94t2S42Oim9HizVcuE0jLEeK6jj2HdzghTreyI/BXkmg3mnxp3zkyPuBQV -PWKchjgGAGYS5Fl2WlPAApiiECtoRHuOec4zSnaqW4EWG7WK2NAAe15itAnWhmMO -pgWVSbooi4iTsjQc2KRVbrcc0N6ZVTsj9CLg+SlmJuwgUHfbSguPvuUCYHBBXtSu -UDkiFCbLsjtzdFVHB3mBOagwE0TlBIqulhMlQg+5U8Sb/M3kHN48+qvWBkofZ6aY -MBzdLNvcGJVXZsb/XItW9XcCAwEAAaNjMGEwDwYDVR0TAQH/BAUwAwEB/zAfBgNV -HSMEGDAWgBT5YLvU49U09rj1BoAlp3PbRmmonjAdBgNVHQ4EFgQU+WC71OPVNPa4 -9QaAJadz20ZpqJ4wDgYDVR0PAQH/BAQDAgGGMA0GCSqGSIb3DQEBCwUAA4ICAQBW -s47LCp1Jjr+kxJG7ZhcFUZh1++VQLHqe8RT6q9OKPv+RKY9ji9i0qVQBDb6Thi/5 -Sm3HXvVX+cpVHBK+Rw82xd9qt9t1wkclf7nxY/hoLVUE0fKNsKTPvDxeH3jnpaAg -cLAExbf3cqfeIg29MyVGjGSSJuM+LmOW2puMPfgYCdcDzH2GguDKBAdRUNf/ktUM -79qGn5nX67evaOI5JpS6aLe/g9Pqemc9YmeuJeVy6OLk7K4S9ksrPJ/psEDzOFSz -/bdoyNrGj1E8svuR3Bznm53htw1yj+KkxKl4+esUrMZDBcJlOSgYAsOCsp0FvmXt -ll9ldDz7CTUue5wT/RsPXcdtgTpWD8w74a8CLyKsRspGPKAcTNZEtF4uXBVmCeEm -Kf7GUmG6sXP/wwyc5WxqlD8UykAWlYTzWamsX0xhk23RO8yilQwipmdnRC652dKK -QbNmC1r7fSOl8hqw/96bg5Qu0T/fkreRrwU7ZcegbLHNYhLDkBvjJc40vG93drEQ -w/cFGsDWr3RiSBd3kmmQYRzelYB0VI8YHMPzA9C/pEN1hlMYegouCRw2n5H9gooi -S9EOUCXdywMMF8mDAAhONU2Ki+3wApRmLER/y5UnlhetCTCstnEXbosX9hwJ1C07 -mKVx01QT2WDz9UtmT/rx7iASjbSsV7FFY6GsdqnC+w== ------END CERTIFICATE----- - -# Issuer: CN=SSL.com EV Root Certification Authority ECC O=SSL Corporation -# Subject: CN=SSL.com EV Root Certification Authority ECC O=SSL Corporation -# Label: "SSL.com EV Root Certification Authority ECC" -# Serial: 3182246526754555285 -# MD5 Fingerprint: 59:53:22:65:83:42:01:54:c0:ce:42:b9:5a:7c:f2:90 -# SHA1 Fingerprint: 4c:dd:51:a3:d1:f5:20:32:14:b0:c6:c5:32:23:03:91:c7:46:42:6d -# SHA256 Fingerprint: 22:a2:c1:f7:bd:ed:70:4c:c1:e7:01:b5:f4:08:c3:10:88:0f:e9:56:b5:de:2a:4a:44:f9:9c:87:3a:25:a7:c8 ------BEGIN CERTIFICATE----- -MIIClDCCAhqgAwIBAgIILCmcWxbtBZUwCgYIKoZIzj0EAwIwfzELMAkGA1UEBhMC -VVMxDjAMBgNVBAgMBVRleGFzMRAwDgYDVQQHDAdIb3VzdG9uMRgwFgYDVQQKDA9T -U0wgQ29ycG9yYXRpb24xNDAyBgNVBAMMK1NTTC5jb20gRVYgUm9vdCBDZXJ0aWZp -Y2F0aW9uIEF1dGhvcml0eSBFQ0MwHhcNMTYwMjEyMTgxNTIzWhcNNDEwMjEyMTgx -NTIzWjB/MQswCQYDVQQGEwJVUzEOMAwGA1UECAwFVGV4YXMxEDAOBgNVBAcMB0hv -dXN0b24xGDAWBgNVBAoMD1NTTCBDb3Jwb3JhdGlvbjE0MDIGA1UEAwwrU1NMLmNv -bSBFViBSb290IENlcnRpZmljYXRpb24gQXV0aG9yaXR5IEVDQzB2MBAGByqGSM49 -AgEGBSuBBAAiA2IABKoSR5CYG/vvw0AHgyBO8TCCogbR8pKGYfL2IWjKAMTH6kMA -VIbc/R/fALhBYlzccBYy3h+Z1MzFB8gIH2EWB1E9fVwHU+M1OIzfzZ/ZLg1Kthku -WnBaBu2+8KGwytAJKaNjMGEwHQYDVR0OBBYEFFvKXuXe0oGqzagtZFG22XKbl+ZP -MA8GA1UdEwEB/wQFMAMBAf8wHwYDVR0jBBgwFoAUW8pe5d7SgarNqC1kUbbZcpuX -5k8wDgYDVR0PAQH/BAQDAgGGMAoGCCqGSM49BAMCA2gAMGUCMQCK5kCJN+vp1RPZ -ytRrJPOwPYdGWBrssd9v+1a6cGvHOMzosYxPD/fxZ3YOg9AeUY8CMD32IygmTMZg -h5Mmm7I1HrrW9zzRHM76JTymGoEVW/MSD2zuZYrJh6j5B+BimoxcSg== ------END CERTIFICATE----- - -# Issuer: CN=GlobalSign O=GlobalSign OU=GlobalSign Root CA - R6 -# Subject: CN=GlobalSign O=GlobalSign OU=GlobalSign Root CA - R6 -# Label: "GlobalSign Root CA - R6" -# Serial: 1417766617973444989252670301619537 -# MD5 Fingerprint: 4f:dd:07:e4:d4:22:64:39:1e:0c:37:42:ea:d1:c6:ae -# SHA1 Fingerprint: 80:94:64:0e:b5:a7:a1:ca:11:9c:1f:dd:d5:9f:81:02:63:a7:fb:d1 -# SHA256 Fingerprint: 2c:ab:ea:fe:37:d0:6c:a2:2a:ba:73:91:c0:03:3d:25:98:29:52:c4:53:64:73:49:76:3a:3a:b5:ad:6c:cf:69 ------BEGIN CERTIFICATE----- -MIIFgzCCA2ugAwIBAgIORea7A4Mzw4VlSOb/RVEwDQYJKoZIhvcNAQEMBQAwTDEg -MB4GA1UECxMXR2xvYmFsU2lnbiBSb290IENBIC0gUjYxEzARBgNVBAoTCkdsb2Jh -bFNpZ24xEzARBgNVBAMTCkdsb2JhbFNpZ24wHhcNMTQxMjEwMDAwMDAwWhcNMzQx -MjEwMDAwMDAwWjBMMSAwHgYDVQQLExdHbG9iYWxTaWduIFJvb3QgQ0EgLSBSNjET -MBEGA1UEChMKR2xvYmFsU2lnbjETMBEGA1UEAxMKR2xvYmFsU2lnbjCCAiIwDQYJ -KoZIhvcNAQEBBQADggIPADCCAgoCggIBAJUH6HPKZvnsFMp7PPcNCPG0RQssgrRI -xutbPK6DuEGSMxSkb3/pKszGsIhrxbaJ0cay/xTOURQh7ErdG1rG1ofuTToVBu1k -ZguSgMpE3nOUTvOniX9PeGMIyBJQbUJmL025eShNUhqKGoC3GYEOfsSKvGRMIRxD -aNc9PIrFsmbVkJq3MQbFvuJtMgamHvm566qjuL++gmNQ0PAYid/kD3n16qIfKtJw -LnvnvJO7bVPiSHyMEAc4/2ayd2F+4OqMPKq0pPbzlUoSB239jLKJz9CgYXfIWHSw -1CM69106yqLbnQneXUQtkPGBzVeS+n68UARjNN9rkxi+azayOeSsJDa38O+2HBNX -k7besvjihbdzorg1qkXy4J02oW9UivFyVm4uiMVRQkQVlO6jxTiWm05OWgtH8wY2 -SXcwvHE35absIQh1/OZhFj931dmRl4QKbNQCTXTAFO39OfuD8l4UoQSwC+n+7o/h -bguyCLNhZglqsQY6ZZZZwPA1/cnaKI0aEYdwgQqomnUdnjqGBQCe24DWJfncBZ4n -WUx2OVvq+aWh2IMP0f/fMBH5hc8zSPXKbWQULHpYT9NLCEnFlWQaYw55PfWzjMpY -rZxCRXluDocZXFSxZba/jJvcE+kNb7gu3GduyYsRtYQUigAZcIN5kZeR1Bonvzce -MgfYFGM8KEyvAgMBAAGjYzBhMA4GA1UdDwEB/wQEAwIBBjAPBgNVHRMBAf8EBTAD -AQH/MB0GA1UdDgQWBBSubAWjkxPioufi1xzWx/B/yGdToDAfBgNVHSMEGDAWgBSu -bAWjkxPioufi1xzWx/B/yGdToDANBgkqhkiG9w0BAQwFAAOCAgEAgyXt6NH9lVLN -nsAEoJFp5lzQhN7craJP6Ed41mWYqVuoPId8AorRbrcWc+ZfwFSY1XS+wc3iEZGt -Ixg93eFyRJa0lV7Ae46ZeBZDE1ZXs6KzO7V33EByrKPrmzU+sQghoefEQzd5Mr61 -55wsTLxDKZmOMNOsIeDjHfrYBzN2VAAiKrlNIC5waNrlU/yDXNOd8v9EDERm8tLj -vUYAGm0CuiVdjaExUd1URhxN25mW7xocBFymFe944Hn+Xds+qkxV/ZoVqW/hpvvf -cDDpw+5CRu3CkwWJ+n1jez/QcYF8AOiYrg54NMMl+68KnyBr3TsTjxKM4kEaSHpz -oHdpx7Zcf4LIHv5YGygrqGytXm3ABdJ7t+uA/iU3/gKbaKxCXcPu9czc8FB10jZp -nOZ7BN9uBmm23goJSFmH63sUYHpkqmlD75HHTOwY3WzvUy2MmeFe8nI+z1TIvWfs -pA9MRf/TuTAjB0yPEL+GltmZWrSZVxykzLsViVO6LAUP5MSeGbEYNNVMnbrt9x+v -JJUEeKgDu+6B5dpffItKoZB0JaezPkvILFa9x8jvOOJckvB595yEunQtYQEgfn7R -8k8HWV+LLUNS60YMlOH1Zkd5d9VUWx+tJDfLRVpOoERIyNiwmcUVhAn21klJwGW4 -5hpxbqCo8YLoRT5s1gLXCmeDBVrJpBA= ------END CERTIFICATE----- - -# Issuer: CN=OISTE WISeKey Global Root GC CA O=WISeKey OU=OISTE Foundation Endorsed -# Subject: CN=OISTE WISeKey Global Root GC CA O=WISeKey OU=OISTE Foundation Endorsed -# Label: "OISTE WISeKey Global Root GC CA" -# Serial: 44084345621038548146064804565436152554 -# MD5 Fingerprint: a9:d6:b9:2d:2f:93:64:f8:a5:69:ca:91:e9:68:07:23 -# SHA1 Fingerprint: e0:11:84:5e:34:de:be:88:81:b9:9c:f6:16:26:d1:96:1f:c3:b9:31 -# SHA256 Fingerprint: 85:60:f9:1c:36:24:da:ba:95:70:b5:fe:a0:db:e3:6f:f1:1a:83:23:be:94:86:85:4f:b3:f3:4a:55:71:19:8d ------BEGIN CERTIFICATE----- -MIICaTCCAe+gAwIBAgIQISpWDK7aDKtARb8roi066jAKBggqhkjOPQQDAzBtMQsw -CQYDVQQGEwJDSDEQMA4GA1UEChMHV0lTZUtleTEiMCAGA1UECxMZT0lTVEUgRm91 -bmRhdGlvbiBFbmRvcnNlZDEoMCYGA1UEAxMfT0lTVEUgV0lTZUtleSBHbG9iYWwg -Um9vdCBHQyBDQTAeFw0xNzA1MDkwOTQ4MzRaFw00MjA1MDkwOTU4MzNaMG0xCzAJ -BgNVBAYTAkNIMRAwDgYDVQQKEwdXSVNlS2V5MSIwIAYDVQQLExlPSVNURSBGb3Vu -ZGF0aW9uIEVuZG9yc2VkMSgwJgYDVQQDEx9PSVNURSBXSVNlS2V5IEdsb2JhbCBS -b290IEdDIENBMHYwEAYHKoZIzj0CAQYFK4EEACIDYgAETOlQwMYPchi82PG6s4ni -eUqjFqdrVCTbUf/q9Akkwwsin8tqJ4KBDdLArzHkdIJuyiXZjHWd8dvQmqJLIX4W -p2OQ0jnUsYd4XxiWD1AbNTcPasbc2RNNpI6QN+a9WzGRo1QwUjAOBgNVHQ8BAf8E -BAMCAQYwDwYDVR0TAQH/BAUwAwEB/zAdBgNVHQ4EFgQUSIcUrOPDnpBgOtfKie7T -rYy0UGYwEAYJKwYBBAGCNxUBBAMCAQAwCgYIKoZIzj0EAwMDaAAwZQIwJsdpW9zV -57LnyAyMjMPdeYwbY9XJUpROTYJKcx6ygISpJcBMWm1JKWB4E+J+SOtkAjEA2zQg -Mgj/mkkCtojeFK9dbJlxjRo/i9fgojaGHAeCOnZT/cKi7e97sIBPWA9LUzm9 ------END CERTIFICATE----- - -# Issuer: CN=UCA Global G2 Root O=UniTrust -# Subject: CN=UCA Global G2 Root O=UniTrust -# Label: "UCA Global G2 Root" -# Serial: 124779693093741543919145257850076631279 -# MD5 Fingerprint: 80:fe:f0:c4:4a:f0:5c:62:32:9f:1c:ba:78:a9:50:f8 -# SHA1 Fingerprint: 28:f9:78:16:19:7a:ff:18:25:18:aa:44:fe:c1:a0:ce:5c:b6:4c:8a -# SHA256 Fingerprint: 9b:ea:11:c9:76:fe:01:47:64:c1:be:56:a6:f9:14:b5:a5:60:31:7a:bd:99:88:39:33:82:e5:16:1a:a0:49:3c ------BEGIN CERTIFICATE----- -MIIFRjCCAy6gAwIBAgIQXd+x2lqj7V2+WmUgZQOQ7zANBgkqhkiG9w0BAQsFADA9 -MQswCQYDVQQGEwJDTjERMA8GA1UECgwIVW5pVHJ1c3QxGzAZBgNVBAMMElVDQSBH -bG9iYWwgRzIgUm9vdDAeFw0xNjAzMTEwMDAwMDBaFw00MDEyMzEwMDAwMDBaMD0x -CzAJBgNVBAYTAkNOMREwDwYDVQQKDAhVbmlUcnVzdDEbMBkGA1UEAwwSVUNBIEds -b2JhbCBHMiBSb290MIICIjANBgkqhkiG9w0BAQEFAAOCAg8AMIICCgKCAgEAxeYr -b3zvJgUno4Ek2m/LAfmZmqkywiKHYUGRO8vDaBsGxUypK8FnFyIdK+35KYmToni9 -kmugow2ifsqTs6bRjDXVdfkX9s9FxeV67HeToI8jrg4aA3++1NDtLnurRiNb/yzm -VHqUwCoV8MmNsHo7JOHXaOIxPAYzRrZUEaalLyJUKlgNAQLx+hVRZ2zA+te2G3/R -VogvGjqNO7uCEeBHANBSh6v7hn4PJGtAnTRnvI3HLYZveT6OqTwXS3+wmeOwcWDc -C/Vkw85DvG1xudLeJ1uK6NjGruFZfc8oLTW4lVYa8bJYS7cSN8h8s+1LgOGN+jIj -tm+3SJUIsUROhYw6AlQgL9+/V087OpAh18EmNVQg7Mc/R+zvWr9LesGtOxdQXGLY -D0tK3Cv6brxzks3sx1DoQZbXqX5t2Okdj4q1uViSukqSKwxW/YDrCPBeKW4bHAyv -j5OJrdu9o54hyokZ7N+1wxrrFv54NkzWbtA+FxyQF2smuvt6L78RHBgOLXMDj6Dl -NaBa4kx1HXHhOThTeEDMg5PXCp6dW4+K5OXgSORIskfNTip1KnvyIvbJvgmRlld6 -iIis7nCs+dwp4wwcOxJORNanTrAmyPPZGpeRaOrvjUYG0lZFWJo8DA+DuAUlwznP -O6Q0ibd5Ei9Hxeepl2n8pndntd978XplFeRhVmUCAwEAAaNCMEAwDgYDVR0PAQH/ -BAQDAgEGMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYEFIHEjMz15DD/pQwIX4wV -ZyF0Ad/fMA0GCSqGSIb3DQEBCwUAA4ICAQATZSL1jiutROTL/7lo5sOASD0Ee/oj -L3rtNtqyzm325p7lX1iPyzcyochltq44PTUbPrw7tgTQvPlJ9Zv3hcU2tsu8+Mg5 -1eRfB70VVJd0ysrtT7q6ZHafgbiERUlMjW+i67HM0cOU2kTC5uLqGOiiHycFutfl -1qnN3e92mI0ADs0b+gO3joBYDic/UvuUospeZcnWhNq5NXHzJsBPd+aBJ9J3O5oU -b3n09tDh05S60FdRvScFDcH9yBIw7m+NESsIndTUv4BFFJqIRNow6rSn4+7vW4LV -PtateJLbXDzz2K36uGt/xDYotgIVilQsnLAXc47QN6MUPJiVAAwpBVueSUmxX8fj -y88nZY41F7dXyDDZQVu5FLbowg+UMaeUmMxq67XhJ/UQqAHojhJi6IjMtX9Gl8Cb -EGY4GjZGXyJoPd/JxhMnq1MGrKI8hgZlb7F+sSlEmqO6SWkoaY/X5V+tBIZkbxqg -DMUIYs6Ao9Dz7GjevjPHF1t/gMRMTLGmhIrDO7gJzRSBuhjjVFc2/tsvfEehOjPI -+Vg7RE+xygKJBJYoaMVLuCaJu9YzL1DV/pqJuhgyklTGW+Cd+V7lDSKb9triyCGy -YiGqhkCyLmTTX8jjfhFnRR8F/uOi77Oos/N9j/gMHyIfLXC0uAE0djAA5SN4p1bX -UB+K+wb1whnw0A== ------END CERTIFICATE----- - -# Issuer: CN=UCA Extended Validation Root O=UniTrust -# Subject: CN=UCA Extended Validation Root O=UniTrust -# Label: "UCA Extended Validation Root" -# Serial: 106100277556486529736699587978573607008 -# MD5 Fingerprint: a1:f3:5f:43:c6:34:9b:da:bf:8c:7e:05:53:ad:96:e2 -# SHA1 Fingerprint: a3:a1:b0:6f:24:61:23:4a:e3:36:a5:c2:37:fc:a6:ff:dd:f0:d7:3a -# SHA256 Fingerprint: d4:3a:f9:b3:54:73:75:5c:96:84:fc:06:d7:d8:cb:70:ee:5c:28:e7:73:fb:29:4e:b4:1e:e7:17:22:92:4d:24 ------BEGIN CERTIFICATE----- -MIIFWjCCA0KgAwIBAgIQT9Irj/VkyDOeTzRYZiNwYDANBgkqhkiG9w0BAQsFADBH -MQswCQYDVQQGEwJDTjERMA8GA1UECgwIVW5pVHJ1c3QxJTAjBgNVBAMMHFVDQSBF -eHRlbmRlZCBWYWxpZGF0aW9uIFJvb3QwHhcNMTUwMzEzMDAwMDAwWhcNMzgxMjMx -MDAwMDAwWjBHMQswCQYDVQQGEwJDTjERMA8GA1UECgwIVW5pVHJ1c3QxJTAjBgNV -BAMMHFVDQSBFeHRlbmRlZCBWYWxpZGF0aW9uIFJvb3QwggIiMA0GCSqGSIb3DQEB -AQUAA4ICDwAwggIKAoICAQCpCQcoEwKwmeBkqh5DFnpzsZGgdT6o+uM4AHrsiWog -D4vFsJszA1qGxliG1cGFu0/GnEBNyr7uaZa4rYEwmnySBesFK5pI0Lh2PpbIILvS -sPGP2KxFRv+qZ2C0d35qHzwaUnoEPQc8hQ2E0B92CvdqFN9y4zR8V05WAT558aop -O2z6+I9tTcg1367r3CTueUWnhbYFiN6IXSV8l2RnCdm/WhUFhvMJHuxYMjMR83dk -sHYf5BA1FxvyDrFspCqjc/wJHx4yGVMR59mzLC52LqGj3n5qiAno8geK+LLNEOfi -c0CTuwjRP+H8C5SzJe98ptfRr5//lpr1kXuYC3fUfugH0mK1lTnj8/FtDw5lhIpj -VMWAtuCeS31HJqcBCF3RiJ7XwzJE+oJKCmhUfzhTA8ykADNkUVkLo4KRel7sFsLz -KuZi2irbWWIQJUoqgQtHB0MGcIfS+pMRKXpITeuUx3BNr2fVUbGAIAEBtHoIppB/ -TuDvB0GHr2qlXov7z1CymlSvw4m6WC31MJixNnI5fkkE/SmnTHnkBVfblLkWU41G -sx2VYVdWf6/wFlthWG82UBEL2KwrlRYaDh8IzTY0ZRBiZtWAXxQgXy0MoHgKaNYs -1+lvK9JKBZP8nm9rZ/+I8U6laUpSNwXqxhaN0sSZ0YIrO7o1dfdRUVjzyAfd5LQD -fwIDAQABo0IwQDAdBgNVHQ4EFgQU2XQ65DA9DfcS3H5aBZ8eNJr34RQwDwYDVR0T -AQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAYYwDQYJKoZIhvcNAQELBQADggIBADaN -l8xCFWQpN5smLNb7rhVpLGsaGvdftvkHTFnq88nIua7Mui563MD1sC3AO6+fcAUR -ap8lTwEpcOPlDOHqWnzcSbvBHiqB9RZLcpHIojG5qtr8nR/zXUACE/xOHAbKsxSQ -VBcZEhrxH9cMaVr2cXj0lH2RC47skFSOvG+hTKv8dGT9cZr4QQehzZHkPJrgmzI5 -c6sq1WnIeJEmMX3ixzDx/BR4dxIOE/TdFpS/S2d7cFOFyrC78zhNLJA5wA3CXWvp -4uXViI3WLL+rG761KIcSF3Ru/H38j9CHJrAb+7lsq+KePRXBOy5nAliRn+/4Qh8s -t2j1da3Ptfb/EX3C8CSlrdP6oDyp+l3cpaDvRKS+1ujl5BOWF3sGPjLtx7dCvHaj -2GU4Kzg1USEODm8uNBNA4StnDG1KQTAYI1oyVZnJF+A83vbsea0rWBmirSwiGpWO -vpaQXUJXxPkUAzUrHC1RVwinOt4/5Mi0A3PCwSaAuwtCH60NryZy2sy+s6ODWA2C -xR9GUeOcGMyNm43sSet1UNWMKFnKdDTajAshqx7qG+XH/RU+wBeq+yNuJkbL+vmx -cmtpzyKEC2IPrNkZAJSidjzULZrtBJ4tBmIQN1IchXIbJ+XMxjHsN+xjWZsLHXbM -fjKaiJUINlK73nZfdklJrX+9ZSCyycErdhh2n1ax ------END CERTIFICATE----- - -# Issuer: CN=Certigna Root CA O=Dhimyotis OU=0002 48146308100036 -# Subject: CN=Certigna Root CA O=Dhimyotis OU=0002 48146308100036 -# Label: "Certigna Root CA" -# Serial: 269714418870597844693661054334862075617 -# MD5 Fingerprint: 0e:5c:30:62:27:eb:5b:bc:d7:ae:62:ba:e9:d5:df:77 -# SHA1 Fingerprint: 2d:0d:52:14:ff:9e:ad:99:24:01:74:20:47:6e:6c:85:27:27:f5:43 -# SHA256 Fingerprint: d4:8d:3d:23:ee:db:50:a4:59:e5:51:97:60:1c:27:77:4b:9d:7b:18:c9:4d:5a:05:95:11:a1:02:50:b9:31:68 ------BEGIN CERTIFICATE----- -MIIGWzCCBEOgAwIBAgIRAMrpG4nxVQMNo+ZBbcTjpuEwDQYJKoZIhvcNAQELBQAw -WjELMAkGA1UEBhMCRlIxEjAQBgNVBAoMCURoaW15b3RpczEcMBoGA1UECwwTMDAw -MiA0ODE0NjMwODEwMDAzNjEZMBcGA1UEAwwQQ2VydGlnbmEgUm9vdCBDQTAeFw0x -MzEwMDEwODMyMjdaFw0zMzEwMDEwODMyMjdaMFoxCzAJBgNVBAYTAkZSMRIwEAYD -VQQKDAlEaGlteW90aXMxHDAaBgNVBAsMEzAwMDIgNDgxNDYzMDgxMDAwMzYxGTAX -BgNVBAMMEENlcnRpZ25hIFJvb3QgQ0EwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAw -ggIKAoICAQDNGDllGlmx6mQWDoyUJJV8g9PFOSbcDO8WV43X2KyjQn+Cyu3NW9sO -ty3tRQgXstmzy9YXUnIo245Onoq2C/mehJpNdt4iKVzSs9IGPjA5qXSjklYcoW9M -CiBtnyN6tMbaLOQdLNyzKNAT8kxOAkmhVECe5uUFoC2EyP+YbNDrihqECB63aCPu -I9Vwzm1RaRDuoXrC0SIxwoKF0vJVdlB8JXrJhFwLrN1CTivngqIkicuQstDuI7pm -TLtipPlTWmR7fJj6o0ieD5Wupxj0auwuA0Wv8HT4Ks16XdG+RCYyKfHx9WzMfgIh -C59vpD++nVPiz32pLHxYGpfhPTc3GGYo0kDFUYqMwy3OU4gkWGQwFsWq4NYKpkDf -ePb1BHxpE4S80dGnBs8B92jAqFe7OmGtBIyT46388NtEbVncSVmurJqZNjBBe3Yz -IoejwpKGbvlw7q6Hh5UbxHq9MfPU0uWZ/75I7HX1eBYdpnDBfzwboZL7z8g81sWT -Co/1VTp2lc5ZmIoJlXcymoO6LAQ6l73UL77XbJuiyn1tJslV1c/DeVIICZkHJC1k -JWumIWmbat10TWuXekG9qxf5kBdIjzb5LdXF2+6qhUVB+s06RbFo5jZMm5BX7CO5 -hwjCxAnxl4YqKE3idMDaxIzb3+KhF1nOJFl0Mdp//TBt2dzhauH8XwIDAQABo4IB -GjCCARYwDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwHQYDVR0OBBYE -FBiHVuBud+4kNTxOc5of1uHieX4rMB8GA1UdIwQYMBaAFBiHVuBud+4kNTxOc5of -1uHieX4rMEQGA1UdIAQ9MDswOQYEVR0gADAxMC8GCCsGAQUFBwIBFiNodHRwczov -L3d3d3cuY2VydGlnbmEuZnIvYXV0b3JpdGVzLzBtBgNVHR8EZjBkMC+gLaArhilo -dHRwOi8vY3JsLmNlcnRpZ25hLmZyL2NlcnRpZ25hcm9vdGNhLmNybDAxoC+gLYYr -aHR0cDovL2NybC5kaGlteW90aXMuY29tL2NlcnRpZ25hcm9vdGNhLmNybDANBgkq -hkiG9w0BAQsFAAOCAgEAlLieT/DjlQgi581oQfccVdV8AOItOoldaDgvUSILSo3L -6btdPrtcPbEo/uRTVRPPoZAbAh1fZkYJMyjhDSSXcNMQH+pkV5a7XdrnxIxPTGRG -HVyH41neQtGbqH6mid2PHMkwgu07nM3A6RngatgCdTer9zQoKJHyBApPNeNgJgH6 -0BGM+RFq7q89w1DTj18zeTyGqHNFkIwgtnJzFyO+B2XleJINugHA64wcZr+shncB -lA2c5uk5jR+mUYyZDDl34bSb+hxnV29qao6pK0xXeXpXIs/NX2NGjVxZOob4Mkdi -o2cNGJHc+6Zr9UhhcyNZjgKnvETq9Emd8VRY+WCv2hikLyhF3HqgiIZd8zvn/yk1 -gPxkQ5Tm4xxvvq0OKmOZK8l+hfZx6AYDlf7ej0gcWtSS6Cvu5zHbugRqh5jnxV/v -faci9wHYTfmJ0A6aBVmknpjZbyvKcL5kwlWj9Omvw5Ip3IgWJJk8jSaYtlu3zM63 -Nwf9JtmYhST/WSMDmu2dnajkXjjO11INb9I/bbEFa0nOipFGc/T2L/Coc3cOZayh -jWZSaX5LaAzHHjcng6WMxwLkFM1JAbBzs/3GkDpv0mztO+7skb6iQ12LAEpmJURw -3kAP+HwV96LOPNdeE4yBFxgX0b3xdxA61GU5wSesVywlVP+i2k+KYTlerj1KjL0= ------END CERTIFICATE----- - -# Issuer: CN=emSign Root CA - G1 O=eMudhra Technologies Limited OU=emSign PKI -# Subject: CN=emSign Root CA - G1 O=eMudhra Technologies Limited OU=emSign PKI -# Label: "emSign Root CA - G1" -# Serial: 235931866688319308814040 -# MD5 Fingerprint: 9c:42:84:57:dd:cb:0b:a7:2e:95:ad:b6:f3:da:bc:ac -# SHA1 Fingerprint: 8a:c7:ad:8f:73:ac:4e:c1:b5:75:4d:a5:40:f4:fc:cf:7c:b5:8e:8c -# SHA256 Fingerprint: 40:f6:af:03:46:a9:9a:a1:cd:1d:55:5a:4e:9c:ce:62:c7:f9:63:46:03:ee:40:66:15:83:3d:c8:c8:d0:03:67 ------BEGIN CERTIFICATE----- -MIIDlDCCAnygAwIBAgIKMfXkYgxsWO3W2DANBgkqhkiG9w0BAQsFADBnMQswCQYD -VQQGEwJJTjETMBEGA1UECxMKZW1TaWduIFBLSTElMCMGA1UEChMcZU11ZGhyYSBU -ZWNobm9sb2dpZXMgTGltaXRlZDEcMBoGA1UEAxMTZW1TaWduIFJvb3QgQ0EgLSBH -MTAeFw0xODAyMTgxODMwMDBaFw00MzAyMTgxODMwMDBaMGcxCzAJBgNVBAYTAklO -MRMwEQYDVQQLEwplbVNpZ24gUEtJMSUwIwYDVQQKExxlTXVkaHJhIFRlY2hub2xv -Z2llcyBMaW1pdGVkMRwwGgYDVQQDExNlbVNpZ24gUm9vdCBDQSAtIEcxMIIBIjAN -BgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAk0u76WaK7p1b1TST0Bsew+eeuGQz -f2N4aLTNLnF115sgxk0pvLZoYIr3IZpWNVrzdr3YzZr/k1ZLpVkGoZM0Kd0WNHVO -8oG0x5ZOrRkVUkr+PHB1cM2vK6sVmjM8qrOLqs1D/fXqcP/tzxE7lM5OMhbTI0Aq -d7OvPAEsbO2ZLIvZTmmYsvePQbAyeGHWDV/D+qJAkh1cF+ZwPjXnorfCYuKrpDhM -tTk1b+oDafo6VGiFbdbyL0NVHpENDtjVaqSW0RM8LHhQ6DqS0hdW5TUaQBw+jSzt -Od9C4INBdN+jzcKGYEho42kLVACL5HZpIQ15TjQIXhTCzLG3rdd8cIrHhQIDAQAB -o0IwQDAdBgNVHQ4EFgQU++8Nhp6w492pufEhF38+/PB3KxowDgYDVR0PAQH/BAQD -AgEGMA8GA1UdEwEB/wQFMAMBAf8wDQYJKoZIhvcNAQELBQADggEBAFn/8oz1h31x -PaOfG1vR2vjTnGs2vZupYeveFix0PZ7mddrXuqe8QhfnPZHr5X3dPpzxz5KsbEjM -wiI/aTvFthUvozXGaCocV685743QNcMYDHsAVhzNixl03r4PEuDQqqE/AjSxcM6d -GNYIAwlG7mDgfrbESQRRfXBgvKqy/3lyeqYdPV8q+Mri/Tm3R7nrft8EI6/6nAYH -6ftjk4BAtcZsCjEozgyfz7MjNYBBjWzEN3uBL4ChQEKF6dk4jeihU80Bv2noWgby -RQuQ+q7hv53yrlc8pa6yVvSLZUDp/TGBLPQ5Cdjua6e0ph0VpZj3AYHYhX3zUVxx -iN66zB+Afko= ------END CERTIFICATE----- - -# Issuer: CN=emSign ECC Root CA - G3 O=eMudhra Technologies Limited OU=emSign PKI -# Subject: CN=emSign ECC Root CA - G3 O=eMudhra Technologies Limited OU=emSign PKI -# Label: "emSign ECC Root CA - G3" -# Serial: 287880440101571086945156 -# MD5 Fingerprint: ce:0b:72:d1:9f:88:8e:d0:50:03:e8:e3:b8:8b:67:40 -# SHA1 Fingerprint: 30:43:fa:4f:f2:57:dc:a0:c3:80:ee:2e:58:ea:78:b2:3f:e6:bb:c1 -# SHA256 Fingerprint: 86:a1:ec:ba:08:9c:4a:8d:3b:be:27:34:c6:12:ba:34:1d:81:3e:04:3c:f9:e8:a8:62:cd:5c:57:a3:6b:be:6b ------BEGIN CERTIFICATE----- -MIICTjCCAdOgAwIBAgIKPPYHqWhwDtqLhDAKBggqhkjOPQQDAzBrMQswCQYDVQQG -EwJJTjETMBEGA1UECxMKZW1TaWduIFBLSTElMCMGA1UEChMcZU11ZGhyYSBUZWNo -bm9sb2dpZXMgTGltaXRlZDEgMB4GA1UEAxMXZW1TaWduIEVDQyBSb290IENBIC0g -RzMwHhcNMTgwMjE4MTgzMDAwWhcNNDMwMjE4MTgzMDAwWjBrMQswCQYDVQQGEwJJ -TjETMBEGA1UECxMKZW1TaWduIFBLSTElMCMGA1UEChMcZU11ZGhyYSBUZWNobm9s -b2dpZXMgTGltaXRlZDEgMB4GA1UEAxMXZW1TaWduIEVDQyBSb290IENBIC0gRzMw -djAQBgcqhkjOPQIBBgUrgQQAIgNiAAQjpQy4LRL1KPOxst3iAhKAnjlfSU2fySU0 -WXTsuwYc58Byr+iuL+FBVIcUqEqy6HyC5ltqtdyzdc6LBtCGI79G1Y4PPwT01xyS -fvalY8L1X44uT6EYGQIrMgqCZH0Wk9GjQjBAMB0GA1UdDgQWBBR8XQKEE9TMipuB -zhccLikenEhjQjAOBgNVHQ8BAf8EBAMCAQYwDwYDVR0TAQH/BAUwAwEB/zAKBggq -hkjOPQQDAwNpADBmAjEAvvNhzwIQHWSVB7gYboiFBS+DCBeQyh+KTOgNG3qxrdWB -CUfvO6wIBHxcmbHtRwfSAjEAnbpV/KlK6O3t5nYBQnvI+GDZjVGLVTv7jHvrZQnD -+JbNR6iC8hZVdyR+EhCVBCyj ------END CERTIFICATE----- - -# Issuer: CN=emSign Root CA - C1 O=eMudhra Inc OU=emSign PKI -# Subject: CN=emSign Root CA - C1 O=eMudhra Inc OU=emSign PKI -# Label: "emSign Root CA - C1" -# Serial: 825510296613316004955058 -# MD5 Fingerprint: d8:e3:5d:01:21:fa:78:5a:b0:df:ba:d2:ee:2a:5f:68 -# SHA1 Fingerprint: e7:2e:f1:df:fc:b2:09:28:cf:5d:d4:d5:67:37:b1:51:cb:86:4f:01 -# SHA256 Fingerprint: 12:56:09:aa:30:1d:a0:a2:49:b9:7a:82:39:cb:6a:34:21:6f:44:dc:ac:9f:39:54:b1:42:92:f2:e8:c8:60:8f ------BEGIN CERTIFICATE----- -MIIDczCCAlugAwIBAgILAK7PALrEzzL4Q7IwDQYJKoZIhvcNAQELBQAwVjELMAkG -A1UEBhMCVVMxEzARBgNVBAsTCmVtU2lnbiBQS0kxFDASBgNVBAoTC2VNdWRocmEg -SW5jMRwwGgYDVQQDExNlbVNpZ24gUm9vdCBDQSAtIEMxMB4XDTE4MDIxODE4MzAw -MFoXDTQzMDIxODE4MzAwMFowVjELMAkGA1UEBhMCVVMxEzARBgNVBAsTCmVtU2ln -biBQS0kxFDASBgNVBAoTC2VNdWRocmEgSW5jMRwwGgYDVQQDExNlbVNpZ24gUm9v -dCBDQSAtIEMxMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAz+upufGZ -BczYKCFK83M0UYRWEPWgTywS4/oTmifQz/l5GnRfHXk5/Fv4cI7gklL35CX5VIPZ -HdPIWoU/Xse2B+4+wM6ar6xWQio5JXDWv7V7Nq2s9nPczdcdioOl+yuQFTdrHCZH -3DspVpNqs8FqOp099cGXOFgFixwR4+S0uF2FHYP+eF8LRWgYSKVGczQ7/g/IdrvH -GPMF0Ybzhe3nudkyrVWIzqa2kbBPrH4VI5b2P/AgNBbeCsbEBEV5f6f9vtKppa+c -xSMq9zwhbL2vj07FOrLzNBL834AaSaTUqZX3noleoomslMuoaJuvimUnzYnu3Yy1 -aylwQ6BpC+S5DwIDAQABo0IwQDAdBgNVHQ4EFgQU/qHgcB4qAzlSWkK+XJGFehiq -TbUwDgYDVR0PAQH/BAQDAgEGMA8GA1UdEwEB/wQFMAMBAf8wDQYJKoZIhvcNAQEL -BQADggEBAMJKVvoVIXsoounlHfv4LcQ5lkFMOycsxGwYFYDGrK9HWS8mC+M2sO87 -/kOXSTKZEhVb3xEp/6tT+LvBeA+snFOvV71ojD1pM/CjoCNjO2RnIkSt1XHLVip4 -kqNPEjE2NuLe/gDEo2APJ62gsIq1NnpSob0n9CAnYuhNlCQT5AoE6TyrLshDCUrG -YQTlSTR+08TI9Q/Aqum6VF7zYytPT1DU/rl7mYw9wC68AivTxEDkigcxHpvOJpkT -+xHqmiIMERnHXhuBUDDIlhJu58tBf5E7oke3VIAb3ADMmpDqw8NQBmIMMMAVSKeo -WXzhriKi4gp6D/piq1JM4fHfyr6DDUI= ------END CERTIFICATE----- - -# Issuer: CN=emSign ECC Root CA - C3 O=eMudhra Inc OU=emSign PKI -# Subject: CN=emSign ECC Root CA - C3 O=eMudhra Inc OU=emSign PKI -# Label: "emSign ECC Root CA - C3" -# Serial: 582948710642506000014504 -# MD5 Fingerprint: 3e:53:b3:a3:81:ee:d7:10:f8:d3:b0:1d:17:92:f5:d5 -# SHA1 Fingerprint: b6:af:43:c2:9b:81:53:7d:f6:ef:6b:c3:1f:1f:60:15:0c:ee:48:66 -# SHA256 Fingerprint: bc:4d:80:9b:15:18:9d:78:db:3e:1d:8c:f4:f9:72:6a:79:5d:a1:64:3c:a5:f1:35:8e:1d:db:0e:dc:0d:7e:b3 ------BEGIN CERTIFICATE----- -MIICKzCCAbGgAwIBAgIKe3G2gla4EnycqDAKBggqhkjOPQQDAzBaMQswCQYDVQQG -EwJVUzETMBEGA1UECxMKZW1TaWduIFBLSTEUMBIGA1UEChMLZU11ZGhyYSBJbmMx -IDAeBgNVBAMTF2VtU2lnbiBFQ0MgUm9vdCBDQSAtIEMzMB4XDTE4MDIxODE4MzAw -MFoXDTQzMDIxODE4MzAwMFowWjELMAkGA1UEBhMCVVMxEzARBgNVBAsTCmVtU2ln -biBQS0kxFDASBgNVBAoTC2VNdWRocmEgSW5jMSAwHgYDVQQDExdlbVNpZ24gRUND -IFJvb3QgQ0EgLSBDMzB2MBAGByqGSM49AgEGBSuBBAAiA2IABP2lYa57JhAd6bci -MK4G9IGzsUJxlTm801Ljr6/58pc1kjZGDoeVjbk5Wum739D+yAdBPLtVb4Ojavti -sIGJAnB9SMVK4+kiVCJNk7tCDK93nCOmfddhEc5lx/h//vXyqaNCMEAwHQYDVR0O -BBYEFPtaSNCAIEDyqOkAB2kZd6fmw/TPMA4GA1UdDwEB/wQEAwIBBjAPBgNVHRMB -Af8EBTADAQH/MAoGCCqGSM49BAMDA2gAMGUCMQC02C8Cif22TGK6Q04ThHK1rt0c -3ta13FaPWEBaLd4gTCKDypOofu4SQMfWh0/434UCMBwUZOR8loMRnLDRWmFLpg9J -0wD8ofzkpf9/rdcw0Md3f76BB1UwUCAU9Vc4CqgxUQ== ------END CERTIFICATE----- - -# Issuer: CN=Hongkong Post Root CA 3 O=Hongkong Post -# Subject: CN=Hongkong Post Root CA 3 O=Hongkong Post -# Label: "Hongkong Post Root CA 3" -# Serial: 46170865288971385588281144162979347873371282084 -# MD5 Fingerprint: 11:fc:9f:bd:73:30:02:8a:fd:3f:f3:58:b9:cb:20:f0 -# SHA1 Fingerprint: 58:a2:d0:ec:20:52:81:5b:c1:f3:f8:64:02:24:4e:c2:8e:02:4b:02 -# SHA256 Fingerprint: 5a:2f:c0:3f:0c:83:b0:90:bb:fa:40:60:4b:09:88:44:6c:76:36:18:3d:f9:84:6e:17:10:1a:44:7f:b8:ef:d6 ------BEGIN CERTIFICATE----- -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 -mpv0 ------END CERTIFICATE----- - -# Issuer: CN=Microsoft ECC Root Certificate Authority 2017 O=Microsoft Corporation -# Subject: CN=Microsoft ECC Root Certificate Authority 2017 O=Microsoft Corporation -# Label: "Microsoft ECC Root Certificate Authority 2017" -# Serial: 136839042543790627607696632466672567020 -# MD5 Fingerprint: dd:a1:03:e6:4a:93:10:d1:bf:f0:19:42:cb:fe:ed:67 -# SHA1 Fingerprint: 99:9a:64:c3:7f:f4:7d:9f:ab:95:f1:47:69:89:14:60:ee:c4:c3:c5 -# SHA256 Fingerprint: 35:8d:f3:9d:76:4a:f9:e1:b7:66:e9:c9:72:df:35:2e:e1:5c:fa:c2:27:af:6a:d1:d7:0e:8e:4a:6e:dc:ba:02 ------BEGIN CERTIFICATE----- -MIICWTCCAd+gAwIBAgIQZvI9r4fei7FK6gxXMQHC7DAKBggqhkjOPQQDAzBlMQsw -CQYDVQQGEwJVUzEeMBwGA1UEChMVTWljcm9zb2Z0IENvcnBvcmF0aW9uMTYwNAYD -VQQDEy1NaWNyb3NvZnQgRUNDIFJvb3QgQ2VydGlmaWNhdGUgQXV0aG9yaXR5IDIw -MTcwHhcNMTkxMjE4MjMwNjQ1WhcNNDIwNzE4MjMxNjA0WjBlMQswCQYDVQQGEwJV -UzEeMBwGA1UEChMVTWljcm9zb2Z0IENvcnBvcmF0aW9uMTYwNAYDVQQDEy1NaWNy -b3NvZnQgRUNDIFJvb3QgQ2VydGlmaWNhdGUgQXV0aG9yaXR5IDIwMTcwdjAQBgcq -hkjOPQIBBgUrgQQAIgNiAATUvD0CQnVBEyPNgASGAlEvaqiBYgtlzPbKnR5vSmZR -ogPZnZH6thaxjG7efM3beaYvzrvOcS/lpaso7GMEZpn4+vKTEAXhgShC48Zo9OYb -hGBKia/teQ87zvH2RPUBeMCjVDBSMA4GA1UdDwEB/wQEAwIBhjAPBgNVHRMBAf8E -BTADAQH/MB0GA1UdDgQWBBTIy5lycFIM+Oa+sgRXKSrPQhDtNTAQBgkrBgEEAYI3 -FQEEAwIBADAKBggqhkjOPQQDAwNoADBlAjBY8k3qDPlfXu5gKcs68tvWMoQZP3zV -L8KxzJOuULsJMsbG7X7JNpQS5GiFBqIb0C8CMQCZ6Ra0DvpWSNSkMBaReNtUjGUB -iudQZsIxtzm6uBoiB078a1QWIP8rtedMDE2mT3M= ------END CERTIFICATE----- - -# Issuer: CN=Microsoft RSA Root Certificate Authority 2017 O=Microsoft Corporation -# Subject: CN=Microsoft RSA Root Certificate Authority 2017 O=Microsoft Corporation -# Label: "Microsoft RSA Root Certificate Authority 2017" -# Serial: 40975477897264996090493496164228220339 -# MD5 Fingerprint: 10:ff:00:ff:cf:c9:f8:c7:7a:c0:ee:35:8e:c9:0f:47 -# SHA1 Fingerprint: 73:a5:e6:4a:3b:ff:83:16:ff:0e:dc:cc:61:8a:90:6e:4e:ae:4d:74 -# SHA256 Fingerprint: c7:41:f7:0f:4b:2a:8d:88:bf:2e:71:c1:41:22:ef:53:ef:10:eb:a0:cf:a5:e6:4c:fa:20:f4:18:85:30:73:e0 ------BEGIN CERTIFICATE----- -MIIFqDCCA5CgAwIBAgIQHtOXCV/YtLNHcB6qvn9FszANBgkqhkiG9w0BAQwFADBl -MQswCQYDVQQGEwJVUzEeMBwGA1UEChMVTWljcm9zb2Z0IENvcnBvcmF0aW9uMTYw -NAYDVQQDEy1NaWNyb3NvZnQgUlNBIFJvb3QgQ2VydGlmaWNhdGUgQXV0aG9yaXR5 -IDIwMTcwHhcNMTkxMjE4MjI1MTIyWhcNNDIwNzE4MjMwMDIzWjBlMQswCQYDVQQG -EwJVUzEeMBwGA1UEChMVTWljcm9zb2Z0IENvcnBvcmF0aW9uMTYwNAYDVQQDEy1N -aWNyb3NvZnQgUlNBIFJvb3QgQ2VydGlmaWNhdGUgQXV0aG9yaXR5IDIwMTcwggIi -MA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQDKW76UM4wplZEWCpW9R2LBifOZ -Nt9GkMml7Xhqb0eRaPgnZ1AzHaGm++DlQ6OEAlcBXZxIQIJTELy/xztokLaCLeX0 -ZdDMbRnMlfl7rEqUrQ7eS0MdhweSE5CAg2Q1OQT85elss7YfUJQ4ZVBcF0a5toW1 -HLUX6NZFndiyJrDKxHBKrmCk3bPZ7Pw71VdyvD/IybLeS2v4I2wDwAW9lcfNcztm -gGTjGqwu+UcF8ga2m3P1eDNbx6H7JyqhtJqRjJHTOoI+dkC0zVJhUXAoP8XFWvLJ -jEm7FFtNyP9nTUwSlq31/niol4fX/V4ggNyhSyL71Imtus5Hl0dVe49FyGcohJUc -aDDv70ngNXtk55iwlNpNhTs+VcQor1fznhPbRiefHqJeRIOkpcrVE7NLP8TjwuaG -YaRSMLl6IE9vDzhTyzMMEyuP1pq9KsgtsRx9S1HKR9FIJ3Jdh+vVReZIZZ2vUpC6 -W6IYZVcSn2i51BVrlMRpIpj0M+Dt+VGOQVDJNE92kKz8OMHY4Xu54+OU4UZpyw4K -UGsTuqwPN1q3ErWQgR5WrlcihtnJ0tHXUeOrO8ZV/R4O03QK0dqq6mm4lyiPSMQH -+FJDOvTKVTUssKZqwJz58oHhEmrARdlns87/I6KJClTUFLkqqNfs+avNJVgyeY+Q -W5g5xAgGwax/Dj0ApQIDAQABo1QwUjAOBgNVHQ8BAf8EBAMCAYYwDwYDVR0TAQH/ -BAUwAwEB/zAdBgNVHQ4EFgQUCctZf4aycI8awznjwNnpv7tNsiMwEAYJKwYBBAGC -NxUBBAMCAQAwDQYJKoZIhvcNAQEMBQADggIBAKyvPl3CEZaJjqPnktaXFbgToqZC -LgLNFgVZJ8og6Lq46BrsTaiXVq5lQ7GPAJtSzVXNUzltYkyLDVt8LkS/gxCP81OC -gMNPOsduET/m4xaRhPtthH80dK2Jp86519efhGSSvpWhrQlTM93uCupKUY5vVau6 -tZRGrox/2KJQJWVggEbbMwSubLWYdFQl3JPk+ONVFT24bcMKpBLBaYVu32TxU5nh -SnUgnZUP5NbcA/FZGOhHibJXWpS2qdgXKxdJ5XbLwVaZOjex/2kskZGT4d9Mozd2 -TaGf+G0eHdP67Pv0RR0Tbc/3WeUiJ3IrhvNXuzDtJE3cfVa7o7P4NHmJweDyAmH3 -pvwPuxwXC65B2Xy9J6P9LjrRk5Sxcx0ki69bIImtt2dmefU6xqaWM/5TkshGsRGR -xpl/j8nWZjEgQRCHLQzWwa80mMpkg/sTV9HB8Dx6jKXB/ZUhoHHBk2dxEuqPiApp -GWSZI1b7rCoucL5mxAyE7+WL85MB+GqQk2dLsmijtWKP6T+MejteD+eMuMZ87zf9 -dOLITzNy4ZQ5bb0Sr74MTnB8G2+NszKTc0QWbej09+CVgI+WXTik9KveCjCHk9hN -AHFiRSdLOkKEW39lt2c0Ui2cFmuqqNh7o0JMcccMyj6D5KbvtwEwXlGjefVwaaZB -RA+GsCyRxj3qrg+E ------END CERTIFICATE----- - -# Issuer: CN=e-Szigno Root CA 2017 O=Microsec Ltd. -# Subject: CN=e-Szigno Root CA 2017 O=Microsec Ltd. -# Label: "e-Szigno Root CA 2017" -# Serial: 411379200276854331539784714 -# MD5 Fingerprint: de:1f:f6:9e:84:ae:a7:b4:21:ce:1e:58:7d:d1:84:98 -# SHA1 Fingerprint: 89:d4:83:03:4f:9e:9a:48:80:5f:72:37:d4:a9:a6:ef:cb:7c:1f:d1 -# SHA256 Fingerprint: be:b0:0b:30:83:9b:9b:c3:2c:32:e4:44:79:05:95:06:41:f2:64:21:b1:5e:d0:89:19:8b:51:8a:e2:ea:1b:99 ------BEGIN CERTIFICATE----- -MIICQDCCAeWgAwIBAgIMAVRI7yH9l1kN9QQKMAoGCCqGSM49BAMCMHExCzAJBgNV -BAYTAkhVMREwDwYDVQQHDAhCdWRhcGVzdDEWMBQGA1UECgwNTWljcm9zZWMgTHRk -LjEXMBUGA1UEYQwOVkFUSFUtMjM1ODQ0OTcxHjAcBgNVBAMMFWUtU3ppZ25vIFJv -b3QgQ0EgMjAxNzAeFw0xNzA4MjIxMjA3MDZaFw00MjA4MjIxMjA3MDZaMHExCzAJ -BgNVBAYTAkhVMREwDwYDVQQHDAhCdWRhcGVzdDEWMBQGA1UECgwNTWljcm9zZWMg -THRkLjEXMBUGA1UEYQwOVkFUSFUtMjM1ODQ0OTcxHjAcBgNVBAMMFWUtU3ppZ25v -IFJvb3QgQ0EgMjAxNzBZMBMGByqGSM49AgEGCCqGSM49AwEHA0IABJbcPYrYsHtv -xie+RJCxs1YVe45DJH0ahFnuY2iyxl6H0BVIHqiQrb1TotreOpCmYF9oMrWGQd+H -Wyx7xf58etqjYzBhMA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgEGMB0G -A1UdDgQWBBSHERUI0arBeAyxr87GyZDvvzAEwDAfBgNVHSMEGDAWgBSHERUI0arB -eAyxr87GyZDvvzAEwDAKBggqhkjOPQQDAgNJADBGAiEAtVfd14pVCzbhhkT61Nlo -jbjcI4qKDdQvfepz7L9NbKgCIQDLpbQS+ue16M9+k/zzNY9vTlp8tLxOsvxyqltZ -+efcMQ== ------END CERTIFICATE----- - -# Issuer: O=CERTSIGN SA OU=certSIGN ROOT CA G2 -# Subject: O=CERTSIGN SA OU=certSIGN ROOT CA G2 -# Label: "certSIGN Root CA G2" -# Serial: 313609486401300475190 -# MD5 Fingerprint: 8c:f1:75:8a:c6:19:cf:94:b7:f7:65:20:87:c3:97:c7 -# SHA1 Fingerprint: 26:f9:93:b4:ed:3d:28:27:b0:b9:4b:a7:e9:15:1d:a3:8d:92:e5:32 -# SHA256 Fingerprint: 65:7c:fe:2f:a7:3f:aa:38:46:25:71:f3:32:a2:36:3a:46:fc:e7:02:09:51:71:07:02:cd:fb:b6:ee:da:33:05 ------BEGIN CERTIFICATE----- -MIIFRzCCAy+gAwIBAgIJEQA0tk7GNi02MA0GCSqGSIb3DQEBCwUAMEExCzAJBgNV -BAYTAlJPMRQwEgYDVQQKEwtDRVJUU0lHTiBTQTEcMBoGA1UECxMTY2VydFNJR04g -Uk9PVCBDQSBHMjAeFw0xNzAyMDYwOTI3MzVaFw00MjAyMDYwOTI3MzVaMEExCzAJ -BgNVBAYTAlJPMRQwEgYDVQQKEwtDRVJUU0lHTiBTQTEcMBoGA1UECxMTY2VydFNJ -R04gUk9PVCBDQSBHMjCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAMDF -dRmRfUR0dIf+DjuW3NgBFszuY5HnC2/OOwppGnzC46+CjobXXo9X69MhWf05N0Iw -vlDqtg+piNguLWkh59E3GE59kdUWX2tbAMI5Qw02hVK5U2UPHULlj88F0+7cDBrZ -uIt4ImfkabBoxTzkbFpG583H+u/E7Eu9aqSs/cwoUe+StCmrqzWaTOTECMYmzPhp -n+Sc8CnTXPnGFiWeI8MgwT0PPzhAsP6CRDiqWhqKa2NYOLQV07YRaXseVO6MGiKs -cpc/I1mbySKEwQdPzH/iV8oScLumZfNpdWO9lfsbl83kqK/20U6o2YpxJM02PbyW -xPFsqa7lzw1uKA2wDrXKUXt4FMMgL3/7FFXhEZn91QqhngLjYl/rNUssuHLoPj1P -rCy7Lobio3aP5ZMqz6WryFyNSwb/EkaseMsUBzXgqd+L6a8VTxaJW732jcZZroiF -DsGJ6x9nxUWO/203Nit4ZoORUSs9/1F3dmKh7Gc+PoGD4FapUB8fepmrY7+EF3fx -DTvf95xhszWYijqy7DwaNz9+j5LP2RIUZNoQAhVB/0/E6xyjyfqZ90bp4RjZsbgy -LcsUDFDYg2WD7rlcz8sFWkz6GZdr1l0T08JcVLwyc6B49fFtHsufpaafItzRUZ6C -eWRgKRM+o/1Pcmqr4tTluCRVLERLiohEnMqE0yo7AgMBAAGjQjBAMA8GA1UdEwEB -/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgEGMB0GA1UdDgQWBBSCIS1mxteg4BXrzkwJ -d8RgnlRuAzANBgkqhkiG9w0BAQsFAAOCAgEAYN4auOfyYILVAzOBywaK8SJJ6ejq -kX/GM15oGQOGO0MBzwdw5AgeZYWR5hEit/UCI46uuR59H35s5r0l1ZUa8gWmr4UC -b6741jH/JclKyMeKqdmfS0mbEVeZkkMR3rYzpMzXjWR91M08KCy0mpbqTfXERMQl -qiCA2ClV9+BB/AYm/7k29UMUA2Z44RGx2iBfRgB4ACGlHgAoYXhvqAEBj500mv/0 -OJD7uNGzcgbJceaBxXntC6Z58hMLnPddDnskk7RI24Zf3lCGeOdA5jGokHZwYa+c -NywRtYK3qq4kNFtyDGkNzVmf9nGvnAvRCjj5BiKDUyUM/FHE5r7iOZULJK2v0ZXk -ltd0ZGtxTgI8qoXzIKNDOXZbbFD+mpwUHmUUihW9o4JFWklWatKcsWMy5WHgUyIO -pwpJ6st+H6jiYoD2EEVSmAYY3qXNL3+q1Ok+CHLsIwMCPKaq2LxndD0UF/tUSxfj -03k9bWtJySgOLnRQvwzZRjoQhsmnP+mg7H/rpXdYaXHmgwo38oZJar55CJD2AhZk -PuXaTH4MNMn5X7azKFGnpyuqSfqNZSlO42sTp5SjLVFteAxEy9/eCG/Oo2Sr05WE -1LlSVHJ7liXMvGnjSG4N0MedJ5qq+BOS3R7fY581qRY27Iy4g/Q9iY/NtBde17MX -QRBdJ3NghVdJIgc= ------END CERTIFICATE----- - -# Issuer: CN=Trustwave Global Certification Authority O=Trustwave Holdings, Inc. -# Subject: CN=Trustwave Global Certification Authority O=Trustwave Holdings, Inc. -# Label: "Trustwave Global Certification Authority" -# Serial: 1846098327275375458322922162 -# MD5 Fingerprint: f8:1c:18:2d:2f:ba:5f:6d:a1:6c:bc:c7:ab:91:c7:0e -# SHA1 Fingerprint: 2f:8f:36:4f:e1:58:97:44:21:59:87:a5:2a:9a:d0:69:95:26:7f:b5 -# SHA256 Fingerprint: 97:55:20:15:f5:dd:fc:3c:87:88:c0:06:94:45:55:40:88:94:45:00:84:f1:00:86:70:86:bc:1a:2b:b5:8d:c8 ------BEGIN CERTIFICATE----- -MIIF2jCCA8KgAwIBAgIMBfcOhtpJ80Y1LrqyMA0GCSqGSIb3DQEBCwUAMIGIMQsw -CQYDVQQGEwJVUzERMA8GA1UECAwISWxsaW5vaXMxEDAOBgNVBAcMB0NoaWNhZ28x -ITAfBgNVBAoMGFRydXN0d2F2ZSBIb2xkaW5ncywgSW5jLjExMC8GA1UEAwwoVHJ1 -c3R3YXZlIEdsb2JhbCBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTAeFw0xNzA4MjMx -OTM0MTJaFw00MjA4MjMxOTM0MTJaMIGIMQswCQYDVQQGEwJVUzERMA8GA1UECAwI -SWxsaW5vaXMxEDAOBgNVBAcMB0NoaWNhZ28xITAfBgNVBAoMGFRydXN0d2F2ZSBI -b2xkaW5ncywgSW5jLjExMC8GA1UEAwwoVHJ1c3R3YXZlIEdsb2JhbCBDZXJ0aWZp -Y2F0aW9uIEF1dGhvcml0eTCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIB -ALldUShLPDeS0YLOvR29zd24q88KPuFd5dyqCblXAj7mY2Hf8g+CY66j96xz0Xzn -swuvCAAJWX/NKSqIk4cXGIDtiLK0thAfLdZfVaITXdHG6wZWiYj+rDKd/VzDBcdu -7oaJuogDnXIhhpCujwOl3J+IKMujkkkP7NAP4m1ET4BqstTnoApTAbqOl5F2brz8 -1Ws25kCI1nsvXwXoLG0R8+eyvpJETNKXpP7ScoFDB5zpET71ixpZfR9oWN0EACyW -80OzfpgZdNmcc9kYvkHHNHnZ9GLCQ7mzJ7Aiy/k9UscwR7PJPrhq4ufogXBeQotP -JqX+OsIgbrv4Fo7NDKm0G2x2EOFYeUY+VM6AqFcJNykbmROPDMjWLBz7BegIlT1l -RtzuzWniTY+HKE40Cz7PFNm73bZQmq131BnW2hqIyE4bJ3XYsgjxroMwuREOzYfw -hI0Vcnyh78zyiGG69Gm7DIwLdVcEuE4qFC49DxweMqZiNu5m4iK4BUBjECLzMx10 -coos9TkpoNPnG4CELcU9402x/RpvumUHO1jsQkUm+9jaJXLE9gCxInm943xZYkqc -BW89zubWR2OZxiRvchLIrH+QtAuRcOi35hYQcRfO3gZPSEF9NUqjifLJS3tBEW1n -twiYTOURGa5CgNz7kAXU+FDKvuStx8KU1xad5hePrzb7AgMBAAGjQjBAMA8GA1Ud -EwEB/wQFMAMBAf8wHQYDVR0OBBYEFJngGWcNYtt2s9o9uFvo/ULSMQ6HMA4GA1Ud -DwEB/wQEAwIBBjANBgkqhkiG9w0BAQsFAAOCAgEAmHNw4rDT7TnsTGDZqRKGFx6W -0OhUKDtkLSGm+J1WE2pIPU/HPinbbViDVD2HfSMF1OQc3Og4ZYbFdada2zUFvXfe -uyk3QAUHw5RSn8pk3fEbK9xGChACMf1KaA0HZJDmHvUqoai7PF35owgLEQzxPy0Q -lG/+4jSHg9bP5Rs1bdID4bANqKCqRieCNqcVtgimQlRXtpla4gt5kNdXElE1GYhB -aCXUNxeEFfsBctyV3lImIJgm4nb1J2/6ADtKYdkNy1GTKv0WBpanI5ojSP5RvbbE -sLFUzt5sQa0WZ37b/TjNuThOssFgy50X31ieemKyJo90lZvkWx3SD92YHJtZuSPT -MaCm/zjdzyBP6VhWOmfD0faZmZ26NraAL4hHT4a/RDqA5Dccprrql5gR0IRiR2Qe -qu5AvzSxnI9O4fKSTx+O856X3vOmeWqJcU9LJxdI/uz0UA9PSX3MReO9ekDFQdxh -VicGaeVyQYHTtgGJoC86cnn+OjC/QezHYj6RS8fZMXZC+fc8Y+wmjHMMfRod6qh8 -h6jCJ3zhM0EPz8/8AKAigJ5Kp28AsEFFtyLKaEjFQqKu3R3y4G5OBVixwJAWKqQ9 -EEC+j2Jjg6mcgn0tAumDMHzLJ8n9HmYAsC7TIS+OMxZsmO0QqAfWzJPP29FpHOTK -yeC2nOnOcXHebD8WpHk= ------END CERTIFICATE----- - -# Issuer: CN=Trustwave Global ECC P256 Certification Authority O=Trustwave Holdings, Inc. -# Subject: CN=Trustwave Global ECC P256 Certification Authority O=Trustwave Holdings, Inc. -# Label: "Trustwave Global ECC P256 Certification Authority" -# Serial: 4151900041497450638097112925 -# MD5 Fingerprint: 5b:44:e3:8d:5d:36:86:26:e8:0d:05:d2:59:a7:83:54 -# SHA1 Fingerprint: b4:90:82:dd:45:0c:be:8b:5b:b1:66:d3:e2:a4:08:26:cd:ed:42:cf -# SHA256 Fingerprint: 94:5b:bc:82:5e:a5:54:f4:89:d1:fd:51:a7:3d:df:2e:a6:24:ac:70:19:a0:52:05:22:5c:22:a7:8c:cf:a8:b4 ------BEGIN CERTIFICATE----- -MIICYDCCAgegAwIBAgIMDWpfCD8oXD5Rld9dMAoGCCqGSM49BAMCMIGRMQswCQYD -VQQGEwJVUzERMA8GA1UECBMISWxsaW5vaXMxEDAOBgNVBAcTB0NoaWNhZ28xITAf -BgNVBAoTGFRydXN0d2F2ZSBIb2xkaW5ncywgSW5jLjE6MDgGA1UEAxMxVHJ1c3R3 -YXZlIEdsb2JhbCBFQ0MgUDI1NiBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTAeFw0x -NzA4MjMxOTM1MTBaFw00MjA4MjMxOTM1MTBaMIGRMQswCQYDVQQGEwJVUzERMA8G -A1UECBMISWxsaW5vaXMxEDAOBgNVBAcTB0NoaWNhZ28xITAfBgNVBAoTGFRydXN0 -d2F2ZSBIb2xkaW5ncywgSW5jLjE6MDgGA1UEAxMxVHJ1c3R3YXZlIEdsb2JhbCBF -Q0MgUDI1NiBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTBZMBMGByqGSM49AgEGCCqG -SM49AwEHA0IABH77bOYj43MyCMpg5lOcunSNGLB4kFKA3TjASh3RqMyTpJcGOMoN -FWLGjgEqZZ2q3zSRLoHB5DOSMcT9CTqmP62jQzBBMA8GA1UdEwEB/wQFMAMBAf8w -DwYDVR0PAQH/BAUDAwcGADAdBgNVHQ4EFgQUo0EGrJBt0UrrdaVKEJmzsaGLSvcw -CgYIKoZIzj0EAwIDRwAwRAIgB+ZU2g6gWrKuEZ+Hxbb/ad4lvvigtwjzRM4q3wgh -DDcCIC0mA6AFvWvR9lz4ZcyGbbOcNEhjhAnFjXca4syc4XR7 ------END CERTIFICATE----- - -# Issuer: CN=Trustwave Global ECC P384 Certification Authority O=Trustwave Holdings, Inc. -# Subject: CN=Trustwave Global ECC P384 Certification Authority O=Trustwave Holdings, Inc. -# Label: "Trustwave Global ECC P384 Certification Authority" -# Serial: 2704997926503831671788816187 -# MD5 Fingerprint: ea:cf:60:c4:3b:b9:15:29:40:a1:97:ed:78:27:93:d6 -# SHA1 Fingerprint: e7:f3:a3:c8:cf:6f:c3:04:2e:6d:0e:67:32:c5:9e:68:95:0d:5e:d2 -# SHA256 Fingerprint: 55:90:38:59:c8:c0:c3:eb:b8:75:9e:ce:4e:25:57:22:5f:f5:75:8b:bd:38:eb:d4:82:76:60:1e:1b:d5:80:97 ------BEGIN CERTIFICATE----- -MIICnTCCAiSgAwIBAgIMCL2Fl2yZJ6SAaEc7MAoGCCqGSM49BAMDMIGRMQswCQYD -VQQGEwJVUzERMA8GA1UECBMISWxsaW5vaXMxEDAOBgNVBAcTB0NoaWNhZ28xITAf -BgNVBAoTGFRydXN0d2F2ZSBIb2xkaW5ncywgSW5jLjE6MDgGA1UEAxMxVHJ1c3R3 -YXZlIEdsb2JhbCBFQ0MgUDM4NCBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTAeFw0x -NzA4MjMxOTM2NDNaFw00MjA4MjMxOTM2NDNaMIGRMQswCQYDVQQGEwJVUzERMA8G -A1UECBMISWxsaW5vaXMxEDAOBgNVBAcTB0NoaWNhZ28xITAfBgNVBAoTGFRydXN0 -d2F2ZSBIb2xkaW5ncywgSW5jLjE6MDgGA1UEAxMxVHJ1c3R3YXZlIEdsb2JhbCBF -Q0MgUDM4NCBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTB2MBAGByqGSM49AgEGBSuB -BAAiA2IABGvaDXU1CDFHBa5FmVXxERMuSvgQMSOjfoPTfygIOiYaOs+Xgh+AtycJ -j9GOMMQKmw6sWASr9zZ9lCOkmwqKi6vr/TklZvFe/oyujUF5nQlgziip04pt89ZF -1PKYhDhloKNDMEEwDwYDVR0TAQH/BAUwAwEB/zAPBgNVHQ8BAf8EBQMDBwYAMB0G -A1UdDgQWBBRVqYSJ0sEyvRjLbKYHTsjnnb6CkDAKBggqhkjOPQQDAwNnADBkAjA3 -AZKXRRJ+oPM+rRk6ct30UJMDEr5E0k9BpIycnR+j9sKS50gU/k6bpZFXrsY3crsC -MGclCrEMXu6pY5Jv5ZAL/mYiykf9ijH3g/56vxC+GCsej/YpHpRZ744hN8tRmKVu -Sw== ------END CERTIFICATE----- - -# Issuer: CN=NAVER Global Root Certification Authority O=NAVER BUSINESS PLATFORM Corp. -# Subject: CN=NAVER Global Root Certification Authority O=NAVER BUSINESS PLATFORM Corp. -# Label: "NAVER Global Root Certification Authority" -# Serial: 9013692873798656336226253319739695165984492813 -# MD5 Fingerprint: c8:7e:41:f6:25:3b:f5:09:b3:17:e8:46:3d:bf:d0:9b -# SHA1 Fingerprint: 8f:6b:f2:a9:27:4a:da:14:a0:c4:f4:8e:61:27:f9:c0:1e:78:5d:d1 -# SHA256 Fingerprint: 88:f4:38:dc:f8:ff:d1:fa:8f:42:91:15:ff:e5:f8:2a:e1:e0:6e:0c:70:c3:75:fa:ad:71:7b:34:a4:9e:72:65 ------BEGIN CERTIFICATE----- -MIIFojCCA4qgAwIBAgIUAZQwHqIL3fXFMyqxQ0Rx+NZQTQ0wDQYJKoZIhvcNAQEM -BQAwaTELMAkGA1UEBhMCS1IxJjAkBgNVBAoMHU5BVkVSIEJVU0lORVNTIFBMQVRG -T1JNIENvcnAuMTIwMAYDVQQDDClOQVZFUiBHbG9iYWwgUm9vdCBDZXJ0aWZpY2F0 -aW9uIEF1dGhvcml0eTAeFw0xNzA4MTgwODU4NDJaFw0zNzA4MTgyMzU5NTlaMGkx -CzAJBgNVBAYTAktSMSYwJAYDVQQKDB1OQVZFUiBCVVNJTkVTUyBQTEFURk9STSBD -b3JwLjEyMDAGA1UEAwwpTkFWRVIgR2xvYmFsIFJvb3QgQ2VydGlmaWNhdGlvbiBB -dXRob3JpdHkwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQC21PGTXLVA -iQqrDZBbUGOukJR0F0Vy1ntlWilLp1agS7gvQnXp2XskWjFlqxcX0TM62RHcQDaH -38dq6SZeWYp34+hInDEW+j6RscrJo+KfziFTowI2MMtSAuXaMl3Dxeb57hHHi8lE -HoSTGEq0n+USZGnQJoViAbbJAh2+g1G7XNr4rRVqmfeSVPc0W+m/6imBEtRTkZaz -kVrd/pBzKPswRrXKCAfHcXLJZtM0l/aM9BhK4dA9WkW2aacp+yPOiNgSnABIqKYP -szuSjXEOdMWLyEz59JuOuDxp7W87UC9Y7cSw0BwbagzivESq2M0UXZR4Yb8Obtoq -vC8MC3GmsxY/nOb5zJ9TNeIDoKAYv7vxvvTWjIcNQvcGufFt7QSUqP620wbGQGHf -nZ3zVHbOUzoBppJB7ASjjw2i1QnK1sua8e9DXcCrpUHPXFNwcMmIpi3Ua2FzUCaG -YQ5fG8Ir4ozVu53BA0K6lNpfqbDKzE0K70dpAy8i+/Eozr9dUGWokG2zdLAIx6yo -0es+nPxdGoMuK8u180SdOqcXYZaicdNwlhVNt0xz7hlcxVs+Qf6sdWA7G2POAN3a -CJBitOUt7kinaxeZVL6HSuOpXgRM6xBtVNbv8ejyYhbLgGvtPe31HzClrkvJE+2K -AQHJuFFYwGY6sWZLxNUxAmLpdIQM201GLQIDAQABo0IwQDAdBgNVHQ4EFgQU0p+I -36HNLL3s9TsBAZMzJ7LrYEswDgYDVR0PAQH/BAQDAgEGMA8GA1UdEwEB/wQFMAMB -Af8wDQYJKoZIhvcNAQEMBQADggIBADLKgLOdPVQG3dLSLvCkASELZ0jKbY7gyKoN -qo0hV4/GPnrK21HUUrPUloSlWGB/5QuOH/XcChWB5Tu2tyIvCZwTFrFsDDUIbatj -cu3cvuzHV+YwIHHW1xDBE1UBjCpD5EHxzzp6U5LOogMFDTjfArsQLtk70pt6wKGm -+LUx5vR1yblTmXVHIloUFcd4G7ad6Qz4G3bxhYTeodoS76TiEJd6eN4MUZeoIUCL -hr0N8F5OSza7OyAfikJW4Qsav3vQIkMsRIz75Sq0bBwcupTgE34h5prCy8VCZLQe -lHsIJchxzIdFV4XTnyliIoNRlwAYl3dqmJLJfGBs32x9SuRwTMKeuB330DTHD8z7 -p/8Dvq1wkNoL3chtl1+afwkyQf3NosxabUzyqkn+Zvjp2DXrDige7kgvOtB5CTh8 -piKCk5XQA76+AqAF3SAi428diDRgxuYKuQl1C/AH6GmWNcf7I4GOODm4RStDeKLR -LBT/DShycpWbXgnbiUSYqqFJu3FS8r/2/yehNq+4tneI3TqkbZs0kNwUXTC/t+sX -5Ie3cdCh13cV1ELX8vMxmV2b3RZtP+oGI/hGoiLtk/bdmuYqh7GYVPEi92tF4+KO -dh2ajcQGjTa3FPOdVGm3jjzVpG2Tgbet9r1ke8LJaDmgkpzNNIaRkPpkUZ3+/uul -9XXeifdy ------END CERTIFICATE----- - -# Issuer: CN=AC RAIZ FNMT-RCM SERVIDORES SEGUROS O=FNMT-RCM OU=Ceres -# Subject: CN=AC RAIZ FNMT-RCM SERVIDORES SEGUROS O=FNMT-RCM OU=Ceres -# Label: "AC RAIZ FNMT-RCM SERVIDORES SEGUROS" -# Serial: 131542671362353147877283741781055151509 -# MD5 Fingerprint: 19:36:9c:52:03:2f:d2:d1:bb:23:cc:dd:1e:12:55:bb -# SHA1 Fingerprint: 62:ff:d9:9e:c0:65:0d:03:ce:75:93:d2:ed:3f:2d:32:c9:e3:e5:4a -# SHA256 Fingerprint: 55:41:53:b1:3d:2c:f9:dd:b7:53:bf:be:1a:4e:0a:e0:8d:0a:a4:18:70:58:fe:60:a2:b8:62:b2:e4:b8:7b:cb ------BEGIN CERTIFICATE----- -MIICbjCCAfOgAwIBAgIQYvYybOXE42hcG2LdnC6dlTAKBggqhkjOPQQDAzB4MQsw -CQYDVQQGEwJFUzERMA8GA1UECgwIRk5NVC1SQ00xDjAMBgNVBAsMBUNlcmVzMRgw -FgYDVQRhDA9WQVRFUy1RMjgyNjAwNEoxLDAqBgNVBAMMI0FDIFJBSVogRk5NVC1S -Q00gU0VSVklET1JFUyBTRUdVUk9TMB4XDTE4MTIyMDA5MzczM1oXDTQzMTIyMDA5 -MzczM1oweDELMAkGA1UEBhMCRVMxETAPBgNVBAoMCEZOTVQtUkNNMQ4wDAYDVQQL -DAVDZXJlczEYMBYGA1UEYQwPVkFURVMtUTI4MjYwMDRKMSwwKgYDVQQDDCNBQyBS -QUlaIEZOTVQtUkNNIFNFUlZJRE9SRVMgU0VHVVJPUzB2MBAGByqGSM49AgEGBSuB -BAAiA2IABPa6V1PIyqvfNkpSIeSX0oNnnvBlUdBeh8dHsVnyV0ebAAKTRBdp20LH -sbI6GA60XYyzZl2hNPk2LEnb80b8s0RpRBNm/dfF/a82Tc4DTQdxz69qBdKiQ1oK -Um8BA06Oi6NCMEAwDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwHQYD -VR0OBBYEFAG5L++/EYZg8k/QQW6rcx/n0m5JMAoGCCqGSM49BAMDA2kAMGYCMQCu -SuMrQMN0EfKVrRYj3k4MGuZdpSRea0R7/DjiT8ucRRcRTBQnJlU5dUoDzBOQn5IC -MQD6SmxgiHPz7riYYqnOK8LZiqZwMR2vsJRM60/G49HzYqc8/5MuB1xJAWdpEgJy -v+c= ------END CERTIFICATE----- - -# Issuer: CN=GlobalSign Root R46 O=GlobalSign nv-sa -# Subject: CN=GlobalSign Root R46 O=GlobalSign nv-sa -# Label: "GlobalSign Root R46" -# Serial: 1552617688466950547958867513931858518042577 -# MD5 Fingerprint: c4:14:30:e4:fa:66:43:94:2a:6a:1b:24:5f:19:d0:ef -# SHA1 Fingerprint: 53:a2:b0:4b:ca:6b:d6:45:e6:39:8a:8e:c4:0d:d2:bf:77:c3:a2:90 -# SHA256 Fingerprint: 4f:a3:12:6d:8d:3a:11:d1:c4:85:5a:4f:80:7c:ba:d6:cf:91:9d:3a:5a:88:b0:3b:ea:2c:63:72:d9:3c:40:c9 ------BEGIN CERTIFICATE----- -MIIFWjCCA0KgAwIBAgISEdK7udcjGJ5AXwqdLdDfJWfRMA0GCSqGSIb3DQEBDAUA -MEYxCzAJBgNVBAYTAkJFMRkwFwYDVQQKExBHbG9iYWxTaWduIG52LXNhMRwwGgYD -VQQDExNHbG9iYWxTaWduIFJvb3QgUjQ2MB4XDTE5MDMyMDAwMDAwMFoXDTQ2MDMy -MDAwMDAwMFowRjELMAkGA1UEBhMCQkUxGTAXBgNVBAoTEEdsb2JhbFNpZ24gbnYt -c2ExHDAaBgNVBAMTE0dsb2JhbFNpZ24gUm9vdCBSNDYwggIiMA0GCSqGSIb3DQEB -AQUAA4ICDwAwggIKAoICAQCsrHQy6LNl5brtQyYdpokNRbopiLKkHWPd08EsCVeJ -OaFV6Wc0dwxu5FUdUiXSE2te4R2pt32JMl8Nnp8semNgQB+msLZ4j5lUlghYruQG -vGIFAha/r6gjA7aUD7xubMLL1aa7DOn2wQL7Id5m3RerdELv8HQvJfTqa1VbkNud -316HCkD7rRlr+/fKYIje2sGP1q7Vf9Q8g+7XFkyDRTNrJ9CG0Bwta/OrffGFqfUo -0q3v84RLHIf8E6M6cqJaESvWJ3En7YEtbWaBkoe0G1h6zD8K+kZPTXhc+CtI4wSE -y132tGqzZfxCnlEmIyDLPRT5ge1lFgBPGmSXZgjPjHvjK8Cd+RTyG/FWaha/LIWF -zXg4mutCagI0GIMXTpRW+LaCtfOW3T3zvn8gdz57GSNrLNRyc0NXfeD412lPFzYE -+cCQYDdF3uYM2HSNrpyibXRdQr4G9dlkbgIQrImwTDsHTUB+JMWKmIJ5jqSngiCN -I/onccnfxkF0oE32kRbcRoxfKWMxWXEM2G/CtjJ9++ZdU6Z+Ffy7dXxd7Pj2Fxzs -x2sZy/N78CsHpdlseVR2bJ0cpm4O6XkMqCNqo98bMDGfsVR7/mrLZqrcZdCinkqa -ByFrgY/bxFn63iLABJzjqls2k+g9vXqhnQt2sQvHnf3PmKgGwvgqo6GDoLclcqUC -4wIDAQABo0IwQDAOBgNVHQ8BAf8EBAMCAYYwDwYDVR0TAQH/BAUwAwEB/zAdBgNV -HQ4EFgQUA1yrc4GHqMywptWU4jaWSf8FmSwwDQYJKoZIhvcNAQEMBQADggIBAHx4 -7PYCLLtbfpIrXTncvtgdokIzTfnvpCo7RGkerNlFo048p9gkUbJUHJNOxO97k4Vg -JuoJSOD1u8fpaNK7ajFxzHmuEajwmf3lH7wvqMxX63bEIaZHU1VNaL8FpO7XJqti -2kM3S+LGteWygxk6x9PbTZ4IevPuzz5i+6zoYMzRx6Fcg0XERczzF2sUyQQCPtIk -pnnpHs6i58FZFZ8d4kuaPp92CC1r2LpXFNqD6v6MVenQTqnMdzGxRBF6XLE+0xRF -FRhiJBPSy03OXIPBNvIQtQ6IbbjhVp+J3pZmOUdkLG5NrmJ7v2B0GbhWrJKsFjLt -rWhV/pi60zTe9Mlhww6G9kuEYO4Ne7UyWHmRVSyBQ7N0H3qqJZ4d16GLuc1CLgSk -ZoNNiTW2bKg2SnkheCLQQrzRQDGQob4Ez8pn7fXwgNNgyYMqIgXQBztSvwyeqiv5 -u+YfjyW6hY0XHgL+XVAEV8/+LbzvXMAaq7afJMbfc2hIkCwU9D9SGuTSyxTDYWnP -4vkYxboznxSjBF25cfe1lNj2M8FawTSLfJvdkzrnE6JwYZ+vj+vYxXX4M2bUdGc6 -N3ec592kD3ZDZopD8p/7DEJ4Y9HiD2971KE9dJeFt0g5QdYg/NA6s/rob8SKunE3 -vouXsXgxT7PntgMTzlSdriVZzH81Xwj3QEUxeCp6 ------END CERTIFICATE----- - -# Issuer: CN=GlobalSign Root E46 O=GlobalSign nv-sa -# Subject: CN=GlobalSign Root E46 O=GlobalSign nv-sa -# Label: "GlobalSign Root E46" -# Serial: 1552617690338932563915843282459653771421763 -# MD5 Fingerprint: b5:b8:66:ed:de:08:83:e3:c9:e2:01:34:06:ac:51:6f -# SHA1 Fingerprint: 39:b4:6c:d5:fe:80:06:eb:e2:2f:4a:bb:08:33:a0:af:db:b9:dd:84 -# SHA256 Fingerprint: cb:b9:c4:4d:84:b8:04:3e:10:50:ea:31:a6:9f:51:49:55:d7:bf:d2:e2:c6:b4:93:01:01:9a:d6:1d:9f:50:58 ------BEGIN CERTIFICATE----- -MIICCzCCAZGgAwIBAgISEdK7ujNu1LzmJGjFDYQdmOhDMAoGCCqGSM49BAMDMEYx -CzAJBgNVBAYTAkJFMRkwFwYDVQQKExBHbG9iYWxTaWduIG52LXNhMRwwGgYDVQQD -ExNHbG9iYWxTaWduIFJvb3QgRTQ2MB4XDTE5MDMyMDAwMDAwMFoXDTQ2MDMyMDAw -MDAwMFowRjELMAkGA1UEBhMCQkUxGTAXBgNVBAoTEEdsb2JhbFNpZ24gbnYtc2Ex -HDAaBgNVBAMTE0dsb2JhbFNpZ24gUm9vdCBFNDYwdjAQBgcqhkjOPQIBBgUrgQQA -IgNiAAScDrHPt+ieUnd1NPqlRqetMhkytAepJ8qUuwzSChDH2omwlwxwEwkBjtjq -R+q+soArzfwoDdusvKSGN+1wCAB16pMLey5SnCNoIwZD7JIvU4Tb+0cUB+hflGdd -yXqBPCCjQjBAMA4GA1UdDwEB/wQEAwIBhjAPBgNVHRMBAf8EBTADAQH/MB0GA1Ud -DgQWBBQxCpCPtsad0kRLgLWi5h+xEk8blTAKBggqhkjOPQQDAwNoADBlAjEA31SQ -7Zvvi5QCkxeCmb6zniz2C5GMn0oUsfZkvLtoURMMA/cVi4RguYv/Uo7njLwcAjA8 -+RHUjE7AwWHCFUyqqx0LMV87HOIAl0Qx5v5zli/altP+CAezNIm8BZ/3Hobui3A= ------END CERTIFICATE----- - -# Issuer: CN=ANF Secure Server Root CA O=ANF Autoridad de Certificacion OU=ANF CA Raiz -# Subject: CN=ANF Secure Server Root CA O=ANF Autoridad de Certificacion OU=ANF CA Raiz -# Label: "ANF Secure Server Root CA" -# Serial: 996390341000653745 -# MD5 Fingerprint: 26:a6:44:5a:d9:af:4e:2f:b2:1d:b6:65:b0:4e:e8:96 -# SHA1 Fingerprint: 5b:6e:68:d0:cc:15:b6:a0:5f:1e:c1:5f:ae:02:fc:6b:2f:5d:6f:74 -# SHA256 Fingerprint: fb:8f:ec:75:91:69:b9:10:6b:1e:51:16:44:c6:18:c5:13:04:37:3f:6c:06:43:08:8d:8b:ef:fd:1b:99:75:99 ------BEGIN CERTIFICATE----- -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 ------END CERTIFICATE----- - -# Issuer: CN=Certum EC-384 CA O=Asseco Data Systems S.A. OU=Certum Certification Authority -# Subject: CN=Certum EC-384 CA O=Asseco Data Systems S.A. OU=Certum Certification Authority -# Label: "Certum EC-384 CA" -# Serial: 160250656287871593594747141429395092468 -# MD5 Fingerprint: b6:65:b3:96:60:97:12:a1:ec:4e:e1:3d:a3:c6:c9:f1 -# SHA1 Fingerprint: f3:3e:78:3c:ac:df:f4:a2:cc:ac:67:55:69:56:d7:e5:16:3c:e1:ed -# SHA256 Fingerprint: 6b:32:80:85:62:53:18:aa:50:d1:73:c9:8d:8b:da:09:d5:7e:27:41:3d:11:4c:f7:87:a0:f5:d0:6c:03:0c:f6 ------BEGIN CERTIFICATE----- -MIICZTCCAeugAwIBAgIQeI8nXIESUiClBNAt3bpz9DAKBggqhkjOPQQDAzB0MQsw -CQYDVQQGEwJQTDEhMB8GA1UEChMYQXNzZWNvIERhdGEgU3lzdGVtcyBTLkEuMScw -JQYDVQQLEx5DZXJ0dW0gQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkxGTAXBgNVBAMT -EENlcnR1bSBFQy0zODQgQ0EwHhcNMTgwMzI2MDcyNDU0WhcNNDMwMzI2MDcyNDU0 -WjB0MQswCQYDVQQGEwJQTDEhMB8GA1UEChMYQXNzZWNvIERhdGEgU3lzdGVtcyBT -LkEuMScwJQYDVQQLEx5DZXJ0dW0gQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkxGTAX -BgNVBAMTEENlcnR1bSBFQy0zODQgQ0EwdjAQBgcqhkjOPQIBBgUrgQQAIgNiAATE -KI6rGFtqvm5kN2PkzeyrOvfMobgOgknXhimfoZTy42B4mIF4Bk3y7JoOV2CDn7Tm -Fy8as10CW4kjPMIRBSqniBMY81CE1700LCeJVf/OTOffph8oxPBUw7l8t1Ot68Kj -QjBAMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYEFI0GZnQkdjrzife81r1HfS+8 -EF9LMA4GA1UdDwEB/wQEAwIBBjAKBggqhkjOPQQDAwNoADBlAjADVS2m5hjEfO/J -UG7BJw+ch69u1RsIGL2SKcHvlJF40jocVYli5RsJHrpka/F2tNQCMQC0QoSZ/6vn -nvuRlydd3LBbMHHOXjgaatkl5+r3YZJW+OraNsKHZZYuciUvf9/DE8k= ------END CERTIFICATE----- - -# Issuer: CN=Certum Trusted Root CA O=Asseco Data Systems S.A. OU=Certum Certification Authority -# Subject: CN=Certum Trusted Root CA O=Asseco Data Systems S.A. OU=Certum Certification Authority -# Label: "Certum Trusted Root CA" -# Serial: 40870380103424195783807378461123655149 -# MD5 Fingerprint: 51:e1:c2:e7:fe:4c:84:af:59:0e:2f:f4:54:6f:ea:29 -# SHA1 Fingerprint: c8:83:44:c0:18:ae:9f:cc:f1:87:b7:8f:22:d1:c5:d7:45:84:ba:e5 -# SHA256 Fingerprint: fe:76:96:57:38:55:77:3e:37:a9:5e:7a:d4:d9:cc:96:c3:01:57:c1:5d:31:76:5b:a9:b1:57:04:e1:ae:78:fd ------BEGIN CERTIFICATE----- -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 ------END CERTIFICATE----- - -# Issuer: CN=TunTrust Root CA O=Agence Nationale de Certification Electronique -# Subject: CN=TunTrust Root CA O=Agence Nationale de Certification Electronique -# Label: "TunTrust Root CA" -# Serial: 108534058042236574382096126452369648152337120275 -# MD5 Fingerprint: 85:13:b9:90:5b:36:5c:b6:5e:b8:5a:f8:e0:31:57:b4 -# SHA1 Fingerprint: cf:e9:70:84:0f:e0:73:0f:9d:f6:0c:7f:2c:4b:ee:20:46:34:9c:bb -# SHA256 Fingerprint: 2e:44:10:2a:b5:8c:b8:54:19:45:1c:8e:19:d9:ac:f3:66:2c:af:bc:61:4b:6a:53:96:0a:30:f7:d0:e2:eb:41 ------BEGIN CERTIFICATE----- -MIIFszCCA5ugAwIBAgIUEwLV4kBMkkaGFmddtLu7sms+/BMwDQYJKoZIhvcNAQEL -BQAwYTELMAkGA1UEBhMCVE4xNzA1BgNVBAoMLkFnZW5jZSBOYXRpb25hbGUgZGUg -Q2VydGlmaWNhdGlvbiBFbGVjdHJvbmlxdWUxGTAXBgNVBAMMEFR1blRydXN0IFJv -b3QgQ0EwHhcNMTkwNDI2MDg1NzU2WhcNNDQwNDI2MDg1NzU2WjBhMQswCQYDVQQG -EwJUTjE3MDUGA1UECgwuQWdlbmNlIE5hdGlvbmFsZSBkZSBDZXJ0aWZpY2F0aW9u -IEVsZWN0cm9uaXF1ZTEZMBcGA1UEAwwQVHVuVHJ1c3QgUm9vdCBDQTCCAiIwDQYJ -KoZIhvcNAQEBBQADggIPADCCAgoCggIBAMPN0/y9BFPdDCA61YguBUtB9YOCfvdZ -n56eY+hz2vYGqU8ftPkLHzmMmiDQfgbU7DTZhrx1W4eI8NLZ1KMKsmwb60ksPqxd -2JQDoOw05TDENX37Jk0bbjBU2PWARZw5rZzJJQRNmpA+TkBuimvNKWfGzC3gdOgF -VwpIUPp6Q9p+7FuaDmJ2/uqdHYVy7BG7NegfJ7/Boce7SBbdVtfMTqDhuazb1YMZ -GoXRlJfXyqNlC/M4+QKu3fZnz8k/9YosRxqZbwUN/dAdgjH8KcwAWJeRTIAAHDOF -li/LQcKLEITDCSSJH7UP2dl3RxiSlGBcx5kDPP73lad9UKGAwqmDrViWVSHbhlnU -r8a83YFuB9tgYv7sEG7aaAH0gxupPqJbI9dkxt/con3YS7qC0lH4Zr8GRuR5KiY2 -eY8fTpkdso8MDhz/yV3A/ZAQprE38806JG60hZC/gLkMjNWb1sjxVj8agIl6qeIb -MlEsPvLfe/ZdeikZjuXIvTZxi11Mwh0/rViizz1wTaZQmCXcI/m4WEEIcb9PuISg -jwBUFfyRbVinljvrS5YnzWuioYasDXxU5mZMZl+QviGaAkYt5IPCgLnPSz7ofzwB -7I9ezX/SKEIBlYrilz0QIX32nRzFNKHsLA4KUiwSVXAkPcvCFDVDXSdOvsC9qnyW -5/yeYa1E0wCXAgMBAAGjYzBhMB0GA1UdDgQWBBQGmpsfU33x9aTI04Y+oXNZtPdE -ITAPBgNVHRMBAf8EBTADAQH/MB8GA1UdIwQYMBaAFAaamx9TffH1pMjThj6hc1m0 -90QhMA4GA1UdDwEB/wQEAwIBBjANBgkqhkiG9w0BAQsFAAOCAgEAqgVutt0Vyb+z -xiD2BkewhpMl0425yAA/l/VSJ4hxyXT968pk21vvHl26v9Hr7lxpuhbI87mP0zYu -QEkHDVneixCwSQXi/5E/S7fdAo74gShczNxtr18UnH1YeA32gAm56Q6XKRm4t+v4 -FstVEuTGfbvE7Pi1HE4+Z7/FXxttbUcoqgRYYdZ2vyJ/0Adqp2RT8JeNnYA/u8EH -22Wv5psymsNUk8QcCMNE+3tjEUPRahphanltkE8pjkcFwRJpadbGNjHh/PqAulxP -xOu3Mqz4dWEX1xAZufHSCe96Qp1bWgvUxpVOKs7/B9dPfhgGiPEZtdmYu65xxBzn -dFlY7wyJz4sfdZMaBBSSSFCp61cpABbjNhzI+L/wM9VBD8TMPN3pM0MBkRArHtG5 -Xc0yGYuPjCB31yLEQtyEFpslbei0VXF/sHyz03FJuc9SpAQ/3D2gu68zngowYI7b -nV2UqL1g52KAdoGDDIzMMEZJ4gzSqK/rYXHv5yJiqfdcZGyfFoxnNidF9Ql7v/YQ -CvGwjVRDjAS6oz/v4jXH+XTgbzRB0L9zZVcg+ZtnemZoJE6AZb0QmQZZ8mWvuMZH -u/2QeItBcy6vVR/cO5JyboTT0GFMDcx2V+IthSIVNg3rAZ3r2OvEhJn7wAzMMujj -d9qDRIueVSjAi1jTkD5OGwDxFa2DK5o= ------END CERTIFICATE----- - -# Issuer: CN=HARICA TLS RSA Root CA 2021 O=Hellenic Academic and Research Institutions CA -# Subject: CN=HARICA TLS RSA Root CA 2021 O=Hellenic Academic and Research Institutions CA -# Label: "HARICA TLS RSA Root CA 2021" -# Serial: 76817823531813593706434026085292783742 -# MD5 Fingerprint: 65:47:9b:58:86:dd:2c:f0:fc:a2:84:1f:1e:96:c4:91 -# SHA1 Fingerprint: 02:2d:05:82:fa:88:ce:14:0c:06:79:de:7f:14:10:e9:45:d7:a5:6d -# SHA256 Fingerprint: d9:5d:0e:8e:da:79:52:5b:f9:be:b1:1b:14:d2:10:0d:32:94:98:5f:0c:62:d9:fa:bd:9c:d9:99:ec:cb:7b:1d ------BEGIN CERTIFICATE----- -MIIFpDCCA4ygAwIBAgIQOcqTHO9D88aOk8f0ZIk4fjANBgkqhkiG9w0BAQsFADBs -MQswCQYDVQQGEwJHUjE3MDUGA1UECgwuSGVsbGVuaWMgQWNhZGVtaWMgYW5kIFJl -c2VhcmNoIEluc3RpdHV0aW9ucyBDQTEkMCIGA1UEAwwbSEFSSUNBIFRMUyBSU0Eg -Um9vdCBDQSAyMDIxMB4XDTIxMDIxOTEwNTUzOFoXDTQ1MDIxMzEwNTUzN1owbDEL -MAkGA1UEBhMCR1IxNzA1BgNVBAoMLkhlbGxlbmljIEFjYWRlbWljIGFuZCBSZXNl -YXJjaCBJbnN0aXR1dGlvbnMgQ0ExJDAiBgNVBAMMG0hBUklDQSBUTFMgUlNBIFJv -b3QgQ0EgMjAyMTCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAIvC569l -mwVnlskNJLnQDmT8zuIkGCyEf3dRywQRNrhe7Wlxp57kJQmXZ8FHws+RFjZiPTgE -4VGC/6zStGndLuwRo0Xua2s7TL+MjaQenRG56Tj5eg4MmOIjHdFOY9TnuEFE+2uv -a9of08WRiFukiZLRgeaMOVig1mlDqa2YUlhu2wr7a89o+uOkXjpFc5gH6l8Cct4M -pbOfrqkdtx2z/IpZ525yZa31MJQjB/OCFks1mJxTuy/K5FrZx40d/JiZ+yykgmvw -Kh+OC19xXFyuQnspiYHLA6OZyoieC0AJQTPb5lh6/a6ZcMBaD9YThnEvdmn8kN3b -LW7R8pv1GmuebxWMevBLKKAiOIAkbDakO/IwkfN4E8/BPzWr8R0RI7VDIp4BkrcY -AuUR0YLbFQDMYTfBKnya4dC6s1BG7oKsnTH4+yPiAwBIcKMJJnkVU2DzOFytOOqB -AGMUuTNe3QvboEUHGjMJ+E20pwKmafTCWQWIZYVWrkvL4N48fS0ayOn7H6NhStYq -E613TBoYm5EPWNgGVMWX+Ko/IIqmhaZ39qb8HOLubpQzKoNQhArlT4b4UEV4AIHr -W2jjJo3Me1xR9BQsQL4aYB16cmEdH2MtiKrOokWQCPxrvrNQKlr9qEgYRtaQQJKQ -CoReaDH46+0N0x3GfZkYVVYnZS6NRcUk7M7jAgMBAAGjQjBAMA8GA1UdEwEB/wQF -MAMBAf8wHQYDVR0OBBYEFApII6ZgpJIKM+qTW8VX6iVNvRLuMA4GA1UdDwEB/wQE -AwIBhjANBgkqhkiG9w0BAQsFAAOCAgEAPpBIqm5iFSVmewzVjIuJndftTgfvnNAU -X15QvWiWkKQUEapobQk1OUAJ2vQJLDSle1mESSmXdMgHHkdt8s4cUCbjnj1AUz/3 -f5Z2EMVGpdAgS1D0NTsY9FVqQRtHBmg8uwkIYtlfVUKqrFOFrJVWNlar5AWMxaja -H6NpvVMPxP/cyuN+8kyIhkdGGvMA9YCRotxDQpSbIPDRzbLrLFPCU3hKTwSUQZqP -JzLB5UkZv/HywouoCjkxKLR9YjYsTewfM7Z+d21+UPCfDtcRj88YxeMn/ibvBZ3P -zzfF0HvaO7AWhAw6k9a+F9sPPg4ZeAnHqQJyIkv3N3a6dcSFA1pj1bF1BcK5vZSt -jBWZp5N99sXzqnTPBIWUmAD04vnKJGW/4GKvyMX6ssmeVkjaef2WdhW+o45WxLM0 -/L5H9MG0qPzVMIho7suuyWPEdr6sOBjhXlzPrjoiUevRi7PzKzMHVIf6tLITe7pT -BGIBnfHAT+7hOtSLIBD6Alfm78ELt5BGnBkpjNxvoEppaZS3JGWg/6w/zgH7IS79 -aPib8qXPMThcFarmlwDB31qlpzmq6YR/PFGoOtmUW4y/Twhx5duoXNTSpv4Ao8YW -xw/ogM4cKGR0GQjTQuPOAF1/sdwTsOEFy9EgqoZ0njnnkf3/W9b3raYvAwtt41dU -63ZTGI0RmLo= ------END CERTIFICATE----- - -# Issuer: CN=HARICA TLS ECC Root CA 2021 O=Hellenic Academic and Research Institutions CA -# Subject: CN=HARICA TLS ECC Root CA 2021 O=Hellenic Academic and Research Institutions CA -# Label: "HARICA TLS ECC Root CA 2021" -# Serial: 137515985548005187474074462014555733966 -# MD5 Fingerprint: ae:f7:4c:e5:66:35:d1:b7:9b:8c:22:93:74:d3:4b:b0 -# SHA1 Fingerprint: bc:b0:c1:9d:e9:98:92:70:19:38:57:e9:8d:a7:b4:5d:6e:ee:01:48 -# SHA256 Fingerprint: 3f:99:cc:47:4a:cf:ce:4d:fe:d5:87:94:66:5e:47:8d:15:47:73:9f:2e:78:0f:1b:b4:ca:9b:13:30:97:d4:01 ------BEGIN CERTIFICATE----- -MIICVDCCAdugAwIBAgIQZ3SdjXfYO2rbIvT/WeK/zjAKBggqhkjOPQQDAzBsMQsw -CQYDVQQGEwJHUjE3MDUGA1UECgwuSGVsbGVuaWMgQWNhZGVtaWMgYW5kIFJlc2Vh -cmNoIEluc3RpdHV0aW9ucyBDQTEkMCIGA1UEAwwbSEFSSUNBIFRMUyBFQ0MgUm9v -dCBDQSAyMDIxMB4XDTIxMDIxOTExMDExMFoXDTQ1MDIxMzExMDEwOVowbDELMAkG -A1UEBhMCR1IxNzA1BgNVBAoMLkhlbGxlbmljIEFjYWRlbWljIGFuZCBSZXNlYXJj -aCBJbnN0aXR1dGlvbnMgQ0ExJDAiBgNVBAMMG0hBUklDQSBUTFMgRUNDIFJvb3Qg -Q0EgMjAyMTB2MBAGByqGSM49AgEGBSuBBAAiA2IABDgI/rGgltJ6rK9JOtDA4MM7 -KKrxcm1lAEeIhPyaJmuqS7psBAqIXhfyVYf8MLA04jRYVxqEU+kw2anylnTDUR9Y -STHMmE5gEYd103KUkE+bECUqqHgtvpBBWJAVcqeht6NCMEAwDwYDVR0TAQH/BAUw -AwEB/zAdBgNVHQ4EFgQUyRtTgRL+BNUW0aq8mm+3oJUZbsowDgYDVR0PAQH/BAQD -AgGGMAoGCCqGSM49BAMDA2cAMGQCMBHervjcToiwqfAircJRQO9gcS3ujwLEXQNw -SaSS6sUUiHCm0w2wqsosQJz76YJumgIwK0eaB8bRwoF8yguWGEEbo/QwCZ61IygN -nxS2PFOiTAZpffpskcYqSUXm7LcT4Tps ------END CERTIFICATE----- - -# Issuer: CN=Autoridad de Certificacion Firmaprofesional CIF A62634068 -# Subject: CN=Autoridad de Certificacion Firmaprofesional CIF A62634068 -# Label: "Autoridad de Certificacion Firmaprofesional CIF A62634068" -# Serial: 1977337328857672817 -# MD5 Fingerprint: 4e:6e:9b:54:4c:ca:b7:fa:48:e4:90:b1:15:4b:1c:a3 -# SHA1 Fingerprint: 0b:be:c2:27:22:49:cb:39:aa:db:35:5c:53:e3:8c:ae:78:ff:b6:fe -# SHA256 Fingerprint: 57:de:05:83:ef:d2:b2:6e:03:61:da:99:da:9d:f4:64:8d:ef:7e:e8:44:1c:3b:72:8a:fa:9b:cd:e0:f9:b2:6a ------BEGIN CERTIFICATE----- -MIIGFDCCA/ygAwIBAgIIG3Dp0v+ubHEwDQYJKoZIhvcNAQELBQAwUTELMAkGA1UE -BhMCRVMxQjBABgNVBAMMOUF1dG9yaWRhZCBkZSBDZXJ0aWZpY2FjaW9uIEZpcm1h -cHJvZmVzaW9uYWwgQ0lGIEE2MjYzNDA2ODAeFw0xNDA5MjMxNTIyMDdaFw0zNjA1 -MDUxNTIyMDdaMFExCzAJBgNVBAYTAkVTMUIwQAYDVQQDDDlBdXRvcmlkYWQgZGUg -Q2VydGlmaWNhY2lvbiBGaXJtYXByb2Zlc2lvbmFsIENJRiBBNjI2MzQwNjgwggIi -MA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQDKlmuO6vj78aI14H9M2uDDUtd9 -thDIAl6zQyrET2qyyhxdKJp4ERppWVevtSBC5IsP5t9bpgOSL/UR5GLXMnE42QQM -cas9UX4PB99jBVzpv5RvwSmCwLTaUbDBPLutN0pcyvFLNg4kq7/DhHf9qFD0sefG -L9ItWY16Ck6WaVICqjaY7Pz6FIMMNx/Jkjd/14Et5cS54D40/mf0PmbR0/RAz15i -NA9wBj4gGFrO93IbJWyTdBSTo3OxDqqHECNZXyAFGUftaI6SEspd/NYrspI8IM/h -X68gvqB2f3bl7BqGYTM+53u0P6APjqK5am+5hyZvQWyIplD9amML9ZMWGxmPsu2b -m8mQ9QEM3xk9Dz44I8kvjwzRAv4bVdZO0I08r0+k8/6vKtMFnXkIoctXMbScyJCy -Z/QYFpM6/EfY0XiWMR+6KwxfXZmtY4laJCB22N/9q06mIqqdXuYnin1oKaPnirja -EbsXLZmdEyRG98Xi2J+Of8ePdG1asuhy9azuJBCtLxTa/y2aRnFHvkLfuwHb9H/T -KI8xWVvTyQKmtFLKbpf7Q8UIJm+K9Lv9nyiqDdVF8xM6HdjAeI9BZzwelGSuewvF -6NkBiDkal4ZkQdU7hwxu+g/GvUgUvzlN1J5Bto+WHWOWk9mVBngxaJ43BjuAiUVh -OSPHG0SjFeUc+JIwuwIDAQABo4HvMIHsMB0GA1UdDgQWBBRlzeurNR4APn7VdMAc -tHNHDhpkLzASBgNVHRMBAf8ECDAGAQH/AgEBMIGmBgNVHSAEgZ4wgZswgZgGBFUd -IAAwgY8wLwYIKwYBBQUHAgEWI2h0dHA6Ly93d3cuZmlybWFwcm9mZXNpb25hbC5j -b20vY3BzMFwGCCsGAQUFBwICMFAeTgBQAGEAcwBlAG8AIABkAGUAIABsAGEAIABC -AG8AbgBhAG4AbwB2AGEAIAA0ADcAIABCAGEAcgBjAGUAbABvAG4AYQAgADAAOAAw -ADEANzAOBgNVHQ8BAf8EBAMCAQYwDQYJKoZIhvcNAQELBQADggIBAHSHKAIrdx9m -iWTtj3QuRhy7qPj4Cx2Dtjqn6EWKB7fgPiDL4QjbEwj4KKE1soCzC1HA01aajTNF -Sa9J8OA9B3pFE1r/yJfY0xgsfZb43aJlQ3CTkBW6kN/oGbDbLIpgD7dvlAceHabJ -hfa9NPhAeGIQcDq+fUs5gakQ1JZBu/hfHAsdCPKxsIl68veg4MSPi3i1O1ilI45P -Vf42O+AMt8oqMEEgtIDNrvx2ZnOorm7hfNoD6JQg5iKj0B+QXSBTFCZX2lSX3xZE -EAEeiGaPcjiT3SC3NL7X8e5jjkd5KAb881lFJWAiMxujX6i6KtoaPc1A6ozuBRWV -1aUsIC+nmCjuRfzxuIgALI9C2lHVnOUTaHFFQ4ueCyE8S1wF3BqfmI7avSKecs2t -CsvMo2ebKHTEm9caPARYpoKdrcd7b/+Alun4jWq9GJAd/0kakFI3ky88Al2CdgtR -5xbHV/g4+afNmyJU72OwFW1TZQNKXkqgsqeOSQBZONXH9IBk9W6VULgRfhVwOEqw -f9DEMnDAGf/JOC0ULGb0QkTmVXYbgBVX/8Cnp6o5qtjTcNAuuuuUavpfNIbnYrX9 -ivAwhZTJryQCL2/W3Wf+47BVTwSYT6RBVuKT0Gro1vP7ZeDOdcQxWQzugsgMYDNK -GbqEZycPvEJdvSRUDewdcAZfpLz6IHxV ------END CERTIFICATE----- - -# Issuer: CN=vTrus ECC Root CA O=iTrusChina Co.,Ltd. -# Subject: CN=vTrus ECC Root CA O=iTrusChina Co.,Ltd. -# Label: "vTrus ECC Root CA" -# Serial: 630369271402956006249506845124680065938238527194 -# MD5 Fingerprint: de:4b:c1:f5:52:8c:9b:43:e1:3e:8f:55:54:17:8d:85 -# SHA1 Fingerprint: f6:9c:db:b0:fc:f6:02:13:b6:52:32:a6:a3:91:3f:16:70:da:c3:e1 -# SHA256 Fingerprint: 30:fb:ba:2c:32:23:8e:2a:98:54:7a:f9:79:31:e5:50:42:8b:9b:3f:1c:8e:eb:66:33:dc:fa:86:c5:b2:7d:d3 ------BEGIN CERTIFICATE----- -MIICDzCCAZWgAwIBAgIUbmq8WapTvpg5Z6LSa6Q75m0c1towCgYIKoZIzj0EAwMw -RzELMAkGA1UEBhMCQ04xHDAaBgNVBAoTE2lUcnVzQ2hpbmEgQ28uLEx0ZC4xGjAY -BgNVBAMTEXZUcnVzIEVDQyBSb290IENBMB4XDTE4MDczMTA3MjY0NFoXDTQzMDcz -MTA3MjY0NFowRzELMAkGA1UEBhMCQ04xHDAaBgNVBAoTE2lUcnVzQ2hpbmEgQ28u -LEx0ZC4xGjAYBgNVBAMTEXZUcnVzIEVDQyBSb290IENBMHYwEAYHKoZIzj0CAQYF -K4EEACIDYgAEZVBKrox5lkqqHAjDo6LN/llWQXf9JpRCux3NCNtzslt188+cToL0 -v/hhJoVs1oVbcnDS/dtitN9Ti72xRFhiQgnH+n9bEOf+QP3A2MMrMudwpremIFUd -e4BdS49nTPEQo0IwQDAdBgNVHQ4EFgQUmDnNvtiyjPeyq+GtJK97fKHbH88wDwYD -VR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwCgYIKoZIzj0EAwMDaAAwZQIw -V53dVvHH4+m4SVBrm2nDb+zDfSXkV5UTQJtS0zvzQBm8JsctBp61ezaf9SXUY2sA -AjEA6dPGnlaaKsyh2j/IZivTWJwghfqrkYpwcBE4YGQLYgmRWAD5Tfs0aNoJrSEG -GJTO ------END CERTIFICATE----- - -# Issuer: CN=vTrus Root CA O=iTrusChina Co.,Ltd. -# Subject: CN=vTrus Root CA O=iTrusChina Co.,Ltd. -# Label: "vTrus Root CA" -# Serial: 387574501246983434957692974888460947164905180485 -# MD5 Fingerprint: b8:c9:37:df:fa:6b:31:84:64:c5:ea:11:6a:1b:75:fc -# SHA1 Fingerprint: 84:1a:69:fb:f5:cd:1a:25:34:13:3d:e3:f8:fc:b8:99:d0:c9:14:b7 -# SHA256 Fingerprint: 8a:71:de:65:59:33:6f:42:6c:26:e5:38:80:d0:0d:88:a1:8d:a4:c6:a9:1f:0d:cb:61:94:e2:06:c5:c9:63:87 ------BEGIN CERTIFICATE----- -MIIFVjCCAz6gAwIBAgIUQ+NxE9izWRRdt86M/TX9b7wFjUUwDQYJKoZIhvcNAQEL -BQAwQzELMAkGA1UEBhMCQ04xHDAaBgNVBAoTE2lUcnVzQ2hpbmEgQ28uLEx0ZC4x -FjAUBgNVBAMTDXZUcnVzIFJvb3QgQ0EwHhcNMTgwNzMxMDcyNDA1WhcNNDMwNzMx -MDcyNDA1WjBDMQswCQYDVQQGEwJDTjEcMBoGA1UEChMTaVRydXNDaGluYSBDby4s -THRkLjEWMBQGA1UEAxMNdlRydXMgUm9vdCBDQTCCAiIwDQYJKoZIhvcNAQEBBQAD -ggIPADCCAgoCggIBAL1VfGHTuB0EYgWgrmy3cLRB6ksDXhA/kFocizuwZotsSKYc -IrrVQJLuM7IjWcmOvFjai57QGfIvWcaMY1q6n6MLsLOaXLoRuBLpDLvPbmyAhykU -AyyNJJrIZIO1aqwTLDPxn9wsYTwaP3BVm60AUn/PBLn+NvqcwBauYv6WTEN+VRS+ -GrPSbcKvdmaVayqwlHeFXgQPYh1jdfdr58tbmnDsPmcF8P4HCIDPKNsFxhQnL4Z9 -8Cfe/+Z+M0jnCx5Y0ScrUw5XSmXX+6KAYPxMvDVTAWqXcoKv8R1w6Jz1717CbMdH -flqUhSZNO7rrTOiwCcJlwp2dCZtOtZcFrPUGoPc2BX70kLJrxLT5ZOrpGgrIDajt -J8nU57O5q4IikCc9Kuh8kO+8T/3iCiSn3mUkpF3qwHYw03dQ+A0Em5Q2AXPKBlim -0zvc+gRGE1WKyURHuFE5Gi7oNOJ5y1lKCn+8pu8fA2dqWSslYpPZUxlmPCdiKYZN -pGvu/9ROutW04o5IWgAZCfEF2c6Rsffr6TlP9m8EQ5pV9T4FFL2/s1m02I4zhKOQ -UqqzApVg+QxMaPnu1RcN+HFXtSXkKe5lXa/R7jwXC1pDxaWG6iSe4gUH3DRCEpHW -OXSuTEGC2/KmSNGzm/MzqvOmwMVO9fSddmPmAsYiS8GVP1BkLFTltvA8Kc9XAgMB -AAGjQjBAMB0GA1UdDgQWBBRUYnBj8XWEQ1iO0RYgscasGrz2iTAPBgNVHRMBAf8E -BTADAQH/MA4GA1UdDwEB/wQEAwIBBjANBgkqhkiG9w0BAQsFAAOCAgEAKbqSSaet -8PFww+SX8J+pJdVrnjT+5hpk9jprUrIQeBqfTNqK2uwcN1LgQkv7bHbKJAs5EhWd -nxEt/Hlk3ODg9d3gV8mlsnZwUKT+twpw1aA08XXXTUm6EdGz2OyC/+sOxL9kLX1j -bhd47F18iMjrjld22VkE+rxSH0Ws8HqA7Oxvdq6R2xCOBNyS36D25q5J08FsEhvM -Kar5CKXiNxTKsbhm7xqC5PD48acWabfbqWE8n/Uxy+QARsIvdLGx14HuqCaVvIiv -TDUHKgLKeBRtRytAVunLKmChZwOgzoy8sHJnxDHO2zTlJQNgJXtxmOTAGytfdELS -S8VZCAeHvsXDf+eW2eHcKJfWjwXj9ZtOyh1QRwVTsMo554WgicEFOwE30z9J4nfr -I8iIZjs9OXYhRvHsXyO466JmdXTBQPfYaJqT4i2pLr0cox7IdMakLXogqzu4sEb9 -b91fUlV1YvCXoHzXOP0l382gmxDPi7g4Xl7FtKYCNqEeXxzP4padKar9mK5S4fNB -UvupLnKWnyfjqnN9+BojZns7q2WwMgFLFT49ok8MKzWixtlnEjUwzXYuFrOZnk1P -Ti07NEPhmg4NpGaXutIcSkwsKouLgU9xGqndXHt7CMUADTdA43x7VF8vhV929ven -sBxXVsFy6K2ir40zSbofitzmdHxghm+Hl3s= ------END CERTIFICATE----- - -# Issuer: CN=ISRG Root X2 O=Internet Security Research Group -# Subject: CN=ISRG Root X2 O=Internet Security Research Group -# Label: "ISRG Root X2" -# Serial: 87493402998870891108772069816698636114 -# MD5 Fingerprint: d3:9e:c4:1e:23:3c:a6:df:cf:a3:7e:6d:e0:14:e6:e5 -# SHA1 Fingerprint: bd:b1:b9:3c:d5:97:8d:45:c6:26:14:55:f8:db:95:c7:5a:d1:53:af -# SHA256 Fingerprint: 69:72:9b:8e:15:a8:6e:fc:17:7a:57:af:b7:17:1d:fc:64:ad:d2:8c:2f:ca:8c:f1:50:7e:34:45:3c:cb:14:70 ------BEGIN CERTIFICATE----- -MIICGzCCAaGgAwIBAgIQQdKd0XLq7qeAwSxs6S+HUjAKBggqhkjOPQQDAzBPMQsw -CQYDVQQGEwJVUzEpMCcGA1UEChMgSW50ZXJuZXQgU2VjdXJpdHkgUmVzZWFyY2gg -R3JvdXAxFTATBgNVBAMTDElTUkcgUm9vdCBYMjAeFw0yMDA5MDQwMDAwMDBaFw00 -MDA5MTcxNjAwMDBaME8xCzAJBgNVBAYTAlVTMSkwJwYDVQQKEyBJbnRlcm5ldCBT -ZWN1cml0eSBSZXNlYXJjaCBHcm91cDEVMBMGA1UEAxMMSVNSRyBSb290IFgyMHYw -EAYHKoZIzj0CAQYFK4EEACIDYgAEzZvVn4CDCuwJSvMWSj5cz3es3mcFDR0HttwW -+1qLFNvicWDEukWVEYmO6gbf9yoWHKS5xcUy4APgHoIYOIvXRdgKam7mAHf7AlF9 -ItgKbppbd9/w+kHsOdx1ymgHDB/qo0IwQDAOBgNVHQ8BAf8EBAMCAQYwDwYDVR0T -AQH/BAUwAwEB/zAdBgNVHQ4EFgQUfEKWrt5LSDv6kviejM9ti6lyN5UwCgYIKoZI -zj0EAwMDaAAwZQIwe3lORlCEwkSHRhtFcP9Ymd70/aTSVaYgLXTWNLxBo1BfASdW -tL4ndQavEi51mI38AjEAi/V3bNTIZargCyzuFJ0nN6T5U6VR5CmD1/iQMVtCnwr1 -/q4AaOeMSQ+2b1tbFfLn ------END CERTIFICATE----- - -# Issuer: CN=HiPKI Root CA - G1 O=Chunghwa Telecom Co., Ltd. -# Subject: CN=HiPKI Root CA - G1 O=Chunghwa Telecom Co., Ltd. -# Label: "HiPKI Root CA - G1" -# Serial: 60966262342023497858655262305426234976 -# MD5 Fingerprint: 69:45:df:16:65:4b:e8:68:9a:8f:76:5f:ff:80:9e:d3 -# SHA1 Fingerprint: 6a:92:e4:a8:ee:1b:ec:96:45:37:e3:29:57:49:cd:96:e3:e5:d2:60 -# SHA256 Fingerprint: f0:15:ce:3c:c2:39:bf:ef:06:4b:e9:f1:d2:c4:17:e1:a0:26:4a:0a:94:be:1f:0c:8d:12:18:64:eb:69:49:cc ------BEGIN CERTIFICATE----- -MIIFajCCA1KgAwIBAgIQLd2szmKXlKFD6LDNdmpeYDANBgkqhkiG9w0BAQsFADBP -MQswCQYDVQQGEwJUVzEjMCEGA1UECgwaQ2h1bmdod2EgVGVsZWNvbSBDby4sIEx0 -ZC4xGzAZBgNVBAMMEkhpUEtJIFJvb3QgQ0EgLSBHMTAeFw0xOTAyMjIwOTQ2MDRa -Fw0zNzEyMzExNTU5NTlaME8xCzAJBgNVBAYTAlRXMSMwIQYDVQQKDBpDaHVuZ2h3 -YSBUZWxlY29tIENvLiwgTHRkLjEbMBkGA1UEAwwSSGlQS0kgUm9vdCBDQSAtIEcx -MIICIjANBgkqhkiG9w0BAQEFAAOCAg8AMIICCgKCAgEA9B5/UnMyDHPkvRN0o9Qw -qNCuS9i233VHZvR85zkEHmpwINJaR3JnVfSl6J3VHiGh8Ge6zCFovkRTv4354twv -Vcg3Px+kwJyz5HdcoEb+d/oaoDjq7Zpy3iu9lFc6uux55199QmQ5eiY29yTw1S+6 -lZgRZq2XNdZ1AYDgr/SEYYwNHl98h5ZeQa/rh+r4XfEuiAU+TCK72h8q3VJGZDnz -Qs7ZngyzsHeXZJzA9KMuH5UHsBffMNsAGJZMoYFL3QRtU6M9/Aes1MU3guvklQgZ -KILSQjqj2FPseYlgSGDIcpJQ3AOPgz+yQlda22rpEZfdhSi8MEyr48KxRURHH+CK -FgeW0iEPU8DtqX7UTuybCeyvQqww1r/REEXgphaypcXTT3OUM3ECoWqj1jOXTyFj -HluP2cFeRXF3D4FdXyGarYPM+l7WjSNfGz1BryB1ZlpK9p/7qxj3ccC2HTHsOyDr -y+K49a6SsvfhhEvyovKTmiKe0xRvNlS9H15ZFblzqMF8b3ti6RZsR1pl8w4Rm0bZ -/W3c1pzAtH2lsN0/Vm+h+fbkEkj9Bn8SV7apI09bA8PgcSojt/ewsTu8mL3WmKgM -a/aOEmem8rJY5AIJEzypuxC00jBF8ez3ABHfZfjcK0NVvxaXxA/VLGGEqnKG/uY6 -fsI/fe78LxQ+5oXdUG+3Se0CAwEAAaNCMEAwDwYDVR0TAQH/BAUwAwEB/zAdBgNV -HQ4EFgQU8ncX+l6o/vY9cdVouslGDDjYr7AwDgYDVR0PAQH/BAQDAgGGMA0GCSqG -SIb3DQEBCwUAA4ICAQBQUfB13HAE4/+qddRxosuej6ip0691x1TPOhwEmSKsxBHi -7zNKpiMdDg1H2DfHb680f0+BazVP6XKlMeJ45/dOlBhbQH3PayFUhuaVevvGyuqc -SE5XCV0vrPSltJczWNWseanMX/mF+lLFjfiRFOs6DRfQUsJ748JzjkZ4Bjgs6Fza -ZsT0pPBWGTMpWmWSBUdGSquEwx4noR8RkpkndZMPvDY7l1ePJlsMu5wP1G4wB9Tc -XzZoZjmDlicmisjEOf6aIW/Vcobpf2Lll07QJNBAsNB1CI69aO4I1258EHBGG3zg -iLKecoaZAeO/n0kZtCW+VmWuF2PlHt/o/0elv+EmBYTksMCv5wiZqAxeJoBF1Pho -L5aPruJKHJwWDBNvOIf2u8g0X5IDUXlwpt/L9ZlNec1OvFefQ05rLisY+GpzjLrF -Ne85akEez3GoorKGB1s6yeHvP2UEgEcyRHCVTjFnanRbEEV16rCf0OY1/k6fi8wr -kkVbbiVghUbN0aqwdmaTd5a+g744tiROJgvM7XpWGuDpWsZkrUx6AEhEL7lAuxM+ -vhV4nYWBSipX3tUZQ9rbyltHhoMLP7YNdnhzeSJesYAfz77RP1YQmCuVh6EfnWQU -YDksswBVLuT1sw5XxJFBAJw/6KXf6vb/yPCtbVKoF6ubYfwSUTXkJf2vqmqGOQ== ------END CERTIFICATE----- - -# Issuer: CN=GlobalSign O=GlobalSign OU=GlobalSign ECC Root CA - R4 -# Subject: CN=GlobalSign O=GlobalSign OU=GlobalSign ECC Root CA - R4 -# Label: "GlobalSign ECC Root CA - R4" -# Serial: 159662223612894884239637590694 -# MD5 Fingerprint: 26:29:f8:6d:e1:88:bf:a2:65:7f:aa:c4:cd:0f:7f:fc -# SHA1 Fingerprint: 6b:a0:b0:98:e1:71:ef:5a:ad:fe:48:15:80:77:10:f4:bd:6f:0b:28 -# SHA256 Fingerprint: b0:85:d7:0b:96:4f:19:1a:73:e4:af:0d:54:ae:7a:0e:07:aa:fd:af:9b:71:dd:08:62:13:8a:b7:32:5a:24:a2 ------BEGIN CERTIFICATE----- -MIIB3DCCAYOgAwIBAgINAgPlfvU/k/2lCSGypjAKBggqhkjOPQQDAjBQMSQwIgYD -VQQLExtHbG9iYWxTaWduIEVDQyBSb290IENBIC0gUjQxEzARBgNVBAoTCkdsb2Jh -bFNpZ24xEzARBgNVBAMTCkdsb2JhbFNpZ24wHhcNMTIxMTEzMDAwMDAwWhcNMzgw -MTE5MDMxNDA3WjBQMSQwIgYDVQQLExtHbG9iYWxTaWduIEVDQyBSb290IENBIC0g -UjQxEzARBgNVBAoTCkdsb2JhbFNpZ24xEzARBgNVBAMTCkdsb2JhbFNpZ24wWTAT -BgcqhkjOPQIBBggqhkjOPQMBBwNCAAS4xnnTj2wlDp8uORkcA6SumuU5BwkWymOx -uYb4ilfBV85C+nOh92VC/x7BALJucw7/xyHlGKSq2XE/qNS5zowdo0IwQDAOBgNV -HQ8BAf8EBAMCAYYwDwYDVR0TAQH/BAUwAwEB/zAdBgNVHQ4EFgQUVLB7rUW44kB/ -+wpu+74zyTyjhNUwCgYIKoZIzj0EAwIDRwAwRAIgIk90crlgr/HmnKAWBVBfw147 -bmF0774BxL4YSFlhgjICICadVGNA3jdgUM/I2O2dgq43mLyjj0xMqTQrbO/7lZsm ------END CERTIFICATE----- - -# Issuer: CN=GTS Root R1 O=Google Trust Services LLC -# Subject: CN=GTS Root R1 O=Google Trust Services LLC -# Label: "GTS Root R1" -# Serial: 159662320309726417404178440727 -# MD5 Fingerprint: 05:fe:d0:bf:71:a8:a3:76:63:da:01:e0:d8:52:dc:40 -# SHA1 Fingerprint: e5:8c:1c:c4:91:3b:38:63:4b:e9:10:6e:e3:ad:8e:6b:9d:d9:81:4a -# SHA256 Fingerprint: d9:47:43:2a:bd:e7:b7:fa:90:fc:2e:6b:59:10:1b:12:80:e0:e1:c7:e4:e4:0f:a3:c6:88:7f:ff:57:a7:f4:cf ------BEGIN CERTIFICATE----- -MIIFVzCCAz+gAwIBAgINAgPlk28xsBNJiGuiFzANBgkqhkiG9w0BAQwFADBHMQsw -CQYDVQQGEwJVUzEiMCAGA1UEChMZR29vZ2xlIFRydXN0IFNlcnZpY2VzIExMQzEU -MBIGA1UEAxMLR1RTIFJvb3QgUjEwHhcNMTYwNjIyMDAwMDAwWhcNMzYwNjIyMDAw -MDAwWjBHMQswCQYDVQQGEwJVUzEiMCAGA1UEChMZR29vZ2xlIFRydXN0IFNlcnZp -Y2VzIExMQzEUMBIGA1UEAxMLR1RTIFJvb3QgUjEwggIiMA0GCSqGSIb3DQEBAQUA -A4ICDwAwggIKAoICAQC2EQKLHuOhd5s73L+UPreVp0A8of2C+X0yBoJx9vaMf/vo -27xqLpeXo4xL+Sv2sfnOhB2x+cWX3u+58qPpvBKJXqeqUqv4IyfLpLGcY9vXmX7w -Cl7raKb0xlpHDU0QM+NOsROjyBhsS+z8CZDfnWQpJSMHobTSPS5g4M/SCYe7zUjw -TcLCeoiKu7rPWRnWr4+wB7CeMfGCwcDfLqZtbBkOtdh+JhpFAz2weaSUKK0Pfybl -qAj+lug8aJRT7oM6iCsVlgmy4HqMLnXWnOunVmSPlk9orj2XwoSPwLxAwAtcvfaH -szVsrBhQf4TgTM2S0yDpM7xSma8ytSmzJSq0SPly4cpk9+aCEI3oncKKiPo4Zor8 -Y/kB+Xj9e1x3+naH+uzfsQ55lVe0vSbv1gHR6xYKu44LtcXFilWr06zqkUspzBmk -MiVOKvFlRNACzqrOSbTqn3yDsEB750Orp2yjj32JgfpMpf/VjsPOS+C12LOORc92 -wO1AK/1TD7Cn1TsNsYqiA94xrcx36m97PtbfkSIS5r762DL8EGMUUXLeXdYWk70p -aDPvOmbsB4om3xPXV2V4J95eSRQAogB/mqghtqmxlbCluQ0WEdrHbEg8QOB+DVrN -VjzRlwW5y0vtOUucxD/SVRNuJLDWcfr0wbrM7Rv1/oFB2ACYPTrIrnqYNxgFlQID -AQABo0IwQDAOBgNVHQ8BAf8EBAMCAYYwDwYDVR0TAQH/BAUwAwEB/zAdBgNVHQ4E -FgQU5K8rJnEaK0gnhS9SZizv8IkTcT4wDQYJKoZIhvcNAQEMBQADggIBAJ+qQibb -C5u+/x6Wki4+omVKapi6Ist9wTrYggoGxval3sBOh2Z5ofmmWJyq+bXmYOfg6LEe -QkEzCzc9zolwFcq1JKjPa7XSQCGYzyI0zzvFIoTgxQ6KfF2I5DUkzps+GlQebtuy -h6f88/qBVRRiClmpIgUxPoLW7ttXNLwzldMXG+gnoot7TiYaelpkttGsN/H9oPM4 -7HLwEXWdyzRSjeZ2axfG34arJ45JK3VmgRAhpuo+9K4l/3wV3s6MJT/KYnAK9y8J -ZgfIPxz88NtFMN9iiMG1D53Dn0reWVlHxYciNuaCp+0KueIHoI17eko8cdLiA6Ef -MgfdG+RCzgwARWGAtQsgWSl4vflVy2PFPEz0tv/bal8xa5meLMFrUKTX5hgUvYU/ -Z6tGn6D/Qqc6f1zLXbBwHSs09dR2CQzreExZBfMzQsNhFRAbd03OIozUhfJFfbdT -6u9AWpQKXCBfTkBdYiJ23//OYb2MI3jSNwLgjt7RETeJ9r/tSQdirpLsQBqvFAnZ -0E6yove+7u7Y/9waLd64NnHi/Hm3lCXRSHNboTXns5lndcEZOitHTtNCjv0xyBZm -2tIMPNuzjsmhDYAPexZ3FL//2wmUspO8IFgV6dtxQ/PeEMMA3KgqlbbC1j+Qa3bb -bP6MvPJwNQzcmRk13NfIRmPVNnGuV/u3gm3c ------END CERTIFICATE----- - -# Issuer: CN=GTS Root R2 O=Google Trust Services LLC -# Subject: CN=GTS Root R2 O=Google Trust Services LLC -# Label: "GTS Root R2" -# Serial: 159662449406622349769042896298 -# MD5 Fingerprint: 1e:39:c0:53:e6:1e:29:82:0b:ca:52:55:36:5d:57:dc -# SHA1 Fingerprint: 9a:44:49:76:32:db:de:fa:d0:bc:fb:5a:7b:17:bd:9e:56:09:24:94 -# SHA256 Fingerprint: 8d:25:cd:97:22:9d:bf:70:35:6b:da:4e:b3:cc:73:40:31:e2:4c:f0:0f:af:cf:d3:2d:c7:6e:b5:84:1c:7e:a8 ------BEGIN CERTIFICATE----- -MIIFVzCCAz+gAwIBAgINAgPlrsWNBCUaqxElqjANBgkqhkiG9w0BAQwFADBHMQsw -CQYDVQQGEwJVUzEiMCAGA1UEChMZR29vZ2xlIFRydXN0IFNlcnZpY2VzIExMQzEU -MBIGA1UEAxMLR1RTIFJvb3QgUjIwHhcNMTYwNjIyMDAwMDAwWhcNMzYwNjIyMDAw -MDAwWjBHMQswCQYDVQQGEwJVUzEiMCAGA1UEChMZR29vZ2xlIFRydXN0IFNlcnZp -Y2VzIExMQzEUMBIGA1UEAxMLR1RTIFJvb3QgUjIwggIiMA0GCSqGSIb3DQEBAQUA -A4ICDwAwggIKAoICAQDO3v2m++zsFDQ8BwZabFn3GTXd98GdVarTzTukk3LvCvpt -nfbwhYBboUhSnznFt+4orO/LdmgUud+tAWyZH8QiHZ/+cnfgLFuv5AS/T3KgGjSY -6Dlo7JUle3ah5mm5hRm9iYz+re026nO8/4Piy33B0s5Ks40FnotJk9/BW9BuXvAu -MC6C/Pq8tBcKSOWIm8Wba96wyrQD8Nr0kLhlZPdcTK3ofmZemde4wj7I0BOdre7k -RXuJVfeKH2JShBKzwkCX44ofR5GmdFrS+LFjKBC4swm4VndAoiaYecb+3yXuPuWg -f9RhD1FLPD+M2uFwdNjCaKH5wQzpoeJ/u1U8dgbuak7MkogwTZq9TwtImoS1mKPV -+3PBV2HdKFZ1E66HjucMUQkQdYhMvI35ezzUIkgfKtzra7tEscszcTJGr61K8Yzo -dDqs5xoic4DSMPclQsciOzsSrZYuxsN2B6ogtzVJV+mSSeh2FnIxZyuWfoqjx5RW -Ir9qS34BIbIjMt/kmkRtWVtd9QCgHJvGeJeNkP+byKq0rxFROV7Z+2et1VsRnTKa -G73VululycslaVNVJ1zgyjbLiGH7HrfQy+4W+9OmTN6SpdTi3/UGVN4unUu0kzCq -gc7dGtxRcw1PcOnlthYhGXmy5okLdWTK1au8CcEYof/UVKGFPP0UJAOyh9OktwID -AQABo0IwQDAOBgNVHQ8BAf8EBAMCAYYwDwYDVR0TAQH/BAUwAwEB/zAdBgNVHQ4E -FgQUu//KjiOfT5nK2+JopqUVJxce2Q4wDQYJKoZIhvcNAQEMBQADggIBAB/Kzt3H -vqGf2SdMC9wXmBFqiN495nFWcrKeGk6c1SuYJF2ba3uwM4IJvd8lRuqYnrYb/oM8 -0mJhwQTtzuDFycgTE1XnqGOtjHsB/ncw4c5omwX4Eu55MaBBRTUoCnGkJE+M3DyC -B19m3H0Q/gxhswWV7uGugQ+o+MePTagjAiZrHYNSVc61LwDKgEDg4XSsYPWHgJ2u -NmSRXbBoGOqKYcl3qJfEycel/FVL8/B/uWU9J2jQzGv6U53hkRrJXRqWbTKH7QMg -yALOWr7Z6v2yTcQvG99fevX4i8buMTolUVVnjWQye+mew4K6Ki3pHrTgSAai/Gev -HyICc/sgCq+dVEuhzf9gR7A/Xe8bVr2XIZYtCtFenTgCR2y59PYjJbigapordwj6 -xLEokCZYCDzifqrXPW+6MYgKBesntaFJ7qBFVHvmJ2WZICGoo7z7GJa7Um8M7YNR -TOlZ4iBgxcJlkoKM8xAfDoqXvneCbT+PHV28SSe9zE8P4c52hgQjxcCMElv924Sg -JPFI/2R80L5cFtHvma3AH/vLrrw4IgYmZNralw4/KBVEqE8AyvCazM90arQ+POuV -7LXTWtiBmelDGDfrs7vRWGJB82bSj6p4lVQgw1oudCvV0b4YacCs1aTPObpRhANl -6WLAYv7YTVWW4tAR+kg0Eeye7QUd5MjWHYbL ------END CERTIFICATE----- - -# Issuer: CN=GTS Root R3 O=Google Trust Services LLC -# Subject: CN=GTS Root R3 O=Google Trust Services LLC -# Label: "GTS Root R3" -# Serial: 159662495401136852707857743206 -# MD5 Fingerprint: 3e:e7:9d:58:02:94:46:51:94:e5:e0:22:4a:8b:e7:73 -# SHA1 Fingerprint: ed:e5:71:80:2b:c8:92:b9:5b:83:3c:d2:32:68:3f:09:cd:a0:1e:46 -# SHA256 Fingerprint: 34:d8:a7:3e:e2:08:d9:bc:db:0d:95:65:20:93:4b:4e:40:e6:94:82:59:6e:8b:6f:73:c8:42:6b:01:0a:6f:48 ------BEGIN CERTIFICATE----- -MIICCTCCAY6gAwIBAgINAgPluILrIPglJ209ZjAKBggqhkjOPQQDAzBHMQswCQYD -VQQGEwJVUzEiMCAGA1UEChMZR29vZ2xlIFRydXN0IFNlcnZpY2VzIExMQzEUMBIG -A1UEAxMLR1RTIFJvb3QgUjMwHhcNMTYwNjIyMDAwMDAwWhcNMzYwNjIyMDAwMDAw -WjBHMQswCQYDVQQGEwJVUzEiMCAGA1UEChMZR29vZ2xlIFRydXN0IFNlcnZpY2Vz -IExMQzEUMBIGA1UEAxMLR1RTIFJvb3QgUjMwdjAQBgcqhkjOPQIBBgUrgQQAIgNi -AAQfTzOHMymKoYTey8chWEGJ6ladK0uFxh1MJ7x/JlFyb+Kf1qPKzEUURout736G -jOyxfi//qXGdGIRFBEFVbivqJn+7kAHjSxm65FSWRQmx1WyRRK2EE46ajA2ADDL2 -4CejQjBAMA4GA1UdDwEB/wQEAwIBhjAPBgNVHRMBAf8EBTADAQH/MB0GA1UdDgQW -BBTB8Sa6oC2uhYHP0/EqEr24Cmf9vDAKBggqhkjOPQQDAwNpADBmAjEA9uEglRR7 -VKOQFhG/hMjqb2sXnh5GmCCbn9MN2azTL818+FsuVbu/3ZL3pAzcMeGiAjEA/Jdm -ZuVDFhOD3cffL74UOO0BzrEXGhF16b0DjyZ+hOXJYKaV11RZt+cRLInUue4X ------END CERTIFICATE----- - -# Issuer: CN=GTS Root R4 O=Google Trust Services LLC -# Subject: CN=GTS Root R4 O=Google Trust Services LLC -# Label: "GTS Root R4" -# Serial: 159662532700760215368942768210 -# MD5 Fingerprint: 43:96:83:77:19:4d:76:b3:9d:65:52:e4:1d:22:a5:e8 -# SHA1 Fingerprint: 77:d3:03:67:b5:e0:0c:15:f6:0c:38:61:df:7c:e1:3b:92:46:4d:47 -# SHA256 Fingerprint: 34:9d:fa:40:58:c5:e2:63:12:3b:39:8a:e7:95:57:3c:4e:13:13:c8:3f:e6:8f:93:55:6c:d5:e8:03:1b:3c:7d ------BEGIN CERTIFICATE----- -MIICCTCCAY6gAwIBAgINAgPlwGjvYxqccpBQUjAKBggqhkjOPQQDAzBHMQswCQYD -VQQGEwJVUzEiMCAGA1UEChMZR29vZ2xlIFRydXN0IFNlcnZpY2VzIExMQzEUMBIG -A1UEAxMLR1RTIFJvb3QgUjQwHhcNMTYwNjIyMDAwMDAwWhcNMzYwNjIyMDAwMDAw -WjBHMQswCQYDVQQGEwJVUzEiMCAGA1UEChMZR29vZ2xlIFRydXN0IFNlcnZpY2Vz -IExMQzEUMBIGA1UEAxMLR1RTIFJvb3QgUjQwdjAQBgcqhkjOPQIBBgUrgQQAIgNi -AATzdHOnaItgrkO4NcWBMHtLSZ37wWHO5t5GvWvVYRg1rkDdc/eJkTBa6zzuhXyi -QHY7qca4R9gq55KRanPpsXI5nymfopjTX15YhmUPoYRlBtHci8nHc8iMai/lxKvR -HYqjQjBAMA4GA1UdDwEB/wQEAwIBhjAPBgNVHRMBAf8EBTADAQH/MB0GA1UdDgQW -BBSATNbrdP9JNqPV2Py1PsVq8JQdjDAKBggqhkjOPQQDAwNpADBmAjEA6ED/g94D -9J+uHXqnLrmvT/aDHQ4thQEd0dlq7A/Cr8deVl5c1RxYIigL9zC2L7F8AjEA8GE8 -p/SgguMh1YQdc4acLa/KNJvxn7kjNuK8YAOdgLOaVsjh4rsUecrNIdSUtUlD ------END CERTIFICATE----- - -# Issuer: CN=Telia Root CA v2 O=Telia Finland Oyj -# Subject: CN=Telia Root CA v2 O=Telia Finland Oyj -# Label: "Telia Root CA v2" -# Serial: 7288924052977061235122729490515358 -# MD5 Fingerprint: 0e:8f:ac:aa:82:df:85:b1:f4:dc:10:1c:fc:99:d9:48 -# SHA1 Fingerprint: b9:99:cd:d1:73:50:8a:c4:47:05:08:9c:8c:88:fb:be:a0:2b:40:cd -# SHA256 Fingerprint: 24:2b:69:74:2f:cb:1e:5b:2a:bf:98:89:8b:94:57:21:87:54:4e:5b:4d:99:11:78:65:73:62:1f:6a:74:b8:2c ------BEGIN CERTIFICATE----- -MIIFdDCCA1ygAwIBAgIPAWdfJ9b+euPkrL4JWwWeMA0GCSqGSIb3DQEBCwUAMEQx -CzAJBgNVBAYTAkZJMRowGAYDVQQKDBFUZWxpYSBGaW5sYW5kIE95ajEZMBcGA1UE -AwwQVGVsaWEgUm9vdCBDQSB2MjAeFw0xODExMjkxMTU1NTRaFw00MzExMjkxMTU1 -NTRaMEQxCzAJBgNVBAYTAkZJMRowGAYDVQQKDBFUZWxpYSBGaW5sYW5kIE95ajEZ -MBcGA1UEAwwQVGVsaWEgUm9vdCBDQSB2MjCCAiIwDQYJKoZIhvcNAQEBBQADggIP -ADCCAgoCggIBALLQPwe84nvQa5n44ndp586dpAO8gm2h/oFlH0wnrI4AuhZ76zBq -AMCzdGh+sq/H1WKzej9Qyow2RCRj0jbpDIX2Q3bVTKFgcmfiKDOlyzG4OiIjNLh9 -vVYiQJ3q9HsDrWj8soFPmNB06o3lfc1jw6P23pLCWBnglrvFxKk9pXSW/q/5iaq9 -lRdU2HhE8Qx3FZLgmEKnpNaqIJLNwaCzlrI6hEKNfdWV5Nbb6WLEWLN5xYzTNTOD -n3WhUidhOPFZPY5Q4L15POdslv5e2QJltI5c0BE0312/UqeBAMN/mUWZFdUXyApT -7GPzmX3MaRKGwhfwAZ6/hLzRUssbkmbOpFPlob/E2wnW5olWK8jjfN7j/4nlNW4o -6GwLI1GpJQXrSPjdscr6bAhR77cYbETKJuFzxokGgeWKrLDiKca5JLNrRBH0pUPC -TEPlcDaMtjNXepUugqD0XBCzYYP2AgWGLnwtbNwDRm41k9V6lS/eINhbfpSQBGq6 -WT0EBXWdN6IOLj3rwaRSg/7Qa9RmjtzG6RJOHSpXqhC8fF6CfaamyfItufUXJ63R -DolUK5X6wK0dmBR4M0KGCqlztft0DbcbMBnEWg4cJ7faGND/isgFuvGqHKI3t+ZI -pEYslOqodmJHixBTB0hXbOKSTbauBcvcwUpej6w9GU7C7WB1K9vBykLVAgMBAAGj -YzBhMB8GA1UdIwQYMBaAFHKs5DN5qkWH9v2sHZ7Wxy+G2CQ5MB0GA1UdDgQWBBRy -rOQzeapFh/b9rB2e1scvhtgkOTAOBgNVHQ8BAf8EBAMCAQYwDwYDVR0TAQH/BAUw -AwEB/zANBgkqhkiG9w0BAQsFAAOCAgEAoDtZpwmUPjaE0n4vOaWWl/oRrfxn83EJ -8rKJhGdEr7nv7ZbsnGTbMjBvZ5qsfl+yqwE2foH65IRe0qw24GtixX1LDoJt0nZi -0f6X+J8wfBj5tFJ3gh1229MdqfDBmgC9bXXYfef6xzijnHDoRnkDry5023X4blMM -A8iZGok1GTzTyVR8qPAs5m4HeW9q4ebqkYJpCh3DflminmtGFZhb069GHWLIzoBS -SRE/yQQSwxN8PzuKlts8oB4KtItUsiRnDe+Cy748fdHif64W1lZYudogsYMVoe+K -TTJvQS8TUoKU1xrBeKJR3Stwbbca+few4GeXVtt8YVMJAygCQMez2P2ccGrGKMOF -6eLtGpOg3kuYooQ+BXcBlj37tCAPnHICehIv1aO6UXivKitEZU61/Qrowc15h2Er -3oBXRb9n8ZuRXqWk7FlIEA04x7D6w0RtBPV4UBySllva9bguulvP5fBqnUsvWHMt -Ty3EHD70sz+rFQ47GUGKpMFXEmZxTPpT41frYpUJnlTd0cI8Vzy9OK2YZLe4A5pT -VmBds9hCG1xLEooc6+t9xnppxyd/pPiL8uSUZodL6ZQHCRJ5irLrdATczvREWeAW -ysUsWNc8e89ihmpQfTU2Zqf7N+cox9jQraVplI/owd8k+BsHMYeB2F326CjYSlKA -rBPuUBQemMc= ------END CERTIFICATE----- - -# Issuer: CN=D-TRUST BR Root CA 1 2020 O=D-Trust GmbH -# Subject: CN=D-TRUST BR Root CA 1 2020 O=D-Trust GmbH -# Label: "D-TRUST BR Root CA 1 2020" -# Serial: 165870826978392376648679885835942448534 -# MD5 Fingerprint: b5:aa:4b:d5:ed:f7:e3:55:2e:8f:72:0a:f3:75:b8:ed -# SHA1 Fingerprint: 1f:5b:98:f0:e3:b5:f7:74:3c:ed:e6:b0:36:7d:32:cd:f4:09:41:67 -# SHA256 Fingerprint: e5:9a:aa:81:60:09:c2:2b:ff:5b:25:ba:d3:7d:f3:06:f0:49:79:7c:1f:81:d8:5a:b0:89:e6:57:bd:8f:00:44 ------BEGIN CERTIFICATE----- -MIIC2zCCAmCgAwIBAgIQfMmPK4TX3+oPyWWa00tNljAKBggqhkjOPQQDAzBIMQsw -CQYDVQQGEwJERTEVMBMGA1UEChMMRC1UcnVzdCBHbWJIMSIwIAYDVQQDExlELVRS -VVNUIEJSIFJvb3QgQ0EgMSAyMDIwMB4XDTIwMDIxMTA5NDUwMFoXDTM1MDIxMTA5 -NDQ1OVowSDELMAkGA1UEBhMCREUxFTATBgNVBAoTDEQtVHJ1c3QgR21iSDEiMCAG -A1UEAxMZRC1UUlVTVCBCUiBSb290IENBIDEgMjAyMDB2MBAGByqGSM49AgEGBSuB -BAAiA2IABMbLxyjR+4T1mu9CFCDhQ2tuda38KwOE1HaTJddZO0Flax7mNCq7dPYS -zuht56vkPE4/RAiLzRZxy7+SmfSk1zxQVFKQhYN4lGdnoxwJGT11NIXe7WB9xwy0 -QVK5buXuQqOCAQ0wggEJMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYEFHOREKv/ -VbNafAkl1bK6CKBrqx9tMA4GA1UdDwEB/wQEAwIBBjCBxgYDVR0fBIG+MIG7MD6g -PKA6hjhodHRwOi8vY3JsLmQtdHJ1c3QubmV0L2NybC9kLXRydXN0X2JyX3Jvb3Rf -Y2FfMV8yMDIwLmNybDB5oHegdYZzbGRhcDovL2RpcmVjdG9yeS5kLXRydXN0Lm5l -dC9DTj1ELVRSVVNUJTIwQlIlMjBSb290JTIwQ0ElMjAxJTIwMjAyMCxPPUQtVHJ1 -c3QlMjBHbWJILEM9REU/Y2VydGlmaWNhdGVyZXZvY2F0aW9ubGlzdDAKBggqhkjO -PQQDAwNpADBmAjEAlJAtE/rhY/hhY+ithXhUkZy4kzg+GkHaQBZTQgjKL47xPoFW -wKrY7RjEsK70PvomAjEA8yjixtsrmfu3Ubgko6SUeho/5jbiA1czijDLgsfWFBHV -dWNbFJWcHwHP2NVypw87 ------END CERTIFICATE----- - -# Issuer: CN=D-TRUST EV Root CA 1 2020 O=D-Trust GmbH -# Subject: CN=D-TRUST EV Root CA 1 2020 O=D-Trust GmbH -# Label: "D-TRUST EV Root CA 1 2020" -# Serial: 126288379621884218666039612629459926992 -# MD5 Fingerprint: 8c:2d:9d:70:9f:48:99:11:06:11:fb:e9:cb:30:c0:6e -# SHA1 Fingerprint: 61:db:8c:21:59:69:03:90:d8:7c:9c:12:86:54:cf:9d:3d:f4:dd:07 -# SHA256 Fingerprint: 08:17:0d:1a:a3:64:53:90:1a:2f:95:92:45:e3:47:db:0c:8d:37:ab:aa:bc:56:b8:1a:a1:00:dc:95:89:70:db ------BEGIN CERTIFICATE----- -MIIC2zCCAmCgAwIBAgIQXwJB13qHfEwDo6yWjfv/0DAKBggqhkjOPQQDAzBIMQsw -CQYDVQQGEwJERTEVMBMGA1UEChMMRC1UcnVzdCBHbWJIMSIwIAYDVQQDExlELVRS -VVNUIEVWIFJvb3QgQ0EgMSAyMDIwMB4XDTIwMDIxMTEwMDAwMFoXDTM1MDIxMTA5 -NTk1OVowSDELMAkGA1UEBhMCREUxFTATBgNVBAoTDEQtVHJ1c3QgR21iSDEiMCAG -A1UEAxMZRC1UUlVTVCBFViBSb290IENBIDEgMjAyMDB2MBAGByqGSM49AgEGBSuB -BAAiA2IABPEL3YZDIBnfl4XoIkqbz52Yv7QFJsnL46bSj8WeeHsxiamJrSc8ZRCC -/N/DnU7wMyPE0jL1HLDfMxddxfCxivnvubcUyilKwg+pf3VlSSowZ/Rk99Yad9rD -wpdhQntJraOCAQ0wggEJMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYEFH8QARY3 -OqQo5FD4pPfsazK2/umLMA4GA1UdDwEB/wQEAwIBBjCBxgYDVR0fBIG+MIG7MD6g -PKA6hjhodHRwOi8vY3JsLmQtdHJ1c3QubmV0L2NybC9kLXRydXN0X2V2X3Jvb3Rf -Y2FfMV8yMDIwLmNybDB5oHegdYZzbGRhcDovL2RpcmVjdG9yeS5kLXRydXN0Lm5l -dC9DTj1ELVRSVVNUJTIwRVYlMjBSb290JTIwQ0ElMjAxJTIwMjAyMCxPPUQtVHJ1 -c3QlMjBHbWJILEM9REU/Y2VydGlmaWNhdGVyZXZvY2F0aW9ubGlzdDAKBggqhkjO -PQQDAwNpADBmAjEAyjzGKnXCXnViOTYAYFqLwZOZzNnbQTs7h5kXO9XMT8oi96CA -y/m0sRtW9XLS/BnRAjEAkfcwkz8QRitxpNA7RJvAKQIFskF3UfN5Wp6OFKBOQtJb -gfM0agPnIjhQW+0ZT0MW ------END CERTIFICATE----- - -# Issuer: CN=DigiCert TLS ECC P384 Root G5 O=DigiCert, Inc. -# Subject: CN=DigiCert TLS ECC P384 Root G5 O=DigiCert, Inc. -# Label: "DigiCert TLS ECC P384 Root G5" -# Serial: 13129116028163249804115411775095713523 -# MD5 Fingerprint: d3:71:04:6a:43:1c:db:a6:59:e1:a8:a3:aa:c5:71:ed -# SHA1 Fingerprint: 17:f3:de:5e:9f:0f:19:e9:8e:f6:1f:32:26:6e:20:c4:07:ae:30:ee -# SHA256 Fingerprint: 01:8e:13:f0:77:25:32:cf:80:9b:d1:b1:72:81:86:72:83:fc:48:c6:e1:3b:e9:c6:98:12:85:4a:49:0c:1b:05 ------BEGIN CERTIFICATE----- -MIICGTCCAZ+gAwIBAgIQCeCTZaz32ci5PhwLBCou8zAKBggqhkjOPQQDAzBOMQsw -CQYDVQQGEwJVUzEXMBUGA1UEChMORGlnaUNlcnQsIEluYy4xJjAkBgNVBAMTHURp -Z2lDZXJ0IFRMUyBFQ0MgUDM4NCBSb290IEc1MB4XDTIxMDExNTAwMDAwMFoXDTQ2 -MDExNDIzNTk1OVowTjELMAkGA1UEBhMCVVMxFzAVBgNVBAoTDkRpZ2lDZXJ0LCBJ -bmMuMSYwJAYDVQQDEx1EaWdpQ2VydCBUTFMgRUNDIFAzODQgUm9vdCBHNTB2MBAG -ByqGSM49AgEGBSuBBAAiA2IABMFEoc8Rl1Ca3iOCNQfN0MsYndLxf3c1TzvdlHJS -7cI7+Oz6e2tYIOyZrsn8aLN1udsJ7MgT9U7GCh1mMEy7H0cKPGEQQil8pQgO4CLp -0zVozptjn4S1mU1YoI71VOeVyaNCMEAwHQYDVR0OBBYEFMFRRVBZqz7nLFr6ICIS -B4CIfBFqMA4GA1UdDwEB/wQEAwIBhjAPBgNVHRMBAf8EBTADAQH/MAoGCCqGSM49 -BAMDA2gAMGUCMQCJao1H5+z8blUD2WdsJk6Dxv3J+ysTvLd6jLRl0mlpYxNjOyZQ -LgGheQaRnUi/wr4CMEfDFXuxoJGZSZOoPHzoRgaLLPIxAJSdYsiJvRmEFOml+wG4 -DXZDjC5Ty3zfDBeWUA== ------END CERTIFICATE----- - -# Issuer: CN=DigiCert TLS RSA4096 Root G5 O=DigiCert, Inc. -# Subject: CN=DigiCert TLS RSA4096 Root G5 O=DigiCert, Inc. -# Label: "DigiCert TLS RSA4096 Root G5" -# Serial: 11930366277458970227240571539258396554 -# MD5 Fingerprint: ac:fe:f7:34:96:a9:f2:b3:b4:12:4b:e4:27:41:6f:e1 -# SHA1 Fingerprint: a7:88:49:dc:5d:7c:75:8c:8c:de:39:98:56:b3:aa:d0:b2:a5:71:35 -# SHA256 Fingerprint: 37:1a:00:dc:05:33:b3:72:1a:7e:eb:40:e8:41:9e:70:79:9d:2b:0a:0f:2c:1d:80:69:31:65:f7:ce:c4:ad:75 ------BEGIN CERTIFICATE----- -MIIFZjCCA06gAwIBAgIQCPm0eKj6ftpqMzeJ3nzPijANBgkqhkiG9w0BAQwFADBN -MQswCQYDVQQGEwJVUzEXMBUGA1UEChMORGlnaUNlcnQsIEluYy4xJTAjBgNVBAMT -HERpZ2lDZXJ0IFRMUyBSU0E0MDk2IFJvb3QgRzUwHhcNMjEwMTE1MDAwMDAwWhcN -NDYwMTE0MjM1OTU5WjBNMQswCQYDVQQGEwJVUzEXMBUGA1UEChMORGlnaUNlcnQs -IEluYy4xJTAjBgNVBAMTHERpZ2lDZXJ0IFRMUyBSU0E0MDk2IFJvb3QgRzUwggIi -MA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQCz0PTJeRGd/fxmgefM1eS87IE+ -ajWOLrfn3q/5B03PMJ3qCQuZvWxX2hhKuHisOjmopkisLnLlvevxGs3npAOpPxG0 -2C+JFvuUAT27L/gTBaF4HI4o4EXgg/RZG5Wzrn4DReW+wkL+7vI8toUTmDKdFqgp -wgscONyfMXdcvyej/Cestyu9dJsXLfKB2l2w4SMXPohKEiPQ6s+d3gMXsUJKoBZM -pG2T6T867jp8nVid9E6P/DsjyG244gXazOvswzH016cpVIDPRFtMbzCe88zdH5RD -nU1/cHAN1DrRN/BsnZvAFJNY781BOHW8EwOVfH/jXOnVDdXifBBiqmvwPXbzP6Po -sMH976pXTayGpxi0KcEsDr9kvimM2AItzVwv8n/vFfQMFawKsPHTDU9qTXeXAaDx -Zre3zu/O7Oyldcqs4+Fj97ihBMi8ez9dLRYiVu1ISf6nL3kwJZu6ay0/nTvEF+cd -Lvvyz6b84xQslpghjLSR6Rlgg/IwKwZzUNWYOwbpx4oMYIwo+FKbbuH2TbsGJJvX -KyY//SovcfXWJL5/MZ4PbeiPT02jP/816t9JXkGPhvnxd3lLG7SjXi/7RgLQZhNe -XoVPzthwiHvOAbWWl9fNff2C+MIkwcoBOU+NosEUQB+cZtUMCUbW8tDRSHZWOkPL -tgoRObqME2wGtZ7P6wIDAQABo0IwQDAdBgNVHQ4EFgQUUTMc7TZArxfTJc1paPKv -TiM+s0EwDgYDVR0PAQH/BAQDAgGGMA8GA1UdEwEB/wQFMAMBAf8wDQYJKoZIhvcN -AQEMBQADggIBAGCmr1tfV9qJ20tQqcQjNSH/0GEwhJG3PxDPJY7Jv0Y02cEhJhxw -GXIeo8mH/qlDZJY6yFMECrZBu8RHANmfGBg7sg7zNOok992vIGCukihfNudd5N7H -PNtQOa27PShNlnx2xlv0wdsUpasZYgcYQF+Xkdycx6u1UQ3maVNVzDl92sURVXLF -O4uJ+DQtpBflF+aZfTCIITfNMBc9uPK8qHWgQ9w+iUuQrm0D4ByjoJYJu32jtyoQ -REtGBzRj7TG5BO6jm5qu5jF49OokYTurWGT/u4cnYiWB39yhL/btp/96j1EuMPik -AdKFOV8BmZZvWltwGUb+hmA+rYAQCd05JS9Yf7vSdPD3Rh9GOUrYU9DzLjtxpdRv -/PNn5AeP3SYZ4Y1b+qOTEZvpyDrDVWiakuFSdjjo4bq9+0/V77PnSIMx8IIh47a+ -p6tv75/fTM8BuGJqIz3nCU2AG3swpMPdB380vqQmsvZB6Akd4yCYqjdP//fx4ilw -MUc/dNAUFvohigLVigmUdy7yWSiLfFCSCmZ4OIN1xLVaqBHG5cGdZlXPU8Sv13WF -qUITVuwhd4GTWgzqltlJyqEI8pc7bZsEGCREjnwB8twl2F6GmrE52/WRMmrRpnCK -ovfepEWFJqgejF0pW8hL2JpqA15w8oVPbEtoL8pU9ozaMv7Da4M/OMZ+ ------END CERTIFICATE----- - -# Issuer: CN=Certainly Root R1 O=Certainly -# Subject: CN=Certainly Root R1 O=Certainly -# Label: "Certainly Root R1" -# Serial: 188833316161142517227353805653483829216 -# MD5 Fingerprint: 07:70:d4:3e:82:87:a0:fa:33:36:13:f4:fa:33:e7:12 -# SHA1 Fingerprint: a0:50:ee:0f:28:71:f4:27:b2:12:6d:6f:50:96:25:ba:cc:86:42:af -# SHA256 Fingerprint: 77:b8:2c:d8:64:4c:43:05:f7:ac:c5:cb:15:6b:45:67:50:04:03:3d:51:c6:0c:62:02:a8:e0:c3:34:67:d3:a0 ------BEGIN CERTIFICATE----- -MIIFRzCCAy+gAwIBAgIRAI4P+UuQcWhlM1T01EQ5t+AwDQYJKoZIhvcNAQELBQAw -PTELMAkGA1UEBhMCVVMxEjAQBgNVBAoTCUNlcnRhaW5seTEaMBgGA1UEAxMRQ2Vy -dGFpbmx5IFJvb3QgUjEwHhcNMjEwNDAxMDAwMDAwWhcNNDYwNDAxMDAwMDAwWjA9 -MQswCQYDVQQGEwJVUzESMBAGA1UEChMJQ2VydGFpbmx5MRowGAYDVQQDExFDZXJ0 -YWlubHkgUm9vdCBSMTCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBANA2 -1B/q3avk0bbm+yLA3RMNansiExyXPGhjZjKcA7WNpIGD2ngwEc/csiu+kr+O5MQT -vqRoTNoCaBZ0vrLdBORrKt03H2As2/X3oXyVtwxwhi7xOu9S98zTm/mLvg7fMbed -aFySpvXl8wo0tf97ouSHocavFwDvA5HtqRxOcT3Si2yJ9HiG5mpJoM610rCrm/b0 -1C7jcvk2xusVtyWMOvwlDbMicyF0yEqWYZL1LwsYpfSt4u5BvQF5+paMjRcCMLT5 -r3gajLQ2EBAHBXDQ9DGQilHFhiZ5shGIXsXwClTNSaa/ApzSRKft43jvRl5tcdF5 -cBxGX1HpyTfcX35pe0HfNEXgO4T0oYoKNp43zGJS4YkNKPl6I7ENPT2a/Z2B7yyQ -wHtETrtJ4A5KVpK8y7XdeReJkd5hiXSSqOMyhb5OhaRLWcsrxXiOcVTQAjeZjOVJ -6uBUcqQRBi8LjMFbvrWhsFNunLhgkR9Za/kt9JQKl7XsxXYDVBtlUrpMklZRNaBA -2CnbrlJ2Oy0wQJuK0EJWtLeIAaSHO1OWzaMWj/Nmqhexx2DgwUMFDO6bW2BvBlyH -Wyf5QBGenDPBt+U1VwV/J84XIIwc/PH72jEpSe31C4SnT8H2TsIonPru4K8H+zMR -eiFPCyEQtkA6qyI6BJyLm4SGcprSp6XEtHWRqSsjAgMBAAGjQjBAMA4GA1UdDwEB -/wQEAwIBBjAPBgNVHRMBAf8EBTADAQH/MB0GA1UdDgQWBBTgqj8ljZ9EXME66C6u -d0yEPmcM9DANBgkqhkiG9w0BAQsFAAOCAgEAuVevuBLaV4OPaAszHQNTVfSVcOQr -PbA56/qJYv331hgELyE03fFo8NWWWt7CgKPBjcZq91l3rhVkz1t5BXdm6ozTaw3d -8VkswTOlMIAVRQdFGjEitpIAq5lNOo93r6kiyi9jyhXWx8bwPWz8HA2YEGGeEaIi -1wrykXprOQ4vMMM2SZ/g6Q8CRFA3lFV96p/2O7qUpUzpvD5RtOjKkjZUbVwlKNrd -rRT90+7iIgXr0PK3aBLXWopBGsaSpVo7Y0VPv+E6dyIvXL9G+VoDhRNCX8reU9di -taY1BMJH/5n9hN9czulegChB8n3nHpDYT3Y+gjwN/KUD+nsa2UUeYNrEjvn8K8l7 -lcUq/6qJ34IxD3L/DCfXCh5WAFAeDJDBlrXYFIW7pw0WwfgHJBu6haEaBQmAupVj -yTrsJZ9/nbqkRxWbRHDxakvWOF5D8xh+UG7pWijmZeZ3Gzr9Hb4DJqPb1OG7fpYn -Kx3upPvaJVQTA945xsMfTZDsjxtK0hzthZU4UHlG1sGQUDGpXJpuHfUzVounmdLy -yCwzk5Iwx06MZTMQZBf9JBeW0Y3COmor6xOLRPIh80oat3df1+2IpHLlOR+Vnb5n -wXARPbv0+Em34yaXOp/SX3z7wJl8OSngex2/DaeP0ik0biQVy96QXr8axGbqwua6 -OV+KmalBWQewLK8= ------END CERTIFICATE----- - -# Issuer: CN=Certainly Root E1 O=Certainly -# Subject: CN=Certainly Root E1 O=Certainly -# Label: "Certainly Root E1" -# Serial: 8168531406727139161245376702891150584 -# MD5 Fingerprint: 0a:9e:ca:cd:3e:52:50:c6:36:f3:4b:a3:ed:a7:53:e9 -# SHA1 Fingerprint: f9:e1:6d:dc:01:89:cf:d5:82:45:63:3e:c5:37:7d:c2:eb:93:6f:2b -# SHA256 Fingerprint: b4:58:5f:22:e4:ac:75:6a:4e:86:12:a1:36:1c:5d:9d:03:1a:93:fd:84:fe:bb:77:8f:a3:06:8b:0f:c4:2d:c2 ------BEGIN CERTIFICATE----- -MIIB9zCCAX2gAwIBAgIQBiUzsUcDMydc+Y2aub/M+DAKBggqhkjOPQQDAzA9MQsw -CQYDVQQGEwJVUzESMBAGA1UEChMJQ2VydGFpbmx5MRowGAYDVQQDExFDZXJ0YWlu -bHkgUm9vdCBFMTAeFw0yMTA0MDEwMDAwMDBaFw00NjA0MDEwMDAwMDBaMD0xCzAJ -BgNVBAYTAlVTMRIwEAYDVQQKEwlDZXJ0YWlubHkxGjAYBgNVBAMTEUNlcnRhaW5s -eSBSb290IEUxMHYwEAYHKoZIzj0CAQYFK4EEACIDYgAE3m/4fxzf7flHh4axpMCK -+IKXgOqPyEpeKn2IaKcBYhSRJHpcnqMXfYqGITQYUBsQ3tA3SybHGWCA6TS9YBk2 -QNYphwk8kXr2vBMj3VlOBF7PyAIcGFPBMdjaIOlEjeR2o0IwQDAOBgNVHQ8BAf8E -BAMCAQYwDwYDVR0TAQH/BAUwAwEB/zAdBgNVHQ4EFgQU8ygYy2R17ikq6+2uI1g4 -hevIIgcwCgYIKoZIzj0EAwMDaAAwZQIxALGOWiDDshliTd6wT99u0nCK8Z9+aozm -ut6Dacpps6kFtZaSF4fC0urQe87YQVt8rgIwRt7qy12a7DLCZRawTDBcMPPaTnOG -BtjOiQRINzf43TNRnXCve1XYAS59BWQOhriR ------END CERTIFICATE----- - -# Issuer: CN=Security Communication ECC RootCA1 O=SECOM Trust Systems CO.,LTD. -# Subject: CN=Security Communication ECC RootCA1 O=SECOM Trust Systems CO.,LTD. -# Label: "Security Communication ECC RootCA1" -# Serial: 15446673492073852651 -# MD5 Fingerprint: 7e:43:b0:92:68:ec:05:43:4c:98:ab:5d:35:2e:7e:86 -# SHA1 Fingerprint: b8:0e:26:a9:bf:d2:b2:3b:c0:ef:46:c9:ba:c7:bb:f6:1d:0d:41:41 -# SHA256 Fingerprint: e7:4f:bd:a5:5b:d5:64:c4:73:a3:6b:44:1a:a7:99:c8:a6:8e:07:74:40:e8:28:8b:9f:a1:e5:0e:4b:ba:ca:11 ------BEGIN CERTIFICATE----- -MIICODCCAb6gAwIBAgIJANZdm7N4gS7rMAoGCCqGSM49BAMDMGExCzAJBgNVBAYT -AkpQMSUwIwYDVQQKExxTRUNPTSBUcnVzdCBTeXN0ZW1zIENPLixMVEQuMSswKQYD -VQQDEyJTZWN1cml0eSBDb21tdW5pY2F0aW9uIEVDQyBSb290Q0ExMB4XDTE2MDYx -NjA1MTUyOFoXDTM4MDExODA1MTUyOFowYTELMAkGA1UEBhMCSlAxJTAjBgNVBAoT -HFNFQ09NIFRydXN0IFN5c3RlbXMgQ08uLExURC4xKzApBgNVBAMTIlNlY3VyaXR5 -IENvbW11bmljYXRpb24gRUNDIFJvb3RDQTEwdjAQBgcqhkjOPQIBBgUrgQQAIgNi -AASkpW9gAwPDvTH00xecK4R1rOX9PVdu12O/5gSJko6BnOPpR27KkBLIE+Cnnfdl -dB9sELLo5OnvbYUymUSxXv3MdhDYW72ixvnWQuRXdtyQwjWpS4g8EkdtXP9JTxpK -ULGjQjBAMB0GA1UdDgQWBBSGHOf+LaVKiwj+KBH6vqNm+GBZLzAOBgNVHQ8BAf8E -BAMCAQYwDwYDVR0TAQH/BAUwAwEB/zAKBggqhkjOPQQDAwNoADBlAjAVXUI9/Lbu -9zuxNuie9sRGKEkz0FhDKmMpzE2xtHqiuQ04pV1IKv3LsnNdo4gIxwwCMQDAqy0O -be0YottT6SXbVQjgUMzfRGEWgqtJsLKB7HOHeLRMsmIbEvoWTSVLY70eN9k= ------END CERTIFICATE----- - -# Issuer: CN=BJCA Global Root CA1 O=BEIJING CERTIFICATE AUTHORITY -# Subject: CN=BJCA Global Root CA1 O=BEIJING CERTIFICATE AUTHORITY -# Label: "BJCA Global Root CA1" -# Serial: 113562791157148395269083148143378328608 -# MD5 Fingerprint: 42:32:99:76:43:33:36:24:35:07:82:9b:28:f9:d0:90 -# SHA1 Fingerprint: d5:ec:8d:7b:4c:ba:79:f4:e7:e8:cb:9d:6b:ae:77:83:10:03:21:6a -# SHA256 Fingerprint: f3:89:6f:88:fe:7c:0a:88:27:66:a7:fa:6a:d2:74:9f:b5:7a:7f:3e:98:fb:76:9c:1f:a7:b0:9c:2c:44:d5:ae ------BEGIN CERTIFICATE----- -MIIFdDCCA1ygAwIBAgIQVW9l47TZkGobCdFsPsBsIDANBgkqhkiG9w0BAQsFADBU -MQswCQYDVQQGEwJDTjEmMCQGA1UECgwdQkVJSklORyBDRVJUSUZJQ0FURSBBVVRI -T1JJVFkxHTAbBgNVBAMMFEJKQ0EgR2xvYmFsIFJvb3QgQ0ExMB4XDTE5MTIxOTAz -MTYxN1oXDTQ0MTIxMjAzMTYxN1owVDELMAkGA1UEBhMCQ04xJjAkBgNVBAoMHUJF -SUpJTkcgQ0VSVElGSUNBVEUgQVVUSE9SSVRZMR0wGwYDVQQDDBRCSkNBIEdsb2Jh -bCBSb290IENBMTCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAPFmCL3Z -xRVhy4QEQaVpN3cdwbB7+sN3SJATcmTRuHyQNZ0YeYjjlwE8R4HyDqKYDZ4/N+AZ -spDyRhySsTphzvq3Rp4Dhtczbu33RYx2N95ulpH3134rhxfVizXuhJFyV9xgw8O5 -58dnJCNPYwpj9mZ9S1WnP3hkSWkSl+BMDdMJoDIwOvqfwPKcxRIqLhy1BDPapDgR -at7GGPZHOiJBhyL8xIkoVNiMpTAK+BcWyqw3/XmnkRd4OJmtWO2y3syJfQOcs4ll -5+M7sSKGjwZteAf9kRJ/sGsciQ35uMt0WwfCyPQ10WRjeulumijWML3mG90Vr4Tq -nMfK9Q7q8l0ph49pczm+LiRvRSGsxdRpJQaDrXpIhRMsDQa4bHlW/KNnMoH1V6XK -V0Jp6VwkYe/iMBhORJhVb3rCk9gZtt58R4oRTklH2yiUAguUSiz5EtBP6DF+bHq/ -pj+bOT0CFqMYs2esWz8sgytnOYFcuX6U1WTdno9uruh8W7TXakdI136z1C2OVnZO -z2nxbkRs1CTqjSShGL+9V/6pmTW12xB3uD1IutbB5/EjPtffhZ0nPNRAvQoMvfXn -jSXWgXSHRtQpdaJCbPdzied9v3pKH9MiyRVVz99vfFXQpIsHETdfg6YmV6YBW37+ -WGgHqel62bno/1Afq8K0wM7o6v0PvY1NuLxxAgMBAAGjQjBAMB0GA1UdDgQWBBTF -7+3M2I0hxkjk49cULqcWk+WYATAPBgNVHRMBAf8EBTADAQH/MA4GA1UdDwEB/wQE -AwIBBjANBgkqhkiG9w0BAQsFAAOCAgEAUoKsITQfI/Ki2Pm4rzc2IInRNwPWaZ+4 -YRC6ojGYWUfo0Q0lHhVBDOAqVdVXUsv45Mdpox1NcQJeXyFFYEhcCY5JEMEE3Kli -awLwQ8hOnThJdMkycFRtwUf8jrQ2ntScvd0g1lPJGKm1Vrl2i5VnZu69mP6u775u -+2D2/VnGKhs/I0qUJDAnyIm860Qkmss9vk/Ves6OF8tiwdneHg56/0OGNFK8YT88 -X7vZdrRTvJez/opMEi4r89fO4aL/3Xtw+zuhTaRjAv04l5U/BXCga99igUOLtFkN -SoxUnMW7gZ/NfaXvCyUeOiDbHPwfmGcCCtRzRBPbUYQaVQNW4AB+dAb/OMRyHdOo -P2gxXdMJxy6MW2Pg6Nwe0uxhHvLe5e/2mXZgLR6UcnHGCyoyx5JO1UbXHfmpGQrI -+pXObSOYqgs4rZpWDW+N8TEAiMEXnM0ZNjX+VVOg4DwzX5Ze4jLp3zO7Bkqp2IRz -znfSxqxx4VyjHQy7Ct9f4qNx2No3WqB4K/TUfet27fJhcKVlmtOJNBir+3I+17Q9 -eVzYH6Eze9mCUAyTF6ps3MKCuwJXNq+YJyo5UOGwifUll35HaBC07HPKs5fRJNz2 -YqAo07WjuGS3iGJCz51TzZm+ZGiPTx4SSPfSKcOYKMryMguTjClPPGAyzQWWYezy -r/6zcCwupvI= ------END CERTIFICATE----- - -# Issuer: CN=BJCA Global Root CA2 O=BEIJING CERTIFICATE AUTHORITY -# Subject: CN=BJCA Global Root CA2 O=BEIJING CERTIFICATE AUTHORITY -# Label: "BJCA Global Root CA2" -# Serial: 58605626836079930195615843123109055211 -# MD5 Fingerprint: 5e:0a:f6:47:5f:a6:14:e8:11:01:95:3f:4d:01:eb:3c -# SHA1 Fingerprint: f4:27:86:eb:6e:b8:6d:88:31:67:02:fb:ba:66:a4:53:00:aa:7a:a6 -# SHA256 Fingerprint: 57:4d:f6:93:1e:27:80:39:66:7b:72:0a:fd:c1:60:0f:c2:7e:b6:6d:d3:09:29:79:fb:73:85:64:87:21:28:82 ------BEGIN CERTIFICATE----- -MIICJTCCAaugAwIBAgIQLBcIfWQqwP6FGFkGz7RK6zAKBggqhkjOPQQDAzBUMQsw -CQYDVQQGEwJDTjEmMCQGA1UECgwdQkVJSklORyBDRVJUSUZJQ0FURSBBVVRIT1JJ -VFkxHTAbBgNVBAMMFEJKQ0EgR2xvYmFsIFJvb3QgQ0EyMB4XDTE5MTIxOTAzMTgy -MVoXDTQ0MTIxMjAzMTgyMVowVDELMAkGA1UEBhMCQ04xJjAkBgNVBAoMHUJFSUpJ -TkcgQ0VSVElGSUNBVEUgQVVUSE9SSVRZMR0wGwYDVQQDDBRCSkNBIEdsb2JhbCBS -b290IENBMjB2MBAGByqGSM49AgEGBSuBBAAiA2IABJ3LgJGNU2e1uVCxA/jlSR9B -IgmwUVJY1is0j8USRhTFiy8shP8sbqjV8QnjAyEUxEM9fMEsxEtqSs3ph+B99iK+ -+kpRuDCK/eHeGBIK9ke35xe/J4rUQUyWPGCWwf0VHKNCMEAwHQYDVR0OBBYEFNJK -sVF/BvDRgh9Obl+rg/xI1LCRMA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQD -AgEGMAoGCCqGSM49BAMDA2gAMGUCMBq8W9f+qdJUDkpd0m2xQNz0Q9XSSpkZElaA -94M04TVOSG0ED1cxMDAtsaqdAzjbBgIxAMvMh1PLet8gUXOQwKhbYdDFUDn9hf7B -43j4ptZLvZuHjw/l1lOWqzzIQNph91Oj9w== ------END CERTIFICATE----- - -# Issuer: CN=Sectigo Public Server Authentication Root E46 O=Sectigo Limited -# Subject: CN=Sectigo Public Server Authentication Root E46 O=Sectigo Limited -# Label: "Sectigo Public Server Authentication Root E46" -# Serial: 88989738453351742415770396670917916916 -# MD5 Fingerprint: 28:23:f8:b2:98:5c:37:16:3b:3e:46:13:4e:b0:b3:01 -# SHA1 Fingerprint: ec:8a:39:6c:40:f0:2e:bc:42:75:d4:9f:ab:1c:1a:5b:67:be:d2:9a -# SHA256 Fingerprint: c9:0f:26:f0:fb:1b:40:18:b2:22:27:51:9b:5c:a2:b5:3e:2c:a5:b3:be:5c:f1:8e:fe:1b:ef:47:38:0c:53:83 ------BEGIN CERTIFICATE----- -MIICOjCCAcGgAwIBAgIQQvLM2htpN0RfFf51KBC49DAKBggqhkjOPQQDAzBfMQsw -CQYDVQQGEwJHQjEYMBYGA1UEChMPU2VjdGlnbyBMaW1pdGVkMTYwNAYDVQQDEy1T -ZWN0aWdvIFB1YmxpYyBTZXJ2ZXIgQXV0aGVudGljYXRpb24gUm9vdCBFNDYwHhcN -MjEwMzIyMDAwMDAwWhcNNDYwMzIxMjM1OTU5WjBfMQswCQYDVQQGEwJHQjEYMBYG -A1UEChMPU2VjdGlnbyBMaW1pdGVkMTYwNAYDVQQDEy1TZWN0aWdvIFB1YmxpYyBT -ZXJ2ZXIgQXV0aGVudGljYXRpb24gUm9vdCBFNDYwdjAQBgcqhkjOPQIBBgUrgQQA -IgNiAAR2+pmpbiDt+dd34wc7qNs9Xzjoq1WmVk/WSOrsfy2qw7LFeeyZYX8QeccC -WvkEN/U0NSt3zn8gj1KjAIns1aeibVvjS5KToID1AZTc8GgHHs3u/iVStSBDHBv+ -6xnOQ6OjQjBAMB0GA1UdDgQWBBTRItpMWfFLXyY4qp3W7usNw/upYTAOBgNVHQ8B -Af8EBAMCAYYwDwYDVR0TAQH/BAUwAwEB/zAKBggqhkjOPQQDAwNnADBkAjAn7qRa -qCG76UeXlImldCBteU/IvZNeWBj7LRoAasm4PdCkT0RHlAFWovgzJQxC36oCMB3q -4S6ILuH5px0CMk7yn2xVdOOurvulGu7t0vzCAxHrRVxgED1cf5kDW21USAGKcw== ------END CERTIFICATE----- - -# Issuer: CN=Sectigo Public Server Authentication Root R46 O=Sectigo Limited -# Subject: CN=Sectigo Public Server Authentication Root R46 O=Sectigo Limited -# Label: "Sectigo Public Server Authentication Root R46" -# Serial: 156256931880233212765902055439220583700 -# MD5 Fingerprint: 32:10:09:52:00:d5:7e:6c:43:df:15:c0:b1:16:93:e5 -# SHA1 Fingerprint: ad:98:f9:f3:e4:7d:75:3b:65:d4:82:b3:a4:52:17:bb:6e:f5:e4:38 -# SHA256 Fingerprint: 7b:b6:47:a6:2a:ee:ac:88:bf:25:7a:a5:22:d0:1f:fe:a3:95:e0:ab:45:c7:3f:93:f6:56:54:ec:38:f2:5a:06 ------BEGIN CERTIFICATE----- -MIIFijCCA3KgAwIBAgIQdY39i658BwD6qSWn4cetFDANBgkqhkiG9w0BAQwFADBf -MQswCQYDVQQGEwJHQjEYMBYGA1UEChMPU2VjdGlnbyBMaW1pdGVkMTYwNAYDVQQD -Ey1TZWN0aWdvIFB1YmxpYyBTZXJ2ZXIgQXV0aGVudGljYXRpb24gUm9vdCBSNDYw -HhcNMjEwMzIyMDAwMDAwWhcNNDYwMzIxMjM1OTU5WjBfMQswCQYDVQQGEwJHQjEY -MBYGA1UEChMPU2VjdGlnbyBMaW1pdGVkMTYwNAYDVQQDEy1TZWN0aWdvIFB1Ymxp -YyBTZXJ2ZXIgQXV0aGVudGljYXRpb24gUm9vdCBSNDYwggIiMA0GCSqGSIb3DQEB -AQUAA4ICDwAwggIKAoICAQCTvtU2UnXYASOgHEdCSe5jtrch/cSV1UgrJnwUUxDa -ef0rty2k1Cz66jLdScK5vQ9IPXtamFSvnl0xdE8H/FAh3aTPaE8bEmNtJZlMKpnz -SDBh+oF8HqcIStw+KxwfGExxqjWMrfhu6DtK2eWUAtaJhBOqbchPM8xQljeSM9xf -iOefVNlI8JhD1mb9nxc4Q8UBUQvX4yMPFF1bFOdLvt30yNoDN9HWOaEhUTCDsG3X -ME6WW5HwcCSrv0WBZEMNvSE6Lzzpng3LILVCJ8zab5vuZDCQOc2TZYEhMbUjUDM3 -IuM47fgxMMxF/mL50V0yeUKH32rMVhlATc6qu/m1dkmU8Sf4kaWD5QazYw6A3OAS -VYCmO2a0OYctyPDQ0RTp5A1NDvZdV3LFOxxHVp3i1fuBYYzMTYCQNFu31xR13NgE -SJ/AwSiItOkcyqex8Va3e0lMWeUgFaiEAin6OJRpmkkGj80feRQXEgyDet4fsZfu -+Zd4KKTIRJLpfSYFplhym3kT2BFfrsU4YjRosoYwjviQYZ4ybPUHNs2iTG7sijbt -8uaZFURww3y8nDnAtOFr94MlI1fZEoDlSfB1D++N6xybVCi0ITz8fAr/73trdf+L -HaAZBav6+CuBQug4urv7qv094PPK306Xlynt8xhW6aWWrL3DkJiy4Pmi1KZHQ3xt -zwIDAQABo0IwQDAdBgNVHQ4EFgQUVnNYZJX5khqwEioEYnmhQBWIIUkwDgYDVR0P -AQH/BAQDAgGGMA8GA1UdEwEB/wQFMAMBAf8wDQYJKoZIhvcNAQEMBQADggIBAC9c -mTz8Bl6MlC5w6tIyMY208FHVvArzZJ8HXtXBc2hkeqK5Duj5XYUtqDdFqij0lgVQ -YKlJfp/imTYpE0RHap1VIDzYm/EDMrraQKFz6oOht0SmDpkBm+S8f74TlH7Kph52 -gDY9hAaLMyZlbcp+nv4fjFg4exqDsQ+8FxG75gbMY/qB8oFM2gsQa6H61SilzwZA -Fv97fRheORKkU55+MkIQpiGRqRxOF3yEvJ+M0ejf5lG5Nkc/kLnHvALcWxxPDkjB -JYOcCj+esQMzEhonrPcibCTRAUH4WAP+JWgiH5paPHxsnnVI84HxZmduTILA7rpX -DhjvLpr3Etiga+kFpaHpaPi8TD8SHkXoUsCjvxInebnMMTzD9joiFgOgyY9mpFui -TdaBJQbpdqQACj7LzTWb4OE4y2BThihCQRxEV+ioratF4yUQvNs+ZUH7G6aXD+u5 -dHn5HrwdVw1Hr8Mvn4dGp+smWg9WY7ViYG4A++MnESLn/pmPNPW56MORcr3Ywx65 -LvKRRFHQV80MNNVIIb/bE/FmJUNS0nAiNs2fxBx1IK1jcmMGDw4nztJqDby1ORrp -0XZ60Vzk50lJLVU3aPAaOpg+VBeHVOmmJ1CJeyAvP/+/oYtKR5j/K3tJPsMpRmAY -QqszKbrAKbkTidOIijlBO8n9pu0f9GBj39ItVQGL ------END CERTIFICATE----- - -# Issuer: CN=SSL.com TLS RSA Root CA 2022 O=SSL Corporation -# Subject: CN=SSL.com TLS RSA Root CA 2022 O=SSL Corporation -# Label: "SSL.com TLS RSA Root CA 2022" -# Serial: 148535279242832292258835760425842727825 -# MD5 Fingerprint: d8:4e:c6:59:30:d8:fe:a0:d6:7a:5a:2c:2c:69:78:da -# SHA1 Fingerprint: ec:2c:83:40:72:af:26:95:10:ff:0e:f2:03:ee:31:70:f6:78:9d:ca -# SHA256 Fingerprint: 8f:af:7d:2e:2c:b4:70:9b:b8:e0:b3:36:66:bf:75:a5:dd:45:b5:de:48:0f:8e:a8:d4:bf:e6:be:bc:17:f2:ed ------BEGIN CERTIFICATE----- -MIIFiTCCA3GgAwIBAgIQb77arXO9CEDii02+1PdbkTANBgkqhkiG9w0BAQsFADBO -MQswCQYDVQQGEwJVUzEYMBYGA1UECgwPU1NMIENvcnBvcmF0aW9uMSUwIwYDVQQD -DBxTU0wuY29tIFRMUyBSU0EgUm9vdCBDQSAyMDIyMB4XDTIyMDgyNTE2MzQyMloX -DTQ2MDgxOTE2MzQyMVowTjELMAkGA1UEBhMCVVMxGDAWBgNVBAoMD1NTTCBDb3Jw -b3JhdGlvbjElMCMGA1UEAwwcU1NMLmNvbSBUTFMgUlNBIFJvb3QgQ0EgMjAyMjCC -AiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBANCkCXJPQIgSYT41I57u9nTP -L3tYPc48DRAokC+X94xI2KDYJbFMsBFMF3NQ0CJKY7uB0ylu1bUJPiYYf7ISf5OY -t6/wNr/y7hienDtSxUcZXXTzZGbVXcdotL8bHAajvI9AI7YexoS9UcQbOcGV0ins -S657Lb85/bRi3pZ7QcacoOAGcvvwB5cJOYF0r/c0WRFXCsJbwST0MXMwgsadugL3 -PnxEX4MN8/HdIGkWCVDi1FW24IBydm5MR7d1VVm0U3TZlMZBrViKMWYPHqIbKUBO -L9975hYsLfy/7PO0+r4Y9ptJ1O4Fbtk085zx7AGL0SDGD6C1vBdOSHtRwvzpXGk3 -R2azaPgVKPC506QVzFpPulJwoxJF3ca6TvvC0PeoUidtbnm1jPx7jMEWTO6Af77w -dr5BUxIzrlo4QqvXDz5BjXYHMtWrifZOZ9mxQnUjbvPNQrL8VfVThxc7wDNY8VLS -+YCk8OjwO4s4zKTGkH8PnP2L0aPP2oOnaclQNtVcBdIKQXTbYxE3waWglksejBYS -d66UNHsef8JmAOSqg+qKkK3ONkRN0VHpvB/zagX9wHQfJRlAUW7qglFA35u5CCoG -AtUjHBPW6dvbxrB6y3snm/vg1UYk7RBLY0ulBY+6uB0rpvqR4pJSvezrZ5dtmi2f -gTIFZzL7SAg/2SW4BCUvAgMBAAGjYzBhMA8GA1UdEwEB/wQFMAMBAf8wHwYDVR0j -BBgwFoAU+y437uOEeicuzRk1sTN8/9REQrkwHQYDVR0OBBYEFPsuN+7jhHonLs0Z -NbEzfP/UREK5MA4GA1UdDwEB/wQEAwIBhjANBgkqhkiG9w0BAQsFAAOCAgEAjYlt -hEUY8U+zoO9opMAdrDC8Z2awms22qyIZZtM7QbUQnRC6cm4pJCAcAZli05bg4vsM -QtfhWsSWTVTNj8pDU/0quOr4ZcoBwq1gaAafORpR2eCNJvkLTqVTJXojpBzOCBvf -R4iyrT7gJ4eLSYwfqUdYe5byiB0YrrPRpgqU+tvT5TgKa3kSM/tKWTcWQA673vWJ -DPFs0/dRa1419dvAJuoSc06pkZCmF8NsLzjUo3KUQyxi4U5cMj29TH0ZR6LDSeeW -P4+a0zvkEdiLA9z2tmBVGKaBUfPhqBVq6+AL8BQx1rmMRTqoENjwuSfr98t67wVy -lrXEj5ZzxOhWc5y8aVFjvO9nHEMaX3cZHxj4HCUp+UmZKbaSPaKDN7EgkaibMOlq -bLQjk2UEqxHzDh1TJElTHaE/nUiSEeJ9DU/1172iWD54nR4fK/4huxoTtrEoZP2w -AgDHbICivRZQIA9ygV/MlP+7mea6kMvq+cYMwq7FGc4zoWtcu358NFcXrfA/rs3q -r5nsLFR+jM4uElZI7xc7P0peYNLcdDa8pUNjyw9bowJWCZ4kLOGGgYz+qxcs+sji -Mho6/4UIyYOf8kpIEFR3N+2ivEC+5BB09+Rbu7nzifmPQdjH5FCQNYA+HLhNkNPU -98OwoX6EyneSMSy4kLGCenROmxMmtNVQZlR4rmA= ------END CERTIFICATE----- - -# Issuer: CN=SSL.com TLS ECC Root CA 2022 O=SSL Corporation -# Subject: CN=SSL.com TLS ECC Root CA 2022 O=SSL Corporation -# Label: "SSL.com TLS ECC Root CA 2022" -# Serial: 26605119622390491762507526719404364228 -# MD5 Fingerprint: 99:d7:5c:f1:51:36:cc:e9:ce:d9:19:2e:77:71:56:c5 -# SHA1 Fingerprint: 9f:5f:d9:1a:54:6d:f5:0c:71:f0:ee:7a:bd:17:49:98:84:73:e2:39 -# SHA256 Fingerprint: c3:2f:fd:9f:46:f9:36:d1:6c:36:73:99:09:59:43:4b:9a:d6:0a:af:bb:9e:7c:f3:36:54:f1:44:cc:1b:a1:43 ------BEGIN CERTIFICATE----- -MIICOjCCAcCgAwIBAgIQFAP1q/s3ixdAW+JDsqXRxDAKBggqhkjOPQQDAzBOMQsw -CQYDVQQGEwJVUzEYMBYGA1UECgwPU1NMIENvcnBvcmF0aW9uMSUwIwYDVQQDDBxT -U0wuY29tIFRMUyBFQ0MgUm9vdCBDQSAyMDIyMB4XDTIyMDgyNTE2MzM0OFoXDTQ2 -MDgxOTE2MzM0N1owTjELMAkGA1UEBhMCVVMxGDAWBgNVBAoMD1NTTCBDb3Jwb3Jh -dGlvbjElMCMGA1UEAwwcU1NMLmNvbSBUTFMgRUNDIFJvb3QgQ0EgMjAyMjB2MBAG -ByqGSM49AgEGBSuBBAAiA2IABEUpNXP6wrgjzhR9qLFNoFs27iosU8NgCTWyJGYm -acCzldZdkkAZDsalE3D07xJRKF3nzL35PIXBz5SQySvOkkJYWWf9lCcQZIxPBLFN -SeR7T5v15wj4A4j3p8OSSxlUgaNjMGEwDwYDVR0TAQH/BAUwAwEB/zAfBgNVHSME -GDAWgBSJjy+j6CugFFR781a4Jl9nOAuc0DAdBgNVHQ4EFgQUiY8vo+groBRUe/NW -uCZfZzgLnNAwDgYDVR0PAQH/BAQDAgGGMAoGCCqGSM49BAMDA2gAMGUCMFXjIlbp -15IkWE8elDIPDAI2wv2sdDJO4fscgIijzPvX6yv/N33w7deedWo1dlJF4AIxAMeN -b0Igj762TVntd00pxCAgRWSGOlDGxK0tk/UYfXLtqc/ErFc2KAhl3zx5Zn6g6g== ------END CERTIFICATE----- - -# Issuer: CN=Atos TrustedRoot Root CA ECC TLS 2021 O=Atos -# Subject: CN=Atos TrustedRoot Root CA ECC TLS 2021 O=Atos -# Label: "Atos TrustedRoot Root CA ECC TLS 2021" -# Serial: 81873346711060652204712539181482831616 -# MD5 Fingerprint: 16:9f:ad:f1:70:ad:79:d6:ed:29:b4:d1:c5:79:70:a8 -# SHA1 Fingerprint: 9e:bc:75:10:42:b3:02:f3:81:f4:f7:30:62:d4:8f:c3:a7:51:b2:dd -# SHA256 Fingerprint: b2:fa:e5:3e:14:cc:d7:ab:92:12:06:47:01:ae:27:9c:1d:89:88:fa:cb:77:5f:a8:a0:08:91:4e:66:39:88:a8 ------BEGIN CERTIFICATE----- -MIICFTCCAZugAwIBAgIQPZg7pmY9kGP3fiZXOATvADAKBggqhkjOPQQDAzBMMS4w -LAYDVQQDDCVBdG9zIFRydXN0ZWRSb290IFJvb3QgQ0EgRUNDIFRMUyAyMDIxMQ0w -CwYDVQQKDARBdG9zMQswCQYDVQQGEwJERTAeFw0yMTA0MjIwOTI2MjNaFw00MTA0 -MTcwOTI2MjJaMEwxLjAsBgNVBAMMJUF0b3MgVHJ1c3RlZFJvb3QgUm9vdCBDQSBF -Q0MgVExTIDIwMjExDTALBgNVBAoMBEF0b3MxCzAJBgNVBAYTAkRFMHYwEAYHKoZI -zj0CAQYFK4EEACIDYgAEloZYKDcKZ9Cg3iQZGeHkBQcfl+3oZIK59sRxUM6KDP/X -tXa7oWyTbIOiaG6l2b4siJVBzV3dscqDY4PMwL502eCdpO5KTlbgmClBk1IQ1SQ4 -AjJn8ZQSb+/Xxd4u/RmAo0IwQDAPBgNVHRMBAf8EBTADAQH/MB0GA1UdDgQWBBR2 -KCXWfeBmmnoJsmo7jjPXNtNPojAOBgNVHQ8BAf8EBAMCAYYwCgYIKoZIzj0EAwMD -aAAwZQIwW5kp85wxtolrbNa9d+F851F+uDrNozZffPc8dz7kUK2o59JZDCaOMDtu -CCrCp1rIAjEAmeMM56PDr9NJLkaCI2ZdyQAUEv049OGYa3cpetskz2VAv9LcjBHo -9H1/IISpQuQo ------END CERTIFICATE----- - -# Issuer: CN=Atos TrustedRoot Root CA RSA TLS 2021 O=Atos -# Subject: CN=Atos TrustedRoot Root CA RSA TLS 2021 O=Atos -# Label: "Atos TrustedRoot Root CA RSA TLS 2021" -# Serial: 111436099570196163832749341232207667876 -# MD5 Fingerprint: d4:d3:46:b8:9a:c0:9c:76:5d:9e:3a:c3:b9:99:31:d2 -# SHA1 Fingerprint: 18:52:3b:0d:06:37:e4:d6:3a:df:23:e4:98:fb:5b:16:fb:86:74:48 -# SHA256 Fingerprint: 81:a9:08:8e:a5:9f:b3:64:c5:48:a6:f8:55:59:09:9b:6f:04:05:ef:bf:18:e5:32:4e:c9:f4:57:ba:00:11:2f ------BEGIN CERTIFICATE----- -MIIFZDCCA0ygAwIBAgIQU9XP5hmTC/srBRLYwiqipDANBgkqhkiG9w0BAQwFADBM -MS4wLAYDVQQDDCVBdG9zIFRydXN0ZWRSb290IFJvb3QgQ0EgUlNBIFRMUyAyMDIx -MQ0wCwYDVQQKDARBdG9zMQswCQYDVQQGEwJERTAeFw0yMTA0MjIwOTIxMTBaFw00 -MTA0MTcwOTIxMDlaMEwxLjAsBgNVBAMMJUF0b3MgVHJ1c3RlZFJvb3QgUm9vdCBD -QSBSU0EgVExTIDIwMjExDTALBgNVBAoMBEF0b3MxCzAJBgNVBAYTAkRFMIICIjAN -BgkqhkiG9w0BAQEFAAOCAg8AMIICCgKCAgEAtoAOxHm9BYx9sKOdTSJNy/BBl01Z -4NH+VoyX8te9j2y3I49f1cTYQcvyAh5x5en2XssIKl4w8i1mx4QbZFc4nXUtVsYv -Ye+W/CBGvevUez8/fEc4BKkbqlLfEzfTFRVOvV98r61jx3ncCHvVoOX3W3WsgFWZ -kmGbzSoXfduP9LVq6hdKZChmFSlsAvFr1bqjM9xaZ6cF4r9lthawEO3NUDPJcFDs -GY6wx/J0W2tExn2WuZgIWWbeKQGb9Cpt0xU6kGpn8bRrZtkh68rZYnxGEFzedUln -nkL5/nWpo63/dgpnQOPF943HhZpZnmKaau1Fh5hnstVKPNe0OwANwI8f4UDErmwh -3El+fsqyjW22v5MvoVw+j8rtgI5Y4dtXz4U2OLJxpAmMkokIiEjxQGMYsluMWuPD -0xeqqxmjLBvk1cbiZnrXghmmOxYsL3GHX0WelXOTwkKBIROW1527k2gV+p2kHYzy -geBYBr3JtuP2iV2J+axEoctr+hbxx1A9JNr3w+SH1VbxT5Aw+kUJWdo0zuATHAR8 -ANSbhqRAvNncTFd+rrcztl524WWLZt+NyteYr842mIycg5kDcPOvdO3GDjbnvezB -c6eUWsuSZIKmAMFwoW4sKeFYV+xafJlrJaSQOoD0IJ2azsct+bJLKZWD6TWNp0lI -pw9MGZHQ9b8Q4HECAwEAAaNCMEAwDwYDVR0TAQH/BAUwAwEB/zAdBgNVHQ4EFgQU -dEmZ0f+0emhFdcN+tNzMzjkz2ggwDgYDVR0PAQH/BAQDAgGGMA0GCSqGSIb3DQEB -DAUAA4ICAQAjQ1MkYlxt/T7Cz1UAbMVWiLkO3TriJQ2VSpfKgInuKs1l+NsW4AmS -4BjHeJi78+xCUvuppILXTdiK/ORO/auQxDh1MoSf/7OwKwIzNsAQkG8dnK/haZPs -o0UvFJ/1TCplQ3IM98P4lYsU84UgYt1UU90s3BiVaU+DR3BAM1h3Egyi61IxHkzJ -qM7F78PRreBrAwA0JrRUITWXAdxfG/F851X6LWh3e9NpzNMOa7pNdkTWwhWaJuyw -xfW70Xp0wmzNxbVe9kzmWy2B27O3Opee7c9GslA9hGCZcbUztVdF5kJHdWoOsAgM -rr3e97sPWD2PAzHoPYJQyi9eDF20l74gNAf0xBLh7tew2VktafcxBPTy+av5EzH4 -AXcOPUIjJsyacmdRIXrMPIWo6iFqO9taPKU0nprALN+AnCng33eU0aKAQv9qTFsR -0PXNor6uzFFcw9VUewyu1rkGd4Di7wcaaMxZUa1+XGdrudviB0JbuAEFWDlN5LuY -o7Ey7Nmj1m+UI/87tyll5gfp77YZ6ufCOB0yiJA8EytuzO+rdwY0d4RPcuSBhPm5 -dDTedk+SKlOxJTnbPP/lPqYO5Wue/9vsL3SD3460s6neFE3/MaNFcyT6lSnMEpcE -oji2jbDwN/zIIX8/syQbPYtuzE2wFg2WHYMfRsCbvUOZ58SWLs5fyQ== ------END CERTIFICATE----- - -# Issuer: CN=TrustAsia Global Root CA G3 O=TrustAsia Technologies, Inc. -# Subject: CN=TrustAsia Global Root CA G3 O=TrustAsia Technologies, Inc. -# Label: "TrustAsia Global Root CA G3" -# Serial: 576386314500428537169965010905813481816650257167 -# MD5 Fingerprint: 30:42:1b:b7:bb:81:75:35:e4:16:4f:53:d2:94:de:04 -# SHA1 Fingerprint: 63:cf:b6:c1:27:2b:56:e4:88:8e:1c:23:9a:b6:2e:81:47:24:c3:c7 -# SHA256 Fingerprint: e0:d3:22:6a:eb:11:63:c2:e4:8f:f9:be:3b:50:b4:c6:43:1b:e7:bb:1e:ac:c5:c3:6b:5d:5e:c5:09:03:9a:08 ------BEGIN CERTIFICATE----- -MIIFpTCCA42gAwIBAgIUZPYOZXdhaqs7tOqFhLuxibhxkw8wDQYJKoZIhvcNAQEM -BQAwWjELMAkGA1UEBhMCQ04xJTAjBgNVBAoMHFRydXN0QXNpYSBUZWNobm9sb2dp -ZXMsIEluYy4xJDAiBgNVBAMMG1RydXN0QXNpYSBHbG9iYWwgUm9vdCBDQSBHMzAe -Fw0yMTA1MjAwMjEwMTlaFw00NjA1MTkwMjEwMTlaMFoxCzAJBgNVBAYTAkNOMSUw -IwYDVQQKDBxUcnVzdEFzaWEgVGVjaG5vbG9naWVzLCBJbmMuMSQwIgYDVQQDDBtU -cnVzdEFzaWEgR2xvYmFsIFJvb3QgQ0EgRzMwggIiMA0GCSqGSIb3DQEBAQUAA4IC -DwAwggIKAoICAQDAMYJhkuSUGwoqZdC+BqmHO1ES6nBBruL7dOoKjbmzTNyPtxNS -T1QY4SxzlZHFZjtqz6xjbYdT8PfxObegQ2OwxANdV6nnRM7EoYNl9lA+sX4WuDqK -AtCWHwDNBSHvBm3dIZwZQ0WhxeiAysKtQGIXBsaqvPPW5vxQfmZCHzyLpnl5hkA1 -nyDvP+uLRx+PjsXUjrYsyUQE49RDdT/VP68czH5GX6zfZBCK70bwkPAPLfSIC7Ep -qq+FqklYqL9joDiR5rPmd2jE+SoZhLsO4fWvieylL1AgdB4SQXMeJNnKziyhWTXA -yB1GJ2Faj/lN03J5Zh6fFZAhLf3ti1ZwA0pJPn9pMRJpxx5cynoTi+jm9WAPzJMs -hH/x/Gr8m0ed262IPfN2dTPXS6TIi/n1Q1hPy8gDVI+lhXgEGvNz8teHHUGf59gX -zhqcD0r83ERoVGjiQTz+LISGNzzNPy+i2+f3VANfWdP3kXjHi3dqFuVJhZBFcnAv -kV34PmVACxmZySYgWmjBNb9Pp1Hx2BErW+Canig7CjoKH8GB5S7wprlppYiU5msT -f9FkPz2ccEblooV7WIQn3MSAPmeamseaMQ4w7OYXQJXZRe0Blqq/DPNL0WP3E1jA -uPP6Z92bfW1K/zJMtSU7/xxnD4UiWQWRkUF3gdCFTIcQcf+eQxuulXUtgQIDAQAB -o2MwYTAPBgNVHRMBAf8EBTADAQH/MB8GA1UdIwQYMBaAFEDk5PIj7zjKsK5Xf/Ih -MBY027ySMB0GA1UdDgQWBBRA5OTyI+84yrCuV3/yITAWNNu8kjAOBgNVHQ8BAf8E -BAMCAQYwDQYJKoZIhvcNAQEMBQADggIBACY7UeFNOPMyGLS0XuFlXsSUT9SnYaP4 -wM8zAQLpw6o1D/GUE3d3NZ4tVlFEbuHGLige/9rsR82XRBf34EzC4Xx8MnpmyFq2 -XFNFV1pF1AWZLy4jVe5jaN/TG3inEpQGAHUNcoTpLrxaatXeL1nHo+zSh2bbt1S1 -JKv0Q3jbSwTEb93mPmY+KfJLaHEih6D4sTNjduMNhXJEIlU/HHzp/LgV6FL6qj6j -ITk1dImmasI5+njPtqzn59ZW/yOSLlALqbUHM/Q4X6RJpstlcHboCoWASzY9M/eV -VHUl2qzEc4Jl6VL1XP04lQJqaTDFHApXB64ipCz5xUG3uOyfT0gA+QEEVcys+TIx -xHWVBqB/0Y0n3bOppHKH/lmLmnp0Ft0WpWIp6zqW3IunaFnT63eROfjXy9mPX1on -AX1daBli2MjN9LdyR75bl87yraKZk62Uy5P2EgmVtqvXO9A/EcswFi55gORngS1d -7XB4tmBZrOFdRWOPyN9yaFvqHbgB8X7754qz41SgOAngPN5C8sLtLpvzHzW2Ntjj -gKGLzZlkD8Kqq7HK9W+eQ42EVJmzbsASZthwEPEGNTNDqJwuuhQxzhB/HIbjj9LV -+Hfsm6vxL2PZQl/gZ4FkkfGXL/xuJvYz+NO1+MRiqzFRJQJ6+N1rZdVtTTDIZbpo -FGWsJwt0ivKH ------END CERTIFICATE----- - -# Issuer: CN=TrustAsia Global Root CA G4 O=TrustAsia Technologies, Inc. -# Subject: CN=TrustAsia Global Root CA G4 O=TrustAsia Technologies, Inc. -# Label: "TrustAsia Global Root CA G4" -# Serial: 451799571007117016466790293371524403291602933463 -# MD5 Fingerprint: 54:dd:b2:d7:5f:d8:3e:ed:7c:e0:0b:2e:cc:ed:eb:eb -# SHA1 Fingerprint: 57:73:a5:61:5d:80:b2:e6:ac:38:82:fc:68:07:31:ac:9f:b5:92:5a -# SHA256 Fingerprint: be:4b:56:cb:50:56:c0:13:6a:52:6d:f4:44:50:8d:aa:36:a0:b5:4f:42:e4:ac:38:f7:2a:f4:70:e4:79:65:4c ------BEGIN CERTIFICATE----- -MIICVTCCAdygAwIBAgIUTyNkuI6XY57GU4HBdk7LKnQV1tcwCgYIKoZIzj0EAwMw -WjELMAkGA1UEBhMCQ04xJTAjBgNVBAoMHFRydXN0QXNpYSBUZWNobm9sb2dpZXMs -IEluYy4xJDAiBgNVBAMMG1RydXN0QXNpYSBHbG9iYWwgUm9vdCBDQSBHNDAeFw0y -MTA1MjAwMjEwMjJaFw00NjA1MTkwMjEwMjJaMFoxCzAJBgNVBAYTAkNOMSUwIwYD -VQQKDBxUcnVzdEFzaWEgVGVjaG5vbG9naWVzLCBJbmMuMSQwIgYDVQQDDBtUcnVz -dEFzaWEgR2xvYmFsIFJvb3QgQ0EgRzQwdjAQBgcqhkjOPQIBBgUrgQQAIgNiAATx -s8045CVD5d4ZCbuBeaIVXxVjAd7Cq92zphtnS4CDr5nLrBfbK5bKfFJV4hrhPVbw -LxYI+hW8m7tH5j/uqOFMjPXTNvk4XatwmkcN4oFBButJ+bAp3TPsUKV/eSm4IJij -YzBhMA8GA1UdEwEB/wQFMAMBAf8wHwYDVR0jBBgwFoAUpbtKl86zK3+kMd6Xg1mD -pm9xy94wHQYDVR0OBBYEFKW7SpfOsyt/pDHel4NZg6ZvccveMA4GA1UdDwEB/wQE -AwIBBjAKBggqhkjOPQQDAwNnADBkAjBe8usGzEkxn0AAbbd+NvBNEU/zy4k6LHiR -UKNbwMp1JvK/kF0LgoxgKJ/GcJpo5PECMFxYDlZ2z1jD1xCMuo6u47xkdUfFVZDj -/bpV6wfEU6s3qe4hsiFbYI89MvHVI5TWWA== ------END CERTIFICATE----- - -# Issuer: CN=Telekom Security TLS ECC Root 2020 O=Deutsche Telekom Security GmbH -# Subject: CN=Telekom Security TLS ECC Root 2020 O=Deutsche Telekom Security GmbH -# Label: "Telekom Security TLS ECC Root 2020" -# Serial: 72082518505882327255703894282316633856 -# MD5 Fingerprint: c1:ab:fe:6a:10:2c:03:8d:bc:1c:22:32:c0:85:a7:fd -# SHA1 Fingerprint: c0:f8:96:c5:a9:3b:01:06:21:07:da:18:42:48:bc:e9:9d:88:d5:ec -# SHA256 Fingerprint: 57:8a:f4:de:d0:85:3f:4e:59:98:db:4a:ea:f9:cb:ea:8d:94:5f:60:b6:20:a3:8d:1a:3c:13:b2:bc:7b:a8:e1 ------BEGIN CERTIFICATE----- -MIICQjCCAcmgAwIBAgIQNjqWjMlcsljN0AFdxeVXADAKBggqhkjOPQQDAzBjMQsw -CQYDVQQGEwJERTEnMCUGA1UECgweRGV1dHNjaGUgVGVsZWtvbSBTZWN1cml0eSBH -bWJIMSswKQYDVQQDDCJUZWxla29tIFNlY3VyaXR5IFRMUyBFQ0MgUm9vdCAyMDIw -MB4XDTIwMDgyNTA3NDgyMFoXDTQ1MDgyNTIzNTk1OVowYzELMAkGA1UEBhMCREUx -JzAlBgNVBAoMHkRldXRzY2hlIFRlbGVrb20gU2VjdXJpdHkgR21iSDErMCkGA1UE -AwwiVGVsZWtvbSBTZWN1cml0eSBUTFMgRUNDIFJvb3QgMjAyMDB2MBAGByqGSM49 -AgEGBSuBBAAiA2IABM6//leov9Wq9xCazbzREaK9Z0LMkOsVGJDZos0MKiXrPk/O -tdKPD/M12kOLAoC+b1EkHQ9rK8qfwm9QMuU3ILYg/4gND21Ju9sGpIeQkpT0CdDP -f8iAC8GXs7s1J8nCG6NCMEAwHQYDVR0OBBYEFONyzG6VmUex5rNhTNHLq+O6zd6f -MA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgEGMAoGCCqGSM49BAMDA2cA -MGQCMHVSi7ekEE+uShCLsoRbQuHmKjYC2qBuGT8lv9pZMo7k+5Dck2TOrbRBR2Di -z6fLHgIwN0GMZt9Ba9aDAEH9L1r3ULRn0SyocddDypwnJJGDSA3PzfdUga/sf+Rn -27iQ7t0l ------END CERTIFICATE----- - -# Issuer: CN=Telekom Security TLS RSA Root 2023 O=Deutsche Telekom Security GmbH -# Subject: CN=Telekom Security TLS RSA Root 2023 O=Deutsche Telekom Security GmbH -# Label: "Telekom Security TLS RSA Root 2023" -# Serial: 44676229530606711399881795178081572759 -# MD5 Fingerprint: bf:5b:eb:54:40:cd:48:71:c4:20:8d:7d:de:0a:42:f2 -# SHA1 Fingerprint: 54:d3:ac:b3:bd:57:56:f6:85:9d:ce:e5:c3:21:e2:d4:ad:83:d0:93 -# SHA256 Fingerprint: ef:c6:5c:ad:bb:59:ad:b6:ef:e8:4d:a2:23:11:b3:56:24:b7:1b:3b:1e:a0:da:8b:66:55:17:4e:c8:97:86:46 ------BEGIN CERTIFICATE----- -MIIFszCCA5ugAwIBAgIQIZxULej27HF3+k7ow3BXlzANBgkqhkiG9w0BAQwFADBj -MQswCQYDVQQGEwJERTEnMCUGA1UECgweRGV1dHNjaGUgVGVsZWtvbSBTZWN1cml0 -eSBHbWJIMSswKQYDVQQDDCJUZWxla29tIFNlY3VyaXR5IFRMUyBSU0EgUm9vdCAy -MDIzMB4XDTIzMDMyODEyMTY0NVoXDTQ4MDMyNzIzNTk1OVowYzELMAkGA1UEBhMC -REUxJzAlBgNVBAoMHkRldXRzY2hlIFRlbGVrb20gU2VjdXJpdHkgR21iSDErMCkG -A1UEAwwiVGVsZWtvbSBTZWN1cml0eSBUTFMgUlNBIFJvb3QgMjAyMzCCAiIwDQYJ -KoZIhvcNAQEBBQADggIPADCCAgoCggIBAO01oYGA88tKaVvC+1GDrib94W7zgRJ9 -cUD/h3VCKSHtgVIs3xLBGYSJwb3FKNXVS2xE1kzbB5ZKVXrKNoIENqil/Cf2SfHV -cp6R+SPWcHu79ZvB7JPPGeplfohwoHP89v+1VmLhc2o0mD6CuKyVU/QBoCcHcqMA -U6DksquDOFczJZSfvkgdmOGjup5czQRxUX11eKvzWarE4GC+j4NSuHUaQTXtvPM6 -Y+mpFEXX5lLRbtLevOP1Czvm4MS9Q2QTps70mDdsipWol8hHD/BeEIvnHRz+sTug -BTNoBUGCwQMrAcjnj02r6LX2zWtEtefdi+zqJbQAIldNsLGyMcEWzv/9FIS3R/qy -8XDe24tsNlikfLMR0cN3f1+2JeANxdKz+bi4d9s3cXFH42AYTyS2dTd4uaNir73J -co4vzLuu2+QVUhkHM/tqty1LkCiCc/4YizWN26cEar7qwU02OxY2kTLvtkCJkUPg -8qKrBC7m8kwOFjQgrIfBLX7JZkcXFBGk8/ehJImr2BrIoVyxo/eMbcgByU/J7MT8 -rFEz0ciD0cmfHdRHNCk+y7AO+oMLKFjlKdw/fKifybYKu6boRhYPluV75Gp6SG12 -mAWl3G0eQh5C2hrgUve1g8Aae3g1LDj1H/1Joy7SWWO/gLCMk3PLNaaZlSJhZQNg -+y+TS/qanIA7AgMBAAGjYzBhMA4GA1UdDwEB/wQEAwIBBjAdBgNVHQ4EFgQUtqeX -gj10hZv3PJ+TmpV5dVKMbUcwDwYDVR0TAQH/BAUwAwEB/zAfBgNVHSMEGDAWgBS2 -p5eCPXSFm/c8n5OalXl1UoxtRzANBgkqhkiG9w0BAQwFAAOCAgEAqMxhpr51nhVQ -pGv7qHBFfLp+sVr8WyP6Cnf4mHGCDG3gXkaqk/QeoMPhk9tLrbKmXauw1GLLXrtm -9S3ul0A8Yute1hTWjOKWi0FpkzXmuZlrYrShF2Y0pmtjxrlO8iLpWA1WQdH6DErw -M807u20hOq6OcrXDSvvpfeWxm4bu4uB9tPcy/SKE8YXJN3nptT+/XOR0so8RYgDd -GGah2XsjX/GO1WfoVNpbOms2b/mBsTNHM3dA+VKq3dSDz4V4mZqTuXNnQkYRIer+ -CqkbGmVps4+uFrb2S1ayLfmlyOw7YqPta9BO1UAJpB+Y1zqlklkg5LB9zVtzaL1t -xKITDmcZuI1CfmwMmm6gJC3VRRvcxAIU/oVbZZfKTpBQCHpCNfnqwmbU+AGuHrS+ -w6jv/naaoqYfRvaE7fzbzsQCzndILIyy7MMAo+wsVRjBfhnu4S/yrYObnqsZ38aK -L4x35bcF7DvB7L6Gs4a8wPfc5+pbrrLMtTWGS9DiP7bY+A4A7l3j941Y/8+LN+lj -X273CXE2whJdV/LItM3z7gLfEdxquVeEHVlNjM7IDiPCtyaaEBRx/pOyiriA8A4Q -ntOoUAw3gi/q4Iqd4Sw5/7W0cwDk90imc6y/st53BIe0o82bNSQ3+pCTE4FCxpgm -dTdmQRCsu/WU48IxK63nI1bMNSWSs1A= ------END CERTIFICATE----- - -# Issuer: CN=FIRMAPROFESIONAL CA ROOT-A WEB O=Firmaprofesional SA -# Subject: CN=FIRMAPROFESIONAL CA ROOT-A WEB O=Firmaprofesional SA -# Label: "FIRMAPROFESIONAL CA ROOT-A WEB" -# Serial: 65916896770016886708751106294915943533 -# MD5 Fingerprint: 82:b2:ad:45:00:82:b0:66:63:f8:5f:c3:67:4e:ce:a3 -# SHA1 Fingerprint: a8:31:11:74:a6:14:15:0d:ca:77:dd:0e:e4:0c:5d:58:fc:a0:72:a5 -# SHA256 Fingerprint: be:f2:56:da:f2:6e:9c:69:bd:ec:16:02:35:97:98:f3:ca:f7:18:21:a0:3e:01:82:57:c5:3c:65:61:7f:3d:4a ------BEGIN CERTIFICATE----- -MIICejCCAgCgAwIBAgIQMZch7a+JQn81QYehZ1ZMbTAKBggqhkjOPQQDAzBuMQsw -CQYDVQQGEwJFUzEcMBoGA1UECgwTRmlybWFwcm9mZXNpb25hbCBTQTEYMBYGA1UE -YQwPVkFURVMtQTYyNjM0MDY4MScwJQYDVQQDDB5GSVJNQVBST0ZFU0lPTkFMIENB -IFJPT1QtQSBXRUIwHhcNMjIwNDA2MDkwMTM2WhcNNDcwMzMxMDkwMTM2WjBuMQsw -CQYDVQQGEwJFUzEcMBoGA1UECgwTRmlybWFwcm9mZXNpb25hbCBTQTEYMBYGA1UE -YQwPVkFURVMtQTYyNjM0MDY4MScwJQYDVQQDDB5GSVJNQVBST0ZFU0lPTkFMIENB -IFJPT1QtQSBXRUIwdjAQBgcqhkjOPQIBBgUrgQQAIgNiAARHU+osEaR3xyrq89Zf -e9MEkVz6iMYiuYMQYneEMy3pA4jU4DP37XcsSmDq5G+tbbT4TIqk5B/K6k84Si6C -cyvHZpsKjECcfIr28jlgst7L7Ljkb+qbXbdTkBgyVcUgt5SjYzBhMA8GA1UdEwEB -/wQFMAMBAf8wHwYDVR0jBBgwFoAUk+FDY1w8ndYn81LsF7Kpryz3dvgwHQYDVR0O -BBYEFJPhQ2NcPJ3WJ/NS7Beyqa8s93b4MA4GA1UdDwEB/wQEAwIBBjAKBggqhkjO -PQQDAwNoADBlAjAdfKR7w4l1M+E7qUW/Runpod3JIha3RxEL2Jq68cgLcFBTApFw -hVmpHqTm6iMxoAACMQD94vizrxa5HnPEluPBMBnYfubDl94cT7iJLzPrSA8Z94dG -XSaQpYXFuXqUPoeovQA= ------END CERTIFICATE----- - -# Issuer: CN=TWCA CYBER Root CA O=TAIWAN-CA OU=Root CA -# Subject: CN=TWCA CYBER Root CA O=TAIWAN-CA OU=Root CA -# Label: "TWCA CYBER Root CA" -# Serial: 85076849864375384482682434040119489222 -# MD5 Fingerprint: 0b:33:a0:97:52:95:d4:a9:fd:bb:db:6e:a3:55:5b:51 -# SHA1 Fingerprint: f6:b1:1c:1a:83:38:e9:7b:db:b3:a8:c8:33:24:e0:2d:9c:7f:26:66 -# SHA256 Fingerprint: 3f:63:bb:28:14:be:17:4e:c8:b6:43:9c:f0:8d:6d:56:f0:b7:c4:05:88:3a:56:48:a3:34:42:4d:6b:3e:c5:58 ------BEGIN CERTIFICATE----- -MIIFjTCCA3WgAwIBAgIQQAE0jMIAAAAAAAAAATzyxjANBgkqhkiG9w0BAQwFADBQ -MQswCQYDVQQGEwJUVzESMBAGA1UEChMJVEFJV0FOLUNBMRAwDgYDVQQLEwdSb290 -IENBMRswGQYDVQQDExJUV0NBIENZQkVSIFJvb3QgQ0EwHhcNMjIxMTIyMDY1NDI5 -WhcNNDcxMTIyMTU1OTU5WjBQMQswCQYDVQQGEwJUVzESMBAGA1UEChMJVEFJV0FO -LUNBMRAwDgYDVQQLEwdSb290IENBMRswGQYDVQQDExJUV0NBIENZQkVSIFJvb3Qg -Q0EwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQDG+Moe2Qkgfh1sTs6P -40czRJzHyWmqOlt47nDSkvgEs1JSHWdyKKHfi12VCv7qze33Kc7wb3+szT3vsxxF -avcokPFhV8UMxKNQXd7UtcsZyoC5dc4pztKFIuwCY8xEMCDa6pFbVuYdHNWdZsc/ -34bKS1PE2Y2yHer43CdTo0fhYcx9tbD47nORxc5zb87uEB8aBs/pJ2DFTxnk684i -JkXXYJndzk834H/nY62wuFm40AZoNWDTNq5xQwTxaWV4fPMf88oon1oglWa0zbfu -j3ikRRjpJi+NmykosaS3Om251Bw4ckVYsV7r8Cibt4LK/c/WMw+f+5eesRycnupf -Xtuq3VTpMCEobY5583WSjCb+3MX2w7DfRFlDo7YDKPYIMKoNM+HvnKkHIuNZW0CP -2oi3aQiotyMuRAlZN1vH4xfyIutuOVLF3lSnmMlLIJXcRolftBL5hSmO68gnFSDA -S9TMfAxsNAwmmyYxpjyn9tnQS6Jk/zuZQXLB4HCX8SS7K8R0IrGsayIyJNN4KsDA -oS/xUgXJP+92ZuJF2A09rZXIx4kmyA+upwMu+8Ff+iDhcK2wZSA3M2Cw1a/XDBzC -kHDXShi8fgGwsOsVHkQGzaRP6AzRwyAQ4VRlnrZR0Bp2a0JaWHY06rc3Ga4udfmW -5cFZ95RXKSWNOkyrTZpB0F8mAwIDAQABo2MwYTAOBgNVHQ8BAf8EBAMCAQYwDwYD -VR0TAQH/BAUwAwEB/zAfBgNVHSMEGDAWgBSdhWEUfMFib5do5E83QOGt4A1WNzAd -BgNVHQ4EFgQUnYVhFHzBYm+XaORPN0DhreANVjcwDQYJKoZIhvcNAQEMBQADggIB -AGSPesRiDrWIzLjHhg6hShbNcAu3p4ULs3a2D6f/CIsLJc+o1IN1KriWiLb73y0t -tGlTITVX1olNc79pj3CjYcya2x6a4CD4bLubIp1dhDGaLIrdaqHXKGnK/nZVekZn -68xDiBaiA9a5F/gZbG0jAn/xX9AKKSM70aoK7akXJlQKTcKlTfjF/biBzysseKNn -TKkHmvPfXvt89YnNdJdhEGoHK4Fa0o635yDRIG4kqIQnoVesqlVYL9zZyvpoBJ7t -RCT5dEA7IzOrg1oYJkK2bVS1FmAwbLGg+LhBoF1JSdJlBTrq/p1hvIbZv97Tujqx -f36SNI7JAG7cmL3c7IAFrQI932XtCwP39xaEBDG6k5TY8hL4iuO/Qq+n1M0RFxbI -Qh0UqEL20kCGoE8jypZFVmAGzbdVAaYBlGX+bgUJurSkquLvWL69J1bY73NxW0Qz -8ppy6rBePm6pUlvscG21h483XjyMnM7k8M4MZ0HMzvaAq07MTFb1wWFZk7Q+ptq4 -NxKfKjLji7gh7MMrZQzvIt6IKTtM1/r+t+FHvpw+PoP7UV31aPcuIYXcv/Fa4nzX -xeSDwWrruoBa3lwtcHb4yOWHh8qgnaHlIhInD0Q9HWzq1MKLL295q39QpsQZp6F6 -t5b5wR9iWqJDB0BeJsas7a5wFsWqynKKTbDPAYsDP27X ------END CERTIFICATE----- - -# Issuer: CN=SecureSign Root CA12 O=Cybertrust Japan Co., Ltd. -# Subject: CN=SecureSign Root CA12 O=Cybertrust Japan Co., Ltd. -# Label: "SecureSign Root CA12" -# Serial: 587887345431707215246142177076162061960426065942 -# MD5 Fingerprint: c6:89:ca:64:42:9b:62:08:49:0b:1e:7f:e9:07:3d:e8 -# SHA1 Fingerprint: 7a:22:1e:3d:de:1b:06:ac:9e:c8:47:70:16:8e:3c:e5:f7:6b:06:f4 -# SHA256 Fingerprint: 3f:03:4b:b5:70:4d:44:b2:d0:85:45:a0:20:57:de:93:eb:f3:90:5f:ce:72:1a:cb:c7:30:c0:6d:da:ee:90:4e ------BEGIN CERTIFICATE----- -MIIDcjCCAlqgAwIBAgIUZvnHwa/swlG07VOX5uaCwysckBYwDQYJKoZIhvcNAQEL -BQAwUTELMAkGA1UEBhMCSlAxIzAhBgNVBAoTGkN5YmVydHJ1c3QgSmFwYW4gQ28u -LCBMdGQuMR0wGwYDVQQDExRTZWN1cmVTaWduIFJvb3QgQ0ExMjAeFw0yMDA0MDgw -NTM2NDZaFw00MDA0MDgwNTM2NDZaMFExCzAJBgNVBAYTAkpQMSMwIQYDVQQKExpD -eWJlcnRydXN0IEphcGFuIENvLiwgTHRkLjEdMBsGA1UEAxMUU2VjdXJlU2lnbiBS -b290IENBMTIwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQC6OcE3emhF -KxS06+QT61d1I02PJC0W6K6OyX2kVzsqdiUzg2zqMoqUm048luT9Ub+ZyZN+v/mt -p7JIKwccJ/VMvHASd6SFVLX9kHrko+RRWAPNEHl57muTH2SOa2SroxPjcf59q5zd -J1M3s6oYwlkm7Fsf0uZlfO+TvdhYXAvA42VvPMfKWeP+bl+sg779XSVOKik71gur -FzJ4pOE+lEa+Ym6b3kaosRbnhW70CEBFEaCeVESE99g2zvVQR9wsMJvuwPWW0v4J -hscGWa5Pro4RmHvzC1KqYiaqId+OJTN5lxZJjfU+1UefNzFJM3IFTQy2VYzxV4+K -h9GtxRESOaCtAgMBAAGjQjBAMA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQD -AgEGMB0GA1UdDgQWBBRXNPN0zwRL1SXm8UC2LEzZLemgrTANBgkqhkiG9w0BAQsF -AAOCAQEAPrvbFxbS8hQBICw4g0utvsqFepq2m2um4fylOqyttCg6r9cBg0krY6Ld -mmQOmFxv3Y67ilQiLUoT865AQ9tPkbeGGuwAtEGBpE/6aouIs3YIcipJQMPTw4WJ -mBClnW8Zt7vPemVV2zfrPIpyMpcemik+rY3moxtt9XUa5rBouVui7mlHJzWhhpmA -8zNL4WukJsPvdFlseqJkth5Ew1DgDzk9qTPxpfPSvWKErI4cqc1avTc7bgoitPQV -55FYxTpE05Uo2cBl6XLK0A+9H7MV2anjpEcJnuDLN/v9vZfVvhgaaaI5gdka9at/ -yOPiZwud9AzqVN/Ssq+xIvEg37xEHA== ------END CERTIFICATE----- - -# Issuer: CN=SecureSign Root CA14 O=Cybertrust Japan Co., Ltd. -# Subject: CN=SecureSign Root CA14 O=Cybertrust Japan Co., Ltd. -# Label: "SecureSign Root CA14" -# Serial: 575790784512929437950770173562378038616896959179 -# MD5 Fingerprint: 71:0d:72:fa:92:19:65:5e:89:04:ac:16:33:f0:bc:d5 -# SHA1 Fingerprint: dd:50:c0:f7:79:b3:64:2e:74:a2:b8:9d:9f:d3:40:dd:bb:f0:f2:4f -# SHA256 Fingerprint: 4b:00:9c:10:34:49:4f:9a:b5:6b:ba:3b:a1:d6:27:31:fc:4d:20:d8:95:5a:dc:ec:10:a9:25:60:72:61:e3:38 ------BEGIN CERTIFICATE----- -MIIFcjCCA1qgAwIBAgIUZNtaDCBO6Ncpd8hQJ6JaJ90t8sswDQYJKoZIhvcNAQEM -BQAwUTELMAkGA1UEBhMCSlAxIzAhBgNVBAoTGkN5YmVydHJ1c3QgSmFwYW4gQ28u -LCBMdGQuMR0wGwYDVQQDExRTZWN1cmVTaWduIFJvb3QgQ0ExNDAeFw0yMDA0MDgw -NzA2MTlaFw00NTA0MDgwNzA2MTlaMFExCzAJBgNVBAYTAkpQMSMwIQYDVQQKExpD -eWJlcnRydXN0IEphcGFuIENvLiwgTHRkLjEdMBsGA1UEAxMUU2VjdXJlU2lnbiBS -b290IENBMTQwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQDF0nqh1oq/ -FjHQmNE6lPxauG4iwWL3pwon71D2LrGeaBLwbCRjOfHw3xDG3rdSINVSW0KZnvOg -vlIfX8xnbacuUKLBl422+JX1sLrcneC+y9/3OPJH9aaakpUqYllQC6KxNedlsmGy -6pJxaeQp8E+BgQQ8sqVb1MWoWWd7VRxJq3qdwudzTe/NCcLEVxLbAQ4jeQkHO6Lo -/IrPj8BGJJw4J+CDnRugv3gVEOuGTgpa/d/aLIJ+7sr2KeH6caH3iGicnPCNvg9J -kdjqOvn90Ghx2+m1K06Ckm9mH+Dw3EzsytHqunQG+bOEkJTRX45zGRBdAuVwpcAQ -0BB8b8VYSbSwbprafZX1zNoCr7gsfXmPvkPx+SgojQlD+Ajda8iLLCSxjVIHvXib -y8posqTdDEx5YMaZ0ZPxMBoH064iwurO8YQJzOAUbn8/ftKChazcqRZOhaBgy/ac -18izju3Gm5h1DVXoX+WViwKkrkMpKBGk5hIwAUt1ax5mnXkvpXYvHUC0bcl9eQjs -0Wq2XSqypWa9a4X0dFbD9ed1Uigspf9mR6XU/v6eVL9lfgHWMI+lNpyiUBzuOIAB -SMbHdPTGrMNASRZhdCyvjG817XsYAFs2PJxQDcqSMxDxJklt33UkN4Ii1+iW/RVL -ApY+B3KVfqs9TC7XyvDf4Fg/LS8EmjijAQIDAQABo0IwQDAPBgNVHRMBAf8EBTAD -AQH/MA4GA1UdDwEB/wQEAwIBBjAdBgNVHQ4EFgQUBpOjCl4oaTeqYR3r6/wtbyPk -86AwDQYJKoZIhvcNAQEMBQADggIBAJaAcgkGfpzMkwQWu6A6jZJOtxEaCnFxEM0E -rX+lRVAQZk5KQaID2RFPeje5S+LGjzJmdSX7684/AykmjbgWHfYfM25I5uj4V7Ib -ed87hwriZLoAymzvftAj63iP/2SbNDefNWWipAA9EiOWWF3KY4fGoweITedpdopT -zfFP7ELyk+OZpDc8h7hi2/DsHzc/N19DzFGdtfCXwreFamgLRB7lUe6TzktuhsHS -DCRZNhqfLJGP4xjblJUK7ZGqDpncllPjYYPGFrojutzdfhrGe0K22VoF3Jpf1d+4 -2kd92jjbrDnVHmtsKheMYc2xbXIBw8MgAGJoFjHVdqqGuw6qnsb58Nn4DSEC5MUo -FlkRudlpcyqSeLiSV5sI8jrlL5WwWLdrIBRtFO8KvH7YVdiI2i/6GaX7i+B/OfVy -K4XELKzvGUWSTLNhB9xNH27SgRNcmvMSZ4PPmz+Ln52kuaiWA3rF7iDeM9ovnhp6 -dB7h7sxaOgTdsxoEqBRjrLdHEoOabPXm6RUVkRqEGQ6UROcSjiVbgGcZ3GOTEAtl -Lor6CZpO2oYofaphNdgOpygau1LgePhsumywbrmHXumZNTfxPWQrqaA0k89jL9WB -365jJ6UeTo3cKXhZ+PmhIIynJkBugnLNeLLIjzwec+fBH7/PzqUqm9tEZDKgu39c -JRNItX+S ------END CERTIFICATE----- - -# Issuer: CN=SecureSign Root CA15 O=Cybertrust Japan Co., Ltd. -# Subject: CN=SecureSign Root CA15 O=Cybertrust Japan Co., Ltd. -# Label: "SecureSign Root CA15" -# Serial: 126083514594751269499665114766174399806381178503 -# MD5 Fingerprint: 13:30:fc:c4:62:a6:a9:de:b5:c1:68:af:b5:d2:31:47 -# SHA1 Fingerprint: cb:ba:83:c8:c1:5a:5d:f1:f9:73:6f:ca:d7:ef:28:13:06:4a:07:7d -# SHA256 Fingerprint: e7:78:f0:f0:95:fe:84:37:29:cd:1a:00:82:17:9e:53:14:a9:c2:91:44:28:05:e1:fb:1d:8f:b6:b8:88:6c:3a ------BEGIN CERTIFICATE----- -MIICIzCCAamgAwIBAgIUFhXHw9hJp75pDIqI7fBw+d23PocwCgYIKoZIzj0EAwMw -UTELMAkGA1UEBhMCSlAxIzAhBgNVBAoTGkN5YmVydHJ1c3QgSmFwYW4gQ28uLCBM -dGQuMR0wGwYDVQQDExRTZWN1cmVTaWduIFJvb3QgQ0ExNTAeFw0yMDA0MDgwODMy -NTZaFw00NTA0MDgwODMyNTZaMFExCzAJBgNVBAYTAkpQMSMwIQYDVQQKExpDeWJl -cnRydXN0IEphcGFuIENvLiwgTHRkLjEdMBsGA1UEAxMUU2VjdXJlU2lnbiBSb290 -IENBMTUwdjAQBgcqhkjOPQIBBgUrgQQAIgNiAAQLUHSNZDKZmbPSYAi4Io5GdCx4 -wCtELW1fHcmuS1Iggz24FG1Th2CeX2yF2wYUleDHKP+dX+Sq8bOLbe1PL0vJSpSR -ZHX+AezB2Ot6lHhWGENfa4HL9rzatAy2KZMIaY+jQjBAMA8GA1UdEwEB/wQFMAMB -Af8wDgYDVR0PAQH/BAQDAgEGMB0GA1UdDgQWBBTrQciu/NWeUUj1vYv0hyCTQSvT -9DAKBggqhkjOPQQDAwNoADBlAjEA2S6Jfl5OpBEHvVnCB96rMjhTKkZEBhd6zlHp -4P9mLQlO4E/0BdGF9jVg3PVys0Z9AjBEmEYagoUeYWmJSwdLZrWeqrqgHkHZAXQ6 -bkU6iYAZezKYVWOr62Nuk22rGwlgMU4= ------END CERTIFICATE----- - -# Issuer: CN=D-TRUST BR Root CA 2 2023 O=D-Trust GmbH -# Subject: CN=D-TRUST BR Root CA 2 2023 O=D-Trust GmbH -# Label: "D-TRUST BR Root CA 2 2023" -# Serial: 153168538924886464690566649552453098598 -# MD5 Fingerprint: e1:09:ed:d3:60:d4:56:1b:47:1f:b7:0c:5f:1b:5f:85 -# SHA1 Fingerprint: 2d:b0:70:ee:71:94:af:69:68:17:db:79:ce:58:9f:a0:6b:96:f7:87 -# SHA256 Fingerprint: 05:52:e6:f8:3f:df:65:e8:fa:96:70:e6:66:df:28:a4:e2:13:40:b5:10:cb:e5:25:66:f9:7c:4f:b9:4b:2b:d1 ------BEGIN CERTIFICATE----- -MIIFqTCCA5GgAwIBAgIQczswBEhb2U14LnNLyaHcZjANBgkqhkiG9w0BAQ0FADBI -MQswCQYDVQQGEwJERTEVMBMGA1UEChMMRC1UcnVzdCBHbWJIMSIwIAYDVQQDExlE -LVRSVVNUIEJSIFJvb3QgQ0EgMiAyMDIzMB4XDTIzMDUwOTA4NTYzMVoXDTM4MDUw -OTA4NTYzMFowSDELMAkGA1UEBhMCREUxFTATBgNVBAoTDEQtVHJ1c3QgR21iSDEi -MCAGA1UEAxMZRC1UUlVTVCBCUiBSb290IENBIDIgMjAyMzCCAiIwDQYJKoZIhvcN -AQEBBQADggIPADCCAgoCggIBAK7/CVmRgApKaOYkP7in5Mg6CjoWzckjYaCTcfKr -i3OPoGdlYNJUa2NRb0kz4HIHE304zQaSBylSa053bATTlfrdTIzZXcFhfUvnKLNE -gXtRr90zsWh81k5M/itoucpmacTsXld/9w3HnDY25QdgrMBM6ghs7wZ8T1soegj8 -k12b9py0i4a6Ibn08OhZWiihNIQaJZG2tY/vsvmA+vk9PBFy2OMvhnbFeSzBqZCT -Rphny4NqoFAjpzv2gTng7fC5v2Xx2Mt6++9zA84A9H3X4F07ZrjcjrqDy4d2A/wl -2ecjbwb9Z/Pg/4S8R7+1FhhGaRTMBffb00msa8yr5LULQyReS2tNZ9/WtT5PeB+U -cSTq3nD88ZP+npNa5JRal1QMNXtfbO4AHyTsA7oC9Xb0n9Sa7YUsOCIvx9gvdhFP -/Wxc6PWOJ4d/GUohR5AdeY0cW/jPSoXk7bNbjb7EZChdQcRurDhaTyN0dKkSw/bS -uREVMweR2Ds3OmMwBtHFIjYoYiMQ4EbMl6zWK11kJNXuHA7e+whadSr2Y23OC0K+ -0bpwHJwh5Q8xaRfX/Aq03u2AnMuStIv13lmiWAmlY0cL4UEyNEHZmrHZqLAbWt4N -DfTisl01gLmB1IRpkQLLddCNxbU9CZEJjxShFHR5PtbJFR2kWVki3PaKRT08EtY+ -XTIvAgMBAAGjgY4wgYswDwYDVR0TAQH/BAUwAwEB/zAdBgNVHQ4EFgQUZ5Dw1t61 -GNVGKX5cq/ieCLxklRAwDgYDVR0PAQH/BAQDAgEGMEkGA1UdHwRCMEAwPqA8oDqG -OGh0dHA6Ly9jcmwuZC10cnVzdC5uZXQvY3JsL2QtdHJ1c3RfYnJfcm9vdF9jYV8y -XzIwMjMuY3JsMA0GCSqGSIb3DQEBDQUAA4ICAQA097N3U9swFrktpSHxQCF16+tI -FoE9c+CeJyrrd6kTpGoKWloUMz1oH4Guaf2Mn2VsNELZLdB/eBaxOqwjMa1ef67n -riv6uvw8l5VAk1/DLQOj7aRvU9f6QA4w9QAgLABMjDu0ox+2v5Eyq6+SmNMW5tTR -VFxDWy6u71cqqLRvpO8NVhTaIasgdp4D/Ca4nj8+AybmTNudX0KEPUUDAxxZiMrc -LmEkWqTqJwtzEr5SswrPMhfiHocaFpVIbVrg0M8JkiZmkdijYQ6qgYF/6FKC0ULn -4B0Y+qSFNueG4A3rvNTJ1jxD8V1Jbn6Bm2m1iWKPiFLY1/4nwSPFyysCu7Ff/vtD -hQNGvl3GyiEm/9cCnnRK3PgTFbGBVzbLZVzRHTF36SXDw7IyN9XxmAnkbWOACKsG -koHU6XCPpz+y7YaMgmo1yEJagtFSGkUPFaUA8JR7ZSdXOUPPfH/mvTWze/EZTN46 -ls/pdu4D58JDUjxqgejBWoC9EV2Ta/vH5mQ/u2kc6d0li690yVRAysuTEwrt+2aS -Ecr1wPrYg1UDfNPFIkZ1cGt5SAYqgpq/5usWDiJFAbzdNpQ0qTUmiteXue4Icr80 -knCDgKs4qllo3UCkGJCy89UDyibK79XH4I9TjvAA46jtn/mtd+ArY0+ew+43u3gJ -hJ65bvspmZDogNOfJA== ------END CERTIFICATE----- - -# Issuer: CN=TrustAsia TLS ECC Root CA O=TrustAsia Technologies, Inc. -# Subject: CN=TrustAsia TLS ECC Root CA O=TrustAsia Technologies, Inc. -# Label: "TrustAsia TLS ECC Root CA" -# Serial: 310892014698942880364840003424242768478804666567 -# MD5 Fingerprint: 09:48:04:77:d2:fc:65:93:71:66:b1:11:95:4f:06:8c -# SHA1 Fingerprint: b5:ec:39:f3:a1:66:37:ae:c3:05:94:57:e2:be:11:be:b7:a1:7f:36 -# SHA256 Fingerprint: c0:07:6b:9e:f0:53:1f:b1:a6:56:d6:7c:4e:be:97:cd:5d:ba:a4:1e:f4:45:98:ac:c2:48:98:78:c9:2d:87:11 ------BEGIN CERTIFICATE----- -MIICMTCCAbegAwIBAgIUNnThTXxlE8msg1UloD5Sfi9QaMcwCgYIKoZIzj0EAwMw -WDELMAkGA1UEBhMCQ04xJTAjBgNVBAoTHFRydXN0QXNpYSBUZWNobm9sb2dpZXMs -IEluYy4xIjAgBgNVBAMTGVRydXN0QXNpYSBUTFMgRUNDIFJvb3QgQ0EwHhcNMjQw -NTE1MDU0MTU2WhcNNDQwNTE1MDU0MTU1WjBYMQswCQYDVQQGEwJDTjElMCMGA1UE -ChMcVHJ1c3RBc2lhIFRlY2hub2xvZ2llcywgSW5jLjEiMCAGA1UEAxMZVHJ1c3RB -c2lhIFRMUyBFQ0MgUm9vdCBDQTB2MBAGByqGSM49AgEGBSuBBAAiA2IABLh/pVs/ -AT598IhtrimY4ZtcU5nb9wj/1WrgjstEpvDBjL1P1M7UiFPoXlfXTr4sP/MSpwDp -guMqWzJ8S5sUKZ74LYO1644xST0mYekdcouJtgq7nDM1D9rs3qlKH8kzsaNCMEAw -DwYDVR0TAQH/BAUwAwEB/zAdBgNVHQ4EFgQULIVTu7FDzTLqnqOH/qKYqKaT6RAw -DgYDVR0PAQH/BAQDAgEGMAoGCCqGSM49BAMDA2gAMGUCMFRH18MtYYZI9HlaVQ01 -L18N9mdsd0AaRuf4aFtOJx24mH1/k78ITcTaRTChD15KeAIxAKORh/IRM4PDwYqR -OkwrULG9IpRdNYlzg8WbGf60oenUoWa2AaU2+dhoYSi3dOGiMQ== ------END CERTIFICATE----- - -# Issuer: CN=TrustAsia TLS RSA Root CA O=TrustAsia Technologies, Inc. -# Subject: CN=TrustAsia TLS RSA Root CA O=TrustAsia Technologies, Inc. -# Label: "TrustAsia TLS RSA Root CA" -# Serial: 160405846464868906657516898462547310235378010780 -# MD5 Fingerprint: 3b:9e:c3:86:0f:34:3c:6b:c5:46:c4:8e:1d:e7:19:12 -# SHA1 Fingerprint: a5:46:50:c5:62:ea:95:9a:1a:a7:04:6f:17:58:c7:29:53:3d:03:fa -# SHA256 Fingerprint: 06:c0:8d:7d:af:d8:76:97:1e:b1:12:4f:e6:7f:84:7e:c0:c7:a1:58:d3:ea:53:cb:e9:40:e2:ea:97:91:f4:c3 ------BEGIN CERTIFICATE----- -MIIFgDCCA2igAwIBAgIUHBjYz+VTPyI1RlNUJDxsR9FcSpwwDQYJKoZIhvcNAQEM -BQAwWDELMAkGA1UEBhMCQ04xJTAjBgNVBAoTHFRydXN0QXNpYSBUZWNobm9sb2dp -ZXMsIEluYy4xIjAgBgNVBAMTGVRydXN0QXNpYSBUTFMgUlNBIFJvb3QgQ0EwHhcN -MjQwNTE1MDU0MTU3WhcNNDQwNTE1MDU0MTU2WjBYMQswCQYDVQQGEwJDTjElMCMG -A1UEChMcVHJ1c3RBc2lhIFRlY2hub2xvZ2llcywgSW5jLjEiMCAGA1UEAxMZVHJ1 -c3RBc2lhIFRMUyBSU0EgUm9vdCBDQTCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCC -AgoCggIBAMMWuBtqpERz5dZO9LnPWwvB0ZqB9WOwj0PBuwhaGnrhB3YmH49pVr7+ -NmDQDIPNlOrnxS1cLwUWAp4KqC/lYCZUlviYQB2srp10Zy9U+5RjmOMmSoPGlbYJ -Q1DNDX3eRA5gEk9bNb2/mThtfWza4mhzH/kxpRkQcwUqwzIZheo0qt1CHjCNP561 -HmHVb70AcnKtEj+qpklz8oYVlQwQX1Fkzv93uMltrOXVmPGZLmzjyUT5tUMnCE32 -ft5EebuyjBza00tsLtbDeLdM1aTk2tyKjg7/D8OmYCYozza/+lcK7Fs/6TAWe8Tb -xNRkoDD75f0dcZLdKY9BWN4ArTr9PXwaqLEX8E40eFgl1oUh63kd0Nyrz2I8sMeX -i9bQn9P+PN7F4/w6g3CEIR0JwqH8uyghZVNgepBtljhb//HXeltt08lwSUq6HTrQ -UNoyIBnkiz/r1RYmNzz7dZ6wB3C4FGB33PYPXFIKvF1tjVEK2sUYyJtt3LCDs3+j -TnhMmCWr8n4uIF6CFabW2I+s5c0yhsj55NqJ4js+k8UTav/H9xj8Z7XvGCxUq0DT -bE3txci3OE9kxJRMT6DNrqXGJyV1J23G2pyOsAWZ1SgRxSHUuPzHlqtKZFlhaxP8 -S8ySpg+kUb8OWJDZgoM5pl+z+m6Ss80zDoWo8SnTq1mt1tve1CuBAgMBAAGjQjBA -MA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYEFLgHkXlcBvRG/XtZylomkadFK/hT -MA4GA1UdDwEB/wQEAwIBBjANBgkqhkiG9w0BAQwFAAOCAgEAIZtqBSBdGBanEqT3 -Rz/NyjuujsCCztxIJXgXbODgcMTWltnZ9r96nBO7U5WS/8+S4PPFJzVXqDuiGev4 -iqME3mmL5Dw8veWv0BIb5Ylrc5tvJQJLkIKvQMKtuppgJFqBTQUYo+IzeXoLH5Pt -7DlK9RME7I10nYEKqG/odv6LTytpEoYKNDbdgptvT+Bz3Ul/KD7JO6NXBNiT2Twp -2xIQaOHEibgGIOcberyxk2GaGUARtWqFVwHxtlotJnMnlvm5P1vQiJ3koP26TpUJ -g3933FEFlJ0gcXax7PqJtZwuhfG5WyRasQmr2soaB82G39tp27RIGAAtvKLEiUUj -pQ7hRGU+isFqMB3iYPg6qocJQrmBktwliJiJ8Xw18WLK7nn4GS/+X/jbh87qqA8M -pugLoDzga5SYnH+tBuYc6kIQX+ImFTw3OffXvO645e8D7r0i+yiGNFjEWn9hongP -XvPKnbwbPKfILfanIhHKA9jnZwqKDss1jjQ52MjqjZ9k4DewbNfFj8GQYSbbJIwe -SsCI3zWQzj8C9GRh3sfIB5XeMhg6j6JCQCTl1jNdfK7vsU1P1FeQNWrcrgSXSYk0 -ly4wBOeY99sLAZDBHwo/+ML+TvrbmnNzFrwFuHnYWa8G5z9nODmxfKuU4CkUpijy -323imttUQ/hHWKNddBWcwauwxzQ= ------END CERTIFICATE----- - -# Issuer: CN=D-TRUST EV Root CA 2 2023 O=D-Trust GmbH -# Subject: CN=D-TRUST EV Root CA 2 2023 O=D-Trust GmbH -# Label: "D-TRUST EV Root CA 2 2023" -# Serial: 139766439402180512324132425437959641711 -# MD5 Fingerprint: 96:b4:78:09:f0:09:cb:77:eb:bb:1b:4d:6f:36:bc:b6 -# SHA1 Fingerprint: a5:5b:d8:47:6c:8f:19:f7:4c:f4:6d:6b:b6:c2:79:82:22:df:54:8b -# SHA256 Fingerprint: 8e:82:21:b2:e7:d4:00:78:36:a1:67:2f:0d:cc:29:9c:33:bc:07:d3:16:f1:32:fa:1a:20:6d:58:71:50:f1:ce ------BEGIN CERTIFICATE----- -MIIFqTCCA5GgAwIBAgIQaSYJfoBLTKCnjHhiU19abzANBgkqhkiG9w0BAQ0FADBI -MQswCQYDVQQGEwJERTEVMBMGA1UEChMMRC1UcnVzdCBHbWJIMSIwIAYDVQQDExlE -LVRSVVNUIEVWIFJvb3QgQ0EgMiAyMDIzMB4XDTIzMDUwOTA5MTAzM1oXDTM4MDUw -OTA5MTAzMlowSDELMAkGA1UEBhMCREUxFTATBgNVBAoTDEQtVHJ1c3QgR21iSDEi -MCAGA1UEAxMZRC1UUlVTVCBFViBSb290IENBIDIgMjAyMzCCAiIwDQYJKoZIhvcN -AQEBBQADggIPADCCAgoCggIBANiOo4mAC7JXUtypU0w3uX9jFxPvp1sjW2l1sJkK -F8GLxNuo4MwxusLyzV3pt/gdr2rElYfXR8mV2IIEUD2BCP/kPbOx1sWy/YgJ25yE -7CUXFId/MHibaljJtnMoPDT3mfd/06b4HEV8rSyMlD/YZxBTfiLNTiVR8CUkNRFe -EMbsh2aJgWi6zCudR3Mfvc2RpHJqnKIbGKBv7FD0fUDCqDDPvXPIEysQEx6Lmqg6 -lHPTGGkKSv/BAQP/eX+1SH977ugpbzZMlWGG2Pmic4ruri+W7mjNPU0oQvlFKzIb -RlUWaqZLKfm7lVa/Rh3sHZMdwGWyH6FDrlaeoLGPaxK3YG14C8qKXO0elg6DpkiV -jTujIcSuWMYAsoS0I6SWhjW42J7YrDRJmGOVxcttSEfi8i4YHtAxq9107PncjLgc -jmgjutDzUNzPZY9zOjLHfP7KgiJPvo5iR2blzYfi6NUPGJ/lBHJLRjwQ8kTCZFZx -TnXonMkmdMV9WdEKWw9t/p51HBjGGjp82A0EzM23RWV6sY+4roRIPrN6TagD4uJ+ -ARZZaBhDM7DS3LAaQzXupdqpRlyuhoFBAUp0JuyfBr/CBTdkdXgpaP3F9ev+R/nk -hbDhezGdpn9yo7nELC7MmVcOIQxFAZRl62UJxmMiCzNJkkg8/M3OsD6Onov4/knF -NXJHAgMBAAGjgY4wgYswDwYDVR0TAQH/BAUwAwEB/zAdBgNVHQ4EFgQUqvyREBuH -kV8Wub9PS5FeAByxMoAwDgYDVR0PAQH/BAQDAgEGMEkGA1UdHwRCMEAwPqA8oDqG -OGh0dHA6Ly9jcmwuZC10cnVzdC5uZXQvY3JsL2QtdHJ1c3RfZXZfcm9vdF9jYV8y -XzIwMjMuY3JsMA0GCSqGSIb3DQEBDQUAA4ICAQCTy6UfmRHsmg1fLBWTxj++EI14 -QvBukEdHjqOSMo1wj/Zbjb6JzkcBahsgIIlbyIIQbODnmaprxiqgYzWRaoUlrRc4 -pZt+UPJ26oUFKidBK7GB0aL2QHWpDsvxVUjY7NHss+jOFKE17MJeNRqrphYBBo7q -3C+jisosketSjl8MmxfPy3MHGcRqwnNU73xDUmPBEcrCRbH0O1P1aa4846XerOhU -t7KR/aypH/KH5BfGSah82ApB9PI+53c0BFLd6IHyTS9URZ0V4U/M5d40VxDJI3IX -cI1QcB9WbMy5/zpaT2N6w25lBx2Eof+pDGOJbbJAiDnXH3dotfyc1dZnaVuodNv8 -ifYbMvekJKZ2t0dT741Jj6m2g1qllpBFYfXeA08mD6iL8AOWsKwV0HFaanuU5nCT -2vFp4LJiTZ6P/4mdm13NRemUAiKN4DV/6PEEeXFsVIP4M7kFMhtYVRFP0OUnR3Hs -7dpn1mKmS00PaaLJvOwiS5THaJQXfuKOKD62xur1NGyfN4gHONuGcfrNlUhDbqNP -gofXNJhuS5N5YHVpD/Aa1VP6IQzCP+k/HxiMkl14p3ZnGbuy6n/pcAlWVqOwDAst -Nl7F6cTVg8uGF5csbBNvh1qvSaYd2804BC5f4ko1Di1L+KIkBI3Y4WNeApI02phh -XBxvWHZks/wCuPWdCg== ------END CERTIFICATE----- - -# Issuer: CN=SwissSign RSA TLS Root CA 2022 - 1 O=SwissSign AG -# Subject: CN=SwissSign RSA TLS Root CA 2022 - 1 O=SwissSign AG -# Label: "SwissSign RSA TLS Root CA 2022 - 1" -# Serial: 388078645722908516278762308316089881486363258315 -# MD5 Fingerprint: 16:2e:e4:19:76:81:85:ba:8e:91:58:f1:15:ef:72:39 -# SHA1 Fingerprint: 81:34:0a:be:4c:cd:ce:cc:e7:7d:cc:8a:d4:57:e2:45:a0:77:5d:ce -# SHA256 Fingerprint: 19:31:44:f4:31:e0:fd:db:74:07:17:d4:de:92:6a:57:11:33:88:4b:43:60:d3:0e:27:29:13:cb:e6:60:ce:41 ------BEGIN CERTIFICATE----- -MIIFkzCCA3ugAwIBAgIUQ/oMX04bgBhE79G0TzUfRPSA7cswDQYJKoZIhvcNAQEL -BQAwUTELMAkGA1UEBhMCQ0gxFTATBgNVBAoTDFN3aXNzU2lnbiBBRzErMCkGA1UE -AxMiU3dpc3NTaWduIFJTQSBUTFMgUm9vdCBDQSAyMDIyIC0gMTAeFw0yMjA2MDgx -MTA4MjJaFw00NzA2MDgxMTA4MjJaMFExCzAJBgNVBAYTAkNIMRUwEwYDVQQKEwxT -d2lzc1NpZ24gQUcxKzApBgNVBAMTIlN3aXNzU2lnbiBSU0EgVExTIFJvb3QgQ0Eg -MjAyMiAtIDEwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQDLKmjiC8NX -vDVjvHClO/OMPE5Xlm7DTjak9gLKHqquuN6orx122ro10JFwB9+zBvKK8i5VUXu7 -LCTLf5ImgKO0lPaCoaTo+nUdWfMHamFk4saMla+ju45vVs9xzF6BYQ1t8qsCLqSX -5XH8irCRIFucdFJtrhUnWXjyCcplDn/L9Ovn3KlMd/YrFgSVrpxxpT8q2kFC5zyE -EPThPYxr4iuRR1VPuFa+Rd4iUU1OKNlfGUEGjw5NBuBwQCMBauTLE5tzrE0USJIt -/m2n+IdreXXhvhCxqohAWVTXz8TQm0SzOGlkjIHRI36qOTw7D59Ke4LKa2/KIj4x -0LDQKhySio/YGZxH5D4MucLNvkEM+KRHBdvBFzA4OmnczcNpI/2aDwLOEGrOyvi5 -KaM2iYauC8BPY7kGWUleDsFpswrzd34unYyzJ5jSmY0lpx+Gs6ZUcDj8fV3oT4MM -0ZPlEuRU2j7yrTrePjxF8CgPBrnh25d7mUWe3f6VWQQvdT/TromZhqwUtKiE+shd -OxtYk8EXlFXIC+OCeYSf8wCENO7cMdWP8vpPlkwGqnj73mSiI80fPsWMvDdUDrta -clXvyFu1cvh43zcgTFeRc5JzrBh3Q4IgaezprClG5QtO+DdziZaKHG29777YtvTK -wP1H8K4LWCDFyB02rpeNUIMmJCn3nTsPBQIDAQABo2MwYTAPBgNVHRMBAf8EBTAD -AQH/MA4GA1UdDwEB/wQEAwIBBjAfBgNVHSMEGDAWgBRvjmKLk0Ow4UD2p8P98Q+4 -DxU4pTAdBgNVHQ4EFgQUb45ii5NDsOFA9qfD/fEPuA8VOKUwDQYJKoZIhvcNAQEL -BQADggIBAKwsKUF9+lz1GpUYvyypiqkkVHX1uECry6gkUSsYP2OprphWKwVDIqO3 -10aewCoSPY6WlkDfDDOLazeROpW7OSltwAJsipQLBwJNGD77+3v1dj2b9l4wBlgz -Hqp41eZUBDqyggmNzhYzWUUo8aWjlw5DI/0LIICQ/+Mmz7hkkeUFjxOgdg3XNwwQ -iJb0Pr6VvfHDffCjw3lHC1ySFWPtUnWK50Zpy1FVCypM9fJkT6lc/2cyjlUtMoIc -gC9qkfjLvH4YoiaoLqNTKIftV+Vlek4ASltOU8liNr3CjlvrzG4ngRhZi0Rjn9UM -ZfQpZX+RLOV/fuiJz48gy20HQhFRJjKKLjpHE7iNvUcNCfAWpO2Whi4Z2L6MOuhF -LhG6rlrnub+xzI/goP+4s9GFe3lmozm1O2bYQL7Pt2eLSMkZJVX8vY3PXtpOpvJp -zv1/THfQwUY1mFwjmwJFQ5Ra3bxHrSL+ul4vkSkphnsh3m5kt8sNjzdbowhq6/Td -Ao9QAwKxuDdollDruF/UKIqlIgyKhPBZLtU30WHlQnNYKoH3dtvi4k0NX/a3vgW0 -rk4N3hY9A4GzJl5LuEsAz/+MF7psYC0nhzck5npgL7XTgwSqT0N1osGDsieYK7EO -gLrAhV5Cud+xYJHT6xh+cHiudoO+cVrQkOPKwRYlZ0rwtnu64ZzZ ------END CERTIFICATE----- - -# Issuer: CN=OISTE Server Root ECC G1 O=OISTE Foundation -# Subject: CN=OISTE Server Root ECC G1 O=OISTE Foundation -# Label: "OISTE Server Root ECC G1" -# Serial: 47819833811561661340092227008453318557 -# MD5 Fingerprint: 42:a7:d2:35:ae:02:92:db:19:76:08:de:2f:05:b4:d4 -# SHA1 Fingerprint: 3b:f6:8b:09:ae:2a:92:7b:ba:e3:8d:3f:11:95:d9:e6:44:0c:45:e2 -# SHA256 Fingerprint: ee:c9:97:c0:c3:0f:21:6f:7e:3b:8b:30:7d:2b:ae:42:41:2d:75:3f:c8:21:9d:af:d1:52:0b:25:72:85:0f:49 ------BEGIN CERTIFICATE----- -MIICNTCCAbqgAwIBAgIQI/nD1jWvjyhLH/BU6n6XnTAKBggqhkjOPQQDAzBLMQsw -CQYDVQQGEwJDSDEZMBcGA1UECgwQT0lTVEUgRm91bmRhdGlvbjEhMB8GA1UEAwwY -T0lTVEUgU2VydmVyIFJvb3QgRUNDIEcxMB4XDTIzMDUzMTE0NDIyOFoXDTQ4MDUy -NDE0NDIyN1owSzELMAkGA1UEBhMCQ0gxGTAXBgNVBAoMEE9JU1RFIEZvdW5kYXRp -b24xITAfBgNVBAMMGE9JU1RFIFNlcnZlciBSb290IEVDQyBHMTB2MBAGByqGSM49 -AgEGBSuBBAAiA2IABBcv+hK8rBjzCvRE1nZCnrPoH7d5qVi2+GXROiFPqOujvqQy -cvO2Ackr/XeFblPdreqqLiWStukhEaivtUwL85Zgmjvn6hp4LrQ95SjeHIC6XG4N -2xml4z+cKrhAS93mT6NjMGEwDwYDVR0TAQH/BAUwAwEB/zAfBgNVHSMEGDAWgBQ3 -TYhlz/w9itWj8UnATgwQb0K0nDAdBgNVHQ4EFgQUN02IZc/8PYrVo/FJwE4MEG9C -tJwwDgYDVR0PAQH/BAQDAgGGMAoGCCqGSM49BAMDA2kAMGYCMQCpKjAd0MKfkFFR -QD6VVCHNFmb3U2wIFjnQEnx/Yxvf4zgAOdktUyBFCxxgZzFDJe0CMQCSia7pXGKD -YmH5LVerVrkR3SW+ak5KGoJr3M/TvEqzPNcum9v4KGm8ay3sMaE641c= ------END CERTIFICATE----- - -# Issuer: CN=OISTE Server Root RSA G1 O=OISTE Foundation -# Subject: CN=OISTE Server Root RSA G1 O=OISTE Foundation -# Label: " OISTE Server Root RSA G1" -# Serial: 113845518112613905024960613408179309848 -# MD5 Fingerprint: 23:a7:9e:d4:70:b8:b9:14:57:41:8a:7e:44:59:e2:68 -# SHA1 Fingerprint: f7:00:34:25:94:88:68:31:e4:34:87:3f:70:fe:86:b3:86:9f:f0:6e -# SHA256 Fingerprint: 9a:e3:62:32:a5:18:9f:fd:db:35:3d:fd:26:52:0c:01:53:95:d2:27:77:da:c5:9d:b5:7b:98:c0:89:a6:51:e6 ------BEGIN CERTIFICATE----- -MIIFgzCCA2ugAwIBAgIQVaXZZ5Qoxu0M+ifdWwFNGDANBgkqhkiG9w0BAQwFADBL -MQswCQYDVQQGEwJDSDEZMBcGA1UECgwQT0lTVEUgRm91bmRhdGlvbjEhMB8GA1UE -AwwYT0lTVEUgU2VydmVyIFJvb3QgUlNBIEcxMB4XDTIzMDUzMTE0MzcxNloXDTQ4 -MDUyNDE0MzcxNVowSzELMAkGA1UEBhMCQ0gxGTAXBgNVBAoMEE9JU1RFIEZvdW5k -YXRpb24xITAfBgNVBAMMGE9JU1RFIFNlcnZlciBSb290IFJTQSBHMTCCAiIwDQYJ -KoZIhvcNAQEBBQADggIPADCCAgoCggIBAKqu9KuCz/vlNwvn1ZatkOhLKdxVYOPM -vLO8LZK55KN68YG0nnJyQ98/qwsmtO57Gmn7KNByXEptaZnwYx4M0rH/1ow00O7b -rEi56rAUjtgHqSSY3ekJvqgiG1k50SeH3BzN+Puz6+mTeO0Pzjd8JnduodgsIUzk -ik/HEzxux9UTl7Ko2yRpg1bTacuCErudG/L4NPKYKyqOBGf244ehHa1uzjZ0Dl4z -O8vbUZeUapU8zhhabkvG/AePLhq5SvdkNCncpo1Q4Y2LS+VIG24ugBA/5J8bZT8R -tOpXaZ+0AOuFJJkk9SGdl6r7NH8CaxWQrbueWhl/pIzY+m0o/DjH40ytas7ZTpOS -jswMZ78LS5bOZmdTaMsXEY5Z96ycG7mOaES3GK/m5Q9l3JUJsJMStR8+lKXHiHUh -sd4JJCpM4rzsTGdHwimIuQq6+cF0zowYJmXa92/GjHtoXAvuY8BeS/FOzJ8vD+Ho -mnqT8eDI278n5mUpezbgMxVz8p1rhAhoKzYHKyfMeNhqhw5HdPSqoBNdZH702xSu -+zrkL8Fl47l6QGzwBrd7KJvX4V84c5Ss2XCTLdyEr0YconosP4EmQufU2MVshGYR -i3drVByjtdgQ8K4p92cIiBdcuJd5z+orKu5YM+Vt6SmqZQENghPsJQtdLEByFSnT -kCz3GkPVavBpAgMBAAGjYzBhMA8GA1UdEwEB/wQFMAMBAf8wHwYDVR0jBBgwFoAU -8snBDw1jALvsRQ5KH7WxszbNDo0wHQYDVR0OBBYEFPLJwQ8NYwC77EUOSh+1sbM2 -zQ6NMA4GA1UdDwEB/wQEAwIBhjANBgkqhkiG9w0BAQwFAAOCAgEANGd5sjrG5T33 -I3K5Ce+SrScfoE4KsvXaFwyihdJ+klH9FWXXXGtkFu6KRcoMQzZENdl//nk6HOjG -5D1rd9QhEOP28yBOqb6J8xycqd+8MDoX0TJD0KqKchxRKEzdNsjkLWd9kYccnbz8 -qyiWXmFcuCIzGEgWUOrKL+mlSdx/PKQZvDatkuK59EvV6wit53j+F8Bdh3foZ3dP -AGav9LEDOr4SfEE15fSmG0eLy3n31r8Xbk5l8PjaV8GUgeV6Vg27Rn9vkf195hfk -gSe7BYhW3SCl95gtkRlpMV+bMPKZrXJAlszYd2abtNUOshD+FKrDgHGdPY3ofRRs -YWSGRqbXVMW215AWRqWFyp464+YTFrYVI8ypKVL9AMb2kI5Wj4kI3Zaq5tNqqYY1 -9tVFeEJKRvwDyF7YZvZFZSS0vod7VSCd9521Kvy5YhnLbDuv0204bKt7ph6N/Ome -/msVuduCmsuY33OhkKCgxeDoAaijFJzIwZqsFVAzje18KotzlUBDJvyBpCpfOZC3 -J8tRd/iWkx7P8nd9H0aTolkelUTFLXVksNb54Dxp6gS1HAviRkRNQzuXSXERvSS2 -wq1yVAb+axj5d9spLFKebXd7Yv0PTY6YMjAwcRLWJTXjn/hvnLXrahut6hDTlhZy -BiElxky8j3C7DOReIoMt0r7+hVu05L0= ------END CERTIFICATE----- diff --git a/venv/lib/python3.12/site-packages/certifi/core.py b/venv/lib/python3.12/site-packages/certifi/core.py deleted file mode 100644 index 1c9661c..0000000 --- a/venv/lib/python3.12/site-packages/certifi/core.py +++ /dev/null @@ -1,83 +0,0 @@ -""" -certifi.py -~~~~~~~~~~ - -This module returns the installation location of cacert.pem or its contents. -""" -import sys -import atexit - -def exit_cacert_ctx() -> None: - _CACERT_CTX.__exit__(None, None, None) # type: ignore[union-attr] - - -if sys.version_info >= (3, 11): - - from importlib.resources import as_file, files - - _CACERT_CTX = None - _CACERT_PATH = None - - def where() -> str: - # This is slightly terrible, but we want to delay extracting the file - # in cases where we're inside of a zipimport situation until someone - # actually calls where(), but we don't want to re-extract the file - # on every call of where(), so we'll do it once then store it in a - # global variable. - global _CACERT_CTX - global _CACERT_PATH - if _CACERT_PATH is None: - # This is slightly janky, the importlib.resources API wants you to - # manage the cleanup of this file, so it doesn't actually return a - # path, it returns a context manager that will give you the path - # when you enter it and will do any cleanup when you leave it. In - # the common case of not needing a temporary file, it will just - # return the file system location and the __exit__() is a no-op. - # - # We also have to hold onto the actual context manager, because - # it will do the cleanup whenever it gets garbage collected, so - # we will also store that at the global level as well. - _CACERT_CTX = as_file(files("certifi").joinpath("cacert.pem")) - _CACERT_PATH = str(_CACERT_CTX.__enter__()) - atexit.register(exit_cacert_ctx) - - return _CACERT_PATH - - def contents() -> str: - return files("certifi").joinpath("cacert.pem").read_text(encoding="ascii") - -else: - - from importlib.resources import path as get_path, read_text - - _CACERT_CTX = None - _CACERT_PATH = None - - def where() -> str: - # This is slightly terrible, but we want to delay extracting the - # file in cases where we're inside of a zipimport situation until - # someone actually calls where(), but we don't want to re-extract - # the file on every call of where(), so we'll do it once then store - # it in a global variable. - global _CACERT_CTX - global _CACERT_PATH - if _CACERT_PATH is None: - # This is slightly janky, the importlib.resources API wants you - # to manage the cleanup of this file, so it doesn't actually - # return a path, it returns a context manager that will give - # you the path when you enter it and will do any cleanup when - # you leave it. In the common case of not needing a temporary - # file, it will just return the file system location and the - # __exit__() is a no-op. - # - # We also have to hold onto the actual context manager, because - # it will do the cleanup whenever it gets garbage collected, so - # we will also store that at the global level as well. - _CACERT_CTX = get_path("certifi", "cacert.pem") - _CACERT_PATH = str(_CACERT_CTX.__enter__()) - atexit.register(exit_cacert_ctx) - - return _CACERT_PATH - - def contents() -> str: - return read_text("certifi", "cacert.pem", encoding="ascii") diff --git a/venv/lib/python3.12/site-packages/certifi/py.typed b/venv/lib/python3.12/site-packages/certifi/py.typed deleted file mode 100644 index e69de29..0000000 diff --git a/venv/lib/python3.12/site-packages/charset_normalizer-3.4.4.dist-info/INSTALLER b/venv/lib/python3.12/site-packages/charset_normalizer-3.4.4.dist-info/INSTALLER deleted file mode 100644 index a1b589e..0000000 --- a/venv/lib/python3.12/site-packages/charset_normalizer-3.4.4.dist-info/INSTALLER +++ /dev/null @@ -1 +0,0 @@ -pip diff --git a/venv/lib/python3.12/site-packages/charset_normalizer-3.4.4.dist-info/METADATA b/venv/lib/python3.12/site-packages/charset_normalizer-3.4.4.dist-info/METADATA deleted file mode 100644 index 8d32edc..0000000 --- a/venv/lib/python3.12/site-packages/charset_normalizer-3.4.4.dist-info/METADATA +++ /dev/null @@ -1,764 +0,0 @@ -Metadata-Version: 2.4 -Name: charset-normalizer -Version: 3.4.4 -Summary: The Real First Universal Charset Detector. Open, modern and actively maintained alternative to Chardet. -Author-email: "Ahmed R. TAHRI" -Maintainer-email: "Ahmed R. TAHRI" -License: MIT -Project-URL: Changelog, https://github.com/jawah/charset_normalizer/blob/master/CHANGELOG.md -Project-URL: Documentation, https://charset-normalizer.readthedocs.io/ -Project-URL: Code, https://github.com/jawah/charset_normalizer -Project-URL: Issue tracker, https://github.com/jawah/charset_normalizer/issues -Keywords: encoding,charset,charset-detector,detector,normalization,unicode,chardet,detect -Classifier: Development Status :: 5 - Production/Stable -Classifier: Intended Audience :: Developers -Classifier: Operating System :: OS Independent -Classifier: Programming Language :: Python -Classifier: Programming Language :: Python :: 3 -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 :: 3.11 -Classifier: Programming Language :: Python :: 3.12 -Classifier: Programming Language :: Python :: 3.13 -Classifier: Programming Language :: Python :: 3.14 -Classifier: Programming Language :: Python :: 3 :: Only -Classifier: Programming Language :: Python :: Implementation :: CPython -Classifier: Programming Language :: Python :: Implementation :: PyPy -Classifier: Topic :: Text Processing :: Linguistic -Classifier: Topic :: Utilities -Classifier: Typing :: Typed -Requires-Python: >=3.7 -Description-Content-Type: text/markdown -License-File: LICENSE -Provides-Extra: unicode-backport -Dynamic: license-file - -

Charset Detection, for Everyone 👋

- -

- The Real First Universal Charset Detector
- - - - - Download Count Total - - - - -

-

- Featured Packages
- - Static Badge - - - Static Badge - -

-

- In other language (unofficial port - by the community)
- - Static Badge - -

- -> 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 | ✅ | ✅ | ✅ | -| `License` | LGPL-2.1
_restrictive_ | MIT | MPL-1.1
_restrictive_ | -| `Native Python` | ✅ | ✅ | ❌ | -| `Detect spoken language` | ❌ | ✅ | N/A | -| `UnicodeDecodeError Safety` | ❌ | ✅ | ❌ | -| `Whl Size (min)` | 193.6 kB | 42 kB | ~200 kB | -| `Supported Encoding` | 33 | 🎉 [99](https://charset-normalizer.readthedocs.io/en/latest/user/support.html#supported-encodings) | 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 (ms) | File per sec (est) | -|-----------------------------------------------|:--------:|:------------------:|:------------------:| -| [chardet](https://github.com/chardet/chardet) | 86 % | 63 ms | 16 file/sec | -| charset-normalizer | **98 %** | **10 ms** | 100 file/sec | - -| Package | 99th percentile | 95th percentile | 50th percentile | -|-----------------------------------------------|:---------------:|:---------------:|:---------------:| -| [chardet](https://github.com/chardet/chardet) | 265 ms | 71 ms | 7 ms | -| charset-normalizer | 100 ms | 50 ms | 5 ms | - -_updated as of december 2024 using CPython 3.12_ - -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. -> The actual delays heavily depends on your CPU capabilities. The factors should remain the same. -> Keep in mind that the stats are generous and that Chardet accuracy vs our is measured using Chardet initial capability -> (e.g. Supported Encoding) Challenge-them if you want. - -## ✨ Installation - -Using pip: - -```sh -pip install charset-normalizer -U -``` - -## 🚀 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 -``` - -or - -```bash -python -m charset_normalizer ./data/sample.1.fr.srt -``` - -🎉 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())) -``` - -*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 rendered string.** -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 noise, or the mess once opened (by chunks) with a corresponding charset encoding. - - Extract matches with the lowest mess detected. - - Additionally, we measure coherence / probe for a language. - -**Wait a minute**, what is noise/mess and coherence according to **YOU ?** - -*Noise :* 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 (aka. defining noise in rendered text). - I know that my interpretation of what is noise is probably incomplete, 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. - -## ⚠️ About Python EOLs - -**If you are running:** - -- Python >=2.7,<3.5: Unsupported -- Python 3.5: charset-normalizer < 2.1 -- Python 3.6: charset-normalizer < 3.1 -- Python 3.7: charset-normalizer < 4.0 - -Upgrade your Python interpreter as soon as possible. - -## 👤 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 © [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://simia.net/letters/) - -## 💼 For Enterprise - -Professional support for charset-normalizer is available as part of the [Tidelift -Subscription][1]. 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. - -[1]: https://tidelift.com/subscription/pkg/pypi-charset-normalizer?utm_source=pypi-charset-normalizer&utm_medium=readme - -[![OpenSSF Best Practices](https://www.bestpractices.dev/projects/7297/badge)](https://www.bestpractices.dev/projects/7297) - -# Changelog -All notable changes to charset-normalizer will be documented in this file. This project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html). -The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/). - -## [3.4.4](https://github.com/Ousret/charset_normalizer/compare/3.4.2...3.4.4) (2025-10-13) - -### Changed -- Bound `setuptools` to a specific constraint `setuptools>=68,<=81`. -- Raised upper bound of mypyc for the optional pre-built extension to v1.18.2 - -### Removed -- `setuptools-scm` as a build dependency. - -### Misc -- Enforced hashes in `dev-requirements.txt` and created `ci-requirements.txt` for security purposes. -- Additional pre-built wheels for riscv64, s390x, and armv7l architectures. -- Restore ` multiple.intoto.jsonl` in GitHub releases in addition to individual attestation file per wheel. - -## [3.4.3](https://github.com/Ousret/charset_normalizer/compare/3.4.2...3.4.3) (2025-08-09) - -### Changed -- mypy(c) is no longer a required dependency at build time if `CHARSET_NORMALIZER_USE_MYPYC` isn't set to `1`. (#595) (#583) -- automatically lower confidence on small bytes samples that are not Unicode in `detect` output legacy function. (#391) - -### Added -- Custom build backend to overcome inability to mark mypy as an optional dependency in the build phase. -- Support for Python 3.14 - -### Fixed -- sdist archive contained useless directories. -- automatically fallback on valid UTF-16 or UTF-32 even if the md says it's noisy. (#633) - -### Misc -- SBOM are automatically published to the relevant GitHub release to comply with regulatory changes. - Each published wheel comes with its SBOM. We choose CycloneDX as the format. -- Prebuilt optimized wheel are no longer distributed by default for CPython 3.7 due to a change in cibuildwheel. - -## [3.4.2](https://github.com/Ousret/charset_normalizer/compare/3.4.1...3.4.2) (2025-05-02) - -### Fixed -- Addressed the DeprecationWarning in our CLI regarding `argparse.FileType` by backporting the target class into the package. (#591) -- Improved the overall reliability of the detector with CJK Ideographs. (#605) (#587) - -### Changed -- Optional mypyc compilation upgraded to version 1.15 for Python >= 3.8 - -## [3.4.1](https://github.com/Ousret/charset_normalizer/compare/3.4.0...3.4.1) (2024-12-24) - -### Changed -- Project metadata are now stored using `pyproject.toml` instead of `setup.cfg` using setuptools as the build backend. -- Enforce annotation delayed loading for a simpler and consistent types in the project. -- Optional mypyc compilation upgraded to version 1.14 for Python >= 3.8 - -### Added -- pre-commit configuration. -- noxfile. - -### Removed -- `build-requirements.txt` as per using `pyproject.toml` native build configuration. -- `bin/integration.py` and `bin/serve.py` in favor of downstream integration test (see noxfile). -- `setup.cfg` in favor of `pyproject.toml` metadata configuration. -- Unused `utils.range_scan` function. - -### Fixed -- Converting content to Unicode bytes may insert `utf_8` instead of preferred `utf-8`. (#572) -- Deprecation warning "'count' is passed as positional argument" when converting to Unicode bytes on Python 3.13+ - -## [3.4.0](https://github.com/Ousret/charset_normalizer/compare/3.3.2...3.4.0) (2024-10-08) - -### Added -- Argument `--no-preemptive` in the CLI to prevent the detector to search for hints. -- Support for Python 3.13 (#512) - -### Fixed -- Relax the TypeError exception thrown when trying to compare a CharsetMatch with anything else than a CharsetMatch. -- Improved the general reliability of the detector based on user feedbacks. (#520) (#509) (#498) (#407) (#537) -- Declared charset in content (preemptive detection) not changed when converting to utf-8 bytes. (#381) - -## [3.3.2](https://github.com/Ousret/charset_normalizer/compare/3.3.1...3.3.2) (2023-10-31) - -### Fixed -- Unintentional memory usage regression when using large payload that match several encoding (#376) -- Regression on some detection case showcased in the documentation (#371) - -### Added -- Noise (md) probe that identify malformed arabic representation due to the presence of letters in isolated form (credit to my wife) - -## [3.3.1](https://github.com/Ousret/charset_normalizer/compare/3.3.0...3.3.1) (2023-10-22) - -### Changed -- Optional mypyc compilation upgraded to version 1.6.1 for Python >= 3.8 -- Improved the general detection reliability based on reports from the community - -## [3.3.0](https://github.com/Ousret/charset_normalizer/compare/3.2.0...3.3.0) (2023-09-30) - -### Added -- Allow to execute the CLI (e.g. normalizer) through `python -m charset_normalizer.cli` or `python -m charset_normalizer` -- Support for 9 forgotten encoding that are supported by Python but unlisted in `encoding.aliases` as they have no alias (#323) - -### Removed -- (internal) Redundant utils.is_ascii function and unused function is_private_use_only -- (internal) charset_normalizer.assets is moved inside charset_normalizer.constant - -### Changed -- (internal) Unicode code blocks in constants are updated using the latest v15.0.0 definition to improve detection -- Optional mypyc compilation upgraded to version 1.5.1 for Python >= 3.8 - -### Fixed -- Unable to properly sort CharsetMatch when both chaos/noise and coherence were close due to an unreachable condition in \_\_lt\_\_ (#350) - -## [3.2.0](https://github.com/Ousret/charset_normalizer/compare/3.1.0...3.2.0) (2023-06-07) - -### Changed -- Typehint for function `from_path` no longer enforce `PathLike` as its first argument -- Minor improvement over the global detection reliability - -### Added -- Introduce function `is_binary` that relies on main capabilities, and optimized to detect binaries -- Propagate `enable_fallback` argument throughout `from_bytes`, `from_path`, and `from_fp` that allow a deeper control over the detection (default True) -- Explicit support for Python 3.12 - -### Fixed -- Edge case detection failure where a file would contain 'very-long' camel cased word (Issue #289) - -## [3.1.0](https://github.com/Ousret/charset_normalizer/compare/3.0.1...3.1.0) (2023-03-06) - -### Added -- Argument `should_rename_legacy` for legacy function `detect` and disregard any new arguments without errors (PR #262) - -### Removed -- Support for Python 3.6 (PR #260) - -### Changed -- Optional speedup provided by mypy/c 1.0.1 - -## [3.0.1](https://github.com/Ousret/charset_normalizer/compare/3.0.0...3.0.1) (2022-11-18) - -### Fixed -- Multi-bytes cutter/chunk generator did not always cut correctly (PR #233) - -### Changed -- Speedup provided by mypy/c 0.990 on Python >= 3.7 - -## [3.0.0](https://github.com/Ousret/charset_normalizer/compare/2.1.1...3.0.0) (2022-10-20) - -### Added -- Extend the capability of explain=True when cp_isolation contains at most two entries (min one), will log in details of the Mess-detector results -- Support for alternative language frequency set in charset_normalizer.assets.FREQUENCIES -- Add parameter `language_threshold` in `from_bytes`, `from_path` and `from_fp` to adjust the minimum expected coherence ratio -- `normalizer --version` now specify if current version provide extra speedup (meaning mypyc compilation whl) - -### Changed -- Build with static metadata using 'build' frontend -- Make the language detection stricter -- Optional: Module `md.py` can be compiled using Mypyc to provide an extra speedup up to 4x faster than v2.1 - -### Fixed -- CLI with opt --normalize fail when using full path for files -- TooManyAccentuatedPlugin induce false positive on the mess detection when too few alpha character have been fed to it -- Sphinx warnings when generating the documentation - -### Removed -- Coherence detector no longer return 'Simple English' instead return 'English' -- Coherence detector no longer return 'Classical Chinese' instead return 'Chinese' -- Breaking: Method `first()` and `best()` from CharsetMatch -- UTF-7 will no longer appear as "detected" without a recognized SIG/mark (is unreliable/conflict with ASCII) -- Breaking: Class aliases CharsetDetector, CharsetDoctor, CharsetNormalizerMatch and CharsetNormalizerMatches -- Breaking: Top-level function `normalize` -- Breaking: Properties `chaos_secondary_pass`, `coherence_non_latin` and `w_counter` from CharsetMatch -- Support for the backport `unicodedata2` - -## [3.0.0rc1](https://github.com/Ousret/charset_normalizer/compare/3.0.0b2...3.0.0rc1) (2022-10-18) - -### Added -- Extend the capability of explain=True when cp_isolation contains at most two entries (min one), will log in details of the Mess-detector results -- Support for alternative language frequency set in charset_normalizer.assets.FREQUENCIES -- Add parameter `language_threshold` in `from_bytes`, `from_path` and `from_fp` to adjust the minimum expected coherence ratio - -### Changed -- Build with static metadata using 'build' frontend -- Make the language detection stricter - -### Fixed -- CLI with opt --normalize fail when using full path for files -- TooManyAccentuatedPlugin induce false positive on the mess detection when too few alpha character have been fed to it - -### Removed -- Coherence detector no longer return 'Simple English' instead return 'English' -- Coherence detector no longer return 'Classical Chinese' instead return 'Chinese' - -## [3.0.0b2](https://github.com/Ousret/charset_normalizer/compare/3.0.0b1...3.0.0b2) (2022-08-21) - -### Added -- `normalizer --version` now specify if current version provide extra speedup (meaning mypyc compilation whl) - -### Removed -- Breaking: Method `first()` and `best()` from CharsetMatch -- UTF-7 will no longer appear as "detected" without a recognized SIG/mark (is unreliable/conflict with ASCII) - -### Fixed -- Sphinx warnings when generating the documentation - -## [3.0.0b1](https://github.com/Ousret/charset_normalizer/compare/2.1.0...3.0.0b1) (2022-08-15) - -### Changed -- Optional: Module `md.py` can be compiled using Mypyc to provide an extra speedup up to 4x faster than v2.1 - -### Removed -- Breaking: Class aliases CharsetDetector, CharsetDoctor, CharsetNormalizerMatch and CharsetNormalizerMatches -- Breaking: Top-level function `normalize` -- Breaking: Properties `chaos_secondary_pass`, `coherence_non_latin` and `w_counter` from CharsetMatch -- Support for the backport `unicodedata2` - -## [2.1.1](https://github.com/Ousret/charset_normalizer/compare/2.1.0...2.1.1) (2022-08-19) - -### Deprecated -- Function `normalize` scheduled for removal in 3.0 - -### Changed -- Removed useless call to decode in fn is_unprintable (#206) - -### Fixed -- Third-party library (i18n xgettext) crashing not recognizing utf_8 (PEP 263) with underscore from [@aleksandernovikov](https://github.com/aleksandernovikov) (#204) - -## [2.1.0](https://github.com/Ousret/charset_normalizer/compare/2.0.12...2.1.0) (2022-06-19) - -### Added -- Output the Unicode table version when running the CLI with `--version` (PR #194) - -### Changed -- Re-use decoded buffer for single byte character sets from [@nijel](https://github.com/nijel) (PR #175) -- Fixing some performance bottlenecks from [@deedy5](https://github.com/deedy5) (PR #183) - -### Fixed -- Workaround potential bug in cpython with Zero Width No-Break Space located in Arabic Presentation Forms-B, Unicode 1.1 not acknowledged as space (PR #175) -- CLI default threshold aligned with the API threshold from [@oleksandr-kuzmenko](https://github.com/oleksandr-kuzmenko) (PR #181) - -### Removed -- Support for Python 3.5 (PR #192) - -### Deprecated -- Use of backport unicodedata from `unicodedata2` as Python is quickly catching up, scheduled for removal in 3.0 (PR #194) - -## [2.0.12](https://github.com/Ousret/charset_normalizer/compare/2.0.11...2.0.12) (2022-02-12) - -### Fixed -- ASCII miss-detection on rare cases (PR #170) - -## [2.0.11](https://github.com/Ousret/charset_normalizer/compare/2.0.10...2.0.11) (2022-01-30) - -### Added -- Explicit support for Python 3.11 (PR #164) - -### Changed -- The logging behavior have been completely reviewed, now using only TRACE and DEBUG levels (PR #163 #165) - -## [2.0.10](https://github.com/Ousret/charset_normalizer/compare/2.0.9...2.0.10) (2022-01-04) - -### Fixed -- Fallback match entries might lead to UnicodeDecodeError for large bytes sequence (PR #154) - -### Changed -- Skipping the language-detection (CD) on ASCII (PR #155) - -## [2.0.9](https://github.com/Ousret/charset_normalizer/compare/2.0.8...2.0.9) (2021-12-03) - -### Changed -- Moderating the logging impact (since 2.0.8) for specific environments (PR #147) - -### Fixed -- Wrong logging level applied when setting kwarg `explain` to True (PR #146) - -## [2.0.8](https://github.com/Ousret/charset_normalizer/compare/2.0.7...2.0.8) (2021-11-24) -### Changed -- Improvement over Vietnamese detection (PR #126) -- MD improvement on trailing data and long foreign (non-pure latin) data (PR #124) -- Efficiency improvements in cd/alphabet_languages from [@adbar](https://github.com/adbar) (PR #122) -- call sum() without an intermediary list following PEP 289 recommendations from [@adbar](https://github.com/adbar) (PR #129) -- Code style as refactored by Sourcery-AI (PR #131) -- Minor adjustment on the MD around european words (PR #133) -- Remove and replace SRTs from assets / tests (PR #139) -- Initialize the library logger with a `NullHandler` by default from [@nmaynes](https://github.com/nmaynes) (PR #135) -- Setting kwarg `explain` to True will add provisionally (bounded to function lifespan) a specific stream handler (PR #135) - -### Fixed -- Fix large (misleading) sequence giving UnicodeDecodeError (PR #137) -- Avoid using too insignificant chunk (PR #137) - -### Added -- Add and expose function `set_logging_handler` to configure a specific StreamHandler from [@nmaynes](https://github.com/nmaynes) (PR #135) -- Add `CHANGELOG.md` entries, format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/) (PR #141) - -## [2.0.7](https://github.com/Ousret/charset_normalizer/compare/2.0.6...2.0.7) (2021-10-11) -### Added -- Add support for Kazakh (Cyrillic) language detection (PR #109) - -### Changed -- Further, improve inferring the language from a given single-byte code page (PR #112) -- Vainly trying to leverage PEP263 when PEP3120 is not supported (PR #116) -- Refactoring for potential performance improvements in loops from [@adbar](https://github.com/adbar) (PR #113) -- Various detection improvement (MD+CD) (PR #117) - -### Removed -- Remove redundant logging entry about detected language(s) (PR #115) - -### Fixed -- Fix a minor inconsistency between Python 3.5 and other versions regarding language detection (PR #117 #102) - -## [2.0.6](https://github.com/Ousret/charset_normalizer/compare/2.0.5...2.0.6) (2021-09-18) -### Fixed -- Unforeseen regression with the loss of the backward-compatibility with some older minor of Python 3.5.x (PR #100) -- Fix CLI crash when using --minimal output in certain cases (PR #103) - -### Changed -- Minor improvement to the detection efficiency (less than 1%) (PR #106 #101) - -## [2.0.5](https://github.com/Ousret/charset_normalizer/compare/2.0.4...2.0.5) (2021-09-14) -### Changed -- The project now comply with: flake8, mypy, isort and black to ensure a better overall quality (PR #81) -- The BC-support with v1.x was improved, the old staticmethods are restored (PR #82) -- The Unicode detection is slightly improved (PR #93) -- Add syntax sugar \_\_bool\_\_ for results CharsetMatches list-container (PR #91) - -### Removed -- The project no longer raise warning on tiny content given for detection, will be simply logged as warning instead (PR #92) - -### Fixed -- In some rare case, the chunks extractor could cut in the middle of a multi-byte character and could mislead the mess detection (PR #95) -- Some rare 'space' characters could trip up the UnprintablePlugin/Mess detection (PR #96) -- The MANIFEST.in was not exhaustive (PR #78) - -## [2.0.4](https://github.com/Ousret/charset_normalizer/compare/2.0.3...2.0.4) (2021-07-30) -### Fixed -- The CLI no longer raise an unexpected exception when no encoding has been found (PR #70) -- Fix accessing the 'alphabets' property when the payload contains surrogate characters (PR #68) -- The logger could mislead (explain=True) on detected languages and the impact of one MBCS match (PR #72) -- Submatch factoring could be wrong in rare edge cases (PR #72) -- Multiple files given to the CLI were ignored when publishing results to STDOUT. (After the first path) (PR #72) -- Fix line endings from CRLF to LF for certain project files (PR #67) - -### Changed -- Adjust the MD to lower the sensitivity, thus improving the global detection reliability (PR #69 #76) -- Allow fallback on specified encoding if any (PR #71) - -## [2.0.3](https://github.com/Ousret/charset_normalizer/compare/2.0.2...2.0.3) (2021-07-16) -### Changed -- Part of the detection mechanism has been improved to be less sensitive, resulting in more accurate detection results. Especially ASCII. (PR #63) -- According to the community wishes, the detection will fall back on ASCII or UTF-8 in a last-resort case. (PR #64) - -## [2.0.2](https://github.com/Ousret/charset_normalizer/compare/2.0.1...2.0.2) (2021-07-15) -### Fixed -- Empty/Too small JSON payload miss-detection fixed. Report from [@tseaver](https://github.com/tseaver) (PR #59) - -### Changed -- Don't inject unicodedata2 into sys.modules from [@akx](https://github.com/akx) (PR #57) - -## [2.0.1](https://github.com/Ousret/charset_normalizer/compare/2.0.0...2.0.1) (2021-07-13) -### Fixed -- Make it work where there isn't a filesystem available, dropping assets frequencies.json. Report from [@sethmlarson](https://github.com/sethmlarson). (PR #55) -- Using explain=False permanently disable the verbose output in the current runtime (PR #47) -- One log entry (language target preemptive) was not show in logs when using explain=True (PR #47) -- Fix undesired exception (ValueError) on getitem of instance CharsetMatches (PR #52) - -### Changed -- Public function normalize default args values were not aligned with from_bytes (PR #53) - -### Added -- You may now use charset aliases in cp_isolation and cp_exclusion arguments (PR #47) - -## [2.0.0](https://github.com/Ousret/charset_normalizer/compare/1.4.1...2.0.0) (2021-07-02) -### Changed -- 4x to 5 times faster than the previous 1.4.0 release. At least 2x faster than Chardet. -- Accent has been made on UTF-8 detection, should perform rather instantaneous. -- The backward compatibility with Chardet has been greatly improved. The legacy detect function returns an identical charset name whenever possible. -- The detection mechanism has been slightly improved, now Turkish content is detected correctly (most of the time) -- The program has been rewritten to ease the readability and maintainability. (+Using static typing)+ -- utf_7 detection has been reinstated. - -### Removed -- This package no longer require anything when used with Python 3.5 (Dropped cached_property) -- Removed support for these languages: Catalan, Esperanto, Kazakh, Baque, Volapük, Azeri, Galician, Nynorsk, Macedonian, and Serbocroatian. -- The exception hook on UnicodeDecodeError has been removed. - -### Deprecated -- Methods coherence_non_latin, w_counter, chaos_secondary_pass of the class CharsetMatch are now deprecated and scheduled for removal in v3.0 - -### Fixed -- The CLI output used the relative path of the file(s). Should be absolute. - -## [1.4.1](https://github.com/Ousret/charset_normalizer/compare/1.4.0...1.4.1) (2021-05-28) -### Fixed -- Logger configuration/usage no longer conflict with others (PR #44) - -## [1.4.0](https://github.com/Ousret/charset_normalizer/compare/1.3.9...1.4.0) (2021-05-21) -### Removed -- Using standard logging instead of using the package loguru. -- Dropping nose test framework in favor of the maintained pytest. -- Choose to not use dragonmapper package to help with gibberish Chinese/CJK text. -- Require cached_property only for Python 3.5 due to constraint. Dropping for every other interpreter version. -- Stop support for UTF-7 that does not contain a SIG. -- Dropping PrettyTable, replaced with pure JSON output in CLI. - -### Fixed -- BOM marker in a CharsetNormalizerMatch instance could be False in rare cases even if obviously present. Due to the sub-match factoring process. -- Not searching properly for the BOM when trying utf32/16 parent codec. - -### Changed -- Improving the package final size by compressing frequencies.json. -- Huge improvement over the larges payload. - -### Added -- CLI now produces JSON consumable output. -- Return ASCII if given sequences fit. Given reasonable confidence. - -## [1.3.9](https://github.com/Ousret/charset_normalizer/compare/1.3.8...1.3.9) (2021-05-13) - -### Fixed -- In some very rare cases, you may end up getting encode/decode errors due to a bad bytes payload (PR #40) - -## [1.3.8](https://github.com/Ousret/charset_normalizer/compare/1.3.7...1.3.8) (2021-05-12) - -### Fixed -- Empty given payload for detection may cause an exception if trying to access the `alphabets` property. (PR #39) - -## [1.3.7](https://github.com/Ousret/charset_normalizer/compare/1.3.6...1.3.7) (2021-05-12) - -### Fixed -- The legacy detect function should return UTF-8-SIG if sig is present in the payload. (PR #38) - -## [1.3.6](https://github.com/Ousret/charset_normalizer/compare/1.3.5...1.3.6) (2021-02-09) - -### Changed -- Amend the previous release to allow prettytable 2.0 (PR #35) - -## [1.3.5](https://github.com/Ousret/charset_normalizer/compare/1.3.4...1.3.5) (2021-02-08) - -### Fixed -- Fix error while using the package with a python pre-release interpreter (PR #33) - -### Changed -- Dependencies refactoring, constraints revised. - -### Added -- Add python 3.9 and 3.10 to the supported interpreters - -MIT License - -Copyright (c) 2025 TAHRI Ahmed R. - -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.12/site-packages/charset_normalizer-3.4.4.dist-info/RECORD b/venv/lib/python3.12/site-packages/charset_normalizer-3.4.4.dist-info/RECORD deleted file mode 100644 index ad5c799..0000000 --- a/venv/lib/python3.12/site-packages/charset_normalizer-3.4.4.dist-info/RECORD +++ /dev/null @@ -1,35 +0,0 @@ -../../../bin/normalizer,sha256=3qqhpv1hZYG7lBFVE402xPwSeHXivpAElqFrsGv2Ano,273 -charset_normalizer-3.4.4.dist-info/INSTALLER,sha256=zuuue4knoyJ-UwPPXg8fezS7VCrXJQrAP7zeNuwvFQg,4 -charset_normalizer-3.4.4.dist-info/METADATA,sha256=jVuUFBti8dav19YLvWissTihVdF2ozUY4KKMw7jdkBQ,37303 -charset_normalizer-3.4.4.dist-info/RECORD,, -charset_normalizer-3.4.4.dist-info/WHEEL,sha256=DxRnWQz-Kp9-4a4hdDHsSv0KUC3H7sN9Nbef3-8RjXU,190 -charset_normalizer-3.4.4.dist-info/entry_points.txt,sha256=ADSTKrkXZ3hhdOVFi6DcUEHQRS0xfxDIE_pEz4wLIXA,65 -charset_normalizer-3.4.4.dist-info/licenses/LICENSE,sha256=bQ1Bv-FwrGx9wkjJpj4lTQ-0WmDVCoJX0K-SxuJJuIc,1071 -charset_normalizer-3.4.4.dist-info/top_level.txt,sha256=7ASyzePr8_xuZWJsnqJjIBtyV8vhEo0wBCv1MPRRi3Q,19 -charset_normalizer/__init__.py,sha256=OKRxRv2Zhnqk00tqkN0c1BtJjm165fWXLydE52IKuHc,1590 -charset_normalizer/__main__.py,sha256=yzYxMR-IhKRHYwcSlavEv8oGdwxsR89mr2X09qXGdps,109 -charset_normalizer/__pycache__/__init__.cpython-312.pyc,, -charset_normalizer/__pycache__/__main__.cpython-312.pyc,, -charset_normalizer/__pycache__/api.cpython-312.pyc,, -charset_normalizer/__pycache__/cd.cpython-312.pyc,, -charset_normalizer/__pycache__/constant.cpython-312.pyc,, -charset_normalizer/__pycache__/legacy.cpython-312.pyc,, -charset_normalizer/__pycache__/md.cpython-312.pyc,, -charset_normalizer/__pycache__/models.cpython-312.pyc,, -charset_normalizer/__pycache__/utils.cpython-312.pyc,, -charset_normalizer/__pycache__/version.cpython-312.pyc,, -charset_normalizer/api.py,sha256=V07i8aVeCD8T2fSia3C-fn0i9t8qQguEBhsqszg32Ns,22668 -charset_normalizer/cd.py,sha256=WKTo1HDb-H9HfCDc3Bfwq5jzS25Ziy9SE2a74SgTq88,12522 -charset_normalizer/cli/__init__.py,sha256=D8I86lFk2-py45JvqxniTirSj_sFyE6sjaY_0-G1shc,136 -charset_normalizer/cli/__main__.py,sha256=dMaXG6IJXRvqq8z2tig7Qb83-BpWTln55ooiku5_uvg,12646 -charset_normalizer/cli/__pycache__/__init__.cpython-312.pyc,, -charset_normalizer/cli/__pycache__/__main__.cpython-312.pyc,, -charset_normalizer/constant.py,sha256=7UVY4ldYhmQMHUdgQ_sgZmzcQ0xxYxpBunqSZ-XJZ8U,42713 -charset_normalizer/legacy.py,sha256=sYBzSpzsRrg_wF4LP536pG64BItw7Tqtc3SMQAHvFLM,2731 -charset_normalizer/md.cpython-312-x86_64-linux-gnu.so,sha256=sZ7umtJLjKfA83NFJ7npkiDyr06zDT8cWtl6uIx2MsM,15912 -charset_normalizer/md.py,sha256=-_oN3h3_X99nkFfqamD3yu45DC_wfk5odH0Tr_CQiXs,20145 -charset_normalizer/md__mypyc.cpython-312-x86_64-linux-gnu.so,sha256=J2WWgLBQiO8sqdFsENp9u5V9uEH0tTwvTLszPdqhsv0,290584 -charset_normalizer/models.py,sha256=lKXhOnIPtiakbK3i__J9wpOfzx3JDTKj7Dn3Rg0VaRI,12394 -charset_normalizer/py.typed,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -charset_normalizer/utils.py,sha256=sTejPgrdlNsKNucZfJCxJ95lMTLA0ShHLLE3n5wpT9Q,12170 -charset_normalizer/version.py,sha256=nKE4qBNk5WA4LIJ_yIH_aSDfvtsyizkWMg-PUG-UZVk,115 diff --git a/venv/lib/python3.12/site-packages/charset_normalizer-3.4.4.dist-info/WHEEL b/venv/lib/python3.12/site-packages/charset_normalizer-3.4.4.dist-info/WHEEL deleted file mode 100644 index f3e8a97..0000000 --- a/venv/lib/python3.12/site-packages/charset_normalizer-3.4.4.dist-info/WHEEL +++ /dev/null @@ -1,7 +0,0 @@ -Wheel-Version: 1.0 -Generator: setuptools (80.9.0) -Root-Is-Purelib: false -Tag: cp312-cp312-manylinux_2_17_x86_64 -Tag: cp312-cp312-manylinux2014_x86_64 -Tag: cp312-cp312-manylinux_2_28_x86_64 - diff --git a/venv/lib/python3.12/site-packages/charset_normalizer-3.4.4.dist-info/entry_points.txt b/venv/lib/python3.12/site-packages/charset_normalizer-3.4.4.dist-info/entry_points.txt deleted file mode 100644 index 65619e7..0000000 --- a/venv/lib/python3.12/site-packages/charset_normalizer-3.4.4.dist-info/entry_points.txt +++ /dev/null @@ -1,2 +0,0 @@ -[console_scripts] -normalizer = charset_normalizer.cli:cli_detect diff --git a/venv/lib/python3.12/site-packages/charset_normalizer-3.4.4.dist-info/licenses/LICENSE b/venv/lib/python3.12/site-packages/charset_normalizer-3.4.4.dist-info/licenses/LICENSE deleted file mode 100644 index 9725772..0000000 --- a/venv/lib/python3.12/site-packages/charset_normalizer-3.4.4.dist-info/licenses/LICENSE +++ /dev/null @@ -1,21 +0,0 @@ -MIT License - -Copyright (c) 2025 TAHRI Ahmed R. - -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.12/site-packages/charset_normalizer-3.4.4.dist-info/top_level.txt b/venv/lib/python3.12/site-packages/charset_normalizer-3.4.4.dist-info/top_level.txt deleted file mode 100644 index 66958f0..0000000 --- a/venv/lib/python3.12/site-packages/charset_normalizer-3.4.4.dist-info/top_level.txt +++ /dev/null @@ -1 +0,0 @@ -charset_normalizer diff --git a/venv/lib/python3.12/site-packages/charset_normalizer/__init__.py b/venv/lib/python3.12/site-packages/charset_normalizer/__init__.py deleted file mode 100644 index 0d3a379..0000000 --- a/venv/lib/python3.12/site-packages/charset_normalizer/__init__.py +++ /dev/null @@ -1,48 +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')) - >>> best_guess = results.best() - >>> str(best_guess) - '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 __future__ import annotations - -import logging - -from .api import from_bytes, from_fp, from_path, is_binary -from .legacy import detect -from .models import CharsetMatch, CharsetMatches -from .utils import set_logging_handler -from .version import VERSION, __version__ - -__all__ = ( - "from_fp", - "from_path", - "from_bytes", - "is_binary", - "detect", - "CharsetMatch", - "CharsetMatches", - "__version__", - "VERSION", - "set_logging_handler", -) - -# Attach a NullHandler to the top level logger by default -# https://docs.python.org/3.3/howto/logging.html#configuring-logging-for-a-library - -logging.getLogger("charset_normalizer").addHandler(logging.NullHandler()) diff --git a/venv/lib/python3.12/site-packages/charset_normalizer/__main__.py b/venv/lib/python3.12/site-packages/charset_normalizer/__main__.py deleted file mode 100644 index e0e76f7..0000000 --- a/venv/lib/python3.12/site-packages/charset_normalizer/__main__.py +++ /dev/null @@ -1,6 +0,0 @@ -from __future__ import annotations - -from .cli import cli_detect - -if __name__ == "__main__": - cli_detect() diff --git a/venv/lib/python3.12/site-packages/charset_normalizer/__pycache__/__init__.cpython-312.pyc b/venv/lib/python3.12/site-packages/charset_normalizer/__pycache__/__init__.cpython-312.pyc deleted file mode 100644 index 95dd4d836d52c1231b878a1a8fb342a10c12323d..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1783 zcmcIk&1)M+6rYu3$zIt`ZBq(`(kX@5YHe*|Lt8{@P#hZzVmmla4|`cgyJPLfvmeaN z%2f`<&85d4`!|$a+(M`+t@{V`vceR@LdYS9lAA;5C8xgGm8_KH+C98|Z)Vc%6GbIeaQqE{E6JUNo4l9i8tN5mlkvkMLi(CZxS(=rJLEoL-UG_@ zZ~pV?doIPhlrX&EaUt=&!0S>jKpv>#TU1h8hPfk=Ugy61W$}m{a0l zNxznOpNBps0gi)%AUq7Po%_c$utUcSI(2<3lwOxe>fm-SyLPBt#CxtMa763_(xDhw z$$Rh`%Mfgfkaa1zR2L$qN>7plbxm+U4>5@%9unIHfQ;c*bGw<@CAOp-L-05tJ{5RB z-tS1JR8RXFgA3I@#^Yo z9`GPaE4a)u_I#z5U0dy*q++N5@x)9D{N-zR3-dSo-zJZfUy~Eu|1LRAepUibPLkh} zW1RfaKT3|_>=Y-zEBQ3}DLeTkdwC3pC&}YF-g(<`|6y|a(R@A2KV6uQ<-YaBe62P_ z)22dNotO#*XaKFQ4i_$;2+0>l&$8qH8?LVJK)JcVK7}edP>I0F^PU%lbcx4En^C+3 z1H5&Id(F+=mfm2VO#?w2c&oLym;t!mT3g?~yPox!uUZP48X$_g z{#*@bO-rjJ2*Mnf*nY02yjDteH7ZiHLO52~SvUFMx>y3uUkggIFu1 zlY`ORBGPu#>DMJH;N=`Ny~V;#2WG@_A$N>&P^)~kzI(T|vz=BgOU*c>$g*lWhsB6^ zMUgQ@#ub@RMD0#qRb*O`DMcoMq_c14uJ&G9u`I~HWu>}h?Z-0a)Ur4%A(U1IVA3Lq zyxhyksq&YW8SN0em-$W0KFl8zBme1GEFqh@^U45wjz=L=o(W^%d7?w*Z3vw5R40zJ zna7@1x1l)(!jI@BsGwJ_;f6jnIDxeUpu+fpaf^xr8Ae8vcS*3+ywh4*W1i8aLDzuA zXGGb`SgBuMHiReX(qLVQw{((WSzh2t%c@7cSK~Jzo|w^9{vkM4r5E>rTog4;dr_Fv zO8Az9q3^ksh_n)F`Ptet;sCH4RRtra!3yiecqslp&>7$us_Uaj$KS#@b aw4AJL9Djbkve94JI9u8L3$^$MVEJEGVqbp% diff --git a/venv/lib/python3.12/site-packages/charset_normalizer/__pycache__/__main__.cpython-312.pyc b/venv/lib/python3.12/site-packages/charset_normalizer/__pycache__/__main__.cpython-312.pyc deleted file mode 100644 index 8041900f73f200058b017dd37d7e5eba28bce511..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 358 zcmXv}Jxc>Y5S_iflaLTQ3l$qHQzVNDRw4v#1QF{r%X+(dOZMZ~+Y4NJ!Ok+jLHsFp zb{+_VSfmT2OXVIhub6pn<_$CR-tD#_V28X&9r8~jHi*^)Ezbg(0SAs0Xf#3yc*L=a zG#+6DBIfb<2*9->5cutX8bOs*NpEZ3=pL#&%oyvLm(~<>w63*NB`FtPq`q!Zs+lyD z-u9BZP3c4FOD8CGICyIuoGxit@EN8<;}w=c!zv@0)q*(2rOBnU<&<2BV(e{BhHk=4 ze|UG@zf_V;gqaW}?@32WA-Qtl4i^m!c$|NW=c+lBb%!Rd9`Yt tYs*U|E?hS(Zhj~ZLResg&=(y3!u~hzJWoIH?q|IHbhE$^@3~HJ`~eRSVo(48 diff --git a/venv/lib/python3.12/site-packages/charset_normalizer/__pycache__/api.cpython-312.pyc b/venv/lib/python3.12/site-packages/charset_normalizer/__pycache__/api.cpython-312.pyc deleted file mode 100644 index 26667e003e6a480aedc51fca2a670dd6875e37f7..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 18194 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 mu%sb_B@G!YX~lNFJ=qWhB_G49hU@ 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 T?%GW^^2u-;K6fBR4Z{BeBIP=8 diff --git a/venv/lib/python3.12/site-packages/charset_normalizer/__pycache__/constant.cpython-312.pyc b/venv/lib/python3.12/site-packages/charset_normalizer/__pycache__/constant.cpython-312.pyc deleted file mode 100644 index b9f289661b89b9e093d70add6ba832a5a753504e..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 40813 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≺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 diff --git a/venv/lib/python3.12/site-packages/charset_normalizer/__pycache__/models.cpython-312.pyc b/venv/lib/python3.12/site-packages/charset_normalizer/__pycache__/models.cpython-312.pyc deleted file mode 100644 index f4db722485cd5c1eecfebf95333d339be966a439..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 17130 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 P3eG{J@Ua8(=wbOkz?~ze diff --git a/venv/lib/python3.12/site-packages/charset_normalizer/__pycache__/version.cpython-312.pyc b/venv/lib/python3.12/site-packages/charset_normalizer/__pycache__/version.cpython-312.pyc deleted file mode 100644 index 3b5782ba08b12179158644414f5ab35d0da57e57..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 385 zcmYLEzfZzI6z;VY@EVK@6AOth4D_Nf8Dm0_fd!2w4qYxMJ>jJ7HFwuWnDj4j)PKSF zr#Kl0O(zp4Hw|%N@+uPF@ZR^m_q|__l?pVpRnZNTI=<&*W!4ga`K|`HhHrR=4}3EK zq3M~x@GZ}x*2UUN{vZ9q16VT8p4yG#YyM$0GUIgh%2IWPR{I> z+jiRv;0_watc0=8hZtuNvE1mX^Px^<0dt;tYUX0L~ zhZG6ovnXbQCo^;?>_G)hsx&QLs6V;;5K?HweUqRp5LCuBq= z8jgvORN;t=kOXW-g>L%&!i}ek@?OaOB%u4EqW9)s%Ps9bEdaomX@bIc*#Mhw>(wjg V6;@wh?FrWIy3eqFT@sEK{s6?rX*K`= diff --git a/venv/lib/python3.12/site-packages/charset_normalizer/api.py b/venv/lib/python3.12/site-packages/charset_normalizer/api.py deleted file mode 100644 index ebd9639..0000000 --- a/venv/lib/python3.12/site-packages/charset_normalizer/api.py +++ /dev/null @@ -1,669 +0,0 @@ -from __future__ import annotations - -import logging -from os import PathLike -from typing import BinaryIO - -from .cd import ( - coherence_ratio, - encoding_languages, - mb_encoding_languages, - merge_coherence_ratios, -) -from .constant import IANA_SUPPORTED, TOO_BIG_SEQUENCE, TOO_SMALL_SEQUENCE, TRACE -from .md import mess_ratio -from .models import CharsetMatch, CharsetMatches -from .utils import ( - any_specified_encoding, - cut_sequence_chunks, - iana_name, - identify_sig_or_bom, - is_cp_similar, - is_multi_byte_encoding, - should_strip_sig_or_bom, -) - -logger = logging.getLogger("charset_normalizer") -explain_handler = logging.StreamHandler() -explain_handler.setFormatter( - logging.Formatter("%(asctime)s | %(levelname)s | %(message)s") -) - - -def from_bytes( - sequences: bytes | bytearray, - steps: int = 5, - chunk_size: int = 512, - threshold: float = 0.2, - cp_isolation: list[str] | None = None, - cp_exclusion: list[str] | None = None, - preemptive_behaviour: bool = True, - explain: bool = False, - language_threshold: float = 0.1, - enable_fallback: bool = True, -) -> 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 blocks 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. - By default the library does not setup any handler other than the NullHandler, if you choose to set the 'explain' - toggle to True it will alter the logger configuration to add a StreamHandler that is suitable for debugging. - Custom logging format and handler can be set manually. - """ - - if not isinstance(sequences, (bytearray, bytes)): - raise TypeError( - "Expected object of type bytes or bytearray, got: {}".format( - type(sequences) - ) - ) - - if explain: - previous_logger_level: int = logger.level - logger.addHandler(explain_handler) - logger.setLevel(TRACE) - - length: int = len(sequences) - - if length == 0: - logger.debug("Encoding detection on empty bytes, assuming utf_8 intention.") - if explain: # Defensive: ensure exit path clean handler - logger.removeHandler(explain_handler) - logger.setLevel(previous_logger_level or logging.WARNING) - return CharsetMatches([CharsetMatch(sequences, "utf_8", 0.0, False, [], "")]) - - if cp_isolation is not None: - logger.log( - TRACE, - "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.log( - TRACE, - "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.log( - TRACE, - "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: bool = len(sequences) < TOO_SMALL_SEQUENCE - is_too_large_sequence: bool = len(sequences) >= TOO_BIG_SEQUENCE - - if is_too_small_sequence: - logger.log( - TRACE, - "Trying to detect encoding from a tiny portion of ({}) byte(s).".format( - length - ), - ) - elif is_too_large_sequence: - logger.log( - TRACE, - "Using lazy str decoding because the payload is quite large, ({}) byte(s).".format( - length - ), - ) - - prioritized_encodings: list[str] = [] - - specified_encoding: str | None = ( - any_specified_encoding(sequences) if preemptive_behaviour else None - ) - - if specified_encoding is not None: - prioritized_encodings.append(specified_encoding) - logger.log( - TRACE, - "Detected declarative mark in sequence. Priority +1 given for %s.", - specified_encoding, - ) - - tested: set[str] = set() - tested_but_hard_failure: list[str] = [] - tested_but_soft_failure: list[str] = [] - - fallback_ascii: CharsetMatch | None = None - fallback_u8: CharsetMatch | None = None - fallback_specified: CharsetMatch | None = None - - results: CharsetMatches = CharsetMatches() - - early_stop_results: CharsetMatches = CharsetMatches() - - sig_encoding, sig_payload = identify_sig_or_bom(sequences) - - if sig_encoding is not None: - prioritized_encodings.append(sig_encoding) - logger.log( - TRACE, - "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: str | None = None - bom_or_sig_available: bool = sig_encoding == encoding_iana - strip_sig_or_bom: bool = bom_or_sig_available and should_strip_sig_or_bom( - encoding_iana - ) - - if encoding_iana in {"utf_16", "utf_32"} and not bom_or_sig_available: - logger.log( - TRACE, - "Encoding %s won't be tested as-is because it require a BOM. Will try some sub-encoder LE/BE.", - encoding_iana, - ) - continue - if encoding_iana in {"utf_7"} and not bom_or_sig_available: - logger.log( - TRACE, - "Encoding %s won't be tested as-is because detection is unreliable without BOM/SIG.", - encoding_iana, - ) - continue - - try: - is_multi_byte_decoder: bool = is_multi_byte_encoding(encoding_iana) - except (ModuleNotFoundError, ImportError): - logger.log( - TRACE, - "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, LookupError) as e: - if not isinstance(e, LookupError): - logger.log( - TRACE, - "Code page %s does not fit given bytes sequence at ALL. %s", - encoding_iana, - str(e), - ) - tested_but_hard_failure.append(encoding_iana) - continue - - similar_soft_failure_test: bool = False - - 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.log( - TRACE, - "%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 not bom_or_sig_available else len(sig_payload), - length, - int(length / steps), - ) - - multi_byte_bonus: bool = ( - is_multi_byte_decoder - and decoded_payload is not None - and len(decoded_payload) < length - ) - - if multi_byte_bonus: - logger.log( - TRACE, - "Code page %s is a multi byte encoding table and it appear that at least one character " - "was encoded using n-bytes.", - encoding_iana, - ) - - max_chunk_gave_up: int = int(len(r_) / 4) - - max_chunk_gave_up = max(max_chunk_gave_up, 2) - early_stop_count: int = 0 - lazy_str_hard_failure = False - - md_chunks: list[str] = [] - md_ratios = [] - - try: - for chunk in cut_sequence_chunks( - sequences, - encoding_iana, - r_, - chunk_size, - bom_or_sig_available, - strip_sig_or_bom, - sig_payload, - is_multi_byte_decoder, - decoded_payload, - ): - md_chunks.append(chunk) - - md_ratios.append( - mess_ratio( - chunk, - threshold, - explain is True and 1 <= len(cp_isolation) <= 2, - ) - ) - - 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 - except ( - UnicodeDecodeError - ) as e: # Lazy str loading may have missed something there - logger.log( - TRACE, - "LazyStr Loading: After MD chunk decode, code page %s does not fit given bytes sequence at ALL. %s", - encoding_iana, - str(e), - ) - early_stop_count = max_chunk_gave_up - lazy_str_hard_failure = True - - # We might want to check the sequence again with the whole content - # Only if initial MD tests passes - if ( - not lazy_str_hard_failure - and is_too_large_sequence - and not is_multi_byte_decoder - ): - try: - sequences[int(50e3) :].decode(encoding_iana, errors="strict") - except UnicodeDecodeError as e: - logger.log( - TRACE, - "LazyStr Loading: After final lookup, code page %s does not fit given bytes sequence at ALL. %s", - encoding_iana, - str(e), - ) - tested_but_hard_failure.append(encoding_iana) - continue - - mean_mess_ratio: float = sum(md_ratios) / len(md_ratios) if md_ratios else 0.0 - if mean_mess_ratio >= threshold or early_stop_count >= max_chunk_gave_up: - tested_but_soft_failure.append(encoding_iana) - logger.log( - TRACE, - "%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 ( - enable_fallback - and encoding_iana - in ["ascii", "utf_8", specified_encoding, "utf_16", "utf_32"] - and not lazy_str_hard_failure - ): - fallback_entry = CharsetMatch( - sequences, - encoding_iana, - threshold, - bom_or_sig_available, - [], - decoded_payload, - preemptive_declaration=specified_encoding, - ) - if encoding_iana == specified_encoding: - fallback_specified = fallback_entry - elif encoding_iana == "ascii": - fallback_ascii = fallback_entry - else: - fallback_u8 = fallback_entry - continue - - logger.log( - TRACE, - "%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: list[str] = encoding_languages(encoding_iana) - else: - target_languages = mb_encoding_languages(encoding_iana) - - if target_languages: - logger.log( - TRACE, - "{} should target any language(s) of {}".format( - encoding_iana, str(target_languages) - ), - ) - - cd_ratios = [] - - # We shall skip the CD when its about ASCII - # Most of the time its not relevant to run "language-detection" on it. - if encoding_iana != "ascii": - for chunk in md_chunks: - chunk_languages = coherence_ratio( - chunk, - language_threshold, - ",".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.log( - TRACE, - "We detected language {} using {}".format( - cd_ratios_merged, encoding_iana - ), - ) - - current_match = CharsetMatch( - sequences, - encoding_iana, - mean_mess_ratio, - bom_or_sig_available, - cd_ratios_merged, - ( - decoded_payload - if ( - is_too_large_sequence is False - or encoding_iana in [specified_encoding, "ascii", "utf_8"] - ) - else None - ), - preemptive_declaration=specified_encoding, - ) - - results.append(current_match) - - if ( - encoding_iana in [specified_encoding, "ascii", "utf_8"] - and mean_mess_ratio < 0.1 - ): - # If md says nothing to worry about, then... stop immediately! - if mean_mess_ratio == 0.0: - logger.debug( - "Encoding detection: %s is most likely the one.", - current_match.encoding, - ) - if explain: # Defensive: ensure exit path clean handler - logger.removeHandler(explain_handler) - logger.setLevel(previous_logger_level) - return CharsetMatches([current_match]) - - early_stop_results.append(current_match) - - if ( - len(early_stop_results) - and (specified_encoding is None or specified_encoding in tested) - and "ascii" in tested - and "utf_8" in tested - ): - probable_result: CharsetMatch = early_stop_results.best() # type: ignore[assignment] - logger.debug( - "Encoding detection: %s is most likely the one.", - probable_result.encoding, - ) - if explain: # Defensive: ensure exit path clean handler - logger.removeHandler(explain_handler) - logger.setLevel(previous_logger_level) - - return CharsetMatches([probable_result]) - - if encoding_iana == sig_encoding: - logger.debug( - "Encoding detection: %s is most likely the one as we detected a BOM or SIG within " - "the beginning of the sequence.", - encoding_iana, - ) - if explain: # Defensive: ensure exit path clean handler - logger.removeHandler(explain_handler) - logger.setLevel(previous_logger_level) - return CharsetMatches([results[encoding_iana]]) - - if len(results) == 0: - if fallback_u8 or fallback_ascii or fallback_specified: - logger.log( - TRACE, - "Nothing got out of the detection process. Using ASCII/UTF-8/Specified fallback.", - ) - - if fallback_specified: - logger.debug( - "Encoding detection: %s will be used as a fallback match", - fallback_specified.encoding, - ) - results.append(fallback_specified) - elif ( - (fallback_u8 and fallback_ascii is None) - or ( - fallback_u8 - and fallback_ascii - and fallback_u8.fingerprint != fallback_ascii.fingerprint - ) - or (fallback_u8 is not None) - ): - logger.debug("Encoding detection: utf_8 will be used as a fallback match") - results.append(fallback_u8) - elif fallback_ascii: - logger.debug("Encoding detection: ascii will be used as a fallback match") - results.append(fallback_ascii) - - if results: - logger.debug( - "Encoding detection: Found %s as plausible (best-candidate) for content. With %i alternatives.", - results.best().encoding, # type: ignore - len(results) - 1, - ) - else: - logger.debug("Encoding detection: Unable to determine any suitable charset.") - - if explain: - logger.removeHandler(explain_handler) - logger.setLevel(previous_logger_level) - - return results - - -def from_fp( - fp: BinaryIO, - steps: int = 5, - chunk_size: int = 512, - threshold: float = 0.20, - cp_isolation: list[str] | None = None, - cp_exclusion: list[str] | None = None, - preemptive_behaviour: bool = True, - explain: bool = False, - language_threshold: float = 0.1, - enable_fallback: bool = True, -) -> 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, - language_threshold, - enable_fallback, - ) - - -def from_path( - path: str | bytes | PathLike, # type: ignore[type-arg] - steps: int = 5, - chunk_size: int = 512, - threshold: float = 0.20, - cp_isolation: list[str] | None = None, - cp_exclusion: list[str] | None = None, - preemptive_behaviour: bool = True, - explain: bool = False, - language_threshold: float = 0.1, - enable_fallback: bool = True, -) -> 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, - language_threshold, - enable_fallback, - ) - - -def is_binary( - fp_or_path_or_payload: PathLike | str | BinaryIO | bytes, # type: ignore[type-arg] - steps: int = 5, - chunk_size: int = 512, - threshold: float = 0.20, - cp_isolation: list[str] | None = None, - cp_exclusion: list[str] | None = None, - preemptive_behaviour: bool = True, - explain: bool = False, - language_threshold: float = 0.1, - enable_fallback: bool = False, -) -> bool: - """ - Detect if the given input (file, bytes, or path) points to a binary file. aka. not a string. - Based on the same main heuristic algorithms and default kwargs at the sole exception that fallbacks match - are disabled to be stricter around ASCII-compatible but unlikely to be a string. - """ - if isinstance(fp_or_path_or_payload, (str, PathLike)): - guesses = from_path( - fp_or_path_or_payload, - steps=steps, - chunk_size=chunk_size, - threshold=threshold, - cp_isolation=cp_isolation, - cp_exclusion=cp_exclusion, - preemptive_behaviour=preemptive_behaviour, - explain=explain, - language_threshold=language_threshold, - enable_fallback=enable_fallback, - ) - elif isinstance( - fp_or_path_or_payload, - ( - bytes, - bytearray, - ), - ): - guesses = from_bytes( - fp_or_path_or_payload, - steps=steps, - chunk_size=chunk_size, - threshold=threshold, - cp_isolation=cp_isolation, - cp_exclusion=cp_exclusion, - preemptive_behaviour=preemptive_behaviour, - explain=explain, - language_threshold=language_threshold, - enable_fallback=enable_fallback, - ) - else: - guesses = from_fp( - fp_or_path_or_payload, - steps=steps, - chunk_size=chunk_size, - threshold=threshold, - cp_isolation=cp_isolation, - cp_exclusion=cp_exclusion, - preemptive_behaviour=preemptive_behaviour, - explain=explain, - language_threshold=language_threshold, - enable_fallback=enable_fallback, - ) - - return not guesses diff --git a/venv/lib/python3.12/site-packages/charset_normalizer/cd.py b/venv/lib/python3.12/site-packages/charset_normalizer/cd.py deleted file mode 100644 index 71a3ed5..0000000 --- a/venv/lib/python3.12/site-packages/charset_normalizer/cd.py +++ /dev/null @@ -1,395 +0,0 @@ -from __future__ import annotations - -import importlib -from codecs import IncrementalDecoder -from collections import Counter -from functools import lru_cache -from typing import Counter as TypeCounter - -from .constant import ( - FREQUENCIES, - KO_NAMES, - LANGUAGE_SUPPORTED_COUNT, - TOO_SMALL_SEQUENCE, - ZH_NAMES, -) -from .md import is_suspiciously_successive_range -from .models import CoherenceMatches -from .utils import ( - is_accentuated, - is_latin, - is_multi_byte_encoding, - is_unicode_range_secondary, - unicode_range, -) - - -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 OSError("Function not supported on multi-byte code page") - - decoder = importlib.import_module(f"encodings.{iana_name}").IncrementalDecoder - - p: IncrementalDecoder = decoder(errors="ignore") - seen_ranges: dict[str, int] = {} - character_count: int = 0 - - for i in range(0x40, 0xFF): - chunk: str = p.decode(bytes([i])) - - if chunk: - character_range: str | None = unicode_range(chunk) - - if character_range is None: - continue - - if is_unicode_range_secondary(character_range) is False: - if character_range not in seen_ranges: - seen_ranges[character_range] = 0 - seen_ranges[character_range] += 1 - character_count += 1 - - return sorted( - [ - character_range - for character_range in seen_ranges - if seen_ranges[character_range] / character_count >= 0.15 - ] - ) - - -def unicode_range_languages(primary_range: str) -> list[str]: - """ - Return inferred languages used with a unicode range. - """ - languages: 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: list[str] = encoding_unicode_range(iana_name) - primary_range: str | None = None - - 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) - - -@lru_cache() -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 == "cp932" - ): - return ["Japanese"] - if iana_name.startswith("gb") or iana_name in ZH_NAMES: - return ["Chinese"] - if iana_name.startswith("iso2022_kr") or iana_name in KO_NAMES: - return ["Korean"] - - return [] - - -@lru_cache(maxsize=LANGUAGE_SUPPORTED_COUNT) -def get_target_features(language: str) -> tuple[bool, bool]: - """ - Determine main aspects from a supported language if it contains accents and if is pure Latin. - """ - target_have_accents: bool = False - target_pure_latin: bool = True - - for character in FREQUENCIES[language]: - if not target_have_accents and is_accentuated(character): - target_have_accents = True - if target_pure_latin and is_latin(character) is False: - target_pure_latin = False - - return target_have_accents, target_pure_latin - - -def alphabet_languages( - characters: list[str], ignore_non_latin: bool = False -) -> list[str]: - """ - Return associated languages associated to given characters. - """ - languages: list[tuple[str, float]] = [] - - source_have_accents = any(is_accentuated(character) for character in characters) - - for language, language_characters in FREQUENCIES.items(): - target_have_accents, target_pure_latin = get_target_features(language) - - if ignore_non_latin and target_pure_latin is False: - continue - - if target_have_accents is False and source_have_accents: - continue - - character_count: int = len(language_characters) - - character_match_count: int = len( - [c for c in language_characters if c in characters] - ) - - ratio: float = character_match_count / character_count - - if ratio >= 0.2: - languages.append((language, ratio)) - - languages = sorted(languages, key=lambda x: x[1], reverse=True) - - return [compatible_language[0] for compatible_language in 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(f"{language} not available") - - character_approved_count: int = 0 - FREQUENCIES_language_set = set(FREQUENCIES[language]) - - ordered_characters_count: int = len(ordered_characters) - target_language_characters_count: int = len(FREQUENCIES[language]) - - large_alphabet: bool = target_language_characters_count > 26 - - for character, character_rank in zip( - ordered_characters, range(0, ordered_characters_count) - ): - if character not in FREQUENCIES_language_set: - continue - - character_rank_in_language: int = FREQUENCIES[language].index(character) - expected_projection_ratio: float = ( - target_language_characters_count / ordered_characters_count - ) - character_rank_projection: int = int(character_rank * expected_projection_ratio) - - if ( - large_alphabet is False - and abs(character_rank_projection - character_rank_in_language) > 4 - ): - continue - - if ( - large_alphabet is True - and abs(character_rank_projection - character_rank_in_language) - < target_language_characters_count / 3 - ): - character_approved_count += 1 - continue - - characters_before_source: list[str] = FREQUENCIES[language][ - 0:character_rank_in_language - ] - characters_after_source: list[str] = FREQUENCIES[language][ - character_rank_in_language: - ] - characters_before: list[str] = ordered_characters[0:character_rank] - characters_after: list[str] = ordered_characters[character_rank:] - - before_match_count: int = len( - set(characters_before) & set(characters_before_source) - ) - - after_match_count: int = len( - set(characters_after) & set(characters_after_source) - ) - - 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: dict[str, str] = {} - - for character in decoded_sequence: - if character.isalpha() is False: - continue - - character_range: str | None = unicode_range(character) - - if character_range is None: - continue - - layer_target_range: str | None = None - - 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: dict[str, list[float]] = {} - 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) - - merge = [ - ( - language, - round( - sum(per_language_ratios[language]) / len(per_language_ratios[language]), - 4, - ), - ) - for language in per_language_ratios - ] - - return sorted(merge, key=lambda x: x[1], reverse=True) - - -def filter_alt_coherence_matches(results: CoherenceMatches) -> CoherenceMatches: - """ - We shall NOT return "English—" in CoherenceMatches because it is an alternative - of "English". This function only keeps the best match and remove the em-dash in it. - """ - index_results: dict[str, list[float]] = dict() - - for result in results: - language, ratio = result - no_em_name: str = language.replace("—", "") - - if no_em_name not in index_results: - index_results[no_em_name] = [] - - index_results[no_em_name].append(ratio) - - if any(len(index_results[e]) > 1 for e in index_results): - filtered_results: CoherenceMatches = [] - - for language in index_results: - filtered_results.append((language, max(index_results[language]))) - - return filtered_results - - return results - - -@lru_cache(maxsize=2048) -def coherence_ratio( - decoded_sequence: str, threshold: float = 0.1, lg_inclusion: str | None = 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: list[tuple[str, float]] = [] - ignore_non_latin: bool = False - - sufficient_match_count: int = 0 - - lg_inclusion_list = lg_inclusion.split(",") if lg_inclusion is not None else [] - if "Latin Based" in lg_inclusion_list: - ignore_non_latin = True - lg_inclusion_list.remove("Latin Based") - - for layer in alpha_unicode_split(decoded_sequence): - sequence_frequencies: TypeCounter[str] = Counter(layer) - most_common = sequence_frequencies.most_common() - - character_count: int = sum(o for c, o in most_common) - - if character_count <= TOO_SMALL_SEQUENCE: - continue - - popular_character_ordered: list[str] = [c for c, o in most_common] - - for language in lg_inclusion_list or alphabet_languages( - popular_character_ordered, ignore_non_latin - ): - ratio: float = characters_popularity_compare( - language, popular_character_ordered - ) - - 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( - filter_alt_coherence_matches(results), key=lambda x: x[1], reverse=True - ) diff --git a/venv/lib/python3.12/site-packages/charset_normalizer/cli/__init__.py b/venv/lib/python3.12/site-packages/charset_normalizer/cli/__init__.py deleted file mode 100644 index 543a5a4..0000000 --- a/venv/lib/python3.12/site-packages/charset_normalizer/cli/__init__.py +++ /dev/null @@ -1,8 +0,0 @@ -from __future__ import annotations - -from .__main__ import cli_detect, query_yes_no - -__all__ = ( - "cli_detect", - "query_yes_no", -) diff --git a/venv/lib/python3.12/site-packages/charset_normalizer/cli/__main__.py b/venv/lib/python3.12/site-packages/charset_normalizer/cli/__main__.py deleted file mode 100644 index cb64156..0000000 --- a/venv/lib/python3.12/site-packages/charset_normalizer/cli/__main__.py +++ /dev/null @@ -1,381 +0,0 @@ -from __future__ import annotations - -import argparse -import sys -import typing -from json import dumps -from os.path import abspath, basename, dirname, join, realpath -from platform import python_version -from unicodedata import unidata_version - -import charset_normalizer.md as md_module -from charset_normalizer import from_fp -from charset_normalizer.models import CliDetectionResult -from charset_normalizer.version import __version__ - - -def query_yes_no(question: str, default: str = "yes") -> bool: - """Ask a yes/no question via input() and return their answer. - - "question" is a string that is presented to the user. - "default" is the presumed answer if the user just hits . - 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") - - -class FileType: - """Factory for creating file object types - - Instances of FileType are typically passed as type= arguments to the - ArgumentParser add_argument() method. - - Keyword Arguments: - - mode -- A string indicating how the file is to be opened. Accepts the - same values as the builtin open() function. - - bufsize -- The file's desired buffer size. Accepts the same values as - the builtin open() function. - - encoding -- The file's encoding. Accepts the same values as the - builtin open() function. - - errors -- A string indicating how encoding and decoding errors are to - be handled. Accepts the same value as the builtin open() function. - - Backported from CPython 3.12 - """ - - def __init__( - self, - mode: str = "r", - bufsize: int = -1, - encoding: str | None = None, - errors: str | None = None, - ): - self._mode = mode - self._bufsize = bufsize - self._encoding = encoding - self._errors = errors - - def __call__(self, string: str) -> typing.IO: # type: ignore[type-arg] - # the special argument "-" means sys.std{in,out} - if string == "-": - if "r" in self._mode: - return sys.stdin.buffer if "b" in self._mode else sys.stdin - elif any(c in self._mode for c in "wax"): - return sys.stdout.buffer if "b" in self._mode else sys.stdout - else: - msg = f'argument "-" with mode {self._mode}' - raise ValueError(msg) - - # all other arguments are used as file names - try: - return open(string, self._mode, self._bufsize, self._encoding, self._errors) - except OSError as e: - message = f"can't open '{string}': {e}" - raise argparse.ArgumentTypeError(message) - - def __repr__(self) -> str: - args = self._mode, self._bufsize - kwargs = [("encoding", self._encoding), ("errors", self._errors)] - args_str = ", ".join( - [repr(arg) for arg in args if arg != -1] - + [f"{kw}={arg!r}" for kw, arg in kwargs if arg is not None] - ) - return f"{type(self).__name__}({args_str})" - - -def cli_detect(argv: list[str] | None = None) -> int: - """ - 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=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( - "-i", - "--no-preemptive", - action="store_true", - default=False, - dest="no_preemptive", - help="Disable looking at a charset declaration to hint the detector.", - ) - parser.add_argument( - "-t", - "--threshold", - action="store", - default=0.2, - type=float, - dest="threshold", - help="Define a custom maximum amount of noise allowed in decoded content. 0. <= noise <= 1.", - ) - parser.add_argument( - "--version", - action="version", - version="Charset-Normalizer {} - Python {} - Unicode {} - SpeedUp {}".format( - __version__, - python_version(), - unidata_version, - "OFF" if md_module.__file__.lower().endswith(".py") else "ON", - ), - help="Show version information and exit.", - ) - - args = parser.parse_args(argv) - - if args.replace is True and args.normalize is False: - if args.files: - for my_file in args.files: - my_file.close() - print("Use --replace in addition of --normalize only.", file=sys.stderr) - return 1 - - if args.force is True and args.replace is False: - if args.files: - for my_file in args.files: - my_file.close() - print("Use --force in addition of --replace only.", file=sys.stderr) - return 1 - - if args.threshold < 0.0 or args.threshold > 1.0: - if args.files: - for my_file in args.files: - my_file.close() - print("--threshold VALUE should be between 0. AND 1.", file=sys.stderr) - return 1 - - x_ = [] - - for my_file in args.files: - matches = from_fp( - my_file, - threshold=args.threshold, - explain=args.verbose, - preemptive_behaviour=args.no_preemptive is False, - ) - - best_guess = matches.best() - - if best_guess is None: - print( - 'Unable to identify originating encoding for "{}". {}'.format( - my_file.name, - ( - "Maybe try increasing maximum amount of chaos." - if args.threshold < 1.0 - else "" - ), - ), - file=sys.stderr, - ) - x_.append( - CliDetectionResult( - abspath(my_file.name), - None, - [], - [], - "Unknown", - [], - False, - 1.0, - 0.0, - None, - True, - ) - ) - else: - x_.append( - CliDetectionResult( - abspath(my_file.name), - best_guess.encoding, - best_guess.encoding_aliases, - [ - cp - for cp in best_guess.could_be_from_charset - if cp != best_guess.encoding - ], - best_guess.language, - best_guess.alphabets, - best_guess.bom, - best_guess.percent_chaos, - best_guess.percent_coherence, - None, - True, - ) - ) - - if len(matches) > 1 and args.alternatives: - for el in matches: - if el != best_guess: - 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 best_guess.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 - - dir_path = dirname(realpath(my_file.name)) - file_name = basename(realpath(my_file.name)) - - o_: list[str] = file_name.split(".") - - if args.replace is False: - o_.insert(-1, best_guess.encoding) - if my_file.closed is False: - my_file.close() - elif ( - 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 = join(dir_path, ".".join(o_)) - - with open(x_[0].unicode_path, "wb") as fp: - fp.write(best_guess.output()) - except OSError 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 len(x_) > 1 else x_[0].__dict__, - ensure_ascii=True, - indent=4, - ) - ) - else: - for my_file in args.files: - print( - ", ".join( - [ - el.encoding or "undefined" - for el in x_ - if el.path == abspath(my_file.name) - ] - ) - ) - - return 0 - - -if __name__ == "__main__": - cli_detect() diff --git a/venv/lib/python3.12/site-packages/charset_normalizer/cli/__pycache__/__init__.cpython-312.pyc b/venv/lib/python3.12/site-packages/charset_normalizer/cli/__pycache__/__init__.cpython-312.pyc deleted file mode 100644 index a298bbdb195d38e027d97d62e0cc44a55e19a999..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 346 zcmXw!ze)o^5XN_JFD4|W5qtr$Ns%mSD?-r5My#(H*4xo6*+1v*Uf|N%*;)DwK8tT~ zU}Yic0_jq@hd9N|_xqS(WG>La2iKLnsT2M-4CYjC* zE11cPJTWVJO+M*ux{(QON5WbcMO4m)4eh+F9hO>w#E4~V51(uF4Kx_Qy1U6iI|O*F zW9<>Zv((=X0E|#JVK1RS=)69F&>G-_>=Kf_<_l+#dm)vrly~)--(XlqSMj-D2|JzN z-%hW!;w!W(uGIstnz(TGVs>`UgNitd4xp@x0JEyu l4=#<9wZ>HAT#e*vOlVdDS* diff --git a/venv/lib/python3.12/site-packages/charset_normalizer/cli/__pycache__/__main__.cpython-312.pyc b/venv/lib/python3.12/site-packages/charset_normalizer/cli/__pycache__/__main__.cpython-312.pyc deleted file mode 100644 index f7ee8a8a98da4a6c53a122bbe1f6ec483db77681..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 14407 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 bdv&-uca=V0Y>3$k6`>Q%f", - "=", - ":", - "/", - "&", - ";", - "{", - "}", - "[", - "]", - ",", - "|", - '"', - "-", - "(", - ")", -} - -# Sample character sets — replace with full lists if needed -COMMON_CHINESE_CHARACTERS = "的一是在不了有和人这中大为上个国我以要他时来用们生到作地于出就分对成会可主发年动同工也能下过子说产种面而方后多定行学法所民得经十三之进着等部度家电力里如水化高自二理起小物现实加量都两体制机当使点从业本去把性好应开它合还因由其些然前外天政四日那社义事平形相全表间样与关各重新线内数正心反你明看原又么利比或但质气第向道命此变条只没结解问意建月公无系军很情者最立代想已通并提直题党程展五果料象员革位入常文总次品式活设及管特件长求老头基资边流路级少图山统接知较将组见计别她手角期根论运农指几九区强放决西被干做必战先回则任取据处队南给色光门即保治北造百规热领七海口东导器压志世金增争济阶油思术极交受联什认六共权收证改清己美再采转更单风切打白教速花带安场身车例真务具万每目至达走积示议声报斗完类八离华名确才科张信马节话米整空元况今集温传土许步群广石记需段研界拉林律叫且究观越织装影算低持音众书布复容儿须际商非验连断深难近矿千周委素技备半办青省列习响约支般史感劳便团往酸历市克何除消构府太准精值号率族维划选标写存候毛亲快效斯院查江型眼王按格养易置派层片始却专状育厂京识适属圆包火住调满县局照参红细引听该铁价严龙飞" - -COMMON_JAPANESE_CHARACTERS = "日一国年大十二本中長出三時行見月分後前生五間上東四今金九入学高円子外八六下来気小七山話女北午百書先名川千水半男西電校語土木聞食車何南万毎白天母火右読友左休父雨" - -COMMON_KOREAN_CHARACTERS = "一二三四五六七八九十百千萬上下左右中人女子大小山川日月火水木金土父母天地國名年時文校學生" - -# Combine all into a set -COMMON_CJK_CHARACTERS = set( - "".join( - [ - COMMON_CHINESE_CHARACTERS, - COMMON_JAPANESE_CHARACTERS, - COMMON_KOREAN_CHARACTERS, - ] - ) -) - -KO_NAMES: set[str] = {"johab", "cp949", "euc_kr"} -ZH_NAMES: set[str] = {"big5", "cp950", "big5hkscs", "hz"} - -# Logging LEVEL below DEBUG -TRACE: int = 5 - - -# Language label that contain the em dash "—" -# character are to be considered alternative seq to origin -FREQUENCIES: dict[str, list[str]] = { - "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", - ], - "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", - ], - "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": [ - "о", - "а", - "е", - "и", - "н", - "с", - "т", - "р", - "в", - "л", - "к", - "м", - "д", - "п", - "у", - "г", - "я", - "ы", - "з", - "б", - "й", - "ь", - "ч", - "х", - "ж", - "ц", - ], - # Jap-Kanji - "Japanese": [ - "人", - "一", - "大", - "亅", - "丁", - "丨", - "竹", - "笑", - "口", - "日", - "今", - "二", - "彳", - "行", - "十", - "土", - "丶", - "寸", - "寺", - "時", - "乙", - "丿", - "乂", - "气", - "気", - "冂", - "巾", - "亠", - "市", - "目", - "儿", - "見", - "八", - "小", - "凵", - "県", - "月", - "彐", - "門", - "間", - "木", - "東", - "山", - "出", - "本", - "中", - "刀", - "分", - "耳", - "又", - "取", - "最", - "言", - "田", - "心", - "思", - "刂", - "前", - "京", - "尹", - "事", - "生", - "厶", - "云", - "会", - "未", - "来", - "白", - "冫", - "楽", - "灬", - "馬", - "尸", - "尺", - "駅", - "明", - "耂", - "者", - "了", - "阝", - "都", - "高", - "卜", - "占", - "厂", - "广", - "店", - "子", - "申", - "奄", - "亻", - "俺", - "上", - "方", - "冖", - "学", - "衣", - "艮", - "食", - "自", - ], - # Jap-Katakana - "Japanese—": [ - "ー", - "ン", - "ス", - "・", - "ル", - "ト", - "リ", - "イ", - "ア", - "ラ", - "ッ", - "ク", - "ド", - "シ", - "レ", - "ジ", - "タ", - "フ", - "ロ", - "カ", - "テ", - "マ", - "ィ", - "グ", - "バ", - "ム", - "プ", - "オ", - "コ", - "デ", - "ニ", - "ウ", - "メ", - "サ", - "ビ", - "ナ", - "ブ", - "ャ", - "エ", - "ュ", - "チ", - "キ", - "ズ", - "ダ", - "パ", - "ミ", - "ェ", - "ョ", - "ハ", - "セ", - "ベ", - "ガ", - "モ", - "ツ", - "ネ", - "ボ", - "ソ", - "ノ", - "ァ", - "ヴ", - "ワ", - "ポ", - "ペ", - "ピ", - "ケ", - "ゴ", - "ギ", - "ザ", - "ホ", - "ゲ", - "ォ", - "ヤ", - "ヒ", - "ユ", - "ヨ", - "ヘ", - "ゼ", - "ヌ", - "ゥ", - "ゾ", - "ヶ", - "ヂ", - "ヲ", - "ヅ", - "ヵ", - "ヱ", - "ヰ", - "ヮ", - "ヽ", - "゠", - "ヾ", - "ヷ", - "ヿ", - "ヸ", - "ヹ", - "ヺ", - ], - # Jap-Hiragana - "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", - ], - "Thai": [ - "า", - "น", - "ร", - "อ", - "ก", - "เ", - "ง", - "ม", - "ย", - "ล", - "ว", - "ด", - "ท", - "ส", - "ต", - "ะ", - "ป", - "บ", - "ค", - "ห", - "แ", - "จ", - "พ", - "ช", - "ข", - "ใ", - ], - "Greek": [ - "α", - "τ", - "ο", - "ι", - "ε", - "ν", - "ρ", - "σ", - "κ", - "η", - "π", - "ς", - "υ", - "μ", - "λ", - "ί", - "ό", - "ά", - "γ", - "έ", - "δ", - "ή", - "ω", - "χ", - "θ", - "ύ", - ], - "Tamil": [ - "க", - "த", - "ப", - "ட", - "ர", - "ம", - "ல", - "ன", - "வ", - "ற", - "ய", - "ள", - "ச", - "ந", - "இ", - "ண", - "அ", - "ஆ", - "ழ", - "ங", - "எ", - "உ", - "ஒ", - "ஸ", - ], - "Kazakh": [ - "а", - "ы", - "е", - "н", - "т", - "р", - "л", - "і", - "д", - "с", - "м", - "қ", - "к", - "о", - "б", - "и", - "у", - "ғ", - "ж", - "ң", - "з", - "ш", - "й", - "п", - "г", - "ө", - ], -} - -LANGUAGE_SUPPORTED_COUNT: int = len(FREQUENCIES) diff --git a/venv/lib/python3.12/site-packages/charset_normalizer/legacy.py b/venv/lib/python3.12/site-packages/charset_normalizer/legacy.py deleted file mode 100644 index 360a310..0000000 --- a/venv/lib/python3.12/site-packages/charset_normalizer/legacy.py +++ /dev/null @@ -1,80 +0,0 @@ -from __future__ import annotations - -from typing import TYPE_CHECKING, Any -from warnings import warn - -from .api import from_bytes -from .constant import CHARDET_CORRESPONDENCE, TOO_SMALL_SEQUENCE - -# TODO: remove this check when dropping Python 3.7 support -if TYPE_CHECKING: - from typing_extensions import TypedDict - - class ResultDict(TypedDict): - encoding: str | None - language: str - confidence: float | None - - -def detect( - byte_str: bytes, should_rename_legacy: bool = False, **kwargs: Any -) -> ResultDict: - """ - 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. - :param should_rename_legacy: Should we rename legacy encodings - to their more modern equivalents? - """ - if len(kwargs): - warn( - f"charset-normalizer disregard arguments '{','.join(list(kwargs.keys()))}' in legacy function detect()" - ) - - if not isinstance(byte_str, (bytearray, bytes)): - raise TypeError( # pragma: nocover - f"Expected object of type bytes or bytearray, got: {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.0 - r.chaos if r is not None else None - - # automatically lower confidence - # on small bytes samples. - # https://github.com/jawah/charset_normalizer/issues/391 - if ( - confidence is not None - and confidence >= 0.9 - and encoding - not in { - "utf_8", - "ascii", - } - and r.bom is False # type: ignore[union-attr] - and len(byte_str) < TOO_SMALL_SEQUENCE - ): - confidence -= 0.2 - - # 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" - - if should_rename_legacy is False and encoding in CHARDET_CORRESPONDENCE: - encoding = CHARDET_CORRESPONDENCE[encoding] - - return { - "encoding": encoding, - "language": language, - "confidence": confidence, - } diff --git a/venv/lib/python3.12/site-packages/charset_normalizer/md.cpython-312-x86_64-linux-gnu.so b/venv/lib/python3.12/site-packages/charset_normalizer/md.cpython-312-x86_64-linux-gnu.so deleted file mode 100755 index 857d7474b7a5a0c5b81989346cf9d845174eed68..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 15912 zcmeHOYit}>6~4QU>E?m$LY@oYG8fH%?PpH|zK{20L*b8?}nUc)T;Vx7vp_ zJDb`eKqMy>CXHA{LZ}r#0^~&LRv*U3__xR5SCETnl^2!0!op{a?ZWy ztjCjenjZ)um}~8vbH4MsbLP(Y&hEWm?iuKfMk0b+m3Ts|NJ7L((fkNoAht)WhvQb! zC~eoRsBYnk)e2%N>XeK*q>5z5nbt>@9aF~9Pv+BMFr zKkVn7HZJ=xClVVaZaY{txamg||OF#AUa zP1|vu$z;xR+>ybqR5s&`SmP;2=_+f?#EfN5Br{ejdDIa@v;CQ*XQplB($iUptjJ*2 z&O@M~*#qOxI0?_}bG%N^a}RoMGBXKqmo=RO1H^~2$qaNrm_xH>w_~MJ*#yTm%_N35 zMJhQy?M=CkW$U@D-hy%hx!s~~pnqSN*`~MY?RdJ8Rew<_sXCzMm%#Eh$!|%*@QI4w zE4ASJmhZDT)wM|XCF6qd>j9kQH}MAg@=SNPA+)S(xNeUDRxm-rqq4~;L`SAz_E5) z95|GxP`A8Pg0}rNlyM5ZyeQ?Lpo~-AfdJQZ6(CkxnyB5@z2cAOf4pNm_=^0eMvb|SD_|*%`K#V02>mN~-77u~ z-74B}xLo~DP(}_z?s9(gUw#&p)SprCI$tBiK`3fN@tvD+M$qpG<8=EE05#@cH|8%E ze~j?_&y7=6Cl_Yc8*{~oF<<5FGEQFe9tTVGH|F0hE~43~QE~FOGaHP#zkt!G@N|r~ z87@%6p~I!6f-(Qc;*894Eq@8o)`dfdFHY#S+fHDaFpe?b-4rVxl)->|>t_=y>ca9N zz`?FO4$4wGYDU0$LEso@OtO6~HQMy85`Z}8;4_mFGK(Uxsvf%~5o5{A4 z4Ufe-8k3c5I7dIN2d-pO&1|BT~yj)>SSTH*@faoZ*Fy9M93N-M-Oz+m3;^Mn*fq++snE+)5_0?L^eI0ay-X|T>}*@a5F>Fv|QJkHJyy-&WZ`wN;{^VPp4%{9@l0J=im1j&$xD=z)OvW#?_TYpk)$!oQ&+u=!)H-5UKXyE){> z3*LWGdBX|Ihi`9uRQO#Qr?5Vj6?{85`zB zmi>9Y69)`qvp>(%nBsHM-zZ!eGJwN568rPKi0NjsfAQ`|>|b1s&7-o;cS|6uvpc06xnTJZVT10VFC0Ss%x^V;&mpZ*E({F%bYzA}## z2cq9!BR{6oeq-QCU8Y|O`1AaMX+Chl*q_6m2>A2=U8ekg!1h>cfBPy3n4*nAjToXw z87Ip1<8GY+9C^Ne$24Wgv`LBOV=(_&(D?n&YRZ&pL5bxf=V#z0U~rDb_6w{`OWnY@#lEI1_s9-`|~`A_qFo=RjwQ7 z<#F&P`1Te z=8?VyAIwkY2+79&_I>1=QG3!MEJMsOGUtCXyU)Rnj6U u@x2+}Rr$R6`HSzLeD2Ca9f$A-PH3+O@&`mY{jcPI?{4M4A>a@Y#lHYyFIRj3 diff --git a/venv/lib/python3.12/site-packages/charset_normalizer/md.py b/venv/lib/python3.12/site-packages/charset_normalizer/md.py deleted file mode 100644 index 12ce024..0000000 --- a/venv/lib/python3.12/site-packages/charset_normalizer/md.py +++ /dev/null @@ -1,635 +0,0 @@ -from __future__ import annotations - -from functools import lru_cache -from logging import getLogger - -from .constant import ( - COMMON_SAFE_ASCII_CHARACTERS, - TRACE, - UNICODE_SECONDARY_RANGE_KEYWORD, -) -from .utils import ( - is_accentuated, - is_arabic, - is_arabic_isolated_form, - is_case_variable, - is_cjk, - is_emoticon, - is_hangul, - is_hiragana, - is_katakana, - is_latin, - is_punctuation, - is_separator, - is_symbol, - is_thai, - is_unprintable, - remove_accent, - unicode_range, - is_cjk_uncommon, -) - - -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: # pragma: no cover - """ - Permit to reset the plugin to the initial state. - """ - raise NotImplementedError - - @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) -> None: - self._punctuation_count: int = 0 - self._symbol_count: int = 0 - self._character_count: int = 0 - - self._last_printable_char: str | None = None - self._frenzy_symbol_in_word: bool = False - - 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 COMMON_SAFE_ASCII_CHARACTERS - ): - if is_punctuation(character): - self._punctuation_count += 1 - elif ( - character.isdigit() is False - and is_symbol(character) - and is_emoticon(character) is False - ): - self._symbol_count += 2 - - self._last_printable_char = character - - def reset(self) -> None: # Abstract - self._punctuation_count = 0 - self._character_count = 0 - self._symbol_count = 0 - - @property - def ratio(self) -> float: - if self._character_count == 0: - return 0.0 - - ratio_of_punctuation: float = ( - self._punctuation_count + self._symbol_count - ) / self._character_count - - return ratio_of_punctuation if ratio_of_punctuation >= 0.3 else 0.0 - - -class TooManyAccentuatedPlugin(MessDetectorPlugin): - def __init__(self) -> None: - self._character_count: int = 0 - self._accentuated_count: int = 0 - - 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: # Abstract - self._character_count = 0 - self._accentuated_count = 0 - - @property - def ratio(self) -> float: - if self._character_count < 8: - return 0.0 - - ratio_of_accentuation: float = self._accentuated_count / self._character_count - return ratio_of_accentuation if ratio_of_accentuation >= 0.35 else 0.0 - - -class UnprintablePlugin(MessDetectorPlugin): - def __init__(self) -> None: - self._unprintable_count: int = 0 - self._character_count: int = 0 - - def eligible(self, character: str) -> bool: - return True - - def feed(self, character: str) -> None: - if is_unprintable(character): - self._unprintable_count += 1 - self._character_count += 1 - - def reset(self) -> None: # Abstract - self._unprintable_count = 0 - - @property - def ratio(self) -> float: - if self._character_count == 0: - return 0.0 - - return (self._unprintable_count * 8) / self._character_count - - -class SuspiciousDuplicateAccentPlugin(MessDetectorPlugin): - def __init__(self) -> None: - self._successive_count: int = 0 - self._character_count: int = 0 - - self._last_latin_character: str | None = None - - def eligible(self, character: str) -> bool: - return character.isalpha() and is_latin(character) - - def feed(self, character: str) -> None: - self._character_count += 1 - if ( - self._last_latin_character is not None - and is_accentuated(character) - and is_accentuated(self._last_latin_character) - ): - if character.isupper() and self._last_latin_character.isupper(): - self._successive_count += 1 - # Worse if its the same char duplicated with different accent. - if remove_accent(character) == remove_accent(self._last_latin_character): - self._successive_count += 1 - self._last_latin_character = character - - def reset(self) -> None: # Abstract - 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.0 - - return (self._successive_count * 2) / self._character_count - - -class SuspiciousRange(MessDetectorPlugin): - def __init__(self) -> None: - self._suspicious_successive_range_count: int = 0 - self._character_count: int = 0 - self._last_printable_seen: str | None = None - - def eligible(self, character: str) -> bool: - return character.isprintable() - - def feed(self, character: str) -> None: - self._character_count += 1 - - if ( - character.isspace() - or is_punctuation(character) - or character in COMMON_SAFE_ASCII_CHARACTERS - ): - self._last_printable_seen = None - return - - if self._last_printable_seen is None: - self._last_printable_seen = character - return - - unicode_range_a: str | None = unicode_range(self._last_printable_seen) - unicode_range_b: str | None = unicode_range(character) - - 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: # Abstract - self._character_count = 0 - self._suspicious_successive_range_count = 0 - self._last_printable_seen = None - - @property - def ratio(self) -> float: - if self._character_count <= 13: - return 0.0 - - ratio_of_suspicious_range_usage: float = ( - self._suspicious_successive_range_count * 2 - ) / self._character_count - - return ratio_of_suspicious_range_usage - - -class SuperWeirdWordPlugin(MessDetectorPlugin): - def __init__(self) -> None: - self._word_count: int = 0 - self._bad_word_count: int = 0 - self._foreign_long_count: int = 0 - - self._is_current_word_bad: bool = False - self._foreign_long_watch: bool = False - - self._character_count: int = 0 - self._bad_character_count: int = 0 - - self._buffer: str = "" - self._buffer_accent_count: int = 0 - self._buffer_glyph_count: int = 0 - - def eligible(self, character: str) -> bool: - return True - - def feed(self, character: str) -> None: - if character.isalpha(): - self._buffer += character - if is_accentuated(character): - self._buffer_accent_count += 1 - if ( - self._foreign_long_watch is False - and (is_latin(character) is False or is_accentuated(character)) - and is_cjk(character) is False - and is_hangul(character) is False - and is_katakana(character) is False - and is_hiragana(character) is False - and is_thai(character) is False - ): - self._foreign_long_watch = True - if ( - is_cjk(character) - or is_hangul(character) - or is_katakana(character) - or is_hiragana(character) - or is_thai(character) - ): - self._buffer_glyph_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: int = len(self._buffer) - - self._character_count += buffer_length - - if buffer_length >= 4: - if self._buffer_accent_count / buffer_length >= 0.5: - self._is_current_word_bad = True - # Word/Buffer ending with an upper case accentuated letter are so rare, - # that we will consider them all as suspicious. Same weight as foreign_long suspicious. - elif ( - is_accentuated(self._buffer[-1]) - and self._buffer[-1].isupper() - and all(_.isupper() for _ in self._buffer) is False - ): - self._foreign_long_count += 1 - self._is_current_word_bad = True - elif self._buffer_glyph_count == 1: - self._is_current_word_bad = True - self._foreign_long_count += 1 - if buffer_length >= 24 and self._foreign_long_watch: - camel_case_dst = [ - i - for c, i in zip(self._buffer, range(0, buffer_length)) - if c.isupper() - ] - probable_camel_cased: bool = False - - if camel_case_dst and (len(camel_case_dst) / buffer_length <= 0.3): - probable_camel_cased = True - - if not probable_camel_cased: - self._foreign_long_count += 1 - 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._foreign_long_watch = False - self._buffer = "" - self._buffer_accent_count = 0 - self._buffer_glyph_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: # Abstract - self._buffer = "" - self._is_current_word_bad = False - self._foreign_long_watch = False - self._bad_word_count = 0 - self._word_count = 0 - self._character_count = 0 - self._bad_character_count = 0 - self._foreign_long_count = 0 - - @property - def ratio(self) -> float: - if self._word_count <= 10 and self._foreign_long_count == 0: - return 0.0 - - return self._bad_character_count / self._character_count - - -class CjkUncommonPlugin(MessDetectorPlugin): - """ - Detect messy CJK text that probably means nothing. - """ - - def __init__(self) -> None: - self._character_count: int = 0 - self._uncommon_count: int = 0 - - def eligible(self, character: str) -> bool: - return is_cjk(character) - - def feed(self, character: str) -> None: - self._character_count += 1 - - if is_cjk_uncommon(character): - self._uncommon_count += 1 - return - - def reset(self) -> None: # Abstract - self._character_count = 0 - self._uncommon_count = 0 - - @property - def ratio(self) -> float: - if self._character_count < 8: - return 0.0 - - uncommon_form_usage: float = self._uncommon_count / self._character_count - - # we can be pretty sure it's garbage when uncommon characters are widely - # used. otherwise it could just be traditional chinese for example. - return uncommon_form_usage / 10 if uncommon_form_usage > 0.5 else 0.0 - - -class ArchaicUpperLowerPlugin(MessDetectorPlugin): - def __init__(self) -> None: - self._buf: bool = False - - self._character_count_since_last_sep: int = 0 - - self._successive_upper_lower_count: int = 0 - self._successive_upper_lower_count_final: int = 0 - - self._character_count: int = 0 - - self._last_alpha_seen: str | None = None - self._current_ascii_only: bool = True - - def eligible(self, character: str) -> bool: - return True - - def feed(self, character: str) -> None: - is_concerned = character.isalpha() and is_case_variable(character) - chunk_sep = is_concerned is False - - if chunk_sep and self._character_count_since_last_sep > 0: - if ( - self._character_count_since_last_sep <= 64 - and character.isdigit() is False - and self._current_ascii_only is False - ): - self._successive_upper_lower_count_final += ( - self._successive_upper_lower_count - ) - - self._successive_upper_lower_count = 0 - self._character_count_since_last_sep = 0 - self._last_alpha_seen = None - self._buf = False - self._character_count += 1 - self._current_ascii_only = True - - return - - if self._current_ascii_only is True and character.isascii() is False: - self._current_ascii_only = False - - 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 += 2 - self._buf = False - else: - self._buf = True - else: - self._buf = False - - self._character_count += 1 - self._character_count_since_last_sep += 1 - self._last_alpha_seen = character - - def reset(self) -> None: # Abstract - 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 - self._buf = False - self._current_ascii_only = True - - @property - def ratio(self) -> float: - if self._character_count == 0: - return 0.0 - - return self._successive_upper_lower_count_final / self._character_count - - -class ArabicIsolatedFormPlugin(MessDetectorPlugin): - def __init__(self) -> None: - self._character_count: int = 0 - self._isolated_form_count: int = 0 - - def reset(self) -> None: # Abstract - self._character_count = 0 - self._isolated_form_count = 0 - - def eligible(self, character: str) -> bool: - return is_arabic(character) - - def feed(self, character: str) -> None: - self._character_count += 1 - - if is_arabic_isolated_form(character): - self._isolated_form_count += 1 - - @property - def ratio(self) -> float: - if self._character_count < 8: - return 0.0 - - isolated_form_usage: float = self._isolated_form_count / self._character_count - - return isolated_form_usage - - -@lru_cache(maxsize=1024) -def is_suspiciously_successive_range( - unicode_range_a: str | None, unicode_range_b: str | None -) -> 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 - - # Latin characters can be accompanied with a combining diacritical mark - # eg. Vietnamese. - if ("Latin" in unicode_range_a or "Latin" in unicode_range_b) and ( - "Combining" in unicode_range_a or "Combining" 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 - range_a_jp_chars, range_b_jp_chars = ( - unicode_range_a - in ( - "Hiragana", - "Katakana", - ), - unicode_range_b in ("Hiragana", "Katakana"), - ) - if (range_a_jp_chars or range_b_jp_chars) and ( - "CJK" in unicode_range_a or "CJK" in unicode_range_b - ): - return False - if range_a_jp_chars and range_b_jp_chars: - 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 - if unicode_range_a == "Basic Latin" or unicode_range_b == "Basic Latin": - 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: list[MessDetectorPlugin] = [ - md_class() for md_class in MessDetectorPlugin.__subclasses__() - ] - - length: int = len(decoded_sequence) + 1 - - mean_mess_ratio: float = 0.0 - - if length < 512: - intermediary_mean_mess_ratio_calc: int = 32 - elif length <= 1024: - intermediary_mean_mess_ratio_calc = 64 - else: - intermediary_mean_mess_ratio_calc = 128 - - for character, index in zip(decoded_sequence + "\n", range(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: - logger = getLogger("charset_normalizer") - - logger.log( - TRACE, - "Mess-detector extended-analysis start. " - f"intermediary_mean_mess_ratio_calc={intermediary_mean_mess_ratio_calc} mean_mess_ratio={mean_mess_ratio} " - f"maximum_threshold={maximum_threshold}", - ) - - if len(decoded_sequence) > 16: - logger.log(TRACE, f"Starting with: {decoded_sequence[:16]}") - logger.log(TRACE, f"Ending with: {decoded_sequence[-16::]}") - - for dt in detectors: - logger.log(TRACE, f"{dt.__class__}: {dt.ratio}") - - return round(mean_mess_ratio, 3) diff --git a/venv/lib/python3.12/site-packages/charset_normalizer/md__mypyc.cpython-312-x86_64-linux-gnu.so b/venv/lib/python3.12/site-packages/charset_normalizer/md__mypyc.cpython-312-x86_64-linux-gnu.so deleted file mode 100755 index b21e77b522ce460c689d283cd4387a97e4d6ee7a..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 290584 zcmeFa33yZ0*2jIypaszeM6Eaw5VRm_z=0y7DQzLu0+B%~%56#;Xt6`=AO%4pgSJ*A zqF(DG|AQ?k{vY{#>nE8D^~ui@=> zmFei81xE=pLw&0AE`{?jpa1Gc)nH7d^vvSop#rH-)iyBQ-mqgX$Bv(3oRstA7rwX7 zIpOux)o=CkAKrg+`r-XBFNebkJK@s``w_68+T5jA(Su&sfX*u{UyUCA#mjvk?q0_KVoh;V(o=xa?cjpJY1nq}C)iq&qQLp3eE3B3jOSwJG zFuVyC@5)my8a=MTFfO&*FH5_n`w=yUcWI}^CB{VilF5aKjXwU;3DZKoy9NEdjNadN z>pA#@4bL2wU>#y~>ar-old#cJu&BY>+ne@h&0*aPVAIwNt%CHf_F?W!`juGVpwe$iyvX%1N&as_rb2VpWw^S zu>V5fH~Rb?KL4Wc>f<1M=>)Ou40|H%-C^$m`%$o~%>v(h!rq(MG4OdT?8&72z~_mu zpA36H*iV6d0PF){Pl26pr-L2>`x&sG1^ZCg&xZXR*w2G~1njttq|XcC^CJ3=d^CN} zq|dSN>3}^O_VKVgVZRjiiLm1~nLaP0&#ClzIecCL`<1XyC+33BJo;V$pEK$EEch&h zy%_cqVx{oufxVJ+6@6lwbKv_trsu==1*ETo&+B1d0{e}`YT)xG*y~`w1@;xN-v;{~ zu;X?oeBK57-LT&S`@OK=2Rq*yK(B=T5!fGv{c+fzfE~A|;qw{TpN0K7*q?_Tw-@OX zzc<78mq@=%pRds8Yw-Cx?0(qS!@d#r7TDj0{ax5`dk;Q0!@h;|`|$YzeaGV;!uOA0 zZ)FVmr=&lp&#&Nf2khUG{vJL<^t}x}chUDB=`#$Ud+9s+`vt!L%JhEt{s-)T!Ja^4 zXeapWOy9e}=V7pSCyhRig6}P$RZ<_{@NP#g_b4XKwuM zDcjP_qwGCtZHsJ-njFs{bKCpm%elShc_fY{KxiQGtY92_#pGn`#&x@|GMz1o}Ua~ z{`pbIR6d=u_pz6UzIt~5!mUGA?C#&I_Rizq-Ie*xT(%clqdv$GSG=G*7$uy`!Ff=I4^S@1AJ+X7Q&3SM*-f zZElaJ?XOp5thxExb(g&R+FN7Ohjd-o>(NQpi+(RC1P*C)<6vEa|dr}}(z`U}%8YJO`|`}S8mpD?n$S8~E%MWb$P{`2Z9>Yp#GNvWuR z^tn&+=8kyv*aw>*9XNJC?VE3IntpG?o>2arkB{~qIi%l_cY9y`Y=zY}^{8Kaz3^kT zfA$MQw(mLp^Y(ilTRC!oYwM5=SAIF`zU<+z-Y{+2Rb5AYId1*)-o&))-`hOkyg#x# zEt@>5=IR#*ep<0Rl(6{B;aMfuy?Vji%;k5UH|wt@KleIw%sZ>bo%d1M;;QB+e*XHM zffcWO^Yict$Bj%bOe?whsq&Xvj}M-DQo%V7U)HbshUL#+mft>n!x#50d8zlqTf4dc zS{k(7ICYk}L zU-NU1qpx_=)3p2jzMDcH{d08T)jNOBf6RU4HQVmK;e@-tIIw8$sv~cDE;#Psgo~O# z`SSZMH{9^jx{ddJxPL+QEywguxHox5@$s*pbkiLZubXktZ6_Z*kmgIj?ZI;n%UZl; zXIkd+5BeT`=E<}Ao%uj}%2V&&F*fh?V{DIKUU$Zam);qkddr%#9)H~O>AX*a^ZHG{ z{o=xT4c)6dA6{~B!TIlxx!3d9i6b_STYbhQ=O458j(h6gUV6skcW-`s&A3&&?q5?o z^wgZ6O4k0g;J!)T)m?5KWxIYzmmSXJ2kt%MnjMpN&lzO-q4z}KJuW(a+qX?EH-CMSD|2{y)tCz(du;T5!;Wovrf~SvnPoGk z_dM&b%$qO%?3BEU1E(%L;q+tXRAs*V$W7CVze{{R-`jPkD>(15YlDZM{>OlYpF2Oc zU1A&m>ztIr%;mE@?p+g>@9OH!a+Tjd@`2pS8@{nUdf>XMr1R$fc;QD!{(R}h6`Aw) zJhW%Su+iSsqQ&pt`lZJ@sA}twkq5>PyYK83J;u+z%`-K3!Spi+?_N=vnlK_|WcI{+ zT=tUc-HV@VZhhm{!2Yh^*Uf0_+T+nDZ+~i8@Yg3dKC{T{+w(%tpXRsCe67znvj=|C z#mb; z%+Cw&`+5G_RUa%KH2kxT>%ZN&chS1NTX$X1Z*BJlZ@)hOw$lRBD|g)gvN3Aq+S(V# zE-UN&MnXaRS$7S7qJHSAti)HY`hH@Q9EIcme47gc|XMcx@|9!{Cw_gkC#*5pmBjekD ze@cA*p-FoyH;KKVC_}p*Oo_m_a^Ba?XRBGb?dXsn>Chh8QlX2iglQ=wP(vMP2>gz-3 zNAcRHuYdgbJZ$3UTo@nX#kq$`d){l}{~VM0`pINmT4a*$W)nXbnv}P~q#g%$k6*60 zOyY2*NqKKGvA@WqzV<>eg4WZXMoG7k4J$$ycF|D7h|cBV;uR>ERtytrMK9G{k~ zQm*e!+H)UR42+kbXHCY9hfU)1j!C(aj*IXA6_a{-(4<^X1CKZU3^M8Oy-oVjI+J*I zG8wn;F&T%SHE9ovP11eDWPEtk#Q%LJ{jtD^AI}8f5TXuSok@SUnzT=k$v8RMo94DqfOe?wuHR(bcobS@ymW_~%vWccw4X0b z+VjK{;`=W#vH!y)K7s!6{j4{!&mIup{^LRM`D-TmNj8bY6DH%p6q9%sn2ck!CiQrg zNj<)4avk~Br2R}X@qdJgpD$p360bdsGr7J$X%e@ECjI50$vFIrS-&%>$Indq-5`_p zu-?S~M<((4(WG2cO~$KHCiV5CNxe@qiO)+W?P``u`=4sUhnwVcrO7yOu1Wj(!X*C3 zn8bON$vC{nP_lp3`7{R)M49}65r2slYTnbgcsZ5`+3M@9p+n;INxY8U%F**eE&5j<=tU2ZeL}> zKQkF;a!vZhEhhbOyh%Mao7Ce6&>o;^b=V#?X+M2U;?Ton9P1DLs29AE&_EA@@wqW> zuR(u7ZhaOC2pc}v#qBy6&yfexBydV>?1FkkZto`TAA$J|Zrh^@j8#~FdmFo3{D#Wn7Lgph|cekZgm z^keZ!2X~6I;GF@APw;EWao&U5!_epnu~Z(*Aa`KMMMt;8#d~5^)RkYvlfP$zPBk##7M0klVIPu$%0w zVemm7ER!6Xx7gmK@&@q1IBX}7pVJ_2!X951fUR8oAD%r!{R@sSSHN~M@jt2kSn!4wvy?2zf&m&$y_3Q5wTfg%u&d!Uay=qstlAkd7nL~d5>_`6T z#Rb(L7eRTkT&-HUwnIf=eq8i&$awN|5&5xDgBmZJi!qks6W07}f(tYHaaPBc_hZ$6 zFPHfbkpI`jJOSFt4U(Tp{LM3@AIp5{=P}}Ash!xrk@l)zJkw3ud+0@)v1Gr6#;d01 zq@S%&e%vO&;3@K1F8x6B7TW-el_mv`_t0ezRei%!jyvQ3Kmf&OZ|G8)ny$mPbaKWb9=Ut~r zdk?(`qsBKcwG;asSuZNi4r&h#OQin-@_)0H{JbIgZIr<8P`}uo6Su^sn+VrC%xCZt z>0gciXHYx0=1D*K1V8B8DHhS4e#qIM`B@gVA_PgbW zcqa?(!_M(rd_?L^h%(~unI)AgtH3*i#m2&%^hda((gAK+F+@$^wVA0j>`h04`Sg6>pb zcT&6ZJtoVg;x>rJRWH8i1l!%vzH$2u22#vV6TYMdn;QRfVLV4}c~Wv!t|q!(IPZ$J zPo(%b=gRzCB)q{pZRFoxB<+_Fe;WoO^dIy}do}*tM)hT*`nrbflc-<&n_}~GG{xC^ zkL0(I{dgMB0}jcrmLJB`)c(UuB{+xdYefHo>$TR-=h1bxDJbo)Ap3hDUF;V@ZCu(* z@oB)9?qE~#>_>6%&XRmK`I!#$YK((zk>skpBPl-C>tf@RM)l&Qm-JNq9!7q=*T<&2 z0Hml#YH#V3?xWOhz4+oEY|77R5TBmLv4%@4*TbrQua)_Ej{Hnfe4ga$`uireL+fhk zU$vjZ;eHeIMFI9yS(G zKAR|?lPTTRbbYbY^##H!w(FrFST37GI(UnCA1YUHp7j47@vEu*yXqz1PP~NrQ3LfO z$e!3IPW$H<1J#`9rR zk4;)VeleKJTQ18B$%*a0ev*6eg;m(Dk{`yS$4cHr_ZK&bqlS@A@$t@=h69QBrGDpJ zDLECx_=Dz44Hc5BdDms9OaFF!!3H+fzdlp@F(mtEgO{I3_qIRYF%P(*u_KQHOG@L_z5}-jM57Ky5MLdV*fvyLny&4aXpmt)> z`%xF^N4yXZJ~q<;)K2B{P@IR8|L-F;# zPrnw=OR4?%Xx^^kiSKG-x*oc|sCJ%0={8*}(=DWQds2K{cF8Xz{w1|rJH-vUmDrwz zev1CZ3+O;pf0;2za@!c$FKD`N%%b@CsNS2%&uuEsS{#A;9q_SKcl6+lkDFY_1MdB(Rdyr{v3^O{;Or&`VoJD+P|TVCwLoz*Bv`u zcS3R)HBN);IC7hIJ(@uCOe@{LzefHqg9;V(c%#hc9mF?MKXPjQsGRcSnj`Ji_%`t@ z>Bn=c%>S3i)Sll^N~-*C3{qwdRYrSaB9>l^;A($SaH-h$N5my-W0$&YKM^pgW!5Vz}2mHBb) zk@->edj{pxO8JCvi7kQBZKCxnH9o&U<#lQ6fh$jx{+phZ{#Ek0e*~!xN#S zVY>=e$$YB*yALve+(+rcurIbJs9u6J?!oXPwjZb-eN>O*WirOms$bAL?VV(QfVh3G zG*t7S+i1MMk08oHYK-BKuWvp+|em7cyNMMvX;eZz1~&$lglz((t&nSM_oW^{=pY zUC5_6yC}|X^0Tp@OjrHEkGgJtN9DCsJ)TYW-%&dWTrA_J+Vf#usl3BvepH1?{{y`6H3D9nEn@RRfjj{1L z3i=J^$42YwQ>D4lTU|#+Nc-;c!ziNr7tg&C+)wt|)UI65NZw!BtM-45%#Ug(>BQ~C zRXlsr_0gdF(0SxP4;m8Yv*8=*_#NUmQ=Bc@{n0w=Uw*po3@7{T#GTad6u*)Bmu0*3 z55tAnTBu$5o|0VEV=9d^O+QGk#+l=2{I@TX zr1FNpm3%wd<0r`qF|B>d^t{Ws6CC-As1*7&8 z?kV%H%JnK;H@%6myf+M(qF!jeaXI;!W|iFahV&2BB(@{Pb?rF#gF1PkhSSA%9?gHO zbU!kU_);~_(EWvKKVL#NFkQPL{ljHTY;!68&J{AB0V{Dx7wvttaP_*x#yvFOZdxS$ zK=%~eSeQ7Wy@3-9*i<|BQom>zDY=?&kAwz;_BOh{sPf)O{o1=w=0}aI_f!1sbYIg? zqym5INc9z@iR5uI8RONH<@K~dyB}Og<8uSeThhqSDUbookLzsdU?uSnp}~l9(K>^R z_+}W8kp~;3y=sTY_m@1dMejMJ#UH+&_*9I`)){JY5iLgJ0ot_>Mxg5{yj85bdmjdYPWW3w>J{+O6Bsb zmHAiW`K{D`{51c3iR=rhew(QOs`~Zylks%DC;g~?5up4SG!9Q7KLd#SDbCQm#dasf z)2fZneW{%o)PG^xBeu?|Ee3ldcQ?ozn4c@;{C8g2RgdFf;KKH18!ini$o zU+eGvC_jE`w`0iv80wD}dLF%+{CuS9_eyD4MEnopO&WiM@?)X3FU^w!v>q~* zcp7mFtz)kt-j&+9liIl&pU*o(mN!i6@Tz_OHdt~yt;1YIemrh*T~J9JTAAuUGAP$R8i?JpFA$TxUAGY zId4X>TONylBsaf0FL!29XJXb2HpCb0?RT zjms;YJ85pojI!bh<<6?o{K~4l%A>XK~f6qS9R4ib{(_w!q_f$Ow6i^^lgI?=Hnt z-31-bB-1ISp7Ns7N-W2}W#cX`npK2_CqI*_Dm+E`MP*eL8C9O*qI^hHCU5FBdd9@O z(phd^s)$dIyL_sG(pf58ld9qd zSg%|2h;d72QT|oM?p%=wTwWyvse*8Nu{#eFoeb^KE$RV;s-H3CWhIdWIE>Vfg6U-?p1gAR)S}A5 zv`Oh%S&_4(-|=qD7uNKoxiB!4$hxkmghqymD=%54Fldx!L95Km$Iwi2UtQ%c&3EUf zmqF(%Ditj_t$bFlGq1eDEnKIS7F^<;bC;JPsDLp{vzzEHfzbix9g$p$#Lph4CC(F; ziGT?u645cvARl0&vKQ-q=y|yazy!XU@>T)69AYoaE3Tp|8e~seq?c6~`LIX8k=n;o$$Cm@Mczy?2qGL^Ra9IchHcMWKH(UXS5cW> z=9!ybmj5tk*aL*?~`EihGVO;lbQ-MQ9nu`mySbnMf_rd zjxj^rU)78XIS0X+Q(i@WQBm%k!lFudg$J*UYzmcCF*V9n2HYOHfU5jWBofI1OxG*s zK%Zx6PR=VThDjG(?#L>$v_RTK+?JGGw)&$PP z<7wsPd2mApGjss>k(*U9scJ^01W}8alPctlLxh}7lVo}qm&xh4YMof4SvU=&j9vy) z{<89XxLp|Mt}KMX1KK+~Gm=f&%OjFXpAEO3GyuRQ3k41zU?sk*`K}ODDDfR<wjxLE`;t1GdqtB}djAR@(J zjVdyapM>FK8hwHmuEjBKJg%y^vdB|Bm!ALwnHyRrH=7u-) z=lnhbk{6O13$;;I!Sa#|w;=MOBm)Xn5FMJt$+D?JI~EEWq!T7)Fan9#snmGNcrC&u ziwFasFx$<8m_UXo6X}sI0zlnL2yapAc#cFPig=+06DK8cK`il9&dtb!+iTh3!CG}F zk};ugkz^{~kK z>P%HR5b=u3io|UtCWlgvQ4nKt4T}bH;tQ$RTJ@=m+fCd|I|LF>ewhrWy)RPUmBmAx^LY0khUJEHM>A zo(PvHY#QzvxWWVnbJKAmBughv$K#3=E>A|*QJ@<}zGFC|4kFG~ayawD1(=Mgk`f%w z;A`$gxONwnMCa*{S+V}0&Y@HEHJiz7wF?S_&ah}j*SJgJ%vfu5Aqy=lUSy*~6v|*F zq^felOu7bCRKk5!xiNE2c@Zp6&74_WRZ(c<&7kXEZWgSl8ZqU8nFub^!X+B+AE_S1 zSect!GS@RVKi7>TNN%NAU=sH_bSs)xA+6!m$eksA!3rP~oGH>>gmdors*)M*auc%BNC%%0`XS1B9At-Vs^0A zir3*dJWzIukJRiIe<}1$~ zieh3)p*K0&u~g=UF&RIE85>K|%1u|q{!HIt7IWovS_FtdP&J#hNWn3)9QW#Y8w)JmZ>FS>}Pcw{TiY(?#dpvF=jS!Ze(E+ zUYuWrPnBUAC@;S_uc89|h^u;>Ly#YF2(vR8=A3vUv_9q`t1yMdlLDLw(p;C;GvO`?pA&00DbZ0J@82TXsSvkAqRYdb zwJ2Kdq+)l`tU{QGV;H0E9eEXWcTDMFwCJf|bX`zBkVJ%v@)LBqgMGw*AF)gcI^1S9rG}3Ak5xZ}PSguCFi?j;t5q^J;kM zK-@7D$u~RLL?5z*kJxc~jZZJD#d@Kf?BRo4sKj~hQV2iY!s9oXmt!g95RBilN<45| zk}E&(We_-#7_>4unWnJEn07c9n@sHaIhI4X-g4M9J_8>X=xco zw+!wPB1Ps|7I8vD?9ve--YI}*)fIC~^RZ`RYlic2AW+{K##3oMKn?`p5ATK4U54-o;U)TyMzLl78bX~ji(75D|~9p1c9#lq96!9j}`&mc%*F<`(r z8!beh)TMnU{aTN;)%pt18CV-x;B+f8l;r_{64Fsk%3Q zSn%SiBC z3m*)#UVx9f5V3Be9x5;^h0rRtEM{Sf=`ZoxaEw7TlB)QT!<2O#X2h}y^zX=WT6Fb< zR#al2!l%27#A85mF|nesXeKYa1gzxQx`hPH0@6_r{#ke!Www!bB$#D{F}u-4m2+Sj z7)v$51236U0da9(eVpWoW*P z7IE>neKE%2-&w1Kb@v@d(|B$>SaopMv9ZPY>2SD%gJ@%n-?(Gk{f+S$C=5ErRFWZ6}p4*vtuj9`&V|y{CBM~ zzIlh%rkQnUOxp3kX&t849Y#TMiRf6hnu88CryVz`k`7k!L(R=_h$*Vbt%zI!i|2xX zSIsLbU{(f^hnKlwTv9Vk?V|j*XVM^60`905V|>ZCH{_TvCa;mnHG2t!S_bnG85&_R zAh#HAd*GdZfOOB3n>(|rvZ@?jLT7L$-nhf-B;wfw8N!QV@W!=xkV6D!G;sSf>!IwbDvQ89%wxqPBqu$i8!I1)hzC;9JjP9^M2z~`@V5Z)ss!d8 zztWATk|J12zoc*!g-n&GJwPZ7_oC_B@JIv>BC zXN=9x8l9dy?98F(M7|C?^IZHBkc7DZ!EaW=fAasa7V%iDMSKG`!SQS67 zvFCS=ThdsYf5ne}#{X99C5i9v@2&pcBEIMU(*H)_|0@x|@u-ur0se+l{T&pc9UiwU=yaGMFYn{cNIcbRaH3HO?Cp9ya;;Y}vo zZ^8p6JZQqhCfv~e{mn@HO}N#B+f2Cn_t#YY2I$|XacK6>_mcIl|9hZ{tAF=L`SEv> z_Jx`sqqF25jXQ`}Ydom_y&R4E$i7D7t;BsAw|0@~)@!_wc!S29h&O7ym3WiJQ}7RD zVQbcSA#uOPn~1k)JV-pC@sz`)|5lBAhzB*^Ks==JR^nleCm$~Tw`<%%+@RlqSM}>7 zo~ZFw;uei3Crbax8g~)5YP^AXipGP)Z5mJRCjF;s+(q23an)`e8gDsD`f+MJo4A$! zo?OLY2aTU88du}BSL5~6FKRTd#^s>Kd(k)?(zwxE=F@(U{8aflp6neOH)^C^gT}37 z->7j5*&Fx9`ahlQ6E&Vl`EhAn<-btl$z<=>xbokkaVyzd?~BckDsPI$t(1SS&ME&j z8n=;sP~$59A&uKq{O^y=kIKJ8g|A%Aqqw??2c)g0h##R0sHSSmOe65fD*q0Rx2X7QT;;z};|9$G zjK*01D*uTZw~)O{<0}7!8gEtc*SN}mi^hX0{*T4xN98|7<5tR#SLbT{*SL-B0~)_g z-8X4`82JfnJe9byIyRpd61QkPow!xw7ZbN>+)3Q7@hQZe8drW?8dvFhH2xIb-+48z z{P;Ak{4{7>`DxPl6_iiE#%B-@Xk3*ysBu-^u*OTsPs-!5@h>OdsPW}0KN@$vDbG)S zBG%6%WN*{B_i*{|*)(Z9rMo=8S>qP^_ul*(_jQtfLK^o|e%dwO@TBygLZ50L=szge z6H+zqqknf+ou}-_(fwVcW^b>da%ns~UjBPaEgCWke{%|kES@c zYdr9(%umi!vGro3bUhmP^^o>qjTchAv}-*4yNsLhbgX|n{X>u`8gJMr?NT)!BweU+ z8>}GVR;_U#{rgGkJXJ3aDpyFeZ`v>O8P>Reh4i1;6r2AVDz8Q3-dbs&tnsFavVLtE zA4mB~)wqrP*fs9IRQk!$cq8SRiDM}z*|+-i;cC|#e%J&Ce@ zEo)-^tR(wnjr*wmTQzR!Ed4k%?%gE)=4jk_R`ME+TdDomYurcwzMVQxwSQH=iR4dl z>rGTHjr%6c`c2XJ%T!*Q#sk!DQ#IZ&N&0bWT-8gC#y#{8f;VgY9ZEN#@j!2xf9G?t z^%5le9G(9r+o4P2-d@sAjmBLq(r>-S?axczqHzn=ORL6x^!qvLJQaVVm-OQxe~LSA zrgCZAdWDQ8R6KlN*$#yywG{4{F(TJqDRaS!=v*0^_y z^b^py>esCr_cqCTNqsT4UY1k3PK{fSl=cCQKS1`a8uw7Y4r<)jh1x@NY`XThq)yhj zpR_~c_{0jg9F2SF-)UCoss0vD@`AEy2o(6}*O#xtaG)o#NYZy-PI8n;|2{a9X# zE$<5yw`7e6sJ&S=?xp^is&Q4nc8!O}%5}jHh#LY(A5ZkUB@>h8nju zZtp7n)M(uLw)9i4ar?`Xw`e>}^ZZtgd+FabSLdnveTU-dAb*PcmQlGh9{h)lPoc(D z{dzQRCqLC14^unwY5WVyPrb&iRIUb{(+?FiYh2Z@U*k6VozK))V(aTCO4q4zS2r1l zfX2HXEzfV&c*C#qx*XKFkLF8>ug0cpyd!n8#{Hxn8V^z&ay0Ixf2Uuar|R)!%4dsa zZ@Y!crE$ND`me@S{f0Fjr21{wcmRJO7dFdlvE^0ulC1G?rnIlt_)yBfPvg$+GXIv> zWBuEy-zDpu>cy&Y3yrG|jR&b-ax`xEWqLIl4^X|-Yuro!uDLo-)r*Q}BKcE1K=oqL zc*6`CpA?N>O!2X4+)I8^HQtmb{WvwQ>Lo|x{)c3on>FsDI0rNyK1|v>--xZ38nVyP zxQE_4)p;uZ(BpyW)lTX)ZY4hr8u#T(Kg}Ayj`HKzxQE(pi^i@0l;sU-{5J9v z(zu2CS6JhI8lMx_$F>L6-YgpT?v&|PYkW1O>(hACUvj*)Y>4&$D%mG%+)nMms&OZA zhsGP;lYVnFZqWK$y~e}zyGH7`YCo#HiFBUgwtJ~vY5Wt)zgl;U*msiosn+a$-6Z#F z{QD%y>owj=_I{14=i03rf6XHO1T{W{c)P|wAa2lln96^D;>j9!(EQ4(@e{~CRpZ|h zw`)9s?jKzmKZ(^n z%B$8nl)Wl%wPvr%>(#g_Z@tDou;*+n{k(UcbgwdDZ=aDwnF?WSXBUuF7lG zxGHa|##MRk8dv4b(YPwFOXI4%)f!jj^=e#|w?X5oyg`kt^0sSSmDiy8po)VkZ?eW! zd94~((aO?Z-d5F{+l(f^6%HU%73fIRsMq-SNU((xXQn=S5iAaN##@;m2jjG)EBrVar=JEBJcn^B^W$Qie$rIf7cx#i zktVo@arGNYc%Yi`tAwTepO^7s#%mb&Fz#dgYR2mse}d(|f$=J4-^e&U$`wbO822+j z&5X}ue*BE*Gy4|C7c%<*{q;ODtU* zRL0jbdpqOju=;XsmgPbhoI9BPQ_R1U@qWxt4&xUw?qZxCU5H#2GX5v??_qo+ z%YQZFn;7>p{ypAl)xh{i%ugfZ^iz-GXcObxn0+(j=d*PE zjCW?dh4I0R2N?gB`EO5 z?qK{BR<0CUk3v73C(` z7^hbj#IZ)kE0~`a#&2dk#P~SI4WArm;Af2K4I-IzBI7JOhJ|r?rnFCHyo*HQ|5nE7 z6%D~t71usouy|&G>XyUN7T(y{Lw9_zB|3=3|_%Bh@p`*NYk$SHH20&KenqpX!Zl zO^o-BQ22Xi#?NH=_cMMBvu|OXuL}hjPhoyq89$Es2{Injj~Gv8_F=~BnE!Uhk7xGA zt>#hLOtn$&A|>@5{J@ z@qUau8Sl?{4&wt@K3$BT!t4tfho97rY#zo3MkuVeFn%iIUdB@xuVH)&%a4!o3s^s` zXM7Oz)4=!^=BJVI9~f_9{B-80nQ`@7)_B;@IQ&F*WNTsk%m_7%0OMyd-pcsXEI&cU zZOlHz_{l5|VaA6t`*z0pI;XKB+WzUMy2V+Ej1OaeER27|@|n!|+05R`xcW_UJe6f%B3;~vIGGG5Ji3-j+~ z`~qfQ!}uu1eT-kocs=76G2Xzqo$*G-b6I|x7*AvN&5ZN;u%GdCX5Yei2IB$7GZ}AX zd<^43#>X-qV*F~B|1jfxLetLp0cLO97H$8pGoHx!#VlP5<9uG4%=mid$IAF6%ufpA z*^Jv5AIEqq<7uqF+Zi9v>>Z5r`)eoT6PSGt<4(q1j89~|kns(yydK7HV!WF1Nz9Lz z@yU$WFg}HGALExXUeEYc#v2&VVZ4#?%NcKCd>Z4;j9mk{IsVD@3g`E!|e#`$v@?nSC|mvl;g? zUcz_{xFg#B`SY?w#>cSwwJ^Sb`AKH{I>xPxdl^q* z{CdW1j33A1kjnTXW^ZSFG2;%#`SUv`%YZ$L(+{ZY7ZdlLwVJvP9jGxWwv61nUn0*uDzq53k8NZ2fKjU?bw=jM);{nD` zW9hasehae?GVWtM#Q3d@hZ*n0%G=I3U+*&h8EyY7n4d((Z)4oT_;8m0WXAb(QY+)P zGe0Se-@&+z@qaR&%D9cCYiE2s;||7;VBE<#e-4|&_uLcu!VeHH_cI?0t;i&3HZIzp?x@FwUPBH!^-N^V7sQe_q_o_@B()&-jfj-4@30 zWA*{YA7s3h@k-_=$T)xg8)Ez+<|oYf!;H5x{t5GM+!<~Ek1+d0##b?JVSG2^$&6c= ze=Fns`Em;5Uov|eq3;+v+F#Z(dKE_{Vaj0kfX=dNRcoXA|j6cJ86XRK*F#8(D-(=j!cp~#t&p3b2p@H!h=BJVIw-|3?{B6dY8NZvA z*U$Jn%)W*3&zOCH@pqYhE92iY`yk`*G5ZkX{QZhBAjDNv+J>y?8-oW@*j5jhKWW0&-?Tj}w z{uASV#`*g*EsS?#@eDA&gZXJ?{AKNOyq)nj#{c{EzY+Lv1pXU= z|3=`y5%_Ne{u_b+zeM1tq?7kM7XOgwsOx(DlbsC5Qh#Nqg8|3l4Tb_zWYb$8Tuq03Ppf!ZeYY}7qaTZNv1 z`bg9kp{Jof3bi5hMAS*B!v_Eiyco3wbx`QhsC%Lg2z@^4Ua0*-4?}%4>L#HFqwbBm zLFoRdk3sDdx)17OQG12%h59(u9-+IVPDbq#x)bW-Q9Fg+{}gC^MXSv&^gh%lptcFU z6ZMIxtwQfWeG+Pm(A!X-jM@--E9$VBvLLa#;LAGKfTHKZK-4~=??!zpYOl~MP@jg{BlJzEQ&78vUW9rOYNyciP!C3J7rGqv z>8Nc&&qh52wN>aDsLw!c5qcWxGf^8tPegqd>hPbU{!!ad2ZbJudMN6E(C4EbhT1Rm zFw|$GZW4Mh>T^&x2;Cp`xu|_Y_d$IgYOm0}P!C7#5xP6-RMak^JE0zd+9~vY=*ETk zs!f|+=zXY1qP7XW6ZHkCtwQfWJqoo&=xwMkL~RJY74=1^!+(hSM{P$P6nY)%G}Hm1 z*PM^LjLa#tQ7PUv{n@~GYyM$hZIt#T^ z=y|9wMr{|m9Q7rrZ9>mRosHTm^bFMFP+NqahI%||L+FX9C!h}R7xjWQfRLJvbd33ZdugHcaL-5_*-)KgIVgzkg-GSpt7d!e3++9Py#)H$eKLU%%a zIclfS`=0=fuVl2@h2Dqy3e+~CccQ)$wN>aHsHda02)zyUKTsP&Z$+JpI{dq+f7CA2 zL7~^7&O;p#dM)Z1sQp5(L7k7fN$Az63s5%*y%Mz>wNL1~QO`u}6?z5gS*Sfi--H@3 zKy5Ce7ojdf?G$<*>e;C6LYJey3bjq>*{F+ATZNv1x&*aF=xL}+Q5!-}L|ukD+%D=L zwFh-j=+UUJMja6PeAMNr{X!2zU4gnu=)tHfQ8x(PA9WRKpU{0!UxV5!bT8C%P# zj=CDPOXyCh=c0BBz5j90^HAG`-iP{H)Hb1aqMnc1D)bK23s75x-iG=*)P~SoQ7=Rt z{!P?BYA@=b(CbiNk2)aqTGWeB`-NVEdNJxIp;x0`g1SNIm8h4Z_6dDA>KjmdgibYzgx-ew ze$%E{UGXq&}&hzMC})P4eEzbHwnEO^~0zegkFjI5!61R z??$}}wO8mBs2@e`5&9<7ji_BhFGBqoYNyciP_IU97rGqvSs^~ggzhj8q|KFhoOEJb(7G8Q9p;eLFoRd zpGWNzx)16XP`UL;W&po6tK^zk=E- z^bXXoqP7UV4fSiN4WYN9ejRoACsF^X{iuUNuS5L?>VVK|QLjVo7kUlq^{AVKUX6MK z>IR`#qJ9&#Pw2Z*Z$#}CdIjoDs69g8gt`T_OXx+Y-$LyadLHVxQQL(sNBs_Jo6xgS zzl+)`^bFMRp|%J;4fST!hR_pHZ$Ta2C+Z({0CiC4(Wu`?9T56_)LT*eg&v0b1Jq4I z4@UhV>IR|vqy7lBPv}0VKSu2px)#j=B}KOXyChKSk{ndVeG6ZK&-+??e3= zYManIQGbrwD)bK2U!b-Ky$$u3s12dFqW%hXc(15`)Iroiq1U0_jyfRpTGTsG`-NVE z`fJopLa#>s4eAD=SEBwFwNL1~QGbWpEA$G~-=p>jeG}>sYM0Q9P`9CW3Ox_?PSkdx z%Tez_Z4-Jn>K{;Bg`ROH8#VNw66!>EHok4C*0bwKFzQSU?T z7kU`#pHMdmJs9=Rs2hatkNOwXKB4=d{uQ-X=w7IQL+uf|JL-1SE}=W2{vEYb=>3m^ z-jCWY^gh&optcFU6ZM~{twQfW{TFJB(A!WSKy3)U74<>X;XR`MQR6G)Z9$>ep-w;@ z5PB_YeAL_K7kUlq&ZwJ&UX2=Gfoy9KdL?Rn)ve7Z^xdfO)wDLR&?`_Mj@l#iO{f!5 zyM$hZ8vo?4%_;Oe)ZJ0rg)T>puQs*Wgr1GM2WqR(Gf?9r>o$wf(@-CU+7Nmo>Lk?R zA4UD6##dL`fLeEA$ z1hrM@8K}=dZ4r7J>N8OrLQh0}7V7X1qW)3it95Nbp+}=0iaH?l`KX7X_6t1>_1UPK zgdU9g9Mla$_eXs$YM;=3P~)Fiw|Rx`g&JQWZ1V`+9W}m^*X9zs6Y3GDokH(_1T?;q z)@B!aAL@~)Z9?xveF18#&^u7$Bj`4Z(A!X7h}sZ(E9#3-hj$&saUf=cb;CF6Vcl@q zxksD;A9bmr{V-~T?toi|wx)Rra9~uzHay;S|EKUVqP_AMIOV%L;X5ofb~_kM>gz>^ z>**8h-$%n`=e~^}gAO=q!;Uw8yvXrJduK<&M#uXHDtm*2=kJyd5)TGvCiTsTo{#I9 z-cgUhxklCLQyhy&tp!WNQTuIW4{-g|icUu8F<90K6+l&P?79H#5~f4ik@WHWwmEQc z=9x)-mx!Xq{iY5M^{=1F419m5(7Y|IZ5!%$EIn9x(iPdY-#KbS)6=fR5ZVpL;_o3;A0PY(qS|}~;Po;t$iYxeWt{Cdaoay;(W%;FYVKznC{@?U}x|aX5u|EEV__wg~uy|McA^wLd&;M0= ze?oivXp(4bwLgjW)E(Pf(o(#u%Bq_`KsGvpc>sD!Vb(u}-p=}mci~WJ{|C_c{V9RlAF6%)r~1>+vOS3LhmSW`VEbkjkPq6XY1sgJ ziw1BMHGs5(A3_Vj)@zr&!+Hf&Np@{eL@qiG!T2OhEAQ0n^+(B<@A@vrB@R#`!K&rE z9#rE~vW(~Bx0%KB85ravm)N^cd%oPO;*#RG($hG*sK6(WL|0Bphx&pr`(nPiQx~|6`>iAGU&)Q7L z7I=L0R(SY_-s*g~@C08|BTZSD*G_e)OgUq6-yy$Pe(;88Z5*2nWp^Y%9_{LEEBLm> zc+kr0s5^YAzq*@aaR|;kyfRVE8`^IB?%+YVj;CFgHYIKHlu6ljb1dVQ{(4BvBQ{nZmo@Ur4arsEE3)b`-ZY@0rcF=#$NHJRp}X1T9Q?u1 z@dK25Y~rt8Ttl){PIc6!M}*Z;`(@~@?++e?_76SfO>q5V)w}XCCmcHJoN#v6Rm;Vc z=EWT_A*xFq>JMeY(gG&EJCZb6&X<<%h~)`jx$8q{{Br!6BIXV7z&6wiR_9=v1aq>3 zj@qw6U+)mP=!@9{?WptGp*`V)+$*MwNs>H2^zzqe|D~gLlcV;{&^S09@@}QG4*JAN zOLtd7-`)Uz_FOT&Z4lfBnTlA*xIJmM1t z{&71LxHe+|JYGIOv>j^5QHNsjhUAES-B`FT{H?z!(%*O7->oM8QvL;hU8TRx++W)N z!r$|<+Fs-S_I?|`ytaQKe{Sh-Blq`UJb!;T-~7Kmu8%*urvB)t{Rj>)U~@LEx}vJ(0y>HUrBB_fr=`wL=FvFZ4dNPj>Qr=t3~>ugf%GKpZOv z#7v`V6vpiaDA=yE+3{YH2B0_Q8Nexmy)U{a#Ex6om6usPi!YbHCiR zNNROkByNa$!S&xNzQLGzg)Hx;^kk?9sCBq)3X0i+xFUQclQ_KU-B2yMe^b@VrgU7Z zkoIe%_D?JORiVq#{sFT852WAi-%S70ul}>?*P_3Fr~Lon^t=6=>3{mAS@~x~>OTd( z!MJ{~62^wZ9h=g{#EDM?X2}L(z_Dn3za6db*HwML5Gum-o{qMUXnTUu1MX-wAzM14VX(>Kti^RA9 zV=Q{xVE6`Cse_d#%4plLq!4Ww&BU}TX$d~BL$5xpi%9=!iN^0$74PRlzkd$-e=-{H zX#Lz0u}`X52*FkEmzHCs-+=Sl3gMd=$5_9YH-PNi5&YaCcw?BTn7QV6aN9Rvl zVQ6Rbr-wcjSCzgvm-^%Y4qfr)QNGZ%+u&Ga{&b|Abq&I^9*mw9oku0%hzf%q%%ir$ zK#tcZn2_OOiawtk9h;w{MSd!CL)~K%ycfn?xIm;r4JC`Zx;RpQ#T_PbFzTzs3m|b3 zM=gEyGjun4s(b%x?Be1e@s8SA!3_UgKKAzdYp|l@H-Sh zysL-lN8>*crk*VRr?iU8TyCfj6g(Q>CtxuBpOm-qoBv38M?v2I-ST#eU)~uzW6FE> zCsf|SQ1EDZU-{~PR^BBrt^W_y?>Gqlzgynp;hZ@2TMlzKR=?>VQ+dyaf=A2yE)1vt zllr|KI^KVvywf50|898)!8wug()cfCDM?H5u_5#*F^VQFZIsF;`sqyIsp8uZ_y+e- zku zzs!U4+GfHx5l1$TCoLHxjOkjKR5P5PI~dO$i04`nv+Hfr5+nA!y*MJ$C1dF~AVRyL z6|`-GZ)*GteFh}%_&f}5t6BT${Gn(leQ~6{5&fEs&!2%^w0V`l=nu_HjL(-w&x$)f zr@>Hji1B$P-X2Epw<|sn?RjBnc1(hQ!T<>gx^P?-wLKfYQS0zwz0f>{uB>Vv6TPzH zDno~Xyk~SEzvn9q9@MY6j`%Pg8o&P;Gk({wx}PhmMP9m>7J~@6KZ1IgfjFlA{viw_ z^*({0HyY171J6r^Z;|>t0m&smdXH` zyv~J6{-4C_FDPtmymldp#>+8sRPA-Jy0#=A9#f@FRm)fSa7e7AlqEVwp7F_iuvm)E z_#LpU72kY;8@bG(zh*BRl?+F-M^;!ClwVvo z|EJ{8El^KcwHw6k>^g9e21{0sWk%bs91r`~8LeGGmDlE=dV{GvS1h8!twqJ$r5X~@YDLw~JtLriVRtb}q;J}+!+hu^G zt}{%2p$}pY>Rg4(YoP&<&FtE5v%nVC25OQZuy{NR%#)TTfPw;r4nhvveuiO(tzhenPKfH&QuyO*~p8I;+4 ztd+=ki8l&3Ug9{Kv=m>d0wu1YNlS6|49YIXSeyfkr%N=dI^baJ6&3#pPB3yxS2s$P zBNaY7mscRn_oj3^XnFmNKL;KJ-2vweUQ7k-BiHAoB{<(@!0N1_kuuK^J%!Sfqq&yURc zla_d6&&PHXxqcVm`Dfty(_+uhQSnMz@_g+1tN8hM;rY9vnYS&EJ>MBUe^%`IIsE)f z@cbw7{4{oc=pH2ffauqseP2T6qt~DH?}!UcUon693l5pgAMSY9ksaH2@B*FF(m)i#V|7J z=2|oA?3TLe=VT_dFa0cO$z2eiw7MPx7XN-$(v3q7!w0c&!m_IqYqzA;o&%%P1>gss zr7k`I$CHjSjKyzQ90}pH+8%HWM#2nu@(O1pizH6$4hye!9?K=mx_p3#tnlU7to#@!)9k_$-(kil) zAj;Q!z~cRo{}s@uYCm4QE-|Y!tO2LNb;VJ4tOMRaSiC;LG2+vtCHN*%TJ5JN=#bv4qk`h(w4RO#{|sL4W-cUvcOlOW7%biSx{k#ZAE}o|Bpm= zYgZXr2qwgI7z8xw=J$Z%dbb#mA|XfOgp3+(_e9!lUFLuhtx3yEAoUT`ZArJ_&tXH+ zs*bM990C`@9*)KEcpat*$q-m^fog}WC4mtJCTlTdJrTpRbUS#&l3bZx2O%Fw~rg~;kcv;JJ6vM9Cn5_mtFfwR{rN$Nhyv&Uu9z%LlrReV|<)h zwSGr!f~YARH?v`ZJ~3;=w(G9K6jCy3zZ(kurFGW`HmLvo*T~B?*>wppkysyjoao5k zw0L8};!SWRo$OC`R0WL>o4_pxp<`s!ehu@U zj6r{7j`%a_mQ4_<4Cojs*>%MOtd82^0g15OKERSu`%4;haL9e~t{yM}${6uW(vmyC z*pdHcHa_?&Q~ zfS zz7B>kRyoigWedryeXni-tg%*EGDqx5x+Mu?IielPxuP8kvFw;H_a+!=NfS0@FYDR{ zUl+G0WW$h=l<__qb;YCEN!jpX5_H8qIBvj{5*Wnf$#U@!BW>bP|3pXaJ_yStZ^49h z4BYfhySxqWDQHL$9>ZDzBh^Iko$jaXcgT))7zE6Qzd*KzO?=xzvteLg{ z4{>h-9z~Tk{3k#l2v|`;BZ9^;YCyn5i6$(PNP-nIxmDfO0dc{&1PA?+;;-cyTu}mUp z)1TP!v000%i$Qc+egDI)m@FK8tsf;&6ETzmv6@`B3-!ew&@kSCsqIt~k)9~_Pb?`< zB2y-{s`ING*IP4MBkhtUO#=5d`6s~Fn$>#1bykeIpR56eR;*KN{#IDA1w6-^qa7OD zegm?to8)EgmPjp(lfmTH0zeYi5|83f*@e!%UFPFy8H;w!8 z3GQi8wJdjpV`B+TB_^rv@q_YCMjOIDCcxa*8b~UO7OAAWN_RVMSOM%J$c3>1cWa!t ztr-u)+2M%+TOx^Giy17*T;hae;rN+=!XxI^G%Uz<>k*1@eS+-_&ZEPyV&_n+CO#$0 zEtOFQ9GM{6_8-5$z|1V?P8i@lz&}3!#x1TXf8Clf7ePdvr7&UI57+`0Al8Cu%=-qO zUFvWQi^L`|VUq@U>YcPSAc`0y2C3WG+ZEMd(8EMWk{!OAl$&+?9b}fCKN{v_i^s1j_pHXHaHy*M8w~S@s`7RGdEYs`s7YAu)E0^&^`E$p z-2}gPZrHi=JKOr}TP}bx_*k! z@}T>Buf};(RIE5T!pKwNk71$|#i{t?9>B&sA1=`8@UNL@$NL_Rbpm@-uI+R-zf(a- zq&#WG9tOoqXJt+K$J72P3S3Dvays2mbVO$GAsu9otr>C0m`~t2{lIv?Nk7h*=xEeq zx9)p*9&OXC;FG*b;(~eCo!NhE@syF$&*^kjytbG8{5@h2yCp7YJYRp$uX|CLmmXKn z6aOzRph`OH%JMna?OoL$w%$@gc^UszJD&`5)_ObC4OBriu}Oh6jk4p9y){3Wa#fBi z(LkP(6Ny*N$*(N``MMI+`^_Z$7tb$ySP)CoWui^u>hCs^p$8m=UVAmPF|#@`Ofn94 z2bB`0Qe&#peW^-^N~O+Jdab_{%J8?3&d>0-30t}i%n%GE)XVc`pa>ENm5JXd77{ma zhFbx3($xfUSvnl+2(cjdXXz9YrCq>L^Sr#e*}Q5cuVg$deSdZ15-av4?Nl~wgQlF9 z)=9Na=SoqlY7TwntGt2Tg;U${@VNQ>fcz03idTSLrSVI}Eu2t!DlHyOP6q$r9?2-{ z+{)430b8Xd!j4G%!oqxTP98Qie)ji7un5UGE$7qW@m?Ei=q261z>~)2sU3%v6FE;? z?ybjetj2~dz|gS5j3lJ4&0-1}{4C-)Y@{ zNZpn25#_n_61C|evtbh0{c|o&?4wBJOg5j!_@8cCA#bcY$*XLX(lE^D)8z_L z`7};`no!MZ?8}3@Z8m^=8Ym|kC`~R0}YIVZknWqbcZ72EJ|FN>pZ8e+wpGwY`pVm z9T?B*gnMshV7v)B1UWn2is7KFStbWcZ*iV*lAyZ+52B-GY;>W}x51mOo@8eq|>xLK@Nq7?}m*DU*2(PqewJEH2 zb}-l;a9wRlP2#%3?AI!&E5gWir_4q};Om{u)~sg8DyDo@VYc{_Tp1hX4k(OXIH01o zeHFu_B58u)G$wafhB$oVMDVj4jQDfCt9eTG$2R4RR*WFJq}3|ca3@Zr<23KRJL%(P zoRNqW3hc%;InY?n2;920o@OfRL6`tnj-3}A3PiW_=$3x6VvAvL6-CReTVGXP_m7}x zBSfZGx>qj-CqL(XlYW);=gvZRFAO9i16S3jTZEJ{*k;A#hCZjvCj4vMDZ{A^hocU(DA}?qG^ETP=Svut)gvL{M(+-wheDLkiHvh2)^JaBDL+EGVRWQ?9WQVXN$K}v zau1)5d}}0VMnNTfuW~vUx;^Gep1ZA*J4I{(4xUFIsdJ%p{Pfj@`O)IcDhn5g>1x&B{=^VrZh5TkX6jzzO1E zVWsn?FxY*cV64Vjs5srI+PE;{>~t?D38(KK6=pe$;+SN1v~{J^t|s0#$gx99tquvA zo5Xp^;8#bU{d_&g}IqUERsm`fdQ>o?0$t-}se!jTR zPz)x1tg0M~LyzGFNDzt5w-V0?V|bcicc6o;?EqQDB)a9=4m7c3y;sMWz=vy0W`^v; z5R)ii1mxGYPmWh@&5suo0$8zu^eIkpNQrNhpxchW;v4Bi4D&ht?H$JlSr5&o3wYNJ zBQUn8R%kUwwQaS@A~D`p-dNtu1l=-4{zu07VEHPfW_fQjP%!Z|>x$jnm*|DQHT8!% zYrG!%)5Py;!S0vhme7;5ot`Wv>}(~UIQ=CI#;{hVGM#JRk~*`JNiNPB#et-ljI;-`tTSEpZ7zQDSL z4I1k47YNJo*Q5EXKhBdM-WI}vV0@C<`i>U@UnD4ae@c(1j9yu>n*q?c#N_w#v#eY1 zrzx>)wO2LouEZs3t3ej-9+9Y;r&@1-Ps-S>TZclW4g|a_C~M}=D3+(#mPzo!(|PhF zY{;iqtFca5AaiN~Fz+WtwIa*y|C$)#{%W<78)YjP(d+bQmG3g))z)f!ga;YJTafGB z#e@1gGLJwf`A{19k_1sA=bx)2_UQ7o{^@ilf2zutRyuQtou}|nZJqMEhSFBm!s_yE zWR&I#nRRIA2`ZH?=bk5)-ESxBhDX@(I|`=@1&PwFvvexzTm0bYv%JZ)pXuOFLASv~ zjBZK?V~8{E6OH7(*&Hgnp%75iMhZqAqIrd`UDF9a^7o(8=R z05X-T6Q_tTdQ~gVGZp_4s`x~z;z?3*861w3UsjkutxTeci0FC1{l1G7qJ zvF&V&#P=Toq*I?4E}k0jm7K8qAgXufIbIQ%!X^?iwG{!dPRlqM7oX~p?g%(~9| zCzXQr*)`7oR*YTLq;=*KUM*la|1q&U^{X6DY)raGI#T*Ka`>*DxWDirG_MLk1S9wn zXK_`JrC9BRNVY4{NtsOmEJftMnnass6Hz8&g|dA{9*S)qX8I2#lw*a>{sTFsSmERT zLqR0*T;Yp6M2M=1uVkizo{iopN+Z$(yB)Ak37k8M9>)J}fRZos_p4a333zBKjwlB| zYsQ;AMG~(RO5Y<azk6_drlX)AuXn8v3o+Ex;HS z?@O4v#T@{H1tkV~is67lmdm@3ffSjcg2yYOlFTfbtFi47zy4O4Y@O{4E!CUK`>n^EAc1tr(&3 zE77G?&!~Eu!3Y-fQBy{2-RxI&s{vM7L(|c`-9} z*o=WN<>yvpXGI|`=kc?|J1|5PF(yh6Wa)}=5Q9(?sUZQ#JQ*N|c+q$lFT8)~+dE9e z@(B5Y>crG+?@{T(5;<4U0PTDu{fQu(yq$RF`maBP4bpv9h=gpi=Eqw-NN!j?hCu3ODNnG zz4(8?zYJt|WgXctHlQ`^$gXAIc}0O8KfreKl#BpH@G^M+lO=k=OFs_${{`PD`y#R zUTm|-jzu(P+@?KPR z-r1_{vxCDslJ@*@llh)rZ!fEJ;_YPAnRME*-*b20&F~JlY9?IQddL4g1uwi_skR?| zS`jO7@|8oZQeqRR9O1CY>`zhHePo4>d{=qMCZ>9Ma>xCHRYbFAx?|+;5||Z}*IDjR zo?BE2acpKr`^*z-Yw7l-?E-=0w>H!L5!{m>q~RxdZc*qL;qOa9g`L7Z%YDk!55NA! z`nn$`fT7%|@HwV98a}7?^2)g$Q%M2Z(yqX@v~M*%;TLsp}#G~#V>z!&8k z!%F3(^y_?;G*3!DS&5YM$*HZf7Q*?3gPC!123G_arPi~!9Uce&_tX5l7XBumNIzdH z{2ra+kKw;~X`lZ?<@<%H=l^T|b&&Q#{QD7n_P{@-datm5WMAdR)EdURF9I+4u~+gp z@;{0X@#pt6L%2Q0S?Ha~5FkaLe4ovloGiDMI5J9*ll6{!A)v1!wllgPv*BNpJ@;+} zqVErRwQU5iuH#jvd>g(d+=>= z_Ld!X$+k(BZ9TowPK?-Tm+!ExYSI%NlTJHln06}OHtlSM276Jnw(~KcpD~{&`Dm=* zb8=PCK5ZYTZFfnxU9ybU88LC{j$mM#-!f@~oxPl3iI$h^CqX@)bE<)UkPrRZbmNL% zh?x=x=&EvM=Q13Z^zQX`_FQ|;x`Jpgi5eN&Ww|GbkB65h8eY~OO7}}%aVY>foI?Es ztHnhQ@A)qUk5iP{FaOOj;k(B~wpmTeh50G{knjPLtA*RS*UNEI_0fZzt3DHbjM@w4=lq@r?)pnAz zj8gXMY?X$$Oj?({oU~T;a$&jQ>vq%ZJZ4#>*~5Zn4OfHy8When1?QTA-u6e);1v8c zzb_C+mYA7Uk7JPq4_R5)^h|O5efbE-D}0V066Uzb&F44xsSs#(?J#A_r9OTQG@Ii0 z!VG?ohY2Ic3m4jrhY9u3p4RNQtE|}zoyGT5ZrM7%WQQ|%l4Z@_NWfEx0Ls6$s+Vd* zs@;=JLl?YZ7}1r6j8sLp-!mWo{HXc(^CKvhw%|&e4_p%sGn+$#(>fU*<1(0zQyT2Huj%ZTYu(a!Ys+m_1bacmL}~ zg#Ex*;O*5CUN&Cgzk&BGxqQ5C#D}-;VFRz}UBPd>RkV1#HL_D7&_SrvbG)6nmv<*r z2Ye8x_Im>(*N5?#591n28wCjL4>l4!AH8^D+fCMQo7s zHr}?T&U3$jpThOt6oBjPQ~e5`FXw2qKAk!UqAsZY&VZiggYMviUb!qgi~Z06K3BK( z*5F_ReEwXcJSp=lE&q$*$zxP%NzcffT$&PO?&hm?SH=Nz!0*#+-P?@PnDGMqTq>#r z-9>y`Jh`nE`w$IB2N3)xCB`(r?@-ejG#V)Dhc7s)%GKb(9}?SZ@#5za+~Ie#$77lBI!?d5eD!3+K#zV#i! zzX-M!(OZn|;G&4q^-7K&Z5w8-$&JNw@)4j8zSfutLDBn+U0J$J3>bJ(a zLB<0H^hgNnv)a0$*}M_t7l0K>bNA19F#)%L>H_9;1v3)H_xbGV6Zp58w-lV**_Wzo z-Mj=aR^vSWMZ3QrqKbO!Lc`qN4;tqFETN6*{n5Xhhp4*rS!UfVxnOWaar%5_HT+XC zQb{hIc%k3K(#d<%X!nl*!O}y&gaT8!3lxDTWoA(ZNdLhEN1573FSTyW(l(A3eVTjC z++Z+b^q*Qebpdj~gM=l9gijY35`Ompf-DR42N?7)>GOv^$vKPKa1Vpny^UZv!Z+(? z*<>I{?qiUgXWhJyKyB=xN+NEkXo1Mvx@p-C^(OB?#;r)B^dzk@@&`&R^kk1rTK<_l zn)R0O$czq(7I-&P)Q=MZJlDE$t^z)K#dzzCE}JMT9I?(oxpdn?{ulDHqTe%TmG!CQDbi~C1%>?Tddekstc#&F(mCjJg;_4l{M>(0{$6Z zP~|MEb{03UYgO6owrW`0uCifuyQ;FeoJWA)t=v4fp!PV<87!;ZJg1;`q#eJe%$h~K z`t&<)^g+!*-+`kdW=_+O?bp*99mYvTcEh5w%7(QS1h`w1ub4Pf2Uwx`g@Z*7WYE5?L=R(U~7Ym9ta`S=~-h zznV2Nf<23Sqf;BUwqpGcVB+0ga6X+)@hta26CUXq>9>Tx5?0=yED{LF@|2twHL28M$!%81Ix^NKlB}21{b*t{+3rG7CU0e{(TpK1v{=}t zP?nBVz9^qq6B$XE>^*C*N;a45d{rdHk~UcycH;v)P@XI*%T(seqHtNG6t{CXUoZQt zS)o6a5+cb+d_-R5OEQD9c}_*`Va;Bv%9kWkY*^Ed>DB1I4cp|!&b%!CVd~GST4M7{ z|C?4-{#K=R;ZISYKtQ&p{$Vm1F!x~pcyKs`)J}kK!T5ybAP_n*ZO}7f`js+xY zN$S39#RgH*Alivv)v?XdoGRzS!ur?m++bzB`Zk3YG5@z^nNFvK# zjSwpv{{VWZPg4cz6R*i91U%_pRUxK=PbX^Tz$}b^0_Q@8*2Yvh&DDwXaw}hh0bsG! z8)N)fwX?d$ndg=26LtgOZv}9ow5I{;-gY-bji=lWjLXa}-{=FfcCCYO(wYV9DmO1E zuo^$$SvEnG1&UYMyuMZCYoa_HcP08)+3-a>)xkjD5ZKSY&aJd&*pO8<{jx%9nDbSQ z^RdljX{9U=yHWP#$&6KjY@KGEo*m!U=yUuk_64y%`xy#EoX=!|As5oeQIazFfY=0vi;)g_6nGoK+lW=#_be|eqkE?uio%BG%L2FmXMFdPYR+q@sH>&8wI^g&}@K^x>LW zh}wu*$r$GRAsDl_IJoPF6O0oCjS^eFI9%~R5_~JSy*{GM`+5)s6W}x2fBgP{r*nj0-+R1 zp#HKx>oa|UZ{x*T)u85hEL~VQ79?mD@26rWB%NX`$EZiEX z7QXsU)AKxY2Zv;801(t5U;UI{{{G}!X1sk8iw+mtiH@9i{wMGSOF7>b1ODJNcX$ZP zE{e{V=#rv{TINzFe68*q5@|`T$b>>RIv6lS~IJR{2=5 zO2E)T50jqzMS5k!7us36@jdG9j5Lw=7}Sh0tMKhQr~R{8#IUUsDXM=O?uTGnbGSdXk~Jz2jJ`;J#NkV2ne-SQ<5 zfcd^mRPgGZ$$f)(tD5f%qx-Pdnd&{Xx;i4;kv$xG$))&ty0}~u%0?3BmkE}U`1yp% zB8Z9bT%};cgOZg*m{x2*k;B$jwSBz){7UIJTKWf2ps6xhRWw$xV*8eokjF!1e8Bw; zJEvXqfqNnfo?K}s&M1l`F2+Aatm?JiAMxUb?!3dT*r3*(u zvgm^KLf^|&85Vor07?0nsYks`{W?}bi9YVIV%yR8!Pcz4eYN7-D#_;+4N=N(tXm(~ z2XHFh4ZM%<_wkuZsT4kc0;b|Kt8XtKpL6)WoBH>g`T;)J$L|!M7y3p+_#7U>XU4}+ z?(L`GD$tXhKOUEsFPe)ph$JrEnd}wTzi&&^_zBuJ7AzYtVtdJh zvj7$RyI}a9I~xa@{8066^V|wM!5IY!T$)uqN4;Chvo#*^qktJ;`x-fxN8@s4S}(BF zR>HSdY3)mT11MnZZe`+%olJTuJM;VlY1>q0aSHb7{^`OzCspDF%G{M6Sr-TCRf zkcalZrBC?-CA~pftP20gr*F(Bf}jnEN~VTP{pJ4qX>Tf%jx>HQ=bgT3{(J{2DgLaJ z2l#^sdkKTybsxA5cpqr(!wfxcoL3^pm;9Qtz&Z9zQ1gWWmx(AP@BKT!ndCc4qpSz_ z-rO#$&wlg{BPQ0j-9Z?7N>+Nm2L$>mp~Cy2PV#N(!E)UN2|>+-3*96IU^~Qga-y%_ zA6Jg`_5rh*?tlJBN&3r=Kw&2+5b-Zfn0Vl!TlhrXVBfps4dp~%;u8AGAG9SqK7^H; zSLB)Hk8Pq?Ao7N(d0Eqr^sYxrGo`Nqd64!bFzGZ?xKTSvG}`VzHgC$gEF}DdP;p4G zfU=ei4SI(6+G7=&l?EBcG}qr{(0LJO;xG4~$Npo_G*Gh4eTG>o!PoREX8hk0e|a{O z$Qt9!`=8K*6`_7g&p?{|FX`FW&@(ti&$BpmMQ0a!qygwzJ>!2s&&Yt|Dk8!W!k8Z; z&KmbNpn>ZC@z%03qLtHHrgLF}&nI?Q>sdpqLW) zINqAcF2;bXN;bQl{m2tdKATWYUT@&_&l)hwNnO!u-Ir(dG&g#P95Iqt0}_O35;-f` z5?>m-HN8D5tMB(mROWrl_%yu!WN9%PTYge5_qmA0v7hl-3@K46e>jiy9Z;OOu z;zp@Vdw)o`XX59;UUt{s#-m%%cdTh|kZJE*n8*4jyh@n9{u%9Mr`kL0=H1fwOY-fj zWauGel_B|dPgB=3B;UL!YZ@h73j~;ho~b^&arhm&7boO88NbY!F320V+1-v0!*&=_ z1wPZeA|_B&FWuWkZU|9a_ab2o`>&@Pzd7M1ny?o&i{BFi3k72{cOBZPzwQ!hxR=D` zZS;j1-r;D)f&1e-ZtVFAs5tP|4Xje`;N$T+cnmUl-?1t^x(IW&eV2;7&Fh|cDTQm2E3nX_ z03YdKBJs=fN_GxS^zG&LzQI65v7WFKbp`6%r7uWaS>QH{PA9G|AP@naNcLCmKY5d^ z4~cuG2`qxs7;~l^<;#8$N8mlfM5KG4-~)Kv_Ls5+nrk(>722v9P+hOb4!MsRr^@&; z@MDVoSnm_!k5F^tXQmE-Z1{SForo3I14L5gMUtH}>&_)rUM#8dGD($J=qh(|c)3BU zJYQ4g-O)|qrSoHxNt7>(ByLe~a&f`tlICUxISGo?ZYA3$sUB}X%=xgU z$41h*oS(Azs)@3E*v@{-E}v(`{zVC``4@gv$CgFgh~%qdpG)SNsn8mYvv4`nbbm;Tu-u_vD0Wr;Sh^uzb46x1#IfR#&3R;`-Nzw$tBZ#V}&%|0+wa~J539CVZ~$`u_Z6U zT1Ts1oHAiK2J4Y?H{Ya29zD`-xHd04Is%bBTcjd;@o^)vwXoepy5fKE1wG_DjpqA}L2EL_&zfxXCXqA~g+)I4x>J)+o(v5{RZ!<~FBWC5K6Hll^+ z1wxkch&U?Y7TXE!#+8!Axst8d5mxBy?7%V!3D09e{>0yqVKl4eNf@am*u|2+6rDJm}E+F*Q3RW-h4(Dfq4MRXz@ z7PQ6J?<0-pU0YM<1d>Kx%@Y+WC?L+mnjtDvoC;j|L5~h z+Mmkih2eeagp`WwU+8SQF+JwLBx^BAvQl#mHnI;y%u@cL8f zjO7xk&KuLmy|IGI;G4a0(i*>ucaK!Xx#uyXI8RKKiA@?|-gssJ?*M^!fPvR$qY&-) zzrcaR8Y(8Jqm;R5;a-C?RI1mghO5x+FRw6XqCgX_=mnbn*A z;yKmxoN}^FL}PnRGethqBFUA$oPz#*NYH*4X`e&igi~$E@JmpGz0jVVTlR(lHpOo* zA;5gz7(TN8;c#v5-l?X&-)WIldlEI2FJvFb?nD898#hnNk;Yc}OdMkx?C3YxE#08s zo`Git2nYHX!1>CDv!8)8->iyr-@7i2cv>6B&tyEoh)g4#%Y2TI%&#jGrj!u@Gp*Q7 zE=z_XM7rfImS~@8J91RE*#srmEX)*A7Q?qY3{!sgnR0s2yy=oF@JBg+EL6T-Fvalg z7%h_G8xB6#?K2sTZao&s@I(qDd8@?h?-3+$y^+t^VVn&V!je2jzZO{T7jb@L3{j(T z<)i!VBp57#C9lJiLsLtR94Fv11_q&tBPkcC_9@^7M3{o|se zZRFfV@zJB$8L-Oz>qL#|r++2@m1sXqN&CB}5$R9AQQ}to#Sr%@T97=@_>FAyY1w4+ z>0wb20KpxGTynP}VK4F?T!20Ma$;f2%d}VHtgo5#Gjdula6%>Oo#0 ztM&ZJa+iow3!x5AX<1!b;2%_6FQq{Bw+5fCKC1hIk9R3OjPkoCZVtjeix;wGpay1G zjS-$C&9?a($`0ZIc`rcTibicWnZs&~@>*oR-n)ulwsUo!C)3{UCaKebS0VMro+TeM zb%H-^g%@gjlH~h3H<_pU#6~zjnRg5`T=^P`%ekKM0Ux@-}r21dtzJrw)-5)f(Sce?PC^J-L<(9>?dtWm^wff*p{K9X(?{vq7ka9Cr>h2WmlXK96Jw&aed1$KaT1oSZY~f0G`PG>Hm(sqd zv+ZorT()~FO$X_p{Y5L}&^EnG=yb+Err)^FSg+iL=4a+Y>_tCi2MhbQ7kbB#ouPjX z!$0~L;pc#mf#3gE;LDIdUjI1kX;@t_Px^1o1@JPbOcX%^TD^ye4B!=Lm9N+CIM9(^ zi16|t{}>?I9H&HbX+WU=?#m)n^2A>NaCSEUnse(u$62tNocxtel+*n-d_DS?2LU+} zNsEu0CBBS|nm@D-h66H|3=OblfQ4_GA!{JeTz~omZPUk2nPeK$s-Zz&~`NYFGz=qd(^3EHJqY3<*>f3nMY9*gh6!Z|@ zG=AvE`$qZZ>fl2&oLy7y!^j5|Qt~;7{?y3FNhUu)-@ClTMettLG-NO6@~mpu!8_;o>Z+>9+BFcN02loU%~u)9-75tnrCei+5YK12 zL(yTGosJIV-&WC+__uZK3epNU0Gl~nGpi*j(|rKLYM2_U`jZsf{9IK<78TZ9rWKNJ z3ZCw<&_#7ZlQc2lhdh2TSe;12&ODq6XMxYp6*WKx(k~0W(&-$E&B8<$npBhQFYOl< z|D{t`M;@ppNS3|{)fr6~_^JF>V^^P7T$?#?CX>1D%NUw?HXx7lQ(U{|w-$<#nnEYA z!ZPjg+C>l69?XQ<@EzRw?TJ4&{$=ImU?hVf)4yp)k$f}tEcPw)d%jztGs{^c)SyCE zqp`T`{4wPC%Q2&NLPtr;^EQZ? zgWd~6JeNyjtk`{0Srfp!WBQ-@Dj|S5*4T7^Za#*CiXCPI;omS5j61c5bi1In9BcXs zwjkQbQ3|q`pG!{9)jLj+Ur;UZi>jBxXzwLRNbygi*D~4*P_!D)gmM10gvi4^h>xDU zOYxUmSK9J2d6(F=&&mSyw#Na!ZApHmkl9!FTv0?L`->&Tk}oM1S*e)L?p!8abOSfs z2K2=TF6ly5;iuT-(eeFQP0aM^ezr53PKfj~5^=v!l=-hEB6~F7D)15B} z{4)O@Wnd%S)@zcbw} zJ=ae7U(<6pAaxqFwWTFy!-V(9znVyx}AO5m@p1Syd zP0wOL>_X3JU-=!ZE9Si)I{Psqn6u$n&bM^_~cJST;H}l?{(b9@rKAf%L z0b|Htt=Pw>pHbYvk%EsU_!#k>`wRZGoA%2pz5x_<&lYaP_Y2!nFYrzI+cX}$42Eu| zALhi4G3?J@WjyYFVi{?V(Sm>K|HJs+!9=KguGsRP@x3e^iz>d#&;Kv*9VeQF;s1Y9P4 z_gwftqwm?he}z6~9yLHx`UcaN?T)@nf$~fAJ*fKgYxGsH1+h~hV8&aQEwOrZEOd_- zT}5INP2Vo?A=rxjQ5b53TI4=5jv~mjkBmvp41Swv2fLvzkA>orKBVf>j#N#QUS?L1 zx!LFeGVff7PzyL*P3Gd_U7qSB_`eg+Hmkg{Q^HpDC@`v_zl*JXP?d)H6~2yFOru^@>U$vu!x6iyYO3FnI@6iGQCbSt!a$W0G78~w7OZbX6Lf;tw7i?dl8b7<-J!m(~I0JomZxc6$UoH*|FXWePGmez_ka;lCn|NM|0|slc9Y%rG zVmX}8u$wZ)C^u)5a;Ui}Q`52xUyI$O^cIlX*u|8(G*`9sIo5)UBEN#Pz3n?B)~SaV zyvxZ}I4WLFtb08=AdQ*IyZkNIbp>)WW#)>1oFb}mWbVPmj=tbBoD)E zTUxxjp259IJwC_FR7}wQqIJ1$XYd-MQBzo>;1~Amo}sLj!Xd8tbHE|s(w@m?Xi~>{ z*FAU)qv8hH?a8@%Q?jz6N7)Viv!a814=8a4aTgpiom(p>Pv%v$Xzlxa8Xo>+YyPx< zR_z?V^v(Rz+J_j#kNDlM#Ef(aM6P?I`Zs!4bOZR|E?Xj@4F1HsKh(ZeR#O**^O|JE z3BDe>NrczI^tbW;?pN@`{nuH>f99+Z3CFwi;}4Uh-IulH(P7DqP?{UWg^ZQ5@g&@L zigMI?W4zNa3H*ukh^g0GBrx@Hj113@$ zzZhb83;NMQq5r^^^n;2S&l`I87bC;gb2AQi6nZtRi%%=C8#w1{UqkO0?+ER>HNO#*?<|B~7vUR#t2uZ2AR6oz-EffvZ*-b{G+8F($^(E{F(Fue8#-l;yl zCuhPNx?6ZH z-snttBQoKQ3d1|l!0YM5J1Z037z1xaCcKJFcx}V*mb6xSf8)d3D-&J^1Fs?zUJHGm z1(Q?!n`Gd1_2D&7nOACFzCJe9Kz+30To16*n zS_5y-_#F|3=VdFsANlZlX2Lt_zrk-gOi9suPbR#N&d8v5rN(Q&;!kf3!>h@JcXKAZ zxPjNg-dgbQxG=nJSsC>9%Y@hezrpWIn3AIR2?OtSpMUE{Wzd_%z5c3v{}hIIrh(Vw z!@D;V-hBq%p5;3v46nU`_b(sb$(itm?iRlm_O=w@WvQ;fxejaEi8NS<8PBc{m$)-m-EA% z_WaakB#h5=lsC`ajLwje-esW2lG=>r5BpR${IoNA6v^r_V@W_Vp)1424^JiEDM$QD zyi2NQu{?8>l03U24^4)e_$I(7h8ObjnIsO0HJ1T0m;3@URV|R|tjKf=A*18nRjy6@ z@~!rB_f5DHDnR@Oeno=czYKnv>nWxRQgR~b^FOL{V_9*uH|qptQae$4>veihNsW5U z48BM_tAQWm35ge_^vUN)X#&Rsjj#TxFSoXTm_$bw3>;#=)=jdcVZL z>DPkab5LjSTMT}q41SBo8vO1O0T}#(=w0a-rl;uV0s8ZIL%+ZunS!tMOU*>-3qJhg z)9_RD|H062?~eYSA^M}GVX_VTm26*rO81wi1avP5#<_`s_p{K?eFcsfx;X(p=NyCA z#XepSf^^2|rY+>ZJxo6j&|k6}`lX$bsdkipsmXag0sY#Ju}6P&B>Wv6hJTcSU%V^) zc`Sl+zlXxKe*MY7Ki-G`0geBHe#tpczph`Swzbr+qTTA()Zqc2Q|n0+1B(Q|ktzH{ zzcvF8`Zt`-AJPB+Eq=4M{&)C&I&3%iO|JvL=fFIq{|3JYef;hM`Q7P1t)}jtH^ zJmNCa<3sFU;EznfSNTiLL}>v3_%!^K{`>Y{{9nmu)|Qs^8$H>@{v*4if1=P2XF~KF z{LT&N2YH`W zYm`I=J9Js1!Co*{EX;G)k^rWL47blpXBVrS^NLJ{@fiKS!Tktkwdh%{@;kx-!Loze zW2E2MIFynN%q;~A38lZ04suctIuqYNX!dd;3Ybwc{aqI_w66U?(0>qsvV5pYkYDA_ zl*d>od7$ufydSb9@p7eP`!C|=aMAEPrTc`kgQUA6_gyNeW%kwVBg|Py)uy8~$y540 zVj_Grt6%4`r@dqvj84Vepz#J^ zz=K8eIolLB(!pfw%XdVp-Dl{?Nd__R^(hU{Jqxw?v*MZ4NANn*;B~ga>jEFI4kDHY zCcQ~nDE;&{_r7~<%S*ix|$T|Oe4z69D_S4_9u*&TW zBD!EXgIxH)eoD#*{QiO8!tcXTyD+~O)a;huqbS~VjG=4FHOlXsX-)WjEHzs2`ypQa zI=}nLj8=-@XH&=Lw*%EgrfGgx5DBOGed?Kz*;}|7&w1@T@ak>w`a&3;7`W+bgV%lb zp80)*@cTGoPT@D8?gP{=yoPV|e?W9!5tAEr;ot9LrfZSzsYiraoXR2PZ_|H9A&G1hD@xx z1?S9}s5xKJlTOaB-Ji2W$u+upxMeb#`~;O+?(CeO?{&jY#6M^^l+XHLJJI{SKS*R7 zN#vYDPlUr}BYEH<5?u;J?Io#xA~p(($AR`C8->cDWdCz(RiDNapunM%_%;-h!uk}< zE2+G~q0T@yCFK=)p>6G{9636%qb6Nlu&p>Q66OBDrDlnt#)( z;z(r8jvcQnaNiRT4SJWGcz+;R*yV$BYX`w~yMOmiJXdhkV|pcI>!_^T%$J2Y>X+c_ zYSVP^u3nloN>hI&ct49oTF8*`RL(IV(=<$qCQ8o};Uxx+r}(R~7hMS2D-4zK3hNzt z6O5;J^~c-E=BNF`0Ln^-m{4drkA5RuGMs1YOAB8*S)kvHG9Zg{nU3uWddF_al!yA# z3V`Hn<4f}Mz>lhY4n7?^mk7e~oU{1c6fty77vUrZ&bUHa&vlQlQW^O^y`D1i^)kM? zw+L->(*9ys`p#nB!L3DMkQNuhK!C~lxnf@fR7bCPf?p0gJPMc=PB+&a<6F?pi$a*z7{g0M&iDuKR_a6gww zHLdT%1b9f_yYu|3`o7ULy&HX>`Frr51NU~L?!OZq$2A4Vt}()Uk<@;&SOI%ZwaYN7Af@zuRwXxpQ{uOt2IHsXqXecvlYlIr_`e1ibd_r1f& zhxGlm-_lfx!ENeuD)KmljlPUXaZ>(($Wx_ovk;>#Zef-cAo9oy}wng#)#Ra}svW zKly#tKT_Z{{@vit)Lu5I|EOQTNkT?v1ASDRLU%o!rHg7)nEbox&&=ylbP@U*73UyD z(jqWt$vOzvJ#mRrS0s}d_%nyCX$_ImUqD_fd4*I+`86WlzJ+cZ#icKEsTz-nQ?%ZG#ifd>C4sn~RzB47F;97H`nonUCVX`s^3!hT=jtNStd?%95y+(EGg zhS}0zbq$fE_In9x;oI-pK{y%DX(f2xYw+x6@I21PbJc)d?U(+lFP~K( zE=Kk(^`TxYLG9uiq`WAdp0?;`P1n{x1>{5zd*FA9e3mFI@mL&>pS6KMB- z+O3JR=I|--<#=*!?-1IPE|his8dl0$PfqK|cW;y~+L>oAw`a$??3ZmPm)`Gm|I=TP z!mN?%|aBlU_5;Pt#DSyOlivfu9O$B?_PQ8_L;Qj{RBXdO%2xFKRfiGiXUgo)~zyRIZ{B*Xn71{vy9U zR&YR2)~^1bX*-Ce{K0jU4f%u8&jsr}#;-lmj*vgNni{DPFvA~|!;}{O;G2^{wY}1r zb1xN}{%&}-SeTU<_?9lc%XKG~E6-Z^gTM3DeM9KnV}IV2+@JeAuH5g>FZe7?lKKPZ z_>@05A&h*;9}E#Z&!;KuY!mgHUNw03GkZv8!hN*#2Um(O5r1$S zI_>*|bKz9Lbu(TwF_Vnf?xXoIe>42S@*41bNw^iyIa%n$AN)sA9eBeyftl+b1&+J* z2chxWmbFqf6u%a@g%VtXo3ajW zQHSM`j$dm)yoJ6WXG7V4YUuh%u$cwApgeXqwmslGo98iBsAPIKMpd*5{b$G0$lGxU9L!E=dli~di5pzl8!eZNhY zTjaX^!7-%oyYYXU6d^yKdL6|>`mkVC8na&*zu!yqA$_=-8ex3X`cMvnE%agd5b$qr z@V}ReO>+AJea2#8F#hjcX&wIuJH(ZmoNPS=%Gba1)qMke_pA?HNu{{Y8)i#9wCU3{ zNyh)tk3oRw!wF&JL;CPoH89Q>PMZ3%mO$|AY4AM4$MfxDchv{v|0D8dJTuW8OVgd( z8aq!roU^KmSarTZvL3;(hH=R3&JgFe1rWJq4hXumLdG>#qn@)8zq(B4*Uyqs!EXkc zp#5Qd@Z?u&o6OKa`h#F35`7GG2SaWXahRZcf#^hH;6$CK&2eP2Imxs$ zn22eoWX2yaY9JUIe|&{JOvP)pSM|qFBeaf>;~|3MRH+$^ot{nAA`!xC)6hZbhRmqt z$q~uV%lPF3#*s39xeMD0jbEB^sGylKet83BYdL<2F|DZfdIjd) z(q5N}h^2qpM40K@>%^656;gX0Rh+WdA3x62{|tMbF&I5M5Vj+jCn+fQO1@HrvR3D& z*w0(S*Yx zmc<1v7Sj)uMFtlG{3U@ZeOiB_E^?3#&n^43E5!``&4B*A(FS)kDC?EVst1xs$~qf5 zO9ZRToO+FhYs{aEHhw0vxru?^7{4=fXTrr@;jePH{=)m!yifikV*+J2@!eVED1?1x zzUY4Hg#6n-RtP8e7~kDXjgWu4{i96zrv2NQXhjSE_CO_k=php2UK=VlO*W*v@CVYr zIZIm4b?-Xb5T5DZ-r%eIwa~c7{;p{q#oot<`TgBTAErrC|2D~V*y7*L0f&@x4*9pu z6~MTjrYN&7Wtw6J&yx+FLwr0p^x2bt`!Dh}eE<;7*I11)(b!bZM(%$TzcB<|6@y-g z@sYFXDmj~V{J!Q1)=lSZRg=_I&`jg?mgAaJUat`%h9TFcgdyTG6bxoxe`YB6ayW<> z4>npon6^4oJ0g?+spTlJ4eo0ak_G-F@-;X4?D-r1Jml||8fTf|?>=<_IUbM_KTE+u(UKk_OKkM+wMW_h|4G9}{w!ge7H~T5a51+nV{SU;za2 z$`xEBPfE47gdA3*?mxmLo<}eFwK*Yoyp0HB^&FtwSzNpfYqpd5*4o!bq{Rm zQE*jTO8z^XN8Ot)BW1^rLQEsfX!^tu^N4UeG4Q3+4KWv>gT@>usW}Gi8+)9uosY4{ zts1z6?D5E;b&pc1NaT;{D#jk0rCxyXcks@jCbL+{jQnZ49)>3e(4&Ryu>#GbN`^f~ zFou@)*anK!9%ticTiW9YQ8ls0tH8#$$6MbM7KG+AzrpT|3J~mZjj_iIMjEzufR;Vl<6aEw+=~#V-`}(fA*1@b4VCxf>2KZ*ArsQqPx}F5 zAA`rklxe~SkZtKlBHP5k<);~3rWNg?ubJ`CaOx5doy#BMp(222Jan>RL((%wO)Cu|1(q+QQJ;p;#42whlwBenQhy_~_a|J+hYJkV7OVhT@@+zxprYkAEJX8GqDH zNXH(UipNjAj$Vj^I~l{9{A%sXCc=oK)G5#OH_%Tm1^q1s{k;tOhxq6(rWNCvWOx*e zt2VgB+7X81i*r;5{kf$-LYh|N1o8BKRX@J?UOOS<&x)j0cs}Tipr%LKBjwNLq^lTz zwowASz@Hr!)Y(mZ(GCYLEI5hoBjnGnG;TA)pIwJihy7V-DIJ>>BhFhg{?${tabbrT zxss>$SVM>NA)RZo;@%z1feD<-Q6d!S*8eTj_rVJ4u1+qz02IwTxX?xto8( zC(h0~$RE9Gqc;0ht(c^D-Qy(Ups|-_5lgB?-w&PnmUxviw-UvmtqAOZT|7$4)(tr-dRqwd|#aY zei+~VLrKEW@@rB@dezr*3gW=uMsUhUil<>>NIH^b!a;Th7cm(njpn&E$_d?Bzdz@s zphYtCw7(UrXp_a^TGn(kKgHH|)&_GQnYb_}y^8%DhI^0pn|zjOu@;Kh9lW@iE;=EN zR~zVQCoF)lz1s>4TI1lv!)*?jhX2)tFa>wGKDssGTu&P0)IGG z_6L5Y&WR8$4Btest3pl&CA5Y^(>Efzz+Rtg%|T>bHr)U48(wE&b!@(}skEMixTsk5 zA;LjfENsPA005(JH&k5OBDWtFg3(P>E@HA%1-x0brYPUk|>pFBzbkTc{P+* zU-_@PnO9}JTFWaDv4{H8PUAkXUnV#?3Ze8xzPTH5l=5LKxTe>yYPyL1c;*1K+PwwD zc+fR^UK5{^?;eSB3Fa*OD%4k>5&96!vF=%LlLL*BK=JqqPUT2UDX8IGUc2F|tu+a5DCvQ0t5M9xyU|&@ z$6MFWnJzyZeV*gB{?2|>=3u*W_YIV8XNpKrx%yxwb~+sg8nijuxh6h}12b&r&Me-T zQyf}V#@j`lS4YDSdC|Jkk;e%<0wLl&KZ26(y{I=NP2b2v##zo0=OPwBmEP?)ctLle zMckbg8=@c@r3K?@j|2d#ZtCRKH zz=4ao%-yywU*KB~N3}HT9xJN{CpNgFq#eI)G)~m(_MJw(#$a8dr0R8j56={KAsDJV zIgsL90k90+MNijDUn&#NEq#9*p-8-r+-27i*cO#`NGFECd^<53oml1eB&txR+z*J9 zPJARfaqeN#n$d}d`F85iJ)JN%`bYjnoy>dPcJ5@udY<>xkJK?a&QLGW1uA?gbDoOn z$!Z+#xBr+AW*VJ!MrInlqnJ_*cpBHNPsaRyfHt(@L%rB2Z728AP4+f<$<4gj&JT_^`W(e)wt{FKhjQ3!v-$4 zn1ZUV=gIqse**tOnYz7G-(#%bfq6O0=PN7E?QK}u4rP{Wp<^>Zq9%@ntmzH>G!kiR zHD1F5XGX)>uVIU~L2+09xj*8HyiZ|hKp*@6q|78ph8}9UFUqsI*;$_-KLF6avptn! z+VuO|M4WZ(_X_p4vR*nmFF(G&?etw_&Pn7Ph;1<$)u3*Snw5 zb$MR`RO&33hewo2U$HgCy#}A;D@3CMmfiz=Gx_>>&YAO+`AtU|=HHC;{oe2pAt>k# z_vJw>VY0x^;lX`~Ux7Z#U7GZb7lA+qzbenDaXv^bt9g@X{W}Jm6U-HP@z-)ijn!ap z$KR{ji$bI5a%v4X!CuG#IE2>)VjIbP^> zicXU9=DuVJ`rIm74Z1uQ2#eh;VRA>j))UZ-uT9sUYR-#R*>7>P4^>6tTpSU%o3df3$Taf73bC2+y*MT)|nKi3(=gR4wxtgIl zo7*Zpt`SHK*;%rrhg-hfipNHm_Y=ixcTWCAnQ^Ht~lYN+qaPPyt$>SI}GS(a0 z#rK1i3$uGCu4?5?g7c~$dJpv}<{s+Ty%i~cDXG`vkpaC{-K**`ftKr4p=weu$Uhae z*emFMc8JvJ{aiDFtf)J~kSzBcI%j5=2{^Lbf;Bp~$E9 zJ-Y{CQ=$Frk{Y(-r!e(kmw(INX>bejZuztR|n`Ts!*{{God}Rw))e@y`W?0|jH!j5{r-7-*S6Q5yU4GZp{WjdxX>rGU*whw*YQLFCg36>ECq4{Dr*} za+zkHV>LVn=QyRSS2H6N<=TNsrpWyMSKAeK)8u1jrQAm8s_?KP0+TwB!{ZrrrTMceN`EiTk}78`G$FUZW+CoNOPsv zTiQz0WqYfjbCY%U90SX0+B(QPL7H!PrBK;y#q=VjcuXH5tc~<J&R`$rPv z+L##4`PqFDCmE!3{sUk#DKlgks6i2qX3kfwQv9&Tjcnb9RUIG1_aQ#!5I= zdt(}!+t}rcYCq=w^_s-lu{MUL+O5ONf2fTMYSSr9#PV1EwLwiD1JtY;vXppO;=%=4 z@%>76MiN)I!4c)U5%H3K?0&QecN}jUmrWgRC(gdTO){sZ{8Mg59@m!K6=?Nc6go^{ zgS!(0$NkoR8Ek(KwqIC{b-XKS_U2Np1)B#Wf{62( zcL*gIZ^(TJINOa_tnU7EFYN@9D8MLOey)tcCH7jxh`QNbDtyj7i&uIsnNCgfSB{3m zQ@Y;?95h$6%sR(j4}&CGNsN?!Hu*tK4mNyk>+L?a)3H!uZqn|AdDaYdCeF__&XyWy zdCAJ;S<(-;;w*Z0HrZ13x(|JffZTK(qS?{L~-BfWxqbxf7jl=>N_ApTO4QCY)S{Sq?25OjS z;5~(sRRX~g2>x(`1(;dxi};UJipq9A6jj<)kAf3_>ZAP) zuvL8lHXsCStN1t6BG(;)y6ys{p3mqB`5jdUS>`C#^du;x7eFKi&K4!jLH089B?bN> z)e@zXXimJ{>#AJ@fQ!gNxZR|E*>WS{R;~;p^R*d0>r{#?a#u)DE@%m`ZnTy@9-`iA zlqn#D`2DjY8ws89GKtbIltZRC{kS@PHM&uOp4LW$zx&X1^2Ahpm$pk=C%R;Qnl9*R z;7gt^WVhz~4SZ*oD!Q+4(t2kJ;Zas}sAN9b%OsgkH5eILA0g8wPn*=|q z1u%q$hS1RXnKBlw<3)0*u?I2N3G)1uc^1U~4{v7zXZ5`Q|CuyQlv9>uiMb4l&`>nD zCNnC|Fu9Qk7u_3)EMX=kYPxfVIgUdvuAS`rnk8c^TCL?;B2;3tD z&o-0lKKy?@9?kiFKi|*iy?@@H_h%pM3hYRMiFyz7p18=>FGP`eT7v!oDO|TpAcb1O zB{#9cK1utovH1&=-_KGw^ggvSh1qmxYzcgmAZR|AasHtKmAdf+`` z@B{#8eSv0ceELue8*VXr=0i_rsZ@UhVc{S1&Jv7x_tObu!C)1!g#i3pgeD%fI%W9f zTEW@f<-d#kf*_30|2`qTZy0 zbmL_!%*(+Y^LSz!c~bOa?-*3{*EQ9TA)V@~J!l^XzlBE|N+m;f3~S6xYy~U6{7y}r z5=t+xc+{3mm;sI_5Ndin)-hDH@T@+aB!BhJx4>y|unT>prg_oVhyn@QLQdkwQ(-PG z%{zwoh9^_?LE|T9%RwvfZfBvBiYM)ghJ)9{4m6!Mo|3#j?qCVq)o5IqY+^n*(Ph-^ zp@(-7Qp3`}_I^ebu#hA@+K@V5UE*t;vuY&W;@Mo|ypR|jr4rTVP z@*>5ESm2?UrQ&u5c#-8YeEklEmE2^R3{6t{B6nRbDxB)%C6uG}ewTZA&WU+^TSR-Y;BOFdBROVDvVL2a%4CZ;O-KPJv&B zO~P{%*QTXknoR$mLSx=`=dUNm5^SUe;2F2QF{V8}xLLlcH8&2dc|@eFts1lDO_sD? z1saG6)s7QB5%g=hjfF%%3e_nLmuIbeRu9FDYaBb@0-;a2?pRBgLdSj|?)1*0DiABVO}J{Nw+-jMuiz)K9RZ*AqY}S)?JYd!N%=>bCn00>OQdUgALP3) z4+gCe(Qr+{$}sB2kvnl7fBf%YD34#>+71OvjAPY8P;N#B(M4;tAfoPQmF~%(xSTu$cBGX+gYpvK_$_-HH%t=*Us;^^Be}L zw_x{o&79nZQ`3mqoJSvjtnbbAab}lKTeN#cE`7|Y<~%Zq1M9jReGsv395X<*#z zUDdjL=(KR?DINQcAE;T^ShZ)kUX<~#G;BuC6XUq^s#=l9wI6+>+lFUNMLmrqsXrV$ zi7|p-@~gJh{p-2Ob5>~_YktYCO8M2AU$(B=hCFNMhi_3n3;YRece7z0?@X+b@N_rp zFLD9Ij>+o|>_q(8jI?w41qB;2W(EBF)xCada$RTauiUl}gfCaZKod{Y#TFse{G88; zo+F@{_BSKW;*`7TbovQ6bbb>4C;xXKYT*)PD&J8=z@*n({N1|hU?8mhB0O{jU>aVO zf5AV^|Bd`97$zrgAU2Y)ss+=nmF*&$7+7u%x2!IETO5M+3tCW*b|u~=CoxpjAl3F- zd*nuO23ad-olhG-@WZt~hu;pOe>3>?er<-|p~O&`{7#@P*=&AO%gWk%Lt0453u$e< zK|Gr4rwy9nU6rPCg(d!S5WmOKvas@^CPqM;9i|#_D9Xk8*M1CqEzEtg z3k!2uy`qLod!yFyezEQy)7YW&6L_DZ#F!U}8oYc6Vx4m*RM+re;5W%Dl2ZBIzKLtB zS$FGb3kOt99+Z(#-o|-7@k}?XO1th3NU`aFG|P z`%3Szyaj9lqBpjjpK_hW!NHh=S>(g~9V`VATPt;~u&?ZWnBKcm12}}`_CoZq0iV=BPuoiB!4Nn=b~E%&;pQ!m6V=F7WVpv@qk*Ox3EuTxsjj>2ErHEDlUr=)Cebh+7G zwy~-nnsNQHy>@7LG|gUX7mRt<>Ar~O!O;1-ue{AWR#Lh_aAnt1e?srwumXz{WT(UT zK$N#i%2_l~P%|#}Tty8@t4_JtDzoVK#R%;a;GIR^ZV8z#_7kP`>{v&pO4j>jx>)Cj zl6D@dHLsoKXJ4YU^Rv@kJlg{?HB1QnSB8H*A4lceL%M&x5=PVg>(dM$dy6IQEW1tm z*J=|-_d01NUUHN2m#s4GWZ13w!-w^uXU9kGkiBY#Byk{r0{ZZ;y?OQhKRzqHj&TMS z-@GM|l3)tX`Pad~+pvGVjNy-zz3xWdz+P{Y6}i1;8}P3OqD$Xi@4NjE?DfzV@Hc;CZ)5ga zuV!;&_SzAqHfpc)q2bT4*E(AE4cP0eII3ps^`ctqhZ7`I25l8XIn`ss+;>>fvn2m!8AJlg(&B^IKxX{M zcCvB3<5&dcVvD1AqJQ;Q-EgX4et*43M|4d*MQMu{nAZUu`w!Ym6->YGDdGF%jbdv; zJ?X%xEG*Ea>$Aj7f%m($k%Mv=D2(1iCKGCy2gl5Jl1r>DV`PNH+V#|y`AJx)DE>KA z`znzFTpYpnj!@)jUW~ER%VV#iV8hf2OokTB)k4_GyF-DUPgQ|IlF*hIp5#P+*d`2% z*ac;}>crQXeZn~n+c2M3Tr%$_+{CR|-T*M;R7yjUB_KpoBgG#3u7s*<3bVIw8q%>c z1k+R*Pua|^FxGz$&h;2knm#Vy^MEfw9g6gTFt{X^U?I0q_DJE<`G!5b7Zjq&KKqe1 z9Fu&tL_rc91c0?LaiUV$dx?F>YcH7Rd7n_QB098` z&}r}#o^vv0|Eo!W9-SjOe|ub6t7RzLb%_04pIU};A1oGu_ zX-u{FanKAkK_(nOOhb{4-ogZcp+0TC&dNPcl8c|>u3Qh4ZBmcirg9Id+(ea|Sk&n4 zymUQ>;)Eis86MQw8w3iK{hlpWM$bjEPH03dW(#4(2i!?d6&dtgdrEsjKUnA71IL zMFK(oSf1e5Pj&Wiiwq%N@&M&!566-*(IAA${+aZs1*1+Mzb`jEru4C!!r7f0d~)>skVy}N^s3QsCchuylo-(Kf4?vJeQsuX=0An?ji3E-gO%QBy)_N-M`Cm!vI(6X?k(#4Y%*C>!id^37V#8XJP~Cl2(Smh= zH(56-jMWgi^V9F}$!ioJG6cURjm}xEXEw@z;!SoX zy80#9dVy~_{}nP<&yo2))3_PFLJMuJpQmhyuKmXzqo9Cab(7$XNe?Grx1BNA5pp?Igd)V&v6iyzvCSdX*Hm{_shu#jO51 z68h@n{YL00g(C5@TU4-#sOaZV-GO?K4((JC8`?EsyPcYYIY%U z7a;VDtf(B69yrFv64PfkWIw4PBY=ne9!*1xQsTbs9m-!(g09Z4kU^)Y3qR$tQJrjD z=`iFFEO_44TF}w>ukLe^9IFLFwM&)e2!CZ^K=`a6Ce>n!P~ncLEHS3#H} z?h(d+o5v{^E)D~HPfN%Qh#v%)txaQu49r(Zl%?MH5J>emFim?*=M@$>7c$41MCx!j zwo|HSv{NWDRG36Vv7@0=k_K%c&+cmclT4za_5-T3Pea%{FO7zA0)v?8M!C)#JX6Ef zI`j)@ur1b^rltM;wk256K61V%DmfpCD7GZQEu-}1%oJQ-$ud+eigaFs4TInCVbSdO}w?)=b`eDW@Zsl@#} z4V&mSe8F=IiaP%y!5(0Y>sS$7 z{Z?f83tP;cmD+jkT5sA;>rHotjAZ*~@K1E`UuGJO!n0Ml68Nk^a`HMq8P6SH9)B!L zFnoC(uXye#FeSnk&&eK5|X6;K4}hJH<(JreQb1a-G9Yrv%Gyl=(o$p@5zqew-F>j z<}|W0XwNPy>Eo!2>*+exkKE$V2tX90sgKM3SQaeTO3oR#J zB-I-xjp=D()An_1O@k!c*T=yWjNe80@W<`zcbJnues>7s*kJqm;4<3R<4huXUjerM zZ;r=Sj>q=!sA%Q&PocX>`}&h6S9YNA2HMv!?W^xa7UEvh>*7qk6KBv%xdF6tBcaF` zOYDAx5@H7o|A?>{nt=o>!H-IDF%cDOOOqVB`_G7(nPY0X|_4L;WKvum)loveT$ zgZD@>Ybk(q1bLL8<>BQ>a!m!wije${ZS7fl-7ahnup;`9ouDE7GpvBw{x-_9iM0hQ=^i z7f_YknFKa=S{`i|iahDa3MI)}0SV=)Fv7@shD?z47N}Wamu%N|M!^;F@vdDXR?X3S zl%~UlFQdI8#3pyA2t;Qisj@H_nhYHX_2oFXR)nE0h$@yvrT)zMR#kak|BvMiub|=( zr)e-WbuJY{zh?+#6B*56?k*HzU|khrw3EgIz)4ACIu;G1{$Qz35LJT>!7lqK%*V15 z&NQumdUW!*v34MD3OA97`A)5sgQ^}@rcemqfuI58>O?C>~$DETH4@`F6^|4$kYrJHN zGN1V&T2SQzVEV|PwSKmEI^KP(%U`Gb-N-MNeq&U>VP>j6C0)sXa3$Wgw)eQ{zi^5`aVhCsX%vQQ|32ZJT*yQ=0Tpbec~yt>E6l3Q*%I;DLRoMwPa_2FcuLF%f?z)<(vGs1wcbN|IhGey)96~pUz`_SXl`E74Ib`ls!qa+zGX|3;5^!;y!j$r?H7sNg8t`@raJZY5ScNL8zQQ^i0r*OMRy|2zY9EwLs^19QzOf0uTzCB&5oW9sDb~(o@ z=QhfzeawQ`Ke`H_L({Sz<+7fjtc%p`P`@H=%&uv?wF|?ssd%dw1pD#Uy36?R$MM#- z#BqMS_2$?=h__}ghMdKKrcJt-jP*~sigqjFMamDdR!{NP-{zWA$eJ&W@YTDY!W)mb z*81)$7|;09eBsanKW?Hw{kfPj4-5s>>P5FLkG)b@&6}4)Ocz93Cz-21;4FxB_k``G z7R3&gN%hg668N4a1!St~jnnLuJ<8#?cMl0^w9f{j3E`$$DLI*3x=xJohQqxx5rz7; zYRr0o+DH}~F069bh#hYJJ=2jN15H+{g*dP)&SonqYZkMY(t75d18q+qIQUjAVm~x8XM&Gybl-7mbi1$>3TNh?G^^-vW@pW(V%j`%k{VDSG zA@t3=g@~7fCizenbGv@ZqHunAdF(kmL!g3bDQ_rbR4@nx9W?5p$XTFu4QPRr1(~!f zzCeHSy>4p!+2vKCE@Cr-0*kc}l&9+vQhwuOdF)7byd6%Ba$B|9R<)s1wPG}+ z);@3F9dX`UFdT##uS-4|BNPyDpsTmLPlX>_u|cDIIuS)idiE&YBr*`Ywt-MUD14x;Qj2%LiEYvpxtAjHfycZJqGkf4WIHeTLzG$Q<34&< zy%}(Hg9)uLP;UZ|=r4ro=gT_c-MctM#iH%ow{WMoK(FL6n2f>wdem&e?MIThb+f5` zWeB1APaT|Z)*8X9Rs-iw;Mjp1!F*kYLi3)iQWIi+pbzz*QzY(CicNMgRCSQjh!s8& zls$RTdONVcs16W5MdLWvTf-fqnHvw@fQBKChVwsduJc2J#|2K9$=zJRO8* z`fR=rvVpO6!S@DafGB>}{#xp-&{0H&Ofm8*r9Sji9+)Kv#|2j?0L3Bvy;~)5;E{_LX)A6I{`09Nq9-6HG z;!Kz1*~r)>g$1c$qA;d#=SFMp{O&!a(;g z_);_zCJ4GvyloX9kgI|3+I#q*L(N)5cha$dzeq2BVDZR%W}=zLo07CBW)_ z-$jyY72{RCy{E*l-vj?IBqW0t&00{MG#J#wi<*hBw>;JF=LoV;WS)o?N4JP0i(F1O zJ~HPn_Jk&zyO>4;R6Vu`AAS%V(CADVDTlr%FAx)sJwFNIdAp|3^m;l?qf<1E_ExJ= zry4n$STig?x)Xa&K?byhI8&8hU%v4ZP@gNe!@{|`Z?kVTFX#UmI!xe=~TbSno#X(fKEXW zIov1V_dC~mBWF;F*5M-X`zE2P;ofhg1uC1nO`6I|Q{pN0KBfUpiO0rsOl9pUVJf?c z2dA=Am6R219%Nq^g=%Y{h^RAkAybK$IT8kYW70_IPtK&(u;wtZny@!;10*!G@k!V& zNy2(;)hd-GrYA`XEYI6rV#tx>!ju&h}j#y77%5lI6srP~=Cx zL_P@Bp2@G1z*G^DlSafNNg_sO5HZsGjJC@p(3FU~C}c#8ND|ReNzD==LPf+_erNV6 z%1xX^u)+T9u>+i6*oKfeZ2J<|g^Q+z>V6=omwTh*I3N_MpzTX^poAX>rdd((8!1^n zflo5}oesnC=L)M~wIce8{d#SZ%)F89(+`#((%}0!z^Eub7m0S}DV#NabPU-lioXg) z_OnQIt5jwry{R+CFTepXQyxkUcWLq+lVsN)PJ5nyB6 zX`8*`R{OsVMQ&vsRAMWL(fDW35MBPdFc1#UaqFSH5hNt$yCqY^^#m}B&mn+eJrR_4 z&tI;ek{y@nOTPEoYgr4va%{XdF(_5u=1u3a(ag(*@$A|4Hq0D=Vw_O097rf0XfPDd zQbZ_D1x3Rn$?;AJKAMM*cHv|jwGBZPiL9U!So6A%WGt>0kYeqdTeqq8KGmnl+vHtww^U^V&roPiTf`-@ZIz( zkQte4^tK^aV$qtQKWR|c^3}-g$Rae?9=mDbTPSNeW>CsP3^Ott4`#8s?n|HLy+rAx ze1xApLc;%dhyNVm-%$P0#CCfVl{o9xeG%Ew z;^RaTwk%>BkP+s+a<+wej7|0SW{Vv^%sU5nU`T{f6GXoA9_ig{s%zS2-mB`Y>UE%b zlHnNkYLI1DuS;l0t$JMz`L2e~=E*xI4f%4)C6Q;ub9)EKn|hdAXa>#0JV|NiVREfv zWqO!t)@FYds{J?8N!d$9?2>SqJCu^u<6EjD_bC*W$1+FZe!=dwCU}sEHdvZ*t3)2Z z)JeySl}Rg!GRI^tCGggucilINJXisIOuXgclDTU`UNi*VSRT8s zqG(m9PQy##nqGxlfu%?2+O18_L4z|%f?zkccMHL)wqJMnF2{DI|CbNimEME*(7*Om zAz&OdvrpIDaa&u&UHe zzS3Jxg|o@)lv~r8XQ7DVI`u8fNtZhf4uO}is<*Yy5%4zhf>G?enJx+ zS_-LZV`1+J`Pqy?iKe}o&K9zb9l+R9*uiKU8)ar%ZEe%xBkRtwak^$Oe8w|Dw|T&BVOpA`1adI5k> z(;8M3eIJUREXeXiyF2VX(2T>bT_0W#Veih9)eF!*L}_bJw?GW3dNol%kHTnzeB*~kRGsm?ZMpGQ$H%{~hp{mU5@g#LAlp#K53h$OzJm6!G85<~Rv^S8^iSyq;G$610K%6);mxfKIoP_Du!ZRE(=ZTmOB4(%& z17lYk0zAp{R2FWjAIzlh^EhPl;er3w^iTEJuK3xHZ~}=U{!r5{Jwr8Z`btu^w_$=( z=yLw4TLAS+ppv!1vflU|Ss#XxWPFm* zsAWjWJ3~nQKw~Z~j#%0Fv-3W2Rx&pT540;il`)ajoz6G0ysS?HBiR-$WUY=KB>QgofcM~-R?3sk(BO~ z+}YV~ChIcfWV2WVNysY{nMTp<8LNGvw14r1#7_U>DI4oQ?Ca7{?eAzYi)Ib@U#e;g zRdrnyi*ZIOJkr!hrt(+9EYOv6+(O6-=WvWI`YLmXB2>0Hiy1jgoloh{T5$_g26ve* zHypjgx!ik9L~crRm=)MQSe6owa%=Jl-20Bd%e1Wn!91)KUwb|!f%HX05=p&@go8vFH)MYx=^eCgu0<3owV0u$+>J!8 z@Rz=t_*W)7p%*wD>*4~O(Q0LiyA_76og!_hu>AUSucX9(k#(v9TT+0NvZZh|;<}cH zsDLPQL0_h*wM5#rc+Xl$nAx+nX>A=nIswP$sJagJ%4=rjmdB4|v%o4Fpg0~%k)O+O znFaH#^$T6s%~T=PppOFAoN_X_c1`*dKamv(!IhhAh9D`%2Jqj6;_~HwP#*n|TNtcP z>V6wUDSk#-LN^AJmwI2a0!ESR=`<}mPw6tCabi%L2YDxgogJ##$(j~4zQqfH#@)qUmECbD*pJ(sKkxfA;)~(CM=P4JPGSQm_n4dRfGg0q=G=5^%E?Xt#kCnz zKBr8)WClgOi!hkPE8qK5CZFR+U6b3{ynfo8I>&r|66mySqWSTXD26| z+ZUK{9;T>w0-q9h)AC5i(Ff$W0%BW1EOwT-fyAH{eSqvn!DUb&l5bS`LDmK;Kt5bB zM?y+-E1QQ~;k?9Pg4&ZEDQz7o9mNGf?aU{D)=t!@ZSN5vyLK6h*-x0>wHPz+L4n{u zI`00i%p+d%*?b40Mj+lZ`7CrQTSbaoR;R=S8^>^lw!l)6Rs z6Ot|t$#93H%15%hkep*kfF`@RCW%B-w?XSYDge2k1s&FPiq0S?lIR|pEcs4PJa0jg zHe=-i-aFX1wg}WVvM2)8D)p6KC!k4L8a6n`9o=C5#ob41;1NJ?0K z)R*n)+~ABuC&?L~v;^z&5~_Hm)WntETxH3J3U8*K)-M+Wa-J`mv8!n(NK{f=?;8u> zc=C@H+W~6*W5tS$N39ed4;WRF{6r&O-5Uv`=0Z;54Z(URBG@9wM949*8%)RmW;~{n zx}QKiYz0H)pQ8MwF8@MlAYQWkW0(J?AitBpC_LVVAVhwcCy8Jru=G1zFek&Egm|cf zcb$WG2k^Xb0PJup(CBRifW*HjKtt@7_dQ@)#Mu$zC0OTtZ8EuB3^z)QMm-};)@1R zv(n3hki;;1`NaDffQfVEh;6IieILQ&hem00*7X*-C74qjg`=dAcu9>49V9@P8B|sB zQ%IB5ckr(C`G)??=xsC&9hzHzLW6E_{~%O1 z0Z;6juNI-&O1;pJ-9z-8EpNS}o{FskiL$95iZWcs3ex4Ln)8N>!7N5QI7Z{rLA>NP zih4(isOxbEYMd0OczvG&WqQD(^+6V}6#8w%ztv!jp@L}@qi2go8ys-mO!2nnGURU-h%1Q-;DK1+YpzOEf5S%K;>a(r*f5-^I z+OySr6GBLKt0U#D!F8Z=u+I$5rkH$EPZH3kN6U z(>LWIvVCXvyU^QTpaxky*y!!9mwy{vZIhbw0f>Jg%>|+UewwYcpQh3K0VtyNFeih% zWFqmB$5iAbA&46S*C@;+!6ZNR8!@ofdtNzym!&*qOG4+XI9 zO2Rrb3F{P|5+5y<7FqvF&cs->kjDA_4%jmQ^G*vOo!~>t_jXbFn<&o^A2_SXX13>t zKKb6QCLD_|iCaT;XDcpnBM+h4Q(TbXMTEG&Op*>v+rVf$JJg4Y58NFK{%eD{ZMNtvp zG;vpdEm^$ptpZVEODxAbTRPNA99`|>eQE@-^rs6MC8yJzgJlPn^a{pdo^)I-t)n7RrJ3Aa59FDz(W8VGX z*iAUBU*(o<4Z-GgdrJMO*pqoob@#c%rRm3S&TkAurpZ1ZwApI3}<7;R0BGWif7+$uQwcb4x zQ>D38#d}cP3#rXeALSnB^R5C>{ZWq4C#AA@$;)httnzo+_W` z0GvuDllTTOjr^}~6hY{P2(~y;o3I>6#fV zHocb=jTIbB8*o{R%40>j)>*mpmiy;^Y7hdZ1aLO@cUe7>NGrUQX z$2D&J*&VLDEsmXD2=N|u^e!6Y+M}sVvqVe0`~B}&WqRo?e((VQygN8T`C^y}*3Uw- z1JwuM1}dQwmXqVFoZ}phb}RJmw?@#N^E@Asi%0d2s=6mndd^Kk;Ph$i$rT*o7ZhW6 zQ&5E(-Uh9}`kkp+lU%y%P_cw8t^cp{njgaBNt8=*zL#~VYVQ|oi`R8UVBbHlc{lu( z`gg&3&6}m)<6mp*Yh#ABbC(n_wUIhn`w}Tw@w<-JZt&GRP&6?Vbc2K*s5nLc(eW-! zGqEmiN-%G*)Ef-&B&Jh&K{g=rrlKKP6gp0xe-wzZ&#^~! zbUh}92#@sl3FxK2eQA@@^f$m!rN}C&zrSNd>H15nk5Z)_an5@E^}CGU%c^Z4@xY#6 z-vx%eHMeU(sq%|3$G*GTNQ09Toviyl7O{mr6 z;sZvOyTbW`Iwe5TrC@Hj)*l~a`~wO}cK%?0_oD93M6{IXYp_JHqiSqYbw~4MVqibt zK&&iAjCJrC%c{R+$&xw=J1F>=Ur=-{^o_9LZL`>9{oRU^0_G}X)B1bZt-k(g*VFY+ zv*U`S=^yh-*FWFe44{}sS4VBFRRTxzc4;Yg)ycaKxQx(EA$VZArICAhg4-^-y4xBBjkqUXQ_sh@ZnXvvV8bT#1pWO6ePZcD#iEhTo2*{0<9snmsIZ!dsZvr=t!r zs<7)heBOI!`#fkaiTjbK)2Ba#-k857nLp=B(YJ?%PNYz$X^BVgK)6YNA^1If_={)& zHUOXG`NHwMW$|$U|5G3S;1v9$GvKGXa3{GZ4p2UgSN@%_!s$YTMCfeCM(JpO^_*(`YsP;=nq(T~TJJhrmv>HoWZ ze2>`E<*`Wb+4k|abmLd)&6CG*Sovnjqf~Cv$)h`uDS0fViv1tdmqj;a%44qHv*qzJ ziT|5C%5dkKCJ#DmI{i2DvbA@=>--Yy!!_nsZmD$`Rp-!+@@IQe?&|2UP#KLH0*sGp4uUksbrujm`Q4(J`b2Bw1ml&$@||Ilv$ z)9@naBON27n5ar`m%Cg}{6X7_L9`~Mz9Ds4p)LTD?mqW!MO%q6z^A!CfZ=&s`V${j zOWwn~0APt~J|*L4^AAn=i$5muTbze*5<} ze)sYDy%u1b#BbNl<+p3I{Ooji7jqsbG#Si$sqNnkDfzR)20QcOV|$E1$SI{60qR zG=4wF8Eu5$b#lVKe~$mv`2F%hr{DJgwn_Z{N&b0gJ^Y@0-RAK7GP%?EU5+!_2*0h; z_`S2(`0efU`z63OiQmDSTYm>PTYoQk34YJHc60cBo7`#q{)RK!2){e4(ed^B1T!PF zzjr<0^!pvaHi_Q>o6GNjX8Em|0>5M8o5Sw{a;NdzdgJ_dR-@zd`zo_}@Vowg$M1T8 zZ4$qwo6B!$v;5xhBK$_L*&Kcw$eqUTZaCkK=(kvnj?eGAOf19iFrVLTH{7 z`R#=>+6ccVtI_fKUD3_>J<#X(K!9x$zkgEu`zFJJ-b>NV;dfW0lcwJaoY6-3Jx7g> z&+qSt7{Avt?5h4kZ-8wQzkgDD^xw(wJEv}Q_}w4rr1ATAoY6-39iv9a=eLdH_q%%> zzsCY>llc9U^!xR*@cZdio5OEUq?5+)c{rnu@EcX5ZvQm=w%ROyN02*>-#c(d8{zjQIbomQ z{v36Ien&9_B7b!)z&45BKS{rPJq5ozM>a>lW67Py@8dY5jqp21PT1%7v;&RbC3iV~ z?*iB+@%ty~_mC&yw{y+r@Eap{8o#gLj5fmWr*gtRzvmxd{2uA^`y{|NiQhj-zkQy7 z-{OC54!^gPJB{CWa7G*9Hz6nN^LqvBnz82x?{xZo4PcwZ@1LaKfsey)`Gn2k_c3y( z@%uT>Xe0ctlN0v&jqh*#ZtL^=9>6w<-#;my9Lj1N@8s&u;rC^7r}4WSXS5N1Tcz=P z=YGcTs5_i~zXaGO@%ty)^CgS}d*_Vb9Dd&>cN)LH;fyxI@6Kv;eEmMb_B`x)$?cBc z?*O(*{QgPyT*J7iH)h=C@VkKAY5ca{IKQ3M==l7;+R6Am*5`LUz_R!~sVw?Q>P#yJ zC71iRlj$g7U6(%Z7hUSdbYCd^Ms(VQ#f;V;&K9Z;;SxQCuB&H_ugxfz&zeCB3+z4! z$GQBXB2@0Jd6WIVivh$Amhze<>&s)uvKnbNizI6nZ4sXK-4@I;u>J8mHcWA;VtLKX z4*l6?TlbKb4HvHtU3Yp*W(=zv_hF-+_CaY5q+KhK#abB_4&FW1=7E?E4@G)!EtRrR zF+PCJ%!_{xN5i1u+YaX>$U2klFc4V)`xSyFN<}%@{r2foM^Xy^)Fr?iW9nX-fW_O=f&mmGS-nG z*ell~`lI9B80}%kH{SB#aQyP_Ei0l^!=0IJ7mHtzL5GFrekbx*wg^vKn$E(oiBR5h z%QC2Dv5u&oRkfmQ&9p5lk1DTO{9FIr#Ye>Y#&eE{w!9jo9PQ&>abWE7T4Xw{ML6EA zR(PYmpf7Pn`&i%ZEu(!8P6w}jz|#_2Fi#YYzUwW%Oxj$=M(e8W6W?GGwvL9S2%*TK zC@fZa!w$7;D!&UCe^j~iOSXg|-i?LeIXRuDg@?`ww^|jB9-|p?@;^xFV17JQJCe8b zIdcD$B(^lR2QJe@J(`~96^{NMuK9L76YyBk8)mJ`wkVH&RKE5LiMArtZ&|ozMh6+V zf6druWx4|_XG8U+(AAf5UBl67Wv?K1SYNk$^t}lz=%qq&xNCUAIz5itHazX;US+RP z2Xa_M(WRo*vQXVkyhzK}OsAx)5o5@}l&E*x=u{=x1?xOI-uhc|W6c9Nm5Rot}LX| zaGNx}pB7cI1|?Mc6D3pY5)$qBfPG<~56C|6Ew7o*aeB+EzDq=5CNF#5$N;c;{+`5dU z|2R|rqhb1n{YNOW8oJVa$Ud1qgw?-+4+%xy(q@K~AKAwFk;G(@9p0ob-cO?aWaco-nneMrzw5zUXD&$pw7-c7^2sU2m&{}w-yFEL)Zl&;f0x4F8aXEC@{ZR z!31)lWvC^F*4(}~uPP<{$H0+p$XKo!vPvbGB)~UBq!@SJ5e5p3#)K-6x6CyPiJPV7 ziJS+bqmy!2*v4JS;m}jdQYVjXfnyObER7jtzUR%vECk@MBf}@L$L4bp6=T6@rk61C zC5>xuC%Vw)xb4%Z_b{hy(@C~PDiz5CPkGJn81UCnmu)5Qla_5wFI&ET;QG$__J~Mt z)^Jj*o6LXr&C8J$?Z#521#f2AkLR~Pc+UQ{TgM{?WZ4E zefx=FJ7s%yyOMS&aUjXgeuDaWwPjTO>;%1O_46V=$o~(WYv&?i9?lx7Fc++=wOzE{ z{lrPKwH{u-QP|d^D@+$=TcK?n9!#@xuD|v!OjwfdU44mivGP*~Q@=@LFFCOpBHua0 z)j@EOARlfdt-(%z4D2hdm8Aisg!Xet)O!LppEnC0zp6G-}eq_{Ihwn zh^&bd^)R)lF)>dkW` zlY;Jee#2i<#+ib(<&uBA<#vfK_TcATMQ~eldEpK@RaY(@7!Zm#LU9qc>K*M$1)oTk#|!L- zcsjpmP2E`r#XGUQ>pSwfxJOm%#KMcTxU(8{ z5v43=cU|7^Y^%ZPetDg2x`%flHldmZoFHE;?>Lo@^+?=9>519+JA>cjv>+Ei%_^mT zz@o=+=z?jYXl7}T7Q;g4O%1gxC5Q$p=O5;kfzy`dKoijm@$`q@N9UXIiK9a*qF-s_ zDBJiBzmQat3Xr-jJw*PoymCkLem>2YT@1|&f*gEb%wDH~;-*?aDZan$B7f5>K(g$P z(PBbfzUbs&7v9??K;h^Xm2DlQH>qTy-#gCct?+E{OoDgLEC;86c zIZY!*|2exh<^LuSSRj+Z|Ah+0n(_~S=xo1hoz5;pEgAf`0>1HIDxhinFRJ{X`9~2O z=D*WFHjDq_X7oQuRo8aFr0f4~SZjv=4vzo0&p%vd@c(I`{~Q5L<9`Uz*#D^i3;u}z z*_>sw8T!AT;}Ej#zq>5G3IAuPfoiIM%1i&(`215ega0DFoBkI;bvpkA)Rg~`e`?Z( z^*{Xd&EmfZ{bck1(TL{wU+7ohtoq;H@gMW~hszB9=V2eN{tIZD{^!z${g3>gw;}!y zrT*u$fz$LK_Whq+UwsSW1ak<(q64}H4gp8lgZ~437h8&B&1(lg+45L@PIK~TR8-l- z9*Q~d4SU$-YA26#5n6^kp5eR6W0HWT$>V9>|2KKGN3t8Xhg(kFEPMErJHfO0|5i1> zNqty|8k*sM2giTZ=bua&{Eq>?@juabCqa8KVEF&c|G69DU+rO!Q+)nsmUd{7Y!had zhJ&`S02An%Y!6>*hX0R-HOK$o)F)`Ff67b$>|Rl;cP_fg;Q!=+|7rnE*FW$7qyDj+ z4eNjY;LXziMa}SE)hz#weud8T2gTbt{;%@+M>iS#w+r|$$l`wpp5uSyAIow4H{HMc zi>5fV9d;GXEz<5!72j4S8XHT*)iqqazVc{qhJC9lbIYbbxsotTg`imU>;~>f|D~}E2@U6C0C5ofZqA3x|k8aICxgOt>LfO}$Y$cQ_ zdbLixy%?S*c4B$QbG&Z-*^c3h*u}@^E3bD9A0&k(8Mb(>sl2b&khJKXK=6vZMemj} ziFA7N2ogl^-kJ0s+Z??oV?bH--Zct(+c|pgrT<@F>*$>(&2az2L`U!Vvo?X=Q}*%c zores4diOyF8T9TAVWPL{mJIpcg>P#j-$$s7S@iBMdjBEm#qxgO9OioF7iCcG9KHMa z^uB-QCeXWIp-=B$QuMyZe(?-?YfZ-o=FOlln6|_0JCd8wyADIoqW3>l(EE&}7t1?B z^uFon{f7*J`_C=Z&-eD&6ncN*C@!;yi*Wb8d|yLn8T9V`Pbc3UGwJQ!9KGdD>D^uQ z<~n-+jV$WFcl16Z!Ez|7h35I*g+n(%zHjZ}(>o0t_32&TCX3z&;6?Uu)_*eOdo8Bg zM83CTr`htYgx=#My;$B?z^*^nMufWOI(pmt^uCT%Hd^0qQ+H7HtzC-V_N}w%y@{Yy z^gho(bDBMTiK#ZBS2qx5(c511-XrP7@(vcgQAh7_GK6@^FbnWw8cW0fm*(;R!kmoZFAD&C z&8VQGA%GCj@FfP<3=IbbG^`h_$Ty+dNq}fh26qCW8QK0C&~UM%p=tv%INcS`K4rQp zz<-F(LPWug;b%{Lx(qrtkN>*>e-9r(?Lr0&oeTm9feb#wh+!d{hP?wCbajr&;0{2f z_M63?AD}uh>kYI+S7f302Gxie-)uA64>&e?Glz#XJI5l@0O;J932HBx1IVUC1n98d zoKWO(V3afF*fuA0ElU}47)LEJHmGMU`B~j)rRvV*X$jwMFOQY)2lQXy1|d>@!wld@HY+ z!TcB3X@;&l83~owbSb2?Y?6^nwhXdcPmyPE0%&(WqziY5gd1I05qn^`$jyTYVcXTp zXIA93q`A4!Oz{c?a;=CxVIbZ(!-3e6?AaooCJ?WZ-x=9Rp3*AX6l7I~tg;-4*|yH! zpHAt1k;YK%Weh<(BMTq|MporOWaE8CB?V$a0OBx#sQD?ktY&p?zx?H)$UY>P<&VxJ zYA=J>#N3kZ!>VB9o1o?er2~S#Ijvc%-x-%}&f^tSX!k#_*?>^)a{#i1@~v@%_j}kl z!gZX*(0lVj8PYrrPX!>(3P9`$h;-wqMii=YE1Rc5S8`d6UB>)ercJ1%>e}>VYC#M9t?v@%Lu^-ChC7fAPgut2x8wxjxr{$To#tRZ`8ymsBXIuNn)-+`^WJ zA%Z*hyo}h@2pP8bBVbe`c7oDuC43HuOukjv>cRt7_yxc4yHF7);oyuQ)UU*ynB zdcuqL0>kS?X`Q@~Df8Evz>O>j-8eN-Oi9fnOo8zn&O4H^&OV8GuAS|Jnf(;KuV(g& z`7(WfSnsn_-*3_Ty3~7}-p}#hV|lqP24 z416i6dGm6~-`eGGM)*PORPz!Mp3tZ9R5akUfC++_@2wj|w)V71YJj{E6ru^uPwWeBadC>Ej5EUXKF$Hkb`HvR4$9U(l*xiJ zm#|1>_EDMlT$y`SW;a*nOZq8b{Q6zaSh?oU@8QlT{zLNm+gI*ZI+*HB-uo94-s1HvY)B!ySwa@T=rZ1>}7(wi&3=HdrmLUnq1!Z z9@5KeCNYcnKf(5ziAtZ#G4D_ox@mf1p5^{dB7Vej&v13pX8OvbTUK`H7g^Cax`@m( z`qGoE{h9)aOAw%n916mQFGYJ7p*{iHmAr>uy4m`Zwcd7m*_+l|I?dCIyVfFa!g^Tj z?O1&EViVl+YJ}C3;@08i!mHCS+v$J334V764Il|LjW$dWo zSl%-#)611vagp)!?G=unYgOhkpM_kNnP<&a-W4j-!$ z;6@>xs+ak)VZKb(iyA+Dc~CF9>4Pqx-ap1xlQDf#rQ6CkN7?}`v8!M3dj zXmfd?%Pqg9E^%}%eb?y66>+T^iN00NGR=6KAM$f^ycI-wT5ZZW0X0jPXB`#XvQX73 z+_U5~$gb*RmokL8uspanoKM}4(5I1Jj0T56>;aLfl}vKvMMzCQ_OXMevdw?$z}k+N z<4DROmz`ZTYPF{o(+I(5I@;%wh9+$C0t&v0%PDUNV0yKw1K% z;U&)NqyKN6|LE$0;R(y(DW~QuVt@J*b{ZfMi)eyAIPotC7~&0r%X0sko6a<*soN;%&V)%Qk6qE$8{Z$!{Bsm9 zA(4Yj%WJMsXNuFl$BRE- zK~%YQmfT4GaPL<_Er!?6;A7n{S~0trLu0obf^7fhtnDHRHD2=UWde}z^+e-Z-?bM* zOS1D_-4Iio*uU(ssA=2?D6ez_XFUgCpBhks=X*KX(CxUJD_T0@FI|?U@H(CTl^d}({d9s}Y)gge{ zDR}5%50oEJT6bRI-*omaYwN&XROIxqz zWY;}cZR!Wcq7~eQBh{Z^n(M=*YhCC=r(H*e#zvtrEXSXh2}QmXJDssLpw!NDcKGbi z(rN;&c0C=fp6;}IyVMyk`Fyk}%lFR03Z%{cjJ?X7s{Y11bQO3b{3qs9Z2mxpu9NWu zCG%UsuiBX%_()A@6R9RR`-%3(uWthOFdWMWYsb1av;c|%>)PJYae`0B?-h8TJFR#` zVuiT8Rclk(zZqj>@9k%QkL<#_t+49$2d%G}Mt;Ze=u1;2A9W=gND{-92uUSBr14Jl zP0>sF3Bq@*6H}!t^}Ju|bnwae_hATCrT?SSTT(hXKB)_VqNkDa8US*<-*Gcsic_=5 zh7-DmB1h;`4yu=6t|L^juu_&U!z~rZJQV05F@U_nHe5pa$`(<{39x*bMr37U+g|t% zEkG8C2+B_THXz@xRF9Lce5cTLVS#pTxOfD$?r|VDU2D8+NX~+#tv7BfAu(=4B^9Qc zz|Ic9vbwS?bmPp2$vmC3GCS{d;`WMu*wIj}3dlJBYJ?Pfcp?m%iT5lS{gW!9?hFja zx{u(+>y6iwsozH$+y_TKaS5Vj%6kDA&J+%nDd1~ZC)fRMX)|83NC7jZa1J$3%ABM2 zG`bK!&sK`Q7OggV=OKGn5&r2vwe>pL*e})DJC-zxa#V9J0fG7%PVBYUTUfi&d*WzR z7vUv2f0(Z3lz%dP53%57WnJIG!CoZ=Loe`@=q*siU<+OIu8_Q7KIY6q&X$$5&+vt+ z%V-!swu@_6N#|j3C~6{CLhDlq1tisk~RDD@he7{5%d@&8IC>uvvU_e+FK8A zFV~>R4M%pQENu4WGW6fnMA6i7btctbH@C&|dQij;@YY&^8KL&ox5zhl?prw0>#w#t zd6Hk+y7uRVn{!Yj^H6)!1@24r8TV2`dCkLgrxDUAsh=CkTS#5Ikd!fC-pDudP77T< zn&>H1doh2VGWR7OFf|!BCz1};xBUp!V_h|myS~$V1oT!yW^r*i(Cyv=7tB{nfAmkX z+83oHCXo*h|GHWuZ}L%Aw`*Bj=jwJfRod#d9uk#~h#f`58IFj2M?^V92>%ZNkO=A- zLYA}msywj7`TkQ|?=HUC3E;{&P09Se#IIcP1S`1G8^f;zmcZ2}PIg_aJAVMLE<~a_ zOsv#T$vlPA;JwVpdxT$14S#T6|1cFh%@sS@6}!zZ*2gcljbY{ftt7dfc@q9}1n5(R znX$Z%X@J@~K*#xjemT;y@diVx;(Hl-a5Zp||J2rdkZ%InULda&$aJ+7m^QX^oK9Yq zBKbjymhqTRD!75uPDVG`$_3 z@jjkT;7Qyia$Jl4JSL&ygDK8BZ!E5&um^|K5#4oLlrb)rcN20dkBv(<@YiEIUYL%G zyk0~W#rVhf1`ZhgqpN7<%TI)ovm7PQNvQFX)x^gvZ-!}CAx06~Kmp_2fxkO}(Pv5f za;ec8{)_#mwq6guDXoKdI%zVkeMqtLiB@zq%40{;CarB`e@)GS_!W(oP!Vw#s)++o$vW#U$u%e@z|=tzE{vCs^h6SO`X9gQq_P&dIQR&(X-^d?{ab~Pp2Ii z%7b?(Zh|28SSShF0M@3&@?Kb(DVnZmBxnV0m3FxQ=t80N<)Z$rWqnb z6^`V+lb3p$YQh5@K97*RbNfkHbpKlxrl4wT&;tBj_CVc-q}iJG&gLld1|fj*;(pvw zx3;yTu%hPy1thBdO@Wi_yHG;yZ|$!pJDC?>MTQ;mYbITrMypRO_`1n(TQz zX)8geaB)T90QP>UWR$&*iM8CRKtU7GVDF(mCRVj(-w=7Am^`#r5i4oW4^7Y0REYA} z;T5q-5A)=8z&zBlsOdRm8)?Zdhpy+FBJ+yqnOqJ1Be9bU+S9BkY`2cuo$NLXRUQk4 zB2PO}{CkB;zYjW%U3!zDDL`_o?Uf8Bn6Th8m4LF>b2_q+5YMMf)gg&13rISU{bVbj z*Hsu)cfzsiso+q_PTqdR2%2{jH*dO(Taghs;LR~rEt?)+|yDsN07UbW>>~er4B=POXxPALWnnC zbPtq12)_qmSFoj1|%Q3+wo%y92BF_12m#xXHqMuyYp* zF^sDyh+8c`G273sKW|&kY`wl=sp^I1N|I=;?k`H>K;fF73qsd^CC3`e>)T)^8(7m> zWhra=z%-L)O_P*>H9dU+sLy-f*?3b84OCX`yE?#t^Aj1eUUzs(*1GyTHI_nE zyhjPhx^LMAWUYJBovd%RvU!&Q-DDlE$HnX4cX35_y*l zsh_M`r`nQY$6XOVP-P``7sck~fH_U-$0@o%>QfQpA4q*JpC$F#{7UM|?yXi?f4aOx z6j^5=RRazst*O+1pbS z+@zQqiBNyQyBonNPbM;el;&3v5WtDiL_ZD*%(nniw zDo<)qyAr)5CfT)D46SgL=}Em@zxf*7d85EYj;f$6`ny+BYH~;n;*0AaU1&W)4em78 zKe|9)i5+_&#GJ(EHjum0TMPU|rQ$j)X_;QG;6;JY7kZh`ZB~Ys&4J#pG*)HuuZoX) z(^*R#0B*VHx~+JyVE_eI+xIjhO8h|Kvg&U!)eZsm-c~BsidVnAyfoQfTC4GzhI3H+OMga0w7@ghWZ<6Fw(;J8%O57j&bJbfB(spuDaQN}G`vAlpS;gQv2)0!Y8x z3*ZQe02yB?fUN{&R= zD7AxgkR!m}ftL7E=(I{AR5u861nI-`q3tCj<9)C3uaNPsX*X}^w;4_+0;r%BZ`(@P z1J8>lZy`ZEz28etrxcPdjaB8Rh4~7wx;yaM;oMo2v*Fw26hn9KeZvn8 zVXXRl98(aPv?cNmYYcT*d1xG~*R(bQ-uC|aJmT>3&;{#>I)6hVg@p<|59X^)+3ZZ(5*TuT zgY^*0Yy4VrTUil%+CqQt>O)rSroWy_s)dm`k~HyopcuY;w85X6}o({tOwa1 z$COmvyHQ5o)482cw3eZp#J~BYso|TIQz`C($t%u;flG>20AGqX>VR@-HAB%jn=Nsi z^%ppVOUMYqeL?8`_b>^5p?ACHYd)9FQjdBI@G!s72v_JCSLla-Qs^$f&@c+gV-Mev{>77fC#858t^cE?3mJj_x2YsM}exsn5`q1-z=xx3A z47@ncSm@(9Q+Ph)iaO!BP5=)CpeoP5^zxLwtn{k%GR0oFe^f88XX0HTp~p*h6W-Z} zI#EpYv2p)rfH(0SH=Ah>H$&b3AZr^0%KmLE0bgC-}+A-yltRJ z?EjY(Vd*0*lQ{%Ki5E~X(E-r%5&zK39=v!bsnW5uwx{FlJPF|tge1-cqY*zWC%0q^ zIRcF?Bre1*ZRn6;fW#Xx;iM3%8^s5ed7Cnc@*tPm&MM@hJM-+SK7WU4ZsnHjZ@fQA2dw{~q_?;mczUb<$mnI|VJYH5b%%-=f6TMCvtEEy1f;}n_Oj9|)XP5B zq%ZV#5{}m;;5JHLXRV}c|szRSFw%REq-8xL`YJWGSD76QGhCq(r;zoPdEexyw?HpD*a_v?+QU(h7(2VZLZCF`g7Fo4+!3eNRjL}e>cydg|7Kt zT~R>F@8)+_dTZqK_q0nP71o|D6}2)?y43rO+=*E}W$)@`E-z^kDRn3&fWkX~?`ox1 zt5;}pXt4g_O7Cla;lGUR@!@n>`?R3>!SG{p2xt4Tvtsu3Nwe>^(AB%VEN zXn+nU5LTT6f+?t_;ZA>@O1$I}A-!K|(X{m?15FXJ18#r}sOf7z9eg%`Dt42aO~x_A~)8bF!u-VUW6TV@z*na43P249PQ!OgS3cp8SGY!>85)9dl<~g znj;2SK^m|@X}~^p!0!FzkAWTRfK7G4bb3udS$-O@=NzydrSm_aY;{`|pFGzW4a zWdewR&FdVnMIZk$uqh7MTnEfnZTT|0APv~L4%jvu0mhmOD7&E)k{Ea6!f>`OdHZ0B zLGSMr|EH4$Y?$-gbj4`wR(S0=J(y}b7@!rV;K**S_Hyrtw z$95=Wnx5TAOs6bkpneBt2*y*~;5^7fdF;^FbFpkXZ7*7H(+#kXFnq?ZW@q9he{BVE z-LZQZZaRi_O~~(&9zr=WH$w8no{`4u^t*VD4L5b(pvf?JzS=TO9xP&GF&p@a<~`4G zMhM~pekx)$Bl%V|RnVRQOhxQvUz97IxCWC;AE)TGecrl{Oo+$(sr$LqODGA%3R1mK ztT*fU+h1lIeS>*fH85Y`Xv<@Ra@a1B64fB8pVlFSV-h>N9S$>7&l~)q zoFMj9GK%KJUI#1_dkA5riM{myvG*?UQB~*K_|D`)U|<*(F; atVq$C}Kp=3Au6~ zxd|1`gk(aZxs1sKf}&0fMiA6gDW!^bPKy*RZF34mY^lyU~ zzidc<&$&ROKgj-JTj|yE8qF#?$|rw>-x03A1^y5_zNogVkv7x}Dgk)v5rh=4NpHhX zA)%{hw~kKVh-aZsj)XsvO?d8UW^MF1G`$SQ!LDPLepwLg69l8vo58l-k4b{s7JY(h zQQXVR(BqnVc|IHx_wtuS%}c)+CQZED!d_lWHPOt=7sHnD^8I3OGhVrWN3DTRk1|Aj z310pKu3fh+pm{*t%L&Ji*F#)vx4gw3KKd(4Z~7AWLU~wL?(G|;hyOxFuqJ&ZzN4Aw z;e!`T4{wpa93_1jVYZSUho-NAarp90W}lU8gDj0bVA}>KWTkD`dK{X5QaUvO>{I`B=xQH zxJAA_l4cg{>}P~0(i@Nx6KC&YXVd(&)7flq$Z%@m@3lPwd&1#ElO5hKA$cE&Gm(TU zJ>cJP_@h)G%p6{>9KIcT2Fv4%bhx+*6nFToV-g+CgBkVEZ;GQT zcJ}v?E#zVgOqw`5!p@#0dV7K6NO&-kIB#Ykuq}2C~`Jpf&%+nx9qW@f@nYj82~dJ&LvT7b5Isg3;-D%-%|6 zGcQ@?-W@Sq{IGviE^) z8!tv6nU(KTR^lF>INHL)e}FUMea%axvo^g1@tJto#UA!hT{RmzUw|#);V&e6_#4z- zxcWaP;!CLh|9uP|zVsRk4?hcW;o({MKpxtTw85)xq~&$&r&Dqdy-8JHP41qCm(U)l z)}cLkAP1lQMEsD*TDlQWMs5>Ew&&n6w%to2L(`vzmDu(LQvP|!li;NwQCzR#5xv#W z^qZgvb5C;cNGg$`=^sK0>}s%W+r<#|KMTGnZd05ZK%V?7&k|o5B?}>Wig*NvF;oIr z1Fqf%dF1Fd7&Iw>N+gb|_}ii{GpXX=gDFt}SKvd!4Dm9VD6x6-7ZF`T0i?W7?UU+< zSruOcaZv!@#Rs@#&;XXBm!3us`Wc{Yu^576ot``Z@lc({rT_QZDlx3dUSn^v zN3TLsWt~1Tc=g}KL;6(|UDru>6T5T;RY0>keI!%a!n)})ihu3)7Sy}8H!qiiw5r(C zMLgTHsJHtb!r)Ee?^a=8We5>r5^{(D_l}(S3DY&WiiMM$wjfmty0&J#N%Fr?6^CTi zWCL1RW8e4@t+lYNB<@4C6$sTXU*g{`6!E1W`XPa?i!J)vH)n&~L{(}9dSI;cx~Acq zLY8`9-n@+RKLg*WlllCsXpAENv`hXS1S{9j*Y}IpuH2gJ0-aod%Qv`| z-u4g`rPd@*RDQ2g8ARrI3{U9%MsN!m_1kuLaa z+j2Akx>DSEY$vZ*%!lYM@;a^+ubF}mlD>4=utNw+Fm2e2fEI?u zq_PA@fa3eMAGYPt^YwI;L*KuBuPvLN>8PFd&DMPKqbrau_##>;JTtBsseJSjxhp+` zw&FT}jkltO=B=2=7=9AoEqz-r4BhlkI2HC9#60p!+`9PQ*K+DnsiS4z1s$yJlw$KnEi5TP>t8B*@wh!FYSNOJik_qIXKF6DkD z<@_W!jO4!EDM$WUP24ls*5&eRqUVG1S@;88BBlRvX(yZP9QXocN)qjS*ybj^=T$v; zugyizzm?Cz&J)tkWN9aw4?F9~&PAPe63gdeDYuK{${|N-9fL{O`|sfpF8=+V58L*U zjXfL>>K7O9?~zWpXE~{lfXD~0i}FvuVh=WA;d#1z@`{w12N~Lk?Z|?qq~D{b`dvx( zM{)h7a(_|g;{mChMG@>F%~_r468YfzIa|uLBVBEqNbbgjaz}bu>>4Td28lJ2*g#4n z#m9adAO*IPz+4jepwn-Z&M+dt%c4q;@HZ?0_1{x6s3A9F>t{SJFcz z9z=|v${cQ#s^dxZPbj7LYv}YK!3E2tz=b66UnH=AZI2^!)npC{c~M%MDuvr7LwG$2 zV=NU3=|{qo_;Bvu6taR2=O~{0(Z*0tgQei^e~h!1l&&#^Y9?zSuYdPELDe-YGfz`?otV1 zm-(bXDhYg_1Pa;qm1J%qnS)1II7bQ}%!TlmN%#v=7-QYQwts-Y4UU2D_rsYG6;YHV z3h1yn!80ErB4qp-GI2Wz97GXO#(zK$_mVW?V>j-T!WATZK83%e%9E~l!q4B90tF=S zj|(BN0vAxoS~*EaI3ah^!(cj8ri7f5s?}0;0IBYTDrr58IobQSzyzg%J(w@${^W+- zlN7}Wl?E2LN(%fJ3Dl54n#d9IPY**7Ee%TV(1TkXY=5GX@IK;(FCHV!8!7xXoSafR zw$KB8?VH^Ab$YmiH96nkmzpz3^OGS6Z&Ag{0#8bTF(hz^1nQIk5AZcoz)k|Mkibj` zP(rV!=$;jEf7o^@JYln0k9(hdb6@SQRE1boFaAj~;a2Pw=$H27V2Kr>{+aTm;{A zAA#Us5^9tF1bInh#y`Cl7up{;Ga>%zBot#e{XqO1z`t!JSIHy2rt^N5{&8xGmZH%< zJ4W-&pYEa#_=Dpu^HAw-b!+&6S@DDF*B+p_FxPCm>H<0Gz_+*Bes%?YzOa(hftx4p zwx5E-VbjfRf5pg+FK}Ncf8>SliKGS`GNQZghF7Tbz#(u5CO>FX^Q?z(6)YAQhBK?; zpP^&LE9vY?+_8G}_kkhCACH+}qZFn;D7=Jo?pWZG;-3k9L{Q|YH z_i?vU_@YAkn(kvo4m44--q*y?=*Il_JQO#OQw`(C!bf+b(*8bhap&*upe>1??nf;TBJ4AjC(TCuwngqBE_k5yh05c8~)(k&hq^Z zw83Dj0lNv8{abW1)B%yR&b`ig;G74}dElG}&UxUR2hMrmoCnT%;G74}dEg8lsHm!M z2yf~A2#ebwT|fKMM)QeD~* zC@HP>SC*DE_zimF;)xri{) z&f><33SYfcpVJ7vJAGC4<#*QAmv_}o)D!Xh>#J%5rHiY532B(q*x;`!tEy{km|a@C z#FrR%7yateKviuC(p+C!7U)ccGLYZsudXU94ft})%HY7R31Z)OvD=w0vMn<=x2|qR zY3=ek%WD?bRnMyTG}e{{8WDe8t)<z3+9i7S3cbPaE32xg@|Ej>WmRRq(VR{T`QfM(FyYfzu%M+}@9esJ znGUzUtSV4h*BH?K^}aG+Ib~*rUW%GITqbM=CGtMs@@1$UdUX|QGfJht%GaQ0k0>9l z2P#WzQY^r3AU?86jHn}{0Y zi0jowWh(R@I|Aa2~I%tF2xhk4YajV%{k7khPx5jS$tdkp?7%bE9eTP`F5s z8xc9y7cbXqOKW_3HbpX8l%~poC^d?A)QCBwsB)wDs<=w4!Z0;WI`oQ1)#H3N^gN#p zqs}&;s2^7OoOf3FL?@>Q>gx1rc*BQJI=btnzIr0{s`2AAg!`8G>h{hd4XB>J+A^PB74X&QXe|?TUlST|05uk!8VofAN)bK=l`F^9fR>2y1bX+@Rn=yX zM(u8BtPW5G5>Bd=X?>u9x*ItviuM4n2GG_M#>eZ%qJ1ao z`D)91tfgt_rjWdNR!a5wNHa#qFp3m%myNNr+E=>-siCeyWv{3CTf98r6C=6k5=-IO zCADI}ufnL?q*I5A2?~~czz)p!Zobmch`9hYMSTB#Fb!*Q(CRE+r8<;^qt9W&n?Q5OSEh7 zUkS#8GM}8iHTe9!vz%xb)0euMnmWv$I*T~(-uvb;ZCbX8`i6ALgmhydQD4p*OO{kG z_g5ySp}RSxvA(jMQZd8prJOwQ67EGFisoAmT($&hF-AyEk} zsdEw26N8ENOw%{7HohV;YnX}pjh&*2{yC$CM19$iu&}`pkdPr>{m6xs2sKGaq8-zG z^vFu`cyuN^Jza|>rmI1$-%PUBQ)7m9>hD|!p0!cT|9K==bB$ZY1XPUB7_n(6Mjqr! z085O(a=(uTZtL|rn@h}iSz~=YmRlvI4P{kTB{X3gg&9FD?IU1Mq1;#PLy=SK>!sZ; z8wp*F_9~s|(5(_S%Df*n$*kIy=$aOhzaHC3>V=olRLU%EJx^CvLy0N}(Xpa;HZv$n z0p-xyjc`9{l2y}<6w7?8Uecmlva;W0qs26WQQW@I(3DIfs6e%RV0j5QOzh{7XH30v zcJ>Vpq7KE>x~5T3gD+50OYN;1%bWV^YRa#hf$3sC8b?{6j`zd3cr4_*bAnYoR-L1j ze3vfWB0Zgz$h6Rr8S{L1>WRvC2Dz@ge$qqccDqaxE#kM>jI>NgZoT;eC22f~ubi;k zsXixfZo)qH?dt1Fcy9{(c4FhT-WO=Buf>{=H}4=PcK7r$RImnL19hgO0(xcXQtVOb zHNHTp2p~^b%9WHfRM!QtHAqsLMt!lbwytqWrH+lkM%cs#0S5HavitOGH8ju?bBw-( zwtpYsEt~-M7HY6J*^O3wzlR%dRgJ$6n-F4qXT)s1qP`A`_u1IhnZuHewGCJ!K?Y+` z9SWJY@@VYIZWt|A;UmQQdIEWp7TTl4prsy=pZGpx@;){)<*oNE!Tz7GK6|ux0wTRm zpV#2ieOS+98^r65hc?vJ_)3HyM|){k#9vJd{7wOoC=&V~zN0ydUP0qA_E4@%h@V4g zX9XR)hz|LT@5T!IBtNROVR>yC$&6B4Zeml5J1wzrE-5L+E=N7p3Lkb!R8jCw1B`UB zQ|7~B6T9=+){)C~;pk2~*t`tr<#i}+Dt{D8wNI@6AyMmV3Y3(ao{=U4EGhY6m8AwRN@E#v{bO1XYN54Un3gPnl|N z7nox-HXs@l-zZ^q6m6_v>xVYHIKt%ob^1+hDjNJ}@Q#?bn0EnKol4gyPKZo*I?Ts4 ztFFb=F7I(^do?fWf!SW!OIWyAZiHB*{Bw)PVjS+3eS=@RY>=4bVN{nP z$h07hTO=lyWX0{FJwr+@GEeoQ$MaLOU6iiL?6tk*-IT5dWwv{hPP5&W&%tibT-x*e zC(ZYH`P(&_J-27ved%h8T-kGbiMugfZNZM3-&?O2df>7i*=dN!Ww|laHHEU`B-l5d zlA5;0-lee$pM{hX>NcDs>?E|JOh||w4XB8@&mi0q zsKbenR0G?9HJ5KtV=e5K`%0Aa>=a#PRekA_(%Mo;m0;>#H4uoC7|i)F15cTha$8DC z%EXk1Q?5-}F&IH*_uf~cCK9Tg(w!7g+Tbf$T3TO4_g^UOv@Zt~=TVeHSj2(bMe$E1 zNfTDGm61N3F2M9JU=K9(&#S9hEN(lb=$Fr%IVEpaenH8cg1lKX^K)k}ESa44n%GX>efa z+PIi2XGuv4euF^MQqQNhpImSHFYyJY*Db;EcKTcttoZU%$`smDxwf1)Rj?2U;9%BQ zel1c^y}SVnGjYCq9i2e?>T7V5q_lo{NsX_x7XLIfpggd`g9EF}CQ-Cn+Id*&Bn3{o z01M)#s+z_clo1vgm37tSlTxeemJFUlC&#ptN~^gEy3p@8sGwHdR*{@-f}W0*P;GhU z;>N0K2shX}SC9<@N=hmkv1am>l=QEzZ$vW6DtX0}+Fz_b>*}f-`XMgdoLX{8SC3qW zx=QEa0WCGlBor&K>V^wV0&2F z4aa*!(7wBD4jTl;4m8Sph%ifaBw?Z1uSBi}5Gd~CvFl~>FHmH{fh+8oEi?wl`zxt> zUYFHU8X2SVzuZ`d46Cn86P?**m8sdTI%Bvzj(5tE?Yydp`g1|tQJtq57g_8Vl3%-A zY2b3m%C*=t?1$ci?zar+>~Elg0y^XPnw>OYl$4Ia=3T-FQnGmTfNQTEFhJ`xnq7{o zo9Ov4g2*d0V@&!j*L63H!2!+U#wC*qORF1jjplkbB(tGeN?GecDT%G{$T6c2F zp0Rr#qtjM0UF5=Gfsgk$mR8elD<0IyqK%k$-H3VeX4730M__*pSEw3pyPFvVcXH-^Al`XVt17iz=6r6 zURpun!&PJri5HGBlr?BH94FsX!!5Q7OjtA=PgY_Nldf9Idqt8FCCdclkW&1MeaiSn zH+8*@?@^gtc%qQ9fYunOxHd-fa#on#Gv@egApdV$3l#xQ6z`XVziI7N50-`m*c0&Ks`B5te^BYM+?c zQ#DLF+|aOpi^A3B3YdXo3$4gki#0}>_*~+tuM5X0HCP`9iW{UEmS1K3{I8gO1+ zw*-6oejKmh3Fi;m#Ku~hEz_|`IhGOCrOR*A@ohy!#Qp59NZGxEkYO^L(_^|AoH9__42=Kvm=mP4|8q2Ed8c-!L zrdM520=4Gj z*`wJ+3*%VVlhe2X!^F{K#;BRi7`0?UIb$@NE()*Us~ZZFri*bhak|(!EQ@(=!Z0kJ z<0&^BxYHatX^J2w?3($6z3XJZ3lop0%ThrN)Lr(!G?QgW*Yyz+nQ%FX6PU0X!E_tm zHM^~#bzOg%Q1OJzu2`*~(bt`OnR);}6{7XS`(nH=!Fw3qm*RaH-k0O8<9()A1_H@O zE@K|!cwj2t>3H9a_ceH*k2n2<*$BKx;(aCFL-6j8_l0<0g!fRq2jNY2zkoM>gHOxC zdm!F}@jeglEAXZ`{dgN+X)f(XZLI5taoP>8aXE+|Q;38)vDuDY1}zHjy^r>T@a-7d zmcgg{c(*3WzI#zvKDWP)AN0WM!$x+lGIzv9h&xYIK=zL=@|W%d+-mZV=eQ6@1Blr z#d8agejh#ri~w7KM}VIHJslecrv`y8U=$btx}&FKyMV30cA);p)3IzP{QalXv1(ul z7z9Ru>w&I6pN<^@wgZQtfOPy(-fW-;I1$(i3<9IT^}u%ER-pD5qzmW-Mu0Bh5ugWn z5*PvwM5Sp3>cA*)9Izc&40Ikn9a}`tz%bB{-;vWU(6lfx3+QY^zJOj}F|ZZr1#0h~ zjx|v@a2-$whJY^M4xk&j59k3N26}<*KtC`I6*dUW0=59h07F1GQ2*=c*hXOF1LOnf zIfnG0Vn=|(fS$jdj^)rZa4spzfwG>FhYPsb{OE&oC~ zfx+YOH!$+i>DVct7e7Zc5sjziW7q?RPo9o#Bm5NlXgto2)A);iumfxXx(9W{#-MRI z@#8JqfFa;Mpa(x)*+z{HKjE2)4#9(8GaU|W0Zs&lfpdYH-Vv(?>cAk-4O|cO1GfU( zf%||S{G?MGumzZj&c%6UM=TrI0xSlG@N-fD>U4%f9~cGh0J=wX#0~)cz&2nDFby43 zD^LeUf#ZN~`~v6#U>Fzxy6~f@>wvAmZ9qL6=>P_SQD6vooOt};=MZ#qA)t#oJNyP} zF;E9C0=58G09%1AKqr3JZX3`G+($g{2vEb%@ty*@fkV(?wgATgBf#mvcA%F!QvCL3 z02s#aCx?KZu^q7pkp6y9JFo@6fv8`O^Z>^Jy|>`ckpi^|@B`2ZYyJA^=$?i6Fc5@*E?_&b80hvOAHXm$2z1>6zX5~5UBC!1LeI02KYUxwIR}0N>cC>4 zdu~T;Bd~oQ{08*T?}+7OquhWVU^~zc4Bv@-0fYFF!%W=AiU7v|^@WHZ=mG|SLEu(k z3vf43`y%`R^xTDXUkx6(2p9tTfzCyc2kOAxKsPV~i~@&YAavi2bONKmAkc%~-HZZ5 zUiftk!b=e^FbdoX3@+}79R_;JkiKhSw;c5o*bdwe^!hqtCxKz$@aw<>bAX`=*a3Q$ zbi`VLu1eHfptGtYmUTVs-ivw)YyoJ!jYi~JA|+yra|?f|;#I%3Cwe&E2dNEdK8Fbd2Ey8Vcso`E5t>wfqR7z9Rv z5n$R4$ag*Z51=179T*1sfzAf>A3!f~7qAt07^nq0VweqR9^i0b2v`hk2UY{!ji|4{ z7T^wG6nF^eT8efJ39!_=6oW=XmG=#{jhzsGsx;mPf&R^S z295!0LFfbZFQMK5L%@B&mM^2e0-Y<-9x*410^LCGD)=4P4h#bQkHY`JR$v(DX@(xq z^%&~YEzn<$`~yS4)j;Y9DbgF_}8L709$|_dVT_OKsRtJFbX^j3_po_a4YOT zg>(bkfnLI|pq>FEPa|HS_Zg&jBJ8Y3xdEfVb-?gf5iiiQ0rr6HK<6areGT~ndN;xz zF#L7M1GQ)2KVS$L1xB7je{mb~xe4V0bU%;&iJo78U0^%#FtFttuzNfF5`tZz_8+hd zbbk|efkEIlp#Ck`1-1e;H`2Ko<0LTrBJ2X4-$p$FdVmpN3otWR)3mL~7tjS<1oQ#} zz|hO6Prz1S8_=^I{+|qfC;SO)1#SZByC4U21CIg2z^pvP_bT!S^t^`nff3*ydJd!g z;J*V%53v2$9kC{0>p_f%z|bMoAE5WQh<_^5_j~jcK<8n^3)J3)zkp$2 z)-=fd74;vee}M7?hW~+jHy!ExC;S0)eTw=EYzH0yYH6|9#2JtSRstj0vDhwP%jj6_ z2(b0)SS)8I_-kUZbwK~Mu~-<`3XB3>*T-T*W`PHe1G>h-4m|@`1Kl^oVq1YB;BKIX z-xrPmo#UYAK{{`W#TEcv<72T+K=;kCOV9Y3!6A1b{1*H`E6_P17Fz+-ZjHrSf$hK} z!05zSENeE>HwnLJ3Jl*Civ@wLSZ(Y8hTQn+abOGn=KZia@WbR-%mei2#bT>~-hAX2 z=qZTBjse|;v6wy=@#A;0=K}R&q79r9AE_K0lG?&Phbmh8}YzB z#4nD;P7x2(zX%?f19X+eVt!x?a6R$BZN!(OT!;r|-UYwiF zi#6SYaQxI}2-y1LSZqH~-yMr-B}fNeLnLS^56sq5nw%+@4D6TLl7gu__+fY-`qAl_ zlY|`3LPyrr!S-dDLGAX7Z@v1);a8HX6K`}iS_Hr2oJs^<#KFDVegjtxZeId74$ncn z_kepAs7-b_*V*zNS@ku^=wP;ujpKW?Fwe+CUv+X6 zmkZoDa9(^i#?=!a=Rl4A{ILf%eq>_9c6Z!C#r9e8^cLD7OKGA%`gI^7O~ma1*Pg(+ z!O>qs8u-rHr&Ht~6*?O>M!+7uh@-!mlMl`z7|G>>a~rq?;3k60NRX=rmjmt#30#ov zC35S*c_5dUAV+^|W1S(6-QZS(OH5w`+-8H^5pW@Jm$E%C@Fcix;C@3K+TD}3$&Rci zQYSm~b!oYd?B?`bhihd<)c{9!p+iRyM9>aVZ3;l;B~ZC`lvt8bE|t|pyceaxe+N#- z9;7(Xc$;l#Z7WlY9QwVoU~?Ur)9f|)obPbrbAcVjn+UGSzzZZ6V%7~BGIk5Dem$~d3OxX9tL%^l!yq11B| z%5}0Gp?S$1%wU?PjYGubpO?A6dCE4$k@aM1fkS^HZL%YK9o3!Yj9f>~%6|C{cj_f6 z0~|Rph6qr-;&rLmo&{S$*gA6XbZj|3Qyp1p`{Dqq2^6*oVa2~O58H*XZ5Ck%5avA8 zRgcEAc7z2G_EJ2)2N7Ss-B#(yq;O|HOap&w9! ze&2h&G$h=0xc7P!q1V<+Jss(!ztt1MUN-&h9a-kKyJR7>#eKLDGW)TgeYQS41pQ&y z_r99r=qv-Y!pLpAokNg!nmW&ayXx&{`5)ePrI}U zYH(rGCQ)EdO{2y#^`~epd(m9>qrLnBo$p)decyIuPO;m(j?AC#-T#ZX-u5^=EBiHP ztV@3)?a9=qY*csmBMqyuS3i}~Ali~`4g4y`PU?@3A$%A1*w4nN8=*gD0M2c&Cr^L* zlKPXUY{kiWL?ds`$d~QDH6?X&8uF57((r8?9lKKU9N`oXFxLUm6ER*aqdo zF3P#~)R$8rQw;55mR*75>_gfH9zPwUzsM@nRuE5HLA*~AX)AI>Y^k@W!#w&aL#Koi z@T58pVW5iI?i2{w@hSK;70eyX*j^aGG6gi&QD0Sz4~uO0)pmT=iX71t+e4x*Q@NBQ zEP}9a#>0XrmMQi-AVJ})5bjOwh`k&Se?l||3Mbo}5#EmQe5%XBHmY!Dk$ngr!w4Im z-VvKbx;}?<3Ur7+1b#aBD~X@m$+v?qH^|fYmN^jf3-F2akYV69g1d}t;3eii;5LIB zEh&-yd~jiK0pdix!^}Oi*nS`9uN>ie2KE->;TZGLWtOS@BixJdaq)239n9hI%?J-7 zd|5o)HXR1?kQEXC9)w3N!m}ZB1mW&}9kBsj`-11u7Zi#a2dq(9I0wO>nbv7_A-o*n zzw1oPDx_taN{ff|`TB0~6Y7IH4bLI_)hu#4kiR4Zgz z>_*sXgbk-KymY)H;5LI>NQAJ3rPQ4R9L{_y5oz-{WTKD}V=ks%4zpa>`n?>=5Ut4 zCi!9o_>JI)5|0=8zXjZ8a4H_ENn*vu@w6g5ZD2>NkrWUQjovEl`w>=&Fl-@c+S1N= z=uET~d}2H&!R-bo@`?P=tYfnM;ka+J2BSY2)Tu*x90M*3oR{n`a_AV0MZt^wBWw}E zJQN0dr3qo>2x~D3BYy`Gwg+KFq*v~6E=CH7-w6H`_?wAG`z4qQVg7vYI|BXbObCqg#M*%5n+#vA0>_8kQ0+C}4pFtyQqdnNuw#iO*-8FSP59kCza zGZN#ha%9eNI2SlFJq{_3w|yvE_Z3Y-p3v=79=dmvaRtxTII zCo5Qc728YI76$9l8GCUr^@^c;9D07}{RDGiqmK+@Wxm6cdM`~$x(=1acCzI@AN{M| z5v##xvh@V{XC3X|G?RZ;l7F!6kUiC*W0DI2jKzMTot8D&h7)5HstF9x9sucwpda`Q`cdd_K1=;^h+n@D z?H~G7KdF8v?oZmL#PdDXj@?m}Z_--;y@6NZ94c8)v}s<%!Clj-O&1H#L5|u}3-t1# zx1RO5JwdNIO|^kCLwhQ)mxC!zsNZsKco?=e!j_nm&Xi+0+@T!@?;PF{TS{@*raPST z<=S^32FNDxtBL2ab&7ondfi+*^@U>)-iGi46b@fJL2I0Ksc3u6v}d$3y~yFVp|7T{ zFy7RP?DN4uCf@v~pexi|c(0)NMs&o=$eyShkfHq{mu<52ENTJPXlijxWzY(p9nkp} zjX6kz`My=YBbbsp68)A7K19G)OA};uTd|ZavfoKt?aFQl zvg1bcoI}Kqs$g>~S=608Axq`DAF`E@ok@1@cQ_Xzg!m)i=}t@`@l}$i@%R+@L*O4E z9_3w)JQY)2LjEXx7$!D3S9iqj<#6;-oO4;fCL(+_!bN{p+Zo?n@L}+Iq*o#Narjsb z{v`NT;ye2Sj1ZKe_&gl0<=qghuCgJz8G8O}aOO#RhBg?8H$izW5P|Fg$f~}L>g^G5 z5pWmLyuz&BQVJe7)LYaPl!&1!ql{r<92QBTF{p!QvR7hIF0}I`A>IzK;~?#=f<5gz zu47Y@$57Gcu?)T+<`PFRY8Kg;g~Z!gE^Q0Qe*XaMxnPfcPIE_^Z&P_51HS2|DhdGDLnW;qaTfnJ&mZPlc1iMl{to9)kr%2i~icCsJ3Sz|k5xU#@; zivAQn!0IL;9?JVk$c};RK$69a(mW8ABpaMq!-;l=nF!BM?u7+8z7^Z^WDYQXO%`Wy z`Oxzw*dqIMe{T^ub>={Iq8eN!xTo=1w!_Z3BInHo?>@br)>yhOK#I zOZZpil@5*M1R@_krF`~jSguP)mvxX%>mlof>=%<{3pLa`x?+F2N~>mfUWWbvXt zgzlEMg4;?2$K|qN^d`L`JI*U;rY&kE6@0FJzO+cXP95vhoZjnF-I)&EjnMrAJ{!mB zso3WMJg3OvxBbY_Ibmah?9qMV>Pfs_!87@17`T1luEJ;OADU6hIYth` z4kHXvin$|&P+#i-e;oWn#EUTm+2Jt+qc#^l_K>jjRqdDjy&8HGZ%f<*MlW!$te516 ztq5O)@axE~sMAOvK8C>uz)vC`%gL2CjQ6P99;Aoz5JmWUgx^8o*o46Dsn4OyvN?sY zLkRmSg~2A54f^-{kW#rVEat;p9!2)WBGJ_P$o51yCg=8!ST5;H+w;ga{?`^DtQuj{ z@L8r8+Z5<)vGzmiq|6G)Z0trR1erbE$n1ekdp9y|kQwGab9x41!BgCgj0-Y>Ze->{ zCe)2g6J+*xBeMxIC%cgeLuPpHne%l7GM;W^GSPvq=tgD?WVUuA-{vhQ2Sb zt{a)dklA$x8PV^LLjMXGF*lq|`#YWU5F2g2qF=x&U+f1{AM1kr-29H%AJUKApmI1?*y4wpvsv+~|_~fy1swc~9s4A(=1uKrFe%*gFy7`w)IR>B~_QRYlHYU7+Z@ zGi?Zef$cZr03B=cI~_Xq#kjub+wWJ)HO&pV7U;~K!RM>k5^lET$#uNTMpr=9!VZT( z{JB`1O7X*FJGJQpu+a`12RYuAHuCoZdA08)j!+1obwUhg7BV}GnG*j{y7Dmo|X}PUuxSN z^Sn_R?L+vmxjj#V7doe)vl=?5$sgDTe~RuNce%5}_gTC))cu^U$6(X!woeey^`=U( zsEgif;lKGk&u0td4?y0m3@M+j2+zN>=lOI)=LmFKq4QblVm2n;(--tS9}6IV3i4L@ zXhL}P!k*^?MWtp!?2Cn202nqN_VvatZ)w%9s9#R%Vz@Sc`G*<1mgoHFzD zc@Vw{;ad^@dDf41*j!cKGar(V^cyf=_jSbYYR303T!~|b^bvh`b3ui=_9grD6|dGxUPcTf%xzQa{aiFlN%Z#1uN0nCfUvs}~pg z5)b^G&^ZGAR_J3XBwj=C?@4g`!CgTN<}S2ei{jk5Mvh$pMI-*$xE)4FOOd01>33o?3?_-Gj)J1f# z*_LK{XN9&E#QD?#*mK^GbHG$(4}LZu*NPmt19Lmwf$2K3iTM%vZ#W9i8R$$im1Pe8 z83^vac;6}JX@$7&t*4;%$W6*zJ0Fo_zj3O#ujq$fej~m|3mdeCp*wz5&sKw<4t^Q& ziE|UT_(q7FkMKHX2V_H#r8Yt~u;Y*GK{D?VgdITGq;!O#{GOuwC|&Z-chlj^-ypFj zc^B(Fs;Bx*D6a?juAE30&P3>3$%XB6?jxqsNfdt;$JKI{s(GRBg?`$DxEslRd}7&l zxhs$K+(7B+dS^BtTizyf40&$12XW{tI%03e<1ou}k-V4dwe2*mJ(%kiBfa#!<;@S_ z{uDl&wo#n%qjyX?ZYWSk{FqL{ZV6xoE%rvM5uUj+v5uo3 z6W@oS?+|bWDxm#&{)}2k?PN3bJkX;tkm@@ITP$9RU=`yM-g^-4ML3n8Y&*g((nx2G zswJXq5!?>hRgfJ(vUs`hPRl|63Qnx6MIC2-SJECeNZAa@P7ZXoL1!Qt!Hc-*;I<}k z3&457Z3g!@5)%C>?u_%D5kB*C+i;mQsX|SqGEZW}4X(s4m*U$E+c~TFyb{kIyd&V& zgPX~1fzJlw=Sr(EX_6U1H7%k8SRI=%$QK@`(f)qtF_S1)if8yOSl>L#XN`C!j=nd4 z*uYH(m)+bE`#Hktm4&w#+!1gML_Fkh`B8S%xw!GT0%66Eb?ytq_n%#~iOmINOoPY&nS+x@D~z+-h)MiYIBlW#ip4v=m$pL>>#oz7wxMH$$)War1cv zjh}lE9zpouIQ`tt#h4wxm$V%~8tyu4_>xjKZDM!_i`v4?3U*@HA;?(sIwJ-Yg-(4JasnJV&A{%sgPzSpxf`5`;x z`xt+EmL}VGO_Nk?Pd(47P^F&^A)ehkyH69f;WTVudS2;>rQn=M)+Y=JUCK_(8SyQk zl+=Hj&l$yhnfx&q_ME@(K5puJgOJ?}+0U!*C7TCe(|`E$v+07(Y&Xt3|A4bn>SGP( zBs50g&I`?v(_9EzPeb>C-CYvh|z7OF+3!C#3ZK6>QgH9`ShD5DxMi4#@;XmZD zAn`m0>BOS7Gnr~_pO%Yp^pEB?DbC>tk0SgHe8%@aTuU99^Bt}RF_Jq$9j&;$a}rhIRc$XFLmhmcGk7^E}rSo zDSp3qIzi~9{k3;GJD?NprA`}kR(#OAc!uR;{5aM-9S?Ml_flsSbXxz`yLfg%r~2=` z(>Vs6><@dVqZeTQ-bFkD1)<1iv(+-^jz0?_Ai2m(gy^Ci7 zbfzEgoz6PwWPa2;oiKFv^it(7f*H(#=nnyr?Ut;Cwr;W0-YTvdmc|Y`b7GT zE&nI@%|@Cein*uR{txdT`cwaDwcVFGgyvLTHv(z$N#o#{V(f1;<2PIJS#$UkzkV*h zXD}V%#rW;4D<~YxLG}HEa`0a8SgO+aDR>$qSAbs)elYQP4Z*tw+$wOG!U!7=@ZQN* z@Y}$9iN|fp#IX|>(s|;MXJ4c~LQKay3cUl+TZGS=IK!qrnd11}af&l-3dZd8SPa{y zB2M})C9PM7fzJW&CB7GN&V`;AdS{B0e%EZ1Nt`X<_nbwX`=EEMn>dd_COe~RKGUXR z{tLdh`J4#7Cg`0hpI*r9Fp0AX{Nb~RvlV)2{mvZc0m!%^Lvwqohq!8+N##ku4c7#| zxA`1C4gGmHaTY`7Fl3B%$O}F#v-fdsgx(nFoyoVmAyWw%V_P`@zU3_990-T)>LyMX zWR63|n9pMH!}|9=pF!y5L(eLo*(kTokO@L&2R>`@{TO_wfwp0$;H%HHFM}YGjX-wD zfLOxsyU^Va%p^%>roB<IOA1{LJF34U@9X!^Iy#H_hJ3$`0pl&+&pnEspm1xRT zKZa7A{9`DHPRIK&;;+0k7JC<;(GTdf&x}1^`bN9hPZ4!)7W{u1eut41Ecb2l=u-z2o=ky#QFrG$iWfLMvmM2`__idz z-9Z%-o2s~Ls4gWnL3AVZj^TG3fAxhkrHjw8{Hg!y?`X0u!r@?{V|B_5M@!0b$3}b( zrA%@7Q@>_&G|ix|4HY<=a`8OM>bFl2)o{G&w#}0W>5dYuF2*bz3E5599Y6X}%(5v0ETy=~g&8X^7IV z81P47pMC=~3%~97Thgf_`!ke%9`d0iN|FT5z5f5~0p~|Db&=x|Lyu9Vv3|WeScbpJ zc$iUX{F9$;PIEig4NB(EJ@?KZkqf2#56@3V<$rXA@?)yRV#X-zwea&HMmPIhkpF*e?Weqc^JKR-6pZW1aTHhA3I_){ce_z@w4({J3oJ~Q7V4I&uvP8?VW>j z9ysTLa~@dmxaz@@eK9^Np9>l1GgdGzWo%~Lz_^8RC*xkmgN#QRPcUZuQ4_DBj3XJx zGZr$=XRKgc%Gk`ffpH7tPR6~A2N{nto?y)Q6UWaul5sp^A>(|;3dW_3&5Rouw=nKx z+{<{7@hIa7#*9C6{EQ9Ch#x0CH8TT?CWIW1vf-&PS96#eo#_^1WjPn^Q7?(0OGj3qq!nl)h zFXKVRql_mQGmdinj3XJxGZr$=XRKgc%Gk`ffpH7tPR6~A2N{nto?y&)kK<| zka0d^1>;i2X2uPSTNrmT?qxj4c$D!3V@4at&p48CJYyl_e8vjKrHsvt8yL4R?quA{ zc#!cZ;|a!$_c?yXk&NRR3mNA#RxmDQY-ZfRxP@^i<6g#tj7J$yFlPLf<7XVnIG(YP zaXw=O<5I?E#tn>H7(#s?ff<4DHwjD?Kz87mlH7(MmxvPIFfNZVw z#tO!zjLnQ27`HI)WZcVmknt$v3C4_naQuuT8OJjgGR|kLU|h=B%(#JZ3*%14y^IGL zk20QM%=jnA&p48CJYyl_e8vjKrHsvt8yL4R?quA{c#!cZ;|a!$e{uYbBN@jt7BbFf ztYBQq*vz8B=7kEdTuz?;nMEooy+2mH``ie7zIq?|UzM+` zkL)Y|yZXpK%KtfiWMBE;-ADdW{`d5eedYh+KJt(9zo(DvEB|}@$Un;e{yws={O|1} z|0w@g_K|(%|6m{aNBO^{kL)Y|H}#Q!l>dW$WMBC|)JOhN{%`Fg`^x_`WNB&X%kMxm!<^QdHNBhXW^1t3k{!#Vc^*PyphS%#jFBY#Gczvgya}3Y78J_bD&r=Q0 z9>eoI!?RJ|XzzP`-$bRSxAJ!x;#+KZ?k;^b2KnyxKh)~Kp7qqTO22wOTkL84PZ{D@ z@p=E}v-JyB@xRFNWvhr7gZ->D41%BcW1%#dJwWEy`Kf$vvGpuHVS}GS-|d~>!m;EG zwLD-;Ci>`U2Hz`kua^02pJ^WNCFjZfv_HoFu#mfe%QfODw7LIRvtNR1WO(ar^YqPNdoGp>-(fDdmF-2j-bOs;a;ko}uv~POx!ip!-VT`$ z-69_=ST3sa`xW#2s&=5gY98KOKU>LLS#RNV8v9p&rj>?O44)Iv?cXl!7vAWmE z>7roe{hxDsyatWP5GxIX;OG6w^(V^dihe932%g`w^mz9r*BAE>lb^dwuG3h5mYJ7N zcXoOm&f~L({wO_O`d#Mno?^dsfl-ZzQ+3@UGy$v@2E5+KbHX^ez|H(#c-! zlsn1!Hr79n!%Cx5w@*HC{mZg*z2W-jPVZTI^f#01oBPMf&)ucD-LO6jHui0~sPz1t z>r2ZMGM~|V%;Qz{&&_h}7WMQGY)|L>=;DWDRBWB7>Ypp$JiboJ&-Tfx^!~-^G|peW z{jD@UTROVc=K7a@fvh*76H=q4hx1qM=gIXg{FCJ8?&6Oc>tCR6%SEN#nv z$JxX2GisGY4z#aSdztV*hPmVd+kQ|Ci2_5EKq^JT`C{?cFX@p+w!MTH;YaK&4p`o66SSNgB< zKK~fQxseKghxscl!i#x*afwCvUzkr(`x=~pOqCEuhao)85Z>KmclrCQ>F>@z=kk}_ zuFsWUa*aJ#Ka=Z+>R)==f1GQ7$^JXne&EIgxNf+~HFm5^&z|io*NaO79B}Q;qoG9Yz)8xOmKEg=Pr0#ltmftKEGaaT z(W0cJX+xs|Ozo)O7}>+WHDYE*#qkB6|C-6X%K8e=Rz{`uk~5@PrS%PtQ|7Mgzch%}B^ormu z;^p<1mq@(mYjMP@eL63Zc+v3*@fz;=MLH-I9G^I!FKP&mWnD=wd zQv6q$SNEe-J=xB@+SgM2FPT^SrHXH3UhU&6eh?;{qCW8XuHvs`UY+|Yej@YgK7r!r zFt6_6DBjP!x<|HL`B~ZL{bR*{Tge;v*Off)7b^L8l|1t=vHj!BtMd`XUz{%UtM-k! z+G)9p=l!k6*v`Got9yC;b!%-c^Xfi{;$LK5?b9p%b>`LntKy@~t9w#Y&>ra3!MwW9 zrP6a*2G<{I$ar1N^5dCT=TnNmhxy=ODfkiUCB5!fJl`Lf%KSR!)jbCl?@P>kFO+tk zcSt*LgHOS)F@+Dx5~n_zUVjq&P_6xC$&0ZDd^__|15bafK1CaG-f7_X zf~WSY?j=qW-pB7fGq3J7Dt;sih~(9MFvZVdUfm~CJpC;=l2`Z96#on6)qOU__wO&| z)jb}?U(dX{2c-D<%&U6`ieJgRy0@VC|72d>k5K&oGOzAeD8ByynI3iDL-FI8SNBB} zU&6e)Z=(2B%&YTl#lOUSJD+38|t9vv`zCy|KeF4R-l`+M2WE`yy2%Llh4%m0q~@Qca(5%A;(b-tw1*$)%k6m5_eGT1*)@Iy7t zVCNF%-J6r`k6=5i4R)?)`QW#bw-?yH+hBhy+tCbme!#r@g=G7?*}l5>sO%qN``HHj ze_}hq=acOmV?MkonLoky)qP!MKMMmlmAlhm|4PB5+zocdFdup@+5UL&y;i4dr-~vSa86ZddY#b~HuF8|wcY zC2y$bcY`PYsQWJ}zmGAm?k_0*TZ-rVT8jS(^BR9&;yw1~hf3bSUwXcbSKU)r@>7{t z_uLi#IP>bByyEvTukP6^Ub{frSNDq*KazQMKUwiJm{<2975@P9>OQ67w=%EpZ7TjC z^XlHG;^~J?$fWB>f5W`GC#Cp-7qb8P zo|WP!Gq3KoD87n$buUKoPcyIXF)04OnOFB96yMIgI*(TTNOUpeA9bFs_=U`?^Kiv~ zg?aaJSy!|$QxyLO%d7LyTUb8I@@|$_<9_BvoE|>^_pFUbBpYUn>NVBTw(S6r&(4gKdRC2ttt$0~V4e}1cy zH;ktRO8(hozs+PmXyET;UN`VwW&fwrPDl=K+M~>e_&$~5cPaVTlI8!b?C(zI`&}&k z7J4kqbr#B1Os zGM&NiNcl?UFA)4inv3PtJbW0-YXC;H}HRCJ6?mG516ks@E@_AputXz`4$7; zA3u;z^W-LjoeP)`8u&{Ee?I=+adNqjV!qYDk7YY820OPhztO-Ku${2M&Mf9527V#i z*=n#;#(b-RuVFh;gPmo}w;T8`v7NBN&RXX88ThZV9re2ms$G18dFPsBzrDnE4jJrh zXFh7+f5LXu?+z&YKVx3~UV!3%DR_)8yzcOFJB>20zW*F$J_QF2v~Qrk2OVO5xZ?N9 z^eg#%=GFIJE4hEJU|xOyPss_BS!FzVD^vUu9l>?<>mo4=MhQ&)JUiBgIJkjgWW7|DJ;iwMzd9AwO6<)+pmu z@`PsjP17mA12uKFtK@Q%ui(A!}Dro=U(utPh(L5D_CBukaoNrxQ6*)f#m6YlwKRao7vgU@-4rX z@&O6jKIWY(q=A>D8SP{6W_B{K)U@+3o`x@!^+e6bE&@+}bKfovW0@viqrscmxtZmI zlcanp%THxK`j+I;jf>Yp=KZJS^9bfwTG)Srz?!iq|hJ?A$rg zJpD(79ac_&lWad)C+%a~R=gZnN&k3weRL!9lbClE+641MsirMrzMa>1i&*|mWZcZ3 zP0D_bG@$DFx51x>eyp9_uPU$oEbnE1s&ux4*Ez047&x5lbbVbe_=~hwgZ*2;o29c5 zyl7v?WIA7ClhqdT%URyd18*M7ueXr@rUm~4wi6A>cvXEkY$5*v%WL;ZdG)o9kC}IK zxlHHuT#0g_d`0S|JdRhyYm!BIEwtck*^ZOTMdkOa%zNCjo`}B(j~HHJ-aAF|^EuvE zEbPC*@-Dh4g4Z~fKg7JB?}NX<{D6_>Q)G9TiOt(?=-%DkKRRaCn>sCd5=#5TKlwK4BqCi#ubf5N=J zU8aY>4x|kj#r1islvnlYR_0xINd8W?GX=a^yO_`N!6j1uUY4)6kY8!RzhJ?C*Mfh| zf`8M3|6lN;-1$6?uPJEl7V>G?+%7!HemD=jnIEoT`QSDw|0w(6b_@B1EFb!{;L-JH!b*A*}m(`(*9CT&rg~6d`a?SnExg7&T*1|nfc=u_O;Q{KT+;CFufNq zCwMdeT+Q;q7o~mWpQ+4y|5Nf;O3-R8>^#KsEqPLK2*^XG6YuzW#0@|0&0--6PYvp5q;OHP=J_zRVTO-vr*wZ$&Kcu99|EvHT+DJ=_n} zGGEQSm*+ETJbj4yXi!$PmstK=;LYM~WqGYZ#``qOA5c7xN55k}#=M*NrB#1*-8JU+ zZwF89(aq=n53`*a%(pC*@kW@x+rm!01^<|^!^#QpEZf&#miEDkIU>zVhwE!&0oo39Al!F;e*%I{$L|F*FIGYkH=Y^Rmii7MW| zGaqi1_EkMR?>ck;TxP*vZ^2Kt;OBs+dY<`qs>o3$=W7XgD#vzS*QkD@iTPGu#}%^t zGlJ)b1lY>*u43uWH#lrJ^PY(^zt~O}ul?Z7>cbycUgP?s#+MJ2odwcP4cqxQ^WJ93 zPhvjxdYP{&%DP&kNa3MA>H^%K`B^44&%4K108k z<}&v~mIZ%<1%DfOs#nfpnXeykywfb??_qg2|IVB8&uR<#4Ho=XwiD%X^CB6&w#!2P zrxyJ0*iOrrlE=-IvE08soXlU(ymzXMFq|$kJWd~y@}VHWd2?jNw65w9}E^E|Dd z`4!-u{5cVxu;4da@UOA`Ft?)!8;daC@{&xynx}OLJ~2l5*?EKXgPZparnATu;LXx` ziv>U3f-kY){oqA^b)NM9YaH+M7Vi>&%BHG#|ATh)WXgQmXC0~Qsde{ z4BY3lZX#SRc&s-k$avL!sSv!Gf9_QBJie=TUB!IpR%vH0NAeZsqr6U3{liw~BcDn^ z)$jdI$#Z^{yltF$dInqY*%th*7W^FWR9<>Ya(Oj@r~W6~a8CLp%ZJ@Eze72{A?72G zNS=ph?LXPhRzpAbOO|)>IKs_QI|AO!|LrUv<$0{~kMky(evQ}ZU*q&#&U~2ttmcP# z%zF&;#v11JKg#qEWILs!WO#Vf-AL8^lSSP}KnAZ!1GJ5S@=37f7 zv6|)218-*kLzeeEEz2>YONEs2=JFR>@WU;5mj&;(;630)y^6~8V>&8cCCvMCCGTav z!NSg0Ech2J`0uj)$PLoI>L=f{kpCUaJ9!?W<|pmUxAVTbs&9jDmiY?vI(MgxMjH-Z z=e#7sjVvEJC0SMO_b~5aKMZ9hKX|k94X}KK{`LUv3Y}zhq(m zhb$ldk7U0cwvhk31#iod{&6pocB(ku^TAVpvdhp9T+i}RUT3NF&u2dJp0sm`1kERS zHkts-SiYV2yQXp2I`C%xe39i_Cd>B1*Tl607V;lj@U~kxzub>K#_nb&z=OZB&o3DQ4N-uGx^JC`vZ;&s6t%#UTho$u?aeC2^R^Uoa? zyw`%SvEUyDPxaHy>#sI0mo*mh{{f!*HxJ)`!|*L$Z!jNPCH+>;{9y|_f4AV%Zk6`K z|6gg>0$j&co)>5#Bs@e5G%eFq6w(G-ge=*z3<;I2M=T=SiX`U&Evu`0SJI8|D|hd; ztPsF0bSO+iT?#{hDVXr+@Cu%iw4npUVWw@MrSVYSQ(99}CQZv=C}gHkntuQ5?B3ly zS8};C_U``spa1;lKmY6e=iDo;hkRY>{F=hgY5daH!9InbxTtqt))hXib#?QHw<-M8 zhlS5CEB!ka-qPR0J0Y)w2NWLYIt9xU{(KYgqIvmm!&iN<9PH97i}9c5f$#IcuLGRq ze=f7Ws{l^(IG9;SA2a;7$$;9*|2q|aM%Q<6Yy9~j;6>xQ+vw;z$mID?3ZHmT=pRu! zk0^X)P2h(VehC7N$wWbXxs2h^t9^ohv0Q@v3O}Ly&I{ToRQNfKUzaJorSR6I=!5ys z*D3t;T>}5YFG_>AD}3Ojboe%<^Ff85(e;tZVdz-1HT<`(!?`kIISk38_FOsG6RE*+YE4JrJLZp3{; z`M(lyn)l(1yKZExQKUc~01RqfNS*@Sk ztn#^A;pcQc^==J>4=Vgj=3K-jlS2Qz%2UlTc!9zLt@~{S^0`Xkt zXWuUHzft&v+HC!T*Wk4{97=Q2dLhMV>9C6Djk41cb?X7ef04pZtNvJhehzT5qk)Vay#nx}@!rJvPYx#ZyweG#zv;n$tq1;A zz)Am4DW4ZBoimtsf}hv=Hp(XaxkK^KJS^k2dHJlu2h`7--ae%8lYcJwrk|J06p!oq zfK$H%#{_>~F2RdD_{)la;x&(D{ywODZYsQ`{_t{zf5=1UPQXe2XESmCex-9t>-on2 ze|YHpkK&)#dMVV2KbNXJC!Q#LzF#MPR^baTm4TW*yjHJ%u`tV$Ze?;+D+CnE%_`M2m>HNM*;SVT0P`~o z{L8VyLGw8H?*d;@{AWQQiuCyi@QdIzr4u|?2>gR43UBb>->&$l)K8k+KB@3?UllrM zl+Q1E=$uph(|YjD@}eigkc;^IWe@y$9{5W<@cn?3+=esz_^S#ZRQcOHwmo!StN0VY zE92Gh6}-jZuNC->atYq+q4SvM6_5ANfKT@F)vUdE=zLB4UC_8=>!u$meC2jwh;^_ z059tI2OjuiQJ^cr|9QY!A4Y}2JG9?1z@LWiSp@ohH*5P+#UJ>l;6F+6U&i=97p&;K zJf!dlaBHg|zPw85oY8Yu(<+}+M*r0U_=Yw*?V)p@2mW=Xb4t(c*n05$9{h{uMGmK5 zDgAC}zt2?o`3yf-0A4h%J&d0osoWn>Iww9U^yhTEEu;T?0)UzG=Qf2;Xr0;WU3V*d zSmpm6#lIi$B7VN8_yZarEkF4o;1mb%&zu8)?7?C>PxZhD0cZQtgM0TXKQC1H;KyWK zi#pyVzy}p4eW@Frk|4fU)IGQr@S<_urue5nD)^RfeB9{VDR7IkU-r;>*aQEu2mYi( zGTs5r6R@o2&!q}qnUH?3Q}}NHUc~>4jn1b9A7v~4EGqnTP2lD~S3GoXRs0jr5`jHN z6PkA`{G_gHDoXz&3LnsX<~a(#&qM!9fK&W>C=^$nd`_a*3SRfga0-U{C!GiK;xb9^Cg9!%;fnGd+7Yo1HS|t76WO)=>4yF;MaKk{BL^j zuk^qdJn#^3vWqhrId3XF$mAh!0G#G)SnK(}p!~l_;jO7aa8oK zT#HKWV7b{mSZZu7ZPizswZrX&Zlm1kf@rg$B&v;SXL~Hy(YEx~qfQvEwWG!@TVc$- zhG2BF*{)bGljU;MASR+pb{Iz*t#-B1DXrF`?5m}2+^UwV&2Bv1ZPlt}G#5gC#Klr$ zJxXM>)NMuW>!WJBay_`oH!FC{gQ>=0x!cBwIy{VUwNwcTY01!=?Wnrm2y4y8dbnBY zlsAH@n~ol7l$-Us6S@=UWV^gks+Nzm(D{6GGs;b@4}tqy?XCrV5sdFrT&`BbW}~(R z{L*T*JQp`>Gy${Cc0DVJsfDd@Iw~(lYr$HzQ3;PmTReRQ`d5icwOX^>pNU#2?u4aU zYoip#QPk)oJB(*7Y6HQhT4s>P%2b?o7$rk2)`_Gc1`92OtlOn>2VLw;jWc~xbHDu3 zhLl%vew$Zs1}Eb!9!3U9grdL#rR6tyonx?1TlA$zHN=(VNeVnasvg&qmxa7eMlA!% zLW^b5L)!1vc8HefuV>_jkRQ9f$&cRNsE*~wZwS805axYvt#wv@d3dn|4Uf#6%)iuG z-fBgMO7*DNGHqT8G|fmIgQ1n$>#=%@c#SN+T5r{c%FRaHX|8;&2U95tf_XMrWHA&WSnf;t;~*F9xwp$Pn;Tf$GcUfXJID9vq=OPtJXk6o%H z(Pvxij5vzzk_QK^NwN*mo<1yt35w*~_TPhKAvP6@^ZXSc#V(46DaB}WPG+21vtm!> znZ6w~N_8k*<-K$vaSvKINlR6BUf<4SMJYJL-4T9Po;%A<{(r4BCl|5otfN-4Xwc#K zViWvx=#u50q!Y{*q`8cr%@6w$r)n_W5sHgV{6ojY1EM!+3N{eJ@OhEwQffoja}n?17%Npq)0ksq(^qQtAF+&1UT*L zY_yx3L;ExlD%YBEG_+5%q!4TNY6pIMwG8Ww!%&hMsz=nLFdW*a2~!+3Dnt9m1LTs+ zrSzLE65jU0Y2H#lI2IEd7dz`xM zc6u{9j@dOs_6Hwfp*SeWyM#&-9_5X9oy`__L1`bi$a?#}Uh;yFQ^E2=(>~^`Uwf}M z7maEAw2xbDoAwpaF1BXI+-cgEM&3T{6YQO)eHX}bPZ+ag$`|ucui7^48sdWxlu|JeQ94I@w|mI+6AP2jDG=XUm+XYy2YQO)rF;f+)+O5OWgea zYG<<=NAoCh9&Uwj?zKu$j&O`ixkYap(Wb?If3l*@x0OqZSU!>HC6a$njq?hit@1Aj zJ@NX*%BYREL+d3aHk4~BU_mXgaED*;jvD0`#o8kOg3x_YMH~5EOH)q`&9(Ksr^Xhw zUGBEm#q_-{rjNMQaOemm=(PvEPM$_imIE6qLTgg2FbcL@g?ihYo35 zCG)9(R<-9S7r%@;*m-->6MmJ?d;UE3tp2 zvMmBuVF*!FLH21~LZZ0xkWk3$wzbW_Nm>9B}d!it!SP zd52>(@^6w>>ICy1%^G_Vay0x=KSRrpn9wZn;6|n3Rno59?!+BzI%0Rd61Agslrd27 z?w}Bl?b|5E27IN7dT?{KR0}KEc8|kS_jrJ+bE^jRtH2KxVoJ zxf4!dO9L2(y7g7a;ZU@W`p&Tk5LwcPOHpSIPCB);?@a`mP_)`z4;N@3Ukd>XTk{Ys z$RQnB*jnne!^NoHJQl@}eD%1rSqs&PV+7kBS%B$xu_*wuw8uUfADL@(#yL`lS4W*m zaM;cf_4x^*wXijFyc{lVVfyPc?RJyfGt(>)bTwORmO9}=a}&bQZs|h*CL5K*IEAr> z-4g0{uHI_4JE2_Y>;(a_*S77jLM^9(nRc5-0-oj?YfT<0sxecnb}TOpcyuImy@n{i zv`aBxuiC=F1!dZ)iI)|p9yG=zX_6GkgsjwxJhkK{9t}+t}{?P1pr#KPl&86vG>mV^CKyA8%CGSQP#H za!R5;VKU}!iAnBpp~;3#Gv_9{XpV6HLwx}It)-}gCbTbneYLZ32vQ5kCN|npsj`G^ z=P1MhoQdQFr>fmc-Bq09f!Cy_BJioGT7yv7 zK~N=hy4h8W;L*)BuI&HMBHrCNn!BaTsbdd8_ z048zP0k5ESaLPEYR&CJZ{w*9yV1yV6!BFA}dpbMZ z0I_vKqJh{rm~-^IgcERP+KE`4i(|he9K{^xWjKgbOYlle6r-y}l`3=}N7P`@lKafk zRv%n6k4|0i9F7XYKo+A`R3cf@IAd`Xj$^Qtk{XR{v4r{%_XH_Pyr(CODO{k_A27@E zQ80u_r@CXT<0aFa)>CCbH|yrC1Md2UI`tt2;qVvIVIMYC7d2)xnbJb zQfIrh8UcE2t01k7*(ExcoDQ66R@s{~J+e7<@$}5SPhzy4U1RLiNIyO26D^D;3V;w# zJQ7Vv3A~y&o}r1FF2M_HG@@~M*9oZ!$qw1u#s+SQ?IaGbNFKym>JmCKq?tw~-b9SR zJg8+aR?8cdT9pvbFb4{qZ#Iv1Tcpznz3p1m=<%gs4Z_JAp39qn&@U(8&9D-V`sf%v zK_{h~npI-Dgf0o1Ck=@qW-J-b)l(sP6!EIPVbr{FaXKSX1Vb9$^av;bVh8wN@?w22 zA)iu2%AFT+aH(34MApt&glhw;L@(ks1@kZgV$tEsZK9!B2E4yp#b%U_ zeirLrQVO_z0-2srrfEiJ@|E?E846UIR;c^oNy7tJl3`FLbT~$ce4b8})7ei;naErw z8;vHNa>ZE(;{bUMicB1Gc03$T-_}~)PC095#%#C*n@sTp4U5_h&C~#AgJ#=vMx$Ol zS(PLsT9ov1r~KK1k@Oc@QE_YYf}|vqf#osM%o5imw{*I4q!E|aQ23AP<$5bC4l&B& z3a|C-5*za$=s?}oBClH6F#DM|X_&3_2`^DdPPkdIdccLIOa^5Z1r~_V4w6MlwmEBe zK`NE8kUvRF(5fvkQVNJuICYl<#CR96O3~Gu)$!EY%3D%wtg}%UU?E9r=*mts3d;8m zMaPq}ASs21zB38(<4!M`PyVh_uT*lS3YIhVC#y~qdyyA+iIbA_FoX$7V`?o!tq8R~ z#Cugn4O1~vhhi=CCa0NMC;pv>lF2ofqr9e;y@`b`m#Q_K)W?^JB>JTiALaTm@j4lA zHOeXHOVdNX&ZQli4je$SkmQ&61hEK8fX&U#!j)6?6FLM>2=_vnly-)78==BQqUgAa zwIhc}@7j)V!`V`eR(-bs~)`9S{qNLkca@q!^ zaP0IMr_Pg3mgIq`z22$N4KWQltB2x4$d0wOr9_Aor5sLNs^JLyM(6O_ffCeG z>8G-f{iO;tvs=ebOlt6R4b<#W%5q*6t5#m_p(FH)4d~dN5UiolkbF0yO-I;?5{)|_ z(A-c7gUnrW&{Sb76F<;^-7fGgyo)-4BdRTE1jK9czpD9o)-X01>pCg{@zxDaFA&L2 zI9-j)C42!>g2Lf4e=U$6S&uAJ(}lqlil&{2%Tvf*@Qod8gC$;JF1|ijGPQV7uy}Ec zN+b$gGDa%Mdm0Hv%lWfAC$iy>A@!=4)wt4*d!brBiWmijC60M+5*zGSU^Te|+aDra z><3nU>e74=r#WYl)(4%i8+2{$bniO;Qg0avHfap$R<9 z>gTCyY56HYFaz0%Ahjgb(kzu`S+_amy-%^zgB5FBx|#D($=E0-1@A0P&k>JQDwP|e zD{3+|9W$>!gSE9Z{bTiX-Wy!%bdnT3mB$B7{gLgWtah%4qfJlsX1kd*jStQM(~>s)2IirNB}{i#e? zmXJJZ=Tte=qlk!UWIIU?sHK@gImHF;ba{p|Vs;fsvv}d>GHtDDvw!t1debg|Mz@nh zMqK%PlbsVa@&`kkG@9?JX1mFLgQ~LXH!wnGuh`2#S$R8!3&6Efr;yQG=00~}C2#2F%?el_ixiyQz`)C^FnvsAU@varkTp|Gg8Ch0EJ zfa-&syP_wVmZ>JkWWi08n^Q|#+YwLdy)Y+~!j2M18qdXtN{8rC6&UjGcDij^&ns`% z**qLNrxo^sMFx&av6kr_UsO5cML!YV#)3?+kXt{wdtN(bh6&KJb~eHicnP7HSl~LF ztLL&jXvSzK+DRk{I8r$$j?tGV>^O5z4XR)I=$ubk=7_y!P8qb%92~~r#+PIbIL@Ro z-|{0U4R63&Qesk1oMGWYFJ)^f|C}r)Xp9L7ORHThfs_i(%E^cn2J*foYG8@MJdp#$ zJqXj@Ul2mpYVHCbknG8A9%toQCclDTuE(@WO zvMhvCG=0?#Gf_QkEoD;k!@O8_21wZvjhvY7E6kK87N!$cMJC(fzFEM14v%3+k<5rD ziFiz(dem|@^werbybzHgC3`%a+07j9Q0|a;8JaK~QQ`!Ae#FTftU#X%=fzngM~9^( zRVng&Vv4fH;3T(%<76|(`KZoRsTJd>zs?YA)?7?yt(0YFrkK>86C{V4yuM|(1J#(O z!?qBb)*H2QDOFvJgQfs)Q!)|HYe^SSyge;d=>Raxk9;0QO8ANtDOtP$;PzqEKsCPy zagJ9~$)0PVK!c4>qM(O7dEZo4Egaw(d&*VGtyhVDX^$4HZMLhOsA#3!XEo!TI=M#J zi?9h%B!`oTWvIWa_2j2Dwj+6o4>7O8SDsNNlW*O#j6r0f^R|!&Ym*!kb4d*RFv)}D ze>I=Y#-_dO6%&VjV>=(QEIeQdVq!Y7ev%17@Aag34%PP%&lrdYOH3rC6r>&WFQqwZ zxLJqqbPZ#tdt`$+q?67Z-R1?AH3@}71AFP7No0RuCjir7LwAx>8tNCOIcf4su9yC2#ZBHx>29nBYNCvVG&}v6?o;~rhRMMgC6B-$zQCNXYM9;MRLtEDa@0o+Ax1T0X?3%{b*_Yk~_Pzr@EH_`3>;$e;(YsI``KSfr*DHb*Ykrxg^P zERWi~$Dz=`(g-;hm#NJs(uJFLTXDfqyj8~+esS%z<+@>aI2I8Ntv9+uR6(h{pjrv| zX@mA5hbmhQw3I6%GQXj$na-i6A40rqN3{|)(7P7a8ADa_{zDyF;t#Fi0q>glO|Vih z6m95tZ8j=sYfsWbzMms4?4DXt7a+jwluVS=Z>&LG2JL&(MYCoZWu*t5&LN3Viui&798+vE-TH4;O^mn@G zWBq5x-@rR+zn_rsx#APO*WfaFruNUkzij*CfRSAFXa0lW93JR%j{grxKhhuSEBzrA zOt&9ACvWXK@bolx@*A}FTe`2#w4eBa;M;Xe|K5gCnXntZz7E%P|DXIvk)&N!om{Id z|8LaxCja1^-s#o!&j<|Kjb7i3EA?;f&pcCR%C42C^ft)$e=5`dip!srI*P``dTe{xfJx!cW`5A*-d-BiekBXDq5d25@_k1{) bool: - if not isinstance(other, CharsetMatch): - if isinstance(other, str): - return iana_name(other) == self.encoding - return False - return self.encoding == other.encoding and self.fingerprint == other.fingerprint - - def __lt__(self, other: object) -> bool: - """ - Implemented to make sorted available upon CharsetMatches items. - """ - if not isinstance(other, CharsetMatch): - raise ValueError - - chaos_difference: float = abs(self.chaos - other.chaos) - coherence_difference: float = abs(self.coherence - other.coherence) - - # Below 1% difference --> Use Coherence - if chaos_difference < 0.01 and coherence_difference > 0.02: - return self.coherence > other.coherence - elif chaos_difference < 0.01 and coherence_difference <= 0.02: - # When having a difficult decision, use the result that decoded as many multi-byte as possible. - # preserve RAM usage! - if len(self._payload) >= TOO_BIG_SEQUENCE: - return self.chaos < other.chaos - return self.multi_byte_usage > other.multi_byte_usage - - return self.chaos < other.chaos - - @property - def multi_byte_usage(self) -> float: - return 1.0 - (len(str(self)) / len(self.raw)) - - 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 f"" - - 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: 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 encoding_languages, mb_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.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 - # list detected ranges - detected_ranges: list[str | None] = [unicode_range(char) for char in str(self)] - # filter and sort - self._unicode_ranges = sorted(list({r for r in detected_ranges if r})) - 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 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 - decoded_string = str(self) - if ( - self._preemptive_declaration is not None - and self._preemptive_declaration.lower() - not in ["utf-8", "utf8", "utf_8"] - ): - patched_header = sub( - RE_POSSIBLE_ENCODING_INDICATION, - lambda m: m.string[m.span()[0] : m.span()[1]].replace( - m.groups()[0], - iana_name(self._output_encoding).replace("_", "-"), # type: ignore[arg-type] - ), - decoded_string[:8192], - count=1, - ) - - decoded_string = patched_header + decoded_string[8192:] - - self._output_payload = decoded_string.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 = None): - self._results: list[CharsetMatch] = sorted(results) if results else [] - - def __iter__(self) -> Iterator[CharsetMatch]: - yield from self._results - - def __getitem__(self, item: int | str) -> 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 __bool__(self) -> bool: - return len(self._results) > 0 - - 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 and match.chaos == item.chaos: - match.add_submatch(item) - return - self._results.append(item) - self._results = sorted(self._results) - - def best(self) -> CharsetMatch | None: - """ - Simply return the first match. Strict equivalent to matches[0]. - """ - if not self._results: - return None - return self._results[0] - - def first(self) -> CharsetMatch | None: - """ - 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 | None, - encoding_aliases: list[str], - alternative_encodings: list[str], - language: str, - alphabets: list[str], - has_sig_or_bom: bool, - chaos: float, - coherence: float, - unicode_path: str | None, - is_preferred: bool, - ): - self.path: str = path - self.unicode_path: str | None = unicode_path - self.encoding: str | None = encoding - self.encoding_aliases: list[str] = encoding_aliases - self.alternative_encodings: list[str] = alternative_encodings - self.language: str = language - self.alphabets: list[str] = alphabets - self.has_sig_or_bom: bool = has_sig_or_bom - self.chaos: float = chaos - self.coherence: float = coherence - self.is_preferred: bool = is_preferred - - @property - def __dict__(self) -> dict[str, Any]: # type: ignore - 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) diff --git a/venv/lib/python3.12/site-packages/charset_normalizer/py.typed b/venv/lib/python3.12/site-packages/charset_normalizer/py.typed deleted file mode 100644 index e69de29..0000000 diff --git a/venv/lib/python3.12/site-packages/charset_normalizer/utils.py b/venv/lib/python3.12/site-packages/charset_normalizer/utils.py deleted file mode 100644 index 6bf0384..0000000 --- a/venv/lib/python3.12/site-packages/charset_normalizer/utils.py +++ /dev/null @@ -1,414 +0,0 @@ -from __future__ import annotations - -import importlib -import logging -import unicodedata -from codecs import IncrementalDecoder -from encodings.aliases import aliases -from functools import lru_cache -from re import findall -from typing import Generator - -from _multibytecodec import ( # type: ignore[import-not-found,import] - MultibyteIncrementalDecoder, -) - -from .constant import ( - ENCODING_MARKS, - IANA_SUPPORTED_SIMILAR, - RE_POSSIBLE_ENCODING_INDICATION, - UNICODE_RANGES_COMBINED, - UNICODE_SECONDARY_RANGE_KEYWORD, - UTF8_MAXIMAL_ALLOCATION, - COMMON_CJK_CHARACTERS, -) - - -@lru_cache(maxsize=UTF8_MAXIMAL_ALLOCATION) -def is_accentuated(character: str) -> bool: - try: - description: str = unicodedata.name(character) - except ValueError: # Defensive: unicode database outdated? - return False - return ( - "WITH GRAVE" in description - or "WITH ACUTE" in description - or "WITH CEDILLA" in description - or "WITH DIAERESIS" in description - or "WITH CIRCUMFLEX" in description - or "WITH TILDE" in description - or "WITH MACRON" in description - or "WITH RING ABOVE" in description - ) - - -@lru_cache(maxsize=UTF8_MAXIMAL_ALLOCATION) -def remove_accent(character: str) -> str: - decomposed: str = unicodedata.decomposition(character) - if not decomposed: - return character - - codes: list[str] = decomposed.split(" ") - - return chr(int(codes[0], 16)) - - -@lru_cache(maxsize=UTF8_MAXIMAL_ALLOCATION) -def unicode_range(character: str) -> str | None: - """ - Retrieve the Unicode range official name from a single character. - """ - character_ord: int = ord(character) - - 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: str = unicodedata.name(character) - except ValueError: # Defensive: unicode database outdated? - return False - return "LATIN" in description - - -@lru_cache(maxsize=UTF8_MAXIMAL_ALLOCATION) -def is_punctuation(character: str) -> bool: - character_category: str = unicodedata.category(character) - - if "P" in character_category: - return True - - character_range: str | None = unicode_range(character) - - 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: str = unicodedata.category(character) - - if "S" in character_category or "N" in character_category: - return True - - character_range: str | None = unicode_range(character) - - if character_range is None: - return False - - return "Forms" in character_range and character_category != "Lo" - - -@lru_cache(maxsize=UTF8_MAXIMAL_ALLOCATION) -def is_emoticon(character: str) -> bool: - character_range: str | None = unicode_range(character) - - if character_range is None: - return False - - return "Emoticons" in character_range or "Pictographs" 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: str = unicodedata.category(character) - - return "Z" in character_category or character_category in {"Po", "Pd", "Pc"} - - -@lru_cache(maxsize=UTF8_MAXIMAL_ALLOCATION) -def is_case_variable(character: str) -> bool: - return character.islower() != character.isupper() - - -@lru_cache(maxsize=UTF8_MAXIMAL_ALLOCATION) -def is_cjk(character: str) -> bool: - try: - character_name = unicodedata.name(character) - except ValueError: # Defensive: unicode database outdated? - return False - - return "CJK" in character_name - - -@lru_cache(maxsize=UTF8_MAXIMAL_ALLOCATION) -def is_hiragana(character: str) -> bool: - try: - character_name = unicodedata.name(character) - except ValueError: # Defensive: unicode database outdated? - return False - - return "HIRAGANA" in character_name - - -@lru_cache(maxsize=UTF8_MAXIMAL_ALLOCATION) -def is_katakana(character: str) -> bool: - try: - character_name = unicodedata.name(character) - except ValueError: # Defensive: unicode database outdated? - return False - - return "KATAKANA" in character_name - - -@lru_cache(maxsize=UTF8_MAXIMAL_ALLOCATION) -def is_hangul(character: str) -> bool: - try: - character_name = unicodedata.name(character) - except ValueError: # Defensive: unicode database outdated? - return False - - return "HANGUL" in character_name - - -@lru_cache(maxsize=UTF8_MAXIMAL_ALLOCATION) -def is_thai(character: str) -> bool: - try: - character_name = unicodedata.name(character) - except ValueError: # Defensive: unicode database outdated? - return False - - return "THAI" in character_name - - -@lru_cache(maxsize=UTF8_MAXIMAL_ALLOCATION) -def is_arabic(character: str) -> bool: - try: - character_name = unicodedata.name(character) - except ValueError: # Defensive: unicode database outdated? - return False - - return "ARABIC" in character_name - - -@lru_cache(maxsize=UTF8_MAXIMAL_ALLOCATION) -def is_arabic_isolated_form(character: str) -> bool: - try: - character_name = unicodedata.name(character) - except ValueError: # Defensive: unicode database outdated? - return False - - return "ARABIC" in character_name and "ISOLATED FORM" in character_name - - -@lru_cache(maxsize=UTF8_MAXIMAL_ALLOCATION) -def is_cjk_uncommon(character: str) -> bool: - return character not in COMMON_CJK_CHARACTERS - - -@lru_cache(maxsize=len(UNICODE_RANGES_COMBINED)) -def is_unicode_range_secondary(range_name: str) -> bool: - return any(keyword in range_name for keyword in UNICODE_SECONDARY_RANGE_KEYWORD) - - -@lru_cache(maxsize=UTF8_MAXIMAL_ALLOCATION) -def is_unprintable(character: str) -> bool: - return ( - character.isspace() is False # includes \n \t \r \v - and character.isprintable() is False - and character != "\x1a" # Why? Its the ASCII substitute character. - and character != "\ufeff" # bug discovered in Python, - # Zero Width No-Break Space located in Arabic Presentation Forms-B, Unicode 1.1 not acknowledged as space. - ) - - -def any_specified_encoding(sequence: bytes, search_zone: int = 8192) -> str | None: - """ - Extract using ASCII-only decoder any specified encoding in the first n-bytes. - """ - if not isinstance(sequence, bytes): - raise TypeError - - seq_len: int = len(sequence) - - results: list[str] = findall( - RE_POSSIBLE_ENCODING_INDICATION, - sequence[: min(seq_len, search_zone)].decode("ascii", errors="ignore"), - ) - - if len(results) == 0: - return None - - for specified_encoding in results: - specified_encoding = specified_encoding.lower().replace("-", "_") - - encoding_alias: str - encoding_iana: str - - 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(f"encodings.{name}").IncrementalDecoder, - MultibyteIncrementalDecoder, - ) - - -def identify_sig_or_bom(sequence: bytes) -> tuple[str | None, bytes]: - """ - Identify and extract SIG/BOM in given sequence. - """ - - for iana_encoding in ENCODING_MARKS: - marks: bytes | list[bytes] = ENCODING_MARKS[iana_encoding] - - 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: - """Returns the Python normalized encoding name (Not the IANA official name).""" - cp_name = cp_name.lower().replace("-", "_") - - encoding_alias: str - encoding_iana: str - - for encoding_alias, encoding_iana in aliases.items(): - if cp_name in [encoding_alias, encoding_iana]: - return encoding_iana - - if strict: - raise ValueError(f"Unable to retrieve IANA for '{cp_name}'") - - return cp_name - - -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.0 - - decoder_a = importlib.import_module(f"encodings.{iana_name_a}").IncrementalDecoder - decoder_b = importlib.import_module(f"encodings.{iana_name_b}").IncrementalDecoder - - id_a: IncrementalDecoder = decoder_a(errors="ignore") - id_b: IncrementalDecoder = decoder_b(errors="ignore") - - character_match_count: int = 0 - - for i in range(255): - to_be_decoded: bytes = bytes([i]) - 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] - ) - - -def set_logging_handler( - name: str = "charset_normalizer", - level: int = logging.INFO, - format_string: str = "%(asctime)s | %(levelname)s | %(message)s", -) -> None: - logger = logging.getLogger(name) - logger.setLevel(level) - - handler = logging.StreamHandler() - handler.setFormatter(logging.Formatter(format_string)) - logger.addHandler(handler) - - -def cut_sequence_chunks( - sequences: bytes, - encoding_iana: str, - offsets: range, - chunk_size: int, - bom_or_sig_available: bool, - strip_sig_or_bom: bool, - sig_payload: bytes, - is_multi_byte_decoder: bool, - decoded_payload: str | None = None, -) -> Generator[str, None, None]: - if decoded_payload and is_multi_byte_decoder is False: - for i in offsets: - chunk = decoded_payload[i : i + chunk_size] - if not chunk: - break - yield chunk - else: - for i in offsets: - chunk_end = i + chunk_size - if chunk_end > len(sequences) + 8: - continue - - 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" if is_multi_byte_decoder else "strict", - ) - - # multi-byte bad cutting detector and adjustment - # not the cleanest way to perform that fix but clever enough for now. - if is_multi_byte_decoder and i > 0: - chunk_partial_size_chk: int = min(chunk_size, 16) - - if ( - decoded_payload - and chunk[:chunk_partial_size_chk] not in decoded_payload - ): - for j in range(i, i - 4, -1): - cut_sequence = sequences[j:chunk_end] - - 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") - - if chunk[:chunk_partial_size_chk] in decoded_payload: - break - - yield chunk diff --git a/venv/lib/python3.12/site-packages/charset_normalizer/version.py b/venv/lib/python3.12/site-packages/charset_normalizer/version.py deleted file mode 100644 index c843e53..0000000 --- a/venv/lib/python3.12/site-packages/charset_normalizer/version.py +++ /dev/null @@ -1,8 +0,0 @@ -""" -Expose version -""" - -from __future__ import annotations - -__version__ = "3.4.4" -VERSION = __version__.split(".") diff --git a/venv/lib/python3.12/site-packages/idna-3.11.dist-info/INSTALLER b/venv/lib/python3.12/site-packages/idna-3.11.dist-info/INSTALLER deleted file mode 100644 index a1b589e..0000000 --- a/venv/lib/python3.12/site-packages/idna-3.11.dist-info/INSTALLER +++ /dev/null @@ -1 +0,0 @@ -pip diff --git a/venv/lib/python3.12/site-packages/idna-3.11.dist-info/METADATA b/venv/lib/python3.12/site-packages/idna-3.11.dist-info/METADATA deleted file mode 100644 index 7a4a4b7..0000000 --- a/venv/lib/python3.12/site-packages/idna-3.11.dist-info/METADATA +++ /dev/null @@ -1,209 +0,0 @@ -Metadata-Version: 2.4 -Name: idna -Version: 3.11 -Summary: Internationalized Domain Names in Applications (IDNA) -Author-email: Kim Davies -Requires-Python: >=3.8 -Description-Content-Type: text/x-rst -License-Expression: BSD-3-Clause -Classifier: Development Status :: 5 - Production/Stable -Classifier: Intended Audience :: Developers -Classifier: Intended Audience :: System Administrators -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.8 -Classifier: Programming Language :: Python :: 3.9 -Classifier: Programming Language :: Python :: 3.10 -Classifier: Programming Language :: Python :: 3.11 -Classifier: Programming Language :: Python :: 3.12 -Classifier: Programming Language :: Python :: 3.13 -Classifier: Programming Language :: Python :: 3.14 -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 -License-File: LICENSE.md -Requires-Dist: ruff >= 0.6.2 ; extra == "all" -Requires-Dist: mypy >= 1.11.2 ; extra == "all" -Requires-Dist: pytest >= 8.3.2 ; extra == "all" -Requires-Dist: flake8 >= 7.1.1 ; extra == "all" -Project-URL: Changelog, https://github.com/kjd/idna/blob/master/HISTORY.rst -Project-URL: Issue tracker, https://github.com/kjd/idna/issues -Project-URL: Source, https://github.com/kjd/idna -Provides-Extra: all - -Internationalized Domain Names in Applications (IDNA) -===================================================== - -Support for `Internationalized Domain Names in -Applications (IDNA) `_ -and `Unicode IDNA Compatibility Processing -`_. - -The latest versions of these standards supplied here provide -more comprehensive language coverage and reduce the potential of -allowing domains with known security vulnerabilities. This library -is a suitable replacement for the “encodings.idna” -module that comes with the Python standard library, but which -only supports an older superseded IDNA specification from 2003. - -Basic functions are simply executed: - -.. code-block:: pycon - - >>> import idna - >>> idna.encode('ドメイン.テスト') - b'xn--eckwd4c7c.xn--zckzah' - >>> print(idna.decode('xn--eckwd4c7c.xn--zckzah')) - ドメイン.テスト - - -Installation ------------- - -This package is available for installation from PyPI via the -typical mechanisms, such as: - -.. code-block:: bash - - $ python3 -m pip install idna - - -Usage ------ - -For typical usage, the ``encode`` and ``decode`` functions will take a -domain name argument and perform a conversion to ASCII compatible encoding -(known as A-labels), or to Unicode strings (known as U-labels) -respectively. - -.. code-block:: pycon - - >>> import idna - >>> idna.encode('ドメイン.テスト') - b'xn--eckwd4c7c.xn--zckzah' - >>> print(idna.decode('xn--eckwd4c7c.xn--zckzah')) - ドメイン.テスト - -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) -+++++++++++++++++++++++++++++++ - -This library provides support for `Unicode IDNA Compatibility -Processing `_ which normalizes input from -different potential ways a user may input a domain prior to performing the IDNA -conversion operations. This functionality, known as a -`mapping `_, is considered by the -specification to be a local user-interface issue distinct from IDNA -conversion functionality. - -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 - - -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 position in the string (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 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 used for IDNA and - UTS 46 conversions. Implementers 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 be used in computing the table data. For -example, ``idna-data --version 9.0.0 make-libdata`` will generate -library data against Unicode 9.0.0. - - -Additional Notes ----------------- - -* **Packages**. The latest tagged release version is published in the - `Python Package Index `_. - -* **Version support**. This library supports Python 3.8 and higher. - As this library serves as a low-level toolkit for a variety of - applications, many of which strive for broad compatibility with older - Python versions, there is no rush to remove older interpreter support. - Support for older versions are likely to be removed from new releases - as automated tests can no longer easily be run, i.e. once the Python - version is officially end-of-life. - -* **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 - `_. - -* **Emoji**. It is an occasional request to support emoji domains in - this library. Encoding of symbols like emoji is expressly prohibited by - the technical standard IDNA 2008 and emoji domains are broadly phased - out across the domain industry due to associated security risks. For - now, applications that need to support these non-compliant labels - may wish to consider trying the encode/decode operation in this library - first, and then falling back to using `encodings.idna`. See `the Github - project `_ for more discussion. - -* **Transitional processing**. Unicode 16.0.0 removed transitional - processing so the `transitional` argument for the encode() method - no longer has any effect and will be removed at a later date. - diff --git a/venv/lib/python3.12/site-packages/idna-3.11.dist-info/RECORD b/venv/lib/python3.12/site-packages/idna-3.11.dist-info/RECORD deleted file mode 100644 index 8525b6d..0000000 --- a/venv/lib/python3.12/site-packages/idna-3.11.dist-info/RECORD +++ /dev/null @@ -1,22 +0,0 @@ -idna-3.11.dist-info/INSTALLER,sha256=zuuue4knoyJ-UwPPXg8fezS7VCrXJQrAP7zeNuwvFQg,4 -idna-3.11.dist-info/METADATA,sha256=fCwSww9SuiN8TIHllFSASUQCW55hAs8dzKnr9RaEEbA,8378 -idna-3.11.dist-info/RECORD,, -idna-3.11.dist-info/WHEEL,sha256=G2gURzTEtmeR8nrdXUJfNiB3VYVxigPQ-bEQujpNiNs,82 -idna-3.11.dist-info/licenses/LICENSE.md,sha256=t6M2q_OwThgOwGXN0W5wXQeeHMehT5EKpukYfza5zYc,1541 -idna/__init__.py,sha256=MPqNDLZbXqGaNdXxAFhiqFPKEQXju2jNQhCey6-5eJM,868 -idna/__pycache__/__init__.cpython-312.pyc,, -idna/__pycache__/codec.cpython-312.pyc,, -idna/__pycache__/compat.cpython-312.pyc,, -idna/__pycache__/core.cpython-312.pyc,, -idna/__pycache__/idnadata.cpython-312.pyc,, -idna/__pycache__/intranges.cpython-312.pyc,, -idna/__pycache__/package_data.cpython-312.pyc,, -idna/__pycache__/uts46data.cpython-312.pyc,, -idna/codec.py,sha256=M2SGWN7cs_6B32QmKTyTN6xQGZeYQgQ2wiX3_DR6loE,3438 -idna/compat.py,sha256=RzLy6QQCdl9784aFhb2EX9EKGCJjg0P3PilGdeXXcx8,316 -idna/core.py,sha256=P26_XVycuMTZ1R2mNK1ZREVzM5mvTzdabBXfyZVU1Lc,13246 -idna/idnadata.py,sha256=SG8jhaGE53iiD6B49pt2pwTv_UvClciWE-N54oR2p4U,79623 -idna/intranges.py,sha256=amUtkdhYcQG8Zr-CoMM_kVRacxkivC1WgxN1b63KKdU,1898 -idna/package_data.py,sha256=_CUavOxobnbyNG2FLyHoN8QHP3QM9W1tKuw7eq9QwBk,21 -idna/py.typed,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -idna/uts46data.py,sha256=H9J35VkD0F9L9mKOqjeNGd2A-Va6FlPoz6Jz4K7h-ps,243725 diff --git a/venv/lib/python3.12/site-packages/idna-3.11.dist-info/WHEEL b/venv/lib/python3.12/site-packages/idna-3.11.dist-info/WHEEL deleted file mode 100644 index d8b9936..0000000 --- a/venv/lib/python3.12/site-packages/idna-3.11.dist-info/WHEEL +++ /dev/null @@ -1,4 +0,0 @@ -Wheel-Version: 1.0 -Generator: flit 3.12.0 -Root-Is-Purelib: true -Tag: py3-none-any diff --git a/venv/lib/python3.12/site-packages/idna-3.11.dist-info/licenses/LICENSE.md b/venv/lib/python3.12/site-packages/idna-3.11.dist-info/licenses/LICENSE.md deleted file mode 100644 index 256ba90..0000000 --- a/venv/lib/python3.12/site-packages/idna-3.11.dist-info/licenses/LICENSE.md +++ /dev/null @@ -1,31 +0,0 @@ -BSD 3-Clause License - -Copyright (c) 2013-2025, Kim Davies and contributors. -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.12/site-packages/idna/__init__.py b/venv/lib/python3.12/site-packages/idna/__init__.py deleted file mode 100644 index cfdc030..0000000 --- a/venv/lib/python3.12/site-packages/idna/__init__.py +++ /dev/null @@ -1,45 +0,0 @@ -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 -from .package_data import __version__ - -__all__ = [ - "__version__", - "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.12/site-packages/idna/__pycache__/__init__.cpython-312.pyc b/venv/lib/python3.12/site-packages/idna/__pycache__/__init__.cpython-312.pyc deleted file mode 100644 index b8a3b045309c8b18bea4da774cd39840be2bd4e3..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 885 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 K0;V6g;C})5B^JH_ diff --git a/venv/lib/python3.12/site-packages/idna/__pycache__/compat.cpython-312.pyc b/venv/lib/python3.12/site-packages/idna/__pycache__/compat.cpython-312.pyc deleted file mode 100644 index e6c4eefa470e11f0379705479bb5b521f8a32dd9..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 889 zcmb7CziSjh6rR~%_bV}Kh$Kj48;ivx8xsN+Q8*Hd1G6YeK&}urH#0IbM+P*P| z=aF%csUTBlRZf}BYKZHI8+pxZoa1YGT$J99!#y4s z4sg{4(b2oc!^A+((JY!%qOQ5uZm1y+lci;!<05RHA}PL-|{g!mhLU}jNo{owHY+smF49}E|WZSg;Z`=MRAmI zSA+>qfv0W?Qpt{tJz7i$Qniva<_Q;yv!?(Ou;ghh;_qs!mN7FI_Bztlm$Y++^!3VSbCJS$Z%YB~-9!n{UJK}%^}F9q> diff --git a/venv/lib/python3.12/site-packages/idna/__pycache__/core.cpython-312.pyc b/venv/lib/python3.12/site-packages/idna/__pycache__/core.cpython-312.pyc deleted file mode 100644 index abbace125041f7817d1d91b96906e822b67fe0a8..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 16197 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 MgBRWI6b~N!e~xIKlmGw# diff --git a/venv/lib/python3.12/site-packages/idna/__pycache__/intranges.cpython-312.pyc b/venv/lib/python3.12/site-packages/idna/__pycache__/intranges.cpython-312.pyc deleted file mode 100644 index edbf8ccb959c03693d11b6af2ede4ac82ed5542a..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2637 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 X*}Kwh&Fs$wuFE<)-MyH7Q2qY^{C+kE diff --git a/venv/lib/python3.12/site-packages/idna/codec.py b/venv/lib/python3.12/site-packages/idna/codec.py deleted file mode 100644 index cbc2e4f..0000000 --- a/venv/lib/python3.12/site-packages/idna/codec.py +++ /dev/null @@ -1,122 +0,0 @@ -import codecs -import re -from typing import Any, Optional, Tuple - -from .core import IDNAError, alabel, decode, encode, ulabel - -_unicode_dots_re = re.compile("[\u002e\u3002\uff0e\uff61]") - - -class Codec(codecs.Codec): - def encode(self, data: str, errors: str = "strict") -> Tuple[bytes, int]: - if errors != "strict": - raise IDNAError('Unsupported error handling "{}"'.format(errors)) - - if not data: - return b"", 0 - - return encode(data), len(data) - - def decode(self, data: bytes, errors: str = "strict") -> 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: str, errors: str, final: bool) -> Tuple[bytes, int]: - if errors != "strict": - raise IDNAError('Unsupported error handling "{}"'.format(errors)) - - if not data: - return b"", 0 - - labels = _unicode_dots_re.split(data) - trailing_dot = b"" - if labels: - if not labels[-1]: - trailing_dot = b"." - del labels[-1] - elif not final: - # Keep potentially unfinished label until the next call - del labels[-1] - if labels: - trailing_dot = b"." - - result = [] - size = 0 - for label in labels: - result.append(alabel(label)) - if size: - size += 1 - size += len(label) - - # Join with U+002E - result_bytes = b".".join(result) + trailing_dot - size += len(trailing_dot) - return result_bytes, size - - -class IncrementalDecoder(codecs.BufferedIncrementalDecoder): - def _buffer_decode(self, data: Any, errors: str, final: bool) -> Tuple[str, int]: - if errors != "strict": - raise IDNAError('Unsupported error handling "{}"'.format(errors)) - - if not data: - return ("", 0) - - if not isinstance(data, str): - data = str(data, "ascii") - - 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 search_function(name: str) -> Optional[codecs.CodecInfo]: - if name != "idna2008": - return None - return codecs.CodecInfo( - name=name, - encode=Codec().encode, - decode=Codec().decode, # type: ignore - incrementalencoder=IncrementalEncoder, - incrementaldecoder=IncrementalDecoder, - streamwriter=StreamWriter, - streamreader=StreamReader, - ) - - -codecs.register(search_function) diff --git a/venv/lib/python3.12/site-packages/idna/compat.py b/venv/lib/python3.12/site-packages/idna/compat.py deleted file mode 100644 index 1df9f2a..0000000 --- a/venv/lib/python3.12/site-packages/idna/compat.py +++ /dev/null @@ -1,15 +0,0 @@ -from typing import Any, Union - -from .core import decode, encode - - -def ToASCII(label: str) -> bytes: - return encode(label) - - -def ToUnicode(label: Union[bytes, bytearray]) -> str: - return decode(label) - - -def nameprep(s: Any) -> None: - raise NotImplementedError("IDNA 2008 does not utilise nameprep protocol") diff --git a/venv/lib/python3.12/site-packages/idna/core.py b/venv/lib/python3.12/site-packages/idna/core.py deleted file mode 100644 index 8177bf7..0000000 --- a/venv/lib/python3.12/site-packages/idna/core.py +++ /dev/null @@ -1,437 +0,0 @@ -import bisect -import re -import unicodedata -from typing import Optional, Union - -from . import idnadata -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: 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: str, script: str) -> bool: - return intranges_contain(ord(cp), idnadata.scripts[script]) - - -def _punycode(s: str) -> bytes: - return s.encode("punycode") - - -def _unot(s: int) -> str: - return "U+{:04X}".format(s) - - -def valid_label_length(label: Union[bytes, str]) -> bool: - if len(label) > 63: - return False - return True - - -def valid_string_length(label: Union[bytes, str], trailing_dot: bool) -> bool: - if len(label) > (254 if trailing_dot else 253): - return False - return True - - -def check_bidi(label: str, check_ltr: bool = False) -> bool: - # Bidi rules should only be applied if string contains RTL characters - bidi_label = False - for idx, cp in enumerate(label, 1): - 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: Optional[str] = None - for idx, cp in enumerate(label, 1): - direction = unicodedata.bidirectional(cp) - - if rtl: - # Bidi rule 2 - if direction not 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 direction not 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: 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: 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: str) -> None: - if unicodedata.normalize("NFC", label) != label: - raise IDNAError("Label must be in Normalization Form C") - - -def valid_contextj(label: str, pos: 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 - elif joining_type in [ord("L"), ord("D")]: - ok = True - break - else: - 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 - elif joining_type in [ord("R"), ord("D")]: - ok = True - break - else: - 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: str, pos: int, exception: bool = False) -> 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: 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: 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 - - check_label(label) - label_bytes = _alabel_prefix + _punycode(label) - - if not valid_label_length(label_bytes): - raise IDNAError("Label too long") - - return label_bytes - - -def ulabel(label: 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 = 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") - - try: - label = label_bytes.decode("punycode") - except UnicodeError: - raise IDNAError("Invalid A-label") - check_label(label) - return label - - -def uts46_remap(domain: str, std3_rules: bool = True, transitional: bool = False) -> str: - """Re-map the characters in the string according to UTS46 processing.""" - from .uts46data import uts46data - - output = "" - - 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: Optional[str] = None - if len(uts46row) == 3: - replacement = uts46row[2] - 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: Union[str, bytes, bytearray], - strict: bool = False, - uts46: bool = False, - std3_rules: bool = False, - transitional: bool = False, -) -> bytes: - if not isinstance(s, str): - try: - s = str(s, "ascii") - except UnicodeDecodeError: - raise IDNAError("should pass a unicode string to the function rather than a byte string.") - if uts46: - s = uts46_remap(s, std3_rules, transitional) - trailing_dot = False - 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: Union[str, bytes, bytearray], - strict: bool = False, - uts46: bool = False, - std3_rules: bool = False, -) -> str: - try: - if not isinstance(s, str): - s = str(s, "ascii") - except UnicodeDecodeError: - raise IDNAError("Invalid ASCII in A-label") - 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.12/site-packages/idna/idnadata.py b/venv/lib/python3.12/site-packages/idna/idnadata.py deleted file mode 100644 index ded47ca..0000000 --- a/venv/lib/python3.12/site-packages/idna/idnadata.py +++ /dev/null @@ -1,4309 +0,0 @@ -# This file is automatically generated by tools/idna-data - -__version__ = "16.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, - 0x4E000000A000, - 0xF9000000FA6E, - 0xFA700000FADA, - 0x16FE200016FE4, - 0x16FF000016FF2, - 0x200000002A6E0, - 0x2A7000002B73A, - 0x2B7400002B81E, - 0x2B8200002CEA2, - 0x2CEB00002EBE1, - 0x2EBF00002EE5E, - 0x2F8000002FA1E, - 0x300000003134B, - 0x31350000323B0, - ), - "Hebrew": ( - 0x591000005C8, - 0x5D0000005EB, - 0x5EF000005F5, - 0xFB1D0000FB37, - 0xFB380000FB3D, - 0xFB3E0000FB3F, - 0xFB400000FB42, - 0xFB430000FB45, - 0xFB460000FB50, - ), - "Hiragana": ( - 0x304100003097, - 0x309D000030A0, - 0x1B0010001B120, - 0x1B1320001B133, - 0x1B1500001B153, - 0x1F2000001F201, - ), - "Katakana": ( - 0x30A1000030FB, - 0x30FD00003100, - 0x31F000003200, - 0x32D0000032FF, - 0x330000003358, - 0xFF660000FF70, - 0xFF710000FF9E, - 0x1AFF00001AFF4, - 0x1AFF50001AFFC, - 0x1AFFD0001AFFF, - 0x1B0000001B001, - 0x1B1200001B123, - 0x1B1550001B156, - 0x1B1640001B168, - ), -} -joining_types = { - 0xAD: 84, - 0x300: 84, - 0x301: 84, - 0x302: 84, - 0x303: 84, - 0x304: 84, - 0x305: 84, - 0x306: 84, - 0x307: 84, - 0x308: 84, - 0x309: 84, - 0x30A: 84, - 0x30B: 84, - 0x30C: 84, - 0x30D: 84, - 0x30E: 84, - 0x30F: 84, - 0x310: 84, - 0x311: 84, - 0x312: 84, - 0x313: 84, - 0x314: 84, - 0x315: 84, - 0x316: 84, - 0x317: 84, - 0x318: 84, - 0x319: 84, - 0x31A: 84, - 0x31B: 84, - 0x31C: 84, - 0x31D: 84, - 0x31E: 84, - 0x31F: 84, - 0x320: 84, - 0x321: 84, - 0x322: 84, - 0x323: 84, - 0x324: 84, - 0x325: 84, - 0x326: 84, - 0x327: 84, - 0x328: 84, - 0x329: 84, - 0x32A: 84, - 0x32B: 84, - 0x32C: 84, - 0x32D: 84, - 0x32E: 84, - 0x32F: 84, - 0x330: 84, - 0x331: 84, - 0x332: 84, - 0x333: 84, - 0x334: 84, - 0x335: 84, - 0x336: 84, - 0x337: 84, - 0x338: 84, - 0x339: 84, - 0x33A: 84, - 0x33B: 84, - 0x33C: 84, - 0x33D: 84, - 0x33E: 84, - 0x33F: 84, - 0x340: 84, - 0x341: 84, - 0x342: 84, - 0x343: 84, - 0x344: 84, - 0x345: 84, - 0x346: 84, - 0x347: 84, - 0x348: 84, - 0x349: 84, - 0x34A: 84, - 0x34B: 84, - 0x34C: 84, - 0x34D: 84, - 0x34E: 84, - 0x34F: 84, - 0x350: 84, - 0x351: 84, - 0x352: 84, - 0x353: 84, - 0x354: 84, - 0x355: 84, - 0x356: 84, - 0x357: 84, - 0x358: 84, - 0x359: 84, - 0x35A: 84, - 0x35B: 84, - 0x35C: 84, - 0x35D: 84, - 0x35E: 84, - 0x35F: 84, - 0x360: 84, - 0x361: 84, - 0x362: 84, - 0x363: 84, - 0x364: 84, - 0x365: 84, - 0x366: 84, - 0x367: 84, - 0x368: 84, - 0x369: 84, - 0x36A: 84, - 0x36B: 84, - 0x36C: 84, - 0x36D: 84, - 0x36E: 84, - 0x36F: 84, - 0x483: 84, - 0x484: 84, - 0x485: 84, - 0x486: 84, - 0x487: 84, - 0x488: 84, - 0x489: 84, - 0x591: 84, - 0x592: 84, - 0x593: 84, - 0x594: 84, - 0x595: 84, - 0x596: 84, - 0x597: 84, - 0x598: 84, - 0x599: 84, - 0x59A: 84, - 0x59B: 84, - 0x59C: 84, - 0x59D: 84, - 0x59E: 84, - 0x59F: 84, - 0x5A0: 84, - 0x5A1: 84, - 0x5A2: 84, - 0x5A3: 84, - 0x5A4: 84, - 0x5A5: 84, - 0x5A6: 84, - 0x5A7: 84, - 0x5A8: 84, - 0x5A9: 84, - 0x5AA: 84, - 0x5AB: 84, - 0x5AC: 84, - 0x5AD: 84, - 0x5AE: 84, - 0x5AF: 84, - 0x5B0: 84, - 0x5B1: 84, - 0x5B2: 84, - 0x5B3: 84, - 0x5B4: 84, - 0x5B5: 84, - 0x5B6: 84, - 0x5B7: 84, - 0x5B8: 84, - 0x5B9: 84, - 0x5BA: 84, - 0x5BB: 84, - 0x5BC: 84, - 0x5BD: 84, - 0x5BF: 84, - 0x5C1: 84, - 0x5C2: 84, - 0x5C4: 84, - 0x5C5: 84, - 0x5C7: 84, - 0x610: 84, - 0x611: 84, - 0x612: 84, - 0x613: 84, - 0x614: 84, - 0x615: 84, - 0x616: 84, - 0x617: 84, - 0x618: 84, - 0x619: 84, - 0x61A: 84, - 0x61C: 84, - 0x620: 68, - 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, - 0x64B: 84, - 0x64C: 84, - 0x64D: 84, - 0x64E: 84, - 0x64F: 84, - 0x650: 84, - 0x651: 84, - 0x652: 84, - 0x653: 84, - 0x654: 84, - 0x655: 84, - 0x656: 84, - 0x657: 84, - 0x658: 84, - 0x659: 84, - 0x65A: 84, - 0x65B: 84, - 0x65C: 84, - 0x65D: 84, - 0x65E: 84, - 0x65F: 84, - 0x66E: 68, - 0x66F: 68, - 0x670: 84, - 0x671: 82, - 0x672: 82, - 0x673: 82, - 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, - 0x6D6: 84, - 0x6D7: 84, - 0x6D8: 84, - 0x6D9: 84, - 0x6DA: 84, - 0x6DB: 84, - 0x6DC: 84, - 0x6DF: 84, - 0x6E0: 84, - 0x6E1: 84, - 0x6E2: 84, - 0x6E3: 84, - 0x6E4: 84, - 0x6E7: 84, - 0x6E8: 84, - 0x6EA: 84, - 0x6EB: 84, - 0x6EC: 84, - 0x6ED: 84, - 0x6EE: 82, - 0x6EF: 82, - 0x6FA: 68, - 0x6FB: 68, - 0x6FC: 68, - 0x6FF: 68, - 0x70F: 84, - 0x710: 82, - 0x711: 84, - 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, - 0x730: 84, - 0x731: 84, - 0x732: 84, - 0x733: 84, - 0x734: 84, - 0x735: 84, - 0x736: 84, - 0x737: 84, - 0x738: 84, - 0x739: 84, - 0x73A: 84, - 0x73B: 84, - 0x73C: 84, - 0x73D: 84, - 0x73E: 84, - 0x73F: 84, - 0x740: 84, - 0x741: 84, - 0x742: 84, - 0x743: 84, - 0x744: 84, - 0x745: 84, - 0x746: 84, - 0x747: 84, - 0x748: 84, - 0x749: 84, - 0x74A: 84, - 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, - 0x7A6: 84, - 0x7A7: 84, - 0x7A8: 84, - 0x7A9: 84, - 0x7AA: 84, - 0x7AB: 84, - 0x7AC: 84, - 0x7AD: 84, - 0x7AE: 84, - 0x7AF: 84, - 0x7B0: 84, - 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, - 0x7EB: 84, - 0x7EC: 84, - 0x7ED: 84, - 0x7EE: 84, - 0x7EF: 84, - 0x7F0: 84, - 0x7F1: 84, - 0x7F2: 84, - 0x7F3: 84, - 0x7FA: 67, - 0x7FD: 84, - 0x816: 84, - 0x817: 84, - 0x818: 84, - 0x819: 84, - 0x81B: 84, - 0x81C: 84, - 0x81D: 84, - 0x81E: 84, - 0x81F: 84, - 0x820: 84, - 0x821: 84, - 0x822: 84, - 0x823: 84, - 0x825: 84, - 0x826: 84, - 0x827: 84, - 0x829: 84, - 0x82A: 84, - 0x82B: 84, - 0x82C: 84, - 0x82D: 84, - 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, - 0x859: 84, - 0x85A: 84, - 0x85B: 84, - 0x860: 68, - 0x862: 68, - 0x863: 68, - 0x864: 68, - 0x865: 68, - 0x867: 82, - 0x868: 68, - 0x869: 82, - 0x86A: 82, - 0x870: 82, - 0x871: 82, - 0x872: 82, - 0x873: 82, - 0x874: 82, - 0x875: 82, - 0x876: 82, - 0x877: 82, - 0x878: 82, - 0x879: 82, - 0x87A: 82, - 0x87B: 82, - 0x87C: 82, - 0x87D: 82, - 0x87E: 82, - 0x87F: 82, - 0x880: 82, - 0x881: 82, - 0x882: 82, - 0x883: 67, - 0x884: 67, - 0x885: 67, - 0x886: 68, - 0x889: 68, - 0x88A: 68, - 0x88B: 68, - 0x88C: 68, - 0x88D: 68, - 0x88E: 82, - 0x897: 84, - 0x898: 84, - 0x899: 84, - 0x89A: 84, - 0x89B: 84, - 0x89C: 84, - 0x89D: 84, - 0x89E: 84, - 0x89F: 84, - 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, - 0x8AE: 82, - 0x8AF: 68, - 0x8B0: 68, - 0x8B1: 82, - 0x8B2: 82, - 0x8B3: 68, - 0x8B4: 68, - 0x8B5: 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, - 0x8C8: 68, - 0x8CA: 84, - 0x8CB: 84, - 0x8CC: 84, - 0x8CD: 84, - 0x8CE: 84, - 0x8CF: 84, - 0x8D0: 84, - 0x8D1: 84, - 0x8D2: 84, - 0x8D3: 84, - 0x8D4: 84, - 0x8D5: 84, - 0x8D6: 84, - 0x8D7: 84, - 0x8D8: 84, - 0x8D9: 84, - 0x8DA: 84, - 0x8DB: 84, - 0x8DC: 84, - 0x8DD: 84, - 0x8DE: 84, - 0x8DF: 84, - 0x8E0: 84, - 0x8E1: 84, - 0x8E3: 84, - 0x8E4: 84, - 0x8E5: 84, - 0x8E6: 84, - 0x8E7: 84, - 0x8E8: 84, - 0x8E9: 84, - 0x8EA: 84, - 0x8EB: 84, - 0x8EC: 84, - 0x8ED: 84, - 0x8EE: 84, - 0x8EF: 84, - 0x8F0: 84, - 0x8F1: 84, - 0x8F2: 84, - 0x8F3: 84, - 0x8F4: 84, - 0x8F5: 84, - 0x8F6: 84, - 0x8F7: 84, - 0x8F8: 84, - 0x8F9: 84, - 0x8FA: 84, - 0x8FB: 84, - 0x8FC: 84, - 0x8FD: 84, - 0x8FE: 84, - 0x8FF: 84, - 0x900: 84, - 0x901: 84, - 0x902: 84, - 0x93A: 84, - 0x93C: 84, - 0x941: 84, - 0x942: 84, - 0x943: 84, - 0x944: 84, - 0x945: 84, - 0x946: 84, - 0x947: 84, - 0x948: 84, - 0x94D: 84, - 0x951: 84, - 0x952: 84, - 0x953: 84, - 0x954: 84, - 0x955: 84, - 0x956: 84, - 0x957: 84, - 0x962: 84, - 0x963: 84, - 0x981: 84, - 0x9BC: 84, - 0x9C1: 84, - 0x9C2: 84, - 0x9C3: 84, - 0x9C4: 84, - 0x9CD: 84, - 0x9E2: 84, - 0x9E3: 84, - 0x9FE: 84, - 0xA01: 84, - 0xA02: 84, - 0xA3C: 84, - 0xA41: 84, - 0xA42: 84, - 0xA47: 84, - 0xA48: 84, - 0xA4B: 84, - 0xA4C: 84, - 0xA4D: 84, - 0xA51: 84, - 0xA70: 84, - 0xA71: 84, - 0xA75: 84, - 0xA81: 84, - 0xA82: 84, - 0xABC: 84, - 0xAC1: 84, - 0xAC2: 84, - 0xAC3: 84, - 0xAC4: 84, - 0xAC5: 84, - 0xAC7: 84, - 0xAC8: 84, - 0xACD: 84, - 0xAE2: 84, - 0xAE3: 84, - 0xAFA: 84, - 0xAFB: 84, - 0xAFC: 84, - 0xAFD: 84, - 0xAFE: 84, - 0xAFF: 84, - 0xB01: 84, - 0xB3C: 84, - 0xB3F: 84, - 0xB41: 84, - 0xB42: 84, - 0xB43: 84, - 0xB44: 84, - 0xB4D: 84, - 0xB55: 84, - 0xB56: 84, - 0xB62: 84, - 0xB63: 84, - 0xB82: 84, - 0xBC0: 84, - 0xBCD: 84, - 0xC00: 84, - 0xC04: 84, - 0xC3C: 84, - 0xC3E: 84, - 0xC3F: 84, - 0xC40: 84, - 0xC46: 84, - 0xC47: 84, - 0xC48: 84, - 0xC4A: 84, - 0xC4B: 84, - 0xC4C: 84, - 0xC4D: 84, - 0xC55: 84, - 0xC56: 84, - 0xC62: 84, - 0xC63: 84, - 0xC81: 84, - 0xCBC: 84, - 0xCBF: 84, - 0xCC6: 84, - 0xCCC: 84, - 0xCCD: 84, - 0xCE2: 84, - 0xCE3: 84, - 0xD00: 84, - 0xD01: 84, - 0xD3B: 84, - 0xD3C: 84, - 0xD41: 84, - 0xD42: 84, - 0xD43: 84, - 0xD44: 84, - 0xD4D: 84, - 0xD62: 84, - 0xD63: 84, - 0xD81: 84, - 0xDCA: 84, - 0xDD2: 84, - 0xDD3: 84, - 0xDD4: 84, - 0xDD6: 84, - 0xE31: 84, - 0xE34: 84, - 0xE35: 84, - 0xE36: 84, - 0xE37: 84, - 0xE38: 84, - 0xE39: 84, - 0xE3A: 84, - 0xE47: 84, - 0xE48: 84, - 0xE49: 84, - 0xE4A: 84, - 0xE4B: 84, - 0xE4C: 84, - 0xE4D: 84, - 0xE4E: 84, - 0xEB1: 84, - 0xEB4: 84, - 0xEB5: 84, - 0xEB6: 84, - 0xEB7: 84, - 0xEB8: 84, - 0xEB9: 84, - 0xEBA: 84, - 0xEBB: 84, - 0xEBC: 84, - 0xEC8: 84, - 0xEC9: 84, - 0xECA: 84, - 0xECB: 84, - 0xECC: 84, - 0xECD: 84, - 0xECE: 84, - 0xF18: 84, - 0xF19: 84, - 0xF35: 84, - 0xF37: 84, - 0xF39: 84, - 0xF71: 84, - 0xF72: 84, - 0xF73: 84, - 0xF74: 84, - 0xF75: 84, - 0xF76: 84, - 0xF77: 84, - 0xF78: 84, - 0xF79: 84, - 0xF7A: 84, - 0xF7B: 84, - 0xF7C: 84, - 0xF7D: 84, - 0xF7E: 84, - 0xF80: 84, - 0xF81: 84, - 0xF82: 84, - 0xF83: 84, - 0xF84: 84, - 0xF86: 84, - 0xF87: 84, - 0xF8D: 84, - 0xF8E: 84, - 0xF8F: 84, - 0xF90: 84, - 0xF91: 84, - 0xF92: 84, - 0xF93: 84, - 0xF94: 84, - 0xF95: 84, - 0xF96: 84, - 0xF97: 84, - 0xF99: 84, - 0xF9A: 84, - 0xF9B: 84, - 0xF9C: 84, - 0xF9D: 84, - 0xF9E: 84, - 0xF9F: 84, - 0xFA0: 84, - 0xFA1: 84, - 0xFA2: 84, - 0xFA3: 84, - 0xFA4: 84, - 0xFA5: 84, - 0xFA6: 84, - 0xFA7: 84, - 0xFA8: 84, - 0xFA9: 84, - 0xFAA: 84, - 0xFAB: 84, - 0xFAC: 84, - 0xFAD: 84, - 0xFAE: 84, - 0xFAF: 84, - 0xFB0: 84, - 0xFB1: 84, - 0xFB2: 84, - 0xFB3: 84, - 0xFB4: 84, - 0xFB5: 84, - 0xFB6: 84, - 0xFB7: 84, - 0xFB8: 84, - 0xFB9: 84, - 0xFBA: 84, - 0xFBB: 84, - 0xFBC: 84, - 0xFC6: 84, - 0x102D: 84, - 0x102E: 84, - 0x102F: 84, - 0x1030: 84, - 0x1032: 84, - 0x1033: 84, - 0x1034: 84, - 0x1035: 84, - 0x1036: 84, - 0x1037: 84, - 0x1039: 84, - 0x103A: 84, - 0x103D: 84, - 0x103E: 84, - 0x1058: 84, - 0x1059: 84, - 0x105E: 84, - 0x105F: 84, - 0x1060: 84, - 0x1071: 84, - 0x1072: 84, - 0x1073: 84, - 0x1074: 84, - 0x1082: 84, - 0x1085: 84, - 0x1086: 84, - 0x108D: 84, - 0x109D: 84, - 0x135D: 84, - 0x135E: 84, - 0x135F: 84, - 0x1712: 84, - 0x1713: 84, - 0x1714: 84, - 0x1732: 84, - 0x1733: 84, - 0x1752: 84, - 0x1753: 84, - 0x1772: 84, - 0x1773: 84, - 0x17B4: 84, - 0x17B5: 84, - 0x17B7: 84, - 0x17B8: 84, - 0x17B9: 84, - 0x17BA: 84, - 0x17BB: 84, - 0x17BC: 84, - 0x17BD: 84, - 0x17C6: 84, - 0x17C9: 84, - 0x17CA: 84, - 0x17CB: 84, - 0x17CC: 84, - 0x17CD: 84, - 0x17CE: 84, - 0x17CF: 84, - 0x17D0: 84, - 0x17D1: 84, - 0x17D2: 84, - 0x17D3: 84, - 0x17DD: 84, - 0x1807: 68, - 0x180A: 67, - 0x180B: 84, - 0x180C: 84, - 0x180D: 84, - 0x180F: 84, - 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, - 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, - 0x18A9: 84, - 0x18AA: 68, - 0x1920: 84, - 0x1921: 84, - 0x1922: 84, - 0x1927: 84, - 0x1928: 84, - 0x1932: 84, - 0x1939: 84, - 0x193A: 84, - 0x193B: 84, - 0x1A17: 84, - 0x1A18: 84, - 0x1A1B: 84, - 0x1A56: 84, - 0x1A58: 84, - 0x1A59: 84, - 0x1A5A: 84, - 0x1A5B: 84, - 0x1A5C: 84, - 0x1A5D: 84, - 0x1A5E: 84, - 0x1A60: 84, - 0x1A62: 84, - 0x1A65: 84, - 0x1A66: 84, - 0x1A67: 84, - 0x1A68: 84, - 0x1A69: 84, - 0x1A6A: 84, - 0x1A6B: 84, - 0x1A6C: 84, - 0x1A73: 84, - 0x1A74: 84, - 0x1A75: 84, - 0x1A76: 84, - 0x1A77: 84, - 0x1A78: 84, - 0x1A79: 84, - 0x1A7A: 84, - 0x1A7B: 84, - 0x1A7C: 84, - 0x1A7F: 84, - 0x1AB0: 84, - 0x1AB1: 84, - 0x1AB2: 84, - 0x1AB3: 84, - 0x1AB4: 84, - 0x1AB5: 84, - 0x1AB6: 84, - 0x1AB7: 84, - 0x1AB8: 84, - 0x1AB9: 84, - 0x1ABA: 84, - 0x1ABB: 84, - 0x1ABC: 84, - 0x1ABD: 84, - 0x1ABE: 84, - 0x1ABF: 84, - 0x1AC0: 84, - 0x1AC1: 84, - 0x1AC2: 84, - 0x1AC3: 84, - 0x1AC4: 84, - 0x1AC5: 84, - 0x1AC6: 84, - 0x1AC7: 84, - 0x1AC8: 84, - 0x1AC9: 84, - 0x1ACA: 84, - 0x1ACB: 84, - 0x1ACC: 84, - 0x1ACD: 84, - 0x1ACE: 84, - 0x1B00: 84, - 0x1B01: 84, - 0x1B02: 84, - 0x1B03: 84, - 0x1B34: 84, - 0x1B36: 84, - 0x1B37: 84, - 0x1B38: 84, - 0x1B39: 84, - 0x1B3A: 84, - 0x1B3C: 84, - 0x1B42: 84, - 0x1B6B: 84, - 0x1B6C: 84, - 0x1B6D: 84, - 0x1B6E: 84, - 0x1B6F: 84, - 0x1B70: 84, - 0x1B71: 84, - 0x1B72: 84, - 0x1B73: 84, - 0x1B80: 84, - 0x1B81: 84, - 0x1BA2: 84, - 0x1BA3: 84, - 0x1BA4: 84, - 0x1BA5: 84, - 0x1BA8: 84, - 0x1BA9: 84, - 0x1BAB: 84, - 0x1BAC: 84, - 0x1BAD: 84, - 0x1BE6: 84, - 0x1BE8: 84, - 0x1BE9: 84, - 0x1BED: 84, - 0x1BEF: 84, - 0x1BF0: 84, - 0x1BF1: 84, - 0x1C2C: 84, - 0x1C2D: 84, - 0x1C2E: 84, - 0x1C2F: 84, - 0x1C30: 84, - 0x1C31: 84, - 0x1C32: 84, - 0x1C33: 84, - 0x1C36: 84, - 0x1C37: 84, - 0x1CD0: 84, - 0x1CD1: 84, - 0x1CD2: 84, - 0x1CD4: 84, - 0x1CD5: 84, - 0x1CD6: 84, - 0x1CD7: 84, - 0x1CD8: 84, - 0x1CD9: 84, - 0x1CDA: 84, - 0x1CDB: 84, - 0x1CDC: 84, - 0x1CDD: 84, - 0x1CDE: 84, - 0x1CDF: 84, - 0x1CE0: 84, - 0x1CE2: 84, - 0x1CE3: 84, - 0x1CE4: 84, - 0x1CE5: 84, - 0x1CE6: 84, - 0x1CE7: 84, - 0x1CE8: 84, - 0x1CED: 84, - 0x1CF4: 84, - 0x1CF8: 84, - 0x1CF9: 84, - 0x1DC0: 84, - 0x1DC1: 84, - 0x1DC2: 84, - 0x1DC3: 84, - 0x1DC4: 84, - 0x1DC5: 84, - 0x1DC6: 84, - 0x1DC7: 84, - 0x1DC8: 84, - 0x1DC9: 84, - 0x1DCA: 84, - 0x1DCB: 84, - 0x1DCC: 84, - 0x1DCD: 84, - 0x1DCE: 84, - 0x1DCF: 84, - 0x1DD0: 84, - 0x1DD1: 84, - 0x1DD2: 84, - 0x1DD3: 84, - 0x1DD4: 84, - 0x1DD5: 84, - 0x1DD6: 84, - 0x1DD7: 84, - 0x1DD8: 84, - 0x1DD9: 84, - 0x1DDA: 84, - 0x1DDB: 84, - 0x1DDC: 84, - 0x1DDD: 84, - 0x1DDE: 84, - 0x1DDF: 84, - 0x1DE0: 84, - 0x1DE1: 84, - 0x1DE2: 84, - 0x1DE3: 84, - 0x1DE4: 84, - 0x1DE5: 84, - 0x1DE6: 84, - 0x1DE7: 84, - 0x1DE8: 84, - 0x1DE9: 84, - 0x1DEA: 84, - 0x1DEB: 84, - 0x1DEC: 84, - 0x1DED: 84, - 0x1DEE: 84, - 0x1DEF: 84, - 0x1DF0: 84, - 0x1DF1: 84, - 0x1DF2: 84, - 0x1DF3: 84, - 0x1DF4: 84, - 0x1DF5: 84, - 0x1DF6: 84, - 0x1DF7: 84, - 0x1DF8: 84, - 0x1DF9: 84, - 0x1DFA: 84, - 0x1DFB: 84, - 0x1DFC: 84, - 0x1DFD: 84, - 0x1DFE: 84, - 0x1DFF: 84, - 0x200B: 84, - 0x200D: 67, - 0x200E: 84, - 0x200F: 84, - 0x202A: 84, - 0x202B: 84, - 0x202C: 84, - 0x202D: 84, - 0x202E: 84, - 0x2060: 84, - 0x2061: 84, - 0x2062: 84, - 0x2063: 84, - 0x2064: 84, - 0x206A: 84, - 0x206B: 84, - 0x206C: 84, - 0x206D: 84, - 0x206E: 84, - 0x206F: 84, - 0x20D0: 84, - 0x20D1: 84, - 0x20D2: 84, - 0x20D3: 84, - 0x20D4: 84, - 0x20D5: 84, - 0x20D6: 84, - 0x20D7: 84, - 0x20D8: 84, - 0x20D9: 84, - 0x20DA: 84, - 0x20DB: 84, - 0x20DC: 84, - 0x20DD: 84, - 0x20DE: 84, - 0x20DF: 84, - 0x20E0: 84, - 0x20E1: 84, - 0x20E2: 84, - 0x20E3: 84, - 0x20E4: 84, - 0x20E5: 84, - 0x20E6: 84, - 0x20E7: 84, - 0x20E8: 84, - 0x20E9: 84, - 0x20EA: 84, - 0x20EB: 84, - 0x20EC: 84, - 0x20ED: 84, - 0x20EE: 84, - 0x20EF: 84, - 0x20F0: 84, - 0x2CEF: 84, - 0x2CF0: 84, - 0x2CF1: 84, - 0x2D7F: 84, - 0x2DE0: 84, - 0x2DE1: 84, - 0x2DE2: 84, - 0x2DE3: 84, - 0x2DE4: 84, - 0x2DE5: 84, - 0x2DE6: 84, - 0x2DE7: 84, - 0x2DE8: 84, - 0x2DE9: 84, - 0x2DEA: 84, - 0x2DEB: 84, - 0x2DEC: 84, - 0x2DED: 84, - 0x2DEE: 84, - 0x2DEF: 84, - 0x2DF0: 84, - 0x2DF1: 84, - 0x2DF2: 84, - 0x2DF3: 84, - 0x2DF4: 84, - 0x2DF5: 84, - 0x2DF6: 84, - 0x2DF7: 84, - 0x2DF8: 84, - 0x2DF9: 84, - 0x2DFA: 84, - 0x2DFB: 84, - 0x2DFC: 84, - 0x2DFD: 84, - 0x2DFE: 84, - 0x2DFF: 84, - 0x302A: 84, - 0x302B: 84, - 0x302C: 84, - 0x302D: 84, - 0x3099: 84, - 0x309A: 84, - 0xA66F: 84, - 0xA670: 84, - 0xA671: 84, - 0xA672: 84, - 0xA674: 84, - 0xA675: 84, - 0xA676: 84, - 0xA677: 84, - 0xA678: 84, - 0xA679: 84, - 0xA67A: 84, - 0xA67B: 84, - 0xA67C: 84, - 0xA67D: 84, - 0xA69E: 84, - 0xA69F: 84, - 0xA6F0: 84, - 0xA6F1: 84, - 0xA802: 84, - 0xA806: 84, - 0xA80B: 84, - 0xA825: 84, - 0xA826: 84, - 0xA82C: 84, - 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, - 0xA8C4: 84, - 0xA8C5: 84, - 0xA8E0: 84, - 0xA8E1: 84, - 0xA8E2: 84, - 0xA8E3: 84, - 0xA8E4: 84, - 0xA8E5: 84, - 0xA8E6: 84, - 0xA8E7: 84, - 0xA8E8: 84, - 0xA8E9: 84, - 0xA8EA: 84, - 0xA8EB: 84, - 0xA8EC: 84, - 0xA8ED: 84, - 0xA8EE: 84, - 0xA8EF: 84, - 0xA8F0: 84, - 0xA8F1: 84, - 0xA8FF: 84, - 0xA926: 84, - 0xA927: 84, - 0xA928: 84, - 0xA929: 84, - 0xA92A: 84, - 0xA92B: 84, - 0xA92C: 84, - 0xA92D: 84, - 0xA947: 84, - 0xA948: 84, - 0xA949: 84, - 0xA94A: 84, - 0xA94B: 84, - 0xA94C: 84, - 0xA94D: 84, - 0xA94E: 84, - 0xA94F: 84, - 0xA950: 84, - 0xA951: 84, - 0xA980: 84, - 0xA981: 84, - 0xA982: 84, - 0xA9B3: 84, - 0xA9B6: 84, - 0xA9B7: 84, - 0xA9B8: 84, - 0xA9B9: 84, - 0xA9BC: 84, - 0xA9BD: 84, - 0xA9E5: 84, - 0xAA29: 84, - 0xAA2A: 84, - 0xAA2B: 84, - 0xAA2C: 84, - 0xAA2D: 84, - 0xAA2E: 84, - 0xAA31: 84, - 0xAA32: 84, - 0xAA35: 84, - 0xAA36: 84, - 0xAA43: 84, - 0xAA4C: 84, - 0xAA7C: 84, - 0xAAB0: 84, - 0xAAB2: 84, - 0xAAB3: 84, - 0xAAB4: 84, - 0xAAB7: 84, - 0xAAB8: 84, - 0xAABE: 84, - 0xAABF: 84, - 0xAAC1: 84, - 0xAAEC: 84, - 0xAAED: 84, - 0xAAF6: 84, - 0xABE5: 84, - 0xABE8: 84, - 0xABED: 84, - 0xFB1E: 84, - 0xFE00: 84, - 0xFE01: 84, - 0xFE02: 84, - 0xFE03: 84, - 0xFE04: 84, - 0xFE05: 84, - 0xFE06: 84, - 0xFE07: 84, - 0xFE08: 84, - 0xFE09: 84, - 0xFE0A: 84, - 0xFE0B: 84, - 0xFE0C: 84, - 0xFE0D: 84, - 0xFE0E: 84, - 0xFE0F: 84, - 0xFE20: 84, - 0xFE21: 84, - 0xFE22: 84, - 0xFE23: 84, - 0xFE24: 84, - 0xFE25: 84, - 0xFE26: 84, - 0xFE27: 84, - 0xFE28: 84, - 0xFE29: 84, - 0xFE2A: 84, - 0xFE2B: 84, - 0xFE2C: 84, - 0xFE2D: 84, - 0xFE2E: 84, - 0xFE2F: 84, - 0xFEFF: 84, - 0xFFF9: 84, - 0xFFFA: 84, - 0xFFFB: 84, - 0x101FD: 84, - 0x102E0: 84, - 0x10376: 84, - 0x10377: 84, - 0x10378: 84, - 0x10379: 84, - 0x1037A: 84, - 0x10A01: 84, - 0x10A02: 84, - 0x10A03: 84, - 0x10A05: 84, - 0x10A06: 84, - 0x10A0C: 84, - 0x10A0D: 84, - 0x10A0E: 84, - 0x10A0F: 84, - 0x10A38: 84, - 0x10A39: 84, - 0x10A3A: 84, - 0x10A3F: 84, - 0x10AC0: 68, - 0x10AC1: 68, - 0x10AC2: 68, - 0x10AC3: 68, - 0x10AC4: 68, - 0x10AC5: 82, - 0x10AC7: 82, - 0x10AC9: 82, - 0x10ACA: 82, - 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, - 0x10AE4: 82, - 0x10AE5: 84, - 0x10AE6: 84, - 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, - 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, - 0x10D24: 84, - 0x10D25: 84, - 0x10D26: 84, - 0x10D27: 84, - 0x10D69: 84, - 0x10D6A: 84, - 0x10D6B: 84, - 0x10D6C: 84, - 0x10D6D: 84, - 0x10EAB: 84, - 0x10EAC: 84, - 0x10EC2: 82, - 0x10EC3: 68, - 0x10EC4: 68, - 0x10EFC: 84, - 0x10EFD: 84, - 0x10EFE: 84, - 0x10EFF: 84, - 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, - 0x10F46: 84, - 0x10F47: 84, - 0x10F48: 84, - 0x10F49: 84, - 0x10F4A: 84, - 0x10F4B: 84, - 0x10F4C: 84, - 0x10F4D: 84, - 0x10F4E: 84, - 0x10F4F: 84, - 0x10F50: 84, - 0x10F51: 68, - 0x10F52: 68, - 0x10F53: 68, - 0x10F54: 82, - 0x10F70: 68, - 0x10F71: 68, - 0x10F72: 68, - 0x10F73: 68, - 0x10F74: 82, - 0x10F75: 82, - 0x10F76: 68, - 0x10F77: 68, - 0x10F78: 68, - 0x10F79: 68, - 0x10F7A: 68, - 0x10F7B: 68, - 0x10F7C: 68, - 0x10F7D: 68, - 0x10F7E: 68, - 0x10F7F: 68, - 0x10F80: 68, - 0x10F81: 68, - 0x10F82: 84, - 0x10F83: 84, - 0x10F84: 84, - 0x10F85: 84, - 0x10FB0: 68, - 0x10FB2: 68, - 0x10FB3: 68, - 0x10FB4: 82, - 0x10FB5: 82, - 0x10FB6: 82, - 0x10FB8: 68, - 0x10FB9: 82, - 0x10FBA: 82, - 0x10FBB: 68, - 0x10FBC: 68, - 0x10FBD: 82, - 0x10FBE: 68, - 0x10FBF: 68, - 0x10FC1: 68, - 0x10FC2: 82, - 0x10FC3: 82, - 0x10FC4: 68, - 0x10FC9: 82, - 0x10FCA: 68, - 0x10FCB: 76, - 0x11001: 84, - 0x11038: 84, - 0x11039: 84, - 0x1103A: 84, - 0x1103B: 84, - 0x1103C: 84, - 0x1103D: 84, - 0x1103E: 84, - 0x1103F: 84, - 0x11040: 84, - 0x11041: 84, - 0x11042: 84, - 0x11043: 84, - 0x11044: 84, - 0x11045: 84, - 0x11046: 84, - 0x11070: 84, - 0x11073: 84, - 0x11074: 84, - 0x1107F: 84, - 0x11080: 84, - 0x11081: 84, - 0x110B3: 84, - 0x110B4: 84, - 0x110B5: 84, - 0x110B6: 84, - 0x110B9: 84, - 0x110BA: 84, - 0x110C2: 84, - 0x11100: 84, - 0x11101: 84, - 0x11102: 84, - 0x11127: 84, - 0x11128: 84, - 0x11129: 84, - 0x1112A: 84, - 0x1112B: 84, - 0x1112D: 84, - 0x1112E: 84, - 0x1112F: 84, - 0x11130: 84, - 0x11131: 84, - 0x11132: 84, - 0x11133: 84, - 0x11134: 84, - 0x11173: 84, - 0x11180: 84, - 0x11181: 84, - 0x111B6: 84, - 0x111B7: 84, - 0x111B8: 84, - 0x111B9: 84, - 0x111BA: 84, - 0x111BB: 84, - 0x111BC: 84, - 0x111BD: 84, - 0x111BE: 84, - 0x111C9: 84, - 0x111CA: 84, - 0x111CB: 84, - 0x111CC: 84, - 0x111CF: 84, - 0x1122F: 84, - 0x11230: 84, - 0x11231: 84, - 0x11234: 84, - 0x11236: 84, - 0x11237: 84, - 0x1123E: 84, - 0x11241: 84, - 0x112DF: 84, - 0x112E3: 84, - 0x112E4: 84, - 0x112E5: 84, - 0x112E6: 84, - 0x112E7: 84, - 0x112E8: 84, - 0x112E9: 84, - 0x112EA: 84, - 0x11300: 84, - 0x11301: 84, - 0x1133B: 84, - 0x1133C: 84, - 0x11340: 84, - 0x11366: 84, - 0x11367: 84, - 0x11368: 84, - 0x11369: 84, - 0x1136A: 84, - 0x1136B: 84, - 0x1136C: 84, - 0x11370: 84, - 0x11371: 84, - 0x11372: 84, - 0x11373: 84, - 0x11374: 84, - 0x113BB: 84, - 0x113BC: 84, - 0x113BD: 84, - 0x113BE: 84, - 0x113BF: 84, - 0x113C0: 84, - 0x113CE: 84, - 0x113D0: 84, - 0x113D2: 84, - 0x113E1: 84, - 0x113E2: 84, - 0x11438: 84, - 0x11439: 84, - 0x1143A: 84, - 0x1143B: 84, - 0x1143C: 84, - 0x1143D: 84, - 0x1143E: 84, - 0x1143F: 84, - 0x11442: 84, - 0x11443: 84, - 0x11444: 84, - 0x11446: 84, - 0x1145E: 84, - 0x114B3: 84, - 0x114B4: 84, - 0x114B5: 84, - 0x114B6: 84, - 0x114B7: 84, - 0x114B8: 84, - 0x114BA: 84, - 0x114BF: 84, - 0x114C0: 84, - 0x114C2: 84, - 0x114C3: 84, - 0x115B2: 84, - 0x115B3: 84, - 0x115B4: 84, - 0x115B5: 84, - 0x115BC: 84, - 0x115BD: 84, - 0x115BF: 84, - 0x115C0: 84, - 0x115DC: 84, - 0x115DD: 84, - 0x11633: 84, - 0x11634: 84, - 0x11635: 84, - 0x11636: 84, - 0x11637: 84, - 0x11638: 84, - 0x11639: 84, - 0x1163A: 84, - 0x1163D: 84, - 0x1163F: 84, - 0x11640: 84, - 0x116AB: 84, - 0x116AD: 84, - 0x116B0: 84, - 0x116B1: 84, - 0x116B2: 84, - 0x116B3: 84, - 0x116B4: 84, - 0x116B5: 84, - 0x116B7: 84, - 0x1171D: 84, - 0x1171F: 84, - 0x11722: 84, - 0x11723: 84, - 0x11724: 84, - 0x11725: 84, - 0x11727: 84, - 0x11728: 84, - 0x11729: 84, - 0x1172A: 84, - 0x1172B: 84, - 0x1182F: 84, - 0x11830: 84, - 0x11831: 84, - 0x11832: 84, - 0x11833: 84, - 0x11834: 84, - 0x11835: 84, - 0x11836: 84, - 0x11837: 84, - 0x11839: 84, - 0x1183A: 84, - 0x1193B: 84, - 0x1193C: 84, - 0x1193E: 84, - 0x11943: 84, - 0x119D4: 84, - 0x119D5: 84, - 0x119D6: 84, - 0x119D7: 84, - 0x119DA: 84, - 0x119DB: 84, - 0x119E0: 84, - 0x11A01: 84, - 0x11A02: 84, - 0x11A03: 84, - 0x11A04: 84, - 0x11A05: 84, - 0x11A06: 84, - 0x11A07: 84, - 0x11A08: 84, - 0x11A09: 84, - 0x11A0A: 84, - 0x11A33: 84, - 0x11A34: 84, - 0x11A35: 84, - 0x11A36: 84, - 0x11A37: 84, - 0x11A38: 84, - 0x11A3B: 84, - 0x11A3C: 84, - 0x11A3D: 84, - 0x11A3E: 84, - 0x11A47: 84, - 0x11A51: 84, - 0x11A52: 84, - 0x11A53: 84, - 0x11A54: 84, - 0x11A55: 84, - 0x11A56: 84, - 0x11A59: 84, - 0x11A5A: 84, - 0x11A5B: 84, - 0x11A8A: 84, - 0x11A8B: 84, - 0x11A8C: 84, - 0x11A8D: 84, - 0x11A8E: 84, - 0x11A8F: 84, - 0x11A90: 84, - 0x11A91: 84, - 0x11A92: 84, - 0x11A93: 84, - 0x11A94: 84, - 0x11A95: 84, - 0x11A96: 84, - 0x11A98: 84, - 0x11A99: 84, - 0x11C30: 84, - 0x11C31: 84, - 0x11C32: 84, - 0x11C33: 84, - 0x11C34: 84, - 0x11C35: 84, - 0x11C36: 84, - 0x11C38: 84, - 0x11C39: 84, - 0x11C3A: 84, - 0x11C3B: 84, - 0x11C3C: 84, - 0x11C3D: 84, - 0x11C3F: 84, - 0x11C92: 84, - 0x11C93: 84, - 0x11C94: 84, - 0x11C95: 84, - 0x11C96: 84, - 0x11C97: 84, - 0x11C98: 84, - 0x11C99: 84, - 0x11C9A: 84, - 0x11C9B: 84, - 0x11C9C: 84, - 0x11C9D: 84, - 0x11C9E: 84, - 0x11C9F: 84, - 0x11CA0: 84, - 0x11CA1: 84, - 0x11CA2: 84, - 0x11CA3: 84, - 0x11CA4: 84, - 0x11CA5: 84, - 0x11CA6: 84, - 0x11CA7: 84, - 0x11CAA: 84, - 0x11CAB: 84, - 0x11CAC: 84, - 0x11CAD: 84, - 0x11CAE: 84, - 0x11CAF: 84, - 0x11CB0: 84, - 0x11CB2: 84, - 0x11CB3: 84, - 0x11CB5: 84, - 0x11CB6: 84, - 0x11D31: 84, - 0x11D32: 84, - 0x11D33: 84, - 0x11D34: 84, - 0x11D35: 84, - 0x11D36: 84, - 0x11D3A: 84, - 0x11D3C: 84, - 0x11D3D: 84, - 0x11D3F: 84, - 0x11D40: 84, - 0x11D41: 84, - 0x11D42: 84, - 0x11D43: 84, - 0x11D44: 84, - 0x11D45: 84, - 0x11D47: 84, - 0x11D90: 84, - 0x11D91: 84, - 0x11D95: 84, - 0x11D97: 84, - 0x11EF3: 84, - 0x11EF4: 84, - 0x11F00: 84, - 0x11F01: 84, - 0x11F36: 84, - 0x11F37: 84, - 0x11F38: 84, - 0x11F39: 84, - 0x11F3A: 84, - 0x11F40: 84, - 0x11F42: 84, - 0x11F5A: 84, - 0x13430: 84, - 0x13431: 84, - 0x13432: 84, - 0x13433: 84, - 0x13434: 84, - 0x13435: 84, - 0x13436: 84, - 0x13437: 84, - 0x13438: 84, - 0x13439: 84, - 0x1343A: 84, - 0x1343B: 84, - 0x1343C: 84, - 0x1343D: 84, - 0x1343E: 84, - 0x1343F: 84, - 0x13440: 84, - 0x13447: 84, - 0x13448: 84, - 0x13449: 84, - 0x1344A: 84, - 0x1344B: 84, - 0x1344C: 84, - 0x1344D: 84, - 0x1344E: 84, - 0x1344F: 84, - 0x13450: 84, - 0x13451: 84, - 0x13452: 84, - 0x13453: 84, - 0x13454: 84, - 0x13455: 84, - 0x1611E: 84, - 0x1611F: 84, - 0x16120: 84, - 0x16121: 84, - 0x16122: 84, - 0x16123: 84, - 0x16124: 84, - 0x16125: 84, - 0x16126: 84, - 0x16127: 84, - 0x16128: 84, - 0x16129: 84, - 0x1612D: 84, - 0x1612E: 84, - 0x1612F: 84, - 0x16AF0: 84, - 0x16AF1: 84, - 0x16AF2: 84, - 0x16AF3: 84, - 0x16AF4: 84, - 0x16B30: 84, - 0x16B31: 84, - 0x16B32: 84, - 0x16B33: 84, - 0x16B34: 84, - 0x16B35: 84, - 0x16B36: 84, - 0x16F4F: 84, - 0x16F8F: 84, - 0x16F90: 84, - 0x16F91: 84, - 0x16F92: 84, - 0x16FE4: 84, - 0x1BC9D: 84, - 0x1BC9E: 84, - 0x1BCA0: 84, - 0x1BCA1: 84, - 0x1BCA2: 84, - 0x1BCA3: 84, - 0x1CF00: 84, - 0x1CF01: 84, - 0x1CF02: 84, - 0x1CF03: 84, - 0x1CF04: 84, - 0x1CF05: 84, - 0x1CF06: 84, - 0x1CF07: 84, - 0x1CF08: 84, - 0x1CF09: 84, - 0x1CF0A: 84, - 0x1CF0B: 84, - 0x1CF0C: 84, - 0x1CF0D: 84, - 0x1CF0E: 84, - 0x1CF0F: 84, - 0x1CF10: 84, - 0x1CF11: 84, - 0x1CF12: 84, - 0x1CF13: 84, - 0x1CF14: 84, - 0x1CF15: 84, - 0x1CF16: 84, - 0x1CF17: 84, - 0x1CF18: 84, - 0x1CF19: 84, - 0x1CF1A: 84, - 0x1CF1B: 84, - 0x1CF1C: 84, - 0x1CF1D: 84, - 0x1CF1E: 84, - 0x1CF1F: 84, - 0x1CF20: 84, - 0x1CF21: 84, - 0x1CF22: 84, - 0x1CF23: 84, - 0x1CF24: 84, - 0x1CF25: 84, - 0x1CF26: 84, - 0x1CF27: 84, - 0x1CF28: 84, - 0x1CF29: 84, - 0x1CF2A: 84, - 0x1CF2B: 84, - 0x1CF2C: 84, - 0x1CF2D: 84, - 0x1CF30: 84, - 0x1CF31: 84, - 0x1CF32: 84, - 0x1CF33: 84, - 0x1CF34: 84, - 0x1CF35: 84, - 0x1CF36: 84, - 0x1CF37: 84, - 0x1CF38: 84, - 0x1CF39: 84, - 0x1CF3A: 84, - 0x1CF3B: 84, - 0x1CF3C: 84, - 0x1CF3D: 84, - 0x1CF3E: 84, - 0x1CF3F: 84, - 0x1CF40: 84, - 0x1CF41: 84, - 0x1CF42: 84, - 0x1CF43: 84, - 0x1CF44: 84, - 0x1CF45: 84, - 0x1CF46: 84, - 0x1D167: 84, - 0x1D168: 84, - 0x1D169: 84, - 0x1D173: 84, - 0x1D174: 84, - 0x1D175: 84, - 0x1D176: 84, - 0x1D177: 84, - 0x1D178: 84, - 0x1D179: 84, - 0x1D17A: 84, - 0x1D17B: 84, - 0x1D17C: 84, - 0x1D17D: 84, - 0x1D17E: 84, - 0x1D17F: 84, - 0x1D180: 84, - 0x1D181: 84, - 0x1D182: 84, - 0x1D185: 84, - 0x1D186: 84, - 0x1D187: 84, - 0x1D188: 84, - 0x1D189: 84, - 0x1D18A: 84, - 0x1D18B: 84, - 0x1D1AA: 84, - 0x1D1AB: 84, - 0x1D1AC: 84, - 0x1D1AD: 84, - 0x1D242: 84, - 0x1D243: 84, - 0x1D244: 84, - 0x1DA00: 84, - 0x1DA01: 84, - 0x1DA02: 84, - 0x1DA03: 84, - 0x1DA04: 84, - 0x1DA05: 84, - 0x1DA06: 84, - 0x1DA07: 84, - 0x1DA08: 84, - 0x1DA09: 84, - 0x1DA0A: 84, - 0x1DA0B: 84, - 0x1DA0C: 84, - 0x1DA0D: 84, - 0x1DA0E: 84, - 0x1DA0F: 84, - 0x1DA10: 84, - 0x1DA11: 84, - 0x1DA12: 84, - 0x1DA13: 84, - 0x1DA14: 84, - 0x1DA15: 84, - 0x1DA16: 84, - 0x1DA17: 84, - 0x1DA18: 84, - 0x1DA19: 84, - 0x1DA1A: 84, - 0x1DA1B: 84, - 0x1DA1C: 84, - 0x1DA1D: 84, - 0x1DA1E: 84, - 0x1DA1F: 84, - 0x1DA20: 84, - 0x1DA21: 84, - 0x1DA22: 84, - 0x1DA23: 84, - 0x1DA24: 84, - 0x1DA25: 84, - 0x1DA26: 84, - 0x1DA27: 84, - 0x1DA28: 84, - 0x1DA29: 84, - 0x1DA2A: 84, - 0x1DA2B: 84, - 0x1DA2C: 84, - 0x1DA2D: 84, - 0x1DA2E: 84, - 0x1DA2F: 84, - 0x1DA30: 84, - 0x1DA31: 84, - 0x1DA32: 84, - 0x1DA33: 84, - 0x1DA34: 84, - 0x1DA35: 84, - 0x1DA36: 84, - 0x1DA3B: 84, - 0x1DA3C: 84, - 0x1DA3D: 84, - 0x1DA3E: 84, - 0x1DA3F: 84, - 0x1DA40: 84, - 0x1DA41: 84, - 0x1DA42: 84, - 0x1DA43: 84, - 0x1DA44: 84, - 0x1DA45: 84, - 0x1DA46: 84, - 0x1DA47: 84, - 0x1DA48: 84, - 0x1DA49: 84, - 0x1DA4A: 84, - 0x1DA4B: 84, - 0x1DA4C: 84, - 0x1DA4D: 84, - 0x1DA4E: 84, - 0x1DA4F: 84, - 0x1DA50: 84, - 0x1DA51: 84, - 0x1DA52: 84, - 0x1DA53: 84, - 0x1DA54: 84, - 0x1DA55: 84, - 0x1DA56: 84, - 0x1DA57: 84, - 0x1DA58: 84, - 0x1DA59: 84, - 0x1DA5A: 84, - 0x1DA5B: 84, - 0x1DA5C: 84, - 0x1DA5D: 84, - 0x1DA5E: 84, - 0x1DA5F: 84, - 0x1DA60: 84, - 0x1DA61: 84, - 0x1DA62: 84, - 0x1DA63: 84, - 0x1DA64: 84, - 0x1DA65: 84, - 0x1DA66: 84, - 0x1DA67: 84, - 0x1DA68: 84, - 0x1DA69: 84, - 0x1DA6A: 84, - 0x1DA6B: 84, - 0x1DA6C: 84, - 0x1DA75: 84, - 0x1DA84: 84, - 0x1DA9B: 84, - 0x1DA9C: 84, - 0x1DA9D: 84, - 0x1DA9E: 84, - 0x1DA9F: 84, - 0x1DAA1: 84, - 0x1DAA2: 84, - 0x1DAA3: 84, - 0x1DAA4: 84, - 0x1DAA5: 84, - 0x1DAA6: 84, - 0x1DAA7: 84, - 0x1DAA8: 84, - 0x1DAA9: 84, - 0x1DAAA: 84, - 0x1DAAB: 84, - 0x1DAAC: 84, - 0x1DAAD: 84, - 0x1DAAE: 84, - 0x1DAAF: 84, - 0x1E000: 84, - 0x1E001: 84, - 0x1E002: 84, - 0x1E003: 84, - 0x1E004: 84, - 0x1E005: 84, - 0x1E006: 84, - 0x1E008: 84, - 0x1E009: 84, - 0x1E00A: 84, - 0x1E00B: 84, - 0x1E00C: 84, - 0x1E00D: 84, - 0x1E00E: 84, - 0x1E00F: 84, - 0x1E010: 84, - 0x1E011: 84, - 0x1E012: 84, - 0x1E013: 84, - 0x1E014: 84, - 0x1E015: 84, - 0x1E016: 84, - 0x1E017: 84, - 0x1E018: 84, - 0x1E01B: 84, - 0x1E01C: 84, - 0x1E01D: 84, - 0x1E01E: 84, - 0x1E01F: 84, - 0x1E020: 84, - 0x1E021: 84, - 0x1E023: 84, - 0x1E024: 84, - 0x1E026: 84, - 0x1E027: 84, - 0x1E028: 84, - 0x1E029: 84, - 0x1E02A: 84, - 0x1E08F: 84, - 0x1E130: 84, - 0x1E131: 84, - 0x1E132: 84, - 0x1E133: 84, - 0x1E134: 84, - 0x1E135: 84, - 0x1E136: 84, - 0x1E2AE: 84, - 0x1E2EC: 84, - 0x1E2ED: 84, - 0x1E2EE: 84, - 0x1E2EF: 84, - 0x1E4EC: 84, - 0x1E4ED: 84, - 0x1E4EE: 84, - 0x1E4EF: 84, - 0x1E5EE: 84, - 0x1E5EF: 84, - 0x1E8D0: 84, - 0x1E8D1: 84, - 0x1E8D2: 84, - 0x1E8D3: 84, - 0x1E8D4: 84, - 0x1E8D5: 84, - 0x1E8D6: 84, - 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, - 0x1E944: 84, - 0x1E945: 84, - 0x1E946: 84, - 0x1E947: 84, - 0x1E948: 84, - 0x1E949: 84, - 0x1E94A: 84, - 0x1E94B: 84, - 0xE0001: 84, - 0xE0020: 84, - 0xE0021: 84, - 0xE0022: 84, - 0xE0023: 84, - 0xE0024: 84, - 0xE0025: 84, - 0xE0026: 84, - 0xE0027: 84, - 0xE0028: 84, - 0xE0029: 84, - 0xE002A: 84, - 0xE002B: 84, - 0xE002C: 84, - 0xE002D: 84, - 0xE002E: 84, - 0xE002F: 84, - 0xE0030: 84, - 0xE0031: 84, - 0xE0032: 84, - 0xE0033: 84, - 0xE0034: 84, - 0xE0035: 84, - 0xE0036: 84, - 0xE0037: 84, - 0xE0038: 84, - 0xE0039: 84, - 0xE003A: 84, - 0xE003B: 84, - 0xE003C: 84, - 0xE003D: 84, - 0xE003E: 84, - 0xE003F: 84, - 0xE0040: 84, - 0xE0041: 84, - 0xE0042: 84, - 0xE0043: 84, - 0xE0044: 84, - 0xE0045: 84, - 0xE0046: 84, - 0xE0047: 84, - 0xE0048: 84, - 0xE0049: 84, - 0xE004A: 84, - 0xE004B: 84, - 0xE004C: 84, - 0xE004D: 84, - 0xE004E: 84, - 0xE004F: 84, - 0xE0050: 84, - 0xE0051: 84, - 0xE0052: 84, - 0xE0053: 84, - 0xE0054: 84, - 0xE0055: 84, - 0xE0056: 84, - 0xE0057: 84, - 0xE0058: 84, - 0xE0059: 84, - 0xE005A: 84, - 0xE005B: 84, - 0xE005C: 84, - 0xE005D: 84, - 0xE005E: 84, - 0xE005F: 84, - 0xE0060: 84, - 0xE0061: 84, - 0xE0062: 84, - 0xE0063: 84, - 0xE0064: 84, - 0xE0065: 84, - 0xE0066: 84, - 0xE0067: 84, - 0xE0068: 84, - 0xE0069: 84, - 0xE006A: 84, - 0xE006B: 84, - 0xE006C: 84, - 0xE006D: 84, - 0xE006E: 84, - 0xE006F: 84, - 0xE0070: 84, - 0xE0071: 84, - 0xE0072: 84, - 0xE0073: 84, - 0xE0074: 84, - 0xE0075: 84, - 0xE0076: 84, - 0xE0077: 84, - 0xE0078: 84, - 0xE0079: 84, - 0xE007A: 84, - 0xE007B: 84, - 0xE007C: 84, - 0xE007D: 84, - 0xE007E: 84, - 0xE007F: 84, - 0xE0100: 84, - 0xE0101: 84, - 0xE0102: 84, - 0xE0103: 84, - 0xE0104: 84, - 0xE0105: 84, - 0xE0106: 84, - 0xE0107: 84, - 0xE0108: 84, - 0xE0109: 84, - 0xE010A: 84, - 0xE010B: 84, - 0xE010C: 84, - 0xE010D: 84, - 0xE010E: 84, - 0xE010F: 84, - 0xE0110: 84, - 0xE0111: 84, - 0xE0112: 84, - 0xE0113: 84, - 0xE0114: 84, - 0xE0115: 84, - 0xE0116: 84, - 0xE0117: 84, - 0xE0118: 84, - 0xE0119: 84, - 0xE011A: 84, - 0xE011B: 84, - 0xE011C: 84, - 0xE011D: 84, - 0xE011E: 84, - 0xE011F: 84, - 0xE0120: 84, - 0xE0121: 84, - 0xE0122: 84, - 0xE0123: 84, - 0xE0124: 84, - 0xE0125: 84, - 0xE0126: 84, - 0xE0127: 84, - 0xE0128: 84, - 0xE0129: 84, - 0xE012A: 84, - 0xE012B: 84, - 0xE012C: 84, - 0xE012D: 84, - 0xE012E: 84, - 0xE012F: 84, - 0xE0130: 84, - 0xE0131: 84, - 0xE0132: 84, - 0xE0133: 84, - 0xE0134: 84, - 0xE0135: 84, - 0xE0136: 84, - 0xE0137: 84, - 0xE0138: 84, - 0xE0139: 84, - 0xE013A: 84, - 0xE013B: 84, - 0xE013C: 84, - 0xE013D: 84, - 0xE013E: 84, - 0xE013F: 84, - 0xE0140: 84, - 0xE0141: 84, - 0xE0142: 84, - 0xE0143: 84, - 0xE0144: 84, - 0xE0145: 84, - 0xE0146: 84, - 0xE0147: 84, - 0xE0148: 84, - 0xE0149: 84, - 0xE014A: 84, - 0xE014B: 84, - 0xE014C: 84, - 0xE014D: 84, - 0xE014E: 84, - 0xE014F: 84, - 0xE0150: 84, - 0xE0151: 84, - 0xE0152: 84, - 0xE0153: 84, - 0xE0154: 84, - 0xE0155: 84, - 0xE0156: 84, - 0xE0157: 84, - 0xE0158: 84, - 0xE0159: 84, - 0xE015A: 84, - 0xE015B: 84, - 0xE015C: 84, - 0xE015D: 84, - 0xE015E: 84, - 0xE015F: 84, - 0xE0160: 84, - 0xE0161: 84, - 0xE0162: 84, - 0xE0163: 84, - 0xE0164: 84, - 0xE0165: 84, - 0xE0166: 84, - 0xE0167: 84, - 0xE0168: 84, - 0xE0169: 84, - 0xE016A: 84, - 0xE016B: 84, - 0xE016C: 84, - 0xE016D: 84, - 0xE016E: 84, - 0xE016F: 84, - 0xE0170: 84, - 0xE0171: 84, - 0xE0172: 84, - 0xE0173: 84, - 0xE0174: 84, - 0xE0175: 84, - 0xE0176: 84, - 0xE0177: 84, - 0xE0178: 84, - 0xE0179: 84, - 0xE017A: 84, - 0xE017B: 84, - 0xE017C: 84, - 0xE017D: 84, - 0xE017E: 84, - 0xE017F: 84, - 0xE0180: 84, - 0xE0181: 84, - 0xE0182: 84, - 0xE0183: 84, - 0xE0184: 84, - 0xE0185: 84, - 0xE0186: 84, - 0xE0187: 84, - 0xE0188: 84, - 0xE0189: 84, - 0xE018A: 84, - 0xE018B: 84, - 0xE018C: 84, - 0xE018D: 84, - 0xE018E: 84, - 0xE018F: 84, - 0xE0190: 84, - 0xE0191: 84, - 0xE0192: 84, - 0xE0193: 84, - 0xE0194: 84, - 0xE0195: 84, - 0xE0196: 84, - 0xE0197: 84, - 0xE0198: 84, - 0xE0199: 84, - 0xE019A: 84, - 0xE019B: 84, - 0xE019C: 84, - 0xE019D: 84, - 0xE019E: 84, - 0xE019F: 84, - 0xE01A0: 84, - 0xE01A1: 84, - 0xE01A2: 84, - 0xE01A3: 84, - 0xE01A4: 84, - 0xE01A5: 84, - 0xE01A6: 84, - 0xE01A7: 84, - 0xE01A8: 84, - 0xE01A9: 84, - 0xE01AA: 84, - 0xE01AB: 84, - 0xE01AC: 84, - 0xE01AD: 84, - 0xE01AE: 84, - 0xE01AF: 84, - 0xE01B0: 84, - 0xE01B1: 84, - 0xE01B2: 84, - 0xE01B3: 84, - 0xE01B4: 84, - 0xE01B5: 84, - 0xE01B6: 84, - 0xE01B7: 84, - 0xE01B8: 84, - 0xE01B9: 84, - 0xE01BA: 84, - 0xE01BB: 84, - 0xE01BC: 84, - 0xE01BD: 84, - 0xE01BE: 84, - 0xE01BF: 84, - 0xE01C0: 84, - 0xE01C1: 84, - 0xE01C2: 84, - 0xE01C3: 84, - 0xE01C4: 84, - 0xE01C5: 84, - 0xE01C6: 84, - 0xE01C7: 84, - 0xE01C8: 84, - 0xE01C9: 84, - 0xE01CA: 84, - 0xE01CB: 84, - 0xE01CC: 84, - 0xE01CD: 84, - 0xE01CE: 84, - 0xE01CF: 84, - 0xE01D0: 84, - 0xE01D1: 84, - 0xE01D2: 84, - 0xE01D3: 84, - 0xE01D4: 84, - 0xE01D5: 84, - 0xE01D6: 84, - 0xE01D7: 84, - 0xE01D8: 84, - 0xE01D9: 84, - 0xE01DA: 84, - 0xE01DB: 84, - 0xE01DC: 84, - 0xE01DD: 84, - 0xE01DE: 84, - 0xE01DF: 84, - 0xE01E0: 84, - 0xE01E1: 84, - 0xE01E2: 84, - 0xE01E3: 84, - 0xE01E4: 84, - 0xE01E5: 84, - 0xE01E6: 84, - 0xE01E7: 84, - 0xE01E8: 84, - 0xE01E9: 84, - 0xE01EA: 84, - 0xE01EB: 84, - 0xE01EC: 84, - 0xE01ED: 84, - 0xE01EE: 84, - 0xE01EF: 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, - 0x87000000888, - 0x8890000088F, - 0x897000008E2, - 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, - 0xC3C00000C45, - 0xC4600000C49, - 0xC4A00000C4E, - 0xC5500000C57, - 0xC5800000C5B, - 0xC5D00000C5E, - 0xC6000000C64, - 0xC6600000C70, - 0xC8000000C84, - 0xC8500000C8D, - 0xC8E00000C91, - 0xC9200000CA9, - 0xCAA00000CB4, - 0xCB500000CBA, - 0xCBC00000CC5, - 0xCC600000CC9, - 0xCCA00000CCE, - 0xCD500000CD7, - 0xCDD00000CDF, - 0xCE000000CE4, - 0xCE600000CF0, - 0xCF100000CF4, - 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, - 0xEC800000ECF, - 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, - 0x170000001716, - 0x171F00001735, - 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, - 0x1ABF00001ACF, - 0x1B0000001B4D, - 0x1B5000001B5A, - 0x1B6B00001B74, - 0x1B8000001BF4, - 0x1C0000001C38, - 0x1C4000001C4A, - 0x1C4D00001C7E, - 0x1C8A00001C8B, - 0x1CD000001CD3, - 0x1CD400001CFB, - 0x1D0000001D2C, - 0x1D2F00001D30, - 0x1D3B00001D3C, - 0x1D4E00001D4F, - 0x1D6B00001D78, - 0x1D7900001D9B, - 0x1DC000001E00, - 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, - 0x2C3000002C60, - 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, - 0x4E000000A48D, - 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, - 0xA7C10000A7C2, - 0xA7C30000A7C4, - 0xA7C80000A7C9, - 0xA7CA0000A7CB, - 0xA7CD0000A7CE, - 0xA7D10000A7D2, - 0xA7D30000A7D4, - 0xA7D50000A7D6, - 0xA7D70000A7D8, - 0xA7D90000A7DA, - 0xA7DB0000A7DC, - 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, - 0xAB600000AB69, - 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, - 0x10597000105A2, - 0x105A3000105B2, - 0x105B3000105BA, - 0x105BB000105BD, - 0x105C0000105F4, - 0x1060000010737, - 0x1074000010756, - 0x1076000010768, - 0x1078000010781, - 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, - 0x10D4000010D50, - 0x10D6900010D6E, - 0x10D6F00010D86, - 0x10E8000010EAA, - 0x10EAB00010EAD, - 0x10EB000010EB2, - 0x10EC200010EC5, - 0x10EFC00010F1D, - 0x10F2700010F28, - 0x10F3000010F51, - 0x10F7000010F86, - 0x10FB000010FC5, - 0x10FE000010FF7, - 0x1100000011047, - 0x1106600011076, - 0x1107F000110BB, - 0x110C2000110C3, - 0x110D0000110E9, - 0x110F0000110FA, - 0x1110000011135, - 0x1113600011140, - 0x1114400011148, - 0x1115000011174, - 0x1117600011177, - 0x11180000111C5, - 0x111C9000111CD, - 0x111CE000111DB, - 0x111DC000111DD, - 0x1120000011212, - 0x1121300011238, - 0x1123E00011242, - 0x1128000011287, - 0x1128800011289, - 0x1128A0001128E, - 0x1128F0001129E, - 0x1129F000112A9, - 0x112B0000112EB, - 0x112F0000112FA, - 0x1130000011304, - 0x113050001130D, - 0x1130F00011311, - 0x1131300011329, - 0x1132A00011331, - 0x1133200011334, - 0x113350001133A, - 0x1133B00011345, - 0x1134700011349, - 0x1134B0001134E, - 0x1135000011351, - 0x1135700011358, - 0x1135D00011364, - 0x113660001136D, - 0x1137000011375, - 0x113800001138A, - 0x1138B0001138C, - 0x1138E0001138F, - 0x11390000113B6, - 0x113B7000113C1, - 0x113C2000113C3, - 0x113C5000113C6, - 0x113C7000113CB, - 0x113CC000113D4, - 0x113E1000113E3, - 0x114000001144B, - 0x114500001145A, - 0x1145E00011462, - 0x11480000114C6, - 0x114C7000114C8, - 0x114D0000114DA, - 0x11580000115B6, - 0x115B8000115C1, - 0x115D8000115DE, - 0x1160000011641, - 0x1164400011645, - 0x116500001165A, - 0x11680000116B9, - 0x116C0000116CA, - 0x116D0000116E4, - 0x117000001171B, - 0x1171D0001172C, - 0x117300001173A, - 0x1174000011747, - 0x118000001183B, - 0x118C0000118EA, - 0x118FF00011907, - 0x119090001190A, - 0x1190C00011914, - 0x1191500011917, - 0x1191800011936, - 0x1193700011939, - 0x1193B00011944, - 0x119500001195A, - 0x119A0000119A8, - 0x119AA000119D8, - 0x119DA000119E2, - 0x119E3000119E5, - 0x11A0000011A3F, - 0x11A4700011A48, - 0x11A5000011A9A, - 0x11A9D00011A9E, - 0x11AB000011AF9, - 0x11BC000011BE1, - 0x11BF000011BFA, - 0x11C0000011C09, - 0x11C0A00011C37, - 0x11C3800011C41, - 0x11C5000011C5A, - 0x11C7200011C90, - 0x11C9200011CA8, - 0x11CA900011CB7, - 0x11D0000011D07, - 0x11D0800011D0A, - 0x11D0B00011D37, - 0x11D3A00011D3B, - 0x11D3C00011D3E, - 0x11D3F00011D48, - 0x11D5000011D5A, - 0x11D6000011D66, - 0x11D6700011D69, - 0x11D6A00011D8F, - 0x11D9000011D92, - 0x11D9300011D99, - 0x11DA000011DAA, - 0x11EE000011EF7, - 0x11F0000011F11, - 0x11F1200011F3B, - 0x11F3E00011F43, - 0x11F5000011F5B, - 0x11FB000011FB1, - 0x120000001239A, - 0x1248000012544, - 0x12F9000012FF1, - 0x1300000013430, - 0x1344000013456, - 0x13460000143FB, - 0x1440000014647, - 0x161000001613A, - 0x1680000016A39, - 0x16A4000016A5F, - 0x16A6000016A6A, - 0x16A7000016ABF, - 0x16AC000016ACA, - 0x16AD000016AEE, - 0x16AF000016AF5, - 0x16B0000016B37, - 0x16B4000016B44, - 0x16B5000016B5A, - 0x16B6300016B78, - 0x16B7D00016B90, - 0x16D4000016D6D, - 0x16D7000016D7A, - 0x16E6000016E80, - 0x16F0000016F4B, - 0x16F4F00016F88, - 0x16F8F00016FA0, - 0x16FE000016FE2, - 0x16FE300016FE5, - 0x16FF000016FF2, - 0x17000000187F8, - 0x1880000018CD6, - 0x18CFF00018D09, - 0x1AFF00001AFF4, - 0x1AFF50001AFFC, - 0x1AFFD0001AFFF, - 0x1B0000001B123, - 0x1B1320001B133, - 0x1B1500001B153, - 0x1B1550001B156, - 0x1B1640001B168, - 0x1B1700001B2FC, - 0x1BC000001BC6B, - 0x1BC700001BC7D, - 0x1BC800001BC89, - 0x1BC900001BC9A, - 0x1BC9D0001BC9F, - 0x1CCF00001CCFA, - 0x1CF000001CF2E, - 0x1CF300001CF47, - 0x1DA000001DA37, - 0x1DA3B0001DA6D, - 0x1DA750001DA76, - 0x1DA840001DA85, - 0x1DA9B0001DAA0, - 0x1DAA10001DAB0, - 0x1DF000001DF1F, - 0x1DF250001DF2B, - 0x1E0000001E007, - 0x1E0080001E019, - 0x1E01B0001E022, - 0x1E0230001E025, - 0x1E0260001E02B, - 0x1E08F0001E090, - 0x1E1000001E12D, - 0x1E1300001E13E, - 0x1E1400001E14A, - 0x1E14E0001E14F, - 0x1E2900001E2AF, - 0x1E2C00001E2FA, - 0x1E4D00001E4FA, - 0x1E5D00001E5FB, - 0x1E7E00001E7E7, - 0x1E7E80001E7EC, - 0x1E7ED0001E7EF, - 0x1E7F00001E7FF, - 0x1E8000001E8C5, - 0x1E8D00001E8D7, - 0x1E9220001E94C, - 0x1E9500001E95A, - 0x200000002A6E0, - 0x2A7000002B73A, - 0x2B7400002B81E, - 0x2B8200002CEA2, - 0x2CEB00002EBE1, - 0x2EBF00002EE5E, - 0x300000003134B, - 0x31350000323B0, - ), - "CONTEXTJ": (0x200C0000200E,), - "CONTEXTO": ( - 0xB7000000B8, - 0x37500000376, - 0x5F3000005F5, - 0x6600000066A, - 0x6F0000006FA, - 0x30FB000030FC, - ), -} diff --git a/venv/lib/python3.12/site-packages/idna/intranges.py b/venv/lib/python3.12/site-packages/idna/intranges.py deleted file mode 100644 index 7bfaa8d..0000000 --- a/venv/lib/python3.12/site-packages/idna/intranges.py +++ /dev/null @@ -1,57 +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_: 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: int, end: int) -> int: - return (start << 32) | end - - -def _decode_range(r: int) -> Tuple[int, int]: - return (r >> 32), (r & ((1 << 32) - 1)) - - -def intranges_contain(int_: int, ranges: Tuple[int, ...]) -> bool: - """Determine if `int_` falls into one of the ranges in `ranges`.""" - tuple_ = _encode_range(int_, 0) - pos = bisect.bisect_left(ranges, tuple_) - # 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.12/site-packages/idna/package_data.py b/venv/lib/python3.12/site-packages/idna/package_data.py deleted file mode 100644 index 7272c8d..0000000 --- a/venv/lib/python3.12/site-packages/idna/package_data.py +++ /dev/null @@ -1 +0,0 @@ -__version__ = "3.11" diff --git a/venv/lib/python3.12/site-packages/idna/py.typed b/venv/lib/python3.12/site-packages/idna/py.typed deleted file mode 100644 index e69de29..0000000 diff --git a/venv/lib/python3.12/site-packages/idna/uts46data.py b/venv/lib/python3.12/site-packages/idna/uts46data.py deleted file mode 100644 index 4610b71..0000000 --- a/venv/lib/python3.12/site-packages/idna/uts46data.py +++ /dev/null @@ -1,8841 +0,0 @@ -# This file is automatically generated by tools/idna-data -# vim: set fileencoding=utf-8 : - -from typing import List, Tuple, Union - -"""IDNA Mapping Table from UTS46.""" - - -__version__ = "16.0.0" - - -def _seg_0() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (0x0, "V"), - (0x1, "V"), - (0x2, "V"), - (0x3, "V"), - (0x4, "V"), - (0x5, "V"), - (0x6, "V"), - (0x7, "V"), - (0x8, "V"), - (0x9, "V"), - (0xA, "V"), - (0xB, "V"), - (0xC, "V"), - (0xD, "V"), - (0xE, "V"), - (0xF, "V"), - (0x10, "V"), - (0x11, "V"), - (0x12, "V"), - (0x13, "V"), - (0x14, "V"), - (0x15, "V"), - (0x16, "V"), - (0x17, "V"), - (0x18, "V"), - (0x19, "V"), - (0x1A, "V"), - (0x1B, "V"), - (0x1C, "V"), - (0x1D, "V"), - (0x1E, "V"), - (0x1F, "V"), - (0x20, "V"), - (0x21, "V"), - (0x22, "V"), - (0x23, "V"), - (0x24, "V"), - (0x25, "V"), - (0x26, "V"), - (0x27, "V"), - (0x28, "V"), - (0x29, "V"), - (0x2A, "V"), - (0x2B, "V"), - (0x2C, "V"), - (0x2D, "V"), - (0x2E, "V"), - (0x2F, "V"), - (0x30, "V"), - (0x31, "V"), - (0x32, "V"), - (0x33, "V"), - (0x34, "V"), - (0x35, "V"), - (0x36, "V"), - (0x37, "V"), - (0x38, "V"), - (0x39, "V"), - (0x3A, "V"), - (0x3B, "V"), - (0x3C, "V"), - (0x3D, "V"), - (0x3E, "V"), - (0x3F, "V"), - (0x40, "V"), - (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, "V"), - (0x5C, "V"), - (0x5D, "V"), - (0x5E, "V"), - (0x5F, "V"), - (0x60, "V"), - (0x61, "V"), - (0x62, "V"), - (0x63, "V"), - ] - - -def _seg_1() -> 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, "V"), - (0x7C, "V"), - (0x7D, "V"), - (0x7E, "V"), - (0x7F, "V"), - (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, "M", " "), - (0xA1, "V"), - (0xA2, "V"), - (0xA3, "V"), - (0xA4, "V"), - (0xA5, "V"), - (0xA6, "V"), - (0xA7, "V"), - (0xA8, "M", " ̈"), - (0xA9, "V"), - (0xAA, "M", "a"), - (0xAB, "V"), - (0xAC, "V"), - (0xAD, "I"), - (0xAE, "V"), - (0xAF, "M", " ̄"), - (0xB0, "V"), - (0xB1, "V"), - (0xB2, "M", "2"), - (0xB3, "M", "3"), - (0xB4, "M", " ́"), - (0xB5, "M", "μ"), - (0xB6, "V"), - (0xB7, "V"), - (0xB8, "M", " ̧"), - (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() -> 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() -> 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() -> 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() -> 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, "M", " ̆"), - (0x2D9, "M", " ̇"), - (0x2DA, "M", " ̊"), - (0x2DB, "M", " ̨"), - (0x2DC, "M", " ̃"), - (0x2DD, "M", " ̋"), - (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() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (0x378, "X"), - (0x37A, "M", " ι"), - (0x37B, "V"), - (0x37E, "M", ";"), - (0x37F, "M", "ϳ"), - (0x380, "X"), - (0x384, "M", " ́"), - (0x385, "M", " ̈́"), - (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() -> 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() -> 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, "M", "ӏ"), - (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() -> 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"), - (0x61D, "V"), - ] - - -def _seg_10() -> 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"), - (0x870, "V"), - (0x88F, "X"), - (0x897, "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", "ਜ਼"), - (0xA5C, "V"), - (0xA5D, "X"), - ] - - -def _seg_11() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (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"), - (0xC29, "X"), - (0xC2A, "V"), - ] - - -def _seg_12() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (0xC3A, "X"), - (0xC3C, "V"), - (0xC45, "X"), - (0xC46, "V"), - (0xC49, "X"), - (0xC4A, "V"), - (0xC4E, "X"), - (0xC55, "V"), - (0xC57, "X"), - (0xC58, "V"), - (0xC5B, "X"), - (0xC5D, "V"), - (0xC5E, "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"), - (0xCDD, "V"), - (0xCDF, "X"), - (0xCE0, "V"), - (0xCE4, "X"), - (0xCE6, "V"), - (0xCF0, "X"), - (0xCF1, "V"), - (0xCF4, "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() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (0xEBE, "X"), - (0xEC0, "V"), - (0xEC5, "X"), - (0xEC6, "V"), - (0xEC7, "X"), - (0xEC8, "V"), - (0xECF, "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, "M", "ⴀ"), - (0x10A1, "M", "ⴁ"), - (0x10A2, "M", "ⴂ"), - (0x10A3, "M", "ⴃ"), - (0x10A4, "M", "ⴄ"), - (0x10A5, "M", "ⴅ"), - (0x10A6, "M", "ⴆ"), - (0x10A7, "M", "ⴇ"), - (0x10A8, "M", "ⴈ"), - (0x10A9, "M", "ⴉ"), - (0x10AA, "M", "ⴊ"), - (0x10AB, "M", "ⴋ"), - (0x10AC, "M", "ⴌ"), - (0x10AD, "M", "ⴍ"), - (0x10AE, "M", "ⴎ"), - (0x10AF, "M", "ⴏ"), - (0x10B0, "M", "ⴐ"), - (0x10B1, "M", "ⴑ"), - (0x10B2, "M", "ⴒ"), - (0x10B3, "M", "ⴓ"), - (0x10B4, "M", "ⴔ"), - (0x10B5, "M", "ⴕ"), - (0x10B6, "M", "ⴖ"), - (0x10B7, "M", "ⴗ"), - (0x10B8, "M", "ⴘ"), - (0x10B9, "M", "ⴙ"), - (0x10BA, "M", "ⴚ"), - (0x10BB, "M", "ⴛ"), - (0x10BC, "M", "ⴜ"), - (0x10BD, "M", "ⴝ"), - (0x10BE, "M", "ⴞ"), - (0x10BF, "M", "ⴟ"), - (0x10C0, "M", "ⴠ"), - (0x10C1, "M", "ⴡ"), - (0x10C2, "M", "ⴢ"), - (0x10C3, "M", "ⴣ"), - (0x10C4, "M", "ⴤ"), - (0x10C5, "M", "ⴥ"), - ] - - -def _seg_14() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (0x10C6, "X"), - (0x10C7, "M", "ⴧ"), - (0x10C8, "X"), - (0x10CD, "M", "ⴭ"), - (0x10CE, "X"), - (0x10D0, "V"), - (0x10FC, "M", "ნ"), - (0x10FD, "V"), - (0x115F, "I"), - (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"), - (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"), - (0x1716, "X"), - (0x171F, "V"), - (0x1737, "X"), - (0x1740, "V"), - (0x1754, "X"), - (0x1760, "V"), - (0x176D, "X"), - (0x176E, "V"), - (0x1771, "X"), - (0x1772, "V"), - (0x1774, "X"), - (0x1780, "V"), - (0x17B4, "I"), - (0x17B6, "V"), - (0x17DE, "X"), - (0x17E0, "V"), - (0x17EA, "X"), - (0x17F0, "V"), - (0x17FA, "X"), - (0x1800, "V"), - (0x180B, "I"), - (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"), - ] - - -def _seg_15() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (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"), - (0x1ACF, "X"), - (0x1B00, "V"), - (0x1B4D, "X"), - (0x1B4E, "V"), - (0x1BF4, "X"), - (0x1BFC, "V"), - (0x1C38, "X"), - (0x1C3B, "V"), - (0x1C4A, "X"), - (0x1C4D, "V"), - (0x1C80, "M", "в"), - (0x1C81, "M", "д"), - (0x1C82, "M", "о"), - (0x1C83, "M", "с"), - (0x1C84, "M", "т"), - (0x1C86, "M", "ъ"), - (0x1C87, "M", "ѣ"), - (0x1C88, "M", "ꙋ"), - (0x1C89, "M", "ᲊ"), - (0x1C8A, "V"), - (0x1C8B, "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"), - ] - - -def _seg_16() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (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"), - (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"), - (0x1E00, "M", "ḁ"), - (0x1E01, "V"), - ] - - -def _seg_17() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (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", "ḡ"), - (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"), - ] - - -def _seg_18() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (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", "ẅ"), - (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", "ß"), - (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", "ỏ"), - ] - - -def _seg_19() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (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"), - (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", "ὕ"), - ] - - -def _seg_20() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (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", "ἄι"), - (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, "M", " ̓"), - (0x1FBE, "M", "ι"), - (0x1FBF, "M", " ̓"), - (0x1FC0, "M", " ͂"), - (0x1FC1, "M", " ̈͂"), - (0x1FC2, "M", "ὴι"), - (0x1FC3, "M", "ηι"), - (0x1FC4, "M", "ήι"), - (0x1FC5, "X"), - (0x1FC6, "V"), - (0x1FC7, "M", "ῆι"), - (0x1FC8, "M", "ὲ"), - (0x1FC9, "M", "έ"), - (0x1FCA, "M", "ὴ"), - ] - - -def _seg_21() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (0x1FCB, "M", "ή"), - (0x1FCC, "M", "ηι"), - (0x1FCD, "M", " ̓̀"), - (0x1FCE, "M", " ̓́"), - (0x1FCF, "M", " ̓͂"), - (0x1FD0, "V"), - (0x1FD3, "M", "ΐ"), - (0x1FD4, "X"), - (0x1FD6, "V"), - (0x1FD8, "M", "ῐ"), - (0x1FD9, "M", "ῑ"), - (0x1FDA, "M", "ὶ"), - (0x1FDB, "M", "ί"), - (0x1FDC, "X"), - (0x1FDD, "M", " ̔̀"), - (0x1FDE, "M", " ̔́"), - (0x1FDF, "M", " ̔͂"), - (0x1FE0, "V"), - (0x1FE3, "M", "ΰ"), - (0x1FE4, "V"), - (0x1FE8, "M", "ῠ"), - (0x1FE9, "M", "ῡ"), - (0x1FEA, "M", "ὺ"), - (0x1FEB, "M", "ύ"), - (0x1FEC, "M", "ῥ"), - (0x1FED, "M", " ̈̀"), - (0x1FEE, "M", " ̈́"), - (0x1FEF, "M", "`"), - (0x1FF0, "X"), - (0x1FF2, "M", "ὼι"), - (0x1FF3, "M", "ωι"), - (0x1FF4, "M", "ώι"), - (0x1FF5, "X"), - (0x1FF6, "V"), - (0x1FF7, "M", "ῶι"), - (0x1FF8, "M", "ὸ"), - (0x1FF9, "M", "ό"), - (0x1FFA, "M", "ὼ"), - (0x1FFB, "M", "ώ"), - (0x1FFC, "M", "ωι"), - (0x1FFD, "M", " ́"), - (0x1FFE, "M", " ̔"), - (0x1FFF, "X"), - (0x2000, "M", " "), - (0x200B, "I"), - (0x200C, "D", ""), - (0x200E, "X"), - (0x2010, "V"), - (0x2011, "M", "‐"), - (0x2012, "V"), - (0x2017, "M", " ̳"), - (0x2018, "V"), - (0x2024, "X"), - (0x2027, "V"), - (0x2028, "X"), - (0x202F, "M", " "), - (0x2030, "V"), - (0x2033, "M", "′′"), - (0x2034, "M", "′′′"), - (0x2035, "V"), - (0x2036, "M", "‵‵"), - (0x2037, "M", "‵‵‵"), - (0x2038, "V"), - (0x203C, "M", "!!"), - (0x203D, "V"), - (0x203E, "M", " ̅"), - (0x203F, "V"), - (0x2047, "M", "??"), - (0x2048, "M", "?!"), - (0x2049, "M", "!?"), - (0x204A, "V"), - (0x2057, "M", "′′′′"), - (0x2058, "V"), - (0x205F, "M", " "), - (0x2060, "I"), - (0x2065, "X"), - (0x206A, "I"), - (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, "M", "+"), - (0x207B, "M", "−"), - (0x207C, "M", "="), - (0x207D, "M", "("), - (0x207E, "M", ")"), - (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"), - ] - - -def _seg_22() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (0x2088, "M", "8"), - (0x2089, "M", "9"), - (0x208A, "M", "+"), - (0x208B, "M", "−"), - (0x208C, "M", "="), - (0x208D, "M", "("), - (0x208E, "M", ")"), - (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"), - (0x20C1, "X"), - (0x20D0, "V"), - (0x20F1, "X"), - (0x2100, "M", "a/c"), - (0x2101, "M", "a/s"), - (0x2102, "M", "c"), - (0x2103, "M", "°c"), - (0x2104, "V"), - (0x2105, "M", "c/o"), - (0x2106, "M", "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, "M", "ⅎ"), - (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"), - ] - - -def _seg_23() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (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"), - (0x217A, "M", "xi"), - (0x217B, "M", "xii"), - (0x217C, "M", "l"), - (0x217D, "M", "c"), - (0x217E, "M", "d"), - (0x217F, "M", "m"), - (0x2180, "V"), - (0x2183, "M", "ↄ"), - (0x2184, "V"), - (0x2189, "M", "0⁄3"), - (0x218A, "V"), - (0x218C, "X"), - (0x2190, "V"), - (0x222C, "M", "∫∫"), - (0x222D, "M", "∫∫∫"), - (0x222E, "V"), - (0x222F, "M", "∮∮"), - (0x2230, "M", "∮∮∮"), - (0x2231, "V"), - (0x2329, "M", "〈"), - (0x232A, "M", "〉"), - (0x232B, "V"), - (0x242A, "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, "M", "(1)"), - (0x2475, "M", "(2)"), - (0x2476, "M", "(3)"), - (0x2477, "M", "(4)"), - (0x2478, "M", "(5)"), - (0x2479, "M", "(6)"), - (0x247A, "M", "(7)"), - (0x247B, "M", "(8)"), - (0x247C, "M", "(9)"), - (0x247D, "M", "(10)"), - (0x247E, "M", "(11)"), - (0x247F, "M", "(12)"), - (0x2480, "M", "(13)"), - (0x2481, "M", "(14)"), - (0x2482, "M", "(15)"), - (0x2483, "M", "(16)"), - (0x2484, "M", "(17)"), - (0x2485, "M", "(18)"), - (0x2486, "M", "(19)"), - (0x2487, "M", "(20)"), - (0x2488, "X"), - (0x249C, "M", "(a)"), - (0x249D, "M", "(b)"), - (0x249E, "M", "(c)"), - (0x249F, "M", "(d)"), - ] - - -def _seg_24() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (0x24A0, "M", "(e)"), - (0x24A1, "M", "(f)"), - (0x24A2, "M", "(g)"), - (0x24A3, "M", "(h)"), - (0x24A4, "M", "(i)"), - (0x24A5, "M", "(j)"), - (0x24A6, "M", "(k)"), - (0x24A7, "M", "(l)"), - (0x24A8, "M", "(m)"), - (0x24A9, "M", "(n)"), - (0x24AA, "M", "(o)"), - (0x24AB, "M", "(p)"), - (0x24AC, "M", "(q)"), - (0x24AD, "M", "(r)"), - (0x24AE, "M", "(s)"), - (0x24AF, "M", "(t)"), - (0x24B0, "M", "(u)"), - (0x24B1, "M", "(v)"), - (0x24B2, "M", "(w)"), - (0x24B3, "M", "(x)"), - (0x24B4, "M", "(y)"), - (0x24B5, "M", "(z)"), - (0x24B6, "M", "a"), - (0x24B7, "M", "b"), - (0x24B8, "M", "c"), - (0x24B9, "M", "d"), - (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, "M", "::="), - (0x2A75, "M", "=="), - (0x2A76, "M", "==="), - (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", "ⰻ"), - ] - - -def _seg_25() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (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", "ⱕ"), - (0x2C26, "M", "ⱖ"), - (0x2C27, "M", "ⱗ"), - (0x2C28, "M", "ⱘ"), - (0x2C29, "M", "ⱙ"), - (0x2C2A, "M", "ⱚ"), - (0x2C2B, "M", "ⱛ"), - (0x2C2C, "M", "ⱜ"), - (0x2C2D, "M", "ⱝ"), - (0x2C2E, "M", "ⱞ"), - (0x2C2F, "M", "ⱟ"), - (0x2C30, "V"), - (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"), - ] - - -def _seg_26() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (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", "ⲿ"), - (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"), - (0x2E5E, "X"), - ] - - -def _seg_27() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (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", "刀"), - (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", "牛"), - ] - - -def _seg_28() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (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", "竹"), - (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", "鬲"), - ] - - -def _seg_29() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (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, "M", " "), - (0x3001, "V"), - (0x3002, "M", "."), - (0x3003, "V"), - (0x3036, "M", "〒"), - (0x3037, "V"), - (0x3038, "M", "十"), - (0x3039, "M", "卄"), - (0x303A, "M", "卅"), - (0x303B, "V"), - (0x3040, "X"), - (0x3041, "V"), - (0x3097, "X"), - (0x3099, "V"), - (0x309B, "M", " ゙"), - (0x309C, "M", " ゚"), - (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, "I"), - (0x3165, "M", "ᄔ"), - (0x3166, "M", "ᄕ"), - (0x3167, "M", "ᇇ"), - ] - - -def _seg_30() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (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", "ᅇ"), - (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"), - (0x31E6, "X"), - (0x31F0, "V"), - (0x3200, "M", "(ᄀ)"), - (0x3201, "M", "(ᄂ)"), - (0x3202, "M", "(ᄃ)"), - (0x3203, "M", "(ᄅ)"), - (0x3204, "M", "(ᄆ)"), - (0x3205, "M", "(ᄇ)"), - (0x3206, "M", "(ᄉ)"), - (0x3207, "M", "(ᄋ)"), - (0x3208, "M", "(ᄌ)"), - (0x3209, "M", "(ᄎ)"), - (0x320A, "M", "(ᄏ)"), - (0x320B, "M", "(ᄐ)"), - (0x320C, "M", "(ᄑ)"), - (0x320D, "M", "(ᄒ)"), - (0x320E, "M", "(가)"), - (0x320F, "M", "(나)"), - (0x3210, "M", "(다)"), - (0x3211, "M", "(라)"), - (0x3212, "M", "(마)"), - (0x3213, "M", "(바)"), - (0x3214, "M", "(사)"), - (0x3215, "M", "(아)"), - (0x3216, "M", "(자)"), - (0x3217, "M", "(차)"), - (0x3218, "M", "(카)"), - (0x3219, "M", "(타)"), - (0x321A, "M", "(파)"), - (0x321B, "M", "(하)"), - (0x321C, "M", "(주)"), - (0x321D, "M", "(오전)"), - (0x321E, "M", "(오후)"), - (0x321F, "X"), - (0x3220, "M", "(一)"), - (0x3221, "M", "(二)"), - (0x3222, "M", "(三)"), - (0x3223, "M", "(四)"), - (0x3224, "M", "(五)"), - (0x3225, "M", "(六)"), - (0x3226, "M", "(七)"), - (0x3227, "M", "(八)"), - (0x3228, "M", "(九)"), - (0x3229, "M", "(十)"), - ] - - -def _seg_31() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (0x322A, "M", "(月)"), - (0x322B, "M", "(火)"), - (0x322C, "M", "(水)"), - (0x322D, "M", "(木)"), - (0x322E, "M", "(金)"), - (0x322F, "M", "(土)"), - (0x3230, "M", "(日)"), - (0x3231, "M", "(株)"), - (0x3232, "M", "(有)"), - (0x3233, "M", "(社)"), - (0x3234, "M", "(名)"), - (0x3235, "M", "(特)"), - (0x3236, "M", "(財)"), - (0x3237, "M", "(祝)"), - (0x3238, "M", "(労)"), - (0x3239, "M", "(代)"), - (0x323A, "M", "(呼)"), - (0x323B, "M", "(学)"), - (0x323C, "M", "(監)"), - (0x323D, "M", "(企)"), - (0x323E, "M", "(資)"), - (0x323F, "M", "(協)"), - (0x3240, "M", "(祭)"), - (0x3241, "M", "(休)"), - (0x3242, "M", "(自)"), - (0x3243, "M", "(至)"), - (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", "名"), - ] - - -def _seg_32() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (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", "企"), - (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", "ル"), - ] - - -def _seg_33() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (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", "ギニー"), - (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点"), - ] - - -def _seg_34() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (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"), - (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ω"), - ] - - -def _seg_35() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (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"), - (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"), - (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", "ꙟ"), - ] - - -def _seg_36() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (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"), - (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"), - ] - - -def _seg_37() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (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", "ꝯ"), - (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, "M", "ꟁ"), - (0xA7C1, "V"), - (0xA7C2, "M", "ꟃ"), - (0xA7C3, "V"), - (0xA7C4, "M", "ꞔ"), - (0xA7C5, "M", "ʂ"), - (0xA7C6, "M", "ᶎ"), - (0xA7C7, "M", "ꟈ"), - (0xA7C8, "V"), - ] - - -def _seg_38() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (0xA7C9, "M", "ꟊ"), - (0xA7CA, "V"), - (0xA7CB, "M", "ɤ"), - (0xA7CC, "M", "ꟍ"), - (0xA7CD, "V"), - (0xA7CE, "X"), - (0xA7D0, "M", "ꟑ"), - (0xA7D1, "V"), - (0xA7D2, "X"), - (0xA7D3, "V"), - (0xA7D4, "X"), - (0xA7D5, "V"), - (0xA7D6, "M", "ꟗ"), - (0xA7D7, "V"), - (0xA7D8, "M", "ꟙ"), - (0xA7D9, "V"), - (0xA7DA, "M", "ꟛ"), - (0xA7DB, "V"), - (0xA7DC, "M", "ƛ"), - (0xA7DD, "X"), - (0xA7F2, "M", "c"), - (0xA7F3, "M", "f"), - (0xA7F4, "M", "q"), - (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"), - (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", "Ꮇ"), - ] - - -def _seg_39() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (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", "Ꮳ"), - (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", "濫"), - ] - - -def _seg_40() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (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", "漏"), - (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", "閭"), - ] - - -def _seg_41() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (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", "零"), - (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", "離"), - ] - - -def _seg_42() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (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", "礼"), - (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", "禎"), - ] - - -def _seg_43() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (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", "嬨"), - (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", "調"), - ] - - -def _seg_44() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (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", "վն"), - (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, "M", "+"), - (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", "پ"), - ] - - -def _seg_45() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (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"), - (0xFBC3, "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", "ئۆ"), - (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", "قح"), - ] - - -def _seg_46() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (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, "M", " ٌّ"), - (0xFC5F, "M", " ٍّ"), - (0xFC60, "M", " َّ"), - (0xFC61, "M", " ُّ"), - (0xFC62, "M", " ِّ"), - (0xFC63, "M", " ّٰ"), - (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", "ئج"), - ] - - -def _seg_47() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (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", "قم"), - (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", "سى"), - ] - - -def _seg_48() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (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", "شخ"), - (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"), - (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", "فخم"), - ] - - -def _seg_49() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (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", "يحي"), - (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"), - (0xFDCF, "V"), - (0xFDD0, "X"), - (0xFDF0, "M", "صلے"), - (0xFDF1, "M", "قلے"), - (0xFDF2, "M", "الله"), - (0xFDF3, "M", "اكبر"), - (0xFDF4, "M", "محمد"), - (0xFDF5, "M", "صلعم"), - (0xFDF6, "M", "رسول"), - (0xFDF7, "M", "عليه"), - (0xFDF8, "M", "وسلم"), - (0xFDF9, "M", "صلى"), - (0xFDFA, "M", "صلى الله عليه وسلم"), - (0xFDFB, "M", "جل جلاله"), - (0xFDFC, "M", "ریال"), - (0xFDFD, "V"), - (0xFE00, "I"), - (0xFE10, "M", ","), - (0xFE11, "M", "、"), - (0xFE12, "X"), - (0xFE13, "M", ":"), - (0xFE14, "M", ";"), - (0xFE15, "M", "!"), - (0xFE16, "M", "?"), - (0xFE17, "M", "〖"), - (0xFE18, "M", "〗"), - (0xFE19, "X"), - (0xFE20, "V"), - (0xFE30, "X"), - (0xFE31, "M", "—"), - (0xFE32, "M", "–"), - ] - - -def _seg_50() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (0xFE33, "M", "_"), - (0xFE35, "M", "("), - (0xFE36, "M", ")"), - (0xFE37, "M", "{"), - (0xFE38, "M", "}"), - (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, "M", "["), - (0xFE48, "M", "]"), - (0xFE49, "M", " ̅"), - (0xFE4D, "M", "_"), - (0xFE50, "M", ","), - (0xFE51, "M", "、"), - (0xFE52, "X"), - (0xFE54, "M", ";"), - (0xFE55, "M", ":"), - (0xFE56, "M", "?"), - (0xFE57, "M", "!"), - (0xFE58, "M", "—"), - (0xFE59, "M", "("), - (0xFE5A, "M", ")"), - (0xFE5B, "M", "{"), - (0xFE5C, "M", "}"), - (0xFE5D, "M", "〔"), - (0xFE5E, "M", "〕"), - (0xFE5F, "M", "#"), - (0xFE60, "M", "&"), - (0xFE61, "M", "*"), - (0xFE62, "M", "+"), - (0xFE63, "M", "-"), - (0xFE64, "M", "<"), - (0xFE65, "M", ">"), - (0xFE66, "M", "="), - (0xFE67, "X"), - (0xFE68, "M", "\\"), - (0xFE69, "M", "$"), - (0xFE6A, "M", "%"), - (0xFE6B, "M", "@"), - (0xFE6C, "X"), - (0xFE70, "M", " ً"), - (0xFE71, "M", "ـً"), - (0xFE72, "M", " ٌ"), - (0xFE73, "V"), - (0xFE74, "M", " ٍ"), - (0xFE75, "X"), - (0xFE76, "M", " َ"), - (0xFE77, "M", "ـَ"), - (0xFE78, "M", " ُ"), - (0xFE79, "M", "ـُ"), - (0xFE7A, "M", " ِ"), - (0xFE7B, "M", "ـِ"), - (0xFE7C, "M", " ّ"), - (0xFE7D, "M", "ـّ"), - (0xFE7E, "M", " ْ"), - (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", "و"), - ] - - -def _seg_51() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (0xFEEF, "M", "ى"), - (0xFEF1, "M", "ي"), - (0xFEF5, "M", "لآ"), - (0xFEF7, "M", "لأ"), - (0xFEF9, "M", "لإ"), - (0xFEFB, "M", "لا"), - (0xFEFD, "X"), - (0xFEFF, "I"), - (0xFF00, "X"), - (0xFF01, "M", "!"), - (0xFF02, "M", '"'), - (0xFF03, "M", "#"), - (0xFF04, "M", "$"), - (0xFF05, "M", "%"), - (0xFF06, "M", "&"), - (0xFF07, "M", "'"), - (0xFF08, "M", "("), - (0xFF09, "M", ")"), - (0xFF0A, "M", "*"), - (0xFF0B, "M", "+"), - (0xFF0C, "M", ","), - (0xFF0D, "M", "-"), - (0xFF0E, "M", "."), - (0xFF0F, "M", "/"), - (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, "M", ":"), - (0xFF1B, "M", ";"), - (0xFF1C, "M", "<"), - (0xFF1D, "M", "="), - (0xFF1E, "M", ">"), - (0xFF1F, "M", "?"), - (0xFF20, "M", "@"), - (0xFF21, "M", "a"), - (0xFF22, "M", "b"), - (0xFF23, "M", "c"), - (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, "M", "["), - (0xFF3C, "M", "\\"), - (0xFF3D, "M", "]"), - (0xFF3E, "M", "^"), - (0xFF3F, "M", "_"), - (0xFF40, "M", "`"), - (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, "M", "{"), - ] - - -def _seg_52() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (0xFF5C, "M", "|"), - (0xFF5D, "M", "}"), - (0xFF5E, "M", "~"), - (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", "ヌ"), - (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, "I"), - (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"), - ] - - -def _seg_53() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (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, "M", " ̄"), - (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"), - (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", "𐐶"), - ] - - -def _seg_54() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (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", "𐓦"), - (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, "M", "𐖗"), - (0x10571, "M", "𐖘"), - (0x10572, "M", "𐖙"), - (0x10573, "M", "𐖚"), - (0x10574, "M", "𐖛"), - (0x10575, "M", "𐖜"), - (0x10576, "M", "𐖝"), - (0x10577, "M", "𐖞"), - (0x10578, "M", "𐖟"), - (0x10579, "M", "𐖠"), - (0x1057A, "M", "𐖡"), - (0x1057B, "X"), - (0x1057C, "M", "𐖣"), - (0x1057D, "M", "𐖤"), - (0x1057E, "M", "𐖥"), - (0x1057F, "M", "𐖦"), - (0x10580, "M", "𐖧"), - (0x10581, "M", "𐖨"), - (0x10582, "M", "𐖩"), - (0x10583, "M", "𐖪"), - (0x10584, "M", "𐖫"), - (0x10585, "M", "𐖬"), - (0x10586, "M", "𐖭"), - (0x10587, "M", "𐖮"), - (0x10588, "M", "𐖯"), - (0x10589, "M", "𐖰"), - (0x1058A, "M", "𐖱"), - ] - - -def _seg_55() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (0x1058B, "X"), - (0x1058C, "M", "𐖳"), - (0x1058D, "M", "𐖴"), - (0x1058E, "M", "𐖵"), - (0x1058F, "M", "𐖶"), - (0x10590, "M", "𐖷"), - (0x10591, "M", "𐖸"), - (0x10592, "M", "𐖹"), - (0x10593, "X"), - (0x10594, "M", "𐖻"), - (0x10595, "M", "𐖼"), - (0x10596, "X"), - (0x10597, "V"), - (0x105A2, "X"), - (0x105A3, "V"), - (0x105B2, "X"), - (0x105B3, "V"), - (0x105BA, "X"), - (0x105BB, "V"), - (0x105BD, "X"), - (0x105C0, "V"), - (0x105F4, "X"), - (0x10600, "V"), - (0x10737, "X"), - (0x10740, "V"), - (0x10756, "X"), - (0x10760, "V"), - (0x10768, "X"), - (0x10780, "V"), - (0x10781, "M", "ː"), - (0x10782, "M", "ˑ"), - (0x10783, "M", "æ"), - (0x10784, "M", "ʙ"), - (0x10785, "M", "ɓ"), - (0x10786, "X"), - (0x10787, "M", "ʣ"), - (0x10788, "M", "ꭦ"), - (0x10789, "M", "ʥ"), - (0x1078A, "M", "ʤ"), - (0x1078B, "M", "ɖ"), - (0x1078C, "M", "ɗ"), - (0x1078D, "M", "ᶑ"), - (0x1078E, "M", "ɘ"), - (0x1078F, "M", "ɞ"), - (0x10790, "M", "ʩ"), - (0x10791, "M", "ɤ"), - (0x10792, "M", "ɢ"), - (0x10793, "M", "ɠ"), - (0x10794, "M", "ʛ"), - (0x10795, "M", "ħ"), - (0x10796, "M", "ʜ"), - (0x10797, "M", "ɧ"), - (0x10798, "M", "ʄ"), - (0x10799, "M", "ʪ"), - (0x1079A, "M", "ʫ"), - (0x1079B, "M", "ɬ"), - (0x1079C, "M", "𝼄"), - (0x1079D, "M", "ꞎ"), - (0x1079E, "M", "ɮ"), - (0x1079F, "M", "𝼅"), - (0x107A0, "M", "ʎ"), - (0x107A1, "M", "𝼆"), - (0x107A2, "M", "ø"), - (0x107A3, "M", "ɶ"), - (0x107A4, "M", "ɷ"), - (0x107A5, "M", "q"), - (0x107A6, "M", "ɺ"), - (0x107A7, "M", "𝼈"), - (0x107A8, "M", "ɽ"), - (0x107A9, "M", "ɾ"), - (0x107AA, "M", "ʀ"), - (0x107AB, "M", "ʨ"), - (0x107AC, "M", "ʦ"), - (0x107AD, "M", "ꭧ"), - (0x107AE, "M", "ʧ"), - (0x107AF, "M", "ʈ"), - (0x107B0, "M", "ⱱ"), - (0x107B1, "X"), - (0x107B2, "M", "ʏ"), - (0x107B3, "M", "ʡ"), - (0x107B4, "M", "ʢ"), - (0x107B5, "M", "ʘ"), - (0x107B6, "M", "ǀ"), - (0x107B7, "M", "ǁ"), - (0x107B8, "M", "ǂ"), - (0x107B9, "M", "𝼊"), - (0x107BA, "M", "𝼞"), - (0x107BB, "X"), - (0x10800, "V"), - (0x10806, "X"), - (0x10808, "V"), - (0x10809, "X"), - (0x1080A, "V"), - (0x10836, "X"), - (0x10837, "V"), - (0x10839, "X"), - (0x1083C, "V"), - (0x1083D, "X"), - (0x1083F, "V"), - (0x10856, "X"), - ] - - -def _seg_56() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (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"), - (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", "𐳭"), - ] - - -def _seg_57() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (0x10CAE, "M", "𐳮"), - (0x10CAF, "M", "𐳯"), - (0x10CB0, "M", "𐳰"), - (0x10CB1, "M", "𐳱"), - (0x10CB2, "M", "𐳲"), - (0x10CB3, "X"), - (0x10CC0, "V"), - (0x10CF3, "X"), - (0x10CFA, "V"), - (0x10D28, "X"), - (0x10D30, "V"), - (0x10D3A, "X"), - (0x10D40, "V"), - (0x10D50, "M", "𐵰"), - (0x10D51, "M", "𐵱"), - (0x10D52, "M", "𐵲"), - (0x10D53, "M", "𐵳"), - (0x10D54, "M", "𐵴"), - (0x10D55, "M", "𐵵"), - (0x10D56, "M", "𐵶"), - (0x10D57, "M", "𐵷"), - (0x10D58, "M", "𐵸"), - (0x10D59, "M", "𐵹"), - (0x10D5A, "M", "𐵺"), - (0x10D5B, "M", "𐵻"), - (0x10D5C, "M", "𐵼"), - (0x10D5D, "M", "𐵽"), - (0x10D5E, "M", "𐵾"), - (0x10D5F, "M", "𐵿"), - (0x10D60, "M", "𐶀"), - (0x10D61, "M", "𐶁"), - (0x10D62, "M", "𐶂"), - (0x10D63, "M", "𐶃"), - (0x10D64, "M", "𐶄"), - (0x10D65, "M", "𐶅"), - (0x10D66, "X"), - (0x10D69, "V"), - (0x10D86, "X"), - (0x10D8E, "V"), - (0x10D90, "X"), - (0x10E60, "V"), - (0x10E7F, "X"), - (0x10E80, "V"), - (0x10EAA, "X"), - (0x10EAB, "V"), - (0x10EAE, "X"), - (0x10EB0, "V"), - (0x10EB2, "X"), - (0x10EC2, "V"), - (0x10EC5, "X"), - (0x10EFC, "V"), - (0x10F28, "X"), - (0x10F30, "V"), - (0x10F5A, "X"), - (0x10F70, "V"), - (0x10F8A, "X"), - (0x10FB0, "V"), - (0x10FCC, "X"), - (0x10FE0, "V"), - (0x10FF7, "X"), - (0x11000, "V"), - (0x1104E, "X"), - (0x11052, "V"), - (0x11076, "X"), - (0x1107F, "V"), - (0x110BD, "X"), - (0x110BE, "V"), - (0x110C3, "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"), - (0x11213, "V"), - (0x11242, "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"), - ] - - -def _seg_58() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (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"), - (0x11380, "V"), - (0x1138A, "X"), - (0x1138B, "V"), - (0x1138C, "X"), - (0x1138E, "V"), - (0x1138F, "X"), - (0x11390, "V"), - (0x113B6, "X"), - (0x113B7, "V"), - (0x113C1, "X"), - (0x113C2, "V"), - (0x113C3, "X"), - (0x113C5, "V"), - (0x113C6, "X"), - (0x113C7, "V"), - (0x113CB, "X"), - (0x113CC, "V"), - (0x113D6, "X"), - (0x113D7, "V"), - (0x113D9, "X"), - (0x113E1, "V"), - (0x113E3, "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"), - (0x116BA, "X"), - (0x116C0, "V"), - (0x116CA, "X"), - (0x116D0, "V"), - (0x116E4, "X"), - (0x11700, "V"), - (0x1171B, "X"), - (0x1171D, "V"), - (0x1172C, "X"), - (0x11730, "V"), - (0x11747, "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", "𑣏"), - ] - - -def _seg_59() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (0x118B0, "M", "𑣐"), - (0x118B1, "M", "𑣑"), - (0x118B2, "M", "𑣒"), - (0x118B3, "M", "𑣓"), - (0x118B4, "M", "𑣔"), - (0x118B5, "M", "𑣕"), - (0x118B6, "M", "𑣖"), - (0x118B7, "M", "𑣗"), - (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"), - (0x11AB0, "V"), - (0x11AF9, "X"), - (0x11B00, "V"), - (0x11B0A, "X"), - (0x11BC0, "V"), - (0x11BE2, "X"), - (0x11BF0, "V"), - (0x11BFA, "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"), - (0x11F00, "V"), - (0x11F11, "X"), - (0x11F12, "V"), - (0x11F3B, "X"), - (0x11F3E, "V"), - (0x11F5B, "X"), - ] - - -def _seg_60() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (0x11FB0, "V"), - (0x11FB1, "X"), - (0x11FC0, "V"), - (0x11FF2, "X"), - (0x11FFF, "V"), - (0x1239A, "X"), - (0x12400, "V"), - (0x1246F, "X"), - (0x12470, "V"), - (0x12475, "X"), - (0x12480, "V"), - (0x12544, "X"), - (0x12F90, "V"), - (0x12FF3, "X"), - (0x13000, "V"), - (0x13430, "X"), - (0x13440, "V"), - (0x13456, "X"), - (0x13460, "V"), - (0x143FB, "X"), - (0x14400, "V"), - (0x14647, "X"), - (0x16100, "V"), - (0x1613A, "X"), - (0x16800, "V"), - (0x16A39, "X"), - (0x16A40, "V"), - (0x16A5F, "X"), - (0x16A60, "V"), - (0x16A6A, "X"), - (0x16A6E, "V"), - (0x16ABF, "X"), - (0x16AC0, "V"), - (0x16ACA, "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"), - (0x16D40, "V"), - (0x16D7A, "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"), - (0x18CFF, "V"), - (0x18D09, "X"), - ] - - -def _seg_61() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (0x1AFF0, "V"), - (0x1AFF4, "X"), - (0x1AFF5, "V"), - (0x1AFFC, "X"), - (0x1AFFD, "V"), - (0x1AFFF, "X"), - (0x1B000, "V"), - (0x1B123, "X"), - (0x1B132, "V"), - (0x1B133, "X"), - (0x1B150, "V"), - (0x1B153, "X"), - (0x1B155, "V"), - (0x1B156, "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"), - (0x1CC00, "V"), - (0x1CCD6, "M", "a"), - (0x1CCD7, "M", "b"), - (0x1CCD8, "M", "c"), - (0x1CCD9, "M", "d"), - (0x1CCDA, "M", "e"), - (0x1CCDB, "M", "f"), - (0x1CCDC, "M", "g"), - (0x1CCDD, "M", "h"), - (0x1CCDE, "M", "i"), - (0x1CCDF, "M", "j"), - (0x1CCE0, "M", "k"), - (0x1CCE1, "M", "l"), - (0x1CCE2, "M", "m"), - (0x1CCE3, "M", "n"), - (0x1CCE4, "M", "o"), - (0x1CCE5, "M", "p"), - (0x1CCE6, "M", "q"), - (0x1CCE7, "M", "r"), - (0x1CCE8, "M", "s"), - (0x1CCE9, "M", "t"), - (0x1CCEA, "M", "u"), - (0x1CCEB, "M", "v"), - (0x1CCEC, "M", "w"), - (0x1CCED, "M", "x"), - (0x1CCEE, "M", "y"), - (0x1CCEF, "M", "z"), - (0x1CCF0, "M", "0"), - (0x1CCF1, "M", "1"), - (0x1CCF2, "M", "2"), - (0x1CCF3, "M", "3"), - (0x1CCF4, "M", "4"), - (0x1CCF5, "M", "5"), - (0x1CCF6, "M", "6"), - (0x1CCF7, "M", "7"), - (0x1CCF8, "M", "8"), - (0x1CCF9, "M", "9"), - (0x1CCFA, "X"), - (0x1CD00, "V"), - (0x1CEB4, "X"), - (0x1CF00, "V"), - (0x1CF2E, "X"), - (0x1CF30, "V"), - (0x1CF47, "X"), - (0x1CF50, "V"), - (0x1CFC4, "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"), - (0x1D173, "I"), - (0x1D17B, "V"), - (0x1D1BB, "M", "𝆹𝅥"), - (0x1D1BC, "M", "𝆺𝅥"), - (0x1D1BD, "M", "𝆹𝅥𝅮"), - (0x1D1BE, "M", "𝆺𝅥𝅮"), - (0x1D1BF, "M", "𝆹𝅥𝅯"), - (0x1D1C0, "M", "𝆺𝅥𝅯"), - (0x1D1C1, "V"), - (0x1D1EB, "X"), - (0x1D200, "V"), - (0x1D246, "X"), - ] - - -def _seg_62() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (0x1D2C0, "V"), - (0x1D2D4, "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"), - (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"), - ] - - -def _seg_63() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (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"), - (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"), - ] - - -def _seg_64() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (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"), - (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"), - ] - - -def _seg_65() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (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"), - (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"), - ] - - -def _seg_66() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (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"), - (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"), - ] - - -def _seg_67() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (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"), - (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"), - ] - - -def _seg_68() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (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", "ι"), - (0x1D6B1, "M", "κ"), - (0x1D6B2, "M", "λ"), - (0x1D6B3, "M", "μ"), - (0x1D6B4, "M", "ν"), - (0x1D6B5, "M", "ξ"), - (0x1D6B6, "M", "ο"), - (0x1D6B7, "M", "π"), - (0x1D6B8, "M", "ρ"), - (0x1D6B9, "M", "θ"), - (0x1D6BA, "M", "σ"), - ] - - -def _seg_69() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (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", "ε"), - (0x1D717, "M", "θ"), - (0x1D718, "M", "κ"), - (0x1D719, "M", "φ"), - (0x1D71A, "M", "ρ"), - (0x1D71B, "M", "π"), - (0x1D71C, "M", "α"), - (0x1D71D, "M", "β"), - (0x1D71E, "M", "γ"), - (0x1D71F, "M", "δ"), - (0x1D720, "M", "ε"), - ] - - -def _seg_70() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (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", "μ"), - (0x1D77C, "M", "ν"), - (0x1D77D, "M", "ξ"), - (0x1D77E, "M", "ο"), - (0x1D77F, "M", "π"), - (0x1D780, "M", "ρ"), - (0x1D781, "M", "σ"), - (0x1D783, "M", "τ"), - (0x1D784, "M", "υ"), - (0x1D785, "M", "φ"), - (0x1D786, "M", "χ"), - ] - - -def _seg_71() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (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"), - (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"), - ] - - -def _seg_72() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (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"), - (0x1DF00, "V"), - (0x1DF1F, "X"), - (0x1DF25, "V"), - (0x1DF2B, "X"), - (0x1E000, "V"), - (0x1E007, "X"), - (0x1E008, "V"), - (0x1E019, "X"), - (0x1E01B, "V"), - (0x1E022, "X"), - (0x1E023, "V"), - (0x1E025, "X"), - (0x1E026, "V"), - (0x1E02B, "X"), - (0x1E030, "M", "а"), - (0x1E031, "M", "б"), - (0x1E032, "M", "в"), - (0x1E033, "M", "г"), - (0x1E034, "M", "д"), - (0x1E035, "M", "е"), - (0x1E036, "M", "ж"), - (0x1E037, "M", "з"), - (0x1E038, "M", "и"), - (0x1E039, "M", "к"), - (0x1E03A, "M", "л"), - (0x1E03B, "M", "м"), - (0x1E03C, "M", "о"), - (0x1E03D, "M", "п"), - (0x1E03E, "M", "р"), - (0x1E03F, "M", "с"), - (0x1E040, "M", "т"), - (0x1E041, "M", "у"), - (0x1E042, "M", "ф"), - (0x1E043, "M", "х"), - (0x1E044, "M", "ц"), - (0x1E045, "M", "ч"), - (0x1E046, "M", "ш"), - (0x1E047, "M", "ы"), - (0x1E048, "M", "э"), - (0x1E049, "M", "ю"), - (0x1E04A, "M", "ꚉ"), - (0x1E04B, "M", "ә"), - (0x1E04C, "M", "і"), - (0x1E04D, "M", "ј"), - (0x1E04E, "M", "ө"), - (0x1E04F, "M", "ү"), - (0x1E050, "M", "ӏ"), - (0x1E051, "M", "а"), - (0x1E052, "M", "б"), - (0x1E053, "M", "в"), - (0x1E054, "M", "г"), - (0x1E055, "M", "д"), - (0x1E056, "M", "е"), - (0x1E057, "M", "ж"), - (0x1E058, "M", "з"), - (0x1E059, "M", "и"), - (0x1E05A, "M", "к"), - (0x1E05B, "M", "л"), - (0x1E05C, "M", "о"), - (0x1E05D, "M", "п"), - (0x1E05E, "M", "с"), - (0x1E05F, "M", "у"), - (0x1E060, "M", "ф"), - (0x1E061, "M", "х"), - (0x1E062, "M", "ц"), - (0x1E063, "M", "ч"), - (0x1E064, "M", "ш"), - (0x1E065, "M", "ъ"), - (0x1E066, "M", "ы"), - (0x1E067, "M", "ґ"), - (0x1E068, "M", "і"), - (0x1E069, "M", "ѕ"), - (0x1E06A, "M", "џ"), - (0x1E06B, "M", "ҫ"), - (0x1E06C, "M", "ꙑ"), - (0x1E06D, "M", "ұ"), - ] - - -def _seg_73() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (0x1E06E, "X"), - (0x1E08F, "V"), - (0x1E090, "X"), - (0x1E100, "V"), - (0x1E12D, "X"), - (0x1E130, "V"), - (0x1E13E, "X"), - (0x1E140, "V"), - (0x1E14A, "X"), - (0x1E14E, "V"), - (0x1E150, "X"), - (0x1E290, "V"), - (0x1E2AF, "X"), - (0x1E2C0, "V"), - (0x1E2FA, "X"), - (0x1E2FF, "V"), - (0x1E300, "X"), - (0x1E4D0, "V"), - (0x1E4FA, "X"), - (0x1E5D0, "V"), - (0x1E5FB, "X"), - (0x1E5FF, "V"), - (0x1E600, "X"), - (0x1E7E0, "V"), - (0x1E7E7, "X"), - (0x1E7E8, "V"), - (0x1E7EC, "X"), - (0x1E7ED, "V"), - (0x1E7EF, "X"), - (0x1E7F0, "V"), - (0x1E7FF, "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"), - (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", "ش"), - ] - - -def _seg_74() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (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", "ك"), - (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", "د"), - ] - - -def _seg_75() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (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, "M", "0,"), - (0x1F102, "M", "1,"), - (0x1F103, "M", "2,"), - (0x1F104, "M", "3,"), - (0x1F105, "M", "4,"), - (0x1F106, "M", "5,"), - (0x1F107, "M", "6,"), - (0x1F108, "M", "7,"), - (0x1F109, "M", "8,"), - (0x1F10A, "M", "9,"), - (0x1F10B, "V"), - (0x1F110, "M", "(a)"), - (0x1F111, "M", "(b)"), - (0x1F112, "M", "(c)"), - (0x1F113, "M", "(d)"), - (0x1F114, "M", "(e)"), - (0x1F115, "M", "(f)"), - (0x1F116, "M", "(g)"), - (0x1F117, "M", "(h)"), - (0x1F118, "M", "(i)"), - (0x1F119, "M", "(j)"), - (0x1F11A, "M", "(k)"), - (0x1F11B, "M", "(l)"), - (0x1F11C, "M", "(m)"), - (0x1F11D, "M", "(n)"), - (0x1F11E, "M", "(o)"), - (0x1F11F, "M", "(p)"), - (0x1F120, "M", "(q)"), - (0x1F121, "M", "(r)"), - (0x1F122, "M", "(s)"), - (0x1F123, "M", "(t)"), - (0x1F124, "M", "(u)"), - (0x1F125, "M", "(v)"), - ] - - -def _seg_76() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (0x1F126, "M", "(w)"), - (0x1F127, "M", "(x)"), - (0x1F128, "M", "(y)"), - (0x1F129, "M", "(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", "販"), - (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"), - ] - - -def _seg_77() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (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"), - (0x1F6DC, "V"), - (0x1F6ED, "X"), - (0x1F6F0, "V"), - (0x1F6FD, "X"), - (0x1F700, "V"), - (0x1F777, "X"), - (0x1F77B, "V"), - (0x1F7DA, "X"), - (0x1F7E0, "V"), - (0x1F7EC, "X"), - (0x1F7F0, "V"), - (0x1F7F1, "X"), - (0x1F800, "V"), - (0x1F80C, "X"), - (0x1F810, "V"), - (0x1F848, "X"), - (0x1F850, "V"), - (0x1F85A, "X"), - (0x1F860, "V"), - (0x1F888, "X"), - (0x1F890, "V"), - (0x1F8AE, "X"), - (0x1F8B0, "V"), - (0x1F8BC, "X"), - (0x1F8C0, "V"), - (0x1F8C2, "X"), - (0x1F900, "V"), - (0x1FA54, "X"), - (0x1FA60, "V"), - (0x1FA6E, "X"), - (0x1FA70, "V"), - (0x1FA7D, "X"), - (0x1FA80, "V"), - (0x1FA8A, "X"), - (0x1FA8F, "V"), - (0x1FAC7, "X"), - (0x1FACE, "V"), - (0x1FADD, "X"), - (0x1FADF, "V"), - (0x1FAEA, "X"), - (0x1FAF0, "V"), - (0x1FAF9, "X"), - (0x1FB00, "V"), - (0x1FB93, "X"), - (0x1FB94, "V"), - (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"), - (0x1FBFA, "X"), - (0x20000, "V"), - (0x2A6E0, "X"), - (0x2A700, "V"), - (0x2B73A, "X"), - (0x2B740, "V"), - (0x2B81E, "X"), - (0x2B820, "V"), - (0x2CEA2, "X"), - (0x2CEB0, "V"), - (0x2EBE1, "X"), - (0x2EBF0, "V"), - (0x2EE5E, "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", "免"), - ] - - -def _seg_78() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (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", "壷"), - (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, "M", "㛼"), - (0x2F869, "M", "嬈"), - (0x2F86A, "M", "嬾"), - (0x2F86C, "M", "𡧈"), - (0x2F86D, "M", "寃"), - (0x2F86E, "M", "寘"), - (0x2F86F, "M", "寧"), - (0x2F870, "M", "寳"), - (0x2F871, "M", "𡬘"), - (0x2F872, "M", "寿"), - (0x2F873, "M", "将"), - (0x2F874, "M", "当"), - (0x2F875, "M", "尢"), - (0x2F876, "M", "㞁"), - ] - - -def _seg_79() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (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", "㨮"), - (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", "杓"), - ] - - -def _seg_80() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (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, "M", "𤎫"), - (0x2F920, "M", "爨"), - (0x2F921, "M", "爵"), - (0x2F922, "M", "牐"), - (0x2F923, "M", "𤘈"), - (0x2F924, "M", "犀"), - (0x2F925, "M", "犕"), - (0x2F926, "M", "𤜵"), - (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", "𥃳"), - ] - - -def _seg_81() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (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, "M", "竮"), - (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", "辞"), - (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", "䔫"), - ] - - -def _seg_82() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (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, "M", "䗗"), - (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", "𨵷"), - (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", "鳽"), - ] - - -def _seg_83() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: - return [ - (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"), - (0x31350, "V"), - (0x323B0, "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() - + _seg_80() - + _seg_81() - + _seg_82() - + _seg_83() -) # type: Tuple[Union[Tuple[int, str], Tuple[int, str, str]], ...] diff --git a/venv/lib/python3.12/site-packages/pip-24.0.dist-info/AUTHORS.txt b/venv/lib/python3.12/site-packages/pip-24.0.dist-info/AUTHORS.txt deleted file mode 100644 index 0e63548..0000000 --- a/venv/lib/python3.12/site-packages/pip-24.0.dist-info/AUTHORS.txt +++ /dev/null @@ -1,760 +0,0 @@ -@Switch01 -A_Rog -Aakanksha Agrawal -Abhinav Sagar -ABHYUDAY PRATAP SINGH -abs51295 -AceGentile -Adam Chainz -Adam Tse -Adam Wentz -admin -Adrien Morison -ahayrapetyan -Ahilya -AinsworthK -Akash Srivastava -Alan Yee -Albert Tugushev -Albert-Guan -albertg -Alberto Sottile -Aleks Bunin -Ales Erjavec -Alethea Flowers -Alex Gaynor -Alex Grönholm -Alex Hedges -Alex Loosley -Alex Morega -Alex Stachowiak -Alexander Shtyrov -Alexandre Conrad -Alexey Popravka -Aleš Erjavec -Alli -Ami Fischman -Ananya Maiti -Anatoly Techtonik -Anders Kaseorg -Andre Aguiar -Andreas Lutro -Andrei Geacar -Andrew Gaul -Andrew Shymanel -Andrey Bienkowski -Andrey Bulgakov -Andrés Delfino -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 -Anudit Nagar -Anuj Godase -AQNOUCH Mohammed -AraHaan -Arindam Choudhury -Armin Ronacher -Artem -Arun Babu Neelicattu -Ashley Manton -Ashwin Ramaswami -atse -Atsushi Odagiri -Avinash Karhana -Avner Cohen -Awit (Ah-Wit) Ghirmai -Baptiste Mispelon -Barney Gale -barneygale -Bartek Ogryczak -Bastian Venthur -Ben Bodenmiller -Ben Darnell -Ben Hoyt -Ben Mares -Ben Rosser -Bence Nagy -Benjamin Peterson -Benjamin VanEvery -Benoit Pierre -Berker Peksag -Bernard -Bernard Tyers -Bernardo B. Marques -Bernhard M. Wiedemann -Bertil Hatt -Bhavam Vidyarthi -Blazej Michalik -Bogdan Opanchuk -BorisZZZ -Brad Erickson -Bradley Ayers -Brandon L. Reiss -Brandt Bucher -Brett Randall -Brett Rosen -Brian Cristante -Brian Rosner -briantracy -BrownTruck -Bruno Oliveira -Bruno Renié -Bruno S -Bstrdsmkr -Buck Golemon -burrows -Bussonnier Matthias -bwoodsend -c22 -Caleb Martinez -Calvin Smith -Carl Meyer -Carlos Liam -Carol Willing -Carter Thayer -Cass -Chandrasekhar Atina -Chih-Hsuan Yen -Chris Brinker -Chris Hunt -Chris Jerdonek -Chris Kuehl -Chris McDonough -Chris Pawley -Chris Pryer -Chris Wolfe -Christian Clauss -Christian Heimes -Christian Oudard -Christoph Reiter -Christopher Hunt -Christopher Snyder -cjc7373 -Clark Boylan -Claudio Jolowicz -Clay McClure -Cody -Cody Soyland -Colin Watson -Collin Anderson -Connor Osborn -Cooper Lees -Cooper Ry Lees -Cory Benfield -Cory Wright -Craig Kerstiens -Cristian Sorinel -Cristina -Cristina Muñoz -Curtis Doty -cytolentino -Daan De Meyer -Dale -Damian -Damian Quiroga -Damian Shaw -Dan Black -Dan Savilonis -Dan Sully -Dane Hillard -daniel -Daniel Collins -Daniel Hahler -Daniel Holth -Daniel Jost -Daniel Katz -Daniel Shaulov -Daniele Esposti -Daniele Nicolodi -Daniele Procida -Daniil Konovalenko -Danny Hermes -Danny McClanahan -Darren Kavanagh -Dav Clark -Dave Abrahams -Dave Jones -David Aguilar -David Black -David Bordeynik -David Caro -David D Lowe -David Evans -David Hewitt -David Linke -David Poggi -David Pursehouse -David Runge -David Tucker -David Wales -Davidovich -ddelange -Deepak Sharma -Deepyaman Datta -Denise Yu -dependabot[bot] -derwolfe -Desetude -Devesh Kumar Singh -Diego Caraballo -Diego Ramirez -DiegoCaraballo -Dimitri Merejkowsky -Dimitri Papadopoulos -Dirk Stolle -Dmitry Gladkov -Dmitry Volodin -Domen Kožar -Dominic Davis-Foster -Donald Stufft -Dongweiming -doron zarhi -Dos Moonen -Douglas Thor -DrFeathers -Dustin Ingram -Dwayne Bailey -Ed Morley -Edgar Ramírez -Edgar Ramírez Mondragón -Ee Durbin -Efflam Lemaillet -efflamlemaillet -Eitan Adler -ekristina -elainechan -Eli Schwartz -Elisha Hollander -Ellen Marie Dash -Emil Burzo -Emil Styrke -Emmanuel Arias -Endoh Takanao -enoch -Erdinc Mutlu -Eric Cousineau -Eric Gillingham -Eric Hanchrow -Eric Hopper -Erik M. Bray -Erik Rose -Erwin Janssen -Eugene Vereshchagin -everdimension -Federico -Felipe Peter -Felix Yan -fiber-space -Filip Kokosiński -Filipe Laíns -Finn Womack -finnagin -Flavio Amurrio -Florian Briand -Florian Rathgeber -Francesco -Francesco Montesano -Frost Ming -Gabriel Curio -Gabriel de Perthuis -Garry Polley -gavin -gdanielson -Geoffrey Sneddon -George Song -Georgi Valkov -Georgy Pchelkin -ghost -Giftlin Rajaiah -gizmoguy1 -gkdoc -Godefroid Chapelle -Gopinath M -GOTO Hayato -gousaiyang -gpiks -Greg Roodt -Greg Ward -Guilherme Espada -Guillaume Seguin -gutsytechster -Guy Rozendorn -Guy Tuval -gzpan123 -Hanjun Kim -Hari Charan -Harsh Vardhan -harupy -Harutaka Kawamura -hauntsaninja -Henrich Hartzer -Henry Schreiner -Herbert Pfennig -Holly Stotelmyer -Honnix -Hsiaoming Yang -Hugo Lopes Tavares -Hugo van Kemenade -Hugues Bruant -Hynek Schlawack -Ian Bicking -Ian Cordasco -Ian Lee -Ian Stapleton Cordasco -Ian Wienand -Igor Kuzmitshov -Igor Sobreira -Ilan Schnell -Illia Volochii -Ilya Baryshev -Inada Naoki -Ionel Cristian Mărieș -Ionel Maries Cristian -Itamar Turner-Trauring -Ivan Pozdeev -J. Nick Koston -Jacob Kim -Jacob Walls -Jaime Sanz -jakirkham -Jakub Kuczys -Jakub Stasiak -Jakub Vysoky -Jakub Wilk -James Cleveland -James Curtin -James Firth -James Gerity -James Polley -Jan Pokorný -Jannis Leidel -Jarek Potiuk -jarondl -Jason Curtis -Jason R. Coombs -JasonMo -JasonMo1 -Jay Graves -Jean Abou Samra -Jean-Christophe Fillion-Robin -Jeff Barber -Jeff Dairiki -Jeff Widman -Jelmer Vernooij -jenix21 -Jeremy Stanley -Jeremy Zafran -Jesse Rittner -Jiashuo Li -Jim Fisher -Jim Garrison -Jiun Bae -Jivan Amara -Joe Bylund -Joe Michelini -John Paton -John T. Wodder II -John-Scott Atlakson -johnthagen -Jon Banafato -Jon Dufresne -Jon Parise -Jonas Nockert -Jonathan Herbert -Joonatan Partanen -Joost Molenaar -Jorge Niedbalski -Joseph Bylund -Joseph Long -Josh Bronson -Josh Hansen -Josh Schneier -Joshua -Juan Luis Cano Rodríguez -Juanjo Bazán -Judah Rand -Julian Berman -Julian Gethmann -Julien Demoor -Jussi Kukkonen -jwg4 -Jyrki Pulliainen -Kai Chen -Kai Mueller -Kamal Bin Mustafa -kasium -kaustav haldar -keanemind -Keith Maxwell -Kelsey Hightower -Kenneth Belitzky -Kenneth Reitz -Kevin Burke -Kevin Carter -Kevin Frommelt -Kevin R Patterson -Kexuan Sun -Kit Randel -Klaas van Schelven -KOLANICH -kpinc -Krishna Oza -Kumar McMillan -Kurt McKee -Kyle Persohn -lakshmanaram -Laszlo Kiss-Kollar -Laurent Bristiel -Laurent LAPORTE -Laurie O -Laurie Opperman -layday -Leon Sasson -Lev Givon -Lincoln de Sousa -Lipis -lorddavidiii -Loren Carvalho -Lucas Cimon -Ludovic Gasc -Lukas Geiger -Lukas Juhrich -Luke Macken -Luo Jiebin -luojiebin -luz.paz -László Kiss Kollár -M00nL1ght -Marc Abramowitz -Marc Tamlyn -Marcus Smith -Mariatta -Mark Kohler -Mark Williams -Markus Hametner -Martey Dodoo -Martin Fischer -Martin Häcker -Martin Pavlasek -Masaki -Masklinn -Matej Stuchlik -Mathew Jennings -Mathieu Bridon -Mathieu Kniewallner -Matt Bacchi -Matt Good -Matt Maker -Matt Robenolt -matthew -Matthew Einhorn -Matthew Feickert -Matthew Gilliard -Matthew Iversen -Matthew Treinish -Matthew Trumbell -Matthew Willson -Matthias Bussonnier -mattip -Maurits van Rees -Max W Chase -Maxim Kurnikov -Maxime Rouyrre -mayeut -mbaluna -mdebi -memoselyk -meowmeowcat -Michael -Michael Aquilina -Michael E. Karpeles -Michael Klich -Michael Mintz -Michael Williamson -michaelpacer -Michał Górny -Mickaël Schoentgen -Miguel Araujo Perez -Mihir Singh -Mike -Mike Hendricks -Min RK -MinRK -Miro Hrončok -Monica Baluna -montefra -Monty Taylor -Muha Ajjan‮ -Nadav Wexler -Nahuel Ambrosini -Nate Coraor -Nate Prewitt -Nathan Houghton -Nathaniel J. Smith -Nehal J Wani -Neil Botelho -Nguyễn Gia Phong -Nicholas Serra -Nick Coghlan -Nick Stenning -Nick Timkovich -Nicolas Bock -Nicole Harris -Nikhil Benesch -Nikhil Ladha -Nikita Chepanov -Nikolay Korolev -Nipunn Koorapati -Nitesh Sharma -Niyas Sait -Noah -Noah Gorny -Nowell Strite -NtaleGrey -nvdv -OBITORASU -Ofek Lev -ofrinevo -Oliver Freund -Oliver Jeeves -Oliver Mannion -Oliver Tonnhofer -Olivier Girardot -Olivier Grisel -Ollie Rutherfurd -OMOTO Kenji -Omry Yadan -onlinejudge95 -Oren Held -Oscar Benjamin -Oz N Tiram -Pachwenko -Patrick Dubroy -Patrick Jenkins -Patrick Lawson -patricktokeeffe -Patrik Kopkan -Paul Ganssle -Paul Kehrer -Paul Moore -Paul Nasrat -Paul Oswald -Paul van der Linden -Paulus Schoutsen -Pavel Safronov -Pavithra Eswaramoorthy -Pawel Jasinski -Paweł Szramowski -Pekka Klärck -Peter Gessler -Peter Lisák -Peter Waller -petr-tik -Phaneendra Chiruvella -Phil Elson -Phil Freo -Phil Pennock -Phil Whelan -Philip Jägenstedt -Philip Molloy -Philippe Ombredanne -Pi Delport -Pierre-Yves Rofes -Pieter Degroote -pip -Prabakaran Kumaresshan -Prabhjyotsing Surjit Singh Sodhi -Prabhu Marappan -Pradyun Gedam -Prashant Sharma -Pratik Mallya -pre-commit-ci[bot] -Preet Thakkar -Preston Holmes -Przemek Wrzos -Pulkit Goyal -q0w -Qiangning Hong -Qiming Xu -Quentin Lee -Quentin Pradet -R. David Murray -Rafael Caricio -Ralf Schmitt -Razzi Abuissa -rdb -Reece Dunham -Remi Rampin -Rene Dudfield -Riccardo Magliocchetti -Riccardo Schirone -Richard Jones -Richard Si -Ricky Ng-Adam -Rishi -RobberPhex -Robert Collins -Robert McGibbon -Robert Pollak -Robert T. McGibbon -robin elisha robinson -Roey Berman -Rohan Jain -Roman Bogorodskiy -Roman Donchenko -Romuald Brunet -ronaudinho -Ronny Pfannschmidt -Rory McCann -Ross Brattain -Roy Wellington Ⅳ -Ruairidh MacLeod -Russell Keith-Magee -Ryan Shepherd -Ryan Wooden -ryneeverett -Sachi King -Salvatore Rinchiera -sandeepkiran-js -Sander Van Balen -Savio Jomton -schlamar -Scott Kitterman -Sean -seanj -Sebastian Jordan -Sebastian Schaetz -Segev Finer -SeongSoo Cho -Sergey Vasilyev -Seth Michael Larson -Seth Woodworth -Shahar Epstein -Shantanu -shireenrao -Shivansh-007 -Shlomi Fish -Shovan Maity -Simeon Visser -Simon Cross -Simon Pichugin -sinoroc -sinscary -snook92 -socketubs -Sorin Sbarnea -Srinivas Nyayapati -Stavros Korokithakis -Stefan Scherfke -Stefano Rivera -Stephan Erb -Stephen Rosen -stepshal -Steve (Gadget) Barnes -Steve Barnes -Steve Dower -Steve Kowalik -Steven Myint -Steven Silvester -stonebig -studioj -Stéphane Bidoul -Stéphane Bidoul (ACSONE) -Stéphane Klein -Sumana Harihareswara -Surbhi Sharma -Sviatoslav Sydorenko -Swat009 -Sylvain -Takayuki SHIMIZUKAWA -Taneli Hukkinen -tbeswick -Thiago -Thijs Triemstra -Thomas Fenzl -Thomas Grainger -Thomas Guettler -Thomas Johansson -Thomas Kluyver -Thomas Smith -Thomas VINCENT -Tim D. Smith -Tim Gates -Tim Harder -Tim Heap -tim smith -tinruufu -Tobias Hermann -Tom Forbes -Tom Freudenheim -Tom V -Tomas Hrnciar -Tomas Orsava -Tomer Chachamu -Tommi Enenkel | AnB -Tomáš Hrnčiar -Tony Beswick -Tony Narlock -Tony Zhaocheng Tan -TonyBeswick -toonarmycaptain -Toshio Kuratomi -toxinu -Travis Swicegood -Tushar Sadhwani -Tzu-ping Chung -Valentin Haenel -Victor Stinner -victorvpaulo -Vikram - Google -Viktor Szépe -Ville Skyttä -Vinay Sajip -Vincent Philippon -Vinicyus Macedo -Vipul Kumar -Vitaly Babiy -Vladimir Fokow -Vladimir Rutsky -W. Trevor King -Wil Tan -Wilfred Hughes -William Edwards -William ML Leslie -William T Olson -William Woodruff -Wilson Mo -wim glenn -Winson Luk -Wolfgang Maier -Wu Zhenyu -XAMES3 -Xavier Fernandez -xoviat -xtreak -YAMAMOTO Takashi -Yen Chi Hsuan -Yeray Diaz Diaz -Yoval P -Yu Jian -Yuan Jing Vincent Yan -Yusuke Hayashi -Zearin -Zhiping Deng -ziebam -Zvezdan Petkovic -Łukasz Langa -Роман Донченко -Семён Марьясин -‮rekcäH nitraM‮ diff --git a/venv/lib/python3.12/site-packages/pip-24.0.dist-info/INSTALLER b/venv/lib/python3.12/site-packages/pip-24.0.dist-info/INSTALLER deleted file mode 100644 index a1b589e..0000000 --- a/venv/lib/python3.12/site-packages/pip-24.0.dist-info/INSTALLER +++ /dev/null @@ -1 +0,0 @@ -pip diff --git a/venv/lib/python3.12/site-packages/pip-24.0.dist-info/LICENSE.txt b/venv/lib/python3.12/site-packages/pip-24.0.dist-info/LICENSE.txt deleted file mode 100644 index 8e7b65e..0000000 --- a/venv/lib/python3.12/site-packages/pip-24.0.dist-info/LICENSE.txt +++ /dev/null @@ -1,20 +0,0 @@ -Copyright (c) 2008-present 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.12/site-packages/pip-24.0.dist-info/METADATA b/venv/lib/python3.12/site-packages/pip-24.0.dist-info/METADATA deleted file mode 100644 index e5b45bd..0000000 --- a/venv/lib/python3.12/site-packages/pip-24.0.dist-info/METADATA +++ /dev/null @@ -1,88 +0,0 @@ -Metadata-Version: 2.1 -Name: pip -Version: 24.0 -Summary: The PyPA recommended tool for installing Python packages. -Author-email: The pip developers -License: MIT -Project-URL: Homepage, https://pip.pypa.io/ -Project-URL: Documentation, https://pip.pypa.io -Project-URL: Source, https://github.com/pypa/pip -Project-URL: Changelog, https://pip.pypa.io/en/stable/news/ -Classifier: Development Status :: 5 - Production/Stable -Classifier: Intended Audience :: Developers -Classifier: License :: OSI Approved :: MIT License -Classifier: Topic :: Software Development :: Build Tools -Classifier: Programming Language :: Python -Classifier: Programming Language :: Python :: 3 -Classifier: Programming Language :: Python :: 3 :: Only -Classifier: Programming Language :: Python :: 3.7 -Classifier: Programming Language :: Python :: 3.8 -Classifier: Programming Language :: Python :: 3.9 -Classifier: Programming Language :: Python :: 3.10 -Classifier: Programming Language :: Python :: 3.11 -Classifier: Programming Language :: Python :: 3.12 -Classifier: Programming Language :: Python :: Implementation :: CPython -Classifier: Programming Language :: Python :: Implementation :: PyPy -Requires-Python: >=3.7 -Description-Content-Type: text/x-rst -License-File: LICENSE.txt -License-File: AUTHORS.txt - -pip - The Python Package Installer -================================== - -.. image:: https://img.shields.io/pypi/v/pip.svg - :target: https://pypi.org/project/pip/ - :alt: PyPI - -.. image:: https://img.shields.io/pypi/pyversions/pip - :target: https://pypi.org/project/pip - :alt: PyPI - Python Version - -.. image:: https://readthedocs.org/projects/pip/badge/?version=latest - :target: https://pip.pypa.io/en/latest - :alt: Documentation - -pip is the `package installer`_ for Python. You can use pip to install packages from the `Python Package Index`_ and other indexes. - -Please take a look at our documentation for how to install and use pip: - -* `Installation`_ -* `Usage`_ - -We release updates regularly, with a new version every 3 months. Find more details in our documentation: - -* `Release notes`_ -* `Release process`_ - -If you find bugs, need help, or want to talk to the developers, please use our mailing lists or chat rooms: - -* `Issue tracking`_ -* `Discourse channel`_ -* `User IRC`_ - -If you want to get involved head over to GitHub to get the source code, look at our development documentation and feel free to jump on the developer mailing lists and chat rooms: - -* `GitHub page`_ -* `Development documentation`_ -* `Development IRC`_ - -Code of Conduct ---------------- - -Everyone interacting in the pip project's codebases, issue trackers, chat -rooms, and mailing lists is expected to follow the `PSF Code of Conduct`_. - -.. _package installer: https://packaging.python.org/guides/tool-recommendations/ -.. _Python Package Index: https://pypi.org -.. _Installation: https://pip.pypa.io/en/stable/installation/ -.. _Usage: https://pip.pypa.io/en/stable/ -.. _Release notes: https://pip.pypa.io/en/stable/news.html -.. _Release process: https://pip.pypa.io/en/latest/development/release-process/ -.. _GitHub page: https://github.com/pypa/pip -.. _Development documentation: https://pip.pypa.io/en/latest/development -.. _Issue tracking: https://github.com/pypa/pip/issues -.. _Discourse channel: https://discuss.python.org/c/packaging -.. _User IRC: https://kiwiirc.com/nextclient/#ircs://irc.libera.chat:+6697/pypa -.. _Development IRC: https://kiwiirc.com/nextclient/#ircs://irc.libera.chat:+6697/pypa-dev -.. _PSF Code of Conduct: https://github.com/pypa/.github/blob/main/CODE_OF_CONDUCT.md diff --git a/venv/lib/python3.12/site-packages/pip-24.0.dist-info/RECORD b/venv/lib/python3.12/site-packages/pip-24.0.dist-info/RECORD deleted file mode 100644 index fa715f8..0000000 --- a/venv/lib/python3.12/site-packages/pip-24.0.dist-info/RECORD +++ /dev/null @@ -1,1005 +0,0 @@ -../../../bin/pip,sha256=JG7py678kO9e5ufCuhnRmUA63gfYRr4lPnVqAX4YVvM,261 -../../../bin/pip3,sha256=JG7py678kO9e5ufCuhnRmUA63gfYRr4lPnVqAX4YVvM,261 -../../../bin/pip3.12,sha256=JG7py678kO9e5ufCuhnRmUA63gfYRr4lPnVqAX4YVvM,261 -pip-24.0.dist-info/AUTHORS.txt,sha256=SwXm4nkwRkmtnO1ZY-dLy7EPeoQNXMNLby5CN3GlNhY,10388 -pip-24.0.dist-info/INSTALLER,sha256=zuuue4knoyJ-UwPPXg8fezS7VCrXJQrAP7zeNuwvFQg,4 -pip-24.0.dist-info/LICENSE.txt,sha256=Y0MApmnUmurmWxLGxIySTFGkzfPR_whtw0VtyLyqIQQ,1093 -pip-24.0.dist-info/METADATA,sha256=kNEfJ3_Vho2mee4lfJdlbd5RHIqsfQJSMUB-bOkIOeI,3581 -pip-24.0.dist-info/RECORD,, -pip-24.0.dist-info/REQUESTED,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -pip-24.0.dist-info/WHEEL,sha256=oiQVh_5PnQM0E3gPdiz09WCNmwiHDMaGer_elqB3coM,92 -pip-24.0.dist-info/entry_points.txt,sha256=Fa_c0b-xGFaYxagIruvpJD6qqXmNTA02vAVIkmMj-9o,125 -pip-24.0.dist-info/top_level.txt,sha256=zuuue4knoyJ-UwPPXg8fezS7VCrXJQrAP7zeNuwvFQg,4 -pip/__init__.py,sha256=oAk1nFpLmUVS5Ln7NxvNoGUn5Vkn6FGQjPaNDf8Q8pk,355 -pip/__main__.py,sha256=WzbhHXTbSE6gBY19mNN9m4s5o_365LOvTYSgqgbdBhE,854 -pip/__pip-runner__.py,sha256=EnrfKmKMzWAdqg_JicLCOP9Y95Ux7zHh4ObvqLtQcjo,1444 -pip/__pycache__/__init__.cpython-312.pyc,, -pip/__pycache__/__main__.cpython-312.pyc,, -pip/__pycache__/__pip-runner__.cpython-312.pyc,, -pip/_internal/__init__.py,sha256=iqZ5-YQsQV08tkUc7L806Reop6tguLFWf70ySF6be0Y,515 -pip/_internal/__pycache__/__init__.cpython-312.pyc,, -pip/_internal/__pycache__/build_env.cpython-312.pyc,, -pip/_internal/__pycache__/cache.cpython-312.pyc,, -pip/_internal/__pycache__/configuration.cpython-312.pyc,, -pip/_internal/__pycache__/exceptions.cpython-312.pyc,, -pip/_internal/__pycache__/main.cpython-312.pyc,, -pip/_internal/__pycache__/pyproject.cpython-312.pyc,, -pip/_internal/__pycache__/self_outdated_check.cpython-312.pyc,, -pip/_internal/__pycache__/wheel_builder.cpython-312.pyc,, -pip/_internal/build_env.py,sha256=1ESpqw0iupS_K7phZK5zshVE5Czy9BtGLFU4W6Enva8,10243 -pip/_internal/cache.py,sha256=uiYD-9F0Bv1C8ZyWE85lpzDmQf7hcUkgL99GmI8I41Q,10370 -pip/_internal/cli/__init__.py,sha256=FkHBgpxxb-_gd6r1FjnNhfMOzAUYyXoXKJ6abijfcFU,132 -pip/_internal/cli/__pycache__/__init__.cpython-312.pyc,, -pip/_internal/cli/__pycache__/autocompletion.cpython-312.pyc,, -pip/_internal/cli/__pycache__/base_command.cpython-312.pyc,, -pip/_internal/cli/__pycache__/cmdoptions.cpython-312.pyc,, -pip/_internal/cli/__pycache__/command_context.cpython-312.pyc,, -pip/_internal/cli/__pycache__/main.cpython-312.pyc,, -pip/_internal/cli/__pycache__/main_parser.cpython-312.pyc,, -pip/_internal/cli/__pycache__/parser.cpython-312.pyc,, -pip/_internal/cli/__pycache__/progress_bars.cpython-312.pyc,, -pip/_internal/cli/__pycache__/req_command.cpython-312.pyc,, -pip/_internal/cli/__pycache__/spinners.cpython-312.pyc,, -pip/_internal/cli/__pycache__/status_codes.cpython-312.pyc,, -pip/_internal/cli/autocompletion.py,sha256=_br_5NgSxSuvPjMF0MLHzS5s6BpSkQAQHKrLK89VauM,6690 -pip/_internal/cli/base_command.py,sha256=iuVWGa2oTq7gBReo0er3Z0tXJ2oqBIC6QjDHcnDhKXY,8733 -pip/_internal/cli/cmdoptions.py,sha256=V8ggG6AtHpHKkH_6tRU0mhJaZTeqtrFpu75ghvMXXJk,30063 -pip/_internal/cli/command_context.py,sha256=RHgIPwtObh5KhMrd3YZTkl8zbVG-6Okml7YbFX4Ehg0,774 -pip/_internal/cli/main.py,sha256=Uzxt_YD1hIvB1AW5mxt6IVcht5G712AtMqdo51UMhmQ,2816 -pip/_internal/cli/main_parser.py,sha256=laDpsuBDl6kyfywp9eMMA9s84jfH2TJJn-vmL0GG90w,4338 -pip/_internal/cli/parser.py,sha256=KW6C3-7-4ErTNB0TfLTKwOdHcd-qefCeGnrOoE2r0RQ,10781 -pip/_internal/cli/progress_bars.py,sha256=So4mPoSjXkXiSHiTzzquH3VVyVD_njXlHJSExYPXAow,1968 -pip/_internal/cli/req_command.py,sha256=c7_XHABnXmD3_qlK9-r37KqdKBAcgmVKvQ2WcTrNLfc,18369 -pip/_internal/cli/spinners.py,sha256=hIJ83GerdFgFCdobIA23Jggetegl_uC4Sp586nzFbPE,5118 -pip/_internal/cli/status_codes.py,sha256=sEFHUaUJbqv8iArL3HAtcztWZmGOFX01hTesSytDEh0,116 -pip/_internal/commands/__init__.py,sha256=5oRO9O3dM2vGuh0bFw4HOVletryrz5HHMmmPWwJrH9U,3882 -pip/_internal/commands/__pycache__/__init__.cpython-312.pyc,, -pip/_internal/commands/__pycache__/cache.cpython-312.pyc,, -pip/_internal/commands/__pycache__/check.cpython-312.pyc,, -pip/_internal/commands/__pycache__/completion.cpython-312.pyc,, -pip/_internal/commands/__pycache__/configuration.cpython-312.pyc,, -pip/_internal/commands/__pycache__/debug.cpython-312.pyc,, -pip/_internal/commands/__pycache__/download.cpython-312.pyc,, -pip/_internal/commands/__pycache__/freeze.cpython-312.pyc,, -pip/_internal/commands/__pycache__/hash.cpython-312.pyc,, -pip/_internal/commands/__pycache__/help.cpython-312.pyc,, -pip/_internal/commands/__pycache__/index.cpython-312.pyc,, -pip/_internal/commands/__pycache__/inspect.cpython-312.pyc,, -pip/_internal/commands/__pycache__/install.cpython-312.pyc,, -pip/_internal/commands/__pycache__/list.cpython-312.pyc,, -pip/_internal/commands/__pycache__/search.cpython-312.pyc,, -pip/_internal/commands/__pycache__/show.cpython-312.pyc,, -pip/_internal/commands/__pycache__/uninstall.cpython-312.pyc,, -pip/_internal/commands/__pycache__/wheel.cpython-312.pyc,, -pip/_internal/commands/cache.py,sha256=xg76_ZFEBC6zoQ3gXLRfMZJft4z2a0RwH4GEFZC6nnU,7944 -pip/_internal/commands/check.py,sha256=Rb13Q28yoLh0j1gpx5SU0jlResNct21eQCRsnaO9xKA,1782 -pip/_internal/commands/completion.py,sha256=HT4lD0bgsflHq2IDgYfiEdp7IGGtE7s6MgI3xn0VQEw,4287 -pip/_internal/commands/configuration.py,sha256=n98enwp6y0b5G6fiRQjaZo43FlJKYve_daMhN-4BRNc,9766 -pip/_internal/commands/debug.py,sha256=63972uUCeMIGOdMMVeIUGrOjTOqTVWplFC82a-hcKyA,6777 -pip/_internal/commands/download.py,sha256=e4hw088zGo26WmJaMIRvCniLlLmoOjqolGyfHjsCkCQ,5335 -pip/_internal/commands/freeze.py,sha256=qrIHS_-c6JPrQ92hMhAv9kkl0bHgFpRLwYJDdbcYr1o,3243 -pip/_internal/commands/hash.py,sha256=EVVOuvGtoPEdFi8SNnmdqlCQrhCxV-kJsdwtdcCnXGQ,1703 -pip/_internal/commands/help.py,sha256=gcc6QDkcgHMOuAn5UxaZwAStsRBrnGSn_yxjS57JIoM,1132 -pip/_internal/commands/index.py,sha256=CNXQer_PeZKSJooURcCFCBEKGfwyNoUWYP_MWczAcOM,4775 -pip/_internal/commands/inspect.py,sha256=2wSPt9yfr3r6g-s2S5L6PvRtaHNVyb4TuodMStJ39cw,3188 -pip/_internal/commands/install.py,sha256=VxDd-BD3a27ApeE2OK34rfBXS6Zo2wtemK9-HCwPqxM,28782 -pip/_internal/commands/list.py,sha256=-QbpPuGDiGN1SdThsk2ml8beBnepliefbGhMAN8tkzU,12547 -pip/_internal/commands/search.py,sha256=sbBZiARRc050QquOKcCvOr2K3XLsoYebLKZGRi__iUI,5697 -pip/_internal/commands/show.py,sha256=t5jia4zcYJRJZy4U_Von7zMl03hJmmcofj6oDNTnj7Y,6419 -pip/_internal/commands/uninstall.py,sha256=OIqO9tqadY8kM4HwhFf1Q62fUIp7v8KDrTRo8yWMz7Y,3886 -pip/_internal/commands/wheel.py,sha256=CSnX8Pmf1oPCnd7j7bn1_f58G9KHNiAblvVJ5zykN-A,6476 -pip/_internal/configuration.py,sha256=XkAiBS0hpzsM-LF0Qu5hvPWO_Bs67-oQKRYFBuMbESs,14006 -pip/_internal/distributions/__init__.py,sha256=Hq6kt6gXBgjNit5hTTWLAzeCNOKoB-N0pGYSqehrli8,858 -pip/_internal/distributions/__pycache__/__init__.cpython-312.pyc,, -pip/_internal/distributions/__pycache__/base.cpython-312.pyc,, -pip/_internal/distributions/__pycache__/installed.cpython-312.pyc,, -pip/_internal/distributions/__pycache__/sdist.cpython-312.pyc,, -pip/_internal/distributions/__pycache__/wheel.cpython-312.pyc,, -pip/_internal/distributions/base.py,sha256=oRSEvnv2ZjBnargamnv2fcJa1n6gUDKaW0g6CWSEpWs,1743 -pip/_internal/distributions/installed.py,sha256=QinHFbWAQ8oE0pbD8MFZWkwlnfU1QYTccA1vnhrlYOU,842 -pip/_internal/distributions/sdist.py,sha256=4K3V0VNMllHbBzCJibjwd_tylUKpmIdu2AQyhplvCQo,6709 -pip/_internal/distributions/wheel.py,sha256=-ma3sOtUQj0AxXCEb6_Fhmjl3nh4k3A0HC2taAb2N-4,1277 -pip/_internal/exceptions.py,sha256=TmF1iNFEneSWaemwlg6a5bpPuq2cMHK7d1-SvjsQHb0,23634 -pip/_internal/index/__init__.py,sha256=vpt-JeTZefh8a-FC22ZeBSXFVbuBcXSGiILhQZJaNpQ,30 -pip/_internal/index/__pycache__/__init__.cpython-312.pyc,, -pip/_internal/index/__pycache__/collector.cpython-312.pyc,, -pip/_internal/index/__pycache__/package_finder.cpython-312.pyc,, -pip/_internal/index/__pycache__/sources.cpython-312.pyc,, -pip/_internal/index/collector.py,sha256=sH0tL_cOoCk6pLLfCSGVjFM4rPEJtllF-VobvAvLSH4,16590 -pip/_internal/index/package_finder.py,sha256=S_nC8gzVIMY6ikWfKoSOzRtoesUqnfNhAPl_BwSOusA,37843 -pip/_internal/index/sources.py,sha256=dJegiR9f86kslaAHcv9-R5L_XBf5Rzm_FkyPteDuPxI,8688 -pip/_internal/locations/__init__.py,sha256=Dh8LJWG8LRlDK4JIj9sfRF96TREzE--N_AIlx7Tqoe4,15365 -pip/_internal/locations/__pycache__/__init__.cpython-312.pyc,, -pip/_internal/locations/__pycache__/_distutils.cpython-312.pyc,, -pip/_internal/locations/__pycache__/_sysconfig.cpython-312.pyc,, -pip/_internal/locations/__pycache__/base.cpython-312.pyc,, -pip/_internal/locations/_distutils.py,sha256=H9ZHK_35rdDV1Qsmi4QeaBULjFT4Mbu6QuoVGkJ6QHI,6009 -pip/_internal/locations/_sysconfig.py,sha256=jyNVtUfMIf0mtyY-Xp1m9yQ8iwECozSVVFmjkN9a2yw,7680 -pip/_internal/locations/base.py,sha256=RQiPi1d4FVM2Bxk04dQhXZ2PqkeljEL2fZZ9SYqIQ78,2556 -pip/_internal/main.py,sha256=r-UnUe8HLo5XFJz8inTcOOTiu_sxNhgHb6VwlGUllOI,340 -pip/_internal/metadata/__init__.py,sha256=9pU3W3s-6HtjFuYhWcLTYVmSaziklPv7k2x8p7X1GmA,4339 -pip/_internal/metadata/__pycache__/__init__.cpython-312.pyc,, -pip/_internal/metadata/__pycache__/_json.cpython-312.pyc,, -pip/_internal/metadata/__pycache__/base.cpython-312.pyc,, -pip/_internal/metadata/__pycache__/pkg_resources.cpython-312.pyc,, -pip/_internal/metadata/_json.py,sha256=Rz5M5ciSNvITwaTQR6NfN8TgKgM5WfTws4D6CFknovE,2627 -pip/_internal/metadata/base.py,sha256=l3Wgku4xlgr8s4p6fS-3qQ4QKOpPbWLRwi5d9omEFG4,25907 -pip/_internal/metadata/importlib/__init__.py,sha256=jUUidoxnHcfITHHaAWG1G2i5fdBYklv_uJcjo2x7VYE,135 -pip/_internal/metadata/importlib/__pycache__/__init__.cpython-312.pyc,, -pip/_internal/metadata/importlib/__pycache__/_compat.cpython-312.pyc,, -pip/_internal/metadata/importlib/__pycache__/_dists.cpython-312.pyc,, -pip/_internal/metadata/importlib/__pycache__/_envs.cpython-312.pyc,, -pip/_internal/metadata/importlib/_compat.py,sha256=GAe_prIfCE4iUylrnr_2dJRlkkBVRUbOidEoID7LPoE,1882 -pip/_internal/metadata/importlib/_dists.py,sha256=UPl1wUujFqiwiltRJ1tMF42WRINO1sSpNNlYQ2mX0mk,8297 -pip/_internal/metadata/importlib/_envs.py,sha256=XTaFIYERP2JF0QUZuPx2ETiugXbPEcZ8q8ZKeht6Lpc,7456 -pip/_internal/metadata/pkg_resources.py,sha256=opjw4IBSqHvie6sXJ_cbT42meygoPEUfNURJuWZY7sk,10035 -pip/_internal/models/__init__.py,sha256=3DHUd_qxpPozfzouoqa9g9ts1Czr5qaHfFxbnxriepM,63 -pip/_internal/models/__pycache__/__init__.cpython-312.pyc,, -pip/_internal/models/__pycache__/candidate.cpython-312.pyc,, -pip/_internal/models/__pycache__/direct_url.cpython-312.pyc,, -pip/_internal/models/__pycache__/format_control.cpython-312.pyc,, -pip/_internal/models/__pycache__/index.cpython-312.pyc,, -pip/_internal/models/__pycache__/installation_report.cpython-312.pyc,, -pip/_internal/models/__pycache__/link.cpython-312.pyc,, -pip/_internal/models/__pycache__/scheme.cpython-312.pyc,, -pip/_internal/models/__pycache__/search_scope.cpython-312.pyc,, -pip/_internal/models/__pycache__/selection_prefs.cpython-312.pyc,, -pip/_internal/models/__pycache__/target_python.cpython-312.pyc,, -pip/_internal/models/__pycache__/wheel.cpython-312.pyc,, -pip/_internal/models/candidate.py,sha256=hEPu8VdGE5qVASv6vLz-R-Rgh5-7LMbai1jgthMCd8M,931 -pip/_internal/models/direct_url.py,sha256=FwouYBKcqckh7B-k2H3HVgRhhFTukFwqiS3kfvtFLSk,6889 -pip/_internal/models/format_control.py,sha256=wtsQqSK9HaUiNxQEuB-C62eVimw6G4_VQFxV9-_KDBE,2486 -pip/_internal/models/index.py,sha256=tYnL8oxGi4aSNWur0mG8DAP7rC6yuha_MwJO8xw0crI,1030 -pip/_internal/models/installation_report.py,sha256=zRVZoaz-2vsrezj_H3hLOhMZCK9c7TbzWgC-jOalD00,2818 -pip/_internal/models/link.py,sha256=XirOAGv1jgMu7vu87kuPbohGj7VHpwVrd2q3KUgVQNg,20777 -pip/_internal/models/scheme.py,sha256=3EFQp_ICu_shH1-TBqhl0QAusKCPDFOlgHFeN4XowWs,738 -pip/_internal/models/search_scope.py,sha256=ASVyyZxiJILw7bTIVVpJx8J293M3Hk5F33ilGn0e80c,4643 -pip/_internal/models/selection_prefs.py,sha256=KZdi66gsR-_RUXUr9uejssk3rmTHrQVJWeNA2sV-VSY,1907 -pip/_internal/models/target_python.py,sha256=34EkorrMuRvRp-bjqHKJ-bOO71m9xdjN2b8WWFEC2HU,4272 -pip/_internal/models/wheel.py,sha256=YqazoIZyma_Q1ejFa1C7NHKQRRWlvWkdK96VRKmDBeI,3600 -pip/_internal/network/__init__.py,sha256=jf6Tt5nV_7zkARBrKojIXItgejvoegVJVKUbhAa5Ioc,50 -pip/_internal/network/__pycache__/__init__.cpython-312.pyc,, -pip/_internal/network/__pycache__/auth.cpython-312.pyc,, -pip/_internal/network/__pycache__/cache.cpython-312.pyc,, -pip/_internal/network/__pycache__/download.cpython-312.pyc,, -pip/_internal/network/__pycache__/lazy_wheel.cpython-312.pyc,, -pip/_internal/network/__pycache__/session.cpython-312.pyc,, -pip/_internal/network/__pycache__/utils.cpython-312.pyc,, -pip/_internal/network/__pycache__/xmlrpc.cpython-312.pyc,, -pip/_internal/network/auth.py,sha256=TC-OcW2KU4W6R1hU4qPgQXvVH54adACpZz6sWq-R9NA,20541 -pip/_internal/network/cache.py,sha256=48A971qCzKNFvkb57uGEk7-0xaqPS0HWj2711QNTxkU,3935 -pip/_internal/network/download.py,sha256=i0Tn55CD5D7XYEFY3TxiYaCf0OaaTQ6SScNgCsSeV14,6086 -pip/_internal/network/lazy_wheel.py,sha256=2PXVduYZPCPZkkQFe1J1GbfHJWeCU--FXonGyIfw9eU,7638 -pip/_internal/network/session.py,sha256=9tqEDD8JiVaFdplOEXJxNo9cjRfBZ6RIa0yQQ_qBNiM,18698 -pip/_internal/network/utils.py,sha256=6A5SrUJEEUHxbGtbscwU2NpCyz-3ztiDlGWHpRRhsJ8,4073 -pip/_internal/network/xmlrpc.py,sha256=sAxzOacJ-N1NXGPvap9jC3zuYWSnnv3GXtgR2-E2APA,1838 -pip/_internal/operations/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -pip/_internal/operations/__pycache__/__init__.cpython-312.pyc,, -pip/_internal/operations/__pycache__/check.cpython-312.pyc,, -pip/_internal/operations/__pycache__/freeze.cpython-312.pyc,, -pip/_internal/operations/__pycache__/prepare.cpython-312.pyc,, -pip/_internal/operations/build/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -pip/_internal/operations/build/__pycache__/__init__.cpython-312.pyc,, -pip/_internal/operations/build/__pycache__/build_tracker.cpython-312.pyc,, -pip/_internal/operations/build/__pycache__/metadata.cpython-312.pyc,, -pip/_internal/operations/build/__pycache__/metadata_editable.cpython-312.pyc,, -pip/_internal/operations/build/__pycache__/metadata_legacy.cpython-312.pyc,, -pip/_internal/operations/build/__pycache__/wheel.cpython-312.pyc,, -pip/_internal/operations/build/__pycache__/wheel_editable.cpython-312.pyc,, -pip/_internal/operations/build/__pycache__/wheel_legacy.cpython-312.pyc,, -pip/_internal/operations/build/build_tracker.py,sha256=z-H5DOknZdBa3dh2Vq6VBMY5qLYIKmlj2p6CGZK5Lc8,4832 -pip/_internal/operations/build/metadata.py,sha256=9S0CUD8U3QqZeXp-Zyt8HxwU90lE4QrnYDgrqZDzBnc,1422 -pip/_internal/operations/build/metadata_editable.py,sha256=VLL7LvntKE8qxdhUdEJhcotFzUsOSI8NNS043xULKew,1474 -pip/_internal/operations/build/metadata_legacy.py,sha256=o-eU21As175hDC7dluM1fJJ_FqokTIShyWpjKaIpHZw,2198 -pip/_internal/operations/build/wheel.py,sha256=sT12FBLAxDC6wyrDorh8kvcZ1jG5qInCRWzzP-UkJiQ,1075 -pip/_internal/operations/build/wheel_editable.py,sha256=yOtoH6zpAkoKYEUtr8FhzrYnkNHQaQBjWQ2HYae1MQg,1417 -pip/_internal/operations/build/wheel_legacy.py,sha256=C9j6rukgQI1n_JeQLoZGuDdfUwzCXShyIdPTp6edbMQ,3064 -pip/_internal/operations/check.py,sha256=fsqA88iGaqftCr2tlP3sSU202CSkoODRtW0O-JU9M4Y,6806 -pip/_internal/operations/freeze.py,sha256=uqoeTAf6HOYVMR2UgAT8N85UZoGEVEoQdan_Ao6SOfk,9816 -pip/_internal/operations/install/__init__.py,sha256=mX7hyD2GNBO2mFGokDQ30r_GXv7Y_PLdtxcUv144e-s,51 -pip/_internal/operations/install/__pycache__/__init__.cpython-312.pyc,, -pip/_internal/operations/install/__pycache__/editable_legacy.cpython-312.pyc,, -pip/_internal/operations/install/__pycache__/wheel.cpython-312.pyc,, -pip/_internal/operations/install/editable_legacy.py,sha256=YeR0KadWXw_ZheC1NtAG1qVIEkOgRGHc23x-YtGW7NU,1282 -pip/_internal/operations/install/wheel.py,sha256=9hGb1c4bRnPIb2FG7CtUSPfPxqprmHQBtwIAlWPNTtE,27311 -pip/_internal/operations/prepare.py,sha256=57Oq87HfunX3Rbqp47FdaJr9cHbAKUm_3gv7WhBAqbE,28128 -pip/_internal/pyproject.py,sha256=4Xszp11xgr126yzG6BbJA0oaQ9WXuhb0jyUb-y_6lPQ,7152 -pip/_internal/req/__init__.py,sha256=TELFgZOof3lhMmaICVWL9U7PlhXo9OufokbMAJ6J2GI,2738 -pip/_internal/req/__pycache__/__init__.cpython-312.pyc,, -pip/_internal/req/__pycache__/constructors.cpython-312.pyc,, -pip/_internal/req/__pycache__/req_file.cpython-312.pyc,, -pip/_internal/req/__pycache__/req_install.cpython-312.pyc,, -pip/_internal/req/__pycache__/req_set.cpython-312.pyc,, -pip/_internal/req/__pycache__/req_uninstall.cpython-312.pyc,, -pip/_internal/req/constructors.py,sha256=8hlY56imEthLORRwmloyKz3YOyXymIaKsNB6P9ewvNI,19018 -pip/_internal/req/req_file.py,sha256=M8ttOZL-PwAj7scPElhW3ZD2hiD9mm_6FJAGIbwAzEI,17790 -pip/_internal/req/req_install.py,sha256=wtOPxkyRSM8comTks8oL1Gp2oyGqbH7JwIDRci2QiPk,35460 -pip/_internal/req/req_set.py,sha256=iMYDUToSgkxFyrP_OrTtPSgw4dwjRyGRDpGooTqeA4Y,4704 -pip/_internal/req/req_uninstall.py,sha256=nmvTQaRCC0iu-5Tw0djlXJhSj6WmqHRvT3qkkEdC35E,24551 -pip/_internal/resolution/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -pip/_internal/resolution/__pycache__/__init__.cpython-312.pyc,, -pip/_internal/resolution/__pycache__/base.cpython-312.pyc,, -pip/_internal/resolution/base.py,sha256=qlmh325SBVfvG6Me9gc5Nsh5sdwHBwzHBq6aEXtKsLA,583 -pip/_internal/resolution/legacy/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -pip/_internal/resolution/legacy/__pycache__/__init__.cpython-312.pyc,, -pip/_internal/resolution/legacy/__pycache__/resolver.cpython-312.pyc,, -pip/_internal/resolution/legacy/resolver.py,sha256=Xk24jQ62GvLr4Mc7IjN_qiO88qp0BImzVmPIFz9QLOE,24025 -pip/_internal/resolution/resolvelib/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -pip/_internal/resolution/resolvelib/__pycache__/__init__.cpython-312.pyc,, -pip/_internal/resolution/resolvelib/__pycache__/base.cpython-312.pyc,, -pip/_internal/resolution/resolvelib/__pycache__/candidates.cpython-312.pyc,, -pip/_internal/resolution/resolvelib/__pycache__/factory.cpython-312.pyc,, -pip/_internal/resolution/resolvelib/__pycache__/found_candidates.cpython-312.pyc,, -pip/_internal/resolution/resolvelib/__pycache__/provider.cpython-312.pyc,, -pip/_internal/resolution/resolvelib/__pycache__/reporter.cpython-312.pyc,, -pip/_internal/resolution/resolvelib/__pycache__/requirements.cpython-312.pyc,, -pip/_internal/resolution/resolvelib/__pycache__/resolver.cpython-312.pyc,, -pip/_internal/resolution/resolvelib/base.py,sha256=jg5COmHLhmBIKOR-4spdJD3jyULYa1BdsqiBu2YJnJ4,5173 -pip/_internal/resolution/resolvelib/candidates.py,sha256=19Ki91Po-MSxBknGIfOGkaWkFdOznN0W_nKv7jL28L0,21052 -pip/_internal/resolution/resolvelib/factory.py,sha256=vqqk-hjchdhShwWVdeW2_A-5ZblLhE_nC_v3Mhz4Svc,32292 -pip/_internal/resolution/resolvelib/found_candidates.py,sha256=hvL3Hoa9VaYo-qEOZkBi2Iqw251UDxPz-uMHVaWmLpE,5705 -pip/_internal/resolution/resolvelib/provider.py,sha256=4t23ivjruqM6hKBX1KpGiTt-M4HGhRcZnGLV0c01K7U,9824 -pip/_internal/resolution/resolvelib/reporter.py,sha256=YFm9hQvz4DFCbjZeFTQ56hTz3Ac-mDBnHkeNRVvMHLY,3100 -pip/_internal/resolution/resolvelib/requirements.py,sha256=-kJONP0WjDfdTvBAs2vUXPgAnOyNIBEAXY4b72ogtPE,5696 -pip/_internal/resolution/resolvelib/resolver.py,sha256=nLJOsVMEVi2gQUVJoUFKMZAeu2f7GRMjGMvNSWyz0Bc,12592 -pip/_internal/self_outdated_check.py,sha256=saxQLB8UzIFtMScquytG10TOTsYVFJQ_mkW1NY-46wE,8378 -pip/_internal/utils/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -pip/_internal/utils/__pycache__/__init__.cpython-312.pyc,, -pip/_internal/utils/__pycache__/_jaraco_text.cpython-312.pyc,, -pip/_internal/utils/__pycache__/_log.cpython-312.pyc,, -pip/_internal/utils/__pycache__/appdirs.cpython-312.pyc,, -pip/_internal/utils/__pycache__/compat.cpython-312.pyc,, -pip/_internal/utils/__pycache__/compatibility_tags.cpython-312.pyc,, -pip/_internal/utils/__pycache__/datetime.cpython-312.pyc,, -pip/_internal/utils/__pycache__/deprecation.cpython-312.pyc,, -pip/_internal/utils/__pycache__/direct_url_helpers.cpython-312.pyc,, -pip/_internal/utils/__pycache__/egg_link.cpython-312.pyc,, -pip/_internal/utils/__pycache__/encoding.cpython-312.pyc,, -pip/_internal/utils/__pycache__/entrypoints.cpython-312.pyc,, -pip/_internal/utils/__pycache__/filesystem.cpython-312.pyc,, -pip/_internal/utils/__pycache__/filetypes.cpython-312.pyc,, -pip/_internal/utils/__pycache__/glibc.cpython-312.pyc,, -pip/_internal/utils/__pycache__/hashes.cpython-312.pyc,, -pip/_internal/utils/__pycache__/logging.cpython-312.pyc,, -pip/_internal/utils/__pycache__/misc.cpython-312.pyc,, -pip/_internal/utils/__pycache__/models.cpython-312.pyc,, -pip/_internal/utils/__pycache__/packaging.cpython-312.pyc,, -pip/_internal/utils/__pycache__/setuptools_build.cpython-312.pyc,, -pip/_internal/utils/__pycache__/subprocess.cpython-312.pyc,, -pip/_internal/utils/__pycache__/temp_dir.cpython-312.pyc,, -pip/_internal/utils/__pycache__/unpacking.cpython-312.pyc,, -pip/_internal/utils/__pycache__/urls.cpython-312.pyc,, -pip/_internal/utils/__pycache__/virtualenv.cpython-312.pyc,, -pip/_internal/utils/__pycache__/wheel.cpython-312.pyc,, -pip/_internal/utils/_jaraco_text.py,sha256=yvDGelTVugRayPaOF2k4ab0Ky4d3uOkAfuOQjASjImY,3351 -pip/_internal/utils/_log.py,sha256=-jHLOE_THaZz5BFcCnoSL9EYAtJ0nXem49s9of4jvKw,1015 -pip/_internal/utils/appdirs.py,sha256=swgcTKOm3daLeXTW6v5BUS2Ti2RvEnGRQYH_yDXklAo,1665 -pip/_internal/utils/compat.py,sha256=ACyBfLgj3_XG-iA5omEDrXqDM0cQKzi8h8HRBInzG6Q,1884 -pip/_internal/utils/compatibility_tags.py,sha256=ydin8QG8BHqYRsPY4OL6cmb44CbqXl1T0xxS97VhHkk,5377 -pip/_internal/utils/datetime.py,sha256=m21Y3wAtQc-ji6Veb6k_M5g6A0ZyFI4egchTdnwh-pQ,242 -pip/_internal/utils/deprecation.py,sha256=NKo8VqLioJ4nnXXGmW4KdasxF90EFHkZaHeX1fT08C8,3627 -pip/_internal/utils/direct_url_helpers.py,sha256=6F1tc2rcKaCZmgfVwsE6ObIe_Pux23mUVYA-2D9wCFc,3206 -pip/_internal/utils/egg_link.py,sha256=0FePZoUYKv4RGQ2t6x7w5Z427wbA_Uo3WZnAkrgsuqo,2463 -pip/_internal/utils/encoding.py,sha256=qqsXDtiwMIjXMEiIVSaOjwH5YmirCaK-dIzb6-XJsL0,1169 -pip/_internal/utils/entrypoints.py,sha256=YlhLTRl2oHBAuqhc-zmL7USS67TPWVHImjeAQHreZTQ,3064 -pip/_internal/utils/filesystem.py,sha256=RhMIXUaNVMGjc3rhsDahWQ4MavvEQDdqXqgq-F6fpw8,5122 -pip/_internal/utils/filetypes.py,sha256=i8XAQ0eFCog26Fw9yV0Yb1ygAqKYB1w9Cz9n0fj8gZU,716 -pip/_internal/utils/glibc.py,sha256=Mesxxgg3BLxheLZx-dSf30b6gKpOgdVXw6W--uHSszQ,3113 -pip/_internal/utils/hashes.py,sha256=MjOigC75z6qoRMkgHiHqot7eqxfwDZSrEflJMPm-bHE,5118 -pip/_internal/utils/logging.py,sha256=fdtuZJ-AKkqwDTANDvGcBEpssL8el7T1jnwk1CnZl3Y,11603 -pip/_internal/utils/misc.py,sha256=fNXwaeeikvnUt4CPMFIL4-IQbZDxxjj4jDpzCi4ZsOw,23623 -pip/_internal/utils/models.py,sha256=5GoYU586SrxURMvDn_jBMJInitviJg4O5-iOU-6I0WY,1193 -pip/_internal/utils/packaging.py,sha256=5Wm6_x7lKrlqVjPI5MBN_RurcRHwVYoQ7Ksrs84de7s,2108 -pip/_internal/utils/setuptools_build.py,sha256=ouXpud-jeS8xPyTPsXJ-m34NPvK5os45otAzdSV_IJE,4435 -pip/_internal/utils/subprocess.py,sha256=zzdimb75jVLE1GU4WlTZ055gczhD7n1y1xTcNc7vNZQ,9207 -pip/_internal/utils/temp_dir.py,sha256=DUAw22uFruQdK43i2L2K53C-CDjRCPeAsBKJpu-rHQ4,9312 -pip/_internal/utils/unpacking.py,sha256=SBb2iV1crb89MDRTEKY86R4A_UOWApTQn9VQVcMDOlE,8821 -pip/_internal/utils/urls.py,sha256=AhaesUGl-9it6uvG6fsFPOr9ynFpGaTMk4t5XTX7Z_Q,1759 -pip/_internal/utils/virtualenv.py,sha256=S6f7csYorRpiD6cvn3jISZYc3I8PJC43H5iMFpRAEDU,3456 -pip/_internal/utils/wheel.py,sha256=i4BwUNHattzN0ixy3HBAF04tZPRh2CcxaT6t86viwkE,4499 -pip/_internal/vcs/__init__.py,sha256=UAqvzpbi0VbZo3Ub6skEeZAw-ooIZR-zX_WpCbxyCoU,596 -pip/_internal/vcs/__pycache__/__init__.cpython-312.pyc,, -pip/_internal/vcs/__pycache__/bazaar.cpython-312.pyc,, -pip/_internal/vcs/__pycache__/git.cpython-312.pyc,, -pip/_internal/vcs/__pycache__/mercurial.cpython-312.pyc,, -pip/_internal/vcs/__pycache__/subversion.cpython-312.pyc,, -pip/_internal/vcs/__pycache__/versioncontrol.cpython-312.pyc,, -pip/_internal/vcs/bazaar.py,sha256=j0oin0fpGRHcCFCxEcpPCQoFEvA-DMLULKdGP8Nv76o,3519 -pip/_internal/vcs/git.py,sha256=CeKBGJnl6uskvvjkAUXrJVxbHJrpS_B_pyfFdjL3CRc,18121 -pip/_internal/vcs/mercurial.py,sha256=oULOhzJ2Uie-06d1omkL-_Gc6meGaUkyogvqG9ZCyPs,5249 -pip/_internal/vcs/subversion.py,sha256=vhZs8L-TNggXqM1bbhl-FpbxE3TrIB6Tgnx8fh3S2HE,11729 -pip/_internal/vcs/versioncontrol.py,sha256=3eIjtOMYvOY5qP6BMYIYDZ375CSuec6kSEB0bOo1cSs,22787 -pip/_internal/wheel_builder.py,sha256=qTTzQV8F6b1jNsFCda1TRQC8J7gK-m7iuRNgKo7Dj68,11801 -pip/_vendor/__init__.py,sha256=U51NPwXdA-wXOiANIQncYjcMp6txgeOL5nHxksJeyas,4993 -pip/_vendor/__pycache__/__init__.cpython-312.pyc,, -pip/_vendor/__pycache__/six.cpython-312.pyc,, -pip/_vendor/__pycache__/typing_extensions.cpython-312.pyc,, -pip/_vendor/cachecontrol/__init__.py,sha256=ctHagMhQXuvQDdm4TirZrwDOT5H8oBNAJqzdKI6sovk,676 -pip/_vendor/cachecontrol/__pycache__/__init__.cpython-312.pyc,, -pip/_vendor/cachecontrol/__pycache__/_cmd.cpython-312.pyc,, -pip/_vendor/cachecontrol/__pycache__/adapter.cpython-312.pyc,, -pip/_vendor/cachecontrol/__pycache__/cache.cpython-312.pyc,, -pip/_vendor/cachecontrol/__pycache__/controller.cpython-312.pyc,, -pip/_vendor/cachecontrol/__pycache__/filewrapper.cpython-312.pyc,, -pip/_vendor/cachecontrol/__pycache__/heuristics.cpython-312.pyc,, -pip/_vendor/cachecontrol/__pycache__/serialize.cpython-312.pyc,, -pip/_vendor/cachecontrol/__pycache__/wrapper.cpython-312.pyc,, -pip/_vendor/cachecontrol/_cmd.py,sha256=iist2EpzJvDVIhMAxXq8iFnTBsiZAd6iplxfmNboNyk,1737 -pip/_vendor/cachecontrol/adapter.py,sha256=_CcWvUP9048qAZjsNqViaHbdcLs9mmFNixVfpO7oebE,6392 -pip/_vendor/cachecontrol/cache.py,sha256=OTQj72tUf8C1uEgczdl3Gc8vkldSzsTITKtDGKMx4z8,1952 -pip/_vendor/cachecontrol/caches/__init__.py,sha256=dtrrroK5BnADR1GWjCZ19aZ0tFsMfvFBtLQQU1sp_ag,303 -pip/_vendor/cachecontrol/caches/__pycache__/__init__.cpython-312.pyc,, -pip/_vendor/cachecontrol/caches/__pycache__/file_cache.cpython-312.pyc,, -pip/_vendor/cachecontrol/caches/__pycache__/redis_cache.cpython-312.pyc,, -pip/_vendor/cachecontrol/caches/file_cache.py,sha256=3z8AWKD-vfKeiJqIzLmJyIYtR2yd6Tsh3u1TyLRQoIQ,5352 -pip/_vendor/cachecontrol/caches/redis_cache.py,sha256=9rmqwtYu_ljVkW6_oLqbC7EaX_a8YT_yLuna-eS0dgo,1386 -pip/_vendor/cachecontrol/controller.py,sha256=keCFA3ZaNVaWTwHd6F1zqWhb4vyvNx_UvZuo5iIYMfo,18384 -pip/_vendor/cachecontrol/filewrapper.py,sha256=STttGmIPBvZzt2b51dUOwoWX5crcMCpKZOisM3f5BNc,4292 -pip/_vendor/cachecontrol/heuristics.py,sha256=fdFbk9W8IeLrjteIz_fK4mj2HD_Y7COXF2Uc8TgjT1c,4828 -pip/_vendor/cachecontrol/serialize.py,sha256=0dHeMaDwysVAAnGVlhMOP4tDliohgNK0Jxk_zsOiWxw,7173 -pip/_vendor/cachecontrol/wrapper.py,sha256=hsGc7g8QGQTT-4f8tgz3AM5qwScg6FO0BSdLSRdEvpU,1417 -pip/_vendor/certifi/__init__.py,sha256=L_j-d0kYuA_MzA2_2hraF1ovf6KT6DTquRdV3paQwOk,94 -pip/_vendor/certifi/__main__.py,sha256=1k3Cr95vCxxGRGDljrW3wMdpZdL3Nhf0u1n-k2qdsCY,255 -pip/_vendor/certifi/__pycache__/__init__.cpython-312.pyc,, -pip/_vendor/certifi/__pycache__/__main__.cpython-312.pyc,, -pip/_vendor/certifi/__pycache__/core.cpython-312.pyc,, -pip/_vendor/certifi/cacert.pem,sha256=eU0Dn_3yd8BH4m8sfVj4Glhl2KDrcCSg-sEWT-pNJ88,281617 -pip/_vendor/certifi/core.py,sha256=DNTl8b_B6C4vO3Vc9_q2uvwHpNnBQoy5onDC4McImxc,4531 -pip/_vendor/chardet/__init__.py,sha256=57R-HSxj0PWmILMN0GFmUNqEMfrEVSamXyjD-W6_fbs,4797 -pip/_vendor/chardet/__pycache__/__init__.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/big5freq.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/big5prober.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/chardistribution.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/charsetgroupprober.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/charsetprober.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/codingstatemachine.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/codingstatemachinedict.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/cp949prober.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/enums.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/escprober.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/escsm.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/eucjpprober.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/euckrfreq.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/euckrprober.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/euctwfreq.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/euctwprober.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/gb2312freq.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/gb2312prober.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/hebrewprober.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/jisfreq.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/johabfreq.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/johabprober.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/jpcntx.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/langbulgarianmodel.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/langgreekmodel.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/langhebrewmodel.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/langhungarianmodel.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/langrussianmodel.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/langthaimodel.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/langturkishmodel.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/latin1prober.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/macromanprober.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/mbcharsetprober.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/mbcsgroupprober.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/mbcssm.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/resultdict.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/sbcharsetprober.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/sbcsgroupprober.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/sjisprober.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/universaldetector.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/utf1632prober.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/utf8prober.cpython-312.pyc,, -pip/_vendor/chardet/__pycache__/version.cpython-312.pyc,, -pip/_vendor/chardet/big5freq.py,sha256=ltcfP-3PjlNHCoo5e4a7C4z-2DhBTXRfY6jbMbB7P30,31274 -pip/_vendor/chardet/big5prober.py,sha256=lPMfwCX6v2AaPgvFh_cSWZcgLDbWiFCHLZ_p9RQ9uxE,1763 -pip/_vendor/chardet/chardistribution.py,sha256=13B8XUG4oXDuLdXvfbIWwLFeR-ZU21AqTS1zcdON8bU,10032 -pip/_vendor/chardet/charsetgroupprober.py,sha256=UKK3SaIZB2PCdKSIS0gnvMtLR9JJX62M-fZJu3OlWyg,3915 -pip/_vendor/chardet/charsetprober.py,sha256=L3t8_wIOov8em-vZWOcbkdsrwe43N6_gqNh5pH7WPd4,5420 -pip/_vendor/chardet/cli/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -pip/_vendor/chardet/cli/__pycache__/__init__.cpython-312.pyc,, -pip/_vendor/chardet/cli/__pycache__/chardetect.cpython-312.pyc,, -pip/_vendor/chardet/cli/chardetect.py,sha256=zibMVg5RpKb-ME9_7EYG4ZM2Sf07NHcQzZ12U-rYJho,3242 -pip/_vendor/chardet/codingstatemachine.py,sha256=K7k69sw3jY5DmTXoSJQVsUtFIQKYPQVOSJJhBuGv_yE,3732 -pip/_vendor/chardet/codingstatemachinedict.py,sha256=0GY3Hi2qIZvDrOOJ3AtqppM1RsYxr_66ER4EHjuMiMc,542 -pip/_vendor/chardet/cp949prober.py,sha256=0jKRV7fECuWI16rNnks0ZECKA1iZYCIEaP8A1ZvjUSI,1860 -pip/_vendor/chardet/enums.py,sha256=TzECiZoCKNMqgwU76cPCeKWFBqaWvAdLMev5_bCkhY8,1683 -pip/_vendor/chardet/escprober.py,sha256=Kho48X65xE0scFylIdeJjM2bcbvRvv0h0WUbMWrJD3A,4006 -pip/_vendor/chardet/escsm.py,sha256=AqyXpA2FQFD7k-buBty_7itGEYkhmVa8X09NLRul3QM,12176 -pip/_vendor/chardet/eucjpprober.py,sha256=5KYaM9fsxkRYzw1b5k0fL-j_-ezIw-ij9r97a9MHxLY,3934 -pip/_vendor/chardet/euckrfreq.py,sha256=3mHuRvXfsq_QcQysDQFb8qSudvTiol71C6Ic2w57tKM,13566 -pip/_vendor/chardet/euckrprober.py,sha256=hiFT6wM174GIwRvqDsIcuOc-dDsq2uPKMKbyV8-1Xnc,1753 -pip/_vendor/chardet/euctwfreq.py,sha256=2alILE1Lh5eqiFJZjzRkMQXolNJRHY5oBQd-vmZYFFM,36913 -pip/_vendor/chardet/euctwprober.py,sha256=NxbpNdBtU0VFI0bKfGfDkpP7S2_8_6FlO87dVH0ogws,1753 -pip/_vendor/chardet/gb2312freq.py,sha256=49OrdXzD-HXqwavkqjo8Z7gvs58hONNzDhAyMENNkvY,20735 -pip/_vendor/chardet/gb2312prober.py,sha256=KPEBueaSLSvBpFeINMu0D6TgHcR90e5PaQawifzF4o0,1759 -pip/_vendor/chardet/hebrewprober.py,sha256=96T_Lj_OmW-fK7JrSHojYjyG3fsGgbzkoTNleZ3kfYE,14537 -pip/_vendor/chardet/jisfreq.py,sha256=mm8tfrwqhpOd3wzZKS4NJqkYBQVcDfTM2JiQ5aW932E,25796 -pip/_vendor/chardet/johabfreq.py,sha256=dBpOYG34GRX6SL8k_LbS9rxZPMjLjoMlgZ03Pz5Hmqc,42498 -pip/_vendor/chardet/johabprober.py,sha256=O1Qw9nVzRnun7vZp4UZM7wvJSv9W941mEU9uDMnY3DU,1752 -pip/_vendor/chardet/jpcntx.py,sha256=uhHrYWkLxE_rF5OkHKInm0HUsrjgKHHVQvtt3UcvotA,27055 -pip/_vendor/chardet/langbulgarianmodel.py,sha256=vmbvYFP8SZkSxoBvLkFqKiH1sjma5ihk3PTpdy71Rr4,104562 -pip/_vendor/chardet/langgreekmodel.py,sha256=JfB7bupjjJH2w3X_mYnQr9cJA_7EuITC2cRW13fUjeI,98484 -pip/_vendor/chardet/langhebrewmodel.py,sha256=3HXHaLQPNAGcXnJjkIJfozNZLTvTJmf4W5Awi6zRRKc,98196 -pip/_vendor/chardet/langhungarianmodel.py,sha256=WxbeQIxkv8YtApiNqxQcvj-tMycsoI4Xy-fwkDHpP_Y,101363 -pip/_vendor/chardet/langrussianmodel.py,sha256=s395bTZ87ESTrZCOdgXbEjZ9P1iGPwCl_8xSsac_DLY,128035 -pip/_vendor/chardet/langthaimodel.py,sha256=7bJlQitRpTnVGABmbSznHnJwOHDy3InkTvtFUx13WQI,102774 -pip/_vendor/chardet/langturkishmodel.py,sha256=XY0eGdTIy4eQ9Xg1LVPZacb-UBhHBR-cq0IpPVHowKc,95372 -pip/_vendor/chardet/latin1prober.py,sha256=p15EEmFbmQUwbKLC7lOJVGHEZwcG45ubEZYTGu01J5g,5380 -pip/_vendor/chardet/macromanprober.py,sha256=9anfzmY6TBfUPDyBDOdY07kqmTHpZ1tK0jL-p1JWcOY,6077 -pip/_vendor/chardet/mbcharsetprober.py,sha256=Wr04WNI4F3X_VxEverNG-H25g7u-MDDKlNt-JGj-_uU,3715 -pip/_vendor/chardet/mbcsgroupprober.py,sha256=iRpaNBjV0DNwYPu_z6TiHgRpwYahiM7ztI_4kZ4Uz9A,2131 -pip/_vendor/chardet/mbcssm.py,sha256=hUtPvDYgWDaA2dWdgLsshbwRfm3Q5YRlRogdmeRUNQw,30391 -pip/_vendor/chardet/metadata/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -pip/_vendor/chardet/metadata/__pycache__/__init__.cpython-312.pyc,, -pip/_vendor/chardet/metadata/__pycache__/languages.cpython-312.pyc,, -pip/_vendor/chardet/metadata/languages.py,sha256=FhvBIdZFxRQ-dTwkb_0madRKgVBCaUMQz9I5xqjE5iQ,13560 -pip/_vendor/chardet/resultdict.py,sha256=ez4FRvN5KaSosJeJ2WzUyKdDdg35HDy_SSLPXKCdt5M,402 -pip/_vendor/chardet/sbcharsetprober.py,sha256=-nd3F90i7GpXLjehLVHqVBE0KlWzGvQUPETLBNn4o6U,6400 -pip/_vendor/chardet/sbcsgroupprober.py,sha256=gcgI0fOfgw_3YTClpbra_MNxwyEyJ3eUXraoLHYb59E,4137 -pip/_vendor/chardet/sjisprober.py,sha256=aqQufMzRw46ZpFlzmYaYeT2-nzmKb-hmcrApppJ862k,4007 -pip/_vendor/chardet/universaldetector.py,sha256=xYBrg4x0dd9WnT8qclfADVD9ondrUNkqPmvte1pa520,14848 -pip/_vendor/chardet/utf1632prober.py,sha256=pw1epGdMj1hDGiCu1AHqqzOEfjX8MVdiW7O1BlT8-eQ,8505 -pip/_vendor/chardet/utf8prober.py,sha256=8m08Ub5490H4jQ6LYXvFysGtgKoKsHUd2zH_i8_TnVw,2812 -pip/_vendor/chardet/version.py,sha256=lGtJcxGM44Qz4Cbk4rbbmrKxnNr1-97U25TameLehZw,244 -pip/_vendor/colorama/__init__.py,sha256=wePQA4U20tKgYARySLEC047ucNX-g8pRLpYBuiHlLb8,266 -pip/_vendor/colorama/__pycache__/__init__.cpython-312.pyc,, -pip/_vendor/colorama/__pycache__/ansi.cpython-312.pyc,, -pip/_vendor/colorama/__pycache__/ansitowin32.cpython-312.pyc,, -pip/_vendor/colorama/__pycache__/initialise.cpython-312.pyc,, -pip/_vendor/colorama/__pycache__/win32.cpython-312.pyc,, -pip/_vendor/colorama/__pycache__/winterm.cpython-312.pyc,, -pip/_vendor/colorama/ansi.py,sha256=Top4EeEuaQdBWdteKMEcGOTeKeF19Q-Wo_6_Cj5kOzQ,2522 -pip/_vendor/colorama/ansitowin32.py,sha256=vPNYa3OZbxjbuFyaVo0Tmhmy1FZ1lKMWCnT7odXpItk,11128 -pip/_vendor/colorama/initialise.py,sha256=-hIny86ClXo39ixh5iSCfUIa2f_h_bgKRDW7gqs-KLU,3325 -pip/_vendor/colorama/tests/__init__.py,sha256=MkgPAEzGQd-Rq0w0PZXSX2LadRWhUECcisJY8lSrm4Q,75 -pip/_vendor/colorama/tests/__pycache__/__init__.cpython-312.pyc,, -pip/_vendor/colorama/tests/__pycache__/ansi_test.cpython-312.pyc,, -pip/_vendor/colorama/tests/__pycache__/ansitowin32_test.cpython-312.pyc,, -pip/_vendor/colorama/tests/__pycache__/initialise_test.cpython-312.pyc,, -pip/_vendor/colorama/tests/__pycache__/isatty_test.cpython-312.pyc,, -pip/_vendor/colorama/tests/__pycache__/utils.cpython-312.pyc,, -pip/_vendor/colorama/tests/__pycache__/winterm_test.cpython-312.pyc,, -pip/_vendor/colorama/tests/ansi_test.py,sha256=FeViDrUINIZcr505PAxvU4AjXz1asEiALs9GXMhwRaE,2839 -pip/_vendor/colorama/tests/ansitowin32_test.py,sha256=RN7AIhMJ5EqDsYaCjVo-o4u8JzDD4ukJbmevWKS70rY,10678 -pip/_vendor/colorama/tests/initialise_test.py,sha256=BbPy-XfyHwJ6zKozuQOvNvQZzsx9vdb_0bYXn7hsBTc,6741 -pip/_vendor/colorama/tests/isatty_test.py,sha256=Pg26LRpv0yQDB5Ac-sxgVXG7hsA1NYvapFgApZfYzZg,1866 -pip/_vendor/colorama/tests/utils.py,sha256=1IIRylG39z5-dzq09R_ngufxyPZxgldNbrxKxUGwGKE,1079 -pip/_vendor/colorama/tests/winterm_test.py,sha256=qoWFPEjym5gm2RuMwpf3pOis3a5r_PJZFCzK254JL8A,3709 -pip/_vendor/colorama/win32.py,sha256=YQOKwMTwtGBbsY4dL5HYTvwTeP9wIQra5MvPNddpxZs,6181 -pip/_vendor/colorama/winterm.py,sha256=XCQFDHjPi6AHYNdZwy0tA02H-Jh48Jp-HvCjeLeLp3U,7134 -pip/_vendor/distlib/__init__.py,sha256=hJKF7FHoqbmGckncDuEINWo_OYkDNiHODtYXSMcvjcc,625 -pip/_vendor/distlib/__pycache__/__init__.cpython-312.pyc,, -pip/_vendor/distlib/__pycache__/compat.cpython-312.pyc,, -pip/_vendor/distlib/__pycache__/database.cpython-312.pyc,, -pip/_vendor/distlib/__pycache__/index.cpython-312.pyc,, -pip/_vendor/distlib/__pycache__/locators.cpython-312.pyc,, -pip/_vendor/distlib/__pycache__/manifest.cpython-312.pyc,, -pip/_vendor/distlib/__pycache__/markers.cpython-312.pyc,, -pip/_vendor/distlib/__pycache__/metadata.cpython-312.pyc,, -pip/_vendor/distlib/__pycache__/resources.cpython-312.pyc,, -pip/_vendor/distlib/__pycache__/scripts.cpython-312.pyc,, -pip/_vendor/distlib/__pycache__/util.cpython-312.pyc,, -pip/_vendor/distlib/__pycache__/version.cpython-312.pyc,, -pip/_vendor/distlib/__pycache__/wheel.cpython-312.pyc,, -pip/_vendor/distlib/compat.py,sha256=Un-uIBvy02w-D267OG4VEhuddqWgKj9nNkxVltAb75w,41487 -pip/_vendor/distlib/database.py,sha256=0V9Qvs0Vrxa2F_-hLWitIyVyRifJ0pCxyOI-kEOBwsA,51965 -pip/_vendor/distlib/index.py,sha256=lTbw268rRhj8dw1sib3VZ_0EhSGgoJO3FKJzSFMOaeA,20797 -pip/_vendor/distlib/locators.py,sha256=o1r_M86_bRLafSpetmyfX8KRtFu-_Q58abvQrnOSnbA,51767 -pip/_vendor/distlib/manifest.py,sha256=3qfmAmVwxRqU1o23AlfXrQGZzh6g_GGzTAP_Hb9C5zQ,14168 -pip/_vendor/distlib/markers.py,sha256=n3DfOh1yvZ_8EW7atMyoYeZFXjYla0Nz0itQlojCd0A,5268 -pip/_vendor/distlib/metadata.py,sha256=pB9WZ9mBfmQxc9OVIldLS5CjOoQRvKAvUwwQyKwKQtQ,39693 -pip/_vendor/distlib/resources.py,sha256=LwbPksc0A1JMbi6XnuPdMBUn83X7BPuFNWqPGEKI698,10820 -pip/_vendor/distlib/scripts.py,sha256=nQFXN6G7nOWNDUyxirUep-3WOlJhB7McvCs9zOnkGTI,18315 -pip/_vendor/distlib/util.py,sha256=XSznxEi_i3T20UJuaVc0qXHz5ksGUCW1khYlBprN_QE,67530 -pip/_vendor/distlib/version.py,sha256=9pXkduchve_aN7JG6iL9VTYV_kqNSGoc2Dwl8JuySnQ,23747 -pip/_vendor/distlib/wheel.py,sha256=FVQCve8u-L0QYk5-YTZc7s4WmNQdvjRWTK08KXzZVX4,43958 -pip/_vendor/distro/__init__.py,sha256=2fHjF-SfgPvjyNZ1iHh_wjqWdR_Yo5ODHwZC0jLBPhc,981 -pip/_vendor/distro/__main__.py,sha256=bu9d3TifoKciZFcqRBuygV3GSuThnVD_m2IK4cz96Vs,64 -pip/_vendor/distro/__pycache__/__init__.cpython-312.pyc,, -pip/_vendor/distro/__pycache__/__main__.cpython-312.pyc,, -pip/_vendor/distro/__pycache__/distro.cpython-312.pyc,, -pip/_vendor/distro/distro.py,sha256=UZO1LjIhtFCMdlbiz39gj3raV-Amf3SBwzGzfApiMHw,49330 -pip/_vendor/idna/__init__.py,sha256=KJQN1eQBr8iIK5SKrJ47lXvxG0BJ7Lm38W4zT0v_8lk,849 -pip/_vendor/idna/__pycache__/__init__.cpython-312.pyc,, -pip/_vendor/idna/__pycache__/codec.cpython-312.pyc,, -pip/_vendor/idna/__pycache__/compat.cpython-312.pyc,, -pip/_vendor/idna/__pycache__/core.cpython-312.pyc,, -pip/_vendor/idna/__pycache__/idnadata.cpython-312.pyc,, -pip/_vendor/idna/__pycache__/intranges.cpython-312.pyc,, -pip/_vendor/idna/__pycache__/package_data.cpython-312.pyc,, -pip/_vendor/idna/__pycache__/uts46data.cpython-312.pyc,, -pip/_vendor/idna/codec.py,sha256=6ly5odKfqrytKT9_7UrlGklHnf1DSK2r9C6cSM4sa28,3374 -pip/_vendor/idna/compat.py,sha256=0_sOEUMT4CVw9doD3vyRhX80X19PwqFoUBs7gWsFME4,321 -pip/_vendor/idna/core.py,sha256=kkCFNJOrE6I3WwBTXcGNuc24V_QZQ8AULE6EYe1iHlU,12813 -pip/_vendor/idna/idnadata.py,sha256=9NIhTqC2piUpeIMOGZ9Bu_7eAFQ-Ic8TkP_hOzUpnDc,78344 -pip/_vendor/idna/intranges.py,sha256=YBr4fRYuWH7kTKS2tXlFjM24ZF1Pdvcir-aywniInqg,1881 -pip/_vendor/idna/package_data.py,sha256=C_jHJzmX8PI4xq0jpzmcTMxpb5lDsq4o5VyxQzlVrZE,21 -pip/_vendor/idna/uts46data.py,sha256=zvjZU24s58_uAS850Mcd0NnD0X7_gCMAMjzWNIeUJdc,206539 -pip/_vendor/msgpack/__init__.py,sha256=hyGhlnmcJkxryJBKC3X5FnEph375kQoL_mG8LZUuXgY,1132 -pip/_vendor/msgpack/__pycache__/__init__.cpython-312.pyc,, -pip/_vendor/msgpack/__pycache__/exceptions.cpython-312.pyc,, -pip/_vendor/msgpack/__pycache__/ext.cpython-312.pyc,, -pip/_vendor/msgpack/__pycache__/fallback.cpython-312.pyc,, -pip/_vendor/msgpack/exceptions.py,sha256=dCTWei8dpkrMsQDcjQk74ATl9HsIBH0ybt8zOPNqMYc,1081 -pip/_vendor/msgpack/ext.py,sha256=C5MK8JhVYGYFWPvxsORsqZAnvOXefYQ57m1Ym0luW5M,6079 -pip/_vendor/msgpack/fallback.py,sha256=tvNBHyxxFbuVlC8GZShETClJxjLiDMOja4XwwyvNm2g,34544 -pip/_vendor/packaging/__about__.py,sha256=ugASIO2w1oUyH8_COqQ2X_s0rDhjbhQC3yJocD03h2c,661 -pip/_vendor/packaging/__init__.py,sha256=b9Kk5MF7KxhhLgcDmiUWukN-LatWFxPdNug0joPhHSk,497 -pip/_vendor/packaging/__pycache__/__about__.cpython-312.pyc,, -pip/_vendor/packaging/__pycache__/__init__.cpython-312.pyc,, -pip/_vendor/packaging/__pycache__/_manylinux.cpython-312.pyc,, -pip/_vendor/packaging/__pycache__/_musllinux.cpython-312.pyc,, -pip/_vendor/packaging/__pycache__/_structures.cpython-312.pyc,, -pip/_vendor/packaging/__pycache__/markers.cpython-312.pyc,, -pip/_vendor/packaging/__pycache__/requirements.cpython-312.pyc,, -pip/_vendor/packaging/__pycache__/specifiers.cpython-312.pyc,, -pip/_vendor/packaging/__pycache__/tags.cpython-312.pyc,, -pip/_vendor/packaging/__pycache__/utils.cpython-312.pyc,, -pip/_vendor/packaging/__pycache__/version.cpython-312.pyc,, -pip/_vendor/packaging/_manylinux.py,sha256=XcbiXB-qcjv3bcohp6N98TMpOP4_j3m-iOA8ptK2GWY,11488 -pip/_vendor/packaging/_musllinux.py,sha256=_KGgY_qc7vhMGpoqss25n2hiLCNKRtvz9mCrS7gkqyc,4378 -pip/_vendor/packaging/_structures.py,sha256=q3eVNmbWJGG_S0Dit_S3Ao8qQqz_5PYTXFAKBZe5yr4,1431 -pip/_vendor/packaging/markers.py,sha256=AJBOcY8Oq0kYc570KuuPTkvuqjAlhufaE2c9sCUbm64,8487 -pip/_vendor/packaging/requirements.py,sha256=NtDlPBtojpn1IUC85iMjPNsUmufjpSlwnNA-Xb4m5NA,4676 -pip/_vendor/packaging/specifiers.py,sha256=LRQ0kFsHrl5qfcFNEEJrIFYsnIHQUJXY9fIsakTrrqE,30110 -pip/_vendor/packaging/tags.py,sha256=lmsnGNiJ8C4D_Pf9PbM0qgbZvD9kmB9lpZBQUZa3R_Y,15699 -pip/_vendor/packaging/utils.py,sha256=dJjeat3BS-TYn1RrUFVwufUMasbtzLfYRoy_HXENeFQ,4200 -pip/_vendor/packaging/version.py,sha256=_fLRNrFrxYcHVfyo8vk9j8s6JM8N_xsSxVFr6RJyco8,14665 -pip/_vendor/pkg_resources/__init__.py,sha256=hTAeJCNYb7dJseIDVsYK3mPQep_gphj4tQh-bspX8bg,109364 -pip/_vendor/pkg_resources/__pycache__/__init__.cpython-312.pyc,, -pip/_vendor/platformdirs/__init__.py,sha256=SkhEYVyC_HUHC6KX7n4M_6coyRMtEB38QMyOYIAX6Yk,20155 -pip/_vendor/platformdirs/__main__.py,sha256=fVvSiTzr2-RM6IsjWjj4fkaOtDOgDhUWv6sA99do4CQ,1476 -pip/_vendor/platformdirs/__pycache__/__init__.cpython-312.pyc,, -pip/_vendor/platformdirs/__pycache__/__main__.cpython-312.pyc,, -pip/_vendor/platformdirs/__pycache__/android.cpython-312.pyc,, -pip/_vendor/platformdirs/__pycache__/api.cpython-312.pyc,, -pip/_vendor/platformdirs/__pycache__/macos.cpython-312.pyc,, -pip/_vendor/platformdirs/__pycache__/unix.cpython-312.pyc,, -pip/_vendor/platformdirs/__pycache__/version.cpython-312.pyc,, -pip/_vendor/platformdirs/__pycache__/windows.cpython-312.pyc,, -pip/_vendor/platformdirs/android.py,sha256=y_EEMKwYl2-bzYBDovksSn8m76on0Lda8eyJksVQE9U,7211 -pip/_vendor/platformdirs/api.py,sha256=jWtX06jAJytYrkJDOqEls97mCkyHRSZkoqUlbMK5Qew,7132 -pip/_vendor/platformdirs/macos.py,sha256=LueVOoVgGWDBwQb8OFwXkVKfVn33CM1Lkwf1-A86tRQ,3678 -pip/_vendor/platformdirs/unix.py,sha256=22JhR8ZY0aLxSVCFnKrc6f1iz6Gv42K24Daj7aTjfSg,8809 -pip/_vendor/platformdirs/version.py,sha256=mavZTQIJIXfdewEaSTn7EWrNfPZWeRofb-74xqW5f2M,160 -pip/_vendor/platformdirs/windows.py,sha256=4TtbPGoWG2PRgI11uquDa7eRk8TcxvnUNuuMGZItnXc,9573 -pip/_vendor/pygments/__init__.py,sha256=6AuDljQtvf89DTNUyWM7k3oUlP_lq70NU-INKKteOBY,2983 -pip/_vendor/pygments/__main__.py,sha256=es8EKMvXj5yToIfQ-pf3Dv5TnIeeM6sME0LW-n4ecHo,353 -pip/_vendor/pygments/__pycache__/__init__.cpython-312.pyc,, -pip/_vendor/pygments/__pycache__/__main__.cpython-312.pyc,, -pip/_vendor/pygments/__pycache__/cmdline.cpython-312.pyc,, -pip/_vendor/pygments/__pycache__/console.cpython-312.pyc,, -pip/_vendor/pygments/__pycache__/filter.cpython-312.pyc,, -pip/_vendor/pygments/__pycache__/formatter.cpython-312.pyc,, -pip/_vendor/pygments/__pycache__/lexer.cpython-312.pyc,, -pip/_vendor/pygments/__pycache__/modeline.cpython-312.pyc,, -pip/_vendor/pygments/__pycache__/plugin.cpython-312.pyc,, -pip/_vendor/pygments/__pycache__/regexopt.cpython-312.pyc,, -pip/_vendor/pygments/__pycache__/scanner.cpython-312.pyc,, -pip/_vendor/pygments/__pycache__/sphinxext.cpython-312.pyc,, -pip/_vendor/pygments/__pycache__/style.cpython-312.pyc,, -pip/_vendor/pygments/__pycache__/token.cpython-312.pyc,, -pip/_vendor/pygments/__pycache__/unistring.cpython-312.pyc,, -pip/_vendor/pygments/__pycache__/util.cpython-312.pyc,, -pip/_vendor/pygments/cmdline.py,sha256=byxYJp9gnjVeyhRlZ3UTMgo_LhkXh1afvN8wJBtAcc8,23685 -pip/_vendor/pygments/console.py,sha256=2wZ5W-U6TudJD1_NLUwjclMpbomFM91lNv11_60sfGY,1697 -pip/_vendor/pygments/filter.py,sha256=j5aLM9a9wSx6eH1oy473oSkJ02hGWNptBlVo4s1g_30,1938 -pip/_vendor/pygments/filters/__init__.py,sha256=h_koYkUFo-FFUxjs564JHUAz7O3yJpVwI6fKN3MYzG0,40386 -pip/_vendor/pygments/filters/__pycache__/__init__.cpython-312.pyc,, -pip/_vendor/pygments/formatter.py,sha256=J9OL9hXLJKZk7moUgKwpjW9HNf4WlJFg_o_-Z_S_tTY,4178 -pip/_vendor/pygments/formatters/__init__.py,sha256=_xgAcdFKr0QNYwh_i98AU9hvfP3X2wAkhElFcRRF3Uo,5424 -pip/_vendor/pygments/formatters/__pycache__/__init__.cpython-312.pyc,, -pip/_vendor/pygments/formatters/__pycache__/_mapping.cpython-312.pyc,, -pip/_vendor/pygments/formatters/__pycache__/bbcode.cpython-312.pyc,, -pip/_vendor/pygments/formatters/__pycache__/groff.cpython-312.pyc,, -pip/_vendor/pygments/formatters/__pycache__/html.cpython-312.pyc,, -pip/_vendor/pygments/formatters/__pycache__/img.cpython-312.pyc,, -pip/_vendor/pygments/formatters/__pycache__/irc.cpython-312.pyc,, -pip/_vendor/pygments/formatters/__pycache__/latex.cpython-312.pyc,, -pip/_vendor/pygments/formatters/__pycache__/other.cpython-312.pyc,, -pip/_vendor/pygments/formatters/__pycache__/pangomarkup.cpython-312.pyc,, -pip/_vendor/pygments/formatters/__pycache__/rtf.cpython-312.pyc,, -pip/_vendor/pygments/formatters/__pycache__/svg.cpython-312.pyc,, -pip/_vendor/pygments/formatters/__pycache__/terminal.cpython-312.pyc,, -pip/_vendor/pygments/formatters/__pycache__/terminal256.cpython-312.pyc,, -pip/_vendor/pygments/formatters/_mapping.py,sha256=1Cw37FuQlNacnxRKmtlPX4nyLoX9_ttko5ZwscNUZZ4,4176 -pip/_vendor/pygments/formatters/bbcode.py,sha256=r1b7wzWTJouADDLh-Z11iRi4iQxD0JKJ1qHl6mOYxsA,3314 -pip/_vendor/pygments/formatters/groff.py,sha256=xy8Zf3tXOo6MWrXh7yPGWx3lVEkg_DhY4CxmsDb0IVo,5094 -pip/_vendor/pygments/formatters/html.py,sha256=PIzAyilNqaTzSSP2slDG2VDLE3qNioWy2rgtSSoviuI,35610 -pip/_vendor/pygments/formatters/img.py,sha256=XKXmg2_XONrR4mtq2jfEU8XCsoln3VSGTw-UYiEokys,21938 -pip/_vendor/pygments/formatters/irc.py,sha256=Ep-m8jd3voFO6Fv57cUGFmz6JVA67IEgyiBOwv0N4a0,4981 -pip/_vendor/pygments/formatters/latex.py,sha256=FGzJ-YqSTE8z_voWPdzvLY5Tq8jE_ygjGjM6dXZJ8-k,19351 -pip/_vendor/pygments/formatters/other.py,sha256=gPxkk5BdAzWTCgbEHg1lpLi-1F6ZPh5A_aotgLXHnzg,5073 -pip/_vendor/pygments/formatters/pangomarkup.py,sha256=6LKnQc8yh49f802bF0sPvbzck4QivMYqqoXAPaYP8uU,2212 -pip/_vendor/pygments/formatters/rtf.py,sha256=aA0v_psW6KZI3N18TKDifxeL6mcF8EDXcPXDWI4vhVQ,5014 -pip/_vendor/pygments/formatters/svg.py,sha256=dQONWypbzfvzGCDtdp3M_NJawScJvM2DiHbx1k-ww7g,7335 -pip/_vendor/pygments/formatters/terminal.py,sha256=FG-rpjRpFmNpiGB4NzIucvxq6sQIXB3HOTo2meTKtrU,4674 -pip/_vendor/pygments/formatters/terminal256.py,sha256=13SJ3D5pFdqZ9zROE6HbWnBDwHvOGE8GlsmqGhprRp4,11753 -pip/_vendor/pygments/lexer.py,sha256=2BpqLlT2ExvOOi7vnjK5nB4Fp-m52ldiPaXMox5uwug,34618 -pip/_vendor/pygments/lexers/__init__.py,sha256=j5KEi5O_VQ5GS59H49l-10gzUOkWKxlwGeVMlGO2MMk,12130 -pip/_vendor/pygments/lexers/__pycache__/__init__.cpython-312.pyc,, -pip/_vendor/pygments/lexers/__pycache__/_mapping.cpython-312.pyc,, -pip/_vendor/pygments/lexers/__pycache__/python.cpython-312.pyc,, -pip/_vendor/pygments/lexers/_mapping.py,sha256=Hts4r_ZQ8icftGM7gkBPeED5lyVSv4affFgXYE6Ap04,72281 -pip/_vendor/pygments/lexers/python.py,sha256=c7jnmKFU9DLxTJW0UbwXt6Z9FJqbBlVsWA1Qr9xSA_w,53424 -pip/_vendor/pygments/modeline.py,sha256=eF2vO4LpOGoPvIKKkbPfnyut8hT4UiebZPpb-BYGQdI,986 -pip/_vendor/pygments/plugin.py,sha256=j1Fh310RbV2DQ9nvkmkqvlj38gdyuYKllLnGxbc8sJM,2591 -pip/_vendor/pygments/regexopt.py,sha256=jg1ALogcYGU96TQS9isBl6dCrvw5y5--BP_K-uFk_8s,3072 -pip/_vendor/pygments/scanner.py,sha256=b_nu5_f3HCgSdp5S_aNRBQ1MSCm4ZjDwec2OmTRickw,3092 -pip/_vendor/pygments/sphinxext.py,sha256=wBFYm180qea9JKt__UzhRlNRNhczPDFDaqGD21sbuso,6882 -pip/_vendor/pygments/style.py,sha256=C4qyoJrUTkq-OV3iO-8Vz3UtWYpJwSTdh5_vlGCGdNQ,6257 -pip/_vendor/pygments/styles/__init__.py,sha256=he7HjQx7sC0d2kfTVLjUs0J15mtToJM6M1brwIm9--Q,3700 -pip/_vendor/pygments/styles/__pycache__/__init__.cpython-312.pyc,, -pip/_vendor/pygments/token.py,sha256=seNsmcch9OEHXYirh8Ool7w8xDhfNTbLj5rHAC-gc_o,6184 -pip/_vendor/pygments/unistring.py,sha256=FaUfG14NBJEKLQoY9qj6JYeXrpYcLmKulghdxOGFaOc,63223 -pip/_vendor/pygments/util.py,sha256=AEVY0qonyyEMgv4Do2dINrrqUAwUk2XYSqHM650uzek,10230 -pip/_vendor/pyparsing/__init__.py,sha256=9m1JbE2JTLdBG0Mb6B0lEaZj181Wx5cuPXZpsbHEYgE,9116 -pip/_vendor/pyparsing/__pycache__/__init__.cpython-312.pyc,, -pip/_vendor/pyparsing/__pycache__/actions.cpython-312.pyc,, -pip/_vendor/pyparsing/__pycache__/common.cpython-312.pyc,, -pip/_vendor/pyparsing/__pycache__/core.cpython-312.pyc,, -pip/_vendor/pyparsing/__pycache__/exceptions.cpython-312.pyc,, -pip/_vendor/pyparsing/__pycache__/helpers.cpython-312.pyc,, -pip/_vendor/pyparsing/__pycache__/results.cpython-312.pyc,, -pip/_vendor/pyparsing/__pycache__/testing.cpython-312.pyc,, -pip/_vendor/pyparsing/__pycache__/unicode.cpython-312.pyc,, -pip/_vendor/pyparsing/__pycache__/util.cpython-312.pyc,, -pip/_vendor/pyparsing/actions.py,sha256=05uaIPOznJPQ7VgRdmGCmG4sDnUPtwgv5qOYIqbL2UY,6567 -pip/_vendor/pyparsing/common.py,sha256=p-3c83E5-DjlkF35G0O9-kjQRpoejP-2_z0hxZ-eol4,13387 -pip/_vendor/pyparsing/core.py,sha256=yvuRlLpXSF8mgk-QhiW3OVLqD9T0rsj9tbibhRH4Yaw,224445 -pip/_vendor/pyparsing/diagram/__init__.py,sha256=nxmDOoYF9NXuLaGYy01tKFjkNReWJlrGFuJNWEiTo84,24215 -pip/_vendor/pyparsing/diagram/__pycache__/__init__.cpython-312.pyc,, -pip/_vendor/pyparsing/exceptions.py,sha256=6Jc6W1eDZBzyFu1J0YrcdNFVBC-RINujZmveSnB8Rxw,9523 -pip/_vendor/pyparsing/helpers.py,sha256=BZJHCA8SS0pYio30KGQTc9w2qMOaK4YpZ7hcvHbnTgk,38646 -pip/_vendor/pyparsing/results.py,sha256=9dyqQ-w3MjfmxWbFt8KEPU6IfXeyRdoWp2Og802rUQY,26692 -pip/_vendor/pyparsing/testing.py,sha256=eJncg0p83zm1FTPvM9auNT6oavIvXaibmRFDf1qmwkY,13488 -pip/_vendor/pyparsing/unicode.py,sha256=fAPdsJiARFbkPAih6NkYry0dpj4jPqelGVMlE4wWFW8,10646 -pip/_vendor/pyparsing/util.py,sha256=vTMzTdwSDyV8d_dSgquUTdWgBFoA_W30nfxEJDsshRQ,8670 -pip/_vendor/pyproject_hooks/__init__.py,sha256=kCehmy0UaBa9oVMD7ZIZrnswfnP3LXZ5lvnNJAL5JBM,491 -pip/_vendor/pyproject_hooks/__pycache__/__init__.cpython-312.pyc,, -pip/_vendor/pyproject_hooks/__pycache__/_compat.cpython-312.pyc,, -pip/_vendor/pyproject_hooks/__pycache__/_impl.cpython-312.pyc,, -pip/_vendor/pyproject_hooks/_compat.py,sha256=by6evrYnqkisiM-MQcvOKs5bgDMzlOSgZqRHNqf04zE,138 -pip/_vendor/pyproject_hooks/_impl.py,sha256=61GJxzQip0IInhuO69ZI5GbNQ82XEDUB_1Gg5_KtUoc,11920 -pip/_vendor/pyproject_hooks/_in_process/__init__.py,sha256=9gQATptbFkelkIy0OfWFEACzqxXJMQDWCH9rBOAZVwQ,546 -pip/_vendor/pyproject_hooks/_in_process/__pycache__/__init__.cpython-312.pyc,, -pip/_vendor/pyproject_hooks/_in_process/__pycache__/_in_process.cpython-312.pyc,, -pip/_vendor/pyproject_hooks/_in_process/_in_process.py,sha256=m2b34c917IW5o-Q_6TYIHlsK9lSUlNiyrITTUH_zwew,10927 -pip/_vendor/requests/__init__.py,sha256=owujob4dk45Siy4EYtbCKR6wcFph7E04a_v_OuAacBA,5169 -pip/_vendor/requests/__pycache__/__init__.cpython-312.pyc,, -pip/_vendor/requests/__pycache__/__version__.cpython-312.pyc,, -pip/_vendor/requests/__pycache__/_internal_utils.cpython-312.pyc,, -pip/_vendor/requests/__pycache__/adapters.cpython-312.pyc,, -pip/_vendor/requests/__pycache__/api.cpython-312.pyc,, -pip/_vendor/requests/__pycache__/auth.cpython-312.pyc,, -pip/_vendor/requests/__pycache__/certs.cpython-312.pyc,, -pip/_vendor/requests/__pycache__/compat.cpython-312.pyc,, -pip/_vendor/requests/__pycache__/cookies.cpython-312.pyc,, -pip/_vendor/requests/__pycache__/exceptions.cpython-312.pyc,, -pip/_vendor/requests/__pycache__/help.cpython-312.pyc,, -pip/_vendor/requests/__pycache__/hooks.cpython-312.pyc,, -pip/_vendor/requests/__pycache__/models.cpython-312.pyc,, -pip/_vendor/requests/__pycache__/packages.cpython-312.pyc,, -pip/_vendor/requests/__pycache__/sessions.cpython-312.pyc,, -pip/_vendor/requests/__pycache__/status_codes.cpython-312.pyc,, -pip/_vendor/requests/__pycache__/structures.cpython-312.pyc,, -pip/_vendor/requests/__pycache__/utils.cpython-312.pyc,, -pip/_vendor/requests/__version__.py,sha256=ssI3Ezt7PaxgkOW45GhtwPUclo_SO_ygtIm4A74IOfw,435 -pip/_vendor/requests/_internal_utils.py,sha256=nMQymr4hs32TqVo5AbCrmcJEhvPUh7xXlluyqwslLiQ,1495 -pip/_vendor/requests/adapters.py,sha256=idj6cZcId3L5xNNeJ7ieOLtw3awJk5A64xUfetHwq3M,19697 -pip/_vendor/requests/api.py,sha256=q61xcXq4tmiImrvcSVLTbFyCiD2F-L_-hWKGbz4y8vg,6449 -pip/_vendor/requests/auth.py,sha256=h-HLlVx9j8rKV5hfSAycP2ApOSglTz77R0tz7qCbbEE,10187 -pip/_vendor/requests/certs.py,sha256=PVPooB0jP5hkZEULSCwC074532UFbR2Ptgu0I5zwmCs,575 -pip/_vendor/requests/compat.py,sha256=IhK9quyX0RRuWTNcg6d2JGSAOUbM6mym2p_2XjLTwf4,1286 -pip/_vendor/requests/cookies.py,sha256=kD3kNEcCj-mxbtf5fJsSaT86eGoEYpD3X0CSgpzl7BM,18560 -pip/_vendor/requests/exceptions.py,sha256=FA-_kVwBZ2jhXauRctN_ewHVK25b-fj0Azyz1THQ0Kk,3823 -pip/_vendor/requests/help.py,sha256=FnAAklv8MGm_qb2UilDQgS6l0cUttiCFKUjx0zn2XNA,3879 -pip/_vendor/requests/hooks.py,sha256=CiuysiHA39V5UfcCBXFIx83IrDpuwfN9RcTUgv28ftQ,733 -pip/_vendor/requests/models.py,sha256=dDZ-iThotky-Noq9yy97cUEJhr3wnY6mv-xR_ePg_lk,35288 -pip/_vendor/requests/packages.py,sha256=njJmVifY4aSctuW3PP5EFRCxjEwMRDO6J_feG2dKWsI,695 -pip/_vendor/requests/sessions.py,sha256=-LvTzrPtetSTrR3buxu4XhdgMrJFLB1q5D7P--L2Xhw,30373 -pip/_vendor/requests/status_codes.py,sha256=FvHmT5uH-_uimtRz5hH9VCbt7VV-Nei2J9upbej6j8g,4235 -pip/_vendor/requests/structures.py,sha256=-IbmhVz06S-5aPSZuUthZ6-6D9XOjRuTXHOabY041XM,2912 -pip/_vendor/requests/utils.py,sha256=BvQDKkLuXCSaVfSW_1blUN0IzJSfNC8njNr8vhKj76Y,33189 -pip/_vendor/resolvelib/__init__.py,sha256=h509TdEcpb5-44JonaU3ex2TM15GVBLjM9CNCPwnTTs,537 -pip/_vendor/resolvelib/__pycache__/__init__.cpython-312.pyc,, -pip/_vendor/resolvelib/__pycache__/providers.cpython-312.pyc,, -pip/_vendor/resolvelib/__pycache__/reporters.cpython-312.pyc,, -pip/_vendor/resolvelib/__pycache__/resolvers.cpython-312.pyc,, -pip/_vendor/resolvelib/__pycache__/structs.cpython-312.pyc,, -pip/_vendor/resolvelib/compat/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -pip/_vendor/resolvelib/compat/__pycache__/__init__.cpython-312.pyc,, -pip/_vendor/resolvelib/compat/__pycache__/collections_abc.cpython-312.pyc,, -pip/_vendor/resolvelib/compat/collections_abc.py,sha256=uy8xUZ-NDEw916tugUXm8HgwCGiMO0f-RcdnpkfXfOs,156 -pip/_vendor/resolvelib/providers.py,sha256=fuuvVrCetu5gsxPB43ERyjfO8aReS3rFQHpDgiItbs4,5871 -pip/_vendor/resolvelib/reporters.py,sha256=TSbRmWzTc26w0ggsV1bxVpeWDB8QNIre6twYl7GIZBE,1601 -pip/_vendor/resolvelib/resolvers.py,sha256=G8rsLZSq64g5VmIq-lB7UcIJ1gjAxIQJmTF4REZleQ0,20511 -pip/_vendor/resolvelib/structs.py,sha256=0_1_XO8z_CLhegP3Vpf9VJ3zJcfLm0NOHRM-i0Ykz3o,4963 -pip/_vendor/rich/__init__.py,sha256=dRxjIL-SbFVY0q3IjSMrfgBTHrm1LZDgLOygVBwiYZc,6090 -pip/_vendor/rich/__main__.py,sha256=TT8sb9PTnsnKhhrGuHkLN0jdN0dtKhtPkEr9CidDbPM,8478 -pip/_vendor/rich/__pycache__/__init__.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/__main__.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/_cell_widths.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/_emoji_codes.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/_emoji_replace.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/_export_format.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/_extension.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/_fileno.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/_inspect.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/_log_render.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/_loop.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/_null_file.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/_palettes.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/_pick.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/_ratio.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/_spinners.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/_stack.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/_timer.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/_win32_console.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/_windows.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/_windows_renderer.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/_wrap.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/abc.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/align.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/ansi.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/bar.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/box.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/cells.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/color.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/color_triplet.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/columns.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/console.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/constrain.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/containers.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/control.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/default_styles.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/diagnose.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/emoji.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/errors.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/file_proxy.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/filesize.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/highlighter.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/json.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/jupyter.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/layout.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/live.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/live_render.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/logging.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/markup.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/measure.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/padding.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/pager.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/palette.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/panel.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/pretty.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/progress.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/progress_bar.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/prompt.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/protocol.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/region.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/repr.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/rule.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/scope.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/screen.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/segment.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/spinner.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/status.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/style.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/styled.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/syntax.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/table.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/terminal_theme.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/text.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/theme.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/themes.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/traceback.cpython-312.pyc,, -pip/_vendor/rich/__pycache__/tree.cpython-312.pyc,, -pip/_vendor/rich/_cell_widths.py,sha256=2n4EiJi3X9sqIq0O16kUZ_zy6UYMd3xFfChlKfnW1Hc,10096 -pip/_vendor/rich/_emoji_codes.py,sha256=hu1VL9nbVdppJrVoijVshRlcRRe_v3dju3Mmd2sKZdY,140235 -pip/_vendor/rich/_emoji_replace.py,sha256=n-kcetsEUx2ZUmhQrfeMNc-teeGhpuSQ5F8VPBsyvDo,1064 -pip/_vendor/rich/_export_format.py,sha256=qxgV3nKnXQu1hfbnRVswPYy-AwIg1X0LSC47cK5s8jk,2100 -pip/_vendor/rich/_extension.py,sha256=Xt47QacCKwYruzjDi-gOBq724JReDj9Cm9xUi5fr-34,265 -pip/_vendor/rich/_fileno.py,sha256=HWZxP5C2ajMbHryvAQZseflVfQoGzsKOHzKGsLD8ynQ,799 -pip/_vendor/rich/_inspect.py,sha256=oZJGw31e64dwXSCmrDnvZbwVb1ZKhWfU8wI3VWohjJk,9695 -pip/_vendor/rich/_log_render.py,sha256=1ByI0PA1ZpxZY3CGJOK54hjlq4X-Bz_boIjIqCd8Kns,3225 -pip/_vendor/rich/_loop.py,sha256=hV_6CLdoPm0va22Wpw4zKqM0RYsz3TZxXj0PoS-9eDQ,1236 -pip/_vendor/rich/_null_file.py,sha256=tGSXk_v-IZmbj1GAzHit8A3kYIQMiCpVsCFfsC-_KJ4,1387 -pip/_vendor/rich/_palettes.py,sha256=cdev1JQKZ0JvlguV9ipHgznTdnvlIzUFDBb0It2PzjI,7063 -pip/_vendor/rich/_pick.py,sha256=evDt8QN4lF5CiwrUIXlOJCntitBCOsI3ZLPEIAVRLJU,423 -pip/_vendor/rich/_ratio.py,sha256=2lLSliL025Y-YMfdfGbutkQDevhcyDqc-DtUYW9mU70,5472 -pip/_vendor/rich/_spinners.py,sha256=U2r1_g_1zSjsjiUdAESc2iAMc3i4ri_S8PYP6kQ5z1I,19919 -pip/_vendor/rich/_stack.py,sha256=-C8OK7rxn3sIUdVwxZBBpeHhIzX0eI-VM3MemYfaXm0,351 -pip/_vendor/rich/_timer.py,sha256=zelxbT6oPFZnNrwWPpc1ktUeAT-Vc4fuFcRZLQGLtMI,417 -pip/_vendor/rich/_win32_console.py,sha256=P0vxI2fcndym1UU1S37XAzQzQnkyY7YqAKmxm24_gug,22820 -pip/_vendor/rich/_windows.py,sha256=dvNl9TmfPzNVxiKk5WDFihErZ5796g2UC9-KGGyfXmk,1926 -pip/_vendor/rich/_windows_renderer.py,sha256=t74ZL3xuDCP3nmTp9pH1L5LiI2cakJuQRQleHCJerlk,2783 -pip/_vendor/rich/_wrap.py,sha256=xfV_9t0Sg6rzimmrDru8fCVmUlalYAcHLDfrJZnbbwQ,1840 -pip/_vendor/rich/abc.py,sha256=ON-E-ZqSSheZ88VrKX2M3PXpFbGEUUZPMa_Af0l-4f0,890 -pip/_vendor/rich/align.py,sha256=Ji-Yokfkhnfe_xMmr4ISjZB07TJXggBCOYoYa-HDAr8,10368 -pip/_vendor/rich/ansi.py,sha256=iD6532QYqnBm6hADulKjrV8l8kFJ-9fEVooHJHH3hMg,6906 -pip/_vendor/rich/bar.py,sha256=a7UD303BccRCrEhGjfMElpv5RFYIinaAhAuqYqhUvmw,3264 -pip/_vendor/rich/box.py,sha256=FJ6nI3jD7h2XNFU138bJUt2HYmWOlRbltoCEuIAZhew,9842 -pip/_vendor/rich/cells.py,sha256=627ztJs9zOL-38HJ7kXBerR-gT8KBfYC8UzEwMJDYYo,4509 -pip/_vendor/rich/color.py,sha256=9Gh958U3f75WVdLTeC0U9nkGTn2n0wnojKpJ6jQEkIE,18224 -pip/_vendor/rich/color_triplet.py,sha256=3lhQkdJbvWPoLDO-AnYImAWmJvV5dlgYNCVZ97ORaN4,1054 -pip/_vendor/rich/columns.py,sha256=HUX0KcMm9dsKNi11fTbiM_h2iDtl8ySCaVcxlalEzq8,7131 -pip/_vendor/rich/console.py,sha256=pDvkbLkvtZIMIwQx_jkZ-seyNl4zGBLviXoWXte9fwg,99218 -pip/_vendor/rich/constrain.py,sha256=1VIPuC8AgtKWrcncQrjBdYqA3JVWysu6jZo1rrh7c7Q,1288 -pip/_vendor/rich/containers.py,sha256=aKgm5UDHn5Nmui6IJaKdsZhbHClh_X7D-_Wg8Ehrr7s,5497 -pip/_vendor/rich/control.py,sha256=DSkHTUQLorfSERAKE_oTAEUFefZnZp4bQb4q8rHbKws,6630 -pip/_vendor/rich/default_styles.py,sha256=-Fe318kMVI_IwciK5POpThcO0-9DYJ67TZAN6DlmlmM,8082 -pip/_vendor/rich/diagnose.py,sha256=an6uouwhKPAlvQhYpNNpGq9EJysfMIOvvCbO3oSoR24,972 -pip/_vendor/rich/emoji.py,sha256=omTF9asaAnsM4yLY94eR_9dgRRSm1lHUszX20D1yYCQ,2501 -pip/_vendor/rich/errors.py,sha256=5pP3Kc5d4QJ_c0KFsxrfyhjiPVe7J1zOqSFbFAzcV-Y,642 -pip/_vendor/rich/file_proxy.py,sha256=Tl9THMDZ-Pk5Wm8sI1gGg_U5DhusmxD-FZ0fUbcU0W0,1683 -pip/_vendor/rich/filesize.py,sha256=9fTLAPCAwHmBXdRv7KZU194jSgNrRb6Wx7RIoBgqeKY,2508 -pip/_vendor/rich/highlighter.py,sha256=p3C1g4QYzezFKdR7NF9EhPbzQDvdPUhGRgSyGGEmPko,9584 -pip/_vendor/rich/json.py,sha256=EYp9ucj-nDjYDkHCV6Mk1ve8nUOpuFLaW76X50Mis2M,5032 -pip/_vendor/rich/jupyter.py,sha256=QyoKoE_8IdCbrtiSHp9TsTSNyTHY0FO5whE7jOTd9UE,3252 -pip/_vendor/rich/layout.py,sha256=RFYL6HdCFsHf9WRpcvi3w-fpj-8O5dMZ8W96VdKNdbI,14007 -pip/_vendor/rich/live.py,sha256=vZzYvu7fqwlv3Gthl2xiw1Dc_O80VlGcCV0DOHwCyDM,14273 -pip/_vendor/rich/live_render.py,sha256=zElm3PrfSIvjOce28zETHMIUf9pFYSUA5o0AflgUP64,3667 -pip/_vendor/rich/logging.py,sha256=uB-cB-3Q4bmXDLLpbOWkmFviw-Fde39zyMV6tKJ2WHQ,11903 -pip/_vendor/rich/markup.py,sha256=xzF4uAafiEeEYDJYt_vUnJOGoTU8RrH-PH7WcWYXjCg,8198 -pip/_vendor/rich/measure.py,sha256=HmrIJX8sWRTHbgh8MxEay_83VkqNW_70s8aKP5ZcYI8,5305 -pip/_vendor/rich/padding.py,sha256=kTFGsdGe0os7tXLnHKpwTI90CXEvrceeZGCshmJy5zw,4970 -pip/_vendor/rich/pager.py,sha256=SO_ETBFKbg3n_AgOzXm41Sv36YxXAyI3_R-KOY2_uSc,828 -pip/_vendor/rich/palette.py,sha256=lInvR1ODDT2f3UZMfL1grq7dY_pDdKHw4bdUgOGaM4Y,3396 -pip/_vendor/rich/panel.py,sha256=wGMe40J8KCGgQoM0LyjRErmGIkv2bsYA71RCXThD0xE,10574 -pip/_vendor/rich/pretty.py,sha256=eLEYN9xVaMNuA6EJVYm4li7HdOHxCqmVKvnOqJpyFt0,35852 -pip/_vendor/rich/progress.py,sha256=n4KF9vky8_5iYeXcyZPEvzyLplWlDvFLkM5JI0Bs08A,59706 -pip/_vendor/rich/progress_bar.py,sha256=cEoBfkc3lLwqba4XKsUpy4vSQKDh2QQ5J2J94-ACFoo,8165 -pip/_vendor/rich/prompt.py,sha256=x0mW-pIPodJM4ry6grgmmLrl8VZp99kqcmdnBe70YYA,11303 -pip/_vendor/rich/protocol.py,sha256=5hHHDDNHckdk8iWH5zEbi-zuIVSF5hbU2jIo47R7lTE,1391 -pip/_vendor/rich/region.py,sha256=rNT9xZrVZTYIXZC0NYn41CJQwYNbR-KecPOxTgQvB8Y,166 -pip/_vendor/rich/repr.py,sha256=9Z8otOmM-tyxnyTodvXlectP60lwahjGiDTrbrxPSTg,4431 -pip/_vendor/rich/rule.py,sha256=0fNaS_aERa3UMRc3T5WMpN_sumtDxfaor2y3of1ftBk,4602 -pip/_vendor/rich/scope.py,sha256=TMUU8qo17thyqQCPqjDLYpg_UU1k5qVd-WwiJvnJVas,2843 -pip/_vendor/rich/screen.py,sha256=YoeReESUhx74grqb0mSSb9lghhysWmFHYhsbMVQjXO8,1591 -pip/_vendor/rich/segment.py,sha256=XLnJEFvcV3bjaVzMNUJiem3n8lvvI9TJ5PTu-IG2uTg,24247 -pip/_vendor/rich/spinner.py,sha256=15koCmF0DQeD8-k28Lpt6X_zJQUlzEhgo_6A6uy47lc,4339 -pip/_vendor/rich/status.py,sha256=gJsIXIZeSo3urOyxRUjs6VrhX5CZrA0NxIQ-dxhCnwo,4425 -pip/_vendor/rich/style.py,sha256=3hiocH_4N8vwRm3-8yFWzM7tSwjjEven69XqWasSQwM,27073 -pip/_vendor/rich/styled.py,sha256=eZNnzGrI4ki_54pgY3Oj0T-x3lxdXTYh4_ryDB24wBU,1258 -pip/_vendor/rich/syntax.py,sha256=jgDiVCK6cpR0NmBOpZmIu-Ud4eaW7fHvjJZkDbjpcSA,35173 -pip/_vendor/rich/table.py,sha256=-WzesL-VJKsaiDU3uyczpJMHy6VCaSewBYJwx8RudI8,39684 -pip/_vendor/rich/terminal_theme.py,sha256=1j5-ufJfnvlAo5Qsi_ACZiXDmwMXzqgmFByObT9-yJY,3370 -pip/_vendor/rich/text.py,sha256=_8JBlSau0c2z8ENOZMi1hJ7M1ZGY408E4-hXjHyyg1A,45525 -pip/_vendor/rich/theme.py,sha256=belFJogzA0W0HysQabKaHOc3RWH2ko3fQAJhoN-AFdo,3777 -pip/_vendor/rich/themes.py,sha256=0xgTLozfabebYtcJtDdC5QkX5IVUEaviqDUJJh4YVFk,102 -pip/_vendor/rich/traceback.py,sha256=yCLVrCtyoFNENd9mkm2xeG3KmqkTwH9xpFOO7p2Bq0A,29604 -pip/_vendor/rich/tree.py,sha256=BMbUYNjS9uodNPfvtY_odmU09GA5QzcMbQ5cJZhllQI,9169 -pip/_vendor/six.py,sha256=TOOfQi7nFGfMrIvtdr6wX4wyHH8M7aknmuLfo2cBBrM,34549 -pip/_vendor/tenacity/__init__.py,sha256=3kvAL6KClq8GFo2KFhmOzskRKSDQI-ubrlfZ8AQEEI0,20493 -pip/_vendor/tenacity/__pycache__/__init__.cpython-312.pyc,, -pip/_vendor/tenacity/__pycache__/_asyncio.cpython-312.pyc,, -pip/_vendor/tenacity/__pycache__/_utils.cpython-312.pyc,, -pip/_vendor/tenacity/__pycache__/after.cpython-312.pyc,, -pip/_vendor/tenacity/__pycache__/before.cpython-312.pyc,, -pip/_vendor/tenacity/__pycache__/before_sleep.cpython-312.pyc,, -pip/_vendor/tenacity/__pycache__/nap.cpython-312.pyc,, -pip/_vendor/tenacity/__pycache__/retry.cpython-312.pyc,, -pip/_vendor/tenacity/__pycache__/stop.cpython-312.pyc,, -pip/_vendor/tenacity/__pycache__/tornadoweb.cpython-312.pyc,, -pip/_vendor/tenacity/__pycache__/wait.cpython-312.pyc,, -pip/_vendor/tenacity/_asyncio.py,sha256=Qi6wgQsGa9MQibYRy3OXqcDQswIZZ00dLOoSUGN-6o8,3551 -pip/_vendor/tenacity/_utils.py,sha256=ubs6a7sxj3JDNRKWCyCU2j5r1CB7rgyONgZzYZq6D_4,2179 -pip/_vendor/tenacity/after.py,sha256=S5NCISScPeIrKwIeXRwdJl3kV9Q4nqZfnNPDx6Hf__g,1682 -pip/_vendor/tenacity/before.py,sha256=dIZE9gmBTffisfwNkK0F1xFwGPV41u5GK70UY4Pi5Kc,1562 -pip/_vendor/tenacity/before_sleep.py,sha256=YmpgN9Y7HGlH97U24vvq_YWb5deaK4_DbiD8ZuFmy-E,2372 -pip/_vendor/tenacity/nap.py,sha256=fRWvnz1aIzbIq9Ap3gAkAZgDH6oo5zxMrU6ZOVByq0I,1383 -pip/_vendor/tenacity/retry.py,sha256=jrzD_mxA5mSTUEdiYB7SHpxltjhPSYZSnSRATb-ggRc,8746 -pip/_vendor/tenacity/stop.py,sha256=YMJs7ZgZfND65PRLqlGB_agpfGXlemx_5Hm4PKnBqpQ,3086 -pip/_vendor/tenacity/tornadoweb.py,sha256=po29_F1Mt8qZpsFjX7EVwAT0ydC_NbVia9gVi7R_wXA,2142 -pip/_vendor/tenacity/wait.py,sha256=3FcBJoCDgym12_dN6xfK8C1gROY0Hn4NSI2u8xv50uE,8024 -pip/_vendor/tomli/__init__.py,sha256=JhUwV66DB1g4Hvt1UQCVMdfCu-IgAV8FXmvDU9onxd4,396 -pip/_vendor/tomli/__pycache__/__init__.cpython-312.pyc,, -pip/_vendor/tomli/__pycache__/_parser.cpython-312.pyc,, -pip/_vendor/tomli/__pycache__/_re.cpython-312.pyc,, -pip/_vendor/tomli/__pycache__/_types.cpython-312.pyc,, -pip/_vendor/tomli/_parser.py,sha256=g9-ENaALS-B8dokYpCuzUFalWlog7T-SIYMjLZSWrtM,22633 -pip/_vendor/tomli/_re.py,sha256=dbjg5ChZT23Ka9z9DHOXfdtSpPwUfdgMXnj8NOoly-w,2943 -pip/_vendor/tomli/_types.py,sha256=-GTG2VUqkpxwMqzmVO4F7ybKddIbAnuAHXfmWQcTi3Q,254 -pip/_vendor/truststore/__init__.py,sha256=qzTLSH8PvAkY1fr6QQ2vV-KwE_M83wdXugtpJaP_AbM,403 -pip/_vendor/truststore/__pycache__/__init__.cpython-312.pyc,, -pip/_vendor/truststore/__pycache__/_api.cpython-312.pyc,, -pip/_vendor/truststore/__pycache__/_macos.cpython-312.pyc,, -pip/_vendor/truststore/__pycache__/_openssl.cpython-312.pyc,, -pip/_vendor/truststore/__pycache__/_ssl_constants.cpython-312.pyc,, -pip/_vendor/truststore/__pycache__/_windows.cpython-312.pyc,, -pip/_vendor/truststore/_api.py,sha256=xjuEu_rlH4hcdJTROImEyOEqdw-F8t5vO2H2BToY0Ro,9893 -pip/_vendor/truststore/_macos.py,sha256=BjvAKoAjXhdIPuxpY124HJIFswDb0pq8DjynzJOVwqc,17694 -pip/_vendor/truststore/_openssl.py,sha256=LLUZ7ZGaio-i5dpKKjKCSeSufmn6T8pi9lDcFnvSyq0,2324 -pip/_vendor/truststore/_ssl_constants.py,sha256=NUD4fVKdSD02ri7-db0tnO0VqLP9aHuzmStcW7tAl08,1130 -pip/_vendor/truststore/_windows.py,sha256=1x_EhROeJ9QK1sMAjfnZC7awYI8UnBJYL-TjACUYI4A,17468 -pip/_vendor/typing_extensions.py,sha256=EWpcpyQnVmc48E9fSyPGs-vXgHcAk9tQABQIxmMsCGk,111130 -pip/_vendor/urllib3/__init__.py,sha256=iXLcYiJySn0GNbWOOZDDApgBL1JgP44EZ8i1760S8Mc,3333 -pip/_vendor/urllib3/__pycache__/__init__.cpython-312.pyc,, -pip/_vendor/urllib3/__pycache__/_collections.cpython-312.pyc,, -pip/_vendor/urllib3/__pycache__/_version.cpython-312.pyc,, -pip/_vendor/urllib3/__pycache__/connection.cpython-312.pyc,, -pip/_vendor/urllib3/__pycache__/connectionpool.cpython-312.pyc,, -pip/_vendor/urllib3/__pycache__/exceptions.cpython-312.pyc,, -pip/_vendor/urllib3/__pycache__/fields.cpython-312.pyc,, -pip/_vendor/urllib3/__pycache__/filepost.cpython-312.pyc,, -pip/_vendor/urllib3/__pycache__/poolmanager.cpython-312.pyc,, -pip/_vendor/urllib3/__pycache__/request.cpython-312.pyc,, -pip/_vendor/urllib3/__pycache__/response.cpython-312.pyc,, -pip/_vendor/urllib3/_collections.py,sha256=pyASJJhW7wdOpqJj9QJA8FyGRfr8E8uUUhqUvhF0728,11372 -pip/_vendor/urllib3/_version.py,sha256=azoM7M7BUADl2kBhMVR6PPf2GhBDI90me1fcnzTwdcw,64 -pip/_vendor/urllib3/connection.py,sha256=92k9td_y4PEiTIjNufCUa1NzMB3J3w0LEdyokYgXnW8,20300 -pip/_vendor/urllib3/connectionpool.py,sha256=Be6q65SR9laoikg-h_jmc_p8OWtEmwgq_Om_Xtig-2M,40285 -pip/_vendor/urllib3/contrib/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -pip/_vendor/urllib3/contrib/__pycache__/__init__.cpython-312.pyc,, -pip/_vendor/urllib3/contrib/__pycache__/_appengine_environ.cpython-312.pyc,, -pip/_vendor/urllib3/contrib/__pycache__/appengine.cpython-312.pyc,, -pip/_vendor/urllib3/contrib/__pycache__/ntlmpool.cpython-312.pyc,, -pip/_vendor/urllib3/contrib/__pycache__/pyopenssl.cpython-312.pyc,, -pip/_vendor/urllib3/contrib/__pycache__/securetransport.cpython-312.pyc,, -pip/_vendor/urllib3/contrib/__pycache__/socks.cpython-312.pyc,, -pip/_vendor/urllib3/contrib/_appengine_environ.py,sha256=bDbyOEhW2CKLJcQqAKAyrEHN-aklsyHFKq6vF8ZFsmk,957 -pip/_vendor/urllib3/contrib/_securetransport/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -pip/_vendor/urllib3/contrib/_securetransport/__pycache__/__init__.cpython-312.pyc,, -pip/_vendor/urllib3/contrib/_securetransport/__pycache__/bindings.cpython-312.pyc,, -pip/_vendor/urllib3/contrib/_securetransport/__pycache__/low_level.cpython-312.pyc,, -pip/_vendor/urllib3/contrib/_securetransport/bindings.py,sha256=4Xk64qIkPBt09A5q-RIFUuDhNc9mXilVapm7WnYnzRw,17632 -pip/_vendor/urllib3/contrib/_securetransport/low_level.py,sha256=B2JBB2_NRP02xK6DCa1Pa9IuxrPwxzDzZbixQkb7U9M,13922 -pip/_vendor/urllib3/contrib/appengine.py,sha256=VR68eAVE137lxTgjBDwCna5UiBZTOKa01Aj_-5BaCz4,11036 -pip/_vendor/urllib3/contrib/ntlmpool.py,sha256=NlfkW7WMdW8ziqudopjHoW299og1BTWi0IeIibquFwk,4528 -pip/_vendor/urllib3/contrib/pyopenssl.py,sha256=hDJh4MhyY_p-oKlFcYcQaVQRDv6GMmBGuW9yjxyeejM,17081 -pip/_vendor/urllib3/contrib/securetransport.py,sha256=yhZdmVjY6PI6EeFbp7qYOp6-vp1Rkv2NMuOGaEj7pmc,34448 -pip/_vendor/urllib3/contrib/socks.py,sha256=aRi9eWXo9ZEb95XUxef4Z21CFlnnjbEiAo9HOseoMt4,7097 -pip/_vendor/urllib3/exceptions.py,sha256=0Mnno3KHTNfXRfY7638NufOPkUb6mXOm-Lqj-4x2w8A,8217 -pip/_vendor/urllib3/fields.py,sha256=kvLDCg_JmH1lLjUUEY_FLS8UhY7hBvDPuVETbY8mdrM,8579 -pip/_vendor/urllib3/filepost.py,sha256=5b_qqgRHVlL7uLtdAYBzBh-GHmU5AfJVt_2N0XS3PeY,2440 -pip/_vendor/urllib3/packages/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -pip/_vendor/urllib3/packages/__pycache__/__init__.cpython-312.pyc,, -pip/_vendor/urllib3/packages/__pycache__/six.cpython-312.pyc,, -pip/_vendor/urllib3/packages/backports/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -pip/_vendor/urllib3/packages/backports/__pycache__/__init__.cpython-312.pyc,, -pip/_vendor/urllib3/packages/backports/__pycache__/makefile.cpython-312.pyc,, -pip/_vendor/urllib3/packages/backports/__pycache__/weakref_finalize.cpython-312.pyc,, -pip/_vendor/urllib3/packages/backports/makefile.py,sha256=nbzt3i0agPVP07jqqgjhaYjMmuAi_W5E0EywZivVO8E,1417 -pip/_vendor/urllib3/packages/backports/weakref_finalize.py,sha256=tRCal5OAhNSRyb0DhHp-38AtIlCsRP8BxF3NX-6rqIA,5343 -pip/_vendor/urllib3/packages/six.py,sha256=b9LM0wBXv7E7SrbCjAm4wwN-hrH-iNxv18LgWNMMKPo,34665 -pip/_vendor/urllib3/poolmanager.py,sha256=mJmZWy_Mb4-dHbmNCKbDqv3fZS9UF_2bVDuiECHyPaI,20943 -pip/_vendor/urllib3/request.py,sha256=YTWFNr7QIwh7E1W9dde9LM77v2VWTJ5V78XuTTw7D1A,6691 -pip/_vendor/urllib3/response.py,sha256=fmDJAFkG71uFTn-sVSTh2Iw0WmcXQYqkbRjihvwBjU8,30641 -pip/_vendor/urllib3/util/__init__.py,sha256=JEmSmmqqLyaw8P51gUImZh8Gwg9i1zSe-DoqAitn2nc,1155 -pip/_vendor/urllib3/util/__pycache__/__init__.cpython-312.pyc,, -pip/_vendor/urllib3/util/__pycache__/connection.cpython-312.pyc,, -pip/_vendor/urllib3/util/__pycache__/proxy.cpython-312.pyc,, -pip/_vendor/urllib3/util/__pycache__/queue.cpython-312.pyc,, -pip/_vendor/urllib3/util/__pycache__/request.cpython-312.pyc,, -pip/_vendor/urllib3/util/__pycache__/response.cpython-312.pyc,, -pip/_vendor/urllib3/util/__pycache__/retry.cpython-312.pyc,, -pip/_vendor/urllib3/util/__pycache__/ssl_.cpython-312.pyc,, -pip/_vendor/urllib3/util/__pycache__/ssl_match_hostname.cpython-312.pyc,, -pip/_vendor/urllib3/util/__pycache__/ssltransport.cpython-312.pyc,, -pip/_vendor/urllib3/util/__pycache__/timeout.cpython-312.pyc,, -pip/_vendor/urllib3/util/__pycache__/url.cpython-312.pyc,, -pip/_vendor/urllib3/util/__pycache__/wait.cpython-312.pyc,, -pip/_vendor/urllib3/util/connection.py,sha256=5Lx2B1PW29KxBn2T0xkN1CBgRBa3gGVJBKoQoRogEVk,4901 -pip/_vendor/urllib3/util/proxy.py,sha256=zUvPPCJrp6dOF0N4GAVbOcl6o-4uXKSrGiTkkr5vUS4,1605 -pip/_vendor/urllib3/util/queue.py,sha256=nRgX8_eX-_VkvxoX096QWoz8Ps0QHUAExILCY_7PncM,498 -pip/_vendor/urllib3/util/request.py,sha256=C0OUt2tcU6LRiQJ7YYNP9GvPrSvl7ziIBekQ-5nlBZk,3997 -pip/_vendor/urllib3/util/response.py,sha256=GJpg3Egi9qaJXRwBh5wv-MNuRWan5BIu40oReoxWP28,3510 -pip/_vendor/urllib3/util/retry.py,sha256=6ENvOZ8PBDzh8kgixpql9lIrb2dxH-k7ZmBanJF2Ng4,22050 -pip/_vendor/urllib3/util/ssl_.py,sha256=X4-AqW91aYPhPx6-xbf66yHFQKbqqfC_5Zt4WkLX1Hc,17177 -pip/_vendor/urllib3/util/ssl_match_hostname.py,sha256=Ir4cZVEjmAk8gUAIHWSi7wtOO83UCYABY2xFD1Ql_WA,5758 -pip/_vendor/urllib3/util/ssltransport.py,sha256=NA-u5rMTrDFDFC8QzRKUEKMG0561hOD4qBTr3Z4pv6E,6895 -pip/_vendor/urllib3/util/timeout.py,sha256=cwq4dMk87mJHSBktK1miYJ-85G-3T3RmT20v7SFCpno,10168 -pip/_vendor/urllib3/util/url.py,sha256=lCAE7M5myA8EDdW0sJuyyZhVB9K_j38ljWhHAnFaWoE,14296 -pip/_vendor/urllib3/util/wait.py,sha256=fOX0_faozG2P7iVojQoE1mbydweNyTcm-hXEfFrTtLI,5403 -pip/_vendor/vendor.txt,sha256=4NKk7fQhVsZw0U-0zmm9Q2LgGyaPXacFbnJAaS0Q6EY,493 -pip/_vendor/webencodings/__init__.py,sha256=qOBJIuPy_4ByYH6W_bNgJF-qYQ2DoU-dKsDu5yRWCXg,10579 -pip/_vendor/webencodings/__pycache__/__init__.cpython-312.pyc,, -pip/_vendor/webencodings/__pycache__/labels.cpython-312.pyc,, -pip/_vendor/webencodings/__pycache__/mklabels.cpython-312.pyc,, -pip/_vendor/webencodings/__pycache__/tests.cpython-312.pyc,, -pip/_vendor/webencodings/__pycache__/x_user_defined.cpython-312.pyc,, -pip/_vendor/webencodings/labels.py,sha256=4AO_KxTddqGtrL9ns7kAPjb0CcN6xsCIxbK37HY9r3E,8979 -pip/_vendor/webencodings/mklabels.py,sha256=GYIeywnpaLnP0GSic8LFWgd0UVvO_l1Nc6YoF-87R_4,1305 -pip/_vendor/webencodings/tests.py,sha256=OtGLyjhNY1fvkW1GvLJ_FV9ZoqC9Anyjr7q3kxTbzNs,6563 -pip/_vendor/webencodings/x_user_defined.py,sha256=yOqWSdmpytGfUgh_Z6JYgDNhoc-BAHyyeeT15Fr42tM,4307 -pip/py.typed,sha256=EBVvvPRTn_eIpz5e5QztSCdrMX7Qwd7VP93RSoIlZ2I,286 diff --git a/venv/lib/python3.12/site-packages/pip-24.0.dist-info/REQUESTED b/venv/lib/python3.12/site-packages/pip-24.0.dist-info/REQUESTED deleted file mode 100644 index e69de29..0000000 diff --git a/venv/lib/python3.12/site-packages/pip-24.0.dist-info/WHEEL b/venv/lib/python3.12/site-packages/pip-24.0.dist-info/WHEEL deleted file mode 100644 index 98c0d20..0000000 --- a/venv/lib/python3.12/site-packages/pip-24.0.dist-info/WHEEL +++ /dev/null @@ -1,5 +0,0 @@ -Wheel-Version: 1.0 -Generator: bdist_wheel (0.42.0) -Root-Is-Purelib: true -Tag: py3-none-any - diff --git a/venv/lib/python3.12/site-packages/pip-24.0.dist-info/entry_points.txt b/venv/lib/python3.12/site-packages/pip-24.0.dist-info/entry_points.txt deleted file mode 100644 index 26fa361..0000000 --- a/venv/lib/python3.12/site-packages/pip-24.0.dist-info/entry_points.txt +++ /dev/null @@ -1,4 +0,0 @@ -[console_scripts] -pip = pip._internal.cli.main:main -pip3 = pip._internal.cli.main:main -pip3.12 = pip._internal.cli.main:main diff --git a/venv/lib/python3.12/site-packages/pip-24.0.dist-info/top_level.txt b/venv/lib/python3.12/site-packages/pip-24.0.dist-info/top_level.txt deleted file mode 100644 index a1b589e..0000000 --- a/venv/lib/python3.12/site-packages/pip-24.0.dist-info/top_level.txt +++ /dev/null @@ -1 +0,0 @@ -pip diff --git a/venv/lib/python3.12/site-packages/pip/__init__.py b/venv/lib/python3.12/site-packages/pip/__init__.py deleted file mode 100644 index be0e3ed..0000000 --- a/venv/lib/python3.12/site-packages/pip/__init__.py +++ /dev/null @@ -1,13 +0,0 @@ -from typing import List, Optional - -__version__ = "24.0" - - -def main(args: Optional[List[str]] = None) -> int: - """This is an internal API only meant for use by pip's own console scripts. - - For additional details, see https://github.com/pypa/pip/issues/7498. - """ - from pip._internal.utils.entrypoints import _wrapper - - return _wrapper(args) diff --git a/venv/lib/python3.12/site-packages/pip/__main__.py b/venv/lib/python3.12/site-packages/pip/__main__.py deleted file mode 100644 index 5991326..0000000 --- a/venv/lib/python3.12/site-packages/pip/__main__.py +++ /dev/null @@ -1,24 +0,0 @@ -import os -import sys - -# Remove '' and current working directory from the first entry -# of sys.path, if present to avoid using current directory -# in pip commands check, freeze, install, list and show, -# when invoked as python -m pip -if sys.path[0] in ("", os.getcwd()): - sys.path.pop(0) - -# 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) - -if __name__ == "__main__": - from pip._internal.cli.main import main as _main - - sys.exit(_main()) diff --git a/venv/lib/python3.12/site-packages/pip/__pip-runner__.py b/venv/lib/python3.12/site-packages/pip/__pip-runner__.py deleted file mode 100644 index 49a148a..0000000 --- a/venv/lib/python3.12/site-packages/pip/__pip-runner__.py +++ /dev/null @@ -1,50 +0,0 @@ -"""Execute exactly this copy of pip, within a different environment. - -This file is named as it is, to ensure that this module can't be imported via -an import statement. -""" - -# /!\ This version compatibility check section must be Python 2 compatible. /!\ - -import sys - -# Copied from setup.py -PYTHON_REQUIRES = (3, 7) - - -def version_str(version): # type: ignore - return ".".join(str(v) for v in version) - - -if sys.version_info[:2] < PYTHON_REQUIRES: - raise SystemExit( - "This version of pip does not support python {} (requires >={}).".format( - version_str(sys.version_info[:2]), version_str(PYTHON_REQUIRES) - ) - ) - -# From here on, we can use Python 3 features, but the syntax must remain -# Python 2 compatible. - -import runpy # noqa: E402 -from importlib.machinery import PathFinder # noqa: E402 -from os.path import dirname # noqa: E402 - -PIP_SOURCES_ROOT = dirname(dirname(__file__)) - - -class PipImportRedirectingFinder: - @classmethod - def find_spec(self, fullname, path=None, target=None): # type: ignore - if fullname != "pip": - return None - - spec = PathFinder.find_spec(fullname, [PIP_SOURCES_ROOT], target) - assert spec, (PIP_SOURCES_ROOT, fullname) - return spec - - -sys.meta_path.insert(0, PipImportRedirectingFinder()) - -assert __name__ == "__main__", "Cannot run __pip-runner__.py as a non-main module" -runpy.run_module("pip", run_name="__main__", alter_sys=True) diff --git a/venv/lib/python3.12/site-packages/pip/__pycache__/__init__.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/__pycache__/__init__.cpython-312.pyc deleted file mode 100644 index fcb75bfd64a481549291621ccef1ece6fad92d2b..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 695 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 NjvuUFpr?N0e*m+3C$azl diff --git a/venv/lib/python3.12/site-packages/pip/_internal/__init__.py b/venv/lib/python3.12/site-packages/pip/_internal/__init__.py deleted file mode 100644 index 96c6b88..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/__init__.py +++ /dev/null @@ -1,18 +0,0 @@ -from typing import List, Optional - -from pip._internal.utils import _log - -# init_logging() must be called before any call to logging.getLogger() -# which happens at import of most modules. -_log.init_logging() - - -def main(args: (Optional[List[str]]) = None) -> 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.12/site-packages/pip/_internal/__pycache__/__init__.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/__pycache__/__init__.cpython-312.pyc deleted file mode 100644 index 954591647b8b1b92e45e67dc1050473e5dbd444f..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 797 zcmZuvy=xRf6rb7MyKKI|m^87_5p5344t_w4NFW#lL8745HRoja0RUv7 zk#h6|mDeOA8O=#S+q4MU0rhr}hegzmCfiaNRKu2qpRU0XE`xV|Y<>cdAAqV)IZ zJTgQ|5g8(VPCc@1x=r>+(T_+g+K5OywC%RcTcY%%( z#|klI*2z3)>%a_bfPpfVWp{!hNtaC2%3UlWvP_I(+gqG>rR(+A zlT;O454GT0YA&tqgXN1imTo3>A%lA$ICb24W`x#Y@J%jYWYUqP1A|YJ^bw6spmb)a z6?&~1_c?)SqNsK2i!gSa@}4Sy81bQ<|@sfhZSN9^PBHlS@8;a=>%B zj=)?`mDiK2*SM7q7PLq=MHdlzu>T@cL1ekB)wkjsZLp=WoZFJ$I`%zP%ZznU>Uw;S)x V?WJ$#56)aVBxrvKe|u3E{tILV(xU(X diff --git a/venv/lib/python3.12/site-packages/pip/_internal/__pycache__/build_env.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/__pycache__/build_env.cpython-312.pyc deleted file mode 100644 index 57fac30fb4c10a3c0e0c643be6a60e27fb2961b7..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 14304 zcmbVzTW}j!c3?NqcsCv-L4q$)Exts^1gN)VJuOSLNSv7rsf@FtYNujq?J0A1QWfPRnbg*1lYM*uCcT8)a*dKWTge|R%Il23 za?WjZ10Qh`W-!uDiqsx8t+VMnq( z)e-5Wurs+O)fMTYuq(MWB}9bOw#c?rcch!<@yVW4Z=^TX7wMyEcd|dVJ+hs`p5#C( z7zw6!M0T)@#1rhlH~Cy@Ffzz8CPrc>BKqW1V=4ST%nyE%A<-x86dT~bQEHMPZi8Hm zrJZ9Yge##{Y@qQ@7}5U@BR0QpLVTdG8!(}+*aGEy00w#*o*00fy%eJrFxm`^ zeKfBf@;an_@0%-h_D`9Dow-9VO(v3}Fr2=UAenSZN-M&oEQ!Kch6o8clZ+{eOj-~p zNg_Qi$YMfPgo}s)N#{Q!rI8@3y3P?%B9eGA5mzAT9wo83bTJmcJUW$?f_BJw+ z#OdJ^XI>dOrP^OnBoe!rlvM645LE5wve-&2shTfHifS31%wicLtCrW&Py|FRS1&;m z*x0Mm+mi_*VP7F>dtD;3R>dBTjwO;(Gz!^#CM%_*ayF4pOC)GkUE`7x&BAb!iHnuQ zB#|)T#1c7v2?z#FY5-HBG!~moDp9FAE2<5#-*1bEfJNCsq977N+e~Hq~nzprt5<+uGCsP z1anND$+MTAXBfgEG-kR0Ib-Yv<^enMfC-vN2h<{+5Xguq2w#gsmoh17h{Rx}vaqz1 zxuKJid|An4hmMmgv2^J8`By?Gl8K=!Fs31xhoS70aw(JE6W+CZNKPnHD692U9?B-N zL(xPU)(nxHMz>Z(-Yl zAEGrVWa1d;A6Eg^uBrn#yHk$|bS| zFh}H}bN|0AE4#F)A_GTci63E`94CpaBCEEG ziF6d0iO#la%U1Z;rgOC&RuRi(V0TWIl4BYztH#?hPK_W4WE&ENt&&J5lxQ^Pt4wQH z&*_D7`3MBCj{epe?v|s}+zyfRQA5Z4OAE?M!{Cgy6xcF%efBzJ^N(7)=C9nle)sy~ zl@G5!xW3$abcXwVH|YTiuxijyI+lVxsXC+4R7RY{{i*WN=-ZRAWTnI`D}?NZ`b5A0 zF=;PJA3_*lmfQ@%J51SRu^gMfP-Y-n7=4P7hJp3s@NawuKm0Gqnqw4W^(SgKTBW*T ztgkMrCu{~K19-mzO&Duv6fx7VB_|BtsOIZ9vP*I6xp_u!_#0ld2>JP3I1~=TzkCLQ8_ZLl@igE5 z*3ECdJGkuLzUm$-x`&qCyH?!?itYn9UViLqxP9d2kz2=}S{Yx{o&CS}or1mnbC>(} zp__;9Tqy{9ih(`LuDu0rFXh8^EQq4S4F78-2x?hSF<4M!bN(>kWXY4vZ8mPY#KcW+!p@&&72RfI>Itt2gBf*d4Cou3`Mzhm z)x!a$Y0x}z6HB41pnh_Hj|?eK$)N58R35;RRL#j6bG;_RW=~EDVvCW&4F&PaEUYn*UV#u_(qOvu?+#1DU z*3{9bh@1v;hv8p74*_s(BV+g8QVPxeE4J;A0v)S?=Zb;nmII-iJTP=y?~mL+{?31% zE(G??@TH+c|JQYRLAmwP?Nc{Tt@52kzH@%`W4`+%*Wm(p_?HmLs1X0M|M+$;4uJ9L z0;|HmRs9V1e6yyTA+~^ywun~AD%m7ES^)Sj+8|9+q8%Uy%|o4T7adUFDLN&W#A~^d zTk^m^FY%i7i@A_PODpy;C%OR3EApaS^ca|4i3fX{r?!GqY=9a*sR3+aenY(`snMv% zgFVgZdnD2XwndBTqgL>6)!fS+KS8-h7Gh~pNX61%vmsouiGfFIWE;xZgeDa=;U|bv zR<2kmhSq^G;iknczV<^1{{vTFAk^FXBKv_!7Zd-Ht8V@oZVZl3@7P7|q#+*k&01@- zjDsME;u6!3rVJ~ms(+LQy#{EqIvQ>Qd3(dBPo&a8$iaLS1e8ZP# zCt5aSK~ks3qIRugZA~DrZ1{i@TFo22Dy3T^9HXH9NI!i9(azk8I5JLw1g3 znOlcA7{O1>S6PBQ5#%(}xvGJGBMq{lLAXEO#7UZaT8UAN|4%HGfI<&+i;NZen5bt(q!UZJ8?)Nyetg zFwo8UP-Dg?WhIjWC5@*~_G->Dsf>jVfZ=DC(qICDx{lq0@i@_>t^E?IY=(eRmj|hR z0^wA}HmR-EBfJd9CuL9&Nd^pGYR`nIq6SkJEDsR-XsT8$f?CWBNsK4pc#N7migkn| zh#yAqn+MXr0llhHYf};HKKx8|-R0CW;ut zL2v-E2Zfrpj?}=L8?3Z}SbDGOHj~lD71pg9+RkQj*rVDp81n&E*}$d=3)Y#X%``Wm z!R&prZYSx?)i%EgwJsW1mGy@Q_Mw8NW$h$wqOf_P^+7{FH+NtYevfbgPBLk6P=Hkw z;7BCEGE!esLaM`cJz#~%nrkkc1)ie^LO3M}6^E20YPKt`g#Oh|$#-;*!817uPL>kv z8yvgNiu#B)bsk%&$AOzy5gb;hU`rE}{=s(AiZJSN)$!76ube#@9Ugg|pj1*FQOz$R z$pBW|9|-FGR_#Or837JUl}n;4(RwA8oP^reSQh+$BEe&xYL%`jn84^BNStP6Bx)sni5Ne*T&byrpm)=X=Pc6N^+;*6@>TS4v_2$*v*Kb~*7w@I-rdPb7N4)3u>6@qTjLy9^ z`_>BI`^epZS#S=yefH+rdH=nxyIqCgp=JK?!}#BxdTKU#oMooV;d$)#mNe8yzScSK ztha0mH2c@gZ4HfI?Pi+VX8RYC4@ZCg)}Oz1r+>Ne?9+W6ZqHXXK>P}^zrf&Y8ILc2 zz5h7#@-g%OIA%Fzw{6nj$YpE)4<;NgFIerUoWP@UPeq4AvG&#T8BG`#wO$Jk%Oay| z>F=9v^=ZdtumiCr`hnF_$F@cbrJVu)BU8`+DAKC|w4z8D{EIG~Ry79uN-r=s*3A2rnA+HNd{E=;G*?5(a9tS0nR+LK8jL#r(7Go8lim~2{A*xy1~&VyS%=ZG zt8rCuBj_AGe|+?`>O23&=;?DKBj;YbF#PI;S4M|br8$MQQ}7 zPR;vHRWEWCiVQ*X2son95Rd?0ZF?QTQ7O9#Nb*AnZZKsl({_UW{}zx9ng!-=_(AvF zj@cb^;o0zle?eJp94zvKPs~-};q&9By&Efdg&D5Y6qq|Ydvu|{*c6s_~Z^rq#-Fe%2)46JIE85#WZ*9Nlyz9K@ zz3W}%mRm!m-tCXNgnJWrC+=nLW)>%wyI%Oh#<@LTnyn7!FQ2qQPpG8)-GLKf4s5w= z@u-5gKQ@Fwq@!4dtc&qlw;0Y7-M@bd09xJ?5O4e@jD1%vdA|a}8TAmud<*z_nwz%d zEjPARy}@Z)h*<0$WbkzVN$ZDnKGDR z&StVftEO14K?a$^AcsY^D>1l>0VCdl45X<%JkL|Esjv+=-a(b2hrgb>(Te^P;8dKT zWuEETj%r}Fdw;Qe|8n<%Ck*G(HBPThH<&s1D3ZxyI-J{c79wh#oPhj;eHFr7|9cS8_x7PDGe7CE9em&PII;Ika z`&4Fc9msPNhL;6qzw!Y^!%v{+Rec}Rw!BSl1i4?&Yhv^lxNlqu=-7GN1e#SFKE?2h z7<1TJzwI9}B3GZrkC;C;PutTS&&0F*Dm=jI+|VgVP8gnyYFT|MqV)rt(RcRNW6*o` zX2qVjj2YSlX67l!AwIe8Qyk)@&h}yspb29Gqy)9ZQqw>T&l|p_cs2H`MnDrD@~!NW~M<{;NJ7x z_pJDaK5rgeZVs1ijN1nmbf@ry@w#7P?*Q($h3(5NJMNf4m-+*92WJl!nu1F`f41YN zJ63lO7k3Z;)z!lJSN|%tvU{}T?<@t{HShc4i4RXdIK3R$cZd5V&{6Vt%$=D%vtV2C z4?wL)O5Gn>ji{gjL2g$$X3W3naf!`?kx6YlLJy+=4|Ik+Geeq-e z@$yz2Nx7TxbFTJjIvkhSx!POZ7TFZ<5(5RN#g<2LhF^>g?7P1zhZ#@|HXY zF7ZlzH1dLGaNM!9%i#Wc1F*>s2-Ie{=%yEz>)49k0qWZIhgf+IgLw>a)buDPZ`7&& zdZcoFn>e&ywf_TDWjqpsf#zcxTjsiEy9&b2V#6-DO>b(OJN&)F1^d>5cWWuoF=M^O zf8y;Z@r@-rziRI;+Pfd|oy&X|=J2f;HZ+%AjHBmE1`H@|W$Cr4e$Pq!zi#Q!3s0@3 z&mjc;3rX#(w@9dEQFnn3FxT@$ik5LZXieh|p`K-=FW0ZWaJ&qRNE(1uQ0#2@z@J>P z2*87D16>Vra@tyROTpIDnt8(u4SLg3PdkWq&_af$tTrk-z~fvw-JqQ%y6W97DEQWf zetFw9RyIT5_)CV4*L%E9`@9L-hpnggrtNt<+53!My7P9?gIj65Mw3CF7f*^X8zA+k z9nZk^CGump*J2$okbc8Ct4pr#5or&F?8sen9Vhq^?A|0u0}nZqh^)F7R9*F(f2`uo#qwv5YbNz z>&4aaV6-@)ogGE6=<0{0D9Ca~jsa>n5XpM732UQLZr*N{oZQRti;eBr)d* zh0>W2y!InGdnlv{|6Ci*yb9-wkoN8mP1eAtU zHu^Oi`kEcgSr4W&Y3U$jCJ1h*f5v^BYY2s?jRSoUrE8%{lFT`2b2OdfLm^a7A$VGH zSu+!33>@u@niPiwRzyfv8_ z9|tR`0nDu7u`%$~Cay?l!6}(kZCC_qRJEKOe(AMS1RtZRHmFCR40trxVHB+^l1Y+p z(^4YAYp%HFFTlqv1jY|$8qQY~<_kK2Qw07`m?C&xs7+85CrDPC;if8cH3}hmO?8t| zb>qr{`#_s7f?gtmM-YM%Fz6xgB3xC0$e~mPs$7hW%VY`Cs!i*xOn!zbmo_!DSLk<5 zUsgHn0$D`d_aKnb7&VML3TXb%KZ5*R|0ac5S4aOH68b0L9I)#AV4|VJl4`%^5-*ha zK#6YwO^BX}62HCN;OGEXC{*MdS6w|tSI@Gm?}NaHTOMrr$hBYhU~nt^mQvTjCydSE znHhQ1vSog3wQEnYYtPbK%Pl8oPF3nX_P5R-UG3Oa?AW!`vm`Hf94h(`mB0`@J$w4y z*B4HG)ceAceKEJZ<>0daP}yQ`X#CP_aeK-ZAX{!^S~^#o`-{!}GtN(3&{xfQ;-Akg zZo4~OXbr9K;nLRN;-*otNwwae*o+4HtH4Hf{S|# ztvf&FcVWfd@Um&uwf!U4cAbuG1tu0Vw|?Z>TFET523PnUV29jx-E`eKxnghA;j=6D zZKbxMKW+Y5pwRlljQf$hZT`$6w{WG<9$t12mBBReEIt2-?|{LTw!ZMN_hCz6%ZsJf zt);H#zI4EReFfeh@Yh1{1qNTsJgoTNIGaxOoByWYa%#x-z@$B*2>Jw zb6{sC;wcH4m+sh72IvJ;D&4o~_VCjVe!~BKW z-zb{_ehkbi-`O|cG#{UDojq3c_AFdjY`Xtj1#hV62(MY7O8F!<{Mfg(Y{3p#nZVY0 zc{WwHVam>Qbd?_*6gt$7jJ!B`v1ru`OAsim!KhL}=;xP}U*pu4SQ2SOSZ zgpkS;FFd zYFr*xCJm)jE?Bq!^-i2aIDx3{L4W!fZ}+mta08IPfb5`mgH$DdiOuiEV7){oKgT>= zL2?6w|A|3Wm}0*+O3D9*c^GtHFKz*VQu5#$$6DNLRtU;gtHr%RNJ37nki=w-ki?`W zBmr9UQ5trTjwtjXt`S$5(u5vDnz%v;#nn?UKpKBz_kz!Bqy7o@m%f)dfY2}o4=@;m z0G(XPB-(bFw5;7sTkw8DrgNfN0Y-NT?o@4BkZm=EM0E_+HmI5iYB;qC?9p%(et02f zNEnPg1srYEE>pW}OSG4tKsa3MrqTR-Tk2O_=fg8Y9pb}Q4`Qom1&58_afIW^M7Uz> z%G4fI1M4g3cE7B>W^F=3ek9bgz8>hy7~FBiG%qA>0<~*>4RAXq<#6>KIki01&U%&f zM@cnr0<<~Ne}59DRwulxq3?^~_dfVL8qJ&K0Mq&`wZ=8R#)Frp?Yj}`!{9gur!k;v zoN}pvNkhMXZ9lC2OyMX|p#XQdybJ+YOf36_iDkJpE5mv}WgMR}o=+Lqr;PJc#`_u5 z^BJ@C7tDoK=E5>_;UAg4&zOUsF}wbe8TgFZ^9$y5kvaVf<_u*1f*Jlhv+pzR#mA2J znZT-}z36D4Kd|iRyw|264W1u)NNk~K`!YHJyBbCI)3O3Y|>*_ zed+g~T`WKfa-7ce40+Dkv*#R~%YXU)|KESEt@SXZxzN?vYkiFUJ3W+=!>p{x0%O;i z%!ZjP$hNpJEb!7cY~!VU*v?CFSVU=$I}*-er$Bwhcum4J>`J(Y-3iaIC*d9T@^(ku zm#7`CP1Ft7CH%vF-sX(gCmMzuc)cdxm}nYq;&oR%kZ2xm=5=?xC9z?61Fw7Ht%lC-rt#psr z+R!HZQ4{6**Tvx;8+)3`4X-n~@urOrV8gw-F_xAs@KPoX+@n-73AS$B%$a{l`ZELRYQMF*$|B+ zQ^{B~5|3pS-V=?1lgaaFkk5`OO8j^%uFwoEOMBHof+Y zl9(`hq|_;F2**ML$F6D%A_qrxL%3_Hw zO69os!Cp7brqe9w$ZmU)uU(2rS~_wru1MNgWY3$v)gr?VwMYOSa z?40g2en)pI$!JPeboZEYL5__oS~_S`o3KJ%&@?(KNxJ`?fw5FV8Bil~EIAQVQHeNk+`Os|Fn|*Ke&Fw3+?JDlYrxMg-s+;>c;n`8oU$8l zJZ68)A$#!b<c-*o&bpgFP(L+*-3~=7nS|Jg{#RZ__9FqzgwjZtZ8`P>FiMG} z1(p-kuC&QStSakNW1O5&Vi?W#40}z;2^R#-24T!{ENn626uTh|fubE+WB@*F{ZPHRNAQ~~Wq(o!O$rKNLarg_~CZ84<#w9L5@&rGSb3zbmI$8^dc(~*8mrxC2t1Lz*6DN>nqctnkik_Lrj zB+%Ke^P`|1mb`FiqNGVkj}r$uk?9d9pQE%qJB_Z`7Yda+u^f(HtH2dCW& zjXil+@A8gAg&j}P)3&^;Z`H>dJ7!N78n#Y5iyqe4I%}J4m}#H=`rP5U$m}=gx87>F zwR?WYt@F1dx6j?mF4P~HcHHv^rhNvFv{>K)C&RS^KjSEIXDQL?aLH3d##T5S|kkDex(x*anFord^opsVK;0f`?b@uKd; zYc+(7gdXTyuZaWBp@K0M>8VGkLoLoaoJ^UNWekGIPs%aq4n-sK=R{~yq2Hv!()(=l z8u}|WpTaQhyT~rFr4H%Mp*MyWTDRY6J+rXq#6susy|q{OUEX)~iOWyS2JU)0m-ij`+w9M?@AMS*J^e3DC+34QFVBg0 z0=;*dPAvFNEcqLz-T(cmodr$`e8s=$_8xvjTq9+PqdC2_pi&9?N^2CFKHWN9&hTKnCh$OaoNlxKtykz%c?5$OP~Rq%1!Vt5N+L zRumM=$Dj_OL46LHM(d@4hIF&z9I|ffNQS8gDTqsKwUPO^R2)OFp0qp3TxfSsIGjky znK;#b;qZ4ek+}J$CLESiQ8e3un7Are>oA{61g##Xj257tr0f`FHIxw)R9`@**P5Up zs>I{r@C`vFrLU2x@RV_h+o&sL68^R8$i8@;ePXjaTt$!Fv16{g$WYApd`3mlv)R!+ z-&15LZtcBo|M`Ixsuqt3E=S|su_8n94o0AOujf7OAA>7YEe33ko;kV5P|Ry9R1{rq zN6)>w#-amd(aAP!p4F};iZ%4)Vr`pdPru_SZ=sjwFFwXI*O1^;3+ zpdQ&5W%xJS_P)uXT%)g%Iz(eM|H_{t<64R+Xk99=5(tk~LwE-At~GV(Vf{cdlQ;*DN57=eU_ei7O-?1Z!8}VP(~(3h2^Cr~Er+1#G5(8Yf3++@p@gMO zGWOk!5|Rc(qai6YU^91S=jQ#G9?C~pH#Rqilwck(V3mg#Nsl}*jzS^ z*%jIq3Wew;wuseImoz_Mepu9--!k3OHrbj@!GO$!gk!)7(=llfzeZ0U*e@exGCbpSpXIyMca+UW`pRfVbKco=xiIZFP(W9-|LjC~8-ebITb#?8tC zBO1Z_jvvnNNB@YaBN5|GrLk%Oxo} z(jtvwBm-y>9Lol(@#rPI(L@lkVc)h+d;ZnGaj9v;^w&P>+H>piLf2CZuFj?2;9~EA zeD8tVJqu5Lz0iC1Q?|ifm-lr|KQrqt+U&J$%dMMc#|y2&8ON%V)pyM`zuo>;d%@qo zufK$Lg06nXyB$|jo8rmncZ1iSM0_jKH0hZ=K8j z`IC8<^vXd!T{;2&IY4SuouC=2v`%7ogs59(Ws zc9i!uVxODdqusV&cDs)bIDQ!tkOynk7tyYsrtA!5FHuHDMg=H7Mvoi-b9hXmh@)Wj zEY-e&tP=SWI9Dkfp%*eTAm0zfT}4p)7;EQFTN|9VaNokA3QHPs4*%c;u*F$| zoJR?2WRDz{*3%cX4-|S-Rmchk4{n3bolHs;d`PMAx|=%5LLqA+3?kOTW%(6UI5ah- zEnH=$w15MYdaX-{GuTS<1n$k!=2+SScb5gYRUz3R{Vmy2o@AWZd|fKZBZ9y|`w*f9 zx=67Ty?!*FItPe76;AM=kQ}U03EQefNqWQJ^Ct$M4WB(RICv_2^zhLWgK(76_PHy# zjG;s5jJUvV8pv%V+Ta=&YU{e=w$Sv?&{NxsjL>x3*5!uI#fDw^hFwdWx>gteWP&X%0~PfhmYscp4|gur6V|rG?9{IF*|_Dp4o)XzgkWlnUKRo*JH@JNw~^ zYb`yGZ!FcyrHr-0NnJ&6L;IVTM*3FY zb1$BJ`s7gfnbXe=g@+D5JBZL5ce<#x#s~y(!aP*xhCG75N4Wss^WcT3!o#y_gnHFX zM${yhth?w3NYPjNnT>_C7z-f|26&)=sj(12(bjsKjo3$1nSL#v{X6`Y_7}*Yb3LrN z4Ls^zYVSeeU)nK%!n@oBFW%d+w_=N159GHVD0CfM>^hw9I(+xonS9q7(#YPfMQ>l; z+jrNyy=e2)HZFH=TkPDO@7%o<*uEIpn-A>0J-QIsTL>IqvD-E`&WJzq79GsD;|mCb zz@|@`6GNbt>#o%;1)jwisO0O@q7iC*ofT~XMtc!5ha0#8ZG-~#>z)eTxpY>IOlZD6kU4~_ThD<&FEI}cqCJp>MicqIAl7WVjWCaiKNCV{dSJgjgl(&5OM^ZM5t7X!oZKfPs?pg%ufJ%B$XlK7mA#$SniRk91d1iwX|Vk{zkvk zIb7mz_B&M=T~;J>jcP9ug%v5qTjEBZN?t2xh1ZHO5WJlnG#ddSuF25EkHc(wh;OT@ ze03I2FJeNCtY^~0W>9ms?XIhPxubvnnpFuWz8$8aK5jYLnfvZbw!6{F=+@9O8aj|84z6D;ETOGGwEwl_xdzZW|3*Js{F)jJq7yX;_{>=-n&Bk4t zN}jLSI)Zob_}ft;9m`LJ%7e)X89}YB;A2s?;d3DKn0OSi8Wbl^SeM8#@)c$mD`%f_ z1fAKxDTivflpN&ngZmS|O7I3ig$qU!jzjPkhWHmB{B|S*$-o}K$6DOfF`RJ}<&q}h zepn+h%lOrr4_}#ZLRHj=>8LAv=-_=LAyKB&GeLnPk>f*%3ULl6IxsXVvCKmViN4~( zmt*T`=#MZW+rE~DDrxh-@Ls!!4D=LWjV+4}Tk;KC78|za8@4VrG%vOFE^Q1JYgps9 z6(%-%c&ysjI2*`&H!U}9njN_nxZCvDg72|=aQOYUL!0k5?OX8eLtv9rr(P?=e2k}n z-eSp-)EdD<#KXnr-*fa|;g7R?N@c5&<8rv~$BD$(rIM~zxrcCPnotx^)qHw{)T@on(Z?rM<}9OkHv;+9>LeDRUO<-p@pJrBMCqj$ zPmyr|%u&g3Xj$jgD-nn}fOr(31%L6_D+(Y`M8X$x@Ys)noAF>w7EP&YhFbyXsZr?Q zEIG_m@cB=w;9>F}nqdb;N-C2Q*a*F{&mT=?5F8*#L?*?0OJ?0-$)Yi5j-<&4fEY|_ z&5wkFK5pKq#BM5m4aRL3_4lZDiLys2BTGenjk50{(>;8RhCNe*FF47@fe0WdqEf_6 zH$Ug(R*IUX=HExQP7dfTux3)KjDWAnVuqQM?WzzB)w{UCaoRs%N(9?m+Gh{^aq4d0 z{(Q@Ru4)#&n;;49dN%{)*S0LTZ83Zg^WR+Dc_hE{$a_yO>^xG~d8W|z(u}j%!UFBr z4_-Ssw`s9!Prhr zdgcx+x;pc&&e@BLoA>57?=5V8?41p;l-_rp{9<+6I-7?)k$dk2Hdi%wh!1|!dt^6z zcenfKM*F)5HymxT|FXq_da!A|vGWogXf;>h480%$VuZ`d`DFM5xd}vK7hg`LfySc= z1)oI8#$ErIx}Bx$8^|g>hL@?4vITmfBjd4h5wUWg-4QZk$=Y(YhuOF7ZJ43IgF$v8CM+;6qSW456p8+mW8&b!?p3 zo_B9r@zUdd=4>q5S{=^_^YCs`c{^s5?;ZP;Kd;!)WtDf~;+}6dxZQBJcGB+2F@eu; z;CYAf!`7!d4$cpS5onWBDn4qXPomH@MBjZF zpDd6K!M|M7H&*Y8@IYMSF#)}m_b7d68&XPc1kH#MY+m~spI0C-A1Zqc44*_>)m~(2 z@gRY@V(UlDStiNls!}{c?^rtlUth>_FP7bq>sD*@gX2O|Nr>xiz|m7YoM8|*7cg7~ zak}oIbJ<228BN?wGQb9>$nR5IFJ;}x?z*`2RrZ~d-OxL{X^FOYc}{H+jY;~KD}Yl z-JW;1&+ad{doDTeHAxGszUZ_I2WEO^wArIG7p{fysfci34up;3bKg-x==p?EzIw`r t;&FABml!c6mLj92)s{uldfg=+u+ diff --git a/venv/lib/python3.12/site-packages/pip/_internal/__pycache__/configuration.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/__pycache__/configuration.cpython-312.pyc deleted file mode 100644 index 44336191a9899fa33ba619105cab1ab9d0a1978a..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 17676 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 Q62)2^g!73&5eBILA4Kzo7XSbN diff --git a/venv/lib/python3.12/site-packages/pip/_internal/__pycache__/main.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/__pycache__/main.cpython-312.pyc deleted file mode 100644 index 43b9b7a4c0518132ce8c5482863e28e25b87ad10..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 680 zcmX|9ziSjh6rS1LJI_mkh*d0f6q^HY2cw`72?T>6NEDLlnqzL~qOzu)lCFH#xkS4Cl(V5KD$7Ha&jGooKHDt5!>hc?9=h?E!K(m-ffSJ6ZBaG z2RH#Ob}AHAu0>XruF65U42|_p_>uCWP*dT&$#XFPfv^JzWoF7@TaX!_w&&m;Q7Em= zKea-GS0;B?g#!>H@2$Hn<?X*q; zzy->dkh`-Kp0PiRtg-ri;oR$umup{=@_!xg$K6b@s~`8RgySF^>>zj$(x9BjQk{q@Y{Lq_8d+3)b1 Gv-|~(ySFj` diff --git a/venv/lib/python3.12/site-packages/pip/_internal/__pycache__/pyproject.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/__pycache__/pyproject.cpython-312.pyc deleted file mode 100644 index 42aa7a0884b49ffc19f3d35b4c67edc89e848fc0..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4981 zcmbUlTWl29_0D6Tvk!aMZ)_N_!QKG75Q9jNF@o3_6Jom|Y89)|YP>URk3BoHxigC& z*=<~u50D}y{;6Fhkw{y$L{N!OKKjvCY7?nH>zIn|#8s%8s_ox`kCO2jeL4T6-`Zo9KrT2LwB9`mmkUjXa^cCawe~8JTy!#;YnW`vHBL6d zo=@_Mekqn^#lTzaWLykNO|Wi)H3#cv8cD1ennq&yC)91)mTj^{j7Wgf4ofi#@D1>5 zwD9~=3)#&E#Ta0>E>em3KMB%Uf--}ukds8CkXNJxV>0K|MU%ZO>xStc&l|F)3JL&u z3@xX~3EGT}s#gU?7GIWLFUVNRNvdIT+ZI5gaa7d}K~V&PJ&du2&8`~O#Nq_jW~GdA zz91_O4c+W|N!E2)o&JVnMw^;7y;w2|Sj|vG?%H7C$-r;x5=^VeaLS+T78Wg{Uo!Jlf*J!824&C{ETm>6lhF+fTXgc6$;yV5(}~zT|5QxPXgMi`1yNS> zGS&)9sUb<9Gqil_9KI^3N6$@+9(_TPQ&%PRYD$r(Qu#$=MpOHf$Dd8Q{CACo>~u=FCuS zZE-S#1s%9c`IE;_nRW5gM10e)LvH0kHj7%C6od@1nlpUxV&&NF_^e%BB^uIzr57TJ;?q-z2VVny`Ba1rTTT@%skz+R(7 zUkRzW=*NAczv#b;a1X%m1Ng3O@PXO*E_Sdi`b9s9CWn^utkJw!M9UY7>;k2qhiXV- z&lD%L16V&k2d<2S$z458N| zfEf%RW4{aK>IntBfd#96t#|znhf?SpAeyG#8>keXMx{tGwCoYXr4Z4w6fq9E90SEr zF;WcQu4Ud8)QygVP3CC|y$Y8Oh2Ev!?q6VDMe|fQG7dO+JqWjyxE=b%i^2Ek59qp< zMeZ7jJ?;nGJT;GO8i{7%Jf!nwO%QowM&jMdlq5BQ&&rCF3}OT@JS&r76V0vqNvY(Php zus!gy)%$ESKQSXOXMrxS&u9fjBo47OR-|bmv&d&O5%|FsbA;ExyLeuPbAh+oJeO~u z`$i<#Ca=zCv6kCqvm-m89Zel4*Djl#Ks!j*Wwq`nUI2?&jgX>1un1WQFdmFd)ZW2~ z$X3W(%1x2Bk%yKCS|XJgb_bw){acDdENQ%)BZjnb?c34Ttgj|6v`NNHVyDoyElB%% z6-=sak0Tyyno$qGgvEa8d%UPgItJB3T|e!}P#1MZ0QCf7@j@QL`jw|)n{v%EOH=zJt>9if}>2!j|q#oiUWFl{1 zGheL(Ug{h*h$Srd@T4Ur;y{ZFM$?mknF4t7c_HYUy3_-}8BK-m3W|}SI`-S19H)73 zf*nkD_{1@}a`0Y@j;xc)iOH9w$!d8?#iUa)JqpxWXc2*pXfo51VS1qgp>o#SOfx{1 zmQ7763r5M?EuS4mX*-N8lbPJMY&AVrA;R5+EV-g^4@^2~j7WNH8+JDzC+gL?T0HPM zfF_pFUxr3|89h0Mnp;;#Rz_CGR>p1)ZZti+{L*GaY}L2oTaBzl))qDz`j$uk!nJ+a zz8Tq9iMC#!ts<)Z3{2s{Ery8(tB45%9|e)Wc{AMjZt~Wt`{8~#4IH`q`ew_X)wz|q zoBMxp=)*%l?b~QMe0}6g296%K?p=LjsC;zrNt zmX9TvEMNvL%xW77HkAW=9){W);iaH2R9>!?_RtgIaBtZsd`aE=h~(9Xz%jHO|E0@x%*rX99Nn; zEAit`JdS+{e4h5}T$T0)+BZY3Yuq10Jyj3v0iWoe2a&z&k-ckgZbVYcBbE5R z2l4Lpc=ye*yXQCJroMe8N>nFRz6a-%jUt!xm?YOkX&@FTs#j3&Y($od2($Kcn lv=XT@_Uc%_^LF;U^EURK+S@}NSfX+!AC#7L!86 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 diff --git a/venv/lib/python3.12/site-packages/pip/_internal/__pycache__/wheel_builder.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/__pycache__/wheel_builder.cpython-312.pyc deleted file mode 100644 index 00f2ba1ca771a7bb14065e64b9c59f01c023e41a..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 13659 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 KeJA87<^3P>??sCM diff --git a/venv/lib/python3.12/site-packages/pip/_internal/build_env.py b/venv/lib/python3.12/site-packages/pip/_internal/build_env.py deleted file mode 100644 index 4f704a3..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/build_env.py +++ /dev/null @@ -1,311 +0,0 @@ -"""Build Environment used for isolation during sdist building -""" - -import logging -import os -import pathlib -import site -import sys -import textwrap -from collections import OrderedDict -from types import TracebackType -from typing import TYPE_CHECKING, Iterable, List, Optional, Set, Tuple, Type, Union - -from pip._vendor.certifi import where -from pip._vendor.packaging.requirements import Requirement -from pip._vendor.packaging.version import Version - -from pip import __file__ as pip_location -from pip._internal.cli.spinners import open_spinner -from pip._internal.locations import get_platlib, get_purelib, get_scheme -from pip._internal.metadata import get_default_environment, get_environment -from pip._internal.utils.subprocess import call_subprocess -from pip._internal.utils.temp_dir import TempDirectory, tempdir_kinds - -if TYPE_CHECKING: - from pip._internal.index.package_finder import PackageFinder - -logger = logging.getLogger(__name__) - - -def _dedup(a: str, b: str) -> Union[Tuple[str], Tuple[str, str]]: - return (a, b) if a != b else (a,) - - -class _Prefix: - def __init__(self, path: str) -> None: - self.path = path - self.setup = False - scheme = get_scheme("", prefix=path) - self.bin_dir = scheme.scripts - self.lib_dirs = _dedup(scheme.purelib, scheme.platlib) - - -def get_runnable_pip() -> str: - """Get a file to pass to a Python executable, to run the currently-running pip. - - This is used to run a pip subprocess, for installing requirements into the build - environment. - """ - source = pathlib.Path(pip_location).resolve().parent - - if not source.is_dir(): - # This would happen if someone is using pip from inside a zip file. In that - # case, we can use that directly. - return str(source) - - return os.fsdecode(source / "__pip-runner__.py") - - -def _get_system_sitepackages() -> Set[str]: - """Get system site packages - - Usually from site.getsitepackages, - but fallback on `get_purelib()/get_platlib()` if unavailable - (e.g. in a virtualenv created by virtualenv<20) - - Returns normalized set of strings. - """ - if hasattr(site, "getsitepackages"): - system_sites = site.getsitepackages() - else: - # virtualenv < 20 overwrites site.py without getsitepackages - # fallback on get_purelib/get_platlib. - # this is known to miss things, but shouldn't in the cases - # where getsitepackages() has been removed (inside a virtualenv) - system_sites = [get_purelib(), get_platlib()] - return {os.path.normcase(path) for path in system_sites} - - -class BuildEnvironment: - """Creates and manages an isolated environment to install build deps""" - - def __init__(self) -> None: - temp_dir = TempDirectory(kind=tempdir_kinds.BUILD_ENV, globally_managed=True) - - self._prefixes = OrderedDict( - (name, _Prefix(os.path.join(temp_dir.path, name))) - for name in ("normal", "overlay") - ) - - self._bin_dirs: List[str] = [] - self._lib_dirs: List[str] = [] - for prefix in reversed(list(self._prefixes.values())): - self._bin_dirs.append(prefix.bin_dir) - self._lib_dirs.extend(prefix.lib_dirs) - - # Customize site to: - # - ensure .pth files are honored - # - prevent access to system site packages - system_sites = _get_system_sitepackages() - - self._site_dir = os.path.join(temp_dir.path, "site") - if not os.path.exists(self._site_dir): - os.mkdir(self._site_dir) - with open( - os.path.join(self._site_dir, "sitecustomize.py"), "w", encoding="utf-8" - ) 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) -> None: - 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: Optional[Type[BaseException]], - exc_val: Optional[BaseException], - exc_tb: Optional[TracebackType], - ) -> None: - for varname, old_value in self._save_env.items(): - if old_value is None: - os.environ.pop(varname, None) - else: - os.environ[varname] = old_value - - def check_requirements( - self, reqs: 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: - env = ( - get_environment(self._lib_dirs) - if hasattr(self, "_lib_dirs") - else get_default_environment() - ) - for req_str in reqs: - req = Requirement(req_str) - # We're explicitly evaluating with an empty extra value, since build - # environments are not provided any mechanism to select specific extras. - if req.marker is not None and not req.marker.evaluate({"extra": ""}): - continue - dist = env.get_distribution(req.name) - if not dist: - missing.add(req_str) - continue - if isinstance(dist.version, Version): - installed_req_str = f"{req.name}=={dist.version}" - else: - installed_req_str = f"{req.name}==={dist.version}" - if not req.specifier.contains(dist.version, prereleases=True): - conflicting.add((installed_req_str, req_str)) - # FIXME: Consider direct URL? - return conflicting, missing - - def install_requirements( - self, - finder: "PackageFinder", - requirements: Iterable[str], - prefix_as_string: str, - *, - kind: str, - ) -> None: - prefix = self._prefixes[prefix_as_string] - assert not prefix.setup - prefix.setup = True - if not requirements: - return - self._install_requirements( - get_runnable_pip(), - finder, - requirements, - prefix, - kind=kind, - ) - - @staticmethod - def _install_requirements( - pip_runnable: str, - finder: "PackageFinder", - requirements: Iterable[str], - prefix: _Prefix, - *, - kind: str, - ) -> None: - args: List[str] = [ - sys.executable, - pip_runnable, - "install", - "--ignore-installed", - "--no-user", - "--prefix", - prefix.path, - "--no-warn-script-location", - ] - if logger.getEffectiveLevel() <= logging.DEBUG: - args.append("-v") - for format_control in ("no_binary", "only_binary"): - 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") - if finder.prefer_binary: - args.append("--prefer-binary") - args.append("--") - args.extend(requirements) - extra_environ = {"_PIP_STANDALONE_CERT": where()} - with open_spinner(f"Installing {kind}") as spinner: - call_subprocess( - args, - command_desc=f"pip subprocess to install {kind}", - spinner=spinner, - extra_environ=extra_environ, - ) - - -class NoOpBuildEnvironment(BuildEnvironment): - """A no-op drop-in replacement for BuildEnvironment""" - - def __init__(self) -> None: - pass - - def __enter__(self) -> None: - pass - - def __exit__( - self, - exc_type: Optional[Type[BaseException]], - exc_val: Optional[BaseException], - exc_tb: Optional[TracebackType], - ) -> None: - pass - - def cleanup(self) -> None: - pass - - def install_requirements( - self, - finder: "PackageFinder", - requirements: Iterable[str], - prefix_as_string: str, - *, - kind: str, - ) -> None: - raise NotImplementedError() diff --git a/venv/lib/python3.12/site-packages/pip/_internal/cache.py b/venv/lib/python3.12/site-packages/pip/_internal/cache.py deleted file mode 100644 index f45ac23..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/cache.py +++ /dev/null @@ -1,290 +0,0 @@ -"""Cache Management -""" - -import hashlib -import json -import logging -import os -from pathlib import Path -from typing import Any, Dict, List, Optional - -from pip._vendor.packaging.tags import Tag, interpreter_name, interpreter_version -from pip._vendor.packaging.utils import canonicalize_name - -from pip._internal.exceptions import InvalidWheelFilename -from pip._internal.models.direct_url import DirectUrl -from pip._internal.models.link import Link -from pip._internal.models.wheel import Wheel -from pip._internal.utils.temp_dir import TempDirectory, tempdir_kinds -from pip._internal.utils.urls import path_to_url - -logger = logging.getLogger(__name__) - -ORIGIN_JSON_NAME = "origin.json" - - -def _hash_dict(d: Dict[str, str]) -> str: - """Return a stable sha224 of a dictionary.""" - s = json.dumps(d, sort_keys=True, separators=(",", ":"), ensure_ascii=True) - return hashlib.sha224(s.encode("ascii")).hexdigest() - - -class Cache: - """An abstract class - provides cache directories for data from links - - :param cache_dir: The root of the cache. - """ - - def __init__(self, cache_dir: str) -> None: - super().__init__() - assert not cache_dir or os.path.isabs(cache_dir) - self.cache_dir = cache_dir or None - - def _get_cache_path_parts(self, link: Link) -> List[str]: - """Get parts of part that must be os.path.joined with cache_dir""" - - # We want to generate an url to use as our cache key, we don't want to - # just re-use the URL because it might have other items in the fragment - # 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: Link, canonical_package_name: str) -> List[Any]: - can_not_cache = not self.cache_dir or not canonical_package_name or not link - if can_not_cache: - return [] - - path = self.get_path_for_link(link) - if os.path.isdir(path): - return [(candidate, path) for candidate in os.listdir(path)] - return [] - - def get_path_for_link(self, link: Link) -> str: - """Return a directory to store cached items in for link.""" - raise NotImplementedError() - - def get( - self, - link: Link, - package_name: Optional[str], - supported_tags: List[Tag], - ) -> Link: - """Returns a link to a cached item if it exists, otherwise returns the - passed link. - """ - raise NotImplementedError() - - -class SimpleWheelCache(Cache): - """A cache of wheels for future installs.""" - - def __init__(self, cache_dir: str) -> None: - super().__init__(cache_dir) - - def get_path_for_link(self, link: Link) -> str: - """Return a directory to store cached wheels for link - - Because there are M wheels for any one sdist, we provide a directory - 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) - assert self.cache_dir - # Store wheels within the root cache_dir - return os.path.join(self.cache_dir, "wheels", *parts) - - def get( - self, - link: Link, - package_name: Optional[str], - supported_tags: List[Tag], - ) -> Link: - candidates = [] - - if not package_name: - return link - - canonical_package_name = canonicalize_name(package_name) - for wheel_name, wheel_dir in self._get_candidates(link, canonical_package_name): - try: - wheel = Wheel(wheel_name) - except InvalidWheelFilename: - continue - if canonicalize_name(wheel.name) != canonical_package_name: - logger.debug( - "Ignoring cached wheel %s for %s as it " - "does not match the expected distribution name %s.", - 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) -> None: - self._temp_dir = TempDirectory( - kind=tempdir_kinds.EPHEM_WHEEL_CACHE, - globally_managed=True, - ) - - super().__init__(self._temp_dir.path) - - -class CacheEntry: - def __init__( - self, - link: Link, - persistent: bool, - ): - self.link = link - self.persistent = persistent - self.origin: Optional[DirectUrl] = None - origin_direct_url_path = Path(self.link.file_path).parent / ORIGIN_JSON_NAME - if origin_direct_url_path.exists(): - try: - self.origin = DirectUrl.from_json( - origin_direct_url_path.read_text(encoding="utf-8") - ) - except Exception as e: - logger.warning( - "Ignoring invalid cache entry origin file %s for %s (%s)", - origin_direct_url_path, - link.filename, - e, - ) - - -class WheelCache(Cache): - """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: str) -> None: - super().__init__(cache_dir) - self._wheel_cache = SimpleWheelCache(cache_dir) - self._ephem_cache = EphemWheelCache() - - def get_path_for_link(self, link: Link) -> str: - return self._wheel_cache.get_path_for_link(link) - - def get_ephem_path_for_link(self, link: Link) -> str: - return self._ephem_cache.get_path_for_link(link) - - def get( - self, - link: Link, - package_name: Optional[str], - supported_tags: List[Tag], - ) -> Link: - cache_entry = self.get_cache_entry(link, package_name, supported_tags) - if cache_entry is None: - return link - return cache_entry.link - - def get_cache_entry( - self, - link: Link, - package_name: Optional[str], - supported_tags: List[Tag], - ) -> Optional[CacheEntry]: - """Returns a CacheEntry with a link to a cached item if it exists or - None. The cache entry indicates if the item was found in the persistent - or ephemeral cache. - """ - retval = self._wheel_cache.get( - link=link, - package_name=package_name, - supported_tags=supported_tags, - ) - if retval is not link: - return CacheEntry(retval, persistent=True) - - retval = self._ephem_cache.get( - link=link, - package_name=package_name, - supported_tags=supported_tags, - ) - if retval is not link: - return CacheEntry(retval, persistent=False) - - return None - - @staticmethod - def record_download_origin(cache_dir: str, download_info: DirectUrl) -> None: - origin_path = Path(cache_dir) / ORIGIN_JSON_NAME - if origin_path.exists(): - try: - origin = DirectUrl.from_json(origin_path.read_text(encoding="utf-8")) - except Exception as e: - logger.warning( - "Could not read origin file %s in cache entry (%s). " - "Will attempt to overwrite it.", - origin_path, - e, - ) - else: - # TODO: use DirectUrl.equivalent when - # https://github.com/pypa/pip/pull/10564 is merged. - if origin.url != download_info.url: - logger.warning( - "Origin URL %s in cache entry %s does not match download URL " - "%s. This is likely a pip bug or a cache corruption issue. " - "Will overwrite it with the new value.", - origin.url, - cache_dir, - download_info.url, - ) - origin_path.write_text(download_info.to_json(), encoding="utf-8") diff --git a/venv/lib/python3.12/site-packages/pip/_internal/cli/__init__.py b/venv/lib/python3.12/site-packages/pip/_internal/cli/__init__.py deleted file mode 100644 index e589bb9..0000000 --- a/venv/lib/python3.12/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.12/site-packages/pip/_internal/cli/__pycache__/__init__.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/cli/__pycache__/__init__.cpython-312.pyc deleted file mode 100644 index c0919571cd3cf5f0426a544c07287ea19afdfd11..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 288 zcmXv~u}T9$5WS5-Lm>aKous%M)K-L`AT}b{*({se$z{mi?6S9aaH;JrZEgJ)|G?HC z5Ywe{PvUFly%~o0Wadr+3Ma&P$8c0Dv{aLfN oP^KM~Bt@kP-|r`vwKJ{7t8korhf|y36W>Qdh@X)V<1kM07mjRI+yDRo diff --git a/venv/lib/python3.12/site-packages/pip/_internal/cli/__pycache__/autocompletion.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/cli/__pycache__/autocompletion.cpython-312.pyc deleted file mode 100644 index 33f2c3c614451f2a82318701e8b334ddfd10e0b5..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 8475 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 diff --git a/venv/lib/python3.12/site-packages/pip/_internal/cli/__pycache__/base_command.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/cli/__pycache__/base_command.cpython-312.pyc deleted file mode 100644 index 82e728280d257fe93cdfc4ab7861cd2919c1055a..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 10465 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 diff --git a/venv/lib/python3.12/site-packages/pip/_internal/cli/__pycache__/cmdoptions.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/cli/__pycache__/cmdoptions.cpython-312.pyc deleted file mode 100644 index 7f9d597089bee88a140b849926a487a0009334c0..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 30384 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 diff --git a/venv/lib/python3.12/site-packages/pip/_internal/cli/__pycache__/parser.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/cli/__pycache__/parser.cpython-312.pyc deleted file mode 100644 index a44b5c443533ecd14dbc48f77ac56bf295f419b0..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 15032 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 JhPCJeeg(N6pV$BZ diff --git a/venv/lib/python3.12/site-packages/pip/_internal/cli/__pycache__/req_command.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/cli/__pycache__/req_command.cpython-312.pyc deleted file mode 100644 index 3cb8a804f3b88f6233397622431c5700d7868bd7..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 18862 zcmcJ1dvF_fe%~(MZ;${<@Xh5zq9BT--Y-j*D3N;DGOd$z=NNM-0%4aVC_Lz0P!f4y zM(3zC<@#c2a*655rItIF9$h&(^*MH%nb_?l>9m~=A;|-HPZ}!|ciKy*Eo92I`wJWdRV+J*_-N%^s#t-azkokWFw0QlKrVo zkxi*^B%InD*_;}P46yuQa!YD3GRWc$$)VJ6WSGSplUq~UBHLKJDY-qhBeH|VL&=?~ zU6Ea>-I3j?J&`>uuQ|ClwJ)-d=Om|W!#cGj_otqTJi~J)PU5F88w+1~O9yZ9S}O9a z*eZF%wiYBOOk(?0OXQG=JI;w6S2?j$YP@CE>m6pfUC0%rpmg|_Mb96R_Do;Z;?*H? z|3P(Hiz9dO$=peEWK7&BcBAiOVvpp)h+GpEu@~v%tk*vDx1-^KR)p-7Bpl78Qn9osoR2Az5KqPwMWTXORuH8b2?d$7a5^z_R#KEiCOzbGokJs| zULuXE2}MX{#Mz`I#AHc8R!mT&nV1~QN=AW_VSUB5z7!#y$-2^#Bqq|6f|$9KPG(}F zFf5#o#V^DrrDKV-D9J)RHWNFaNG7s#sFUu`3bX076vsGXaw0h=BvLaOIZJR|Yulw_ z@u@^wlIH}PS1g$n5?MvKh`D5BNz|t$rQ-=n*&;~U_>k-8w7lbCUbSP`*+eXfsO>wk zMKS5=vHeyf~A^qQsJ__1x@CQbIG=OH-1R zJc=Q(R6HeSSRI9+>uZf@P><49NSCuOBrcy!hfS(S&mNQIjI1`EmZgh{%&c-`HjxxZ z6Ee$2YwxK<`ohsnGAYHg8JRNHtN=0^&Pr5>!2!mEBxAam3$J?4#pFpTdwMQAl}RJ* zs%$NlvX0Kl*anHf2G2;Z%qC^$zoljvh+%HLe8Y3*vV|{d{R;y zpD0RVE7aa6vH?qxM1o*+pte0xiQp?)8K(q;39u&BEoef4liFCSM#?6F(|kr!GRcc< zB26=inW!QqC!$ExIgVm~;upeZY_61=!P2sooKsuYB+t#w0Lmn`TAowAS=1C0a`Xa@ zCw1K{<3M6;(OEjK(TfQ=I~z+%>5C|HojrR>-&@rtOW9dDE%)M(#j7u}6$!!=s{vff zx43M%Y#KOz{Uh=hkSn{h)QUZ#$-qai@=i`Pi(JyYz_FM$X-_#8c%IAg(?O$t<(=cE z8!9OyWSH;(CmxKu^hIIwTQGla> z5Mmc&i6osuVIm_7+7TCa3~k#wAk%uzZyQZ0C?=d!1w~2VY6yyw6qMN+hEWKgC4lYN zsdH7T&i6lk0JG_G@B4+YTQw_lis~^ATOy4S`7j3LD@oOTlA$i`lG~D*$w^68?U!OQ zohH?dvpR%xO6W@7ghuS(sKL``UOe~W(HBoe&z(9OJ$mZo*!a1ySstJYR7>S0h1N=% zYx}U0$V!7V8YWhTF___K0!T^*nj4Oz4P8ndkq^zxsh!cdjE#_@m4%98lBmKko4f;K z+K!*{0|ZyN`*v5s9?IK8OZ|83-S>U1D{bGo>w9U%@lwfRu{Qk75h%IL*5~*Kj?E`` 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: List[str], cword: int, opts: Iterable[Any] -) -> Optional[str]: - """Get the type of path completion (``file``, ``dir``, ``path`` or None) - - :param cwords: same as the environmental variable ``COMP_WORDS`` - :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: str, completion_type: str) -> Iterable[str]: - """If ``completion_type`` is ``file`` or ``path``, list all regular files - and directories starting with ``current``; otherwise only list directories - starting with ``current``. - - :param current: The word to be completed - :param completion_type: path completion type(``file``, ``path`` or ``dir``) - :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.12/site-packages/pip/_internal/cli/base_command.py b/venv/lib/python3.12/site-packages/pip/_internal/cli/base_command.py deleted file mode 100644 index db9d5cc..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/cli/base_command.py +++ /dev/null @@ -1,236 +0,0 @@ -"""Base Command class, and related routines""" - -import functools -import logging -import logging.config -import optparse -import os -import sys -import traceback -from optparse import Values -from typing import Any, Callable, List, Optional, Tuple - -from pip._vendor.rich import traceback as rich_traceback - -from pip._internal.cli import cmdoptions -from pip._internal.cli.command_context import CommandContextMixIn -from pip._internal.cli.parser import ConfigOptionParser, UpdatingDefaultsHelpFormatter -from pip._internal.cli.status_codes import ( - ERROR, - PREVIOUS_BUILD_DIR_ERROR, - UNKNOWN_ERROR, - VIRTUALENV_NOT_FOUND, -) -from pip._internal.exceptions import ( - BadCommand, - CommandError, - DiagnosticPipError, - InstallationError, - NetworkConnectionError, - PreviousBuildDirError, - UninstallationError, -) -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 TempDirectoryTypeRegistry as TempDirRegistry -from pip._internal.utils.temp_dir import global_tempdir_manager, tempdir_registry -from pip._internal.utils.virtualenv import running_under_virtualenv - -__all__ = ["Command"] - -logger = logging.getLogger(__name__) - - -class Command(CommandContextMixIn): - usage: str = "" - ignore_require_venv: bool = False - - def __init__(self, name: str, summary: str, isolated: bool = False) -> None: - super().__init__() - - self.name = name - self.summary = summary - self.parser = ConfigOptionParser( - usage=self.usage, - prog=f"{get_prog()} {name}", - formatter=UpdatingDefaultsHelpFormatter(), - add_help_option=False, - name=name, - description=self.__doc__, - isolated=isolated, - ) - - self.tempdir_registry: Optional[TempDirRegistry] = None - - # Commands should add options to this option group - optgroup_name = f"{self.name.capitalize()} Options" - 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) - - self.add_options() - - def add_options(self) -> None: - pass - - def handle_pip_version_check(self, options: Values) -> None: - """ - This is a no-op so that commands by default do not do the pip version - check. - """ - # 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: Values, args: List[str]) -> int: - raise NotImplementedError - - def parse_args(self, args: List[str]) -> Tuple[Values, List[str]]: - # factored out for testability - return self.parser.parse_args(args) - - def main(self, args: List[str]) -> int: - try: - with self.main_context(): - return self._main(args) - finally: - logging.shutdown() - - def _main(self, args: List[str]) -> int: - # We must initialize this before the tempdir manager, otherwise the - # configuration would not be accessible by the time we clean up the - # tempdir manager. - self.tempdir_registry = self.enter_context(tempdir_registry()) - # 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, - ) - - always_enabled_features = set(options.features_enabled) & set( - cmdoptions.ALWAYS_ENABLED_FEATURES - ) - if always_enabled_features: - logger.warning( - "The following features are always enabled: %s. ", - ", ".join(sorted(always_enabled_features)), - ) - - # Make sure that the --python argument isn't specified after the - # subcommand. We can tell, because if --python was specified, - # we should only reach this point if we're running in the created - # subprocess, which has the _PIP_RUNNING_IN_SUBPROCESS environment - # variable set. - if options.python and "_PIP_RUNNING_IN_SUBPROCESS" not in os.environ: - logger.critical( - "The --python option must be placed before the pip subcommand name" - ) - sys.exit(ERROR) - - # TODO: Try to get these passing down from the command? - # without resorting to os.environ to hold these. - # This also affects isolated builds and it should. - - 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 should " - "use sudo's -H flag.", - options.cache_dir, - ) - options.cache_dir = None - - def intercepts_unhandled_exc( - run_func: Callable[..., int] - ) -> Callable[..., int]: - @functools.wraps(run_func) - def exc_logging_wrapper(*args: Any) -> int: - try: - status = run_func(*args) - assert isinstance(status, int) - return status - except DiagnosticPipError as exc: - logger.error("%s", exc, extra={"rich": True}) - logger.debug("Exception information:", exc_info=True) - - return ERROR - except PreviousBuildDirError as exc: - logger.critical(str(exc)) - logger.debug("Exception information:", exc_info=True) - - return PREVIOUS_BUILD_DIR_ERROR - except ( - InstallationError, - UninstallationError, - BadCommand, - NetworkConnectionError, - ) as exc: - logger.critical(str(exc)) - logger.debug("Exception information:", exc_info=True) - - return ERROR - except CommandError as exc: - logger.critical("%s", exc) - logger.debug("Exception information:", exc_info=True) - - return ERROR - except BrokenStdoutLoggingError: - # Bypass our logger and write any remaining messages to - # stderr because stdout no longer works. - print("ERROR: Pipe to stdout was broken", file=sys.stderr) - if level_number <= logging.DEBUG: - traceback.print_exc(file=sys.stderr) - - return ERROR - except KeyboardInterrupt: - logger.critical("Operation cancelled by user") - logger.debug("Exception information:", exc_info=True) - - return ERROR - except BaseException: - logger.critical("Exception:", exc_info=True) - - return UNKNOWN_ERROR - - return exc_logging_wrapper - - try: - if not options.debug_mode: - run = intercepts_unhandled_exc(self.run) - else: - run = self.run - rich_traceback.install(show_locals=True) - return run(options, args) - finally: - self.handle_pip_version_check(options) diff --git a/venv/lib/python3.12/site-packages/pip/_internal/cli/cmdoptions.py b/venv/lib/python3.12/site-packages/pip/_internal/cli/cmdoptions.py deleted file mode 100644 index d643256..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/cli/cmdoptions.py +++ /dev/null @@ -1,1074 +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 - -import importlib.util -import logging -import os -import textwrap -from functools import partial -from optparse import SUPPRESS_HELP, Option, OptionGroup, OptionParser, Values -from textwrap import dedent -from typing import Any, Callable, Dict, Optional, Tuple - -from pip._vendor.packaging.utils import canonicalize_name - -from pip._internal.cli.parser import ConfigOptionParser -from pip._internal.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.misc import strtobool - -logger = logging.getLogger(__name__) - - -def raise_option_error(parser: OptionParser, option: Option, msg: str) -> None: - """ - Raise an option parsing error using parser.error(). - - Args: - parser: an OptionParser instance. - option: an Option instance. - msg: the error text. - """ - msg = f"{option} error: {msg}" - msg = textwrap.fill(" ".join(msg.split())) - parser.error(msg) - - -def make_option_group(group: Dict[str, Any], parser: ConfigOptionParser) -> OptionGroup: - """ - Return an OptionGroup object - group -- assumed to be dict with 'name' and 'options' keys - 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_dist_restriction(options: Values, check_target: bool = False) -> 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.platforms, - options.abis, - 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 not options.dry_run and dist_restriction_set and not options.target_dir: - raise CommandError( - "Can not use any platform or abi specific options unless " - "installing via '--target' or using '--dry-run'" - ) - - -def _path_option_check(option: Option, opt: str, value: str) -> str: - return os.path.expanduser(value) - - -def _package_name_option_check(option: Option, opt: str, value: str) -> str: - return canonicalize_name(value) - - -class PipOption(Option): - TYPES = Option.TYPES + ("path", "package_name") - TYPE_CHECKER = Option.TYPE_CHECKER.copy() - TYPE_CHECKER["package_name"] = _package_name_option_check - TYPE_CHECKER["path"] = _path_option_check - - -########### -# options # -########### - -help_: Callable[..., Option] = partial( - Option, - "-h", - "--help", - dest="help", - action="help", - help="Show help.", -) - -debug_mode: Callable[..., Option] = partial( - Option, - "--debug", - dest="debug_mode", - action="store_true", - default=False, - help=( - "Let unhandled exceptions propagate outside the main subroutine, " - "instead of logging them to stderr." - ), -) - -isolated_mode: Callable[..., Option] = partial( - Option, - "--isolated", - dest="isolated_mode", - action="store_true", - default=False, - help=( - "Run pip in an isolated mode, ignoring environment variables and user " - "configuration." - ), -) - -require_virtualenv: Callable[..., Option] = partial( - Option, - "--require-virtualenv", - "--require-venv", - dest="require_venv", - action="store_true", - default=False, - help=( - "Allow pip to only run in a virtual environment; " - "exit with an error otherwise." - ), -) - -override_externally_managed: Callable[..., Option] = partial( - Option, - "--break-system-packages", - dest="override_externally_managed", - action="store_true", - help="Allow pip to modify an EXTERNALLY-MANAGED Python installation", -) - -python: Callable[..., Option] = partial( - Option, - "--python", - dest="python", - help="Run pip with the specified Python interpreter.", -) - -verbose: Callable[..., Option] = 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.", -) - -no_color: Callable[..., Option] = partial( - Option, - "--no-color", - dest="no_color", - action="store_true", - default=False, - help="Suppress colored output.", -) - -version: Callable[..., Option] = partial( - Option, - "-V", - "--version", - dest="version", - action="store_true", - help="Show version and exit.", -) - -quiet: Callable[..., Option] = 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)." - ), -) - -progress_bar: Callable[..., Option] = partial( - Option, - "--progress-bar", - dest="progress_bar", - type="choice", - choices=["on", "off"], - default="on", - help="Specify whether the progress bar should be used [on, off] (default: on)", -) - -log: Callable[..., Option] = partial( - PipOption, - "--log", - "--log-file", - "--local-log", - dest="log", - metavar="path", - type="path", - help="Path to a verbose appending log.", -) - -no_input: Callable[..., Option] = partial( - Option, - # Don't ask for input - "--no-input", - dest="no_input", - action="store_true", - default=False, - help="Disable prompting for input.", -) - -keyring_provider: Callable[..., Option] = partial( - Option, - "--keyring-provider", - dest="keyring_provider", - choices=["auto", "disabled", "import", "subprocess"], - default="auto", - help=( - "Enable the credential lookup via the keyring library if user input is allowed." - " Specify which mechanism to use [disabled, import, subprocess]." - " (default: disabled)" - ), -) - -proxy: Callable[..., Option] = partial( - Option, - "--proxy", - dest="proxy", - type="str", - default="", - help="Specify a proxy in the form scheme://[user:passwd@]proxy.server:port.", -) - -retries: Callable[..., Option] = partial( - Option, - "--retries", - dest="retries", - type="int", - default=5, - help="Maximum number of retries each connection should attempt " - "(default %default times).", -) - -timeout: Callable[..., Option] = partial( - Option, - "--timeout", - "--default-timeout", - metavar="sec", - dest="timeout", - type="float", - default=15, - help="Set the socket timeout (default %default seconds).", -) - - -def exists_action() -> 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: Callable[..., Option] = partial( - PipOption, - "--cert", - dest="cert", - type="path", - metavar="path", - help=( - "Path to PEM-encoded CA certificate bundle. " - "If provided, overrides the default. " - "See 'SSL Certificate Verification' in pip documentation " - "for more information." - ), -) - -client_cert: Callable[..., Option] = 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.", -) - -index_url: Callable[..., Option] = 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.", -) - - -def extra_index_url() -> 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: Callable[..., Option] = partial( - Option, - "--no-index", - dest="no_index", - action="store_true", - default=False, - help="Ignore package index (only looking at --find-links URLs instead).", -) - - -def find_links() -> 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 such as sdist (.tar.gz) or wheel (.whl) files. " - "If a local path or file:// URL that's a directory, " - "then look for archives in the directory listing. " - "Links to VCS project URLs are not supported.", - ) - - -def trusted_host() -> 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() -> 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() -> 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() -> 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: Option, opt_str: str, value: str, parser: OptionParser) -> None: - value = os.path.abspath(value) - setattr(parser.values, option.dest, value) - - -src: Callable[..., Option] = 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".', -) - - -def _get_format_control(values: Values, option: Option) -> Any: - """Get a format_control object.""" - return getattr(values, option.dest) - - -def _handle_no_binary( - option: Option, opt_str: str, value: str, parser: OptionParser -) -> None: - existing = _get_format_control(parser.values, option) - FormatControl.handle_mutual_excludes( - value, - existing.no_binary, - existing.only_binary, - ) - - -def _handle_only_binary( - option: Option, opt_str: str, value: str, parser: OptionParser -) -> None: - existing = _get_format_control(parser.values, option) - FormatControl.handle_mutual_excludes( - value, - existing.only_binary, - existing.no_binary, - ) - - -def no_binary() -> 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 (notice ' - "the colons), 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() -> 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.", - ) - - -platforms: Callable[..., Option] = partial( - Option, - "--platform", - dest="platforms", - metavar="platform", - action="append", - default=None, - help=( - "Only use wheels compatible with . Defaults to the " - "platform of the running system. Use this option multiple times to " - "specify multiple platforms supported by the target interpreter." - ), -) - - -# This was made a separate function for unit-testing purposes. -def _convert_python_version(value: str) -> Tuple[Tuple[int, ...], Optional[str]]: - """ - Convert a version string like "3", "37", or "3.7.3" into a tuple of ints. - - :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: Option, opt_str: str, value: str, parser: OptionParser -) -> None: - """ - Handle a provided --python-version value. - """ - version_info, error_msg = _convert_python_version(value) - if error_msg is not None: - msg = f"invalid --python-version value: {value!r}: {error_msg}" - raise_option_error(parser, option=option, msg=msg) - - parser.values.python_version = version_info - - -python_version: Callable[..., Option] = 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). - """ - ), -) - - -implementation: Callable[..., Option] = 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." - ), -) - - -abis: Callable[..., Option] = partial( - Option, - "--abi", - dest="abis", - metavar="abi", - action="append", - 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. " - "Use this option multiple times to specify multiple abis supported " - "by the target interpreter. Generally you will need to specify " - "--implementation, --platform, and --python-version when using this " - "option." - ), -) - - -def add_target_python_options(cmd_opts: OptionGroup) -> None: - cmd_opts.add_option(platforms()) - cmd_opts.add_option(python_version()) - cmd_opts.add_option(implementation()) - cmd_opts.add_option(abis()) - - -def make_target_python(options: Values) -> TargetPython: - target_python = TargetPython( - platforms=options.platforms, - py_version_info=options.python_version, - abis=options.abis, - implementation=options.implementation, - ) - - return target_python - - -def prefer_binary() -> Option: - return Option( - "--prefer-binary", - dest="prefer_binary", - action="store_true", - default=False, - help=( - "Prefer binary packages over source packages, even if the " - "source packages are newer." - ), - ) - - -cache_dir: Callable[..., Option] = partial( - PipOption, - "--cache-dir", - dest="cache_dir", - default=USER_CACHE_DIR, - metavar="dir", - type="path", - help="Store the cache data in .", -) - - -def _handle_no_cache_dir( - option: Option, opt: str, value: str, parser: 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: Callable[..., Option] = partial( - Option, - "--no-cache-dir", - dest="cache_dir", - action="callback", - callback=_handle_no_cache_dir, - help="Disable the cache.", -) - -no_deps: Callable[..., Option] = partial( - Option, - "--no-deps", - "--no-dependencies", - dest="ignore_dependencies", - action="store_true", - default=False, - help="Don't install package dependencies.", -) - -ignore_requires_python: Callable[..., Option] = partial( - Option, - "--ignore-requires-python", - dest="ignore_requires_python", - action="store_true", - help="Ignore the Requires-Python information.", -) - -no_build_isolation: Callable[..., Option] = 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.", -) - -check_build_deps: Callable[..., Option] = partial( - Option, - "--check-build-dependencies", - dest="check_build_deps", - action="store_true", - default=False, - help="Check the build dependencies when PEP517 is used.", -) - - -def _handle_no_use_pep517( - option: Option, opt: str, value: str, parser: 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) - - # If user doesn't wish to use pep517, we check if setuptools and wheel are installed - # and raise error if it is not. - packages = ("setuptools", "wheel") - if not all(importlib.util.find_spec(package) for package in packages): - msg = ( - f"It is not possible to use --no-use-pep517 " - f"without {' and '.join(packages)} installed." - ) - raise_option_error(parser, option=option, msg=msg) - - # Otherwise, --no-use-pep517 was passed via the command-line. - parser.values.use_pep517 = False - - -use_pep517: Any = 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).", -) - -no_use_pep517: Any = partial( - Option, - "--no-use-pep517", - dest="use_pep517", - action="callback", - callback=_handle_no_use_pep517, - default=None, - help=SUPPRESS_HELP, -) - - -def _handle_config_settings( - option: Option, opt_str: str, value: str, parser: OptionParser -) -> None: - key, sep, val = value.partition("=") - if sep != "=": - parser.error(f"Arguments to {opt_str} must be of the form KEY=VAL") - dest = getattr(parser.values, option.dest) - if dest is None: - dest = {} - setattr(parser.values, option.dest, dest) - if key in dest: - if isinstance(dest[key], list): - dest[key].append(val) - else: - dest[key] = [dest[key], val] - else: - dest[key] = val - - -config_settings: Callable[..., Option] = partial( - Option, - "-C", - "--config-settings", - dest="config_settings", - type=str, - action="callback", - callback=_handle_config_settings, - metavar="settings", - help="Configuration settings to be passed to the PEP 517 build backend. " - "Settings take the form KEY=VALUE. Use multiple --config-settings options " - "to pass multiple keys to the backend.", -) - -build_options: Callable[..., Option] = partial( - Option, - "--build-option", - dest="build_options", - metavar="options", - action="append", - help="Extra arguments to be supplied to 'setup.py bdist_wheel'.", -) - -global_options: Callable[..., Option] = 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 or bdist_wheel command.", -) - -no_clean: Callable[..., Option] = partial( - Option, - "--no-clean", - action="store_true", - default=False, - help="Don't clean up build directories.", -) - -pre: Callable[..., Option] = partial( - Option, - "--pre", - action="store_true", - default=False, - help="Include pre-release and development versions. By default, " - "pip only finds stable versions.", -) - -disable_pip_version_check: Callable[..., Option] = 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.", -) - -root_user_action: Callable[..., Option] = partial( - Option, - "--root-user-action", - dest="root_user_action", - default="warn", - choices=["warn", "ignore"], - help="Action if pip is run as a root user. By default, a warning message is shown.", -) - - -def _handle_merge_hash( - option: Option, opt_str: str, value: str, parser: OptionParser -) -> None: - """Given a value spelled "algo:digest", append the digest to a list - pointed to in a dict by the algo name.""" - if not parser.values.hashes: - parser.values.hashes = {} - try: - algo, digest = value.split(":", 1) - except ValueError: - parser.error( - f"Arguments to {opt_str} must be a hash name " - "followed by a value, like --hash=sha256:" - "abcde..." - ) - if algo not in STRONG_HASHES: - parser.error( - "Allowed hash algorithms for {} are {}.".format( - opt_str, ", ".join(STRONG_HASHES) - ) - ) - parser.values.hashes.setdefault(algo, []).append(digest) - - -hash: Callable[..., Option] = 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...", -) - - -require_hashes: Callable[..., Option] = 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.", -) - - -list_path: Callable[..., Option] = partial( - PipOption, - "--path", - dest="path", - type="path", - action="append", - help="Restrict to the specified installation path for listing " - "packages (can be used multiple times).", -) - - -def check_list_path_option(options: Values) -> None: - if options.path and (options.user or options.local): - raise CommandError("Cannot combine '--path' with '--user' or '--local'") - - -list_exclude: Callable[..., Option] = partial( - PipOption, - "--exclude", - dest="excludes", - action="append", - metavar="package", - type="package_name", - help="Exclude specified package from the output", -) - - -no_python_version_warning: Callable[..., Option] = partial( - Option, - "--no-python-version-warning", - dest="no_python_version_warning", - action="store_true", - default=False, - help="Silence deprecation warnings for upcoming unsupported Pythons.", -) - - -# Features that are now always on. A warning is printed if they are used. -ALWAYS_ENABLED_FEATURES = [ - "no-binary-enable-wheel-cache", # always on since 23.1 -] - -use_new_feature: Callable[..., Option] = partial( - Option, - "--use-feature", - dest="features_enabled", - metavar="feature", - action="append", - default=[], - choices=[ - "fast-deps", - "truststore", - ] - + ALWAYS_ENABLED_FEATURES, - help="Enable new functionality, that may be backward incompatible.", -) - -use_deprecated_feature: Callable[..., Option] = partial( - Option, - "--use-deprecated", - dest="deprecated_features_enabled", - metavar="feature", - action="append", - default=[], - choices=[ - "legacy-resolver", - ], - help=("Enable deprecated functionality, that will be removed in the future."), -) - - -########## -# groups # -########## - -general_group: Dict[str, Any] = { - "name": "General Options", - "options": [ - help_, - debug_mode, - isolated_mode, - require_virtualenv, - python, - verbose, - version, - quiet, - log, - no_input, - keyring_provider, - proxy, - retries, - timeout, - exists_action, - trusted_host, - cert, - client_cert, - cache_dir, - no_cache, - disable_pip_version_check, - no_color, - no_python_version_warning, - use_new_feature, - use_deprecated_feature, - ], -} - -index_group: Dict[str, Any] = { - "name": "Package Index Options", - "options": [ - index_url, - extra_index_url, - no_index, - find_links, - ], -} diff --git a/venv/lib/python3.12/site-packages/pip/_internal/cli/command_context.py b/venv/lib/python3.12/site-packages/pip/_internal/cli/command_context.py deleted file mode 100644 index 139995a..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/cli/command_context.py +++ /dev/null @@ -1,27 +0,0 @@ -from contextlib import ExitStack, contextmanager -from typing import ContextManager, Generator, TypeVar - -_T = TypeVar("_T", covariant=True) - - -class CommandContextMixIn: - def __init__(self) -> None: - super().__init__() - self._in_main_context = False - self._main_context = ExitStack() - - @contextmanager - def main_context(self) -> Generator[None, None, 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: ContextManager[_T]) -> _T: - assert self._in_main_context - - return self._main_context.enter_context(context_provider) diff --git a/venv/lib/python3.12/site-packages/pip/_internal/cli/main.py b/venv/lib/python3.12/site-packages/pip/_internal/cli/main.py deleted file mode 100644 index 7e061f5..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/cli/main.py +++ /dev/null @@ -1,79 +0,0 @@ -"""Primary application entrypoint. -""" -import locale -import logging -import os -import sys -import warnings -from typing import List, Optional - -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 - -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: Optional[List[str]] = None) -> int: - if args is None: - args = sys.argv[1:] - - # Suppress the pkg_resources deprecation warning - # Note - we use a module of .*pkg_resources to cover - # the normal case (pip._vendor.pkg_resources) and the - # devendored case (a bare pkg_resources) - warnings.filterwarnings( - action="ignore", category=DeprecationWarning, module=".*pkg_resources" - ) - - # Configure our deprecation warnings to be sent through loggers - deprecation.install_warning_logger() - - autocomplete() - - try: - cmd_name, cmd_args = parse_command(args) - except PipError as exc: - sys.stderr.write(f"ERROR: {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.12/site-packages/pip/_internal/cli/main_parser.py b/venv/lib/python3.12/site-packages/pip/_internal/cli/main_parser.py deleted file mode 100644 index 5ade356..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/cli/main_parser.py +++ /dev/null @@ -1,134 +0,0 @@ -"""A single place for constructing and exposing the main parser -""" - -import os -import subprocess -import sys -from typing import List, Optional, Tuple - -from pip._internal.build_env import get_runnable_pip -from pip._internal.cli import cmdoptions -from pip._internal.cli.parser import ConfigOptionParser, UpdatingDefaultsHelpFormatter -from pip._internal.commands import commands_dict, get_similar_commands -from pip._internal.exceptions import CommandError -from pip._internal.utils.misc import get_pip_version, get_prog - -__all__ = ["create_main_parser", "parse_command"] - - -def create_main_parser() -> ConfigOptionParser: - """Creates and returns the main parser for pip's CLI""" - - parser = ConfigOptionParser( - usage="\n%prog [options]", - add_help_option=False, - formatter=UpdatingDefaultsHelpFormatter(), - name="global", - prog=get_prog(), - ) - 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 = [""] + [ - f"{name:27} {command_info.summary}" - for name, command_info in commands_dict.items() - ] - parser.description = "\n".join(description) - - return parser - - -def identify_python_interpreter(python: str) -> Optional[str]: - # If the named file exists, use it. - # If it's a directory, assume it's a virtual environment and - # look for the environment's Python executable. - if os.path.exists(python): - if os.path.isdir(python): - # bin/python for Unix, Scripts/python.exe for Windows - # Try both in case of odd cases like cygwin. - for exe in ("bin/python", "Scripts/python.exe"): - py = os.path.join(python, exe) - if os.path.exists(py): - return py - else: - return python - - # Could not find the interpreter specified - return None - - -def parse_command(args: List[str]) -> Tuple[str, List[str]]: - parser = create_main_parser() - - # Note: parser calls disable_interspersed_args(), so the result of this - # 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) - - # --python - if general_options.python and "_PIP_RUNNING_IN_SUBPROCESS" not in os.environ: - # Re-invoke pip using the specified Python interpreter - interpreter = identify_python_interpreter(general_options.python) - if interpreter is None: - raise CommandError( - f"Could not locate Python interpreter {general_options.python}" - ) - - pip_cmd = [ - interpreter, - get_runnable_pip(), - ] - pip_cmd.extend(args) - - # Set a flag so the child doesn't re-invoke itself, causing - # an infinite loop. - os.environ["_PIP_RUNNING_IN_SUBPROCESS"] = "1" - returncode = 0 - try: - proc = subprocess.run(pip_cmd) - returncode = proc.returncode - except (subprocess.SubprocessError, OSError) as exc: - raise CommandError(f"Failed to run pip under {interpreter}: {exc}") - sys.exit(returncode) - - # --version - if general_options.version: - sys.stdout.write(parser.version) - 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 = [f'unknown command "{cmd_name}"'] - if guess: - msg.append(f'maybe you meant "{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.12/site-packages/pip/_internal/cli/parser.py b/venv/lib/python3.12/site-packages/pip/_internal/cli/parser.py deleted file mode 100644 index ae554b2..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/cli/parser.py +++ /dev/null @@ -1,294 +0,0 @@ -"""Base option parser setup""" - -import logging -import optparse -import shutil -import sys -import textwrap -from contextlib import suppress -from typing import Any, Dict, Generator, List, Tuple - -from pip._internal.cli.status_codes import UNKNOWN_ERROR -from pip._internal.configuration import Configuration, ConfigurationError -from pip._internal.utils.misc import redact_auth_from_url, strtobool - -logger = logging.getLogger(__name__) - - -class PrettyHelpFormatter(optparse.IndentedHelpFormatter): - """A prettier/less verbose help formatter for optparse.""" - - def __init__(self, *args: Any, **kwargs: Any) -> None: - # help position must be aligned with __init__.parseopts.description - kwargs["max_help_position"] = 30 - kwargs["indent_increment"] = 1 - kwargs["width"] = shutil.get_terminal_size()[0] - 2 - super().__init__(*args, **kwargs) - - def format_option_strings(self, option: optparse.Option) -> str: - return self._format_option_strings(option) - - def _format_option_strings( - self, option: optparse.Option, mvarfmt: str = " <{}>", optsep: str = ", " - ) -> str: - """ - 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 - :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(): - assert option.dest is not None - metavar = option.metavar or option.dest.lower() - opts.append(mvarfmt.format(metavar.lower())) - - return "".join(opts) - - def format_heading(self, heading: str) -> str: - if heading == "Options": - return "" - return heading + ":\n" - - def format_usage(self, usage: str) -> str: - """ - Ensure there is only one newline between usage and the first heading - if there is no description. - """ - msg = "\nUsage: {}\n".format(self.indent_lines(textwrap.dedent(usage), " ")) - return msg - - def format_description(self, description: str) -> str: - # 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 = f"{label}:\n{description}\n" - return description - else: - return "" - - def format_epilog(self, epilog: str) -> str: - # leave full control over epilog to us - if epilog: - return epilog - else: - return "" - - def indent_lines(self, text: str, indent: str) -> str: - 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. - - Also redact auth from url type options - """ - - def expand_default(self, option: optparse.Option) -> str: - default_values = None - if self.parser is not None: - assert isinstance(self.parser, ConfigOptionParser) - self.parser._update_defaults(self.parser.defaults) - assert option.dest is not None - default_values = self.parser.defaults.get(option.dest) - help_text = super().expand_default(option) - - if default_values and option.metavar == "URL": - if isinstance(default_values, str): - default_values = [default_values] - - # If its not a list, we should abort and just return the help text - if not isinstance(default_values, list): - default_values = [] - - for val in default_values: - help_text = help_text.replace(val, redact_auth_from_url(val)) - - return help_text - - -class CustomOptionParser(optparse.OptionParser): - def insert_option_group( - self, idx: int, *args: Any, **kwargs: Any - ) -> optparse.OptionGroup: - """Insert an OptionGroup at a given position.""" - group = self.add_option_group(*args, **kwargs) - - self.option_groups.pop() - self.option_groups.insert(idx, group) - - return group - - @property - def option_list_all(self) -> List[optparse.Option]: - """Get a list of all options, including those in option groups.""" - res = self.option_list[:] - for i in self.option_groups: - 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: Any, - name: str, - isolated: bool = False, - **kwargs: Any, - ) -> None: - self.name = name - self.config = Configuration(isolated) - - assert self.name - super().__init__(*args, **kwargs) - - def check_default(self, option: optparse.Option, key: str, val: Any) -> Any: - try: - return option.check_value(key, val) - except optparse.OptionValueError as exc: - print(f"An error occurred during configuration: {exc}") - sys.exit(3) - - def _get_ordered_configuration_items( - self, - ) -> Generator[Tuple[str, Any], None, None]: - # Configuration gives keys in an unordered manner. Order them. - override_order = ["global", self.name, ":env:"] - - # Pool the options into different groups - section_items: Dict[str, List[Tuple[str, Any]]] = { - 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: Dict[str, Any]) -> Dict[str, Any]: - """Updates the given defaults with values from the config files and - the environ. Does a little special handling for certain types of - options (lists).""" - - # 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 - - assert option.dest is not None - - if option.action in ("store_true", "store_false"): - try: - val = strtobool(val) - except ValueError: - self.error( - f"{val} is not a valid value for {key} option, " - "please specify a boolean value like yes/no, " - "true/false or 1/0 instead." - ) - elif option.action == "count": - with suppress(ValueError): - val = strtobool(val) - with suppress(ValueError): - val = int(val) - if not isinstance(val, int) or val < 0: - self.error( - f"{val} is not a valid value for {key} option, " - "please instead specify either a non-negative integer " - "or a boolean value like yes/no or false/true " - "which is equivalent to 1/0." - ) - elif option.action == "append": - val = val.split() - val = [self.check_default(option, key, v) for v in val] - elif option.action == "callback": - assert option.callback is not None - 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) -> optparse.Values: - """Overriding to make updating the defaults after instantiation of - the option parser possible, _update_defaults() does the dirty work.""" - if not self.process_default_values: - # 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(): - assert option.dest is not None - default = defaults.get(option.dest) - if isinstance(default, str): - opt_str = option.get_opt_string() - defaults[option.dest] = option.check_value(opt_str, default) - return optparse.Values(defaults) - - def error(self, msg: str) -> None: - self.print_usage(sys.stderr) - self.exit(UNKNOWN_ERROR, f"{msg}\n") diff --git a/venv/lib/python3.12/site-packages/pip/_internal/cli/progress_bars.py b/venv/lib/python3.12/site-packages/pip/_internal/cli/progress_bars.py deleted file mode 100644 index 0ad1403..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/cli/progress_bars.py +++ /dev/null @@ -1,68 +0,0 @@ -import functools -from typing import Callable, Generator, Iterable, Iterator, Optional, Tuple - -from pip._vendor.rich.progress import ( - BarColumn, - DownloadColumn, - FileSizeColumn, - Progress, - ProgressColumn, - SpinnerColumn, - TextColumn, - TimeElapsedColumn, - TimeRemainingColumn, - TransferSpeedColumn, -) - -from pip._internal.utils.logging import get_indentation - -DownloadProgressRenderer = Callable[[Iterable[bytes]], Iterator[bytes]] - - -def _rich_progress_bar( - iterable: Iterable[bytes], - *, - bar_type: str, - size: int, -) -> Generator[bytes, None, None]: - assert bar_type == "on", "This should only be used in the default mode." - - if not size: - total = float("inf") - columns: Tuple[ProgressColumn, ...] = ( - TextColumn("[progress.description]{task.description}"), - SpinnerColumn("line", speed=1.5), - FileSizeColumn(), - TransferSpeedColumn(), - TimeElapsedColumn(), - ) - else: - total = size - columns = ( - TextColumn("[progress.description]{task.description}"), - BarColumn(), - DownloadColumn(), - TransferSpeedColumn(), - TextColumn("eta"), - TimeRemainingColumn(), - ) - - progress = Progress(*columns, refresh_per_second=30) - task_id = progress.add_task(" " * (get_indentation() + 2), total=total) - with progress: - for chunk in iterable: - yield chunk - progress.update(task_id, advance=len(chunk)) - - -def get_download_progress_renderer( - *, bar_type: str, size: Optional[int] = None -) -> DownloadProgressRenderer: - """Get an object that can be used to render the download progress. - - Returns a callable, that takes an iterable to "wrap". - """ - if bar_type == "on": - return functools.partial(_rich_progress_bar, bar_type=bar_type, size=size) - else: - return iter # no-op, when passed an iterator diff --git a/venv/lib/python3.12/site-packages/pip/_internal/cli/req_command.py b/venv/lib/python3.12/site-packages/pip/_internal/cli/req_command.py deleted file mode 100644 index 6f2f79c..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/cli/req_command.py +++ /dev/null @@ -1,505 +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 -import sys -from functools import partial -from optparse import Values -from typing import TYPE_CHECKING, Any, List, Optional, Tuple - -from pip._internal.cache import WheelCache -from pip._internal.cli import cmdoptions -from pip._internal.cli.base_command import Command -from pip._internal.cli.command_context import CommandContextMixIn -from pip._internal.exceptions import CommandError, PreviousBuildDirError -from pip._internal.index.collector import LinkCollector -from pip._internal.index.package_finder import PackageFinder -from pip._internal.models.selection_prefs import SelectionPreferences -from pip._internal.models.target_python import TargetPython -from pip._internal.network.session import PipSession -from pip._internal.operations.build.build_tracker import BuildTracker -from pip._internal.operations.prepare import RequirementPreparer -from pip._internal.req.constructors import ( - install_req_from_editable, - install_req_from_line, - install_req_from_parsed_requirement, - install_req_from_req_string, -) -from pip._internal.req.req_file import parse_requirements -from pip._internal.req.req_install import InstallRequirement -from pip._internal.resolution.base import BaseResolver -from pip._internal.self_outdated_check import pip_self_version_check -from pip._internal.utils.temp_dir import ( - TempDirectory, - TempDirectoryTypeRegistry, - tempdir_kinds, -) -from pip._internal.utils.virtualenv import running_under_virtualenv - -if TYPE_CHECKING: - from ssl import SSLContext - -logger = logging.getLogger(__name__) - - -def _create_truststore_ssl_context() -> Optional["SSLContext"]: - if sys.version_info < (3, 10): - raise CommandError("The truststore feature is only available for Python 3.10+") - - try: - import ssl - except ImportError: - logger.warning("Disabling truststore since ssl support is missing") - return None - - try: - from pip._vendor import truststore - except ImportError as e: - raise CommandError(f"The truststore feature is unavailable: {e}") - - return truststore.SSLContext(ssl.PROTOCOL_TLS_CLIENT) - - -class SessionCommandMixin(CommandContextMixIn): - - """ - A class mixin for command classes needing _build_session(). - """ - - def __init__(self) -> None: - super().__init__() - self._session: Optional[PipSession] = None - - @classmethod - def _get_index_urls(cls, options: Values) -> Optional[List[str]]: - """Return a list of index urls from user-provided options.""" - index_urls = [] - if not getattr(options, "no_index", False): - 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: 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: Values, - retries: Optional[int] = None, - timeout: Optional[int] = None, - fallback_to_certifi: bool = False, - ) -> PipSession: - cache_dir = options.cache_dir - assert not cache_dir or os.path.isabs(cache_dir) - - if "truststore" in options.features_enabled: - try: - ssl_context = _create_truststore_ssl_context() - except Exception: - if not fallback_to_certifi: - raise - ssl_context = None - else: - ssl_context = None - - session = PipSession( - cache=os.path.join(cache_dir, "http-v2") if cache_dir else None, - retries=retries if retries is not None else options.retries, - trusted_hosts=options.trusted_hosts, - index_urls=self._get_index_urls(options), - ssl_context=ssl_context, - ) - - # Handle custom ca-bundles from the user - 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 - session.auth.keyring_provider = options.keyring_provider - - 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: 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), - # This is set to ensure the function does not fail when truststore is - # specified in use-feature but cannot be loaded. This usually raises a - # CommandError and shows a nice user-facing error, but this function is not - # called in that try-except block. - fallback_to_certifi=True, - ) - with session: - pip_self_version_check(session, options) - - -KEEPABLE_TEMPDIR_TYPES = [ - tempdir_kinds.BUILD_ENV, - tempdir_kinds.EPHEM_WHEEL_CACHE, - tempdir_kinds.REQ_BUILD, -] - - -def warn_if_run_as_root() -> None: - """Output a warning for sudo users on Unix. - - In a virtual environment, sudo pip still writes to virtualenv. - On Windows, users may run pip as Administrator without issues. - This warning only applies to Unix root users outside of virtualenv. - """ - if running_under_virtualenv(): - return - if not hasattr(os, "getuid"): - return - # On Windows, there are no "system managed" Python packages. Installing as - # Administrator via pip is the correct way of updating system environments. - # - # We choose sys.platform over utils.compat.WINDOWS here to enable Mypy platform - # checks: https://mypy.readthedocs.io/en/stable/common_issues.html - if sys.platform == "win32" or sys.platform == "cygwin": - return - - if os.getuid() != 0: - return - - logger.warning( - "Running pip as the 'root' user can result in broken permissions and " - "conflicting behaviour with the system package manager. " - "It is recommended to use a virtual environment instead: " - "https://pip.pypa.io/warnings/venv" - ) - - -def with_cleanup(func: Any) -> Any: - """Decorator for common logic related to managing temporary - directories. - """ - - def configure_tempdir_registry(registry: TempDirectoryTypeRegistry) -> None: - for t in KEEPABLE_TEMPDIR_TYPES: - registry.set_delete(t, False) - - def wrapper( - self: RequirementCommand, options: Values, args: List[Any] - ) -> Optional[int]: - assert self.tempdir_registry is not None - if options.no_clean: - configure_tempdir_registry(self.tempdir_registry) - - try: - return func(self, options, args) - except PreviousBuildDirError: - # This kind of conflict can occur when the user passes an explicit - # build directory with a pre-existing folder. In that case we do - # not want to accidentally remove it. - configure_tempdir_registry(self.tempdir_registry) - raise - - return wrapper - - -class RequirementCommand(IndexGroupCommand): - def __init__(self, *args: Any, **kw: Any) -> None: - super().__init__(*args, **kw) - - self.cmd_opts.add_option(cmdoptions.no_clean()) - - @staticmethod - def determine_resolver_variant(options: Values) -> str: - """Determines which resolver should be used, based on the given options.""" - if "legacy-resolver" in options.deprecated_features_enabled: - return "legacy" - - return "resolvelib" - - @classmethod - def make_requirement_preparer( - cls, - temp_build_dir: TempDirectory, - options: Values, - build_tracker: BuildTracker, - session: PipSession, - finder: PackageFinder, - use_user_site: bool, - download_dir: Optional[str] = None, - verbosity: int = 0, - ) -> RequirementPreparer: - """ - Create a RequirementPreparer instance for the given parameters. - """ - temp_build_dir_path = temp_build_dir.path - assert temp_build_dir_path is not None - legacy_resolver = False - - resolver_variant = cls.determine_resolver_variant(options) - if resolver_variant == "resolvelib": - lazy_wheel = "fast-deps" in options.features_enabled - if lazy_wheel: - logger.warning( - "pip is using lazily downloaded wheels using HTTP " - "range requests to obtain dependency information. " - "This experimental feature is enabled through " - "--use-feature=fast-deps and it is not ready for " - "production." - ) - else: - legacy_resolver = True - lazy_wheel = False - if "fast-deps" in options.features_enabled: - logger.warning( - "fast-deps has no effect when used with the legacy resolver." - ) - - return RequirementPreparer( - build_dir=temp_build_dir_path, - src_dir=options.src_dir, - download_dir=download_dir, - build_isolation=options.build_isolation, - check_build_deps=options.check_build_deps, - build_tracker=build_tracker, - session=session, - progress_bar=options.progress_bar, - finder=finder, - require_hashes=options.require_hashes, - use_user_site=use_user_site, - lazy_wheel=lazy_wheel, - verbosity=verbosity, - legacy_resolver=legacy_resolver, - ) - - @classmethod - def make_resolver( - cls, - preparer: RequirementPreparer, - finder: PackageFinder, - options: Values, - wheel_cache: Optional[WheelCache] = None, - use_user_site: bool = False, - ignore_installed: bool = True, - ignore_requires_python: bool = False, - force_reinstall: bool = False, - upgrade_strategy: str = "to-satisfy-only", - use_pep517: Optional[bool] = None, - py_version_info: Optional[Tuple[int, ...]] = None, - ) -> BaseResolver: - """ - Create a Resolver instance for the given parameters. - """ - make_install_req = partial( - install_req_from_req_string, - isolated=options.isolated_mode, - use_pep517=use_pep517, - ) - resolver_variant = cls.determine_resolver_variant(options) - # The long import name and duplicated invocation is needed to convince - # Mypy into correctly typechecking. Otherwise it would complain the - # "Resolver" class being redefined. - if resolver_variant == "resolvelib": - import pip._internal.resolution.resolvelib.resolver - - return pip._internal.resolution.resolvelib.resolver.Resolver( - preparer=preparer, - finder=finder, - wheel_cache=wheel_cache, - 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, - ) - import pip._internal.resolution.legacy.resolver - - return pip._internal.resolution.legacy.resolver.Resolver( - preparer=preparer, - finder=finder, - wheel_cache=wheel_cache, - 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 get_requirements( - self, - args: List[str], - options: Values, - finder: PackageFinder, - session: PipSession, - ) -> List[InstallRequirement]: - """ - Parse command-line arguments into the corresponding requirements. - """ - requirements: List[InstallRequirement] = [] - for filename in options.constraints: - for parsed_req in parse_requirements( - filename, - constraint=True, - finder=finder, - options=options, - session=session, - ): - req_to_add = install_req_from_parsed_requirement( - parsed_req, - isolated=options.isolated_mode, - user_supplied=False, - ) - requirements.append(req_to_add) - - for req in args: - req_to_add = install_req_from_line( - req, - comes_from=None, - isolated=options.isolated_mode, - use_pep517=options.use_pep517, - user_supplied=True, - config_settings=getattr(options, "config_settings", None), - ) - requirements.append(req_to_add) - - for req in options.editables: - req_to_add = install_req_from_editable( - req, - user_supplied=True, - isolated=options.isolated_mode, - use_pep517=options.use_pep517, - config_settings=getattr(options, "config_settings", None), - ) - requirements.append(req_to_add) - - # NOTE: options.require_hashes may be set if --require-hashes is True - for filename in options.requirements: - for parsed_req in parse_requirements( - filename, finder=finder, options=options, session=session - ): - req_to_add = install_req_from_parsed_requirement( - parsed_req, - isolated=options.isolated_mode, - use_pep517=options.use_pep517, - user_supplied=True, - config_settings=parsed_req.options.get("config_settings") - if parsed_req.options - else None, - ) - requirements.append(req_to_add) - - # If any requirement has hash options, enable hash checking. - 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} " - '(maybe you meant "pip {name} {links}"?)'.format( - **dict(opts, links=" ".join(options.find_links)) - ) - ) - else: - raise CommandError( - "You must give at least one requirement to {name} " - '(see "pip help {name}")'.format(**opts) - ) - - return requirements - - @staticmethod - def trace_basic_info(finder: 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: Values, - session: PipSession, - target_python: Optional[TargetPython] = None, - ignore_requires_python: Optional[bool] = None, - ) -> 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 = LinkCollector.create(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.12/site-packages/pip/_internal/cli/spinners.py b/venv/lib/python3.12/site-packages/pip/_internal/cli/spinners.py deleted file mode 100644 index cf2b976..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/cli/spinners.py +++ /dev/null @@ -1,159 +0,0 @@ -import contextlib -import itertools -import logging -import sys -import time -from typing import IO, Generator, Optional - -from pip._internal.utils.compat import WINDOWS -from pip._internal.utils.logging import get_indentation - -logger = logging.getLogger(__name__) - - -class SpinnerInterface: - def spin(self) -> None: - raise NotImplementedError() - - def finish(self, final_status: str) -> None: - raise NotImplementedError() - - -class InteractiveSpinner(SpinnerInterface): - def __init__( - self, - message: str, - file: Optional[IO[str]] = None, - spin_chars: str = "-\\|/", - # Empirically, 8 updates/second looks nice - min_update_interval_seconds: float = 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: str) -> None: - assert not self._finished - # Erase what we wrote before by backspacing to the beginning, writing - # spaces to overwrite the old text, and then backspacing again - 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) -> None: - if self._finished: - return - if not self._rate_limiter.ready(): - return - self._write(next(self._spin_cycle)) - - def finish(self, final_status: 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: str, min_update_interval_seconds: float = 60.0) -> None: - self._message = message - self._finished = False - self._rate_limiter = RateLimiter(min_update_interval_seconds) - self._update("started") - - def _update(self, status: str) -> None: - assert not self._finished - self._rate_limiter.reset() - logger.info("%s: %s", self._message, status) - - def spin(self) -> None: - if self._finished: - return - if not self._rate_limiter.ready(): - return - self._update("still running...") - - def finish(self, final_status: str) -> None: - if self._finished: - return - self._update(f"finished with status '{final_status}'") - self._finished = True - - -class RateLimiter: - def __init__(self, min_update_interval_seconds: float) -> None: - self._min_update_interval_seconds = min_update_interval_seconds - self._last_update: float = 0 - - def ready(self) -> bool: - now = time.time() - delta = now - self._last_update - return delta >= self._min_update_interval_seconds - - def reset(self) -> None: - self._last_update = time.time() - - -@contextlib.contextmanager -def open_spinner(message: str) -> Generator[SpinnerInterface, None, None]: - # Interactive spinner goes directly to sys.stdout rather than being routed - # through the logging system, but it acts like it has level INFO, - # i.e. it's only displayed if we're at level INFO or better. - # Non-interactive spinner goes through the logging system, so it is always - # in sync with logging configuration. - if sys.stdout.isatty() and logger.getEffectiveLevel() <= logging.INFO: - spinner: SpinnerInterface = InteractiveSpinner(message) - 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") - - -HIDE_CURSOR = "\x1b[?25l" -SHOW_CURSOR = "\x1b[?25h" - - -@contextlib.contextmanager -def hidden_cursor(file: IO[str]) -> Generator[None, None, None]: - # The Windows terminal does not support the hide/show cursor ANSI codes, - # even via colorama. So don't even try. - if WINDOWS: - 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) diff --git a/venv/lib/python3.12/site-packages/pip/_internal/cli/status_codes.py b/venv/lib/python3.12/site-packages/pip/_internal/cli/status_codes.py deleted file mode 100644 index 5e29502..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/cli/status_codes.py +++ /dev/null @@ -1,6 +0,0 @@ -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.12/site-packages/pip/_internal/commands/__init__.py b/venv/lib/python3.12/site-packages/pip/_internal/commands/__init__.py deleted file mode 100644 index 858a410..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/commands/__init__.py +++ /dev/null @@ -1,132 +0,0 @@ -""" -Package containing all pip commands -""" - -import importlib -from collections import namedtuple -from typing import Any, Dict, Optional - -from pip._internal.cli.base_command import Command - -CommandInfo = namedtuple("CommandInfo", "module_path, class_name, summary") - -# This dictionary does a bunch of heavy lifting for help output: -# - Enables avoiding additional (costly) imports for presenting `--help`. -# - The ordering matters for help display. -# -# Even though the module path starts with the same "pip._internal.commands" -# prefix, the full path makes testing easier (specifically when modifying -# `commands_dict` in test setup / teardown). -commands_dict: Dict[str, CommandInfo] = { - "install": CommandInfo( - "pip._internal.commands.install", - "InstallCommand", - "Install packages.", - ), - "download": CommandInfo( - "pip._internal.commands.download", - "DownloadCommand", - "Download packages.", - ), - "uninstall": CommandInfo( - "pip._internal.commands.uninstall", - "UninstallCommand", - "Uninstall packages.", - ), - "freeze": CommandInfo( - "pip._internal.commands.freeze", - "FreezeCommand", - "Output installed packages in requirements format.", - ), - "inspect": CommandInfo( - "pip._internal.commands.inspect", - "InspectCommand", - "Inspect the python environment.", - ), - "list": CommandInfo( - "pip._internal.commands.list", - "ListCommand", - "List installed packages.", - ), - "show": CommandInfo( - "pip._internal.commands.show", - "ShowCommand", - "Show information about installed packages.", - ), - "check": CommandInfo( - "pip._internal.commands.check", - "CheckCommand", - "Verify installed packages have compatible dependencies.", - ), - "config": CommandInfo( - "pip._internal.commands.configuration", - "ConfigurationCommand", - "Manage local and global configuration.", - ), - "search": CommandInfo( - "pip._internal.commands.search", - "SearchCommand", - "Search PyPI for packages.", - ), - "cache": CommandInfo( - "pip._internal.commands.cache", - "CacheCommand", - "Inspect and manage pip's wheel cache.", - ), - "index": CommandInfo( - "pip._internal.commands.index", - "IndexCommand", - "Inspect information available from package indexes.", - ), - "wheel": CommandInfo( - "pip._internal.commands.wheel", - "WheelCommand", - "Build wheels from your requirements.", - ), - "hash": CommandInfo( - "pip._internal.commands.hash", - "HashCommand", - "Compute hashes of package archives.", - ), - "completion": CommandInfo( - "pip._internal.commands.completion", - "CompletionCommand", - "A helper command used for command completion.", - ), - "debug": CommandInfo( - "pip._internal.commands.debug", - "DebugCommand", - "Show information useful for debugging.", - ), - "help": CommandInfo( - "pip._internal.commands.help", - "HelpCommand", - "Show help for commands.", - ), -} - - -def create_command(name: str, **kwargs: 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: str) -> Optional[str]: - """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 None diff --git a/venv/lib/python3.12/site-packages/pip/_internal/commands/__pycache__/__init__.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/commands/__pycache__/__init__.cpython-312.pyc deleted file mode 100644 index 232d6c5fdb83783fe13a46a425902292b768e834..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4012 zcmaJ^&2!tv6<>fP2#F%8Pg}Mu8@46clugp|N8HMeU0I4^*|DTVjngX0a3Jndgarc3 z0+dXKn&F{`YBJNr(}Q*BL7nL#8Ry_*|A$_z(IF@%o!ZmMp*K#IQ%-%mAY>>tixGj{ z-|y{j-@bkOp})oBod}+t%$M4D5}|*wivL7gg?(8>=qdUTVYG~}fJI$c7T_Dw#ZqWF zBrq(jhf9&=NJ(0jO3~#g$0E91>R9d&kcdbKOE~%rbl9`psUZxaq!V}GP8@p{^6)84HXg@~>@DY48fDUr>7(R}N0_X{j4&#&fQ~*^tdK#a>X9MU6 zM@R7(J{LgGb2Np=@r3|-k)vsx!Px+MiK7$vGQJW(uX6MnehXg@pugbgFYzS45kPNp z^lf|#-wvR^;^-8}$(UCgo&#_t1~tcs}*YNMTtYJN>!B}(2jY*jNfV^vXg zT`6m2fJ!CRz*gtK*__U&1h>;rO9b1MvQAPVH#B8b-SCW-w_SOmY-^^W>R=R|_S(6z zR$t_C|N~wqpcDn-PjVmeWh_$0VQvYka~)`V!kmf88?zIlKfijL>o6b z>vl~uBVYddLqfGe^$o5nMRlF6mJ%egwxSaSlQJi_pco5*Vjo{^)K3xSChQi>Zy5SHOW7zA0xmOSP}U$skJ~D9*6o^O zM!xbDU-{4^udAA_valDZS@K-J0xVMk>0%X$rI>{SXW5)->&)BEJQ(SOr9$m=+l28= z+#aUsnfu+Or<5Ym%Y^!ywNkNQOJLIq+HCjcsp>U?@L;l1S#290&bnPQ%*gLy?0*&- z^iZhiybs=B70wJ6An>DofPjPm!Q0n8%5_nXBZFhX_2&bv?GMzSexhBm`?>u!S3qws;zL7^@_YpHHV zZ2!K5>XCZLzw2yDBC1PRtfP7u3x5*p!e4|x2%FJ*bP1(Gwb@Puo@q){n0D3h_6{RY z*xa)Xv^8??>{B*0yU5{H$OS`Tqs(xDlt?dvQ*N|%E`EbjVS0ff9a^buQd`$n+_+cF zd55YST_v_^+cYKfwlvMmV}TPFQtjZxrI#2hwVL|j&T#`b>PKG&BQ_rP{G?}#W{G5} ziZ!DQ+kd5&ogvnmZI-iBbX_&lQ;T!yXLYij} z&i1U|TQ&!nX6JI5a@9@bc?@$clHLGUO7OGp!K;COl+pQX&wsspZgMv~(zyTC@$HYk zk01FiKC&Ah+4*=cKGB%{zJF+YcIVz+f41@9?}?!oiK(6buQzrRQ-2+USL5B6vEIh~ zKB%EXnG^wl<;XtEp{L&c7?p%gL4aI(#Mqxb&sz0OxEI%jI9UwZxZtq<}^ ztcx^K7qP(dbO}{Msc`MMpC&9L6t!ZT>AXoPoWdE(?%Z&}>VesY=`t;ngYzBsS8F~M zaidr(6d?5U7Ff9v-P|D5%bV~TsamO!ml~W+c&+{DTWruU&vcSC?Pv0qR)UR|`g35> zX`rg`v)+PN1N{(Ay^JNloZOoH;$~y!)xg+}{q3jUrEl-1Z||k2_6F`W=3hkzoaFGf zx|>v9$jZxPA7vNRRJR+=<*=F0<>+OoyRp2f>o7dn1TD%OaV5K2hCPL{MM_!JDGRIn z^J}55WmZ&(fuAO9%~F=O-l#*CP2FTJry7O{i-XBSmn@g~Sm*>RF^~ADf0A!{3*r`K zS;lq(>wSoKGb9MYe?(CT@5@N&`3E}lPc*iR#(qGTUnK^&hhLn(x0krzh&6j33MtVE z$G1Lr?wWpLFC)K!PVr9{Gt+ zdTyTe$WJ}8a9B3$$*y{2`7rsmM}Fp!wZmk_BR}^@_(v%?$TW~J$ah5U?L3e@PcAqz z{6S!^1KB4v7d-MeKnBLih63aKtw*jLmObss<~iAj|K9#;dVA&`AIQ diff --git a/venv/lib/python3.12/site-packages/pip/_internal/commands/__pycache__/cache.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/commands/__pycache__/cache.cpython-312.pyc deleted file mode 100644 index 7a16be612bc63938935fdfb8e6659ab4e7ed36d7..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 9721 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 F{|AD5sMi1h diff --git a/venv/lib/python3.12/site-packages/pip/_internal/commands/__pycache__/check.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/commands/__pycache__/check.cpython-312.pyc deleted file mode 100644 index 8a488dfa0f396ac5dcaec10678b3a462d0fff2e0..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2100 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 G>;C{c3NeBJ diff --git a/venv/lib/python3.12/site-packages/pip/_internal/commands/__pycache__/debug.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/commands/__pycache__/debug.cpython-312.pyc deleted file mode 100644 index ac30f83f5573b9249b59794f56e7eba756d3d0ba..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 10171 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 diff --git a/venv/lib/python3.12/site-packages/pip/_internal/commands/__pycache__/download.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/commands/__pycache__/download.cpython-312.pyc deleted file mode 100644 index 5f0808a5d9956f5885f0c4bde97b12e797c549bc..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 7599 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 diff --git a/venv/lib/python3.12/site-packages/pip/_internal/commands/__pycache__/hash.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/commands/__pycache__/hash.cpython-312.pyc deleted file mode 100644 index e0ebf2fdbf6c4137b2a1701e38a4640108dcfe39..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2993 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 diff --git a/venv/lib/python3.12/site-packages/pip/_internal/commands/__pycache__/index.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/commands/__pycache__/index.cpython-312.pyc deleted file mode 100644 index 38bab2f38e18a64c8d095a9840ac686445affa97..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6730 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 diff --git a/venv/lib/python3.12/site-packages/pip/_internal/commands/__pycache__/inspect.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/commands/__pycache__/inspect.cpython-312.pyc deleted file mode 100644 index 5409b5f59c9afc847490d869ae51028febda4c62..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3985 zcmb7HO>7&-6`o!0E|-5I^)FGfwN&g_G%V7V?ItN=r?zCbat$SgoEBgZY}ecsMQORq z%q|^BkPHX#K`9E@1`5ap4Acb*RIUuvz2(@Rdl9WTB&HH#pv|E-x^fTAsc(k65~b*p zIn2I!@6DSxGw*wE_V2M+7(siSxmR?f2>p`|{3d$D&R0OJA|2_RiE{MIn_P*{@f@WC zW}qbGgp!yOOHxi^Ji!c>W+c`F9{0!smyZ9N4yMu^k$$e36~jpfNZ^vSK!k~6-X+5IqT_5aanVW30MOcZ&s)(i5HB6t3(`EH;Xsb@_d0>ij*~XR&{N)g3Ww$E6rZ=20J%^ zScOx`aXQNJI+qLRd`{2h1!$uUwF(YKO z&G1w@Bj^#3#23VLjI>Q!PT9!2-fk9iVFjAURNPrZ$=j9-r=!?2il%(9;Lh5X(sF7F zoPkotwqD5_pn#3Cja{W^Dc7dopHgOQT+-YOGkRmOhkX_0IOrFYkG#YDm`K=gE7+RK zd-u!s9fY3V?9K>qSJ4uhW9fG#{0*M+8t`#!VbEZKbdX=vR;%=ek^ z`Y1zl{{6N1x9-t?Bs0r$i-JeaMZU|^!-t>2I^Wdg&;m+FrWS*vqo$qLOcHin8yl*N zE5_Bu>B$*-E1ClF?p8Dtt`M$QbCp@mQ3|GgQ!^DUpEn%ml%m^;WxI+AaqNlAh0&tr zxSDAiaNAmbUMm<*2CyY*c^2kD4^TvyHO%s&G&)*w3`_*tFP?heG8YuP;+8A!?riYJ zHwb=Fy-}y=8kw{}1l<4x^}x1pFYWqhM|YW)hzuxHA#xlN)^tVz$}mlOBt#unDVm5> z)-YYa6BaSBOD9km7qDF^1LOq9FlQVZZOXUv*;%_}WU;0ftuo|-%3^lHaOPdRoV|o^ zY1Zha4<<*)&0_Wz99b4{n=LaCoXwmW%TkX={qx9{i{-2e3BU=eIelzvfm-5?mrO4-zntY-vpIGD8 z&i(nqlM658cXq%JM1me%iJ;+vlWzqc4PXY}L(Q_e3S%aB&x4qv_$m_YZ0JYPV0{^L%B zmIZ)cw=doME(yM+2mG(Q1<+m=TpG5l`GD60kA!8>rTLe&CGqL*JPx@@pFa)rIcDQi zloqD|VPOVl)dmQW5QRyT6rA~DnQ&(SEX=&4; z_+pyTF^v^WuP7~Hh0@1pcN{t*Qo|0o2OlCe(}hEmC@o2ff>Tr}fGgHw#{uL3?=%RV z73l7uExDs6r>k;$?ZlVz*j8fbaqy4P-$yqSqqW4fYT{bG_vq^KgXMb9kyZ17xz*nF zn~yfzQ;i^M|0%bFg!b@?*odOOfvtfz>+el`)qmxg`|wyTd8(Q`wRYo0a_o8km92ry z=D_J!A*mz0BE1Gsbv~3{$U|H4o|U%${U?HwS2^bS-$wc_D>8ly{K~gtfue;WCc_W| zQ45TN4Y;jyJh9F_;+J`l2?zBdMgvQM&$^ZZbM&YWG(QrTc%6S2WL64n98!89&V|o9 z-Q5DT7vHp~7CBvf#QQeD!Xao|77yoRaY=-k5?viMXoMYTI1c<>gzgDpR*=o&r%_s- zf`^t|GF*+uF=_WHl?Ea!Mq#~(A>q;o6_E|S=xR4j;|9zMFb+r|nrG}ih+q=J#wYMv zbPYWnBC%bQG;T?ZD(_my7r-wP^n#l7`}S3M)XdRUeK#=O2);zM`}V-|X%QZKG{Tt+ z_%eunB+w{<_%wba>a z>g+2qFce-1K#cb!SJemVO1K{B-iV~?%E_8CR#nC}m2)fO_oL6FM;a1JkJd)6R!6RG zM32|wBOCE^{~CC6HTmUc;^RR*y(|9XC1Ba}7j~h(W1UdShxf!Sx zZp8sLc*?PKPkQz%`4DSf0IN31{TlH9WI7pG2#OFZDx~i)1%R}}phiOQt92bt&cJw* z9Tz=D7_ck+8F2Ql^;`MfW=LJczXSm!VdPwgt`Xok?jNXa8x4GohO21!8+2hCo%jX~ zY@?BFbY>fkeT^od-$tijhLS72wNSDeN5TxEJ7pyIA<%1xc(H zwq&a@=*kgTCm}g@DyVfv)QA}~&9r4EGp#z)W|C&wUC5u z_nrG%fJ@P)wW97l_dLFH&Ue1^o$q|#cMks2@Aq){Ek)jrPtS1Nf2I%pSFQ!_{-%}V zE^`7WSQ6Zr`nHT&*td1e%HFmy8++Tw?Ck9rbKq@FIFqh1SJFM^woo}+qAckd^CZ1v zUiNKI_>%rHKMOk&<;jY%3Kn)I0?FW5kcC}|%4F486$`r))ybN%nq=)*ZL)5xj>VNF zLdp8E`eegc1N-(Q8k0?9P08l5X7=q(v?N={T3Oha;FIC8Fbn$=ZOQhrb`~yAbR;{+ zI$5|P(Ut5T>rVEJ^|0?iqBq$$*2luZM1OK%Y#=!}Hpsp!6OrW5*boa>B_2y|8Qa3b z)rqaiZDZS5xF)eZxnpcca_892pl<#lsU$q3uok*i#1Vh|rGmhZ)=s z15&3E>M}yzsEZ)@gdV^?CiIF=3w?;|XYofS+`<4LKQm|P9r_t{Vzk$)_)orY;>7cZ zPo9iEb@=!R#rc(3Vpf!qU_Tz0(~A4KnRGlg9ZU3D6wizlpH4@o#}i^~dUgg)aU6dB`RATjTqj>Rcn~c`j87|nSdvnb z5y3_U$*k{s~&%Jo^eKadA%IWBNDV~mNF?{1IrMt@ba0|ED)}ueIg|lA(oNJxH{$3 zr(65DyMVxDPUMI;f-hRY6RqHfm4X9Q?hu`VQ*;R~(Jhv-xnmPOm|N~Q?H_0W#=JtA zSSENxpWqe!f=#evhWJpnT=1h*g;pvc1}QXQ7s`=VDO89-A%Jp}-zfwUS2btvty0Q0 zdeTTUb`0#p!{evL^D`hP42aAVn)i5E+8}>o?!+;^2Xlc>rO${G4{VDUFa!Bn8Mx#@ zKl+^EX%%tSgqF#|Gs9lX=wNSCi^PK=Z$-k`4 zlUMkCMQt!~w4Z-jL--&=>7bE65>a8^4{1=^08H)BqX2q&P(-`VjmyRuV08BL53X4) zkk~M6GqLoUFDkQ78!a07AtSTml)y=(>Ctg*`C`;glZFG+AznMQ?meX-ivi zY}%oJO*!?D`PQe>2U=a0M}w?SX%jH_B|&E5RuNbPza+@MjZo?9OMgx-wmn=~KJa^x~&5oVDoXn0!(K?gPq|l*Ko|Dy~Qimy*?mUBYf* z59GAH#Ztx`*Sl{tQ#Lp#NOObOqAMO58+NE?q*+mMA(C`2M>206N=!vGFb5=*p2^yW&JkNI_v2p!q;M#fjK#BCXiZ zh>4kubugWA4-TptCdH#^ny}ARYAr%qR;(1=v zyig}4B5=i(gjVTXOp>N|`V%x7 zO_>Hk79k&mEJ|o9o_uP8hlXZ=fgt*2)g$uNSM@Hx`f7xy(PK&+g2Iv*)x7#DuWCg2 z_yntfAWzej<1r^dU^+n+kuqXqsEE{5Ju@j;j-Li4p$UT%k|_2TYjGl&qAw8B(I$!F z(gK-py`W7SkfEWi5lrQnM%tJunD;#9MLa<&Pkq{ehS7~Pz*>UPi{1+2j0m0C^f=U8 z+K0@e7t~#?(m@%z+_X43$5>P(Q)#rzNKpb>-l(28Q=Xbm%nimT2B$?)fF9K$LVG90 zj)HKY2NtDdd>S>LNu4*FfC^aesA;NFllUTQEqLC`8r#{!cWR+mB77Tz+Qtu>P^cqB zTUv_*Q2S&|62Oblu?eD3HU!kc@mUEZk~aA@s?it>FN5f0s0%Tg$XTQ$V^E6FV_?5W z?nQ$(cAHwZu{D%VjbJDSFHJG#sn!PV-mg%X#sL}QQ(WU`QgKkf$^nCegWxRV;-DmI zgs4=o2x!!`h|J#S^&kiw>P}t1ib)D0W>gIoBM=!&NMcN&!5K`a1_h7;(dRLugUt(* z5>R7w6|^X1ZX9Eamo`cC1x&9E{1XT#-8c<8dQWVYmX&c@6jAS4l?lspa#~F4lg(IS zG%z&hFtjl+t_e2l)5b7@zn+g7npcc3TT+X2>M&G=zZ9l8JQpZ>OepqR6ddB2wWm8A8o`EAf&!Ecl25I48 zYkM`b{;080JvQ^0RwE^0NhsbS*pZ=!tpRdc0Qw?o0fWY&zi06SSpA^Y2Nz-jpQutM^=oht z-4WCJ3PbD0xfHsej9(y>5H=DpTv1rHC#gjl{?v#_Z?octQIX7Hvf_yeEQHlbD#Oqy zzG8$aUW_`iZ7gB3;(~<mlK6Mx5EPWmxeez34Nb8spRwtTBzmB_vR6w1kDOf~Yn=Nj5;@ zBC=Ahn#lA9DrHnXL~3bH@e=#hKl~)LKswaY%C%-k&&1?2B20ES_PUFLHWfwVZO7=Vq!w^s3mBeWSTZS z|M}UWGpVFF1nC%V4ludSW`+)l@>xhwLnG3;*!1AYiDQEY6Y(K1>T^SowT4t9@wUj8 ztwSVC4(i->2&6IuUd)8M#1IIL%*OJNHi;rLK!`~ja;D*!Dh3}^Ge(Nios-O@d)t4}pLg>)H~*uCe0WzbylW-AXVty;zNFz?cz7ked)2+?zNBrr@V1rkj#c;0 zO-b*yyxX!8-m>c6dV6zC+jHUVE8(51?%@q(3ck8RRcj&GP^hk7w_Af-*8N;r_#Wpe z^Q_l$Wqz}{1z(`xt1SeZk+V=8TDRMRo$D1Wv#-o^uYoJ8%DV@0?tyEke*DV&ub@jC z+EDOS7lJ(MQVV(?SW6wt#;*li*5QhPrZ~_P-=?MjR+HL}LhuAkOO(%veC3<+p}j47 zd!4~nt#jqb$#2N{qlO2dj`bQ%YG5t5278O}6WRcx;NuIy_Cj?>p{8@`{Brfsy4@K( zYI$Il1s~Af#*jZ+)YHv90MZ#;6>-}&a9;EP7%v(gqNXQv;U`zZhgRK(H;geQ?azhx zuY{jib&uSav@;jpxf0&B>fU`{((YV%_eyy0s(askN&9l)eJkPptL_8$B^}L$kFJD| zt-7DyKmpW@y}9t-mGI-M?)~?b+LH_KSqbl3bw9qLR1txO3c)=^V;$Jg|AG%g1WYv) zf+Jsm&Tf{e8w6Yk9xMX38SUYse7hc)kGixY7v8ZF9$t0ty01%LFonMWvnC?$1Na5( z!W@q~HLdxYExDR4YrfjNuPx_m0};Rd%*AK!I&8I`1<$&N5a+$<&AYpE?(S=rYv4bO zlN85o|MBDRW1Mzx8VpP*&^WjS7=S_EKj$!`?t;xhr=YTGS+T`aTS}RNr8>lGYA^z*|K9ML>NdfmoAbV9LGBXf;R_bY2W6OLs)T{p$00SsQcDV z6bIN4z181CU=Ql~%=Z_=mbO0xB5iOs{k|BYTs&)BdLO=JNt4Ep{RH>*GCh9Yk#&^9 z5^&8;ZPQDb@2o>F$!0?dHTMOJY_)Kc+`J1AhRu?C2&!uhoAd6pq1-NtEkn7zdT#Tb zwPfAdGW30)8K;M?dp^)q@AID0?M@%i^BT0Sx58^;2GF0-^Orqh|aRNsF6)29Cxnn|>-iuBSf$dZkcxy;`Tv9o&3%TGUHSP3R%>{l#@>tA!e&_IjO8!^~qD9^N{Z z*t{>X{z_i~ZsKMwdPwgRoOsUaaYE=#t~4eO-RIaeUz4qo+R{m*ESyNDQu>$q78(Jw z=Kk_#yVEmz?vwDQM*Xt>ZN7yj9rN?G+1jbJnWBf-YG0S0)4#KI*PHb+z)j^;Mo%%{ zQ}bq659xS0#JwFFw@z~7)>kSp%R}jJ>N&C@9j;`}hAvs(3fj5(dgOS+$Wfmy7i^PU z)^)u_cZT^IsC>R*zA@VOR@`UiU0d<%R@OooBU#uAv+IHukzNMgaM@0if^ zP_|OfG2et$yBSowpr@H{CX=ZW+jq@aJv85vZINiUe@~Aw-&u2v2=;HADSBwW74aoz zyG)W*3AshG3bpgC=}UU~Y*W^SoTa1|l0iy9$Wo1Z@uD|k|54GW7KH1P#%JdF^zZ8F z4}d^5mTF1qc9fQ?+I8xf52r61^@WXbYRmFdSM_-Fo&JFyp8BC4GT%anUjBNg9%3th zdzQzVbqI9Wk?olJ$7TsVG~bE&*EaR8{%yXq2Bi6}Y}XsXZ08R+A&~8w`X^={J@f3uVY9?CW&UZ0G5B;KY(a=pvsA*Fdwwq5W4 ze0R26@)dC_e4C{)k|n58>d!i4>(d*$z%}Vuh%k zuX~Adymg*a^Nge1xOF~soL=MQ@;TeYEgGaWfTRMl^HrUE7)%~&-^y3|uR%ivS>wQ81(`vvBD-zmdB zwHx(IBy>x=@KF4!`d1X_n1q;l{1iLm0@D+`9GFc<=1@(8rdPHNgTP6cVlSYq;cJifuXo%R_tM0dZ6$1|80 zIVMf}Y>D;84hR;o8AM?PF_eYFu7qOhnw7vXq z+~2*Xoe0kVG1~3@V)hIb*9oUF&qGCpyv@JK#9e6NpYDlgG zk~u>1`xf9=dL5-Dk{llutv3j*)c~NPH9T_dH4v^Hevbt-n|eq$#C zj^ZTqQv8B6Lba>BVP+2emCVREa%Lx6l0>qUL}HrseLNJm&LLTwF+8@j;v8N9&D#qH z!(viAHl5DYpPU_sy?{LQaa% z;~+hVJFCq4B!yb(v4xKw>q8!(T#--;X z>Qd^8V9L>SO829XNRgqq5Fr5ViaiCV9dHep)v*Z7CTEm(<_n-5hSXTB9EGtjY94!2 zoH7jXq9C;cm~@dI*q?Fgsm7v;6`$_=fO{csEtngU72`N&5^aR< z6Fi_87R#y5N*I~pgk>D_C6XtVj6^%J-hSy-3X?b^k-9@^*N{nE8s=P(vFf>0d?=UA zRi#1`dYJ4&G+ezYg8A>Usl05O zGGu$FqjSvN!!m(`$?Qm~*6Ju*(G(Zf7n*d^TT~@&-W5MpL3GX*62%f#%2oMlA{I~J z)Gd4$%t?Tmsh<>98nr{OrG|--jZ&sn4%ah(G0niUfezI=)Hb2bms(S96u~ru z+idYSd8GV%mI*bVXQ!LR({Pz0|5G-+az9dWUiFv#F&Rg(L6XVn$D4JtJL1Z~!{uSj z`q#PJ-pag}zvbnZUd(q6=Q@X%I}ff^wk)?kwNiO(*>`L`z*W{?ZoSlcEBH8Nc|6zo z__A+5#2^1aAyAhOgmZ!L(y8S@?`Jkd-KMCvT%c`9SPt}k=0McClM9COf%aUWeJQ;h z=qJnLz^CP$|FJ@KW4?O$R`u{5U&pGi>vrS7vO84pR=$1Uy9WxbUHR7GT6efW;M{O$6K<%^jg9aw4KzUtnw#&0Y5s`9>Y&KE9(TJxd)T&TZL z*OIU6&DHf5YMb-5-MQNCLPI#;FqCT;y61I!qHV<$6C1ky}Ebn-fMlg^+sKO%fZ~1gRmV_Qp-K`s_L@qlIwE$rSdE1^Q~KQ zty@+DTi2>h^zyTpo?YtBw{6e0ZC|b4f!uYl37))bv({CvbJk$xJrCD9a3i$Z zvS;DBLi^Ty`*5xuedS??%==n$zLqQBT=fmzuIKahL%I5)TlG6`Y+We7U0Iv2?8{a5 zT^nAh+_vDl6QWRP+k(FktjP!abHRQfmHst!7ux&s?IXE%GWAvt+~pjVo&_ho1nQgf zp}t(GZ?%8lO8@?q(18X2o$4^dR(Gzhd%3EcEX2*>doFv8XQ6D}CtAzu3srUbs-9d` z&$a4n=WjYcbgfi9wQy+7hatJKebu+?PD2M#$Ie{m&XtDYg=b(u4K;nnS^QfUZH2)t zi?)vfed{)Sf*L|i`MMpsx*dhq9t>8YrJtU4&4rfEe9N|6%eF#8%R7;)5jakScHZUO zq4I^N)+<>lHk$QlYcmyT>Nbmnd-7qj7ZEH?!yJXJI@d2_~Al$OQEqX-#D0S z99*yALVb5RF9X@Y`GYFSEOo8=dT+OM^D`GJ$Ufs-rsrxu-ss)l@3f3B+kntZDYM9{Ky+CH3Itsh}uIk*L#t7BP(rNZ;afG{kiy2 z=+rN4lmplb)V=-9?|zde5uXnn%mogv1`e-v4SdS>AI$^#=0myWL-!omY24*(-IdFM z_D|hhb@y5|UkLRTLXGdZueu?cFYkM9l|Qi(I)SV;wfEdysCBV?-R|-~UTEmeH|)+e z?7rE#((uHh3nT(;^4oL#_M7%)e&3>h&A0u-$3OD@2KtY@^*eI)JM#7Wa`pRG>i7RI zhrPM{c6H5K)wUZWt5rKcb8x}RbsHiVo?Ykgx(9Gwg+Mb6S6ySFg)g)Y()=sW`I;9- z7QXRmfD5#&)poC2Ej9aoy6?$9IZ{w@0^#>YWHmgp5*op@dA#ozfx(Aj69hhW=KtmzWQmARl z*L3A-x(YSDY`*m6>iP6-q^X)x@Tc@)wj1$UAu6& z(9r%F=k~XQ^y-=~zjo=hMf{#hMusB+%>s+qeQfTX1s$Kf} zwU&JEfn4u_<(?;&TSugGac zZ@%+TuJh1`FRpYxyN(g=zsK1y4j!&0{LWXeesxLwL3CmCCl$?W0k|9u6{_1nWk}~a zaAn3(e^S-9>}y**z}Q=R&ezV?4z^G{cjLu>8U3T^J)6~Ejs{VQ_MEqU>D(>v;F_;> z)fZl?s9h-k#X&pGh)>zf`TKi4Ts7k_T?M}L`+j0AUH|8^0O;-S?j5pnp)hz)u>L1- z!LZ@|_xE_rqtD>6RS(AY&Tn4*&1+xJH9xj6dZ%`<5U8P{rFE+_7wEj}ve%U_90hy! zSG|4w;_)kW*Y+PQzcwgRT`*_Gk z;jI=5Z)5R$%f9Avtl6!IUvpY0?4mqtp0ZbX+gjC#^_523Cp8v)eA4K^Q&oih2Q-ZB zt;R{~p#Ny+VZ;A-e~8%c_%3s4+QhM+sX<_>XnUISv7cbcTBnMkXz|yrx(bjP!%LX9 zU<`MZG7Q4R?I@+1hhdupQ}!!W;}mTqHvO_rU4;y@hkc4R2%COp4k&7Wb@+xW0Nhku zS?5`p<{wy-k@t~mazC^uMh+;c?T5HU%PVJ~q$o@K^)8oEY-bIp1yLGQJzGTy{ zsIJ;{SWldyE%c_JnG>e*nj(tn*pv~U#d(XMcHN)zAuTRNJ!R%-7WaP9^44>9Q1n}8 zNvYQB8dacNVtT96n$aiFnBTP+$~x4<6v+lZGuwL6s*gvJZj`C*q($U{3JZrVW4Jhn z&TQal#G8mzEYKVY*rdwD26_H~u^Ztl zTi)4sb>B5R$)pX(R0ZF+8(S4Rc6r7J5|ZSk!Zg8fcbLHVzojEk!u& zhci7zRg;wk=Pa<>7b3mY5)TYWWPFp}#RGeF?7p#WMgac$2uO33wnUGAN{@eshvG_L zn+!BCWs+jUVOQz*Sv+map{s!PL8dlKKcZNtdAYGC*@v6V2`q%Rv6AZ6URR6IuAh>n|Be>P z#GQ-x>rbe}^p}Xvgda*w4x*et23^D0fbC;h)goL_TOhE88Wwzz-z%H0Jh>EAWxdtl zo&{&2w(0WprRfE)8K|niy!X=H1@|4V|Lx(6!*B1uxc^H3s<*4)3*~*SIbZ9Nchxtr zwkh@6-kbfm`VT)iQ_rfm-Ar}U=BcjzF4tW4v}NJwTBzY2&sEP7wx#`dxhDV9mPI>u zM_10=s_I&6Y<_3>>M$dJ_l=H~#^J?7Yjq7Pm=)O%4}SRk^6*ou4aZjNjuk@uT3g3^ z-S2k4H}LMjwam@!D{W6KR;*RkTpqqOe0l$+{YyiuRa<}3*tQmGd8hnpId%`t`)@b( zW7AsS0J*e2yjE9#`TV8xm%nl88%wFxx}8QwTXQ$C*gOD{8(GVXvd&+cUy82Q?Vzmw ztNx|bN1>f}&>h;K4XuW@-U-xR_FnS-@X2?MUOoEG@vFzL)u9tj!#7+1I&kc>-PG4l zZG;6$z!*y(<1vm=G=6r3h_Bo|jmKs9)RYp#PLc)KCGX`eXJ}{=Tyyqx1QrJz5SfXw!yqiHJcRS1u=LcSnbN29wFZLPVy0^UN@{qDGVV(%c{m!t30+(^VE)tLnS9XQgWAvTx_#tyP3R!+D6% zny)hNYs&eWKpMeO%ROkP%4ugDTK6LLbD1Q%8W$6mC zY;e!^B7zOzGUg?@XEWy^8++Oz4clcKToWvFlhw{vgpfJ2A_@SvS9QJ=%8ZwJSH4fvV&&im&5f~V9y2#}@Sa4z)1 z=~C-4oQb^C7QqLHN^LLkOSNkl?K)1>{M?h~g?=?iDs6DeHrI9U>QMDb{?!CI7gPi=8gBT6*YIFOu%1qp}9 z>FnS5cxo26M$jQ$cIr_-sLKwl(*a#WZT+P*nw{R1zJn3Tcz{iIvJ$r3s}xaRWZfmy znl)!8UnBeeJpYJ;x8c$KlkF zgpm*j=Hd2XL(z;AkM2aG*Qwfe-$3IOZ&5XhTZgK6i-3}A5BIsn)9YXYjP$1{r!qe` z4xBP6ipes)Haj#sKCZfB zDSNAG+p=%lauxLTMLF)V9OYbd$7h_YtZU(Tp*FlUkgFZKVae5QT{sE_+fo9WVK8=o z*P;i~#^UtS$kOD}OV_4uHhehpC(So2pi+Ix5+TKE1p2;U2y48i+j{Y%KteEu$|z82kA`j_N&=$(#O{%d9EQdgnAv(VID;M)t$ zodv$X0DW!ZR@;+TYyRAgLuXa>cR5#8<+_V%uia34JpisdQ0G0IsjGOq;$p=WI}xqF$wfOV0qJfpqUiaW~2HyTwuQSxS*g)J|t_@dFT;{q6>W_-D#QQY={fMb>n zfYLb1N+feiBrQk|JaBF{jcZph(WU=NaUB$AKb=Y?B$7fUS_&j$x>7AYX#JIlD&FT* z35MhpsZW29mxO!+k2kqbtsaMaJ>>8|_WI$w<=?bAJnK(7IcMd%b~? z<9DeurdP!8(dYN+ zL6{#WoasM9XLbrP#Tql{#jx_@=z=Y4hc1lJhac008Dg6nM^9+HXgD_gCaovAUfZbj zGsJ^iJg8OJm9kCK|3o%vo$@*#m{M)ED0Sl|>9OrT6|@QI)athsI~#Qc8fC)tbQ@ z+du4Ct$Ai8cpQ573MULfKIb}Tb2wGX--#ldoF$pJ%m#WVDrE!uBh*ArdT)fXoLoyD zC+e@1G*`U!n6qZ#>XWrd#RsZv`at7Am9cgCK!b>!hIA$vvMqAzRdOZkEILv(hhtZ7 zsII^`MwPWn4{L9crgqMn_UILra#4S1-;1=efMsYP8DA*Vb%_scQPEKxK+zk-mC|Sn zhKA9?%{hC0u`vwQA>FfuWKBqL5~+f4?@NsCk1(&EQeEM+t9NknA5xO$cBkDZeQbgX zm={`+NP2{>eHwt6%j2v*1Q@z(Ufo5im*5DgX;Hnexm4*>(ku$&&I&+cTTl3pkr$sX zZp9ODV^uGgVD}bzh;bQ>qK{HgM^Wbh6IJz#!b~Yz6@-i%hKg>k9$>%?nGZq~U4M-m z($q_F)O(Ylcw?7mX*Y3aI#3t821}PjDLY(7aoaq4Me-m#)sAGo@-Xja)l(17&P>RM zJ6&=HPIcyOGMb#re3@|fhI#>uoEg*M!sUoupD?6`-?UaF!oNU+yy02~cB>AF&*$QF z2^0zNKo`cqyy!iWQOjviN_Fd0X4`$e7oZjZaSdvBcG2Zzy6d(!Zkg@(6*?`B$3R#r zHEwJu++gVXD1mXo%wrEMy0H|y0fowCo;{>qJV!euw5yojRb1+I<9@p&D0d?qV1%$_ zfa@(&Wp#%jo}QgleHgniA64fwI~7&}het=AJbpOJ?o&H??9^e#m*G?kKS-?O4`Q@3 z2^K`qn&kZsfu+ayiKE{_0D^TJS5~|14!{5G8r)la7k$e$>{5Y>>c4SS|HNAhrySB` zY`bf-Rh5Ie`^%vO^zp0S@LFX%rR?000x6ThV2AE2s>rZfzwG6g?L3~ag}bXRO&JwE zz3P6ZP*DvvBfL+TH;|F^%&Pl1CAm3w%hK)}^B=hm8)-*Z-A^Iyj@|Q}XWn=QZ76Gm zn#JLS=unQo-)bH~Gs3#R`cnZ1K4Qgj^=|3C@R?RGJv4Vd=bvJn(>A zMXHt3IZO#9%jrv${)RdxSh|#8EN7@4*LGj9Ua*o3EjTg|yvJ?h)_wTGi40myH~orq zc+}fXKc*;pL2%C71=qa8To(1EQtr%J<#x2nyQv^PVR&;x%p}o&(@!rwS=8ws;AM)2ann!79!3`_kW2j;=?HT{h0TO#?v}jfp2yZTL~34|>R)I$mgebF z!PGe1DN$lB9mf?;!YnT7WOtEaB@xG&qbS`jM!FZB9bcEDSoiRsTO!i`K#L_0#Dh%RLEOK@6jbUTt)Pl<2O%*_{g%N@%|ZH;DXRX5e3F^l zvz)OLhtF6ep17SL{l!zqMo;ZgFHqBZAD=vvR`o2bm$3GL$*Q*^g1u_jsu`*>rjXID zuH=uWfQA!vHb*;tf-4HyY7pUHO3ktx+Q`KkNTIb)<>wGz=t@8EdNr@QuHgzVT`3JE z7_J?fiACb6A84om_R-vyuyK-#)fjowL_``xuzD z+y9-{-gxbI#LJ0GiCeC=LgNAQ!)%00Wav&s_i9D&9}Q{hn%lU#hi*3M$XEB}s{2-| z2i9HoVCBzkPH1?rajYb*&vJe5s;^IP&kL*W#-HOl6@S5Ee;#U1}}f8N`g^R}*d!%K&9-kxQ9 z4_jw?9Y;n-kBs)(NAc=CF7*@M|CrGCZ|Jc^kDt?n{!|G$ai@WB3<#|`OkINGUbudB zdXlM4m`ViW17d={5PxAuir_rL8P!d`ibde-If--vN@FP~+I@Ob3+31}CMp>4+;R0_439kQl#6;GqMeFtq9C=1 z?t`yt^-4C*l=vA(lSrK1+(LG|O7)Njlk2A1VTOXWo~964?oD`icuJMTFUmRb6iYr5}o z6j&dvnw)mr)4L zf;EdLFFw0YC86nddKTK>chqX9wcCgon+wamBl+kVQVC*Qg zwig;&KlSdh1PWD+R}Nj;zivbLcCh|R`=#b}2g0ZvUsad<>n{3&D{|c1?erGrCiw6jh0Pp5aNW3IVmPewj=$33*k}cVex#NW)c9VpJgYE`(V91Gf z%A27QRhe=oBRX-`bk)|HDr($Kq6^EQtA-&8P?Q-9g`KF@JC zIgu0j7&oRp`7s`4Q_K`MkC}O@Gsi4(>zFle8?(jjWA?aX%n^5vIpeM|SKK}3W_>I% zPrPcZioIK7)$y9K8uo6B)yBPJUiNN})x~{dKKAa2`Q!Ct_3YglYlsKN0_@!t3&tDA z8ri!$))a3ZYmT>!wXm`$)*5dcYh&+KvG%wyCb0MFSVz2btdqUh#Jb|$W8Lwdu^yh2 zta1b9UmNR<_l@=OoQXTiiQacOu}*6K#H_8sSij_y`WsOg3!$$swk5uGY%BGZ`18MO zELia=4Ss?(qck?e@cDtSUh)?34T}w8KnzM|u~BkKcKjP5?DR9trgd|5& zNm;d=h$<=7acVjhO(r5S)p168dqzr(ORDwk%ydjrE#na-b&FTM!%5gm`jqG>6d zh{Pp~;2MvMNd~H*vVMbjHD=NK*_D7#8~uPc>2Pm0?dw7HF|%ZmtfFZYEs_myW_r6~ z30YNNnDD+HO--G^s7mU1Vj`LT%cIeYl8~B`1hM2Jh2**O_#h!7jAJQdl8~Gbq{}He zB1}Z3n5Yc7T!Nm?PDzR+T#CkG!Z}HpPENCL5(RNajwU9Bx89=V!l#KCQ|u4D_12JZ zb}Fg}_%BA~)D;2CT0j<$T#ytt8yOR%QE6u5Nl_BwGviajcub0bZiWf~YBjB(k_unc zmPxJA%M;OgXFQ$g4l5uHRj)>93G^k)EJ$y(~E~Jvv!~5lnk;LHs z)5ix7#-hU)K_$c3@!{z!si|b*nW1glhZXGf;Iu|$%J6h_dN>?Sq$C-XKRm9HtO6J% zH8g!iZozOY3*bemNA_>I&rBAlC-31J2i6>0bB!(Qjux57fb|3MSf?YhB5fiUJDMqN z{7+;>av@?7O=A|(JZ1$S+rYgx5nL}iB!_5`oZx6D>RhbOCAlRJ@jhCr(Bei*wdfJ6 zSgS>(x@y$bl-1RsuC}bM7IofYom3}!b*WN^7GJSNv;wOSb$-#0@%0(7S=1XP(ZYH) zpjZ7BYbdC?NuKC@p4Lc@?QlWTg~8|UlZOXx*5FZ zYryX6yoZeIyQE5>gV+iweBYy1weQ|uDEzb14K#_ke(#lGA9|H54%&L~Sy z?n=onGP7|rKuTYK?6GHa3zfiY)lb%bV$$m7_{#0)y-&i3p;_L5V>?v=?^EC^@_P~2 z6)v>pWZE>COuGgL4MnQD6c{X0I3>?WN74;Uz!_}?`4%#(wg@vzRJ$lmL}p?s)iNc; zrh#pSu+2=TlBAb)1V*ud0R1HDX9&l1fDL361xPnC6O+>yRQvc;GK!tk7O;A75SXxLZ_h+!NmM;3g^g1Bc}6UTvehVnv?&cPO4AZ7 z?8JB!_8!c<;?5cUhp;Mazu4exzv@7Vmq}qu1&So2n)qNM5>q6#R@3KF*r3pK&tVOq zpx+H*!BQpTIspx(fmsJFU{3cKWMLqy2zoYTDVwH7U?f69PSpYTB#hNmR98e~Z!jq3 zD%x!)BZcWmYD)F6SN+>mFIm9^gs$O9@?}&vxg(eLf{j^tvg#u%M22x)(i47#MUi3? zs!M~Qp%t2oAjo|*s=GK1MPp~(R2nL2*nysk7hqSpoWt{O)wQauL&!LUoToPD3Fdt5 zIe%l$8_K&mXUAjC=5*z&IcL?swBMF5$5*e7o44@Z;d~Vv*@=<;Wh47@-heT~eNV;s z@0+q6J2M?S*E)8sJDw~1NMCWJ?K%cWg^?O^zNVbFE$45|`M1%uUgq;PY+f$(4wlWU zg^+sj|K+@sb+T4iHX-K|a^9|-_qmczo-$161T@qs=MR4A7e1Hicy6s@_qt=x{rdK7 z{kBZ~wjXWDZatB-SfI$MRg&~nr8Xi1B*iv`c|pe#Z236UaKGnZe8Ohck19!VO`_ zZ7trQ)__&DxB+#XP#|x~v`}s1Y;rPre5#pn)Zq=Shwxy7%E##K1Z6KFQ^=BK4!OqV z_2F|f(U=(4g=v`76SQUrNo0fHD|VqRQ|PO%a*sV+Q(v}mFw;1=JbCxhdgIag>c=*& zc{tbDmg@|Cy!E54kFDlr*L=-m7gyVwt?A0tbmf{uxfZIgb>%s;)1}diB_dBMn`new zQbr^H1e$=)!&mZo=n`n85)}jK$p$h&;is*wSz%&@|#iucg z^W-s?B|uQ5qb#A8Vh&{qwQXfpD56%VP;0(zHLU(a+`E=>(b{jp4Pq_|OIO(pkG;1wd+;e!ZNI^cphROg@+zgv&19T-iqmj4% zHfZ!2{PI3Lmm*7sr88I!9=|!uB`#z?ncjIy3tkE())(2HMdKV12g6>22s#%{NaB$E zERd!55jz`JUBSvLcK>bW-KHo6N$qFw+aP=EMfj@}iFmUH`^Fa~c#-bE&)?*E?z-2) zUEzLUzQo_+Ps(mULduzjMpQmgYIS_!9GyhG_wuy-e7dt#2FWvtp;6{ED9;ZS`rHN{ zh3NV3xqrIKtp<+X@va9$%N^O^KqheXbA_h*o%#Ten5K&Xhsg$4on-NAuhoXlrf6kv zxnZclOu7)A)`Dh1)nWKfs>5)CWMV>@EFsNYYZ#xB#xI0P6+o<}rgXClkwGaXQ+!T! z=mwmk+GeK7t&;szZDA%}3mg#{p+4O~371A&71hcua!YN(}1 zYN>^-dP-xfTFIEc+MxLi1rBKGFuxUwIxvl*8;)k| zRl25Z^FBl;e$?th;&D-MnPa3L~q+$o;yumG;-x>Rw;*y#BDX@tKV9%$>`t z!anrK)xNx8Hu)oaQ$;TSN7)tiSGgswZ@%AqB_dHwjW>n5Q z@*E!dHqPVAy4zRX?YTg6HUL^2SpMBRm(~LN=8qLVkTvyZ0{zRuJG<5bd#)YJRr#}3 zt*ce7(uKZ>&pMTY+7j&3rhJIB4BjxUnpN#%^bZytMwQa{& zYmPs%f}$Ro0g~q|PS@v;IJ|Dq(*E&&+x|AoCd26e&z;0Z{Fa@Rr}4eALaVxY8=|Os zavKaWmLY(zvkg6eVZM9lCntV z8<{0G2iv%b%>Y*8oNd;2p5|GWW~~=_g}+`mYkSXhy`Hg@&A_g+7Vyr2xpW)E1{=h5 zQtkmB=u$7^w9?3o>_Llap(8TYLJCB!E}X$?2e9@sPLopvVFnV_fh>GMx}v~?!HFk* z4KW{*#($HjNVk;p-zNQr9?BdtjR!k^W3~8+?Q+4EY;Y(O99j#GtOlRGbKsF34S5^q z^*;u$wJnZ+IQ9P2Jx^cWjQX7ZoOgW2q4>CttMxA(`y2n6#WQ!z*^vX8kpn;LUmbbn zy)&!+Gix;4bIoLI&Q2mKuF?_DHONOpX8(arJMbxnv_D}6h@wt~TJtj8RG%~6R}lpe+k zCS7yEftfSSnks3jO6;MaFLX@{7>u7YVP0gfmZi$`LV!YNc*gt%hpz}+G>qZKSg!I{ zI52w!?TH<*R625~|pmdd~^UBK1YY}g=Uf#i3_R&IM~okKg;AqhMby+sNOuf>MX)Ki@2-H&{oS*Jc+9k z#%aG9NBjtzv*-rX^a`yJ6EcEu^{N&OahKQ(={=$F5ArE>@TI^=5p%S>N!gZy09pje`%HIu;J* zdUq^X)@!?ReOu_+4Lfwf{rRI1MrLuNAG9CXX~7vuwH^`DV|wywe5p)gTQ$cc)1fCs z{V{64K^X~sc>$R&<=?^%{EjB&-$re^_n)`ue@_@l-ha*u|O&zYeoKTR)tsAHHM18(6E~KYt`|X{u_;HEhkB@%)vyaiwWE;~n|66{W||ag8mD zFD?hyg4-X#$7o-$XMGkB+Ne~AD7v-?}k zpH|r@_d8MXX{&XAul>_bJKi_ReOe`EG~9)pC=Gee@*@8Zce`MB<4Dm|N%Dzi7L4ki z<>k&23%tZ)|0d++9Mm@?6pdDvW)bQvmEcbq#ll9BNQ%B0X8OQXNm7c|3vdYK!Bjy) zB4A^!cz|lHB+bybwrqkZ7LTH@?<>J<|0}noqd6*w1(W>5gLpw9P|eKw!Z8|)#LtP5=hHh% zxuCLlUKBe96z&{y3YlS7xy7^D){#u>$W@L-RUzfgFt6CrA&Uq71C5$?_b7Y!_9#Ms zj}l7Tw1T_~Eg_d`)9$LUsD@gn9S723B!#5uAX06sJgq`Id06L?2(wT`QFX|XOH9FN z8pAQEgLF1aWC?%}85nl3SA;6wlinEvh`ZYFeS6p)*3( zHqPIa^Z0*WJAx3jpFDR5bK2W7?zW}Ss(b4X9rv3Dm#6O9*P4Il+KKr?3%!UaWIe+f z&+r|~or!y%z06%_GUwQ8)j%#NJmPFs$9R$(O*i-5*tZl}_4VEN3%Ov=QtIQmkLK=( z|2g)<*iR4rx0gPB=^xFe`Ub=z>N}Q#%k0eLZud_Hemro`fAq5|LW6^{>Uv$K9a*i~ za^DmDpq+&Z8u#4uj6&*HZ)LkHFX4;ikC0UsGk!i{cpm7iC$U7N zATC+B0aG+!3_(*V>ZjxGhX+&%H%ygE!ihz-El)vTp zrWyAnRGW6DD+g&Zmh;JIg0Y&xKuf4*M4`IjQ-$ePYGM-MLj^Zt;b*}nV{xNWHu_V5 zq__O@KcS1}n*b2l3CvS7pZddZEWG^(d-cfMBER_Tx~KD3tvyTPpZ@ENqiNo~@GAJO zv|}LaY0G%p7T;d#`ndn2ethWN!|PiPtaTn(_Z)oaYkS1;&bIl3p#4SPJx}XrW)wA% zW?~M-$xwsbPG2fe)a?Y!RYUw6-oH!~rJYRPGFfn{OQoA=#km^yqy!>oP4)s?1(QlF#7=OZi?3)V*_oO2GO}HQ|`r|75bQFu{kcbXdKiO_z!`j-hhWlpimA-ltmP$q(NS~5{ z4Qo>o59UB;)@7*#$|AQv6_UhdS<<6wt`ZDiwkJ==P2!;}eMQ{OPn|bO?XpxdUu&iH zp0yWyT+dtRWD=nq+*NR=!!DBJ2a^dHT`6`$OOJvJaM&ZbGKK323T~p~iUKY$Lk!~X z83Q?I+>9$f{3)m@)=jma*6yLJ_Sf{=^R^Qd3cxMFv$#6HNxc%oGWEIxF9r1q0)a!)(E%7v=rH!(NWhQD^e1vS+iNnF7t%4xc- zCVxOv|1-+EDWfn+F|eUF8s~Nho3Lw<;lhCb4n0+;arh^P9P$qd_9$f^QClqz*Am#p z!XHYgRk$lzxW=Y1YY>tYh*h(kyreh)Mbtq_GnfB_kWsdS*5?Q^1SzVyn&4vNN>$g@ zBM$>@*+5?=(6?go|J)wPIjZTt*23kbhLwi?bw}t|{s0zm`Otb`+nRsd)t7#5_v?LD z8n)pu?xDT)$~@>D4blEgZb(2H7M$v{| z6%++pt*n)=k!Tq|^m4FXrt^i%EX9vPOarS+ z2`<2Yv~a0_R>EcO3ZfRLn|g1EPv^;yNxp*a8k>^GApbdK#EbGzC~KvRVv_P-A_M1_ zvGxblRP0W2p$ta;FI2Y+nQ9eh;?oN3^n#DecvcH`TIjfvjiS(=GOpFxmQK)R$|9J% z@>h7FqjbhP!AD%RwQ1h+&>y_{(v6qy2bvald^r04=vtuvGrC{}rXugQNY?FLAI`l$ zx7xn_jtQP^Q^wPh6S_aH{-_$I=8UJcaEgAvr+?X>4UJ|(qia2T=MSxTJ2IZmT;Vtq8(FtSr6lnsfNa5QSIVJ>l5`ua3G)x*>ygd z2wZJ@vJWn5q-GR!!_9GaX+jNd?u6SOl6H58T@_Kw#-W(><)Ok|KkZ^)=VlaIA6={K zm-LwHqBd;q2qhmOr7u%FO1oClUDgBhj44B97Yel-gk>{JNU2Ln`2zZ~zf5EfliIWy z9a~q-K90*P+U=IIuh%-nqsln*RkeVSwn>F8FlIe;4maxAAJ%DyMhRMSZBkEcs2j!+=KLes%a>oFecp}Jnm$YDd+P5VQ?=b_X|e1N$!$ns{M z=l_;-|1DSjfNTB*_ez#~CBwb)cicDrj_ZHG?Rmg$f52^f!0md#jsAi=^ng43fZKt} zUvPVVX|8=>+4tDuu(qzW4L#=Y#O32a`%3%vOv5u*PyM5f<453X%?Gm1ri`;`@wqi; z_f^|t+c68@wo=#in4_2cYmO~^Fz0H{o9Wp*z@87Su6YFM7tY*pLWvz(^1Xk2#od#! g_HJ0wD?i42`IeQo;XH@u-Cp+i>6yn=VxRo~0A0Wg3jhEB diff --git a/venv/lib/python3.12/site-packages/pip/_internal/commands/__pycache__/search.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/commands/__pycache__/search.cpython-312.pyc deleted file mode 100644 index 5f123d85d1e409d69bac8ae1fa8b064e6a41e72e..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 7631 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 XV&~w1we=Xtt(6_hSPcsX(0V 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 j&3A@!o5?)d)#*DcYB diff --git a/venv/lib/python3.12/site-packages/pip/_internal/commands/__pycache__/uninstall.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/commands/__pycache__/uninstall.cpython-312.pyc deleted file mode 100644 index d7676d635bb2ca9c6ee7422c3ca81aafbec6bc8c..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4736 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 diff --git a/venv/lib/python3.12/site-packages/pip/_internal/commands/cache.py b/venv/lib/python3.12/site-packages/pip/_internal/commands/cache.py deleted file mode 100644 index 3283361..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/commands/cache.py +++ /dev/null @@ -1,225 +0,0 @@ -import os -import textwrap -from optparse import Values -from typing import Any, List - -from pip._internal.cli.base_command import Command -from pip._internal.cli.status_codes import ERROR, SUCCESS -from pip._internal.exceptions import CommandError, PipError -from pip._internal.utils import filesystem -from pip._internal.utils.logging import getLogger - -logger = getLogger(__name__) - - -class CacheCommand(Command): - """ - Inspect and manage pip's wheel cache. - - Subcommands: - - - dir: Show the cache directory. - - info: Show information about the cache. - - list: List filenames of packages stored in the cache. - - remove: Remove one or more package from the cache. - - purge: Remove all items from the cache. - - ```` can be a glob expression or a package name. - """ - - ignore_require_venv = True - usage = """ - %prog dir - %prog info - %prog list [] [--format=[human, abspath]] - %prog remove - %prog purge - """ - - def add_options(self) -> None: - self.cmd_opts.add_option( - "--format", - action="store", - dest="list_format", - default="human", - choices=("human", "abspath"), - help="Select the output format among: human (default) or abspath", - ) - - self.parser.insert_option_group(0, self.cmd_opts) - - def run(self, options: Values, args: List[str]) -> int: - handlers = { - "dir": self.get_cache_dir, - "info": self.get_cache_info, - "list": self.list_cache_items, - "remove": self.remove_cache_items, - "purge": self.purge_cache, - } - - if not options.cache_dir: - logger.error("pip cache commands can not function since cache is disabled.") - return ERROR - - # Determine action - if not args or args[0] not in handlers: - logger.error( - "Need an action (%s) to perform.", - ", ".join(sorted(handlers)), - ) - return ERROR - - action = args[0] - - # 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 get_cache_dir(self, options: Values, args: List[Any]) -> None: - if args: - raise CommandError("Too many arguments") - - logger.info(options.cache_dir) - - def get_cache_info(self, options: Values, args: List[Any]) -> None: - if args: - raise CommandError("Too many arguments") - - num_http_files = len(self._find_http_files(options)) - num_packages = len(self._find_wheels(options, "*")) - - http_cache_location = self._cache_dir(options, "http-v2") - old_http_cache_location = self._cache_dir(options, "http") - wheels_cache_location = self._cache_dir(options, "wheels") - http_cache_size = filesystem.format_size( - filesystem.directory_size(http_cache_location) - + filesystem.directory_size(old_http_cache_location) - ) - wheels_cache_size = filesystem.format_directory_size(wheels_cache_location) - - message = ( - textwrap.dedent( - """ - Package index page cache location (pip v23.3+): {http_cache_location} - Package index page cache location (older pips): {old_http_cache_location} - Package index page cache size: {http_cache_size} - Number of HTTP files: {num_http_files} - Locally built wheels location: {wheels_cache_location} - Locally built wheels size: {wheels_cache_size} - Number of locally built wheels: {package_count} - """ # noqa: E501 - ) - .format( - http_cache_location=http_cache_location, - old_http_cache_location=old_http_cache_location, - http_cache_size=http_cache_size, - num_http_files=num_http_files, - wheels_cache_location=wheels_cache_location, - package_count=num_packages, - wheels_cache_size=wheels_cache_size, - ) - .strip() - ) - - logger.info(message) - - def list_cache_items(self, options: Values, args: List[Any]) -> None: - if len(args) > 1: - raise CommandError("Too many arguments") - - if args: - pattern = args[0] - else: - pattern = "*" - - files = self._find_wheels(options, pattern) - if options.list_format == "human": - self.format_for_human(files) - else: - self.format_for_abspath(files) - - def format_for_human(self, files: List[str]) -> None: - if not files: - logger.info("No locally built wheels cached.") - return - - results = [] - for filename in files: - wheel = os.path.basename(filename) - size = filesystem.format_file_size(filename) - results.append(f" - {wheel} ({size})") - logger.info("Cache contents:\n") - logger.info("\n".join(sorted(results))) - - def format_for_abspath(self, files: List[str]) -> None: - if files: - logger.info("\n".join(sorted(files))) - - def remove_cache_items(self, options: Values, args: List[Any]) -> None: - if len(args) > 1: - raise CommandError("Too many arguments") - - if not args: - raise CommandError("Please provide a pattern") - - files = self._find_wheels(options, args[0]) - - no_matching_msg = "No matching packages" - if args[0] == "*": - # Only fetch http files if no specific pattern given - files += self._find_http_files(options) - else: - # Add the pattern to the log message - no_matching_msg += f' for pattern "{args[0]}"' - - if not files: - logger.warning(no_matching_msg) - - for filename in files: - os.unlink(filename) - logger.verbose("Removed %s", filename) - logger.info("Files removed: %s", len(files)) - - def purge_cache(self, options: Values, args: List[Any]) -> None: - if args: - raise CommandError("Too many arguments") - - return self.remove_cache_items(options, ["*"]) - - def _cache_dir(self, options: Values, subdir: str) -> str: - return os.path.join(options.cache_dir, subdir) - - def _find_http_files(self, options: Values) -> List[str]: - old_http_dir = self._cache_dir(options, "http") - new_http_dir = self._cache_dir(options, "http-v2") - return filesystem.find_files(old_http_dir, "*") + filesystem.find_files( - new_http_dir, "*" - ) - - def _find_wheels(self, options: Values, pattern: str) -> List[str]: - wheel_dir = self._cache_dir(options, "wheels") - - # The wheel filename format, as specified in PEP 427, is: - # {distribution}-{version}(-{build})?-{python}-{abi}-{platform}.whl - # - # Additionally, non-alphanumeric values in the distribution are - # normalized to underscores (_), meaning hyphens can never occur - # before `-{version}`. - # - # Given that information: - # - If the pattern we're given contains a hyphen (-), the user is - # providing at least the version. Thus, we can just append `*.whl` - # to match the rest of it. - # - If the pattern we're given doesn't contain a hyphen (-), the - # user is only providing the name. Thus, we append `-*.whl` to - # match the hyphen before the version, followed by anything else. - # - # PEP 427: https://www.python.org/dev/peps/pep-0427/ - pattern = pattern + ("*.whl" if "-" in pattern else "-*.whl") - - return filesystem.find_files(wheel_dir, pattern) diff --git a/venv/lib/python3.12/site-packages/pip/_internal/commands/check.py b/venv/lib/python3.12/site-packages/pip/_internal/commands/check.py deleted file mode 100644 index 5efd0a3..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/commands/check.py +++ /dev/null @@ -1,54 +0,0 @@ -import logging -from optparse import Values -from typing import List - -from pip._internal.cli.base_command import Command -from pip._internal.cli.status_codes import ERROR, SUCCESS -from pip._internal.operations.check import ( - check_package_set, - create_package_set_from_installed, - warn_legacy_versions_and_specifiers, -) -from pip._internal.utils.misc import write_output - -logger = logging.getLogger(__name__) - - -class CheckCommand(Command): - """Verify installed packages have compatible dependencies.""" - - usage = """ - %prog [options]""" - - def run(self, options: Values, args: List[str]) -> int: - package_set, parsing_probs = create_package_set_from_installed() - warn_legacy_versions_and_specifiers(package_set) - missing, conflicting = check_package_set(package_set) - - for project_name in missing: - 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 ERROR - else: - write_output("No broken requirements found.") - return SUCCESS diff --git a/venv/lib/python3.12/site-packages/pip/_internal/commands/completion.py b/venv/lib/python3.12/site-packages/pip/_internal/commands/completion.py deleted file mode 100644 index 9e89e27..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/commands/completion.py +++ /dev/null @@ -1,130 +0,0 @@ -import sys -import textwrap -from optparse import Values -from typing import List - -from pip._internal.cli.base_command import Command -from pip._internal.cli.status_codes import SUCCESS -from pip._internal.utils.misc import get_prog - -BASE_COMPLETION = """ -# pip {shell} completion start{script}# pip {shell} 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} - """, - "zsh": """ - #compdef -P pip[0-9.]# - __pip() {{ - compadd $( COMP_WORDS="$words[*]" \\ - COMP_CWORD=$((CURRENT-1)) \\ - PIP_AUTO_COMPLETE=1 $words[1] 2>/dev/null ) - }} - if [[ $zsh_eval_context[-1] == loadautofunc ]]; then - # autoload from fpath, call function directly - __pip "$@" - else - # eval/source/. command, register function for later - compdef __pip -P 'pip[0-9.]#' - fi - """, - "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} - """, - "powershell": """ - if ((Test-Path Function:\\TabExpansion) -and -not ` - (Test-Path Function:\\_pip_completeBackup)) {{ - Rename-Item Function:\\TabExpansion _pip_completeBackup - }} - function TabExpansion($line, $lastWord) {{ - $lastBlock = [regex]::Split($line, '[|;]')[-1].TrimStart() - if ($lastBlock.StartsWith("{prog} ")) {{ - $Env:COMP_WORDS=$lastBlock - $Env:COMP_CWORD=$lastBlock.Split().Length - 1 - $Env:PIP_AUTO_COMPLETE=1 - (& {prog}).Split() - Remove-Item Env:COMP_WORDS - Remove-Item Env:COMP_CWORD - Remove-Item Env:PIP_AUTO_COMPLETE - }} - elseif (Test-Path Function:\\_pip_completeBackup) {{ - # Fall back on existing tab expansion - _pip_completeBackup $line $lastWord - }} - }} - """, -} - - -class CompletionCommand(Command): - """A helper command to be used for command completion.""" - - ignore_require_venv = True - - def add_options(self) -> None: - self.cmd_opts.add_option( - "--bash", - "-b", - action="store_const", - const="bash", - dest="shell", - help="Emit completion code for bash", - ) - self.cmd_opts.add_option( - "--zsh", - "-z", - action="store_const", - const="zsh", - dest="shell", - help="Emit completion code for zsh", - ) - self.cmd_opts.add_option( - "--fish", - "-f", - action="store_const", - const="fish", - dest="shell", - help="Emit completion code for fish", - ) - self.cmd_opts.add_option( - "--powershell", - "-p", - action="store_const", - const="powershell", - dest="shell", - help="Emit completion code for powershell", - ) - - self.parser.insert_option_group(0, self.cmd_opts) - - def run(self, options: Values, args: List[str]) -> int: - """Prints the completion code of the given shell""" - shells = COMPLETION_SCRIPTS.keys() - shell_options = ["--" + shell for shell in sorted(shells)] - if options.shell in shells: - script = textwrap.dedent( - COMPLETION_SCRIPTS.get(options.shell, "").format(prog=get_prog()) - ) - print(BASE_COMPLETION.format(script=script, shell=options.shell)) - return SUCCESS - else: - sys.stderr.write( - "ERROR: You must pass {}\n".format(" or ".join(shell_options)) - ) - return SUCCESS diff --git a/venv/lib/python3.12/site-packages/pip/_internal/commands/configuration.py b/venv/lib/python3.12/site-packages/pip/_internal/commands/configuration.py deleted file mode 100644 index 1a1dc6b..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/commands/configuration.py +++ /dev/null @@ -1,280 +0,0 @@ -import logging -import os -import subprocess -from optparse import Values -from typing import Any, List, Optional - -from pip._internal.cli.base_command import Command -from pip._internal.cli.status_codes import ERROR, SUCCESS -from pip._internal.configuration import ( - Configuration, - Kind, - get_configuration_files, - kinds, -) -from pip._internal.exceptions import PipError -from pip._internal.utils.logging import indent_log -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 command.option - - set: Set the command.option=value - - unset: Unset the value associated with command.option - - debug: List the configuration files and values defined under them - - Configuration keys should be dot separated command and option name, - with the special prefix "global" affecting any command. For example, - "pip config set global.index-url https://example.org/" would configure - the index url for all commands, but "pip config set download.timeout 10" - would configure a 10 second timeout only for "pip download" commands. - - If none of --user, --global and --site are passed, a virtual - environment configuration file is used if one is active and the file - exists. Otherwise, all modifications happen to the user file by - default. - """ - - ignore_require_venv = True - usage = """ - %prog [] list - %prog [] [--editor ] edit - - %prog [] get command.option - %prog [] set command.option value - %prog [] unset command.option - %prog [] debug - """ - - def add_options(self) -> 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: Values, args: List[str]) -> int: - handlers = { - "list": self.list_values, - "edit": self.open_in_editor, - "get": self.get_name, - "set": self.set_name_value, - "unset": self.unset_name, - "debug": self.list_config_values, - } - - # Determine action - if not args or args[0] not in handlers: - logger.error( - "Need an action (%s) to perform.", - ", ".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: Values, need_value: bool) -> Optional[Kind]: - file_options = [ - key - for key, value in ( - (kinds.USER, options.user_file), - (kinds.GLOBAL, options.global_file), - (kinds.SITE, options.site_file), - ) - if value - ] - - if not file_options: - if not need_value: - 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: Values, args: List[str]) -> None: - self._get_n_args(args, "list", n=0) - - for key, value in sorted(self.configuration.items()): - write_output("%s=%r", key, value) - - def get_name(self, options: Values, args: List[str]) -> None: - key = self._get_n_args(args, "get [name]", n=1) - value = self.configuration.get_value(key) - - write_output("%s", value) - - def set_name_value(self, options: Values, args: List[str]) -> None: - key, value = self._get_n_args(args, "set [name] [value]", n=2) - self.configuration.set_value(key, value) - - self._save_configuration() - - def unset_name(self, options: Values, args: List[str]) -> None: - key = self._get_n_args(args, "unset [name]", n=1) - self.configuration.unset_value(key) - - self._save_configuration() - - def list_config_values(self, options: Values, args: List[str]) -> None: - """List config key-value pairs across different config files""" - self._get_n_args(args, "debug", n=0) - - self.print_env_var_values() - # Iterate over config files and print if they exist, and the - # key-value pairs present in them if they do - for variant, files in sorted(self.configuration.iter_config_files()): - write_output("%s:", variant) - for fname in files: - with indent_log(): - file_exists = os.path.exists(fname) - write_output("%s, exists: %r", fname, file_exists) - if file_exists: - self.print_config_file_values(variant) - - def print_config_file_values(self, variant: Kind) -> None: - """Get key-value pairs from the file of a variant""" - for name, value in self.configuration.get_values_in_config(variant).items(): - with indent_log(): - write_output("%s: %s", name, value) - - def print_env_var_values(self) -> None: - """Get key-values pairs present as environment variables""" - write_output("%s:", "env_var") - with indent_log(): - for key, value in sorted(self.configuration.get_environ_vars()): - env_var = f"PIP_{key.upper()}" - write_output("%s=%r", env_var, value) - - def open_in_editor(self, options: Values, args: List[str]) -> None: - editor = self._determine_editor(options) - - fname = self.configuration.get_file_to_edit() - if fname is None: - raise PipError("Could not determine appropriate file.") - elif '"' in fname: - # This shouldn't happen, unless we see a username like that. - # If that happens, we'd appreciate a pull request fixing this. - raise PipError( - f'Can not open an editor for a file name containing "\n{fname}' - ) - - try: - subprocess.check_call(f'{editor} "{fname}"', shell=True) - except FileNotFoundError as e: - if not e.filename: - e.filename = editor - raise - except subprocess.CalledProcessError as e: - raise PipError(f"Editor Subprocess exited with exit code {e.returncode}") - - def _get_n_args(self, args: List[str], example: str, n: int) -> Any: - """Helper to make sure the command got the right number of arguments""" - if len(args) != n: - msg = ( - f"Got unexpected number of arguments, expected {n}. " - f'(example: "{get_prog()} config {example}")' - ) - raise PipError(msg) - - if n == 1: - return args[0] - else: - return args - - def _save_configuration(self) -> None: - # We successfully ran a modifying command. Need to save the - # configuration. - try: - self.configuration.save() - except Exception: - logger.exception( - "Unable to save configuration. Please report this as a bug." - ) - raise PipError("Internal Error.") - - def _determine_editor(self, options: Values) -> str: - 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.12/site-packages/pip/_internal/commands/debug.py b/venv/lib/python3.12/site-packages/pip/_internal/commands/debug.py deleted file mode 100644 index 7e5271c..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/commands/debug.py +++ /dev/null @@ -1,201 +0,0 @@ -import importlib.resources -import locale -import logging -import os -import sys -from optparse import Values -from types import ModuleType -from typing import Any, Dict, List, Optional - -import pip._vendor -from pip._vendor.certifi import where -from pip._vendor.packaging.version import parse as parse_version - -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.configuration import Configuration -from pip._internal.metadata import get_environment -from pip._internal.utils.logging import indent_log -from pip._internal.utils.misc import get_pip_version - -logger = logging.getLogger(__name__) - - -def show_value(name: str, value: Any) -> None: - logger.info("%s: %s", name, value) - - -def show_sys_implementation() -> None: - logger.info("sys.implementation:") - implementation_name = sys.implementation.name - with indent_log(): - show_value("name", implementation_name) - - -def create_vendor_txt_map() -> Dict[str, str]: - with importlib.resources.open_text("pip._vendor", "vendor.txt") as f: - # Purge non version specifying lines. - # Also, remove any space prefix or suffixes (including comments). - lines = [ - line.strip().split(" ", 1)[0] for line in f.readlines() if "==" in line - ] - - # Transform into "module" -> version dict. - return dict(line.split("==", 1) for line in lines) - - -def get_module_from_module_name(module_name: str) -> Optional[ModuleType]: - # Module name can be uppercase in vendor.txt for some reason... - module_name = module_name.lower().replace("-", "_") - # PATCH: setuptools is actually only pkg_resources. - if module_name == "setuptools": - module_name = "pkg_resources" - - try: - __import__(f"pip._vendor.{module_name}", globals(), locals(), level=0) - return getattr(pip._vendor, module_name) - except ImportError: - # We allow 'truststore' to fail to import due - # to being unavailable on Python 3.9 and earlier. - if module_name == "truststore" and sys.version_info < (3, 10): - return None - raise - - -def get_vendor_version_from_module(module_name: str) -> Optional[str]: - module = get_module_from_module_name(module_name) - version = getattr(module, "__version__", None) - - if module and not version: - # Try to find version in debundled module info. - assert module.__file__ is not None - env = get_environment([os.path.dirname(module.__file__)]) - dist = env.get_distribution(module_name) - if dist: - version = str(dist.version) - - return version - - -def show_actual_vendor_versions(vendor_txt_versions: Dict[str, str]) -> None: - """Log the actual version and print extra info if there is - a conflict or if the actual version could not be imported. - """ - for module_name, expected_version in vendor_txt_versions.items(): - extra_message = "" - actual_version = get_vendor_version_from_module(module_name) - if not actual_version: - extra_message = ( - " (Unable to locate actual module version, using" - " vendor.txt specified version)" - ) - actual_version = expected_version - elif parse_version(actual_version) != parse_version(expected_version): - extra_message = ( - " (CONFLICT: vendor.txt suggests version should" - f" be {expected_version})" - ) - logger.info("%s==%s%s", module_name, actual_version, extra_message) - - -def show_vendor_versions() -> None: - logger.info("vendored library versions:") - - vendor_txt_versions = create_vendor_txt_map() - with indent_log(): - show_actual_vendor_versions(vendor_txt_versions) - - -def show_tags(options: Values) -> None: - tag_limit = 10 - - target_python = make_target_python(options) - tags = target_python.get_sorted_tags() - - # Display the target options that were explicitly provided. - formatted_target = target_python.format_given() - suffix = "" - if formatted_target: - suffix = f" (target: {formatted_target})" - - msg = f"Compatible tags: {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 = f"...\n[First {tag_limit} tags shown. Pass --verbose to show all.]" - logger.info(msg) - - -def ca_bundle_info(config: Configuration) -> str: - levels = {key.split(".", 1)[0] for key, _ in config.items()} - 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" - - if "global" in levels: - levels.remove("global") - return ", ".join(levels) - - -class DebugCommand(Command): - """ - Display debug information. - """ - - usage = """ - %prog """ - ignore_require_venv = True - - def add_options(self) -> None: - cmdoptions.add_target_python_options(self.cmd_opts) - self.parser.insert_option_group(0, self.cmd_opts) - self.parser.config.load() - - def run(self, options: Values, args: List[str]) -> int: - logger.warning( - "This command is only meant for debugging. " - "Do not use this with automation for parsing and getting these " - "details, since the output and options of this command may " - "change without notice." - ) - show_value("pip version", get_pip_version()) - show_value("sys.version", sys.version) - show_value("sys.executable", sys.executable) - show_value("sys.getdefaultencoding", sys.getdefaultencoding()) - show_value("sys.getfilesystemencoding", sys.getfilesystemencoding()) - show_value( - "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_value("pip._vendor.DEBUNDLED", pip._vendor.DEBUNDLED) - - show_vendor_versions() - - show_tags(options) - - return SUCCESS diff --git a/venv/lib/python3.12/site-packages/pip/_internal/commands/download.py b/venv/lib/python3.12/site-packages/pip/_internal/commands/download.py deleted file mode 100644 index 54247a7..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/commands/download.py +++ /dev/null @@ -1,147 +0,0 @@ -import logging -import os -from optparse import Values -from typing import List - -from pip._internal.cli import cmdoptions -from pip._internal.cli.cmdoptions import make_target_python -from pip._internal.cli.req_command import RequirementCommand, with_cleanup -from pip._internal.cli.status_codes import SUCCESS -from pip._internal.operations.build.build_tracker import get_build_tracker -from pip._internal.req.req_install import check_legacy_setup_py_options -from pip._internal.utils.misc import ensure_dir, normalize_path, write_output -from pip._internal.utils.temp_dir import TempDirectory - -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 add_options(self) -> None: - self.cmd_opts.add_option(cmdoptions.constraints()) - self.cmd_opts.add_option(cmdoptions.requirements()) - self.cmd_opts.add_option(cmdoptions.no_deps()) - self.cmd_opts.add_option(cmdoptions.global_options()) - self.cmd_opts.add_option(cmdoptions.no_binary()) - self.cmd_opts.add_option(cmdoptions.only_binary()) - self.cmd_opts.add_option(cmdoptions.prefer_binary()) - self.cmd_opts.add_option(cmdoptions.src()) - self.cmd_opts.add_option(cmdoptions.pre()) - self.cmd_opts.add_option(cmdoptions.require_hashes()) - self.cmd_opts.add_option(cmdoptions.progress_bar()) - self.cmd_opts.add_option(cmdoptions.no_build_isolation()) - self.cmd_opts.add_option(cmdoptions.use_pep517()) - self.cmd_opts.add_option(cmdoptions.no_use_pep517()) - self.cmd_opts.add_option(cmdoptions.check_build_deps()) - self.cmd_opts.add_option(cmdoptions.ignore_requires_python()) - - self.cmd_opts.add_option( - "-d", - "--dest", - "--destination-dir", - "--destination-directory", - dest="download_dir", - metavar="dir", - default=os.curdir, - help="Download packages into .", - ) - - cmdoptions.add_target_python_options(self.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, self.cmd_opts) - - @with_cleanup - def run(self, options: Values, args: List[str]) -> int: - options.ignore_installed = True - # editable doesn't really make sense for `pip download`, but the bowels - # of the RequirementSet code require that property. - 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, - ignore_requires_python=options.ignore_requires_python, - ) - - build_tracker = self.enter_context(get_build_tracker()) - - directory = TempDirectory( - delete=not options.no_clean, - kind="download", - globally_managed=True, - ) - - reqs = self.get_requirements(args, options, finder, session) - check_legacy_setup_py_options(options, reqs) - - preparer = self.make_requirement_preparer( - temp_build_dir=directory, - options=options, - build_tracker=build_tracker, - session=session, - finder=finder, - download_dir=options.download_dir, - use_user_site=False, - verbosity=self.verbosity, - ) - - resolver = self.make_resolver( - preparer=preparer, - finder=finder, - options=options, - ignore_requires_python=options.ignore_requires_python, - use_pep517=options.use_pep517, - py_version_info=options.python_version, - ) - - self.trace_basic_info(finder) - - requirement_set = resolver.resolve(reqs, check_supported_wheels=True) - - downloaded: List[str] = [] - for req in requirement_set.requirements.values(): - if req.satisfied_by is None: - assert req.name is not None - preparer.save_linked_requirement(req) - downloaded.append(req.name) - - preparer.prepare_linked_requirements_more(requirement_set.requirements.values()) - requirement_set.warn_legacy_versions_and_specifiers() - - if downloaded: - write_output("Successfully downloaded %s", " ".join(downloaded)) - - return SUCCESS diff --git a/venv/lib/python3.12/site-packages/pip/_internal/commands/freeze.py b/venv/lib/python3.12/site-packages/pip/_internal/commands/freeze.py deleted file mode 100644 index e64cb3d..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/commands/freeze.py +++ /dev/null @@ -1,109 +0,0 @@ -import sys -from optparse import Values -from typing import AbstractSet, List - -from pip._internal.cli import cmdoptions -from pip._internal.cli.base_command import Command -from pip._internal.cli.status_codes import SUCCESS -from pip._internal.operations.freeze import freeze -from pip._internal.utils.compat import stdlib_pkgs - - -def _should_suppress_build_backends() -> bool: - return sys.version_info < (3, 12) - - -def _dev_pkgs() -> AbstractSet[str]: - pkgs = {"pip"} - - if _should_suppress_build_backends(): - pkgs |= {"setuptools", "distribute", "wheel"} - pkgs |= {"setuptools", "distribute", "wheel", "pkg-resources"} - - return pkgs - - -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 add_options(self) -> None: - self.cmd_opts.add_option( - "-r", - "--requirement", - dest="requirements", - action="append", - default=[], - metavar="file", - help=( - "Use the order in the given requirements file and its " - "comments when generating output. This option can be " - "used multiple times." - ), - ) - 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:" - " {}".format(", ".join(_dev_pkgs())) - ), - ) - self.cmd_opts.add_option( - "--exclude-editable", - dest="exclude_editable", - action="store_true", - help="Exclude editable package from output.", - ) - self.cmd_opts.add_option(cmdoptions.list_exclude()) - - self.parser.insert_option_group(0, self.cmd_opts) - - def run(self, options: Values, args: List[str]) -> int: - skip = set(stdlib_pkgs) - if not options.freeze_all: - skip.update(_dev_pkgs()) - - if options.excludes: - skip.update(options.excludes) - - cmdoptions.check_list_path_option(options) - - for line in freeze( - requirement=options.requirements, - local_only=options.local, - user_only=options.user, - paths=options.path, - isolated=options.isolated_mode, - skip=skip, - exclude_editable=options.exclude_editable, - ): - sys.stdout.write(line + "\n") - return SUCCESS diff --git a/venv/lib/python3.12/site-packages/pip/_internal/commands/hash.py b/venv/lib/python3.12/site-packages/pip/_internal/commands/hash.py deleted file mode 100644 index 042dac8..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/commands/hash.py +++ /dev/null @@ -1,59 +0,0 @@ -import hashlib -import logging -import sys -from optparse import Values -from typing import List - -from pip._internal.cli.base_command import Command -from pip._internal.cli.status_codes import ERROR, SUCCESS -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 add_options(self) -> None: - 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 {}".format( - ", ".join(STRONG_HASHES) - ), - ) - self.parser.insert_option_group(0, self.cmd_opts) - - def run(self, options: Values, args: List[str]) -> int: - if not args: - self.parser.print_usage(sys.stderr) - return ERROR - - algorithm = options.algorithm - for path in args: - write_output( - "%s:\n--hash=%s:%s", path, algorithm, _hash_of_file(path, algorithm) - ) - return SUCCESS - - -def _hash_of_file(path: str, algorithm: str) -> str: - """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.12/site-packages/pip/_internal/commands/help.py b/venv/lib/python3.12/site-packages/pip/_internal/commands/help.py deleted file mode 100644 index 6206631..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/commands/help.py +++ /dev/null @@ -1,41 +0,0 @@ -from optparse import Values -from typing import List - -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: Values, args: List[str]) -> int: - 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 = [f'unknown command "{cmd_name}"'] - if guess: - msg.append(f'maybe you meant "{guess}"') - - raise CommandError(" - ".join(msg)) - - command = create_command(cmd_name) - command.parser.print_help() - - return SUCCESS diff --git a/venv/lib/python3.12/site-packages/pip/_internal/commands/index.py b/venv/lib/python3.12/site-packages/pip/_internal/commands/index.py deleted file mode 100644 index f55e9e4..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/commands/index.py +++ /dev/null @@ -1,139 +0,0 @@ -import logging -from optparse import Values -from typing import Any, Iterable, List, Optional, Union - -from pip._vendor.packaging.version import LegacyVersion, Version - -from pip._internal.cli import cmdoptions -from pip._internal.cli.req_command import IndexGroupCommand -from pip._internal.cli.status_codes import ERROR, SUCCESS -from pip._internal.commands.search import print_dist_installation_info -from pip._internal.exceptions import CommandError, DistributionNotFound, PipError -from pip._internal.index.collector import LinkCollector -from pip._internal.index.package_finder import PackageFinder -from pip._internal.models.selection_prefs import SelectionPreferences -from pip._internal.models.target_python import TargetPython -from pip._internal.network.session import PipSession -from pip._internal.utils.misc import write_output - -logger = logging.getLogger(__name__) - - -class IndexCommand(IndexGroupCommand): - """ - Inspect information available from package indexes. - """ - - ignore_require_venv = True - usage = """ - %prog versions - """ - - def add_options(self) -> None: - cmdoptions.add_target_python_options(self.cmd_opts) - - self.cmd_opts.add_option(cmdoptions.ignore_requires_python()) - self.cmd_opts.add_option(cmdoptions.pre()) - self.cmd_opts.add_option(cmdoptions.no_binary()) - self.cmd_opts.add_option(cmdoptions.only_binary()) - - index_opts = cmdoptions.make_option_group( - cmdoptions.index_group, - self.parser, - ) - - self.parser.insert_option_group(0, index_opts) - self.parser.insert_option_group(0, self.cmd_opts) - - def run(self, options: Values, args: List[str]) -> int: - handlers = { - "versions": self.get_available_package_versions, - } - - logger.warning( - "pip index is currently an experimental command. " - "It may be removed/changed in a future release " - "without prior warning." - ) - - # Determine action - if not args or args[0] not in handlers: - logger.error( - "Need an action (%s) to perform.", - ", ".join(sorted(handlers)), - ) - return ERROR - - action = args[0] - - # 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 _build_package_finder( - self, - options: Values, - session: PipSession, - target_python: Optional[TargetPython] = None, - ignore_requires_python: Optional[bool] = None, - ) -> PackageFinder: - """ - Create a package finder appropriate to the index command. - """ - link_collector = LinkCollector.create(session, options=options) - - # Pass allow_yanked=False to ignore yanked versions. - selection_prefs = SelectionPreferences( - allow_yanked=False, - allow_all_prereleases=options.pre, - ignore_requires_python=ignore_requires_python, - ) - - return PackageFinder.create( - link_collector=link_collector, - selection_prefs=selection_prefs, - target_python=target_python, - ) - - def get_available_package_versions(self, options: Values, args: List[Any]) -> None: - if len(args) != 1: - raise CommandError("You need to specify exactly one argument") - - target_python = cmdoptions.make_target_python(options) - query = args[0] - - with self._build_session(options) as session: - finder = self._build_package_finder( - options=options, - session=session, - target_python=target_python, - ignore_requires_python=options.ignore_requires_python, - ) - - versions: Iterable[Union[LegacyVersion, Version]] = ( - candidate.version for candidate in finder.find_all_candidates(query) - ) - - if not options.pre: - # Remove prereleases - versions = ( - version for version in versions if not version.is_prerelease - ) - versions = set(versions) - - if not versions: - raise DistributionNotFound( - f"No matching distribution found for {query}" - ) - - formatted_versions = [str(ver) for ver in sorted(versions, reverse=True)] - latest = formatted_versions[0] - - write_output(f"{query} ({latest})") - write_output("Available versions: {}".format(", ".join(formatted_versions))) - print_dist_installation_info(query, latest) diff --git a/venv/lib/python3.12/site-packages/pip/_internal/commands/inspect.py b/venv/lib/python3.12/site-packages/pip/_internal/commands/inspect.py deleted file mode 100644 index 27c8fa3..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/commands/inspect.py +++ /dev/null @@ -1,92 +0,0 @@ -import logging -from optparse import Values -from typing import Any, Dict, List - -from pip._vendor.packaging.markers import default_environment -from pip._vendor.rich import print_json - -from pip import __version__ -from pip._internal.cli import cmdoptions -from pip._internal.cli.req_command import Command -from pip._internal.cli.status_codes import SUCCESS -from pip._internal.metadata import BaseDistribution, get_environment -from pip._internal.utils.compat import stdlib_pkgs -from pip._internal.utils.urls import path_to_url - -logger = logging.getLogger(__name__) - - -class InspectCommand(Command): - """ - Inspect the content of a Python environment and produce a report in JSON format. - """ - - ignore_require_venv = True - usage = """ - %prog [options]""" - - def add_options(self) -> None: - self.cmd_opts.add_option( - "--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.", - ) - self.cmd_opts.add_option(cmdoptions.list_path()) - self.parser.insert_option_group(0, self.cmd_opts) - - def run(self, options: Values, args: List[str]) -> int: - cmdoptions.check_list_path_option(options) - dists = get_environment(options.path).iter_installed_distributions( - local_only=options.local, - user_only=options.user, - skip=set(stdlib_pkgs), - ) - output = { - "version": "1", - "pip_version": __version__, - "installed": [self._dist_to_dict(dist) for dist in dists], - "environment": default_environment(), - # TODO tags? scheme? - } - print_json(data=output) - return SUCCESS - - def _dist_to_dict(self, dist: BaseDistribution) -> Dict[str, Any]: - res: Dict[str, Any] = { - "metadata": dist.metadata_dict, - "metadata_location": dist.info_location, - } - # direct_url. Note that we don't have download_info (as in the installation - # report) since it is not recorded in installed metadata. - direct_url = dist.direct_url - if direct_url is not None: - res["direct_url"] = direct_url.to_dict() - else: - # Emulate direct_url for legacy editable installs. - editable_project_location = dist.editable_project_location - if editable_project_location is not None: - res["direct_url"] = { - "url": path_to_url(editable_project_location), - "dir_info": { - "editable": True, - }, - } - # installer - installer = dist.installer - if dist.installer: - res["installer"] = installer - # requested - if dist.installed_with_dist_info: - res["requested"] = dist.requested - return res diff --git a/venv/lib/python3.12/site-packages/pip/_internal/commands/install.py b/venv/lib/python3.12/site-packages/pip/_internal/commands/install.py deleted file mode 100644 index e944bb9..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/commands/install.py +++ /dev/null @@ -1,774 +0,0 @@ -import errno -import json -import operator -import os -import shutil -import site -from optparse import SUPPRESS_HELP, Values -from typing import List, Optional - -from pip._vendor.rich import print_json - -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, - warn_if_run_as_root, - with_cleanup, -) -from pip._internal.cli.status_codes import ERROR, SUCCESS -from pip._internal.exceptions import CommandError, InstallationError -from pip._internal.locations import get_scheme -from pip._internal.metadata import get_environment -from pip._internal.models.installation_report import InstallationReport -from pip._internal.operations.build.build_tracker import get_build_tracker -from pip._internal.operations.check import ConflictDetails, check_install_conflicts -from pip._internal.req import install_given_reqs -from pip._internal.req.req_install import ( - InstallRequirement, - check_legacy_setup_py_options, -) -from pip._internal.utils.compat import WINDOWS -from pip._internal.utils.filesystem import test_writable_dir -from pip._internal.utils.logging import getLogger -from pip._internal.utils.misc import ( - check_externally_managed, - ensure_dir, - get_pip_version, - protect_pip_from_modification_on_windows, - write_output, -) -from pip._internal.utils.temp_dir import TempDirectory -from pip._internal.utils.virtualenv import ( - running_under_virtualenv, - virtualenv_no_global, -) -from pip._internal.wheel_builder import build, should_build_for_install_command - -logger = getLogger(__name__) - - -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 add_options(self) -> None: - self.cmd_opts.add_option(cmdoptions.requirements()) - self.cmd_opts.add_option(cmdoptions.constraints()) - self.cmd_opts.add_option(cmdoptions.no_deps()) - self.cmd_opts.add_option(cmdoptions.pre()) - - self.cmd_opts.add_option(cmdoptions.editable()) - self.cmd_opts.add_option( - "--dry-run", - action="store_true", - dest="dry_run", - default=False, - help=( - "Don't actually install anything, just print what would be. " - "Can be used in combination with --ignore-installed " - "to 'resolve' the requirements." - ), - ) - self.cmd_opts.add_option( - "-t", - "--target", - dest="target_dir", - metavar="dir", - default=None, - help=( - "Install packages into . " - "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(self.cmd_opts) - - self.cmd_opts.add_option( - "--user", - dest="use_user_site", - action="store_true", - help=( - "Install to the Python user install directory for your " - "platform. Typically ~/.local/, or %APPDATA%\\Python on " - "Windows. (See the Python documentation for site.USER_BASE " - "for full details.)" - ), - ) - self.cmd_opts.add_option( - "--no-user", - dest="use_user_site", - action="store_false", - help=SUPPRESS_HELP, - ) - self.cmd_opts.add_option( - "--root", - dest="root_path", - metavar="dir", - default=None, - help="Install everything relative to this alternate root directory.", - ) - self.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. Note that the resulting installation may " - "contain scripts and other resources which reference the " - "Python interpreter of pip, and not that of ``--prefix``. " - "See also the ``--python`` option if the intention is to " - "install packages into another (possibly pip-free) " - "environment." - ), - ) - - self.cmd_opts.add_option(cmdoptions.src()) - - self.cmd_opts.add_option( - "-U", - "--upgrade", - dest="upgrade", - action="store_true", - help=( - "Upgrade all specified packages to the newest available " - "version. The handling of dependencies depends on the " - "upgrade-strategy used." - ), - ) - - self.cmd_opts.add_option( - "--upgrade-strategy", - dest="upgrade_strategy", - default="only-if-needed", - choices=["only-if-needed", "eager"], - help=( - "Determines how dependency upgrading should be handled " - "[default: %default]. " - '"eager" - dependencies are upgraded regardless of ' - "whether the currently installed version satisfies the " - "requirements of the upgraded package(s). " - '"only-if-needed" - are upgraded only when they do not ' - "satisfy the requirements of the upgraded package(s)." - ), - ) - - self.cmd_opts.add_option( - "--force-reinstall", - dest="force_reinstall", - action="store_true", - help="Reinstall all packages even if they are already up-to-date.", - ) - - self.cmd_opts.add_option( - "-I", - "--ignore-installed", - dest="ignore_installed", - action="store_true", - help=( - "Ignore the installed packages, overwriting them. " - "This can break your system if the existing package " - "is of a different version or was installed " - "with a different package manager!" - ), - ) - - self.cmd_opts.add_option(cmdoptions.ignore_requires_python()) - self.cmd_opts.add_option(cmdoptions.no_build_isolation()) - self.cmd_opts.add_option(cmdoptions.use_pep517()) - self.cmd_opts.add_option(cmdoptions.no_use_pep517()) - self.cmd_opts.add_option(cmdoptions.check_build_deps()) - self.cmd_opts.add_option(cmdoptions.override_externally_managed()) - - self.cmd_opts.add_option(cmdoptions.config_settings()) - self.cmd_opts.add_option(cmdoptions.global_options()) - - self.cmd_opts.add_option( - "--compile", - action="store_true", - dest="compile", - default=True, - help="Compile Python source files to bytecode", - ) - - self.cmd_opts.add_option( - "--no-compile", - action="store_false", - dest="compile", - help="Do not compile Python source files to bytecode", - ) - - self.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", - ) - self.cmd_opts.add_option( - "--no-warn-conflicts", - action="store_false", - dest="warn_about_conflicts", - default=True, - help="Do not warn about broken dependencies", - ) - self.cmd_opts.add_option(cmdoptions.no_binary()) - self.cmd_opts.add_option(cmdoptions.only_binary()) - self.cmd_opts.add_option(cmdoptions.prefer_binary()) - self.cmd_opts.add_option(cmdoptions.require_hashes()) - self.cmd_opts.add_option(cmdoptions.progress_bar()) - self.cmd_opts.add_option(cmdoptions.root_user_action()) - - index_opts = cmdoptions.make_option_group( - cmdoptions.index_group, - self.parser, - ) - - self.parser.insert_option_group(0, index_opts) - self.parser.insert_option_group(0, self.cmd_opts) - - self.cmd_opts.add_option( - "--report", - dest="json_report_file", - metavar="file", - default=None, - help=( - "Generate a JSON file describing what pip did to install " - "the provided requirements. " - "Can be used in combination with --dry-run and --ignore-installed " - "to 'resolve' the requirements. " - "When - is used as file name it writes to stdout. " - "When writing to stdout, please combine with the --quiet option " - "to avoid mixing pip logging output with JSON output." - ), - ) - - @with_cleanup - def run(self, options: Values, args: List[str]) -> int: - if options.use_user_site and options.target_dir is not None: - raise CommandError("Can not combine '--user' and '--target'") - - # Check whether the environment we're installing into is externally - # managed, as specified in PEP 668. Specifying --root, --target, or - # --prefix disables the check, since there's no reliable way to locate - # the EXTERNALLY-MANAGED file for those cases. An exception is also - # made specifically for "--dry-run --report" for convenience. - installing_into_current_environment = ( - not (options.dry_run and options.json_report_file) - and options.root_path is None - and options.target_dir is None - and options.prefix_path is None - ) - if ( - installing_into_current_environment - and not options.override_externally_managed - ): - check_externally_managed() - - upgrade_strategy = "to-satisfy-only" - if options.upgrade: - upgrade_strategy = options.upgrade_strategy - - cmdoptions.check_dist_restriction(options, check_target=True) - - logger.verbose("Using %s", get_pip_version()) - 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: Optional[TempDirectory] = None - target_temp_dir_path: Optional[str] = None - if options.target_dir: - options.ignore_installed = True - options.target_dir = os.path.abspath(options.target_dir) - if ( - # fmt: off - os.path.exists(options.target_dir) and - not os.path.isdir(options.target_dir) - # fmt: on - ): - raise CommandError( - "Target path exists but is not a directory, will not continue." - ) - - # Create a target directory for using with the target option - target_temp_dir = TempDirectory(kind="target") - target_temp_dir_path = target_temp_dir.path - self.enter_context(target_temp_dir) - - 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_tracker = self.enter_context(get_build_tracker()) - - directory = TempDirectory( - delete=not options.no_clean, - kind="install", - globally_managed=True, - ) - - try: - reqs = self.get_requirements(args, options, finder, session) - check_legacy_setup_py_options(options, reqs) - - wheel_cache = WheelCache(options.cache_dir) - - # Only when installing is it permitted to use PEP 660. - # In other circumstances (pip wheel, pip download) we generate - # regular (i.e. non editable) metadata and wheels. - for req in reqs: - req.permit_editable_wheels = True - - preparer = self.make_requirement_preparer( - temp_build_dir=directory, - options=options, - build_tracker=build_tracker, - session=session, - finder=finder, - use_user_site=options.use_user_site, - verbosity=self.verbosity, - ) - 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) - - requirement_set = resolver.resolve( - reqs, check_supported_wheels=not options.target_dir - ) - - if options.json_report_file: - report = InstallationReport(requirement_set.requirements_to_install) - if options.json_report_file == "-": - print_json(data=report.to_dict()) - else: - with open(options.json_report_file, "w", encoding="utf-8") as f: - json.dump(report.to_dict(), f, indent=2, ensure_ascii=False) - - if options.dry_run: - # In non dry-run mode, the legacy versions and specifiers check - # will be done as part of conflict detection. - requirement_set.warn_legacy_versions_and_specifiers() - would_install_items = sorted( - (r.metadata["name"], r.metadata["version"]) - for r in requirement_set.requirements_to_install - ) - if would_install_items: - write_output( - "Would install %s", - " ".join("-".join(item) for item in would_install_items), - ) - return SUCCESS - - try: - pip_req = requirement_set.get_requirement("pip") - except KeyError: - modifying_pip = False - 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) - - reqs_to_build = [ - r - for r in requirement_set.requirements.values() - if should_build_for_install_command(r) - ] - - _, build_failures = build( - reqs_to_build, - wheel_cache=wheel_cache, - verify=True, - build_options=[], - global_options=global_options, - ) - - if build_failures: - raise InstallationError( - "Could not build wheels for {}, which is required to " - "install pyproject.toml-based projects".format( - ", ".join(r.name for r in build_failures) # type: ignore - ) - ) - - to_install = resolver.get_installation_order(requirement_set) - - # Check for conflicts in the package set we're installing. - conflicts: Optional[ConflictDetails] = None - should_warn_about_conflicts = ( - not options.ignore_dependencies and options.warn_about_conflicts - ) - if should_warn_about_conflicts: - conflicts = self._determine_conflicts(to_install) - - # Don't warn about script install locations if - # --target or --prefix has been specified - warn_script_location = options.warn_script_location - if options.target_dir or options.prefix_path: - warn_script_location = False - - installed = install_given_reqs( - to_install, - global_options, - root=options.root_path, - home=target_temp_dir_path, - prefix=options.prefix_path, - warn_script_location=warn_script_location, - use_user_site=options.use_user_site, - pycompile=options.compile, - ) - - 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, - ) - env = get_environment(lib_locations) - - installed.sort(key=operator.attrgetter("name")) - items = [] - for result in installed: - item = result.name - try: - installed_dist = env.get_distribution(item) - if installed_dist is not None: - item = f"{item}-{installed_dist.version}" - except Exception: - pass - items.append(item) - - if conflicts is not None: - self._warn_about_conflicts( - conflicts, - resolver_variant=self.determine_resolver_variant(options), - ) - - installed_desc = " ".join(items) - if installed_desc: - write_output( - "Successfully installed %s", - installed_desc, - ) - except OSError as error: - show_traceback = self.verbosity >= 1 - - message = create_os_error_message( - error, - show_traceback, - options.use_user_site, - ) - logger.error(message, exc_info=show_traceback) - - return ERROR - - if options.target_dir: - assert target_temp_dir - self._handle_target_dir( - options.target_dir, target_temp_dir, options.upgrade - ) - if options.root_user_action == "warn": - warn_if_run_as_root() - return SUCCESS - - def _handle_target_dir( - self, target_dir: str, target_temp_dir: TempDirectory, upgrade: bool - ) -> None: - ensure_dir(target_dir) - - # Checking both purelib and platlib directories for installed - # packages to be moved to target directory - lib_dir_list = [] - - # Checking both purelib and platlib directories for installed - # packages to be moved to target directory - scheme = get_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 _determine_conflicts( - self, to_install: List[InstallRequirement] - ) -> Optional[ConflictDetails]: - try: - return check_install_conflicts(to_install) - except Exception: - logger.exception( - "Error while checking for conflicts. Please file an issue on " - "pip's issue tracker: https://github.com/pypa/pip/issues/new" - ) - return None - - def _warn_about_conflicts( - self, conflict_details: ConflictDetails, resolver_variant: str - ) -> None: - package_set, (missing, conflicting) = conflict_details - if not missing and not conflicting: - return - - parts: List[str] = [] - if resolver_variant == "legacy": - parts.append( - "pip's legacy dependency resolver does not consider dependency " - "conflicts when selecting packages. This behaviour is the " - "source of the following dependency conflicts." - ) - else: - assert resolver_variant == "resolvelib" - parts.append( - "pip's dependency resolver does not currently take into account " - "all the packages that are installed. This behaviour is the " - "source of the following dependency conflicts." - ) - - # NOTE: There is some duplication here, with commands/check.py - for project_name in missing: - version = package_set[project_name][0] - for dependency in missing[project_name]: - message = ( - f"{project_name} {version} requires {dependency[1]}, " - "which is not installed." - ) - parts.append(message) - - for project_name in conflicting: - version = package_set[project_name][0] - for dep_name, dep_version, req in conflicting[project_name]: - message = ( - "{name} {version} requires {requirement}, but {you} have " - "{dep_name} {dep_version} which is incompatible." - ).format( - name=project_name, - version=version, - requirement=req, - dep_name=dep_name, - dep_version=dep_version, - you=("you" if resolver_variant == "resolvelib" else "you'll"), - ) - parts.append(message) - - logger.critical("\n".join(parts)) - - -def get_lib_location_guesses( - user: bool = False, - home: Optional[str] = None, - root: Optional[str] = None, - isolated: bool = False, - prefix: Optional[str] = None, -) -> List[str]: - scheme = get_scheme( - "", - user=user, - home=home, - root=root, - isolated=isolated, - prefix=prefix, - ) - return [scheme.purelib, scheme.platlib] - - -def site_packages_writable(root: Optional[str], isolated: bool) -> bool: - return all( - test_writable_dir(d) - for d in set(get_lib_location_guesses(root=root, isolated=isolated)) - ) - - -def decide_user_install( - use_user_site: Optional[bool], - prefix_path: Optional[str] = None, - target_dir: Optional[str] = None, - root_path: Optional[str] = None, - isolated_mode: bool = False, -) -> bool: - """Determine whether to do a user install based on the input options. - - If use_user_site is False, no additional checks are done. - 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 create_os_error_message( - error: OSError, show_traceback: bool, using_user_site: bool -) -> str: - """Format an error message for an OSError - - It may occur anytime during the execution of the install command. - """ - parts = [] - - # Mention the error if we are not going to show a traceback - parts.append("Could not install packages due to an OSError") - 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 running_under_virtualenv() and not using_user_site: - parts.extend( - [ - user_option_part, - " or ", - permissions_part.lower(), - ] - ) - else: - parts.append(permissions_part) - parts.append(".\n") - - # Suggest the user to enable Long Paths if path length is - # more than 260 - if ( - WINDOWS - and error.errno == errno.ENOENT - and error.filename - and len(error.filename) > 260 - ): - parts.append( - "HINT: This error might have occurred since " - "this system does not have Windows Long Path " - "support enabled. You can find information on " - "how to enable this at " - "https://pip.pypa.io/warnings/enable-long-paths\n" - ) - - return "".join(parts).strip() + "\n" diff --git a/venv/lib/python3.12/site-packages/pip/_internal/commands/list.py b/venv/lib/python3.12/site-packages/pip/_internal/commands/list.py deleted file mode 100644 index 32fb19b..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/commands/list.py +++ /dev/null @@ -1,370 +0,0 @@ -import json -import logging -from optparse import Values -from typing import TYPE_CHECKING, Generator, List, Optional, Sequence, Tuple, cast - -from pip._vendor.packaging.utils import canonicalize_name - -from pip._internal.cli import cmdoptions -from pip._internal.cli.req_command import IndexGroupCommand -from pip._internal.cli.status_codes import SUCCESS -from pip._internal.exceptions import CommandError -from pip._internal.index.collector import LinkCollector -from pip._internal.index.package_finder import PackageFinder -from pip._internal.metadata import BaseDistribution, get_environment -from pip._internal.models.selection_prefs import SelectionPreferences -from pip._internal.network.session import PipSession -from pip._internal.utils.compat import stdlib_pkgs -from pip._internal.utils.misc import tabulate, write_output - -if TYPE_CHECKING: - from pip._internal.metadata.base import DistributionVersion - - class _DistWithLatestInfo(BaseDistribution): - """Give the distribution object a couple of extra fields. - - These will be populated during ``get_outdated()``. This is dirty but - makes the rest of the code much cleaner. - """ - - latest_version: DistributionVersion - latest_filetype: str - - _ProcessedDists = Sequence[_DistWithLatestInfo] - - -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. - """ - - ignore_require_venv = True - usage = """ - %prog [options]""" - - def add_options(self) -> None: - self.cmd_opts.add_option( - "-o", - "--outdated", - action="store_true", - default=False, - help="List outdated packages", - ) - self.cmd_opts.add_option( - "-u", - "--uptodate", - action="store_true", - default=False, - help="List uptodate packages", - ) - self.cmd_opts.add_option( - "-e", - "--editable", - action="store_true", - default=False, - help="List editable projects.", - ) - self.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.", - ) - self.cmd_opts.add_option(cmdoptions.list_path()) - self.cmd_opts.add_option( - "--pre", - action="store_true", - default=False, - help=( - "Include pre-release and development versions. By default, " - "pip only finds stable versions." - ), - ) - - self.cmd_opts.add_option( - "--format", - action="store", - dest="list_format", - default="columns", - choices=("columns", "freeze", "json"), - help=( - "Select the output format among: columns (default), freeze, or json. " - "The 'freeze' format cannot be used with the --outdated option." - ), - ) - - self.cmd_opts.add_option( - "--not-required", - action="store_true", - dest="not_required", - help="List packages that are not dependencies of installed packages.", - ) - - self.cmd_opts.add_option( - "--exclude-editable", - action="store_false", - dest="include_editable", - help="Exclude editable package from output.", - ) - self.cmd_opts.add_option( - "--include-editable", - action="store_true", - dest="include_editable", - help="Include editable package from output.", - default=True, - ) - self.cmd_opts.add_option(cmdoptions.list_exclude()) - index_opts = cmdoptions.make_option_group(cmdoptions.index_group, self.parser) - - self.parser.insert_option_group(0, index_opts) - self.parser.insert_option_group(0, self.cmd_opts) - - def _build_package_finder( - self, options: Values, session: PipSession - ) -> PackageFinder: - """ - Create a package finder appropriate to this list command. - """ - link_collector = LinkCollector.create(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: Values, args: List[str]) -> int: - if options.outdated and options.uptodate: - raise CommandError("Options --outdated and --uptodate cannot be combined.") - - if options.outdated and options.list_format == "freeze": - raise CommandError( - "List format 'freeze' cannot be used with the --outdated option." - ) - - cmdoptions.check_list_path_option(options) - - skip = set(stdlib_pkgs) - if options.excludes: - skip.update(canonicalize_name(n) for n in options.excludes) - - packages: "_ProcessedDists" = [ - cast("_DistWithLatestInfo", d) - for d in get_environment(options.path).iter_installed_distributions( - local_only=options.local, - user_only=options.user, - editables_only=options.editable, - include_editables=options.include_editable, - skip=skip, - ) - ] - - # get_not_required must be called firstly in order to find and - # filter out all dependencies correctly. Otherwise a package - # 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) - return SUCCESS - - def get_outdated( - self, packages: "_ProcessedDists", options: Values - ) -> "_ProcessedDists": - return [ - dist - for dist in self.iter_packages_latest_infos(packages, options) - if parse(str(dist.latest_version)) > parse(str(dist.version)) - ] - - def get_uptodate( - self, packages: "_ProcessedDists", options: Values - ) -> "_ProcessedDists": - return [ - dist - for dist in self.iter_packages_latest_infos(packages, options) - if parse(str(dist.latest_version)) == parse(str(dist.version)) - ] - - def get_not_required( - self, packages: "_ProcessedDists", options: Values - ) -> "_ProcessedDists": - dep_keys = { - canonicalize_name(dep.name) - for dist in packages - for dep in (dist.iter_dependencies() or ()) - } - - # Create a set to remove duplicate packages, and cast it to a list - # to keep the return type consistent with get_outdated and - # get_uptodate - return list({pkg for pkg in packages if pkg.canonical_name not in dep_keys}) - - def iter_packages_latest_infos( - self, packages: "_ProcessedDists", options: Values - ) -> Generator["_DistWithLatestInfo", None, None]: - with self._build_session(options) as session: - finder = self._build_package_finder(options, session) - - def latest_info( - dist: "_DistWithLatestInfo", - ) -> Optional["_DistWithLatestInfo"]: - all_candidates = finder.find_all_candidates(dist.canonical_name) - if not options.pre: - # Remove prereleases - all_candidates = [ - candidate - for candidate in all_candidates - if not candidate.version.is_prerelease - ] - - evaluator = finder.make_candidate_evaluator( - project_name=dist.canonical_name, - ) - best_candidate = evaluator.sort_best_candidate(all_candidates) - if best_candidate is None: - return None - - remote_version = best_candidate.version - if best_candidate.link.is_wheel: - typ = "wheel" - else: - typ = "sdist" - dist.latest_version = remote_version - dist.latest_filetype = typ - return dist - - for dist in map(latest_info, packages): - if dist is not None: - yield dist - - def output_package_listing( - self, packages: "_ProcessedDists", options: Values - ) -> None: - packages = sorted( - packages, - key=lambda dist: dist.canonical_name, - ) - 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.raw_name, dist.version, dist.location - ) - else: - write_output("%s==%s", dist.raw_name, dist.version) - elif options.list_format == "json": - write_output(format_for_json(packages, options)) - - def output_package_listing_columns( - self, data: List[List[str]], header: List[str] - ) -> None: - # insert the header first: we need to know the size of column names - if len(data) > 0: - data.insert(0, header) - - pkg_strings, sizes = tabulate(data) - - # Create and add a separator. - if len(data) > 0: - pkg_strings.insert(1, " ".join("-" * x for x in sizes)) - - for val in pkg_strings: - write_output(val) - - -def format_for_columns( - pkgs: "_ProcessedDists", options: Values -) -> Tuple[List[List[str]], List[str]]: - """ - Convert the package data into something usable - by output_package_listing_columns. - """ - header = ["Package", "Version"] - - running_outdated = options.outdated - if running_outdated: - header.extend(["Latest", "Type"]) - - has_editables = any(x.editable for x in pkgs) - if has_editables: - header.append("Editable project location") - - if options.verbose >= 1: - header.append("Location") - if options.verbose >= 1: - header.append("Installer") - - data = [] - for proj in pkgs: - # if we're working on the 'outdated' list, separate out the - # latest_version and type - row = [proj.raw_name, str(proj.version)] - - if running_outdated: - row.append(str(proj.latest_version)) - row.append(proj.latest_filetype) - - if has_editables: - row.append(proj.editable_project_location or "") - - if options.verbose >= 1: - row.append(proj.location or "") - if options.verbose >= 1: - row.append(proj.installer) - - data.append(row) - - return data, header - - -def format_for_json(packages: "_ProcessedDists", options: Values) -> str: - data = [] - for dist in packages: - info = { - "name": dist.raw_name, - "version": str(dist.version), - } - if options.verbose >= 1: - info["location"] = dist.location or "" - info["installer"] = dist.installer - if options.outdated: - info["latest_version"] = str(dist.latest_version) - info["latest_filetype"] = dist.latest_filetype - editable_project_location = dist.editable_project_location - if editable_project_location: - info["editable_project_location"] = editable_project_location - data.append(info) - return json.dumps(data) diff --git a/venv/lib/python3.12/site-packages/pip/_internal/commands/search.py b/venv/lib/python3.12/site-packages/pip/_internal/commands/search.py deleted file mode 100644 index 03ed925..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/commands/search.py +++ /dev/null @@ -1,174 +0,0 @@ -import logging -import shutil -import sys -import textwrap -import xmlrpc.client -from collections import OrderedDict -from optparse import Values -from typing import TYPE_CHECKING, Dict, List, Optional - -from pip._vendor.packaging.version import parse as parse_version - -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.metadata import get_default_environment -from pip._internal.models.index import PyPI -from pip._internal.network.xmlrpc import PipXmlrpcTransport -from pip._internal.utils.logging import indent_log -from pip._internal.utils.misc import write_output - -if TYPE_CHECKING: - from typing import TypedDict - - class TransformedHit(TypedDict): - name: str - summary: str - versions: List[str] - - -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 add_options(self) -> None: - 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: Values, args: List[str]) -> int: - 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 = shutil.get_terminal_size()[0] - - print_results(hits, terminal_width=terminal_width) - if pypi_hits: - return SUCCESS - return NO_MATCHES_FOUND - - def search(self, query: List[str], options: Values) -> List[Dict[str, str]]: - index_url = options.index - - session = self.get_default_session(options) - - transport = PipXmlrpcTransport(index_url, session) - pypi = xmlrpc.client.ServerProxy(index_url, transport) - try: - hits = pypi.search({"name": query, "summary": query}, "or") - except xmlrpc.client.Fault as fault: - message = "XMLRPC request failed [code: {code}]\n{string}".format( - code=fault.faultCode, - string=fault.faultString, - ) - raise CommandError(message) - assert isinstance(hits, list) - return hits - - -def transform_hits(hits: List[Dict[str, str]]) -> List["TransformedHit"]: - """ - The list from pypi is really a list of versions. We want a list of - packages with the list of versions stored inline. This converts the - list from pypi into one we can use. - """ - packages: Dict[str, "TransformedHit"] = 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_dist_installation_info(name: str, latest: str) -> None: - env = get_default_environment() - dist = env.get_distribution(name) - if dist is not None: - with indent_log(): - if dist.version == latest: - write_output("INSTALLED: %s (latest)", dist.version) - else: - write_output("INSTALLED: %s", dist.version) - if parse_version(latest).pre: - write_output( - "LATEST: %s (pre-release; install" - " with `pip install --pre`)", - latest, - ) - else: - write_output("LATEST: %s", latest) - - -def print_results( - hits: List["TransformedHit"], - name_column_width: Optional[int] = None, - terminal_width: Optional[int] = None, -) -> None: - if not hits: - return - if name_column_width is None: - name_column_width = ( - max( - [ - len(hit["name"]) + len(highest_version(hit.get("versions", ["-"]))) - for hit in hits - ] - ) - + 4 - ) - - 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_lines = textwrap.wrap(summary, target_width) - summary = ("\n" + " " * (name_column_width + 3)).join(summary_lines) - - name_latest = f"{name} ({latest})" - line = f"{name_latest:{name_column_width}} - {summary}" - try: - write_output(line) - print_dist_installation_info(name, latest) - except UnicodeEncodeError: - pass - - -def highest_version(versions: List[str]) -> str: - return max(versions, key=parse_version) diff --git a/venv/lib/python3.12/site-packages/pip/_internal/commands/show.py b/venv/lib/python3.12/site-packages/pip/_internal/commands/show.py deleted file mode 100644 index 3f10701..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/commands/show.py +++ /dev/null @@ -1,189 +0,0 @@ -import logging -from optparse import Values -from typing import Generator, Iterable, Iterator, List, NamedTuple, Optional - -from pip._vendor.packaging.utils import canonicalize_name - -from pip._internal.cli.base_command import Command -from pip._internal.cli.status_codes import ERROR, SUCCESS -from pip._internal.metadata import BaseDistribution, get_default_environment -from pip._internal.utils.misc import write_output - -logger = logging.getLogger(__name__) - - -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 add_options(self) -> None: - 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: Values, args: List[str]) -> int: - 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 - - -class _PackageInfo(NamedTuple): - name: str - version: str - location: str - editable_project_location: Optional[str] - requires: List[str] - required_by: List[str] - installer: str - metadata_version: str - classifiers: List[str] - summary: str - homepage: str - project_urls: List[str] - author: str - author_email: str - license: str - entry_points: List[str] - files: Optional[List[str]] - - -def search_packages_info(query: List[str]) -> Generator[_PackageInfo, None, None]: - """ - Gather details from installed distributions. Print distribution name, - version, location, and installed files. Installed files requires a - pip generated 'installed-files.txt' in the distributions '.egg-info' - directory. - """ - env = get_default_environment() - - installed = {dist.canonical_name: dist for dist in env.iter_all_distributions()} - query_names = [canonicalize_name(name) for name in query] - missing = sorted( - [name for name, pkg in zip(query, query_names) if pkg not in installed] - ) - if missing: - logger.warning("Package(s) not found: %s", ", ".join(missing)) - - def _get_requiring_packages(current_dist: BaseDistribution) -> Iterator[str]: - return ( - dist.metadata["Name"] or "UNKNOWN" - for dist in installed.values() - if current_dist.canonical_name - in {canonicalize_name(d.name) for d in dist.iter_dependencies()} - ) - - for query_name in query_names: - try: - dist = installed[query_name] - except KeyError: - continue - - requires = sorted((req.name for req in dist.iter_dependencies()), key=str.lower) - required_by = sorted(_get_requiring_packages(dist), key=str.lower) - - try: - entry_points_text = dist.read_text("entry_points.txt") - entry_points = entry_points_text.splitlines(keepends=False) - except FileNotFoundError: - entry_points = [] - - files_iter = dist.iter_declared_entries() - if files_iter is None: - files: Optional[List[str]] = None - else: - files = sorted(files_iter) - - metadata = dist.metadata - - yield _PackageInfo( - name=dist.raw_name, - version=str(dist.version), - location=dist.location or "", - editable_project_location=dist.editable_project_location, - requires=requires, - required_by=required_by, - installer=dist.installer, - metadata_version=dist.metadata_version or "", - classifiers=metadata.get_all("Classifier", []), - summary=metadata.get("Summary", ""), - homepage=metadata.get("Home-page", ""), - project_urls=metadata.get_all("Project-URL", []), - author=metadata.get("Author", ""), - author_email=metadata.get("Author-email", ""), - license=metadata.get("License", ""), - entry_points=entry_points, - files=files, - ) - - -def print_results( - distributions: Iterable[_PackageInfo], - list_files: bool, - verbose: bool, -) -> bool: - """ - Print the information from installed distributions found. - """ - results_printed = False - for i, dist in enumerate(distributions): - results_printed = True - if i > 0: - write_output("---") - - write_output("Name: %s", dist.name) - write_output("Version: %s", dist.version) - write_output("Summary: %s", dist.summary) - write_output("Home-page: %s", dist.homepage) - write_output("Author: %s", dist.author) - write_output("Author-email: %s", dist.author_email) - write_output("License: %s", dist.license) - write_output("Location: %s", dist.location) - if dist.editable_project_location is not None: - write_output( - "Editable project location: %s", dist.editable_project_location - ) - write_output("Requires: %s", ", ".join(dist.requires)) - write_output("Required-by: %s", ", ".join(dist.required_by)) - - if verbose: - write_output("Metadata-Version: %s", dist.metadata_version) - write_output("Installer: %s", dist.installer) - write_output("Classifiers:") - for classifier in dist.classifiers: - write_output(" %s", classifier) - write_output("Entry-points:") - for entry in dist.entry_points: - write_output(" %s", entry.strip()) - write_output("Project-URLs:") - for project_url in dist.project_urls: - write_output(" %s", project_url) - if list_files: - write_output("Files:") - if dist.files is None: - write_output("Cannot locate RECORD or installed-files.txt") - else: - for line in dist.files: - write_output(" %s", line.strip()) - return results_printed diff --git a/venv/lib/python3.12/site-packages/pip/_internal/commands/uninstall.py b/venv/lib/python3.12/site-packages/pip/_internal/commands/uninstall.py deleted file mode 100644 index f198fc3..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/commands/uninstall.py +++ /dev/null @@ -1,113 +0,0 @@ -import logging -from optparse import Values -from typing import List - -from pip._vendor.packaging.utils import canonicalize_name - -from pip._internal.cli import cmdoptions -from pip._internal.cli.base_command import Command -from pip._internal.cli.req_command import SessionCommandMixin, warn_if_run_as_root -from pip._internal.cli.status_codes import SUCCESS -from pip._internal.exceptions import InstallationError -from pip._internal.req import parse_requirements -from pip._internal.req.constructors import ( - install_req_from_line, - install_req_from_parsed_requirement, -) -from pip._internal.utils.misc import ( - check_externally_managed, - protect_pip_from_modification_on_windows, -) - -logger = logging.getLogger(__name__) - - -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 add_options(self) -> None: - 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.cmd_opts.add_option(cmdoptions.root_user_action()) - self.cmd_opts.add_option(cmdoptions.override_externally_managed()) - self.parser.insert_option_group(0, self.cmd_opts) - - def run(self, options: Values, args: List[str]) -> int: - session = self.get_default_session(options) - - reqs_to_uninstall = {} - for name in args: - req = install_req_from_line( - name, - isolated=options.isolated_mode, - ) - if req.name: - reqs_to_uninstall[canonicalize_name(req.name)] = req - else: - logger.warning( - "Invalid requirement: %r ignored -" - " the uninstall command expects named" - " requirements.", - name, - ) - for filename in options.requirements: - for parsed_req in parse_requirements( - filename, options=options, session=session - ): - req = install_req_from_parsed_requirement( - parsed_req, isolated=options.isolated_mode - ) - if req.name: - reqs_to_uninstall[canonicalize_name(req.name)] = req - if not reqs_to_uninstall: - raise InstallationError( - f"You must give at least one requirement to {self.name} (see " - f'"pip help {self.name}")' - ) - - if not options.override_externally_managed: - check_externally_managed() - - protect_pip_from_modification_on_windows( - modifying_pip="pip" in reqs_to_uninstall - ) - - for req in reqs_to_uninstall.values(): - uninstall_pathset = req.uninstall( - auto_confirm=options.yes, - verbose=self.verbosity > 0, - ) - if uninstall_pathset: - uninstall_pathset.commit() - if options.root_user_action == "warn": - warn_if_run_as_root() - return SUCCESS diff --git a/venv/lib/python3.12/site-packages/pip/_internal/commands/wheel.py b/venv/lib/python3.12/site-packages/pip/_internal/commands/wheel.py deleted file mode 100644 index ed578aa..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/commands/wheel.py +++ /dev/null @@ -1,183 +0,0 @@ -import logging -import os -import shutil -from optparse import Values -from typing import List - -from pip._internal.cache import WheelCache -from pip._internal.cli import cmdoptions -from pip._internal.cli.req_command import RequirementCommand, with_cleanup -from pip._internal.cli.status_codes import SUCCESS -from pip._internal.exceptions import CommandError -from pip._internal.operations.build.build_tracker import get_build_tracker -from pip._internal.req.req_install import ( - InstallRequirement, - check_legacy_setup_py_options, -) -from pip._internal.utils.misc import ensure_dir, normalize_path -from pip._internal.utils.temp_dir import TempDirectory -from pip._internal.wheel_builder import build, should_build_for_wheel_command - -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/ - - 'pip wheel' uses the build system interface as described here: - https://pip.pypa.io/en/stable/reference/build-system/ - - """ - - usage = """ - %prog [options] ... - %prog [options] -r ... - %prog [options] [-e] ... - %prog [options] [-e] ... - %prog [options] ...""" - - def add_options(self) -> None: - self.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." - ), - ) - self.cmd_opts.add_option(cmdoptions.no_binary()) - self.cmd_opts.add_option(cmdoptions.only_binary()) - self.cmd_opts.add_option(cmdoptions.prefer_binary()) - self.cmd_opts.add_option(cmdoptions.no_build_isolation()) - self.cmd_opts.add_option(cmdoptions.use_pep517()) - self.cmd_opts.add_option(cmdoptions.no_use_pep517()) - self.cmd_opts.add_option(cmdoptions.check_build_deps()) - self.cmd_opts.add_option(cmdoptions.constraints()) - self.cmd_opts.add_option(cmdoptions.editable()) - self.cmd_opts.add_option(cmdoptions.requirements()) - self.cmd_opts.add_option(cmdoptions.src()) - self.cmd_opts.add_option(cmdoptions.ignore_requires_python()) - self.cmd_opts.add_option(cmdoptions.no_deps()) - self.cmd_opts.add_option(cmdoptions.progress_bar()) - - self.cmd_opts.add_option( - "--no-verify", - dest="no_verify", - action="store_true", - default=False, - help="Don't verify if built wheel is valid.", - ) - - self.cmd_opts.add_option(cmdoptions.config_settings()) - self.cmd_opts.add_option(cmdoptions.build_options()) - self.cmd_opts.add_option(cmdoptions.global_options()) - - self.cmd_opts.add_option( - "--pre", - action="store_true", - default=False, - help=( - "Include pre-release and development versions. By default, " - "pip only finds stable versions." - ), - ) - - self.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, self.cmd_opts) - - @with_cleanup - def run(self, options: Values, args: List[str]) -> int: - session = self.get_default_session(options) - - finder = self._build_package_finder(options, session) - - options.wheel_dir = normalize_path(options.wheel_dir) - ensure_dir(options.wheel_dir) - - build_tracker = self.enter_context(get_build_tracker()) - - directory = TempDirectory( - delete=not options.no_clean, - kind="wheel", - globally_managed=True, - ) - - reqs = self.get_requirements(args, options, finder, session) - check_legacy_setup_py_options(options, reqs) - - wheel_cache = WheelCache(options.cache_dir) - - preparer = self.make_requirement_preparer( - temp_build_dir=directory, - options=options, - build_tracker=build_tracker, - session=session, - finder=finder, - download_dir=options.wheel_dir, - use_user_site=False, - verbosity=self.verbosity, - ) - - 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) - - requirement_set = resolver.resolve(reqs, check_supported_wheels=True) - - reqs_to_build: List[InstallRequirement] = [] - for req in requirement_set.requirements.values(): - if req.is_wheel: - preparer.save_linked_requirement(req) - elif should_build_for_wheel_command(req): - reqs_to_build.append(req) - - preparer.prepare_linked_requirements_more(requirement_set.requirements.values()) - requirement_set.warn_legacy_versions_and_specifiers() - - # build wheels - build_successes, build_failures = build( - reqs_to_build, - wheel_cache=wheel_cache, - verify=(not options.no_verify), - 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") - - return SUCCESS diff --git a/venv/lib/python3.12/site-packages/pip/_internal/configuration.py b/venv/lib/python3.12/site-packages/pip/_internal/configuration.py deleted file mode 100644 index c25273d..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/configuration.py +++ /dev/null @@ -1,383 +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 -""" - -import configparser -import locale -import os -import sys -from typing import Any, Dict, Iterable, List, NewType, Optional, Tuple - -from pip._internal.exceptions import ( - ConfigurationError, - ConfigurationFileCouldNotBeLoaded, -) -from pip._internal.utils import appdirs -from pip._internal.utils.compat import WINDOWS -from pip._internal.utils.logging import getLogger -from pip._internal.utils.misc import ensure_dir, enum - -RawConfigParser = configparser.RawConfigParser # Shorthand -Kind = NewType("Kind", str) - -CONFIG_BASENAME = "pip.ini" if WINDOWS else "pip.conf" -ENV_NAMES_IGNORED = "version", "help" - -# The kinds of configurations there are. -kinds = enum( - USER="user", # User Specific - GLOBAL="global", # System Wide - SITE="site", # [Virtual] Environment Specific - ENV="env", # from PIP_CONFIG_FILE - ENV_VAR="env-var", # from Environment Variables -) -OVERRIDE_ORDER = kinds.GLOBAL, kinds.USER, kinds.SITE, kinds.ENV, kinds.ENV_VAR -VALID_LOAD_ONLY = kinds.USER, kinds.GLOBAL, kinds.SITE - -logger = getLogger(__name__) - - -# NOTE: Maybe use the optionx attribute to normalize keynames. -def _normalize_name(name: str) -> str: - """Make a name consistent regardless of source (environment or file)""" - name = name.lower().replace("_", "-") - if name.startswith("--"): - name = name[2:] # only prefer long opts - return name - - -def _disassemble_key(name: str) -> List[str]: - if "." not in name: - error_message = ( - "Key does not contain dot separated section and key. " - f"Perhaps you wanted to use 'global.{name}' instead?" - ) - raise ConfigurationError(error_message) - return name.split(".", 1) - - -def get_configuration_files() -> Dict[Kind, List[str]]: - global_config_files = [ - os.path.join(path, CONFIG_BASENAME) for path in appdirs.site_config_dirs("pip") - ] - - site_config_file = os.path.join(sys.prefix, CONFIG_BASENAME) - legacy_config_file = os.path.join( - os.path.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: - """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: bool, load_only: Optional[Kind] = None) -> None: - super().__init__() - - if load_only is not None and 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)) - ) - ) - self.isolated = isolated - self.load_only = load_only - - # Because we keep track of where we got the data from - self._parsers: Dict[Kind, List[Tuple[str, RawConfigParser]]] = { - variant: [] for variant in OVERRIDE_ORDER - } - self._config: Dict[Kind, Dict[str, Any]] = { - variant: {} for variant in OVERRIDE_ORDER - } - self._modified_parsers: List[Tuple[str, RawConfigParser]] = [] - - def load(self) -> None: - """Loads configuration from configuration files and environment""" - self._load_config_files() - if not self.isolated: - self._load_environment_vars() - - def get_file_to_edit(self) -> 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) -> Iterable[Tuple[str, Any]]: - """Returns key-value pairs like dict.items() representing the loaded - configuration - """ - return self._dictionary.items() - - def get_value(self, key: str) -> Any: - """Get a value from the configuration.""" - orig_key = key - key = _normalize_name(key) - try: - return self._dictionary[key] - except KeyError: - # disassembling triggers a more useful error message than simply - # "No such key" in the case that the key isn't in the form command.option - _disassemble_key(key) - raise ConfigurationError(f"No such key - {orig_key}") - - def set_value(self, key: str, value: Any) -> None: - """Modify a value in the configuration.""" - key = _normalize_name(key) - self._ensure_have_load_only() - - assert self.load_only - 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: str) -> None: - """Unset a value in the configuration.""" - orig_key = key - key = _normalize_name(key) - self._ensure_have_load_only() - - assert self.load_only - if key not in self._config[self.load_only]: - raise ConfigurationError(f"No such key - {orig_key}") - - fname, parser = self._get_parser_to_modify() - - if parser is not None: - section, name = _disassemble_key(key) - if not ( - parser.has_section(section) and parser.remove_option(section, name) - ): - # The option was not removed. - raise ConfigurationError( - "Fatal Internal error [id=1]. Please report as a bug." - ) - - # The section may be empty after the option was removed. - if not parser.items(section): - parser.remove_section(section) - self._mark_as_modified(fname, parser) - - del self._config[self.load_only][key] - - def save(self) -> 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)) - - # Ensure directory's permission(need to be writeable) - try: - with open(fname, "w") as f: - parser.write(f) - except OSError as error: - raise ConfigurationError( - f"An error occurred while writing to the configuration file " - f"{fname}: {error}" - ) - - # - # Private routines - # - - def _ensure_have_load_only(self) -> 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) -> 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 OVERRIDE_ORDER: - retval.update(self._config[variant]) - - return retval - - def _load_config_files(self) -> None: - """Loads configuration from configuration files""" - config_files = dict(self.iter_config_files()) - if config_files[kinds.ENV][0:1] == [os.devnull]: - logger.debug( - "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: Kind, fname: str) -> RawConfigParser: - logger.verbose("For variant '%s', will try loading '%s'", variant, fname) - parser = self._construct_parser(fname) - - for section in parser.sections(): - items = parser.items(section) - self._config[variant].update(self._normalized_keys(section, items)) - - return parser - - def _construct_parser(self, fname: str) -> RawConfigParser: - parser = configparser.RawConfigParser() - # If there is no such file, don't bother reading it but create the - # parser anyway, to hold the data. - # Doing this is useful when modifying and saving files, where we don't - # need to construct a parser. - if os.path.exists(fname): - locale_encoding = locale.getpreferredencoding(False) - try: - parser.read(fname, encoding=locale_encoding) - except UnicodeDecodeError: - # See https://github.com/pypa/pip/issues/4963 - raise ConfigurationFileCouldNotBeLoaded( - reason=f"contains invalid {locale_encoding} characters", - 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) -> 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: str, items: Iterable[Tuple[str, Any]] - ) -> Dict[str, Any]: - """Normalizes items to construct a dictionary with normalized keys. - - This routine is where the names become keys and are made the same - 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) -> Iterable[Tuple[str, str]]: - """Returns a generator with all environmental vars with prefix PIP_""" - for key, val in os.environ.items(): - if key.startswith("PIP_"): - name = key[4:].lower() - if name not in ENV_NAMES_IGNORED: - yield name, val - - # XXX: This is patched in the tests. - def iter_config_files(self) -> Iterable[Tuple[Kind, List[str]]]: - """Yields variant and configuration files associated with it. - - This should be treated like items of a dictionary. The order - here doesn't affect what gets overridden. That is controlled - by OVERRIDE_ORDER. However this does control the order they are - displayed to the user. It's probably most ergononmic to display - things in the same order as OVERRIDE_ORDER - """ - # SMELL: Move the conditions out of this function - - env_config_file = os.environ.get("PIP_CONFIG_FILE", None) - config_files = get_configuration_files() - - yield kinds.GLOBAL, config_files[kinds.GLOBAL] - - # per-user config is not loaded when env_config_file exists - should_load_user_config = not self.isolated and not ( - env_config_file and os.path.exists(env_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] - - # virtualenv config - yield kinds.SITE, config_files[kinds.SITE] - - if env_config_file is not None: - yield kinds.ENV, [env_config_file] - else: - yield kinds.ENV, [] - - def get_values_in_config(self, variant: Kind) -> Dict[str, Any]: - """Get values present in a config file""" - return self._config[variant] - - def _get_parser_to_modify(self) -> Tuple[str, RawConfigParser]: - # Determine which parser to modify - assert self.load_only - 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: str, parser: RawConfigParser) -> None: - file_parser_tuple = (fname, parser) - if file_parser_tuple not in self._modified_parsers: - self._modified_parsers.append(file_parser_tuple) - - def __repr__(self) -> str: - return f"{self.__class__.__name__}({self._dictionary!r})" diff --git a/venv/lib/python3.12/site-packages/pip/_internal/distributions/__init__.py b/venv/lib/python3.12/site-packages/pip/_internal/distributions/__init__.py deleted file mode 100644 index 9a89a83..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/distributions/__init__.py +++ /dev/null @@ -1,21 +0,0 @@ -from pip._internal.distributions.base import AbstractDistribution -from pip._internal.distributions.sdist import SourceDistribution -from pip._internal.distributions.wheel import WheelDistribution -from pip._internal.req.req_install import InstallRequirement - - -def make_distribution_for_install_requirement( - install_req: InstallRequirement, -) -> AbstractDistribution: - """Returns a Distribution for the given InstallRequirement""" - # Editable requirements will always be source distributions. They use the - # legacy logic until we create a modern standard for them. - 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.12/site-packages/pip/_internal/distributions/__pycache__/__init__.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/distributions/__pycache__/__init__.cpython-312.pyc deleted file mode 100644 index 38d57867eb1ff5d8e5393978b094651b283f06b0..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 951 zcmaJ;zi-n(6uzq++a*b(mM$m)xk5s6tJnet1}Y#TOBaON0m+Ny#MkDCf938Hl&S** zJ7XEMBK{PXhzuZ$NJvaz=u^MWT?&^RGL=QBAkJUhbqq@exu-1Rb zmKM&o>rF10-x3W9o;G`eCNboK-wA2cNe7~x#P{vH_Z&_I zsil6a5Tu0BW z^~?m4_HUB*G6`-seNLDhX|{7!8P9L!KYL}}pD)jD{@o8G+OQUqnFep>THhnKA#n+| zOJhGuf?h}-v26(DxcD8|rV7S*g6b3WWP%<~(Ee20zez9yaTpaXig>cRRaI z>ZpeZRiZsqoKUZ=kbtNh_yhP4IM50NXrU4kaNuT|f~uZ)Z`SMBZCb%fJNst#y_xs% zd%xXp#>NT+t{at)#kW~Pe#1#}={;ey3Bq;42-6%=!)MCTTB%w}LpklFTbWu$$r(p) zWoua_>rSp^)C`TJ$UB5(FB6vIOj48m#S{cZ1M!ocH;KwvfEV-O%1Thmd@4viUU# zA3;c*)HFtFDW=uZEX6Y{%`%P571Gd{etEQ}^X&QJ;0CeG(%j(r379le5Lo6`Po-7> z{XN_2kAh}yKy&N~ng%bjJRfHTxX~AbjSN_ou8@mbZO2(s9*uU-)ggAv4hM5!eU>6* zj@BVH)OM^OpbbybrsXn6xJy*T>9Oh#r>NsFOcz{@?S;ZzLJkFgQZRS`C6z{9pb6w8smZyqui{w zg#+t=q-8F*5;ai7CGK(=d(w8rg?9fu>^=0rqXOaqICUN?^LB?+l)q6L&=zGS6id1b zHsH2@AsgVmc@&0EwCg17zq*>bM6LlZB`v3sOWGx3_N_Z)Lt7}PBRy#QTt{V+$9+BL0^##M!m>y;6J3567Z*)2Z6DkG|g;F3TLdU(D;7d)3AK_vthSYy!8 z!~u1Ch{Hw$tZa)rpr{1KbaAobOYU2en}dln6J*bn7Z;%`9S3$+bYlbOb5_~VqFoDK zIN$Oe#r>SUC8Z}fG&v602rw5^?tn2WsW8kQ>P^Acp5L|%kE&7JXAFjQa(|SJANsC% z__lFa;z#ZOmO+k!k=%^~)@snZi6tKPgB?o2T4h@|pQt~BJCDGyPJS;wH{flQZKw}v zG#-a20?)CK(V~*wp$RYE3k4#C0_?nSAXC;(KO9+UV7CGkf=V$e~h?s<+ph~ij}eQfSH zrdifx304&d-c%5k23p~O%oThJ!-LD@uT)7ly3;9r@9q7SE`jG)ul$XVu0gW-AN7el z`b0OS>(e)8zBqn!_8tLoGflFSYOz~XN_+2seoE7)Z@={VJpxbE*r!&y*#V8LKK*Oy zKv#z+tWO^7=1?-o)U(|@N(E9V-Wvf)+22orq&h))4S!>K>{msx%p0*JC<$A>RQ zoV7zhk(EA0RuGOCD?R=+V|2z@n;KS3SfGM5sxlny7}fyVQk9Exb0<%|3r;AHHc0Fp z62L>_L|pneBz|L%8G>mTx@k?*ekO&xWaZl3#xfT(u) E7vEbQ9RL6T diff --git a/venv/lib/python3.12/site-packages/pip/_internal/distributions/__pycache__/installed.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/distributions/__pycache__/installed.cpython-312.pyc deleted file mode 100644 index 2cd81041018bb4110e05d113de138ca304177d39..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1710 zcma)6&2Jk;6rcU{+OcD!G=a9XtWc=1P7bptKbQu^OlYt*zx)3-p1}Hgc>7=AhIrDMTfo5^9_h zYBKFPtc}vP(o)m<9br?+tk2?vN1-18zP8(uiSWD0eGVh<4ABGj+P>dC^bgo4Jfuv3 zq4AL~*)`3BR6Et5&w|?}@K|8ePxW@0 z8mt0mUZExURBH7sS_XSHwVIV|{Xr-bKL{9IJi_Rk&si*(WMLw0KeYKg$c~HCJC%wJ z@@1b(n?_99VU*Y*V-%uO8>Ys-@R70YOFQW^Td>DNF2K*jUL*#EuMbW?5X`4(zFdc~ z(C$Wqc$hHiM+4>xpYkx~ zA{vg|`%E4tQS9!DBR|~Q-G8w4alqXp79P0)@3?WA^rLXcdH=2}dBV14T%{ZH*!6gr zFafo7=|VxJdyyI^PP0a5$OGzO-4B`YI33-&GQZB{xH=qJVt<~H7xlF%0J6kb1w+ob z58#Y^MIK?uC3%EVm*k|>f;OKw#@EXKpZNu8s(YgiEG%^K5PBs2rw^KHra?)ws)S0) z9%t0+q@o6!7ugp`D7${Z5^ul~pZbaKE#__HUY(bJov?;WJD^U;FZH!2$KM|RT;Ke$ zzB#UMkFD1DZtEw|_3dS!wJBc1bC|vSvSsxm?OaAd-hf%7+h^TFuP{><%e^kP)S@i) znOFgrsDf(hVioZQs@GAy0ZQU*ych-lTg63SOVlqCGTOO12md(ocUylFfKzR5oS3Td z&iK6#rUb@`Wg4{?jaw4~#)(O8+@6#WS>)zhlQN_o9#8rnVF<94-bmd z+i*Lbi`(fecA0cK@U{vpO7`}07&gSQGrQql(H{lrjpe|3`xd#$c`xVUm36Pk_lM#R nY=n=GybWriDT;DVZvIAg&&j=Wvh&hhS8C%oxBntA=7jzR8?ee^ diff --git a/venv/lib/python3.12/site-packages/pip/_internal/distributions/__pycache__/sdist.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/distributions/__pycache__/sdist.cpython-312.pyc deleted file mode 100644 index 4bbe5b6dc2117cf6665bc9af548d0783f537c8db..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 8498 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 None: - super().__init__() - self.req = req - - @abc.abstractproperty - def build_tracker_id(self) -> Optional[str]: - """A string that uniquely identifies this requirement to the build tracker. - - If None, then this dist has no work to do in the build tracker, and - ``.prepare_distribution_metadata()`` will not be called.""" - raise NotImplementedError() - - @abc.abstractmethod - def get_metadata_distribution(self) -> BaseDistribution: - raise NotImplementedError() - - @abc.abstractmethod - def prepare_distribution_metadata( - self, - finder: PackageFinder, - build_isolation: bool, - check_build_deps: bool, - ) -> None: - raise NotImplementedError() diff --git a/venv/lib/python3.12/site-packages/pip/_internal/distributions/installed.py b/venv/lib/python3.12/site-packages/pip/_internal/distributions/installed.py deleted file mode 100644 index ab8d53b..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/distributions/installed.py +++ /dev/null @@ -1,29 +0,0 @@ -from typing import Optional - -from pip._internal.distributions.base import AbstractDistribution -from pip._internal.index.package_finder import PackageFinder -from pip._internal.metadata import BaseDistribution - - -class InstalledDistribution(AbstractDistribution): - """Represents an installed package. - - This does not need any preparation as the required information has already - been computed. - """ - - @property - def build_tracker_id(self) -> Optional[str]: - return None - - def get_metadata_distribution(self) -> BaseDistribution: - assert self.req.satisfied_by is not None, "not actually installed" - return self.req.satisfied_by - - def prepare_distribution_metadata( - self, - finder: PackageFinder, - build_isolation: bool, - check_build_deps: bool, - ) -> None: - pass diff --git a/venv/lib/python3.12/site-packages/pip/_internal/distributions/sdist.py b/venv/lib/python3.12/site-packages/pip/_internal/distributions/sdist.py deleted file mode 100644 index 15ff42b..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/distributions/sdist.py +++ /dev/null @@ -1,156 +0,0 @@ -import logging -from typing import Iterable, Optional, Set, Tuple - -from pip._internal.build_env import BuildEnvironment -from pip._internal.distributions.base import AbstractDistribution -from pip._internal.exceptions import InstallationError -from pip._internal.index.package_finder import PackageFinder -from pip._internal.metadata import BaseDistribution -from pip._internal.utils.subprocess import runner_with_spinner_message - -logger = logging.getLogger(__name__) - - -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`. - """ - - @property - def build_tracker_id(self) -> Optional[str]: - """Identify this requirement uniquely by its link.""" - assert self.req.link - return self.req.link.url_without_fragment - - def get_metadata_distribution(self) -> BaseDistribution: - return self.req.get_dist() - - def prepare_distribution_metadata( - self, - finder: PackageFinder, - build_isolation: bool, - check_build_deps: bool, - ) -> None: - # Load pyproject.toml, to determine whether PEP 517 is to be used - self.req.load_pyproject_toml() - - # Set up the build isolation, if this requirement should be isolated - should_isolate = self.req.use_pep517 and build_isolation - if should_isolate: - # Setup an isolated environment and install the build backend static - # requirements in it. - self._prepare_build_backend(finder) - # Check that if the requirement is editable, it either supports PEP 660 or - # has a setup.py or a setup.cfg. This cannot be done earlier because we need - # to setup the build backend to verify it supports build_editable, nor can - # it be done later, because we want to avoid installing build requirements - # needlessly. Doing it here also works around setuptools generating - # UNKNOWN.egg-info when running get_requires_for_build_wheel on a directory - # without setup.py nor setup.cfg. - self.req.isolated_editable_sanity_check() - # Install the dynamic build requirements. - self._install_build_reqs(finder) - # Check if the current environment provides build dependencies - should_check_deps = self.req.use_pep517 and check_build_deps - if should_check_deps: - pyproject_requires = self.req.pyproject_requires - assert pyproject_requires is not None - conflicting, missing = self.req.build_env.check_requirements( - pyproject_requires - ) - if conflicting: - self._raise_conflicts("the backend dependencies", conflicting) - if missing: - self._raise_missing_reqs(missing) - self.req.prepare_metadata() - - def _prepare_build_backend(self, finder: PackageFinder) -> None: - # Isolate in a BuildEnvironment and install the build-time - # requirements. - pyproject_requires = self.req.pyproject_requires - assert pyproject_requires is not None - - self.req.build_env = BuildEnvironment() - self.req.build_env.install_requirements( - finder, pyproject_requires, "overlay", kind="build dependencies" - ) - conflicting, missing = self.req.build_env.check_requirements( - self.req.requirements_to_check - ) - if conflicting: - self._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))), - ) - - def _get_build_requires_wheel(self) -> Iterable[str]: - with self.req.build_env: - runner = runner_with_spinner_message("Getting requirements to build wheel") - backend = self.req.pep517_backend - assert backend is not None - with backend.subprocess_runner(runner): - return backend.get_requires_for_build_wheel() - - def _get_build_requires_editable(self) -> Iterable[str]: - with self.req.build_env: - runner = runner_with_spinner_message( - "Getting requirements to build editable" - ) - backend = self.req.pep517_backend - assert backend is not None - with backend.subprocess_runner(runner): - return backend.get_requires_for_build_editable() - - def _install_build_reqs(self, finder: PackageFinder) -> None: - # Install any extra build dependencies that the backend requests. - # This must be done in a second pass, as the pyproject.toml - # dependencies must be installed before we can call the backend. - if ( - self.req.editable - and self.req.permit_editable_wheels - and self.req.supports_pyproject_editable() - ): - build_reqs = self._get_build_requires_editable() - else: - build_reqs = self._get_build_requires_wheel() - conflicting, missing = self.req.build_env.check_requirements(build_reqs) - if conflicting: - self._raise_conflicts("the backend dependencies", conflicting) - self.req.build_env.install_requirements( - finder, missing, "normal", kind="backend dependencies" - ) - - def _raise_conflicts( - self, conflicting_with: str, conflicting_reqs: Set[Tuple[str, str]] - ) -> None: - format_string = ( - "Some build dependencies for {requirement} " - "conflict with {conflicting_with}: {description}." - ) - error_message = format_string.format( - requirement=self.req, - conflicting_with=conflicting_with, - description=", ".join( - f"{installed} is incompatible with {wanted}" - for installed, wanted in sorted(conflicting_reqs) - ), - ) - raise InstallationError(error_message) - - def _raise_missing_reqs(self, missing: Set[str]) -> None: - format_string = ( - "Some build dependencies for {requirement} are missing: {missing}." - ) - error_message = format_string.format( - requirement=self.req, missing=", ".join(map(repr, sorted(missing))) - ) - raise InstallationError(error_message) diff --git a/venv/lib/python3.12/site-packages/pip/_internal/distributions/wheel.py b/venv/lib/python3.12/site-packages/pip/_internal/distributions/wheel.py deleted file mode 100644 index eb16e25..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/distributions/wheel.py +++ /dev/null @@ -1,40 +0,0 @@ -from typing import Optional - -from pip._vendor.packaging.utils import canonicalize_name - -from pip._internal.distributions.base import AbstractDistribution -from pip._internal.index.package_finder import PackageFinder -from pip._internal.metadata import ( - BaseDistribution, - FilesystemWheel, - get_wheel_distribution, -) - - -class WheelDistribution(AbstractDistribution): - """Represents a wheel distribution. - - This does not need any preparation as wheels can be directly unpacked. - """ - - @property - def build_tracker_id(self) -> Optional[str]: - return None - - def get_metadata_distribution(self) -> BaseDistribution: - """Loads the metadata from the wheel file into memory and returns a - Distribution that uses it, not relying on the wheel file or - requirement. - """ - assert self.req.local_file_path, "Set as part of preparation during download" - assert self.req.name, "Wheels are never unnamed" - wheel = FilesystemWheel(self.req.local_file_path) - return get_wheel_distribution(wheel, canonicalize_name(self.req.name)) - - def prepare_distribution_metadata( - self, - finder: PackageFinder, - build_isolation: bool, - check_build_deps: bool, - ) -> None: - pass diff --git a/venv/lib/python3.12/site-packages/pip/_internal/exceptions.py b/venv/lib/python3.12/site-packages/pip/_internal/exceptions.py deleted file mode 100644 index 5007a62..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/exceptions.py +++ /dev/null @@ -1,728 +0,0 @@ -"""Exceptions used throughout package. - -This module MUST NOT try to import from anything within `pip._internal` to -operate. This is expected to be importable from any/all files within the -subpackage and, thus, should not depend on them. -""" - -import configparser -import contextlib -import locale -import logging -import pathlib -import re -import sys -from itertools import chain, groupby, repeat -from typing import TYPE_CHECKING, Dict, Iterator, List, Optional, Union - -from pip._vendor.requests.models import Request, Response -from pip._vendor.rich.console import Console, ConsoleOptions, RenderResult -from pip._vendor.rich.markup import escape -from pip._vendor.rich.text import Text - -if TYPE_CHECKING: - from hashlib import _Hash - from typing import Literal - - from pip._internal.metadata import BaseDistribution - from pip._internal.req.req_install import InstallRequirement - -logger = logging.getLogger(__name__) - - -# -# Scaffolding -# -def _is_kebab_case(s: str) -> bool: - return re.match(r"^[a-z]+(-[a-z]+)*$", s) is not None - - -def _prefix_with_indent( - s: Union[Text, str], - console: Console, - *, - prefix: str, - indent: str, -) -> Text: - if isinstance(s, Text): - text = s - else: - text = console.render_str(s) - - return console.render_str(prefix, overflow="ignore") + console.render_str( - f"\n{indent}", overflow="ignore" - ).join(text.split(allow_blank=True)) - - -class PipError(Exception): - """The base pip error.""" - - -class DiagnosticPipError(PipError): - """An error, that presents diagnostic information to the user. - - This contains a bunch of logic, to enable pretty presentation of our error - messages. Each error gets a unique reference. Each error can also include - additional context, a hint and/or a note -- which are presented with the - main error message in a consistent style. - - This is adapted from the error output styling in `sphinx-theme-builder`. - """ - - reference: str - - def __init__( - self, - *, - kind: 'Literal["error", "warning"]' = "error", - reference: Optional[str] = None, - message: Union[str, Text], - context: Optional[Union[str, Text]], - hint_stmt: Optional[Union[str, Text]], - note_stmt: Optional[Union[str, Text]] = None, - link: Optional[str] = None, - ) -> None: - # Ensure a proper reference is provided. - if reference is None: - assert hasattr(self, "reference"), "error reference not provided!" - reference = self.reference - assert _is_kebab_case(reference), "error reference must be kebab-case!" - - self.kind = kind - self.reference = reference - - self.message = message - self.context = context - - self.note_stmt = note_stmt - self.hint_stmt = hint_stmt - - self.link = link - - super().__init__(f"<{self.__class__.__name__}: {self.reference}>") - - def __repr__(self) -> str: - return ( - f"<{self.__class__.__name__}(" - f"reference={self.reference!r}, " - f"message={self.message!r}, " - f"context={self.context!r}, " - f"note_stmt={self.note_stmt!r}, " - f"hint_stmt={self.hint_stmt!r}" - ")>" - ) - - def __rich_console__( - self, - console: Console, - options: ConsoleOptions, - ) -> RenderResult: - colour = "red" if self.kind == "error" else "yellow" - - yield f"[{colour} bold]{self.kind}[/]: [bold]{self.reference}[/]" - yield "" - - if not options.ascii_only: - # Present the main message, with relevant context indented. - if self.context is not None: - yield _prefix_with_indent( - self.message, - console, - prefix=f"[{colour}]×[/] ", - indent=f"[{colour}]│[/] ", - ) - yield _prefix_with_indent( - self.context, - console, - prefix=f"[{colour}]╰─>[/] ", - indent=f"[{colour}] [/] ", - ) - else: - yield _prefix_with_indent( - self.message, - console, - prefix="[red]×[/] ", - indent=" ", - ) - else: - yield self.message - if self.context is not None: - yield "" - yield self.context - - if self.note_stmt is not None or self.hint_stmt is not None: - yield "" - - if self.note_stmt is not None: - yield _prefix_with_indent( - self.note_stmt, - console, - prefix="[magenta bold]note[/]: ", - indent=" ", - ) - if self.hint_stmt is not None: - yield _prefix_with_indent( - self.hint_stmt, - console, - prefix="[cyan bold]hint[/]: ", - indent=" ", - ) - - if self.link is not None: - yield "" - yield f"Link: {self.link}" - - -# -# Actual Errors -# -class ConfigurationError(PipError): - """General exception in configuration""" - - -class InstallationError(PipError): - """General exception during installation""" - - -class UninstallationError(PipError): - """General exception during uninstallation""" - - -class MissingPyProjectBuildRequires(DiagnosticPipError): - """Raised when pyproject.toml has `build-system`, but no `build-system.requires`.""" - - reference = "missing-pyproject-build-system-requires" - - def __init__(self, *, package: str) -> None: - super().__init__( - message=f"Can not process {escape(package)}", - context=Text( - "This package has an invalid pyproject.toml file.\n" - "The [build-system] table is missing the mandatory `requires` key." - ), - note_stmt="This is an issue with the package mentioned above, not pip.", - hint_stmt=Text("See PEP 518 for the detailed specification."), - ) - - -class InvalidPyProjectBuildRequires(DiagnosticPipError): - """Raised when pyproject.toml an invalid `build-system.requires`.""" - - reference = "invalid-pyproject-build-system-requires" - - def __init__(self, *, package: str, reason: str) -> None: - super().__init__( - message=f"Can not process {escape(package)}", - context=Text( - "This package has an invalid `build-system.requires` key in " - f"pyproject.toml.\n{reason}" - ), - note_stmt="This is an issue with the package mentioned above, not pip.", - hint_stmt=Text("See PEP 518 for the detailed specification."), - ) - - -class NoneMetadataError(PipError): - """Raised when accessing a Distribution's "METADATA" or "PKG-INFO". - - This signifies an inconsistency, when the Distribution claims to have - the metadata file (if not, raise ``FileNotFoundError`` instead), but is - not actually able to produce its content. This may be due to permission - errors. - """ - - def __init__( - self, - dist: "BaseDistribution", - metadata_name: 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) -> str: - # Use `dist` in the error message because its stringification - # includes more information, like the version and location. - return f"None {self.metadata_name} metadata found for distribution: {self.dist}" - - -class UserInstallationInvalid(InstallationError): - """A --user install is requested on an environment without user site.""" - - def __str__(self) -> str: - return "User base directory is not specified" - - -class InvalidSchemeCombination(InstallationError): - def __str__(self) -> str: - before = ", ".join(str(a) for a in self.args[:-1]) - return f"Cannot set {before} and {self.args[-1]} together" - - -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 NetworkConnectionError(PipError): - """HTTP connection error""" - - def __init__( - self, - error_msg: str, - response: Optional[Response] = None, - request: Optional[Request] = None, - ) -> None: - """ - Initialize NetworkConnectionError with `request` and `response` - objects. - """ - self.response = response - self.request = request - self.error_msg = error_msg - if ( - self.response is not None - and not self.request - and hasattr(response, "request") - ): - self.request = self.response.request - super().__init__(error_msg, response, request) - - def __str__(self) -> str: - return str(self.error_msg) - - -class InvalidWheelFilename(InstallationError): - """Invalid wheel filename.""" - - -class UnsupportedWheel(InstallationError): - """Unsupported wheel.""" - - -class InvalidWheel(InstallationError): - """Invalid (e.g. corrupt) wheel.""" - - def __init__(self, location: str, name: str): - self.location = location - self.name = name - - def __str__(self) -> str: - return f"Wheel '{self.name}' located at {self.location} is invalid." - - -class MetadataInconsistent(InstallationError): - """Built metadata contains inconsistent information. - - This is raised when the metadata contains values (e.g. name and version) - that do not match the information previously obtained from sdist filename, - user-supplied ``#egg=`` value, or an install requirement name. - """ - - def __init__( - self, ireq: "InstallRequirement", field: str, f_val: str, m_val: str - ) -> None: - self.ireq = ireq - self.field = field - self.f_val = f_val - self.m_val = m_val - - def __str__(self) -> str: - return ( - f"Requested {self.ireq} has inconsistent {self.field}: " - f"expected {self.f_val!r}, but metadata has {self.m_val!r}" - ) - - -class InstallationSubprocessError(DiagnosticPipError, InstallationError): - """A subprocess call failed.""" - - reference = "subprocess-exited-with-error" - - def __init__( - self, - *, - command_description: str, - exit_code: int, - output_lines: Optional[List[str]], - ) -> None: - if output_lines is None: - output_prompt = Text("See above for output.") - else: - output_prompt = ( - Text.from_markup(f"[red][{len(output_lines)} lines of output][/]\n") - + Text("".join(output_lines)) - + Text.from_markup(R"[red]\[end of output][/]") - ) - - super().__init__( - message=( - f"[green]{escape(command_description)}[/] did not run successfully.\n" - f"exit code: {exit_code}" - ), - context=output_prompt, - hint_stmt=None, - note_stmt=( - "This error originates from a subprocess, and is likely not a " - "problem with pip." - ), - ) - - self.command_description = command_description - self.exit_code = exit_code - - def __str__(self) -> str: - return f"{self.command_description} exited with {self.exit_code}" - - -class MetadataGenerationFailed(InstallationSubprocessError, InstallationError): - reference = "metadata-generation-failed" - - def __init__( - self, - *, - package_details: str, - ) -> None: - super(InstallationSubprocessError, self).__init__( - message="Encountered error while generating package metadata.", - context=escape(package_details), - hint_stmt="See above for details.", - note_stmt="This is an issue with the package mentioned above, not pip.", - ) - - def __str__(self) -> str: - return "metadata generation failed" - - -class HashErrors(InstallationError): - """Multiple HashError instances rolled into one for reporting""" - - def __init__(self) -> None: - self.errors: List["HashError"] = [] - - def append(self, error: "HashError") -> None: - self.errors.append(error) - - def __str__(self) -> str: - lines = [] - self.errors.sort(key=lambda e: e.order) - for cls, errors_of_cls in groupby(self.errors, lambda e: e.__class__): - lines.append(cls.head) - lines.extend(e.body() for e in errors_of_cls) - if lines: - return "\n".join(lines) - return "" - - def __bool__(self) -> bool: - return bool(self.errors) - - -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: Optional["InstallRequirement"] = None - head = "" - order: int = -1 - - def body(self) -> str: - """Return a summary of me for display under the heading. - - This default implementation simply prints a description of the - triggering requirement. - - :param req: The InstallRequirement that provoked this error, with - its link already populated by the resolver's _populate_link(). - - """ - return f" {self._requirement_name()}" - - def __str__(self) -> str: - return f"{self.head}\n{self.body()}" - - def _requirement_name(self) -> str: - """Return a description of the requirement that triggered me. - - This default implementation returns long description of the req, with - line numbers - - """ - return str(self.req) if self.req else "unknown package" - - -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: str) -> None: - """ - :param gotten_hash: The hash of the (possibly malicious) archive we - just downloaded - """ - self.gotten_hash = gotten_hash - - def body(self) -> str: - # 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.is_direct - # In case someone feeds something downright stupid - # to InstallRequirement's constructor. - else getattr(self.req, "req", None) - ) - return " {} --hash={}:{}".format( - package or "unknown package", FAVORITE_HASH, self.gotten_hash - ) - - -class HashUnpinned(HashError): - """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: Dict[str, List[str]], gots: Dict[str, "_Hash"]) -> None: - """ - :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) -> str: - return f" {self._requirement_name()}:\n{self._hash_comparison()}" - - def _hash_comparison(self) -> str: - """ - Return a comparison of actual and expected hash values. - - Example:: - - Expected sha256 abcdeabcdeabcdeabcdeabcdeabcdeabcdeabcdeabcde - or 123451234512345123451234512345123451234512345 - Got bcdefbcdefbcdefbcdefbcdefbcdefbcdefbcdefbcdef - - """ - - def hash_then_or(hash_name: str) -> "chain[str]": - # For now, all the decent hashes have 6-char names, so we can get - # away with hard-coding space literals. - return chain([hash_name], repeat(" or")) - - lines: List[str] = [] - for hash_name, expecteds in self.allowed.items(): - prefix = hash_then_or(hash_name) - lines.extend((f" Expected {next(prefix)} {e}") for e in expecteds) - lines.append( - f" Got {self.gots[hash_name].hexdigest()}\n" - ) - 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: str = "could not be loaded", - fname: Optional[str] = None, - error: Optional[configparser.Error] = None, - ) -> None: - super().__init__(error) - self.reason = reason - self.fname = fname - self.error = error - - def __str__(self) -> str: - if self.fname is not None: - message_part = f" in {self.fname}." - else: - assert self.error is not None - message_part = f".\n{self.error}\n" - return f"Configuration file {self.reason}{message_part}" - - -_DEFAULT_EXTERNALLY_MANAGED_ERROR = f"""\ -The Python environment under {sys.prefix} is managed externally, and may not be -manipulated by the user. Please use specific tooling from the distributor of -the Python installation to interact with this environment instead. -""" - - -class ExternallyManagedEnvironment(DiagnosticPipError): - """The current environment is externally managed. - - This is raised when the current environment is externally managed, as - defined by `PEP 668`_. The ``EXTERNALLY-MANAGED`` configuration is checked - and displayed when the error is bubbled up to the user. - - :param error: The error message read from ``EXTERNALLY-MANAGED``. - """ - - reference = "externally-managed-environment" - - def __init__(self, error: Optional[str]) -> None: - if error is None: - context = Text(_DEFAULT_EXTERNALLY_MANAGED_ERROR) - else: - context = Text(error) - super().__init__( - message="This environment is externally managed", - context=context, - note_stmt=( - "If you believe this is a mistake, please contact your " - "Python installation or OS distribution provider. " - "You can override this, at the risk of breaking your Python " - "installation or OS, by passing --break-system-packages." - ), - hint_stmt=Text("See PEP 668 for the detailed specification."), - ) - - @staticmethod - def _iter_externally_managed_error_keys() -> Iterator[str]: - # LC_MESSAGES is in POSIX, but not the C standard. The most common - # platform that does not implement this category is Windows, where - # using other categories for console message localization is equally - # unreliable, so we fall back to the locale-less vendor message. This - # can always be re-evaluated when a vendor proposes a new alternative. - try: - category = locale.LC_MESSAGES - except AttributeError: - lang: Optional[str] = None - else: - lang, _ = locale.getlocale(category) - if lang is not None: - yield f"Error-{lang}" - for sep in ("-", "_"): - before, found, _ = lang.partition(sep) - if not found: - continue - yield f"Error-{before}" - yield "Error" - - @classmethod - def from_config( - cls, - config: Union[pathlib.Path, str], - ) -> "ExternallyManagedEnvironment": - parser = configparser.ConfigParser(interpolation=None) - try: - parser.read(config, encoding="utf-8") - section = parser["externally-managed"] - for key in cls._iter_externally_managed_error_keys(): - with contextlib.suppress(KeyError): - return cls(section[key]) - except KeyError: - pass - except (OSError, UnicodeDecodeError, configparser.ParsingError): - from pip._internal.utils._log import VERBOSE - - exc_info = logger.isEnabledFor(VERBOSE) - logger.warning("Failed to read %s", config, exc_info=exc_info) - return cls(None) diff --git a/venv/lib/python3.12/site-packages/pip/_internal/index/__init__.py b/venv/lib/python3.12/site-packages/pip/_internal/index/__init__.py deleted file mode 100644 index 7a17b7b..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/index/__init__.py +++ /dev/null @@ -1,2 +0,0 @@ -"""Index interaction code -""" diff --git a/venv/lib/python3.12/site-packages/pip/_internal/index/__pycache__/__init__.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/index/__pycache__/__init__.cpython-312.pyc deleted file mode 100644 index 07c5a4ea6ce73e48459f13846ad6ed97e2e85777..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 242 zcmXv}F>V4e5VQd$=p^cN5iP~t3TP1$N*WrJn#MBc6|A_kEuT5%_(V!t+Poz{pydN7 zbX3?;m}X{H8qMraua~fZWA;U_fzQ!A!2iXy8^nPrwqy+-wDvD^t?;u?+M|=XC!_nh zQJ5?S{PZk@GPw}n>>ATIf{iH=oK&POIkVftJ62n7EX-UjbvpZ)r*8#8jk<<{R$v>y zF?yU0M^KT+)XID-*I0oi3*xU-%K|8F01*!4g~)7k>rP6eb_Gt|Q)rIktN7cc%{l*V Jao%yAVDHc*M796` diff --git a/venv/lib/python3.12/site-packages/pip/_internal/index/__pycache__/collector.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/index/__pycache__/collector.cpython-312.pyc deleted file mode 100644 index 942dea18aa9cf0a24b31c4a44718969d61068db2..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 21896 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 diff --git a/venv/lib/python3.12/site-packages/pip/_internal/index/__pycache__/package_finder.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/index/__pycache__/package_finder.cpython-312.pyc deleted file mode 100644 index fce1fd1ee9a03bb1b31377ca93454be61bccfd7d..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 40745 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 diff --git a/venv/lib/python3.12/site-packages/pip/_internal/index/__pycache__/sources.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/index/__pycache__/sources.cpython-312.pyc deleted file mode 100644 index e3f7f39c73df793e69a9097a4eb000621fff01da..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 12614 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 NoNaik9+`Y2{~x@S>|_7{ diff --git a/venv/lib/python3.12/site-packages/pip/_internal/index/collector.py b/venv/lib/python3.12/site-packages/pip/_internal/index/collector.py deleted file mode 100644 index 08c8bdd..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/index/collector.py +++ /dev/null @@ -1,507 +0,0 @@ -""" -The main purpose of this module is to expose LinkCollector.collect_sources(). -""" - -import collections -import email.message -import functools -import itertools -import json -import logging -import os -import urllib.parse -import urllib.request -from html.parser import HTMLParser -from optparse import Values -from typing import ( - TYPE_CHECKING, - Callable, - Dict, - Iterable, - List, - MutableMapping, - NamedTuple, - Optional, - Sequence, - Tuple, - Union, -) - -from pip._vendor import requests -from pip._vendor.requests import Response -from pip._vendor.requests.exceptions import RetryError, SSLError - -from pip._internal.exceptions import NetworkConnectionError -from pip._internal.models.link import Link -from pip._internal.models.search_scope import SearchScope -from pip._internal.network.session import PipSession -from pip._internal.network.utils import raise_for_status -from pip._internal.utils.filetypes import is_archive_file -from pip._internal.utils.misc import redact_auth_from_url -from pip._internal.vcs import vcs - -from .sources import CandidatesFromPage, LinkSource, build_source - -if TYPE_CHECKING: - from typing import Protocol -else: - Protocol = object - -logger = logging.getLogger(__name__) - -ResponseHeaders = MutableMapping[str, str] - - -def _match_vcs_scheme(url: str) -> Optional[str]: - """Look for VCS schemes in the URL. - - Returns the matched VCS scheme, or None if there's no match. - """ - for scheme in vcs.schemes: - if url.lower().startswith(scheme) and url[len(scheme)] in "+:": - return scheme - return None - - -class _NotAPIContent(Exception): - def __init__(self, content_type: str, request_desc: str) -> None: - super().__init__(content_type, request_desc) - self.content_type = content_type - self.request_desc = request_desc - - -def _ensure_api_header(response: Response) -> None: - """ - Check the Content-Type header to ensure the response contains a Simple - API Response. - - Raises `_NotAPIContent` if the content type is not a valid content-type. - """ - content_type = response.headers.get("Content-Type", "Unknown") - - content_type_l = content_type.lower() - if content_type_l.startswith( - ( - "text/html", - "application/vnd.pypi.simple.v1+html", - "application/vnd.pypi.simple.v1+json", - ) - ): - return - - raise _NotAPIContent(content_type, response.request.method) - - -class _NotHTTP(Exception): - pass - - -def _ensure_api_response(url: str, session: PipSession) -> None: - """ - Send a HEAD request to the URL, and ensure the response contains a simple - API Response. - - Raises `_NotHTTP` if the URL is not available for a HEAD request, or - `_NotAPIContent` if the content type is not a valid content type. - """ - scheme, netloc, path, query, fragment = urllib.parse.urlsplit(url) - if scheme not in {"http", "https"}: - raise _NotHTTP() - - resp = session.head(url, allow_redirects=True) - raise_for_status(resp) - - _ensure_api_header(resp) - - -def _get_simple_response(url: str, session: PipSession) -> Response: - """Access an Simple API response with GET, and return the response. - - This consists of three parts: - - 1. If the URL looks suspiciously like an archive, send a HEAD first to - check the Content-Type is HTML or Simple API, to avoid downloading a - large file. Raise `_NotHTTP` if the content type cannot be determined, or - `_NotAPIContent` if it is not HTML or a Simple API. - 2. Actually perform the request. Raise HTTP exceptions on network failures. - 3. Check the Content-Type header to make sure we got a Simple API response, - and raise `_NotAPIContent` otherwise. - """ - if is_archive_file(Link(url).filename): - _ensure_api_response(url, session=session) - - logger.debug("Getting page %s", redact_auth_from_url(url)) - - resp = session.get( - url, - headers={ - "Accept": ", ".join( - [ - "application/vnd.pypi.simple.v1+json", - "application/vnd.pypi.simple.v1+html; q=0.1", - "text/html; q=0.01", - ] - ), - # We don't want to blindly returned cached data for - # /simple/, because authors generally expecting that - # twine upload && pip install will function, but if - # 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", - }, - ) - raise_for_status(resp) - - # 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 a - # Simple API response or not. However we can check after we've - # downloaded it. - _ensure_api_header(resp) - - logger.debug( - "Fetched page %s as %s", - redact_auth_from_url(url), - resp.headers.get("Content-Type", "Unknown"), - ) - - return resp - - -def _get_encoding_from_headers(headers: ResponseHeaders) -> Optional[str]: - """Determine if we have any encoding information in our headers.""" - if headers and "Content-Type" in headers: - m = email.message.Message() - m["content-type"] = headers["Content-Type"] - charset = m.get_param("charset") - if charset: - return str(charset) - return None - - -class CacheablePageContent: - def __init__(self, page: "IndexContent") -> None: - assert page.cache_link_parsing - self.page = page - - def __eq__(self, other: object) -> bool: - return isinstance(other, type(self)) and self.page.url == other.page.url - - def __hash__(self) -> int: - return hash(self.page.url) - - -class ParseLinks(Protocol): - def __call__(self, page: "IndexContent") -> Iterable[Link]: - ... - - -def with_cached_index_content(fn: ParseLinks) -> ParseLinks: - """ - Given a function that parses an Iterable[Link] from an IndexContent, cache the - function's result (keyed by CacheablePageContent), unless the IndexContent - `page` has `page.cache_link_parsing == False`. - """ - - @functools.lru_cache(maxsize=None) - def wrapper(cacheable_page: CacheablePageContent) -> List[Link]: - return list(fn(cacheable_page.page)) - - @functools.wraps(fn) - def wrapper_wrapper(page: "IndexContent") -> List[Link]: - if page.cache_link_parsing: - return wrapper(CacheablePageContent(page)) - return list(fn(page)) - - return wrapper_wrapper - - -@with_cached_index_content -def parse_links(page: "IndexContent") -> Iterable[Link]: - """ - Parse a Simple API's Index Content, and yield its anchor elements as Link objects. - """ - - content_type_l = page.content_type.lower() - if content_type_l.startswith("application/vnd.pypi.simple.v1+json"): - data = json.loads(page.content) - for file in data.get("files", []): - link = Link.from_json(file, page.url) - if link is None: - continue - yield link - return - - parser = HTMLLinkParser(page.url) - encoding = page.encoding or "utf-8" - parser.feed(page.content.decode(encoding)) - - url = page.url - base_url = parser.base_url or url - for anchor in parser.anchors: - link = Link.from_element(anchor, page_url=url, base_url=base_url) - if link is None: - continue - yield link - - -class IndexContent: - """Represents one response (or page), along with its URL""" - - def __init__( - self, - content: bytes, - content_type: str, - encoding: Optional[str], - url: str, - cache_link_parsing: bool = True, - ) -> None: - """ - :param encoding: the encoding to decode the given content. - :param url: the URL from which the HTML was downloaded. - :param cache_link_parsing: whether links parsed from this page's url - should be cached. PyPI index urls should - have this set to False, for example. - """ - self.content = content - self.content_type = content_type - self.encoding = encoding - self.url = url - self.cache_link_parsing = cache_link_parsing - - def __str__(self) -> str: - return redact_auth_from_url(self.url) - - -class HTMLLinkParser(HTMLParser): - """ - HTMLParser that keeps the first base HREF and a list of all anchor - elements' attributes. - """ - - def __init__(self, url: str) -> None: - super().__init__(convert_charrefs=True) - - self.url: str = url - self.base_url: Optional[str] = None - self.anchors: List[Dict[str, Optional[str]]] = [] - - def handle_starttag(self, tag: str, attrs: List[Tuple[str, Optional[str]]]) -> None: - if tag == "base" and self.base_url is None: - href = self.get_href(attrs) - if href is not None: - self.base_url = href - elif tag == "a": - self.anchors.append(dict(attrs)) - - def get_href(self, attrs: List[Tuple[str, Optional[str]]]) -> Optional[str]: - for name, value in attrs: - if name == "href": - return value - return None - - -def _handle_get_simple_fail( - link: Link, - reason: Union[str, Exception], - meth: Optional[Callable[..., None]] = None, -) -> None: - if meth is None: - meth = logger.debug - meth("Could not fetch URL %s: %s - skipping", link, reason) - - -def _make_index_content( - response: Response, cache_link_parsing: bool = True -) -> IndexContent: - encoding = _get_encoding_from_headers(response.headers) - return IndexContent( - response.content, - response.headers["Content-Type"], - encoding=encoding, - url=response.url, - cache_link_parsing=cache_link_parsing, - ) - - -def _get_index_content(link: Link, *, session: PipSession) -> Optional["IndexContent"]: - url = link.url.split("#", 1)[0] - - # Check for VCS schemes that do not support lookup as web pages. - vcs_scheme = _match_vcs_scheme(url) - if vcs_scheme: - logger.warning( - "Cannot look at %s URL %s because it does not support lookup as web pages.", - vcs_scheme, - link, - ) - 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 += "/" - # TODO: In the future, it would be nice if pip supported PEP 691 - # style responses in the file:// URLs, however there's no - # standard file extension for application/vnd.pypi.simple.v1+json - # so we'll need to come up with something on our own. - url = urllib.parse.urljoin(url, "index.html") - logger.debug(" file: URL is directory, getting %s", url) - - try: - resp = _get_simple_response(url, session=session) - except _NotHTTP: - logger.warning( - "Skipping page %s because it looks like an archive, and cannot " - "be checked by a HTTP HEAD request.", - link, - ) - except _NotAPIContent as exc: - logger.warning( - "Skipping page %s because the %s request got Content-Type: %s. " - "The only supported Content-Types are application/vnd.pypi.simple.v1+json, " - "application/vnd.pypi.simple.v1+html, and text/html", - link, - exc.request_desc, - exc.content_type, - ) - except NetworkConnectionError as exc: - _handle_get_simple_fail(link, exc) - except RetryError as exc: - _handle_get_simple_fail(link, exc) - except SSLError as exc: - reason = "There was a problem confirming the ssl certificate: " - reason += str(exc) - _handle_get_simple_fail(link, reason, meth=logger.info) - except requests.ConnectionError as exc: - _handle_get_simple_fail(link, f"connection error: {exc}") - except requests.Timeout: - _handle_get_simple_fail(link, "timed out") - else: - return _make_index_content(resp, cache_link_parsing=link.cache_link_parsing) - return None - - -class CollectedSources(NamedTuple): - find_links: Sequence[Optional[LinkSource]] - index_urls: Sequence[Optional[LinkSource]] - - -class LinkCollector: - - """ - Responsible for collecting Link objects from all configured locations, - making network requests as needed. - - The class's main method is its collect_sources() method. - """ - - def __init__( - self, - session: PipSession, - search_scope: SearchScope, - ) -> None: - self.search_scope = search_scope - self.session = session - - @classmethod - def create( - cls, - session: PipSession, - options: Values, - suppress_no_index: bool = False, - ) -> "LinkCollector": - """ - :param session: The Session to use to make requests. - :param suppress_no_index: Whether to ignore the --no-index option - 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, - no_index=options.no_index, - ) - link_collector = LinkCollector( - session=session, - search_scope=search_scope, - ) - return link_collector - - @property - def find_links(self) -> List[str]: - return self.search_scope.find_links - - def fetch_response(self, location: Link) -> Optional[IndexContent]: - """ - Fetch an HTML page containing package links. - """ - return _get_index_content(location, session=self.session) - - def collect_sources( - self, - project_name: str, - candidates_from_page: CandidatesFromPage, - ) -> CollectedSources: - # The OrderedDict calls deduplicate sources by URL. - index_url_sources = collections.OrderedDict( - build_source( - loc, - candidates_from_page=candidates_from_page, - page_validator=self.session.is_secure_origin, - expand_dir=False, - cache_link_parsing=False, - project_name=project_name, - ) - for loc in self.search_scope.get_index_urls_locations(project_name) - ).values() - find_links_sources = collections.OrderedDict( - build_source( - loc, - candidates_from_page=candidates_from_page, - page_validator=self.session.is_secure_origin, - expand_dir=True, - cache_link_parsing=True, - project_name=project_name, - ) - for loc in self.find_links - ).values() - - if logger.isEnabledFor(logging.DEBUG): - lines = [ - f"* {s.link}" - for s in itertools.chain(find_links_sources, index_url_sources) - if s is not None and s.link is not None - ] - lines = [ - f"{len(lines)} location(s) to search " - f"for versions of {project_name}:" - ] + lines - logger.debug("\n".join(lines)) - - return CollectedSources( - find_links=list(find_links_sources), - index_urls=list(index_url_sources), - ) diff --git a/venv/lib/python3.12/site-packages/pip/_internal/index/package_finder.py b/venv/lib/python3.12/site-packages/pip/_internal/index/package_finder.py deleted file mode 100644 index ec9ebc3..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/index/package_finder.py +++ /dev/null @@ -1,1027 +0,0 @@ -"""Routines related to PyPI, indexes""" - -import enum -import functools -import itertools -import logging -import re -from typing import TYPE_CHECKING, FrozenSet, Iterable, List, Optional, Set, Tuple, Union - -from pip._vendor.packaging import specifiers -from pip._vendor.packaging.tags import Tag -from pip._vendor.packaging.utils import canonicalize_name -from pip._vendor.packaging.version import _BaseVersion -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 LinkCollector, 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.search_scope import SearchScope -from pip._internal.models.selection_prefs import SelectionPreferences -from pip._internal.models.target_python import TargetPython -from pip._internal.models.wheel import Wheel -from pip._internal.req import InstallRequirement -from pip._internal.utils._log import getLogger -from pip._internal.utils.filetypes import WHEEL_EXTENSION -from pip._internal.utils.hashes import Hashes -from pip._internal.utils.logging import indent_log -from pip._internal.utils.misc import build_netloc -from pip._internal.utils.packaging import check_requires_python -from pip._internal.utils.unpacking import SUPPORTED_EXTENSIONS - -if TYPE_CHECKING: - from pip._vendor.typing_extensions import TypeGuard - -__all__ = ["FormatControl", "BestCandidateResult", "PackageFinder"] - - -logger = getLogger(__name__) - -BuildTag = Union[Tuple[()], Tuple[int, str]] -CandidateSortingKey = Tuple[int, int, int, _BaseVersion, Optional[int], BuildTag] - - -def _check_link_requires_python( - link: Link, - version_info: Tuple[int, int, int], - ignore_requires_python: bool = False, -) -> bool: - """ - Return whether the given Python version is compatible with a link's - "Requires-Python" value. - - :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.verbose( - "Link requires a different Python (%s not in: %r): %s", - version, - link.requires_python, - link, - ) - return False - - logger.debug( - "Ignoring failed Requires-Python check (%s not in: %r) for link: %s", - version, - link.requires_python, - link, - ) - - return True - - -class LinkType(enum.Enum): - candidate = enum.auto() - different_project = enum.auto() - yanked = enum.auto() - format_unsupported = enum.auto() - format_invalid = enum.auto() - platform_mismatch = enum.auto() - requires_python_mismatch = enum.auto() - - -class LinkEvaluator: - - """ - Responsible for evaluating links for a particular project. - """ - - _py_version_re = re.compile(r"-py([123]\.?[0-9]?)$") - - # 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: str, - canonical_name: str, - formats: FrozenSet[str], - target_python: TargetPython, - allow_yanked: bool, - ignore_requires_python: Optional[bool] = None, - ) -> None: - """ - :param project_name: The user supplied package name. - :param canonical_name: The canonical package name. - :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: Link) -> Tuple[LinkType, str]: - """ - Determine whether a link is a candidate for installation. - - :return: A tuple (result, detail), where *result* is an enum - representing whether the evaluation found a candidate, or the reason - why one is not found. If a candidate is found, *detail* will be the - candidate's version string; if one is not found, it contains the - reason the link fails to qualify. - """ - version = None - if link.is_yanked and not self._allow_yanked: - reason = link.yanked_reason or "" - return (LinkType.yanked, f"yanked for reason: {reason}") - - if link.egg_fragment: - egg_info = link.egg_fragment - ext = link.ext - else: - egg_info, ext = link.splitext() - if not ext: - return (LinkType.format_unsupported, "not a file") - if ext not in SUPPORTED_EXTENSIONS: - return ( - LinkType.format_unsupported, - f"unsupported archive format: {ext}", - ) - if "binary" not in self._formats and ext == WHEEL_EXTENSION: - reason = f"No binaries permitted for {self.project_name}" - return (LinkType.format_unsupported, reason) - if "macosx10" in link.path and ext == ".zip": - return (LinkType.format_unsupported, "macosx10 one") - if ext == WHEEL_EXTENSION: - try: - wheel = Wheel(link.filename) - except InvalidWheelFilename: - return ( - LinkType.format_invalid, - "invalid wheel filename", - ) - if canonicalize_name(wheel.name) != self._canonical_name: - reason = f"wrong project name (not {self.project_name})" - return (LinkType.different_project, reason) - - supported_tags = self._target_python.get_unsorted_tags() - if not wheel.supported(supported_tags): - # Include the wheel's tags in the reason string to - # simplify troubleshooting compatibility issues. - file_tags = ", ".join(wheel.get_formatted_file_tags()) - reason = ( - f"none of the wheel's tags ({file_tags}) are compatible " - f"(run pip debug --verbose to show compatible tags)" - ) - return (LinkType.platform_mismatch, reason) - - version = wheel.version - - # This should be up by the self.ok_binary check, but see issue 2700. - if "source" not in self._formats and ext != WHEEL_EXTENSION: - reason = f"No sources permitted for {self.project_name}" - return (LinkType.format_unsupported, reason) - - if not version: - version = _extract_version_from_fragment( - egg_info, - self._canonical_name, - ) - if not version: - reason = f"Missing project version for {self.project_name}" - return (LinkType.format_invalid, reason) - - match = self._py_version_re.search(version) - if match: - version = version[: match.start()] - py_version = match.group(1) - if py_version != self._target_python.py_version: - return ( - LinkType.platform_mismatch, - "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: - reason = f"{version} Requires-Python {link.requires_python}" - return (LinkType.requires_python_mismatch, reason) - - logger.debug("Found link %s, version: %s", link, version) - - return (LinkType.candidate, version) - - -def filter_unallowed_hashes( - candidates: List[InstallationCandidate], - hashes: Optional[Hashes], - project_name: str, -) -> List[InstallationCandidate]: - """ - Filter out candidates whose hashes aren't allowed, and return a new - list of candidates. - - 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: - - """ - Encapsulates some of the preferences for filtering and sorting - InstallationCandidate objects. - """ - - def __init__( - self, - prefer_binary: bool = False, - allow_all_prereleases: bool = False, - ) -> 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: - """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: List[InstallationCandidate], - applicable_candidates: List[InstallationCandidate], - best_candidate: Optional[InstallationCandidate], - ) -> None: - """ - :param candidates: A sequence of all available candidates found. - :param applicable_candidates: The applicable candidates. - :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) -> Iterable[InstallationCandidate]: - """Iterate through all candidates.""" - return iter(self._candidates) - - def iter_applicable(self) -> Iterable[InstallationCandidate]: - """Iterate through the applicable candidates.""" - return iter(self._applicable_candidates) - - -class CandidateEvaluator: - - """ - Responsible for filtering and sorting candidates for installation based - on what tags are valid. - """ - - @classmethod - def create( - cls, - project_name: str, - target_python: Optional[TargetPython] = None, - prefer_binary: bool = False, - allow_all_prereleases: bool = False, - specifier: Optional[specifiers.BaseSpecifier] = None, - hashes: Optional[Hashes] = None, - ) -> "CandidateEvaluator": - """Create a CandidateEvaluator object. - - :param target_python: The target Python interpreter to use when - 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_sorted_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: str, - supported_tags: List[Tag], - specifier: specifiers.BaseSpecifier, - prefer_binary: bool = False, - allow_all_prereleases: bool = False, - hashes: Optional[Hashes] = None, - ) -> None: - """ - :param supported_tags: The PEP 425 tags supported by the target - Python in order of preference (most preferred first). - """ - 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 - # Since the index of the tag in the _supported_tags list is used - # as a priority, precompute a map from tag to index/priority to be - # used in wheel.find_most_preferred_tag. - self._wheel_tag_preferences = { - tag: idx for idx, tag in enumerate(supported_tags) - } - - def get_applicable_candidates( - self, - candidates: List[InstallationCandidate], - ) -> 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: 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: BuildTag = () - binary_preference = 0 - link = candidate.link - if link.is_wheel: - # can raise InvalidWheelFilename - wheel = Wheel(link.filename) - try: - pri = -( - wheel.find_most_preferred_tag( - valid_tags, self._wheel_tag_preferences - ) - ) - except ValueError: - raise UnsupportedWheel( - f"{wheel.filename} is not a supported wheel for this platform. It " - "can't be sorted." - ) - if self._prefer_binary: - binary_preference = 1 - if wheel.build_tag is not None: - match = re.match(r"^(\d+)(.*)$", wheel.build_tag) - assert match is not None, "guaranteed by filename validation" - build_tag_groups = match.groups() - build_tag = (int(build_tag_groups[0]), build_tag_groups[1]) - else: # sdist - 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, - pri, - build_tag, - ) - - def sort_best_candidate( - self, - candidates: List[InstallationCandidate], - ) -> 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) - return best_candidate - - def compute_best_candidate( - self, - candidates: List[InstallationCandidate], - ) -> 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: - """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: LinkCollector, - target_python: TargetPython, - allow_yanked: bool, - format_control: Optional[FormatControl] = None, - candidate_prefs: Optional[CandidatePreferences] = None, - ignore_requires_python: Optional[bool] = None, - ) -> None: - """ - This constructor is primarily meant to be used by the create() class - method and from tests. - - :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[Tuple[Link, LinkType, str]] = set() - - # Don't include an allow_yanked default value to make sure each call - # site considers whether yanked releases are allowed. This also causes - # that decision to be made explicit in the calling code, which helps - # people when reading the code. - @classmethod - def create( - cls, - link_collector: LinkCollector, - selection_prefs: SelectionPreferences, - target_python: Optional[TargetPython] = None, - ) -> "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 target_python(self) -> TargetPython: - return self._target_python - - @property - def search_scope(self) -> SearchScope: - return self._link_collector.search_scope - - @search_scope.setter - def search_scope(self, search_scope: SearchScope) -> None: - self._link_collector.search_scope = search_scope - - @property - def find_links(self) -> List[str]: - return self._link_collector.find_links - - @property - def index_urls(self) -> List[str]: - return self.search_scope.index_urls - - @property - def trusted_hosts(self) -> Iterable[str]: - for host_port in self._link_collector.session.pip_trusted_origins: - yield build_netloc(*host_port) - - @property - def allow_all_prereleases(self) -> bool: - return self._candidate_prefs.allow_all_prereleases - - def set_allow_all_prereleases(self) -> None: - self._candidate_prefs.allow_all_prereleases = True - - @property - def prefer_binary(self) -> bool: - return self._candidate_prefs.prefer_binary - - def set_prefer_binary(self) -> None: - self._candidate_prefs.prefer_binary = True - - def requires_python_skipped_reasons(self) -> List[str]: - reasons = { - detail - for _, result, detail in self._logged_links - if result == LinkType.requires_python_mismatch - } - return sorted(reasons) - - def make_link_evaluator(self, project_name: str) -> LinkEvaluator: - canonical_name = canonicalize_name(project_name) - formats = self.format_control.get_allowed_formats(canonical_name) - - 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: 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[Link] = set() - 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: Link, result: LinkType, detail: str) -> None: - entry = (link, result, detail) - if entry not in self._logged_links: - # Put the link at the end so the reason is more visible and because - # the link string is usually very long. - logger.debug("Skipping link: %s: %s", detail, link) - self._logged_links.add(entry) - - def get_install_candidate( - self, link_evaluator: LinkEvaluator, link: Link - ) -> Optional[InstallationCandidate]: - """ - If the link is a candidate for install, convert it to an - InstallationCandidate and return it. Otherwise, return None. - """ - result, detail = link_evaluator.evaluate_link(link) - if result != LinkType.candidate: - self._log_skipped_link(link, result, detail) - return None - - return InstallationCandidate( - name=link_evaluator.project_name, - link=link, - version=detail, - ) - - def evaluate_links( - self, link_evaluator: LinkEvaluator, links: 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, link_evaluator: LinkEvaluator - ) -> List[InstallationCandidate]: - logger.debug( - "Fetching project page and analyzing links: %s", - project_url, - ) - index_response = self._link_collector.fetch_response(project_url) - if index_response is None: - return [] - - page_links = list(parse_links(index_response)) - - with indent_log(): - package_links = self.evaluate_links( - link_evaluator, - links=page_links, - ) - - return package_links - - @functools.lru_cache(maxsize=None) - def find_all_candidates(self, project_name: 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. - """ - link_evaluator = self.make_link_evaluator(project_name) - - collected_sources = self._link_collector.collect_sources( - project_name=project_name, - candidates_from_page=functools.partial( - self.process_project_url, - link_evaluator=link_evaluator, - ), - ) - - page_candidates_it = itertools.chain.from_iterable( - source.page_candidates() - for sources in collected_sources - for source in sources - if source is not None - ) - page_candidates = list(page_candidates_it) - - file_links_it = itertools.chain.from_iterable( - source.file_links() - for sources in collected_sources - for source in sources - if source is not None - ) - file_candidates = self.evaluate_links( - link_evaluator, - sorted(file_links_it, reverse=True), - ) - - if logger.isEnabledFor(logging.DEBUG) and file_candidates: - paths = [] - for candidate in file_candidates: - assert candidate.link.url # we need to have a URL - try: - paths.append(candidate.link.file_path) - except Exception: - paths.append(candidate.link.url) # it's not a local file - - logger.debug("Local files found: %s", ", ".join(paths)) - - # This is an intentional priority ordering - return file_candidates + page_candidates - - def make_candidate_evaluator( - self, - project_name: str, - specifier: Optional[specifiers.BaseSpecifier] = None, - hashes: Optional[Hashes] = None, - ) -> CandidateEvaluator: - """Create a CandidateEvaluator object to use.""" - candidate_prefs = self._candidate_prefs - return CandidateEvaluator.create( - project_name=project_name, - target_python=self._target_python, - prefer_binary=candidate_prefs.prefer_binary, - allow_all_prereleases=candidate_prefs.allow_all_prereleases, - specifier=specifier, - hashes=hashes, - ) - - @functools.lru_cache(maxsize=None) - def find_best_candidate( - self, - project_name: str, - specifier: Optional[specifiers.BaseSpecifier] = None, - hashes: Optional[Hashes] = None, - ) -> BestCandidateResult: - """Find matches for the given project and specifier. - - :param specifier: An optional object implementing `filter` - (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: InstallRequirement, upgrade: bool - ) -> Optional[InstallationCandidate]: - """Try to find a Link matching req - - Expects req, an InstallRequirement and upgrade, a boolean - Returns a InstallationCandidate 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: Optional[_BaseVersion] = None - if req.satisfied_by is not None: - installed_version = req.satisfied_by.version - - def _format_versions(cand_iter: Iterable[InstallationCandidate]) -> str: - # This repeated parse_version and str() conversion is needed to - # handle different vendoring sources from pip and pkg_resources. - # If we stop using the pkg_resources provided specifier and start - # using our own, we can drop the cast to str(). - return ( - ", ".join( - sorted( - {str(c.version) for c in cand_iter}, - key=parse_version, - ) - ) - or "none" - ) - - 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(f"No matching distribution found for {req}") - - def _should_install_candidate( - candidate: Optional[InstallationCandidate], - ) -> "TypeGuard[InstallationCandidate]": - if installed_version is None: - return True - if best_candidate is None: - return False - return best_candidate.version > installed_version - - if not upgrade and installed_version is not None: - if _should_install_candidate(best_candidate): - logger.debug( - "Existing installed version (%s) satisfies requirement " - "(most up-to-date version is %s)", - installed_version, - best_candidate.version, - ) - else: - logger.debug( - "Existing installed version (%s) is most up-to-date and " - "satisfies requirement", - installed_version, - ) - return None - - if _should_install_candidate(best_candidate): - logger.debug( - "Using version %s (newest of versions: %s)", - best_candidate.version, - _format_versions(best_candidate_result.iter_applicable()), - ) - return best_candidate - - # 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 - - -def _find_name_version_sep(fragment: str, canonical_name: str) -> int: - """Find the separator's index based on the package's canonical name. - - :param fragment: A + 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(f"{fragment} does not match {canonical_name}") - - -def _extract_version_from_fragment(fragment: str, canonical_name: 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.12/site-packages/pip/_internal/index/sources.py b/venv/lib/python3.12/site-packages/pip/_internal/index/sources.py deleted file mode 100644 index f4626d7..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/index/sources.py +++ /dev/null @@ -1,285 +0,0 @@ -import logging -import mimetypes -import os -from collections import defaultdict -from typing import Callable, Dict, Iterable, List, Optional, Tuple - -from pip._vendor.packaging.utils import ( - InvalidSdistFilename, - InvalidVersion, - InvalidWheelFilename, - canonicalize_name, - parse_sdist_filename, - parse_wheel_filename, -) - -from pip._internal.models.candidate import InstallationCandidate -from pip._internal.models.link import Link -from pip._internal.utils.urls import path_to_url, url_to_path -from pip._internal.vcs import is_url - -logger = logging.getLogger(__name__) - -FoundCandidates = Iterable[InstallationCandidate] -FoundLinks = Iterable[Link] -CandidatesFromPage = Callable[[Link], Iterable[InstallationCandidate]] -PageValidator = Callable[[Link], bool] - - -class LinkSource: - @property - def link(self) -> Optional[Link]: - """Returns the underlying link, if there's one.""" - raise NotImplementedError() - - def page_candidates(self) -> FoundCandidates: - """Candidates found by parsing an archive listing HTML file.""" - raise NotImplementedError() - - def file_links(self) -> FoundLinks: - """Links found by specifying archives directly.""" - raise NotImplementedError() - - -def _is_html_file(file_url: str) -> bool: - return mimetypes.guess_type(file_url, strict=False)[0] == "text/html" - - -class _FlatDirectoryToUrls: - """Scans directory and caches results""" - - def __init__(self, path: str) -> None: - self._path = path - self._page_candidates: List[str] = [] - self._project_name_to_urls: Dict[str, List[str]] = defaultdict(list) - self._scanned_directory = False - - def _scan_directory(self) -> None: - """Scans directory once and populates both page_candidates - and project_name_to_urls at the same time - """ - for entry in os.scandir(self._path): - url = path_to_url(entry.path) - if _is_html_file(url): - self._page_candidates.append(url) - continue - - # File must have a valid wheel or sdist name, - # otherwise not worth considering as a package - try: - project_filename = parse_wheel_filename(entry.name)[0] - except (InvalidWheelFilename, InvalidVersion): - try: - project_filename = parse_sdist_filename(entry.name)[0] - except (InvalidSdistFilename, InvalidVersion): - continue - - self._project_name_to_urls[project_filename].append(url) - self._scanned_directory = True - - @property - def page_candidates(self) -> List[str]: - if not self._scanned_directory: - self._scan_directory() - - return self._page_candidates - - @property - def project_name_to_urls(self) -> Dict[str, List[str]]: - if not self._scanned_directory: - self._scan_directory() - - return self._project_name_to_urls - - -class _FlatDirectorySource(LinkSource): - """Link source specified by ``--find-links=``. - - This looks the content of the directory, and returns: - - * ``page_candidates``: Links listed on each HTML file in the directory. - * ``file_candidates``: Archives in the directory. - """ - - _paths_to_urls: Dict[str, _FlatDirectoryToUrls] = {} - - def __init__( - self, - candidates_from_page: CandidatesFromPage, - path: str, - project_name: str, - ) -> None: - self._candidates_from_page = candidates_from_page - self._project_name = canonicalize_name(project_name) - - # Get existing instance of _FlatDirectoryToUrls if it exists - if path in self._paths_to_urls: - self._path_to_urls = self._paths_to_urls[path] - else: - self._path_to_urls = _FlatDirectoryToUrls(path=path) - self._paths_to_urls[path] = self._path_to_urls - - @property - def link(self) -> Optional[Link]: - return None - - def page_candidates(self) -> FoundCandidates: - for url in self._path_to_urls.page_candidates: - yield from self._candidates_from_page(Link(url)) - - def file_links(self) -> FoundLinks: - for url in self._path_to_urls.project_name_to_urls[self._project_name]: - yield Link(url) - - -class _LocalFileSource(LinkSource): - """``--find-links=`` or ``--[extra-]index-url=``. - - If a URL is supplied, it must be a ``file:`` URL. If a path is supplied to - the option, it is converted to a URL first. This returns: - - * ``page_candidates``: Links listed on an HTML file. - * ``file_candidates``: The non-HTML file. - """ - - def __init__( - self, - candidates_from_page: CandidatesFromPage, - link: Link, - ) -> None: - self._candidates_from_page = candidates_from_page - self._link = link - - @property - def link(self) -> Optional[Link]: - return self._link - - def page_candidates(self) -> FoundCandidates: - if not _is_html_file(self._link.url): - return - yield from self._candidates_from_page(self._link) - - def file_links(self) -> FoundLinks: - if _is_html_file(self._link.url): - return - yield self._link - - -class _RemoteFileSource(LinkSource): - """``--find-links=`` or ``--[extra-]index-url=``. - - This returns: - - * ``page_candidates``: Links listed on an HTML file. - * ``file_candidates``: The non-HTML file. - """ - - def __init__( - self, - candidates_from_page: CandidatesFromPage, - page_validator: PageValidator, - link: Link, - ) -> None: - self._candidates_from_page = candidates_from_page - self._page_validator = page_validator - self._link = link - - @property - def link(self) -> Optional[Link]: - return self._link - - def page_candidates(self) -> FoundCandidates: - if not self._page_validator(self._link): - return - yield from self._candidates_from_page(self._link) - - def file_links(self) -> FoundLinks: - yield self._link - - -class _IndexDirectorySource(LinkSource): - """``--[extra-]index-url=``. - - This is treated like a remote URL; ``candidates_from_page`` contains logic - for this by appending ``index.html`` to the link. - """ - - def __init__( - self, - candidates_from_page: CandidatesFromPage, - link: Link, - ) -> None: - self._candidates_from_page = candidates_from_page - self._link = link - - @property - def link(self) -> Optional[Link]: - return self._link - - def page_candidates(self) -> FoundCandidates: - yield from self._candidates_from_page(self._link) - - def file_links(self) -> FoundLinks: - return () - - -def build_source( - location: str, - *, - candidates_from_page: CandidatesFromPage, - page_validator: PageValidator, - expand_dir: bool, - cache_link_parsing: bool, - project_name: str, -) -> Tuple[Optional[str], Optional[LinkSource]]: - path: Optional[str] = None - url: Optional[str] = None - if os.path.exists(location): # Is a local path. - url = path_to_url(location) - path = location - elif location.startswith("file:"): # A file: URL. - url = location - path = url_to_path(location) - elif is_url(location): - url = location - - if url is None: - msg = ( - "Location '%s' is ignored: " - "it is either a non-existing path or lacks a specific scheme." - ) - logger.warning(msg, location) - return (None, None) - - if path is None: - source: LinkSource = _RemoteFileSource( - candidates_from_page=candidates_from_page, - page_validator=page_validator, - link=Link(url, cache_link_parsing=cache_link_parsing), - ) - return (url, source) - - if os.path.isdir(path): - if expand_dir: - source = _FlatDirectorySource( - candidates_from_page=candidates_from_page, - path=path, - project_name=project_name, - ) - else: - source = _IndexDirectorySource( - candidates_from_page=candidates_from_page, - link=Link(url, cache_link_parsing=cache_link_parsing), - ) - return (url, source) - elif os.path.isfile(path): - source = _LocalFileSource( - candidates_from_page=candidates_from_page, - link=Link(url, cache_link_parsing=cache_link_parsing), - ) - return (url, source) - logger.warning( - "Location '%s' is ignored: it is neither a file nor a directory.", - location, - ) - return (url, None) diff --git a/venv/lib/python3.12/site-packages/pip/_internal/locations/__init__.py b/venv/lib/python3.12/site-packages/pip/_internal/locations/__init__.py deleted file mode 100644 index d54bc63..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/locations/__init__.py +++ /dev/null @@ -1,467 +0,0 @@ -import functools -import logging -import os -import pathlib -import sys -import sysconfig -from typing import Any, Dict, Generator, Optional, Tuple - -from pip._internal.models.scheme import SCHEME_KEYS, Scheme -from pip._internal.utils.compat import WINDOWS -from pip._internal.utils.deprecation import deprecated -from pip._internal.utils.virtualenv import running_under_virtualenv - -from . import _sysconfig -from .base import ( - USER_CACHE_DIR, - get_major_minor_version, - get_src_prefix, - is_osx_framework, - site_packages, - user_site, -) - -__all__ = [ - "USER_CACHE_DIR", - "get_bin_prefix", - "get_bin_user", - "get_major_minor_version", - "get_platlib", - "get_purelib", - "get_scheme", - "get_src_prefix", - "site_packages", - "user_site", -] - - -logger = logging.getLogger(__name__) - - -_PLATLIBDIR: str = getattr(sys, "platlibdir", "lib") - -_USE_SYSCONFIG_DEFAULT = sys.version_info >= (3, 10) - - -def _should_use_sysconfig() -> bool: - """This function determines the value of _USE_SYSCONFIG. - - By default, pip uses sysconfig on Python 3.10+. - But Python distributors can override this decision by setting: - sysconfig._PIP_USE_SYSCONFIG = True / False - Rationale in https://github.com/pypa/pip/issues/10647 - - This is a function for testability, but should be constant during any one - run. - """ - return bool(getattr(sysconfig, "_PIP_USE_SYSCONFIG", _USE_SYSCONFIG_DEFAULT)) - - -_USE_SYSCONFIG = _should_use_sysconfig() - -if not _USE_SYSCONFIG: - # Import distutils lazily to avoid deprecation warnings, - # but import it soon enough that it is in memory and available during - # a pip reinstall. - from . import _distutils - -# Be noisy about incompatibilities if this platforms "should" be using -# sysconfig, but is explicitly opting out and using distutils instead. -if _USE_SYSCONFIG_DEFAULT and not _USE_SYSCONFIG: - _MISMATCH_LEVEL = logging.WARNING -else: - _MISMATCH_LEVEL = logging.DEBUG - - -def _looks_like_bpo_44860() -> bool: - """The resolution to bpo-44860 will change this incorrect platlib. - - See . - """ - from distutils.command.install import INSTALL_SCHEMES - - try: - unix_user_platlib = INSTALL_SCHEMES["unix_user"]["platlib"] - except KeyError: - return False - return unix_user_platlib == "$usersite" - - -def _looks_like_red_hat_patched_platlib_purelib(scheme: Dict[str, str]) -> bool: - platlib = scheme["platlib"] - if "/$platlibdir/" in platlib: - platlib = platlib.replace("/$platlibdir/", f"/{_PLATLIBDIR}/") - if "/lib64/" not in platlib: - return False - unpatched = platlib.replace("/lib64/", "/lib/") - return unpatched.replace("$platbase/", "$base/") == scheme["purelib"] - - -@functools.lru_cache(maxsize=None) -def _looks_like_red_hat_lib() -> bool: - """Red Hat patches platlib in unix_prefix and unix_home, but not purelib. - - This is the only way I can see to tell a Red Hat-patched Python. - """ - from distutils.command.install import INSTALL_SCHEMES - - return all( - k in INSTALL_SCHEMES - and _looks_like_red_hat_patched_platlib_purelib(INSTALL_SCHEMES[k]) - for k in ("unix_prefix", "unix_home") - ) - - -@functools.lru_cache(maxsize=None) -def _looks_like_debian_scheme() -> bool: - """Debian adds two additional schemes.""" - from distutils.command.install import INSTALL_SCHEMES - - return "deb_system" in INSTALL_SCHEMES and "unix_local" in INSTALL_SCHEMES - - -@functools.lru_cache(maxsize=None) -def _looks_like_red_hat_scheme() -> bool: - """Red Hat patches ``sys.prefix`` and ``sys.exec_prefix``. - - Red Hat's ``00251-change-user-install-location.patch`` changes the install - command's ``prefix`` and ``exec_prefix`` to append ``"/local"``. This is - (fortunately?) done quite unconditionally, so we create a default command - object without any configuration to detect this. - """ - from distutils.command.install import install - from distutils.dist import Distribution - - cmd: Any = install(Distribution()) - cmd.finalize_options() - return ( - cmd.exec_prefix == f"{os.path.normpath(sys.exec_prefix)}/local" - and cmd.prefix == f"{os.path.normpath(sys.prefix)}/local" - ) - - -@functools.lru_cache(maxsize=None) -def _looks_like_slackware_scheme() -> bool: - """Slackware patches sysconfig but fails to patch distutils and site. - - Slackware changes sysconfig's user scheme to use ``"lib64"`` for the lib - path, but does not do the same to the site module. - """ - if user_site is None: # User-site not available. - return False - try: - paths = sysconfig.get_paths(scheme="posix_user", expand=False) - except KeyError: # User-site not available. - return False - return "/lib64/" in paths["purelib"] and "/lib64/" not in user_site - - -@functools.lru_cache(maxsize=None) -def _looks_like_msys2_mingw_scheme() -> bool: - """MSYS2 patches distutils and sysconfig to use a UNIX-like scheme. - - However, MSYS2 incorrectly patches sysconfig ``nt`` scheme. The fix is - likely going to be included in their 3.10 release, so we ignore the warning. - See msys2/MINGW-packages#9319. - - MSYS2 MINGW's patch uses lowercase ``"lib"`` instead of the usual uppercase, - and is missing the final ``"site-packages"``. - """ - paths = sysconfig.get_paths("nt", expand=False) - return all( - "Lib" not in p and "lib" in p and not p.endswith("site-packages") - for p in (paths[key] for key in ("platlib", "purelib")) - ) - - -def _fix_abiflags(parts: Tuple[str]) -> Generator[str, None, None]: - ldversion = sysconfig.get_config_var("LDVERSION") - abiflags = getattr(sys, "abiflags", None) - - # LDVERSION does not end with sys.abiflags. Just return the path unchanged. - if not ldversion or not abiflags or not ldversion.endswith(abiflags): - yield from parts - return - - # Strip sys.abiflags from LDVERSION-based path components. - for part in parts: - if part.endswith(ldversion): - part = part[: (0 - len(abiflags))] - yield part - - -@functools.lru_cache(maxsize=None) -def _warn_mismatched(old: pathlib.Path, new: pathlib.Path, *, key: str) -> None: - issue_url = "https://github.com/pypa/pip/issues/10151" - message = ( - "Value for %s does not match. Please report this to <%s>" - "\ndistutils: %s" - "\nsysconfig: %s" - ) - logger.log(_MISMATCH_LEVEL, message, key, issue_url, old, new) - - -def _warn_if_mismatch(old: pathlib.Path, new: pathlib.Path, *, key: str) -> bool: - if old == new: - return False - _warn_mismatched(old, new, key=key) - return True - - -@functools.lru_cache(maxsize=None) -def _log_context( - *, - user: bool = False, - home: Optional[str] = None, - root: Optional[str] = None, - prefix: Optional[str] = None, -) -> None: - parts = [ - "Additional context:", - "user = %r", - "home = %r", - "root = %r", - "prefix = %r", - ] - - logger.log(_MISMATCH_LEVEL, "\n".join(parts), user, home, root, prefix) - - -def get_scheme( - dist_name: str, - user: bool = False, - home: Optional[str] = None, - root: Optional[str] = None, - isolated: bool = False, - prefix: Optional[str] = None, -) -> Scheme: - new = _sysconfig.get_scheme( - dist_name, - user=user, - home=home, - root=root, - isolated=isolated, - prefix=prefix, - ) - if _USE_SYSCONFIG: - return new - - old = _distutils.get_scheme( - dist_name, - user=user, - home=home, - root=root, - isolated=isolated, - prefix=prefix, - ) - - warning_contexts = [] - for k in SCHEME_KEYS: - old_v = pathlib.Path(getattr(old, k)) - new_v = pathlib.Path(getattr(new, k)) - - if old_v == new_v: - continue - - # distutils incorrectly put PyPy packages under ``site-packages/python`` - # in the ``posix_home`` scheme, but PyPy devs said they expect the - # directory name to be ``pypy`` instead. So we treat this as a bug fix - # and not warn about it. See bpo-43307 and python/cpython#24628. - skip_pypy_special_case = ( - sys.implementation.name == "pypy" - and home is not None - and k in ("platlib", "purelib") - and old_v.parent == new_v.parent - and old_v.name.startswith("python") - and new_v.name.startswith("pypy") - ) - if skip_pypy_special_case: - continue - - # sysconfig's ``osx_framework_user`` does not include ``pythonX.Y`` in - # the ``include`` value, but distutils's ``headers`` does. We'll let - # CPython decide whether this is a bug or feature. See bpo-43948. - skip_osx_framework_user_special_case = ( - user - and is_osx_framework() - and k == "headers" - and old_v.parent.parent == new_v.parent - and old_v.parent.name.startswith("python") - ) - if skip_osx_framework_user_special_case: - continue - - # On Red Hat and derived Linux distributions, distutils is patched to - # use "lib64" instead of "lib" for platlib. - if k == "platlib" and _looks_like_red_hat_lib(): - continue - - # On Python 3.9+, sysconfig's posix_user scheme sets platlib against - # sys.platlibdir, but distutils's unix_user incorrectly coninutes - # using the same $usersite for both platlib and purelib. This creates a - # mismatch when sys.platlibdir is not "lib". - skip_bpo_44860 = ( - user - and k == "platlib" - and not WINDOWS - and sys.version_info >= (3, 9) - and _PLATLIBDIR != "lib" - and _looks_like_bpo_44860() - ) - if skip_bpo_44860: - continue - - # Slackware incorrectly patches posix_user to use lib64 instead of lib, - # but not usersite to match the location. - skip_slackware_user_scheme = ( - user - and k in ("platlib", "purelib") - and not WINDOWS - and _looks_like_slackware_scheme() - ) - if skip_slackware_user_scheme: - continue - - # Both Debian and Red Hat patch Python to place the system site under - # /usr/local instead of /usr. Debian also places lib in dist-packages - # instead of site-packages, but the /usr/local check should cover it. - skip_linux_system_special_case = ( - not (user or home or prefix or running_under_virtualenv()) - and old_v.parts[1:3] == ("usr", "local") - and len(new_v.parts) > 1 - and new_v.parts[1] == "usr" - and (len(new_v.parts) < 3 or new_v.parts[2] != "local") - and (_looks_like_red_hat_scheme() or _looks_like_debian_scheme()) - ) - if skip_linux_system_special_case: - continue - - # On Python 3.7 and earlier, sysconfig does not include sys.abiflags in - # the "pythonX.Y" part of the path, but distutils does. - skip_sysconfig_abiflag_bug = ( - sys.version_info < (3, 8) - and not WINDOWS - and k in ("headers", "platlib", "purelib") - and tuple(_fix_abiflags(old_v.parts)) == new_v.parts - ) - if skip_sysconfig_abiflag_bug: - continue - - # MSYS2 MINGW's sysconfig patch does not include the "site-packages" - # part of the path. This is incorrect and will be fixed in MSYS. - skip_msys2_mingw_bug = ( - WINDOWS and k in ("platlib", "purelib") and _looks_like_msys2_mingw_scheme() - ) - if skip_msys2_mingw_bug: - continue - - # CPython's POSIX install script invokes pip (via ensurepip) against the - # interpreter located in the source tree, not the install site. This - # triggers special logic in sysconfig that's not present in distutils. - # https://github.com/python/cpython/blob/8c21941ddaf/Lib/sysconfig.py#L178-L194 - skip_cpython_build = ( - sysconfig.is_python_build(check_home=True) - and not WINDOWS - and k in ("headers", "include", "platinclude") - ) - if skip_cpython_build: - continue - - warning_contexts.append((old_v, new_v, f"scheme.{k}")) - - if not warning_contexts: - return old - - # Check if this path mismatch is caused by distutils config files. Those - # files will no longer work once we switch to sysconfig, so this raises a - # deprecation message for them. - default_old = _distutils.distutils_scheme( - dist_name, - user, - home, - root, - isolated, - prefix, - ignore_config_files=True, - ) - if any(default_old[k] != getattr(old, k) for k in SCHEME_KEYS): - deprecated( - reason=( - "Configuring installation scheme with distutils config files " - "is deprecated and will no longer work in the near future. If you " - "are using a Homebrew or Linuxbrew Python, please see discussion " - "at https://github.com/Homebrew/homebrew-core/issues/76621" - ), - replacement=None, - gone_in=None, - ) - return old - - # Post warnings about this mismatch so user can report them back. - for old_v, new_v, key in warning_contexts: - _warn_mismatched(old_v, new_v, key=key) - _log_context(user=user, home=home, root=root, prefix=prefix) - - return old - - -def get_bin_prefix() -> str: - new = _sysconfig.get_bin_prefix() - if _USE_SYSCONFIG: - return new - - old = _distutils.get_bin_prefix() - if _warn_if_mismatch(pathlib.Path(old), pathlib.Path(new), key="bin_prefix"): - _log_context() - return old - - -def get_bin_user() -> str: - return _sysconfig.get_scheme("", user=True).scripts - - -def _looks_like_deb_system_dist_packages(value: str) -> bool: - """Check if the value is Debian's APT-controlled dist-packages. - - Debian's ``distutils.sysconfig.get_python_lib()`` implementation returns the - default package path controlled by APT, but does not patch ``sysconfig`` to - do the same. This is similar to the bug worked around in ``get_scheme()``, - but here the default is ``deb_system`` instead of ``unix_local``. Ultimately - we can't do anything about this Debian bug, and this detection allows us to - skip the warning when needed. - """ - if not _looks_like_debian_scheme(): - return False - if value == "/usr/lib/python3/dist-packages": - return True - return False - - -def get_purelib() -> str: - """Return the default pure-Python lib location.""" - new = _sysconfig.get_purelib() - if _USE_SYSCONFIG: - return new - - old = _distutils.get_purelib() - if _looks_like_deb_system_dist_packages(old): - return old - if _warn_if_mismatch(pathlib.Path(old), pathlib.Path(new), key="purelib"): - _log_context() - return old - - -def get_platlib() -> str: - """Return the default platform-shared lib location.""" - new = _sysconfig.get_platlib() - if _USE_SYSCONFIG: - return new - - from . import _distutils - - old = _distutils.get_platlib() - if _looks_like_deb_system_dist_packages(old): - return old - if _warn_if_mismatch(pathlib.Path(old), pathlib.Path(new), key="platlib"): - _log_context() - return old diff --git a/venv/lib/python3.12/site-packages/pip/_internal/locations/__pycache__/__init__.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/locations/__pycache__/__init__.cpython-312.pyc deleted file mode 100644 index 2cffd18be5e9bfb8465cba481257c6fcd7c57c34..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 16786 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 diff --git a/venv/lib/python3.12/site-packages/pip/_internal/locations/__pycache__/_sysconfig.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/locations/__pycache__/_sysconfig.cpython-312.pyc deleted file mode 100644 index 2abc79d3e7df197559fb6d52ee600eb9ebfe3f46..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 8021 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 diff --git a/venv/lib/python3.12/site-packages/pip/_internal/locations/__pycache__/base.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/locations/__pycache__/base.cpython-312.pyc deleted file mode 100644 index b7f4fec44c36acb068faa44a74afb2e3284e3203..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3791 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 Dict[str, str]: - """ - Return a distutils install scheme - """ - from distutils.dist import Distribution - - dist_args: Dict[str, Union[str, List[str]]] = {"name": dist_name} - if isolated: - dist_args["script_args"] = ["--no-user-cfg"] - - d = Distribution(dist_args) - if not ignore_config_files: - try: - d.parse_config_files() - except UnicodeDecodeError: - paths = d.find_config_files() - logger.warning( - "Ignore distutils configs in %s due to encoding errors.", - ", ".join(os.path.basename(p) for p in paths), - ) - obj: Optional[DistutilsCommand] = None - obj = d.get_command_obj("install", create=True) - assert obj is not None - i = cast(distutils_install_command, obj) - # 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), f"user={user} prefix={prefix}" - assert not (home and prefix), f"home={home} prefix={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({"purelib": i.install_lib, "platlib": i.install_lib}) - - if running_under_virtualenv(): - if home: - prefix = home - elif user: - prefix = i.install_userbase - else: - prefix = i.prefix - scheme["headers"] = os.path.join( - prefix, - "include", - "site", - f"python{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: str, - user: bool = False, - home: Optional[str] = None, - root: Optional[str] = None, - isolated: bool = False, - prefix: Optional[str] = None, -) -> Scheme: - """ - Get the "scheme" corresponding to the input parameters. The distutils - documentation provides the context for the available schemes: - 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"], - ) - - -def get_bin_prefix() -> str: - # XXX: In old virtualenv versions, sys.prefix can contain '..' components, - # so we need to call normpath to eliminate them. - prefix = os.path.normpath(sys.prefix) - if WINDOWS: - bin_py = os.path.join(prefix, "Scripts") - # buildout uses 'bin' on Windows too? - if not os.path.exists(bin_py): - bin_py = os.path.join(prefix, "bin") - return bin_py - # Forcing to use /usr/local/bin for standard macOS framework installs - # Also log to ~/Library/Logs/ for use with the Console.app log viewer - if sys.platform[:6] == "darwin" and prefix[:16] == "/System/Library/": - return "/usr/local/bin" - return os.path.join(prefix, "bin") - - -def get_purelib() -> str: - return get_python_lib(plat_specific=False) - - -def get_platlib() -> str: - return get_python_lib(plat_specific=True) diff --git a/venv/lib/python3.12/site-packages/pip/_internal/locations/_sysconfig.py b/venv/lib/python3.12/site-packages/pip/_internal/locations/_sysconfig.py deleted file mode 100644 index 97aef1f..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/locations/_sysconfig.py +++ /dev/null @@ -1,213 +0,0 @@ -import logging -import os -import sys -import sysconfig -import typing - -from pip._internal.exceptions import InvalidSchemeCombination, UserInstallationInvalid -from pip._internal.models.scheme import SCHEME_KEYS, Scheme -from pip._internal.utils.virtualenv import running_under_virtualenv - -from .base import change_root, get_major_minor_version, is_osx_framework - -logger = logging.getLogger(__name__) - - -# Notes on _infer_* functions. -# Unfortunately ``get_default_scheme()`` didn't exist before 3.10, so there's no -# way to ask things like "what is the '_prefix' scheme on this platform". These -# functions try to answer that with some heuristics while accounting for ad-hoc -# platforms not covered by CPython's default sysconfig implementation. If the -# ad-hoc implementation does not fully implement sysconfig, we'll fall back to -# a POSIX scheme. - -_AVAILABLE_SCHEMES = set(sysconfig.get_scheme_names()) - -_PREFERRED_SCHEME_API = getattr(sysconfig, "get_preferred_scheme", None) - - -def _should_use_osx_framework_prefix() -> bool: - """Check for Apple's ``osx_framework_library`` scheme. - - Python distributed by Apple's Command Line Tools has this special scheme - that's used when: - - * This is a framework build. - * We are installing into the system prefix. - - This does not account for ``pip install --prefix`` (also means we're not - installing to the system prefix), which should use ``posix_prefix``, but - logic here means ``_infer_prefix()`` outputs ``osx_framework_library``. But - since ``prefix`` is not available for ``sysconfig.get_default_scheme()``, - which is the stdlib replacement for ``_infer_prefix()``, presumably Apple - wouldn't be able to magically switch between ``osx_framework_library`` and - ``posix_prefix``. ``_infer_prefix()`` returning ``osx_framework_library`` - means its behavior is consistent whether we use the stdlib implementation - or our own, and we deal with this special case in ``get_scheme()`` instead. - """ - return ( - "osx_framework_library" in _AVAILABLE_SCHEMES - and not running_under_virtualenv() - and is_osx_framework() - ) - - -def _infer_prefix() -> str: - """Try to find a prefix scheme for the current platform. - - This tries: - - * A special ``osx_framework_library`` for Python distributed by Apple's - Command Line Tools, when not running in a virtual environment. - * Implementation + OS, used by PyPy on Windows (``pypy_nt``). - * Implementation without OS, used by PyPy on POSIX (``pypy``). - * OS + "prefix", used by CPython on POSIX (``posix_prefix``). - * Just the OS name, used by CPython on Windows (``nt``). - - If none of the above works, fall back to ``posix_prefix``. - """ - if _PREFERRED_SCHEME_API: - return _PREFERRED_SCHEME_API("prefix") - if _should_use_osx_framework_prefix(): - return "osx_framework_library" - implementation_suffixed = f"{sys.implementation.name}_{os.name}" - if implementation_suffixed in _AVAILABLE_SCHEMES: - return implementation_suffixed - if sys.implementation.name in _AVAILABLE_SCHEMES: - return sys.implementation.name - suffixed = f"{os.name}_prefix" - if suffixed in _AVAILABLE_SCHEMES: - return suffixed - if os.name in _AVAILABLE_SCHEMES: # On Windows, prefx is just called "nt". - return os.name - return "posix_prefix" - - -def _infer_user() -> str: - """Try to find a user scheme for the current platform.""" - if _PREFERRED_SCHEME_API: - return _PREFERRED_SCHEME_API("user") - if is_osx_framework() and not running_under_virtualenv(): - suffixed = "osx_framework_user" - else: - suffixed = f"{os.name}_user" - if suffixed in _AVAILABLE_SCHEMES: - return suffixed - if "posix_user" not in _AVAILABLE_SCHEMES: # User scheme unavailable. - raise UserInstallationInvalid() - return "posix_user" - - -def _infer_home() -> str: - """Try to find a home for the current platform.""" - if _PREFERRED_SCHEME_API: - return _PREFERRED_SCHEME_API("home") - suffixed = f"{os.name}_home" - if suffixed in _AVAILABLE_SCHEMES: - return suffixed - return "posix_home" - - -# Update these keys if the user sets a custom home. -_HOME_KEYS = [ - "installed_base", - "base", - "installed_platbase", - "platbase", - "prefix", - "exec_prefix", -] -if sysconfig.get_config_var("userbase") is not None: - _HOME_KEYS.append("userbase") - - -def get_scheme( - dist_name: str, - user: bool = False, - home: typing.Optional[str] = None, - root: typing.Optional[str] = None, - isolated: bool = False, - prefix: typing.Optional[str] = None, -) -> Scheme: - """ - Get the "scheme" corresponding to the input parameters. - - :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 - :param root: root under which other directories are re-based - :param isolated: ignored, but kept for distutils compatibility (where - this controls whether the user-site pydistutils.cfg is honored) - :param prefix: indicates to use the "prefix" scheme and provides the - base directory for the same - """ - if user and prefix: - raise InvalidSchemeCombination("--user", "--prefix") - if home and prefix: - raise InvalidSchemeCombination("--home", "--prefix") - - if home is not None: - scheme_name = _infer_home() - elif user: - scheme_name = _infer_user() - else: - scheme_name = _infer_prefix() - - # Special case: When installing into a custom prefix, use posix_prefix - # instead of osx_framework_library. See _should_use_osx_framework_prefix() - # docstring for details. - if prefix is not None and scheme_name == "osx_framework_library": - scheme_name = "posix_prefix" - - if home is not None: - variables = {k: home for k in _HOME_KEYS} - elif prefix is not None: - variables = {k: prefix for k in _HOME_KEYS} - else: - variables = {} - - paths = sysconfig.get_paths(scheme=scheme_name, vars=variables) - - # Logic here is very arbitrary, we're doing it for compatibility, don't ask. - # 1. Pip historically uses a special header path in virtual environments. - # 2. If the distribution name is not known, distutils uses 'UNKNOWN'. We - # only do the same when not running in a virtual environment because - # pip's historical header path logic (see point 1) did not do this. - if running_under_virtualenv(): - if user: - base = variables.get("userbase", sys.prefix) - else: - base = variables.get("base", sys.prefix) - python_xy = f"python{get_major_minor_version()}" - paths["include"] = os.path.join(base, "include", "site", python_xy) - elif not dist_name: - dist_name = "UNKNOWN" - - scheme = Scheme( - platlib=paths["platlib"], - purelib=paths["purelib"], - headers=os.path.join(paths["include"], dist_name), - scripts=paths["scripts"], - data=paths["data"], - ) - if root is not None: - for key in SCHEME_KEYS: - value = change_root(root, getattr(scheme, key)) - setattr(scheme, key, value) - return scheme - - -def get_bin_prefix() -> str: - # Forcing to use /usr/local/bin for standard macOS framework installs. - if sys.platform[:6] == "darwin" and sys.prefix[:16] == "/System/Library/": - return "/usr/local/bin" - return sysconfig.get_paths()["scripts"] - - -def get_purelib() -> str: - return sysconfig.get_paths()["purelib"] - - -def get_platlib() -> str: - return sysconfig.get_paths()["platlib"] diff --git a/venv/lib/python3.12/site-packages/pip/_internal/locations/base.py b/venv/lib/python3.12/site-packages/pip/_internal/locations/base.py deleted file mode 100644 index 3f9f896..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/locations/base.py +++ /dev/null @@ -1,81 +0,0 @@ -import functools -import os -import site -import sys -import sysconfig -import typing - -from pip._internal.exceptions import InstallationError -from pip._internal.utils import appdirs -from pip._internal.utils.virtualenv import running_under_virtualenv - -# Application Directories -USER_CACHE_DIR = appdirs.user_cache_dir("pip") - -# FIXME doesn't account for venv linked to global site-packages -site_packages: str = sysconfig.get_path("purelib") - - -def get_major_minor_version() -> str: - """ - Return the major-minor version of the current Python as a string, e.g. - "3.7" or "3.10". - """ - return "{}.{}".format(*sys.version_info) - - -def change_root(new_root: str, pathname: str) -> str: - """Return 'pathname' with 'new_root' prepended. - - If 'pathname' is relative, this is equivalent to os.path.join(new_root, pathname). - Otherwise, it requires making 'pathname' relative and then joining the - two, which is tricky on DOS/Windows and Mac OS. - - This is borrowed from Python's standard library's distutils module. - """ - if os.name == "posix": - if not os.path.isabs(pathname): - return os.path.join(new_root, pathname) - else: - return os.path.join(new_root, pathname[1:]) - - elif os.name == "nt": - (drive, path) = os.path.splitdrive(pathname) - if path[0] == "\\": - path = path[1:] - return os.path.join(new_root, path) - - else: - raise InstallationError( - f"Unknown platform: {os.name}\n" - "Can not change root path prefix on unknown platform." - ) - - -def get_src_prefix() -> str: - if running_under_virtualenv(): - src_prefix = os.path.join(sys.prefix, "src") - else: - # 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) - - -try: - # Use getusersitepackages if this is present, as it ensures that the - # value is initialised properly. - user_site: typing.Optional[str] = site.getusersitepackages() -except AttributeError: - user_site = site.USER_SITE - - -@functools.lru_cache(maxsize=None) -def is_osx_framework() -> bool: - return bool(sysconfig.get_config_var("PYTHONFRAMEWORK")) diff --git a/venv/lib/python3.12/site-packages/pip/_internal/main.py b/venv/lib/python3.12/site-packages/pip/_internal/main.py deleted file mode 100644 index 33c6d24..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/main.py +++ /dev/null @@ -1,12 +0,0 @@ -from typing import List, Optional - - -def main(args: Optional[List[str]] = None) -> 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.12/site-packages/pip/_internal/metadata/__init__.py b/venv/lib/python3.12/site-packages/pip/_internal/metadata/__init__.py deleted file mode 100644 index aa232b6..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/metadata/__init__.py +++ /dev/null @@ -1,128 +0,0 @@ -import contextlib -import functools -import os -import sys -from typing import TYPE_CHECKING, List, Optional, Type, cast - -from pip._internal.utils.misc import strtobool - -from .base import BaseDistribution, BaseEnvironment, FilesystemWheel, MemoryWheel, Wheel - -if TYPE_CHECKING: - from typing import Literal, Protocol -else: - Protocol = object - -__all__ = [ - "BaseDistribution", - "BaseEnvironment", - "FilesystemWheel", - "MemoryWheel", - "Wheel", - "get_default_environment", - "get_environment", - "get_wheel_distribution", - "select_backend", -] - - -def _should_use_importlib_metadata() -> bool: - """Whether to use the ``importlib.metadata`` or ``pkg_resources`` backend. - - By default, pip uses ``importlib.metadata`` on Python 3.11+, and - ``pkg_resourcess`` otherwise. This can be overridden by a couple of ways: - - * If environment variable ``_PIP_USE_IMPORTLIB_METADATA`` is set, it - dictates whether ``importlib.metadata`` is used, regardless of Python - version. - * On Python 3.11+, Python distributors can patch ``importlib.metadata`` - to add a global constant ``_PIP_USE_IMPORTLIB_METADATA = False``. This - makes pip use ``pkg_resources`` (unless the user set the aforementioned - environment variable to *True*). - """ - with contextlib.suppress(KeyError, ValueError): - return bool(strtobool(os.environ["_PIP_USE_IMPORTLIB_METADATA"])) - if sys.version_info < (3, 11): - return False - import importlib.metadata - - return bool(getattr(importlib.metadata, "_PIP_USE_IMPORTLIB_METADATA", True)) - - -class Backend(Protocol): - NAME: 'Literal["importlib", "pkg_resources"]' - Distribution: Type[BaseDistribution] - Environment: Type[BaseEnvironment] - - -@functools.lru_cache(maxsize=None) -def select_backend() -> Backend: - if _should_use_importlib_metadata(): - from . import importlib - - return cast(Backend, importlib) - from . import pkg_resources - - return cast(Backend, pkg_resources) - - -def get_default_environment() -> BaseEnvironment: - """Get the default representation for the current environment. - - This returns an Environment instance from the chosen backend. The default - Environment instance should be built from ``sys.path`` and may use caching - to share instance state accorss calls. - """ - return select_backend().Environment.default() - - -def get_environment(paths: Optional[List[str]]) -> BaseEnvironment: - """Get a representation of the environment specified by ``paths``. - - This returns an Environment instance from the chosen backend based on the - given import paths. The backend must build a fresh instance representing - the state of installed distributions when this function is called. - """ - return select_backend().Environment.from_paths(paths) - - -def get_directory_distribution(directory: str) -> BaseDistribution: - """Get the distribution metadata representation in the specified directory. - - This returns a Distribution instance from the chosen backend based on - the given on-disk ``.dist-info`` directory. - """ - return select_backend().Distribution.from_directory(directory) - - -def get_wheel_distribution(wheel: Wheel, canonical_name: str) -> BaseDistribution: - """Get the representation of the specified wheel's distribution metadata. - - This returns a Distribution instance from the chosen backend based on - the given wheel's ``.dist-info`` directory. - - :param canonical_name: Normalized project name of the given wheel. - """ - return select_backend().Distribution.from_wheel(wheel, canonical_name) - - -def get_metadata_distribution( - metadata_contents: bytes, - filename: str, - canonical_name: str, -) -> BaseDistribution: - """Get the dist representation of the specified METADATA file contents. - - This returns a Distribution instance from the chosen backend sourced from the data - in `metadata_contents`. - - :param metadata_contents: Contents of a METADATA file within a dist, or one served - via PEP 658. - :param filename: Filename for the dist this metadata represents. - :param canonical_name: Normalized project name of the given dist. - """ - return select_backend().Distribution.from_metadata_file_contents( - metadata_contents, - filename, - canonical_name, - ) diff --git a/venv/lib/python3.12/site-packages/pip/_internal/metadata/__pycache__/__init__.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/metadata/__pycache__/__init__.cpython-312.pyc deleted file mode 100644 index 166ebdf9c305451daa5ebd31167fb50a3062c6e7..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 5892 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 g_JD5H&=AwPdA*8YD|eSO568;OAD(5^2o7iu6 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 diff --git a/venv/lib/python3.12/site-packages/pip/_internal/metadata/__pycache__/pkg_resources.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/metadata/__pycache__/pkg_resources.cpython-312.pyc deleted file mode 100644 index ec26c62320f390439f03aaf94026c0357124dda0..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 15800 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�qFt%V;oMpL73nU@ffM8Uy+17uYBSsjcu zs^TgBP*I|~yxdv8A-&60ObN<~y6ZR7ZVcTxmA7#!e%es`mDp(I2V_bR4_=ATARf7^ zx*`1_MwHUub}F$6HDf7F;!(K!LPdi#iYHk@ZMu zYymN`>_<%VM~v?y#{Cgvhx}vaOo=&DV9xv>X6Q%EzK@yXKVlC41%>>GnfjQS{FpiM zQ;Ur?{gi?1ftPXax?=mp-m%nHvUe2h9V>f__Q5OGPi(DMEDx<_)^n}nAp?(}x&my& krwn8dkFqbC*eN#e8+gdj(!)!Zo$T1PvA<^EK~ePY0PDEHegFUf diff --git a/venv/lib/python3.12/site-packages/pip/_internal/metadata/_json.py b/venv/lib/python3.12/site-packages/pip/_internal/metadata/_json.py deleted file mode 100644 index 27362fc..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/metadata/_json.py +++ /dev/null @@ -1,84 +0,0 @@ -# Extracted from https://github.com/pfmoore/pkg_metadata - -from email.header import Header, decode_header, make_header -from email.message import Message -from typing import Any, Dict, List, Union - -METADATA_FIELDS = [ - # Name, Multiple-Use - ("Metadata-Version", False), - ("Name", False), - ("Version", False), - ("Dynamic", True), - ("Platform", True), - ("Supported-Platform", True), - ("Summary", False), - ("Description", False), - ("Description-Content-Type", False), - ("Keywords", False), - ("Home-page", False), - ("Download-URL", False), - ("Author", False), - ("Author-email", False), - ("Maintainer", False), - ("Maintainer-email", False), - ("License", False), - ("Classifier", True), - ("Requires-Dist", True), - ("Requires-Python", False), - ("Requires-External", True), - ("Project-URL", True), - ("Provides-Extra", True), - ("Provides-Dist", True), - ("Obsoletes-Dist", True), -] - - -def json_name(field: str) -> str: - return field.lower().replace("-", "_") - - -def msg_to_json(msg: Message) -> Dict[str, Any]: - """Convert a Message object into a JSON-compatible dictionary.""" - - def sanitise_header(h: Union[Header, str]) -> str: - if isinstance(h, Header): - chunks = [] - for bytes, encoding in decode_header(h): - if encoding == "unknown-8bit": - try: - # See if UTF-8 works - bytes.decode("utf-8") - encoding = "utf-8" - except UnicodeDecodeError: - # If not, latin1 at least won't fail - encoding = "latin1" - chunks.append((bytes, encoding)) - return str(make_header(chunks)) - return str(h) - - result = {} - for field, multi in METADATA_FIELDS: - if field not in msg: - continue - key = json_name(field) - if multi: - value: Union[str, List[str]] = [ - sanitise_header(v) for v in msg.get_all(field) # type: ignore - ] - else: - value = sanitise_header(msg.get(field)) # type: ignore - if key == "keywords": - # Accept both comma-separated and space-separated - # forms, for better compatibility with old data. - if "," in value: - value = [v.strip() for v in value.split(",")] - else: - value = value.split() - result[key] = value - - payload = msg.get_payload() - if payload: - result["description"] = payload - - return result diff --git a/venv/lib/python3.12/site-packages/pip/_internal/metadata/base.py b/venv/lib/python3.12/site-packages/pip/_internal/metadata/base.py deleted file mode 100644 index 9249124..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/metadata/base.py +++ /dev/null @@ -1,702 +0,0 @@ -import csv -import email.message -import functools -import json -import logging -import pathlib -import re -import zipfile -from typing import ( - IO, - TYPE_CHECKING, - Any, - Collection, - Container, - Dict, - Iterable, - Iterator, - List, - NamedTuple, - Optional, - Tuple, - Union, -) - -from pip._vendor.packaging.requirements import Requirement -from pip._vendor.packaging.specifiers import InvalidSpecifier, SpecifierSet -from pip._vendor.packaging.utils import NormalizedName, canonicalize_name -from pip._vendor.packaging.version import LegacyVersion, Version - -from pip._internal.exceptions import NoneMetadataError -from pip._internal.locations import site_packages, user_site -from pip._internal.models.direct_url import ( - DIRECT_URL_METADATA_NAME, - DirectUrl, - DirectUrlValidationError, -) -from pip._internal.utils.compat import stdlib_pkgs # TODO: Move definition here. -from pip._internal.utils.egg_link import egg_link_path_from_sys_path -from pip._internal.utils.misc import is_local, normalize_path -from pip._internal.utils.urls import url_to_path - -from ._json import msg_to_json - -if TYPE_CHECKING: - from typing import Protocol -else: - Protocol = object - -DistributionVersion = Union[LegacyVersion, Version] - -InfoPath = Union[str, pathlib.PurePath] - -logger = logging.getLogger(__name__) - - -class BaseEntryPoint(Protocol): - @property - def name(self) -> str: - raise NotImplementedError() - - @property - def value(self) -> str: - raise NotImplementedError() - - @property - def group(self) -> str: - raise NotImplementedError() - - -def _convert_installed_files_path( - entry: Tuple[str, ...], - info: Tuple[str, ...], -) -> str: - """Convert a legacy installed-files.txt path into modern RECORD path. - - The legacy format stores paths relative to the info directory, while the - modern format stores paths relative to the package root, e.g. the - site-packages directory. - - :param entry: Path parts of the installed-files.txt entry. - :param info: Path parts of the egg-info directory relative to package root. - :returns: The converted entry. - - For best compatibility with symlinks, this does not use ``abspath()`` or - ``Path.resolve()``, but tries to work with path parts: - - 1. While ``entry`` starts with ``..``, remove the equal amounts of parts - from ``info``; if ``info`` is empty, start appending ``..`` instead. - 2. Join the two directly. - """ - while entry and entry[0] == "..": - if not info or info[-1] == "..": - info += ("..",) - else: - info = info[:-1] - entry = entry[1:] - return str(pathlib.Path(*info, *entry)) - - -class RequiresEntry(NamedTuple): - requirement: str - extra: str - marker: str - - -class BaseDistribution(Protocol): - @classmethod - def from_directory(cls, directory: str) -> "BaseDistribution": - """Load the distribution from a metadata directory. - - :param directory: Path to a metadata directory, e.g. ``.dist-info``. - """ - raise NotImplementedError() - - @classmethod - def from_metadata_file_contents( - cls, - metadata_contents: bytes, - filename: str, - project_name: str, - ) -> "BaseDistribution": - """Load the distribution from the contents of a METADATA file. - - This is used to implement PEP 658 by generating a "shallow" dist object that can - be used for resolution without downloading or building the actual dist yet. - - :param metadata_contents: The contents of a METADATA file. - :param filename: File name for the dist with this metadata. - :param project_name: Name of the project this dist represents. - """ - raise NotImplementedError() - - @classmethod - def from_wheel(cls, wheel: "Wheel", name: str) -> "BaseDistribution": - """Load the distribution from a given wheel. - - :param wheel: A concrete wheel definition. - :param name: File name of the wheel. - - :raises InvalidWheel: Whenever loading of the wheel causes a - :py:exc:`zipfile.BadZipFile` exception to be thrown. - :raises UnsupportedWheel: If the wheel is a valid zip, but malformed - internally. - """ - raise NotImplementedError() - - def __repr__(self) -> str: - return f"{self.raw_name} {self.version} ({self.location})" - - def __str__(self) -> str: - return f"{self.raw_name} {self.version}" - - @property - def location(self) -> Optional[str]: - """Where the distribution is loaded from. - - A string value is not necessarily a filesystem path, since distributions - can be loaded from other sources, e.g. arbitrary zip archives. ``None`` - means the distribution is created in-memory. - - Do not canonicalize this value with e.g. ``pathlib.Path.resolve()``. If - this is a symbolic link, we want to preserve the relative path between - it and files in the distribution. - """ - raise NotImplementedError() - - @property - def editable_project_location(self) -> Optional[str]: - """The project location for editable distributions. - - This is the directory where pyproject.toml or setup.py is located. - None if the distribution is not installed in editable mode. - """ - # TODO: this property is relatively costly to compute, memoize it ? - direct_url = self.direct_url - if direct_url: - if direct_url.is_local_editable(): - return url_to_path(direct_url.url) - else: - # Search for an .egg-link file by walking sys.path, as it was - # done before by dist_is_editable(). - egg_link_path = egg_link_path_from_sys_path(self.raw_name) - if egg_link_path: - # TODO: get project location from second line of egg_link file - # (https://github.com/pypa/pip/issues/10243) - return self.location - return None - - @property - def installed_location(self) -> Optional[str]: - """The distribution's "installed" location. - - This should generally be a ``site-packages`` directory. This is - usually ``dist.location``, except for legacy develop-installed packages, - where ``dist.location`` is the source code location, and this is where - the ``.egg-link`` file is. - - The returned location is normalized (in particular, with symlinks removed). - """ - raise NotImplementedError() - - @property - def info_location(self) -> Optional[str]: - """Location of the .[egg|dist]-info directory or file. - - Similarly to ``location``, a string value is not necessarily a - filesystem path. ``None`` means the distribution is created in-memory. - - For a modern .dist-info installation on disk, this should be something - like ``{location}/{raw_name}-{version}.dist-info``. - - Do not canonicalize this value with e.g. ``pathlib.Path.resolve()``. If - this is a symbolic link, we want to preserve the relative path between - it and other files in the distribution. - """ - raise NotImplementedError() - - @property - def installed_by_distutils(self) -> bool: - """Whether this distribution is installed with legacy distutils format. - - A distribution installed with "raw" distutils not patched by setuptools - uses one single file at ``info_location`` to store metadata. We need to - treat this specially on uninstallation. - """ - info_location = self.info_location - if not info_location: - return False - return pathlib.Path(info_location).is_file() - - @property - def installed_as_egg(self) -> bool: - """Whether this distribution is installed as an egg. - - This usually indicates the distribution was installed by (older versions - of) easy_install. - """ - location = self.location - if not location: - return False - return location.endswith(".egg") - - @property - def installed_with_setuptools_egg_info(self) -> bool: - """Whether this distribution is installed with the ``.egg-info`` format. - - This usually indicates the distribution was installed with setuptools - with an old pip version or with ``single-version-externally-managed``. - - Note that this ensure the metadata store is a directory. distutils can - also installs an ``.egg-info``, but as a file, not a directory. This - property is *False* for that case. Also see ``installed_by_distutils``. - """ - info_location = self.info_location - if not info_location: - return False - if not info_location.endswith(".egg-info"): - return False - return pathlib.Path(info_location).is_dir() - - @property - def installed_with_dist_info(self) -> bool: - """Whether this distribution is installed with the "modern format". - - This indicates a "modern" installation, e.g. storing metadata in the - ``.dist-info`` directory. This applies to installations made by - setuptools (but through pip, not directly), or anything using the - standardized build backend interface (PEP 517). - """ - info_location = self.info_location - if not info_location: - return False - if not info_location.endswith(".dist-info"): - return False - return pathlib.Path(info_location).is_dir() - - @property - def canonical_name(self) -> NormalizedName: - raise NotImplementedError() - - @property - def version(self) -> DistributionVersion: - raise NotImplementedError() - - @property - def setuptools_filename(self) -> str: - """Convert a project name to its setuptools-compatible filename. - - This is a copy of ``pkg_resources.to_filename()`` for compatibility. - """ - return self.raw_name.replace("-", "_") - - @property - def direct_url(self) -> Optional[DirectUrl]: - """Obtain a DirectUrl from this distribution. - - Returns None if the distribution has no `direct_url.json` metadata, - or if `direct_url.json` is invalid. - """ - try: - content = self.read_text(DIRECT_URL_METADATA_NAME) - except FileNotFoundError: - return None - try: - return DirectUrl.from_json(content) - except ( - UnicodeDecodeError, - json.JSONDecodeError, - DirectUrlValidationError, - ) as e: - logger.warning( - "Error parsing %s for %s: %s", - DIRECT_URL_METADATA_NAME, - self.canonical_name, - e, - ) - return None - - @property - def installer(self) -> str: - try: - installer_text = self.read_text("INSTALLER") - except (OSError, ValueError, NoneMetadataError): - return "" # Fail silently if the installer file cannot be read. - for line in installer_text.splitlines(): - cleaned_line = line.strip() - if cleaned_line: - return cleaned_line - return "" - - @property - def requested(self) -> bool: - return self.is_file("REQUESTED") - - @property - def editable(self) -> bool: - return bool(self.editable_project_location) - - @property - def local(self) -> bool: - """If distribution is installed in the current virtual environment. - - Always True if we're not in a virtualenv. - """ - if self.installed_location is None: - return False - return is_local(self.installed_location) - - @property - def in_usersite(self) -> bool: - if self.installed_location is None or user_site is None: - return False - return self.installed_location.startswith(normalize_path(user_site)) - - @property - def in_site_packages(self) -> bool: - if self.installed_location is None or site_packages is None: - return False - return self.installed_location.startswith(normalize_path(site_packages)) - - def is_file(self, path: InfoPath) -> bool: - """Check whether an entry in the info directory is a file.""" - raise NotImplementedError() - - def iter_distutils_script_names(self) -> Iterator[str]: - """Find distutils 'scripts' entries metadata. - - If 'scripts' is supplied in ``setup.py``, distutils records those in the - installed distribution's ``scripts`` directory, a file for each script. - """ - raise NotImplementedError() - - def read_text(self, path: InfoPath) -> str: - """Read a file in the info directory. - - :raise FileNotFoundError: If ``path`` does not exist in the directory. - :raise NoneMetadataError: If ``path`` exists in the info directory, but - cannot be read. - """ - raise NotImplementedError() - - def iter_entry_points(self) -> Iterable[BaseEntryPoint]: - raise NotImplementedError() - - def _metadata_impl(self) -> email.message.Message: - raise NotImplementedError() - - @functools.lru_cache(maxsize=1) - def _metadata_cached(self) -> email.message.Message: - # When we drop python 3.7 support, move this to the metadata property and use - # functools.cached_property instead of lru_cache. - metadata = self._metadata_impl() - self._add_egg_info_requires(metadata) - return metadata - - @property - def metadata(self) -> email.message.Message: - """Metadata of distribution parsed from e.g. METADATA or PKG-INFO. - - This should return an empty message if the metadata file is unavailable. - - :raises NoneMetadataError: If the metadata file is available, but does - not contain valid metadata. - """ - return self._metadata_cached() - - @property - def metadata_dict(self) -> Dict[str, Any]: - """PEP 566 compliant JSON-serializable representation of METADATA or PKG-INFO. - - This should return an empty dict if the metadata file is unavailable. - - :raises NoneMetadataError: If the metadata file is available, but does - not contain valid metadata. - """ - return msg_to_json(self.metadata) - - @property - def metadata_version(self) -> Optional[str]: - """Value of "Metadata-Version:" in distribution metadata, if available.""" - return self.metadata.get("Metadata-Version") - - @property - def raw_name(self) -> str: - """Value of "Name:" in distribution metadata.""" - # The metadata should NEVER be missing the Name: key, but if it somehow - # does, fall back to the known canonical name. - return self.metadata.get("Name", self.canonical_name) - - @property - def requires_python(self) -> SpecifierSet: - """Value of "Requires-Python:" in distribution metadata. - - If the key does not exist or contains an invalid value, an empty - SpecifierSet should be returned. - """ - value = self.metadata.get("Requires-Python") - if value is None: - return SpecifierSet() - try: - # Convert to str to satisfy the type checker; this can be a Header object. - spec = SpecifierSet(str(value)) - except InvalidSpecifier as e: - message = "Package %r has an invalid Requires-Python: %s" - logger.warning(message, self.raw_name, e) - return SpecifierSet() - return spec - - def iter_dependencies(self, extras: Collection[str] = ()) -> Iterable[Requirement]: - """Dependencies of this distribution. - - For modern .dist-info distributions, this is the collection of - "Requires-Dist:" entries in distribution metadata. - """ - raise NotImplementedError() - - def iter_provided_extras(self) -> Iterable[str]: - """Extras provided by this distribution. - - For modern .dist-info distributions, this is the collection of - "Provides-Extra:" entries in distribution metadata. - - The return value of this function is not particularly useful other than - display purposes due to backward compatibility issues and the extra - names being poorly normalized prior to PEP 685. If you want to perform - logic operations on extras, use :func:`is_extra_provided` instead. - """ - raise NotImplementedError() - - def is_extra_provided(self, extra: str) -> bool: - """Check whether an extra is provided by this distribution. - - This is needed mostly for compatibility issues with pkg_resources not - following the extra normalization rules defined in PEP 685. - """ - raise NotImplementedError() - - def _iter_declared_entries_from_record(self) -> Optional[Iterator[str]]: - try: - text = self.read_text("RECORD") - except FileNotFoundError: - return None - # This extra Path-str cast normalizes entries. - return (str(pathlib.Path(row[0])) for row in csv.reader(text.splitlines())) - - def _iter_declared_entries_from_legacy(self) -> Optional[Iterator[str]]: - try: - text = self.read_text("installed-files.txt") - except FileNotFoundError: - return None - paths = (p for p in text.splitlines(keepends=False) if p) - root = self.location - info = self.info_location - if root is None or info is None: - return paths - try: - info_rel = pathlib.Path(info).relative_to(root) - except ValueError: # info is not relative to root. - return paths - if not info_rel.parts: # info *is* root. - return paths - return ( - _convert_installed_files_path(pathlib.Path(p).parts, info_rel.parts) - for p in paths - ) - - def iter_declared_entries(self) -> Optional[Iterator[str]]: - """Iterate through file entries declared in this distribution. - - For modern .dist-info distributions, this is the files listed in the - ``RECORD`` metadata file. For legacy setuptools distributions, this - comes from ``installed-files.txt``, with entries normalized to be - compatible with the format used by ``RECORD``. - - :return: An iterator for listed entries, or None if the distribution - contains neither ``RECORD`` nor ``installed-files.txt``. - """ - return ( - self._iter_declared_entries_from_record() - or self._iter_declared_entries_from_legacy() - ) - - def _iter_requires_txt_entries(self) -> Iterator[RequiresEntry]: - """Parse a ``requires.txt`` in an egg-info directory. - - This is an INI-ish format where an egg-info stores dependencies. A - section name describes extra other environment markers, while each entry - is an arbitrary string (not a key-value pair) representing a dependency - as a requirement string (no markers). - - There is a construct in ``importlib.metadata`` called ``Sectioned`` that - does mostly the same, but the format is currently considered private. - """ - try: - content = self.read_text("requires.txt") - except FileNotFoundError: - return - extra = marker = "" # Section-less entries don't have markers. - for line in content.splitlines(): - line = line.strip() - if not line or line.startswith("#"): # Comment; ignored. - continue - if line.startswith("[") and line.endswith("]"): # A section header. - extra, _, marker = line.strip("[]").partition(":") - continue - yield RequiresEntry(requirement=line, extra=extra, marker=marker) - - def _iter_egg_info_extras(self) -> Iterable[str]: - """Get extras from the egg-info directory.""" - known_extras = {""} - for entry in self._iter_requires_txt_entries(): - extra = canonicalize_name(entry.extra) - if extra in known_extras: - continue - known_extras.add(extra) - yield extra - - def _iter_egg_info_dependencies(self) -> Iterable[str]: - """Get distribution dependencies from the egg-info directory. - - To ease parsing, this converts a legacy dependency entry into a PEP 508 - requirement string. Like ``_iter_requires_txt_entries()``, there is code - in ``importlib.metadata`` that does mostly the same, but not do exactly - what we need. - - Namely, ``importlib.metadata`` does not normalize the extra name before - putting it into the requirement string, which causes marker comparison - to fail because the dist-info format do normalize. This is consistent in - all currently available PEP 517 backends, although not standardized. - """ - for entry in self._iter_requires_txt_entries(): - extra = canonicalize_name(entry.extra) - if extra and entry.marker: - marker = f'({entry.marker}) and extra == "{extra}"' - elif extra: - marker = f'extra == "{extra}"' - elif entry.marker: - marker = entry.marker - else: - marker = "" - if marker: - yield f"{entry.requirement} ; {marker}" - else: - yield entry.requirement - - def _add_egg_info_requires(self, metadata: email.message.Message) -> None: - """Add egg-info requires.txt information to the metadata.""" - if not metadata.get_all("Requires-Dist"): - for dep in self._iter_egg_info_dependencies(): - metadata["Requires-Dist"] = dep - if not metadata.get_all("Provides-Extra"): - for extra in self._iter_egg_info_extras(): - metadata["Provides-Extra"] = extra - - -class BaseEnvironment: - """An environment containing distributions to introspect.""" - - @classmethod - def default(cls) -> "BaseEnvironment": - raise NotImplementedError() - - @classmethod - def from_paths(cls, paths: Optional[List[str]]) -> "BaseEnvironment": - raise NotImplementedError() - - def get_distribution(self, name: str) -> Optional["BaseDistribution"]: - """Given a requirement name, return the installed distributions. - - The name may not be normalized. The implementation must canonicalize - it for lookup. - """ - raise NotImplementedError() - - def _iter_distributions(self) -> Iterator["BaseDistribution"]: - """Iterate through installed distributions. - - This function should be implemented by subclass, but never called - directly. Use the public ``iter_distribution()`` instead, which - implements additional logic to make sure the distributions are valid. - """ - raise NotImplementedError() - - def iter_all_distributions(self) -> Iterator[BaseDistribution]: - """Iterate through all installed distributions without any filtering.""" - for dist in self._iter_distributions(): - # Make sure the distribution actually comes from a valid Python - # packaging distribution. Pip's AdjacentTempDirectory leaves folders - # e.g. ``~atplotlib.dist-info`` if cleanup was interrupted. The - # valid project name pattern is taken from PEP 508. - project_name_valid = re.match( - r"^([A-Z0-9]|[A-Z0-9][A-Z0-9._-]*[A-Z0-9])$", - dist.canonical_name, - flags=re.IGNORECASE, - ) - if not project_name_valid: - logger.warning( - "Ignoring invalid distribution %s (%s)", - dist.canonical_name, - dist.location, - ) - continue - yield dist - - def iter_installed_distributions( - self, - local_only: bool = True, - skip: Container[str] = stdlib_pkgs, - include_editables: bool = True, - editables_only: bool = False, - user_only: bool = False, - ) -> Iterator[BaseDistribution]: - """Return a list of installed distributions. - - This is based on ``iter_all_distributions()`` with additional filtering - options. Note that ``iter_installed_distributions()`` without arguments - is *not* equal to ``iter_all_distributions()``, since some of the - configurations exclude packages by default. - - :param local_only: If True (default), only return installations - local to the current virtualenv, if in a virtualenv. - :param skip: An iterable of canonicalized project names to ignore; - defaults to ``stdlib_pkgs``. - :param include_editables: If False, don't report editables. - :param editables_only: If True, only report editables. - :param user_only: If True, only report installations in the user - site directory. - """ - it = self.iter_all_distributions() - if local_only: - it = (d for d in it if d.local) - if not include_editables: - it = (d for d in it if not d.editable) - if editables_only: - it = (d for d in it if d.editable) - if user_only: - it = (d for d in it if d.in_usersite) - return (d for d in it if d.canonical_name not in skip) - - -class Wheel(Protocol): - location: str - - def as_zipfile(self) -> zipfile.ZipFile: - raise NotImplementedError() - - -class FilesystemWheel(Wheel): - def __init__(self, location: str) -> None: - self.location = location - - def as_zipfile(self) -> zipfile.ZipFile: - return zipfile.ZipFile(self.location, allowZip64=True) - - -class MemoryWheel(Wheel): - def __init__(self, location: str, stream: IO[bytes]) -> None: - self.location = location - self.stream = stream - - def as_zipfile(self) -> zipfile.ZipFile: - return zipfile.ZipFile(self.stream, allowZip64=True) diff --git a/venv/lib/python3.12/site-packages/pip/_internal/metadata/importlib/__init__.py b/venv/lib/python3.12/site-packages/pip/_internal/metadata/importlib/__init__.py deleted file mode 100644 index a779138..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/metadata/importlib/__init__.py +++ /dev/null @@ -1,6 +0,0 @@ -from ._dists import Distribution -from ._envs import Environment - -__all__ = ["NAME", "Distribution", "Environment"] - -NAME = "importlib" diff --git a/venv/lib/python3.12/site-packages/pip/_internal/metadata/importlib/__pycache__/__init__.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/metadata/importlib/__pycache__/__init__.cpython-312.pyc deleted file mode 100644 index 4040bb42f45b5bb5febc48e73c6da68c475f17de..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 368 zcmX|6yGjE=6rIWLCYqQ=uoX+UNQP)DLNF;T4A$EW6K6<<%!`@HLaem1w6qmFzr{aT z2#8j8Lb_Dm_`1cp=W@<{y|mj+1o7Ctmv@lgH^pDne#z<($OGbtV}&#>Fy8Q*s_CRi zFq$BqJmDhcX^}0my#9f~p5tm~AVc(WJde^Es9Qr*N^gx8Cgw?%j`|lvpMck=0M)kC z&ibh2c$C+xI_1zEzV#}j!j$31)}WLrMXArA=^3p6(Yhp4s|E3lOXFb2{F)3zm__SI z-g;E_ diff --git a/venv/lib/python3.12/site-packages/pip/_internal/metadata/importlib/__pycache__/_compat.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/metadata/importlib/__pycache__/_compat.cpython-312.pyc deleted file mode 100644 index cec912b26cda32a306d8dc6c4299119d3c9afe49..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3343 zcmbVOO>7&-72YM66e;S@mXk_NR8JZOG8LP&Q?xM(+l6d5P7p+KP^UkSRx?iRv9Q+-^J;N~^(=#e2`jnTdrz`2Y zRk7-sN~WHzWKAPw+%TN)@H?7K$Gx$HP9>%%?){V5x;?Tdz?0nIR({p|+&b=QhH}JU^=WfbC1$N-Y zmdzt&cXy{g+xa=T1>v3{bPy^j#}w)1TxYDWTh<}%Q$Tc5BI~3bYbonw;L3oL7TKkg zlZBjXS;c|4aFsjn3B?_*cx*Xtq~fd;JPLg3RYUsocB*63L{BmW`GBFhXRMp+Mio-> zt*7uuv-H<8cFg&ml+5E#l5fRyY(>IbdZvlU6l3gZqg)H>qAa=N`k^a>##;Hhh*ne( zmgi)X`{(9vzH{!H=a!qoZe{KkIF!0tNG|(>$OuNd5$zksNcs<%9~ebzer*iSu&(FK_1RjA zoq1{&

< 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 Gc>W(+M4t`- diff --git a/venv/lib/python3.12/site-packages/pip/_internal/operations/build/__init__.py b/venv/lib/python3.12/site-packages/pip/_internal/operations/build/__init__.py deleted file mode 100644 index e69de29..0000000 diff --git a/venv/lib/python3.12/site-packages/pip/_internal/operations/build/__pycache__/__init__.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/operations/build/__pycache__/__init__.cpython-312.pyc deleted file mode 100644 index b62c9b48a74572bd527a136882a3b9459a7d024f..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 213 zcmZ8bK?=e!5Nxc12z`i$c2Tb)6uo#6e-Kg|?9wy|Nm{6%@aWa6Z}AzvKzi%R`@N7NC1qDY?m3Yq02es@bJxS8hS028z;gBbflDxnT~Kv{1AtN}&FS dj?zr`<9yqwvK4%1X1)aRV}tm{gb)*Z^#imKI`RMj diff --git a/venv/lib/python3.12/site-packages/pip/_internal/operations/build/__pycache__/build_tracker.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/operations/build/__pycache__/build_tracker.cpython-312.pyc deleted file mode 100644 index d381d194eb098440cda98fc620d56c9eac4c4b39..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 7833 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 IEGg^$2f9YnPXGV_ diff --git a/venv/lib/python3.12/site-packages/pip/_internal/operations/build/__pycache__/metadata.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/operations/build/__pycache__/metadata.cpython-312.pyc deleted file mode 100644 index 937bfbbdf4582e07229c219e83f70b1e8e64dd0d..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1890 zcmZ`)&2JM&6rb4-ukCpAK~RVk+N=sq>PqpJ0!6BT76T2aZHQtx;LB>`nZ%pymuA*6 ziJTTyJrt=b>Zv{Sz_o%updTl4iquO`kU*VB9I)cD_;(`dtX=$aXf{b=Z7^2&y82iR9uchE;YYPp-;XoGGs2sZ}-E zt8T{As+yOrW)nH%=Dd70pX@ca$179|u+LJJV<#jdFgGv4F+HDUiu7jt^|d zr39Rfu!axdtfmvyEgm|F;K5aUo`PDxO1T!Tg%siMLoZ_!si_92T*UU~UhQfqU{@sV%L_EqS4{Pc6i{sgX zES>6jBU}c$E&#iBpw|TH^wxh@lvJky#HsYBHNRehAgtSTQe9z8D3ed5$gF{=~WI%M<5a$6SJn zGF@lZ440#N;2$p?d)wqrL?=3N;AZHArsen%1lo4ZAnf!LZYE!6rT|Ofay-y!H~V2= zhXIu!DgOzkn`oyO9Xh&Ee0Tlo!=ag*SDp;M_GobY!QlAKkDlZXJVQCPf_Jj$z{JMH z%;rGli_ByF;3IwPfj)L;X;UvfLrSiKwHb<|0UD#EHZnr0K zF@y@ew@=+Vb^G+K)87{ExSKu4HL2YeN75iZs zOx8x!^3mLyp@GfXxLSToEB3{jWs#s}S?nOVi$@@|B?~e@0tVshP|>PG%jHb;uJ}-5 zkp{oi?SV`Y+TrK5^hS+_Ni+Ws*2rDxd~h@w66OE5t=F@7dttZZix&Ob$GpQ01Hl8mLlvItM&-_Sc- gnIU}Qao^~cEY>&QZ?7LtCF>J4yQ9K6dmWtp3v&brlmGw# diff --git a/venv/lib/python3.12/site-packages/pip/_internal/operations/build/__pycache__/metadata_editable.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/operations/build/__pycache__/metadata_editable.cpython-312.pyc deleted file mode 100644 index 9a2c06737893776db7c72815dd92e41f4c20a3aa..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1924 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 diff --git a/venv/lib/python3.12/site-packages/pip/_internal/operations/build/__pycache__/wheel_editable.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/operations/build/__pycache__/wheel_editable.cpython-312.pyc deleted file mode 100644 index 15c56ae653da4b606ee55083cbf49745831b3eab..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2035 zcmZuyZ)_Ar6rbI_-MhWpJ7{Tv{$)d3@UYy1V5v||XoZL(Ao_(%@Up#~_O|Tpo-=bT zceyGOV`!oweuBi9^sB)Se)NMeQa}2o1QP0k35goxw}Upp)Gxl-?Y3B%%f6ZS=FPnK z=KbEgpVR3if-#@FZqLaG{l=MSq}CS8S7C7jS;!I`ln-YiF90t(Vp+;d0+&fntSsl{ zvXWNrbk$mLU(j5SNavK5Cp0iTK`taZTlMAAxr63eG+ zLN@gmS3i>#{KVM`vpv^zvZB9zv}!xns9C&(UF!|cyEJAx4kmtzuiv&QwcSZL(nYGS zi%DU|W~BnH*a1_u z3q22L9H<1}@{bVD4b%{?h;O2+f{NI>(iGp{G%T?p-4a8gfEc`fI4r4wzC>2+D=B)P z*;qrE;#M||Ml8~J83{;5prvk70k$DE#Bb!t(yXjP9{DelfbFf(spsWssy*7>m>beZ z>o>lO`Vb3H#P|CV$<8XzM4sL_6|F3#ff~xKwKoya1@LHA`B2&HR}H-6@)=T+Sthz2Jm`R!A{I?O&x3daZNz^8)z&R!6ZOvnMCqQ3^;0fo z0H^c#gDN1Qj9sQzIiPe_!uq)r=k%eW1Nt}zpk5(f5#W?dCUqF+1DH^~VzQFXJbk8w zv7_4)I;|GD+C-r;dMb0obdPv z2O?ByQ0#s(c=ke2-2$dul_v+rYTYP#Wo!`BvfYYJylUNmXTHR|igBDwo9_PO=T7Y( zb8KT8yVHhaj~kU5D|zmr+`*R&YBRjQ0^I_d2Q?~o#VFV=!vs2#;Z-mRQbmm*BqQ`8 z3M^Nt`E6mW|J@*+;GG5^eGKFZYPKP*cQKV+jAel~#qDz2!$jt~Hm5DNANY3QUSjz7 zmcgY=|NMLNCl~h}ThvCDC9ySmO=&79(|$j_=T3Uh{Pf*)?lDTM-Az$TcQ5ty-|sne zr{~a8TgTGgSDG^FJ-m#h-qtUYPi0VA*^RW!^&@jfu8+)(+>~$D@22)G#`gWavIDj4 zdV=EV?uT2q-_X9$nxfD?{HSf`Qd|3qDz~&QYiMWp(=Kj@8~dlJf$r+l^txcB8)@xN zkoZgtL*K>jC0_ky%eJNr;#K+%ME&W|=rQ!YFltCYY&(8byxp1r{`OIIbWmQ9c8uR z_xN3qxm*DfYmGI&Q+Q1(A)-sLrANWn4J!ho+t!}D-;Ot zJibI336lFYS_U4v6Oh%!NZGTh4t|aF1Izyi=|vz-Nf3kwDDwcRzoM=`(OZ9@laJKS zYdh|%op;pEo5Oe2{wt8;-NK7Y$#heK`BA#BDZ>nT@91vE`6_|5ElriLl1Ry1D}H=& LB?TPm0}KBG)BOzR diff --git a/venv/lib/python3.12/site-packages/pip/_internal/operations/build/__pycache__/wheel_legacy.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/operations/build/__pycache__/wheel_legacy.cpython-312.pyc deleted file mode 100644 index 9942f745db990028e74dc0cd160b70ea756c7f25..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3939 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 Hj#=VA2} Generator[None, None, None]: - target = os.environ - - # Save values from the target and change them. - non_existent_marker = object() - saved_values: 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_build_tracker() -> Generator["BuildTracker", None, None]: - root = os.environ.get("PIP_BUILD_TRACKER") - with contextlib.ExitStack() as ctx: - if root is None: - root = ctx.enter_context(TempDirectory(kind="build-tracker")).path - ctx.enter_context(update_env_context_manager(PIP_BUILD_TRACKER=root)) - logger.debug("Initialized build tracking at %s", root) - - with BuildTracker(root) as tracker: - yield tracker - - -class TrackerId(str): - """Uniquely identifying string provided to the build tracker.""" - - -class BuildTracker: - """Ensure that an sdist cannot request itself as a setup requirement. - - When an sdist is prepared, it identifies its setup requirements in the - context of ``BuildTracker.track()``. If a requirement shows up recursively, this - raises an exception. - - This stops fork bombs embedded in malicious packages.""" - - def __init__(self, root: str) -> None: - self._root = root - self._entries: Dict[TrackerId, InstallRequirement] = {} - logger.debug("Created build tracker: %s", self._root) - - def __enter__(self) -> "BuildTracker": - logger.debug("Entered build tracker: %s", self._root) - return self - - def __exit__( - self, - exc_type: Optional[Type[BaseException]], - exc_val: Optional[BaseException], - exc_tb: Optional[TracebackType], - ) -> None: - self.cleanup() - - def _entry_path(self, key: TrackerId) -> str: - hashed = hashlib.sha224(key.encode()).hexdigest() - return os.path.join(self._root, hashed) - - def add(self, req: InstallRequirement, key: TrackerId) -> None: - """Add an InstallRequirement to build tracking.""" - - # Get the file to write information about this requirement. - entry_path = self._entry_path(key) - - # Try reading from the file. If it exists and can be read from, a build - # is already in progress, so a LookupError is raised. - try: - with open(entry_path) as fp: - contents = fp.read() - except FileNotFoundError: - pass - else: - message = "{} is already being built: {}".format(req.link, contents) - raise LookupError(message) - - # If we're here, req should really not be building already. - assert key not in self._entries - - # Start tracking this requirement. - with open(entry_path, "w", encoding="utf-8") as fp: - fp.write(str(req)) - self._entries[key] = req - - logger.debug("Added %s to build tracker %r", req, self._root) - - def remove(self, req: InstallRequirement, key: TrackerId) -> None: - """Remove an InstallRequirement from build tracking.""" - - # Delete the created file and the corresponding entry. - os.unlink(self._entry_path(key)) - del self._entries[key] - - logger.debug("Removed %s from build tracker %r", req, self._root) - - def cleanup(self) -> None: - for key, req in list(self._entries.items()): - self.remove(req, key) - - logger.debug("Removed build tracker: %r", self._root) - - @contextlib.contextmanager - def track(self, req: InstallRequirement, key: str) -> Generator[None, None, None]: - """Ensure that `key` cannot install itself as a setup requirement. - - :raises LookupError: If `key` was already provided in a parent invocation of - the context introduced by this method.""" - tracker_id = TrackerId(key) - self.add(req, tracker_id) - yield - self.remove(req, tracker_id) diff --git a/venv/lib/python3.12/site-packages/pip/_internal/operations/build/metadata.py b/venv/lib/python3.12/site-packages/pip/_internal/operations/build/metadata.py deleted file mode 100644 index c66ac35..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/operations/build/metadata.py +++ /dev/null @@ -1,39 +0,0 @@ -"""Metadata generation logic for source distributions. -""" - -import os - -from pip._vendor.pyproject_hooks import BuildBackendHookCaller - -from pip._internal.build_env import BuildEnvironment -from pip._internal.exceptions import ( - InstallationSubprocessError, - MetadataGenerationFailed, -) -from pip._internal.utils.subprocess import runner_with_spinner_message -from pip._internal.utils.temp_dir import TempDirectory - - -def generate_metadata( - build_env: BuildEnvironment, backend: BuildBackendHookCaller, details: str -) -> str: - """Generate metadata using mechanisms described in PEP 517. - - Returns the generated metadata directory. - """ - metadata_tmpdir = TempDirectory(kind="modern-metadata", globally_managed=True) - - metadata_dir = metadata_tmpdir.path - - with build_env: - # Note that BuildBackendHookCaller implements a fallback for - # prepare_metadata_for_build_wheel, so we don't have to - # consider the possibility that this hook doesn't exist. - runner = runner_with_spinner_message("Preparing metadata (pyproject.toml)") - with backend.subprocess_runner(runner): - try: - distinfo_dir = backend.prepare_metadata_for_build_wheel(metadata_dir) - except InstallationSubprocessError as error: - raise MetadataGenerationFailed(package_details=details) from error - - return os.path.join(metadata_dir, distinfo_dir) diff --git a/venv/lib/python3.12/site-packages/pip/_internal/operations/build/metadata_editable.py b/venv/lib/python3.12/site-packages/pip/_internal/operations/build/metadata_editable.py deleted file mode 100644 index 27c69f0..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/operations/build/metadata_editable.py +++ /dev/null @@ -1,41 +0,0 @@ -"""Metadata generation logic for source distributions. -""" - -import os - -from pip._vendor.pyproject_hooks import BuildBackendHookCaller - -from pip._internal.build_env import BuildEnvironment -from pip._internal.exceptions import ( - InstallationSubprocessError, - MetadataGenerationFailed, -) -from pip._internal.utils.subprocess import runner_with_spinner_message -from pip._internal.utils.temp_dir import TempDirectory - - -def generate_editable_metadata( - build_env: BuildEnvironment, backend: BuildBackendHookCaller, details: str -) -> str: - """Generate metadata using mechanisms described in PEP 660. - - Returns the generated metadata directory. - """ - metadata_tmpdir = TempDirectory(kind="modern-metadata", globally_managed=True) - - metadata_dir = metadata_tmpdir.path - - with build_env: - # Note that BuildBackendHookCaller implements a fallback for - # prepare_metadata_for_build_wheel/editable, so we don't have to - # consider the possibility that this hook doesn't exist. - runner = runner_with_spinner_message( - "Preparing editable metadata (pyproject.toml)" - ) - with backend.subprocess_runner(runner): - try: - distinfo_dir = backend.prepare_metadata_for_build_editable(metadata_dir) - except InstallationSubprocessError as error: - raise MetadataGenerationFailed(package_details=details) from error - - return os.path.join(metadata_dir, distinfo_dir) diff --git a/venv/lib/python3.12/site-packages/pip/_internal/operations/build/metadata_legacy.py b/venv/lib/python3.12/site-packages/pip/_internal/operations/build/metadata_legacy.py deleted file mode 100644 index e60988d..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/operations/build/metadata_legacy.py +++ /dev/null @@ -1,74 +0,0 @@ -"""Metadata generation logic for legacy source distributions. -""" - -import logging -import os - -from pip._internal.build_env import BuildEnvironment -from pip._internal.cli.spinners import open_spinner -from pip._internal.exceptions import ( - InstallationError, - InstallationSubprocessError, - MetadataGenerationFailed, -) -from pip._internal.utils.setuptools_build import make_setuptools_egg_info_args -from pip._internal.utils.subprocess import call_subprocess -from pip._internal.utils.temp_dir import TempDirectory - -logger = logging.getLogger(__name__) - - -def _find_egg_info(directory: str) -> str: - """Find an .egg-info subdirectory in `directory`.""" - filenames = [f for f in os.listdir(directory) if f.endswith(".egg-info")] - - if not filenames: - raise InstallationError(f"No .egg-info directory found in {directory}") - - if len(filenames) > 1: - raise InstallationError( - "More than one .egg-info directory found in {}".format(directory) - ) - - return os.path.join(directory, filenames[0]) - - -def generate_metadata( - build_env: BuildEnvironment, - setup_py_path: str, - source_dir: str, - isolated: bool, - details: str, -) -> str: - """Generate metadata using setup.py-based defacto mechanisms. - - Returns the generated metadata directory. - """ - logger.debug( - "Running setup.py (path:%s) egg_info for package %s", - setup_py_path, - details, - ) - - egg_info_dir = TempDirectory(kind="pip-egg-info", globally_managed=True).path - - args = make_setuptools_egg_info_args( - setup_py_path, - egg_info_dir=egg_info_dir, - no_user_config=isolated, - ) - - with build_env: - with open_spinner("Preparing metadata (setup.py)") as spinner: - try: - call_subprocess( - args, - cwd=source_dir, - command_desc="python setup.py egg_info", - spinner=spinner, - ) - except InstallationSubprocessError as error: - raise MetadataGenerationFailed(package_details=details) from error - - # Return the .egg-info directory. - return _find_egg_info(egg_info_dir) diff --git a/venv/lib/python3.12/site-packages/pip/_internal/operations/build/wheel.py b/venv/lib/python3.12/site-packages/pip/_internal/operations/build/wheel.py deleted file mode 100644 index 064811a..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/operations/build/wheel.py +++ /dev/null @@ -1,37 +0,0 @@ -import logging -import os -from typing import Optional - -from pip._vendor.pyproject_hooks import BuildBackendHookCaller - -from pip._internal.utils.subprocess import runner_with_spinner_message - -logger = logging.getLogger(__name__) - - -def build_wheel_pep517( - name: str, - backend: BuildBackendHookCaller, - metadata_directory: str, - tempd: str, -) -> Optional[str]: - """Build one InstallRequirement using the PEP 517 build process. - - Returns path to wheel if successfully built. Otherwise, returns None. - """ - assert metadata_directory is not None - try: - logger.debug("Destination directory: %s", tempd) - - runner = runner_with_spinner_message( - f"Building wheel for {name} (pyproject.toml)" - ) - 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.12/site-packages/pip/_internal/operations/build/wheel_editable.py b/venv/lib/python3.12/site-packages/pip/_internal/operations/build/wheel_editable.py deleted file mode 100644 index 719d69d..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/operations/build/wheel_editable.py +++ /dev/null @@ -1,46 +0,0 @@ -import logging -import os -from typing import Optional - -from pip._vendor.pyproject_hooks import BuildBackendHookCaller, HookMissing - -from pip._internal.utils.subprocess import runner_with_spinner_message - -logger = logging.getLogger(__name__) - - -def build_wheel_editable( - name: str, - backend: BuildBackendHookCaller, - metadata_directory: str, - tempd: str, -) -> Optional[str]: - """Build one InstallRequirement using the PEP 660 build process. - - Returns path to wheel if successfully built. Otherwise, returns None. - """ - assert metadata_directory is not None - try: - logger.debug("Destination directory: %s", tempd) - - runner = runner_with_spinner_message( - f"Building editable for {name} (pyproject.toml)" - ) - with backend.subprocess_runner(runner): - try: - wheel_name = backend.build_editable( - tempd, - metadata_directory=metadata_directory, - ) - except HookMissing as e: - logger.error( - "Cannot build editable %s because the build " - "backend does not have the %s hook", - name, - e, - ) - return None - except Exception: - logger.error("Failed building editable for %s", name) - return None - return os.path.join(tempd, wheel_name) diff --git a/venv/lib/python3.12/site-packages/pip/_internal/operations/build/wheel_legacy.py b/venv/lib/python3.12/site-packages/pip/_internal/operations/build/wheel_legacy.py deleted file mode 100644 index c5f0492..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/operations/build/wheel_legacy.py +++ /dev/null @@ -1,102 +0,0 @@ -import logging -import os.path -from typing import List, Optional - -from pip._internal.cli.spinners import open_spinner -from pip._internal.utils.setuptools_build import make_setuptools_bdist_wheel_args -from pip._internal.utils.subprocess import call_subprocess, format_command_args - -logger = logging.getLogger(__name__) - - -def format_command_result( - command_args: List[str], - command_output: str, -) -> str: - """Format command information for logging.""" - command_desc = format_command_args(command_args) - text = f"Command arguments: {command_desc}\n" - - 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 += f"Command output:\n{command_output}" - - return text - - -def get_legacy_build_wheel_path( - names: List[str], - temp_dir: str, - name: str, - command_args: List[str], - command_output: str, -) -> Optional[str]: - """Return the path to the wheel in the temporary build directory.""" - # Sort for determinism. - names = sorted(names) - if not names: - msg = ("Legacy build of wheel for {!r} created no files.\n").format(name) - msg += 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: str, - setup_py_path: str, - source_dir: str, - global_options: List[str], - build_options: List[str], - tempd: str, -) -> Optional[str]: - """Build one unpacked package using the "legacy" build process. - - Returns path to wheel if successfully built. Otherwise, returns None. - """ - wheel_args = make_setuptools_bdist_wheel_args( - setup_py_path, - global_options=global_options, - build_options=build_options, - destination_dir=tempd, - ) - - spin_message = f"Building wheel for {name} (setup.py)" - with open_spinner(spin_message) as spinner: - logger.debug("Destination directory: %s", tempd) - - try: - output = call_subprocess( - wheel_args, - command_desc="python setup.py bdist_wheel", - cwd=source_dir, - spinner=spinner, - ) - except Exception: - spinner.finish("error") - logger.error("Failed building wheel for %s", name) - 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.12/site-packages/pip/_internal/operations/check.py b/venv/lib/python3.12/site-packages/pip/_internal/operations/check.py deleted file mode 100644 index 90c6a58..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/operations/check.py +++ /dev/null @@ -1,187 +0,0 @@ -"""Validation of dependencies of packages -""" - -import logging -from typing import Callable, Dict, List, NamedTuple, Optional, Set, Tuple - -from pip._vendor.packaging.requirements import Requirement -from pip._vendor.packaging.specifiers import LegacySpecifier -from pip._vendor.packaging.utils import NormalizedName, canonicalize_name -from pip._vendor.packaging.version import LegacyVersion - -from pip._internal.distributions import make_distribution_for_install_requirement -from pip._internal.metadata import get_default_environment -from pip._internal.metadata.base import DistributionVersion -from pip._internal.req.req_install import InstallRequirement -from pip._internal.utils.deprecation import deprecated - -logger = logging.getLogger(__name__) - - -class PackageDetails(NamedTuple): - version: DistributionVersion - dependencies: List[Requirement] - - -# Shorthands -PackageSet = Dict[NormalizedName, PackageDetails] -Missing = Tuple[NormalizedName, Requirement] -Conflicting = Tuple[NormalizedName, DistributionVersion, Requirement] - -MissingDict = Dict[NormalizedName, List[Missing]] -ConflictingDict = Dict[NormalizedName, List[Conflicting]] -CheckResult = Tuple[MissingDict, ConflictingDict] -ConflictDetails = Tuple[PackageSet, CheckResult] - - -def create_package_set_from_installed() -> Tuple[PackageSet, bool]: - """Converts a list of distributions into a PackageSet.""" - package_set = {} - problems = False - env = get_default_environment() - for dist in env.iter_installed_distributions(local_only=False, skip=()): - name = dist.canonical_name - try: - dependencies = list(dist.iter_dependencies()) - package_set[name] = PackageDetails(dist.version, dependencies) - except (OSError, ValueError) as e: - # Don't crash on unreadable or broken metadata. - logger.warning("Error parsing requirements for %s: %s", name, e) - problems = True - return package_set, problems - - -def check_package_set( - package_set: PackageSet, should_ignore: Optional[Callable[[str], bool]] = None -) -> CheckResult: - """Check if a package set is consistent - - If should_ignore is passed, it should be a callable that takes a - package name and returns a boolean. - """ - - warn_legacy_versions_and_specifiers(package_set) - - missing = {} - conflicting = {} - - for package_name, package_detail in package_set.items(): - # Info about dependencies of package_name - missing_deps: Set[Missing] = set() - conflicting_deps: Set[Conflicting] = set() - - if should_ignore and should_ignore(package_name): - continue - - for req in package_detail.dependencies: - name = canonicalize_name(req.name) - - # Check if it's missing - if name not in package_set: - missed = True - if req.marker is not None: - missed = req.marker.evaluate({"extra": ""}) - if missed: - missing_deps.add((name, req)) - continue - - # Check if there's a conflict - version = package_set[name].version - 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: List[InstallRequirement]) -> ConflictDetails: - """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: List[InstallRequirement], package_set: PackageSet -) -> Set[NormalizedName]: - """Computes the version of packages after installing to_install.""" - # Keep track of packages that were installed - installed = set() - - # Modify it as installing requirement_set would (assuming no errors) - for inst_req in to_install: - abstract_dist = make_distribution_for_install_requirement(inst_req) - dist = abstract_dist.get_metadata_distribution() - name = dist.canonical_name - package_set[name] = PackageDetails(dist.version, list(dist.iter_dependencies())) - - installed.add(name) - - return installed - - -def _create_whitelist( - would_be_installed: Set[NormalizedName], package_set: PackageSet -) -> Set[NormalizedName]: - packages_affected = set(would_be_installed) - - for package_name in package_set: - if package_name in packages_affected: - continue - - for req in package_set[package_name].dependencies: - if canonicalize_name(req.name) in packages_affected: - packages_affected.add(package_name) - break - - return packages_affected - - -def warn_legacy_versions_and_specifiers(package_set: PackageSet) -> None: - for project_name, package_details in package_set.items(): - if isinstance(package_details.version, LegacyVersion): - deprecated( - reason=( - f"{project_name} {package_details.version} " - f"has a non-standard version number." - ), - replacement=( - f"to upgrade to a newer version of {project_name} " - f"or contact the author to suggest that they " - f"release a version with a conforming version number" - ), - issue=12063, - gone_in="24.1", - ) - for dep in package_details.dependencies: - if any(isinstance(spec, LegacySpecifier) for spec in dep.specifier): - deprecated( - reason=( - f"{project_name} {package_details.version} " - f"has a non-standard dependency specifier {dep}." - ), - replacement=( - f"to upgrade to a newer version of {project_name} " - f"or contact the author to suggest that they " - f"release a version with a conforming dependency specifiers" - ), - issue=12063, - gone_in="24.1", - ) diff --git a/venv/lib/python3.12/site-packages/pip/_internal/operations/freeze.py b/venv/lib/python3.12/site-packages/pip/_internal/operations/freeze.py deleted file mode 100644 index 3544568..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/operations/freeze.py +++ /dev/null @@ -1,255 +0,0 @@ -import collections -import logging -import os -from typing import Container, Dict, Generator, Iterable, List, NamedTuple, Optional, Set - -from pip._vendor.packaging.utils import canonicalize_name -from pip._vendor.packaging.version import Version - -from pip._internal.exceptions import BadCommand, InstallationError -from pip._internal.metadata import BaseDistribution, get_environment -from pip._internal.req.constructors import ( - install_req_from_editable, - install_req_from_line, -) -from pip._internal.req.req_file import COMMENT_RE -from pip._internal.utils.direct_url_helpers import direct_url_as_pep440_direct_reference - -logger = logging.getLogger(__name__) - - -class _EditableInfo(NamedTuple): - requirement: str - comments: List[str] - - -def freeze( - requirement: Optional[List[str]] = None, - local_only: bool = False, - user_only: bool = False, - paths: Optional[List[str]] = None, - isolated: bool = False, - exclude_editable: bool = False, - skip: Container[str] = (), -) -> Generator[str, None, None]: - installations: Dict[str, FrozenRequirement] = {} - - dists = get_environment(paths).iter_installed_distributions( - local_only=local_only, - skip=(), - user_only=user_only, - ) - for dist in dists: - req = FrozenRequirement.from_dist(dist) - if exclude_editable and req.editable: - continue - installations[req.canonical_name] = req - - 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[str] = set() - # keep track of which files a requirement is in so that we can - # give an accurate warning if a requirement appears multiple times. - req_files: Dict[str, List[str]] = collections.defaultdict(list) - for req_file_path in requirement: - with open(req_file_path) as req_file: - for line in req_file: - if ( - not line.strip() - or line.strip().startswith("#") - or line.startswith( - ( - "-r", - "--requirement", - "-f", - "--find-links", - "-i", - "--index-url", - "--pre", - "--trusted-host", - "--process-dependency-links", - "--extra-index-url", - "--use-feature", - ) - ) - ): - 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, - ) - else: - line_req = install_req_from_line( - COMMENT_RE.sub("", line).strip(), - isolated=isolated, - ) - - 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 req_files.items(): - 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 _format_as_name_version(dist: BaseDistribution) -> str: - dist_version = dist.version - if isinstance(dist_version, Version): - return f"{dist.raw_name}=={dist_version}" - return f"{dist.raw_name}==={dist_version}" - - -def _get_editable_info(dist: BaseDistribution) -> _EditableInfo: - """ - Compute and return values (req, comments) for use in - FrozenRequirement.from_dist(). - """ - editable_project_location = dist.editable_project_location - assert editable_project_location - location = os.path.normcase(os.path.abspath(editable_project_location)) - - from pip._internal.vcs import RemoteNotFoundError, RemoteNotValidError, vcs - - vcs_backend = vcs.get_backend_for_dir(location) - - if vcs_backend is None: - display = _format_as_name_version(dist) - logger.debug( - 'No VCS found for editable requirement "%s" in: %r', - display, - location, - ) - return _EditableInfo( - requirement=location, - comments=[f"# Editable install with no version control ({display})"], - ) - - vcs_name = type(vcs_backend).__name__ - - try: - req = vcs_backend.get_src_requirement(location, dist.raw_name) - except RemoteNotFoundError: - display = _format_as_name_version(dist) - return _EditableInfo( - requirement=location, - comments=[f"# Editable {vcs_name} install with no remote ({display})"], - ) - except RemoteNotValidError as ex: - display = _format_as_name_version(dist) - return _EditableInfo( - requirement=location, - comments=[ - f"# Editable {vcs_name} install ({display}) with either a deleted " - f"local remote or invalid URI:", - f"# '{ex.url}'", - ], - ) - except BadCommand: - logger.warning( - "cannot determine version of editable source in %s " - "(%s command not found in path)", - location, - vcs_backend.name, - ) - return _EditableInfo(requirement=location, comments=[]) - except InstallationError as exc: - logger.warning("Error when trying to get requirement for VCS system %s", exc) - else: - return _EditableInfo(requirement=req, comments=[]) - - logger.warning("Could not determine repository location of %s", location) - - return _EditableInfo( - requirement=location, - comments=["## !! Could not determine repository location"], - ) - - -class FrozenRequirement: - def __init__( - self, - name: str, - req: str, - editable: bool, - comments: Iterable[str] = (), - ) -> None: - self.name = name - self.canonical_name = canonicalize_name(name) - self.req = req - self.editable = editable - self.comments = comments - - @classmethod - def from_dist(cls, dist: BaseDistribution) -> "FrozenRequirement": - editable = dist.editable - if editable: - req, comments = _get_editable_info(dist) - else: - comments = [] - direct_url = dist.direct_url - if direct_url: - # if PEP 610 metadata is present, use it - req = direct_url_as_pep440_direct_reference(direct_url, dist.raw_name) - else: - # name==version requirement - req = _format_as_name_version(dist) - - return cls(dist.raw_name, req, editable, comments=comments) - - def __str__(self) -> str: - req = self.req - if self.editable: - req = f"-e {req}" - return "\n".join(list(self.comments) + [str(req)]) + "\n" diff --git a/venv/lib/python3.12/site-packages/pip/_internal/operations/install/__init__.py b/venv/lib/python3.12/site-packages/pip/_internal/operations/install/__init__.py deleted file mode 100644 index 24d6a5d..0000000 --- a/venv/lib/python3.12/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.12/site-packages/pip/_internal/operations/install/__pycache__/__init__.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/operations/install/__pycache__/__init__.cpython-312.pyc deleted file mode 100644 index 25df9245eadbd0896e627be8ff1ff5b890e88583..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 276 zcmXw!!Ae6h5Ji((v=sUe*%o|n&~8hiD1sYt?Ixtn&<;&AAxR&+{)9`nZv7Vjz^y+Z zcGs18*xt?D%fRK_&(UZoir(v2nw0z9g|pWxI2jR77Vo zT9sLmPuVy}ex-t0Zp;c(J$xF=uPd!BFSY&dp}~=o@gffY9bO`$>Is3yCsT=Y9wjK$FiHy>Y++qshcR!3hR*`BK)p4()L; a{imMA%YxC(OWpdP3n}GqPs)Dmm-q)2!%^}8 diff --git a/venv/lib/python3.12/site-packages/pip/_internal/operations/install/__pycache__/editable_legacy.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/operations/install/__pycache__/editable_legacy.cpython-312.pyc deleted file mode 100644 index 9f60172718d251cc68b206c50ac813270a3a455e..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1827 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 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, - no_user_config=isolated, - prefix=prefix, - home=home, - use_user_site=use_user_site, - ) - - with indent_log(): - with build_env: - call_subprocess( - args, - command_desc="python setup.py develop", - cwd=unpacked_source_directory, - ) diff --git a/venv/lib/python3.12/site-packages/pip/_internal/operations/install/wheel.py b/venv/lib/python3.12/site-packages/pip/_internal/operations/install/wheel.py deleted file mode 100644 index f67180c..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/operations/install/wheel.py +++ /dev/null @@ -1,734 +0,0 @@ -"""Support for installing and building the "wheel" binary package format. -""" - -import collections -import compileall -import contextlib -import csv -import importlib -import logging -import os.path -import re -import shutil -import sys -import warnings -from base64 import urlsafe_b64encode -from email.message import Message -from itertools import chain, filterfalse, starmap -from typing import ( - IO, - TYPE_CHECKING, - Any, - BinaryIO, - Callable, - Dict, - Generator, - Iterable, - Iterator, - List, - NewType, - Optional, - Sequence, - Set, - Tuple, - Union, - cast, -) -from zipfile import ZipFile, ZipInfo - -from pip._vendor.distlib.scripts import ScriptMaker -from pip._vendor.distlib.util import get_export_entry -from pip._vendor.packaging.utils import canonicalize_name - -from pip._internal.exceptions import InstallationError -from pip._internal.locations import get_major_minor_version -from pip._internal.metadata import ( - BaseDistribution, - FilesystemWheel, - get_wheel_distribution, -) -from pip._internal.models.direct_url import DIRECT_URL_METADATA_NAME, DirectUrl -from pip._internal.models.scheme import SCHEME_KEYS, Scheme -from pip._internal.utils.filesystem import adjacent_tmp_file, replace -from pip._internal.utils.misc import captured_stdout, ensure_dir, hash_file, partition -from pip._internal.utils.unpacking import ( - current_umask, - is_within_directory, - set_extracted_file_to_default_mode_plus_executable, - zip_item_is_executable, -) -from pip._internal.utils.wheel import parse_wheel - -if TYPE_CHECKING: - from typing import Protocol - - class File(Protocol): - src_record_path: "RecordPath" - dest_path: str - changed: bool - - def save(self) -> None: - pass - - -logger = logging.getLogger(__name__) - -RecordPath = NewType("RecordPath", str) -InstalledCSVRow = Tuple[RecordPath, str, Union[int, str]] - - -def rehash(path: str, blocksize: int = 1 << 20) -> Tuple[str, str]: - """Return (encoded_digest, length) for path using hashlib.sha256()""" - h, length = hash_file(path, blocksize) - digest = "sha256=" + urlsafe_b64encode(h.digest()).decode("latin1").rstrip("=") - return (digest, str(length)) - - -def csv_io_kwargs(mode: str) -> Dict[str, Any]: - """Return keyword arguments to properly open a CSV file - in the given mode. - """ - return {"mode": mode, "newline": "", "encoding": "utf-8"} - - -def fix_script(path: str) -> bool: - """Replace #!python with #!/path/to/python - Return True if file was changed. - """ - # XXX RECORD hashes will need to be updated - assert os.path.isfile(path) - - with open(path, "rb") as script: - 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 - - -def wheel_root_is_purelib(metadata: Message) -> bool: - return metadata.get("Root-Is-Purelib", "").lower() == "true" - - -def get_entrypoints(dist: BaseDistribution) -> Tuple[Dict[str, str], Dict[str, str]]: - console_scripts = {} - gui_scripts = {} - for entry_point in dist.iter_entry_points(): - if entry_point.group == "console_scripts": - console_scripts[entry_point.name] = entry_point.value - elif entry_point.group == "gui_scripts": - gui_scripts[entry_point.name] = entry_point.value - return console_scripts, gui_scripts - - -def message_about_scripts_not_on_PATH(scripts: Sequence[str]) -> Optional[str]: - """Determine if any scripts are not on PATH and format a warning. - Returns a warning message if one or more scripts are not on PATH, - otherwise None. - """ - if not scripts: - return None - - # Group scripts by the path they were installed in - grouped_by_dir: Dict[str, Set[str]] = collections.defaultdict(set) - for destfile in scripts: - parent_dir = os.path.dirname(destfile) - script_name = os.path.basename(destfile) - 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(os.path.normpath(i)).rstrip(os.sep) - for i in os.environ.get("PATH", "").split(os.pathsep) - ] - # If an executable sits with sys.executable, we don't warn for it. - # This covers the case of venv invocations without activating the venv. - not_warn_dirs.append( - os.path.normcase(os.path.normpath(os.path.dirname(sys.executable))) - ) - warn_for: Dict[str, Set[str]] = { - parent_dir: scripts - for parent_dir, scripts in grouped_by_dir.items() - if os.path.normcase(os.path.normpath(parent_dir)) not in not_warn_dirs - } - if not warn_for: - return None - - # Format a message - msg_lines = [] - for parent_dir, dir_scripts in warn_for.items(): - sorted_scripts: List[str] = sorted(dir_scripts) - if len(sorted_scripts) == 1: - start_text = f"script {sorted_scripts[0]} is" - else: - start_text = "scripts {} are".format( - ", ".join(sorted_scripts[:-1]) + " and " + sorted_scripts[-1] - ) - - msg_lines.append( - f"The {start_text} installed in '{parent_dir}' which is not on PATH." - ) - - 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 _normalized_outrows( - outrows: Iterable[InstalledCSVRow], -) -> List[Tuple[str, str, str]]: - """Normalize the given rows of a RECORD file. - - Items in each row are converted into str. Rows are then sorted to make - the value more predictable for tests. - - 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( - (record_path, hash_, str(size)) for record_path, hash_, size in outrows - ) - - -def _record_to_fs_path(record_path: RecordPath, lib_dir: str) -> str: - return os.path.join(lib_dir, record_path) - - -def _fs_to_record_path(path: str, lib_dir: str) -> RecordPath: - # On Windows, do not handle relative paths if they belong to different - # logical disks - if os.path.splitdrive(path)[0].lower() == os.path.splitdrive(lib_dir)[0].lower(): - path = os.path.relpath(path, lib_dir) - - path = path.replace(os.path.sep, "/") - return cast("RecordPath", path) - - -def get_csv_rows_for_installed( - old_csv_rows: List[List[str]], - installed: Dict[RecordPath, RecordPath], - changed: Set[RecordPath], - generated: List[str], - lib_dir: str, -) -> List[InstalledCSVRow]: - """ - :param installed: A map from archive RECORD path to installation RECORD - path. - """ - installed_rows: List[InstalledCSVRow] = [] - for row in old_csv_rows: - if len(row) > 3: - logger.warning("RECORD line has more than three elements: %s", row) - old_record_path = cast("RecordPath", row[0]) - new_record_path = installed.pop(old_record_path, old_record_path) - if new_record_path in changed: - digest, length = rehash(_record_to_fs_path(new_record_path, lib_dir)) - else: - digest = row[1] if len(row) > 1 else "" - length = row[2] if len(row) > 2 else "" - installed_rows.append((new_record_path, digest, length)) - for f in generated: - path = _fs_to_record_path(f, lib_dir) - digest, length = rehash(f) - installed_rows.append((path, digest, length)) - return installed_rows + [ - (installed_record_path, "", "") for installed_record_path in installed.values() - ] - - -def get_console_script_specs(console: Dict[str, str]) -> List[str]: - """ - Given the mapping from entrypoint name to callable, return the relevant - console script specs. - """ - # Don't mutate caller's version - console = console.copy() - - 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(f"pip{sys.version_info[0]} = {pip_script}") - - scripts_to_generate.append(f"pip{get_major_minor_version()} = {pip_script}") - # Delete any other versioned pip entry points - pip_ep = [k for k in console if re.match(r"pip(\d+(\.\d+)?)?$", k)] - 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( - f"easy_install-{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 entry points specified in the wheel - scripts_to_generate.extend(starmap("{} = {}".format, console.items())) - - return scripts_to_generate - - -class ZipBackedFile: - def __init__( - self, src_record_path: RecordPath, dest_path: str, zip_file: ZipFile - ) -> None: - self.src_record_path = src_record_path - self.dest_path = dest_path - self._zip_file = zip_file - self.changed = False - - def _getinfo(self) -> ZipInfo: - return self._zip_file.getinfo(self.src_record_path) - - def save(self) -> None: - # directory creation is lazy and after file filtering - # to ensure we don't install empty dirs; empty dirs can't be - # uninstalled. - parent_dir = os.path.dirname(self.dest_path) - ensure_dir(parent_dir) - - # When we open the output file below, any existing file is truncated - # before we start writing 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(self.dest_path): - os.unlink(self.dest_path) - - zipinfo = self._getinfo() - - with self._zip_file.open(zipinfo) as f: - with open(self.dest_path, "wb") as dest: - shutil.copyfileobj(f, dest) - - if zip_item_is_executable(zipinfo): - set_extracted_file_to_default_mode_plus_executable(self.dest_path) - - -class ScriptFile: - def __init__(self, file: "File") -> None: - self._file = file - self.src_record_path = self._file.src_record_path - self.dest_path = self._file.dest_path - self.changed = False - - def save(self) -> None: - self._file.save() - self.changed = fix_script(self.dest_path) - - -class MissingCallableSuffix(InstallationError): - def __init__(self, entry_point: str) -> None: - super().__init__( - f"Invalid script entry point: {entry_point} - A callable " - "suffix is required. Cf https://packaging.python.org/" - "specifications/entry-points/#use-for-scripts for more " - "information." - ) - - -def _raise_for_invalid_entrypoint(specification: str) -> None: - entry = get_export_entry(specification) - if entry is not None and entry.suffix is None: - raise MissingCallableSuffix(str(entry)) - - -class PipScriptMaker(ScriptMaker): - def make( - self, specification: str, options: Optional[Dict[str, Any]] = None - ) -> List[str]: - _raise_for_invalid_entrypoint(specification) - return super().make(specification, options) - - -def _install_wheel( - name: str, - wheel_zip: ZipFile, - wheel_path: str, - scheme: Scheme, - pycompile: bool = True, - warn_script_location: bool = True, - direct_url: Optional[DirectUrl] = None, - requested: bool = False, -) -> None: - """Install a wheel. - - :param name: Name of the project to install - :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 - """ - info_dir, metadata = parse_wheel(wheel_zip, name) - - if wheel_root_is_purelib(metadata): - lib_dir = scheme.purelib - else: - lib_dir = scheme.platlib - - # 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: Dict[RecordPath, RecordPath] = {} - changed: Set[RecordPath] = set() - generated: List[str] = [] - - def record_installed( - srcfile: RecordPath, destfile: str, modified: bool = False - ) -> None: - """Map archive RECORD paths to installation RECORD paths.""" - newpath = _fs_to_record_path(destfile, lib_dir) - installed[srcfile] = newpath - if modified: - changed.add(newpath) - - def is_dir_path(path: RecordPath) -> bool: - return path.endswith("/") - - def assert_no_path_traversal(dest_dir_path: str, target_path: str) -> None: - if not is_within_directory(dest_dir_path, target_path): - message = ( - "The wheel {!r} has a file {!r} trying to install" - " outside the target directory {!r}" - ) - raise InstallationError( - message.format(wheel_path, target_path, dest_dir_path) - ) - - def root_scheme_file_maker( - zip_file: ZipFile, dest: str - ) -> Callable[[RecordPath], "File"]: - def make_root_scheme_file(record_path: RecordPath) -> "File": - normed_path = os.path.normpath(record_path) - dest_path = os.path.join(dest, normed_path) - assert_no_path_traversal(dest, dest_path) - return ZipBackedFile(record_path, dest_path, zip_file) - - return make_root_scheme_file - - def data_scheme_file_maker( - zip_file: ZipFile, scheme: Scheme - ) -> Callable[[RecordPath], "File"]: - scheme_paths = {key: getattr(scheme, key) for key in SCHEME_KEYS} - - def make_data_scheme_file(record_path: RecordPath) -> "File": - normed_path = os.path.normpath(record_path) - try: - _, scheme_key, dest_subpath = normed_path.split(os.path.sep, 2) - except ValueError: - message = ( - "Unexpected file in {}: {!r}. .data directory contents" - " should be named like: '/'." - ).format(wheel_path, record_path) - raise InstallationError(message) - - try: - scheme_path = scheme_paths[scheme_key] - except KeyError: - valid_scheme_keys = ", ".join(sorted(scheme_paths)) - message = ( - "Unknown scheme key used in {}: {} (for file {!r}). .data" - " directory contents should be in subdirectories named" - " with a valid scheme key ({})" - ).format(wheel_path, scheme_key, record_path, valid_scheme_keys) - raise InstallationError(message) - - dest_path = os.path.join(scheme_path, dest_subpath) - assert_no_path_traversal(scheme_path, dest_path) - return ZipBackedFile(record_path, dest_path, zip_file) - - return make_data_scheme_file - - def is_data_scheme_path(path: RecordPath) -> bool: - return path.split("/", 1)[0].endswith(".data") - - paths = cast(List[RecordPath], wheel_zip.namelist()) - file_paths = filterfalse(is_dir_path, paths) - root_scheme_paths, data_scheme_paths = partition(is_data_scheme_path, file_paths) - - make_root_scheme_file = root_scheme_file_maker(wheel_zip, lib_dir) - files: Iterator[File] = map(make_root_scheme_file, root_scheme_paths) - - def is_script_scheme_path(path: RecordPath) -> bool: - parts = path.split("/", 2) - return len(parts) > 2 and parts[0].endswith(".data") and parts[1] == "scripts" - - other_scheme_paths, script_scheme_paths = partition( - is_script_scheme_path, data_scheme_paths - ) - - make_data_scheme_file = data_scheme_file_maker(wheel_zip, scheme) - other_scheme_files = map(make_data_scheme_file, other_scheme_paths) - files = chain(files, other_scheme_files) - - # Get the defined entry points - distribution = get_wheel_distribution( - FilesystemWheel(wheel_path), - canonicalize_name(name), - ) - console, gui = get_entrypoints(distribution) - - def is_entrypoint_wrapper(file: "File") -> bool: - # EP, EP.exe and EP-script.py are scripts generated for - # entry point EP by setuptools - path = file.dest_path - name = os.path.basename(path) - if name.lower().endswith(".exe"): - 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 - - script_scheme_files: Iterator[File] = map( - make_data_scheme_file, script_scheme_paths - ) - script_scheme_files = filterfalse(is_entrypoint_wrapper, script_scheme_files) - script_scheme_files = map(ScriptFile, script_scheme_files) - files = chain(files, script_scheme_files) - - for file in files: - file.save() - record_installed(file.src_record_path, file.dest_path, file.changed) - - def pyc_source_file_paths() -> Generator[str, None, None]: - # We de-duplicate installation paths, since there can be overlap (e.g. - # file in .data maps to same location as file in wheel root). - # Sorting installation paths makes it easier to reproduce and debug - # issues related to permissions on existing files. - for installed_path in sorted(set(installed.values())): - full_installed_path = os.path.join(lib_dir, installed_path) - if not os.path.isfile(full_installed_path): - continue - if not full_installed_path.endswith(".py"): - continue - yield full_installed_path - - def pyc_output_path(path: str) -> str: - """Return the path the pyc file would have been written to.""" - return importlib.util.cache_from_source(path) - - # Compile all of the pyc files for the installed files - if pycompile: - with captured_stdout() as stdout: - with warnings.catch_warnings(): - warnings.filterwarnings("ignore") - for path in pyc_source_file_paths(): - success = compileall.compile_file(path, force=True, quiet=True) - if success: - pyc_path = pyc_output_path(path) - assert os.path.exists(pyc_path) - pyc_record_path = cast( - "RecordPath", pyc_path.replace(os.path.sep, "/") - ) - record_installed(pyc_record_path, pyc_path) - logger.debug(stdout.getvalue()) - - 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 - - # Generate the console and GUI entry points specified in the wheel - scripts_to_generate = get_console_script_specs(console) - - gui_scripts_to_generate = list(starmap("{} = {}".format, gui.items())) - - 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})) - - if warn_script_location: - msg = message_about_scripts_not_on_PATH(generated_console_scripts) - if msg is not None: - logger.warning(msg) - - generated_file_mode = 0o666 & ~current_umask() - - @contextlib.contextmanager - def _generate_file(path: str, **kwargs: Any) -> Generator[BinaryIO, None, None]: - with adjacent_tmp_file(path, **kwargs) as f: - yield f - os.chmod(f.name, generated_file_mode) - replace(f.name, path) - - dest_info_dir = os.path.join(lib_dir, info_dir) - - # Record pip as the installer - installer_path = os.path.join(dest_info_dir, "INSTALLER") - with _generate_file(installer_path) as installer_file: - installer_file.write(b"pip\n") - generated.append(installer_path) - - # Record the PEP 610 direct URL reference - if direct_url is not None: - direct_url_path = os.path.join(dest_info_dir, DIRECT_URL_METADATA_NAME) - with _generate_file(direct_url_path) as direct_url_file: - direct_url_file.write(direct_url.to_json().encode("utf-8")) - generated.append(direct_url_path) - - # Record the REQUESTED file - if requested: - requested_path = os.path.join(dest_info_dir, "REQUESTED") - with open(requested_path, "wb"): - pass - generated.append(requested_path) - - record_text = distribution.read_text("RECORD") - record_rows = list(csv.reader(record_text.splitlines())) - - rows = get_csv_rows_for_installed( - record_rows, - installed=installed, - changed=changed, - generated=generated, - lib_dir=lib_dir, - ) - - # Record details of all files installed - record_path = os.path.join(dest_info_dir, "RECORD") - - with _generate_file(record_path, **csv_io_kwargs("w")) as record_file: - # Explicitly cast to typing.IO[str] as a workaround for the mypy error: - # "writer" has incompatible type "BinaryIO"; expected "_Writer" - writer = csv.writer(cast("IO[str]", record_file)) - writer.writerows(_normalized_outrows(rows)) - - -@contextlib.contextmanager -def req_error_context(req_description: str) -> Generator[None, None, None]: - try: - yield - except InstallationError as e: - message = f"For req: {req_description}. {e.args[0]}" - raise InstallationError(message) from e - - -def install_wheel( - name: str, - wheel_path: str, - scheme: Scheme, - req_description: str, - pycompile: bool = True, - warn_script_location: bool = True, - direct_url: Optional[DirectUrl] = None, - requested: bool = False, -) -> None: - with ZipFile(wheel_path, allowZip64=True) as z: - with req_error_context(req_description): - _install_wheel( - name=name, - wheel_zip=z, - wheel_path=wheel_path, - scheme=scheme, - pycompile=pycompile, - warn_script_location=warn_script_location, - direct_url=direct_url, - requested=requested, - ) diff --git a/venv/lib/python3.12/site-packages/pip/_internal/operations/prepare.py b/venv/lib/python3.12/site-packages/pip/_internal/operations/prepare.py deleted file mode 100644 index 956717d..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/operations/prepare.py +++ /dev/null @@ -1,730 +0,0 @@ -"""Prepares a distribution for installation -""" - -# The following comment should be removed at some point in the future. -# mypy: strict-optional=False - -import mimetypes -import os -import shutil -from pathlib import Path -from typing import Dict, Iterable, List, Optional - -from pip._vendor.packaging.utils import canonicalize_name - -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, - MetadataInconsistent, - NetworkConnectionError, - VcsHashUnsupported, -) -from pip._internal.index.package_finder import PackageFinder -from pip._internal.metadata import BaseDistribution, get_metadata_distribution -from pip._internal.models.direct_url import ArchiveInfo -from pip._internal.models.link import Link -from pip._internal.models.wheel import Wheel -from pip._internal.network.download import BatchDownloader, Downloader -from pip._internal.network.lazy_wheel import ( - HTTPRangeRequestUnsupported, - dist_from_wheel_url, -) -from pip._internal.network.session import PipSession -from pip._internal.operations.build.build_tracker import BuildTracker -from pip._internal.req.req_install import InstallRequirement -from pip._internal.utils._log import getLogger -from pip._internal.utils.direct_url_helpers import ( - direct_url_for_editable, - direct_url_from_link, -) -from pip._internal.utils.hashes import Hashes, MissingHashes -from pip._internal.utils.logging import indent_log -from pip._internal.utils.misc import ( - display_path, - hash_file, - hide_url, - redact_auth_from_requirement, -) -from pip._internal.utils.temp_dir import TempDirectory -from pip._internal.utils.unpacking import unpack_file -from pip._internal.vcs import vcs - -logger = getLogger(__name__) - - -def _get_prepared_distribution( - req: InstallRequirement, - build_tracker: BuildTracker, - finder: PackageFinder, - build_isolation: bool, - check_build_deps: bool, -) -> BaseDistribution: - """Prepare a distribution for installation.""" - abstract_dist = make_distribution_for_install_requirement(req) - tracker_id = abstract_dist.build_tracker_id - if tracker_id is not None: - with build_tracker.track(req, tracker_id): - abstract_dist.prepare_distribution_metadata( - finder, build_isolation, check_build_deps - ) - return abstract_dist.get_metadata_distribution() - - -def unpack_vcs_link(link: Link, location: str, verbosity: int) -> None: - vcs_backend = vcs.get_backend_for_scheme(link.scheme) - assert vcs_backend is not None - vcs_backend.unpack(location, url=hide_url(link.url), verbosity=verbosity) - - -class File: - def __init__(self, path: str, content_type: Optional[str]) -> None: - self.path = path - if content_type is None: - self.content_type = mimetypes.guess_type(path)[0] - else: - self.content_type = content_type - - -def get_http_url( - link: Link, - download: Downloader, - download_dir: Optional[str] = None, - hashes: Optional[Hashes] = None, -) -> File: - temp_dir = TempDirectory(kind="unpack", globally_managed=True) - # If a download dir is specified, is the file already downloaded there? - already_downloaded_path = None - if download_dir: - already_downloaded_path = _check_download_dir(link, download_dir, hashes) - - if already_downloaded_path: - from_path = already_downloaded_path - content_type = None - else: - # let's download to a tmp dir - from_path, content_type = download(link, temp_dir.path) - if hashes: - hashes.check_against_path(from_path) - - return File(from_path, content_type) - - -def get_file_url( - link: Link, download_dir: Optional[str] = None, hashes: Optional[Hashes] = None -) -> File: - """Get file and optionally check its hash.""" - # If a download dir is specified, is the file already there and valid? - already_downloaded_path = None - if download_dir: - already_downloaded_path = _check_download_dir(link, download_dir, hashes) - - if already_downloaded_path: - from_path = already_downloaded_path - else: - from_path = link.file_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) - return File(from_path, None) - - -def unpack_url( - link: Link, - location: str, - download: Downloader, - verbosity: int, - download_dir: Optional[str] = None, - hashes: Optional[Hashes] = None, -) -> Optional[File]: - """Unpack link into location, downloading if required. - - :param hashes: A Hashes object, one of whose embedded hashes must match, - 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, verbosity=verbosity) - return None - - assert not link.is_existing_dir() - - # file urls - if link.is_file: - file = get_file_url(link, download_dir, hashes=hashes) - - # http urls - else: - file = get_http_url( - link, - download, - download_dir, - hashes=hashes, - ) - - # unpack the archive to the build dir location. even when only downloading - # archives, they have to be unpacked to parse dependencies, except wheels - if not link.is_wheel: - unpack_file(file.path, location, file.content_type) - - return file - - -def _check_download_dir( - link: Link, - download_dir: str, - hashes: Optional[Hashes], - warn_on_hash_mismatch: bool = True, -) -> Optional[str]: - """Check download_dir for previously downloaded file with correct hash - If a correct file is found return its path else None - """ - download_path = os.path.join(download_dir, link.filename) - - 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: - if warn_on_hash_mismatch: - logger.warning( - "Previously-downloaded file %s has bad hash. Re-downloading.", - download_path, - ) - os.unlink(download_path) - return None - return download_path - - -class RequirementPreparer: - """Prepares a Requirement""" - - def __init__( - self, - build_dir: str, - download_dir: Optional[str], - src_dir: str, - build_isolation: bool, - check_build_deps: bool, - build_tracker: BuildTracker, - session: PipSession, - progress_bar: str, - finder: PackageFinder, - require_hashes: bool, - use_user_site: bool, - lazy_wheel: bool, - verbosity: int, - legacy_resolver: bool, - ) -> None: - super().__init__() - - self.src_dir = src_dir - self.build_dir = build_dir - self.build_tracker = build_tracker - self._session = session - self._download = Downloader(session, progress_bar) - self._batch_download = BatchDownloader(session, progress_bar) - 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 - - # Is build isolation allowed? - self.build_isolation = build_isolation - - # Should check build dependencies? - self.check_build_deps = check_build_deps - - # Should hash-checking be required? - self.require_hashes = require_hashes - - # Should install in user site-packages? - self.use_user_site = use_user_site - - # Should wheels be downloaded lazily? - self.use_lazy_wheel = lazy_wheel - - # How verbose should underlying tooling be? - self.verbosity = verbosity - - # Are we using the legacy resolver? - self.legacy_resolver = legacy_resolver - - # Memoized downloaded files, as mapping of url: path. - self._downloaded: Dict[str, str] = {} - - # Previous "header" printed for a link-based InstallRequirement - self._previous_requirement_header = ("", "") - - def _log_preparing_link(self, req: InstallRequirement) -> None: - """Provide context for the requirement being prepared.""" - if req.link.is_file and not req.is_wheel_from_cache: - message = "Processing %s" - information = str(display_path(req.link.file_path)) - else: - message = "Collecting %s" - information = redact_auth_from_requirement(req.req) if req.req else str(req) - - # If we used req.req, inject requirement source if available (this - # would already be included if we used req directly) - if req.req and req.comes_from: - if isinstance(req.comes_from, str): - comes_from: Optional[str] = req.comes_from - else: - comes_from = req.comes_from.from_path() - if comes_from: - information += f" (from {comes_from})" - - if (message, information) != self._previous_requirement_header: - self._previous_requirement_header = (message, information) - logger.info(message, information) - - if req.is_wheel_from_cache: - with indent_log(): - logger.info("Using cached %s", req.link.filename) - - def _ensure_link_req_src_dir( - self, req: InstallRequirement, parallel_builds: bool - ) -> None: - """Ensure source_dir of a linked InstallRequirement.""" - # Since source_dir is only set for editable requirements. - if req.link.is_wheel: - # We don't need to unpack wheels, so no need for a source - # directory. - return - assert req.source_dir is None - if req.link.is_existing_dir(): - # build local directories in-tree - req.source_dir = req.link.file_path - return - - # We always delete unpacked sdists after pip runs. - req.ensure_has_source_dir( - self.build_dir, - autodelete=True, - parallel_builds=parallel_builds, - ) - req.ensure_pristine_source_checkout() - - def _get_linked_req_hashes(self, req: InstallRequirement) -> Hashes: - # By the time this is called, the requirement's link should have - # been checked so we can tell what kind of requirements req is - # and raise some more informative errors than otherwise. - # (For example, we can raise VcsHashUnsupported for a VCS URL - # rather than HashMissing.) - if not self.require_hashes: - return req.hashes(trust_internet=True) - - # 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 req.link.is_vcs: - raise VcsHashUnsupported() - if req.link.is_existing_dir(): - raise DirectoryUrlHashUnsupported() - - # 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. - if not req.is_direct and not req.is_pinned: - raise HashUnpinned() - - # If known-good hashes are missing for this requirement, - # 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. - return req.hashes(trust_internet=False) or MissingHashes() - - def _fetch_metadata_only( - self, - req: InstallRequirement, - ) -> Optional[BaseDistribution]: - if self.legacy_resolver: - logger.debug( - "Metadata-only fetching is not used in the legacy resolver", - ) - return None - if self.require_hashes: - logger.debug( - "Metadata-only fetching is not used as hash checking is required", - ) - return None - # Try PEP 658 metadata first, then fall back to lazy wheel if unavailable. - return self._fetch_metadata_using_link_data_attr( - req - ) or self._fetch_metadata_using_lazy_wheel(req.link) - - def _fetch_metadata_using_link_data_attr( - self, - req: InstallRequirement, - ) -> Optional[BaseDistribution]: - """Fetch metadata from the data-dist-info-metadata attribute, if possible.""" - # (1) Get the link to the metadata file, if provided by the backend. - metadata_link = req.link.metadata_link() - if metadata_link is None: - return None - assert req.req is not None - logger.verbose( - "Obtaining dependency information for %s from %s", - req.req, - metadata_link, - ) - # (2) Download the contents of the METADATA file, separate from the dist itself. - metadata_file = get_http_url( - metadata_link, - self._download, - hashes=metadata_link.as_hashes(), - ) - with open(metadata_file.path, "rb") as f: - metadata_contents = f.read() - # (3) Generate a dist just from those file contents. - metadata_dist = get_metadata_distribution( - metadata_contents, - req.link.filename, - req.req.name, - ) - # (4) Ensure the Name: field from the METADATA file matches the name from the - # install requirement. - # - # NB: raw_name will fall back to the name from the install requirement if - # the Name: field is not present, but it's noted in the raw_name docstring - # that that should NEVER happen anyway. - if canonicalize_name(metadata_dist.raw_name) != canonicalize_name(req.req.name): - raise MetadataInconsistent( - req, "Name", req.req.name, metadata_dist.raw_name - ) - return metadata_dist - - def _fetch_metadata_using_lazy_wheel( - self, - link: Link, - ) -> Optional[BaseDistribution]: - """Fetch metadata using lazy wheel, if possible.""" - # --use-feature=fast-deps must be provided. - if not self.use_lazy_wheel: - return None - if link.is_file or not link.is_wheel: - logger.debug( - "Lazy wheel is not used as %r does not point to a remote wheel", - link, - ) - return None - - wheel = Wheel(link.filename) - name = canonicalize_name(wheel.name) - logger.info( - "Obtaining dependency information from %s %s", - name, - wheel.version, - ) - url = link.url.split("#", 1)[0] - try: - return dist_from_wheel_url(name, url, self._session) - except HTTPRangeRequestUnsupported: - logger.debug("%s does not support range requests", url) - return None - - def _complete_partial_requirements( - self, - partially_downloaded_reqs: Iterable[InstallRequirement], - parallel_builds: bool = False, - ) -> None: - """Download any requirements which were only fetched by metadata.""" - # Download to a temporary directory. These will be copied over as - # needed for downstream 'download', 'wheel', and 'install' commands. - temp_dir = TempDirectory(kind="unpack", globally_managed=True).path - - # Map each link to the requirement that owns it. This allows us to set - # `req.local_file_path` on the appropriate requirement after passing - # all the links at once into BatchDownloader. - links_to_fully_download: Dict[Link, InstallRequirement] = {} - for req in partially_downloaded_reqs: - assert req.link - links_to_fully_download[req.link] = req - - batch_download = self._batch_download( - links_to_fully_download.keys(), - temp_dir, - ) - for link, (filepath, _) in batch_download: - logger.debug("Downloading link %s to %s", link, filepath) - req = links_to_fully_download[link] - # Record the downloaded file path so wheel reqs can extract a Distribution - # in .get_dist(). - req.local_file_path = filepath - # Record that the file is downloaded so we don't do it again in - # _prepare_linked_requirement(). - self._downloaded[req.link.url] = filepath - - # If this is an sdist, we need to unpack it after downloading, but the - # .source_dir won't be set up until we are in _prepare_linked_requirement(). - # Add the downloaded archive to the install requirement to unpack after - # preparing the source dir. - if not req.is_wheel: - req.needs_unpacked_archive(Path(filepath)) - - # This step is necessary to ensure all lazy wheels are processed - # successfully by the 'download', 'wheel', and 'install' commands. - for req in partially_downloaded_reqs: - self._prepare_linked_requirement(req, parallel_builds) - - def prepare_linked_requirement( - self, req: InstallRequirement, parallel_builds: bool = False - ) -> BaseDistribution: - """Prepare a requirement to be obtained from req.link.""" - assert req.link - self._log_preparing_link(req) - with indent_log(): - # Check if the relevant file is already available - # in the download directory - file_path = None - if self.download_dir is not None and req.link.is_wheel: - hashes = self._get_linked_req_hashes(req) - file_path = _check_download_dir( - req.link, - self.download_dir, - hashes, - # When a locally built wheel has been found in cache, we don't warn - # about re-downloading when the already downloaded wheel hash does - # not match. This is because the hash must be checked against the - # original link, not the cached link. It that case the already - # downloaded file will be removed and re-fetched from cache (which - # implies a hash check against the cache entry's origin.json). - warn_on_hash_mismatch=not req.is_wheel_from_cache, - ) - - if file_path is not None: - # The file is already available, so mark it as downloaded - self._downloaded[req.link.url] = file_path - else: - # The file is not available, attempt to fetch only metadata - metadata_dist = self._fetch_metadata_only(req) - if metadata_dist is not None: - req.needs_more_preparation = True - return metadata_dist - - # None of the optimizations worked, fully prepare the requirement - return self._prepare_linked_requirement(req, parallel_builds) - - def prepare_linked_requirements_more( - self, reqs: Iterable[InstallRequirement], parallel_builds: bool = False - ) -> None: - """Prepare linked requirements more, if needed.""" - reqs = [req for req in reqs if req.needs_more_preparation] - for req in reqs: - # Determine if any of these requirements were already downloaded. - if self.download_dir is not None and req.link.is_wheel: - hashes = self._get_linked_req_hashes(req) - file_path = _check_download_dir(req.link, self.download_dir, hashes) - if file_path is not None: - self._downloaded[req.link.url] = file_path - req.needs_more_preparation = False - - # Prepare requirements we found were already downloaded for some - # reason. The other downloads will be completed separately. - partially_downloaded_reqs: List[InstallRequirement] = [] - for req in reqs: - if req.needs_more_preparation: - partially_downloaded_reqs.append(req) - else: - self._prepare_linked_requirement(req, parallel_builds) - - # TODO: separate this part out from RequirementPreparer when the v1 - # resolver can be removed! - self._complete_partial_requirements( - partially_downloaded_reqs, - parallel_builds=parallel_builds, - ) - - def _prepare_linked_requirement( - self, req: InstallRequirement, parallel_builds: bool - ) -> BaseDistribution: - assert req.link - link = req.link - - hashes = self._get_linked_req_hashes(req) - - if hashes and req.is_wheel_from_cache: - assert req.download_info is not None - assert link.is_wheel - assert link.is_file - # We need to verify hashes, and we have found the requirement in the cache - # of locally built wheels. - if ( - isinstance(req.download_info.info, ArchiveInfo) - and req.download_info.info.hashes - and hashes.has_one_of(req.download_info.info.hashes) - ): - # At this point we know the requirement was built from a hashable source - # artifact, and we verified that the cache entry's hash of the original - # artifact matches one of the hashes we expect. We don't verify hashes - # against the cached wheel, because the wheel is not the original. - hashes = None - else: - logger.warning( - "The hashes of the source archive found in cache entry " - "don't match, ignoring cached built wheel " - "and re-downloading source." - ) - req.link = req.cached_wheel_source_link - link = req.link - - self._ensure_link_req_src_dir(req, parallel_builds) - - if link.is_existing_dir(): - local_file = None - elif link.url not in self._downloaded: - try: - local_file = unpack_url( - link, - req.source_dir, - self._download, - self.verbosity, - self.download_dir, - hashes, - ) - except NetworkConnectionError as exc: - raise InstallationError( - f"Could not install requirement {req} because of HTTP " - f"error {exc} for URL {link}" - ) - else: - file_path = self._downloaded[link.url] - if hashes: - hashes.check_against_path(file_path) - local_file = File(file_path, content_type=None) - - # If download_info is set, we got it from the wheel cache. - if req.download_info is None: - # Editables don't go through this function (see - # prepare_editable_requirement). - assert not req.editable - req.download_info = direct_url_from_link(link, req.source_dir) - # Make sure we have a hash in download_info. If we got it as part of the - # URL, it will have been verified and we can rely on it. Otherwise we - # compute it from the downloaded file. - # FIXME: https://github.com/pypa/pip/issues/11943 - if ( - isinstance(req.download_info.info, ArchiveInfo) - and not req.download_info.info.hashes - and local_file - ): - hash = hash_file(local_file.path)[0].hexdigest() - # We populate info.hash for backward compatibility. - # This will automatically populate info.hashes. - req.download_info.info.hash = f"sha256={hash}" - - # For use in later processing, - # preserve the file path on the requirement. - if local_file: - req.local_file_path = local_file.path - - dist = _get_prepared_distribution( - req, - self.build_tracker, - self.finder, - self.build_isolation, - self.check_build_deps, - ) - return dist - - def save_linked_requirement(self, req: InstallRequirement) -> None: - assert self.download_dir is not None - assert req.link is not None - link = req.link - if link.is_vcs or (link.is_existing_dir() and req.editable): - # Make a .zip of the source_dir we already created. - req.archive(self.download_dir) - return - - if link.is_existing_dir(): - logger.debug( - "Not copying link to destination directory " - "since it is a directory: %s", - link, - ) - return - if req.local_file_path is None: - # No distribution was downloaded for this requirement. - return - - download_location = os.path.join(self.download_dir, link.filename) - if not os.path.exists(download_location): - shutil.copy(req.local_file_path, download_location) - download_path = display_path(download_location) - logger.info("Saved %s", download_path) - - def prepare_editable_requirement( - self, - req: InstallRequirement, - ) -> BaseDistribution: - """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( - f"The editable requirement {req} cannot be installed when " - "requiring hashes, because there is no single file to " - "hash." - ) - req.ensure_has_source_dir(self.src_dir) - req.update_editable() - assert req.source_dir - req.download_info = direct_url_for_editable(req.unpacked_source_directory) - - dist = _get_prepared_distribution( - req, - self.build_tracker, - self.finder, - self.build_isolation, - self.check_build_deps, - ) - - req.check_if_exists(self.use_user_site) - - return dist - - def prepare_installed_requirement( - self, - req: InstallRequirement, - skip_reason: str, - ) -> BaseDistribution: - """Prepare an already-installed requirement.""" - assert req.satisfied_by, "req should have been satisfied but isn't" - assert skip_reason is not None, ( - "did not get skip reason skipped but req.satisfied_by " - f"is set to {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." - ) - return InstalledDistribution(req).get_metadata_distribution() diff --git a/venv/lib/python3.12/site-packages/pip/_internal/pyproject.py b/venv/lib/python3.12/site-packages/pip/_internal/pyproject.py deleted file mode 100644 index 8de36b8..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/pyproject.py +++ /dev/null @@ -1,179 +0,0 @@ -import importlib.util -import os -from collections import namedtuple -from typing import Any, List, Optional - -from pip._vendor import tomli -from pip._vendor.packaging.requirements import InvalidRequirement, Requirement - -from pip._internal.exceptions import ( - InstallationError, - InvalidPyProjectBuildRequires, - MissingPyProjectBuildRequires, -) - - -def _is_list_of_str(obj: Any) -> bool: - return isinstance(obj, list) and all(isinstance(item, str) for item in obj) - - -def make_pyproject_path(unpacked_source_directory: str) -> str: - return os.path.join(unpacked_source_directory, "pyproject.toml") - - -BuildSystemDetails = namedtuple( - "BuildSystemDetails", ["requires", "backend", "check", "backend_path"] -) - - -def load_pyproject_toml( - use_pep517: Optional[bool], pyproject_toml: str, setup_py: str, req_name: str -) -> 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 not has_pyproject and not has_setup: - raise InstallationError( - f"{req_name} does not appear to be a Python project: " - f"neither 'setup.py' nor 'pyproject.toml' found." - ) - - if has_pyproject: - with open(pyproject_toml, encoding="utf-8") as f: - pp_toml = tomli.loads(f.read()) - 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 - # or if we cannot import setuptools or wheels. - - # We fallback to PEP 517 when without setuptools or without the wheel package, - # so setuptools can be installed as a default build backend. - # For more info see: - # https://discuss.python.org/t/pip-without-setuptools-could-the-experience-be-improved/11810/9 - # https://github.com/pypa/pip/issues/8559 - elif use_pep517 is None: - use_pep517 = ( - has_pyproject - or not importlib.util.find_spec("setuptools") - or not importlib.util.find_spec("wheel") - ) - - # At this point, we know whether we're going to use PEP 517. - assert use_pep517 is not None - - # 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"], - "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. - - # Specifying the build-system table but not the requires key is invalid - if "requires" not in build_system: - raise MissingPyProjectBuildRequires(package=req_name) - - # Error out if requires is not a list of strings - requires = build_system["requires"] - if not _is_list_of_str(requires): - raise InvalidPyProjectBuildRequires( - package=req_name, - reason="It is not a list of strings.", - ) - - # Each requirement must be valid as per PEP 508 - for requirement in requires: - try: - Requirement(requirement) - except InvalidRequirement as error: - raise InvalidPyProjectBuildRequires( - package=req_name, - reason=f"It contains an invalid requirement: {requirement!r}", - ) from error - - backend = build_system.get("build-backend") - backend_path = build_system.get("backend-path", []) - check: 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. So we - # make a note to check that this requirement is present once - # we have set up the environment. - # This is quite a lot of work to check for a very specific case. But - # the problem is, that case is potentially quite common - projects that - # 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"] - - return BuildSystemDetails(requires, backend, check, backend_path) diff --git a/venv/lib/python3.12/site-packages/pip/_internal/req/__init__.py b/venv/lib/python3.12/site-packages/pip/_internal/req/__init__.py deleted file mode 100644 index 16de903..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/req/__init__.py +++ /dev/null @@ -1,92 +0,0 @@ -import collections -import logging -from typing import Generator, List, Optional, Sequence, Tuple - -from pip._internal.utils.logging import indent_log - -from .req_file import parse_requirements -from .req_install import InstallRequirement -from .req_set import RequirementSet - -__all__ = [ - "RequirementSet", - "InstallRequirement", - "parse_requirements", - "install_given_reqs", -] - -logger = logging.getLogger(__name__) - - -class InstallationResult: - def __init__(self, name: str) -> None: - self.name = name - - def __repr__(self) -> str: - return f"InstallationResult(name={self.name!r})" - - -def _validate_requirements( - requirements: List[InstallRequirement], -) -> Generator[Tuple[str, InstallRequirement], None, None]: - for req in requirements: - assert req.name, f"invalid to-be-installed requirement: {req}" - yield req.name, req - - -def install_given_reqs( - requirements: List[InstallRequirement], - global_options: Sequence[str], - root: Optional[str], - home: Optional[str], - prefix: Optional[str], - warn_script_location: bool, - use_user_site: bool, - pycompile: bool, -) -> List[InstallationResult]: - """ - Install everything in the given list. - - (to be called after having downloaded and unpacked the packages) - """ - to_install = collections.OrderedDict(_validate_requirements(requirements)) - - if to_install: - logger.info( - "Installing collected packages: %s", - ", ".join(to_install.keys()), - ) - - installed = [] - - with indent_log(): - for req_name, requirement in to_install.items(): - if requirement.should_reinstall: - logger.info("Attempting uninstall: %s", req_name) - with indent_log(): - uninstalled_pathset = requirement.uninstall(auto_confirm=True) - else: - uninstalled_pathset = None - - try: - requirement.install( - global_options, - root=root, - home=home, - prefix=prefix, - warn_script_location=warn_script_location, - use_user_site=use_user_site, - pycompile=pycompile, - ) - except Exception: - # if install did not succeed, rollback previous uninstall - if uninstalled_pathset and not requirement.install_succeeded: - uninstalled_pathset.rollback() - raise - else: - if uninstalled_pathset and requirement.install_succeeded: - uninstalled_pathset.commit() - - installed.append(InstallationResult(req_name)) - - return installed diff --git a/venv/lib/python3.12/site-packages/pip/_internal/req/__pycache__/__init__.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/req/__pycache__/__init__.cpython-312.pyc deleted file mode 100644 index 042a3b8ee032725cd526ceb7cc24180e9e83289c..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3753 zcmahLTWl29_0DVG>wS3F7<&y1#<9m>FC-!f5JFIaKnhM3^OIGo(Xw-GkC~m>+?mDL zU8@%2!}K9Ql?qZ6DQ$m1q$=uHKhr#o>RFA z0jUX5jb0Sa@ z2>q)dwyBjNAg&Qg@Kp1>%27e(RRKIEf`y{WQ(=NvC7`8QLH4bxQ$W++qE9nmP1 zsN-YQt}tV)*ghI}1EdA`R+8>ERjx`DcL32WSUq-=V{xEm-VrUTPq>VQ)3VtolesCg zM02d5YDQUOW@RpSgj#29vz$B3&J~Q2!#_AN@;zP4fr;mGx^^a4p0%e;Z&*v=7 zrX%G-@oZs|TDh`T&MBHim+wNXx->5g(1zK4_KntXi z>RuFo9$W#26x;EMv}>$u@OEI}=77P|?!eRNJznMC7siP!jLmg_d&?p8=)otP%^ai?}dyl-&--1~P7oH(oJv}!^!;E+<<1BE9jbb6RkkbfsZM8 zVVq!jwrG~hnof%WSlk0lEN)o;8BDxJ?A4H;Mw2&yEqNVP;w5jdoexw4>;>EBNlfE? z+5jr2^3%BE2B-$6qZ_(__0HJa!7B||TIPc`Mwttq++K(xSP4UI19%b;U%w*c9k6UZ zG#{>pr!jeL0QSoNu|cS=7AcNALyPb<-kA-ciXTdzE%Oo8hrczO3|{rkM}h>j!t1*M zAiwfep(<9Ts;}z*(0|L{65z;>BdibRbZ?jdEK5`))4kvB_q@Ro*ey7X7kdNP7|Jey zt?h{LTDVca5n<*={j0%oxX^nbna%JVc^l3GB&W^`Z<86WpV%31#T|rYU9B_Ut+f>g zt+#s8YweoW7sw3p)_rO2XX!c0poD0~WL7h>_7u&!^)stOK_3md zqC>WsJwvlasL7BJ3KLLLvQvd~I7KyQ4BafK*l(!Wih<<^7+lAzM6$cc+_v_PIIU>H zQbijCJ)!;C0c(!mm7VK8Y}>R1mm0(>MmrDT=xKNaL<$w#REnlCp|R4K>|+Dq2lgDI zK}1;EnT%){keqbF?VX@>TTb{*rcy@LBU;gRlak|u$H*jw=Zj`cn2tDYYK9}8rLz{p zRNzREA4--Jx2DXBu0s83tK$S$HFNx4U!qMYR;5^^6kOu?AhDD*+X)^$U!-oHasmuY zKLbv3e1&qE8me1JDX%h*oms-jd?$_0DM zqPB%81w&vJT4fEp86s4`QX#w-$fGSJ*|(e+swal-%7;FREXk*q5@QQ*eC1Ev3v^r# zUkW!Oxke;@`NX9YSEjF-SIwoa!KKL1BS{E`njw|Gjo=^^P29;ipQEgrvewh`-Dj_te?+j%eEbuD}~T+6)phrr$V;d|+=zj)^X;S%Fq zV|efK@S*zfp+B9j4If$>eyf%md@SGylw8CEUOr*_|uq?aR^ zdL(nVFLyhz)VJ^R$o>Z}fx?dkFr)bjiKJ^{>ha#S{r>}=O7%S?Vzle4&gX9YXgPQC zPVS_;=I(lG_ubUoAU`DohzSsLX(>z0mg_sg5v2(01wF__`nI6ix}3@yX*#js#9 zEKdw85X1E7^upV4boFgGTCp|V8g0*RMZOzO6HpUdZ)=PxFY4SUx8uhi2qyOx?)Vi2 zk^{VE0=Z36|v$VL@VB5Mlas#51O;yMe|qovl5ro&;WLJ;q*TZ@>WNSL>gE zngYjhUy$S%q~ovT;OFGv*W~%H$oE!=tKg-at%KXL(&3nCXH(e#z^OQ)J)zD&h74*0XSMYn>0DMZ{K_F?fX3UobQ~*e=aF;a=4a#H-pbV&vAc4560D`M>ekt z9Cw?OxKU2xB~yqW<=NddYGQZusF~e`Q2}>z$P%`WTEn(cTi8Bo4?9L3Vdtnb>>722 z-J@=v>JUOD;nLAk7Po{v;j+=PaQSFCd$xuu!j+?yEN%-`g{w!aS==6~3D=I+hU-S_ z*s~*4A8r_JU~y-tG2ArT#Nw_{b9l$-4iOWrR#mbLk&68CajVpToP$!MUaMXwYB$Q7_1c?2cSvd`I>|IHNIUR6fEuYa`|-RJ z&xcLiDNYh^a8k=Xlh)+XLA~xl(6oZ)DF-JVlT1<@eiYI_lhppMozd+=>)o=58dNlPRa^msu-IL#1P0T1|X`0Wl0Q(;lLDX9h;nqToR+>#j96?v$9i- z_K4x=Woj0x2#bM;B&svh(@`ac_e$uqECt5`G1MB1Y9!H_n2H8az3kOvp@6D7C*{yI znySd4Rau`d%CVTNh%*sMR?xeM6u1}+1!LD(CSE2gvKrHBk=eU^taIo_038dEJZwYp)c8G=h;aygNGXd~!H_&R@~4Kkc<;oI}x2 zNFJlH&j`c8u~&&sik<=hOWDP#G11c_cgV|^*0T#^;9DO2%W zVslnQ1m<0^OnvE%HtJQf@ef}YQm>&;=)eNs`PREcor+L`Av_H!5mih&HRh+M+m z^36$E4pF%?0R=tZS~Fh0eW`%d6IA^HWo$BdS@w?yLo$*oki-Th6bf7n$$lwFZShRV zF~5>uW=L{P2V#@{SkynGgwQZ6$|069UmjDv=1jd_2Nm*3!*Og~~63&xSmnep5F7YJ^1v0UDi&Y~HW9!PwgGg$W=FL86G zIIncX`6){wl@^yw#!)tB{t^mvj=~f-$4%p=vs|15wI25hr)MjEx68NN+jai6*M9f> zg$ujSU+}j7ikkQAvI2qBlKaavDvVA`!G*^g&e~-eJxYs2LlOC>y1#l z(TLsnspk;Pa~pQ&P5YufS>CZCtl4|#kEct@=SM!V+0*q6cWdv|E|W!35)XOQI2)4{O%@mvOaYSxoyj5p@ z&J980EEgjhcF~*{n_q)=7F5POPFeLr1-G-D*K`^SJQNs{C!--SBCn7!t8z@K1y#lp zie8Zw)=n?aZYs^MsCX&26r*@qR$|7e?Lp!p{M0T4^V}z{@(oYL+cOL94Oc_r=*q$0 zKl0&`drzkt53jif*Ima`uH#AJxI*KcF=J9P&WLj) zgT7;8s6xAnjlxH!d-{lC&zR<2&vTMF&b`A)!h2?8B;VxYrYVO}Oa3ldjCWvf6sNG} zD1^BAx+yNOH`t22fmfO(yX2U1r32@8^9^@X8jun10-|MqgN6AcQkdx+YErRJ{O*qxvbP$ZYLNVi%5MNr_HRquSuO7>TlG zX)jUsTUseJsHkxSK3fA;~1X_g)~lR2B*nbj-MTR?m1-_KU?gKzAyLSZ;zp9! zs_ey0*+)S;(U_;fN`>ht$`aF1X-m)~iuzWp^<&Q#9$UtqJO;v}RN_A&nCBk3xsI+6 z&cA>Dp}lLv?phdn+rCj+c5`xZ@{z;RVVysjE#n-eNqc?PY_hz_KXkM&pIttg^gf@o zy|8Jaq_n;MVf~J~jdvQCzxK|K`Jr^f&bzzs>|PGM& zW|IA1Pujjg<-dvYJ%9bw$)%3O{<{Nr27WZMGPu@$aINvsFDefG`M&v)4OdN~Em57g zoS0mWEsrN_d)HjPq~O!ogxfe;sjFK!rw!esIokY>;2gv`=lDG5%2abw=ticcB;KXMw~}ghLr+ ziuIH@kz{@^*E5y>eg{hv;ym%EIi3dx6S#s=$c@dMHEx}1Fxrs6t9vBNRCE5>h~?Wm zMZ(6m>z>XD=WH?B*z97Q*c!K?jkfm$g904i`Xw_Us15njl6{Ky__iy5_7v2I-WDHY zuOq;rVN9L{OOA-fLf^uzAi_ik8S|r^-zx^TFyVYp&6O zsnx_r=2~<{@$2HKp9*>_n2eb*MO95Awggp-mqJ@j=|hllLWxmgDz!!_rvx{K82UwE zf)ryWp0T4q@lg@l9!xQTPNF>2~(Z%FKh4v&1zJZAP8rJnZm#yJk zwev%dtXy;VO50kKFD2B^zqEAlGn?bBE7z~QHFte(>B0kB+h=uc%P+0f?OP~$XscSc zHKc3}Yqq9!TW8AFxng@@+p|&In0RTewtKzyP^$LOf*Vri!?LDyS@TBO&gGI->rdQ2 zcK<4vRwJ4G`@g?2A?B4TX$7<7B_tTpeGtrts z3%#N)QTguJJ95(1mK55wgV9d=h89-wL$M!oP$)RZ8OHmO*${gV;JB0oV1JeyT$~@~ z3|5|x(eVcM?+5!gOV+sgGN)9<&5{iVj~TPP?UHgLZv#^qi>WA*{T^CHmm*S4lB0nu zcJLZ)DLix~r=jT5(T3wZcO1oYqAm}Hidyl{pyj!1HUW6qlc{aoUQXq&n0W40lp?yT z=2y8Zyw?>F(a51mdF&ENr8LUKi%5Yd4PS&v8z|%o0CqqEoQ8J8Ig%*xe^L%y4u-Df zdzL>Lup0f3B8!vhMKi~6l^^@tZ|VyqgK;4p$p7{W9)1560p8Vw@xd^`x~ zh+#qCT@W%wLKyV-4=RD63cTk@G-gnj*ozkz#{v=JwqT#EWfE%!^@zH=MS#{tam!3> zymtT$Xd)6-WMCwAIRbDDO@f|Jc#gVdU6RPPAHU5J1TSE`NnpDG*m8~sWKj+ALSGrk z&RtSYnNx9${%ig=&vV~z6u4{re=uXFOpp1t(@;{W$`4H$lWz~>RI*Bvp3a#bJC01q z5&7!0^7QOJHip20Fn(JE=U{{ZM7|^JxKN+=<;o;bliGpczjI&AbHC<Y@Z|-d2xAdKM3+ww4L~?zHP)2<()^B6|>piYP zk2&h`hdjEQu`t|1`5kInK~I&}knm6GY zCVti=ww->=pa0eW{)d0~2ZgkLuQek?p)X~G@nA%v6(DJ+*Y6@TBVgELnsOs3U!xR$ z9Pk1btE!CRF^BtT(8A8Im>p#TWqv^A{yhTdH5Ht*bYXJ2cD3$-V=&8=St{=bJ{K?z ze_hwV+VY^T|B(d`3l{L&>V{u)c1PvH@Iz1KQfx7vu5C;<^(Lgd!8^ef;hku**0&@e z@8;a%T;kjVPb&x#Ly1?GuHAm))*EZJT_5$YT2_^N$5OR}OTvb`HX%H4H>cedziGj1 z*}Fe4!wY^>j>q3nQ$DBQv08zq-aNkhM5+0Y%{+yrmJ_wMEvq930R07M!Lbo)S24h^ z7+1}UovM|3DE_Nnn(g_sp|UQ)nfg<=VIy9qsIDhlIg% zF=j=igkmB-PK6x&NPLv)xWegt)HZv=z#9k$Cq@-k0rW?}YalfhvObN;N>MN_VnXs& zK+ipl0})`qjWZdX4ty#QR;ivr02?_dLu1EG1Y|YL+QboJ;hnSPo#NJ4_-1Rsu!-YA zTx417%|3Cqk&*+-#0&{uB1Ab7Auj{q2WT;S)hiN8fb&3y;)@*z8n=ZJ0*3)HZR&Fm zf%fdFvsdX9396tPbi|lt82F_wRMG*UBm2RaZ?}Dp!EG%Y5%*tW{tdw?&joTq138Ri{R+vf33KrTKlGQV=g3(uA27SgBW;PL( zN!DXIU=mrxtm!P!TN1}!g>a=`aTA_$XCNSV&YuG;pr~_xD#@;EoN@sX0PEAZv6m{} zrdTJXS~3D)s_|lZDm4a2x`80s{XocrF~5JdetW-sM%JI8h}wbx@_Z@R)VUx$u-B!l z>K26WJJPi~aC4_?nihl~xR_LW+Uv}qS`thB{*2S_4@adL7+U-px8MKmnLtR(QLLzu z9Suy;QHaYZ#Hf_R6c7*mkYg2U>P3`NDfnajR06nea9NYn()_TxIdLgf-JP}IA#3G4 zwP5d&tc{-RTt!2oBURp#bG_^MH|LQ* z#}l9w=dYK5zvkv84>`>V5fh9tLZSR>lm}p&mt2LoMdBd83V0nZ#)0)X$AJTvfdl9G zH+VaM6XNYgU2pO^ZfidMxJDQH3K_zn*!h_61h~i)Gy)nK4`AA%HuN+G$bSYmoYy&Knzr8RaO9LXi#{jW?ELl z*gpoS;)f{~7TJskMaF{@gwMtx533o}0hOGMj`9W?rOZ=soq{(h_$~!EDEMa-5Od90 zL+C*E;K!CF(G*{nbIyW==q!eCg5B7#gzRx=F?&ed3I=2bqp`#tpvZ{!GN&E7PYwo@CCqHvFr|l){_WG2)K3&XS0PuK2BSGT0=I@6x2oAJf?qsCIVHOrM+tQt>=qvkC< zg(i+o9&LrMlz}8EFE#F^uu_dM8c2CZ&-Bg#H3U9);rwboy~9wm|Ke z9Sf*l2!>B;F*YyOGO$ag$P=jsg?1awS7j`-08mbn?Z%_<lIzsp>YcbB}r7h}Tje;lXx0 zov~`~V7f3=Vp@fTcH1&Pn+HG515il-j5k4H#?-0LA%d+?#o3(q`Tg#6welYR=#0Qc0Blm?=#}VYGZLYW8xcI!@u#R(PBi*dlUeR4nta zXdi*K+pfH_1=~^nz|YkR>kB`Xv*zRrO9HIRy5Kiwid7pqd8?CTy>uR|%u`_NGD$WP zRSmI#wU`uoc1=;%wo9@@Skd1C5u<4PV4rvaQ^wZp2tg)2Vo-;n@;e*o zeP>Rd5&Qf1Fk?c27JvaDOA2)^*K!>*a}FE!5pi~i7yxOz1%u@iPwR}N6SBk1G~84= zL8FMB)7NwxhA$QkhoCzW+wlR7d4}1ll~zo!LK8ZByg-x}cPX%d82lG}hgdGjcnoP| zt)rA}YO%M3F^4>dQBG3rw4gL&1(_BUTA5^ipb7v<0j`W?%&1+Nq72)WfI_AfubF9~ zj2~s(uso2IsGZVg(1A&7;7^60e6Ywe!Q81Bhq?`d8sboYf(XNV>~+9hY|TGv{h;&x z&JTLu?_Cuhv>w=SH7BG8uC|TJ9f{alWqZ=y4x58VOqbRrsuK1r$G3DNDCyob8<6@V zKBi0r=WV2Rc#2)w@zO_owmP_w!0r$%oZ!X2O7zmt0^foG2WPQ5dh}b zVBjr`l1^J1lg&^Lj@fUpMrcf7}6S4j$#ua&jW%R1QPRH?SC*^c5vY2;O$(ne08R z6T0TCc()BddjWgQkDWV~W7YYxbGArl-mo6e*)iCdIZ#uc2|Mz5*PJu%yzVNf&zWn3 zEpAg%aobdm1#4}iP!cY6Ve?##<(P6YGq+?x>85-sBWBE|@;mwW#&#OHUon2UgU_Jn z3ediyb5v}^ZN(^!o`2bW4kI!p=HF|?l)bSwBMypoBc8t-HO{%>uBncEx)FmuY();n zbo<3z3@i~3>h0d1hjn6!VDDg+_8NKdoNa2(E!kpZVr7?P&&S7w1%8~D95>wG^GMEo zI%xJ7^q}#8#&yFzR}!~ecbK?1?zw)HGGw4MM)m-9#Y^Khs9o+n2Hq17n>8Ihnh|28oYTB-Q8Y+(AcY>vN!4JP1<`kmRLfELO^Byn30JseIn_R_32-s!r$ZH zf&>Z3Mc?ckx0u`7%#@-_G$@n1V8HCdbejr11alrK#O|hY@Jg--#>$v3_^gQJX@l`I z!(*io&?)d45g70d@I1%p0Nq3(R}tRAt|>Y)w_U~jOcqJiE0+ZL+gS1}Dc?&5)mtJh zl7&$==2_DMhec<-VUOjQPTr84>kUk^C?$c5ROlguqp42+X|yY4>#%-z)Ko2`bE#uh1rNqdj^qg!U04lvpj zo3zV+kI$LOaE#F0E}AZLx;e~gn8O$hs;yqL@+ykKw_;jZMnt9BM12WshOy)S=+Y&b z1lSNQL``umVhf~YrxJqjg>DQq?JG@pbuXEg!Vk*YJ~!i0GnRd~w49&qIcf-ah6f8Q zWlU}KiNisO85PK%Up#tLJjSeP7%0t$9@1mZoG~cQ+MLeRx1xRA3}#-TZ!z>i)- zOUIC?0eU3I7l>^?pvN#3F+|L^@%W5Aq_O6828jqyP zj@+`P%c~M4sq$SPjcsz6&kf(9M>MaGI8$FKWW2`b_*=Gz4NXh7Pb!*|;(^t0^1w)P z$Emf7XW=5^sewr&QMcT=T%WAnohsYCWClLDJhWEPm2`Jy8_|fzD)EFHuHzo==bqyO zLpHOwK_OW{`5^^lH`T!KVTut0&Dfy;glWrQQZA}YGA1F0ITI-)Bg2mrSP6hzI!o~Y z%hcE;Lvfk7PDrPQOe$oJWR_S>9=GZHR5?ZIbb@IMiowKDJbKF*Av+W@PR*_XRC790 zuG={BTwAk1EK?oSYRwcxJje1I0y&k$fSZP-c{q#N;cb^W6AVRhYtGi@thI+wE5r&~Kd=zhO@ zW%PdeTI*9O`_2U+2}hl#-u0&asiysFO$Xou`w7&Bnuf(wpVc(MhP77Hw|MGdMa_aO z4PT$Z#lg3a%n!r(G5^wrtAy-c>#oL>tMT0vcTe3p#ry$=*P8aOx%Pp|5vrzS! z)}jrVo`>I_T@*gsv3q5BZO7h}y>Wq0x*9i1#pUwl;k8olf*C$Z3&%DpYZK-l9$py! z+{)SA%*|-=sYJ&wT;h*j`QX*}UtPI+zv_?bep>fn*9nlm>-y1&4^F**YQ4Qb)!zSy zul(ejKmO)V{6F@8eD2R){rRhF2VP!lKeJZ%wYADuVE#roj(+dxMpb>H{ci7_-nFW( zg_G%>?RRJI%qBuBtt(&u{RrK6>re5|?-@H)rSqTj1J!>Vs z^CMZoZ1KI@1_PeO_oKGIqg&S5XsP@N_Hf+(u<`HcmL25m)k&N9$*zN|b8EX!E}9>f zRuHsx6dVmbd2EG1%NR@)gkR>NgPsC?A0Psp9=F)enct8u z*$s-v;qkA3>m};gtt6{sO7J38itP$td;(%<(=qH4NULU}r)JUjdSq56+UXeuUhA;s z8>W6htmrOt3etcOud~2vS!~8>inVDcTL7DO*r;f$Z?_eEo6?BL>(Y4DTa-|&&LXQw z`5uT>IyI>e`lXo*NQPD@_?N_6&LRQ?qJt|Dmxbj^Ywms93p>0t5NQF5nht#Nuk6g%+8Ws*J>vPV!;YUmb z@d;)GDxC;GY@S}sR_G1Hux?4JD=^EF+MTH+r4RC06yCr1PB9wB?pEk%)DHHSiN+d{ zWAIqh);-zKAlLnjNZ1~jr&#Vanygo;RiwiIH|B>81)q9JOu8#v`($V9bk`~oC8)gF=ZDw>}Bir_LRLnYcV%klR_kO}Sf>9fwoy!wkD4XW0D@J@q%=SbPJgbRxbov~pmT zCokIlc`sUg+Tz}kw!6~Uez43jtKB1)m3EiaV*TQgS9c+y2JTF@4%~0J@Ba9BQXE+; zJ(aYdf}I#`f6N%bo30Zs?vGvdC)&*!CzCTI>i(7uN!x^N$amR>1PX?P?U%Bzz!1w7 zHN?8W@zG(L-0{tP8Qr9HWZ2y@i2SFGEbfl+Uic4CWZ z+bdn$vR>Phs_j7}AFpmsH*}_(c0cmiJ>-5h$egPl?czM`#YN z7u_#pq${=(`J(b3Uu+)~KPr)0Y%Lc(8bM3UecJ_&pz{EdEl=YZVJZ|`fs3I1Z6vH4 zphH2beS2vpR}~YZ*ivN$P1-B|9HqB74(@nj$wFql17P09-ruf<9;bW)47)MCc1;R2!BRu5kU;8#a0nlOuzzdkyV7$n!>khamLf@o=gXI zL(x>?cH1tv3+XK;zDnY0r`05L5&ESw^u%-IwvuAv!g});LE(-4oR!djj zJ4-hopZ1n+-wz~kX&6VbO~F`xCz0f~2Xln-dI~nzG0OK*@LTLpR^ztHc!ljXELu)C zo7NU?HTsm=_y+jDfTouA*xQI;kCCACaNx)v*?($J4!rol-L^dZ!L#o_`_b4v`GLDX z`N}sQR@UZs-OX1QU;S-&p1xx}r%36_wopW z`H>qhK^g#$A6Ohnx^_M?a}FrdAK2fwuXOx=?}xo>_5nx|7T1mEp(D5}=3l~}&nT_P z+6t32AwctdK0R`J#48{;?LC#T`Jo?;`TYv5po~q2Av7GkjgqXfYt!H;3iVE*c~(eC z)O?U_6r&?vA^Ur#8Gkp#=f|HvkfI6@ZTe#(DCsj?x`|(BT8q;ZOrff2bHv9pVsYvm zhOa6lz+~zenehipeDYQLB$u4fv=2EOwr0bt8jhwud~_pURY*i5Q)+V`Zz zYtf)s(#bR12+$=Te(d8YrIHA=@yRvQAkfz`V|LqVW@14!mDE{G13vv>jw9Q;tI>pm zz?r6zwQ3mPrF$3HqY`9)#mxlJ{RBoIfo$IRKh>K0;n3dWG_xp#Gc za_7NR{h?IZfKj}>K2de6H0z+soN!;yx+sS4&YBbFmfP;UnyTu|mQYeDR|&tPW%Kg6 zmA3a^T`o;E_N6NJWIdEu#+6rR%PCfYkAt(76srORpRJ}?4Og=xAuaD;v8;@(_TM-E z`0z?3)pa!4b~Lr)=~VTxEHyP-$64z(>nZjOU&faw_T$?$zI?fVlWy6LoqTiRY?i}q z1yhLIs{MZDk4rWwnjPl9$@2pV3@hEW94($a@yaGk%w9EVqt=QyJTYo5yJ+BO)R3Ka zmSoMivr$W^$@YT^u0&ht>$bcJyp>dR#WV& zM~voXlvMVgt)W0iwlUb=SJ|=V;uM2=*4)7(~0$eZRNOI+_Rj- z4RR7MnL_*^&tlV{iN)qYGmC{mfyI_V3yZCTHpJ$TY1}?&=c%m_a*R6%o#U=S*SLGo zJzg|eH0~MnjC%*Yf>v zYgpPIsvWNztYc|MsD8X*uz{tWp~ms1!6ue=g~ajZ!DgP5or)XtaAO`VgDtGADAYRM zHrR%=XM`VYm%VbS+#zooHq~GO=x?x7cFUVac;s)A?Rvf*4*E=-ER0<;mMj}fUgSTQ zeK%4cn)K9Q*ArV7f5@lnbU(39Nv2MZTt4=a(R(&V?&a*8kwWejBb|+rD`nq|6mo}+ zbT&rrX!gxWA$QD3XJh1svTsHTxf4b@8zXlz`(~t&s~G8QjNC}}%}62ls*%pd$i1F@ zGg2d-!2@!!?3PMp(^%BV&Bocimk&v0`%!>?=Cb8R3c0Tv>1>SLH?nU=YQ#Kv^lOh< zo*uJMKm1_d*Y2l+^>eh3yTJ{aM)3C{4)iRCbG6CDMY#{tlN)=}m}NFLPS{P;+jRn3 z&T@mt<-Y$GX_D-N}J?!k|=xRGm=R%4Vx)%*ex}`VHxa~TF{p$ zcMc0u>l?!00Q%n}waI6{qDN6aGi;UG(Zl)ltoBMBvYpLrlicyOXI6)K*ReT@n3+fF zM33Ld^!U~D$gV(6Pw4Xu`$nhaLw^_8T5iT#Zpp0W#he+6vJYS1g|EMaFQ?TY{Flay zDCtJYv#gIE^wBFn_n}!|;K6UAu4!yFXSvhKVUx5Kt-d8~lRML^`xM>>bKbY({o6V3 zJMjL3v@^Z4`E#&JyHNV#v}wr1vlDs^p^@_Ko2heNkiRn(ROE4aBBF}J!H_IY1{5_o zG2;Atno_@y*R0P4LQ}Hpb7)1EzIFbX|LDnMN6(z+JpGhk@HK9hR zJF0d}QP4+i?gWoxe&;bgnU$fr>!KV`hDI+Ag(q2W=Yx|MWmQFM6c#Iipep-^!-^lh zMy6D15SWUD{gONsmZ*VeM2`5Ul#pK?8pRqQ$KD^lAV;PY>Y(U+VCdz*h|=eWE*(B{_8659<(?^T`epqr61O;+16#rkniw*0N+#JXnPou|5L*yiWs7W;&9W_v z+$9_G7}!g8i3gZD02cOX-sjRv*hWY>+taVPa@Iz31y#Q+1taVLIETXHvg#jJ!sFQU zFt!<+GZE2j>CM+%q2Pq8Q-)B`CkfAhE&_qEq1tJA42z)k8Q036@ z##*cbt4g(0n!2bzUySsQ;_G{rfE1jV3@YKNnchBGeK``I>^-bp4NP<&K7XqFXeiiw zRi3!o8wy_Oot%!0h9|c7YT-!D;yzNa^H6n5+({EJxiM@Iq zjX0mFzaOXoL(xI@`!%QEKOUB*LX>v<{ok1igwiEu?6M|Y35P?93oR8|6NOe==|u1W zr}!wniGq3~cmWAjLhuHc@^IbTlI^~SUXNwdgNo{u1#!yCRo13#l(KWkb5P33Rn(+h zlyY;WwM%VF>hjU0>$iL2CB9S<4Rif9LxwN2ZwE>3;n&*C&|cG?$O3(ZQWdm^j}0cAwh z1RQ!*KT)k1p??VCL*~hx^CYrvabJ4Q=`26#oST(OiC`pi)+K_G%vonJk{Ndza53h| z%psFdS~v7TJ!bnT*hXUb0`+owXJcn(GR^sf{!7Odn!3-fJcUTvPQgwJL<4tmXWqS6F(5Y!JDow}K_>;`2(B8&p{Wds0;Vy>ncXTK;} zS&zt-EU!l7NJGN!T;60$$9&&CcT=*djpF)bQ|o-+Cy0wmZoKs7OW9&%qxeBn>pQRB zesv`fZ`#W0J!siPaT7ax`1;KlR@p)Uoi?Q#fo2ATD}=I?9tvpQN-qUjfFS@@C?HWm zJ&XVVW2&-rJ}9k7Sr7wIO3G6`eV4@5@Aup)w`5W~Zd573j_GQGU4p_t`dG6UsR*0(^fD>60-Q=u_H5qfBQ zuJ`0|D|wC6L{@J-6bg#zjJ!%&s*HN4hQ)|7C3hLzAXY0|uJeiD@kV7ujEn{**jLf_ zKenR!2tKoZY@WuBDfPun0GRiCBHO)z+`?RKG7mFp!=bKE15 zD{EQqNR;~K&fG6*T|Tk$?L^Vux#JJ28g4~zMwd^nj3uh}e#TiW4fC%16=Kp|wOqAY z`Ek`Fv#HWK?*u@)E90)_WNCfEUH{O9dVf@jF1~*7u${ld+Yo9tta1dr_)rFJP=U@h zLCpHA2=ZWx8_Pfviqg-A=~&`_ZZhCzmXBm0E6Qgekc2K228Ka`esbsL-tzRx%`umPuyrk7WUI}t1 zD`UJDi3Soh0e-*E)f3m|vnl6k6vEP)mu5{6X$XWKb!u`ltVCo9k~#DQBu4rT!BC(q zCV8nu^L0d>hRdonNyxz$4DJ<@B1pTU{sRIqbxy9TbFH!`UfGi@F2CjdGw*`1d?{&n z-zZurqR6%2TDJ*R*0}*NM(*M@SL0n*V@zm_xf+4C?d~;O)m>ZF{hIv?o=k8j@p(WS)ZBT2FC zeaE|wHSwvq_|)o-xVUHj%#v`|-H@`N3zB6Zx4g6E_LilFWoc!{FAjWgV5K)!x(~F* zRSza~t-LK>-j+?2wIs``ZXLRLC|O*WEN^;LWOG|noXuj@xj4oI6HlEdTM!9gnB}`T z&EFFsU2tQ_+W06{kqmAr#E?NI;G-r3Z}8lLpnMZO6~HY@N#XnjAx9!Fh;@{n1)&f& z8Y7Ci;h7hPVRU)JjwFq&T%gMkI* z3SlST2#1fglDY^U>T(Wt?Ht-LhFOR3be>s4X)5S zC_hEJ0_!6Qgl%UX5isKVGgfP)vhf&!{f6f&T9C43!;@t{jM>gQzoHjHF&mz!GwR4N zLawi9-@2hOUZXB!bj1{P%{m~av=^x5Flym^S#a_#W5hgcc%rs!tq6&8?13K27PbG} zV!+g_JL-;_{h8B@ogg`J!=n`AM3TU`;V~FM%!3;v339{3+L4^M;mK)dQMREi(TEMt zbzX%6d4vO9#}3aHN!F+d6w(&u88!6as|ojPc%ns7&(H0~9zY~(f=I^x`5gT-2isMh zQA9i%P{rsfaic&SeI5=JHxF6cVq1tz@j7)RV_66M7@OxBd)*AM&~s8s%OD zk)8$GS}+wtcvpEa52aB)EiYEl61>&7-{O+9|{izLh8YuOtt@k)+!ylKQK81G^NXv ztgKo+{Lwep4m=w_@a)|k&;EdaXh!xQRXP&?tgMm0WozUw=^7NX<|OHmx_?>KoJ<%b zrM9ZsC&Ew&LN-(`pqX+J0lvnnYgv7Dnw8dBR-v8>kBmS9vt0`)6VUx@o-{@E>lGBz zv}#uQI+%1x8KS-<%5keq{SNIp^zVvHS&q!`S~2P?0eu4cd`w{|za}9!YBnhd4JI^W zw!jsY+$^70*Cb{6q^z9D#Lmnz=pSym zN>&ohM!X9?POHFNV8^&B`(bcECY0aM1}Y(%y+C6s!$_*6q9>l_G6njh%N(VTpB?2j zRK82Ceh-NNA}N$rcK7#QdHt39cFzsZf+y)dn{<~a-KCFgg2VaH&Dp&VTwa}xh?itd;e~%X;VS==;Wjg#$}{adcl*H-9o&Q#TKp z$9v=8n+Mxi| zZVlWVSUwyt@0dS!zq0z)$jy;k;hW+2uDn0;?#TP$cf+friH<{w%4gcXor^zGe|tnOa4WCxY+x!Zo{Dt$o9(H?h0 zQoHBg_Gwj1vZ|T>S2SQrtDW<1u#!z%=B@Yaby(ROd*0lG)n0RV#ob-^+&yfu8}7Oq zSSGFNJ$DCsO;*>hRd0@0Z@yc-b>#{Gyy)PfkgOAzE0^sn!pie2r(-p{7p=+SsNEnwW;P_8UO2!ZeqQ@TBoqx0mb+@Mo7Ffk-F z;Ubr#8Ysxcff8gW5k^Ws$So|_@KLiNzwjJvMW%oS6F$kbH)22}<6_#(C`-B6T_*xh zivWlu=e|SPpFY0k+}T$Q0Y66N7x z%!UmWP_SUI4~hllOP%zivuTkkGKwRK*fM0X<~eKHBM#8CGb0x6RU8jY>l-es&^>iA zegl28-VEMCS6OZNP$`UE{D1mh*0=u6>@y0_4D;7b;$N~JG<((?JF@v-kl~Ezh-2&Y zJ)+MgJsWM&IN&M>3%s#Jtf$UE2v*0b5ooZd6j2HfsbX+^l6H=5A1U%wF(az`^c?}= zWz}_+Dk%e5UjeqSZ1W8`Bp4>^DpNO*fX>L-1|sXTWEBOvVwcg{K2%ppdZkWu;a_=% zx}cyM#85qr1PJ0jCal-qwbkCQ=vuk7x;s(vG^mxgCT6es)Lxr(7vDIwaEhXH3+E_0 zvv3B;8dMPfAw)ZzpsB^>I+{h7na9wGuFoN>kWEk$;MZb-9nb0jMA=N!g@W4qjE(IW?NS+PGIdOi$ZTw6 zeg4E=qw6dfrzN6B-gkg>=td6x@G#V#ljIC+ReRf zVMZX+%w~ob#eg^h{%nGoGrDxU4-t>_QD#unLk=*d`ZD-QZ>-2eQ$VT4ie%=Tzaob) z*O~e!tO)D>94!Ya-5Adg4hJfpvd!_b%`1CW2NPw_tl6KrYk%eol?3qDD@A^ZZxn7@ zMLutBNaNCqzx98K@BX@L)5k6HFGBj8HA8yL=y}jf`dQ@F29(gcZ+Hr6c+|=#)Gfd< zC=Z`dm%d}eqtt)>x)RSc5`tu!wM^7Kp-r9vw%ps z=MiXj42j7=A}s+QL*ii0sB|nD!Aave>SxCH1gL%-M_eQjw<6F%+zKH^*WxZezcQ03 z-?z@yI_l>8pvQ&$lql;U)wJWLW39O3ZgGd9Kt6PL^C769%d2(uvhQx04;}~aOy8bf zYuXua+PMnHf<22Tlbzl1@^*4IU?n@^O*>Y<5pUW}C0()d_DATVVXdq+Ue>yN@?Kf@ zr%mneL~lpenzqNAwy&Q2Xf)Au;^xUuYg*Q7eDNCJO6R?r?VmO^zjN*OHL7>Ny7nF0 zZQDEE+ujv>qIz4hT3ol7#mdE#kcaBUwYsO`bx*DCi5=)q)D5f^58N#tcu-mU1Lwn? z_{7v!uH-!bg<6W`d%bVpu_FGj_w&bG*1taBMLG|m5s)&3R*YqP%!7c8Pz4Z{aUfqn z*{pe1$Ps5UphN~JsI0bd9IIuWwK+&RmhmFMxalXWpkp=dP;`=v&K>}=HENGKKxl{= z!IRb)b<8BUnNe|Z1E3%S?A984dd!?eAet22Ag^G-7 z>5!8PKX0OFrsd1whoJ-loS&hxZg+>rSI6?`s_?6#Ult`Q4lX$7`T5;;D^rfih5!{KM$L8)TFa+pt6*QLxX;p^5D4;-b7`<5chmttkUxMTCWg-TQI z21^~QOEFbN{8&xor4CkDJgg$cR1xupijOSF)44vHbe;y6u&x<@>&Fp%j~T!tNa>Gc z%9^IKxseRBlD>N)%yTdancr}e&KE{h5FbMKj7`oPjKG*E_Id}_?T37>bA_P|r!KzC z&0^LhaZyv&4{yPtlq@(3@k*#gAI6@DAy5Df8T8&jU=A+gGU^qwz<^F;w)6n4@neNJ z4oj97X1&^Akupc&*?W=DRK`jVG*u1@Hl0HD0AUG0OBq+KsP%Px-K_OhYZev30d%J3 zXm|=vQX~a4#|uM_+$Z{+n)}LBFeK^p5MI-Sl_YsM0Fe_O7vxECNI5ZKp&K|z$K-P z|GaVDnj{5jSG=q%QPuf)Sn+;ekI<#{rB{q>VzAV;r)^aiv+|B@QL^{O(x=vkCfx41RE+G|LAH; zElD#x2>eOF1az8(;8ijkP@|SSp+*L-6xg^X+M=dH*6%FzksY}Z3n5vIkznaM4bKvO zECcP??*W9SzwZgnW>*#8CJ4ZoFc-E3u1-os+RbBnyW)N8@Ws4_(v z=E?9RW8TxcAk7*HzbsFv$_|w39wZh$XM;kBsGdT>pVLu%4GE@d@RZ&dTo_z3zvZ7h zo^%z>^(8&!H@`6-oI8;$sUmm1x_L{|1)q<)xT|jI=slOXd~B_4N4#yv>ZN;a`+nmt zd7$fwmMr(&jZhPj&S;7Met!xse0Ah60z1IMp2fbm4lZqfXV2|D%O?_bT`^ZzOz3)C zk7Q7)^?J;2qaH~z9gi?=#@7>$WBgQFy+d$kJd|d@LR|Gm^^T#?;aTesOgdA? zI5TQzXwZmtnW-CKy2f0lFr%~iOIk=ex^rBzta4uXzMXv#rnVWG8@!eax+$|ypx`g4 zD;QxJU&33emX4-4M9Y1TDAHL0syBqc%#&dS{vEP%X>%blfVn$j6nbX4EK3lfUf45( zkf=HEL@iP#T<|kxs66@16@t7l*KPUigZwQ2c;QgKvEutKt z*FLkG!HKS!7X!MINfAK%OyR@i^tux{(e>@QF;&*xG1m{t5R$VO(Gb4mIJ!lzgH8`@tIW#+j19&x!W z;c1WA+x6pO*X#z0(cIbN1{s2;r;rvybJ8d3s7JpdLi9%yXmlL6BlJ?N7yE|;L%3ZQ zgq7Emmou$d(;fT@)iIw|my?HF0~*QpYFuX7b!>Nx6AT$4^@6Fn7Gi&UDAh z>2-R8WL(xbcl?br4_qa4=kya!QdAzzqqEtHzx5wrR=U6|@v}UmY~*8s2^(A?Xjb}k zqkiU*GE_vV$g;*?PPdfvU%RFSzN7+!8zE{^x1-{)BQzpmAxQ5 zW#&6<(uHUG*0-m?oeDt5Z>E%eGzUvcrcd7{!d)UU=i<91#n71cp??IUKG%r8({_b~ouk1;* z?udDIBx1qWM zA6t;u%upwk!$ql={4O(4vI|P5^tG0mZR~Jeqz#7cJnihxI6^2?;C?U4@E5w>vow}m@4N}OU8X4Vz&(wXob$nZoNCyuY>Di}^%$Rc9Ws(UdHbun1&`?mq zr(&wpVkg9nNRW~~QNNF2xLZ8cBOcR-Aw4`?!Q_b{Sp0{Su&Rn!y9j+EE^C2p+Bk9J zUKUmbHt$K`Y}{xkUjck6Dl=CS_{j%EDX0!ju}k6xuDv`0JU(?roSX`UGK&IpfY`cy z=e8Z|*fM5e(X9GOBzHGA)#Xwkt2*^w}=KtY2LEdyd7GE)xJbCU9)m*C5`Wi z#pmyrSKc~x^VHI4qI}c*vEP(Iw_E)H&hh(i?q9a8R3yrJ7y2NpIku)eoVRuf*u5!X zZ+cjQzSG$KaLwU5UNggnl*dIA?jh{APD<50E;^&KBg8H7S2<-zVI^T!xi@RhVjMU~ zp+|a{3W3Ji@IbLZs^1L{DFSkpgHhNP3=*;vijN#yf-sh`T4Xyh$cZufEZ95xXY@f1 z!+&DYm4w?kmA?ix$hR;@h(1NS9RkY3VxvDO56hrD%%~r6fySDvJcJd)yg_wn2{huv zPsliZbn?=63gU7C%nJWB?ur?HIeHF(3%hFuzpZC4oFz9e2B8F!EC+m);qKH)uC?^j z5nV>l#AO{#-z@`Po0%F2EbgX*c1N`Uf-+G}R8wvS!JQGQ6}6qJL=sVhi8xGLs6^-D(+MdI9Xx*?5LbQ3g`TdS}JAT%gsN6Dt;&W&-yPy|!dlzl<`@w*I?w|~+{Ewfy zN}&m*PCQMqmcEZKetaw@o=$kq#O!BC4T_R4)UBB89gF*jnY&X`dw93`&K5hRcUz8d zwmbW6NdMaGIMQVPwcB%~*8J;Q3(`JwfB$jaX9lT$-%FYecb>vS_yq(Txl-dGDId|2 zgb`rtWaVd+aO0@JV%@`(ZORR*Kxf9YC!iV4vxTcD?+}n zD$}PZP;ha|w<&mzf@f)P2XMk!=IO8N??$PF^pLuRv4>Js6bw-C0tK&8@C*fHr(=qK zref6`$C!wVgQe?_{tXo~9m^R?k%+*kI>QQ3Vew&=NZwZcj)Z-`{*xgGmH&fGDo`)u z^aCb&{xg$_7uM|@@BKRt{~heV`|r52-*R=Io1DDqa}L4pSy0XKzW>Ty_${~hx7?23 za(h^~{deZ#-&;A0_}_(R9=MufPI1mg781+S(DL@B(c9j*w{y<@pr~R|U6hxeUEaQ8 zU4A;=&>O4ljTdd5b3Sla&L6pPdf{}es(VHGMdX7>!o6e8ku0j3zra+t9QlAcCT|@ z-jwQK^D}xGcx{07!W!FzLug#F7+E^Gd~v1o7rh_!#@hGB>-WX0o?hn!H1@E@tg_j3 zl1J^vWdXh{L#um!b?BFeVm(LV?MLHcAMOyKwwv2^hX2nEXIA;!L+>{Kto8lQcRPPN zez)OFjH`W6xA%XUO`A-(e)EYx-LRcnsgxTAJyPr}hQ zXZ_sjDoZNs3YZ|EGJijAH<-Po3najUU9i?MTmL3;+F39BFf(7;47ERDGt%H zd!3?GJ-4~%p{0qpCY|LeGh#YQnQo~716!-sZIn98r{~z#`LO6H&mT-Wi&JJwJiu%% zl%Q!Ar)(@~&&=4t-ko_`{&Q|=-%^?qcC;WRDm@)x$KYE?@Vz>f3$g> zqSRIo-@SA(#UWaLc4hmjd1cSL{&jkN)MDbRmTGX7gs)0D%lXp9(Y4Ag@k-n`!Aq*A zmfyLwKgA(hISaQaerM{Soo`!qr#M8b_3IR+Dyw;M`GpjAUR({WQ{@wZc?cpiQSzRm8y!UPGuy=o>OwVbF4n;lXB&x)1K)$9YB-^@GE*+-ElIh$z%>} zy2jm}$(i~7`xb!UlkA%0%$X@UPDD@o zPDaOkW6|e)&qbg2Js*9+_X3O87;qka+ zI~orOfwPg2WIhoV;eKw4LIV-Wb}ICp>CohONV1%ngcs#{G9X+G39yyCh`_KAiiRfR za5_#+g~r3@!Xe>Qh}`AlfyvlpcsvjZCqn+oKr{qT>o-DzC}(7u3J4^X> zFN7|IW78swJ{lI7H_9tMABy|M@e8Q9$BZ%pVrUf27Q$zzS*O%ccrbJ>Fdd2eLwSYQ zvjDVsJRTEf{K5Q0)f9I5LMRkj=a1r?hr*GNI3vbG(U&M3UUt+5nVb>Gfj*zSh~M(_ zp-BuwJmimt;(=fw9)Kr`R6Ik$aGb^{KhzbLTkTf^k)l-fW0gVIxFfMZ&_6XZCB!CB zs6QTyMkIGMa50qUIYkr1Ah|Hga+Wk>o$~qT>SfWP>n0iLUft4kHh7D$E?w zkSGSuhtNxMILYhOFm|!D@gbr(&;x-KE%T zVJ{C=z-5;6K-{`F&2KAR$A=evpdQlESCe7iK? zfjr-C&3AL2uSfIUlIPolx@|?>dhxprzkT=}#BV=~?L~Rp^I{L6?VI7Z12MKB=1%-> zrMVq^KDaBt4=__~!6Ee4w&3p2Ae%Yn;4_H59jW%$U zj-m!MLdU2kXn`wu9Ca9;F?n8;Dvrt!GjBIc{Oe*K--`q|MQmFlFUA1WF92Zh@e6@C z9}Ud#XG6RK=R!dq8&^o+W0QR>=tAHU1)hruQMRG6+yZA~({Ub9T?p~<7=JDlAHRUy zLc9=)gf0ap9hzi zDNavKMZ%$=R6P|EqG9Z=>ZZmvD^W6`36vginZbFQ=zHt zTXsseuo$Bb3<}R+f(U!a7$#$cjJ;$$OU6DJQjrjfPYaXdDn@UGrv-li&D>htOaOY; z@J3Bs!Phvr;tHO|aVo|pT93hB1xepG%o=7nzZPrO2p8qYzS$DEkgwu0!A0e2^oZ(~e}!+(nnmL=4rQ7rTxj|9i{a8nmX*P4VWkLb)m&D%+EiEkuxiU|XNT&?YS+2W zwMlicT6L)|7PDJ*%@&~ykLKbg2tE{iLN7-3#R5+_gNA8NsE(gjLndBQZMokd*1ZZL zKo`MQ6y?eR**VUa<2kZwX5N)`5#aexd46i3O%;9;>Cn-<1H3@5h& z_a+2aGR8#7Oqjc5LlvUTW(}MbnZ-^~WVGD`Ok1Gw6%N9XN@GI!d>DkIp8@OI@c^i- zph6ZY<*<;_VC?cFqf2O)lbn$l$V65&%a_4y$%OVvMKZt_4pIIN5!;~%5;N#OJ0rQo z3$f`)5VU}@nMqDRq3!;&L{G8?l`A3GdB(>>q2PusLb73t1|f=oXQ>%S$e@KO+2ve- z(n}R8K}LDX#Gh1=BdC;ZSCp#qHeeBSmLIJjzbKW-!|5mD2NbSAb6YCHc6>f0NY={% zfd~nydJ^>${ZWj#U#=6|`q8F8E={m#Wl&AXGfy$=qo*!Cu!yEE?UdGil!nfea= zIMtt89iPN6-#PwKsVh_8bi3zP54k?6 zZ~9^9{OAvkXG$vO_udjS)pa)~7ANKpXKI>Jz5~U`Mc2XBx`_&Gdc2EuL*wHu+sWPh z*PBOfO}@XM>?mU44{IJ8YW==glA58rLu@xN!|pgM$z&hR8jS zxdKFvo1iEKpKv&yL(X(#XvhXO#R+pkayW(4vxcA{o{y^O#F|i1%)AWLoPWsu*qA8g zxH-e5_X%b2|0Ve&U+@s-sQx-gBl^oc zYs|G8IcW%-nmhXSL|jAH^kc*|G)moQ1)vdndCi$7>-9tQP+%3!m^00q1UqVLnKk{8 z3l{y@B#+Xp;S?yLu|yG1>?b}^xo0D^8cEppL_+}JGb3M`LB8<`E8oqce`)Y|95TQj zKx^4%DQqU&DKdO8BpdC4#D5eBOOUtf;}l>5EhX6**Ne7ak6E}t-Ud;KsS!n*eFVXU zFa=rtexw0Nt>0KlfK(Rt0V0Z@!nn#25ZZNZ*Q%@U-szvd{MO4Wt{wCHXkpG=o5{G! zZ(MrRy!HOzdqeLIy*K>s@JjQ(WYhj+)q#}jz@i~jT7LbNYp<-jI+jo0edW$8cVE5p z>WXXI!oJ6@O~|CgnJ#Hel{6+xx{+bp$)}ur+UZF-JxS;G)rPKn=5+T^s(UEiy+75x zf2HBTqU~`*=M7uNQF>!=$#x@=EN@FW+E`B4_g>q(>a1JpxIJ)d;GJ!coCBG@%|Cta zt>+etA2+q$_TTcSn|7p{cC0k*x>5X*vyQ5Mc`30Jx!0Pk>Pxx$ZWuC7*St-*h*qzI z8bp9GsBsAv2zLw<`7i~3^kFUmrWAg9&>?@_s_Ou$^`L-yNjSlZE^aC)V<1o^vZqnd!_G|u9=Lk z;w)#h7eA#x{}nR(ZPQIIkC@ho#A~J;6kaf?{WNEoH=P4)ebbf;1);5s$0(<*Q$V)~ zg7yU;`dK5Vb3uB2A2dyrB;_h2z>k?e<2hB2ZJHz z;QJHXgNOJb9_nLW!O+?1^T318d)G}fs_r)Yt!;(z_YKE61KXlr1%3`dZ2-98762%T zB>SQ9$EH6p+%y=tAGplijN!jCT{d`(UmAwTgxv`Cm?Wcjvt$m$0UC)pdJaB;+|rTJfxmDmR3Z~p`Lw^zA`u4DH{ zZ;am9u~fdadpVeD=uOspAC(WJT*v;7fuG-~tT7}S_qe~b{yOWJxw*NKgt3nY zr`=33Bn$KQ6iMbw5Ccg?VoV?g&NK=XXc-EZVMykQSa?!}cos@13g4&D@4--^-m@~) zbL2ND(ef27{&$qY85n5WCslwdzvr7T1_p8?vEpi*xBOezu|GZZ{`P-<@{#M?s=PZ>QGL_1=vg|rQqh*RaIWoZoQc+iNpDTi3}!Iq2rN&+ zOs*Pco`AFH!JboC>SG?Gysx~0Y=tW@^47gTo{1Wro}iv2;4c#WewBMnJHW!OWJyED zT|O|5Y7O#) zg=#GlUY)7+l=xpDU-7?%ff+}5|F!RB+_elZXnW{vOWN9!&Nf0QzP<46PdSVIjA6BE zbH;T5TTOM@{2}1|71inTj#PO^x_n2fe8>GuE9E1fa)#0~hD=S@y}@+vNUC=v-TPvy z_r;ao)5)6CUzjK`%c6W?ryS*czp&-}zswK*f)y)A`ciC1Rqu7}uQdJK*|=}S^7CFh z*+(qE9Yfb5jDF4nh=h{~|y;Rx_DYlT1a;t4O57X)Io6}C>YgFhw5(`};` z3hf$BBrXov1x1{zQf|?`%A}KM^Nr2Y$i{#2lxF?9gEnV~YY0jXCqhx|$9NRubL6RBVAwjamfIS7EM4>{SVs$bI;yUO<11?wNNdqp2 zmePQqKv@`Y2L_xru-vq+s=N8};>+o(u2fYQHhE{ojop9md&`*Q?GK$Vzhi#q^!=Wd z{^6DGk#zUrRQKTzhLhbdCv7jYc_O)F2^P~hV94J%HB|k~u&@O&2Fq{Lk}!x6?9Uk% zbQkv>2h+wvoUQ@L$z*C>3(z5Vi9v_mPu0dVFWn z!5Ef%7WO1d+E?AxYf9sry`Pt&QgBw5WjSkUS+)WV*$8H7CbGps9FFx=q28{STMQmU z;;jNehqm$;Cm}`XKOc*MAY)od>jfdSuP7qxJh*on+DjoGFfn`y69&Q*g=ycfWD$)8 zL(i!BsbC4Rbil)a5a(m(_<#mOv03rK7|(#A=1C;Z*;p(h%b^QUa><2a{Q2_pM7z#V z6h`W%(U3Q^&s~6TH%8NyovF&s73Zd;ZIcYB%HqPb7+09>P!7-qQ_x*};=Zj1DO8-8 zICzZHMgXti1E;M^pY9gw;IG5?U^x{RWCJI1BH&3pxaVd~dfZ6i0Q^ayRq!dBvvH!l zAOKGN6z4VUenR6p=F;kyuFgno-82~N%W(_{=Ly_Jw<}XMz-AGIb&#J43=4wh2kAyY z)lCrj=!`Nu`IU4bXcFUE!g%0o0+tpCpWdNHiwK z`Kb`qp48}A9xQ>D(YZ+Ayy)ez$Y!8ZLc+S4jZ3Us#a6=5XTib>0|^O_hvO0Sh^(DL zSOqv2s;|0QgC5X9ab?Nn)^IrP<)gvvtQ*A(fvsBy86ZF_wR%A{GlZdIc>}f^GXV(N`jxty*YM<+97M_F$-sBFqh-Thuh*lLrB#IbsBqk9yk%)y zDBedf>+B3a6`PtS?HDGL?e^p_z%fq=gHe)sJT^5WGo^nIb6R+o3_`#qGtEKCPA20s zLZ>nmS5#xAqQKM?$uoh^LV(RSS>Y{8RYG0IfE?I02jQb~YLvaGNS@h=I(^6o01ee~ zPP~Scz~`E|nuc_BSE{-zUEPEY++Cl8)<-xlncSi1SU2*J4 zJBCw^;RnH=h5sb{$Z=%VS#{&$3ZqRoZf6?qN66Tdh#|0a3^|++;1F>Ozqip^`WTx- z2f#w7Cx;;EGEO#XC_NEa8<|){rxZPAN*?$(LTd&1>Z~z=n&t^bOo?3}C4gP<0Up}k zH2;E7`UY}O1PIpGWmRX5h`=_c+r?l;8$XsX_Jgl2QwofKeE@k2$H@RjOE?^1Zh}At z1t~b3JdIcsU9v!vm7Jt$G>(J?EUs0D^M?7RZPE7kPR<)h`~lIzC+kHEvP9u2qJ`5- z$5K_BQm#$;Vg*%e07NSIveR+k5|L0mBspo_L#aI?>n4cf`Tb9*oC$wx53qL-1@SaW z^9>RgB68uUhd^npw!+A8>%~7s%*XtiDe126$j!gFww>$JrG|HmD$@+wFIu@@zs{$) zIK-mzr(YYr?O$6#W}pu3vu5zpO>qqsn5a;5%>Ak}TTe$0VoKATIbN;C*6XVYO>;_( zMVf+YJ;dI)rb{)U=}6^bLKtdL`w7T|rjs{8e3gPPmn&jEy-uwKN#TTMq9(|I2AEL* zYjYCf&AFo7m_jeC=qtyy=xt?Y==BCrAL|$h5y?#Y@{&td7>&$;keY-ZNKi8P6IBNU z@EeKCscF$btLYGSj^|KMsYqTb!h3KC4`6u8g>R9aLS+y^l&>%dL$bek@CE<=Ge=L1 zGGdQ0x+U}UbT}wk$Q+bR7eZGABFaexl@1>WL2_7_xI?nh@ds2x6n+!F9;*yz{s?yA zkIDFF6xW6b@~-Cs0s{5^JjEg$ilBuJ-JJ6x!DiZw@yU{is?ekezN!*kmFp(Db+$X* zm^f4f799+keN~rqb|h^bFqu5HB~{XrEa_$2Tvy87m3H?%boV74eMxs;zGsSgGT|;` z?SF3LI<~ApPu_P^D?QoC#3 z_EAZFroL^detFAJPT%$2@%^K3r8~E$I=3e~b|ho(u_JaX(=b(CE{zHofW{>ag`+R$`+=dGQ$_uSfZ&whW`O2eL{t@hI* zuDN^h^u060rfJNSw`SZ;tL3V^rK$CEyTw)fMKM?6TeMz^M1Y9&k99*?`R6t9s#=qL*o-q{)tRdwLJV*&wI z;Sb2TNyah^$vg&;lE=mtDwdaWf=M8r9NW;PQfz@x*;W{lavns;$tzHiKp10F>-c{z z(kjnC?4wI97e@MRT0j2{^3G#%wmL{ zN>8S;I-@u}smi`AX)mprib~7YOt#A6dGqf)P4S@YDRWhxkLz$qotYVAa$|LTF`H-& zu@u&p|BlC8Jl7h%^lD?~+xSh>Lz5JDWV;|GzdTw`HHz$GnjR}8_ zG7_P~@(H;7Imo2!ijE;^#zMvwoE`^xr_MV$f_&hOCt)XIdHF-(EBp+!UHSIV`SZg_ zcTNbLr(=bp7hAx7lqT;cACT=0GJ<4;$e^jJa;r<#V%YAmZo<}*I;TH2>5qm*#&JWn zS*%2_4)lLgH;mon;Un+Y~r41P_F1ENpk5UK4Kb|bBZz~w3} z^v5-1lCHr-%?2LDJQMv*d&S) z?;HYhC-a8bVOuP?{4=of(I!}1)4aLO$c0O;6&E_8-<_B zdHFXKUdnJ?f;m(TsX{5r&v=mWFpduwuwtA{Mcp4hryS8uwCRAUf;c}V=tMjZpr^&q z862H(?Ggu zSE^|jz){-KnsT&eY8#w$%n&#r9t^QMBlWiHkgHY5aO77-mR2OQ0H%33K^sH9( zKdKtIe=fePi1wc|G-sN7)6Ija=D}ps_N>KN zw{y*8Zm7<3=BjE)Zan=r%pbZsvrcaNDMPYq0J00n59hAUWxD%rm>(gei0kxFoYu!3 zTiEYLq!T?NBb`TJc@it=DNsuXu_JEs*dc5=#6Y7XZt^jTLYcU*ieO!}J~hRMG+d2{ zC1XRR)XB6iuFovY{1=P*ITH2D$_WPH3<@c%pX65SAs^gkM?w;tbY_`OykAh&365f> zVKzXH-PGaUC{~C;;rA zPd2FdByGX1&MwRnBJ$kAb3k8Sx%JA!repU8e>(Km zP`dY6s`uE#rsqF6`!qFEGm2rO{adj7e=yoQW0xBt(%@vHBs@lK5;kmR(^EL$@|Hz+ zZ2kt3RCH2~3;n8fm}Du-0lw@+l&-*bT?|sf5O*Wnr}ezM>gLYHog{`PZuv-xA9=rc z#eIC<_Sji7uR~1#|GA6pau<)EJ1=~a*PF7pAKvS_vrO(Rc+36SsxzzCN6Au$(g~`k zb!cVv&BKd_Z=P5@v0RyM-J5FN`+mbp<;i*bV`nY+85=zq)gd_Z*)wYIsBBDHuve>*PGicT9?B;$HV?y( zQ78GEF|Y%jntRspEsVjOaSp6vFjmdLmbDtJ$DMPG=vmqVbePezrdbR0&6P1lPFkIS zcUuDcQ0NI<;=+(sZ6LffU`(K!Ct%#i*fuy!iDQ;@*8oH=IKKz3E2O?8uY~#nVZ1q& zaj507qw|E(K7a6e9_Q(c87mWpqB=@BLAP4TE$@y2c1^+A5CooBIbNugFcpdLIK+*R zgrXcRCt%phVf|duJnjb~$u`26u38ZMR9p%$8Pb&5F5^@y!}hg&&f)4J2$ZM^N@a=4 zh=k4u#%K6$86Zr}ctCdqA#jFOp_>j)E zJ^vRbf=J}VRSsl(%T{gsOgC*$HEq8iPwzaM+IjSU-1b5IFNUynwg8WA0OsTX!+28$ zV$_=6hc&%PM{m;In`vg}>If;Xr{jXo%$CuV%{y2ZakPuGf=-BA1f(3Et|5c8}7Ap9(9G$s^FXNj*oa#_Rzi*f^ssB9YMDhTs zfMa5l92H8N%DoutlxCqE4mCI2(?N?7t47wrP}ae~_AR^e;J|5G`Jn#jJ}z-%wyYdT z;rRex08c{D>mX`a)jOx`ckI}#tw0pblBsKr)?a|uKd>Eau3Ef=?Rka$miQ%UE+A6Z z`l7lR(H~ZI+clMUR2IIG8}YzFop&aQO}?eN>OXp z1z)P0;(^L_^-%(V9f}Uf6PDQkvRa7N<)i@SrOU0Do(?*iY7!{W%V!-}*hx@awzDHx zGDNwKiNQorihzqwuH#-a24j9nVMNkz*pZvn%S>{Yqlf{Vke-oGlP9+5ATCc&Qi}y9 z{szhd6;(z|z?0WbW?Ypwoxke@$2wg(n5rCnRJmhS!DYr4$7svmo@(E|(U%S-KdRjM zNkx06qJC*`X%ook)+11{H5uV;Do44v+2VQ&`wUGoe-*QsK{OWi0Wf{78?A}f;i!~kVXf~*CayPww#w{R3EMg zyWp=Q#Ze)c(4B)0h^dDZ=+Fd528k^igYH=JWiJ~2N{#x2)Ju9F^< z5;^FwAkh}f+X|G=Zwq4U>&E}=|;T9_i=7)Sti9w>`8OIF}msJaN9 z8|KMC5u*@}AXxZ6V0hdz$?yhw93BfOn<3Ogd9oHN5RuDU}>vIR!yXUK7 zbnVU5H{bT&@*-lod2_0HbEcss-7u7D7|PT&-EO+ol&Nj`yrig$iS*lLE++B%2xBAm z>W7Z@$7J`U91z9#KDIg1ww{!&=R;fHMxac9lL2MIh1b($K}~T*Y{7C;KoO#8pSqm% zz%Q1$mIA4DfH0$8al~1jKe(dP3jBc`b+u^>_76~+@PCqV1xEgvM+(v9hpHLALQ{b7 zc^v$7R^Ny(ee;pilL2EI(z74p3^`%axN%~Pj;KM8A!%#c*gsTn);~{EGQg!)`E5m# z!cRp8pQLytd_%vFgk$ix73PK($?6FuYDk`#Rd+K~%U^fHgHFDB5-&AvjzyWfyFm}# z1p_nT-iW*Ki31EhoQ&l_tj4co7$QQTFC2>OCd{pi?#{ai0(PC`$?GW=UPGgW1~OhE zgV^G-Xogtd0_kAosS1_tV=za(D|W*q`p<~2JBic@_!>>3-$E>QeL}jV?O{pVs=NPQ zFzr2<^3suxq~j12Q`4ob4@+B@gLk8U7$yDFU5mSt?yjVx3+AfZv+8OgM%-YEA6#*5 zUv;%Eciip1(|x!9PXCH)^P0s(2P#aZWzei~Hf72XybQsGq1!`;7JJrACg+pR8*4KZ zHzEI5L91j{mM5yH9>Re=j)$?too|Lc0GR8Jn;Sr)Hx?TjKFW(2yDfThVbcLcIib2`Gpm>mY z=9J8|4^NV^0ue*GKur;yDa#YFrmzo4F9Fe^Qo}ZA2JrTySazf?Pch+r@*^&sx>Hi! z@^?ysM0JVH8<(E6HaWnA^ z$az8vnRbf8mdhLZVwDLO776IF;~)IYx^k4m1i3!hP3JCnoGuAOaCmcyxN%BvDf~O| z(_|zI_0HjoRFbS@6Tt}#Q5a{NgKnacBPtkWnA@{hRzH>khO9xkU^VUfJpt$b0AtB?egR+TYnGRI;|LFE>A!& zEKiz%iqauqO5Oz1gs11JCuB7^!Hk~BU&89;aGKansY=45v#RBLVq%Ifc?(?RyAqx*J~+*kNx+8_Lj9`tMh;3S zWpyWhm2}5)4d8R_6`XL6vgE+uh;5@GR^{N7Bn#00&G8hk? z7K2bjMgfv8wJ3VeP}>nnIH4|S#wUloLifU&uSoL`Xogckia07yt21A3deu?$Bh%7o zx^Z)=aWk}4aI+O|`1{atV6_yu*j?ux=cCfiz_;AE-(}|m^ZiRewMMpNwrqc|<=vL# z=6%4&_8YclP3H2gdHgOrSGHy2>e2S4|LJK+SZnU|jvmjOkZC zX<_KF!cR{m7BpV$#z2xzsD@JMoy5>zU3xjHYmEePVl#9yp0G0Yh>rr@4Y%5YCzS3| z!*jn{={VRrQI+#oZTfvai_7`Jvr;exh7uNyB}NX&EamAb2!QB5?x`4bw{Q;}gk3=4 zp2_!7PXo|8o}Ogex@0E4aH8@I*iP)W7cAIs95_XX0C|DHB({Z9_>t^D8_!bKGmu;z zgpZ5{zE3u`n~qYfBKc_xVJA7*vlOb#3){Bx?uC5sTtAB*J4u!NLVZ^K(o`n-oc!=f6id=Fq}Wx}+gh(y(;tVM!+xU018?($$+&)tm2EzE}5d zU3$yD)RuiK)%)j5aGt=`0I72_{|3AJ1IfnyE4Kafudh}$Ed_6fZ-sA1Z$($C`sRx> zHh0=qpR$3seS7b%z4wdX4?q>|L)#G<2XN4tE@;!?!gC?YH2E+dq49jI(u@|8du`9t z*1SxpYw0wW2|df?Ogf9 zR33&7(NuJb1WzF>30knx*d+$ zFNV%RI0vCyOx-WFY?VB*!I5lMv#qe-zkx~H2HIWt? zn_2RaExQ&+_e7}{`aS`%8Kh-o1YI<9?aI7!{>rLz(~7e@?Ho!uhaPnNtou*8f7bse z{VUER^X8A7ZiVViHaz=&$DezC4*u&2FoRZYW!FmTTSMB`ma?@i@3~*|$TpP8okNx-igua614=4cg;*>O%Q~`H;{g#%fbO-7<5&KI z#yqZgdMDD^os(A;HQ20FFbr*CKgrWZ6zJ2tgj#p!LiIX6m^`v^kxw)*DLL^Gptp}pOc*U9cNs7IePsKkVE|V#7PC;1Li6O-xQ2a7SVAOBvJhTu z8pm@<^139=j&)?J6Zeva0+aqkcuGF>GORb;nOW$r0v7V znf<6qu3y->HP#P`Hju1&i%0i3p^*$cr6d_xx`I=)UvNz@qgiDo@{b>F9EN#ff{gKXNuN#g|`Naf0wyju_E}k4s_- z3VWyNeqNhLre{#5_K|3S;Wp1=T|J4-p->hEy7>TCP~-Y%U9OuhyBKRh2d@d5>3oce z9n6{X@Dd$~{Dcm!vJTvszaqVc$!P5cz*5(`@Mk%>ebAB0o6ZkCTvu zeYqGo4PL4G>ei%GuO@kZMQZ=#Xrs7x?p;^*Z=Nm6wFGxkSb}A&epT^SttM@%E%zIA zswF|6o*e{>cdDTigcuZjv*uuNyhHVz01aFC;n0^$W%AEiXRYiKQkv=P)7yk5dezX} z?^nzzBDD%W%ynXr6ntvy)ZaN<-Y9P_hz#efO^rFqy?UGDzJ>KUXP+ycE14~Z4}|w~ zcxz^YIG+U{-k`D1+TJNwM{KS%uO|l!BEvab8m!3Q_2$Zg?%6VbZZ=sbhICTlLAcyF z|KO;Zn=L`Tj-X!7C)CSXP%qb4^sU}{x6eA&Qc;d|;u)QqIcHsJ9Ne>f%*_4Zj+q`T z!}ZfSAvac8Ze@^CXu%h(%3B2*l*r{fV<@~P_6Hv2>euST+$lWt1$f=j5@gB%uZF_My&s9mV|t3H1yC2AqR@koU;f|tprl(2 zg_+o8UwCTAAW)6mj!K(xnB)GFft`9u*r@k{L^ia@?2l=Tjf|OmK(;Y5o+INo$@m!= zJ!FuyEKh<)SKSG;q`^A50A1;bWF~R~7w^yD6&w&Namk7vqHd9_sMR5|IDAK+_m3Vt zbYkD>gQM~*Ipa8GDA3s#rYJ0#F9#wQg-&G7QXQp-Zg4&iO3w5^j;zmcS-=@Ty5HZz zYyzJ3rF$DtB2)P#pJLS94}x=QIxd+Q zr2s>Y4hx}QB1kE;NVZxPPpJeJDwVvYB4h%$WK$zb4zj7?VmYd+lIhy7Ojuc!3hTZ_ zpoIMg!fQ^$08v#;*b5UjGHy?0vV@%*tZSMt%ha@`YdonMIsol?%X9zqd#}Fx>ia{f z?I%}i#^xQXHFY;HFJ8VmyEwai^xo`B&7OJ3CncrVcP{L_KC&>f)c2^QYqe%mrlR3T zC+;<_H10??>;!LjS0{|}&d08fHLJO{Z2kyUp>}B-E+=l?v{;rYuUk6xyDiGwBujJe zL>}x}@g8~PI=bqrxM^RsFZDr%M~&6EX?b>~aqxy+iJ!qK#Y%p;ai!8rzjZ5>z3f?& z&x^V8nwuqyB}*snc|LUEUU8)qH{D9KRPpQ8y^z}W z!bjTptIX>gcONZ%M1nW}m@=&Iw>od+)K6vABrfpNYZC9#o z7Zi#zZJrF@4v|n>$H9d+(bMwx#+LOv57~@Omu!k z4-uXg)9hW5Xgh z5{wpnG8vQiEa9)yKArq#Z8^jiB^H!MP8E@xwbDa<6FSH*p7!G=G-NiH1uk?VHi8cN z3t@#aM>h5exF>j2#0+MoARMPX@E93KkS$vkiG__1&E>yHr)Z|CIsz&)kGPt2*+x!* ze(F4XNemoWTu7~{z91UYVU6ReRON(1p*}s|Ju=J#2k=6zo)9=zExD@yhMaGZ@$boC zl_se=+j>ufA}1YB$qAGQ4_wF#o1WI83*m$l6jY4;48m3Ri5JMu+Q|lj z4GDoKR$+m)nAM+}CelnV+-jA|=x()2ST7)wIDibW)mCm`6qGm6iJ~J5N3Ne-IGHJL z#+^6xANOa!y7+3wU55)pDvIZe0MQW*kEbnH-fjBBCRv~0p|f3kz{^;*9W0lsI_y&A z6{OwMk=e30x#jq+?nbD)!n};x7&-+MQwOD?L%8LE7j| z7zOCH96E&S&+whb8M6`j<&t7Qp7IM$14;5r4!{39xIT1LBLC(Q5HxCLm=2F5Y!MvGKd8&{5A}Fz>scJkI%6A3S4e_63^3PO-c5M zFzsjO?PYy!;%ms-V{GdEn4C5;{xKQ%$mk~HT{6By#-EY#7i9b;84?+68T`*=`x`RY z^7|#({v#O#oP^KG_&YKzWPCsdad3qHOvc}mL9Y-9X0jELjV|mL%E=%YCe)LSFlXT? z8MNaHr^&XPY!}H0lR@+*GxotE{!`@lCikh)Y_VbB>RU1`?U|15Os6MP*PJc?uE8=0 z?}2TZozG+r9m_NT0qMXYxJ*~yXRQ?YxDgK=UO|ntkKyv zuDEQio%ud%uC|mfxz{-SWH*~E#Y^qDi^Ec!Ew;lxzQ*AvTgw&UJ|UB(>Bfa6aWVQC zA~da;R8Qc}MRiwSNn2`Dmf96deb#8VoH5)x{Tb4p!TBJrs6qC^TBdxAmbRrmpK00iflwDfFu1_oKEbYsuvmAcze`Ae)vO7xA6}y%X+!|ivV9hprEY3__W7b5! zJzn{D-$C~K*zQ=fz<=!#9LEr*Fp}zUk@|~7V zcwT zW+`KAp~YpNyJ3^T8G~f|37pZEG7ea$eFXW5j#zsW21)Ul4z?DYvxp{o@o};Vm>?*V z!cUN|8pMO+dQ=Cl1;rJFvj)MLQ_>4sf<<`A$oh^=Wsid8N|#*N$7BY~wlkBor>%Q9 zp14_1YQ+Id#>7D&I8jiT0Fwh+CUG$_cu?nT>sO{~CUjECf<)cgflv8$jsR{;;qs$U zB}f{s)dIL@oDL3<$}L!EQFf6(SY+&WC0PlVblP(Gse1Ll;N_n~BBt~j#l7daPYQYh z@-xTCUw+7*-h@LtA%YK#kAr^))on$km+m$XkuEnAa?4ucEDs36W8>2l0?{~A+?@=x-qN|yJu@j3x`3L>VM`DwBH#m1d7j?r?U}}=+P4vnVI%2L-Lv#Hui~IulJi>4V z546)PL3$n#W0O*eBHg1ZN!IhYA0BTBNERH$oen`o_YF)a`2^TrvUR}#0z^|*vH}Hx zDq(b;EU<~`@*xX$W|?$ml=1V&XXy183|NSeQR31;W3SA0^>C)7j2@!QR2*KgX6%mZ zjn^786-Q)y{k8f`1x{f7wY6;3R*^NE%LlN+>JAxj2P2Ma{i?gAxH-GTY-ji3Ei0Pm#Zn9N2E8Xdx#N#m0Puz z&0k(BS~fqjb^_hTe}de#^QP63iW}P~;KPzmJY|gQt+3VM4$E@Z3F}1RT5JEs#?}(U zn_vvSIb&W6vEFgTjT(aXicpmo_U6tt1x-OS!HIXQIT#TK9wvW!*CquufyEOqL?V2z z;Cowflgb^=Vc5r{Qkg@pj54E}5?lNGnQy=B%d}Mc`(@n~%@6B02#GcxQ>T>|KIH{V zx)$JpPSkIpcoXKWgWjzeKf04w@RRW>8Q+GHIDHh0o9PO%m)pq){eJ2v zB4&j@rGDB%G4Qlh9D)zAf+fNB9(0McH8ggL$%X%ZV}3IL)pVZOPiK%t!A&u0Sc&Q*?Ou7-K($OD!Iwa~u~O~& zD4{Fkp(%Q+Sd{NDsL{zrWuuA$F;k@K^*N}AF=e{2o(dvCqCku@r3 zC$$vhM)&NC-W*Fupws43oo*~rYGWj})U`fbew2(_CHH|>Em+_wx6NNOw#Ew*S}B?L z>n2mqNq_P5vJ^g!w~*n~hGfDiS^=A$SfHAg9j6r9si1d+>SoP)M@*#luxvtBiFZ)FNwDWgWcNOX{kjz?X zPH}V#%;{XpcYckoIU<3o>BN8Sh+@%1vZxEC&;FElb zcgYzqYD8E>DE@O|E6l9PU@-iGbNzxV`vqtJ1y}kDuJ{*R37j8u4Igv0f5n|jbEj6g zQ~!?J{4uxtV{VB3-|{i{?8n^5|H2*nEAHgSoc9Z(#b8|HVEoDfdD_R^_K&%qkGX>% zb1(hMXoPPOGdROO!(VYHKIZm(%;J-NHyFR*V1ToLSe2Xs2@m}hC4}X`$6V`U zd;NS(+FqZs*Dvi_v3Fc8`l2Y{Fl_piBQtxXuFl|2b`61YH@F{wL4lv_t|CMEQZ+Q9 z4CTx5WZy`tYcF$r;ATIJAAqoIMY&;HrqrD^;rDTISrU(47K8T#7x1T|;?J$HvAyU2 E0dhA8&Hw-a diff --git a/venv/lib/python3.12/site-packages/pip/_internal/req/__pycache__/req_set.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/req/__pycache__/req_set.cpython-312.pyc deleted file mode 100644 index a09e4837e555c111f7757dbb6f71c500edbc9e77..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 7228 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 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: Optional[str]) -> Set[str]: - if not extras: - return set() - return get_requirement("placeholder" + extras.lower()).extras - - -def _set_requirement_extras(req: Requirement, new_extras: Set[str]) -> Requirement: - """ - Returns a new requirement based on the given one, with the supplied extras. If the - given requirement already has extras those are replaced (or dropped if no new extras - are given). - """ - match: Optional[re.Match[str]] = re.fullmatch( - # see https://peps.python.org/pep-0508/#complete-grammar - r"([\w\t .-]+)(\[[^\]]*\])?(.*)", - str(req), - flags=re.ASCII, - ) - # ireq.req is a valid requirement so the regex should always match - assert ( - match is not None - ), f"regex match on requirement {req} failed, this should never happen" - pre: Optional[str] = match.group(1) - post: Optional[str] = match.group(3) - assert ( - pre is not None and post is not None - ), f"regex group selection for requirement {req} failed, this should never happen" - extras: str = "[%s]" % ",".join(sorted(new_extras)) if new_extras else "" - return Requirement(f"{pre}{extras}{post}") - - -def parse_editable(editable_req: str) -> Tuple[Optional[str], str, 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): - # 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, - get_requirement("placeholder" + extras.lower()).extras, - ) - else: - return package_name, url_no_extras, set() - - for version_control in vcs: - if url.lower().startswith(f"{version_control}:"): - url = f"{version_control}+{url}" - break - - link = Link(url) - - if not link.is_vcs: - backends = ", ".join(vcs.all_schemes) - raise InstallationError( - f"{editable_req} is not a valid editable requirement. " - f"It should either be a path to a local project or a VCS URL " - f"(beginning with {backends})." - ) - - package_name = link.egg_fragment - if not package_name: - raise InstallationError( - "Could not detect requirement name for '{}', please specify one " - "with #egg=your_package_name".format(editable_req) - ) - return package_name, url, set() - - -def check_first_requirement_in_file(filename: str) -> None: - """Check if file is parsable as a requirements file. - - This is heavily based on ``pkg_resources.parse_requirements``, but - simplified to just check the first meaningful line. - - :raises InvalidRequirement: If the first meaningful line cannot be parsed - as an requirement. - """ - with open(filename, encoding="utf-8", errors="ignore") as f: - # Create a steppable iterator, so we can handle \-continuations. - lines = ( - line - for line in (line.strip() for line in f) - if line and not line.startswith("#") # Skip blank lines/comments. - ) - - for line in lines: - # Drop comments -- a hash without a space may be in a URL. - if " #" in line: - line = line[: line.find(" #")] - # If there is a line continuation, drop it, and append the next line. - if line.endswith("\\"): - line = line[:-2].strip() + next(lines, "") - Requirement(line) - return - - -def deduce_helpful_msg(req: str) -> str: - """Returns helpful msg in case requirements file does not exist, - or cannot be parsed. - - :params req: Requirements file path - """ - if not os.path.exists(req): - return f" File '{req}' does not exist." - msg = " The path does exist. " - # Try to parse and check if it is a requirements file. - try: - check_first_requirement_in_file(req) - except InvalidRequirement: - logger.debug("Cannot parse '%s' as requirements file", req) - else: - msg += ( - f"The argument you provided " - f"({req}) appears to be a" - f" requirements file. If that is the" - f" case, use the '-r' flag to install" - f" the packages specified within it." - ) - return msg - - -class RequirementParts: - def __init__( - self, - requirement: Optional[Requirement], - link: Optional[Link], - markers: Optional[Marker], - extras: Set[str], - ): - self.requirement = requirement - self.link = link - self.markers = markers - self.extras = extras - - -def parse_req_from_editable(editable_req: str) -> RequirementParts: - name, url, extras_override = parse_editable(editable_req) - - if name is not None: - try: - req: Optional[Requirement] = Requirement(name) - except InvalidRequirement: - raise InstallationError(f"Invalid requirement: '{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: str, - comes_from: Optional[Union[InstallRequirement, str]] = None, - *, - use_pep517: Optional[bool] = None, - isolated: bool = False, - global_options: Optional[List[str]] = None, - hash_options: Optional[Dict[str, List[str]]] = None, - constraint: bool = False, - user_supplied: bool = False, - permit_editable_wheels: bool = False, - config_settings: Optional[Dict[str, Union[str, List[str]]]] = None, -) -> InstallRequirement: - parts = parse_req_from_editable(editable_req) - - return InstallRequirement( - parts.requirement, - comes_from=comes_from, - user_supplied=user_supplied, - editable=True, - permit_editable_wheels=permit_editable_wheels, - link=parts.link, - constraint=constraint, - use_pep517=use_pep517, - isolated=isolated, - global_options=global_options, - hash_options=hash_options, - config_settings=config_settings, - extras=parts.extras, - ) - - -def _looks_like_path(name: str) -> bool: - """Checks whether the string "looks like" a path on the filesystem. - - This does not check whether the target actually exists, only judge from the - 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: str, name: str) -> Optional[str]: - """ - First, it checks whether a provided path is an installable directory. If it - is, returns the path. - - If false, check if the path is an archive file (such as a .whl). - The function checks if the path is a file. If false, if the path has - 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) - # TODO: The is_installable_dir test here might not be necessary - # now that it is done in load_pyproject_toml too. - raise InstallationError( - f"Directory {name!r} is not installable. Neither 'setup.py' " - "nor 'pyproject.toml' found." - ) - 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: str, line_source: 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 = f"{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: str) -> str: - if not line_source: - return text - return f"{text} (from {line_source})" - - def _parse_req_string(req_as_string: str) -> Requirement: - try: - req = get_requirement(req_as_string) - except InvalidRequirement: - if os.path.sep in req_as_string: - add_msg = "It looks like a path." - add_msg += deduce_helpful_msg(req_as_string) - elif "=" in req_as_string and not any( - op in req_as_string for op in operators - ): - add_msg = "= is not a valid operator. Did you mean == ?" - else: - add_msg = "" - msg = with_source(f"Invalid requirement: {req_as_string!r}") - if add_msg: - msg += f"\nHint: {add_msg}" - raise InstallationError(msg) - else: - # Deprecate extras after specifiers: "name>=1.0[extras]" - # This currently works by accident because _strip_extras() parses - # any extras in the end of the string and those are saved in - # RequirementParts - for spec in req.specifier: - spec_str = str(spec) - if spec_str.endswith("]"): - msg = f"Extras after version '{spec_str}'." - raise InstallationError(msg) - return req - - if req_as_string is not None: - req: Optional[Requirement] = _parse_req_string(req_as_string) - else: - req = None - - return RequirementParts(req, link, markers, extras) - - -def install_req_from_line( - name: str, - comes_from: Optional[Union[str, InstallRequirement]] = None, - *, - use_pep517: Optional[bool] = None, - isolated: bool = False, - global_options: Optional[List[str]] = None, - hash_options: Optional[Dict[str, List[str]]] = None, - constraint: bool = False, - line_source: Optional[str] = None, - user_supplied: bool = False, - config_settings: Optional[Dict[str, Union[str, List[str]]]] = None, -) -> InstallRequirement: - """Creates an InstallRequirement from a name, which might be a - requirement, directory containing 'setup.py', filename, or URL. - - :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, - global_options=global_options, - hash_options=hash_options, - config_settings=config_settings, - constraint=constraint, - extras=parts.extras, - user_supplied=user_supplied, - ) - - -def install_req_from_req_string( - req_string: str, - comes_from: Optional[InstallRequirement] = None, - isolated: bool = False, - use_pep517: Optional[bool] = None, - user_supplied: bool = False, -) -> InstallRequirement: - try: - req = get_requirement(req_string) - except InvalidRequirement: - raise InstallationError(f"Invalid requirement: '{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" - f"{comes_from.name} depends on {req} " - ) - - return InstallRequirement( - req, - comes_from, - isolated=isolated, - use_pep517=use_pep517, - user_supplied=user_supplied, - ) - - -def install_req_from_parsed_requirement( - parsed_req: ParsedRequirement, - isolated: bool = False, - use_pep517: Optional[bool] = None, - user_supplied: bool = False, - config_settings: Optional[Dict[str, Union[str, List[str]]]] = None, -) -> InstallRequirement: - if parsed_req.is_editable: - req = install_req_from_editable( - parsed_req.requirement, - comes_from=parsed_req.comes_from, - use_pep517=use_pep517, - constraint=parsed_req.constraint, - isolated=isolated, - user_supplied=user_supplied, - config_settings=config_settings, - ) - - else: - req = install_req_from_line( - parsed_req.requirement, - comes_from=parsed_req.comes_from, - use_pep517=use_pep517, - isolated=isolated, - global_options=( - parsed_req.options.get("global_options", []) - if parsed_req.options - else [] - ), - hash_options=( - parsed_req.options.get("hashes", {}) if parsed_req.options else {} - ), - constraint=parsed_req.constraint, - line_source=parsed_req.line_source, - user_supplied=user_supplied, - config_settings=config_settings, - ) - return req - - -def install_req_from_link_and_ireq( - link: Link, ireq: InstallRequirement -) -> InstallRequirement: - return InstallRequirement( - req=ireq.req, - comes_from=ireq.comes_from, - editable=ireq.editable, - link=link, - markers=ireq.markers, - use_pep517=ireq.use_pep517, - isolated=ireq.isolated, - global_options=ireq.global_options, - hash_options=ireq.hash_options, - config_settings=ireq.config_settings, - user_supplied=ireq.user_supplied, - ) - - -def install_req_drop_extras(ireq: InstallRequirement) -> InstallRequirement: - """ - Creates a new InstallationRequirement using the given template but without - any extras. Sets the original requirement as the new one's parent - (comes_from). - """ - return InstallRequirement( - req=( - _set_requirement_extras(ireq.req, set()) if ireq.req is not None else None - ), - comes_from=ireq, - editable=ireq.editable, - link=ireq.link, - markers=ireq.markers, - use_pep517=ireq.use_pep517, - isolated=ireq.isolated, - global_options=ireq.global_options, - hash_options=ireq.hash_options, - constraint=ireq.constraint, - extras=[], - config_settings=ireq.config_settings, - user_supplied=ireq.user_supplied, - permit_editable_wheels=ireq.permit_editable_wheels, - ) - - -def install_req_extend_extras( - ireq: InstallRequirement, - extras: Collection[str], -) -> InstallRequirement: - """ - Returns a copy of an installation requirement with some additional extras. - Makes a shallow copy of the ireq object. - """ - result = copy.copy(ireq) - result.extras = {*ireq.extras, *extras} - result.req = ( - _set_requirement_extras(ireq.req, result.extras) - if ireq.req is not None - else None - ) - return result diff --git a/venv/lib/python3.12/site-packages/pip/_internal/req/req_file.py b/venv/lib/python3.12/site-packages/pip/_internal/req/req_file.py deleted file mode 100644 index 1ef3d5e..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/req/req_file.py +++ /dev/null @@ -1,554 +0,0 @@ -""" -Requirements file parsing -""" - -import logging -import optparse -import os -import re -import shlex -import urllib.parse -from optparse import Values -from typing import ( - TYPE_CHECKING, - Any, - Callable, - Dict, - Generator, - Iterable, - List, - Optional, - Tuple, -) - -from pip._internal.cli import cmdoptions -from pip._internal.exceptions import InstallationError, RequirementsFileParseError -from pip._internal.models.search_scope import SearchScope -from pip._internal.network.session import PipSession -from pip._internal.network.utils import raise_for_status -from pip._internal.utils.encoding import auto_decode -from pip._internal.utils.urls import get_url_scheme - -if TYPE_CHECKING: - # NoReturn introduced in 3.6.2; imported only for type checking to maintain - # pip compatibility with older patch versions of Python 3.6 - from typing import NoReturn - - from pip._internal.index.package_finder import PackageFinder - -__all__ = ["parse_requirements"] - -ReqFileLines = Iterable[Tuple[int, str]] - -LineParser = Callable[[str], Tuple[str, Values]] - -SCHEME_RE = re.compile(r"^(http|https|file):", re.I) -COMMENT_RE = re.compile(r"(^|\s+)#.*$") - -# 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: List[Callable[..., optparse.Option]] = [ - 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.prefer_binary, - cmdoptions.require_hashes, - cmdoptions.pre, - cmdoptions.trusted_host, - cmdoptions.use_new_feature, -] - -# options to be passed to requirements -SUPPORTED_OPTIONS_REQ: List[Callable[..., optparse.Option]] = [ - cmdoptions.global_options, - cmdoptions.hash, - cmdoptions.config_settings, -] - -SUPPORTED_OPTIONS_EDITABLE_REQ: List[Callable[..., optparse.Option]] = [ - cmdoptions.config_settings, -] - - -# the 'dest' string values -SUPPORTED_OPTIONS_REQ_DEST = [str(o().dest) for o in SUPPORTED_OPTIONS_REQ] -SUPPORTED_OPTIONS_EDITABLE_REQ_DEST = [ - str(o().dest) for o in SUPPORTED_OPTIONS_EDITABLE_REQ -] - -logger = logging.getLogger(__name__) - - -class ParsedRequirement: - def __init__( - self, - requirement: str, - is_editable: bool, - comes_from: str, - constraint: bool, - options: Optional[Dict[str, Any]] = None, - line_source: Optional[str] = None, - ) -> None: - self.requirement = requirement - self.is_editable = is_editable - self.comes_from = comes_from - self.options = options - self.constraint = constraint - self.line_source = line_source - - -class ParsedLine: - def __init__( - self, - filename: str, - lineno: int, - args: str, - opts: Values, - constraint: bool, - ) -> None: - self.filename = filename - self.lineno = lineno - self.opts = opts - self.constraint = constraint - - if args: - self.is_requirement = True - self.is_editable = False - self.requirement = args - elif opts.editables: - self.is_requirement = True - self.is_editable = True - # We don't support multiple -e on one line - self.requirement = opts.editables[0] - else: - self.is_requirement = False - - -def parse_requirements( - filename: str, - session: PipSession, - finder: Optional["PackageFinder"] = None, - options: Optional[optparse.Values] = None, - constraint: bool = False, -) -> Generator[ParsedRequirement, None, None]: - """Parse a requirements file and yield ParsedRequirement instances. - - :param filename: Path or url of requirements file. - :param session: PipSession instance. - :param finder: Instance of pip.index.PackageFinder. - :param options: cli options. - :param constraint: If true, parsing a constraint file rather than - requirements file. - """ - line_parser = get_line_parser(finder) - parser = RequirementsFileParser(session, line_parser) - - for parsed_line in parser.parse(filename, constraint): - parsed_req = handle_line( - parsed_line, options=options, finder=finder, session=session - ) - if parsed_req is not None: - yield parsed_req - - -def preprocess(content: str) -> ReqFileLines: - """Split, filter, and join lines, and return a line iterator - - :param content: the content of the requirements file - """ - lines_enum: ReqFileLines = enumerate(content.splitlines(), start=1) - lines_enum = join_lines(lines_enum) - lines_enum = ignore_comments(lines_enum) - lines_enum = expand_env_variables(lines_enum) - return lines_enum - - -def handle_requirement_line( - line: ParsedLine, - options: Optional[optparse.Values] = None, -) -> ParsedRequirement: - # preserve for the nested code path - line_comes_from = "{} {} (line {})".format( - "-c" if line.constraint else "-r", - line.filename, - line.lineno, - ) - - assert line.is_requirement - - # get the options that apply to requirements - if line.is_editable: - supported_dest = SUPPORTED_OPTIONS_EDITABLE_REQ_DEST - else: - supported_dest = SUPPORTED_OPTIONS_REQ_DEST - req_options = {} - for dest in supported_dest: - if dest in line.opts.__dict__ and line.opts.__dict__[dest]: - req_options[dest] = line.opts.__dict__[dest] - - line_source = f"line {line.lineno} of {line.filename}" - return ParsedRequirement( - requirement=line.requirement, - is_editable=line.is_editable, - comes_from=line_comes_from, - constraint=line.constraint, - options=req_options, - line_source=line_source, - ) - - -def handle_option_line( - opts: Values, - filename: str, - lineno: int, - finder: Optional["PackageFinder"] = None, - options: Optional[optparse.Values] = None, - session: Optional[PipSession] = None, -) -> None: - if opts.hashes: - logger.warning( - "%s line %s has --hash but no requirement, and will be ignored.", - filename, - lineno, - ) - - if options: - # percolate options upward - if opts.require_hashes: - options.require_hashes = opts.require_hashes - if opts.features_enabled: - options.features_enabled.extend( - f for f in opts.features_enabled if f not in options.features_enabled - ) - - # set finder options - if finder: - find_links = finder.find_links - index_urls = finder.index_urls - no_index = finder.search_scope.no_index - if opts.no_index is True: - no_index = True - index_urls = [] - if opts.index_url and not no_index: - index_urls = [opts.index_url] - if opts.extra_index_urls and not no_index: - index_urls.extend(opts.extra_index_urls) - if opts.find_links: - # FIXME: it would be nice to keep track of the source - # of the find_links: support a find-links local path - # relative to a requirements file. - value = opts.find_links[0] - req_dir = os.path.dirname(os.path.abspath(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) - - if session: - # We need to update the auth urls in session - session.update_index_urls(index_urls) - - search_scope = SearchScope( - find_links=find_links, - index_urls=index_urls, - no_index=no_index, - ) - finder.search_scope = search_scope - - if opts.pre: - finder.set_allow_all_prereleases() - - if opts.prefer_binary: - finder.set_prefer_binary() - - if session: - for host in opts.trusted_hosts or []: - source = f"line {lineno} of {filename}" - session.add_trusted_host(host, source=source) - - -def handle_line( - line: ParsedLine, - options: Optional[optparse.Values] = None, - finder: Optional["PackageFinder"] = None, - session: Optional[PipSession] = None, -) -> Optional[ParsedRequirement]: - """Handle a single parsed requirements line; This can result in - creating/yielding requirements, or updating the finder. - - :param line: The parsed line to be processed. - :param options: CLI options. - :param finder: The finder - updated by non-requirement lines. - :param session: The session - updated by non-requirement lines. - - Returns a ParsedRequirement object if the line is a requirement line, - otherwise returns None. - - 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. - """ - - if line.is_requirement: - parsed_req = handle_requirement_line(line, options) - return parsed_req - else: - handle_option_line( - line.opts, - line.filename, - line.lineno, - finder, - options, - session, - ) - return None - - -class RequirementsFileParser: - def __init__( - self, - session: PipSession, - line_parser: LineParser, - ) -> None: - self._session = session - self._line_parser = line_parser - - def parse( - self, filename: str, constraint: bool - ) -> Generator[ParsedLine, None, None]: - """Parse a given file, yielding parsed lines.""" - yield from self._parse_and_recurse(filename, constraint) - - def _parse_and_recurse( - self, filename: str, constraint: bool - ) -> Generator[ParsedLine, None, None]: - for line in self._parse_file(filename, constraint): - if not line.is_requirement and ( - line.opts.requirements or line.opts.constraints - ): - # 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, - ) - - yield from self._parse_and_recurse(req_path, nested_constraint) - else: - yield line - - def _parse_file( - self, filename: str, constraint: bool - ) -> Generator[ParsedLine, None, None]: - _, content = get_file_content(filename, self._session) - - lines_enum = preprocess(content) - - for line_number, line in lines_enum: - try: - args_str, opts = self._line_parser(line) - except OptionParsingError as e: - # add offending line - msg = f"Invalid requirement: {line}\n{e.msg}" - raise RequirementsFileParseError(msg) - - yield ParsedLine( - filename, - line_number, - args_str, - opts, - constraint, - ) - - -def get_line_parser(finder: Optional["PackageFinder"]) -> LineParser: - def parse_line(line: str) -> Tuple[str, Values]: - # Build new parser for each line since it accumulates appendable - # options. - parser = build_parser() - 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) - - try: - options = shlex.split(options_str) - except ValueError as e: - raise OptionParsingError(f"Could not split options: {options_str}") from e - - opts, _ = parser.parse_args(options, defaults) - - return args_str, opts - - return parse_line - - -def break_args_options(line: str) -> Tuple[str, str]: - """Break up the line into an args and options string. We only want to shlex - (and then optparse) the options, not the args. args can contain markers - which are corrupted by shlex. - """ - tokens = line.split(" ") - 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) - - -class OptionParsingError(Exception): - def __init__(self, msg: str) -> None: - self.msg = msg - - -def build_parser() -> 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: Any, msg: str) -> "NoReturn": - raise OptionParsingError(msg) - - # NOTE: mypy disallows assigning to a method - # https://github.com/python/mypy/issues/2427 - parser.exit = parser_exit # type: ignore - - return parser - - -def join_lines(lines_enum: ReqFileLines) -> ReqFileLines: - """Joins a line ending in '\' with the previous line (except when following - comments). The joined line takes on the index of the first line. - """ - primary_line_number = None - new_line: List[str] = [] - 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) - assert primary_line_number is not None - 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: - assert primary_line_number is not None - yield primary_line_number, "".join(new_line) - - # TODO: handle space after '\'. - - -def ignore_comments(lines_enum: ReqFileLines) -> ReqFileLines: - """ - Strips comments and filter empty lines. - """ - for line_number, line in lines_enum: - line = COMMENT_RE.sub("", line) - line = line.strip() - if line: - yield line_number, line - - -def expand_env_variables(lines_enum: ReqFileLines) -> ReqFileLines: - """Replace all environment variables that can be retrieved via `os.getenv`. - - The only allowed format for environment variables defined in the - 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: str, session: PipSession) -> Tuple[str, str]: - """Gets the content of a file; it may be a filename, file: URL, or - http: URL. Returns (location, content). Content is unicode. - Respects # -*- coding: declarations on the retrieved files. - - :param url: File path or url. - :param session: PipSession instance. - """ - scheme = get_url_scheme(url) - - # Pip has special support for file:// URLs (LocalFSAdapter). - if scheme in ["http", "https", "file"]: - resp = session.get(url) - raise_for_status(resp) - return resp.url, resp.text - - # Assume this is a bare path. - try: - with open(url, "rb") as f: - content = auto_decode(f.read()) - except OSError as exc: - raise InstallationError(f"Could not open requirements file: {exc}") - return url, content diff --git a/venv/lib/python3.12/site-packages/pip/_internal/req/req_install.py b/venv/lib/python3.12/site-packages/pip/_internal/req/req_install.py deleted file mode 100644 index a65611c..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/req/req_install.py +++ /dev/null @@ -1,923 +0,0 @@ -import functools -import logging -import os -import shutil -import sys -import uuid -import zipfile -from optparse import Values -from pathlib import Path -from typing import Any, Collection, Dict, Iterable, List, Optional, Sequence, Union - -from pip._vendor.packaging.markers import Marker -from pip._vendor.packaging.requirements import Requirement -from pip._vendor.packaging.specifiers import SpecifierSet -from pip._vendor.packaging.utils import canonicalize_name -from pip._vendor.packaging.version import Version -from pip._vendor.packaging.version import parse as parse_version -from pip._vendor.pyproject_hooks import BuildBackendHookCaller - -from pip._internal.build_env import BuildEnvironment, NoOpBuildEnvironment -from pip._internal.exceptions import InstallationError, PreviousBuildDirError -from pip._internal.locations import get_scheme -from pip._internal.metadata import ( - BaseDistribution, - get_default_environment, - get_directory_distribution, - get_wheel_distribution, -) -from pip._internal.metadata.base import FilesystemWheel -from pip._internal.models.direct_url import DirectUrl -from pip._internal.models.link import Link -from pip._internal.operations.build.metadata import generate_metadata -from pip._internal.operations.build.metadata_editable import generate_editable_metadata -from pip._internal.operations.build.metadata_legacy import ( - generate_metadata as generate_metadata_legacy, -) -from pip._internal.operations.install.editable_legacy import ( - install_editable as install_editable_legacy, -) -from pip._internal.operations.install.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.misc import ( - ConfiguredBuildBackendHookCaller, - ask_path_exists, - backup_dir, - display_path, - hide_url, - is_installable_dir, - redact_auth_from_requirement, - redact_auth_from_url, -) -from pip._internal.utils.packaging import safe_extra -from pip._internal.utils.subprocess import runner_with_spinner_message -from pip._internal.utils.temp_dir import TempDirectory, tempdir_kinds -from pip._internal.utils.unpacking import unpack_file -from pip._internal.utils.virtualenv import running_under_virtualenv -from pip._internal.vcs import vcs - -logger = logging.getLogger(__name__) - - -class InstallRequirement: - """ - 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: Optional[Requirement], - comes_from: Optional[Union[str, "InstallRequirement"]], - editable: bool = False, - link: Optional[Link] = None, - markers: Optional[Marker] = None, - use_pep517: Optional[bool] = None, - isolated: bool = False, - *, - global_options: Optional[List[str]] = None, - hash_options: Optional[Dict[str, List[str]]] = None, - config_settings: Optional[Dict[str, Union[str, List[str]]]] = None, - constraint: bool = False, - extras: Collection[str] = (), - user_supplied: bool = False, - permit_editable_wheels: bool = False, - ) -> None: - assert req is None or isinstance(req, Requirement), req - self.req = req - self.comes_from = comes_from - self.constraint = constraint - self.editable = editable - self.permit_editable_wheels = permit_editable_wheels - - # source_dir is the local directory where the linked requirement is - # located, or unpacked. In case unpacking is needed, creating and - # populating source_dir is done by the RequirementPreparer. Note this - # is not necessarily the directory where pyproject.toml or setup.py is - # located - that one is obtained via unpacked_source_directory. - self.source_dir: Optional[str] = None - if self.editable: - assert link - if link.is_file: - self.source_dir = os.path.normpath(os.path.abspath(link.file_path)) - - # original_link is the direct URL that was provided by the user for the - # requirement, either directly or via a constraints file. - if link is None and req and req.url: - # PEP 508 URL requirement - link = Link(req.url) - self.link = self.original_link = link - - # When this InstallRequirement is a wheel obtained from the cache of locally - # built wheels, this is the source link corresponding to the cache entry, which - # was used to download and build the cached wheel. - self.cached_wheel_source_link: Optional[Link] = None - - # Information about the location of the artifact that was downloaded . This - # property is guaranteed to be set in resolver results. - self.download_info: Optional[DirectUrl] = None - - # Path to any downloaded or already-existing package. - self.local_file_path: Optional[str] = None - if self.link and self.link.is_file: - self.local_file_path = self.link.file_path - - if extras: - self.extras = extras - elif req: - self.extras = req.extras - else: - self.extras = set() - if markers is None and req: - markers = req.marker - self.markers = markers - - # This holds the Distribution object if this requirement is already installed. - self.satisfied_by: Optional[BaseDistribution] = None - # Whether the installation process should try to uninstall an existing - # distribution before installing this requirement. - self.should_reinstall = False - # Temporary build location - self._temp_build_dir: Optional[TempDirectory] = None - # Set to True after successful installation - self.install_succeeded: Optional[bool] = None - # Supplied options - self.global_options = global_options if global_options else [] - self.hash_options = hash_options if hash_options else {} - self.config_settings = config_settings - # Set to True after successful preparation of this requirement - self.prepared = False - # User supplied requirement are explicitly requested for installation - # by the user via CLI arguments or requirements files, as opposed to, - # e.g. dependencies, extras or constraints. - self.user_supplied = user_supplied - - self.isolated = isolated - self.build_env: BuildEnvironment = NoOpBuildEnvironment() - - # For PEP 517, the directory where we request the project metadata - # gets stored. We need this to pass to build_wheel, so the backend - # can ensure that the wheel matches the metadata (see the PEP for - # details). - self.metadata_directory: Optional[str] = None - - # The static build requirements (from pyproject.toml) - self.pyproject_requires: Optional[List[str]] = None - - # Build requirements that we will check are available - self.requirements_to_check: List[str] = [] - - # The PEP 517 backend we should use to build the project - self.pep517_backend: Optional[BuildBackendHookCaller] = None - - # Are we using PEP 517 for this requirement? - # After pyproject.toml has been loaded, the only valid values are True - # 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 - - # If config settings are provided, enforce PEP 517. - if self.config_settings: - if self.use_pep517 is False: - logger.warning( - "--no-use-pep517 ignored for %s " - "because --config-settings are specified.", - self, - ) - self.use_pep517 = True - - # This requirement needs more preparation before it can be built - self.needs_more_preparation = False - - # This requirement needs to be unpacked before it can be installed. - self._archive_source: Optional[Path] = None - - def __str__(self) -> str: - if self.req: - s = redact_auth_from_requirement(self.req) - if self.link: - s += f" from {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: - if self.satisfied_by.location is not None: - location = display_path(self.satisfied_by.location) - else: - location = "" - s += f" in {location}" - if self.comes_from: - if isinstance(self.comes_from, str): - comes_from: Optional[str] = self.comes_from - else: - comes_from = self.comes_from.from_path() - if comes_from: - s += f" (from {comes_from})" - return s - - def __repr__(self) -> str: - return "<{} object: {} editable={!r}>".format( - self.__class__.__name__, str(self), self.editable - ) - - def format_debug(self) -> str: - """An un-tested helper for getting state, for debugging.""" - attributes = vars(self) - names = sorted(attributes) - - state = (f"{attr}={attributes[attr]!r}" for attr in sorted(names)) - return "<{name} object: {{{state}}}>".format( - name=self.__class__.__name__, - state=", ".join(state), - ) - - # Things that are valid for all kinds of requirements? - @property - def name(self) -> Optional[str]: - if self.req is None: - return None - return self.req.name - - @functools.lru_cache() # use cached_property in python 3.8+ - def supports_pyproject_editable(self) -> bool: - if not self.use_pep517: - return False - assert self.pep517_backend - with self.build_env: - runner = runner_with_spinner_message( - "Checking if build backend supports build_editable" - ) - with self.pep517_backend.subprocess_runner(runner): - return "build_editable" in self.pep517_backend._supported_features() - - @property - def specifier(self) -> SpecifierSet: - assert self.req is not None - return self.req.specifier - - @property - def is_direct(self) -> bool: - """Whether this requirement was specified as a direct URL.""" - return self.original_link is not None - - @property - def is_pinned(self) -> bool: - """Return whether I am pinned to an exact version. - - For example, some-package==1.2 is pinned; some-package>1.2 is not. - """ - assert self.req is not None - specifiers = self.req.specifier - return len(specifiers) == 1 and next(iter(specifiers)).operator in {"==", "==="} - - def match_markers(self, extras_requested: Optional[Iterable[str]] = None) -> bool: - if not extras_requested: - # Provide an extra to safely evaluate the markers - # without matching any extra - extras_requested = ("",) - if self.markers is not None: - return any( - self.markers.evaluate({"extra": extra}) - # TODO: Remove these two variants when packaging is upgraded to - # support the marker comparison logic specified in PEP 685. - or self.markers.evaluate({"extra": safe_extra(extra)}) - or self.markers.evaluate({"extra": canonicalize_name(extra)}) - for extra in extras_requested - ) - else: - return True - - @property - def has_hash_options(self) -> bool: - """Return whether any known-good hashes are specified as options. - - These activate --require-hashes mode; hashes specified as part of a - URL do not. - - """ - return bool(self.hash_options) - - def hashes(self, trust_internet: bool = True) -> 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.hash_options.copy() - if trust_internet: - link = self.link - elif self.is_direct and self.user_supplied: - link = self.original_link - else: - link = None - if link and link.hash: - assert link.hash_name is not None - good_hashes.setdefault(link.hash_name, []).append(link.hash) - return Hashes(good_hashes) - - def from_path(self) -> Optional[str]: - """Format a nice indicator to show where this "comes from" """ - if self.req is None: - return None - s = str(self.req) - if self.comes_from: - comes_from: Optional[str] - if isinstance(self.comes_from, str): - 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: str, autodelete: bool, parallel_builds: bool - ) -> str: - assert build_dir is not None - if self._temp_build_dir is not None: - assert self._temp_build_dir.path - 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=tempdir_kinds.REQ_BUILD, globally_managed=True - ) - - return self._temp_build_dir.path - - # This is the only remaining place where we manually determine the path - # for the temporary directory. It is only needed for editables where - # it is the value of the --src option. - - # When parallel builds are enabled, add a UUID to the build directory - # name so multiple builds do not interfere with each other. - dir_name: str = canonicalize_name(self.req.name) - if parallel_builds: - dir_name = f"{dir_name}_{uuid.uuid4().hex}" - - # FIXME: Is there a better place to create the build_dir? (hg and bzr - # need this) - if not os.path.exists(build_dir): - logger.debug("Creating directory %s", build_dir) - os.makedirs(build_dir) - actual_build_dir = os.path.join(build_dir, dir_name) - # `None` indicates that we respect the globally-configured deletion - # settings, which is what we actually want when auto-deleting. - delete_arg = None if autodelete else False - return TempDirectory( - path=actual_build_dir, - delete=delete_arg, - kind=tempdir_kinds.REQ_BUILD, - globally_managed=True, - ).path - - def _set_requirement(self) -> None: - """Set requirement after generating metadata.""" - assert self.req is None - assert self.metadata is not None - assert self.source_dir is not None - - # 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) -> None: - assert self.req is not 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 check_if_exists(self, use_user_site: bool) -> None: - """Find an installed distribution that satisfies or conflicts - with this requirement, and set self.satisfied_by or - self.should_reinstall appropriately. - """ - if self.req is None: - return - existing_dist = get_default_environment().get_distribution(self.req.name) - if not existing_dist: - return - - version_compatible = self.req.specifier.contains( - existing_dist.version, - prereleases=True, - ) - if not version_compatible: - self.satisfied_by = None - if use_user_site: - if existing_dist.in_usersite: - self.should_reinstall = True - elif running_under_virtualenv() and existing_dist.in_site_packages: - raise InstallationError( - f"Will not install to the user site because it will " - f"lack sys.path precedence to {existing_dist.raw_name} " - f"in {existing_dist.location}" - ) - else: - self.should_reinstall = True - else: - if self.editable: - self.should_reinstall = True - # when installing editables, nothing pre-existing should ever - # satisfy - self.satisfied_by = None - else: - self.satisfied_by = existing_dist - - # Things valid for wheels - @property - def is_wheel(self) -> bool: - if not self.link: - return False - return self.link.is_wheel - - @property - def is_wheel_from_cache(self) -> bool: - # When True, it means that this InstallRequirement is a local wheel file in the - # cache of locally built wheels. - return self.cached_wheel_source_link is not None - - # Things valid for sdists - @property - def unpacked_source_directory(self) -> str: - assert self.source_dir, f"No source dir for {self}" - return os.path.join( - self.source_dir, self.link and self.link.subdirectory_fragment or "" - ) - - @property - def setup_py_path(self) -> str: - assert self.source_dir, f"No source dir for {self}" - setup_py = os.path.join(self.unpacked_source_directory, "setup.py") - - return setup_py - - @property - def setup_cfg_path(self) -> str: - assert self.source_dir, f"No source dir for {self}" - setup_cfg = os.path.join(self.unpacked_source_directory, "setup.cfg") - - return setup_cfg - - @property - def pyproject_toml_path(self) -> str: - assert self.source_dir, f"No source dir for {self}" - return make_pyproject_path(self.unpacked_source_directory) - - def load_pyproject_toml(self) -> 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: - assert not self.config_settings - 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 = ConfiguredBuildBackendHookCaller( - self, - self.unpacked_source_directory, - backend, - backend_path=backend_path, - ) - - def isolated_editable_sanity_check(self) -> None: - """Check that an editable requirement if valid for use with PEP 517/518. - - This verifies that an editable that has a pyproject.toml either supports PEP 660 - or as a setup.py or a setup.cfg - """ - if ( - self.editable - and self.use_pep517 - and not self.supports_pyproject_editable() - and not os.path.isfile(self.setup_py_path) - and not os.path.isfile(self.setup_cfg_path) - ): - raise InstallationError( - f"Project {self} has a 'pyproject.toml' and its build " - f"backend is missing the 'build_editable' hook. Since it does not " - f"have a 'setup.py' nor a 'setup.cfg', " - f"it cannot be installed in editable mode. " - f"Consider using a build backend that supports PEP 660." - ) - - def prepare_metadata(self) -> None: - """Ensure that project metadata is available. - - Under PEP 517 and PEP 660, call the backend hook to prepare the metadata. - Under legacy processing, call setup.py egg-info. - """ - assert self.source_dir, f"No source dir for {self}" - details = self.name or f"from {self.link}" - - if self.use_pep517: - assert self.pep517_backend is not None - if ( - self.editable - and self.permit_editable_wheels - and self.supports_pyproject_editable() - ): - self.metadata_directory = generate_editable_metadata( - build_env=self.build_env, - backend=self.pep517_backend, - details=details, - ) - else: - self.metadata_directory = generate_metadata( - build_env=self.build_env, - backend=self.pep517_backend, - details=details, - ) - else: - self.metadata_directory = generate_metadata_legacy( - build_env=self.build_env, - setup_py_path=self.setup_py_path, - source_dir=self.unpacked_source_directory, - isolated=self.isolated, - details=details, - ) - - # Act on the newly generated metadata, based on the name and version. - if not self.name: - self._set_requirement() - else: - self.warn_on_mismatching_name() - - self.assert_source_matches_version() - - @property - def metadata(self) -> Any: - if not hasattr(self, "_metadata"): - self._metadata = self.get_dist().metadata - - return self._metadata - - def get_dist(self) -> BaseDistribution: - if self.metadata_directory: - return get_directory_distribution(self.metadata_directory) - elif self.local_file_path and self.is_wheel: - assert self.req is not None - return get_wheel_distribution( - FilesystemWheel(self.local_file_path), - canonicalize_name(self.req.name), - ) - raise AssertionError( - f"InstallRequirement {self} has no metadata directory and no wheel: " - f"can't make a distribution." - ) - - def assert_source_matches_version(self) -> None: - assert self.source_dir, f"No source dir for {self}" - version = self.metadata["version"] - if self.req and 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: str, - autodelete: bool = False, - parallel_builds: bool = False, - ) -> None: - """Ensure that a source_dir is set. - - This will create a temporary build dir if the name of the requirement - 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, - autodelete=autodelete, - parallel_builds=parallel_builds, - ) - - def needs_unpacked_archive(self, archive_source: Path) -> None: - assert self._archive_source is None - self._archive_source = archive_source - - def ensure_pristine_source_checkout(self) -> None: - """Ensure the source directory has not yet been built in.""" - assert self.source_dir is not None - if self._archive_source is not None: - unpack_file(str(self._archive_source), self.source_dir) - elif is_installable_dir(self.source_dir): - # If a checkout exists, it's unwise to keep going. - # version inconsistencies are logged later, but do not fail - # the installation. - raise PreviousBuildDirError( - f"pip can't proceed with requirements '{self}' due to a " - f"pre-existing build directory ({self.source_dir}). 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." - ) - - # For editable installations - def update_editable(self) -> 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 - vcs_backend = vcs.get_backend_for_scheme(self.link.scheme) - # Editable requirements are validated in Requirement constructors. - # So here, if it's neither a path nor a valid VCS URL, it's a bug. - assert vcs_backend, f"Unsupported VCS URL {self.link.url}" - hidden_url = hide_url(self.link.url) - vcs_backend.obtain(self.source_dir, url=hidden_url, verbosity=0) - - # Top-level Actions - def uninstall( - self, auto_confirm: bool = False, verbose: bool = False - ) -> 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 - dist = get_default_environment().get_distribution(self.req.name) - if not dist: - logger.warning("Skipping %s as it is not installed.", self.name) - return None - logger.info("Found existing installation: %s", dist) - - uninstalled_pathset = UninstallPathSet.from_dist(dist) - uninstalled_pathset.remove(auto_confirm, verbose) - return uninstalled_pathset - - def _get_archive_name(self, path: str, parentdir: str, rootdir: str) -> str: - def _clean_zip_name(name: str, prefix: str) -> str: - assert name.startswith( - prefix + os.path.sep - ), f"name {name!r} doesn't start with prefix {prefix!r}" - name = name[len(prefix) + 1 :] - name = name.replace(os.path.sep, "/") - return name - - assert self.req is not None - path = os.path.join(parentdir, path) - name = _clean_zip_name(path, rootdir) - return self.req.name + "/" + name - - def archive(self, build_dir: Optional[str]) -> None: - """Saves archive to provided build_dir. - - Used for saving downloaded VCS requirements as part of `pip download`. - """ - assert self.source_dir - if build_dir is None: - return - - create_archive = True - archive_name = "{}-{}.zip".format(self.name, self.metadata["version"]) - archive_path = os.path.join(build_dir, archive_name) - - if os.path.exists(archive_path): - response = ask_path_exists( - f"The file {display_path(archive_path)} exists. (i)gnore, (w)ipe, " - "(b)ackup, (a)bort ", - ("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): - 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: - 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, - global_options: Optional[Sequence[str]] = None, - root: Optional[str] = None, - home: Optional[str] = None, - prefix: Optional[str] = None, - warn_script_location: bool = True, - use_user_site: bool = False, - pycompile: bool = True, - ) -> None: - assert self.req is not None - scheme = get_scheme( - self.req.name, - user=use_user_site, - home=home, - root=root, - isolated=self.isolated, - prefix=prefix, - ) - - if self.editable and not self.is_wheel: - if self.config_settings: - logger.warning( - "--config-settings ignored for legacy editable install of %s. " - "Consider upgrading to a version of setuptools " - "that supports PEP 660 (>= 64).", - self, - ) - install_editable_legacy( - global_options=global_options if global_options is not None else [], - prefix=prefix, - home=home, - use_user_site=use_user_site, - name=self.req.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 - - assert self.is_wheel - assert self.local_file_path - - install_wheel( - self.req.name, - self.local_file_path, - scheme=scheme, - req_description=str(self.req), - pycompile=pycompile, - warn_script_location=warn_script_location, - direct_url=self.download_info if self.is_direct else None, - requested=self.user_supplied, - ) - self.install_succeeded = True - - -def check_invalid_constraint_type(req: InstallRequirement) -> str: - # Check for unsupported forms - problem = "" - if not req.name: - problem = "Unnamed requirements are not allowed as constraints" - elif req.editable: - problem = "Editable requirements are not allowed as constraints" - elif req.extras: - problem = "Constraints cannot have extras" - - if problem: - deprecated( - reason=( - "Constraints are only allowed to take the form of a package " - "name and a version specifier. Other forms were originally " - "permitted as an accident of the implementation, but were " - "undocumented. The new implementation of the resolver no " - "longer supports these forms." - ), - replacement="replacing the constraint with a requirement", - # No plan yet for when the new resolver becomes default - gone_in=None, - issue=8210, - ) - - return problem - - -def _has_option(options: Values, reqs: List[InstallRequirement], option: str) -> bool: - if getattr(options, option, None): - return True - for req in reqs: - if getattr(req, option, None): - return True - return False - - -def check_legacy_setup_py_options( - options: Values, - reqs: List[InstallRequirement], -) -> None: - has_build_options = _has_option(options, reqs, "build_options") - has_global_options = _has_option(options, reqs, "global_options") - if has_build_options or has_global_options: - deprecated( - reason="--build-option and --global-option are deprecated.", - issue=11859, - replacement="to use --config-settings", - gone_in="24.2", - ) - logger.warning( - "Implying --no-binary=:all: due to the presence of " - "--build-option / --global-option. " - ) - options.format_control.disallow_binaries() diff --git a/venv/lib/python3.12/site-packages/pip/_internal/req/req_set.py b/venv/lib/python3.12/site-packages/pip/_internal/req/req_set.py deleted file mode 100644 index bf36114..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/req/req_set.py +++ /dev/null @@ -1,119 +0,0 @@ -import logging -from collections import OrderedDict -from typing import Dict, List - -from pip._vendor.packaging.specifiers import LegacySpecifier -from pip._vendor.packaging.utils import canonicalize_name -from pip._vendor.packaging.version import LegacyVersion - -from pip._internal.req.req_install import InstallRequirement -from pip._internal.utils.deprecation import deprecated - -logger = logging.getLogger(__name__) - - -class RequirementSet: - def __init__(self, check_supported_wheels: bool = True) -> None: - """Create a RequirementSet.""" - - self.requirements: Dict[str, InstallRequirement] = OrderedDict() - self.check_supported_wheels = check_supported_wheels - - self.unnamed_requirements: List[InstallRequirement] = [] - - def __str__(self) -> str: - requirements = sorted( - (req for req in self.requirements.values() if not req.comes_from), - key=lambda req: canonicalize_name(req.name or ""), - ) - return " ".join(str(req.req) for req in requirements) - - def __repr__(self) -> str: - requirements = sorted( - self.requirements.values(), - key=lambda req: canonicalize_name(req.name or ""), - ) - - format_string = "<{classname} object; {count} requirement(s): {reqs}>" - 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: InstallRequirement) -> None: - assert not install_req.name - self.unnamed_requirements.append(install_req) - - def add_named_requirement(self, install_req: InstallRequirement) -> None: - assert install_req.name - - project_name = canonicalize_name(install_req.name) - self.requirements[project_name] = install_req - - def has_requirement(self, name: 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: str) -> InstallRequirement: - project_name = canonicalize_name(name) - - if project_name in self.requirements: - return self.requirements[project_name] - - raise KeyError(f"No project with the name {name!r}") - - @property - def all_requirements(self) -> List[InstallRequirement]: - return self.unnamed_requirements + list(self.requirements.values()) - - @property - def requirements_to_install(self) -> List[InstallRequirement]: - """Return the list of requirements that need to be installed. - - TODO remove this property together with the legacy resolver, since the new - resolver only returns requirements that need to be installed. - """ - return [ - install_req - for install_req in self.all_requirements - if not install_req.constraint and not install_req.satisfied_by - ] - - def warn_legacy_versions_and_specifiers(self) -> None: - for req in self.requirements_to_install: - version = req.get_dist().version - if isinstance(version, LegacyVersion): - deprecated( - reason=( - f"pip has selected the non standard version {version} " - f"of {req}. In the future this version will be " - f"ignored as it isn't standard compliant." - ), - replacement=( - "set or update constraints to select another version " - "or contact the package author to fix the version number" - ), - issue=12063, - gone_in="24.1", - ) - for dep in req.get_dist().iter_dependencies(): - if any(isinstance(spec, LegacySpecifier) for spec in dep.specifier): - deprecated( - reason=( - f"pip has selected {req} {version} which has non " - f"standard dependency specifier {dep}. " - f"In the future this version of {req} will be " - f"ignored as it isn't standard compliant." - ), - replacement=( - "set or update constraints to select another version " - "or contact the package author to fix the version number" - ), - issue=12063, - gone_in="24.1", - ) diff --git a/venv/lib/python3.12/site-packages/pip/_internal/req/req_uninstall.py b/venv/lib/python3.12/site-packages/pip/_internal/req/req_uninstall.py deleted file mode 100644 index 707fde1..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/req/req_uninstall.py +++ /dev/null @@ -1,649 +0,0 @@ -import functools -import os -import sys -import sysconfig -from importlib.util import cache_from_source -from typing import Any, Callable, Dict, Generator, Iterable, List, Optional, Set, Tuple - -from pip._internal.exceptions import UninstallationError -from pip._internal.locations import get_bin_prefix, get_bin_user -from pip._internal.metadata import BaseDistribution -from pip._internal.utils.compat import WINDOWS -from pip._internal.utils.egg_link import egg_link_path_from_location -from pip._internal.utils.logging import getLogger, indent_log -from pip._internal.utils.misc import ask, normalize_path, renames, rmtree -from pip._internal.utils.temp_dir import AdjacentTempDirectory, TempDirectory -from pip._internal.utils.virtualenv import running_under_virtualenv - -logger = getLogger(__name__) - - -def _script_names( - bin_dir: str, script_name: str, is_gui: bool -) -> Generator[str, None, None]: - """Create the fully qualified name of the files created by - {console,gui}_scripts for the given ``dist``. - Returns the list of file names - """ - exe_name = os.path.join(bin_dir, script_name) - yield exe_name - if not WINDOWS: - return - yield f"{exe_name}.exe" - yield f"{exe_name}.exe.manifest" - if is_gui: - yield f"{exe_name}-script.pyw" - else: - yield f"{exe_name}-script.py" - - -def _unique( - fn: Callable[..., Generator[Any, None, None]] -) -> Callable[..., Generator[Any, None, None]]: - @functools.wraps(fn) - def unique(*args: Any, **kw: Any) -> Generator[Any, None, None]: - seen: Set[Any] = set() - for item in fn(*args, **kw): - if item not in seen: - seen.add(item) - yield item - - return unique - - -@_unique -def uninstallation_paths(dist: BaseDistribution) -> Generator[str, None, None]: - """ - 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]. - - If RECORD is not found, raises UninstallationError, - with possible information from the INSTALLER file. - - https://packaging.python.org/specifications/recording-installed-packages/ - """ - location = dist.location - assert location is not None, "not installed" - - entries = dist.iter_declared_entries() - if entries is None: - msg = f"Cannot uninstall {dist}, RECORD file not found." - installer = dist.installer - if not installer or installer == "pip": - dep = f"{dist.raw_name}=={dist.version}" - msg += ( - " You might be able to recover from this via: " - f"'pip install --force-reinstall --no-deps {dep}'." - ) - else: - msg += f" Hint: The package was installed by {installer}." - raise UninstallationError(msg) - - for entry in entries: - path = os.path.join(location, entry) - 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: 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[str] = set() - 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: 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 = {os.path.normcase(p): p for p in paths} - remaining = set(case_map) - unchecked = sorted({os.path.split(p)[0] for p in case_map.values()}, key=len) - wildcards: Set[str] = set() - - def norm_join(*a: str) -> str: - return os.path.normcase(os.path.join(*a)) - - for root in unchecked: - if any(os.path.normcase(root).startswith(w) for w in wildcards): - # This directory has already been handled. - continue - - all_files: Set[str] = set() - all_subdirs: Set[str] = set() - for dirname, subdirs, files in os.walk(root): - all_subdirs.update(norm_join(root, dirname, d) for d in subdirs) - all_files.update(norm_join(root, dirname, f) for f in files) - # 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: 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) - - _normcased_files = set(map(os.path.normcase, files)) - - 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: - """A set of file rename operations to stash files while - tentatively uninstalling them.""" - - def __init__(self) -> None: - # Mapping from source file root to [Adjacent]TempDirectory - # for files under that directory. - self._save_dirs: Dict[str, TempDirectory] = {} - # (old path, new path) tuples for each move that may need - # to be undone. - self._moves: List[Tuple[str, str]] = [] - - def _get_directory_stash(self, path: str) -> str: - """Stashes a directory. - - Directories are stashed adjacent to their original location if - possible, or else moved/copied into the user's temp dir.""" - - try: - save_dir: TempDirectory = AdjacentTempDirectory(path) - except OSError: - save_dir = TempDirectory(kind="uninstall") - self._save_dirs[os.path.normcase(path)] = save_dir - - return save_dir.path - - def _get_file_stash(self, path: 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: 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) -> None: - """Commits the uninstall by removing stashed files.""" - for save_dir in self._save_dirs.values(): - save_dir.cleanup() - self._moves = [] - self._save_dirs = {} - - def rollback(self) -> None: - """Undoes the uninstall by moving stashed files back.""" - for p in self._moves: - logger.info("Moving to %s\n from %s", *p) - - for new_path, path in self._moves: - try: - logger.debug("Replacing %s from %s", new_path, path) - 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) -> bool: - return bool(self._moves) - - -class UninstallPathSet: - """A set of file paths to be removed in the uninstallation of a - requirement.""" - - def __init__(self, dist: BaseDistribution) -> None: - self._paths: Set[str] = set() - self._refuse: Set[str] = set() - self._pth: Dict[str, UninstallPthEntries] = {} - self._dist = dist - self._moved_paths = StashedUninstallPathSet() - # Create local cache of normalize_path results. Creating an UninstallPathSet - # can result in hundreds/thousands of redundant calls to normalize_path with - # the same args, which hurts performance. - self._normalize_path_cached = functools.lru_cache()(normalize_path) - - def _permitted(self, path: str) -> bool: - """ - Return True if the given path is one we are permitted to - remove/modify, False otherwise. - - """ - # aka is_local, but caching normalized sys.prefix - if not running_under_virtualenv(): - return True - return path.startswith(self._normalize_path_cached(sys.prefix)) - - def add(self, path: 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(self._normalize_path_cached(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": - self.add(cache_from_source(path)) - - def add_pth(self, pth_file: str, entry: str) -> None: - pth_file = self._normalize_path_cached(pth_file) - if self._permitted(pth_file): - if pth_file not in self._pth: - self._pth[pth_file] = UninstallPthEntries(pth_file) - self._pth[pth_file].add(entry) - else: - self._refuse.add(pth_file) - - def remove(self, auto_confirm: bool = False, verbose: bool = False) -> None: - """Remove paths in ``self._paths`` with confirmation (unless - ``auto_confirm`` is True).""" - - if not self._paths: - logger.info( - "Can't uninstall '%s'. No files were found to uninstall.", - self._dist.raw_name, - ) - return - - dist_name_version = f"{self._dist.raw_name}-{self._dist.version}" - logger.info("Uninstalling %s:", dist_name_version) - - with indent_log(): - if auto_confirm or self._allowed_to_proceed(verbose): - moved = self._moved_paths - - for_rename = compress_for_rename(self._paths) - - for path in sorted(compact(for_rename)): - moved.stash(path) - logger.verbose("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: bool) -> bool: - """Display which files would be deleted and prompt for confirmation""" - - def _display(msg: str, paths: 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", "")) != "n" - - def rollback(self) -> None: - """Rollback the changes previously made by remove().""" - if not self._moved_paths.can_rollback: - logger.error( - "Can't roll back %s; was not uninstalled", - self._dist.raw_name, - ) - return - logger.info("Rolling back uninstall of %s", self._dist.raw_name) - self._moved_paths.rollback() - for pth in self._pth.values(): - pth.rollback() - - def commit(self) -> None: - """Remove temporary save dir: rollback will no longer be possible.""" - self._moved_paths.commit() - - @classmethod - def from_dist(cls, dist: BaseDistribution) -> "UninstallPathSet": - dist_location = dist.location - info_location = dist.info_location - if dist_location is None: - logger.info( - "Not uninstalling %s since it is not installed", - dist.canonical_name, - ) - return cls(dist) - - normalized_dist_location = normalize_path(dist_location) - if not dist.local: - logger.info( - "Not uninstalling %s at %s, outside environment %s", - dist.canonical_name, - normalized_dist_location, - sys.prefix, - ) - return cls(dist) - - if normalized_dist_location in { - p - for p in {sysconfig.get_path("stdlib"), sysconfig.get_path("platstdlib")} - if p - }: - logger.info( - "Not uninstalling %s at %s, as it is in the standard library.", - dist.canonical_name, - normalized_dist_location, - ) - return cls(dist) - - paths_to_remove = cls(dist) - develop_egg_link = egg_link_path_from_location(dist.raw_name) - - # Distribution is installed with metadata in a "flat" .egg-info - # directory. This means it is not a modern .dist-info installation, an - # egg, or legacy editable. - setuptools_flat_installation = ( - dist.installed_with_setuptools_egg_info - and info_location is not None - and os.path.exists(info_location) - # If dist is editable and the location points to a ``.egg-info``, - # we are in fact in the legacy editable case. - and not info_location.endswith(f"{dist.setuptools_filename}.egg-info") - ) - - # Uninstall cases order do matter as in the case of 2 installs of the - # same package, pip needs to uninstall the currently detected version - if setuptools_flat_installation: - if info_location is not None: - paths_to_remove.add(info_location) - installed_files = dist.iter_declared_entries() - if installed_files is not None: - for installed_file in installed_files: - paths_to_remove.add(os.path.join(dist_location, installed_file)) - # FIXME: need a test for this elif block - # occurs with --single-version-externally-managed/--record outside - # of pip - elif dist.is_file("top_level.txt"): - try: - namespace_packages = dist.read_text("namespace_packages.txt") - except FileNotFoundError: - namespaces = [] - else: - namespaces = namespace_packages.splitlines(keepends=False) - for top_level_pkg in [ - p - for p in dist.read_text("top_level.txt").splitlines() - if p and p not in namespaces - ]: - path = os.path.join(dist_location, top_level_pkg) - paths_to_remove.add(path) - paths_to_remove.add(f"{path}.py") - paths_to_remove.add(f"{path}.pyc") - paths_to_remove.add(f"{path}.pyo") - - elif dist.installed_by_distutils: - raise UninstallationError( - "Cannot uninstall {!r}. It is a distutils installed project " - "and thus we cannot accurately determine which files belong " - "to it which would lead to only a partial uninstall.".format( - dist.raw_name, - ) - ) - - elif dist.installed_as_egg: - # package installed by easy_install - # We cannot match on dist.egg_name because it can slightly vary - # i.e. setuptools-0.6c11-py2.6.egg vs setuptools-0.6rc11-py2.6.egg - paths_to_remove.add(dist_location) - easy_install_egg = os.path.split(dist_location)[1] - easy_install_pth = os.path.join( - os.path.dirname(dist_location), - "easy-install.pth", - ) - paths_to_remove.add_pth(easy_install_pth, "./" + easy_install_egg) - - elif dist.installed_with_dist_info: - for path in uninstallation_paths(dist): - paths_to_remove.add(path) - - elif develop_egg_link: - # PEP 660 modern editable is handled in the ``.dist-info`` case - # above, so this only covers the setuptools-style editable. - with open(develop_egg_link) as fh: - link_pointer = os.path.normcase(fh.readline().strip()) - normalized_link_pointer = paths_to_remove._normalize_path_cached( - link_pointer - ) - assert os.path.samefile( - normalized_link_pointer, normalized_dist_location - ), ( - f"Egg-link {develop_egg_link} (to {link_pointer}) does not match " - f"installed location of {dist.raw_name} (at {dist_location})" - ) - paths_to_remove.add(develop_egg_link) - easy_install_pth = os.path.join( - os.path.dirname(develop_egg_link), "easy-install.pth" - ) - paths_to_remove.add_pth(easy_install_pth, dist_location) - - else: - logger.debug( - "Not sure how to uninstall: %s - Check: %s", - dist, - dist_location, - ) - - if dist.in_usersite: - bin_dir = get_bin_user() - else: - bin_dir = get_bin_prefix() - - # find distutils scripts= scripts - try: - for script in dist.iter_distutils_script_names(): - paths_to_remove.add(os.path.join(bin_dir, script)) - if WINDOWS: - paths_to_remove.add(os.path.join(bin_dir, f"{script}.bat")) - except (FileNotFoundError, NotADirectoryError): - pass - - # find console_scripts and gui_scripts - def iter_scripts_to_remove( - dist: BaseDistribution, - bin_dir: str, - ) -> Generator[str, None, None]: - for entry_point in dist.iter_entry_points(): - if entry_point.group == "console_scripts": - yield from _script_names(bin_dir, entry_point.name, False) - elif entry_point.group == "gui_scripts": - yield from _script_names(bin_dir, entry_point.name, True) - - for s in iter_scripts_to_remove(dist, bin_dir): - paths_to_remove.add(s) - - return paths_to_remove - - -class UninstallPthEntries: - def __init__(self, pth_file: str) -> None: - self.file = pth_file - self.entries: Set[str] = set() - self._saved_lines: Optional[List[bytes]] = None - - def add(self, entry: str) -> None: - entry = os.path.normcase(entry) - # On Windows, os.path.normcase converts the entry to use - # backslashes. This is correct for entries that describe absolute - # 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". - if WINDOWS and not os.path.splitdrive(entry)[0]: - entry = entry.replace("\\", "/") - self.entries.add(entry) - - def remove(self) -> None: - logger.verbose("Removing pth entries from %s:", self.file) - - # If the file doesn't exist, log a warning and return - if not os.path.isfile(self.file): - logger.warning("Cannot remove entries from nonexistent file %s", self.file) - return - 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.verbose("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) -> 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.12/site-packages/pip/_internal/resolution/__init__.py b/venv/lib/python3.12/site-packages/pip/_internal/resolution/__init__.py deleted file mode 100644 index e69de29..0000000 diff --git a/venv/lib/python3.12/site-packages/pip/_internal/resolution/__pycache__/__init__.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/resolution/__pycache__/__init__.cpython-312.pyc deleted file mode 100644 index 7e9ecd4df4430dfee1ca0216d9c2158ef273f6ab..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 207 zcmZ9FK?=e!5JeNKAVLq~q8-$&2t_w;#2bXD!46H6kfeor372l&dKQo238cHOOtyab z^WS_1=AEW967?FLW!7jo#p_JMr&<`>dIK2P> diff --git a/venv/lib/python3.12/site-packages/pip/_internal/resolution/__pycache__/base.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/resolution/__pycache__/base.cpython-312.pyc deleted file mode 100644 index 5b205cc08b4854902b1ea66f3547b5ed712f49ab..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1195 zcma)5OKTKC5bmDW&aO#B6Qc=4R+FfUWXGr{4dN3CN(_1%gkiE%Nyf};dwN$kClL?c zJm%^(_*1-W@DdtCK|FYit{`}_YIY+LJy&RO!^>M)mI?`h_jDZ~%9SNRwnWm<_toG^ zHB;OhN4Lc!$EC10gY`Mz=1bdLjV`5fG0vi*N(k->H)NVQH$>Y{=58!6&fSVarwvKliNX~p>&W#qxm2IO=;Wb< zxy)~D_-l|mS(rIqm`D)Vbw^OaEgFHdg7w$4jw%&g8#c!dcBDRFhfq;(7~M1W-C~DN zzZ;qE+S5HG7`@r_a-7j%^hEwoOT-AC6Nk~&G;xG5wJ)bE)v7p(iyB`8iK>hH;gei1 z6#Q`Mmsdd@pk4l-(d}HW}+`j<2vo*;8 diff --git a/venv/lib/python3.12/site-packages/pip/_internal/resolution/base.py b/venv/lib/python3.12/site-packages/pip/_internal/resolution/base.py deleted file mode 100644 index 42dade1..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/resolution/base.py +++ /dev/null @@ -1,20 +0,0 @@ -from typing import Callable, List, Optional - -from pip._internal.req.req_install import InstallRequirement -from pip._internal.req.req_set import RequirementSet - -InstallRequirementProvider = Callable[ - [str, Optional[InstallRequirement]], InstallRequirement -] - - -class BaseResolver: - def resolve( - self, root_reqs: List[InstallRequirement], check_supported_wheels: bool - ) -> RequirementSet: - raise NotImplementedError() - - def get_installation_order( - self, req_set: RequirementSet - ) -> List[InstallRequirement]: - raise NotImplementedError() diff --git a/venv/lib/python3.12/site-packages/pip/_internal/resolution/legacy/__init__.py b/venv/lib/python3.12/site-packages/pip/_internal/resolution/legacy/__init__.py deleted file mode 100644 index e69de29..0000000 diff --git a/venv/lib/python3.12/site-packages/pip/_internal/resolution/legacy/__pycache__/__init__.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/resolution/legacy/__pycache__/__init__.cpython-312.pyc deleted file mode 100644 index 2405f19bda057e14ff8468f20059e073e0a6e815..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 214 zcmZ8bF$%&!5X>0`5%Lg=WKmlYf;Kkd55k!&X36F5xVr@6CoFAkeT&cV1(Gh6m)3#Z znc1CU-chs&Jf6v&M*fWJAN|x{9zho@+36LSiFf^&85$^6jbL~|Qj<~54Gw54r!=Id zLq^h}kz9a5t3=~SNf3DDc?X$) elFPD0cf)*JtD+IOGc(_U`LUz;hKw;2di4YP>pN%w diff --git a/venv/lib/python3.12/site-packages/pip/_internal/resolution/legacy/__pycache__/resolver.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/resolution/legacy/__pycache__/resolver.cpython-312.pyc deleted file mode 100644 index fe42720fc02df7276817bdd4063458e359010ee1..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 22449 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 diff --git a/venv/lib/python3.12/site-packages/pip/_internal/resolution/legacy/resolver.py b/venv/lib/python3.12/site-packages/pip/_internal/resolution/legacy/resolver.py deleted file mode 100644 index 5ddb848..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/resolution/legacy/resolver.py +++ /dev/null @@ -1,598 +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 - -import logging -import sys -from collections import defaultdict -from itertools import chain -from typing import DefaultDict, Iterable, List, Optional, Set, Tuple - -from pip._vendor.packaging import specifiers -from pip._vendor.packaging.requirements import Requirement - -from pip._internal.cache import WheelCache -from pip._internal.exceptions import ( - BestVersionAlreadyInstalled, - DistributionNotFound, - HashError, - HashErrors, - InstallationError, - NoneMetadataError, - UnsupportedPythonVersion, -) -from pip._internal.index.package_finder import PackageFinder -from pip._internal.metadata import BaseDistribution -from pip._internal.models.link import Link -from pip._internal.models.wheel import Wheel -from pip._internal.operations.prepare import RequirementPreparer -from pip._internal.req.req_install import ( - InstallRequirement, - check_invalid_constraint_type, -) -from pip._internal.req.req_set import RequirementSet -from pip._internal.resolution.base import BaseResolver, InstallRequirementProvider -from pip._internal.utils import compatibility_tags -from pip._internal.utils.compatibility_tags import get_supported -from pip._internal.utils.direct_url_helpers import direct_url_from_link -from pip._internal.utils.logging import indent_log -from pip._internal.utils.misc import normalize_version_info -from pip._internal.utils.packaging import check_requires_python - -logger = logging.getLogger(__name__) - -DiscoveredDependencies = DefaultDict[str, List[InstallRequirement]] - - -def _check_dist_requires_python( - dist: BaseDistribution, - version_info: Tuple[int, int, int], - ignore_requires_python: bool = False, -) -> None: - """ - Check whether the given Python version is compatible with a distribution's - "Requires-Python" value. - - :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. - """ - # This idiosyncratically converts the SpecifierSet to str and let - # check_requires_python then parse it again into SpecifierSet. But this - # is the legacy resolver so I'm just not going to bother refactoring. - try: - requires_python = str(dist.requires_python) - except FileNotFoundError as e: - raise NoneMetadataError(dist, str(e)) - try: - is_compatible = check_requires_python( - requires_python, - version_info=version_info, - ) - except specifiers.InvalidSpecifier as exc: - logger.warning( - "Package %r has an invalid Requires-Python: %s", dist.raw_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.raw_name, - version, - requires_python, - ) - return - - raise UnsupportedPythonVersion( - "Package {!r} requires a different Python: {} not in {!r}".format( - dist.raw_name, version, requires_python - ) - ) - - -class Resolver(BaseResolver): - """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: RequirementPreparer, - finder: PackageFinder, - wheel_cache: Optional[WheelCache], - make_install_req: InstallRequirementProvider, - use_user_site: bool, - ignore_dependencies: bool, - ignore_installed: bool, - ignore_requires_python: bool, - force_reinstall: bool, - upgrade_strategy: str, - py_version_info: Optional[Tuple[int, ...]] = None, - ) -> None: - super().__init__() - assert upgrade_strategy in self._allowed_strategies - - 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.wheel_cache = wheel_cache - - 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: DiscoveredDependencies = defaultdict(list) - - def resolve( - self, root_reqs: List[InstallRequirement], check_supported_wheels: bool - ) -> RequirementSet: - """Resolve what operations need to be done - - As a side-effect of this method, the packages (and their dependencies) - 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. - """ - requirement_set = RequirementSet(check_supported_wheels=check_supported_wheels) - for req in root_reqs: - if req.constraint: - check_invalid_constraint_type(req) - self._add_requirement_to_set(requirement_set, req) - - # Actually prepare the files, and collect any exceptions. Most hash - # exceptions cannot be checked ahead of time, because - # _populate_link() needs to be called before we can make decisions - # based on link type. - discovered_reqs: List[InstallRequirement] = [] - hash_errors = HashErrors() - for req in chain(requirement_set.all_requirements, 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 - - return requirement_set - - def _add_requirement_to_set( - self, - requirement_set: RequirementSet, - install_req: InstallRequirement, - parent_req_name: Optional[str] = None, - extras_requested: Optional[Iterable[str]] = None, - ) -> Tuple[List[InstallRequirement], Optional[InstallRequirement]]: - """Add install_req as a requirement to install. - - :param parent_req_name: The name of the requirement that needed this - added. The name is used because when multiple unnamed requirements - resolve to the same name, we could otherwise end up with dependency - links that point outside the Requirements set. parent_req must - already be added. Note that None implies that this is a user - supplied requirement, vs an inferred one. - :param extras_requested: an iterable of extras used to evaluate the - environment markers. - :return: Additional requirements to scan. That is either [] if - the requirement is not applicable, or [install_req] if the - requirement is applicable and has just been added. - """ - # If the markers do not match, ignore this requirement. - if not install_req.match_markers(extras_requested): - logger.info( - "Ignoring %s: markers '%s' don't match your environment", - install_req.name, - install_req.markers, - ) - return [], None - - # If the wheel is not supported, raise an error. - # Should check this after filtering out based on environment markers to - # allow specifying different wheels based on the environment/OS, in a - # single requirements file. - if install_req.link and install_req.link.is_wheel: - wheel = Wheel(install_req.link.filename) - tags = compatibility_tags.get_supported() - if requirement_set.check_supported_wheels and not wheel.supported(tags): - raise InstallationError( - f"{wheel.filename} is not a supported wheel on this platform." - ) - - # This next bit is really a sanity check. - assert ( - not install_req.user_supplied or parent_req_name is None - ), "a user supplied req shouldn't have a parent" - - # Unnamed requirements are scanned again and the requirement won't be - # added as a dependency until after scanning. - if not install_req.name: - requirement_set.add_unnamed_requirement(install_req) - return [install_req], None - - try: - existing_req: Optional[ - InstallRequirement - ] = requirement_set.get_requirement(install_req.name) - except KeyError: - existing_req = None - - has_conflicting_requirement = ( - parent_req_name is None - and existing_req - and not existing_req.constraint - and existing_req.extras == install_req.extras - and existing_req.req - and install_req.req - and existing_req.req.specifier != install_req.req.specifier - ) - if has_conflicting_requirement: - raise InstallationError( - "Double requirement given: {} (already in {}, name={!r})".format( - install_req, existing_req, install_req.name - ) - ) - - # When no existing requirement exists, add the requirement as a - # dependency and it will be scanned again after. - if not existing_req: - requirement_set.add_named_requirement(install_req) - # We'd want to rescan this requirement later - return [install_req], install_req - - # Assume there's no need to scan, and that we've already - # encountered this for scanning. - if install_req.constraint or not existing_req.constraint: - return [], existing_req - - does_not_satisfy_constraint = install_req.link and not ( - existing_req.link and install_req.link.path == existing_req.link.path - ) - if does_not_satisfy_constraint: - raise InstallationError( - f"Could not satisfy constraints for '{install_req.name}': " - "installation from path or url cannot be " - "constrained to a version" - ) - # If we're now installing a constraint, mark the existing - # object for real installation. - existing_req.constraint = False - # If we're now installing a user supplied requirement, - # mark the existing object as such. - if install_req.user_supplied: - existing_req.user_supplied = True - existing_req.extras = tuple( - sorted(set(existing_req.extras) | set(install_req.extras)) - ) - logger.debug( - "Setting %s extras to: %s", - existing_req, - existing_req.extras, - ) - # Return the existing requirement for addition to the parent and - # scanning again. - return [existing_req], existing_req - - def _is_upgrade_allowed(self, req: InstallRequirement) -> bool: - if self.upgrade_strategy == "to-satisfy-only": - return False - elif self.upgrade_strategy == "eager": - return True - else: - assert self.upgrade_strategy == "only-if-needed" - return req.user_supplied or req.constraint - - def _set_req_to_reinstall(self, req: InstallRequirement) -> None: - """ - Set a requirement to be installed. - """ - # Don't uninstall the conflict if doing a user install and the - # conflict is not a user install. - if not self.use_user_site or req.satisfied_by.in_usersite: - req.should_reinstall = True - req.satisfied_by = None - - def _check_skip_installed( - self, req_to_install: InstallRequirement - ) -> Optional[str]: - """Check if req_to_install should be skipped. - - This will check if the req is installed, and whether we should upgrade - 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 _find_requirement_link(self, req: InstallRequirement) -> Optional[Link]: - upgrade = self._is_upgrade_allowed(req) - best_candidate = self.finder.find_requirement(req, upgrade) - if not best_candidate: - return None - - # 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. - "The candidate selected for download or install is a " - f"yanked version: {best_candidate}\n" - f"Reason for being yanked: {reason}" - ) - logger.warning(msg) - - return link - - def _populate_link(self, req: InstallRequirement) -> None: - """Ensure that if a link can be found for this, that it is found. - - Note that req.link may still be None - if the requirement is already - installed and not needed to be upgraded based on the return value of - _is_upgrade_allowed(). - - If preparer.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 req.link is None: - req.link = self._find_requirement_link(req) - - if self.wheel_cache is None or self.preparer.require_hashes: - return - cache_entry = self.wheel_cache.get_cache_entry( - link=req.link, - package_name=req.name, - supported_tags=get_supported(), - ) - if cache_entry is not None: - logger.debug("Using cached wheel link: %s", cache_entry.link) - if req.link is req.original_link and cache_entry.persistent: - req.cached_wheel_source_link = req.link - if cache_entry.origin is not None: - req.download_info = cache_entry.origin - else: - # Legacy cache entry that does not have origin.json. - # download_info may miss the archive_info.hashes field. - req.download_info = direct_url_from_link( - req.link, link_is_in_wheel_cache=cache_entry.persistent - ) - req.link = cache_entry.link - - def _get_dist_for(self, req: InstallRequirement) -> BaseDistribution: - """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) - - # We eagerly populate the link, since that's our "legacy" behavior. - self._populate_link(req) - 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 dist - - def _resolve_one( - self, - requirement_set: RequirementSet, - req_to_install: InstallRequirement, - ) -> 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 - - # Parse and return dependencies - dist = self._get_dist_for(req_to_install) - # 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: List[InstallRequirement] = [] - - def add_req(subreq: Requirement, extras_requested: Iterable[str]) -> None: - # This idiosyncratically converts the Requirement to str and let - # make_install_req then parse it again into Requirement. But this is - # the legacy resolver so I'm just not going to bother refactoring. - sub_install_req = self._make_install_req(str(subreq), req_to_install) - parent_req_name = req_to_install.name - to_scan_again, add_to_parent = self._add_requirement_to_set( - requirement_set, - 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.user_supplied - self._add_requirement_to_set( - requirement_set, 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.iter_provided_extras()) - ) - for missing in missing_requested: - logger.warning( - "%s %s does not provide the extra '%s'", - dist.raw_name, - dist.version, - missing, - ) - - available_requested = sorted( - set(dist.iter_provided_extras()) & set(req_to_install.extras) - ) - for subreq in dist.iter_dependencies(available_requested): - add_req(subreq, extras_requested=available_requested) - - return more_reqs - - def get_installation_order( - self, req_set: 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[InstallRequirement] = set() - - def schedule(req: InstallRequirement) -> None: - 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.12/site-packages/pip/_internal/resolution/resolvelib/__init__.py b/venv/lib/python3.12/site-packages/pip/_internal/resolution/resolvelib/__init__.py deleted file mode 100644 index e69de29..0000000 diff --git a/venv/lib/python3.12/site-packages/pip/_internal/resolution/resolvelib/__pycache__/__init__.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/resolution/resolvelib/__pycache__/__init__.cpython-312.pyc deleted file mode 100644 index e7c425f7351600a58d0cf0c6c86a38bfea3492f9..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 218 zcmZ9GO$x#=5QQ6mK!hH|MLVcl5sGfyh&L$F4t6jmAxQ)E5-#1k^(-F46NtO6OmOFe znfJ}`2IiTj<0R;wUn%-4wtsyFVRK8`WWu(O#Pq`SiJ7j2TAdLLuSjY#s=2@#?a3(( zh4EZw#cq?W1c68CLC_v_>uM$E`E&-B9A=syPW*@#G-)VFIy90CFld!%94YxjkMXz+ f0di%T>$V#$&Z=qzF3m7}!a~^y?>=M9^aFhX71lj2 diff --git a/venv/lib/python3.12/site-packages/pip/_internal/resolution/resolvelib/__pycache__/base.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/resolution/resolvelib/__pycache__/base.cpython-312.pyc deleted file mode 100644 index 2d511a97240acce34172e1a10bc8c532d39cb0ac..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 8347 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 diff --git a/venv/lib/python3.12/site-packages/pip/_internal/resolution/resolvelib/__pycache__/candidates.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/resolution/resolvelib/__pycache__/candidates.cpython-312.pyc deleted file mode 100644 index 55dcc51226d560791709d02b1b9ac28b3cebf830..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 30408 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 diff --git a/venv/lib/python3.12/site-packages/pip/_internal/resolution/resolvelib/__pycache__/factory.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/resolution/resolvelib/__pycache__/factory.cpython-312.pyc deleted file mode 100644 index 0c74cd943eaa3fffa5624538be8560f2302f0eff..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 32124 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 bm>!x9y5?ouLk_P`9VhHM+XIeV)(`(L=&VHF diff --git a/venv/lib/python3.12/site-packages/pip/_internal/resolution/resolvelib/__pycache__/found_candidates.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/resolution/resolvelib/__pycache__/found_candidates.cpython-312.pyc deleted file mode 100644 index ef2409b533a3af2efeb4cd5852279cd97ce81cd9..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6218 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 Ic=A2}2g-wRjsO4v diff --git a/venv/lib/python3.12/site-packages/pip/_internal/resolution/resolvelib/__pycache__/provider.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/resolution/resolvelib/__pycache__/provider.cpython-312.pyc deleted file mode 100644 index ea5a3bc04a685709caf4a49682551b6ef2b84269..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 10388 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 PTKMLr!C!IoW@P;jc7K7J diff --git a/venv/lib/python3.12/site-packages/pip/_internal/resolution/resolvelib/__pycache__/reporter.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/resolution/resolvelib/__pycache__/reporter.cpython-312.pyc deleted file mode 100644 index 40a3494577acd8a7443d223d5e33cf73298eb01e..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4945 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 diff --git a/venv/lib/python3.12/site-packages/pip/_internal/resolution/resolvelib/__pycache__/resolver.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/resolution/resolvelib/__pycache__/resolver.cpython-312.pyc deleted file mode 100644 index bec3aa3c04808dc3a61189c5f5e9bbc5c8b943e7..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 12361 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 C!iazX diff --git a/venv/lib/python3.12/site-packages/pip/_internal/resolution/resolvelib/base.py b/venv/lib/python3.12/site-packages/pip/_internal/resolution/resolvelib/base.py deleted file mode 100644 index 9c0ef5c..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/resolution/resolvelib/base.py +++ /dev/null @@ -1,141 +0,0 @@ -from typing import FrozenSet, Iterable, Optional, Tuple, Union - -from pip._vendor.packaging.specifiers import SpecifierSet -from pip._vendor.packaging.utils import NormalizedName -from pip._vendor.packaging.version import LegacyVersion, Version - -from pip._internal.models.link import Link, links_equivalent -from pip._internal.req.req_install import InstallRequirement -from pip._internal.utils.hashes import Hashes - -CandidateLookup = Tuple[Optional["Candidate"], Optional[InstallRequirement]] -CandidateVersion = Union[LegacyVersion, Version] - - -def format_name(project: NormalizedName, extras: FrozenSet[NormalizedName]) -> str: - if not extras: - return project - extras_expr = ",".join(sorted(extras)) - return f"{project}[{extras_expr}]" - - -class Constraint: - def __init__( - self, specifier: SpecifierSet, hashes: Hashes, links: FrozenSet[Link] - ) -> None: - self.specifier = specifier - self.hashes = hashes - self.links = links - - @classmethod - def empty(cls) -> "Constraint": - return Constraint(SpecifierSet(), Hashes(), frozenset()) - - @classmethod - def from_ireq(cls, ireq: InstallRequirement) -> "Constraint": - links = frozenset([ireq.link]) if ireq.link else frozenset() - return Constraint(ireq.specifier, ireq.hashes(trust_internet=False), links) - - def __bool__(self) -> bool: - return bool(self.specifier) or bool(self.hashes) or bool(self.links) - - def __and__(self, other: InstallRequirement) -> "Constraint": - if not isinstance(other, InstallRequirement): - return NotImplemented - specifier = self.specifier & other.specifier - hashes = self.hashes & other.hashes(trust_internet=False) - links = self.links - if other.link: - links = links.union([other.link]) - return Constraint(specifier, hashes, links) - - def is_satisfied_by(self, candidate: "Candidate") -> bool: - # Reject if there are any mismatched URL constraints on this package. - if self.links and not all(_match_link(link, candidate) for link in self.links): - return False - # We can safely always allow prereleases here since PackageFinder - # already implements the prerelease logic, and would have filtered out - # prerelease candidates if the user does not expect them. - return self.specifier.contains(candidate.version, prereleases=True) - - -class Requirement: - @property - def project_name(self) -> NormalizedName: - """The "project name" of a requirement. - - This is different from ``name`` if this requirement contains extras, - in which case ``name`` would contain the ``[...]`` part, while this - refers to the name of the project. - """ - raise NotImplementedError("Subclass should override") - - @property - def name(self) -> str: - """The name identifying this requirement in the resolver. - - This is different from ``project_name`` if this requirement contains - extras, where ``project_name`` would not contain the ``[...]`` part. - """ - raise NotImplementedError("Subclass should override") - - def is_satisfied_by(self, candidate: "Candidate") -> bool: - return False - - def get_candidate_lookup(self) -> CandidateLookup: - raise NotImplementedError("Subclass should override") - - def format_for_error(self) -> str: - raise NotImplementedError("Subclass should override") - - -def _match_link(link: Link, candidate: "Candidate") -> bool: - if candidate.source_link: - return links_equivalent(link, candidate.source_link) - return False - - -class Candidate: - @property - def project_name(self) -> NormalizedName: - """The "project name" of the candidate. - - This is different from ``name`` if this candidate contains extras, - in which case ``name`` would contain the ``[...]`` part, while this - refers to the name of the project. - """ - raise NotImplementedError("Override in subclass") - - @property - def name(self) -> str: - """The name identifying this candidate in the resolver. - - This is different from ``project_name`` if this candidate contains - extras, where ``project_name`` would not contain the ``[...]`` part. - """ - raise NotImplementedError("Override in subclass") - - @property - def version(self) -> CandidateVersion: - raise NotImplementedError("Override in subclass") - - @property - def is_installed(self) -> bool: - raise NotImplementedError("Override in subclass") - - @property - def is_editable(self) -> bool: - raise NotImplementedError("Override in subclass") - - @property - def source_link(self) -> Optional[Link]: - raise NotImplementedError("Override in subclass") - - def iter_dependencies(self, with_requires: bool) -> Iterable[Optional[Requirement]]: - raise NotImplementedError("Override in subclass") - - def get_install_requirement(self) -> Optional[InstallRequirement]: - raise NotImplementedError("Override in subclass") - - def format_for_error(self) -> str: - raise NotImplementedError("Subclass should override") diff --git a/venv/lib/python3.12/site-packages/pip/_internal/resolution/resolvelib/candidates.py b/venv/lib/python3.12/site-packages/pip/_internal/resolution/resolvelib/candidates.py deleted file mode 100644 index 4125cda..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/resolution/resolvelib/candidates.py +++ /dev/null @@ -1,597 +0,0 @@ -import logging -import sys -from typing import TYPE_CHECKING, Any, FrozenSet, Iterable, Optional, Tuple, Union, cast - -from pip._vendor.packaging.utils import NormalizedName, canonicalize_name -from pip._vendor.packaging.version import Version - -from pip._internal.exceptions import ( - HashError, - InstallationSubprocessError, - MetadataInconsistent, -) -from pip._internal.metadata import BaseDistribution -from pip._internal.models.link import Link, links_equivalent -from pip._internal.models.wheel import Wheel -from pip._internal.req.constructors import ( - install_req_from_editable, - install_req_from_line, -) -from pip._internal.req.req_install import InstallRequirement -from pip._internal.utils.direct_url_helpers import direct_url_from_link -from pip._internal.utils.misc import normalize_version_info - -from .base import Candidate, CandidateVersion, Requirement, format_name - -if TYPE_CHECKING: - from .factory import Factory - -logger = logging.getLogger(__name__) - -BaseCandidate = Union[ - "AlreadyInstalledCandidate", - "EditableCandidate", - "LinkCandidate", -] - -# Avoid conflicting with the PyPI package "Python". -REQUIRES_PYTHON_IDENTIFIER = cast(NormalizedName, "") - - -def as_base_candidate(candidate: Candidate) -> Optional[BaseCandidate]: - """The runtime version of BaseCandidate.""" - base_candidate_classes = ( - AlreadyInstalledCandidate, - EditableCandidate, - LinkCandidate, - ) - if isinstance(candidate, base_candidate_classes): - return candidate - return None - - -def make_install_req_from_link( - link: Link, template: InstallRequirement -) -> InstallRequirement: - assert not template.editable, "template is editable" - if template.req: - line = str(template.req) - else: - line = link.url - ireq = install_req_from_line( - line, - user_supplied=template.user_supplied, - comes_from=template.comes_from, - use_pep517=template.use_pep517, - isolated=template.isolated, - constraint=template.constraint, - global_options=template.global_options, - hash_options=template.hash_options, - config_settings=template.config_settings, - ) - ireq.original_link = template.original_link - ireq.link = link - ireq.extras = template.extras - return ireq - - -def make_install_req_from_editable( - link: Link, template: InstallRequirement -) -> InstallRequirement: - assert template.editable, "template not editable" - ireq = install_req_from_editable( - link.url, - user_supplied=template.user_supplied, - comes_from=template.comes_from, - use_pep517=template.use_pep517, - isolated=template.isolated, - constraint=template.constraint, - permit_editable_wheels=template.permit_editable_wheels, - global_options=template.global_options, - hash_options=template.hash_options, - config_settings=template.config_settings, - ) - ireq.extras = template.extras - return ireq - - -def _make_install_req_from_dist( - dist: BaseDistribution, template: InstallRequirement -) -> InstallRequirement: - if template.req: - line = str(template.req) - elif template.link: - line = f"{dist.canonical_name} @ {template.link.url}" - else: - line = f"{dist.canonical_name}=={dist.version}" - ireq = install_req_from_line( - line, - user_supplied=template.user_supplied, - comes_from=template.comes_from, - use_pep517=template.use_pep517, - isolated=template.isolated, - constraint=template.constraint, - global_options=template.global_options, - hash_options=template.hash_options, - config_settings=template.config_settings, - ) - ireq.satisfied_by = dist - return ireq - - -class _InstallRequirementBackedCandidate(Candidate): - """A candidate backed by an ``InstallRequirement``. - - This represents a package request with the target not being already - in the environment, and needs to be fetched and installed. The backing - ``InstallRequirement`` is responsible for most of the leg work; this - class exposes appropriate information to the resolver. - - :param link: The link passed to the ``InstallRequirement``. The backing - ``InstallRequirement`` will use this link to fetch the distribution. - :param source_link: The link this candidate "originates" from. This is - different from ``link`` when the link is found in the wheel cache. - ``link`` would point to the wheel cache, while this points to the - found remote link (e.g. from pypi.org). - """ - - dist: BaseDistribution - is_installed = False - - def __init__( - self, - link: Link, - source_link: Link, - ireq: InstallRequirement, - factory: "Factory", - name: Optional[NormalizedName] = None, - version: Optional[CandidateVersion] = None, - ) -> None: - self._link = link - self._source_link = source_link - self._factory = factory - self._ireq = ireq - self._name = name - self._version = version - self.dist = self._prepare() - - def __str__(self) -> str: - return f"{self.name} {self.version}" - - def __repr__(self) -> str: - return f"{self.__class__.__name__}({str(self._link)!r})" - - def __hash__(self) -> int: - return hash((self.__class__, self._link)) - - def __eq__(self, other: Any) -> bool: - if isinstance(other, self.__class__): - return links_equivalent(self._link, other._link) - return False - - @property - def source_link(self) -> Optional[Link]: - return self._source_link - - @property - def project_name(self) -> NormalizedName: - """The normalised name of the project the candidate refers to""" - if self._name is None: - self._name = self.dist.canonical_name - return self._name - - @property - def name(self) -> str: - return self.project_name - - @property - def version(self) -> CandidateVersion: - if self._version is None: - self._version = self.dist.version - return self._version - - def format_for_error(self) -> str: - return "{} {} (from {})".format( - self.name, - self.version, - self._link.file_path if self._link.is_file else self._link, - ) - - def _prepare_distribution(self) -> BaseDistribution: - raise NotImplementedError("Override in subclass") - - def _check_metadata_consistency(self, dist: BaseDistribution) -> None: - """Check for consistency of project name and version of dist.""" - if self._name is not None and self._name != dist.canonical_name: - raise MetadataInconsistent( - self._ireq, - "name", - self._name, - dist.canonical_name, - ) - if self._version is not None and self._version != dist.version: - raise MetadataInconsistent( - self._ireq, - "version", - str(self._version), - str(dist.version), - ) - - def _prepare(self) -> BaseDistribution: - try: - dist = self._prepare_distribution() - except HashError as e: - # Provide HashError the underlying ireq that caused it. This - # provides context for the resulting error message to show the - # offending line to the user. - e.req = self._ireq - raise - except InstallationSubprocessError as exc: - # The output has been presented already, so don't duplicate it. - exc.context = "See above for output." - raise - - self._check_metadata_consistency(dist) - return dist - - def iter_dependencies(self, with_requires: bool) -> Iterable[Optional[Requirement]]: - requires = self.dist.iter_dependencies() if with_requires else () - for r in requires: - yield from self._factory.make_requirements_from_spec(str(r), self._ireq) - yield self._factory.make_requires_python_requirement(self.dist.requires_python) - - def get_install_requirement(self) -> Optional[InstallRequirement]: - return self._ireq - - -class LinkCandidate(_InstallRequirementBackedCandidate): - is_editable = False - - def __init__( - self, - link: Link, - template: InstallRequirement, - factory: "Factory", - name: Optional[NormalizedName] = None, - version: Optional[CandidateVersion] = None, - ) -> None: - source_link = link - cache_entry = factory.get_wheel_cache_entry(source_link, name) - if cache_entry is not None: - logger.debug("Using cached wheel link: %s", cache_entry.link) - link = cache_entry.link - ireq = make_install_req_from_link(link, template) - assert ireq.link == link - if ireq.link.is_wheel and not ireq.link.is_file: - wheel = Wheel(ireq.link.filename) - wheel_name = canonicalize_name(wheel.name) - assert name == wheel_name, f"{name!r} != {wheel_name!r} for wheel" - # Version may not be present for PEP 508 direct URLs - if version is not None: - wheel_version = Version(wheel.version) - assert version == wheel_version, "{!r} != {!r} for wheel {}".format( - version, wheel_version, name - ) - - if cache_entry is not None: - assert ireq.link.is_wheel - assert ireq.link.is_file - if cache_entry.persistent and template.link is template.original_link: - ireq.cached_wheel_source_link = source_link - if cache_entry.origin is not None: - ireq.download_info = cache_entry.origin - else: - # Legacy cache entry that does not have origin.json. - # download_info may miss the archive_info.hashes field. - ireq.download_info = direct_url_from_link( - source_link, link_is_in_wheel_cache=cache_entry.persistent - ) - - super().__init__( - link=link, - source_link=source_link, - ireq=ireq, - factory=factory, - name=name, - version=version, - ) - - def _prepare_distribution(self) -> BaseDistribution: - preparer = self._factory.preparer - return preparer.prepare_linked_requirement(self._ireq, parallel_builds=True) - - -class EditableCandidate(_InstallRequirementBackedCandidate): - is_editable = True - - def __init__( - self, - link: Link, - template: InstallRequirement, - factory: "Factory", - name: Optional[NormalizedName] = None, - version: Optional[CandidateVersion] = None, - ) -> None: - super().__init__( - link=link, - source_link=link, - ireq=make_install_req_from_editable(link, template), - factory=factory, - name=name, - version=version, - ) - - def _prepare_distribution(self) -> BaseDistribution: - return self._factory.preparer.prepare_editable_requirement(self._ireq) - - -class AlreadyInstalledCandidate(Candidate): - is_installed = True - source_link = None - - def __init__( - self, - dist: BaseDistribution, - template: InstallRequirement, - factory: "Factory", - ) -> None: - self.dist = dist - self._ireq = _make_install_req_from_dist(dist, template) - self._factory = factory - self._version = None - - # This is just logging some messages, so we can do it eagerly. - # The returned dist would be exactly the same as self.dist because we - # set satisfied_by in _make_install_req_from_dist. - # TODO: Supply reason based on force_reinstall and upgrade_strategy. - skip_reason = "already satisfied" - factory.preparer.prepare_installed_requirement(self._ireq, skip_reason) - - def __str__(self) -> str: - return str(self.dist) - - def __repr__(self) -> str: - return f"{self.__class__.__name__}({self.dist!r})" - - def __hash__(self) -> int: - return hash((self.__class__, self.name, self.version)) - - def __eq__(self, other: Any) -> bool: - if isinstance(other, self.__class__): - return self.name == other.name and self.version == other.version - return False - - @property - def project_name(self) -> NormalizedName: - return self.dist.canonical_name - - @property - def name(self) -> str: - return self.project_name - - @property - def version(self) -> CandidateVersion: - if self._version is None: - self._version = self.dist.version - return self._version - - @property - def is_editable(self) -> bool: - return self.dist.editable - - def format_for_error(self) -> str: - return f"{self.name} {self.version} (Installed)" - - def iter_dependencies(self, with_requires: bool) -> Iterable[Optional[Requirement]]: - if not with_requires: - return - for r in self.dist.iter_dependencies(): - yield from self._factory.make_requirements_from_spec(str(r), self._ireq) - - def get_install_requirement(self) -> Optional[InstallRequirement]: - return None - - -class ExtrasCandidate(Candidate): - """A candidate that has 'extras', indicating additional dependencies. - - Requirements can be for a project with dependencies, something like - foo[extra]. The extras don't affect the project/version being installed - directly, but indicate that we need additional dependencies. We model that - by having an artificial ExtrasCandidate that wraps the "base" candidate. - - The ExtrasCandidate differs from the base in the following ways: - - 1. It has a unique name, of the form foo[extra]. This causes the resolver - to treat it as a separate node in the dependency graph. - 2. When we're getting the candidate's dependencies, - a) We specify that we want the extra dependencies as well. - b) We add a dependency on the base candidate. - See below for why this is needed. - 3. We return None for the underlying InstallRequirement, as the base - candidate will provide it, and we don't want to end up with duplicates. - - The dependency on the base candidate is needed so that the resolver can't - decide that it should recommend foo[extra1] version 1.0 and foo[extra2] - version 2.0. Having those candidates depend on foo=1.0 and foo=2.0 - respectively forces the resolver to recognise that this is a conflict. - """ - - def __init__( - self, - base: BaseCandidate, - extras: FrozenSet[str], - *, - comes_from: Optional[InstallRequirement] = None, - ) -> None: - """ - :param comes_from: the InstallRequirement that led to this candidate if it - differs from the base's InstallRequirement. This will often be the - case in the sense that this candidate's requirement has the extras - while the base's does not. Unlike the InstallRequirement backed - candidates, this requirement is used solely for reporting purposes, - it does not do any leg work. - """ - self.base = base - self.extras = frozenset(canonicalize_name(e) for e in extras) - # If any extras are requested in their non-normalized forms, keep track - # of their raw values. This is needed when we look up dependencies - # since PEP 685 has not been implemented for marker-matching, and using - # the non-normalized extra for lookup ensures the user can select a - # non-normalized extra in a package with its non-normalized form. - # TODO: Remove this attribute when packaging is upgraded to support the - # marker comparison logic specified in PEP 685. - self._unnormalized_extras = extras.difference(self.extras) - self._comes_from = comes_from if comes_from is not None else self.base._ireq - - def __str__(self) -> str: - name, rest = str(self.base).split(" ", 1) - return "{}[{}] {}".format(name, ",".join(self.extras), rest) - - def __repr__(self) -> str: - return f"{self.__class__.__name__}(base={self.base!r}, extras={self.extras!r})" - - def __hash__(self) -> int: - return hash((self.base, self.extras)) - - def __eq__(self, other: Any) -> bool: - if isinstance(other, self.__class__): - return self.base == other.base and self.extras == other.extras - return False - - @property - def project_name(self) -> NormalizedName: - return self.base.project_name - - @property - def name(self) -> str: - """The normalised name of the project the candidate refers to""" - return format_name(self.base.project_name, self.extras) - - @property - def version(self) -> CandidateVersion: - return self.base.version - - def format_for_error(self) -> str: - return "{} [{}]".format( - self.base.format_for_error(), ", ".join(sorted(self.extras)) - ) - - @property - def is_installed(self) -> bool: - return self.base.is_installed - - @property - def is_editable(self) -> bool: - return self.base.is_editable - - @property - def source_link(self) -> Optional[Link]: - return self.base.source_link - - def _warn_invalid_extras( - self, - requested: FrozenSet[str], - valid: FrozenSet[str], - ) -> None: - """Emit warnings for invalid extras being requested. - - This emits a warning for each requested extra that is not in the - candidate's ``Provides-Extra`` list. - """ - invalid_extras_to_warn = frozenset( - extra - for extra in requested - if extra not in valid - # If an extra is requested in an unnormalized form, skip warning - # about the normalized form being missing. - and extra in self.extras - ) - if not invalid_extras_to_warn: - return - for extra in sorted(invalid_extras_to_warn): - logger.warning( - "%s %s does not provide the extra '%s'", - self.base.name, - self.version, - extra, - ) - - def _calculate_valid_requested_extras(self) -> FrozenSet[str]: - """Get a list of valid extras requested by this candidate. - - The user (or upstream dependant) may have specified extras that the - candidate doesn't support. Any unsupported extras are dropped, and each - cause a warning to be logged here. - """ - requested_extras = self.extras.union(self._unnormalized_extras) - valid_extras = frozenset( - extra - for extra in requested_extras - if self.base.dist.is_extra_provided(extra) - ) - self._warn_invalid_extras(requested_extras, valid_extras) - return valid_extras - - def iter_dependencies(self, with_requires: bool) -> Iterable[Optional[Requirement]]: - factory = self.base._factory - - # Add a dependency on the exact base - # (See note 2b in the class docstring) - yield factory.make_requirement_from_candidate(self.base) - if not with_requires: - return - - valid_extras = self._calculate_valid_requested_extras() - for r in self.base.dist.iter_dependencies(valid_extras): - yield from factory.make_requirements_from_spec( - str(r), - self._comes_from, - valid_extras, - ) - - def get_install_requirement(self) -> Optional[InstallRequirement]: - # We don't return anything here, because we always - # depend on the base candidate, and we'll get the - # install requirement from that. - return None - - -class RequiresPythonCandidate(Candidate): - is_installed = False - source_link = None - - def __init__(self, py_version_info: Optional[Tuple[int, ...]]) -> None: - if py_version_info is not None: - version_info = normalize_version_info(py_version_info) - else: - version_info = sys.version_info[:3] - self._version = Version(".".join(str(c) for c in version_info)) - - # We don't need to implement __eq__() and __ne__() since there is always - # only one RequiresPythonCandidate in a resolution, i.e. the host Python. - # The built-in object.__eq__() and object.__ne__() do exactly what we want. - - def __str__(self) -> str: - return f"Python {self._version}" - - @property - def project_name(self) -> NormalizedName: - return REQUIRES_PYTHON_IDENTIFIER - - @property - def name(self) -> str: - return REQUIRES_PYTHON_IDENTIFIER - - @property - def version(self) -> CandidateVersion: - return self._version - - def format_for_error(self) -> str: - return f"Python {self.version}" - - def iter_dependencies(self, with_requires: bool) -> Iterable[Optional[Requirement]]: - return () - - def get_install_requirement(self) -> Optional[InstallRequirement]: - return None diff --git a/venv/lib/python3.12/site-packages/pip/_internal/resolution/resolvelib/factory.py b/venv/lib/python3.12/site-packages/pip/_internal/resolution/resolvelib/factory.py deleted file mode 100644 index 4adeb43..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/resolution/resolvelib/factory.py +++ /dev/null @@ -1,812 +0,0 @@ -import contextlib -import functools -import logging -from typing import ( - TYPE_CHECKING, - Dict, - FrozenSet, - Iterable, - Iterator, - List, - Mapping, - NamedTuple, - Optional, - Sequence, - Set, - Tuple, - TypeVar, - cast, -) - -from pip._vendor.packaging.requirements import InvalidRequirement -from pip._vendor.packaging.specifiers import SpecifierSet -from pip._vendor.packaging.utils import NormalizedName, canonicalize_name -from pip._vendor.resolvelib import ResolutionImpossible - -from pip._internal.cache import CacheEntry, WheelCache -from pip._internal.exceptions import ( - DistributionNotFound, - InstallationError, - MetadataInconsistent, - UnsupportedPythonVersion, - UnsupportedWheel, -) -from pip._internal.index.package_finder import PackageFinder -from pip._internal.metadata import BaseDistribution, get_default_environment -from pip._internal.models.link import Link -from pip._internal.models.wheel import Wheel -from pip._internal.operations.prepare import RequirementPreparer -from pip._internal.req.constructors import ( - install_req_drop_extras, - install_req_from_link_and_ireq, -) -from pip._internal.req.req_install import ( - InstallRequirement, - check_invalid_constraint_type, -) -from pip._internal.resolution.base import InstallRequirementProvider -from pip._internal.utils.compatibility_tags import get_supported -from pip._internal.utils.hashes import Hashes -from pip._internal.utils.packaging import get_requirement -from pip._internal.utils.virtualenv import running_under_virtualenv - -from .base import Candidate, CandidateVersion, Constraint, Requirement -from .candidates import ( - AlreadyInstalledCandidate, - BaseCandidate, - EditableCandidate, - ExtrasCandidate, - LinkCandidate, - RequiresPythonCandidate, - as_base_candidate, -) -from .found_candidates import FoundCandidates, IndexCandidateInfo -from .requirements import ( - ExplicitRequirement, - RequiresPythonRequirement, - SpecifierRequirement, - SpecifierWithoutExtrasRequirement, - UnsatisfiableRequirement, -) - -if TYPE_CHECKING: - from typing import Protocol - - class ConflictCause(Protocol): - requirement: RequiresPythonRequirement - parent: Candidate - - -logger = logging.getLogger(__name__) - -C = TypeVar("C") -Cache = Dict[Link, C] - - -class CollectedRootRequirements(NamedTuple): - requirements: List[Requirement] - constraints: Dict[str, Constraint] - user_requested: Dict[str, int] - - -class Factory: - def __init__( - self, - finder: PackageFinder, - preparer: RequirementPreparer, - make_install_req: InstallRequirementProvider, - wheel_cache: Optional[WheelCache], - use_user_site: bool, - force_reinstall: bool, - ignore_installed: bool, - ignore_requires_python: bool, - py_version_info: Optional[Tuple[int, ...]] = None, - ) -> None: - self._finder = finder - self.preparer = preparer - self._wheel_cache = wheel_cache - self._python_candidate = RequiresPythonCandidate(py_version_info) - self._make_install_req_from_spec = make_install_req - self._use_user_site = use_user_site - self._force_reinstall = force_reinstall - self._ignore_requires_python = ignore_requires_python - - self._build_failures: Cache[InstallationError] = {} - self._link_candidate_cache: Cache[LinkCandidate] = {} - self._editable_candidate_cache: Cache[EditableCandidate] = {} - self._installed_candidate_cache: Dict[str, AlreadyInstalledCandidate] = {} - self._extras_candidate_cache: Dict[ - Tuple[int, FrozenSet[NormalizedName]], ExtrasCandidate - ] = {} - - if not ignore_installed: - env = get_default_environment() - self._installed_dists = { - dist.canonical_name: dist - for dist in env.iter_installed_distributions(local_only=False) - } - else: - self._installed_dists = {} - - @property - def force_reinstall(self) -> bool: - return self._force_reinstall - - def _fail_if_link_is_unsupported_wheel(self, link: Link) -> None: - if not link.is_wheel: - return - wheel = Wheel(link.filename) - if wheel.supported(self._finder.target_python.get_unsorted_tags()): - return - msg = f"{link.filename} is not a supported wheel on this platform." - raise UnsupportedWheel(msg) - - def _make_extras_candidate( - self, - base: BaseCandidate, - extras: FrozenSet[str], - *, - comes_from: Optional[InstallRequirement] = None, - ) -> ExtrasCandidate: - cache_key = (id(base), frozenset(canonicalize_name(e) for e in extras)) - try: - candidate = self._extras_candidate_cache[cache_key] - except KeyError: - candidate = ExtrasCandidate(base, extras, comes_from=comes_from) - self._extras_candidate_cache[cache_key] = candidate - return candidate - - def _make_candidate_from_dist( - self, - dist: BaseDistribution, - extras: FrozenSet[str], - template: InstallRequirement, - ) -> Candidate: - try: - base = self._installed_candidate_cache[dist.canonical_name] - except KeyError: - base = AlreadyInstalledCandidate(dist, template, factory=self) - self._installed_candidate_cache[dist.canonical_name] = base - if not extras: - return base - return self._make_extras_candidate(base, extras, comes_from=template) - - def _make_candidate_from_link( - self, - link: Link, - extras: FrozenSet[str], - template: InstallRequirement, - name: Optional[NormalizedName], - version: Optional[CandidateVersion], - ) -> Optional[Candidate]: - base: Optional[BaseCandidate] = self._make_base_candidate_from_link( - link, template, name, version - ) - if not extras or base is None: - return base - return self._make_extras_candidate(base, extras, comes_from=template) - - def _make_base_candidate_from_link( - self, - link: Link, - template: InstallRequirement, - name: Optional[NormalizedName], - version: Optional[CandidateVersion], - ) -> Optional[BaseCandidate]: - # TODO: Check already installed candidate, and use it if the link and - # editable flag match. - - if link in self._build_failures: - # We already tried this candidate before, and it does not build. - # Don't bother trying again. - return None - - if template.editable: - if link not in self._editable_candidate_cache: - try: - self._editable_candidate_cache[link] = EditableCandidate( - link, - template, - factory=self, - name=name, - version=version, - ) - except MetadataInconsistent as e: - logger.info( - "Discarding [blue underline]%s[/]: [yellow]%s[reset]", - link, - e, - extra={"markup": True}, - ) - self._build_failures[link] = e - return None - - return self._editable_candidate_cache[link] - else: - if link not in self._link_candidate_cache: - try: - self._link_candidate_cache[link] = LinkCandidate( - link, - template, - factory=self, - name=name, - version=version, - ) - except MetadataInconsistent as e: - logger.info( - "Discarding [blue underline]%s[/]: [yellow]%s[reset]", - link, - e, - extra={"markup": True}, - ) - self._build_failures[link] = e - return None - return self._link_candidate_cache[link] - - def _iter_found_candidates( - self, - ireqs: Sequence[InstallRequirement], - specifier: SpecifierSet, - hashes: Hashes, - prefers_installed: bool, - incompatible_ids: Set[int], - ) -> Iterable[Candidate]: - if not ireqs: - return () - - # The InstallRequirement implementation requires us to give it a - # "template". Here we just choose the first requirement to represent - # all of them. - # Hopefully the Project model can correct this mismatch in the future. - template = ireqs[0] - assert template.req, "Candidates found on index must be PEP 508" - name = canonicalize_name(template.req.name) - - extras: FrozenSet[str] = frozenset() - for ireq in ireqs: - assert ireq.req, "Candidates found on index must be PEP 508" - specifier &= ireq.req.specifier - hashes &= ireq.hashes(trust_internet=False) - extras |= frozenset(ireq.extras) - - def _get_installed_candidate() -> Optional[Candidate]: - """Get the candidate for the currently-installed version.""" - # If --force-reinstall is set, we want the version from the index - # instead, so we "pretend" there is nothing installed. - if self._force_reinstall: - return None - try: - installed_dist = self._installed_dists[name] - except KeyError: - return None - # Don't use the installed distribution if its version does not fit - # the current dependency graph. - if not specifier.contains(installed_dist.version, prereleases=True): - return None - candidate = self._make_candidate_from_dist( - dist=installed_dist, - extras=extras, - template=template, - ) - # The candidate is a known incompatibility. Don't use it. - if id(candidate) in incompatible_ids: - return None - return candidate - - def iter_index_candidate_infos() -> Iterator[IndexCandidateInfo]: - result = self._finder.find_best_candidate( - project_name=name, - specifier=specifier, - hashes=hashes, - ) - icans = list(result.iter_applicable()) - - # PEP 592: Yanked releases are ignored unless the specifier - # explicitly pins a version (via '==' or '===') that can be - # solely satisfied by a yanked release. - all_yanked = all(ican.link.is_yanked for ican in icans) - - def is_pinned(specifier: SpecifierSet) -> bool: - for sp in specifier: - if sp.operator == "===": - return True - if sp.operator != "==": - continue - if sp.version.endswith(".*"): - continue - return True - return False - - pinned = is_pinned(specifier) - - # PackageFinder returns earlier versions first, so we reverse. - for ican in reversed(icans): - if not (all_yanked and pinned) and ican.link.is_yanked: - continue - func = functools.partial( - self._make_candidate_from_link, - link=ican.link, - extras=extras, - template=template, - name=name, - version=ican.version, - ) - yield ican.version, func - - return FoundCandidates( - iter_index_candidate_infos, - _get_installed_candidate(), - prefers_installed, - incompatible_ids, - ) - - def _iter_explicit_candidates_from_base( - self, - base_requirements: Iterable[Requirement], - extras: FrozenSet[str], - ) -> Iterator[Candidate]: - """Produce explicit candidates from the base given an extra-ed package. - - :param base_requirements: Requirements known to the resolver. The - requirements are guaranteed to not have extras. - :param extras: The extras to inject into the explicit requirements' - candidates. - """ - for req in base_requirements: - lookup_cand, _ = req.get_candidate_lookup() - if lookup_cand is None: # Not explicit. - continue - # We've stripped extras from the identifier, and should always - # get a BaseCandidate here, unless there's a bug elsewhere. - base_cand = as_base_candidate(lookup_cand) - assert base_cand is not None, "no extras here" - yield self._make_extras_candidate(base_cand, extras) - - def _iter_candidates_from_constraints( - self, - identifier: str, - constraint: Constraint, - template: InstallRequirement, - ) -> Iterator[Candidate]: - """Produce explicit candidates from constraints. - - This creates "fake" InstallRequirement objects that are basically clones - of what "should" be the template, but with original_link set to link. - """ - for link in constraint.links: - self._fail_if_link_is_unsupported_wheel(link) - candidate = self._make_base_candidate_from_link( - link, - template=install_req_from_link_and_ireq(link, template), - name=canonicalize_name(identifier), - version=None, - ) - if candidate: - yield candidate - - def find_candidates( - self, - identifier: str, - requirements: Mapping[str, Iterable[Requirement]], - incompatibilities: Mapping[str, Iterator[Candidate]], - constraint: Constraint, - prefers_installed: bool, - ) -> Iterable[Candidate]: - # Collect basic lookup information from the requirements. - explicit_candidates: Set[Candidate] = set() - ireqs: List[InstallRequirement] = [] - for req in requirements[identifier]: - cand, ireq = req.get_candidate_lookup() - if cand is not None: - explicit_candidates.add(cand) - if ireq is not None: - ireqs.append(ireq) - - # If the current identifier contains extras, add requires and explicit - # candidates from entries from extra-less identifier. - with contextlib.suppress(InvalidRequirement): - parsed_requirement = get_requirement(identifier) - if parsed_requirement.name != identifier: - explicit_candidates.update( - self._iter_explicit_candidates_from_base( - requirements.get(parsed_requirement.name, ()), - frozenset(parsed_requirement.extras), - ), - ) - for req in requirements.get(parsed_requirement.name, []): - _, ireq = req.get_candidate_lookup() - if ireq is not None: - ireqs.append(ireq) - - # Add explicit candidates from constraints. We only do this if there are - # known ireqs, which represent requirements not already explicit. If - # there are no ireqs, we're constraining already-explicit requirements, - # which is handled later when we return the explicit candidates. - if ireqs: - try: - explicit_candidates.update( - self._iter_candidates_from_constraints( - identifier, - constraint, - template=ireqs[0], - ), - ) - except UnsupportedWheel: - # If we're constrained to install a wheel incompatible with the - # target architecture, no candidates will ever be valid. - return () - - # Since we cache all the candidates, incompatibility identification - # can be made quicker by comparing only the id() values. - incompat_ids = {id(c) for c in incompatibilities.get(identifier, ())} - - # If none of the requirements want an explicit candidate, we can ask - # the finder for candidates. - if not explicit_candidates: - return self._iter_found_candidates( - ireqs, - constraint.specifier, - constraint.hashes, - prefers_installed, - incompat_ids, - ) - - return ( - c - for c in explicit_candidates - if id(c) not in incompat_ids - and constraint.is_satisfied_by(c) - and all(req.is_satisfied_by(c) for req in requirements[identifier]) - ) - - def _make_requirements_from_install_req( - self, ireq: InstallRequirement, requested_extras: Iterable[str] - ) -> Iterator[Requirement]: - """ - Returns requirement objects associated with the given InstallRequirement. In - most cases this will be a single object but the following special cases exist: - - the InstallRequirement has markers that do not apply -> result is empty - - the InstallRequirement has both a constraint (or link) and extras - -> result is split in two requirement objects: one with the constraint - (or link) and one with the extra. This allows centralized constraint - handling for the base, resulting in fewer candidate rejections. - """ - if not ireq.match_markers(requested_extras): - logger.info( - "Ignoring %s: markers '%s' don't match your environment", - ireq.name, - ireq.markers, - ) - elif not ireq.link: - if ireq.extras and ireq.req is not None and ireq.req.specifier: - yield SpecifierWithoutExtrasRequirement(ireq) - yield SpecifierRequirement(ireq) - else: - self._fail_if_link_is_unsupported_wheel(ireq.link) - # Always make the link candidate for the base requirement to make it - # available to `find_candidates` for explicit candidate lookup for any - # set of extras. - # The extras are required separately via a second requirement. - cand = self._make_base_candidate_from_link( - ireq.link, - template=install_req_drop_extras(ireq) if ireq.extras else ireq, - name=canonicalize_name(ireq.name) if ireq.name else None, - version=None, - ) - if cand is None: - # There's no way we can satisfy a URL requirement if the underlying - # candidate fails to build. An unnamed URL must be user-supplied, so - # we fail eagerly. If the URL is named, an unsatisfiable requirement - # can make the resolver do the right thing, either backtrack (and - # maybe find some other requirement that's buildable) or raise a - # ResolutionImpossible eventually. - if not ireq.name: - raise self._build_failures[ireq.link] - yield UnsatisfiableRequirement(canonicalize_name(ireq.name)) - else: - # require the base from the link - yield self.make_requirement_from_candidate(cand) - if ireq.extras: - # require the extras on top of the base candidate - yield self.make_requirement_from_candidate( - self._make_extras_candidate(cand, frozenset(ireq.extras)) - ) - - def collect_root_requirements( - self, root_ireqs: List[InstallRequirement] - ) -> CollectedRootRequirements: - collected = CollectedRootRequirements([], {}, {}) - for i, ireq in enumerate(root_ireqs): - if ireq.constraint: - # Ensure we only accept valid constraints - problem = check_invalid_constraint_type(ireq) - if problem: - raise InstallationError(problem) - if not ireq.match_markers(): - continue - assert ireq.name, "Constraint must be named" - name = canonicalize_name(ireq.name) - if name in collected.constraints: - collected.constraints[name] &= ireq - else: - collected.constraints[name] = Constraint.from_ireq(ireq) - else: - reqs = list( - self._make_requirements_from_install_req( - ireq, - requested_extras=(), - ) - ) - if not reqs: - continue - template = reqs[0] - if ireq.user_supplied and template.name not in collected.user_requested: - collected.user_requested[template.name] = i - collected.requirements.extend(reqs) - # Put requirements with extras at the end of the root requires. This does not - # affect resolvelib's picking preference but it does affect its initial criteria - # population: by putting extras at the end we enable the candidate finder to - # present resolvelib with a smaller set of candidates to resolvelib, already - # taking into account any non-transient constraints on the associated base. This - # means resolvelib will have fewer candidates to visit and reject. - # Python's list sort is stable, meaning relative order is kept for objects with - # the same key. - collected.requirements.sort(key=lambda r: r.name != r.project_name) - return collected - - def make_requirement_from_candidate( - self, candidate: Candidate - ) -> ExplicitRequirement: - return ExplicitRequirement(candidate) - - def make_requirements_from_spec( - self, - specifier: str, - comes_from: Optional[InstallRequirement], - requested_extras: Iterable[str] = (), - ) -> Iterator[Requirement]: - """ - Returns requirement objects associated with the given specifier. In most cases - this will be a single object but the following special cases exist: - - the specifier has markers that do not apply -> result is empty - - the specifier has both a constraint and extras -> result is split - in two requirement objects: one with the constraint and one with the - extra. This allows centralized constraint handling for the base, - resulting in fewer candidate rejections. - """ - ireq = self._make_install_req_from_spec(specifier, comes_from) - return self._make_requirements_from_install_req(ireq, requested_extras) - - def make_requires_python_requirement( - self, - specifier: SpecifierSet, - ) -> Optional[Requirement]: - if self._ignore_requires_python: - return None - # Don't bother creating a dependency for an empty Requires-Python. - if not str(specifier): - return None - return RequiresPythonRequirement(specifier, self._python_candidate) - - def get_wheel_cache_entry( - self, link: Link, name: Optional[str] - ) -> Optional[CacheEntry]: - """Look up the link in the wheel cache. - - If ``preparer.require_hashes`` is True, don't use the wheel cache, - 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 - nondeterministic contents due to file modification times. - """ - if self._wheel_cache is None: - return None - return self._wheel_cache.get_cache_entry( - link=link, - package_name=name, - supported_tags=get_supported(), - ) - - def get_dist_to_uninstall(self, candidate: Candidate) -> Optional[BaseDistribution]: - # TODO: Are there more cases this needs to return True? Editable? - dist = self._installed_dists.get(candidate.project_name) - if dist is None: # Not installed, no uninstallation required. - return None - - # We're installing into global site. The current installation must - # be uninstalled, no matter it's in global or user site, because the - # user site installation has precedence over global. - if not self._use_user_site: - return dist - - # We're installing into user site. Remove the user site installation. - if dist.in_usersite: - return dist - - # We're installing into user site, but the installed incompatible - # package is in global site. We can't uninstall that, and would let - # the new user installation to "shadow" it. But shadowing won't work - # in virtual environments, so we error out. - if running_under_virtualenv() and dist.in_site_packages: - message = ( - f"Will not install to the user site because it will lack " - f"sys.path precedence to {dist.raw_name} in {dist.location}" - ) - raise InstallationError(message) - return None - - def _report_requires_python_error( - self, causes: Sequence["ConflictCause"] - ) -> UnsupportedPythonVersion: - assert causes, "Requires-Python error reported with no cause" - - version = self._python_candidate.version - - if len(causes) == 1: - specifier = str(causes[0].requirement.specifier) - message = ( - f"Package {causes[0].parent.name!r} requires a different " - f"Python: {version} not in {specifier!r}" - ) - return UnsupportedPythonVersion(message) - - message = f"Packages require a different Python. {version} not in:" - for cause in causes: - package = cause.parent.format_for_error() - specifier = str(cause.requirement.specifier) - message += f"\n{specifier!r} (required by {package})" - return UnsupportedPythonVersion(message) - - def _report_single_requirement_conflict( - self, req: Requirement, parent: Optional[Candidate] - ) -> DistributionNotFound: - if parent is None: - req_disp = str(req) - else: - req_disp = f"{req} (from {parent.name})" - - cands = self._finder.find_all_candidates(req.project_name) - skipped_by_requires_python = self._finder.requires_python_skipped_reasons() - - versions_set: Set[CandidateVersion] = set() - yanked_versions_set: Set[CandidateVersion] = set() - for c in cands: - is_yanked = c.link.is_yanked if c.link else False - if is_yanked: - yanked_versions_set.add(c.version) - else: - versions_set.add(c.version) - - versions = [str(v) for v in sorted(versions_set)] - yanked_versions = [str(v) for v in sorted(yanked_versions_set)] - - if yanked_versions: - # Saying "version X is yanked" isn't entirely accurate. - # https://github.com/pypa/pip/issues/11745#issuecomment-1402805842 - logger.critical( - "Ignored the following yanked versions: %s", - ", ".join(yanked_versions) or "none", - ) - if skipped_by_requires_python: - logger.critical( - "Ignored the following versions that require a different python " - "version: %s", - "; ".join(skipped_by_requires_python) or "none", - ) - logger.critical( - "Could not find a version that satisfies the requirement %s " - "(from versions: %s)", - req_disp, - ", ".join(versions) or "none", - ) - if str(req) == "requirements.txt": - logger.info( - "HINT: You are attempting to install a package literally " - 'named "requirements.txt" (which cannot exist). Consider ' - "using the '-r' flag to install the packages listed in " - "requirements.txt" - ) - - return DistributionNotFound(f"No matching distribution found for {req}") - - def get_installation_error( - self, - e: "ResolutionImpossible[Requirement, Candidate]", - constraints: Dict[str, Constraint], - ) -> InstallationError: - assert e.causes, "Installation error reported with no cause" - - # If one of the things we can't solve is "we need Python X.Y", - # that is what we report. - requires_python_causes = [ - cause - for cause in e.causes - if isinstance(cause.requirement, RequiresPythonRequirement) - and not cause.requirement.is_satisfied_by(self._python_candidate) - ] - if requires_python_causes: - # The comprehension above makes sure all Requirement instances are - # RequiresPythonRequirement, so let's cast for convenience. - return self._report_requires_python_error( - cast("Sequence[ConflictCause]", requires_python_causes), - ) - - # Otherwise, we have a set of causes which can't all be satisfied - # at once. - - # The simplest case is when we have *one* cause that can't be - # satisfied. We just report that case. - if len(e.causes) == 1: - req, parent = e.causes[0] - if req.name not in constraints: - return self._report_single_requirement_conflict(req, parent) - - # OK, we now have a list of requirements that can't all be - # satisfied at once. - - # A couple of formatting helpers - def text_join(parts: List[str]) -> str: - if len(parts) == 1: - return parts[0] - - return ", ".join(parts[:-1]) + " and " + parts[-1] - - def describe_trigger(parent: Candidate) -> str: - ireq = parent.get_install_requirement() - if not ireq or not ireq.comes_from: - return f"{parent.name}=={parent.version}" - if isinstance(ireq.comes_from, InstallRequirement): - return str(ireq.comes_from.name) - return str(ireq.comes_from) - - triggers = set() - for req, parent in e.causes: - if parent is None: - # This is a root requirement, so we can report it directly - trigger = req.format_for_error() - else: - trigger = describe_trigger(parent) - triggers.add(trigger) - - if triggers: - info = text_join(sorted(triggers)) - else: - info = "the requested packages" - - msg = ( - f"Cannot install {info} because these package versions " - "have conflicting dependencies." - ) - logger.critical(msg) - msg = "\nThe conflict is caused by:" - - relevant_constraints = set() - for req, parent in e.causes: - if req.name in constraints: - relevant_constraints.add(req.name) - msg = msg + "\n " - if parent: - msg = msg + f"{parent.name} {parent.version} depends on " - else: - msg = msg + "The user requested " - msg = msg + req.format_for_error() - for key in relevant_constraints: - spec = constraints[key].specifier - msg += f"\n The user requested (constraint) {key}{spec}" - - msg = ( - msg - + "\n\n" - + "To fix this you could try to:\n" - + "1. loosen the range of package versions you've specified\n" - + "2. remove package versions to allow pip attempt to solve " - + "the dependency conflict\n" - ) - - logger.info(msg) - - return DistributionNotFound( - "ResolutionImpossible: for help visit " - "https://pip.pypa.io/en/latest/topics/dependency-resolution/" - "#dealing-with-dependency-conflicts" - ) diff --git a/venv/lib/python3.12/site-packages/pip/_internal/resolution/resolvelib/found_candidates.py b/venv/lib/python3.12/site-packages/pip/_internal/resolution/resolvelib/found_candidates.py deleted file mode 100644 index 8663097..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/resolution/resolvelib/found_candidates.py +++ /dev/null @@ -1,155 +0,0 @@ -"""Utilities to lazily create and visit candidates found. - -Creating and visiting a candidate is a *very* costly operation. It involves -fetching, extracting, potentially building modules from source, and verifying -distribution metadata. It is therefore crucial for performance to keep -everything here lazy all the way down, so we only touch candidates that we -absolutely need, and not "download the world" when we only need one version of -something. -""" - -import functools -from collections.abc import Sequence -from typing import TYPE_CHECKING, Any, Callable, Iterator, Optional, Set, Tuple - -from pip._vendor.packaging.version import _BaseVersion - -from .base import Candidate - -IndexCandidateInfo = Tuple[_BaseVersion, Callable[[], Optional[Candidate]]] - -if TYPE_CHECKING: - SequenceCandidate = Sequence[Candidate] -else: - # For compatibility: Python before 3.9 does not support using [] on the - # Sequence class. - # - # >>> from collections.abc import Sequence - # >>> Sequence[str] - # Traceback (most recent call last): - # File "", line 1, in - # TypeError: 'ABCMeta' object is not subscriptable - # - # TODO: Remove this block after dropping Python 3.8 support. - SequenceCandidate = Sequence - - -def _iter_built(infos: Iterator[IndexCandidateInfo]) -> Iterator[Candidate]: - """Iterator for ``FoundCandidates``. - - This iterator is used when the package is not already installed. Candidates - from index come later in their normal ordering. - """ - versions_found: Set[_BaseVersion] = set() - for version, func in infos: - if version in versions_found: - continue - candidate = func() - if candidate is None: - continue - yield candidate - versions_found.add(version) - - -def _iter_built_with_prepended( - installed: Candidate, infos: Iterator[IndexCandidateInfo] -) -> Iterator[Candidate]: - """Iterator for ``FoundCandidates``. - - This iterator is used when the resolver prefers the already-installed - candidate and NOT to upgrade. The installed candidate is therefore - always yielded first, and candidates from index come later in their - normal ordering, except skipped when the version is already installed. - """ - yield installed - versions_found: Set[_BaseVersion] = {installed.version} - for version, func in infos: - if version in versions_found: - continue - candidate = func() - if candidate is None: - continue - yield candidate - versions_found.add(version) - - -def _iter_built_with_inserted( - installed: Candidate, infos: Iterator[IndexCandidateInfo] -) -> Iterator[Candidate]: - """Iterator for ``FoundCandidates``. - - This iterator is used when the resolver prefers to upgrade an - already-installed package. Candidates from index are returned in their - normal ordering, except replaced when the version is already installed. - - The implementation iterates through and yields other candidates, inserting - the installed candidate exactly once before we start yielding older or - equivalent candidates, or after all other candidates if they are all newer. - """ - versions_found: Set[_BaseVersion] = set() - for version, func in infos: - if version in versions_found: - continue - # If the installed candidate is better, yield it first. - if installed.version >= version: - yield installed - versions_found.add(installed.version) - candidate = func() - if candidate is None: - continue - yield candidate - versions_found.add(version) - - # If the installed candidate is older than all other candidates. - if installed.version not in versions_found: - yield installed - - -class FoundCandidates(SequenceCandidate): - """A lazy sequence to provide candidates to the resolver. - - The intended usage is to return this from `find_matches()` so the resolver - can iterate through the sequence multiple times, but only access the index - page when remote packages are actually needed. This improve performances - when suitable candidates are already installed on disk. - """ - - def __init__( - self, - get_infos: Callable[[], Iterator[IndexCandidateInfo]], - installed: Optional[Candidate], - prefers_installed: bool, - incompatible_ids: Set[int], - ): - self._get_infos = get_infos - self._installed = installed - self._prefers_installed = prefers_installed - self._incompatible_ids = incompatible_ids - - def __getitem__(self, index: Any) -> Any: - # Implemented to satisfy the ABC check. This is not needed by the - # resolver, and should not be used by the provider either (for - # performance reasons). - raise NotImplementedError("don't do this") - - def __iter__(self) -> Iterator[Candidate]: - infos = self._get_infos() - if not self._installed: - iterator = _iter_built(infos) - elif self._prefers_installed: - iterator = _iter_built_with_prepended(self._installed, infos) - else: - iterator = _iter_built_with_inserted(self._installed, infos) - return (c for c in iterator if id(c) not in self._incompatible_ids) - - def __len__(self) -> int: - # Implemented to satisfy the ABC check. This is not needed by the - # resolver, and should not be used by the provider either (for - # performance reasons). - raise NotImplementedError("don't do this") - - @functools.lru_cache(maxsize=1) - def __bool__(self) -> bool: - if self._prefers_installed and self._installed: - return True - return any(self) diff --git a/venv/lib/python3.12/site-packages/pip/_internal/resolution/resolvelib/provider.py b/venv/lib/python3.12/site-packages/pip/_internal/resolution/resolvelib/provider.py deleted file mode 100644 index 315fb9c..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/resolution/resolvelib/provider.py +++ /dev/null @@ -1,255 +0,0 @@ -import collections -import math -from typing import ( - TYPE_CHECKING, - Dict, - Iterable, - Iterator, - Mapping, - Sequence, - TypeVar, - Union, -) - -from pip._vendor.resolvelib.providers import AbstractProvider - -from .base import Candidate, Constraint, Requirement -from .candidates import REQUIRES_PYTHON_IDENTIFIER -from .factory import Factory - -if TYPE_CHECKING: - from pip._vendor.resolvelib.providers import Preference - from pip._vendor.resolvelib.resolvers import RequirementInformation - - PreferenceInformation = RequirementInformation[Requirement, Candidate] - - _ProviderBase = AbstractProvider[Requirement, Candidate, str] -else: - _ProviderBase = AbstractProvider - -# Notes on the relationship between the provider, the factory, and the -# candidate and requirement classes. -# -# The provider is a direct implementation of the resolvelib class. Its role -# is to deliver the API that resolvelib expects. -# -# Rather than work with completely abstract "requirement" and "candidate" -# concepts as resolvelib does, pip has concrete classes implementing these two -# ideas. The API of Requirement and Candidate objects are defined in the base -# classes, but essentially map fairly directly to the equivalent provider -# methods. In particular, `find_matches` and `is_satisfied_by` are -# requirement methods, and `get_dependencies` is a candidate method. -# -# The factory is the interface to pip's internal mechanisms. It is stateless, -# and is created by the resolver and held as a property of the provider. It is -# responsible for creating Requirement and Candidate objects, and provides -# services to those objects (access to pip's finder and preparer). - - -D = TypeVar("D") -V = TypeVar("V") - - -def _get_with_identifier( - mapping: Mapping[str, V], - identifier: str, - default: D, -) -> Union[D, V]: - """Get item from a package name lookup mapping with a resolver identifier. - - This extra logic is needed when the target mapping is keyed by package - name, which cannot be directly looked up with an identifier (which may - contain requested extras). Additional logic is added to also look up a value - by "cleaning up" the extras from the identifier. - """ - if identifier in mapping: - return mapping[identifier] - # HACK: Theoretically we should check whether this identifier is a valid - # "NAME[EXTRAS]" format, and parse out the name part with packaging or - # some regular expression. But since pip's resolver only spits out three - # kinds of identifiers: normalized PEP 503 names, normalized names plus - # extras, and Requires-Python, we can cheat a bit here. - name, open_bracket, _ = identifier.partition("[") - if open_bracket and name in mapping: - return mapping[name] - return default - - -class PipProvider(_ProviderBase): - """Pip's provider implementation for resolvelib. - - :params constraints: A mapping of constraints specified by the user. Keys - are canonicalized project names. - :params ignore_dependencies: Whether the user specified ``--no-deps``. - :params upgrade_strategy: The user-specified upgrade strategy. - :params user_requested: A set of canonicalized package names that the user - supplied for pip to install/upgrade. - """ - - def __init__( - self, - factory: Factory, - constraints: Dict[str, Constraint], - ignore_dependencies: bool, - upgrade_strategy: str, - user_requested: Dict[str, int], - ) -> None: - self._factory = factory - self._constraints = constraints - self._ignore_dependencies = ignore_dependencies - self._upgrade_strategy = upgrade_strategy - self._user_requested = user_requested - self._known_depths: Dict[str, float] = collections.defaultdict(lambda: math.inf) - - def identify(self, requirement_or_candidate: Union[Requirement, Candidate]) -> str: - return requirement_or_candidate.name - - def get_preference( - self, - identifier: str, - resolutions: Mapping[str, Candidate], - candidates: Mapping[str, Iterator[Candidate]], - information: Mapping[str, Iterable["PreferenceInformation"]], - backtrack_causes: Sequence["PreferenceInformation"], - ) -> "Preference": - """Produce a sort key for given requirement based on preference. - - The lower the return value is, the more preferred this group of - arguments is. - - Currently pip considers the following in order: - - * Prefer if any of the known requirements is "direct", e.g. points to an - explicit URL. - * If equal, prefer if any requirement is "pinned", i.e. contains - operator ``===`` or ``==``. - * If equal, calculate an approximate "depth" and resolve requirements - closer to the user-specified requirements first. If the depth cannot - by determined (eg: due to no matching parents), it is considered - infinite. - * Order user-specified requirements by the order they are specified. - * If equal, prefers "non-free" requirements, i.e. contains at least one - operator, such as ``>=`` or ``<``. - * If equal, order alphabetically for consistency (helps debuggability). - """ - try: - next(iter(information[identifier])) - except StopIteration: - # There is no information for this identifier, so there's no known - # candidates. - has_information = False - else: - has_information = True - - if has_information: - lookups = (r.get_candidate_lookup() for r, _ in information[identifier]) - candidate, ireqs = zip(*lookups) - else: - candidate, ireqs = None, () - - operators = [ - specifier.operator - for specifier_set in (ireq.specifier for ireq in ireqs if ireq) - for specifier in specifier_set - ] - - direct = candidate is not None - pinned = any(op[:2] == "==" for op in operators) - unfree = bool(operators) - - try: - requested_order: Union[int, float] = self._user_requested[identifier] - except KeyError: - requested_order = math.inf - if has_information: - parent_depths = ( - self._known_depths[parent.name] if parent is not None else 0.0 - for _, parent in information[identifier] - ) - inferred_depth = min(d for d in parent_depths) + 1.0 - else: - inferred_depth = math.inf - else: - inferred_depth = 1.0 - self._known_depths[identifier] = inferred_depth - - requested_order = self._user_requested.get(identifier, math.inf) - - # Requires-Python has only one candidate and the check is basically - # free, so we always do it first to avoid needless work if it fails. - requires_python = identifier == REQUIRES_PYTHON_IDENTIFIER - - # Prefer the causes of backtracking on the assumption that the problem - # resolving the dependency tree is related to the failures that caused - # the backtracking - backtrack_cause = self.is_backtrack_cause(identifier, backtrack_causes) - - return ( - not requires_python, - not direct, - not pinned, - not backtrack_cause, - inferred_depth, - requested_order, - not unfree, - identifier, - ) - - def find_matches( - self, - identifier: str, - requirements: Mapping[str, Iterator[Requirement]], - incompatibilities: Mapping[str, Iterator[Candidate]], - ) -> Iterable[Candidate]: - def _eligible_for_upgrade(identifier: str) -> bool: - """Are upgrades allowed for this project? - - This checks the upgrade strategy, and whether the project was one - that the user specified in the command line, in order to decide - whether we should upgrade if there's a newer version available. - - (Note that we don't need access to the `--upgrade` flag, because - an upgrade strategy of "to-satisfy-only" means that `--upgrade` - was not specified). - """ - if self._upgrade_strategy == "eager": - return True - elif self._upgrade_strategy == "only-if-needed": - user_order = _get_with_identifier( - self._user_requested, - identifier, - default=None, - ) - return user_order is not None - return False - - constraint = _get_with_identifier( - self._constraints, - identifier, - default=Constraint.empty(), - ) - return self._factory.find_candidates( - identifier=identifier, - requirements=requirements, - constraint=constraint, - prefers_installed=(not _eligible_for_upgrade(identifier)), - incompatibilities=incompatibilities, - ) - - def is_satisfied_by(self, requirement: Requirement, candidate: Candidate) -> bool: - return requirement.is_satisfied_by(candidate) - - def get_dependencies(self, candidate: Candidate) -> Sequence[Requirement]: - with_requires = not self._ignore_dependencies - return [r for r in candidate.iter_dependencies(with_requires) if r is not None] - - @staticmethod - def is_backtrack_cause( - identifier: str, backtrack_causes: Sequence["PreferenceInformation"] - ) -> bool: - for backtrack_cause in backtrack_causes: - if identifier == backtrack_cause.requirement.name: - return True - if backtrack_cause.parent and identifier == backtrack_cause.parent.name: - return True - return False diff --git a/venv/lib/python3.12/site-packages/pip/_internal/resolution/resolvelib/reporter.py b/venv/lib/python3.12/site-packages/pip/_internal/resolution/resolvelib/reporter.py deleted file mode 100644 index 12adeff..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/resolution/resolvelib/reporter.py +++ /dev/null @@ -1,80 +0,0 @@ -from collections import defaultdict -from logging import getLogger -from typing import Any, DefaultDict - -from pip._vendor.resolvelib.reporters import BaseReporter - -from .base import Candidate, Requirement - -logger = getLogger(__name__) - - -class PipReporter(BaseReporter): - def __init__(self) -> None: - self.reject_count_by_package: DefaultDict[str, int] = defaultdict(int) - - self._messages_at_reject_count = { - 1: ( - "pip is looking at multiple versions of {package_name} to " - "determine which version is compatible with other " - "requirements. This could take a while." - ), - 8: ( - "pip is still looking at multiple versions of {package_name} to " - "determine which version is compatible with other " - "requirements. This could take a while." - ), - 13: ( - "This is taking longer than usual. You might need to provide " - "the dependency resolver with stricter constraints to reduce " - "runtime. See https://pip.pypa.io/warnings/backtracking for " - "guidance. If you want to abort this run, press Ctrl + C." - ), - } - - def rejecting_candidate(self, criterion: Any, candidate: Candidate) -> None: - self.reject_count_by_package[candidate.name] += 1 - - count = self.reject_count_by_package[candidate.name] - if count not in self._messages_at_reject_count: - return - - message = self._messages_at_reject_count[count] - logger.info("INFO: %s", message.format(package_name=candidate.name)) - - msg = "Will try a different candidate, due to conflict:" - for req_info in criterion.information: - req, parent = req_info.requirement, req_info.parent - # Inspired by Factory.get_installation_error - msg += "\n " - if parent: - msg += f"{parent.name} {parent.version} depends on " - else: - msg += "The user requested " - msg += req.format_for_error() - logger.debug(msg) - - -class PipDebuggingReporter(BaseReporter): - """A reporter that does an info log for every event it sees.""" - - def starting(self) -> None: - logger.info("Reporter.starting()") - - def starting_round(self, index: int) -> None: - logger.info("Reporter.starting_round(%r)", index) - - def ending_round(self, index: int, state: Any) -> None: - logger.info("Reporter.ending_round(%r, state)", index) - - def ending(self, state: Any) -> None: - logger.info("Reporter.ending(%r)", state) - - def adding_requirement(self, requirement: Requirement, parent: Candidate) -> None: - logger.info("Reporter.adding_requirement(%r, %r)", requirement, parent) - - def rejecting_candidate(self, criterion: Any, candidate: Candidate) -> None: - logger.info("Reporter.rejecting_candidate(%r, %r)", criterion, candidate) - - def pinning(self, candidate: Candidate) -> None: - logger.info("Reporter.pinning(%r)", candidate) diff --git a/venv/lib/python3.12/site-packages/pip/_internal/resolution/resolvelib/requirements.py b/venv/lib/python3.12/site-packages/pip/_internal/resolution/resolvelib/requirements.py deleted file mode 100644 index 4af4a9f..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/resolution/resolvelib/requirements.py +++ /dev/null @@ -1,166 +0,0 @@ -from pip._vendor.packaging.specifiers import SpecifierSet -from pip._vendor.packaging.utils import NormalizedName, canonicalize_name - -from pip._internal.req.constructors import install_req_drop_extras -from pip._internal.req.req_install import InstallRequirement - -from .base import Candidate, CandidateLookup, Requirement, format_name - - -class ExplicitRequirement(Requirement): - def __init__(self, candidate: Candidate) -> None: - self.candidate = candidate - - def __str__(self) -> str: - return str(self.candidate) - - def __repr__(self) -> str: - return f"{self.__class__.__name__}({self.candidate!r})" - - @property - def project_name(self) -> NormalizedName: - # No need to canonicalize - the candidate did this - return self.candidate.project_name - - @property - def name(self) -> str: - # No need to canonicalize - the candidate did this - return self.candidate.name - - def format_for_error(self) -> str: - return self.candidate.format_for_error() - - def get_candidate_lookup(self) -> CandidateLookup: - return self.candidate, None - - def is_satisfied_by(self, candidate: Candidate) -> bool: - return candidate == self.candidate - - -class SpecifierRequirement(Requirement): - def __init__(self, ireq: InstallRequirement) -> None: - assert ireq.link is None, "This is a link, not a specifier" - self._ireq = ireq - self._extras = frozenset(canonicalize_name(e) for e in self._ireq.extras) - - def __str__(self) -> str: - return str(self._ireq.req) - - def __repr__(self) -> str: - return f"{self.__class__.__name__}({str(self._ireq.req)!r})" - - @property - def project_name(self) -> NormalizedName: - assert self._ireq.req, "Specifier-backed ireq is always PEP 508" - return canonicalize_name(self._ireq.req.name) - - @property - def name(self) -> str: - return format_name(self.project_name, self._extras) - - def format_for_error(self) -> str: - # Convert comma-separated specifiers into "A, B, ..., F and G" - # This makes the specifier a bit more "human readable", without - # risking a change in meaning. (Hopefully! Not all edge cases have - # been checked) - parts = [s.strip() for s in str(self).split(",")] - if len(parts) == 0: - return "" - elif len(parts) == 1: - return parts[0] - - return ", ".join(parts[:-1]) + " and " + parts[-1] - - def get_candidate_lookup(self) -> CandidateLookup: - return None, self._ireq - - def is_satisfied_by(self, candidate: Candidate) -> bool: - assert candidate.name == self.name, ( - f"Internal issue: Candidate is not for this requirement " - f"{candidate.name} vs {self.name}" - ) - # We can safely always allow prereleases here since PackageFinder - # already implements the prerelease logic, and would have filtered out - # prerelease candidates if the user does not expect them. - assert self._ireq.req, "Specifier-backed ireq is always PEP 508" - spec = self._ireq.req.specifier - return spec.contains(candidate.version, prereleases=True) - - -class SpecifierWithoutExtrasRequirement(SpecifierRequirement): - """ - Requirement backed by an install requirement on a base package. - Trims extras from its install requirement if there are any. - """ - - def __init__(self, ireq: InstallRequirement) -> None: - assert ireq.link is None, "This is a link, not a specifier" - self._ireq = install_req_drop_extras(ireq) - self._extras = frozenset(canonicalize_name(e) for e in self._ireq.extras) - - -class RequiresPythonRequirement(Requirement): - """A requirement representing Requires-Python metadata.""" - - def __init__(self, specifier: SpecifierSet, match: Candidate) -> None: - self.specifier = specifier - self._candidate = match - - def __str__(self) -> str: - return f"Python {self.specifier}" - - def __repr__(self) -> str: - return f"{self.__class__.__name__}({str(self.specifier)!r})" - - @property - def project_name(self) -> NormalizedName: - return self._candidate.project_name - - @property - def name(self) -> str: - return self._candidate.name - - def format_for_error(self) -> str: - return str(self) - - def get_candidate_lookup(self) -> CandidateLookup: - if self.specifier.contains(self._candidate.version, prereleases=True): - return self._candidate, None - return None, None - - def is_satisfied_by(self, candidate: Candidate) -> bool: - assert candidate.name == self._candidate.name, "Not Python candidate" - # We can safely always allow prereleases here since PackageFinder - # already implements the prerelease logic, and would have filtered out - # prerelease candidates if the user does not expect them. - return self.specifier.contains(candidate.version, prereleases=True) - - -class UnsatisfiableRequirement(Requirement): - """A requirement that cannot be satisfied.""" - - def __init__(self, name: NormalizedName) -> None: - self._name = name - - def __str__(self) -> str: - return f"{self._name} (unavailable)" - - def __repr__(self) -> str: - return f"{self.__class__.__name__}({str(self._name)!r})" - - @property - def project_name(self) -> NormalizedName: - return self._name - - @property - def name(self) -> str: - return self._name - - def format_for_error(self) -> str: - return str(self) - - def get_candidate_lookup(self) -> CandidateLookup: - return None, None - - def is_satisfied_by(self, candidate: Candidate) -> bool: - return False diff --git a/venv/lib/python3.12/site-packages/pip/_internal/resolution/resolvelib/resolver.py b/venv/lib/python3.12/site-packages/pip/_internal/resolution/resolvelib/resolver.py deleted file mode 100644 index c12beef..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/resolution/resolvelib/resolver.py +++ /dev/null @@ -1,317 +0,0 @@ -import contextlib -import functools -import logging -import os -from typing import TYPE_CHECKING, Dict, List, Optional, Set, Tuple, cast - -from pip._vendor.packaging.utils import canonicalize_name -from pip._vendor.resolvelib import BaseReporter, ResolutionImpossible -from pip._vendor.resolvelib import Resolver as RLResolver -from pip._vendor.resolvelib.structs import DirectedGraph - -from pip._internal.cache import WheelCache -from pip._internal.index.package_finder import PackageFinder -from pip._internal.operations.prepare import RequirementPreparer -from pip._internal.req.constructors import install_req_extend_extras -from pip._internal.req.req_install import InstallRequirement -from pip._internal.req.req_set import RequirementSet -from pip._internal.resolution.base import BaseResolver, InstallRequirementProvider -from pip._internal.resolution.resolvelib.provider import PipProvider -from pip._internal.resolution.resolvelib.reporter import ( - PipDebuggingReporter, - PipReporter, -) -from pip._internal.utils.packaging import get_requirement - -from .base import Candidate, Requirement -from .factory import Factory - -if TYPE_CHECKING: - from pip._vendor.resolvelib.resolvers import Result as RLResult - - Result = RLResult[Requirement, Candidate, str] - - -logger = logging.getLogger(__name__) - - -class Resolver(BaseResolver): - _allowed_strategies = {"eager", "only-if-needed", "to-satisfy-only"} - - def __init__( - self, - preparer: RequirementPreparer, - finder: PackageFinder, - wheel_cache: Optional[WheelCache], - make_install_req: InstallRequirementProvider, - use_user_site: bool, - ignore_dependencies: bool, - ignore_installed: bool, - ignore_requires_python: bool, - force_reinstall: bool, - upgrade_strategy: str, - py_version_info: Optional[Tuple[int, ...]] = None, - ): - super().__init__() - assert upgrade_strategy in self._allowed_strategies - - self.factory = Factory( - finder=finder, - preparer=preparer, - make_install_req=make_install_req, - wheel_cache=wheel_cache, - use_user_site=use_user_site, - force_reinstall=force_reinstall, - ignore_installed=ignore_installed, - ignore_requires_python=ignore_requires_python, - py_version_info=py_version_info, - ) - self.ignore_dependencies = ignore_dependencies - self.upgrade_strategy = upgrade_strategy - self._result: Optional[Result] = None - - def resolve( - self, root_reqs: List[InstallRequirement], check_supported_wheels: bool - ) -> RequirementSet: - collected = self.factory.collect_root_requirements(root_reqs) - provider = PipProvider( - factory=self.factory, - constraints=collected.constraints, - ignore_dependencies=self.ignore_dependencies, - upgrade_strategy=self.upgrade_strategy, - user_requested=collected.user_requested, - ) - if "PIP_RESOLVER_DEBUG" in os.environ: - reporter: BaseReporter = PipDebuggingReporter() - else: - reporter = PipReporter() - resolver: RLResolver[Requirement, Candidate, str] = RLResolver( - provider, - reporter, - ) - - try: - limit_how_complex_resolution_can_be = 200000 - result = self._result = resolver.resolve( - collected.requirements, max_rounds=limit_how_complex_resolution_can_be - ) - - except ResolutionImpossible as e: - error = self.factory.get_installation_error( - cast("ResolutionImpossible[Requirement, Candidate]", e), - collected.constraints, - ) - raise error from e - - req_set = RequirementSet(check_supported_wheels=check_supported_wheels) - # process candidates with extras last to ensure their base equivalent is - # already in the req_set if appropriate. - # Python's sort is stable so using a binary key function keeps relative order - # within both subsets. - for candidate in sorted( - result.mapping.values(), key=lambda c: c.name != c.project_name - ): - ireq = candidate.get_install_requirement() - if ireq is None: - if candidate.name != candidate.project_name: - # extend existing req's extras - with contextlib.suppress(KeyError): - req = req_set.get_requirement(candidate.project_name) - req_set.add_named_requirement( - install_req_extend_extras( - req, get_requirement(candidate.name).extras - ) - ) - continue - - # Check if there is already an installation under the same name, - # and set a flag for later stages to uninstall it, if needed. - installed_dist = self.factory.get_dist_to_uninstall(candidate) - if installed_dist is None: - # There is no existing installation -- nothing to uninstall. - ireq.should_reinstall = False - elif self.factory.force_reinstall: - # The --force-reinstall flag is set -- reinstall. - ireq.should_reinstall = True - elif installed_dist.version != candidate.version: - # The installation is different in version -- reinstall. - ireq.should_reinstall = True - elif candidate.is_editable or installed_dist.editable: - # The incoming distribution is editable, or different in - # editable-ness to installation -- reinstall. - ireq.should_reinstall = True - elif candidate.source_link and candidate.source_link.is_file: - # The incoming distribution is under file:// - if candidate.source_link.is_wheel: - # is a local wheel -- do nothing. - logger.info( - "%s is already installed with the same version as the " - "provided wheel. Use --force-reinstall to force an " - "installation of the wheel.", - ireq.name, - ) - continue - - # is a local sdist or path -- reinstall - ireq.should_reinstall = True - else: - continue - - link = candidate.source_link - if link and link.is_yanked: - # The reason can contain non-ASCII characters, Unicode - # is required for Python 2. - msg = ( - "The candidate selected for download or install is a " - "yanked version: {name!r} candidate (version {version} " - "at {link})\nReason for being yanked: {reason}" - ).format( - name=candidate.name, - version=candidate.version, - link=link, - reason=link.yanked_reason or "", - ) - logger.warning(msg) - - req_set.add_named_requirement(ireq) - - reqs = req_set.all_requirements - self.factory.preparer.prepare_linked_requirements_more(reqs) - for req in reqs: - req.prepared = True - req.needs_more_preparation = False - return req_set - - def get_installation_order( - self, req_set: RequirementSet - ) -> List[InstallRequirement]: - """Get order for installation of requirements in RequirementSet. - - The returned list contains a requirement before another that depends on - it. This helps ensure that the environment is kept consistent as they - get installed one-by-one. - - The current implementation creates a topological ordering of the - dependency graph, giving more weight to packages with less - or no dependencies, while breaking any cycles in the graph at - arbitrary points. We make no guarantees about where the cycle - would be broken, other than it *would* be broken. - """ - assert self._result is not None, "must call resolve() first" - - if not req_set.requirements: - # Nothing is left to install, so we do not need an order. - return [] - - graph = self._result.graph - weights = get_topological_weights(graph, set(req_set.requirements.keys())) - - sorted_items = sorted( - req_set.requirements.items(), - key=functools.partial(_req_set_item_sorter, weights=weights), - reverse=True, - ) - return [ireq for _, ireq in sorted_items] - - -def get_topological_weights( - graph: "DirectedGraph[Optional[str]]", requirement_keys: Set[str] -) -> Dict[Optional[str], int]: - """Assign weights to each node based on how "deep" they are. - - This implementation may change at any point in the future without prior - notice. - - We first simplify the dependency graph by pruning any leaves and giving them - the highest weight: a package without any dependencies should be installed - first. This is done again and again in the same way, giving ever less weight - to the newly found leaves. The loop stops when no leaves are left: all - remaining packages have at least one dependency left in the graph. - - Then we continue with the remaining graph, by taking the length for the - longest path to any node from root, ignoring any paths that contain a single - node twice (i.e. cycles). This is done through a depth-first search through - the graph, while keeping track of the path to the node. - - Cycles in the graph result would result in node being revisited while also - being on its own path. In this case, take no action. This helps ensure we - don't get stuck in a cycle. - - When assigning weight, the longer path (i.e. larger length) is preferred. - - We are only interested in the weights of packages that are in the - requirement_keys. - """ - path: Set[Optional[str]] = set() - weights: Dict[Optional[str], int] = {} - - def visit(node: Optional[str]) -> None: - if node in path: - # We hit a cycle, so we'll break it here. - return - - # Time to visit the children! - path.add(node) - for child in graph.iter_children(node): - visit(child) - path.remove(node) - - if node not in requirement_keys: - return - - last_known_parent_count = weights.get(node, 0) - weights[node] = max(last_known_parent_count, len(path)) - - # Simplify the graph, pruning leaves that have no dependencies. - # This is needed for large graphs (say over 200 packages) because the - # `visit` function is exponentially slower then, taking minutes. - # See https://github.com/pypa/pip/issues/10557 - # We will loop until we explicitly break the loop. - while True: - leaves = set() - for key in graph: - if key is None: - continue - for _child in graph.iter_children(key): - # This means we have at least one child - break - else: - # No child. - leaves.add(key) - if not leaves: - # We are done simplifying. - break - # Calculate the weight for the leaves. - weight = len(graph) - 1 - for leaf in leaves: - if leaf not in requirement_keys: - continue - weights[leaf] = weight - # Remove the leaves from the graph, making it simpler. - for leaf in leaves: - graph.remove(leaf) - - # Visit the remaining graph. - # `None` is guaranteed to be the root node by resolvelib. - visit(None) - - # Sanity check: all requirement keys should be in the weights, - # and no other keys should be in the weights. - difference = set(weights.keys()).difference(requirement_keys) - assert not difference, difference - - return weights - - -def _req_set_item_sorter( - item: Tuple[str, InstallRequirement], - weights: Dict[Optional[str], int], -) -> Tuple[int, str]: - """Key function used to sort install requirements for installation. - - Based on the "weight" mapping calculated in ``get_installation_order()``. - The canonical package name is returned as the second member as a tie- - breaker to ensure the result is predictable, which is useful in tests. - """ - name = canonicalize_name(item[0]) - return weights[name], name diff --git a/venv/lib/python3.12/site-packages/pip/_internal/self_outdated_check.py b/venv/lib/python3.12/site-packages/pip/_internal/self_outdated_check.py deleted file mode 100644 index 0f64ae0..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/self_outdated_check.py +++ /dev/null @@ -1,248 +0,0 @@ -import datetime -import functools -import hashlib -import json -import logging -import optparse -import os.path -import sys -from dataclasses import dataclass -from typing import Any, Callable, Dict, Optional - -from pip._vendor.packaging.version import parse as parse_version -from pip._vendor.rich.console import Group -from pip._vendor.rich.markup import escape -from pip._vendor.rich.text import Text - -from pip._internal.index.collector import LinkCollector -from pip._internal.index.package_finder import PackageFinder -from pip._internal.metadata import get_default_environment -from pip._internal.metadata.base import DistributionVersion -from pip._internal.models.selection_prefs import SelectionPreferences -from pip._internal.network.session import PipSession -from pip._internal.utils.compat import WINDOWS -from pip._internal.utils.entrypoints import ( - get_best_invocation_for_this_pip, - get_best_invocation_for_this_python, -) -from pip._internal.utils.filesystem import adjacent_tmp_file, check_path_owner, replace -from pip._internal.utils.misc import ensure_dir - -_WEEK = datetime.timedelta(days=7) - -logger = logging.getLogger(__name__) - - -def _get_statefile_name(key: str) -> str: - key_bytes = key.encode() - name = hashlib.sha224(key_bytes).hexdigest() - return name - - -def _convert_date(isodate: str) -> datetime.datetime: - """Convert an ISO format string to a date. - - Handles the format 2020-01-22T14:24:01Z (trailing Z) - which is not supported by older versions of fromisoformat. - """ - return datetime.datetime.fromisoformat(isodate.replace("Z", "+00:00")) - - -class SelfCheckState: - def __init__(self, cache_dir: str) -> None: - self._state: Dict[str, Any] = {} - self._statefile_path = None - - # Try to load the existing state - if cache_dir: - self._statefile_path = os.path.join( - cache_dir, "selfcheck", _get_statefile_name(self.key) - ) - try: - with open(self._statefile_path, encoding="utf-8") as statefile: - self._state = json.load(statefile) - except (OSError, ValueError, KeyError): - # Explicitly suppressing exceptions, since we don't want to - # error out if the cache file is invalid. - pass - - @property - def key(self) -> str: - return sys.prefix - - def get(self, current_time: datetime.datetime) -> Optional[str]: - """Check if we have a not-outdated version loaded already.""" - if not self._state: - return None - - if "last_check" not in self._state: - return None - - if "pypi_version" not in self._state: - return None - - # Determine if we need to refresh the state - last_check = _convert_date(self._state["last_check"]) - time_since_last_check = current_time - last_check - if time_since_last_check > _WEEK: - return None - - return self._state["pypi_version"] - - def set(self, pypi_version: str, current_time: datetime.datetime) -> None: - # If we do not have a path to cache in, don't bother saving. - if not self._statefile_path: - 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.isoformat(), - "pypi_version": pypi_version, - } - - text = json.dumps(state, sort_keys=True, separators=(",", ":")) - - with adjacent_tmp_file(self._statefile_path) as f: - f.write(text.encode()) - - try: - # Since we have a prefix-specific state file, we can just - # overwrite whatever is there, no need to check. - replace(f.name, self._statefile_path) - except OSError: - # Best effort. - pass - - -@dataclass -class UpgradePrompt: - old: str - new: str - - def __rich__(self) -> Group: - if WINDOWS: - pip_cmd = f"{get_best_invocation_for_this_python()} -m pip" - else: - pip_cmd = get_best_invocation_for_this_pip() - - notice = "[bold][[reset][blue]notice[reset][bold]][reset]" - return Group( - Text(), - Text.from_markup( - f"{notice} A new release of pip is available: " - f"[red]{self.old}[reset] -> [green]{self.new}[reset]" - ), - Text.from_markup( - f"{notice} To update, run: " - f"[green]{escape(pip_cmd)} install --upgrade pip" - ), - ) - - -def was_installed_by_pip(pkg: str) -> bool: - """Checks whether pkg was installed by pip - - This is used not to display the upgrade message when pip is in fact - installed by system package manager, such as dnf on Fedora. - """ - dist = get_default_environment().get_distribution(pkg) - return dist is not None and "pip" == dist.installer - - -def _get_current_remote_pip_version( - session: PipSession, options: optparse.Values -) -> Optional[str]: - # Lets use PackageFinder to see what the latest pip version is - link_collector = LinkCollector.create( - session, - options=options, - suppress_no_index=True, - ) - - # Pass allow_yanked=False so we don't suggest upgrading to a - # yanked version. - selection_prefs = SelectionPreferences( - allow_yanked=False, - allow_all_prereleases=False, # Explicitly set to False - ) - - finder = PackageFinder.create( - link_collector=link_collector, - selection_prefs=selection_prefs, - ) - best_candidate = finder.find_best_candidate("pip").best_candidate - if best_candidate is None: - return None - - return str(best_candidate.version) - - -def _self_version_check_logic( - *, - state: SelfCheckState, - current_time: datetime.datetime, - local_version: DistributionVersion, - get_remote_version: Callable[[], Optional[str]], -) -> Optional[UpgradePrompt]: - remote_version_str = state.get(current_time) - if remote_version_str is None: - remote_version_str = get_remote_version() - if remote_version_str is None: - logger.debug("No remote pip version found") - return None - state.set(remote_version_str, current_time) - - remote_version = parse_version(remote_version_str) - logger.debug("Remote version of pip: %s", remote_version) - logger.debug("Local version of pip: %s", local_version) - - pip_installed_by_pip = was_installed_by_pip("pip") - logger.debug("Was pip installed by pip? %s", pip_installed_by_pip) - if not pip_installed_by_pip: - return None # Only suggest upgrade if pip is installed by pip. - - local_version_is_older = ( - local_version < remote_version - and local_version.base_version != remote_version.base_version - ) - if local_version_is_older: - return UpgradePrompt(old=str(local_version), new=remote_version_str) - - return None - - -def pip_self_version_check(session: PipSession, options: optparse.Values) -> None: - """Check for an update for pip. - - Limit the frequency of checks to once per week. State is stored either in - the active virtualenv or in the user's USER_CACHE_DIR keyed off the prefix - of the pip script path. - """ - installed_dist = get_default_environment().get_distribution("pip") - if not installed_dist: - return - - try: - upgrade_prompt = _self_version_check_logic( - state=SelfCheckState(cache_dir=options.cache_dir), - current_time=datetime.datetime.now(datetime.timezone.utc), - local_version=installed_dist.version, - get_remote_version=functools.partial( - _get_current_remote_pip_version, session, options - ), - ) - if upgrade_prompt is not None: - logger.warning("%s", upgrade_prompt, extra={"rich": True}) - except Exception: - logger.warning("There was an error checking the latest version of pip.") - logger.debug("See below for error", exc_info=True) diff --git a/venv/lib/python3.12/site-packages/pip/_internal/utils/__init__.py b/venv/lib/python3.12/site-packages/pip/_internal/utils/__init__.py deleted file mode 100644 index e69de29..0000000 diff --git a/venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/__init__.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/__init__.cpython-312.pyc deleted file mode 100644 index 7c84fce78e5f273f8314b4884c36c0aae2cd5d1e..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 202 zcmX@j%ge<81Pk=~GePuY5P=Rpvj9b=GgLBYGWxA#C}INgK7-W!%GA%u&rQ`YN=(Vj zE66O$FRjvdNiEJU$uH1%EGkRP({&8+)OF6u)GtfTE7Q-(Owuo?EXl~vGuAUS(l5>| zN!2Y#OwLYBPc7Cj$Sly0&&(@HEy_#G(Jw8@%qiB72MT1C#K-FuRQ}?y$<0qG%}KQ@ WVg=gF2*kx8#z$sGM#ds$APWHN-8Pi~ diff --git a/venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/_jaraco_text.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/_jaraco_text.cpython-312.pyc deleted file mode 100644 index 9f6d566b1dd8b088839ceba477b69239529cca9c..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4543 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 diff --git a/venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/_log.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/_log.cpython-312.pyc deleted file mode 100644 index 6d19003d0e8ad8151aa607a9dcffb0452eab07a5..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1873 zcmZux&u<$=6rR~#d!4lt^P|ubDrE$htdy(^mC_ynDNRDCR9w`G3i-0#cqYy!>s>Ru zPHQWN9D0BY4H8m%$RR=;fC#Ba{s%4z1*KXcaezy2t{e%eC*IrjI!To$`Mu|vw{PZs z^S$@m=%_(JcCCl*e<~sW;Gax#1E;?X&NktsMmXh)M{5+U>M2dNrZ%;jMhVwyIfX0| zo_j!eUeMK2mgLy(L4K5)&UI1X1)(o%eB^;v8{tK6fHgXbS?c~g*AAng>2?M4f=0vj z8-_72mR(q4@+=Y%0!4kU|K1iOpTLR#xWE(M{Ov@FZK%bFru3Akk#uJ1?m$4cmx{;n_Ji~ITrV^{O zeka!IP8dBa!%`jBGbs$5{v`+U(#!eX@@98gjmu#p%&~NB%V$uXJxN58qE@*1877A}!B2sb$6>>7vKw%v(L}evtii&i& z>$hAPw7Zpg5w1l+t1>Is9e;ZEv+L7yo?BTL{(8l8mny9eyt;qcdhh*8=tg3?<i- z`}%%)W;go1JoDrFL3w7sFw=(+V(M|hwtc55Y&$k=JEar&CENb8?RbM7-L`p9hh;U4 zq{RM^uY&rC$k)(+1(lvD{1+mL9+2mXnk)1Sn!EDoa*u%74HNUYo|s?x5iX`l@cUT9 z17#81It7(U9vnQi{|TsV5)Jo`A2G_N09nQ8mt=$N4ZhhMJUc#d_ZmQooqOCYQ*5an zG2w@830)PmB|8Q3pqGKFDf0w3HHidB%8&IyzIbHVeI}J}!G4IxvlOX|7>{ZkH&AVo ze~absMtANVPFy;exb*nklZlxp#Vh+-ip{A$#nTcjkklu!SRE1?HU<)5bRt>(^aOfm zAr&FJ6X7(&iV~Q3YIp0FXt*J8@(f(CS+hn45LnXRFwU?sZm$Gw4`Ey(f3^uWO!goMzlA{vIl@7J>18scg!#_0hFRgf}T{zG#?3~{<|J0_E zJf@N`wrUn7HeY(1eAHc+v*Vkw|7pVSGVSR1k9sP`)G~~ JolYlr{vU+R#$x~g diff --git a/venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/appdirs.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/appdirs.cpython-312.pyc deleted file mode 100644 index fdeda2592b698a4d8980ff8e29aef51eb3942838..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2417 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 diff --git a/venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/datetime.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/datetime.cpython-312.pyc deleted file mode 100644 index 8bb912bf76a43b5e314c642d0ed7bd0f0b677bb7..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 691 zcmZuvF>ljA6uz_1NmLwEsSGgH2nHgQ90jqpNL5oLhE_;ySuEE+>T8@k>wHO-DwQ&@ zbShgrW(0L%0Iv|}GkeJv4Vd}&?lL!g%r1yRAJ>R?c-IG7m>q`i1(mLfofxp>g zVYPWMy9dD;N>B$SIB_!E!HLV9gn)bC73RLICDm7?LxxVHcGP+*RdARx5#&4%4kMw9 zK+7ObS=3{5Eo*%m!FFyURcZ5cG|sZL^}QWllHMAQH{Z z=g*p38K=-Tpc&tz`B0})JZh~yqy^WknMZLq+GhoY9n+8t&6J2T+SfcQ=t5g7ADWd? zSjdYo1Dz_=X(Ut~lvKfs2LNOA#lLa7bF%ZpY$!pf`6)dbd^5`}QweEN}b`6Sk*9 diff --git a/venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/deprecation.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/deprecation.cpython-312.pyc deleted file mode 100644 index 6544236950fd22611f6e61e8edfe7b37c9b66aca..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4193 zcmai1Uu@gP89!1KMg5O0+liApx%_LQB$nDH{TC!%jU-KiHA>OCXeYEFXz?V`p-AqI zvSUXEoFc#)pg`T1#lSWo4}0j44(MYa_7GshP+%|ek}L)nU@q1I>zh*NVawCLBPB{r zi|qs*?~dPn-`(%~%fF=42?XtC;bY@)2BClQNv~zQgH1_5=mvTl>8Ol!K^IM-Ecj2c zEW$HlMjBFCYDCM?hFq2#v2v`Tlof%~N@l!~C@1`J)J!%~vNKQ|a5j{hqMD|y*Fv|HO z;8e}%L)W6^QGJI#d`&8k=_34czZUfo*f$zdj)kMG;bpIR&> zrf|d7nV__*aDu{s0GUmYcqD!#X4~)sc5cY zTda`ymS4P-k9v_QYr#`4I(%I-J$ag3cF$k*r0E5Rc+s~lSk4Px)X^v-Fi5KE9H9(W zRdq3a`pg?|o;fu&eg0zUIIeJ(y#|W&+hz(LHxNOfI8+uFguLjDzF|10`=@y)IA1dTpT8*%xV>m_Cuv|g`fnw7& zOjaB~tKclqB#898EihnF=&qr4Nuhk|uY04aO^uoX98^}f=eyv0u?Arbq<9KIPii&= zu&ag%dTJ0)2DK5(_9VXINqpwXl(swjwR56}{EvAfN^Kxm`;~K;cTg&9}s0L=U*J-r6je_C(W#TU{ATa!a1&Xgtwc zs7Jx&{r?l?#nR$-0KO0cUl@R#hcf~=YL;OW*P-hgw5~pX}qL)!;3sO?;*wzP0 z+)f^OklKCoz^5;L{_YoZx7{zN@1@@CL{Mt->v(SE+})i=@5YZklF{(^{h>W;LwnkL ze{yH&)eq%$CG&CSdS+$*p0ev}Wn#5<^YZ80zIfsGu`fsNDJ9>EzUMvMzO+apFM9a8uFh8bXE#ms&m^1BDs-dB96Us{^FQ${K)->H| z2nDj{IKH0%0drB^tOEQLCm_^P=3ce0S5BZFxyb98;_K5!H*;Y>R+l(u4evdFVpz zaLsU3eeFP|;qC~js3}|)=ng^>{}Yd^_0dzIY&%~P@al|ftOvcR zf9z9sqoG;)B+q4-I~qSc*Im`74Lmss7oP0yJb7i1#S*8$F2~oZh2okHDC$Q{hu_P0 z;J)PZ+@G=4Y|Oy&gd|Wg7rI zL+aX`VK*tR0K_#?SUmKW0p{l`_{!3efC>mL8=E!|P|TW+V^cUmVR2##J2o7F*LVW~ z3!ngLg~c;JvztA$3P9%ycmnh#-G_jwlo*&N3rmX7oF2g z2<(YqQDrV=JXnLl___XZ{6vjd38e~;q+Yh`gT12K8yhI8)eCQ(RiVIs?fko*G;2dX^2^YDe51tk zWL}|%U_uY`j%Ue!!t!DUQ+ZJF(%lMFg%aLneuc!iYyiY>K?RiPLqSi%+ZW-_{s0}+ zKgUsaY<0Sw+5Oi{>9^#wi+7$r@u%qR+8;A(PnVX@c4U;;a(CoVJ9qfgW9^}5+RC#V zsoYn&?GGa;{qn}p$xb{PPjoUUy=^^pxD$=QB!SZ7U5aU8V`wxa8D3A70+Rh>qw?~F z&NC=G{Biwy{UL{cV|U?E6rP(%%F4@UA7+q}eURCE^X#3>k+yOKii2NVxO!pbz} z-`4&no$F@)QVBG`KdMUkZC*@Ob-SXf6wD7%A4}O?a3ID|ZYGp#j`A!|d77s@uX+=H zp$Z=ox=jngX9Lg|y5Tv{WCUm^ C{M_=OmV($c>HUouFR#i32vfbc23_flmV4z+E zzCMDoh}S#50-h+49xEq;@1a-dYe2%igpEMoi3o!5ohS;@rhFg+w(6xP$jD=)5|S~;j1c&yQZ8?D#xE?Q&u> z%inAsRD>fPjP@Q_-?8hv^pqf+7dBGaPShU(_u=iUdq0`z#DckkGGi;1>+g5s!90O- gJ64Z=GTBK6^At*rtem=jvJ-If1wG38?|ilY7yA89Q2+n{ diff --git a/venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/direct_url_helpers.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/direct_url_helpers.cpython-312.pyc deleted file mode 100644 index 60d41e884353dc99098130b6f82f0195c50027d7..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3570 zcma)8T}&g_6~5yc+hco-Z7}|U1-k)nVz!G-*eX(#ZL&Y91WBRoZrjMIG#We?7}g%U zcgCcE9ib>{*_SS)53q`=b)-m1v^4%XG|$0k z+_I@krwmS&^4M??te1$Iwb5PM%>k5!|4|iYH&GcaFxFCsK5erMDl;;(45Nx|4pms4 zYMKr7IE(L4omw~B)ApWZqHL3G3)aP0%Rn!-uwY*98L^fmT=e<&68*08atJ+bd%f(X z=TO%#J%!)0ae9jP$~M^V0xw!NU*b!*Wv4^QFU#ygZ)a?A|G$N&?fYVodhODage?2k zNi^Fe`h>akG!aX$L&@O9p35xwet|sAnvSn!mV_Y_IN83?-?3?NW!93UTJ4zH?xCb( zIen*~E@Gm`rTFR7i0cIy7L{V0;NO=Z>+@LEF4Nie~Mx5Y;;Q%Ht>4YYv!O}7xFkoBw1053MrJ9Q+KiUKra+ix5%QTUcdE=iR*WAN@@|Si>aJ4lPWIh z^96N$bnNw%rs(*3QOZ7$=CGE6_@qQd)iD8_NtJXZr=>a&AGOiP+r z#Kjvo(qem(;8{#C1cwZQlk_2L0F`JJ{lInAxp0jO?{m>ccWA43PH69>+~ z`p9N#BlYDQ`_5|(zGr>89)7JBeyt&d9!)=-t_!i65UcimHTcEgPTzO2Z)5eb$=cZD z5o?RM50TB~e&{)NAa`(ma&vlP`pXaZU1O$|&5t)euJMUAPs7vu=gezN_C*otVJ}_1r82hL2`oDeAt&u0G$Eoc%_I=~K{P?bK{G1tQpza*}-Z|Ld z19d)9<0D(Kuiva+yIq4{^!7e~=b6(_RkW>pPd<43K~>osNY}#Y8lR>%_rOivr_}??iZ0FM zaMDI7mXIFkk}RS6gx-*uj7f&Xf!FAsaWVkC5k7O#klvzYhYV2}_-irfR?&eccp!wg z+JBoX4_ zPsc}ht&&4$&o%PrPDm~)EdVm7#igTa1*yW8**3JXFDW(`6c$VSci>%xtJo`!vW+;) z_O>N^#i{m|nNzz^KF+r?W7()Ub)U6b=JdcR&n{e02FkF@He(egI9t$??@&mAb`H+@7dze(eZ&Z_z#MvL-nEn(yAmbT3kf>8D~0eR-B}p3{z`y z+9jYfJa7uj_tt@5rPGXP2BxJs1~VEB7A-KX)Yh?WH4SVc_- z;)Or0e6n&7iq=EvS}45}{I37o{=Lx6HP16&-!9*`w$ezX>xp-3iFX@E|gFvJajMam~wcv20Z>TZ!lVc~>-PLrXzQKBQycQil_VIpq6Y(y0vm3d) z>aKyBYhd3MGxdXYf3oIJf|b8S8_|KbhLfWj9B2s0A6(-a!N}&+#?+eYnJ3r?#nwNp zGS%U)l3ygN{kuKa*Y3V(>PmHZKk(`W)=W@L+NOS%>^2Pcxl`Pb9O7n|N<< zGlfFVyzg(2>A#s4C;VIBWGRP#N^Zhlw0dYdbWN6FnCGbfKj{7*y8j%FJV)v0=toUQ zkO}W7O$6j`no0hy9nn#9lw%xUvk+{?vEw?Tr0GY$Vt&gUvT4TMaCbFLdS$qJ@A1!D R{N$8Lf3SBQ+d;VKVy1|0wZ diff --git a/venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/egg_link.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/egg_link.cpython-312.pyc deleted file mode 100644 index 813c92d2502a3a7791db2f808d66c468c4ce1af5..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3233 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 UZ-_mNxQQBokR9#~CGO4s11$*fi~s-t diff --git a/venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/entrypoints.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/entrypoints.cpython-312.pyc deleted file mode 100644 index 89bbadcd9e6414ac1e9f79c6c54dc34349aaf150..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4000 zcmb7HU2GHC6~5yc|HS!moF6BfhH^=O$ZRrh7pN8%kRYIh2m)$oX};<=8;jAy3z zjvb7gDwS4RP^loRN&#(G8>E#$;)O?ETUF{qUu>mq*dbM`wmkHu%0gPTJoVfePaJ4k z+AGifzvrHNe!g@3tM>LNg0dpt*8b6o(4Y9gFQG=~0mLG4hejpsE3P@bj0mTdP^~yjzT}E28mcm_}4VsLVvUG_dY?N2L8YO zYUn>uAMj~5Tc9q@iRlg!rH9n88p#LJu>c~dfSY^#9_b*lM*(ki8r??Oz#M#6x)EAH zYPc}$?`yVI^av!!%TnN0uLQdnP`X3yP+Lfd1WDIBu);qzO1g8B+WKKI-2?ruTtIF6 zP)heU`t8t9RD^6ma4F2AWb7}T=yWpRNar+WJCO^Pt(k_RCk00;Dw+Xp`10B5(-$t! zIHILluLRja*Cm-;BaWodIp%~Yu}jp*HW=jekl6TMej7T=$mVlyDKwt#k9k`NZXbDl zRq!7yAUo`@H^nf6k^$ufTsck*n<_eq^v16 zflD-oEl{m@zeUZmrUDsUB-y-TXsqZ8abBSY=fk@eICYs+HA;Ycn0I-#fv|x=^3=4b zOWo3yEO80siEfSJd4dgdz9CCbGdb_MCHkh4Fesy;N9K}%J8-r{DQE?o29Z6v4}#h+ zpZw|b0x4} zfO=vhGeU6Qwk>uvm73G+d}&tBn#Gh=v6K|-OL-QNI(+!Z5zqM4 zvIY_WLOJbPLr}P6sD$bjmq%_va+Is2Y-(yl9n_rFLH8B2gtNf9_mGD10Kaw~kBk*L zUn8)_Yyu_=eA1HP>WEviry0E>N0X8xf+ad3X2Y%23C>dutd4tGQlK2A8TVEEN>Am@ zB1ut2)eK9cX6btBG+|e5(@LGBWyKgfdGYMnxUQwj#3-k9Z5Ce5t@)t*_4iT?XpUJ* z_Np>Rm@A2lYutbxsgkYfEVa#-WUJytG7a6*INaXH*%*Op5pDLPVC18zA5N`FJ$0#P zBM@vE+7!dV&}JuU>%1fV=x9yqeFrX#gTr==$U(j?yMT!5oJevt)DJ1his+Ns7DFaCPp&fJWO9 z51bC1(kOx-$xe92MKb1yvzp;ZJl@b2xbS)yd%%#4Q|=K?z+{fZgODQ?AoNkLR3~In z2xixuh+)!V7GTW@H>f)zL<}d$EM2pmFh9qL<-{{*zH?^$TbE9rI(H^Bee(R789-b#KDTu4^X>-& z_XlcY$5(q!ES}$tpst?fzNNmk_?~)v&*wuA4%|QRK)x?OPCV&a9XhreKfV?pugAxK zaq5>-Kbu;OUs#-4PxLR(EzPYZ_SX~pR~A+iho218661>(z6dAQ`;#wFYYVLnt^H&{W;oxTfQkTj<3h!x94xpuf=xPW4l+x z)!5#}$;}Yz|LSsesk$<`+BXK)`bD_!r>8!fxHqvjI9eYZ1zUZ>emyw;G}d<`wh=;Y zvBfD@-AQ3O+2^$I1i>~w%zDUSS1d?dC})py^*RZFDtRl`%UNBM`5y&0zisaQq%yLDCXq5Gmxs9^Mt#$O$?rrF#slNs->(= zd7y#p#-@%4*@l}*xE|{Y3;wGFUEFZYAF6?6iKa5zq0FY`R-^<>I345kvrdA>)l`P-CrAdzjpNe zYVY*lgW@}(KeWX+MAXuHJA5;IC-~!z7a~kT=JRD+kC3?Y{@v3n-S^JcyZ3J(7(X6< o$(s$iUpW2{`p|5Aqg9AKoY_Rs{PV^41vt&P7ydljKQ2iB0#jVemjD0& diff --git a/venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/filesystem.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/filesystem.cpython-312.pyc deleted file mode 100644 index 8d44a6e7bb7a11d6b39c9e5f06d4117debef95e9..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 7465 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 XuVFq@$uR9HD~h)-TAyKL?D2mC`59bh diff --git a/venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/filetypes.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/filetypes.cpython-312.pyc deleted file mode 100644 index a09011bd32e345d8e0b2b24dd8290ff0b57d632c..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1171 zcmZ8fy>HV%6uh-~ZP6km#Ft75q7o{o4N!S8ZhUF3IJR|m0HkGp^PI{xkI!DWu43! zYMrc^+Y`^FaT$qK&Xo7$hSJxpu~oU%$w<yc0+>+WX~higH}?&p*2u$u>={R8V=AeJW8PrzRAVT ziKqJ7NLN1mSw7O0k8H@}?b%*N{-mhgjM^*g?+p!aQZAU+3Q5MY9KT{&i9~O}-U?xD zPYzNU`nC)`m7&*hSlQ}M;pXL1>B|465Rnz}VMLOGW!awRN9h|5EsIDrMKTPs3>3x` zmVMt%g}(-*$il-E{$$V8eW&4~bL24HvVnvzDD-&<;ZF`i;kN|fq3>YwOYva4&>K71 zRyty*vNqkRJuhs4lYLGayDmy`=C2odYA8xUjGP+eMy8PYvX-D&HBVIW>U?60nEHQ3jhEB diff --git a/venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/glibc.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/glibc.cpython-312.pyc deleted file mode 100644 index c746100fc93339383dbfae937dd0f9f2bc74a7f9..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2349 zcmb7F-ER{|5Z}G?*=Juu08bknSX z+1cCq-OR7;?GXgD5dX&1+7SAaFMJ9#g=GhX>nMw|xPZnQGakdR779X9921Lyu>eL{ z(GU%33)tp_Y~YK)Sg=JSfhN?V34%rjO~8;0DJL{NL!b?pu_ph;!>2UCmCrcLv@N~h zO6N;X!El4bU?pN@xPeas2qKK-II!!8VSnRpQ@Da@1S7_6Jo5FUNW(Kn&Uq(Nb-Z9+ z&Ztucp%77}jF{H=e$^&w%C-#E%&C^m)Di`4!!!=}+vYi?n@;J5Q#xZ?IS}36^> zG3ZZdncrnKm&n^iBSG}6X*njbOEZb%2AyQKlSq;&-5N}u9T^-dn29OFno7VG6Hb}s zZR>FS;GqOHnK9_-nMr-zpb5ux5^2+727w1ll$cqd3GW7Rr|d@8y9)Y($C$;5N#IE3Kd}#?L^FjGPh>@lRRP@d?_dHLPW&q z5-JPR=!$p=O=B%E^X^$<7Ijiq%_2anXjn|=U{mc}Bf&4FwV8XH#+&(#yVA629X^zD zyM{*7CsG&Er$^o!N?#m4H#%}ArOB>H%hZ*fg3fX_DY}A9-H?wBi8=+7xf_xUfOfgW zjA24-;)c$QHiXDUy-;c>HPP)Hw@PV_PybFXPP?Hd>?lu%s;WeRnS^}CSJVJDhgRB< ztbAGdta5Goe(1HOj;^{OOVQtYx8FQ^<7joyo3-9!ReAH0(pyz_E_L-hiS2$E+jlRv zuNE8pDsmNHeWNa;wywF<^OX>4@BQJ#?XjwI;29F6=pS&F1oJBGhDhJ{Bt`Ud7qCS! zn%pWbZo$A?;KM762cK0CuA?wi7N{kNCw*cKAh6Y>tgr?P97Ywq9&`W%XkrZjz9&Kz zA-x7P0aiYAW<}QFTUA8X>C1PU0Hzx&;zXCP{cnB&qGCn#V7CVOR{;i~lzrbra_lb*pG3W7c@~F6Y1OsnDF@Jmy#k)XQujMq07+|{sJrNp>IP=|k zC^gJhvj$Y?q6s~P<&D;^6N&Ig^Ba<`GT!reJ!&)-st!O6*zfl!O`Xo0nLHer(@O=$ z&o+tKblQkjucMis= zV%E)gTHJNUIMc52dRyZ*Gr^PXEc>heneDI6^bZP~!k%Vlcc(kk_MdE=N!HWp^nJf` zBqWyIbb1)R`~7>~=Y8K#|Kjnu34Dve+p+)g6Y}qvDSVQh*!WvW+$Abexi|@9%*VL| zALbK6SV)LrF(HMegd^-oRD>%ytQX?Wge&YyxWn#5Ww?@+iSeq0C+y*f#?vZjBgIL= z8}_m~2aM+n`ygErt{x+*^Y6HD4Np!H)pdiY?oW7YCE;3DRtaTQTJ0x-UFx6V0-pcE z%t*jtdM>>4=0N1+(7?$v!y~6m=j*YgLT85GFvb2@)G(dHhDMbuam^IJ9n&HIM%sv_ zl1e-vm{miHK7KZ)Cln((ZdTekJ(e6ZYlf4$p~T|~HXfifMFX5!Ni{`{M8~I+lR9Lj z2=;)4b0l?6Gp1R-rkXp?;Ld5dT$C&~YO7jtLkzn#w<>CtqrB?8A$|gF z@C#R|F3q93;a}7|qYkwaT6*CeeOh(NI36giQN1{q>a%8n8LDB18mOsNYc;<;qaX5h zY8{TpR!|T5dRQl}(oyIMGl^;g)HJYJd9@MJjjBUyVtG+*f_$^R+Ga?%%euv1Bb5%FpjVY-_lY-$yHCbrp{rW*YA7DN z5=ze)mlo&g6SDp9n{5)NF?L4 zfD$Ye?1aVW#~`>)@^0dc#FSEiB3cFr6jBBV;4J`zQG`L3Gm4j3pex;BAb{9+ zo@6;4t{P$jF?Zeu(}bhYVl$p_ZKeyU5^#NM6I@v#OST)~Do43n^;xl>+?JyJ7>V+i z8UT(`R@%OORzM24N_6Zc-QjOFiO>hy7l3+LBqc!R3qU>(tvJ?lnmpo004(kp&?PV> zh$96lAf|UDWeg`kSQ8ptr%G`m+6Y0wL0d4r3tI_EZJO@Dl*5uvle?-xgKYo%(}6DO&zU-vi8o%w~&zwU3E z`!?LMuVzkIZKb0>9Y5PALKrO~1}ac=7@FROL@An7?grpwqKGJ{w!evjQZ5ugyorrM zYV&>q{7Bi92*_Ue-#7@t8N$J|S#k-K(=1mC=E49!;O=r9xm6>Q8S)RpG)Ft28)!Ho zt|bG!$p;UZ6*isdxLVn|s^_jFV_H(XmZrxtyY0)ennj|isiYA+5>G{yxPB~HYqs*HNxr^LKC2yEJoQ(-^V4^aU3 z2CP{^-*QX`ExcyR_C8%(VrVW*)b%wjEvZ9bIuAwGPN(nLuSsiNcFBZ!E#p*sAmY zd?p1PgDP!BHR>Wp5%=5iT~;Unw#Zm*pjtWT-v#}}EI)zv*Osqj7Qe-g6E$0!Kz37Y zgCKyyzO@&X_5}3U`jw2gyU5XwtYe~nYs*cU-5w_;e7u_@Gd#>lCXh6@eAyxsW2+8g zI13F7X4YeFlo&LE)f@>3$n6I%budt_w41D@iM%jv`5z zj;S;(M`L;i#96y$iLmL2P+V4^!jhR+v8_0kGIWaKV@hmSrihb)a6vihf3~}VJk>FK zGh!c+?F(dDai5wV+^%vEhR}Zn0hlOWQe8VIt~a+mXuH?8*1Rv*yl=I+`zaA!XSliH zJTG|8a9^|sKHm3m-%@O~{ndGK{+$nfc?s+DRit4Dm@}@9xqY zURh>oB6y*hImv@q#9S@@D0H|L4x;uboSi+L8(rnuR%e^W8aK*@t3d-N-|gu-j;9F4`bvb7ee{$;2~?YW&VP+}}`1!^k9jN+9)EM|&~b9TpLlbW2m zGNDC{|CbbjQs{>jQnWxI&6L6^NSB_8SzC@!oH*0GEqJl&GIqy-0J>GAx^B(amGgD| zxOMr$YM^h`cX-8l*gmziVvLuange>V8y<&5*$s1Q@it#V|B7s@B#UGf<>BoB{t5`- zKxKB29xz>}!4!RmaPT)%pfi5ND7 zZ5G9$t&Wxom>Mtc`}pF+i+_)9nrla{Y8MbxX5Hss^L6BW9gD+Dna_cl8e5T>b^tR~ z*E778S-5xt3~BozQHHc_4eBzf+`r{KhS{?LyerIl@W*|64Bm+O%{2TWv8(jcK&^j3~m$E&7$98`)Pb$hC4MF2fyDe}L%kGbC<9mG%+Oby?=6iwp z(OCPNrmh8H;k)bY-A^kZi!UQP^Af3Vx;u1dXd$}z^1`LHx_x;8>elP_J;B)a()I+n zfJD)MpkWM}FerNcbQ?KAc`B0=t00T3Itl@T$iH6YyFGMs=!@!xC%C>}??3R9vyaZM z?SCz||FzZqC!R@AxIx64+6}?s@oostYImMEU2X=h0+fC%ov((>1H%ZD9SifO>_iPZ(?vB0@Gn>fBGFPK~v=sv37%gnY9f+ zr0{HYCwN&m$P-?WoKM_tNnW_NBrcs_?p)S?8d!Qa*L5Vf^Jtzx#Xr|=V6@RxBemvt z6Nfj?bJ8hpAqsj4;tio#ly~sbu_b?=K=inSMW1$VU@q^hms*xyT^@M!TAo1iv9W0hFn;#5WK?*Gl<_ScL&=aD(+ahM2$$rGfNVY<)MmEcpP0VDo)*jKsJf7foIC zM!~$;)t^f4!T0J>`w`>vWfW~qzkFGqoL1;qFu<{gW%dHCPl4nxSu#C?C*FSJ-0+2g z$k2)NL$>lUU6DvMuIPFsVyU3(%(`GbG7V+dQG5@chxIax72cHKdCuj%S&?%#eblzh zugJYC&Zf_uhb*)lhlbzeoFJ!_Dx=ajUlhVW_BK~gC@$vPaj;$BdJ<5|?3&}&X~(cB26I?}r1v%QjwCt1^or6; z`6^C2yoCb}FYg7*SF(Hq);CZ``=F=kFlN$#NQyACc#tgzdD3E5WLvWdehml~e+>v0 z0j*n3A3I2NHn%opKN|!=;-bt6+Pq$N?55}Zg>!F=oMI3gIB)SO+uayWFJpj2``mfN z(h0{X3IOmd(T5=bH<#o7jd*`WPOp*E|3Ti$k+*(H4*W)_{-xOVrISc9`~p$aeBJXD eqR@5ESMVbz=YB#keD<#3;||Xcen}u=Q~fXR_L!vr diff --git a/venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/logging.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/logging.cpython-312.pyc deleted file mode 100644 index c9bd767f900dc616b7daad894a940d6477aee4a9..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 13564 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 diff --git a/venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/misc.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/misc.cpython-312.pyc deleted file mode 100644 index 4aa9f1c06c00941fb426d916fc9f3c1d26476988..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 34128 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 diff --git a/venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/models.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/models.cpython-312.pyc deleted file mode 100644 index 9015fff42a8570bcffb4afcd19e34e91e7d22888..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2719 zcmc&$O-vg{6rTOX{2GFxrTJkg0c5q{LLiM4Qi(v-(l#V2O%J}T7SGsTSnqCT7gQr6 zao~`ik{cYURH;F^aO|;%9wPN(i&UhmNNv?qZ?vvdDW|@-YrBvFrz)AloB7_Gw|?)< zyl?zNYikpMu|0C%+>r_S4MA-H4oBq*Oq+y~G@$|&Eg>zyELmbfN=pSfEf$ zK&ZSysPagR9Mfu1OscCFZu_QX`X=+Vtiv_RvZig?Ij!JOW_eA&0PI?GTOwj)%CNwKIh&IT5}q zM!ya#m3F|6j$%XdOpy4P6|Wl}qti~oH8{Ireqq|H@806hib4@Tbt+0B=GCVJkP}}x`QsvBF=Js4hs@4)GJTAl) z4a6o{6V`|ht7xo=fP@+dnIL=3n{ng=N{ z$Gntlx+&eXea3CWN-e{E@>0?D8FAsx=wLH_U0*$aT!lw!=2ndE42X5|^jz;f`AMwj zY47ko`N!C~3TR2Do+bdyA}q?=u-GJi-L^&+tM?lW_3@}`pC`Nxlu0p=^M;oX3zZaj z9CRLT(Re#Z3>nR*gdCYW(61B3I(ZiFd@!@07$_$O_Tq!3*dWJL0>$z3jAssqgpC`9 zejOHYo@B8eJSeJTP4MeJi?vp-8DXw9aV;SUVy@n|Am+G?8@|H>Ro5*j{EirA$h*PO z!_R6_p8O41ubw^ORM0a48!E4XfHR4A-oN|h-L2bSfB4PKuWs(e$4jyCFv*vY9e*8S z;MlfdPE6PNSpY|pxd4ijlK~gZgP%izNAuF7&Otr@8?^?ZoESB_;2FKjsE@7no2Nz% zF6Uou)a=f2wZ3>-)aarei8@dV3>c3dVdHxD`mpy1@c=I$OFh*-_Ef*#$MZny$lQyy zHxs^98*9RG+86s>4w_8Qv_0RjGc2U~pl#0aXA7>y3Jj>2M%*U-+xdI|exgSIAb}9 z_+%+I8Fm@Gt3alM_prP_d66!F!N H2tV)-Ardr^ diff --git a/venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/packaging.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/packaging.cpython-312.pyc deleted file mode 100644 index dbf20113794b67634ff4e8a05d395e8dce1a4079..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2590 zcmai0OKcNI7@qYrek2Yd0TKb7gjQg{HW2ZOP^B~!frJ7gIhm&RWOr<@v#-vq6C8n* z1Bc!UQYCV#K&k`?4z1Kfj=lF{dk6U51jhXc-Ki0YFF_*{`u#B|KH?? z{{AF_?|%LZ{ahbHzllxo#r(zQ->|rcG^8m8Dt2e3sK|Y&7=k%ugw04XVn&NmGgge5 z@nT#Nd|{){OcWDlvY3?nh>L?BXMXB!(RBz36@QLE{?9gHq z?u^1#i_;h#()ubPxl7QUm6(>i9Vrfj98^ENbw5~Xsi)~clGacAwFFI9BHF<1$P=HX zxJ%1O`T)=eLDuf3lHKvAIGxQ#y!b3#nQuDO>$~E(x@{4|i_SM3gL)B_a5o$BlH8%H zUePJzUVIrw;CifhscZDJhR&!-E!WG;+RP+|zDl)^Z@7$j8P+}JC8z1uY|BggH%q!z zvGZPxQMbV?)en@k6%vKQ@Z0e>xT)U`gUG<0Rd0o{H>51^@*q+q&OhJ ztcB`{ZCiiorUIIq4pujnAbo-CV7?W;8NL}>Msp||ChK5W62muBqv{gYE7+}3T-BGU zg|AAVvF|cAiL2Hq#{^IKLF2hD%LMKPH=mT!rX0eE8C;don!?j~GUtkJTCJl&u`Dn^{L5)ayGD~ zo1`gRo@WhO{!bq{adi$w!etoz?2FpS_pG`C0b(mUr$@njk$qggKnzaHJ#_>QIlg2q zLn&!D_YphT7nhQ3(nN}9|cKT+ViOLGoUmq?ZJf}=YH$h}J$ zG-RRS>ITr{A>=#nG`$g-#nM|=G65R{@Z%R@SVNt?sBd>GzW-Hb=TG?XbA0+4KE07? zTpht9Wsf+~CmXUJ`VdAZ%ce+UrqZ6df$Pcn>V@p{@Si>Q(3;W%cBYZNc@1>O%c) z`F3p!Rj|ESr*OQYyEUv5wFat~XyUBG_QJ%4TFitVFH@y%5DigvOknN@f++*T8hSm5 z(!1}hwo?c|}N_n}Q$FsIeK|FC`fE(~< z*{;+p(368l!dVI#rws0^1l$3U;$$BjlHBUC z+}V6?;fSY{vQZ|U116B(3o#14-dOaa(izyv5;8KjZNRH(*wv~i z-U*Q7#oVSNHlj$F01qY}E@`AU0*#*sWU(}x<$FybfvgK%6Ypfm`#2yfpEL2V4;vAK z^f>{oaTyGt%+C#_JGOrS2 zpYML27<-l&TR+oIyuTLf#Dck(DS zvNrl$8Gfb=uh0FcjCVqD<-q-L2f_3x^_Q47!zeT%>7C((a#gvbc959Y?bmXaj{E~w CgTD{} diff --git a/venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/setuptools_build.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/setuptools_build.cpython-312.pyc deleted file mode 100644 index 7cbb4cc51fb3e6dfd086510c65242e1b717d89f6..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4557 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 diff --git a/venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/subprocess.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/subprocess.cpython-312.pyc deleted file mode 100644 index b42916f79c9f39a1b88df5f414d79fc1a0b546e4..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 8725 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 diff --git a/venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/temp_dir.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/temp_dir.cpython-312.pyc deleted file mode 100644 index 020df150c0d6213a42e95a108dc52ccead33d1dc..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 12069 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 XB-bdZ?>@rB$|H3Iq%yKjiTmo`T<;_E diff --git a/venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/virtualenv.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/virtualenv.cpython-312.pyc deleted file mode 100644 index 7d8da7c315107dcb79fd9e7a3ad44c5ea1dd64a4..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4487 zcmbVPU2GHC6}~eb|L4aLlK?^Ng@goei46n@8wG+(5{gP8BIyrSTQl+8*yD_6thwX- zHAs1ArA1nmqE-qIRYfEuvZ4>&YNh3+4?Og#FG-C=c0ejpdFh+AL0XBv^xQihI|<%h zsW+K>&&>Tl=X~dU{zr3j2tj!mzo#xYBlK_f;ufhYY`pUkL)=B3$O>q2jKhO>X;zNZB;o0aG z074TeCNAoib0jlEu{w?62JtDGl627|)9O5yb%lScz7}LFlZ%H!7|LW$r8oxzG(z$C z=r}%e@+{66g`%d)x`k&|(<;dtCOSxlULd+f<9wnW-nK)`V|!pz+vn_H`?JK7EzA5A zZLu@Hn@Qx10!f&%qUuFhsI-_EA#}zviixB-E9-s9@vD88H8n8{8znS#Dp6dpa)#a? zKXp2>!w`w0T1=!>-6AF!Em5*mjV7w6gt_tJg58!jOS-P=*>p))h?!<~-dUL!Xh=X-)n^fMzk{lT#gRz>6Z6|S(rXf2wH{V=swxD_?q#<- z;R!s(u!jvRN6a~ul6XwyHs(j)ec}DP9KvyG<`z*n+XwJaCM=^j;lt%H{%3gXdG|=U zdu&}Ad;hLAWFv5b??QIIhHO~BS}e8#FL`F2U8U|ucTf;n%yhggLCpQL$91u@=#H=? zh@(sMPh&MY63)%E_4b}VNMj#Ex4F~7NmL4Ei@-|A*&YIyOHT( z{R`3@a(ZLl#oyc{vO@8%SkQ6ce+SUZKo`$UXL;;#;v_Qa5GQ}E1U~Ei7 zs}t(PqnkXGQheRe$qD8Yss&R@nu2x1!rUD57qkNO`E zt`4p(mD`7wZ&XB|H~Q9xTK4`fv3BKo^O*_~g0ZKLm|5dNh(c?$jQaPpYvS!WQ$XUDwBxc}LQ9wx_m zeJYr|;CVJAK%IdZwIYGU!TeVc8iDx^T0+b1^~l%A$-#}QF%n!!TtXx07bg)o?KbCU zs^3+XYP0T$OX9NdN#~N7uR)+bxK0`rY34YnSNP;4+ebnR-k48L!PY$d;@jWgmbdY= zVX~YEnI7**Fc5Zt22kJxjzhXRkrqitomL@BS~=Omb2*|no-acPW4=mD#iBtWZd(SP zB0NgZs#KlQz->*V@J(^;cHNI}<3b4l!Vn{?y5sPMrWteK(0o1SV}s5ySuX!J0)sDL z&Q_e!Nkvf|+M_L;z?uOt#dEUBk|x8PgE02uf(#}@qOC&hx0h>xtYWdZe&}AT5LyK8 z)cAs+3bwACvD8@-$4N>{1@^emYBA`dNaE#ef9d~Yd;m64dgAKjXnH((`G?6XqZ8?yqgO_M zW_vk1vb|YgDMjElL56rI97wD&d%+DU!v|>G#lCK&oeONI9N&X6{cLa*`|W5?PdU=N ze09?wS@-V;um@Z3wcKr~h+=csTaOeBRYE8deH}UQ74mrZe=NO<^uLIFv=RB}X?Hm? z{IPd49N7pTdbsa#=W6HLPs>NnKJ6$Ux%6dQN5v20D*@EB=lyiW5)eD>R`mZ(S1{Qr zjc91z@AlSPtCrUC{HI5~he>W+aN9fIL5>?GIY@>zwgoYzwn4)aHb{i^IK#Qx-<@Cq zo_|y~`W#E{4Kr8VWxek?(Y1%`y+`@-jNlLrt3o;GX6f- zJOf*e!$W@p73Z4K_LYJA11rP#haa7OJg_?OczAXA^D|#u`0PTtD_L&){_?d~UB`IG z(CW};Ai5biw&nG7`_?7=7C_K)Z{Y60y^D7*t{*&C4iBtL1Mj1vMp!3d(?&VY3^gLF z^&e_3m4b0K1i0TO5d6>-7k}V#85vI*hDK!lM9tuJj*A&na=5*2G|VXRv6$p=TNY6q zg3FY)o8?C91ir3z^Bj!)B|P*PRG{7f3UogAA9~f=U2g4J5A?k8_dfT>UbUVoxAw0G z`d^15TwAer+t1=Bcqw-rTQrH8V7oGK+dgZd$huf$F&Sa7gTQ~TIRO{kh><3I@sKSLC;22j6wYcYz`B!IDNUn#0h`2nPKVRKR-# z;U#K$iGut;{1S!!g^s)q9{jlDMeyK8@Zf{<Pyl)%>P3yyX#l#dXwG z33-L2@L+Nav9=QN3B7CGTL_xUUQxIrJcJk4Rzgie^uhd^v^Mc+aN~p1TL|7OhYt#S d9#~rln#y2UIKMWsg`lY%3c+{fErN#Y^M9|ZSo#0} diff --git a/venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/wheel.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/utils/__pycache__/wheel.cpython-312.pyc deleted file mode 100644 index ab2321635cb9ae88d406eaeffa8662bbdcca1b24..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 5933 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 list(yield_lines('')) - [] - >>> list(yield_lines(['foo', 'bar'])) - ['foo', 'bar'] - >>> list(yield_lines('foo\nbar')) - ['foo', 'bar'] - >>> list(yield_lines('\nfoo\n#bar\nbaz #comment')) - ['foo', 'baz #comment'] - >>> list(yield_lines(['foo\nbar', 'baz', 'bing\n\n\n'])) - ['foo', 'bar', 'baz', 'bing'] - """ - return itertools.chain.from_iterable(map(yield_lines, iterable)) - - -@yield_lines.register(str) -def _(text): - return filter(_nonblank, map(str.strip, text.splitlines())) - - -def drop_comment(line): - """ - Drop comments. - - >>> drop_comment('foo # bar') - 'foo' - - A hash without a space may be in a URL. - - >>> drop_comment('http://example.com/foo#bar') - 'http://example.com/foo#bar' - """ - return line.partition(" #")[0] - - -def join_continuation(lines): - r""" - Join lines continued by a trailing backslash. - - >>> list(join_continuation(['foo \\', 'bar', 'baz'])) - ['foobar', 'baz'] - >>> list(join_continuation(['foo \\', 'bar', 'baz'])) - ['foobar', 'baz'] - >>> list(join_continuation(['foo \\', 'bar \\', 'baz'])) - ['foobarbaz'] - - Not sure why, but... - The character preceeding the backslash is also elided. - - >>> list(join_continuation(['goo\\', 'dly'])) - ['godly'] - - A terrible idea, but... - If no line is available to continue, suppress the lines. - - >>> list(join_continuation(['foo', 'bar\\', 'baz\\'])) - ['foo'] - """ - lines = iter(lines) - for item in lines: - while item.endswith("\\"): - try: - item = item[:-2].strip() + next(lines) - except StopIteration: - return - yield item diff --git a/venv/lib/python3.12/site-packages/pip/_internal/utils/_log.py b/venv/lib/python3.12/site-packages/pip/_internal/utils/_log.py deleted file mode 100644 index 92c4c6a..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/utils/_log.py +++ /dev/null @@ -1,38 +0,0 @@ -"""Customize logging - -Defines custom logger class for the `logger.verbose(...)` method. - -init_logging() must be called before any other modules that call logging.getLogger. -""" - -import logging -from typing import Any, cast - -# custom log level for `--verbose` output -# between DEBUG and INFO -VERBOSE = 15 - - -class VerboseLogger(logging.Logger): - """Custom Logger, defining a verbose log-level - - VERBOSE is between INFO and DEBUG. - """ - - def verbose(self, msg: str, *args: Any, **kwargs: Any) -> None: - return self.log(VERBOSE, msg, *args, **kwargs) - - -def getLogger(name: str) -> VerboseLogger: - """logging.getLogger, but ensures our VerboseLogger class is returned""" - return cast(VerboseLogger, logging.getLogger(name)) - - -def init_logging() -> None: - """Register our VerboseLogger and VERBOSE log level. - - Should be called before any calls to getLogger(), - i.e. in pip._internal.__init__ - """ - logging.setLoggerClass(VerboseLogger) - logging.addLevelName(VERBOSE, "VERBOSE") diff --git a/venv/lib/python3.12/site-packages/pip/_internal/utils/appdirs.py b/venv/lib/python3.12/site-packages/pip/_internal/utils/appdirs.py deleted file mode 100644 index 16933bf..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/utils/appdirs.py +++ /dev/null @@ -1,52 +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. -""" - -import os -import sys -from typing import List - -from pip._vendor import platformdirs as _appdirs - - -def user_cache_dir(appname: str) -> str: - return _appdirs.user_cache_dir(appname, appauthor=False) - - -def _macos_user_config_dir(appname: str, roaming: bool = True) -> str: - # Use ~/Application Support/pip, if the directory exists. - path = _appdirs.user_data_dir(appname, appauthor=False, roaming=roaming) - if os.path.isdir(path): - return path - - # Use a Linux-like ~/.config/pip, by default. - linux_like_path = "~/.config/" - if appname: - linux_like_path = os.path.join(linux_like_path, appname) - - return os.path.expanduser(linux_like_path) - - -def user_config_dir(appname: str, roaming: bool = True) -> str: - if sys.platform == "darwin": - return _macos_user_config_dir(appname, roaming) - - return _appdirs.user_config_dir(appname, appauthor=False, roaming=roaming) - - -# for the discussion regarding site_config_dir locations -# see -def site_config_dirs(appname: str) -> List[str]: - if sys.platform == "darwin": - return [_appdirs.site_data_dir(appname, appauthor=False, multipath=True)] - - dirval = _appdirs.site_config_dir(appname, appauthor=False, multipath=True) - if sys.platform == "win32": - return [dirval] - - # Unix-y system. Look in /etc as well. - return dirval.split(os.pathsep) + ["/etc"] diff --git a/venv/lib/python3.12/site-packages/pip/_internal/utils/compat.py b/venv/lib/python3.12/site-packages/pip/_internal/utils/compat.py deleted file mode 100644 index 3f4d300..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/utils/compat.py +++ /dev/null @@ -1,63 +0,0 @@ -"""Stuff that differs in different Python versions and platform -distributions.""" - -import logging -import os -import sys - -__all__ = ["get_path_uid", "stdlib_pkgs", "WINDOWS"] - - -logger = logging.getLogger(__name__) - - -def has_tls() -> 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 get_path_uid(path: 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(f"{path} is a symlink; Will not return uid for symlinks") - return file_uid - - -# 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") diff --git a/venv/lib/python3.12/site-packages/pip/_internal/utils/compatibility_tags.py b/venv/lib/python3.12/site-packages/pip/_internal/utils/compatibility_tags.py deleted file mode 100644 index b6ed9a7..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/utils/compatibility_tags.py +++ /dev/null @@ -1,165 +0,0 @@ -"""Generate and work with PEP 425 Compatibility Tags. -""" - -import re -from typing import List, Optional, Tuple - -from pip._vendor.packaging.tags import ( - PythonVersion, - Tag, - compatible_tags, - cpython_tags, - generic_tags, - interpreter_name, - interpreter_version, - mac_platforms, -) - -_osx_arch_pat = re.compile(r"(.+)_(\d+)_(\d+)_(.+)") - - -def version_info_to_nodot(version_info: Tuple[int, ...]) -> str: - # Only use up to the first two numbers. - return "".join(map(str, version_info[:2])) - - -def _mac_platforms(arch: 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: 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: 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 _expand_allowed_platforms(platforms: Optional[List[str]]) -> Optional[List[str]]: - if not platforms: - return None - - seen = set() - result = [] - - for p in platforms: - if p in seen: - continue - additions = [c for c in _get_custom_platforms(p) if c not in seen] - seen.update(additions) - result.extend(additions) - - return result - - -def _get_python_version(version: str) -> PythonVersion: - if len(version) > 1: - return int(version[0]), int(version[1:]) - else: - return (int(version[0]),) - - -def _get_custom_interpreter( - implementation: Optional[str] = None, version: Optional[str] = None -) -> str: - if implementation is None: - implementation = interpreter_name() - if version is None: - version = interpreter_version() - return f"{implementation}{version}" - - -def get_supported( - version: Optional[str] = None, - platforms: Optional[List[str]] = None, - impl: Optional[str] = None, - abis: Optional[List[str]] = None, -) -> List[Tag]: - """Return a list of supported tags for each version specified in - `versions`. - - :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 a list of platforms 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 abis: specify a list of abis you want valid - tags for, or None. If None, use the local interpreter abi. - """ - supported: List[Tag] = [] - - python_version: Optional[PythonVersion] = None - if version is not None: - python_version = _get_python_version(version) - - interpreter = _get_custom_interpreter(impl, version) - - platforms = _expand_allowed_platforms(platforms) - - 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.12/site-packages/pip/_internal/utils/datetime.py b/venv/lib/python3.12/site-packages/pip/_internal/utils/datetime.py deleted file mode 100644 index 8668b3b..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/utils/datetime.py +++ /dev/null @@ -1,11 +0,0 @@ -"""For when pip wants to check the date or time. -""" - -import datetime - - -def today_is_later_than(year: int, month: int, day: int) -> bool: - today = datetime.date.today() - given = datetime.date(year, month, day) - - return today > given diff --git a/venv/lib/python3.12/site-packages/pip/_internal/utils/deprecation.py b/venv/lib/python3.12/site-packages/pip/_internal/utils/deprecation.py deleted file mode 100644 index 72bd6f2..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/utils/deprecation.py +++ /dev/null @@ -1,120 +0,0 @@ -""" -A module that implements tooling to enable easy warnings about deprecations. -""" - -import logging -import warnings -from typing import Any, Optional, TextIO, Type, Union - -from pip._vendor.packaging.version import parse - -from pip import __version__ as current_version # NOTE: tests patch this name. - -DEPRECATION_MSG_PREFIX = "DEPRECATION: " - - -class PipDeprecationWarning(Warning): - pass - - -_original_showwarning: Any = None - - -# Warnings <-> Logging Integration -def _showwarning( - message: Union[Warning, str], - category: Type[Warning], - filename: str, - lineno: int, - file: Optional[TextIO] = None, - line: Optional[str] = None, -) -> None: - if file is not None: - if _original_showwarning is not None: - _original_showwarning(message, category, filename, lineno, file, line) - 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() -> 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: str, - replacement: Optional[str], - gone_in: Optional[str], - feature_flag: Optional[str] = None, - issue: Optional[int] = None, -) -> None: - """Helper to deprecate existing functionality. - - reason: - Textual reason shown to the user about why this functionality has - been deprecated. Should be a complete sentence. - replacement: - Textual suggestion shown to the user about what alternative - functionality they can use. - gone_in: - The version of pip does this functionality should get removed in. - Raises an error if pip's current version is greater than or equal to - this. - feature_flag: - Command-line flag of the form --use-feature={feature_flag} for testing - upcoming functionality. - issue: - Issue number on the tracker that would serve as a useful place for - users to find related discussion and provide feedback. - """ - - # Determine whether or not the feature is already gone in this version. - is_gone = gone_in is not None and parse(current_version) >= parse(gone_in) - - message_parts = [ - (reason, f"{DEPRECATION_MSG_PREFIX}{{}}"), - ( - gone_in, - "pip {} will enforce this behaviour change." - if not is_gone - else "Since pip {}, this is no longer supported.", - ), - ( - replacement, - "A possible replacement is {}.", - ), - ( - feature_flag, - "You can use the flag --use-feature={} to test the upcoming behaviour." - if not is_gone - else None, - ), - ( - issue, - "Discussion can be found at https://github.com/pypa/pip/issues/{}", - ), - ] - - message = " ".join( - format_str.format(value) - for value, format_str in message_parts - if format_str is not None and value is not None - ) - - # Raise as an error if this behaviour is deprecated. - if is_gone: - raise PipDeprecationWarning(message) - - warnings.warn(message, category=PipDeprecationWarning, stacklevel=2) diff --git a/venv/lib/python3.12/site-packages/pip/_internal/utils/direct_url_helpers.py b/venv/lib/python3.12/site-packages/pip/_internal/utils/direct_url_helpers.py deleted file mode 100644 index 0e8e5e1..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/utils/direct_url_helpers.py +++ /dev/null @@ -1,87 +0,0 @@ -from typing import Optional - -from pip._internal.models.direct_url import ArchiveInfo, DirectUrl, DirInfo, VcsInfo -from pip._internal.models.link import Link -from pip._internal.utils.urls import path_to_url -from pip._internal.vcs import vcs - - -def direct_url_as_pep440_direct_reference(direct_url: DirectUrl, name: str) -> str: - """Convert a DirectUrl to a pip requirement string.""" - direct_url.validate() # if invalid, this is a pip bug - requirement = name + " @ " - fragments = [] - if isinstance(direct_url.info, VcsInfo): - requirement += "{}+{}@{}".format( - direct_url.info.vcs, direct_url.url, direct_url.info.commit_id - ) - elif isinstance(direct_url.info, ArchiveInfo): - requirement += direct_url.url - if direct_url.info.hash: - fragments.append(direct_url.info.hash) - else: - assert isinstance(direct_url.info, DirInfo) - requirement += direct_url.url - if direct_url.subdirectory: - fragments.append("subdirectory=" + direct_url.subdirectory) - if fragments: - requirement += "#" + "&".join(fragments) - return requirement - - -def direct_url_for_editable(source_dir: str) -> DirectUrl: - return DirectUrl( - url=path_to_url(source_dir), - info=DirInfo(editable=True), - ) - - -def direct_url_from_link( - link: Link, source_dir: Optional[str] = None, link_is_in_wheel_cache: bool = False -) -> DirectUrl: - if link.is_vcs: - vcs_backend = vcs.get_backend_for_scheme(link.scheme) - assert vcs_backend - url, requested_revision, _ = vcs_backend.get_url_rev_and_auth( - link.url_without_fragment - ) - # For VCS links, we need to find out and add commit_id. - if link_is_in_wheel_cache: - # If the requested VCS link corresponds to a cached - # wheel, it means the requested revision was an - # immutable commit hash, otherwise it would not have - # been cached. In that case we don't have a source_dir - # with the VCS checkout. - assert requested_revision - commit_id = requested_revision - else: - # If the wheel was not in cache, it means we have - # had to checkout from VCS to build and we have a source_dir - # which we can inspect to find out the commit id. - assert source_dir - commit_id = vcs_backend.get_revision(source_dir) - return DirectUrl( - url=url, - info=VcsInfo( - vcs=vcs_backend.name, - commit_id=commit_id, - requested_revision=requested_revision, - ), - subdirectory=link.subdirectory_fragment, - ) - elif link.is_existing_dir(): - return DirectUrl( - url=link.url_without_fragment, - info=DirInfo(), - subdirectory=link.subdirectory_fragment, - ) - else: - hash = None - hash_name = link.hash_name - if hash_name: - hash = f"{hash_name}={link.hash}" - return DirectUrl( - url=link.url_without_fragment, - info=ArchiveInfo(hash=hash), - subdirectory=link.subdirectory_fragment, - ) diff --git a/venv/lib/python3.12/site-packages/pip/_internal/utils/egg_link.py b/venv/lib/python3.12/site-packages/pip/_internal/utils/egg_link.py deleted file mode 100644 index 4a384a6..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/utils/egg_link.py +++ /dev/null @@ -1,80 +0,0 @@ -import os -import re -import sys -from typing import List, Optional - -from pip._internal.locations import site_packages, user_site -from pip._internal.utils.virtualenv import ( - running_under_virtualenv, - virtualenv_no_global, -) - -__all__ = [ - "egg_link_path_from_sys_path", - "egg_link_path_from_location", -] - - -def _egg_link_names(raw_name: str) -> List[str]: - """ - Convert a Name metadata value to a .egg-link name, by applying - the same substitution as pkg_resources's safe_name function. - Note: we cannot use canonicalize_name because it has a different logic. - - We also look for the raw name (without normalization) as setuptools 69 changed - the way it names .egg-link files (https://github.com/pypa/setuptools/issues/4167). - """ - return [ - re.sub("[^A-Za-z0-9.]+", "-", raw_name) + ".egg-link", - f"{raw_name}.egg-link", - ] - - -def egg_link_path_from_sys_path(raw_name: str) -> Optional[str]: - """ - Look for a .egg-link file for project name, by walking sys.path. - """ - egg_link_names = _egg_link_names(raw_name) - for path_item in sys.path: - for egg_link_name in egg_link_names: - egg_link = os.path.join(path_item, egg_link_name) - if os.path.isfile(egg_link): - return egg_link - return None - - -def egg_link_path_from_location(raw_name: str) -> 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: List[str] = [] - 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) - - egg_link_names = _egg_link_names(raw_name) - for site in sites: - for egg_link_name in egg_link_names: - egglink = os.path.join(site, egg_link_name) - if os.path.isfile(egglink): - return egglink - return None diff --git a/venv/lib/python3.12/site-packages/pip/_internal/utils/encoding.py b/venv/lib/python3.12/site-packages/pip/_internal/utils/encoding.py deleted file mode 100644 index 008f06a..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/utils/encoding.py +++ /dev/null @@ -1,36 +0,0 @@ -import codecs -import locale -import re -import sys -from typing import List, Tuple - -BOMS: List[Tuple[bytes, str]] = [ - (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"), -] - -ENCODING_RE = re.compile(rb"coding[:=]\s*([-\w.]+)") - - -def auto_decode(data: bytes) -> str: - """Check a bytes string for a BOM to correctly detect the encoding - - Fallback to locale.getpreferredencoding(False) like open() on Python3""" - 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): - result = ENCODING_RE.search(line) - assert result is not None - encoding = result.groups()[0].decode("ascii") - return data.decode(encoding) - return data.decode( - locale.getpreferredencoding(False) or sys.getdefaultencoding(), - ) diff --git a/venv/lib/python3.12/site-packages/pip/_internal/utils/entrypoints.py b/venv/lib/python3.12/site-packages/pip/_internal/utils/entrypoints.py deleted file mode 100644 index 1501369..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/utils/entrypoints.py +++ /dev/null @@ -1,84 +0,0 @@ -import itertools -import os -import shutil -import sys -from typing import List, Optional - -from pip._internal.cli.main import main -from pip._internal.utils.compat import WINDOWS - -_EXECUTABLE_NAMES = [ - "pip", - f"pip{sys.version_info.major}", - f"pip{sys.version_info.major}.{sys.version_info.minor}", -] -if WINDOWS: - _allowed_extensions = {"", ".exe"} - _EXECUTABLE_NAMES = [ - "".join(parts) - for parts in itertools.product(_EXECUTABLE_NAMES, _allowed_extensions) - ] - - -def _wrapper(args: Optional[List[str]] = None) -> 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) - - -def get_best_invocation_for_this_pip() -> str: - """Try to figure out the best way to invoke pip in the current environment.""" - binary_directory = "Scripts" if WINDOWS else "bin" - binary_prefix = os.path.join(sys.prefix, binary_directory) - - # Try to use pip[X[.Y]] names, if those executables for this environment are - # the first on PATH with that name. - path_parts = os.path.normcase(os.environ.get("PATH", "")).split(os.pathsep) - exe_are_in_PATH = os.path.normcase(binary_prefix) in path_parts - if exe_are_in_PATH: - for exe_name in _EXECUTABLE_NAMES: - found_executable = shutil.which(exe_name) - binary_executable = os.path.join(binary_prefix, exe_name) - if ( - found_executable - and os.path.exists(binary_executable) - and os.path.samefile( - found_executable, - binary_executable, - ) - ): - return exe_name - - # Use the `-m` invocation, if there's no "nice" invocation. - return f"{get_best_invocation_for_this_python()} -m pip" - - -def get_best_invocation_for_this_python() -> str: - """Try to figure out the best way to invoke the current Python.""" - exe = sys.executable - exe_name = os.path.basename(exe) - - # Try to use the basename, if it's the first executable. - found_executable = shutil.which(exe_name) - if found_executable and os.path.samefile(found_executable, exe): - return exe_name - - # Use the full executable name, because we couldn't find something simpler. - return exe diff --git a/venv/lib/python3.12/site-packages/pip/_internal/utils/filesystem.py b/venv/lib/python3.12/site-packages/pip/_internal/utils/filesystem.py deleted file mode 100644 index 83c2df7..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/utils/filesystem.py +++ /dev/null @@ -1,153 +0,0 @@ -import fnmatch -import os -import os.path -import random -import sys -from contextlib import contextmanager -from tempfile import NamedTemporaryFile -from typing import Any, BinaryIO, Generator, List, Union, cast - -from pip._vendor.tenacity import retry, stop_after_delay, wait_fixed - -from pip._internal.utils.compat import get_path_uid -from pip._internal.utils.misc import format_size - - -def check_path_owner(path: str) -> bool: - # If we don't have a way to check the effective uid of this process, then - # we'll just assume that we own the directory. - if sys.platform == "win32" or not hasattr(os, "geteuid"): - 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 - - -@contextmanager -def adjacent_tmp_file(path: str, **kwargs: Any) -> Generator[BinaryIO, None, None]: - """Return a file-like object pointing to a tmp file next to path. - - The file is created securely and is ensured to be written to disk - after the context reaches its end. - - kwargs will be passed to tempfile.NamedTemporaryFile to control - the way the temporary file will be opened. - """ - with NamedTemporaryFile( - delete=False, - dir=os.path.dirname(path), - prefix=os.path.basename(path), - suffix=".tmp", - **kwargs, - ) as f: - result = cast(BinaryIO, f) - try: - yield result - finally: - result.flush() - os.fsync(result.fileno()) - - -# Tenacity raises RetryError by default, explicitly raise the original exception -_replace_retry = retry(reraise=True, stop=stop_after_delay(1), wait=wait_fixed(0.25)) - -replace = _replace_retry(os.replace) - - -# 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: 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: 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 _ 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 FileExistsError: - pass - except PermissionError: - # 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. - # This could as well be because the parent dir is not readable, - # due to non-privileged user access. - return False - else: - os.close(fd) - os.unlink(file) - return True - - # This should never be reached - raise OSError("Unexpected condition testing for writable directory") - - -def find_files(path: str, pattern: str) -> List[str]: - """Returns a list of absolute paths of files beneath path, recursively, - with filenames which match the UNIX-style shell glob pattern.""" - result: List[str] = [] - for root, _, files in os.walk(path): - matches = fnmatch.filter(files, pattern) - result.extend(os.path.join(root, f) for f in matches) - return result - - -def file_size(path: str) -> Union[int, float]: - # If it's a symlink, return 0. - if os.path.islink(path): - return 0 - return os.path.getsize(path) - - -def format_file_size(path: str) -> str: - return format_size(file_size(path)) - - -def directory_size(path: str) -> Union[int, float]: - size = 0.0 - for root, _dirs, files in os.walk(path): - for filename in files: - file_path = os.path.join(root, filename) - size += file_size(file_path) - return size - - -def format_directory_size(path: str) -> str: - return format_size(directory_size(path)) diff --git a/venv/lib/python3.12/site-packages/pip/_internal/utils/filetypes.py b/venv/lib/python3.12/site-packages/pip/_internal/utils/filetypes.py deleted file mode 100644 index 5948570..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/utils/filetypes.py +++ /dev/null @@ -1,27 +0,0 @@ -"""Filetype information. -""" - -from typing import Tuple - -from pip._internal.utils.misc import splitext - -WHEEL_EXTENSION = ".whl" -BZ2_EXTENSIONS: Tuple[str, ...] = (".tar.bz2", ".tbz") -XZ_EXTENSIONS: Tuple[str, ...] = ( - ".tar.xz", - ".txz", - ".tlz", - ".tar.lz", - ".tar.lzma", -) -ZIP_EXTENSIONS: Tuple[str, ...] = (".zip", WHEEL_EXTENSION) -TAR_EXTENSIONS: Tuple[str, ...] = (".tar.gz", ".tgz", ".tar") -ARCHIVE_EXTENSIONS = ZIP_EXTENSIONS + BZ2_EXTENSIONS + TAR_EXTENSIONS + XZ_EXTENSIONS - - -def is_archive_file(name: 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 diff --git a/venv/lib/python3.12/site-packages/pip/_internal/utils/glibc.py b/venv/lib/python3.12/site-packages/pip/_internal/utils/glibc.py deleted file mode 100644 index 81342af..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/utils/glibc.py +++ /dev/null @@ -1,88 +0,0 @@ -import os -import sys -from typing import Optional, Tuple - - -def glibc_version_string() -> Optional[str]: - "Returns glibc version string, or None if not using glibc." - return glibc_version_string_confstr() or glibc_version_string_ctypes() - - -def glibc_version_string_confstr() -> 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: - gnu_libc_version = os.confstr("CS_GNU_LIBC_VERSION") - if gnu_libc_version is None: - return None - # os.confstr("CS_GNU_LIBC_VERSION") returns a string like "glibc 2.17": - _, version = 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() -> 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() -> 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.12/site-packages/pip/_internal/utils/hashes.py b/venv/lib/python3.12/site-packages/pip/_internal/utils/hashes.py deleted file mode 100644 index 843cffc..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/utils/hashes.py +++ /dev/null @@ -1,151 +0,0 @@ -import hashlib -from typing import TYPE_CHECKING, BinaryIO, Dict, Iterable, List, Optional - -from pip._internal.exceptions import HashMismatch, HashMissing, InstallationError -from pip._internal.utils.misc import read_chunks - -if TYPE_CHECKING: - from hashlib import _Hash - - # NoReturn introduced in 3.6.2; imported only for type checking to maintain - # pip compatibility with older patch versions of Python 3.6 - from typing import NoReturn - - -# 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: - """A wrapper that builds multiple hashes at once and checks them against - known-good values - - """ - - def __init__(self, hashes: Optional[Dict[str, List[str]]] = None) -> None: - """ - :param hashes: A dict of algorithm names pointing to lists of allowed - hex digests - """ - allowed = {} - if hashes is not None: - for alg, keys in hashes.items(): - # Make sure values are always sorted (to ease equality checks) - allowed[alg] = sorted(keys) - self._allowed = allowed - - def __and__(self, other: "Hashes") -> "Hashes": - if not isinstance(other, Hashes): - return NotImplemented - - # If either of the Hashes object is entirely empty (i.e. no hash - # specified at all), all hashes from the other object are allowed. - if not other: - return self - if not self: - return other - - # Otherwise only hashes that present in both objects are allowed. - new = {} - for alg, values in other._allowed.items(): - if alg not in self._allowed: - continue - new[alg] = [v for v in values if v in self._allowed[alg]] - return Hashes(new) - - @property - def digest_count(self) -> int: - return sum(len(digests) for digests in self._allowed.values()) - - def is_hash_allowed(self, hash_name: str, hex_digest: str) -> bool: - """Return whether the given hex digest is allowed.""" - return hex_digest in self._allowed.get(hash_name, []) - - def check_against_chunks(self, chunks: Iterable[bytes]) -> None: - """Check good hashes against ones built from iterable of chunks of - data. - - Raise HashMismatch if none match. - - """ - gots = {} - for hash_name in self._allowed.keys(): - try: - gots[hash_name] = hashlib.new(hash_name) - except (ValueError, TypeError): - raise InstallationError(f"Unknown hash name: {hash_name}") - - for chunk in chunks: - for hash in gots.values(): - hash.update(chunk) - - for hash_name, got in gots.items(): - if got.hexdigest() in self._allowed[hash_name]: - return - self._raise(gots) - - def _raise(self, gots: Dict[str, "_Hash"]) -> "NoReturn": - raise HashMismatch(self._allowed, gots) - - def check_against_file(self, file: 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: str) -> None: - with open(path, "rb") as file: - return self.check_against_file(file) - - def has_one_of(self, hashes: Dict[str, str]) -> bool: - """Return whether any of the given hashes are allowed.""" - for hash_name, hex_digest in hashes.items(): - if self.is_hash_allowed(hash_name, hex_digest): - return True - return False - - def __bool__(self) -> bool: - """Return whether I know any known-good hashes.""" - return bool(self._allowed) - - def __eq__(self, other: object) -> bool: - if not isinstance(other, Hashes): - return NotImplemented - return self._allowed == other._allowed - - def __hash__(self) -> int: - return hash( - ",".join( - sorted( - ":".join((alg, digest)) - for alg, digest_list in self._allowed.items() - for digest in digest_list - ) - ) - ) - - -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) -> None: - """Don't offer the ``hashes`` kwarg.""" - # Pass our favorite hash in to generate a "gotten hash". With the - # empty list, it will never match, so an error will always raise. - super().__init__(hashes={FAVORITE_HASH: []}) - - def _raise(self, gots: Dict[str, "_Hash"]) -> "NoReturn": - raise HashMissing(gots[FAVORITE_HASH].hexdigest()) diff --git a/venv/lib/python3.12/site-packages/pip/_internal/utils/logging.py b/venv/lib/python3.12/site-packages/pip/_internal/utils/logging.py deleted file mode 100644 index 95982df..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/utils/logging.py +++ /dev/null @@ -1,348 +0,0 @@ -import contextlib -import errno -import logging -import logging.handlers -import os -import sys -import threading -from dataclasses import dataclass -from io import TextIOWrapper -from logging import Filter -from typing import Any, ClassVar, Generator, List, Optional, TextIO, Type - -from pip._vendor.rich.console import ( - Console, - ConsoleOptions, - ConsoleRenderable, - RenderableType, - RenderResult, - RichCast, -) -from pip._vendor.rich.highlighter import NullHighlighter -from pip._vendor.rich.logging import RichHandler -from pip._vendor.rich.segment import Segment -from pip._vendor.rich.style import Style - -from pip._internal.utils._log import VERBOSE, getLogger -from pip._internal.utils.compat import WINDOWS -from pip._internal.utils.deprecation import DEPRECATION_MSG_PREFIX -from pip._internal.utils.misc import ensure_dir - -_log_state = threading.local() -subprocess_logger = getLogger("pip.subprocessor") - - -class BrokenStdoutLoggingError(Exception): - """ - Raised if BrokenPipeError occurs for the stdout stream while logging. - """ - - -def _is_broken_pipe_error(exc_class: Type[BaseException], exc: BaseException) -> bool: - if exc_class is BrokenPipeError: - return True - - # On Windows, a broken pipe can show up as EINVAL rather than EPIPE: - # https://bugs.python.org/issue19612 - # https://bugs.python.org/issue30418 - if not WINDOWS: - return False - - return isinstance(exc, OSError) and exc.errno in (errno.EINVAL, errno.EPIPE) - - -@contextlib.contextmanager -def indent_log(num: int = 2) -> Generator[None, None, None]: - """ - A context manager which will cause the log output to be indented for any - log messages emitted inside it. - """ - # For thread-safety - _log_state.indentation = get_indentation() - _log_state.indentation += num - try: - yield - finally: - _log_state.indentation -= num - - -def get_indentation() -> int: - return getattr(_log_state, "indentation", 0) - - -class IndentingFormatter(logging.Formatter): - default_time_format = "%Y-%m-%dT%H:%M:%S" - - def __init__( - self, - *args: Any, - add_timestamp: bool = False, - **kwargs: Any, - ) -> None: - """ - 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 = add_timestamp - super().__init__(*args, **kwargs) - - def get_message_start(self, formatted: str, levelno: int) -> str: - """ - Return the start of the formatted log message (not counting the - prefix to add to each line). - """ - 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: logging.LogRecord) -> str: - """ - Calls the standard formatter, but will indent all of the log message - lines by our current indentation level. - """ - formatted = super().format(record) - message_start = self.get_message_start(formatted, record.levelno) - formatted = message_start + formatted - - prefix = "" - if self.add_timestamp: - prefix = f"{self.formatTime(record)} " - prefix += " " * get_indentation() - formatted = "".join([prefix + line for line in formatted.splitlines(True)]) - return formatted - - -@dataclass -class IndentedRenderable: - renderable: RenderableType - indent: int - - def __rich_console__( - self, console: Console, options: ConsoleOptions - ) -> RenderResult: - segments = console.render(self.renderable, options) - lines = Segment.split_lines(segments) - for line in lines: - yield Segment(" " * self.indent) - yield from line - yield Segment("\n") - - -class RichPipStreamHandler(RichHandler): - KEYWORDS: ClassVar[Optional[List[str]]] = [] - - def __init__(self, stream: Optional[TextIO], no_color: bool) -> None: - super().__init__( - console=Console(file=stream, no_color=no_color, soft_wrap=True), - show_time=False, - show_level=False, - show_path=False, - highlighter=NullHighlighter(), - ) - - # Our custom override on Rich's logger, to make things work as we need them to. - def emit(self, record: logging.LogRecord) -> None: - style: Optional[Style] = None - - # If we are given a diagnostic error to present, present it with indentation. - assert isinstance(record.args, tuple) - if getattr(record, "rich", False): - (rich_renderable,) = record.args - assert isinstance( - rich_renderable, (ConsoleRenderable, RichCast, str) - ), f"{rich_renderable} is not rich-console-renderable" - - renderable: RenderableType = IndentedRenderable( - rich_renderable, indent=get_indentation() - ) - else: - message = self.format(record) - renderable = self.render_message(record, message) - if record.levelno is not None: - if record.levelno >= logging.ERROR: - style = Style(color="red") - elif record.levelno >= logging.WARNING: - style = Style(color="yellow") - - try: - self.console.print(renderable, overflow="ignore", crop=False, style=style) - except Exception: - self.handleError(record) - - def handleError(self, record: logging.LogRecord) -> None: - """Called when logging is unable to log some output.""" - - 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 exc - and self.console.file is sys.stdout - and _is_broken_pipe_error(exc_class, exc) - ): - raise BrokenStdoutLoggingError() - - return super().handleError(record) - - -class BetterRotatingFileHandler(logging.handlers.RotatingFileHandler): - def _open(self) -> TextIOWrapper: - ensure_dir(os.path.dirname(self.baseFilename)) - return super()._open() - - -class MaxLevelFilter(Filter): - def __init__(self, level: int) -> None: - self.level = level - - def filter(self, record: logging.LogRecord) -> bool: - return record.levelno < self.level - - -class ExcludeLoggerFilter(Filter): - - """ - A logging Filter that excludes records from a logger (or its children). - """ - - def filter(self, record: logging.LogRecord) -> bool: - # The base Filter class allows only records from a logger (or its - # children). - return not super().filter(record) - - -def setup_logging(verbosity: int, no_color: bool, user_log_file: Optional[str]) -> int: - """Configures and sets up all of the logging - - Returns the requested logging level, as its integer value. - """ - - # Determine the level to be logging at. - if verbosity >= 2: - level_number = logging.DEBUG - elif verbosity == 1: - level_number = VERBOSE - elif verbosity == -1: - level_number = logging.WARNING - elif verbosity == -2: - level_number = logging.ERROR - elif verbosity <= -3: - level_number = logging.CRITICAL - else: - level_number = logging.INFO - - level = logging.getLevelName(level_number) - - # 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.RichPipStreamHandler", - "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"], - "stream": log_streams["stderr"], - "no_color": no_color, - "filters": ["restrict_to_subprocess"], - "formatter": "indent", - }, - "user_log": { - "level": "DEBUG", - "class": handler_classes["file"], - "filename": additional_log_file, - "encoding": "utf-8", - "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.12/site-packages/pip/_internal/utils/misc.py b/venv/lib/python3.12/site-packages/pip/_internal/utils/misc.py deleted file mode 100644 index 1ad3f61..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/utils/misc.py +++ /dev/null @@ -1,783 +0,0 @@ -import contextlib -import errno -import getpass -import hashlib -import io -import logging -import os -import posixpath -import shutil -import stat -import sys -import sysconfig -import urllib.parse -from functools import partial -from io import StringIO -from itertools import filterfalse, tee, zip_longest -from pathlib import Path -from types import FunctionType, TracebackType -from typing import ( - Any, - BinaryIO, - Callable, - ContextManager, - Dict, - Generator, - Iterable, - Iterator, - List, - Optional, - TextIO, - Tuple, - Type, - TypeVar, - Union, - cast, -) - -from pip._vendor.packaging.requirements import Requirement -from pip._vendor.pyproject_hooks import BuildBackendHookCaller -from pip._vendor.tenacity import retry, stop_after_delay, wait_fixed - -from pip import __version__ -from pip._internal.exceptions import CommandError, ExternallyManagedEnvironment -from pip._internal.locations import get_major_minor_version -from pip._internal.utils.compat import WINDOWS -from pip._internal.utils.virtualenv import running_under_virtualenv - -__all__ = [ - "rmtree", - "display_path", - "backup_dir", - "ask", - "splitext", - "format_size", - "is_installable_dir", - "normalize_path", - "renames", - "get_prog", - "captured_stdout", - "ensure_dir", - "remove_auth_from_url", - "check_externally_managed", - "ConfiguredBuildBackendHookCaller", -] - -logger = logging.getLogger(__name__) - -T = TypeVar("T") -ExcInfo = Tuple[Type[BaseException], BaseException, TracebackType] -VersionInfo = Tuple[int, int, int] -NetlocTuple = Tuple[str, Tuple[Optional[str], Optional[str]]] -OnExc = Callable[[FunctionType, Path, BaseException], Any] -OnErr = Callable[[FunctionType, Path, ExcInfo], Any] - - -def get_pip_version() -> str: - pip_pkg_dir = os.path.join(os.path.dirname(__file__), "..", "..") - pip_pkg_dir = os.path.abspath(pip_pkg_dir) - - return f"pip {__version__} from {pip_pkg_dir} (python {get_major_minor_version()})" - - -def normalize_version_info(py_version_info: Tuple[int, ...]) -> Tuple[int, int, int]: - """ - Convert a tuple of ints representing a Python version to one of length - three. - - :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: str) -> 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() -> str: - try: - prog = os.path.basename(sys.argv[0]) - if prog in ("__main__.py", "-c"): - return f"{sys.executable} -m pip" - else: - return prog - except (AttributeError, TypeError, IndexError): - pass - return "pip" - - -# Retry every half second for up to 3 seconds -# Tenacity raises RetryError by default, explicitly raise the original exception -@retry(reraise=True, stop=stop_after_delay(3), wait=wait_fixed(0.5)) -def rmtree( - dir: str, - ignore_errors: bool = False, - onexc: Optional[OnExc] = None, -) -> None: - if ignore_errors: - onexc = _onerror_ignore - if onexc is None: - onexc = _onerror_reraise - handler: OnErr = partial( - # `[func, path, Union[ExcInfo, BaseException]] -> Any` is equivalent to - # `Union[([func, path, ExcInfo] -> Any), ([func, path, BaseException] -> Any)]`. - cast(Union[OnExc, OnErr], rmtree_errorhandler), - onexc=onexc, - ) - if sys.version_info >= (3, 12): - # See https://docs.python.org/3.12/whatsnew/3.12.html#shutil. - shutil.rmtree(dir, onexc=handler) # type: ignore - else: - shutil.rmtree(dir, onerror=handler) # type: ignore - - -def _onerror_ignore(*_args: Any) -> None: - pass - - -def _onerror_reraise(*_args: Any) -> None: - raise - - -def rmtree_errorhandler( - func: FunctionType, - path: Path, - exc_info: Union[ExcInfo, BaseException], - *, - onexc: OnExc = _onerror_reraise, -) -> None: - """ - `rmtree` error handler to 'force' a file remove (i.e. like `rm -f`). - - * If a file is readonly then it's write flag is set and operation is - retried. - - * `onerror` is the original callback from `rmtree(... onerror=onerror)` - that is chained at the end if the "rm -f" still fails. - """ - try: - st_mode = os.stat(path).st_mode - except OSError: - # it's equivalent to os.path.exists - return - - if not st_mode & stat.S_IWRITE: - # convert to read/write - try: - os.chmod(path, st_mode | stat.S_IWRITE) - except OSError: - pass - else: - # use the original function to repeat the operation - try: - func(path) - return - except OSError: - pass - - if not isinstance(exc_info, BaseException): - _, exc_info, _ = exc_info - onexc(func, path, exc_info) - - -def display_path(path: str) -> str: - """Gives the display value for a given path, making it relative to cwd - if possible.""" - path = os.path.normcase(os.path.abspath(path)) - if path.startswith(os.getcwd() + os.path.sep): - path = "." + path[len(os.getcwd()) :] - return path - - -def backup_dir(dir: str, ext: str = ".bak") -> str: - """Figure out the name of a directory to back up the given dir to - (adding .bak, .bak2, etc)""" - n = 1 - extension = ext - while os.path.exists(dir + extension): - n += 1 - extension = ext + str(n) - return dir + extension - - -def ask_path_exists(message: str, options: Iterable[str]) -> str: - for action in os.environ.get("PIP_EXISTS_ACTION", "").split(): - if action in options: - return action - return ask(message, options) - - -def _check_no_input(message: str) -> None: - """Raise an error if no input is allowed.""" - if os.environ.get("PIP_NO_INPUT"): - raise Exception( - f"No input was expected ($PIP_NO_INPUT set); question: {message}" - ) - - -def ask(message: str, options: 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: " - "{}".format(response, ", ".join(options)) - ) - else: - return response - - -def ask_input(message: str) -> str: - """Ask for input interactively.""" - _check_no_input(message) - return input(message) - - -def ask_password(message: str) -> str: - """Ask for a password interactively.""" - _check_no_input(message) - return getpass.getpass(message) - - -def strtobool(val: str) -> int: - """Convert a string representation of truth to true (1) or false (0). - - True values are 'y', 'yes', 't', 'true', 'on', and '1'; false values - are 'n', 'no', 'f', 'false', 'off', and '0'. Raises ValueError if - 'val' is anything else. - """ - val = val.lower() - if val in ("y", "yes", "t", "true", "on", "1"): - return 1 - elif val in ("n", "no", "f", "false", "off", "0"): - return 0 - else: - raise ValueError(f"invalid truth value {val!r}") - - -def format_size(bytes: float) -> str: - if bytes > 1000 * 1000: - return f"{bytes / 1000.0 / 1000:.1f} MB" - elif bytes > 10 * 1000: - return f"{int(bytes / 1000)} kB" - elif bytes > 1000: - return f"{bytes / 1000.0:.1f} kB" - else: - return f"{int(bytes)} bytes" - - -def tabulate(rows: Iterable[Iterable[Any]]) -> Tuple[List[str], List[int]]: - """Return a list of formatted rows and a list of column sizes. - - For example:: - - >>> tabulate([['foobar', 2000], [0xdeadbeef]]) - (['foobar 2000', '3735928559'], [10, 4]) - """ - rows = [tuple(map(str, row)) for row in rows] - sizes = [max(map(len, col)) for col in zip_longest(*rows, fillvalue="")] - table = [" ".join(map(str.ljust, row, sizes)).rstrip() for row in rows] - return table, sizes - - -def is_installable_dir(path: str) -> bool: - """Is path is a directory containing pyproject.toml or setup.py? - - If pyproject.toml exists, this is a PEP 517 project. Otherwise we look for - a legacy setuptools layout by identifying setup.py. We don't check for the - setup.cfg because using it without setup.py is only available for PEP 517 - projects, which are already covered by the pyproject.toml check. - """ - if not os.path.isdir(path): - return False - if os.path.isfile(os.path.join(path, "pyproject.toml")): - return True - if os.path.isfile(os.path.join(path, "setup.py")): - return True - return False - - -def read_chunks( - file: BinaryIO, size: int = io.DEFAULT_BUFFER_SIZE -) -> Generator[bytes, None, None]: - """Yield pieces of data from a file-like object until EOF.""" - while True: - chunk = file.read(size) - if not chunk: - break - yield chunk - - -def normalize_path(path: str, resolve_symlinks: bool = True) -> str: - """ - Convert a path to its canonical, case-normalized, absolute version. - - """ - path = os.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: 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: str, new: 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: str) -> bool: - """ - Return True if path is within sys.prefix, if we're running in a virtualenv. - - If we're not in a virtualenv, all paths are considered "local." - - Caution: this function assumes the head of path has been normalized - with normalize_path. - """ - if not running_under_virtualenv(): - return True - return path.startswith(normalize_path(sys.prefix)) - - -def write_output(msg: Any, *args: Any) -> None: - logger.info(msg, *args) - - -class StreamWrapper(StringIO): - orig_stream: TextIO - - @classmethod - def from_stream(cls, orig_stream: TextIO) -> "StreamWrapper": - ret = cls() - ret.orig_stream = orig_stream - return ret - - # compileall.compile_dir() needs stdout.encoding to print to stdout - # type ignore is because TextIOBase.encoding is writeable - @property - def encoding(self) -> str: # type: ignore - return self.orig_stream.encoding - - -@contextlib.contextmanager -def captured_output(stream_name: str) -> Generator[StreamWrapper, None, None]: - """Return a context manager used by captured_stdout/stdin/stderr - that temporarily replaces the sys stream *stream_name* with a StringIO. - - 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() -> ContextManager[StreamWrapper]: - """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() -> ContextManager[StreamWrapper]: - """ - See captured_stdout(). - """ - return captured_output("stderr") - - -# Simulates an enum -def enum(*sequential: Any, **named: Any) -> Type[Any]: - enums = dict(zip(sequential, range(len(sequential))), **named) - reverse = {value: key for key, value in enums.items()} - enums["reverse_mapping"] = reverse - return type("Enum", (), enums) - - -def build_netloc(host: str, port: 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 = f"[{host}]" - return f"{host}:{port}" - - -def build_url_from_netloc(netloc: str, scheme: str = "https") -> 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 = f"[{netloc}]" - return f"{scheme}://{netloc}" - - -def parse_netloc(netloc: str) -> Tuple[Optional[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: str) -> NetlocTuple: - """ - 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) - pw: Optional[str] = None - if ":" in auth: - # Split from the left because that's how urllib.parse.urlsplit() - # behaves if more than one : is present (which again can be checked - # using the password attribute of the return value) - user, pw = auth.split(":", 1) - else: - user, pw = auth, None - - user = urllib.parse.unquote(user) - if pw is not None: - pw = urllib.parse.unquote(pw) - - return netloc, (user, pw) - - -def redact_netloc(netloc: 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 f"{user}{password}@{netloc}" - - -def _transform_url( - url: str, transform_netloc: Callable[[str], Tuple[Any, ...]] -) -> Tuple[str, NetlocTuple]: - """Transform and replace netloc in a url. - - transform_netloc is a function taking the netloc and returning a - 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, cast("NetlocTuple", netloc_tuple) - - -def _get_netloc(netloc: str) -> NetlocTuple: - return split_auth_from_netloc(netloc) - - -def _redact_netloc(netloc: str) -> Tuple[str]: - return (redact_netloc(netloc),) - - -def split_auth_netloc_from_url( - url: str, -) -> Tuple[str, str, Tuple[Optional[str], Optional[str]]]: - """ - Parse a url into separate netloc, auth, and url with no auth. - - 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: 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: str) -> str: - """Replace the password in a given url with ****.""" - return _transform_url(url, _redact_netloc)[0] - - -def redact_auth_from_requirement(req: Requirement) -> str: - """Replace the password in a given requirement url with ****.""" - if not req.url: - return str(req) - return str(req).replace(req.url, redact_auth_from_url(req.url)) - - -class HiddenText: - def __init__(self, secret: str, redacted: str) -> None: - self.secret = secret - self.redacted = redacted - - def __repr__(self) -> str: - return f"" - - def __str__(self) -> str: - return self.redacted - - # This is useful for testing. - def __eq__(self, other: 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 - - -def hide_value(value: str) -> HiddenText: - return HiddenText(value, redacted="****") - - -def hide_url(url: str) -> HiddenText: - redacted = redact_auth_from_url(url) - return HiddenText(url, redacted=redacted) - - -def protect_pip_from_modification_on_windows(modifying_pip: 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", - f"pip{sys.version_info.major}", - f"pip{sys.version_info.major}.{sys.version_info.minor}", - ] - - # See https://github.com/pypa/pip/issues/1299 for more discussion - 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 check_externally_managed() -> None: - """Check whether the current environment is externally managed. - - If the ``EXTERNALLY-MANAGED`` config file is found, the current environment - is considered externally managed, and an ExternallyManagedEnvironment is - raised. - """ - if running_under_virtualenv(): - return - marker = os.path.join(sysconfig.get_path("stdlib"), "EXTERNALLY-MANAGED") - if not os.path.isfile(marker): - return - raise ExternallyManagedEnvironment.from_config(marker) - - -def is_console_interactive() -> bool: - """Is this console interactive?""" - return sys.stdin is not None and sys.stdin.isatty() - - -def hash_file(path: str, blocksize: int = 1 << 20) -> 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 pairwise(iterable: Iterable[Any]) -> Iterator[Tuple[Any, Any]]: - """ - Return paired elements. - - For example: - s -> (s0, s1), (s2, s3), (s4, s5), ... - """ - iterable = iter(iterable) - return zip_longest(iterable, iterable) - - -def partition( - pred: Callable[[T], bool], - iterable: Iterable[T], -) -> Tuple[Iterable[T], Iterable[T]]: - """ - Use a predicate to partition entries into false entries and true entries, - like - - partition(is_odd, range(10)) --> 0 2 4 6 8 and 1 3 5 7 9 - """ - t1, t2 = tee(iterable) - return filterfalse(pred, t1), filter(pred, t2) - - -class ConfiguredBuildBackendHookCaller(BuildBackendHookCaller): - def __init__( - self, - config_holder: Any, - source_dir: str, - build_backend: str, - backend_path: Optional[str] = None, - runner: Optional[Callable[..., None]] = None, - python_executable: Optional[str] = None, - ): - super().__init__( - source_dir, build_backend, backend_path, runner, python_executable - ) - self.config_holder = config_holder - - def build_wheel( - self, - wheel_directory: str, - config_settings: Optional[Dict[str, Union[str, List[str]]]] = None, - metadata_directory: Optional[str] = None, - ) -> str: - cs = self.config_holder.config_settings - return super().build_wheel( - wheel_directory, config_settings=cs, metadata_directory=metadata_directory - ) - - def build_sdist( - self, - sdist_directory: str, - config_settings: Optional[Dict[str, Union[str, List[str]]]] = None, - ) -> str: - cs = self.config_holder.config_settings - return super().build_sdist(sdist_directory, config_settings=cs) - - def build_editable( - self, - wheel_directory: str, - config_settings: Optional[Dict[str, Union[str, List[str]]]] = None, - metadata_directory: Optional[str] = None, - ) -> str: - cs = self.config_holder.config_settings - return super().build_editable( - wheel_directory, config_settings=cs, metadata_directory=metadata_directory - ) - - def get_requires_for_build_wheel( - self, config_settings: Optional[Dict[str, Union[str, List[str]]]] = None - ) -> List[str]: - cs = self.config_holder.config_settings - return super().get_requires_for_build_wheel(config_settings=cs) - - def get_requires_for_build_sdist( - self, config_settings: Optional[Dict[str, Union[str, List[str]]]] = None - ) -> List[str]: - cs = self.config_holder.config_settings - return super().get_requires_for_build_sdist(config_settings=cs) - - def get_requires_for_build_editable( - self, config_settings: Optional[Dict[str, Union[str, List[str]]]] = None - ) -> List[str]: - cs = self.config_holder.config_settings - return super().get_requires_for_build_editable(config_settings=cs) - - def prepare_metadata_for_build_wheel( - self, - metadata_directory: str, - config_settings: Optional[Dict[str, Union[str, List[str]]]] = None, - _allow_fallback: bool = True, - ) -> str: - cs = self.config_holder.config_settings - return super().prepare_metadata_for_build_wheel( - metadata_directory=metadata_directory, - config_settings=cs, - _allow_fallback=_allow_fallback, - ) - - def prepare_metadata_for_build_editable( - self, - metadata_directory: str, - config_settings: Optional[Dict[str, Union[str, List[str]]]] = None, - _allow_fallback: bool = True, - ) -> str: - cs = self.config_holder.config_settings - return super().prepare_metadata_for_build_editable( - metadata_directory=metadata_directory, - config_settings=cs, - _allow_fallback=_allow_fallback, - ) diff --git a/venv/lib/python3.12/site-packages/pip/_internal/utils/models.py b/venv/lib/python3.12/site-packages/pip/_internal/utils/models.py deleted file mode 100644 index b6bb21a..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/utils/models.py +++ /dev/null @@ -1,39 +0,0 @@ -"""Utilities for defining models -""" - -import operator -from typing import Any, Callable, Type - - -class KeyBasedCompareMixin: - """Provides comparison capabilities that is based on a key""" - - __slots__ = ["_compare_key", "_defining_class"] - - def __init__(self, key: Any, defining_class: Type["KeyBasedCompareMixin"]) -> None: - self._compare_key = key - self._defining_class = defining_class - - def __hash__(self) -> int: - return hash(self._compare_key) - - def __lt__(self, other: Any) -> bool: - return self._compare(other, operator.__lt__) - - def __le__(self, other: Any) -> bool: - return self._compare(other, operator.__le__) - - def __gt__(self, other: Any) -> bool: - return self._compare(other, operator.__gt__) - - def __ge__(self, other: Any) -> bool: - return self._compare(other, operator.__ge__) - - def __eq__(self, other: Any) -> bool: - return self._compare(other, operator.__eq__) - - def _compare(self, other: Any, method: Callable[[Any, Any], bool]) -> bool: - if not isinstance(other, self._defining_class): - return NotImplemented - - return method(self._compare_key, other._compare_key) diff --git a/venv/lib/python3.12/site-packages/pip/_internal/utils/packaging.py b/venv/lib/python3.12/site-packages/pip/_internal/utils/packaging.py deleted file mode 100644 index b9f6af4..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/utils/packaging.py +++ /dev/null @@ -1,57 +0,0 @@ -import functools -import logging -import re -from typing import NewType, Optional, Tuple, cast - -from pip._vendor.packaging import specifiers, version -from pip._vendor.packaging.requirements import Requirement - -NormalizedExtra = NewType("NormalizedExtra", str) - -logger = logging.getLogger(__name__) - - -def check_requires_python( - requires_python: Optional[str], version_info: 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 - - -@functools.lru_cache(maxsize=512) -def get_requirement(req_string: str) -> Requirement: - """Construct a packaging.Requirement object with caching""" - # Parsing requirement strings is expensive, and is also expected to happen - # with a low diversity of different arguments (at least relative the number - # constructed). This method adds a cache to requirement object creation to - # minimize repeated parsing of the same string to construct equivalent - # Requirement objects. - return Requirement(req_string) - - -def safe_extra(extra: str) -> NormalizedExtra: - """Convert an arbitrary string to a standard 'extra' name - - Any runs of non-alphanumeric characters are replaced with a single '_', - and the result is always lowercased. - - This function is duplicated from ``pkg_resources``. Note that this is not - the same to either ``canonicalize_name`` or ``_egg_link_name``. - """ - return cast(NormalizedExtra, re.sub("[^A-Za-z0-9.-]+", "_", extra).lower()) diff --git a/venv/lib/python3.12/site-packages/pip/_internal/utils/setuptools_build.py b/venv/lib/python3.12/site-packages/pip/_internal/utils/setuptools_build.py deleted file mode 100644 index 96d1b24..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/utils/setuptools_build.py +++ /dev/null @@ -1,146 +0,0 @@ -import sys -import textwrap -from typing import List, Optional, Sequence - -# Shim to wrap setup.py invocation with setuptools -# Note that __file__ is handled via two {!r} *and* %r, to ensure that paths on -# Windows are correctly handled (it should be "C:\\Users" not "C:\Users"). -_SETUPTOOLS_SHIM = textwrap.dedent( - """ - exec(compile(''' - # This is -- a caller that pip uses to run setup.py - # - # - It imports setuptools before invoking setup.py, to enable projects that directly - # import from `distutils.core` to work with newer packaging standards. - # - It provides a clear error message when setuptools is not installed. - # - It sets `sys.argv[0]` to the underlying `setup.py`, when invoking `setup.py` so - # setuptools doesn't think the script is `-c`. This avoids the following warning: - # manifest_maker: standard file '-c' not found". - # - It generates a shim setup.py, for handling setup.cfg-only projects. - import os, sys, tokenize - - try: - import setuptools - except ImportError as error: - print( - "ERROR: Can not execute `setup.py` since setuptools is not available in " - "the build environment.", - file=sys.stderr, - ) - sys.exit(1) - - __file__ = %r - sys.argv[0] = __file__ - - if os.path.exists(__file__): - filename = __file__ - with tokenize.open(__file__) as f: - setup_py_code = f.read() - else: - filename = "" - setup_py_code = "from setuptools import setup; setup()" - - exec(compile(setup_py_code, filename, "exec")) - ''' % ({!r},), "", "exec")) - """ -).rstrip() - - -def make_setuptools_shim_args( - setup_py_path: str, - global_options: Optional[Sequence[str]] = None, - no_user_config: bool = False, - unbuffered_output: bool = False, -) -> List[str]: - """ - Get setuptools command arguments with shim wrapped setup file invocation. - - :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: str, - global_options: Sequence[str], - build_options: Sequence[str], - destination_dir: str, -) -> List[str]: - # NOTE: Eventually, we'd want to also -S to the flags here, when we're - # isolating. Currently, it breaks Python in virtualenvs, because it - # relies on site.py to find parts of the standard library outside the - # 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: str, - global_options: Sequence[str], -) -> 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: str, - *, - global_options: Sequence[str], - no_user_config: bool, - prefix: Optional[str], - home: Optional[str], - use_user_site: bool, -) -> List[str]: - assert not (use_user_site and prefix) - - args = make_setuptools_shim_args( - setup_py_path, - global_options=global_options, - no_user_config=no_user_config, - ) - - args += ["develop", "--no-deps"] - - if prefix: - args += ["--prefix", prefix] - if home is not None: - args += ["--install-dir", home] - - if use_user_site: - args += ["--user", "--prefix="] - - return args - - -def make_setuptools_egg_info_args( - setup_py_path: str, - egg_info_dir: Optional[str], - no_user_config: bool, -) -> List[str]: - args = make_setuptools_shim_args(setup_py_path, no_user_config=no_user_config) - - args += ["egg_info"] - - if egg_info_dir: - args += ["--egg-base", egg_info_dir] - - return args diff --git a/venv/lib/python3.12/site-packages/pip/_internal/utils/subprocess.py b/venv/lib/python3.12/site-packages/pip/_internal/utils/subprocess.py deleted file mode 100644 index 79580b0..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/utils/subprocess.py +++ /dev/null @@ -1,260 +0,0 @@ -import logging -import os -import shlex -import subprocess -from typing import ( - TYPE_CHECKING, - Any, - Callable, - Iterable, - List, - Mapping, - Optional, - Union, -) - -from pip._vendor.rich.markup import escape - -from pip._internal.cli.spinners import SpinnerInterface, open_spinner -from pip._internal.exceptions import InstallationSubprocessError -from pip._internal.utils.logging import VERBOSE, subprocess_logger -from pip._internal.utils.misc import HiddenText - -if TYPE_CHECKING: - # Literal was introduced in Python 3.8. - # - # TODO: Remove `if TYPE_CHECKING` when dropping support for Python 3.7. - from typing import Literal - -CommandArgs = List[Union[str, HiddenText]] - - -def make_command(*args: Union[str, HiddenText, CommandArgs]) -> CommandArgs: - """ - Create a CommandArgs object. - """ - command_args: 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: 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: 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 call_subprocess( - cmd: Union[List[str], CommandArgs], - show_stdout: bool = False, - cwd: Optional[str] = None, - on_returncode: 'Literal["raise", "warn", "ignore"]' = "raise", - extra_ok_returncodes: Optional[Iterable[int]] = None, - extra_environ: Optional[Mapping[str, Any]] = None, - unset_environ: Optional[Iterable[str]] = None, - spinner: Optional[SpinnerInterface] = None, - log_failed_cmd: Optional[bool] = True, - stdout_only: Optional[bool] = False, - *, - command_desc: str, -) -> str: - """ - Args: - show_stdout: if true, use INFO to log the subprocess's stderr and - 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. - stdout_only: if true, return only stdout, else return both. When true, - logging of both stdout and stderr occurs when the subprocess has - terminated, else logging occurs as subprocess output is produced. - """ - 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: Callable[..., None] = subprocess_logger.info - used_level = logging.INFO - else: - # Then log the subprocess output using VERBOSE. This also ensures - # it will be logged to the log file (aka user_log), if enabled. - log_subprocess = subprocess_logger.verbose - used_level = VERBOSE - - # 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 - - 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), - stdin=subprocess.PIPE, - stdout=subprocess.PIPE, - stderr=subprocess.STDOUT if not stdout_only else subprocess.PIPE, - cwd=cwd, - env=env, - errors="backslashreplace", - ) - except Exception as exc: - if log_failed_cmd: - subprocess_logger.critical( - "Error %s while executing command %s", - exc, - command_desc, - ) - raise - all_output = [] - if not stdout_only: - assert proc.stdout - assert proc.stdin - proc.stdin.close() - # In this mode, stdout and stderr are in the same pipe. - while True: - line: 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: - assert spinner - spinner.spin() - try: - proc.wait() - finally: - if proc.stdout: - proc.stdout.close() - output = "".join(all_output) - else: - # In this mode, stdout and stderr are in different pipes. - # We must use communicate() which is the only safe way to read both. - out, err = proc.communicate() - # log line by line to preserve pip log indenting - for out_line in out.splitlines(): - log_subprocess(out_line) - all_output.append(out) - for err_line in err.splitlines(): - log_subprocess(err_line) - all_output.append(err) - output = out - - proc_had_error = proc.returncode and proc.returncode not in extra_ok_returncodes - if use_spinner: - assert spinner - if proc_had_error: - spinner.finish("error") - else: - spinner.finish("done") - if proc_had_error: - if on_returncode == "raise": - error = InstallationSubprocessError( - command_description=command_desc, - exit_code=proc.returncode, - output_lines=all_output if not showing_subprocess else None, - ) - if log_failed_cmd: - subprocess_logger.error("%s", error, extra={"rich": True}) - subprocess_logger.verbose( - "[bold magenta]full command[/]: [blue]%s[/]", - escape(format_command_args(cmd)), - extra={"markup": True}, - ) - subprocess_logger.verbose( - "[bold magenta]cwd[/]: %s", - escape(cwd or "[inherit]"), - extra={"markup": True}, - ) - - raise error - elif on_returncode == "warn": - subprocess_logger.warning( - 'Command "%s" had error code %s in %s', - command_desc, - proc.returncode, - cwd, - ) - elif on_returncode == "ignore": - pass - else: - raise ValueError(f"Invalid value: on_returncode={on_returncode!r}") - return output - - -def runner_with_spinner_message(message: str) -> Callable[..., None]: - """Provide a subprocess_runner that shows a spinner message. - - Intended for use with for BuildBackendHookCaller. Thus, the runner has - an API that matches what's expected by BuildBackendHookCaller.subprocess_runner. - """ - - def runner( - cmd: List[str], - cwd: Optional[str] = None, - extra_environ: Optional[Mapping[str, Any]] = None, - ) -> None: - with open_spinner(message) as spinner: - call_subprocess( - cmd, - command_desc=message, - cwd=cwd, - extra_environ=extra_environ, - spinner=spinner, - ) - - return runner diff --git a/venv/lib/python3.12/site-packages/pip/_internal/utils/temp_dir.py b/venv/lib/python3.12/site-packages/pip/_internal/utils/temp_dir.py deleted file mode 100644 index 4eec5f3..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/utils/temp_dir.py +++ /dev/null @@ -1,296 +0,0 @@ -import errno -import itertools -import logging -import os.path -import tempfile -import traceback -from contextlib import ExitStack, contextmanager -from pathlib import Path -from typing import ( - Any, - Callable, - Dict, - Generator, - List, - Optional, - TypeVar, - Union, -) - -from pip._internal.utils.misc import enum, rmtree - -logger = logging.getLogger(__name__) - -_T = TypeVar("_T", bound="TempDirectory") - - -# Kinds of temporary directories. Only needed for ones that are -# globally-managed. -tempdir_kinds = enum( - BUILD_ENV="build-env", - EPHEM_WHEEL_CACHE="ephem-wheel-cache", - REQ_BUILD="req-build", -) - - -_tempdir_manager: Optional[ExitStack] = None - - -@contextmanager -def global_tempdir_manager() -> Generator[None, None, 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: - """Manages temp directory behavior""" - - def __init__(self) -> None: - self._should_delete: Dict[str, bool] = {} - - def set_delete(self, kind: str, value: bool) -> None: - """Indicate whether a TempDirectory of the given kind should be - auto-deleted. - """ - self._should_delete[kind] = value - - def get_delete(self, kind: str) -> bool: - """Get configured auto-delete flag for a given TempDirectory type, - default True. - """ - return self._should_delete.get(kind, True) - - -_tempdir_registry: Optional[TempDirectoryTypeRegistry] = None - - -@contextmanager -def tempdir_registry() -> Generator[TempDirectoryTypeRegistry, None, None]: - """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 _Default: - pass - - -_default = _Default() - - -class TempDirectory: - """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: Optional[str] = None, - delete: Union[bool, None, _Default] = _default, - kind: str = "temp", - globally_managed: bool = False, - ignore_cleanup_errors: bool = True, - ): - super().__init__() - - if delete is _default: - if path is not None: - # If we were given an explicit directory, resolve delete option - # now. - delete = False - else: - # Otherwise, we wait until cleanup and see what - # tempdir_registry says. - delete = None - - # The only time we specify path is in for editables where it - # is the value of the --src option. - if path is None: - path = self._create(kind) - - self._path = path - self._deleted = False - self.delete = delete - self.kind = kind - self.ignore_cleanup_errors = ignore_cleanup_errors - - if globally_managed: - assert _tempdir_manager is not None - _tempdir_manager.enter_context(self) - - @property - def path(self) -> str: - assert not self._deleted, f"Attempted to access deleted path: {self._path}" - return self._path - - def __repr__(self) -> str: - return f"<{self.__class__.__name__} {self.path!r}>" - - def __enter__(self: _T) -> _T: - return self - - def __exit__(self, exc: Any, value: Any, tb: 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: 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=f"pip-{kind}-")) - logger.debug("Created temporary directory: %s", path) - return path - - def cleanup(self) -> None: - """Remove the temporary directory created and reset state""" - self._deleted = True - if not os.path.exists(self._path): - return - - errors: List[BaseException] = [] - - def onerror( - func: Callable[..., Any], - path: Path, - exc_val: BaseException, - ) -> None: - """Log a warning for a `rmtree` error and continue""" - formatted_exc = "\n".join( - traceback.format_exception_only(type(exc_val), exc_val) - ) - formatted_exc = formatted_exc.rstrip() # remove trailing new line - if func in (os.unlink, os.remove, os.rmdir): - logger.debug( - "Failed to remove a temporary file '%s' due to %s.\n", - path, - formatted_exc, - ) - else: - logger.debug("%s failed with %s.", func.__qualname__, formatted_exc) - errors.append(exc_val) - - if self.ignore_cleanup_errors: - try: - # first try with tenacity; retrying to handle ephemeral errors - rmtree(self._path, ignore_errors=False) - except OSError: - # last pass ignore/log all errors - rmtree(self._path, onexc=onerror) - if errors: - logger.warning( - "Failed to remove contents in a temporary directory '%s'.\n" - "You can safely remove it manually.", - self._path, - ) - else: - 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: str, delete: Optional[bool] = None) -> None: - self.original = original.rstrip("/\\") - super().__init__(delete=delete) - - @classmethod - def _generate_names(cls, name: str) -> Generator[str, None, None]: - """Generates a series of temporary names. - - The algorithm replaces the leading characters in the name - 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: 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=f"pip-{kind}-")) - - logger.debug("Created temporary directory: %s", path) - return path diff --git a/venv/lib/python3.12/site-packages/pip/_internal/utils/unpacking.py b/venv/lib/python3.12/site-packages/pip/_internal/utils/unpacking.py deleted file mode 100644 index 78b5c13..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/utils/unpacking.py +++ /dev/null @@ -1,257 +0,0 @@ -"""Utilities related archives. -""" - -import logging -import os -import shutil -import stat -import tarfile -import zipfile -from typing import Iterable, List, Optional -from zipfile import ZipInfo - -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 - -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() -> int: - """Get the current umask which involves having to set it temporarily.""" - mask = os.umask(0) - os.umask(mask) - return mask - - -def split_leading_dir(path: str) -> List[str]: - 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: Iterable[str]) -> bool: - """Returns true if all the paths have the same leading path name - (i.e., everything is in one subdirectory in an archive)""" - common_prefix = None - 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: str, target: str) -> 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 set_extracted_file_to_default_mode_plus_executable(path: str) -> None: - """ - Make file present at path have execute for user/group/world - (chmod +x) is no-op on windows per python docs - """ - os.chmod(path, (0o777 & ~current_umask() | 0o111)) - - -def zip_item_is_executable(info: ZipInfo) -> bool: - mode = info.external_attr >> 16 - # if mode and regular file and any execute permissions for - # user/group/world? - return bool(mode and stat.S_ISREG(mode) and mode & 0o111) - - -def unzip_file(filename: str, location: str, flatten: bool = True) -> None: - """ - Unzip the file (with path `filename`) to the destination `location`. All - files are written based on system defaults and umask (i.e. permissions are - 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() - if zip_item_is_executable(info): - set_extracted_file_to_default_mode_plus_executable(fn) - finally: - zipfp.close() - - -def untar_file(filename: str, location: str) -> None: - """ - Untar the file (with path `filename`) to the destination `location`. - All files are written based on system defaults and umask (i.e. permissions - 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, encoding="utf-8") - try: - leading = has_leading_dir([member.name for member in tar.getmembers()]) - for member in tar.getmembers(): - fn = member.name - if leading: - fn = split_leading_dir(fn)[1] - 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: - tar._extract_member(member, path) - 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)) - assert fp is not None - with open(path, "wb") as destfp: - shutil.copyfileobj(fp, destfp) - fp.close() - # Update the timestamp (useful for cython compiled files) - tar.utime(member, path) - # member have any execute permissions for user/group/world? - if member.mode & 0o111: - set_extracted_file_to_default_mode_plus_executable(path) - finally: - tar.close() - - -def unpack_file( - filename: str, - location: str, - content_type: Optional[str] = None, -) -> 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(f"Cannot determine archive format of {location}") diff --git a/venv/lib/python3.12/site-packages/pip/_internal/utils/urls.py b/venv/lib/python3.12/site-packages/pip/_internal/utils/urls.py deleted file mode 100644 index 6ba2e04..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/utils/urls.py +++ /dev/null @@ -1,62 +0,0 @@ -import os -import string -import urllib.parse -import urllib.request -from typing import Optional - -from .compat import WINDOWS - - -def get_url_scheme(url: str) -> Optional[str]: - if ":" not in url: - return None - return url.split(":", 1)[0].lower() - - -def path_to_url(path: str) -> 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: str) -> str: - """ - Convert a file: URL to a path. - """ - assert url.startswith( - "file:" - ), f"You can only turn file: urls into filenames (not {url!r})" - - _, netloc, path, _, _ = urllib.parse.urlsplit(url) - - if not netloc or netloc == "localhost": - # According to RFC 8089, same as empty authority. - netloc = "" - elif WINDOWS: - # If we have a UNC path, prepend UNC share notation. - netloc = "\\\\" + netloc - else: - raise ValueError( - f"non-local file URIs are not supported on this platform: {url!r}" - ) - - path = urllib.request.url2pathname(netloc + path) - - # On Windows, urlsplit parses the path as something like "/C:/Users/foo". - # This creates issues for path-related functions like io.open(), so we try - # to detect and strip the leading slash. - if ( - WINDOWS - and not netloc # Not UNC. - and len(path) >= 3 - and path[0] == "/" # Leading slash to strip. - and path[1] in string.ascii_letters # Drive letter. - and path[2:4] in (":", ":/") # Colon + end of string, or colon + absolute path. - ): - path = path[1:] - - return path diff --git a/venv/lib/python3.12/site-packages/pip/_internal/utils/virtualenv.py b/venv/lib/python3.12/site-packages/pip/_internal/utils/virtualenv.py deleted file mode 100644 index 882e36f..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/utils/virtualenv.py +++ /dev/null @@ -1,104 +0,0 @@ -import logging -import os -import re -import site -import sys -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() -> 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_legacy_virtualenv() -> 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() -> bool: - """True if we're running inside a virtual environment, False otherwise.""" - return _running_under_venv() or _running_under_legacy_virtualenv() - - -def _get_pyvenv_cfg_lines() -> 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: - # Although PEP 405 does not specify, the built-in venv module always - # writes with UTF-8. (pypa/pip#8717) - with open(pyvenv_cfg_file, encoding="utf-8") as f: - return f.read().splitlines() # avoids trailing newlines - except OSError: - return None - - -def _no_global_under_venv() -> bool: - """Check `{sys.prefix}/pyvenv.cfg` for system site-packages inclusion - - PEP 405 specifies that when system site-packages are not supposed to be - 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_legacy_virtualenv() -> 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() -> bool: - """Returns a boolean, whether running in venv with no system site-packages.""" - # PEP 405 compliance needs to be checked first since virtualenv >=20 would - # return True for both checks, but is only able to use the PEP 405 config. - if _running_under_venv(): - return _no_global_under_venv() - - if _running_under_legacy_virtualenv(): - return _no_global_under_legacy_virtualenv() - - return False diff --git a/venv/lib/python3.12/site-packages/pip/_internal/utils/wheel.py b/venv/lib/python3.12/site-packages/pip/_internal/utils/wheel.py deleted file mode 100644 index 3551f8f..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/utils/wheel.py +++ /dev/null @@ -1,134 +0,0 @@ -"""Support functions for working with wheel files. -""" - -import logging -from email.message import Message -from email.parser import Parser -from typing import Tuple -from zipfile import BadZipFile, ZipFile - -from pip._vendor.packaging.utils import canonicalize_name - -from pip._internal.exceptions import UnsupportedWheel - -VERSION_COMPATIBLE = (1, 0) - - -logger = logging.getLogger(__name__) - - -def parse_wheel(wheel_zip: ZipFile, name: 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(f"{name} has an invalid wheel, {str(e)}") - - check_compatibility(version, name) - - return info_dir, metadata - - -def wheel_dist_info_dir(source: ZipFile, name: str) -> str: - """Returns the name of the contained .dist-info directory. - - Raises AssertionError or UnsupportedWheel if not found, >1 found, or - it doesn't match the provided name. - """ - # Zip file path separators must be / - subdirs = {p.split("/", 1)[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( - f".dist-info directory {info_dir!r} does not start with {canonical_name!r}" - ) - - return info_dir - - -def read_wheel_metadata_file(source: ZipFile, path: 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(f"could not read {path!r} file: {e!r}") - - -def wheel_metadata(source: ZipFile, dist_info_dir: str) -> Message: - """Return the WHEEL metadata of an extracted wheel, if possible. - Otherwise, raise UnsupportedWheel. - """ - path = f"{dist_info_dir}/WHEEL" - # Zip file path separators must be / - wheel_contents = read_wheel_metadata_file(source, path) - - try: - wheel_text = wheel_contents.decode() - except UnicodeDecodeError as e: - raise UnsupportedWheel(f"error decoding {path!r}: {e!r}") - - # 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: 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(f"invalid Wheel-Version: {version!r}") - - -def check_compatibility(version: Tuple[int, ...], name: str) -> None: - """Raises errors or warns if called with an incompatible Wheel-Version. - - pip should refuse to install a Wheel-Version that's a major series - 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 Wheel-Version ({}) is not compatible with this version " - "of pip".format(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.12/site-packages/pip/_internal/vcs/__init__.py b/venv/lib/python3.12/site-packages/pip/_internal/vcs/__init__.py deleted file mode 100644 index b6beddb..0000000 --- a/venv/lib/python3.12/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 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, - RemoteNotValidError, - is_url, - make_vcs_requirement_url, - vcs, -) diff --git a/venv/lib/python3.12/site-packages/pip/_internal/vcs/__pycache__/__init__.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/vcs/__pycache__/__init__.cpython-312.pyc deleted file mode 100644 index f03fa7e87c2e704bcb51644b6927516164fbe24c..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 541 zcmZXPy-EW?6oqGY%_c@fLXo zzQLxnvJ(Odsk|Ga2)Qud;huAunftc9+$2~p;gh`e2zjrX-@<-c<71R(l8}Td649x8 zGxcY>FjY_0bPxr)9@TXtYUssiQ8%L|B}3ZwKdQ^F+O=}+MriBAm30?3H_17Gg@5K9 zS8`?sGK+Ii<%Z@15f{BI2Jw(f5Ly^FO?))lOXWr?(=e9C2{2rRXog+>$T^fgCgu8k z+?TH0oVT@rUJjD0vNa!OdAAUdNo&gO`E(ZbtZ`r!__!@BRH#)5D%26LWQ-(}KD)PC zFyM(asRWxpvNMqloK4vY6x?)9t}i>MO0q(jf+^W$>CoL$j*rDetQA+z6b(V GaN-Bp)Tj~w diff --git a/venv/lib/python3.12/site-packages/pip/_internal/vcs/__pycache__/bazaar.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/vcs/__pycache__/bazaar.cpython-312.pyc deleted file mode 100644 index c7a87250dc0ab2275ad035df7587a16ae59b6a7b..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 5033 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 diff --git a/venv/lib/python3.12/site-packages/pip/_internal/vcs/__pycache__/git.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/vcs/__pycache__/git.cpython-312.pyc deleted file mode 100644 index ddb59e78c99b0bc6aa281e55dcbee03a94f5aa83..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 19002 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

%r5i8j zQ)-7cd43LI0iWGd*2(pF}M~l?HVoZe7ey0bfN2+{HbzF-@Eqrd^da>17pR3 zu@4TG299kEyi^=`3FhRh@w*mt#P_eh(9-19Ge5lWna$kVo<9P+e>?xPj<-5i&Xn3B ztNRgVkv|S0XSri}SD~rzU3a;$b=ke_DKz%3Os-C?&96@*dXIJW8D|dq@?)?|cpH~3 zMNdaL*uDbspR5gqU|$*0jf2+)mnT<}rKY|4v0L5!Z}%6wpIetp-D5@X_Wan@;MIf< zHN9#sH4QF}eNq?dw!i7>*m4{EEnh51{R(Rh9)MJR>KQKT8J)kRMIHJN)xx;tp>qI4 zX^>)4#|~M~R1QC=bv)}K0;4%ka3=l>;UYC&4FWcNeIYhI-bFV^%i7zB6%3gkH|E^CRm`~X;LcWKf^UWW7vVJE$i8O;1V}1JXOf5 zAz0s9X3RCDVQ7wRFy@l*!Jc{n7{n}f#>KQuE@RlW49$}>G*8#KDi8XHhFJVF?$sv6 zi((Sd)i#OjyVz^e5NouZGxYOskz`N6Dx6fq%y9QYln_qFqE-7Kf66?9*%0~zG$X?< z-TgNB6x9KMtigsdn>9DM;Z@t<;fK*XYaZ;2i6HdQ@ z7nr$$inx)Hjw>cf`Ym1RKqx=)1(&9ZzR2o8$+tIe z`Pk#b?TP&Hin$RgZXkHwf6WgSx6n0G2s}c%ZRd`1CtvRBBPF+iYvk{8jz(X8Kg=4c zh^mDPnSSYf+qv3O;vXsb_Y|CaKED@aHdMO{&N=4&t(Z-XBew(Ldk$#HpShtW-}3XM zB8L%jO)7HuzDyw~f7P~s8~2-S+Yh)bzj@Ay^tVnEQi>>tL=GOX$?l2P67HYN)69@Yx(Smwh;JcEShI)CsiKXbiV@h`!Qr!N_=HLN zC-hu4KM-Q)on0G^L=jgM^A5s#hWR{XuO6X)u#ONg=uM#1$^god(4Vrim7n8|o z6ya_R?}5tP3#xR`MWB=r-IX7~hkX7fSM~%J50-tQ#UtfF>*BGB+3vS59zhIr^Pa`8 zlv_F%Pu;dP0vBz~%W{Q7hMSaQZ(jx?+M4fLaM6gptJuA^-qkY|4%xbeWgl4Y(yvOV z$2PjsydtlTt-SH}_PZQ@;sSsjeYV&_t34GC*&6O|zCUz_iqxn2uJQ;g4caeocZ-vK76e3%&FoNFW#YdS~HX?6DHO!WDBhXD;%=by)0XM><<0XAW^F9 z)&_ty(NeJt+B(YH`qli27g&DV6})3Zz0rGz-n-W}yn^W?LvJ>6PG{c_N`L#3a10U@D_0Wgm!s9O$M^4|PYOM)M z+KlZs_bN6V*;?ohWf}xZFfyu0^(f&&i|x_1ed}ZIKYNdg8Wc)|a99H~Fa{rlj6N9| zK{VZ?dX)mv5sC~c4!Ua!?MHE>@Pa znagwNLM1AUQV=Oo!tmM*8~<&^u=ob~Z*cosmKZZ67Pu8=K9fkw!?OuFu2L704B72& zrE7C%Dj;M(n2+L!Yg5Cr`OQF})5DPd=*G9k$W^*SdIvN3tJI4mA7&JinrKQk^-JHQ z+JB%57xbl*>_)Eizo?R;!W9QRLvv8)q-Urq%&Kse_rR$$horZtYJ(C+Tsx>l%T3&D z3cd+ZVq8YuhjzTU?|eoj{?AGO7e9&G$)6$tgEX0b&-wI!uHSRP-*e6X%ncN|fq&%= z{4;l?$Q}9L+>?JaJ5A<4a!5X-1U^=<-)EMd+3@g155MRvHw3SoTROMV&|7TiU35c- zad+ffH(c#SSNrn5lB;*oj=JXUR}Wl2ehp%Q)#kZtu{WCwTqCf~7tWu)GO;vKKvY)4 zZq~e^HGkmB@g;z|Y%UCEbA12!caPs~^){FnU6n4Asec(*jBF)zm$G}#7agWhe)t|o Zd1cbanHm-?-}ipkn?Lgr*T|OQ{{!xwTjl@& diff --git a/venv/lib/python3.12/site-packages/pip/_internal/vcs/__pycache__/mercurial.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/vcs/__pycache__/mercurial.cpython-312.pyc deleted file mode 100644 index f922e1cb34dfc8ef16d774898c5e99ba4b7388e0..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 7622 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 X8~PRHBk%FQ$nvm= diff --git a/venv/lib/python3.12/site-packages/pip/_internal/vcs/__pycache__/versioncontrol.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/vcs/__pycache__/versioncontrol.cpython-312.pyc deleted file mode 100644 index 425e074fc9b0663d6dcabfe5b946f9523f0d98c7..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 29020 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 n`A}fqN2jbWSS&ps3e3G|6 List[str]: - return ["-r", rev] - - def fetch_new( - self, dest: str, url: HiddenText, rev_options: RevOptions, verbosity: int - ) -> None: - rev_display = rev_options.to_display() - logger.info( - "Checking out %s%s to %s", - url, - rev_display, - display_path(dest), - ) - if verbosity <= 0: - flag = "--quiet" - elif verbosity == 1: - flag = "" - else: - flag = f"-{'v'*verbosity}" - cmd_args = make_command( - "checkout", "--lightweight", flag, rev_options.to_args(), url, dest - ) - self.run_command(cmd_args) - - def switch(self, dest: str, url: HiddenText, rev_options: RevOptions) -> None: - self.run_command(make_command("switch", url), cwd=dest) - - def update(self, dest: str, url: HiddenText, rev_options: RevOptions) -> None: - output = self.run_command( - make_command("info"), show_stdout=False, stdout_only=True, cwd=dest - ) - if output.startswith("Standalone "): - # Older versions of pip used to create standalone branches. - # Convert the standalone branch to a checkout by calling "bzr bind". - cmd_args = make_command("bind", "-q", url) - self.run_command(cmd_args, cwd=dest) - - cmd_args = make_command("update", "-q", rev_options.to_args()) - self.run_command(cmd_args, cwd=dest) - - @classmethod - def get_url_rev_and_auth(cls, url: str) -> Tuple[str, Optional[str], AuthInfo]: - # hotfix the URL scheme after removing bzr+ from bzr+ssh:// re-add it - url, rev, user_pass = super().get_url_rev_and_auth(url) - if url.startswith("ssh://"): - url = "bzr+" + url - return url, rev, user_pass - - @classmethod - def get_remote_url(cls, location: str) -> str: - urls = cls.run_command( - ["info"], show_stdout=False, stdout_only=True, cwd=location - ) - for line in urls.splitlines(): - line = line.strip() - for x in ("checkout of branch: ", "parent branch: "): - if line.startswith(x): - repo = line.split(x)[1] - if cls._is_local_repository(repo): - return path_to_url(repo) - return repo - raise RemoteNotFoundError - - @classmethod - def get_revision(cls, location: str) -> str: - revision = cls.run_command( - ["revno"], - show_stdout=False, - stdout_only=True, - cwd=location, - ) - return revision.splitlines()[-1] - - @classmethod - def is_commit_id_equal(cls, dest: str, name: Optional[str]) -> bool: - """Always assume the versions don't match""" - return False - - -vcs.register(Bazaar) diff --git a/venv/lib/python3.12/site-packages/pip/_internal/vcs/git.py b/venv/lib/python3.12/site-packages/pip/_internal/vcs/git.py deleted file mode 100644 index 8c242cf..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/vcs/git.py +++ /dev/null @@ -1,526 +0,0 @@ -import logging -import os.path -import pathlib -import re -import urllib.parse -import urllib.request -from typing import List, Optional, Tuple - -from pip._internal.exceptions import BadCommand, InstallationError -from pip._internal.utils.misc import HiddenText, display_path, hide_url -from pip._internal.utils.subprocess import make_command -from pip._internal.vcs.versioncontrol import ( - AuthInfo, - RemoteNotFoundError, - RemoteNotValidError, - RevOptions, - VersionControl, - find_path_to_project_root_from_repo_root, - vcs, -) - -urlsplit = urllib.parse.urlsplit -urlunsplit = urllib.parse.urlunsplit - - -logger = logging.getLogger(__name__) - - -GIT_VERSION_REGEX = re.compile( - r"^git version " # Prefix. - r"(\d+)" # Major. - r"\.(\d+)" # Dot, minor. - r"(?:\.(\d+))?" # Optional dot, patch. - r".*$" # Suffix, including any pre- and post-release segments we don't care about. -) - -HASH_REGEX = re.compile("^[a-fA-F0-9]{40}$") - -# SCP (Secure copy protocol) shorthand. e.g. 'git@example.com:foo/bar.git' -SCP_REGEX = re.compile( - r"""^ - # Optional user, e.g. 'git@' - (\w+@)? - # Server, e.g. 'github.com'. - ([^/:]+): - # The server-side path. e.g. 'user/project.git'. Must start with an - # alphanumeric character so as not to be confusable with a Windows paths - # like 'C:/foo/bar' or 'C:\foo\bar'. - (\w[^:]*) - $""", - re.VERBOSE, -) - - -def looks_like_hash(sha: str) -> bool: - return bool(HASH_REGEX.match(sha)) - - -class Git(VersionControl): - name = "git" - dirname = ".git" - repo_name = "clone" - schemes = ( - "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: str) -> List[str]: - return [rev] - - def is_immutable_rev_checkout(self, url: str, dest: str) -> bool: - _, rev_options = self.get_url_rev_options(hide_url(url)) - if not rev_options.rev: - return False - 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) -> Tuple[int, ...]: - version = self.run_command( - ["version"], - command_desc="git version", - show_stdout=False, - stdout_only=True, - ) - match = GIT_VERSION_REGEX.match(version) - if not match: - logger.warning("Can't parse git version: %s", version) - return () - return (int(match.group(1)), int(match.group(2))) - - @classmethod - def get_current_branch(cls, location: str) -> Optional[str]: - """ - Return the current branch, or None if HEAD isn't at a branch - (e.g. detached HEAD). - """ - # 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, - stdout_only=True, - cwd=location, - ) - ref = output.strip() - - if ref.startswith("refs/heads/"): - return ref[len("refs/heads/") :] - - return None - - @classmethod - def get_revision_sha(cls, dest: str, rev: str) -> Tuple[Optional[str], bool]: - """ - Return (sha_or_none, is_branch), where sha_or_none is a commit hash - if the revision names a remote branch or tag, otherwise None. - - 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, - stdout_only=True, - 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: - ref_sha, ref_name = line.split(" ", maxsplit=2) - except ValueError: - # Include the offending line to simplify troubleshooting if - # this error ever occurs. - raise ValueError(f"unexpected show-ref line: {line!r}") - - refs[ref_name] = ref_sha - - branch_ref = f"refs/remotes/origin/{rev}" - tag_ref = f"refs/tags/{rev}" - - sha = refs.get(branch_ref) - if sha is not None: - return (sha, True) - - sha = refs.get(tag_ref) - - return (sha, False) - - @classmethod - def _should_fetch(cls, dest: str, rev: str) -> bool: - """ - Return true if rev is a ref or is a commit that we don't have locally. - - Branches and tags are not considered in this method because they are - assumed to be always available locally (which is a normal outcome of - ``git clone`` and ``git fetch --tags``). - """ - if rev.startswith("refs/"): - # Always fetch remote refs. - return True - - if not looks_like_hash(rev): - # Git fetch would fail with abbreviated commits. - return False - - if cls.has_commit(dest, rev): - # Don't fetch if we have the commit locally. - return False - - return True - - @classmethod - def resolve_revision( - cls, dest: str, url: HiddenText, rev_options: RevOptions - ) -> RevOptions: - """ - Resolve a revision to a new RevOptions object with the SHA1 of the - branch, tag, or ref if found. - - 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 cls._should_fetch(dest, rev): - return rev_options - - # fetch the requested revision - 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: str, name: Optional[str]) -> bool: - """ - 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: str, url: HiddenText, rev_options: RevOptions, verbosity: int - ) -> None: - rev_display = rev_options.to_display() - logger.info("Cloning %s%s to %s", url, rev_display, display_path(dest)) - if verbosity <= 0: - flags: Tuple[str, ...] = ("--quiet",) - elif verbosity == 1: - flags = () - else: - flags = ("--verbose", "--progress") - if self.get_git_version() >= (2, 17): - # Git added support for partial clone in 2.17 - # https://git-scm.com/docs/partial-clone - # Speeds up cloning by functioning without a complete copy of repository - self.run_command( - make_command( - "clone", - "--filter=blob:none", - *flags, - url, - dest, - ) - ) - else: - self.run_command(make_command("clone", *flags, url, dest)) - - if rev_options.rev: - # Then a specific revision was requested. - rev_options = self.resolve_revision(dest, url, rev_options) - branch_name = getattr(rev_options, "branch_name", None) - logger.debug("Rev options %s, branch_name %s", rev_options, branch_name) - if branch_name is None: - # Only do a checkout if the current commit id doesn't match - # the requested revision. - if not self.is_commit_id_equal(dest, rev_options.rev): - cmd_args = make_command( - "checkout", - "-q", - rev_options.to_args(), - ) - self.run_command(cmd_args, cwd=dest) - elif self.get_current_branch(dest) != branch_name: - # Then a specific branch was requested, and that branch - # is not yet checked out. - track_branch = f"origin/{branch_name}" - cmd_args = [ - "checkout", - "-b", - branch_name, - "--track", - track_branch, - ] - self.run_command(cmd_args, cwd=dest) - else: - sha = self.get_revision(dest) - rev_options = rev_options.make_new(sha) - - logger.info("Resolved %s to commit %s", url, rev_options.rev) - - #: repo may contain submodules - self.update_submodules(dest) - - def switch(self, dest: str, url: HiddenText, rev_options: 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: str, url: HiddenText, rev_options: RevOptions) -> None: - # First fetch changes from the default remote - if self.get_git_version() >= (1, 9): - # 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: str) -> str: - """ - 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, - stdout_only=True, - 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 cls._git_remote_to_pip_url(url.strip()) - - @staticmethod - def _git_remote_to_pip_url(url: str) -> str: - """ - Convert a remote url from what git uses to what pip accepts. - - There are 3 legal forms **url** may take: - - 1. A fully qualified url: ssh://git@example.com/foo/bar.git - 2. A local project.git folder: /path/to/bare/repository.git - 3. SCP shorthand for form 1: git@example.com:foo/bar.git - - Form 1 is output as-is. Form 2 must be converted to URI and form 3 must - be converted to form 1. - - See the corresponding test test_git_remote_url_to_pip() for examples of - sample inputs/outputs. - """ - if re.match(r"\w+://", url): - # This is already valid. Pass it though as-is. - return url - if os.path.exists(url): - # A local bare remote (git clone --mirror). - # Needs a file:// prefix. - return pathlib.PurePath(url).as_uri() - scp_match = SCP_REGEX.match(url) - if scp_match: - # Add an ssh:// prefix and replace the ':' with a '/'. - return scp_match.expand(r"ssh://\1\2/\3") - # Otherwise, bail out. - raise RemoteNotValidError(url) - - @classmethod - def has_commit(cls, location: str, rev: str) -> bool: - """ - Check if rev is a commit that is available in the local repository. - """ - try: - cls.run_command( - ["rev-parse", "-q", "--verify", "sha^" + rev], - cwd=location, - log_failed_cmd=False, - ) - except InstallationError: - return False - else: - return True - - @classmethod - def get_revision(cls, location: str, rev: Optional[str] = None) -> str: - if rev is None: - rev = "HEAD" - current_rev = cls.run_command( - ["rev-parse", rev], - show_stdout=False, - stdout_only=True, - cwd=location, - ) - return current_rev.strip() - - @classmethod - def get_subdirectory(cls, location: str) -> Optional[str]: - """ - Return the path to Python project root, relative to the repo root. - Return None if the project root is in the repo root. - """ - # find the repo root - git_dir = cls.run_command( - ["rev-parse", "--git-dir"], - show_stdout=False, - stdout_only=True, - cwd=location, - ).strip() - if not os.path.isabs(git_dir): - git_dir = os.path.join(location, git_dir) - repo_root = os.path.abspath(os.path.join(git_dir, "..")) - return find_path_to_project_root_from_repo_root(location, repo_root) - - @classmethod - def get_url_rev_and_auth(cls, url: str) -> Tuple[str, Optional[str], AuthInfo]: - """ - Prefixes stub URLs like 'user@hostname:user/repo.git' with 'ssh://'. - That's required because although they use SSH they sometimes don't - 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("/") - 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().get_url_rev_and_auth(url) - url = url.replace("ssh://", "") - else: - url, rev, user_pass = super().get_url_rev_and_auth(url) - - return url, rev, user_pass - - @classmethod - def update_submodules(cls, location: str) -> None: - if not os.path.exists(os.path.join(location, ".gitmodules")): - return - cls.run_command( - ["submodule", "update", "--init", "--recursive", "-q"], - cwd=location, - ) - - @classmethod - def get_repository_root(cls, location: str) -> Optional[str]: - loc = super().get_repository_root(location) - if loc: - return loc - try: - r = cls.run_command( - ["rev-parse", "--show-toplevel"], - cwd=location, - show_stdout=False, - stdout_only=True, - on_returncode="raise", - log_failed_cmd=False, - ) - except BadCommand: - logger.debug( - "could not determine if %s is under git control " - "because git is not available", - location, - ) - return None - except InstallationError: - return None - return os.path.normpath(r.rstrip("\r\n")) - - @staticmethod - def should_add_vcs_url_prefix(repo_url: str) -> bool: - """In either https or ssh form, requirements must be prefixed with git+.""" - return True - - -vcs.register(Git) diff --git a/venv/lib/python3.12/site-packages/pip/_internal/vcs/mercurial.py b/venv/lib/python3.12/site-packages/pip/_internal/vcs/mercurial.py deleted file mode 100644 index c183d41..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/vcs/mercurial.py +++ /dev/null @@ -1,163 +0,0 @@ -import configparser -import logging -import os -from typing import List, Optional, Tuple - -from pip._internal.exceptions import BadCommand, InstallationError -from pip._internal.utils.misc import HiddenText, display_path -from pip._internal.utils.subprocess import make_command -from pip._internal.utils.urls import path_to_url -from pip._internal.vcs.versioncontrol import ( - RevOptions, - VersionControl, - find_path_to_project_root_from_repo_root, - vcs, -) - -logger = logging.getLogger(__name__) - - -class Mercurial(VersionControl): - name = "hg" - dirname = ".hg" - repo_name = "clone" - schemes = ( - "hg+file", - "hg+http", - "hg+https", - "hg+ssh", - "hg+static-http", - ) - - @staticmethod - def get_base_rev_args(rev: str) -> List[str]: - return [f"--rev={rev}"] - - def fetch_new( - self, dest: str, url: HiddenText, rev_options: RevOptions, verbosity: int - ) -> None: - rev_display = rev_options.to_display() - logger.info( - "Cloning hg %s%s to %s", - url, - rev_display, - display_path(dest), - ) - if verbosity <= 0: - flags: Tuple[str, ...] = ("--quiet",) - elif verbosity == 1: - flags = () - elif verbosity == 2: - flags = ("--verbose",) - else: - flags = ("--verbose", "--debug") - self.run_command(make_command("clone", "--noupdate", *flags, url, dest)) - self.run_command( - make_command("update", *flags, rev_options.to_args()), - cwd=dest, - ) - - def switch(self, dest: str, url: HiddenText, rev_options: RevOptions) -> None: - repo_config = os.path.join(dest, self.dirname, "hgrc") - config = configparser.RawConfigParser() - try: - config.read(repo_config) - config.set("paths", "default", url.secret) - with open(repo_config, "w") as config_file: - config.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: str, url: HiddenText, rev_options: RevOptions) -> None: - self.run_command(["pull", "-q"], cwd=dest) - cmd_args = make_command("update", "-q", rev_options.to_args()) - self.run_command(cmd_args, cwd=dest) - - @classmethod - def get_remote_url(cls, location: str) -> str: - url = cls.run_command( - ["showconfig", "paths.default"], - show_stdout=False, - stdout_only=True, - cwd=location, - ).strip() - if cls._is_local_repository(url): - url = path_to_url(url) - return url.strip() - - @classmethod - def get_revision(cls, location: str) -> str: - """ - Return the repository-local changeset revision number, as an integer. - """ - current_revision = cls.run_command( - ["parents", "--template={rev}"], - show_stdout=False, - stdout_only=True, - cwd=location, - ).strip() - return current_revision - - @classmethod - def get_requirement_revision(cls, location: str) -> str: - """ - Return the changeset identification hash, as a 40-character - hexadecimal string - """ - current_rev_hash = cls.run_command( - ["parents", "--template={node}"], - show_stdout=False, - stdout_only=True, - cwd=location, - ).strip() - return current_rev_hash - - @classmethod - def is_commit_id_equal(cls, dest: str, name: Optional[str]) -> bool: - """Always assume the versions don't match""" - return False - - @classmethod - def get_subdirectory(cls, location: str) -> Optional[str]: - """ - Return the path to Python project root, relative to the repo root. - Return None if the project root is in the repo root. - """ - # find the repo root - repo_root = cls.run_command( - ["root"], show_stdout=False, stdout_only=True, cwd=location - ).strip() - if not os.path.isabs(repo_root): - repo_root = os.path.abspath(os.path.join(location, repo_root)) - return find_path_to_project_root_from_repo_root(location, repo_root) - - @classmethod - def get_repository_root(cls, location: str) -> Optional[str]: - loc = super().get_repository_root(location) - if loc: - return loc - try: - r = cls.run_command( - ["root"], - cwd=location, - show_stdout=False, - stdout_only=True, - on_returncode="raise", - log_failed_cmd=False, - ) - except BadCommand: - logger.debug( - "could not determine if %s is under hg control " - "because hg is not available", - location, - ) - return None - except InstallationError: - return None - return os.path.normpath(r.rstrip("\r\n")) - - -vcs.register(Mercurial) diff --git a/venv/lib/python3.12/site-packages/pip/_internal/vcs/subversion.py b/venv/lib/python3.12/site-packages/pip/_internal/vcs/subversion.py deleted file mode 100644 index 16d93a6..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/vcs/subversion.py +++ /dev/null @@ -1,324 +0,0 @@ -import logging -import os -import re -from typing import List, Optional, Tuple - -from pip._internal.utils.misc import ( - HiddenText, - display_path, - is_console_interactive, - is_installable_dir, - split_auth_from_netloc, -) -from pip._internal.utils.subprocess import CommandArgs, make_command -from pip._internal.vcs.versioncontrol import ( - AuthInfo, - RemoteNotFoundError, - RevOptions, - VersionControl, - vcs, -) - -logger = logging.getLogger(__name__) - -_svn_xml_url_re = re.compile('url="([^"]+)"') -_svn_rev_re = re.compile(r'committed-rev="(\d+)"') -_svn_info_xml_rev_re = re.compile(r'\s*revision="(\d+)"') -_svn_info_xml_url_re = re.compile(r"(.*)") - - -class Subversion(VersionControl): - name = "svn" - dirname = ".svn" - repo_name = "checkout" - schemes = ("svn+ssh", "svn+http", "svn+https", "svn+svn", "svn+file") - - @classmethod - def should_add_vcs_url_prefix(cls, remote_url: str) -> bool: - return True - - @staticmethod - def get_base_rev_args(rev: str) -> List[str]: - return ["-r", rev] - - @classmethod - def get_revision(cls, location: str) -> str: - """ - Return the maximum revision for all files under a given location - """ - # Note: taken from setuptools.command.egg_info - revision = 0 - - for base, dirs, _ 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: - assert dirurl is not None - 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 str(revision) - - @classmethod - def get_netloc_and_auth( - cls, netloc: str, scheme: str - ) -> Tuple[str, Tuple[Optional[str], Optional[str]]]: - """ - This override allows the auth information to be passed to svn via the - --username and --password options instead of via the URL. - """ - if scheme == "ssh": - # The --username and --password options can't be used for - # svn+ssh URLs, so keep the auth information in the URL. - return super().get_netloc_and_auth(netloc, scheme) - - return split_auth_from_netloc(netloc) - - @classmethod - def get_url_rev_and_auth(cls, url: str) -> Tuple[str, Optional[str], AuthInfo]: - # hotfix the URL scheme after removing svn+ from svn+ssh:// re-add it - url, rev, user_pass = super().get_url_rev_and_auth(url) - if url.startswith("ssh://"): - url = "svn+" + url - return url, rev, user_pass - - @staticmethod - def make_rev_args( - username: Optional[str], password: Optional[HiddenText] - ) -> CommandArgs: - extra_args: CommandArgs = [] - if username: - extra_args += ["--username", username] - if password: - extra_args += ["--password", password] - - return extra_args - - @classmethod - def get_remote_url(cls, location: str) -> str: - # In cases where the source is in a subdirectory, we have to look up in - # the location until we find a valid project root. - orig_location = location - while not is_installable_dir(location): - last_location = location - location = os.path.dirname(location) - if location == last_location: - # We've traversed up to the root of the filesystem without - # finding a Python project. - logger.warning( - "Could not find Python project for directory %s (tried all " - "parent directories)", - orig_location, - ) - raise RemoteNotFoundError - - url, _rev = cls._get_svn_url_rev(location) - if url is None: - raise RemoteNotFoundError - - return url - - @classmethod - def _get_svn_url_rev(cls, location: str) -> Tuple[Optional[str], int]: - from pip._internal.exceptions import InstallationError - - entries_path = os.path.join(location, cls.dirname, "entries") - 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 = "" - - url = None - if data.startswith("8") or data.startswith("9") or data.startswith("10"): - entries = list(map(str.splitlines, data.split("\n\x0c\n"))) - del entries[0][0] # get rid of the '8' - url = entries[0][3] - revs = [int(d[9]) for d in entries if len(d) > 9 and d[9]] + [0] - elif data.startswith("= 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, - stdout_only=True, - ) - match = _svn_info_xml_url_re.search(xml) - assert match is not None - url = match.group(1) - revs = [int(m.group(1)) for m in _svn_info_xml_rev_re.finditer(xml)] - except InstallationError: - url, revs = None, [] - - if revs: - rev = max(revs) - else: - rev = 0 - - return url, rev - - @classmethod - def is_commit_id_equal(cls, dest: str, name: Optional[str]) -> bool: - """Always assume the versions don't match""" - return False - - def __init__(self, use_interactive: Optional[bool] = None) -> 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: Optional[Tuple[int, ...]] = None - - super().__init__() - - def call_vcs_version(self) -> Tuple[int, ...]: - """Query the version of the currently installed Subversion client. - - :return: A tuple containing the parts of the version information or - ``()`` 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 - # svn, version 1.12.0-SlikSvn (SlikSvn/1.12.0) - # compiled May 28 2019, 13:44:56 on x86_64-microsoft-windows6.2 - version_prefix = "svn, version " - version = self.run_command(["--version"], show_stdout=False, stdout_only=True) - if not version.startswith(version_prefix): - return () - - version = version[len(version_prefix) :].split()[0] - version_list = version.partition("-")[0].split(".") - try: - parsed_version = tuple(map(int, version_list)) - except ValueError: - return () - - return parsed_version - - def get_vcs_version(self) -> Tuple[int, ...]: - """Return the version of the currently installed Subversion client. - - If the version of the Subversion client has already been queried, - 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) -> 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 - - 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 fetch_new( - self, dest: str, url: HiddenText, rev_options: RevOptions, verbosity: int - ) -> None: - rev_display = rev_options.to_display() - logger.info( - "Checking out %s%s to %s", - url, - rev_display, - display_path(dest), - ) - if verbosity <= 0: - flag = "--quiet" - else: - flag = "" - cmd_args = make_command( - "checkout", - flag, - self.get_remote_call_options(), - rev_options.to_args(), - url, - dest, - ) - self.run_command(cmd_args) - - def switch(self, dest: str, url: HiddenText, rev_options: RevOptions) -> None: - cmd_args = make_command( - "switch", - self.get_remote_call_options(), - rev_options.to_args(), - url, - dest, - ) - self.run_command(cmd_args) - - def update(self, dest: str, url: HiddenText, rev_options: RevOptions) -> None: - cmd_args = make_command( - "update", - self.get_remote_call_options(), - rev_options.to_args(), - dest, - ) - self.run_command(cmd_args) - - -vcs.register(Subversion) diff --git a/venv/lib/python3.12/site-packages/pip/_internal/vcs/versioncontrol.py b/venv/lib/python3.12/site-packages/pip/_internal/vcs/versioncontrol.py deleted file mode 100644 index 46ca279..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/vcs/versioncontrol.py +++ /dev/null @@ -1,705 +0,0 @@ -"""Handles all VCS (version control) support""" - -import logging -import os -import shutil -import sys -import urllib.parse -from typing import ( - TYPE_CHECKING, - Any, - Dict, - Iterable, - Iterator, - List, - Mapping, - Optional, - Tuple, - Type, - Union, -) - -from pip._internal.cli.spinners import SpinnerInterface -from pip._internal.exceptions import BadCommand, InstallationError -from pip._internal.utils.misc import ( - HiddenText, - ask_path_exists, - backup_dir, - display_path, - hide_url, - hide_value, - is_installable_dir, - rmtree, -) -from pip._internal.utils.subprocess import ( - CommandArgs, - call_subprocess, - format_command_args, - make_command, -) -from pip._internal.utils.urls import get_url_scheme - -if TYPE_CHECKING: - # Literal was introduced in Python 3.8. - # - # TODO: Remove `if TYPE_CHECKING` when dropping support for Python 3.7. - from typing import Literal - - -__all__ = ["vcs"] - - -logger = logging.getLogger(__name__) - -AuthInfo = Tuple[Optional[str], Optional[str]] - - -def is_url(name: str) -> bool: - """ - Return true if the name looks like a URL. - """ - scheme = get_url_scheme(name) - if scheme is None: - return False - return scheme in ["http", "https", "file", "ftp"] + vcs.all_schemes - - -def make_vcs_requirement_url( - repo_url: str, rev: str, project_name: str, subdir: Optional[str] = None -) -> str: - """ - Return the URL for a VCS requirement. - - Args: - repo_url: the remote VCS url, with any needed VCS prefix (e.g. "git+"). - project_name: the (unescaped) project name. - """ - egg_project_name = project_name.replace("-", "_") - req = f"{repo_url}@{rev}#egg={egg_project_name}" - if subdir: - req += f"&subdirectory={subdir}" - - return req - - -def find_path_to_project_root_from_repo_root( - location: str, repo_root: str -) -> Optional[str]: - """ - Find the the Python project's root by searching up the filesystem from - `location`. Return the path to project root relative to `repo_root`. - Return None if the project root is `repo_root`, or cannot be found. - """ - # find project root. - orig_location = location - while not is_installable_dir(location): - last_location = location - location = os.path.dirname(location) - if location == last_location: - # We've traversed up to the root of the filesystem without - # finding a Python project. - logger.warning( - "Could not find a Python project for directory %s (tried all " - "parent directories)", - orig_location, - ) - return None - - if os.path.samefile(repo_root, location): - return None - - return os.path.relpath(location, repo_root) - - -class RemoteNotFoundError(Exception): - pass - - -class RemoteNotValidError(Exception): - def __init__(self, url: str): - super().__init__(url) - self.url = url - - -class RevOptions: - - """ - 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["VersionControl"], - rev: Optional[str] = None, - extra_args: Optional[CommandArgs] = None, - ) -> 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: Optional[str] = None - - def __repr__(self) -> str: - return f"" - - @property - def arg_rev(self) -> Optional[str]: - if self.rev is None: - return self.vc_class.default_arg_rev - - return self.rev - - def to_args(self) -> CommandArgs: - """ - Return the VCS-specific command arguments. - """ - args: 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) -> str: - if not self.rev: - return "" - - return f" (to revision {self.rev})" - - def make_new(self, rev: 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: - _registry: Dict[str, "VersionControl"] = {} - schemes = ["ssh", "git", "hg", "bzr", "sftp", "svn"] - - def __init__(self) -> None: - # Register more schemes with urlparse for various version control - # systems - urllib.parse.uses_netloc.extend(self.schemes) - super().__init__() - - def __iter__(self) -> Iterator[str]: - return self._registry.__iter__() - - @property - def backends(self) -> List["VersionControl"]: - return list(self._registry.values()) - - @property - def dirnames(self) -> List[str]: - return [backend.dirname for backend in self.backends] - - @property - def all_schemes(self) -> List[str]: - schemes: List[str] = [] - for backend in self.backends: - schemes.extend(backend.schemes) - return schemes - - def register(self, cls: Type["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: str) -> None: - if name in self._registry: - del self._registry[name] - - def get_backend_for_dir(self, location: str) -> Optional["VersionControl"]: - """ - Return a VersionControl object if a repository of that type is found - at the given directory. - """ - vcs_backends = {} - for vcs_backend in self._registry.values(): - repo_path = vcs_backend.get_repository_root(location) - if not repo_path: - continue - logger.debug("Determine that %s uses VCS: %s", location, vcs_backend.name) - vcs_backends[repo_path] = vcs_backend - - if not vcs_backends: - return None - - # Choose the VCS in the inner-most directory. Since all repository - # roots found here would be either `location` or one of its - # parents, the longest path should have the most path components, - # i.e. the backend representing the inner-most repository. - inner_most_repo_path = max(vcs_backends, key=len) - return vcs_backends[inner_most_repo_path] - - def get_backend_for_scheme(self, scheme: 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: str) -> Optional["VersionControl"]: - """ - Return a VersionControl object or None. - """ - name = name.lower() - return self._registry.get(name) - - -vcs = VcsSupport() - - -class VersionControl: - name = "" - dirname = "" - repo_name = "" - # List of supported schemes for this Version Control - schemes: Tuple[str, ...] = () - # Iterable of environment variable names to pass to call_subprocess(). - unset_environ: Tuple[str, ...] = () - default_arg_rev: Optional[str] = None - - @classmethod - def should_add_vcs_url_prefix(cls, remote_url: str) -> bool: - """ - Return whether the vcs prefix (e.g. "git+") should be added to a - repository's remote url when used in a requirement. - """ - return not remote_url.lower().startswith(f"{cls.name}:") - - @classmethod - def get_subdirectory(cls, location: str) -> Optional[str]: - """ - Return the path to Python project root, relative to the repo root. - Return None if the project root is in the repo root. - """ - return None - - @classmethod - def get_requirement_revision(cls, repo_dir: 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: str, project_name: str) -> 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 cls.should_add_vcs_url_prefix(repo_url): - repo_url = f"{cls.name}+{repo_url}" - - revision = cls.get_requirement_revision(repo_dir) - subdir = cls.get_subdirectory(repo_dir) - req = make_vcs_requirement_url(repo_url, revision, project_name, subdir=subdir) - - return req - - @staticmethod - def get_base_rev_args(rev: 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: str, dest: 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: Optional[str] = None, extra_args: Optional[CommandArgs] = None - ) -> 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: 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) - - @classmethod - def get_netloc_and_auth( - cls, netloc: str, scheme: str - ) -> Tuple[str, Tuple[Optional[str], Optional[str]]]: - """ - Parse the repository URL's netloc, and return the new netloc to use - along with auth information. - - 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: 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( - f"Sorry, {url!r} is a malformed VCS url. " - "The format is +://, " - "e.g. svn+http://myrepo/svn/MyApp#egg=MyApp" - ) - # 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) - if not rev: - raise InstallationError( - f"The URL {url!r} has an empty revision (after @) " - "which is not supported. Include a revision after @ " - "or remove @ from the URL." - ) - url = urllib.parse.urlunsplit((scheme, netloc, path, query, "")) - return url, rev, user_pass - - @staticmethod - def make_rev_args( - username: Optional[str], password: Optional[HiddenText] - ) -> CommandArgs: - """ - Return the RevOptions "extra arguments" to use in obtain(). - """ - return [] - - def get_url_rev_options(self, url: HiddenText) -> Tuple[HiddenText, RevOptions]: - """ - Return the URL and RevOptions object to use in obtain(), - as a tuple (url, rev_options). - """ - secret_url, rev, user_pass = self.get_url_rev_and_auth(url.secret) - username, secret_password = user_pass - password: Optional[HiddenText] = None - 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: 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: str, url2: 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: str, url: HiddenText, rev_options: RevOptions, verbosity: int - ) -> None: - """ - Fetch a revision from a repository, in the case that this is the - first fetch from the repository. - - Args: - dest: the directory to fetch the repository to. - rev_options: a RevOptions object. - verbosity: verbosity level. - """ - raise NotImplementedError - - def switch(self, dest: str, url: HiddenText, rev_options: RevOptions) -> None: - """ - Switch the repo at ``dest`` to point to ``URL``. - - Args: - rev_options: a RevOptions object. - """ - raise NotImplementedError - - def update(self, dest: str, url: HiddenText, rev_options: 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: str, name: 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: str, url: HiddenText, verbosity: int) -> None: - """ - Install or update in editable mode the package represented by this - VersionControl object. - - :param dest: the repository directory in which to install or update. - :param url: the repository URL starting with a vcs prefix. - :param verbosity: verbosity level. - """ - url, rev_options = self.get_url_rev_options(url) - - if not os.path.exists(dest): - self.fetch_new(dest, url, rev_options, verbosity=verbosity) - 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 ", ("i", "w", "b")) # type: ignore - - logger.warning( - "The plan is to install the %s repository %s", - self.name, - url, - ) - response = ask_path_exists(f"What to do? {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, verbosity=verbosity) - 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, verbosity=verbosity) - 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: str, url: HiddenText, verbosity: int) -> None: - """ - Clean up current location and download the url repository - (and vcs infos) into location - - :param url: the repository URL starting with a vcs prefix. - :param verbosity: verbosity level. - """ - if os.path.exists(location): - rmtree(location) - self.obtain(location, url=url, verbosity=verbosity) - - @classmethod - def get_remote_url(cls, location: 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: str) -> str: - """ - Return the current commit id of the files at the given location. - """ - raise NotImplementedError - - @classmethod - def run_command( - cls, - cmd: Union[List[str], CommandArgs], - show_stdout: bool = True, - cwd: Optional[str] = None, - on_returncode: 'Literal["raise", "warn", "ignore"]' = "raise", - extra_ok_returncodes: Optional[Iterable[int]] = None, - command_desc: Optional[str] = None, - extra_environ: Optional[Mapping[str, Any]] = None, - spinner: Optional[SpinnerInterface] = None, - log_failed_cmd: bool = True, - stdout_only: bool = False, - ) -> str: - """ - Run a VCS subcommand - This is simply a wrapper around call_subprocess that adds the VCS - command name, and checks that the VCS is available - """ - cmd = make_command(cls.name, *cmd) - if command_desc is None: - command_desc = format_command_args(cmd) - try: - return call_subprocess( - cmd, - show_stdout, - cwd, - on_returncode=on_returncode, - extra_ok_returncodes=extra_ok_returncodes, - command_desc=command_desc, - extra_environ=extra_environ, - unset_environ=cls.unset_environ, - spinner=spinner, - log_failed_cmd=log_failed_cmd, - stdout_only=stdout_only, - ) - except FileNotFoundError: - # errno.ENOENT = no such file or directory - # In other words, the VCS executable isn't available - raise BadCommand( - f"Cannot find command {cls.name!r} - do you have " - f"{cls.name!r} installed and in your PATH?" - ) - except PermissionError: - # errno.EACCES = Permission denied - # This error occurs, for instance, when the command is installed - # only for another user. So, the current user don't have - # permission to call the other user command. - raise BadCommand( - f"No permission to execute {cls.name!r} - install it " - f"locally, globally (ask admin), or check your PATH. " - f"See possible solutions at " - f"https://pip.pypa.io/en/latest/reference/pip_freeze/" - f"#fixing-permission-denied." - ) - - @classmethod - def is_repository_directory(cls, path: str) -> bool: - """ - Return whether a directory path is a repository directory. - """ - logger.debug("Checking in %s for %s (%s)...", path, cls.dirname, cls.name) - return os.path.exists(os.path.join(path, cls.dirname)) - - @classmethod - def get_repository_root(cls, location: str) -> Optional[str]: - """ - Return the "root" (top-level) directory controlled by the vcs, - or `None` if the directory is not in any. - - 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. - """ - if cls.is_repository_directory(location): - return location - return None diff --git a/venv/lib/python3.12/site-packages/pip/_internal/wheel_builder.py b/venv/lib/python3.12/site-packages/pip/_internal/wheel_builder.py deleted file mode 100644 index b1debe3..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/wheel_builder.py +++ /dev/null @@ -1,354 +0,0 @@ -"""Orchestrator for building wheels from InstallRequirements. -""" - -import logging -import os.path -import re -import shutil -from typing import Iterable, List, Optional, Tuple - -from pip._vendor.packaging.utils import canonicalize_name, canonicalize_version -from pip._vendor.packaging.version import InvalidVersion, Version - -from pip._internal.cache import WheelCache -from pip._internal.exceptions import InvalidWheelFilename, UnsupportedWheel -from pip._internal.metadata import FilesystemWheel, get_wheel_distribution -from pip._internal.models.link import Link -from pip._internal.models.wheel import Wheel -from pip._internal.operations.build.wheel import build_wheel_pep517 -from pip._internal.operations.build.wheel_editable import build_wheel_editable -from pip._internal.operations.build.wheel_legacy import build_wheel_legacy -from pip._internal.req.req_install import InstallRequirement -from pip._internal.utils.logging import indent_log -from pip._internal.utils.misc import ensure_dir, hash_file -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.urls import path_to_url -from pip._internal.vcs import vcs - -logger = logging.getLogger(__name__) - -_egg_info_re = re.compile(r"([a-z0-9_.]+)-([a-z0-9_.!+-]+)", re.IGNORECASE) - -BuildResult = Tuple[List[InstallRequirement], List[InstallRequirement]] - - -def _contains_egg_info(s: str) -> bool: - """Determine whether the string looks like an egg_info. - - :param s: The string to parse. E.g. foo-2.1 - """ - return bool(_egg_info_re.search(s)) - - -def _should_build( - req: InstallRequirement, - need_wheel: bool, -) -> bool: - """Return whether an InstallRequirement should be built into a wheel.""" - if req.constraint: - # never build requirements that are merely constraints - 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.source_dir: - return False - - if req.editable: - # we only build PEP 660 editable requirements - return req.supports_pyproject_editable() - - return True - - -def should_build_for_wheel_command( - req: InstallRequirement, -) -> bool: - return _should_build(req, need_wheel=True) - - -def should_build_for_install_command( - req: InstallRequirement, -) -> bool: - return _should_build(req, need_wheel=False) - - -def _should_cache( - req: InstallRequirement, -) -> Optional[bool]: - """ - Return whether a built InstallRequirement can be stored in the persistent - wheel cache, assuming the wheel cache is available, and _should_build() - has determined a wheel needs to be built. - """ - if req.editable or not req.source_dir: - # never cache editable requirements - 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 - - assert req.link - base, ext = req.link.splitext() - if _contains_egg_info(base): - return True - - # Otherwise, do not cache. - return False - - -def _get_cache_dir( - req: InstallRequirement, - wheel_cache: WheelCache, -) -> str: - """Return the persistent or temporary cache directory where the built - wheel need to be stored. - """ - cache_available = bool(wheel_cache.cache_dir) - assert req.link - 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 _verify_one(req: InstallRequirement, wheel_path: str) -> None: - canonical_name = canonicalize_name(req.name or "") - w = Wheel(os.path.basename(wheel_path)) - if canonicalize_name(w.name) != canonical_name: - raise InvalidWheelFilename( - f"Wheel has unexpected file name: expected {canonical_name!r}, " - f"got {w.name!r}", - ) - dist = get_wheel_distribution(FilesystemWheel(wheel_path), canonical_name) - dist_verstr = str(dist.version) - if canonicalize_version(dist_verstr) != canonicalize_version(w.version): - raise InvalidWheelFilename( - f"Wheel has unexpected file name: expected {dist_verstr!r}, " - f"got {w.version!r}", - ) - metadata_version_value = dist.metadata_version - if metadata_version_value is None: - raise UnsupportedWheel("Missing Metadata-Version") - try: - metadata_version = Version(metadata_version_value) - except InvalidVersion: - msg = f"Invalid Metadata-Version: {metadata_version_value}" - raise UnsupportedWheel(msg) - if metadata_version >= Version("1.2") and not isinstance(dist.version, Version): - raise UnsupportedWheel( - f"Metadata 1.2 mandates PEP 440 version, but {dist_verstr!r} is not" - ) - - -def _build_one( - req: InstallRequirement, - output_dir: str, - verify: bool, - build_options: List[str], - global_options: List[str], - editable: bool, -) -> Optional[str]: - """Build one wheel. - - :return: The filename of the built wheel, or None if the build failed. - """ - artifact = "editable" if editable else "wheel" - try: - ensure_dir(output_dir) - except OSError as e: - logger.warning( - "Building %s for %s failed: %s", - artifact, - req.name, - e, - ) - return None - - # Install build deps into temporary directory (PEP 518) - with req.build_env: - wheel_path = _build_one_inside_env( - req, output_dir, build_options, global_options, editable - ) - if wheel_path and verify: - try: - _verify_one(req, wheel_path) - except (InvalidWheelFilename, UnsupportedWheel) as e: - logger.warning("Built %s for %s is invalid: %s", artifact, req.name, e) - return None - return wheel_path - - -def _build_one_inside_env( - req: InstallRequirement, - output_dir: str, - build_options: List[str], - global_options: List[str], - editable: bool, -) -> Optional[str]: - with TempDirectory(kind="wheel") as temp_dir: - assert req.name - if req.use_pep517: - assert req.metadata_directory - assert req.pep517_backend - if global_options: - logger.warning( - "Ignoring --global-option when building %s using PEP 517", req.name - ) - if build_options: - logger.warning( - "Ignoring --build-option when building %s using PEP 517", req.name - ) - if editable: - wheel_path = build_wheel_editable( - name=req.name, - backend=req.pep517_backend, - metadata_directory=req.metadata_directory, - tempd=temp_dir.path, - ) - else: - wheel_path = build_wheel_pep517( - name=req.name, - backend=req.pep517_backend, - metadata_directory=req.metadata_directory, - tempd=temp_dir.path, - ) - 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: InstallRequirement, global_options: List[str]) -> bool: - clean_args = make_setuptools_clean_args( - req.setup_py_path, - global_options=global_options, - ) - - logger.info("Running setup.py clean for %s", req.name) - try: - call_subprocess( - clean_args, command_desc="python setup.py clean", cwd=req.source_dir - ) - return True - except Exception: - logger.error("Failed cleaning build dir for %s", req.name) - return False - - -def build( - requirements: Iterable[InstallRequirement], - wheel_cache: WheelCache, - verify: bool, - build_options: List[str], - global_options: List[str], -) -> BuildResult: - """Build wheels. - - :return: The list of InstallRequirement that succeeded to build and - 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), # type: ignore - ) - - with indent_log(): - build_successes, build_failures = [], [] - for req in requirements: - assert req.name - cache_dir = _get_cache_dir(req, wheel_cache) - wheel_file = _build_one( - req, - cache_dir, - verify, - build_options, - global_options, - req.editable and req.permit_editable_wheels, - ) - if wheel_file: - # Record the download origin in the cache - if req.download_info is not None: - # download_info is guaranteed to be set because when we build an - # InstallRequirement it has been through the preparer before, but - # let's be cautious. - wheel_cache.record_download_origin(cache_dir, req.download_info) - # Update the link for this. - req.link = Link(path_to_url(wheel_file)) - req.local_file_path = req.link.file_path - 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]), # type: ignore - ) - if build_failures: - logger.info( - "Failed to build %s", - " ".join([req.name for req in build_failures]), # type: ignore - ) - # Return a list of requirements that failed to build - return build_successes, build_failures diff --git a/venv/lib/python3.12/site-packages/pip/_vendor/__init__.py b/venv/lib/python3.12/site-packages/pip/_vendor/__init__.py deleted file mode 100644 index c1884ba..0000000 --- a/venv/lib/python3.12/site-packages/pip/_vendor/__init__.py +++ /dev/null @@ -1,121 +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 = False - -# 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. -WHEEL_DIR = os.path.abspath(os.path.dirname(__file__)) - - -# 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("cachecontrol") - vendored("certifi") - vendored("colorama") - vendored("distlib") - vendored("distro") - 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("platformdirs") - vendored("progress") - 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") - vendored("requests.packages.urllib3.packages.ordered_dict") - vendored("requests.packages.urllib3.packages.six") - 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("resolvelib") - vendored("rich") - vendored("rich.console") - vendored("rich.highlighter") - vendored("rich.logging") - vendored("rich.markup") - vendored("rich.progress") - vendored("rich.segment") - vendored("rich.style") - vendored("rich.text") - vendored("rich.traceback") - vendored("tenacity") - vendored("tomli") - vendored("truststore") - vendored("urllib3") diff --git a/venv/lib/python3.12/site-packages/pip/_vendor/__pycache__/__init__.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_vendor/__pycache__/__init__.cpython-312.pyc deleted file mode 100644 index e20b751a73aabf2a2663d26d83fccc60f21fdaf3..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4703 zcmbW3U2GKB702)F-2L<}HvZtt7zS)U7Q!sXm=DJx!Po&*0&S%%v>ljw9?80KX=4I_xx8pI8r)X77U6~+C!3qSF=!#J)RhTwm5=ATPN?l@=%_`_p6uF#lVTTQb`i>eh)H;bY&F*HHyCT;Qt*mxQXQ z7qRvlA=HPcETPNby^e0km(g`88@uSnKRkR({jmQQBKf?Z%GY-e?D&*vO=za$$4slhTiK~Pe!OJq6-X~XMjhKUm>+it(-@$0)UE7W=81kO%fNwL~X+FpiHWG>7=ONHpEyJEXw%Ldz8)mvdBuM7IrURovVt zajr7U&Yh;$wDO_TKRgt zleznUipsVu)7{ln$tW!GfpsNnnVIkcLAZnKYwfB9=Y`{#Zj)zOv5v~xAz|B0-Ens} zQ<%iI9M(+J*q+?laYBu1QJuiClh=&`Yqn{P8+Zl}{)E7=AbBWgg<`%4^W~+-9s9p- zQ+XLQNeRwgjpvNJr%4#tvyxVZ%0ruFLOnpUMT9rPhO8&k0qn;u2g)%k`Vq^a8SYPxj*Yy1arDC2sE>o5IDB^145+TbfeR=4 zBzy!y)Z{zo#>Ot>N6-H)TihPK>lgq{1(0#mSstj zoQalxd$yE~inZ_4e7hv$rqJUAi~&>Dl{dKfQGS()_ul z?So6{V>8L8>2_&EdU_P$%yJBMY`@cYH~UGpuDo#n!u-~UXP34QFSWn+SNZRWza z7y}+Y8W_htd?GLod$>O^PI`DKForz*YG5?PIS(HWJpCR%vf4Q1;nxFCV~9}?kAY_y zNgH-PM^aSz7k}WR9v%#Ijqw_>4tZD&x=wibK&5oxH8DQ)8_|$Ly~?+|32zf`$Pao7Cgs9b6c$^gABz;v5PuKf;@r$0CqE^f=_? Fe*rQ0@X!DN diff --git a/venv/lib/python3.12/site-packages/pip/_vendor/__pycache__/six.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_vendor/__pycache__/six.cpython-312.pyc deleted file mode 100644 index 4a47820df7c09fa1d1692634c184427a1b5357ab..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 41280 zcmc(|3t(HvbtZiAA^-v)_ofY-hZRo83nqH?HrOme9HrwCHzq`%ucC&y$FR2@4f4NO}oBg|8*pywz z**5=oX70Us5K^49-Tz9QJNL|)nKNh3%$zy%z<+SL3I#mV-d6%2|EeJTIelo)a@DiY zyHpUa3!>l?M1yD?Gz=MiMg#dxgC?Jez0E!|ds}=K_Ac-hu(#D`70o`IXz|&lg7f8C z(&@KosKJL=aG^yIe2xd=SQ(D-v{k%Bi(f#&m72m7QN9!FYo)=04=>-o)Ec>0a7GHDsoDq?AEPlsr}^BtNm{TA)- z82FcLHwsd*Sg3s?=M_fbfFL?v6hx;~_l}9<`8;+3nDzMcyrU+h#W7GwvFOsiebtY9 zB$sRj*NX-lh8lg11|et^O}<9a{i5J&5{u!kWVw_em(q+}ni;eV&~m9+&%1>|D*&wo z7fz(hq4{*oHilUR%<7Ezs~EHf&?Omptp?SrrFNZaFT+|2tYuQ0p5mGTD%~n^IsVm( zb?=yYo|6U!^@#Q23b8@-ykp6NHv(QSHi?Zn@RedS@LR-{Iq+7%^*q(ISFyBLi>q>Q z+eI(_tr6RE;AsQ5>#EG2zu8O}VeklibO?+AW z^&HqMVoaROfqhwgReUW6_7(A;h}UyqQ{oNr|Hy&;hWNVpn>n!G62B@==fK_&zb5|E z9N3%U|G9|f-xl8zXL9h~7XO*}P7dtr;_oaf$3K_a#cxE>ti+o+*xy9R@3N5J%L(}w zLjDDXXz!fx-xvQtd^ZR7FU3C;|0oCcZSh};f1HN-)}k%t83o1vi$-kOC9Orj-6Fmx zen+d@0YlVlgwNA6}_&RB=w5D&ZmI|m@10Ma~3{xGoeVgx-&t~yor&D9& z*}uVf_HQ%Bvn_1g`V;Yc>AGT&f42zo?-xP-!y?F^E`t2WMUd|;f_#4wENjSZ~)?=Qmp&x;^)iy-rhAh#Dmltm@^!6L|=MUWpZ zg8Y|E$Uu#6tF#poTd7Ozmi!WyDY4h8nS5=Pwxs1Nza)VtTOf6;RcjiO`2UD^Go>F| z;s=nfKg*D=ZH$+HF8)Z=+dG5&#UjXm1)p@B0h4dLv^}dd+dg+`woBVSM`^a9H2*EL z4T*m#{y3*J{~e|Ie=|z6L)HEM3e^7(4Oi8m{yGorf98RuP|n=AALfC5ln1tuC%t=l zU?1m!eUbtyF9R;Er!JmqL3GA$O|>*g_`n0 z&3U1gywHNYP-|YOEicr*xPDQ#!n{yNUZ^uK)Rh-nl$Qo~Hq^IM+L_hnc6{zOw^Q2j zIojL~sU2l3&TMt~F2P@^)|zM(Js<#rIUn5ejMmpdJqKVF;}B;RNM_dTo*@PDi?=fLYG}b~-1`Cv|D#uJ6=+ak_P!hwqECU&ndm zzBmVToJa4A)1%`&c3+%>I?ieE^bktA3taKxy&Lbx@!o^?6L@#x{Ul50+ggd!Z-npF zQ|fyF);=BU=?7q?Iq44`MB3ddP5V`v4yZKs{2ZFnrF#%fhdvighjlDJC~uO8M@O=x zqDdlt9nFCe?{rH8n}ak-PXcx8t=y#>@QC`IP2Qzok*FHq;V7gOWXy zuf&%PzGr+ga_RGh;pWiHB!lYkX)Qgq#`^*Dr(yUy11h6<_v8I6-Xh*(cuRO+fkZ4t zT3?VhpZ~iwm6{J&XSK9^~_moChGQ|w%*{X!bEBj|9V>P|$OHG;$8F^&Wpv^lbPsQQvA%-2OA+(BMc!>I)1FhvZ0aw0W-- zJntV0Acho?}NmwVn06hN7WgH1rqq{f+YAbPxKi@1IlL_HMW`*!(;s#k`{{+U!YX43!{cs zWAC84wuLFk+rrxh#T=Ff&xR?M=d&l)oC^&}Yh=F|2o4A2&`5MmmlVDb2@S95lrQ>& z?VZODw(lDZthp!!FRmF3oLR%mw86V>{hDwfBDD|u`!Dzhr0|;I!0?(rpot+FA(y?w zql&e!Z%_*M^+oNEc~$Q&WE-Y(j|=lvwF~eFy{%@&*4G#G4@rG}N?~8$P)HmZB)_w- z@0k(*APRPi^IcGf8SX- zG}Jd3@{5w(PnDuQ=sC zq?!Q+{ox2o9q~fyP)WQ2pps1C(Xe9WiG)eKsJgg#@p2YvxEx3JfPjbb7bZ%^g&&!V zCL*)u@;i>AS9V<85sM@o%i`u`y!61(AFZ?t)d1x-2GNKnVIDO>mJ0ih_@ko`wfa*(oND^87 z{XRU`g)!m0RwfMtZ*35{Vv6W-NeJ`Srmi>`1iKI+`Df3V;k-@rr{DS0NUI8CrjtU0 z5YZI@bhl=Ma9SX^){V-INUya3!YfPY3NK2EH7ubKL}bP=#VSgJ^rhJQ`uZUqjS#PH%i`+Z)?v zo$aXtp}2Cw_31r}P+a?wV6d0WJB#Pt6%($M1s|V-spRHzq)kIV*3%|e0QQpr0f3hu|B{%F;`K#IUi znIdkU5Y8IV>)WySg9*B5g1B2I1nAWTXv`MHaWr&M5|6T;v!58LJ(MW@Ej$J1D+cr$ zT8NPDDaM4CQGhXha$^u81sa;{95am@#|&3YV5+o@zWa=6PiCbsJAWD|DdRtg3=|q4VY|DpxPhjJv*^BTAooVy`=>SyB*G_)M5>jR{-pOyjI=%?}+#^X}4#XXh)I#7y&5OD4Kr?zzif59m#a-PyhAdA$!skossn z>`8%_)5tn9nG_tEDmbIdlS%u_Azp1Rmk5)j2(-JGPl;bWcjH{r-5j?ya{@Cn*1LhdpDc;<1b_gBmt3jERw~SkbyzTZVclXzkR@+Ot(1mKDoI z|KNy}(^ws>u@WL0Y*luxsc9kriH51J(P~R8ueVROzq)3^dZ)N*$~s-1EM7Tbp%!e8 ziBsLPwiWa4@(CwzDUC#pHE-i1PRleLDlWCd>6Zov`}*ECaH*mWb`O^*CXeI{;x9~% z_|q4KkIh!g(vM0FmX=Qn%$5qCA0cJ6Os!THh%cEfQ*D&UdwXN66yao4>`2$E< z?j~n9IeXx+&PSDVR=?ytM*$UZAm{hYMvM0&o5@mdc1+$@3V2&N2$FeQ*+@Rt*^@A!X3_(h6$2Udj*1n7 z8S~f(LZYMC2t+>KtgMJjgIspg;vJ^WJ-u~(8Q9?gIBM$(PKgQI>X}osw)JeJtDN}a z{F2(36*H-cu4_H>?y9)EZoX`3ysTlqt|8U~J*TD~W8lG*N$|A9dgiM=^mR82eQ90H zrUon?BhAR1)g2##GG`q5+MYH>UNK}0I;6X1$^(+5M;oBDA;_FDp2C_TutxVbSH_hB zuorW}OnsaWvWr-!jXF_jI$+m)8@BqZ`hJ0txyu(m9dLck*|*47)`ocRTYgOy)F38$-Bm zCz_$*6^KP*0jy0{ysdcKL>r)X(GIszEQITz9jrd5q`%VTf zAH|4%+#fl|Cwr0{{eB^dU#DjX0iI!mc=%L~rg->`PQ=WHN|nKg^fC)r-l!H6e(E;KSIdd^5NxeOum zz?ngbrFJO*LNud`cN2@}9~|^ZmjhvDqPYm;3g*@@&YV^8Hn52K=k6ZH+w8e}028i0 zeZn=Wt8p~ZQ(PBir~vu?%-}_9qDd1U;rJ|!b!m$I?8qQ9vxF6!?xnU*qQa+R4rZ<3A`tcDFE!aS zIL7ZIZg?#mjDXekG{x#PO!Ulm?3w7AbJixDwY&w+Y`F2oo7IWBZMU4;KQs~2V!lxK z!@8h7@GvbH@7(8sykH#RW)Jx^V#+irQ+pPf&D)8O>4MS}^T7p8WBegvhCOglP`AQHnQ(W+Z5^y&z5P@Y?V(&*$r|B7$?j9n7qK^X3?>^* zVhyYkHI2S6!^_+{`rXTo7;#FHT}TANoG z_3-Z^5v_)@igu^0VY+8VOqOkkJ2&V>%xqHBBv}#p=w~O34M4fi7&}nGY$tkb*iPJ- zMe7=g2tAaVGnx@Ys%GSi4Yd*c> zuA+wAYq(RoJYL)RUQeR-NV4>3+<7#GrrT@yEKD}1=Zi{&$?8^9R==#v%8!6?olI4D z^Cw>)mcdYp$sRD&M8>F~Sz{b3gZj&yCvC*IVvN|ez%gUmtfk4HT!IM%joLYnZh$ie zt(Y+z`}ACpijJF~Zt8KzjG9Vglb7LJUQSK`j*_?E%&Z2bFc1y|!x4Y5U*ZOoW{L-U zD;EyflhvsjwR_fi=QMl5dvLSQ!1#|ygejO*>t=h&kIE{q@0i>%bvaSi5_h&}RbF!2 zSxj|Y^4Z;@(z&9#L{Z(eEm_n$VY=g}i1oj|W7g3;Us`c}_2lYTy;t|$U0y%2?^^G? zr{S9E6~|RatS4bxPIj3>W(j+~v_klbz1}o!sLz%Xy}9uoB}>_)W|;G&YZ|NaYQw{1 z#2Ec8rWnxBb%L3+JrQ|CTI~s(Wp->bPm5Z!f(k=Q5L?1f^%{!zsN@M^eH{2efTDCR z1b@hb76rXUmZg4ZGU$3duwcR;_K^0XXR2y38@wAmEn!I_g=piZb**|hEp||U&DI92 z=lo$dJs3ji7B^#v18^C6(Ym~iIF0ZFq!1>78yD^s3B^^^i?<}IT4t(~RqJmaO1gK) zZMz>ZzS4w`jjy_n1c3Uad5twYS_9dkvbHxAl(;^~`TfjDK$b+t>@;N_a8cJ0B@xRb za{l7lsL!Isxclf;S}=7ZY-S6&wF!3DoUJBdtC?zRJd8lDLaCDzGs!|$@9XN9B|laPRV`vg-kQt8`70_>6&zKMs7ttM)?$Cd zo^-dxZG1A3)u$4PtW4BJVyTbov)m9(Dr6Qx4(T$MydJ33WMKSHicYN&#Mm-zaK*VZ zq)H(1`7xQ7Wj{G0IRoUdN@nb$ep9{(M=7K_42MQ!ba0~teU_XY^Z6-)k@GhG!aZ@j>)YO$2V z*ipJ<{1BPmS1lA6EG{PhEa`rvsy~{@FO&n6Jt>1p&&-xu9evEmaWEncg`>-9jmbk@ zDJ_^`PQuJcT8EHlseo}xM(Vj`{Q|+r`51rULO3r9ADElx-6hZUaB3+~vG<>Zg(^63 z@R(u@gcO_pRd6;ih&4LJj@4K>5(*7Mhd(m{7{(FB8c;)_4ieT`|6o{BoGO%mS+Mjw z5`nFWW)UJ4ETJ**UB5;-h~`lWDKvB>`5fTR>$=5LoQWsFNG3|pJTg0o_RmzIbqnBL+@ zzeE!jthKVjI>P4$rOQ|-4n-uzf>meJvwXhDQ4$=g{qliZk;|&Hcxu3Sm)NMJYNLi43Es4P6LG=lu{K?ghW2EXbP(_u>S zNj6GnK&<`81N|2U(N2f?8%;_YK|6bhy{xh{EK?&jlSgreL;V*pRpW^}PqHtbFQ#!^ zIIWQjtV2<(r&Ldo3W4q1KNuQN3cA=ks=>V~yi~(OS0<^j!u{~8_*%F(BfMOTgUtZc z^hL%K=SlU8u}s79X5nbizA)p7nxB(%NX=2h@n+#Tv^*n$%Zlk#;Br)hcnP9?^hF{U z6ce0`U_eT=*yv$s9uNsDj#C%(kEj-owx@?{QN*CASWaEQE1f36G&<4X2SalIxljmI zq=3Ks=zAakj%rv)IRi_BBJR*oD5&y*#ij3DPGn)}aU&Np>cknjkghcaUrZkQ&W6y= z3lN5PRD*gMRIAxOY%B?*(Vhuirg%sB*WS?OsD|Oqz^K$xj$Fv9AJCpzi;8nZ9)t`- z&qik+E#r1iZx&ER;a!s+0c+eLIX40aY7y9%Qos|7y0X$%O4U5%(3wy~>-91|qAG$n z1E#nx4-Lx0{aVLp=bzLysv%nEs3EGYv6Pqjv7<*$9N)*=q#i>>v0MrSH>_6*@M6PI zANNFIe1|328!h1ED;D;hUwWRQV^^J`}|U+E{fcj*}R4A{v;% z`ko0ZcFi}a*nx{NPWEHihWC6Z5M=Sg6j3PzXe7wf;(is*6qCN;!4c?ABSEgFI8_e^ z7i(XUP~Vx+2$UMiN($2K2#ORXkFHoARcy>30ReXA8=cYkqO>}ehHai5qsso zqw3BPfhDMUnVc_>=VydLqRK$f1Wz34rpCtz9a%zEg(J~zzj)(OqvmH-J#mPfFXN9*1F5y_L#6r%n`Ru3}2tVcA~i>}uoY+8t^!DZ~sRjem? z$&{jFESWBt6rk+ON)=T~mvq(-eT&sX52h7^$ft|~PCzLj#4I3JSC8{a2a<5YdwEnt zaWLgbO~g%!9LJWmOCec2Iv^``Ie5BI{>L?>mQW-!I5Fbj;5qme$jqdF-Ozi&S7Fb zIP4CGNitH|M?TD&YUSjfS@5Dy#f%fqya6YcmV*qDxUHQ2hT=d{R zX6y9$7wKpowi6uYYwc`>6qbgt;2&moc+E_n#*(Y47VF6ACg%t_$Khmc8Y3GmF?fMY zW!HrPY#aL;ws>I~4clNXT-UO&VOGKPlns%JO_OGM0g16`PaJE#uvb0Yz1FMGc9fhIr%lWYLcC1M}|cId@~i z-577$nRIs`jnbuarOk=b=6K8AWa+-~!#F%)>EWyJEZ?Xzvn^y*1nJSNBDTYmxqmiu zUvb`D>wBNBwf6xO9<`Av3q?P?%EO*hKOJ*SDMt7VrU?hPdg1R@shE5O0 zZCErO2lVfVRiy}}vjvW8ho{QFT63djy6b&2-|LfA2-=v$3h`U;u$4(lmpz%q(AJkg zun}A2%^D6?CD*d8_xc8>{F^a5uyV;_lF+gz&jPXV8^+(%JAw29v9{jXYKksBAyF|o zqv!xj2CJe)L2z!Q{~R+#ulCS>rdDLdS+|OOKZQf9PaZWT9b z3x~UZSnBy^BwpWS z5|L!#g(Vt3IjmUH~2w<8C!H1P@Ou$Gbq_YOJ5qU6l24-%2SOY^W8Rnr> z6emknO@>>MSvrb~1!xJWcxp;n0;6|7E5MTbEtkE6FnY8_BRUlWV;qhJ8L^j&Butgu zV!wz}R{c0n1{=E{I<6c?_L4sm%{-W6Tik2rpe z9NwLnw4!czdG$bCZ^%y){Uz;^yj6PaW_N7+bj4e>Z`96~tx1#~`w81Q@_h9Y0}d{k z{J~Mh92p(PxfL8VlS5d9HOQ+$duFZJwEX1DAaNDtupB6~Wxo_De*4sW4S#fcuA?{6 z(K}muEa^TLw;fwtIaJN8YoS^qNl~SN_3=0;g^B-}&DWkXojEwObxXYMU~%ESqpVpomM5 zHfszzHEECD2xJL~%27BOMP`L#&UVUMc9* zV8|!++7P5sXHqOA7O;X~$0XMKPvL{@*~J11agGZK@mt#{R;F@}RU%B26ifaUlnyt# z2;rryAa~s5b8fztJKaCC;Ts)qcO>20;oklRR-|U(&rcZd=Pq0}=Xzq}X%+W2iQ)in9J|QLn*Tz-C0x?4Hu+70*+6 z&XW$+D#s{a1P#=CP&bO9D_40NL~zul5#c4Q?u=rVRZW>+-9A^gGEug2I+83~9e1u~ z#l+duT+NM=%2mTA2u996O4JH^*)dalJ4=LxL^mA3?hraT$(AP3Y&}^2q?KW8FbRdj z*y%dzQ5%_#lEp1bmaJB+kIm$kk@lS-u$2*pMS6fBda2e+nZM>6lY%VPUuo!9qI?w>p|bz<^J(p?|7)pNlB zs{Z_gkSt$Al4xZwvN!2&h}#1h4}KkiDrJpf`4Odgm#I(269XwtnRZd>ucg;+AH+>clu z_Bx2gr7wbf10F8izfQi_$hi(DOJb=jW)iy+p6fVYo_~L2T29fPS!ElT#4TbQhmtU! zquQk{6EqgoOg!^S^lB74Vy5=OiQD+;?tds!NSYRt!l2|_$RuScNEy32hE2XxXW-;* z6n_t{kgO~wg+a*)k{D@RSprg?z4~mz?U_0OCvNjBmZ84~DI^JtNnucOo*^NbCLA)O zE4GUP=@NA%N+J1pJ5}uDXRRQ*PTeoYXL)R>@X&;f^_Ucq_mngQ_x}6@9_N`qdA~HW1e3-$HU>7bHi8xcrsY2AYlWEV z9ktT3OR#+%CJY69$p`wPA)KK$DTXuh+eqmJlFkyOM-8R;mCIKzPhrPc{vL%gW~Ag( zNaeQ>oRz_dO!I+XC7Gjso@Fp$WAz<1?%JyqLu1E|qkYg}Bi(dQ!;dKgrIdqD_ybsW zIw1`}g;&Z{82dWvkHFv@Rw_BLH-rT?!qVU+ixN;A8S#~(?08w+{)LLj7|5L8Bx(LS zA}?-2`V=eI%7L0BX68I}hEX#X;94J~OAl(*+#5AM@kG@81RkYmBp6`RS6ouyAC@p! zV=}-XWV0F`gvl(oK3HWi=MAcIO}(s)J#&3@a&)?4#+s~J8(+US>E0K&@x_`f&X_?4 ztNdDcGPR2_7|>{F%9{MiL^x#5gryJ&q47+X?Ad5Ray^#q~GXs&}%C+!8%zOpz+ohaQsvfzb7qg;B* zF_v+LUaRXd(#njam8G>;k{uj1<${}TFmLm{+=>||9I&2g7 z-M#aURoAw}HqO?xB^|3~PQ@KNZ$6T6?2MatE*9T^DB??1;xn4H%vLQ(rabDDNd8@- zmYhG#q;@r@c2&}`dPa;pI&Pj#I6C5HekA4}h1E`tTIyKx(D{2rCpmvibn><|?^sE6 zzP>E!SUF>kJGR^`NI15{&0GHQnCe!^)VjbtlzxjSCFi@Dl(sTT>ynPvnT>JB_M4j% zj_q;tc1EdUrk%W52aWV*M|K)Aa*i3st)#7Kb}Bk0ozI3dW*jl#n1mr;PdAofsvI*s zZ)gxiW(~Sx)C`vVB(0H7=F=*vbOsyQVU;VQ-STM&EWGU?OYWdHVvL;0l7H$BWg1E3 zS@7WB5fAnOkB%$Y?3HwA`pWIg(E;i?_lksj#SEO)^OZ~ID%%p3Z8PhWmEL%< zcfJ(om_EIWn_0SXW60IL>S2|()xy^c)|;}pMH0<=$_aR2)G&;%OSkyE^DvzgbVo)$ zV*~hW9LGHx`Od*!F@C`mG$Wi&BWE00!RUb^)5EOf=IF9+)GIDg;kQ*`PmDjkbmHxm z|2eRuwN&>WZW^U+Gt3wo?py7_&ei^KAMW3vE(B{5urpyt$Pn$M)eNRM`bStWugU)j zY2j3N0Z#~~GO~n*`v73cC>9ns=SY@??I4$bh`8@lMeRjSxXj2=Ig7)O^LViT!tM&bVvc`?mE=rlS%p zv$&v$i9$NH}K(* zCR>;(v!+s*CMSDbWCdr0%Xg8|hg27;0#~G2@vu;a&E%1OJxh4>p~8n4FBOvH=hs!! z3nTetT^k2~t?+8$xM9>dQHZN+OfTB57)3K3X3d+XC9O5liTvlh8Fv|(BXq8eJzCl_ zu3o%i3NFpU(w9~=tgs`Zud|9)tu;MQeI0Q)=MilgG~hmgEE+7Iiw4W$LuOet=s!n9 zG{~9M=|4<_5L0;Rn7}VUzEY4;!h*##;0nKT;sn2nZ_FfDrH{Oc4z0vjtQk2wm47(qaj%`uGp^>jM-%yMiAqezT!+5_~Bb$ zJ%;7K#>`>*nlmk*wYs7kPr*!vixJwxkjPt=z^X}BFXigeY9a9(G%MwuYwPY?E9wUf9)7&Ph2dD3M9qv@&>%pPf5 z8+1$TQ^M4`)h-7SM=7K|B?Jl%;QlsTPVwj9oBS>u#m45F2#`r>m4BOH7P==y z6WcYvyeYPy?w5IX^4aP2Z|!(v$IXId)s~of-dXfY&()sTsh4}%xUnCllZH=4m%;T6 zjo<=1+&n;Cy$6>+`aK#4aA{$58Jzo~L>mJ^bk_mV0}BFe5A#4%XV?E>FGGk6a7*iF zhQiMbo>rS;8V(KfffjrhVFqSgXZ)4_l9*?w)rD@h_tKD}imq6VpuY&Rcx_6K^xKH)fOzZ=-)8 zb^k=?MEJJ580tu@|Fy!~&XQQe%ZHG-y$XrjizfPCF62`Juvvff!SkO1^!FV)akY^l z-`Qpnzb>cu0j6}PJ|<`j0S4UsAeWCBpQE$QBnLUqJL)&}5A+Xa3D)+Z(P1z0x&64= z&ji(w39tMSNz{jMp!YH9k$;L0teB+5l;n*;vvolxWz1OvJtlkzxx##uPtuAjuNO`h zPHma)P8PS(1z<%nGYq^_1-EQVwrzN4O+sZrmD2X$h^5C--4iW%q6K{tPJ>w;P5sU>sG92Wywv=ufCX0>MU7Adq) z3K{Wn)sPlHU!7%OBBy{p257@DQf@=a7zxrBc8$Scl(WkOL;Pvs+SA!nD+}+VL6IP@ zf`fww!|0(U+68e*_74x^Vyiw>sg-|Vd$S5vY%oOx27(gqEaFi_cHIusEW@OA^1g$2 z9qvAkqoyg#7W5yxsA69PCgx%VLdEirgaW&Fq6>E}y1aL)>!z(U<;iMq%yQ2rlvL9N zZ_^|17q_Qez)BSf70c)DM` z?RYyubEf?(-;6H3!G|p%8^3ON$Bbxrn0*#@8zWdCo5(T4!5sE=1S(c+Ka1e>6627J zDR$1SVHimL!(sX{N}-qd=RqXwQled19@y~Ttb4b4zHR-x2kw~+#odM!Sk$fFh@#6Y zVo*^?p=UP;y(GMZOC9O=7$yw3po{JXh9XPnZTX`~Fs7CoD6ipi41J48@|iBECEBF# z?IVRjz3qpl?;bz9KZsrb01?r(7?yKCZ4QH#L+6=X z3Mr7w$*F+Djx&HMDof;Qz@qJ+haGzAWD8?UlVHhRx+J9`fs16iW|}g}mFF(8O5}v| z$F$8!-6}$PLq^iH;akw^%C3vM>;(Kt%9JFA-7sdiuS-=5g%$UV2K%}N6MP?%j}46S z63WO8GdC_M$2uCng;(7Zz_wAyL<)K=;s?*2qA+Ft>8I6wNZdx3rePT{9wQo>LBmhR zg}*6uTh_hSbx*+So=0#Nzq0e{&MAAmVdKp+@2*JR$GnR~_<&5iGwE(Y?fOib5K+$> z-Mo(&Yoncbt_CD2wnniS?=mCk3=)cPW#=RBp8^Q715 z==RCyR%Oi2jd>=9rZM9HY4!2sISzme) z8~HK&q0DghjpYdtYXDk1_o$Oo{ERV-qimb-;*mwwj%1SWuOUM;Y)lodADKKdSKgE; zZ%URoPuS;+Yp%N{T~imBo;vR+jysmo^rz{~vRQW%jF?ka7@?Ol#iTW+qX*tEZXq3| z^{%bt71vc)?EEw?DsG-vzlNr9nPb}>M`>)sR1w{x)3R!=Wox2k>%_rWFyU;v?XI3G z`|7eA%cjF`U3ufm%|Oz?Xl>Eep-oVW}589 z6qgia+oyS2GHsoGo@8PlDg`1@DcDM5^{+iXYpus#f(hFlYY9G2&syuWtp&E}mHg7o zJB4NO^7e0;Z$9*U)QeBKQt$`6ewX?cFhpQr_(69#r4Ic34egaMN zJ_z+6XhI!kBF*IP{~tllX$fiBr2$%`3$j9Lv!K=@;|J^o^zI~y+|GrI-`Dfby$wNJ zST}+Paw|TS0-g#N-&KHQOKYJjt!Py;?S6iZMD-G4LsY8;n{%S`g-fqBJog1At3R|B zUW-oEzkZr*QR+q*U0Q!=cfPh{s`K?{XG>Ns3cTa0nlik8@XcrAOE=8AHr^?!idV1u zR@b{Fzjq)}y(3w)Gj7{C?{JRu%XspO_vh**Nm%pf6gk40AtZTB(d;6~U$~e2cD6v# z@fy7c`TT;Vcb9p(My)61SAqSU?(vtAD&7q;xslh9EHQ!7J3e`__&8MYp_0n$5rt;L z`MWx{ZAzDxJNB|z=WC<0cHRsAD4#&^u1>Ej2qn#4kb$regM+RPE`Q|Rxcf2h{@sfP zxjH=s6;ZeOrlHwm9&pI4mGflYU`^Kt=Ngk*&He%q%POu@Rie{6Hv8ctEP2A19QO2S z_U67mw)6sRjxP0AZ@~*=3o~8os|}`JmgK{kunjn!q~BqA4uhF0VW;SH(lGsMk{+97 zuz}s4=kenxQ*Z#QLDaE$NZ(tHX#mlLpll*oo^txvYG~sQ{Y(=KUf5&J?(EAbT!?Kk z^m>hk{-+>1yaY6j3)83Onl>exHYJ<3%r)&wH0^r# zQnKm5INvJ={lrVnkyC1>vXI@pD6R7#Q>?s8h_P51>chjyQiz zBphKRd|WKp9P^IysqU}#-snv@+U}GtgLSO-km2s~6<>Yo##0|!jJ2y51Y=oyN-(Y@OF1ik9K$1C(AAI0;0~JC&A1pm|CkP)$twa9H;Xo8e znvQlpcJiRFTmElU8)mw?OtG^WH9O71*Y~iyFalfC5bg-UT3#ef#t)@{-(<;tPfIc3 zni0iy4D_EJ3|->OR7Ly{EAGbdj^HQMQ$nW5{KJnWs(yAd(ZxX8 z2}hvulZtfPOA+^@lVPVEv7d^Csiza=LCSz^9g4jdJ9>EYyG+0_a@c7gI+nyw08J2L zAze9&bsjn(QiivBdWoe=>nMsl1IWl@2h+5ZEjpDYgqDU9u@zY$o#yQL8tGpqve-`h zDe}?Aa>dEbV{`-$b@?@d|5I|_B!{*5XPIg8TgnPVzVI!|uO; z^DV*1dTJ-QRTuU!5Qg%yEvxLFLV~fKqx|FvJF>xB)i}xCb0mA#z0}MO9+UqKW&H2S z`BQSfPYyOf2=dE>`)&GUTQzC(BimWXHtq5CnHLF#wnec`Y;02wUm*Kiz?8B_PjntX z-hHC4^W@2c2YQco_ntbbxHaIz$GbXDb)RGl3fMNxmUr}Z7+Ob=$u!5N_iR4LG-aml zus&3lsT5=!<(J6Pp;(Ri%<{4Wv6UtI<^DKp>&FFQY#$g20t_o;1Z4Ns%J--U-yxc9 z+L3mpfL57;V$Ojn3_C-t8`vdZMh1w2Q}gIDUV9e*LL{BxoB2lU_l1EKH- zg7dCx^LXKWQRTP;SGrmY=L#wl1=!u3D5#lwC{a*5ZkjK!=K%uKT9vRuho7pCTbE52 zB&;jP%^#SsQ=l@oar_7@IkB$sqxiw0Skw67`QozigIN6?KYX{SS0HePFWw7xS9CRZHXM z@{bCPhN_PWO@`(7oJEGpSmiwduX`&>4HdDrdjekf+MI@^v8K7w6^YUn_XK?0tF1J& z#eDY!yzZ?(U@*9*Hs2HI{ULrS)Kx!SopiR1+d+?^G`0%#7)n#l{e}wTZF6aC$FyVS z)XnWlGY(=C>;u5IPCY);b~Er^b<%t&Wg+N?1%jn4)-kA3t}RnmMg zRl(qu1m8V<^gE5;-0{8c_{qnU<|k5BEU21-h{VH5^VU=igDoLg$8__|mYXQd&eT!{ zT}IIDQ_-1?N%Pv&at5o_U>!t69fNtYVD${Pf?zwRm(5(Ef;BK$Bf%)=L+{$&YbGW) zG5AV?XECUm!CMHP#r#$VZxbxVvBD`-M_XzYgRCY<(R5MLye8GoAYMS?#r4x2?}g_M zJeoN0X#8>itponV`hD?%NYXr#TEo!RQbhX{NElIHf*1_s+mu)?YC zY2bNNn;2{}!Q9ie@9mrGI+f@;6@T=}TU}3nvo790m^2TiwlJivK#CW8rdP$+>`t2Z zq_#2Wc8XdwZJY5D4|g!wPL^D}e%(zV?n`wr;4T8Xrp9KTOqzG3b~D%>0|$=Iv{U_c z8W?mhK~dg#!-n{#{YmqI)IJ{2#RFEv8#l$bK$s4tx_Q8U9HrVu z;Q_7jRr})IPbJNLse?S=(4ssJ^ME5fz!P7w{w6AAZ|W$ALor}Hs=EnN_oR+-C@wJ} zQbEz?cU?*I{?tPp4&4CQ_Ni^t=cpP_a_A`rwN62{>r)SN*dr?D=A?N=>QN4ZD#e(} zMBp@s`Bc2E)2AuL$2s%~6^i<8NGdOb;c^8&d-udM+Cp;83jd5iJeVPsTT*G4`Y` za5z*Omd2$SaBXvHh(n?45H_lD>wNLb1rvU}EfwNHa-N_t4}w*S#UlFAn;cDD;&5n6 zjEkyhj&dkYsS|eNbTGd8P||!j^(=>vad=C-ZM&ZL6&|$5s3sI&wI|`(^ByGqp;V`l z%WA%`eLSp-h1sTBru!00Hr_n za_Aurjn{9w`9*3IhZ#67l%$Ru1+(>~ozLxzZMkJyGH4TJ zCK|WCZ`+2QQiknF!(zYdSvT&O6_$U%^0}NSZ$?(*mU+QGCsZVaikLL@=&aCm598oo z!}Q^M0=+R{vL3K)CJ3RVVXI?0?Wdl3SJJ$l4`+ol5X2q1{%up|SuaEIO#Dp$&gmsH zXy-c#C)2-Ws%IMcZsPE2J+Ez3=VpqM<}C!@HN91f8!u~`zI?Oxy_)zD>NO~IhuX*G zrm%hL@=PsyuLt4mo<4LFx$GvK%u;9iGpW_^QyZ47Fvf-2)Mml83Oi#AJ6X-eoj4xy zjcsplyD7epz7)FG&bwyY-Sx-g!tz;R&0Vb?5|tZn_QZFeN^CrptbBOBvMs)P4|brS zGVa+HSIzdRQJuXzrtKPw;$^KfTW^93UAW(cQ&aelKuwon`T_|`mmyWy*vQnHZBv1G zD|)u=DH9-2YVh-C)2HKW_mJ9Q0f=ifyQa6ry}Q8Ol$Bsin?Y5^+cB!|O4$jIcL%|sl9WxNU8B!uItjr@C1Ke-rm8ue1_F~#LdDU;deMnm3o z^IW3yvBc)bl9i`#SFTQYyQm@WH++JI+-;bCmYPmC?_(#?rzKjb-JrW6k`wLJI_M)S z1k6aRVhV!Y(gf=2@tX=RFA=v}B@Uz#|zg@XDvHl2U+>4AI$Z$%U ztMw*oz4rwA!jib5kdIG^%J!La@75)}J;}<0w<{Yd(#i#JvTdQzX4s83Yqs7lSvr1* zIUkhQk00fq6%FIPx6A9FJNiKhethCKIUkg-pwMObtZ1ZAe5MM_h8pZ>##|8NrLB70 zOpxOS{Ep)|O&rbE1*5@Ig@P~j%q?k4ENP3ItLTEZa)62}pX(ui-2#5rVmmqOKEaP+ zw8tE7CSdr*_x;vc zIa#uH{LtOvrkHK6xG7QG^u|E4*!$c;Dzt}EUH+XSaAxiGLipTf= zz+5u#UN&*@l`B`T+&G2P_jB&%gu5BH>)G&g)GMfrbTDyxUDDkIU`fqfNqwTEe*DmU zaryYcADCTq$rrA2Kv+>RZL-HjeYV2e)u`@@dCk6Y!;r8px#7QMt-HN^9Zoghu3A0e zyuD=oRrd$Wacd908|l04s+$;8vVdPl=`vt*|M-6V^3pgHl_kWhrFV<#WA?e?`UGZ* zt#5hX@ZM}l7H=jx%I0h8=W5y#HORPayl3JPC*gKYd)!=kyR2pW$n8q+_%UKn34X$F zR;bJHB5gwlay9HCXDc~77_)9;gKzis-pSrK_9vaI#=Ac;;}_6Bt}e7}pz*EnL&4%O z-xDkrOR5;GoimjsOl7gXv4`TOsvC{BOtrVoc82pY;VcwE`jKp5Nvz^}?PTp6RWprA z`dhx-qSkg*>=mb?ViPjwzy2FYniLve5-czT_w!WXu^)bV`BpcQ0Y5f=(t_wnJ#;4`PY^wtJZuZ*es=29oP=M6&j7JBv$>U-Z^JO z!r2gS?npX2=8LOoClgFX#jUW1U3Y!iHRZ>Q9VZ=9C5W0T73_r*Tki^{mt4=g=7jQF zLV4`;`$FBPse{XfV(j!b+FL)UtYKEIFC9o(@cGl!9=BjCL6D*56LeZNm{AyNeu^sP zz~csj9ybv9IDRRPE`<8-PS?l=;YTZs7p=mNnvEB$gpW74E}BiBm<;4v?H9{UpOhKM Pt+HQiG=0)wfcyUeDBED* diff --git a/venv/lib/python3.12/site-packages/pip/_vendor/__pycache__/typing_extensions.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_vendor/__pycache__/typing_extensions.cpython-312.pyc deleted file mode 100644 index 14de116b0683515d8c52200c8f1735c6bf0f3517..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 122060 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 diff --git a/venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/__pycache__/_cmd.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/__pycache__/_cmd.cpython-312.pyc deleted file mode 100644 index 7aef28a32d3977393e3cb74834203c1c8a3b9602..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2657 zcmaJ@O>7fK6rS~t?Ty!V9FjmN2^gG0e26UyY7uSIrZFTyFj0X@wJNQ)-mSf6y>@5U zsca>Zk*J{J0F^3*Ll5DEDmc(fd+n)G)eCNdoURh773I)dq|ghezM0*P4GkT6XWqPd z^Y-og-j9EcL_!G0a_W}$O8}uKbmI-5LvUL^0I`G=q;NVab2*Nqv`_cte6aF5U&cAi zcv$zB1GxaB{d%x0DdIJp>r?uaFs!?jT}lMje&9!89Z(0A-Ya7W5y6Mlf%~rY9IE^3zGVO3bf4sG zQ8tWFtf0aPLe{ctQyvwOiYykCvxfIxl_{A%&Dn!XR_145QzGDO*JhO=>91= zUsR_mhD9p+q#{=>cBdz!gnj>bB;Fq;gJ z9^l)8samt@ysFzl`o)@2u>F}+A6%ZcBNr{A%H ziR5M-Gs%Z(tlnP1bDNcC@r?iwWE2(PTj)29rs^nTr2Ec&b@R%u>nrIz| zu3xx%;hX8D^IxA|#fR3TgY9Ud6-}%}UvEysX&Vo=@ZjyjW4wP0ZlD(sq)0FXe+Hr( zL5pI`hUamGgBV8-eD_@(0f7!uJ0a@cU*s0J5_SDcL*W4jkye%?cN~$FnOgjWgqRG0}09<>DYK>^7rR5vJqGeT2rqd095++c|APIt< zghn2rYVF`f)ifdRY=5~@Gb}sg!b3wO=DefBN&4)d?Bth?O}J>%4~)l2KUF0bR7;{< zP)Fjx8HUIF2qu6rdT?FnyD2UYJRJRL^cnB#4K$~p1yFdPE$(ZH`&Pt}W@Zfw*Uw%( zd!v5m2q5k48h74W#fd+L6Yb$tYdF=+tm3_EVsG;t83ffYz)hiJaDM_sH{2e`i;y^_ zZRkPB9RR-X0pA4|Ds6-B$spuu0T6K3=4(W63|%U!@yj31#;r=+BK0_AQJi@Vataq! zy_)0+waN}dx=FHI*6dJ~7B;%4^((-3#K}F!mjd-AJtjxsHWW}~j>80wjO<&9j5JTL z(a7J^!h7!cAB|2t!h2Tnduw7}TO4kQ!z<$cM|l7L_-6vrd}sgsH!)a%@8AvaQ4-+7#;I`?~o_KHCUR(R!vFY(%mZ%Yj{qpBzhy3^bMkHV;6OL!g)yHZlT~ z9d+`GKo^3Br`kccm)Sg#zi>|#$z%GfL^G@;wlRx`15^X1cbPJiMpqn$6F0alYX&(A zJX$`@I!q8VV*kyP&CI&E`{ujN%qC=A?AD2|PTbBc&3rw>G7mD*zw6qCO#$^p+QLXn z7}?~Je-K3dgKeB>;ly(0-t67khoe7^eLuE}--Z)ms2x1q3Lajz?k(J1SPdRu7a}*b z$HLHGuvQ)mPW;(|BvG3r35rL6K&dB&jk6U)P5Q_&Fs~8wI(f=1MeYHik&@hPha~B< z8eCH)iO|#~G$w2ToZ+MmORs=cuR^aQG)`?1dQQsiIZl;}cX3k8`)*N7x#f(NMSK4% z#n>HIHtoc#g`Ca?rIYny_5nnsCexzu%c&A)ZYPvc> zCP0XGV{;CsO`hYpe+0xOo}lOkN^GF`Q~G;<10CN$Z~n>0Ht?aRcxo%aa|gD@n2uuO>h7J diff --git a/venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/__pycache__/adapter.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/__pycache__/adapter.cpython-312.pyc deleted file mode 100644 index 55ae30287bb02c368e797e8af03a065006f4ea17..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6475 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 vBhUVeTzW(r_(vJFG%CJ71z=z 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 diff --git a/venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/__pycache__/filewrapper.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/__pycache__/filewrapper.cpython-312.pyc deleted file mode 100644 index 73ac8df0f45d4fc71a251844c092a44d8729f355..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4358 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 aMmqT6d#_-7cyDBy@45HN*BrdqI{pXVVFKv@ diff --git a/venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/__pycache__/serialize.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/__pycache__/serialize.cpython-312.pyc deleted file mode 100644 index 64040924d430d96accadb387bad042293928419d..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6416 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 CXnbD) diff --git a/venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/__pycache__/wrapper.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/__pycache__/wrapper.cpython-312.pyc deleted file mode 100644 index a15e2264b8f462b75e960d395c22427ed4302afa..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1685 zcmaJ>&2QsG6rYJ5$8qZBqoLbv%Wk$UECw0_TcE61M9EgW-HK?X?gdvUa^s;f>n~=U zLL*lS5)vS-#IY48j-Ybl-{6LNFqSGULMz10QkP3l%s3xSfih9XzxUp6p5MF=|18TA zpzFKpH|E!A0Dfn}U~xSFPky3c9~i)Z7OxSiMX3C>ytyQmc*$e#NdW9Q}nk__3% zeUa8myOJ{gC%b?Gqnz$IuCM#1>kuUs$qzobzuKtXU9GLJ)$c@7&9yAlWLCUTdqMmnU?Q+H&wMGGC(L&IGmxOVitXrw%xYl zE7^!Ah&o6o4)8d$=h;?ZTahtky;rQ>t8j_wGJPG%QmHanr?%R1ZKPt|FdfgtZo8x2 zM&zOIdg=<^(VfMW`)i9e%T#xev!hz(mg?=&Xq_9?S6@?!>7zwYZ$8ww5m7zUQyY|K zxL8eM>)%=Z6ziUcaMjz5#%d!ig)h@k%Jfe*>DC2t8O&Zgxb+gDKbM*4G6FwYJCK;vjFG_#phBQ{k&g9vMZW4d! zBN8z3+t|S~l%z~VQls%vn<`MFf!W6^5~zFA*~UB-Fq?p=LJL;y7pyv3uxh_mdTn>* zLRxYrY0xM)Lc(l%F>AAEenfr#6=(B+*;n^}n8P6=ILDZC7y3LKy)hO6>#iRFo@RK8 zZl~hgwrjL4^bWpGMfN=*`*e#r2;pBMfb)NVm!E)lkHOM!T;Z5sc)~9q^R;7s<(R(} zOW^8!I5itCybwPBV)*)7;Tt!@SC-=9C0Gch>6oL>$GMp}O`ovvLs+#zUOF)=>Ize?w;C};VTG8VG diff --git a/venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/_cmd.py b/venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/_cmd.py deleted file mode 100644 index 2c84208..0000000 --- a/venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/_cmd.py +++ /dev/null @@ -1,70 +0,0 @@ -# SPDX-FileCopyrightText: 2015 Eric Larson -# -# SPDX-License-Identifier: Apache-2.0 -from __future__ import annotations - -import logging -from argparse import ArgumentParser -from typing import TYPE_CHECKING - -from pip._vendor import requests - -from pip._vendor.cachecontrol.adapter import CacheControlAdapter -from pip._vendor.cachecontrol.cache import DictCache -from pip._vendor.cachecontrol.controller import logger - -if TYPE_CHECKING: - from argparse import Namespace - - from pip._vendor.cachecontrol.controller import CacheController - - -def setup_logging() -> None: - logger.setLevel(logging.DEBUG) - handler = logging.StreamHandler() - logger.addHandler(handler) - - -def get_session() -> requests.Session: - adapter = CacheControlAdapter( - DictCache(), cache_etags=True, serializer=None, heuristic=None - ) - sess = requests.Session() - sess.mount("http://", adapter) - sess.mount("https://", adapter) - - sess.cache_controller = adapter.controller # type: ignore[attr-defined] - return sess - - -def get_args() -> Namespace: - parser = ArgumentParser() - parser.add_argument("url", help="The URL to try and cache") - return parser.parse_args() - - -def main() -> None: - args = get_args() - sess = get_session() - - # Make a request to get a response - resp = sess.get(args.url) - - # Turn on logging - setup_logging() - - # try setting the cache - cache_controller: CacheController = ( - sess.cache_controller # type: ignore[attr-defined] - ) - cache_controller.cache_response(resp.request, resp.raw) - - # Now try to get it - if cache_controller.cached_request(resp.request): - print("Cached!") - else: - print("Not cached :(") - - -if __name__ == "__main__": - main() diff --git a/venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/adapter.py b/venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/adapter.py deleted file mode 100644 index 3e83e30..0000000 --- a/venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/adapter.py +++ /dev/null @@ -1,161 +0,0 @@ -# SPDX-FileCopyrightText: 2015 Eric Larson -# -# SPDX-License-Identifier: Apache-2.0 -from __future__ import annotations - -import functools -import types -import zlib -from typing import TYPE_CHECKING, Any, Collection, Mapping - -from pip._vendor.requests.adapters import HTTPAdapter - -from pip._vendor.cachecontrol.cache import DictCache -from pip._vendor.cachecontrol.controller import PERMANENT_REDIRECT_STATUSES, CacheController -from pip._vendor.cachecontrol.filewrapper import CallbackFileWrapper - -if TYPE_CHECKING: - from pip._vendor.requests import PreparedRequest, Response - from pip._vendor.urllib3 import HTTPResponse - - from pip._vendor.cachecontrol.cache import BaseCache - from pip._vendor.cachecontrol.heuristics import BaseHeuristic - from pip._vendor.cachecontrol.serialize import Serializer - - -class CacheControlAdapter(HTTPAdapter): - invalidating_methods = {"PUT", "PATCH", "DELETE"} - - def __init__( - self, - cache: BaseCache | None = None, - cache_etags: bool = True, - controller_class: type[CacheController] | None = None, - serializer: Serializer | None = None, - heuristic: BaseHeuristic | None = None, - cacheable_methods: Collection[str] | None = None, - *args: Any, - **kw: Any, - ) -> None: - super().__init__(*args, **kw) - self.cache = DictCache() if cache is None else cache - self.heuristic = heuristic - self.cacheable_methods = cacheable_methods or ("GET",) - - controller_factory = controller_class or CacheController - self.controller = controller_factory( - self.cache, cache_etags=cache_etags, serializer=serializer - ) - - def send( - self, - request: PreparedRequest, - stream: bool = False, - timeout: None | float | tuple[float, float] | tuple[float, None] = None, - verify: bool | str = True, - cert: (None | bytes | str | tuple[bytes | str, bytes | str]) = None, - proxies: Mapping[str, str] | None = None, - cacheable_methods: Collection[str] | None = None, - ) -> Response: - """ - Send a request. Use the request information to see if it - exists in the cache and cache the response if we need to and can. - """ - cacheable = cacheable_methods or self.cacheable_methods - if request.method in cacheable: - try: - cached_response = self.controller.cached_request(request) - except zlib.error: - cached_response = None - if cached_response: - return self.build_response(request, cached_response, from_cache=True) - - # check for etags and add headers if appropriate - request.headers.update(self.controller.conditional_headers(request)) - - resp = super().send(request, stream, timeout, verify, cert, proxies) - - return resp - - def build_response( - self, - request: PreparedRequest, - response: HTTPResponse, - from_cache: bool = False, - cacheable_methods: Collection[str] | None = None, - ) -> Response: - """ - Build a response by making a request or using the cache. - - This will end up calling send and returning a potentially - cached response - """ - cacheable = cacheable_methods or self.cacheable_methods - if not from_cache and request.method in cacheable: - # Check for any heuristics that might update headers - # before trying to cache. - if self.heuristic: - response = self.heuristic.apply(response) - - # apply any expiration heuristics - if response.status == 304: - # We must have sent an ETag request. This could mean - # that we've been expired already or that we simply - # have an etag. In either case, we want to try and - # update the cache if that is the case. - cached_response = self.controller.update_cached_response( - request, response - ) - - if cached_response is not response: - from_cache = True - - # We are done with the server response, read a - # possible response body (compliant servers will - # not return one, but we cannot be 100% sure) and - # release the connection back to the pool. - response.read(decode_content=False) - response.release_conn() - - response = cached_response - - # We always cache the 301 responses - elif int(response.status) in PERMANENT_REDIRECT_STATUSES: - self.controller.cache_response(request, response) - else: - # Wrap the response file with a wrapper that will cache the - # response when the stream has been consumed. - response._fp = CallbackFileWrapper( # type: ignore[attr-defined] - response._fp, # type: ignore[attr-defined] - functools.partial( - self.controller.cache_response, request, response - ), - ) - if response.chunked: - super_update_chunk_length = response._update_chunk_length # type: ignore[attr-defined] - - def _update_chunk_length(self: HTTPResponse) -> None: - super_update_chunk_length() - if self.chunk_left == 0: - self._fp._close() # type: ignore[attr-defined] - - response._update_chunk_length = types.MethodType( # type: ignore[attr-defined] - _update_chunk_length, response - ) - - resp: Response = super().build_response(request, response) # type: ignore[no-untyped-call] - - # See if we should invalidate the cache. - if request.method in self.invalidating_methods and resp.ok: - assert request.url is not None - cache_url = self.controller.cache_url(request.url) - self.cache.delete(cache_url) - - # Give the request a from_cache attr to let people use it - resp.from_cache = from_cache # type: ignore[attr-defined] - - return resp - - def close(self) -> None: - self.cache.close() - super().close() # type: ignore[no-untyped-call] diff --git a/venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/cache.py b/venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/cache.py deleted file mode 100644 index 3293b00..0000000 --- a/venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/cache.py +++ /dev/null @@ -1,74 +0,0 @@ -# SPDX-FileCopyrightText: 2015 Eric Larson -# -# SPDX-License-Identifier: Apache-2.0 - -""" -The cache object API for implementing caches. The default is a thread -safe in-memory dictionary. -""" -from __future__ import annotations - -from threading import Lock -from typing import IO, TYPE_CHECKING, MutableMapping - -if TYPE_CHECKING: - from datetime import datetime - - -class BaseCache: - def get(self, key: str) -> bytes | None: - raise NotImplementedError() - - def set( - self, key: str, value: bytes, expires: int | datetime | None = None - ) -> None: - raise NotImplementedError() - - def delete(self, key: str) -> None: - raise NotImplementedError() - - def close(self) -> None: - pass - - -class DictCache(BaseCache): - def __init__(self, init_dict: MutableMapping[str, bytes] | None = None) -> None: - self.lock = Lock() - self.data = init_dict or {} - - def get(self, key: str) -> bytes | None: - return self.data.get(key, None) - - def set( - self, key: str, value: bytes, expires: int | datetime | None = None - ) -> None: - with self.lock: - self.data.update({key: value}) - - def delete(self, key: str) -> None: - with self.lock: - if key in self.data: - self.data.pop(key) - - -class SeparateBodyBaseCache(BaseCache): - """ - In this variant, the body is not stored mixed in with the metadata, but is - passed in (as a bytes-like object) in a separate call to ``set_body()``. - - That is, the expected interaction pattern is:: - - cache.set(key, serialized_metadata) - cache.set_body(key) - - Similarly, the body should be loaded separately via ``get_body()``. - """ - - def set_body(self, key: str, body: bytes) -> None: - raise NotImplementedError() - - def get_body(self, key: str) -> IO[bytes] | None: - """ - Return the body as file-like object. - """ - raise NotImplementedError() diff --git a/venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/caches/__init__.py b/venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/caches/__init__.py deleted file mode 100644 index 24ff469..0000000 --- a/venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/caches/__init__.py +++ /dev/null @@ -1,8 +0,0 @@ -# SPDX-FileCopyrightText: 2015 Eric Larson -# -# SPDX-License-Identifier: Apache-2.0 - -from pip._vendor.cachecontrol.caches.file_cache import FileCache, SeparateBodyFileCache -from pip._vendor.cachecontrol.caches.redis_cache import RedisCache - -__all__ = ["FileCache", "SeparateBodyFileCache", "RedisCache"] diff --git a/venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/caches/__pycache__/__init__.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/caches/__pycache__/__init__.cpython-312.pyc deleted file mode 100644 index 5f4920c433ac07cc3b4d2af87a7c932f9f574ae3..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 446 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 IO[bytes]: - # We only want to write to this file, so open it in write only mode - flags = os.O_WRONLY - - # os.O_CREAT | os.O_EXCL will fail if the file already exists, so we only - # will open *new* files. - # We specify this because we want to ensure that the mode we pass is the - # mode of the file. - flags |= os.O_CREAT | os.O_EXCL - - # Do not follow symlinks to prevent someone from making a symlink that - # we follow and insecurely open a cache file. - if hasattr(os, "O_NOFOLLOW"): - flags |= os.O_NOFOLLOW - - # On Windows we'll mark this file as binary - if hasattr(os, "O_BINARY"): - flags |= os.O_BINARY - - # Before we open our file, we want to delete any existing file that is - # there - try: - os.remove(filename) - except OSError: - # The file must not exist already, so we can just skip ahead to opening - pass - - # Open our file, the use of os.O_CREAT | os.O_EXCL will ensure that if a - # race condition happens between the os.remove and this line, that an - # error will be raised. Because we utilize a lockfile this should only - # happen if someone is attempting to attack us. - fd = os.open(filename, flags, fmode) - try: - return os.fdopen(fd, "wb") - - except: - # An error occurred wrapping our FD in a file object - os.close(fd) - raise - - -class _FileCacheMixin: - """Shared implementation for both FileCache variants.""" - - def __init__( - self, - directory: str, - forever: bool = False, - filemode: int = 0o0600, - dirmode: int = 0o0700, - lock_class: type[BaseFileLock] | None = None, - ) -> None: - try: - if lock_class is None: - from filelock import FileLock - - lock_class = FileLock - except ImportError: - notice = dedent( - """ - NOTE: In order to use the FileCache you must have - filelock installed. You can install it via pip: - pip install filelock - """ - ) - raise ImportError(notice) - - self.directory = directory - self.forever = forever - self.filemode = filemode - self.dirmode = dirmode - self.lock_class = lock_class - - @staticmethod - def encode(x: str) -> str: - return hashlib.sha224(x.encode()).hexdigest() - - def _fn(self, name: str) -> str: - # NOTE: This method should not change as some may depend on it. - # See: https://github.com/ionrock/cachecontrol/issues/63 - hashed = self.encode(name) - parts = list(hashed[:5]) + [hashed] - return os.path.join(self.directory, *parts) - - def get(self, key: str) -> bytes | None: - name = self._fn(key) - try: - with open(name, "rb") as fh: - return fh.read() - - except FileNotFoundError: - return None - - def set( - self, key: str, value: bytes, expires: int | datetime | None = None - ) -> None: - name = self._fn(key) - self._write(name, value) - - def _write(self, path: str, data: bytes) -> None: - """ - Safely write the data to the given path. - """ - # Make sure the directory exists - try: - os.makedirs(os.path.dirname(path), self.dirmode) - except OSError: - pass - - with self.lock_class(path + ".lock"): - # Write our actual file - with _secure_open_write(path, self.filemode) as fh: - fh.write(data) - - def _delete(self, key: str, suffix: str) -> None: - name = self._fn(key) + suffix - if not self.forever: - try: - os.remove(name) - except FileNotFoundError: - pass - - -class FileCache(_FileCacheMixin, BaseCache): - """ - Traditional FileCache: body is stored in memory, so not suitable for large - downloads. - """ - - def delete(self, key: str) -> None: - self._delete(key, "") - - -class SeparateBodyFileCache(_FileCacheMixin, SeparateBodyBaseCache): - """ - Memory-efficient FileCache: body is stored in a separate file, reducing - peak memory usage. - """ - - def get_body(self, key: str) -> IO[bytes] | None: - name = self._fn(key) + ".body" - try: - return open(name, "rb") - except FileNotFoundError: - return None - - def set_body(self, key: str, body: bytes) -> None: - name = self._fn(key) + ".body" - self._write(name, body) - - def delete(self, key: str) -> None: - self._delete(key, "") - self._delete(key, ".body") - - -def url_to_file_path(url: str, filecache: FileCache) -> str: - """Return the file cache path based on the URL. - - This does not ensure the file exists! - """ - key = CacheController.cache_url(url) - return filecache._fn(key) diff --git a/venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/caches/redis_cache.py b/venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/caches/redis_cache.py deleted file mode 100644 index f4f68c4..0000000 --- a/venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/caches/redis_cache.py +++ /dev/null @@ -1,48 +0,0 @@ -# SPDX-FileCopyrightText: 2015 Eric Larson -# -# SPDX-License-Identifier: Apache-2.0 -from __future__ import annotations - - -from datetime import datetime, timezone -from typing import TYPE_CHECKING - -from pip._vendor.cachecontrol.cache import BaseCache - -if TYPE_CHECKING: - from redis import Redis - - -class RedisCache(BaseCache): - def __init__(self, conn: Redis[bytes]) -> None: - self.conn = conn - - def get(self, key: str) -> bytes | None: - return self.conn.get(key) - - def set( - self, key: str, value: bytes, expires: int | datetime | None = None - ) -> None: - if not expires: - self.conn.set(key, value) - elif isinstance(expires, datetime): - now_utc = datetime.now(timezone.utc) - if expires.tzinfo is None: - now_utc = now_utc.replace(tzinfo=None) - delta = expires - now_utc - self.conn.setex(key, int(delta.total_seconds()), value) - else: - self.conn.setex(key, expires, value) - - def delete(self, key: str) -> None: - self.conn.delete(key) - - def clear(self) -> None: - """Helper for clearing all the keys in a database. Use with - caution!""" - for key in self.conn.keys(): - self.conn.delete(key) - - def close(self) -> None: - """Redis uses connection pooling, no need to close the connection.""" - pass diff --git a/venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/controller.py b/venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/controller.py deleted file mode 100644 index 586b9f9..0000000 --- a/venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/controller.py +++ /dev/null @@ -1,494 +0,0 @@ -# SPDX-FileCopyrightText: 2015 Eric Larson -# -# SPDX-License-Identifier: Apache-2.0 - -""" -The httplib2 algorithms ported for use with requests. -""" -from __future__ import annotations - -import calendar -import logging -import re -import time -from email.utils import parsedate_tz -from typing import TYPE_CHECKING, Collection, Mapping - -from pip._vendor.requests.structures import CaseInsensitiveDict - -from pip._vendor.cachecontrol.cache import DictCache, SeparateBodyBaseCache -from pip._vendor.cachecontrol.serialize import Serializer - -if TYPE_CHECKING: - from typing import Literal - - from pip._vendor.requests import PreparedRequest - from pip._vendor.urllib3 import HTTPResponse - - from pip._vendor.cachecontrol.cache import BaseCache - -logger = logging.getLogger(__name__) - -URI = re.compile(r"^(([^:/?#]+):)?(//([^/?#]*))?([^?#]*)(\?([^#]*))?(#(.*))?") - -PERMANENT_REDIRECT_STATUSES = (301, 308) - - -def parse_uri(uri: str) -> tuple[str, str, str, str, str]: - """Parses a URI using the regex given in Appendix B of RFC 3986. - - (scheme, authority, path, query, fragment) = parse_uri(uri) - """ - match = URI.match(uri) - assert match is not None - groups = match.groups() - return (groups[1], groups[3], groups[4], groups[6], groups[8]) - - -class CacheController: - """An interface to see if request should cached or not.""" - - def __init__( - self, - cache: BaseCache | None = None, - cache_etags: bool = True, - serializer: Serializer | None = None, - status_codes: Collection[int] | None = None, - ): - self.cache = DictCache() if cache is None else cache - self.cache_etags = cache_etags - self.serializer = serializer or Serializer() - self.cacheable_status_codes = status_codes or (200, 203, 300, 301, 308) - - @classmethod - def _urlnorm(cls, uri: str) -> str: - """Normalize the URL to create a safe key for the cache""" - (scheme, authority, path, query, fragment) = parse_uri(uri) - if not scheme or not authority: - raise Exception("Only absolute URIs are allowed. uri = %s" % uri) - - scheme = scheme.lower() - authority = authority.lower() - - if not path: - path = "/" - - # Could do syntax based normalization of the URI before - # computing the digest. See Section 6.2.2 of Std 66. - request_uri = query and "?".join([path, query]) or path - defrag_uri = scheme + "://" + authority + request_uri - - return defrag_uri - - @classmethod - def cache_url(cls, uri: str) -> str: - return cls._urlnorm(uri) - - def parse_cache_control(self, headers: Mapping[str, str]) -> dict[str, int | None]: - known_directives = { - # https://tools.ietf.org/html/rfc7234#section-5.2 - "max-age": (int, True), - "max-stale": (int, False), - "min-fresh": (int, True), - "no-cache": (None, False), - "no-store": (None, False), - "no-transform": (None, False), - "only-if-cached": (None, False), - "must-revalidate": (None, False), - "public": (None, False), - "private": (None, False), - "proxy-revalidate": (None, False), - "s-maxage": (int, True), - } - - cc_headers = headers.get("cache-control", headers.get("Cache-Control", "")) - - retval: dict[str, int | None] = {} - - for cc_directive in cc_headers.split(","): - if not cc_directive.strip(): - continue - - parts = cc_directive.split("=", 1) - directive = parts[0].strip() - - try: - typ, required = known_directives[directive] - except KeyError: - logger.debug("Ignoring unknown cache-control directive: %s", directive) - continue - - if not typ or not required: - retval[directive] = None - if typ: - try: - retval[directive] = typ(parts[1].strip()) - except IndexError: - if required: - logger.debug( - "Missing value for cache-control " "directive: %s", - directive, - ) - except ValueError: - logger.debug( - "Invalid value for cache-control directive " "%s, must be %s", - directive, - typ.__name__, - ) - - return retval - - def _load_from_cache(self, request: PreparedRequest) -> HTTPResponse | None: - """ - Load a cached response, or return None if it's not available. - """ - cache_url = request.url - assert cache_url is not None - cache_data = self.cache.get(cache_url) - if cache_data is None: - logger.debug("No cache entry available") - return None - - if isinstance(self.cache, SeparateBodyBaseCache): - body_file = self.cache.get_body(cache_url) - else: - body_file = None - - result = self.serializer.loads(request, cache_data, body_file) - if result is None: - logger.warning("Cache entry deserialization failed, entry ignored") - return result - - def cached_request(self, request: PreparedRequest) -> HTTPResponse | Literal[False]: - """ - Return a cached response if it exists in the cache, otherwise - return False. - """ - assert request.url is not None - cache_url = self.cache_url(request.url) - logger.debug('Looking up "%s" in the cache', cache_url) - cc = self.parse_cache_control(request.headers) - - # Bail out if the request insists on fresh data - if "no-cache" in cc: - logger.debug('Request header has "no-cache", cache bypassed') - return False - - if "max-age" in cc and cc["max-age"] == 0: - logger.debug('Request header has "max_age" as 0, cache bypassed') - return False - - # Check whether we can load the response from the cache: - resp = self._load_from_cache(request) - if not resp: - return False - - # If we have a cached permanent redirect, return it immediately. We - # don't need to test our response for other headers b/c it is - # intrinsically "cacheable" as it is Permanent. - # - # See: - # https://tools.ietf.org/html/rfc7231#section-6.4.2 - # - # Client can try to refresh the value by repeating the request - # with cache busting headers as usual (ie no-cache). - if int(resp.status) in PERMANENT_REDIRECT_STATUSES: - msg = ( - "Returning cached permanent redirect response " - "(ignoring date and etag information)" - ) - logger.debug(msg) - return resp - - headers: CaseInsensitiveDict[str] = CaseInsensitiveDict(resp.headers) - if not headers or "date" not in headers: - if "etag" not in headers: - # Without date or etag, the cached response can never be used - # and should be deleted. - logger.debug("Purging cached response: no date or etag") - self.cache.delete(cache_url) - logger.debug("Ignoring cached response: no date") - return False - - now = time.time() - time_tuple = parsedate_tz(headers["date"]) - assert time_tuple is not None - date = calendar.timegm(time_tuple[:6]) - current_age = max(0, now - date) - logger.debug("Current age based on date: %i", current_age) - - # TODO: There is an assumption that the result will be a - # urllib3 response object. This may not be best since we - # could probably avoid instantiating or constructing the - # response until we know we need it. - resp_cc = self.parse_cache_control(headers) - - # determine freshness - freshness_lifetime = 0 - - # Check the max-age pragma in the cache control header - max_age = resp_cc.get("max-age") - if max_age is not None: - freshness_lifetime = max_age - logger.debug("Freshness lifetime from max-age: %i", freshness_lifetime) - - # If there isn't a max-age, check for an expires header - elif "expires" in headers: - expires = parsedate_tz(headers["expires"]) - if expires is not None: - expire_time = calendar.timegm(expires[:6]) - date - freshness_lifetime = max(0, expire_time) - logger.debug("Freshness lifetime from expires: %i", freshness_lifetime) - - # Determine if we are setting freshness limit in the - # request. Note, this overrides what was in the response. - max_age = cc.get("max-age") - if max_age is not None: - freshness_lifetime = max_age - logger.debug( - "Freshness lifetime from request max-age: %i", freshness_lifetime - ) - - min_fresh = cc.get("min-fresh") - if min_fresh is not None: - # adjust our current age by our min fresh - current_age += min_fresh - logger.debug("Adjusted current age from min-fresh: %i", current_age) - - # Return entry if it is fresh enough - if freshness_lifetime > current_age: - logger.debug('The response is "fresh", returning cached response') - logger.debug("%i > %i", freshness_lifetime, current_age) - return resp - - # we're not fresh. If we don't have an Etag, clear it out - if "etag" not in headers: - logger.debug('The cached response is "stale" with no etag, purging') - self.cache.delete(cache_url) - - # return the original handler - return False - - def conditional_headers(self, request: PreparedRequest) -> dict[str, str]: - resp = self._load_from_cache(request) - new_headers = {} - - if resp: - headers: CaseInsensitiveDict[str] = CaseInsensitiveDict(resp.headers) - - if "etag" in headers: - new_headers["If-None-Match"] = headers["ETag"] - - if "last-modified" in headers: - new_headers["If-Modified-Since"] = headers["Last-Modified"] - - return new_headers - - def _cache_set( - self, - cache_url: str, - request: PreparedRequest, - response: HTTPResponse, - body: bytes | None = None, - expires_time: int | None = None, - ) -> None: - """ - Store the data in the cache. - """ - if isinstance(self.cache, SeparateBodyBaseCache): - # We pass in the body separately; just put a placeholder empty - # string in the metadata. - self.cache.set( - cache_url, - self.serializer.dumps(request, response, b""), - expires=expires_time, - ) - # body is None can happen when, for example, we're only updating - # headers, as is the case in update_cached_response(). - if body is not None: - self.cache.set_body(cache_url, body) - else: - self.cache.set( - cache_url, - self.serializer.dumps(request, response, body), - expires=expires_time, - ) - - def cache_response( - self, - request: PreparedRequest, - response: HTTPResponse, - body: bytes | None = None, - status_codes: Collection[int] | None = None, - ) -> None: - """ - Algorithm for caching requests. - - This assumes a requests Response object. - """ - # From httplib2: Don't cache 206's since we aren't going to - # handle byte range requests - cacheable_status_codes = status_codes or self.cacheable_status_codes - if response.status not in cacheable_status_codes: - logger.debug( - "Status code %s not in %s", response.status, cacheable_status_codes - ) - return - - response_headers: CaseInsensitiveDict[str] = CaseInsensitiveDict( - response.headers - ) - - if "date" in response_headers: - time_tuple = parsedate_tz(response_headers["date"]) - assert time_tuple is not None - date = calendar.timegm(time_tuple[:6]) - else: - date = 0 - - # If we've been given a body, our response has a Content-Length, that - # Content-Length is valid then we can check to see if the body we've - # been given matches the expected size, and if it doesn't we'll just - # skip trying to cache it. - if ( - body is not None - and "content-length" in response_headers - and response_headers["content-length"].isdigit() - and int(response_headers["content-length"]) != len(body) - ): - return - - cc_req = self.parse_cache_control(request.headers) - cc = self.parse_cache_control(response_headers) - - assert request.url is not None - cache_url = self.cache_url(request.url) - logger.debug('Updating cache with response from "%s"', cache_url) - - # Delete it from the cache if we happen to have it stored there - no_store = False - if "no-store" in cc: - no_store = True - logger.debug('Response header has "no-store"') - if "no-store" in cc_req: - no_store = True - logger.debug('Request header has "no-store"') - if no_store and self.cache.get(cache_url): - logger.debug('Purging existing cache entry to honor "no-store"') - self.cache.delete(cache_url) - if no_store: - return - - # https://tools.ietf.org/html/rfc7234#section-4.1: - # A Vary header field-value of "*" always fails to match. - # Storing such a response leads to a deserialization warning - # during cache lookup and is not allowed to ever be served, - # so storing it can be avoided. - if "*" in response_headers.get("vary", ""): - logger.debug('Response header has "Vary: *"') - return - - # If we've been given an etag, then keep the response - if self.cache_etags and "etag" in response_headers: - expires_time = 0 - if response_headers.get("expires"): - expires = parsedate_tz(response_headers["expires"]) - if expires is not None: - expires_time = calendar.timegm(expires[:6]) - date - - expires_time = max(expires_time, 14 * 86400) - - logger.debug(f"etag object cached for {expires_time} seconds") - logger.debug("Caching due to etag") - self._cache_set(cache_url, request, response, body, expires_time) - - # Add to the cache any permanent redirects. We do this before looking - # that the Date headers. - elif int(response.status) in PERMANENT_REDIRECT_STATUSES: - logger.debug("Caching permanent redirect") - self._cache_set(cache_url, request, response, b"") - - # Add to the cache if the response headers demand it. If there - # is no date header then we can't do anything about expiring - # the cache. - elif "date" in response_headers: - time_tuple = parsedate_tz(response_headers["date"]) - assert time_tuple is not None - date = calendar.timegm(time_tuple[:6]) - # cache when there is a max-age > 0 - max_age = cc.get("max-age") - if max_age is not None and max_age > 0: - logger.debug("Caching b/c date exists and max-age > 0") - expires_time = max_age - self._cache_set( - cache_url, - request, - response, - body, - expires_time, - ) - - # If the request can expire, it means we should cache it - # in the meantime. - elif "expires" in response_headers: - if response_headers["expires"]: - expires = parsedate_tz(response_headers["expires"]) - if expires is not None: - expires_time = calendar.timegm(expires[:6]) - date - else: - expires_time = None - - logger.debug( - "Caching b/c of expires header. expires in {} seconds".format( - expires_time - ) - ) - self._cache_set( - cache_url, - request, - response, - body, - expires_time, - ) - - def update_cached_response( - self, request: PreparedRequest, response: HTTPResponse - ) -> HTTPResponse: - """On a 304 we will get a new set of headers that we want to - update our cached value with, assuming we have one. - - This should only ever be called when we've sent an ETag and - gotten a 304 as the response. - """ - assert request.url is not None - cache_url = self.cache_url(request.url) - cached_response = self._load_from_cache(request) - - if not cached_response: - # we didn't have a cached response - return response - - # Lets update our headers with the headers from the new request: - # http://tools.ietf.org/html/draft-ietf-httpbis-p4-conditional-26#section-4.1 - # - # The server isn't supposed to send headers that would make - # the cached body invalid. But... just in case, we'll be sure - # to strip out ones we know that might be problmatic due to - # typical assumptions. - excluded_headers = ["content-length"] - - cached_response.headers.update( - { - k: v - for k, v in response.headers.items() # type: ignore[no-untyped-call] - if k.lower() not in excluded_headers - } - ) - - # we want a 200 b/c we have content via the cache - cached_response.status = 200 - - # update our cache - self._cache_set(cache_url, request, cached_response) - - return cached_response diff --git a/venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/filewrapper.py b/venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/filewrapper.py deleted file mode 100644 index 2514390..0000000 --- a/venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/filewrapper.py +++ /dev/null @@ -1,119 +0,0 @@ -# SPDX-FileCopyrightText: 2015 Eric Larson -# -# SPDX-License-Identifier: Apache-2.0 -from __future__ import annotations - -import mmap -from tempfile import NamedTemporaryFile -from typing import TYPE_CHECKING, Any, Callable - -if TYPE_CHECKING: - from http.client import HTTPResponse - - -class CallbackFileWrapper: - """ - Small wrapper around a fp object which will tee everything read into a - buffer, and when that file is closed it will execute a callback with the - contents of that buffer. - - All attributes are proxied to the underlying file object. - - This class uses members with a double underscore (__) leading prefix so as - not to accidentally shadow an attribute. - - The data is stored in a temporary file until it is all available. As long - as the temporary files directory is disk-based (sometimes it's a - memory-backed-``tmpfs`` on Linux), data will be unloaded to disk if memory - pressure is high. For small files the disk usually won't be used at all, - it'll all be in the filesystem memory cache, so there should be no - performance impact. - """ - - def __init__( - self, fp: HTTPResponse, callback: Callable[[bytes], None] | None - ) -> None: - self.__buf = NamedTemporaryFile("rb+", delete=True) - self.__fp = fp - self.__callback = callback - - def __getattr__(self, name: str) -> Any: - # The vaguaries of garbage collection means that self.__fp is - # not always set. By using __getattribute__ and the private - # name[0] allows looking up the attribute value and raising an - # AttributeError when it doesn't exist. This stop thigns from - # infinitely recursing calls to getattr in the case where - # self.__fp hasn't been set. - # - # [0] https://docs.python.org/2/reference/expressions.html#atom-identifiers - fp = self.__getattribute__("_CallbackFileWrapper__fp") - return getattr(fp, name) - - def __is_fp_closed(self) -> bool: - try: - return self.__fp.fp is None - - except AttributeError: - pass - - try: - closed: bool = self.__fp.closed - return closed - - except AttributeError: - pass - - # We just don't cache it then. - # TODO: Add some logging here... - return False - - def _close(self) -> None: - if self.__callback: - if self.__buf.tell() == 0: - # Empty file: - result = b"" - else: - # Return the data without actually loading it into memory, - # relying on Python's buffer API and mmap(). mmap() just gives - # a view directly into the filesystem's memory cache, so it - # doesn't result in duplicate memory use. - self.__buf.seek(0, 0) - result = memoryview( - mmap.mmap(self.__buf.fileno(), 0, access=mmap.ACCESS_READ) - ) - self.__callback(result) - - # We assign this to None here, because otherwise we can get into - # really tricky problems where the CPython interpreter dead locks - # because the callback is holding a reference to something which - # has a __del__ method. Setting this to None breaks the cycle - # and allows the garbage collector to do it's thing normally. - self.__callback = None - - # Closing the temporary file releases memory and frees disk space. - # Important when caching big files. - self.__buf.close() - - def read(self, amt: int | None = None) -> bytes: - data: bytes = self.__fp.read(amt) - if data: - # We may be dealing with b'', a sign that things are over: - # it's passed e.g. after we've already closed self.__buf. - self.__buf.write(data) - if self.__is_fp_closed(): - self._close() - - return data - - def _safe_read(self, amt: int) -> bytes: - data: bytes = self.__fp._safe_read(amt) # type: ignore[attr-defined] - if amt == 2 and data == b"\r\n": - # urllib executes this read to toss the CRLF at the end - # of the chunk. - return data - - self.__buf.write(data) - if self.__is_fp_closed(): - self._close() - - return data diff --git a/venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/heuristics.py b/venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/heuristics.py deleted file mode 100644 index b9d72ca..0000000 --- a/venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/heuristics.py +++ /dev/null @@ -1,154 +0,0 @@ -# SPDX-FileCopyrightText: 2015 Eric Larson -# -# SPDX-License-Identifier: Apache-2.0 -from __future__ import annotations - -import calendar -import time -from datetime import datetime, timedelta, timezone -from email.utils import formatdate, parsedate, parsedate_tz -from typing import TYPE_CHECKING, Any, Mapping - -if TYPE_CHECKING: - from pip._vendor.urllib3 import HTTPResponse - -TIME_FMT = "%a, %d %b %Y %H:%M:%S GMT" - - -def expire_after(delta: timedelta, date: datetime | None = None) -> datetime: - date = date or datetime.now(timezone.utc) - return date + delta - - -def datetime_to_header(dt: datetime) -> str: - return formatdate(calendar.timegm(dt.timetuple())) - - -class BaseHeuristic: - def warning(self, response: HTTPResponse) -> str | None: - """ - Return a valid 1xx warning header value describing the cache - adjustments. - - The response is provided too allow warnings like 113 - http://tools.ietf.org/html/rfc7234#section-5.5.4 where we need - to explicitly say response is over 24 hours old. - """ - return '110 - "Response is Stale"' - - def update_headers(self, response: HTTPResponse) -> dict[str, str]: - """Update the response headers with any new headers. - - NOTE: This SHOULD always include some Warning header to - signify that the response was cached by the client, not - by way of the provided headers. - """ - return {} - - def apply(self, response: HTTPResponse) -> HTTPResponse: - updated_headers = self.update_headers(response) - - if updated_headers: - response.headers.update(updated_headers) - warning_header_value = self.warning(response) - if warning_header_value is not None: - response.headers.update({"Warning": warning_header_value}) - - return response - - -class OneDayCache(BaseHeuristic): - """ - Cache the response by providing an expires 1 day in the - future. - """ - - def update_headers(self, response: HTTPResponse) -> dict[str, str]: - headers = {} - - if "expires" not in response.headers: - date = parsedate(response.headers["date"]) - expires = expire_after(timedelta(days=1), date=datetime(*date[:6], tzinfo=timezone.utc)) # type: ignore[misc] - headers["expires"] = datetime_to_header(expires) - headers["cache-control"] = "public" - return headers - - -class ExpiresAfter(BaseHeuristic): - """ - Cache **all** requests for a defined time period. - """ - - def __init__(self, **kw: Any) -> None: - self.delta = timedelta(**kw) - - def update_headers(self, response: HTTPResponse) -> dict[str, str]: - expires = expire_after(self.delta) - return {"expires": datetime_to_header(expires), "cache-control": "public"} - - def warning(self, response: HTTPResponse) -> str | None: - tmpl = "110 - Automatically cached for %s. Response might be stale" - return tmpl % self.delta - - -class LastModified(BaseHeuristic): - """ - If there is no Expires header already, fall back on Last-Modified - using the heuristic from - http://tools.ietf.org/html/rfc7234#section-4.2.2 - to calculate a reasonable value. - - Firefox also does something like this per - https://developer.mozilla.org/en-US/docs/Web/HTTP/Caching_FAQ - http://lxr.mozilla.org/mozilla-release/source/netwerk/protocol/http/nsHttpResponseHead.cpp#397 - Unlike mozilla we limit this to 24-hr. - """ - - cacheable_by_default_statuses = { - 200, - 203, - 204, - 206, - 300, - 301, - 404, - 405, - 410, - 414, - 501, - } - - def update_headers(self, resp: HTTPResponse) -> dict[str, str]: - headers: Mapping[str, str] = resp.headers - - if "expires" in headers: - return {} - - if "cache-control" in headers and headers["cache-control"] != "public": - return {} - - if resp.status not in self.cacheable_by_default_statuses: - return {} - - if "date" not in headers or "last-modified" not in headers: - return {} - - time_tuple = parsedate_tz(headers["date"]) - assert time_tuple is not None - date = calendar.timegm(time_tuple[:6]) - last_modified = parsedate(headers["last-modified"]) - if last_modified is None: - return {} - - now = time.time() - current_age = max(0, now - date) - delta = date - calendar.timegm(last_modified) - freshness_lifetime = max(0, min(delta / 10, 24 * 3600)) - if freshness_lifetime <= current_age: - return {} - - expires = date + freshness_lifetime - return {"expires": time.strftime(TIME_FMT, time.gmtime(expires))} - - def warning(self, resp: HTTPResponse) -> str | None: - return None diff --git a/venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/serialize.py b/venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/serialize.py deleted file mode 100644 index f9e967c..0000000 --- a/venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/serialize.py +++ /dev/null @@ -1,206 +0,0 @@ -# SPDX-FileCopyrightText: 2015 Eric Larson -# -# SPDX-License-Identifier: Apache-2.0 -from __future__ import annotations - -import io -from typing import IO, TYPE_CHECKING, Any, Mapping, cast - -from pip._vendor import msgpack -from pip._vendor.requests.structures import CaseInsensitiveDict -from pip._vendor.urllib3 import HTTPResponse - -if TYPE_CHECKING: - from pip._vendor.requests import PreparedRequest - - -class Serializer: - serde_version = "4" - - def dumps( - self, - request: PreparedRequest, - response: HTTPResponse, - body: bytes | None = None, - ) -> bytes: - response_headers: CaseInsensitiveDict[str] = CaseInsensitiveDict( - response.headers - ) - - if body is None: - # When a body isn't passed in, we'll read the response. We - # also update the response with a new file handler to be - # sure it acts as though it was never read. - body = response.read(decode_content=False) - response._fp = io.BytesIO(body) # type: ignore[attr-defined] - response.length_remaining = len(body) - - data = { - "response": { - "body": body, # Empty bytestring if body is stored separately - "headers": {str(k): str(v) for k, v in response.headers.items()}, # type: ignore[no-untyped-call] - "status": response.status, - "version": response.version, - "reason": str(response.reason), - "decode_content": response.decode_content, - } - } - - # Construct our vary headers - data["vary"] = {} - if "vary" in response_headers: - varied_headers = response_headers["vary"].split(",") - for header in varied_headers: - header = str(header).strip() - header_value = request.headers.get(header, None) - if header_value is not None: - header_value = str(header_value) - data["vary"][header] = header_value - - return b",".join([f"cc={self.serde_version}".encode(), self.serialize(data)]) - - def serialize(self, data: dict[str, Any]) -> bytes: - return cast(bytes, msgpack.dumps(data, use_bin_type=True)) - - def loads( - self, - request: PreparedRequest, - data: bytes, - body_file: IO[bytes] | None = None, - ) -> HTTPResponse | None: - # Short circuit if we've been given an empty set of data - if not data: - return None - - # Determine what version of the serializer the data was serialized - # with - try: - ver, data = data.split(b",", 1) - except ValueError: - ver = b"cc=0" - - # Make sure that our "ver" is actually a version and isn't a false - # positive from a , being in the data stream. - if ver[:3] != b"cc=": - data = ver + data - ver = b"cc=0" - - # Get the version number out of the cc=N - verstr = ver.split(b"=", 1)[-1].decode("ascii") - - # Dispatch to the actual load method for the given version - try: - return getattr(self, f"_loads_v{verstr}")(request, data, body_file) # type: ignore[no-any-return] - - except AttributeError: - # This is a version we don't have a loads function for, so we'll - # just treat it as a miss and return None - return None - - def prepare_response( - self, - request: PreparedRequest, - cached: Mapping[str, Any], - body_file: IO[bytes] | None = None, - ) -> HTTPResponse | None: - """Verify our vary headers match and construct a real urllib3 - HTTPResponse object. - """ - # Special case the '*' Vary value as it means we cannot actually - # determine if the cached response is suitable for this request. - # This case is also handled in the controller code when creating - # a cache entry, but is left here for backwards compatibility. - if "*" in cached.get("vary", {}): - return None - - # Ensure that the Vary headers for the cached response match our - # request - for header, value in cached.get("vary", {}).items(): - if request.headers.get(header, None) != value: - return None - - body_raw = cached["response"].pop("body") - - headers: CaseInsensitiveDict[str] = CaseInsensitiveDict( - data=cached["response"]["headers"] - ) - if headers.get("transfer-encoding", "") == "chunked": - headers.pop("transfer-encoding") - - cached["response"]["headers"] = headers - - try: - body: IO[bytes] - if body_file is None: - body = io.BytesIO(body_raw) - else: - body = body_file - except TypeError: - # This can happen if cachecontrol serialized to v1 format (pickle) - # using Python 2. A Python 2 str(byte string) will be unpickled as - # a Python 3 str (unicode string), which will cause the above to - # fail with: - # - # TypeError: 'str' does not support the buffer interface - body = io.BytesIO(body_raw.encode("utf8")) - - # Discard any `strict` parameter serialized by older version of cachecontrol. - cached["response"].pop("strict", None) - - return HTTPResponse(body=body, preload_content=False, **cached["response"]) - - def _loads_v0( - self, - request: PreparedRequest, - data: bytes, - body_file: IO[bytes] | None = None, - ) -> None: - # The original legacy cache data. This doesn't contain enough - # information to construct everything we need, so we'll treat this as - # a miss. - return None - - def _loads_v1( - self, - request: PreparedRequest, - data: bytes, - body_file: IO[bytes] | None = None, - ) -> HTTPResponse | None: - # The "v1" pickled cache format. This is no longer supported - # for security reasons, so we treat it as a miss. - return None - - def _loads_v2( - self, - request: PreparedRequest, - data: bytes, - body_file: IO[bytes] | None = None, - ) -> HTTPResponse | None: - # The "v2" compressed base64 cache format. - # This has been removed due to age and poor size/performance - # characteristics, so we treat it as a miss. - return None - - def _loads_v3( - self, - request: PreparedRequest, - data: bytes, - body_file: IO[bytes] | None = None, - ) -> None: - # Due to Python 2 encoding issues, it's impossible to know for sure - # exactly how to load v3 entries, thus we'll treat these as a miss so - # that they get rewritten out as v4 entries. - return None - - def _loads_v4( - self, - request: PreparedRequest, - data: bytes, - body_file: IO[bytes] | None = None, - ) -> HTTPResponse | None: - try: - cached = msgpack.loads(data, raw=False) - except ValueError: - return None - - return self.prepare_response(request, cached, body_file) diff --git a/venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/wrapper.py b/venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/wrapper.py deleted file mode 100644 index f618bc3..0000000 --- a/venv/lib/python3.12/site-packages/pip/_vendor/cachecontrol/wrapper.py +++ /dev/null @@ -1,43 +0,0 @@ -# SPDX-FileCopyrightText: 2015 Eric Larson -# -# SPDX-License-Identifier: Apache-2.0 -from __future__ import annotations - -from typing import TYPE_CHECKING, Collection - -from pip._vendor.cachecontrol.adapter import CacheControlAdapter -from pip._vendor.cachecontrol.cache import DictCache - -if TYPE_CHECKING: - from pip._vendor import requests - - from pip._vendor.cachecontrol.cache import BaseCache - from pip._vendor.cachecontrol.controller import CacheController - from pip._vendor.cachecontrol.heuristics import BaseHeuristic - from pip._vendor.cachecontrol.serialize import Serializer - - -def CacheControl( - sess: requests.Session, - cache: BaseCache | None = None, - cache_etags: bool = True, - serializer: Serializer | None = None, - heuristic: BaseHeuristic | None = None, - controller_class: type[CacheController] | None = None, - adapter_class: type[CacheControlAdapter] | None = None, - cacheable_methods: Collection[str] | None = None, -) -> requests.Session: - cache = DictCache() if cache is None else cache - adapter_class = adapter_class or CacheControlAdapter - adapter = adapter_class( - cache, - cache_etags=cache_etags, - serializer=serializer, - heuristic=heuristic, - controller_class=controller_class, - cacheable_methods=cacheable_methods, - ) - sess.mount("http://", adapter) - sess.mount("https://", adapter) - - return sess diff --git a/venv/lib/python3.12/site-packages/pip/_vendor/certifi/__init__.py b/venv/lib/python3.12/site-packages/pip/_vendor/certifi/__init__.py deleted file mode 100644 index 8ce89ce..0000000 --- a/venv/lib/python3.12/site-packages/pip/_vendor/certifi/__init__.py +++ /dev/null @@ -1,4 +0,0 @@ -from .core import contents, where - -__all__ = ["contents", "where"] -__version__ = "2023.07.22" diff --git a/venv/lib/python3.12/site-packages/pip/_vendor/certifi/__main__.py b/venv/lib/python3.12/site-packages/pip/_vendor/certifi/__main__.py deleted file mode 100644 index 0037634..0000000 --- a/venv/lib/python3.12/site-packages/pip/_vendor/certifi/__main__.py +++ /dev/null @@ -1,12 +0,0 @@ -import argparse - -from pip._vendor.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.12/site-packages/pip/_vendor/certifi/__pycache__/__init__.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_vendor/certifi/__pycache__/__init__.cpython-312.pyc deleted file mode 100644 index b85d221f1f3cad31b24fe8302eac35a1071a905a..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 329 zcmYjMJx{|h5Vi9`OQNzNBo<)o(72=n3qq=3VL{9putIE_Qxn^A+*IiVzW_E?R(=Z$ zBgz626B|;uPPh_Cyy4xudv|)emtHSG7EjSVT-o}$ZvNo>isil)kBA|L3sm9+mrmkf z#2n^MoWx~b;x&GM;|trhzSDLyDGV2;YW;c6HP^14YtPamh==hg8XiS)e9`w?FO&c6 zwnJ%J6qL3hr8U;3bdRp$QiGuMk+Gabt(qq%k#l$0i@=l zCIws*)tFq0QFIuS3Jf2pG@GUqUJ(U~*Z{$#CK=ZTZh%k<0t}^*YF6FjQnFdWPjqOL h*KbujmcCt#@jE*B2)7^Rufg7J=WT2EF4UXW`vDRfS~&m! diff --git a/venv/lib/python3.12/site-packages/pip/_vendor/certifi/__pycache__/__main__.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_vendor/certifi/__pycache__/__main__.cpython-312.pyc deleted file mode 100644 index cfadaf823e47c211bf8a0655016c9eaa9e92d8c8..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 656 zcmZuty>AmS9JTNJPNYRdND)(ngdm7J3s_sEh%PKuN0jAc&L(ksU-CIYi5My*1gHaS zFfxL|f5Jl4q7<_fF(5XiZe75a-ZcxB?BDZyzmI2sZZtfg*8AW!`>W#5@=`Ce0w;$G zyafah7=vCJwHPK^PfPTk4uJ+J7&>*)D$Xj{GpRXjtoRxcofyRYWX<$51_G70UaPBk z-p8TN&{**`;%mx*tF~5W&fu8_!30*C{y(i_|1J}^JDPN&EEO~rg*2ZGD5q1+kEWjQ zpVM9;GEPImN3;W_g(JbTwBtz!^L~zbL1i;%c@U0iN-`cqlneHl@$zlFG%eSyunUu-_x{AReXZtUOuYFz%I(6#;R&$szS)%+is CIHXqq diff --git a/venv/lib/python3.12/site-packages/pip/_vendor/certifi/__pycache__/core.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_vendor/certifi/__pycache__/core.cpython-312.pyc deleted file mode 100644 index df541d50e73f180344360a2fd8c89f31f8ba1a38..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3338 zcmbVOO>7(25q@uf_$P`>i4-N7iOEWKVmcOSJ8By@Z5l-}Qok!SREwCM}G`bJ$_mAvBeXg&(Ov(&ZFo$scEb+c&kg+r@732p0#PCgDR zf_kLc>j{z|(ff3T#q}ub(Ys&{=kYEfJ@&Djk2LQRZ?mHZ?P!iC+Qxfvd|Al!udtBD zxNXcB*~)V0_pKHRP0txtdco8eODxTqy~xW}+MZ)+qiorQQmJ4YW;tClwT58Mq_qNS z%2wDy+T>}&w$hqewprP>vZ2R#yNQ*79J95YWtDQc)XHgvq2}qJhFMvS+Zo}p2x}iB z@)^PL7c6zgC^1JyYB|1!DH`hYnhXN&+5a<;Tg3Lp$=d5Sj=RmqRc_PiT?i&@MSp|0 zQ(f?8JzkJ(FARwt@YWVPJ?W6&ZHld(ZMIC2ZE@ltRxv7B^#&{JCeJpneh@nJT*mK& z)zOjB%h#sW$&u+R9IfUU<4&Mx8s$pCo^v|96{FL?c0|kOPEb|B&y1_;HrYob4p?r^ zTwpm~&|#Co&Bc}6o6MTG%}Q>B-zb!aMke1H8Z8+)u;oUsWc)T)S+?iQ^2^x^7ju?j zv!O~sn=i~VD+ea$nkKujL9FC7lQReyM_!s^obfmu*$sc|bs%fxNtA^9svW5(36dQ6 z%jxQwU(^O(+Z`C&85sL#xHj-^?Zoxe*WQZYIr9#Tuc3=mi+1Z_%}+j8c1@~ zbOc}o(FOQA2mo*sJ_5DCb9J!=G%RVhLnw|^vHUVYX6?EUaRmL4cqtAVQxWT+#*TZX!~(qUTJNx)^?m}ic^nJP|z zGs|4$kk?qi9UtS|Q1Tw3@LMJ~#rMb(%?J~`56<5f9m%Y)vWtu(VN?UKr(lMkMuNBC z_(VC9Ua$)m`a6xy4fcjFF)-n^CDwT$0BV>-y8n3kvls7NdC)mjCp4J4AAcC@y>;mi zmp*&-dlCBI4{Ki`&6YwOd_-aixo~@@& zYTf;Jpv46p?%t8AN~vd0Y-PwwOv~yxkM;qJ7XHN60EUE*Ac;9FZm*%6Ts+ zc5{Ve9nVny60mkyTTWcWiAEAU3U+?VKAGLJ?)>UO5R*VoLJ}yk&E<{dPdBNkMipgzw#j{=ovJSr-xLcaBTsP{o3x;bp1~5+{!7S!OKpfd#uHbhTFnIR( zAdZFJaX$m6VaD-KHogm-z%{Sf9R>R!@bku3<7<2bHY0r2^FZq&rSv;NrqX_x(2l*{ zSF0qxC;E29*p3+6TKZBv`K@$uuRF2!Hq?u?@w$|dpWAwQp8%_$r?N`7v?t&&mDYX4 z7u=P5cI2Mhi7(~Ux6&`$xAiu*0jpo6@?>+{B;5}XIr5bh{aSi%FB03jyc<8Y6F+rF ztHv`sk+W-K50&`V)a{{a&xN0RJA(p87 zQ3{Z*cpcZ&LnPF>-+@v>l!wrCVD(VLhJ7%7l0uKB*DdJKbUh%@= (3, 11): - - from importlib.resources import as_file, files - - _CACERT_CTX = None - _CACERT_PATH = None - - def where() -> str: - # This is slightly terrible, but we want to delay extracting the file - # in cases where we're inside of a zipimport situation until someone - # actually calls where(), but we don't want to re-extract the file - # on every call of where(), so we'll do it once then store it in a - # global variable. - global _CACERT_CTX - global _CACERT_PATH - if _CACERT_PATH is None: - # This is slightly janky, the importlib.resources API wants you to - # manage the cleanup of this file, so it doesn't actually return a - # path, it returns a context manager that will give you the path - # when you enter it and will do any cleanup when you leave it. In - # the common case of not needing a temporary file, it will just - # return the file system location and the __exit__() is a no-op. - # - # We also have to hold onto the actual context manager, because - # it will do the cleanup whenever it gets garbage collected, so - # we will also store that at the global level as well. - _CACERT_CTX = as_file(files("pip._vendor.certifi").joinpath("cacert.pem")) - _CACERT_PATH = str(_CACERT_CTX.__enter__()) - - return _CACERT_PATH - - def contents() -> str: - return files("pip._vendor.certifi").joinpath("cacert.pem").read_text(encoding="ascii") - -elif sys.version_info >= (3, 7): - - from importlib.resources import path as get_path, read_text - - _CACERT_CTX = None - _CACERT_PATH = None - - def where() -> str: - # This is slightly terrible, but we want to delay extracting the - # file in cases where we're inside of a zipimport situation until - # someone actually calls where(), but we don't want to re-extract - # the file on every call of where(), so we'll do it once then store - # it in a global variable. - global _CACERT_CTX - global _CACERT_PATH - if _CACERT_PATH is None: - # This is slightly janky, the importlib.resources API wants you - # to manage the cleanup of this file, so it doesn't actually - # return a path, it returns a context manager that will give - # you the path when you enter it and will do any cleanup when - # you leave it. In the common case of not needing a temporary - # file, it will just return the file system location and the - # __exit__() is a no-op. - # - # We also have to hold onto the actual context manager, because - # it will do the cleanup whenever it gets garbage collected, so - # we will also store that at the global level as well. - _CACERT_CTX = get_path("pip._vendor.certifi", "cacert.pem") - _CACERT_PATH = str(_CACERT_CTX.__enter__()) - - return _CACERT_PATH - - def contents() -> str: - return read_text("pip._vendor.certifi", "cacert.pem", encoding="ascii") - -else: - import os - import types - from typing import Union - - Package = Union[types.ModuleType, str] - Resource = Union[str, "os.PathLike"] - - # This fallback will work for Python versions prior to 3.7 that lack the - # importlib.resources module but relies on the existing `where` function - # so won't address issues with environments like PyOxidizer that don't set - # __file__ on modules. - def read_text( - package: Package, - resource: Resource, - encoding: str = 'utf-8', - errors: str = 'strict' - ) -> str: - with open(where(), encoding=encoding) as data: - return data.read() - - # If we don't have importlib.resources, then we will just do the old logic - # of assuming we're on the filesystem and munge the path directly. - def where() -> str: - f = os.path.dirname(__file__) - - return os.path.join(f, "cacert.pem") - - def contents() -> str: - return read_text("pip._vendor.certifi", "cacert.pem", encoding="ascii") - - -# Debian: Use system CA certs: -def where() -> str: - return DEBIAN_CA_CERTS_PATH - - -def contents() -> str: - with open(where(), "r", encoding="ascii") as data: - return data.read() diff --git a/venv/lib/python3.12/site-packages/pip/_vendor/chardet/__init__.py b/venv/lib/python3.12/site-packages/pip/_vendor/chardet/__init__.py deleted file mode 100644 index fe58162..0000000 --- a/venv/lib/python3.12/site-packages/pip/_vendor/chardet/__init__.py +++ /dev/null @@ -1,115 +0,0 @@ -######################## BEGIN LICENSE BLOCK ######################## -# This library is free software; you can redistribute it and/or -# modify it under the terms of the GNU Lesser General Public -# License as published by the Free Software Foundation; either -# version 2.1 of the License, or (at your option) any later version. -# -# This library is distributed in the hope that it will be useful, -# but WITHOUT ANY WARRANTY; without even the implied warranty of -# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU -# Lesser General Public License for more details. -# -# You should have received a copy of the GNU Lesser General Public -# License along with this library; if not, write to the Free Software -# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA -# 02110-1301 USA -######################### END LICENSE BLOCK ######################### - -from typing import List, Union - -from .charsetgroupprober import CharSetGroupProber -from .charsetprober import CharSetProber -from .enums import InputState -from .resultdict import ResultDict -from .universaldetector import UniversalDetector -from .version import VERSION, __version__ - -__all__ = ["UniversalDetector", "detect", "detect_all", "__version__", "VERSION"] - - -def detect( - byte_str: Union[bytes, bytearray], should_rename_legacy: bool = False -) -> ResultDict: - """ - Detect the encoding of the given byte string. - - :param byte_str: The byte sequence to examine. - :type byte_str: ``bytes`` or ``bytearray`` - :param should_rename_legacy: Should we rename legacy encodings - to their more modern equivalents? - :type should_rename_legacy: ``bool`` - """ - if not isinstance(byte_str, bytearray): - if not isinstance(byte_str, bytes): - raise TypeError( - f"Expected object of type bytes or bytearray, got: {type(byte_str)}" - ) - byte_str = bytearray(byte_str) - detector = UniversalDetector(should_rename_legacy=should_rename_legacy) - detector.feed(byte_str) - return detector.close() - - -def detect_all( - byte_str: Union[bytes, bytearray], - ignore_threshold: bool = False, - should_rename_legacy: bool = False, -) -> List[ResultDict]: - """ - Detect all the possible encodings of the given byte string. - - :param byte_str: The byte sequence to examine. - :type byte_str: ``bytes`` or ``bytearray`` - :param ignore_threshold: Include encodings that are below - ``UniversalDetector.MINIMUM_THRESHOLD`` - in results. - :type ignore_threshold: ``bool`` - :param should_rename_legacy: Should we rename legacy encodings - to their more modern equivalents? - :type should_rename_legacy: ``bool`` - """ - if not isinstance(byte_str, bytearray): - if not isinstance(byte_str, bytes): - raise TypeError( - f"Expected object of type bytes or bytearray, got: {type(byte_str)}" - ) - byte_str = bytearray(byte_str) - - detector = UniversalDetector(should_rename_legacy=should_rename_legacy) - detector.feed(byte_str) - detector.close() - - if detector.input_state == InputState.HIGH_BYTE: - results: List[ResultDict] = [] - probers: List[CharSetProber] = [] - for prober in detector.charset_probers: - if isinstance(prober, CharSetGroupProber): - probers.extend(p for p in prober.probers) - else: - probers.append(prober) - for prober in probers: - if ignore_threshold or prober.get_confidence() > detector.MINIMUM_THRESHOLD: - charset_name = prober.charset_name or "" - lower_charset_name = charset_name.lower() - # Use Windows encoding name instead of ISO-8859 if we saw any - # extra Windows-specific bytes - if lower_charset_name.startswith("iso-8859") and detector.has_win_bytes: - charset_name = detector.ISO_WIN_MAP.get( - lower_charset_name, charset_name - ) - # Rename legacy encodings with superset encodings if asked - if should_rename_legacy: - charset_name = detector.LEGACY_MAP.get( - charset_name.lower(), charset_name - ) - results.append( - { - "encoding": charset_name, - "confidence": prober.get_confidence(), - "language": prober.language, - } - ) - if len(results) > 0: - return sorted(results, key=lambda result: -result["confidence"]) - - return [detector.result] diff --git a/venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/__init__.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/__init__.cpython-312.pyc deleted file mode 100644 index 5627f42f67805f4898f4eaa8ac12ec702262e6c3..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4579 zcmd59TTC3+_0GOu>;j81Hjf>90kg#3#kl5WOhpYC!pkvENRXmo*cq0=voq^EvtX=6 zB2lCgC6eh+jZ{~1t4OuwRQ0ESDphJfD)omoq`Mv2D(XXO{%~;B)?Yn$W{1T#PO9`L zBh9_%o^$TG=iGbG=H|o{waSlFcqLs z0&(u2Q&XjG#FcR#-olsh<+GL}urBB2gPf1|%sRM|kL*(wZUj8#FY)++$Ka!Q51BRV z;sU^ZXsI+3{1V0}V$p0Pf}(2nwGk4gjq1?`}hL3#r69{mUSAkMDi~Qd(c2+f3d)`eD^+;y6lmn{Wo*FUb7~`l-c) zKcrN$vi=o0mXS(~F|gF1i@anVzO)To|wzvrE&{`7L=Q+(D7iEQySTQ+yU7Y4JyhFwcxnHmY&xP2WoaAGeg=0<$;ITJieY|p2 zl~b`^yueDQdM^!~x*!TMIQWH_D9prCOX{2~or#`qjVXf4pGvXut89W-VksdN1ILs& z8OP!f0${Be!w8a~GE6kJgvk}vn>qj#4w@D8tP1%m*XBNRZ+V*^2ac>aeb&DfXntH? zoiD%eyT0F7{dR2Q!o)`Dm0hbP=-)w>68|#?s;FImcQe?y>UtcYH`?CZ3Jk9d=54+o zj(#w@*0g1-&U=G5dp_>j^j2@!s&`=>q?HN@2~Lwy=P(avCUWsT2Lm#3P2JTWLHnI^ zb;~|iw`Q#0=<3$5b9D#>)_HQZUiwr>RK_=7VM4|JY7;_h6dp^UWgGl{dlfpU4DPX_aUZioZ zkI?6C)7lAguRBa?u}@Ht+&pX_et@a zyEHVzh=L@NLGMEaxlCoKA5*s|xY{loT0+0HE>aO{>>jC|EzuT@N-1P6P2*bVp1Zpf zyu@Em;hr0{Mye)-Y_waHg|GZeDG3VN{cP|UUuZ?p}s zAWSL*5Ny55FGXtcAsAtjZ}4H#kc@(fE_$(pj}nOF6U_@HOj?Cf5}p*;MKJEcp^Jme z58k`duLVd+qVOt{(qAMBCiT7M;IFGtv1rZ$R&%ha6hZhCz`Adz%3kpb&1Xs^FA2>K z&cm_-hJ!0%!B3hj00R<3We(zCwrG<*NgK3WV;o<-#4=aK~o2>*2e(^OM>0lbhkme5fH8 zYR!gPAB8#|%&htH4X1Mr?b(L*&4$j6(&IZ&T{h-|E!kkpgQHu)?%!19dM6+CPUgdJ z229Ctl5KoLzVxuI?Bp-LSVzQlgJlXUHqhb z{n#UK_2b}?^%L0>!&||T4d2MNuj1zT$KxB`nhjfx?kr;wY9L}67>HDA4tNK^%M6o( z7L#b8l@~5Uf;`9zcSXPbB?UqON6KK$&P(Z}Vz`gTxMmzY$}zb^T3OnBmm6L!W8=Z$ zEWF3{*S7xd)|?CpT?}LREb(5=M&3lmGeEz7Bz)-F8^O=j4R5Wq$oJr3Adq09+=OPw zN>S9m>Jb(CJ8FG`nx3HAC+PSS)beK(`HSbR73Yo%^;2(BPpuVHP2L||>tFBOsHo5S z8+LTe`Ch%>wg-0Yz_HVc>caVBjZd9DRP9UbfZ47*x?_hP4y!t}LwG>E!?W6)wI6!s JhM}(Te*vhWPwW5y diff --git a/venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/big5freq.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/big5freq.cpython-312.pyc deleted file mode 100644 index 7ac276c823da5a2d261443fa803d626753fa5223..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 27210 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 b{a8_wr5c?0evC#j(?vTQB~|Y@A@F|y?$5V^ diff --git a/venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/big5prober.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/big5prober.cpython-312.pyc deleted file mode 100644 index c6d088a573e5cda4e32fa5be5f771803a0c38362..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1398 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 TaekJ7aIaTy;A?D+;o$!OhT0HN diff --git a/venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/charsetgroupprober.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/charsetgroupprober.cpython-312.pyc deleted file mode 100644 index 694d59b8add0e1422c00e0ad1a349bf5c079ebe3..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4133 zcmd5qp7yldm&e>b~9 zwQDLKqSlep0w=0~RH^RUQL0nlN~KDbsy>|5hh`I~-4#+>ReiXpy2qhA-BZ7B)^`4! zLA|$*?3r(7zWHY6`@Y}z&Hl;n?

H(|6MI0Yd(XomLT>#EWkMu}UTH?ESTwhE}pT)t2rP(;&7I;{im1Ex#MDy2ls_=Htg?KKt7*FYQ>5QpU+lMph zTKa@XZ5YgWARai%U@blv^bx zv`$&(%jCzPk23cw?lEc>3fihn)V72afnL)>a7ye64ksZ+FjQ3Gs1F7xu24i ze@Ru-xwNUOwpWcO%=ArN%`Il_t^zZdVfU)nbi-6ri@IT`&LA4y&@)LU&i1HkA`^#6 z)xh1u;oF}Zk?Z-a9-(n9ohzh438lyx-MC@q3z1XwW;{1_>eAa&r!(ouO+9xrl1X2S z6pH5cd~Rm?$QuzOZR%5nc;W{5h!H8I3lSCAv^!_~U?6U*fy!jTjUu*}GvvF|gxuoF+(O%Un;ctY@nvq) zpk;8jg|>M&`88L`4=3g~-D2gi;5b7IPUs9mlzG7wiU(5M6oLk^MXG~V=`NsYFAlgJ zf1p8Ra?ubQa}-W@L#JhLx(7NGu~F*lpnoP-LH=(;)l&Yle&A%{Q>_8>n)YZ}>01fkqebH6$`R&WuF&g4k_FLJwy~ zx(&oCAYlR8oy8c0@z<*S73;X-DErJ@pOOgL`Yi z$@So5eeeD{W3U2awZM!Om|2r%{?C<12jOB(_0a=B+Y-i6%pWui-L2XhfqusT&{}Z} z7kqh5MXW$%O^Ps0+0wP5sjG%bw}tL@RQMfO?^O;5NdE&MoiFnX=%71_!L7(J(?;p$ zbh#b!Z@J1Y;QLD1Wws+pr&M@j0`NFl#`MsZ_xcsU*_H@y-?O=Ui%ReuxlFe0j1hN7 z!JXlRixByEwH-HEw8D_GqiB2yunW=3)0%+2JMp=0>|=6&vE>#WcK=^*As~P|+!2zu z5S?Q|(aDnCED%!IoY+EA*ENbKwWYa>SEFatx34&`c7s2_;{`G*YuwR`SJZdTvOuZ` z4AgWKmeKuKfr5yE{t|}b!2BTeN_#uN9C!RC^8W^^+oawKlL5~dgvnt4>WTMG)aAZ< zXy5Amz4@xN5mG8={~GMWu|Vi&zFOau)i<>sn5s`6zAHSH$DbdVtR0xK4$RyY?t38~ ztd{PT*5%`;J$&%4`@X*}hiYu zHZp6C%-%h7f4;td=;y~C9$OC`Yz)ES8et-b?v$2GYf}Fg156iOhDGN;z6LCq5Y0AB zIz?9Iw% z2_U0`J3nsTiz6#<0tcqj9i^4_ZwX&wH?i|>FpBwkM=1-B(Fvh&1OkO{1I`4%{XtoP z0ObN8HD?J~sW7;7cySwC(N*RFH125XgLD5Vg+BQA$<+5lNG_dBInu$i{RfS3E^mgN z*FLg@(tGI@%Q)Cl;f6i{7Lfn`QPS0G(U0i z{+@=L$o&tFZUlzl<#gA>K>ti0Z|sIm8+!nf&BsA-Pd(5F?_LH?g{SahBvB=Vp91(0 zflq;MRn6wL#SGFuReg6co^fUx*tiTfU0t;%)2|UuvB<=~$i&}By4DMEn;vQ9qIZ diff --git a/venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/charsetprober.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/charsetprober.cpython-312.pyc deleted file mode 100644 index 90bc8b1147cc63bba5d7c3b840f70468b798373f..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 5029 zcmb7IO>7&-6`m!R6sdoU60IN0-pGz6CYID#aho`pRR?RQ2S%C0o>d5twes zqpOpn(VH*bSRei7=F7F=Pn`**z8S}LD#cUo97wRpLqZ9jG3ru;sGEvQ+)fo%r%eco zi;8&egs6CKd!kj&IsJ=3;sf**8 zoRu>4iLqDCkDIDRM>BGK8N%Ki�O47_cb@8;^q{6l(F-q*jJIWGs`zU8%Zi#bT?$ z24{^`=;vTx=69f4C(nXIPlM;SgXaq3-Im>8KW_%k7Q`K2@3Y|G)8O!SaQGA7li(`_ z@xzt_kRkDMB4Z!&z3kL6==?uU&5@6VaLCPV&)Ptkp|3s`ST{5#E+H|%CSrRSh10DD z8jr$>=aIDos)loX*ustjtznxmc47|$=OM`vhN<>3Vg1n5uhxoIh4r{!SNj_mt)IJq zf(Rb#WUnLe{EB!29_@Indc*u&aMl*=K-jQm(;1DXscunahB1RZw;>pJge=Y!2{Km(c%wDo-9FoxXe3#2?;zHp0kCAr{&>L;KUz*DiaZayW`#mcRtwi z^*`?wT#$RE90vj*KoW^q*dSJiBcdJBJr+0ggsMw5~S$_ zyUpw(81N+^)dzNu1I@9NnoPxbY#6$hTRq))nj@LsMpbAQjIhpoi93m{p0k_cX8cL} z`GOnHS!jOV(q7=_huncq{UIxN;+kMp5q_z13j=SZz@f{AS##xG)8yt99N(Q6mJqEE zmAo6x)L)el2vFb-?9X@0x+paaC4?imp(q2vKdz7d>GwCQa%q_@QwB@G?FDxUTw4;=Oe)Sl zImy|8IVMF?swpM1I^3j&E`h|diRzp{gQIIm11(lcwrY!5Rb3jDO-nMstlx6@F=-N% z;P%vH*2tQ$zxT43soePGeN@%Sj7p4VG&xQc@C+UYjH6M>ggcf>vKd#^nqkMPa?UaM z>qe3@84WD}$H4uYai(T0Q@WK><0(loB;By2EEs#H?BAN7YWl)od;^6i?mEN!IOMVY z7%4Jia?T!@4M%3Kg(oAkbK%LWv3KXLP0z>PnT#OOZh|ONU}f7&-?!i`U^l5IkD-u< zr@ifStVi~OyIqw@x9OJU9BS#{{5u8`y6y^$4>*T9` z(mnX=HwwP5n#r+qPdg{JJ0~7bJ?VU{;Mwc$+b7Nb;llK8YxljmJ9EY9jljlGadxNm zY^jy>4HmBz=ZpTr>~7%1)4-YSz?q%E+0EA<-}>z3%eyC}`~Hg9>|a5k2Q-y>NoQ}N zw05e{kF@?K*c`@%^hKqv@=UwKD06<5;RUQB>FE#+&k$mt; zRo)+bn)zU*D*#q5v-{h%D*i^T0Bp_j4Ny`I{cHR!Z$hfXjZ6*^ZD9dmVqw9_S$OIL zEX4Ln(80urbjOP3s_TegYL_cUL*PcaH@N-rbJQg7~bxw;1@P@w9ztyM1V5;z|2( z!TtHk;Z65%^nKFdKY1ryn7%(!@ycRG%C#97T%BfUHd_qOg=bh0x@-W)KKR(mP-f*A;s!jqEXGda>=0HW(medy z=WcYqabCo!VLp}64B28K?6>0URgI@9T(t@tN1jVqUBQaKNAX*RdyFA2@CtwfzTY56 zZg!7VYkcVX)3g)7?^u6#*E&-smT37bDh4zM|B6+EM0A#Z!hC3w1vsSWd^^ge;^ zfxAMiP7f7FHYPqA#p$8y^iatQ!{YUg3!9;>(-Yf+ua~ zfejC`1(2<)KNL9g8BcHH4uSA#&pv^MGk@uV9={{F2}3Om|D|H1P}yF1tHCRP zJG1OPOf!=^-}!f-DQ=`Qszw>U*&RV;%Yx9mPq5~@{11w4$A16- diff --git a/venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/codingstatemachine.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/codingstatemachine.cpython-312.pyc deleted file mode 100644 index d1f171dc206b17fcbc0ffc21f3f3507cf722e5e8..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3889 zcmb_f&2JmW6`x&xtw~C3?UGf@IvmKbW!4r6CH+X9B84iuMbbtMBo`={!(z2N6jxsE z(z8R^WMsex9~_{CQJ|P>SfoIJqKDj+=ujZ1zBkJyDT(T- z3vlMm%=`Gw``YE-r>3$5o}Job`*+iX{0kTHlN=C-uK=-4EMh4RX%I`b5{}YV8>)hI z(n++Fjif?U@>61^9uh14OpPQPsh(2Je2$Cd&lMP}N?2O*EZbdQ6^3AM8fMFO*$vwi zaFQP^<&ha_h{hq1Cakv!BMrqO4b@T_2}@;3D`6#@Nidykq^!J^hB<9zSjI}Q4D4&L z)+DW3XMjEfbhfElS)g+)KUn1+CZ7##Hl}*X>Qs34BvRw|03}P|S)@MRfVQJ6P~p){ z#_eX08g#7(2R^&gWvH2A#gd5NQQLAUOI=wBX|C ze}}Cb&e6z7RT#_RbH%QKQw+LkIJQM0N{n_qz*Ch$1lMqIG~={o_;igiaEHZQVK;4N z)gokX-i%=laJiOkLY^Qz@H_hH=*>qO!0wU6ISx-MfP4BKW`ao*{e$`tmd^y{2%K8X zx7S?=mP|Vt8bh2^1s+Cj*P|Zj;BZafw;@f2$w}|FY)DEIB4B#1Fd%3G9gPr=tBX?| zBMvMwQvsaA49E-_M7!N)mW}lShHT7L2(5n?3hMx=zz1% zzkCWYaz?Q~Zi*f)Q|aPSd5&%~=_)66xsYSW?iM+1r1C~w+tNwwp6PTU$WvQ?la*IN|zwx!08qMNtOg|gg1zGtL!u>6>@y+;r zG{>D;Aw5z}EOUf-tC|nfdK-$=38!_l%ejupsY8avYb*`jVJ=6YVM?}*Fc6gug@$<+(4{7GA1DNwE2j zVcs^N_0~Ifr>+B=zyiG>bF2o$HW4sJ&&DvD;vI~!KHTk*r^<3QAtS`$1B7r)o~H^g!Q`U} z$}u5$5r+QEglo!}{1~}0*&dLw%Y35E@E2e+RLsd0@dg-xiXa=nbo{Xt6y1{JeaP=g zHxcod3E3EC|47g6D}eh&SsO#XQ*0%qEme+Vbv4=QDLRrU-G@})Qu{#NPn^P+l2#&% zW3|6U?kSV%+)DSSAlj-veurWFMz>uh)y#63GabYCb%Ea;vP{G2xC*1qFduO=q4GQ) z=44I}_%Va3X`X{gromWNa0;D=0q2gOzrcRi3**&4l zlm3MX88kY+33C1)VR%3e(xh~L`|aPpy>lTb)}Jdu@uf%E{aj%$R}OOJKW*(*7J|yc zN4bUl*^7^Ee4MZB&tCq^)jwa|t-Th^{^)~jF#9vP{aNvaz2c>ycm07AP!N-h1^AukPFr%HMsy5tJ9B3e@s@TKOZb{Nzrc(NCaI3+MIR$k#b=zFp;!Uv6x5rekbzdXTN6Zlq8 z7uGH`7z8>S6lQm|*^@vqYa~z##A!gIx`S*|m%}7BU}y$1BaTC!kx=BPbQD~D&>H(! zPs2Td`Ii92|2hm3{Ns1tedo#d{%`m-2fn7e(AD|3!NPH;^Lf~u*t%n}UyZ%ufw?LNsv#8v=?>a46@@e3qK$Kl076}sNYCw2iG#G;%<52 zfWZ9RI>hPltdgo7q;o0yWa)sww6k=G)4_Qqb#Z6)kic}1hT;8-1Dd3#4^$;J_vGT2 za5#6EfQ>J3BZ7d2p+{iE!jdTiI{sRO&ut+u8K#)qZTnFRk&wRwBBN`3rTsAS)oc9w jaDX-BWBnW?6h(o5yh`EU z6vR{GEmzTl|A!~ZCCo*{lea?DLr>1^CW7L?zWv@e@6EjT&HI$k=YU+3+G}r11K^u- zmdjdzc~gQ@KmdV0=)(@|YaI;&3fZRQG|A~59RdyP1EN0%#GpDcKUnXLG{0kvGSpPI zVt-duMHBh<J`nbNT?gJujfD zwwhRReH_P#<0GGn)zmr0E)SVliBRwW~BgcOO8 z$RX4Z$-q~56`>~s?58_SDJgU>;9?yi90Z}f!V7~~2I?_q@4#FJfb*wLFYHr?VOezK zv2gIrY0~(Fhmo_(hB&D19v)O1zUK^SFm!zH$caY07Y6m(&09|FaaxVAdm`(KoydzE zB*RF^9MuD%+;I~zlJ@$k7(|H?jaWwBo)|Suv6Alvm=((7`a~b!euJj=wOO$=wM+kS zmoAUpNqyXVyFRtIXKNQfx=Lw zuubJB*+q%Y?VVK5JFF~SD8KlIG-o=5@C(@fs$ck-1Ll<HwEI?p#T5? diff --git a/venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/cp949prober.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/cp949prober.cpython-312.pyc deleted file mode 100644 index 26e80b1d8a9a74ebaf4dd0c7310fd96eb602de16..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1407 zcmah}OK%)S5U!rrj-B-blh|vxSdNGoMfO0FLn2U!Sw{#GI~Ep~xwOVJZF|VP($i~Y zEgyWa#9AWC2{}iuk@+WFK*<4(VhM>8H;c8UC?~3WcEaXFOH*B4kFKh(s^{0Su~ESF z^WxKJxdHH(Jk-k^F#T_kIf4*E5<@~fLL{%nTB3Wp;`P`_OwUxj5nD;aYY@=jD+tX4 z2rXtF>(yPJ-EBDb-vmz%DQE9~*S`1da#RQ&ZFEGGrAw(FcZ;Y%nn8S!Sdbv!613H4WdK;J|2I- zS{QgF1Wyai9&D0OJ7{`3GeW}5O)b<9jN^f~XT6mgL()bM9uv=A2gfQesJK-crNx=( z@HCJG)=LJLU%!XsCvpU$*1#dzgC_`c9gcvgK?h;gX2*lu_JA6-OkAkB+84ENJ@(-H ziCX{PURx6ABKoV2U7AHFXS}p2jnYU^%H{oBUQ><)3VvE7Tqa*$3WwT6ec7j7bTv6E zm~gbxC|JB%j!+uJeo;_bXy`S!|0Z^~vxK?a$7bdc&pNyAGAka6EO(dqj-M_pt$n@F zjw5%6r8{mMZMb8Cc0Xjo4RUOHu4Z5{ z@A4)F-Mu)}k;S^S%cvC`EbPRRZ&LcG1F z3`4-;m{N!E_hdks-yH=Ex235h^HOme$?F3+*DUkW=_FX=ry4P5o(2B^ZhgHLoLU2} z_3W}#wUp`%ZCk1Yb)hU^Qq9QF)K-H$RSk9_|0_xLUr}RUP9z(Hc2x7kB{Zdl(gGiW zd=yo}3ToLMRm2DgaymI_508`!`4L>sk1ShyyEQ)L7=_7T|11#q2qO&vOcyeQ zM%V~7B1X6oH6o2zKbnjAl45szUd_`zHmFGyp8B@wQU;nSXI;)*W_x%fMh$aoi*XoI z7sXww)1GbaFz)IWg(I<+=WyDBL)>80wDW;Bj$YZr9ql2d=HkAnX|~>Bn&wNI)^UuU zg>+KWZuN9)@+YoohSNfk_00`gE7nSi;wR)97LV z4b$$LVDdqs%-oxv(=8PFj&3g$*Oi5mWfpdry;HEv8-;Ek%x+)Ke|o9lnjTx2c*HGq z&2B*hF~i}7iMtAD5I5iLbBIwA0EVsmF2Eh~BovB@k42I_GrT&Q%M2BOU4>_+qDQ{HJ9QE_;NHFpFv0h_z|_L%6_)As;F{J)@sVydPP}QO;g zUM;Q{QPPiHt8U0e)sKS$t#tL8A1+oZeta^?4+D$i>SG^dk(!?Z67DJhIxY;3lSp!I zSRTFi!NbVgqxV027`(Sb z@aH}jhI^zhpgpD6Sa3u!EQO(}E_`cDM zw=CDi#VE%l_p@#0X&|K?P99u%)hhW{#Y!;U#UeH&k7Hym6NImtn>jIKL{(lX)|Ibi zU))qH$~C!i-H%Pa;(E0P1q=Sov@G3qI}F;4;fGDzVAFy6FGIh6250 zb(&F7i!ir-jm|xWc9Xe(`6+?Vewf5E*nh?w4ivRO$H6o8#Qw*?Iz6(m-Sp!*(a)5o zQBWHDpg;Ke^e{TS8yp&*9<&x{^2~A}qIjUC*{nfWS!}8AFyWs=!BEf=+YIkJYZPEmbRiw5+T^d5lliKJLv$(997O zc-?aV=*=i}nKa4FLwy9eI!eufH^zzNnn+UZ`1UyN^6Uvj)+U;wyPfX87$5T1l0Lgaap2xp(i;zITb0eCi_7CyOK ne@5W*>|9)!z5CfS;Lkpv2S5p+QbOhl0eDW6LiQ;E2zLDspOyB5 diff --git a/venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/escprober.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/escprober.cpython-312.pyc deleted file mode 100644 index 1838c7bddf19a3db1afab06b098af30332e515c3..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4577 zcmbtXT}&I<6~1GS%^2I55ECE-JizkfO@IVK!mjd114+CIHVNd#+wRoyT!V@Ka%V^v zi%5BhRFJX?(zZ>IRtl9?ZK71sKJ=jved<%CzF;7-HA>Y#Rnukkrcv0(h+tfE5nsK&7N>3U13+!9d;+H!c|F6*uxPE zIZxz@J46;J|HNv1FI+wA@K=6~3%^AZLK!ulPDK)$?P>}pUvo(3H22x52pgyB7)xKH z3R)I+Q3o|px-0H-F#%TD0zohP4iVedHcyS3^OCA#IRv%jwtp-oK1 z6>$qgoKdJEM#R==TBf2BouWzFDn>FHmIil-u{0B9s?w+m7cSBiNWnxoq-*=h6lL_< ztVknDJTWUW8ck28;@QZx1Qn?gjbx|@+m)$!OcfP+V+OY4w-^P{M4ZZEIwh)UT~%DB zDK#FO71b%Kz;5$HJvvu&CLkcBm=O(jM%5XX3PvrP?jQYyq4??-K>ay)pQt6~f@O|; z2K+hhH{25pL}(nDBy&V6X_zC^c7wCIR|Rvmo4>Q5i;clf-jphj)9&)zoT-qiMpLWJ znQ4zXa$wav=&O0FzPF#uYwj(N`pLT9$&!7h7V|{rsGscZmeiYj%j5rH$$nFdX@NN+ zuz~NZOumefQ1XqwD)~okHKnHCGiT)y_U$!Sa9e(JULMW-=EyAZTZ4X%?ExmkxbxR) zHf1IQ@Fqx7JQY_ZNpl$aB`HZm4&x6n@W-f ztHf2>ory%RgCR<9CZ6e)Kuk`vUbGm@?**IzsDj6&Co{`x;hWip?bz32UhiRGEB}J- z+uP*1;9jW63H8e#uL$+)!jVEl<2--2s^IkGosBtX;}@xX^XXjk=~d_Hf~)#oa3Pp? zwd7na>#awB`|(=q(7Njf+v)2A=hs>&$6W9+r=Jf7 zJeq2oTp<&=y;1k=+E!FDF$`hIN&~1N7mrv)AN7JdY}IL^d#)i z8+#vy9cETdQWdZ=6~pQzO0&KlH@H>cGAL0HgKm>TU1Pqkd$q26UR@E6e{~c(-EvL1 zHmd>#t8Dk`r4n8SI0FY+2HATH-l^UE4&1*3*E(mN2Kntx;qF!gr<6lw{+z|kv0MBc zua@#^x>VP!BB1BRtFHY$`t)nHC|$d zxT@Jku3QOSG4KwrUb6>76Vm7i^XXjU&9(<7#(|~@=R#M5!%|>Et2aUzt9nD5lr;W^ z8KBt%n+@c&8OV7AwQ*4cXpBbG0|j4K-q)Y=^?xnV2Or&7t2_L>qc7j_L9XM2 z2mBXKfa-_YrR;jWzfjxqwc5ewtv&hH0X@WZ7K*S+m8n!x0u6;4rXCDq=0*@f(i(4Z&0-@?$f zL8$hi%tIiCGOtpSl4*G+fpeE6-I$3aHaHcMB&Va2#4!FfJ{Ss)=v9sWG-(2qI#4jG zvkadG%?dEW4#A9}n>1T2k&dVgs~pDb1jHIebKnqREHbOta_j{1+#8izlqM3A1VD}G zsblmR<1NGzm|=%Nu6z#Nw|B@33vUyOE^=&`%MV=04P1CZs%*8(!6FWSoOq4HYq7%C zS*#)Us-lInbv&3_R+f@42~1yEO=8i$G3$KLwcNkdjqJ`6yR&HLY=g_TS3n&s+G}k4 zA6#7?c;sJc>(4bEEfOI7?!X%y^efh_4EpzIc6BxbajajCaRcs+C(bAl83LYGv+*Am zW7dpytSK}bP0b_~{pR(QGAdsiRiaRiJ3&IPvGvMYuc-C!J|>0@SU-FxoG{#aiUnbb xu&JPXidK%}-V741?VqIU&!q1!mpn`xkG$CNSvQ{sT|y!p;By diff --git a/venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/escsm.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/escsm.cpython-312.pyc deleted file mode 100644 index a448fb9324d57ffce980faadddc3edc9a82bce39..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 15321 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 diff --git a/venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/eucjpprober.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/eucjpprober.cpython-312.pyc deleted file mode 100644 index d27e8ff761e41de48f6435dbb48344b3bf945664..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4394 zcmbUkZEO?Cb=LMe>%_@A!JP8}i6MkyxWvr|(BnIo5vo? zBdJ<;-?N)*M)=v9fcptS0*t{#Dokw{ zNJ%kedR!AVc|?rP#1uJTGu%axk`4EHoSL*IfsB_b97rjed|4~g_0~uxp~c>v)#QO0 z5s%9nk&`h<)KLjxd_))-9UM9rHH|iVM-kb)3cx3DZZe865{lR)*BqK+B-?d oB$ z06Sz>Vr1u(O>$g!+$#!4s!CM0jLJz)*(F!YHB+`Gmb-4Uq;xDIr10P}O` zG86HPqd>J$LoGE8H=J13GFXX{gR~ksaPr^$9dy5D7LjIg&^(hvpMn!uMlndUTmorM zYude{wj2_yts||b#4Q5AElFtLXlAoC1DCUCITYV!!Our)CWB_tT_yxOW7SMr#s(({ zF(sx60w($~S=ewzsS^ll5)*@s?NXVu2qN*8tcD+V_dzOe!e{u?U`)j^R`$8yu9?i&`oj?8lcxrL+J1aOXfG7Q7@Y zmx77dWH3Fe&7_pxuI`?o8q?&?v>3f8PRnXA9ZLrVm?ougFbYm4$y!j(MC0i+b+xYa zEN*~Bv!;uh*Vtw4_y@pI-+}JCYiNzDov+fl#z$Q9TGN3qLiwhnbB-HzYaJ)@9jE3T zkGS1y{=U5b5CM0ta_*be^VOfaH$fP^+#TKr&gWGufv>;Xc+ zj_YB-Z;@_0>3q-?PZ&2_tZaRm|8~)f=_2!5p|f^9Uweax9Tm8pI=8dHwd-8_pScd) z0#mkZ4RF)biOq{>mI>HGStsc4JbV5wI2CRLx=Os+PYp2K9WvZc9%s7z`T(S^*sj=L zt~*XFsAxI6rQ?bt=g>+|KTdPe*2x$5!SS30-R`Y)g2hXL4f}7W3#)(%}Gzd{83mDkBQnkf$;;|KtTJ9^;x}#zOpj)*nkGJR~o>9?=PL;Xw z$5)*7u8Qe^S}*Sko3lwaYSV`~a#y=woGaOn0TFn6UgX6|w5ez>*OFuJ75#`Ix{7eQ z=$q+UU~atgf7r&re(hQCC_2LO&FBp+dyOWr>lY4`V$yPjBxWCF)<{|ql zc?i)PJNJrxcfL5^x^LVAGQn5#f&0T3xfcgXI4-m3H9iYkUa}*oJlIfnSBL6{pP9-0 zGcnB%IX8vi$-kimnlQ=yn7l*7B`cYvjG>G(suifqAhH3BNi;Fo zp|P>iF~gZiO;1A!z)JFDW*Ym6Y&+>VGRYYl4GSYfhSQWZoWtR9f^+YUPJ{-9;jqDu zhx^CE#h!=cj#Kb_J9 zSxIH4X9P*qM5B(XODR(^Nmin=(J+2ybSykD5f;K{#)benHyCizT!YCoGnkm+Am;(; zrdYMmB{*V<0H&y}VdhWI_0MVREp5L&@!5$&OP}7-_fgmzjdLHsUYpweWt-X3{FX8^R#3ifbVHL}c<9f^Se9OrNZgrdY zHuK9vtAWmi!Nt*Aqf7m|cQ0K$pnC%aZ@u_5{|&nmeD48>U#Jv6bN|9}{nr!A7ar7qGqKY5 z;|HMW{f!_wxQ!mvx_4>vvk&GRH~D$~HluUR>oxq%BlAZ--%)4^>P^9iH9>m(dvtzJ zf$!7#zDN8aILLyhUH7!-Jso!(g?%UWeJ3A!PJUZ{F6(fK+4<}WXQuZpl?-_?G^zgv zfHz6%@lqWR3X07N99KvJwTNZof0eOmr8J*|aA_rgaby;I4*I6eI`1&(H0(+7GL(R% z;v#-ezq|w(rwn(oR;QRsb_uR;IzExiHkUj8)~6-{Umb>yK7k6CU-z{Xd~fT%w+p_b zy6ue;zorTb3heece>*Z78oV@o^oeAf!sMJua-4cCFvP@tZCY>-+| z5FkDX$&{2y5ZEmUKhKB>lSAuuTGkpIgg*F0(Pj-hlx1b{iR{W?$)i^d7a2s1#aSA* zFnQeuJC#U@8m328Tm1fr%87&^1Q<-R46PMUna5HKI40d*!bn2*-F5WL#6&Mc8l_q2}A|gwtn0Zkr@CBfe y8e2U8-G-fEm}fsiOw&Km;m4@wZ>aMz+V>dsK1RErI!`f7aHV12GeiKo!~XzashRNr diff --git a/venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/euckrfreq.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/euckrfreq.cpython-312.pyc deleted file mode 100644 index a05812dbb5810839880a3bad38162e96971e1378..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 12093 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 diff --git a/venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/euckrprober.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/euckrprober.cpython-312.pyc deleted file mode 100644 index 8dab56fb4b3ffc8dcfe5d68ff4cdef7874672c99..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1401 zcmah}&1>976n~?ym7QHXb?ao^UW`LZMcEZiE`bCS*AAt1?1q?LbQxr6Y^&B+MBq0m!rrW-@Zsc)oJvN?4?Z=T+p_c6cUlYVWrCIQ#a z-KW8y2EgC)rC$0-8GeJxG5Fw<5F+9bB6THHBGpk#T@AHJcl1)%LL+K84FU>$1-^a= zzQObpwaVp~y@qA}L-5Ta#oWE`mRBFH1exH$W-fvxUW(nYmjxL*XOy@=U6v3B0!IpPizQM!;o@_FXo~be!-B_b*->%%d?~R%-w^4N%-pAL+cozl^ z@xf7ieE?g;R}Pzw$~2!aeM|AxL+xY~?HF&Z+L*O5fJekJH^4HAOJ&`vjl$qe6 zcYA%3Ko8Mhx6DG%@|5wyq%?>FK`EE{xlB_`cqRNai@0pQnDxhKqORnrkD)qe855RL zXc-H)iU~@+(9JSRGX*tFB0*h%7>-7jv~Ss+*^b-i78n`L$yq&CH4e!^`J+4q^SS?=xfw48x%+T%?u z+W%;bk#2ppYv{?kC|)1Hso6Se{BE{injfFeeg4b(i@Dna?Z>Ip>x(b0-yLW#&4oYA z=F`ce$tTSrM!e>` z_IPvS9t+P7CHn{P*Ys8XA!`3yw=h-{&fJ*K;%R;b#du*ebmQ$Dp?e>Z+S-vZZ7F0e zOW_l^ty>dv9AvAM7L$}liJym3Z&Lb0?uM181iCO0c$^>6D^&c1`BjjGzK0E zLrN{eKR|2Q+T9WpZpx!lEJ(*9ir0s5p=kQ-c@vDObA{;bXWqYn+fc0y=SHnPyY|lY zN}esRP$rZYxLi)h*t}LFJX4KyCjTf=^+zcOzL<_SM@&?c#3c=dfz}MiUw#f%!zIcR ytnw0X%sUl0i~LixNyf8z6z3`-F#bR$(L@V6r{UBx&@SO1f)e!IuxWsIEn%y2B6;a z``>$A-faYth0#mgSokRbYCwXm@IT=^-dCX)#Ag~XaTKPe z4ZSVGlfn#%Lh~?IX#NT{1wG~Fg}ERTZ(V}W#18p`S~~K`m5&#C#6|UcJv8IPFzOQo zvtooMZQ`(+MzvPL&@>E5qc*Ch3ky+C@m=FB2uY(>>dnWiqc@88dALUq=A#AQG9^)c z9gd5d77CA=q*_*Px^MC8q43}q$lvs3 zv~NspVH7PYy|x4Hmri&Yq?Z-4+IN;aM}_F%W7W@W)LykX8MDkdL2gXDy$o}~s|e15 zv%_jIRXD^R!$L1OE$mNFX5I$+I)^#NtkF*9Q?}bME!loi3{?1xK>mp%QUj|??{)aR*|cN^bpd@dgr@F zT~ynI`R)6iYCqv`q!ps{-7pLa$}OH0Lt2k3`)stSKGw(o{3tFI>Wv!Ch=7r!OH+&@-c$1mVp6pE>@hHd`@&$c_(lEfvhT0X);l^>W{#iXBk^moYR!S8cr% z@`FTIUF24E5fmh{rNSrSTETVTO*Ch>^kTS`w2U<9HbD(Ra_ZP5_b+J&<$8xRf>yjG z+KN&TrT2wb&4KSNxg_S^QF?*Wr4i#Kad-uFln5cg;}9Hl*O5o>*Sz>{ z8V&PJUOM1qdY3c9gmUI4%JJJbH@60;G)P) z9|{kOA(+k7fIAD4iTb+~9CqT^Rv76xS3qi0^->`hmU^mB|H9&VeL8SMty z2-+^(!JM;9MvxI$Uh2)rt8U~2rVzQu9d@>A5-fc~F9?T)KbKbc&G1>;UXivhECfAN zpCR}(atQCS!^Qt$KEQH_+;0(_x9S?Wom8#mJwy5gX*RvtZFCgrYue%>SO@nRvs{?U z3;qqVE1Vl-=Y6i4L&thv8n_&8un_ZK&YmyC1zUkP7@5?n8-T0Xd}HVZmm^ieFHo8_ zWC^m!9q~MsY?+u)_ixF0@p)sJ8Adbd9~aE)g5xN@D&F6%G}FH z{~@ENTy9j!bbP0w(P41%{EF{f$i9pZQ4ufVghG^RNx zRX;LCY}s6IS6W`_=q|UD$N}1ttL6gUtv5ICZKeruLc&YyJw?@6!p|CXMB7o}75Y{q zEvzt3A(IY&MH;mpq>)@6Nhs>~_hva@#=u(XlBM6s$44yxc0)e-+}9k(${@!5$+Y zILTPjHrrzlzK3#O@V*RtgZrpzW7&me41$FoYBTybP+hZhQ`HevO#?7{5l0qE%RgKLUJQ{U&tNQ z+s>2iq$-1H^<1|m+;e<+P<=_z8HH1D#h4tz0Xlx7eyH8L>G(NvA>l`Gzk0Vla3z>W zs>u}IQW(km*NhcZ9U|ys;d%rkR11W-;Cy(O;C;tQ4EH;Id#!L-$0l3$k~^u|Od*d! z^@;QgNH9|G5#S{*^s(WuGv8Bng=xkd4I#l4;9c%gB;*S!8NOL=4?*2sV-oX=87;A7 z)caNF1)sw;r(ia4Ho0VS`5dP?kslM8J0gSdV^rD}}|v-l&d~HWO9P zFbvxBI+O7>s<@~g(UL>1pm4d(Q^K9M%up;#fxFZ4HToXBzZK@Vcu9L4=XE0THF8hD z4Ff3>hQU>QUmEl#+%2!wg8H+R?&tl1bPID*?-GSP=B^-ZtHLtjH#RDT?_0R)NSiai zI_y&;TjFbGMrML;yGwj?Pw6ezrjIf8!` zb|a|7%pvkI+yRg>Agw^opwEN!Ebkn15B)&ZTG}dv;2_FI+2OvDyP^7@!#)xIA>621 z74vy4KbiYxgh2Iz+?O`br0tHSpAa;_CI1G#E4RX07quPqP#KZ7qd76}9>`?Xfmj;q zy@+`@NGZ9w)K_wiOA4iV_o#XYK{O9_S>Zieaw7On7@LAq5oRW17zWcUec#CML9T=* zSS**1@Fzw-4ZWa*Ts3WJ&G>_YAGJMTS{YOs{c2iH!d(zvbe9dlnS{R~%}?KXav!U1 z6GkI4ue-$7yHmBkj@-OI5#+<1AHhj&`QjHi&;^}zbg869i`#@3Syiw|~5G>Gp4fr~9gZU;xuPp|B(JiwBK`tAO zk}GJ1mH5V^x~c6a%(r;AneRb%+q?zH9l1sbVxS*nnGHz4!S}nRSHUe3?$P#KE{-jK z#=I1`We5rC()@?&1RdMyYpYs}`2cfkkM}3YU(7-yC)ns0s{Rwcr}r*ZkI>)a-DiGe z9x$D084tY5syz+bE%%y1ZBWhOeHePd_f)ME{(|ovb3Xw-KubG?Ulj(^*UIpRW(3Sn z%-=fBg%=7!rf_Mw)o`Ue)C0MR!o2qQla|N$YRNqc!GXT07g+L>o5siR1mr363rJg# zCpOALT4vY%)u8A|AM=uGdk4WBO8eRJExDJN@AEpy_0xM5~AcbDS zrwU8G{%^cz%C_68q?9YIBH z4dGs)YV9s-oP9KK5mbNZ_>-w1yrbGi$1|tPW2SJd4}~UlB8|c&MRrpPLp<;T7+N zj;spBtQ8GQZG|Qle8=3r!chiYklW)aIt!CCO_+6N6i4tMEhTt)fLjpxt&JvQ9*Qpu zf~FCAOGl?ATDs6=6|Pj6=U|8JyUp;zI%2@JMD>#9fi%xmjjp#nZ?tL?Gip0~R>Sj# zd_hCn~Ey+mATcvPOTPz((4CTwyiH16mGH-xf;>g*TY77TkbplD0y& zOsSBHDW#*Y;i-jhGHIA%I+~-Zg}Ic|?crU;@&of0TwL^NLoXO%twt7nkN1eGy_QJ_ z_b!5m2%1n(#K_qo=~b_}#;3x4I$o+~P{<7Y0g>7CzTx(znBo*<1ldSww4|XaNK0j= zv}u`CXCR2K`ZZ~-NsA#Igzvh!nc;Q`9~vH0wI2oZgjrPIHL|{I#P$Hc^7`t?sv1YG zmASF>W|RAq=6s$udj!HOgr$frD*(^o4OYkjas%IXa(5aY7wN8u2U5mH&3WxS{QFE! zZJ$`-b=Sxx%*~_~Cbw@Y`^FAc1&4SgDcIy-MGfCeMr%srnHJNuv5|w>Jf|(cGU#oj zZ^Oj`iOqaKZXSjBdh_Y%0+OG|yb5t#Bd*~S41W!-iIH&-Y}An;6clt(Jx$sWz4`Q} zBx987KdLi@@9O=F_X|^sg8aZ`9p@#v@r+F5B!9TUJF3O)dkJ$~b5Gd32&$q8<^#7e zD3?J6bQEObqbkH3Y^`)5UyvN+jNxBK&TgaDs0zcaHej(;ofDQ5!6JXgw6L5RFv_X zUs2V=k-;ET!-eg=Z)?+H(43H#68Orw>1G74IYfEk>%5EBTB`R`T1oTW`J-v-xZIO;wWUK=|NmVk!rzup%(nD?naJk40^pFq)0{o}vsUvq#_?eLvv~6>+ioB-0MmA~`4hq71g@2=s zAfeOkMcT=6N>NZrML%LYUb-4@Hf0OsOxnF~fvce1DyI4xoa)Y^qKCa;z zC~YEq!JN>R*q~mhZiD;+!X1MCl}ieejHyIgUR1>u zu41l=rGt^z(I=4m27NV!{%}vx$6~6>4Z-{xlfvz5$bGBh6jM|9hQfb(huLxta7wvD z6ig772@AoOlwNX|Pbk>xILRqZ!PG)k(&-M7R$BEu8MPxbK+2-uXV5AvDdno^_z7;Z zW!|vwC#rR{r2^R`oQ$-tTsNC%DWyPCHIBx#yN{&U*{4ffYKd4$zxU#~EQ4<}CAp8KrIX8hvTCwLmbPf_GI< zI9)o0mI`0WWidCsTxnrO`@W}|RUv~yD`7P!uFkX;7Nejpa8_SV3<}yPWYac~`WnEK z3D1Zn6EjGmKN;yMZL6al^FC7oUv>oF+cLA>p{_PDay4sB0m%W83g(9$PB z&g+QHHm!B)7ax30PIRX4zmQ@Eq|ZK~?2c7?mdlreXPGwo#lMSoCl`cOg8oZOGGl=tcN zH*E{t0A4oI;$YbbGEi<5Z;g`-!BS8-NFk5mhbg@gnqUX!QMN2ZT79a1Fnp5UxJWrG&p2c~6m#1B;qnwv+pib6ee zCt~U0Bp-pihHnI~BYpi;4X-%*14YD+7(-?WjyuPf{WX{S)gpca&71IcUTD^wo? z-@!Z;OJTTCa-*4xAm#1$1#gVpVi)?Jz9`HItuD=Av21QRs-KV%r&`wAcwW>MSslFlk}G3P0%}$Y2q0t z@$yr3MB8-)MUggDEw7`PfZ8CxayiKO{1ep@%f*0X;5VT|J`yvX0 zOa<>K6RNv>_^YBaHrpwKzAQ5Rp2`YrD7?G9TWggs4ZELOY85x(D zVZc>Dsxr-NGy~sEW|fnyh5LqsM|>qQzvENB zVPsF}=!E68pP9`(B1zaTkG`%+<|X>ri6N56qd zp|COZf+m)^ta_NpwqD_99fgH{b3JM#=F#4$CNF_i+rb?(qo~3OpU*=bKZ2}7{{}M! zRc7b>oU|>xnqF&*wuGqCf^4GdD}|%fH`iO0>7`?{>ib4^l55W^=FSO__QTRU#07mV z^B;oZVKq1>{L^k*5Nu_}n46d>PknvhrM!w($U}WJ;Wprta@%>S>~`BV-Xo|MrC%66 zAnfpuQo~;xwcV!WxatmVC5U{4^cjK*UTdd93rp`u^_h)6iYQS1TJLG#blSS|I@os# z@H<9!u~BDjBS1Q;enV+(y~BCMEO>{OU8Y4x|0#k>X3Vto-DkG@E{H2;R%mvG>zksxN;l4EJ2Lx5&YAcjh803DP%@`y1A*KCkDU0fg z++W%b*e!->{hg_YTo$-v%y_uBQB5^ynrauMd#!L@$IK8CtfT5J;Fhj20$*Lre1>JK z+!ECvu*6ioE3ClVhw2vQtib(UGM0laSKR`alE`+d-y-;&w_jT|ODCc4V};3ZH!WCS zm>J8vz=@E4>jqzH%d4XR<^#ekzym;XAh^m@0=`Lj0^WZ*67ud)Ro&cQX)fc~HH6s= zdWLiaf_m2fNXKh%QLZ*ZxB@|G(%SJ3Qcx4YA>KeT4)cyMN10RFMgq^b+vzY2Muis- z+Bo|yxvuCh5LuR>$~p>I>n^^p^iH9w8{E$d#f9~WJZ8o=t9DmCY=y7n66+m_s)s^3 z%t=D3;4gFEx55bo(=B*hM-nUzeCaecb+$LTp|k9lr>RVE&c&1_ifG8_N67pdG?t2!=BaJ;jH- z-?hc^C@F!*xqS;GTQZOFr7|Nm+$&}^(-z+&nyctoVue;rGKKL>Pq=F!Pq0*XjmvV$ zOiQHgXW>)TeP;Z|o1nLb~TFiV)!A?^de@1Z^he&L8+U3>(Bk&%;_cGmD8fu9TiU|N~hn)y>Wp2)v=?XjHG zaSZ9-atY}B7{McVdEmP3s4vMBkh_TBV7O-9msGBE(^a_&559^`^Cc&pZO4^391TVZ_qOG6fW6R?hfyJ-uw7o(@`DYXd~Mr zeO>M&EL$xz)LK_`Ow@bZ$Y11+^V(w>0sOTvf!+>s33;ROwX(u@I*!frm%1JsnOjIS$}!su%#e5|)QeQ)x%V5y2UKB{iODajpUWEa)C z&Xh`Sl#cPhNl~>jt)6NNe3K~cj^GDjeTA01ZkQ*l_E7D~G*IouYft#UrX@0M3f%ON zIe6)u4dI$uCN%|bGH;ms9_F`sPi=XPwkfhx2c6 zMOC8UE!DJ4I;J;$>3My4vBS2Y8_w=7k?x4f+aeh3Y*YU z+;{(zj*P&|?ADk1a@02k>1*20AQiP$Roxw$UiC|Q1}>AiWA*k_=x5qasxm7)0?ES5%CvIM{vaDIolWk6`(@|#rG9{F4&mDh zIeEF5X^zuT?k%LlEtr-!UEw?I*UbI;%k?#_tlSNQ#+sW~$7ECkX&wMK6z*5I8U#E@;iis!z#j-3DdaID76mc2 zO~H~MkeM-h+W-F>|=Kd~x&4cD5_dOk(c!jl$GZnWN_ykg8uPtid~E4`1+ zy=_`+VR4Xu(Pu|>0xo$tHyGo|QczHW+`*BTuXej$=!--m%=#U z4-`sbo(5Nn_b!u3H7jsw;Xh^!qcok~{}jq7bPzrPegi>SxsFt&vdlC}@6vLQNeME? z3cFSB%cZyAQv}1&mqSpVslXgVpAXB2s_k^t^~ebo?qj*eYwK3;tIj8FJicta*U_(~ z{<5}Dy+SEV`_FDf&7d^B>RhTS8W~eqiT5M=c?usHei^uvw#?{jS!M!nI&TKEz{sCK zDkCUG_z1mKgxOWA@_y5n3ho(wA9$H+3b{!8-k_1%+S_Q2w(6=KgpE`eGCw1jh^nK) z3AxAk9`K@}N`iTv3)Mi7ipb89bB4KKp0Bg9@Dp2h1WwAl=?2Li>|-)Ip>G%Y2>|Xa zd}i)u;P(}}$kjAsu-py9=OdVDWG#jCWR!H%NqT=GGCGqw%ms&O$*rxnjwpN^g*Sxl z&FF9VZ41`MSBJTabR^s!%=7ILA8vvbQoGPgkcA+fNE>CN1#rz3I$-X|EDGfYxyeXv ztzojh;Q_9H6a(6HvF>;YXKT=;^+k3)ts$&q0Wp1MHhajuo-s`ei24+~?y7(4Xr($)M|U$?3)?WAY0eg5LEl!cU8F!pYFj2obsJh!_*_UJ~JI(SJ$`;JVO|bH`SKE(VWu?>zFp=_C?T- znSyyLv&af@$$gi!%5V+PccSGOb1NhWHaX`FVJq|#&`;x4XZj;8t@j100m9Gl4di|7 zB-5?>nAgijGlYLL-K>yDp*wGojvNZ>FmJU{4~4Cmr@}2}s+iW6nWAtfqB(LfW)#Rw zEDfz+L-+ya#r7S{8^ZL&{5hqy!p944+Oju&b&)>Sn3qC?rsV=zfuKKvvgaK z7U@(3Kf&d}T$-0abpr573ew08u;n4SmD*AfenXfa-(bV1p^78?M%!SJf!ekS?-Dc} zWRTn(f@TP3G7H?`XRGcv?O)zYf`(w81u|F18%CbOTt>&Qs47No?>PSven{c5!ce_$ zDYU@1oHrZQ9Oe^(<{|xr`Ptl~c57!wO5Qz#KB0b<6Zb)1*0e2V#I@>Zq{9rFi*!41 zX4B>ge+79$O9E8G5uA>Ys?Im}scLDtv__T(nNL~)gXY8K!nc68kXgi(rQkF4bDU`( zND>|U5qy9uIW3EUQ}9wp_;{~$EHGoWwYs2MNbif!W@x7 z)DLF%8u<^%f3z$_l@R1Hk;`?gU{*4}>1bna41%5sUkJ;1g{9htyJ<4jB44Qv zvFc^7@LxnE+%VN>3Re`ip&t)C4Z()UHOO6JkD+keL3S_;^hTF^$J|MjKH<&7{I=?J z!t?O{pm`~l^&wwS-M%}q>|(|lzMHqmGH+=+LqQ^>70CEfZVyOdVLvnG+2aejz05vl zKXV_;DO$da6bvt`qoUrA-DMdqDI?OXP}S@IV#Zlo{*+q|vV!?bcmUNXy$5-Rn3bxB zc}JKySXRjm(@}te)xsFU9+s(SsBXb;gx@ls8s0=l95YVIZSbI{d1DZ)rTL7oHG;8nXNBjO0~F*nBOmj( zJz}BCrEQ~W8}Usde4O4jMs7h>P;MJs6yY)To=19G;R0_4`l(pTBmI(hQ0{kLUhjJm z?h>=vhdJJiUqL=my{wQ1-zFX361mmz?dHxi_dAeRUVnWANA7&RYbpI+b%Vkc-WhLH zAJthX2wTI7cmnRhRD?<@(AxqNDzGLLvM-nDZUy6T{Y+|ubkXA z;Cu#shIxiV%)+uBq>_!&%MEwG{BY&)O)_$!@CSUK>pes163<;uM>3{?Wv+p&2f2^0 zE8K_pwpi=BY7Kk5kh>v#3i8+y|4`T(;(|+-nXK@Rx%1KYU?$UYQ`<)fdRXg2gKkA~ zydSBGrCLDmZG|b?epH>x+dyAzkeL>oCbtNQ?aA7Ug8Nxz#dmxwA3J-Z3dacdESHe-=?QbGSllF@FN8y3qSRr3iTczTyLjRxM{ir@d@QmE#cH6@H3Bhu5pOG8g zwA6afsjfzlSv4DiHxz==oX*?{_9zA%9qG^Lx9X^)BRxnDVS2q8m@}qj zc}Nr>!u%A`n0*-5X4el?%iVZp1F8#;J2BB zZgm*TclNEM_mJE=RCz#VVp+?i(fcXfK~#x(HRbZc_vq$ z;p&DL3U2%4UsElnP@Fk}xdiVhuOx4keSdJ%Qo^rv95Lf7T8>4uD9mt!Fdu^~ zWh!ERo!m;iNx)gmn9N&YMj2*`urkO(TfQ);im(N6WmKCz%2c>tge?`aGTV(jZbnrd zW$~pT=vTPkUFaOSRgpfW`D@@E29*P@rtQ9t^1}C!*3$MT$b5y9p6s}*tpusABQ^R2 zsNPWBLf;$ojnNw=R|9St+#{r`^u`g^RH((YQmDl4&lS26uwylT3>+7tHrje*@CNjFxciZBz}_cGKFB@rh~{Bj0h7_uvv?X~o+C z*OSuMtaS$DTcoF$#Bi4ZHU;kse^NavT&|BtJ&b}OV-cno|-;Z0#u!#n70?HMbZ+fkT7TS|Xw`37XB6_W9GDD1)43GR!C zaJ|JGB9)GK%tcR|k-jyNm(g2=7Y8o6urq?ZE_9Zl)Y>xXNTGU8t_#R0n)|qTDWt1S z+iUJAxP824o?=d9BrmRxuXwZ2M`7v8>@edz=F@u9S*x2ucjkh^75YA8ddO9!xvh~s zg@di%o5&gNcU0I*p$vUHBURxU^nG}*oADWG>j>&AchR7BNUtl*M77@@{Z#uinavo$ z8|E!9=_rf-4a|SZ#T5<&`BLw43hr6(GVocrjv%w$;JNA`;18I=%mHl&nH8!x=^LUj zlqu&1!+7UV?QzrL!a1aUA)H0{4Y+KU=|@#cBO6%y5axV_ALi9Iqb#%5O}``ZLwp$! z907SB%SUqGtCj;kf#8^tFW@qm@f&kg$1gf2gIv*Zl{ruDh=_347|B~_|3V}8|p3%I7XPvmY3=kv12-4Whpj`^tP$z3w& z9MT1F3zPMxklw{t!%4n!rZ?qk8NLtS9D|N4Y{Rmh*}?1#O`TjZuV$>= zxMHKGZ5lPNSG{8ST5T#-Z`i0o^$Lv}Rj*s8O@s2`|6NV;e~9uGYE^F2uzHKiS5yCQ zred}74cauS+ono`%JtjSZBVIlgLTpT#~7o%=$gMvuO1!q_ifi9s%P)0zP$zv$zQ2s zzi$0|_0C_u@4$9F^OmnyJ#WSCQTYdU>^U%h_o(;t_a5B8ORt`V@)anUzh6}Uj(K~x zYu~M1=Z^jI_m1kFzfB11(5r9$_FdZb?a;A*{*D9M_aD@$Z^u6QdJldP@7*4~It=LE zu}t6i;Ss|BMf0cFXis8Bj~@L=_^U?NoM)qDd=e*GiqvPLC3zC3e(ba{&P7YzH*Sdh EAID?e0ssI2 diff --git a/venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/euctwprober.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/euctwprober.cpython-312.pyc deleted file mode 100644 index 0114dcc7575382dd8df4835af1a836d93a8b7cc9..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1401 zcmah}&1>976n~?ym7QHXb>n2+UW`LZMcEZiE`bCS*AAs6b^~?^=rYLC*jA&jjz&&) z@xcc}*U*qtagMzP_dn^SB{{UhhC)xhnQjarr@oO^$>!7ny?J_X-pBlYPx`ghngm=w zcb^7-8UTOGmwM?VW%xBJN8p1`LWqb%h}4x(iBv}|bv4u?-O)>33yrAZGzcj0CHVRQ z_y*ID)hd@`_8OM?55YH!6mxgKUEX-G5@do0o4E**cqw+nUKV8NoLNr%Al_aVu3)RK zw-dw+t(RBxPy}D}1Y6#5`8pH#d9ukkdZx-`bbXbsezS7-o;PZ~+(y-5cn@EHz`HPT zh!2k9>jT&#zH-oXRHpfa>064g9%#p-XvcVK)yAxi0X!y-xek_5Tqx^SZ4?G)BImIu zFIX>GTt34Ail4|4h}r{(WDlMo%yl^eq6QrV(owDBQMNsxT5S^-YORh%@7sty_-?xP zzuW7R1bT@6nq?MxmZyvtCZ$0f2uiuk&t;lo!YkpYS;S@Y#jHO@6Llp|eGJt(%b2i~ zLd#gVRZLLog>IHnnkg7HzyBt*can(N+(k0efG2t1USZiok)-w#-*w~8(*3VG%VA*e zvUt}HgH1c_iJc_A(f$0oodtq*QrCOvZnMlzgVd&Y%ul%OA^ScPHp@NnC@p88oA!7U zi}o*#G19HCb`?EY7scy+I5As?jo;1oOY@_XxzB!Cdog!wp#3;?a&7U&wL1gtrMd8j z*?c;AIQgVG#0YqgPH8CVlvo`>k66lD-@uZcjR()+IpG)4o=M8)`3%aUDSJhbXzWI; z-yUyn++*R{p=5s_{+hnRKSb?+>lVg_8$5DjK8vUMWfbFu&CrdvbA;}FL~3hC#$Z?RZQd&$>8YO-nO1(+x_qiKZo)YN7MBs6LM6Xcs6XsWBu8&a^t$@BWovgzOt>kJO0ggvizr?nz`3I7vu8~(rp^?ix1V|c0&YXKHk=u?_U!6A z*DHCpyh52!Uf^Om9b@xajqpr0(wY3DMAaXq9Qa~7+8i-aO%j(h6b4!|9Dn&aR1KFX zOR&mIyfJTA;4Jb_&?Xtr=24ufgpl)_KyIGG^;5WU3Jb4{7HR)B^XWO@UiSJQQan%8 diff --git a/venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/gb2312freq.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/gb2312freq.cpython-312.pyc deleted file mode 100644 index d7d9e4a5084b43814d9b7072cc94d8d2cecda31d..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 19137 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 diff --git a/venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/gb2312prober.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/gb2312prober.cpython-312.pyc deleted file mode 100644 index 70aca46360d168175c4b6b2eef732a678f63e81f..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1414 zcmah}&1>976n~?ymEGMqad6^IFD51dQM@AdrG=2xu}f%)oq%t;3|eVyE74bHW=+@l z;DaG+XvnEJ$6kZ`pY+m_9Ez}Mp{L$VH-?Z?-$<)ulS>Em=FNNaK7ViYYpXR0xPIclmJ)lM{lb_XGZHwCX7JKk`s@8wl z>zf4n2*A2y7pCatj2AYgQ5s1~x$@7In_?m;0iYt`D*0k290Q8_3aMQ*H8~SZI$B`} z7H<|4lm@Xc1f@bltGWGmiMyR8%;i49nMXY9?YgT>Jds)MF7q8fU08nf?ZQeNxjQV~ zapS1#=6$)HrAwV#i>`}&hlN&Aam9=>Yd9vDAfIJt56)s5wW@!G!rhuwTW zc{us3IYbNi2v8*`0ae{Pfvj_y2(#E9!9w#;@RYepR^`3vI`Ky4Az>ebSU#yrAyaA!o~wj>acY zy6#Me3R1edwyJL%8nN{B7l=5`-P6rna`?JK1WitMgtMBIHuGg z{E`Z&68yUC4Y$=*MXoEw9VBlL;9N7znX@KX7tSA;uEjY7AT>HhmQngFf z8@$^tODG+x0xp(wGB&x@Fi%&*E!5v7ss1kI=oeE-cLYc^Qe3sBuuv-SA*hE@C0zDe y;Zqjz&c0nW=MKM#GF6?JLvp4QLe9Sg^3^FUp2E^8%)hZ(r2X4v=Nxb^bNvsC)K6Xj diff --git a/venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/hebrewprober.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/hebrewprober.cpython-312.pyc deleted file mode 100644 index fd9d7773e42a16220965b84ae5ab7075bff0a571..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 5833 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 diff --git a/venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/jisfreq.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/jisfreq.cpython-312.pyc deleted file mode 100644 index 2d61dd805579f835b0a7b909e71a78858193ed9f..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 22166 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 yfA9Y~(xu diff --git a/venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/johabfreq.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/johabfreq.cpython-312.pyc deleted file mode 100644 index ad420a092b8e5b4318365623d70603d6961effc3..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 83014 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

`P!75h<)SJm4^>6^ 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 diff --git a/venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/langbulgarianmodel.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/langbulgarianmodel.cpython-312.pyc deleted file mode 100644 index 5c2160331dd724ff264f57f6ee78976e67403428..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 83133 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 diff --git a/venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/langgreekmodel.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_vendor/chardet/__pycache__/langgreekmodel.cpython-312.pyc deleted file mode 100644 index 3eb459f47adc228db8a50873d8645fdc0408d79e..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 76999 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 GNBd-|t_1{(!wDfm(>CQ#IW;145l#mw3;O;MLA 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 z zQ@8k3gZrm-PSiI>F-?}mgAK4HxFkOhJ&U?MVN2TQ?L1fU7p7_P?>j1%kSq{cpO=q7 zrbXaz3%ggQOj|ak(k5Ge1$Mz!8(|)Cn&M0M9oNgg5bglj3?Ib4p{=nziXYgRC(!~c z@@0W@QzRIF6)QIf7*}go=Bhmb@q|iS4!Wd)iB}D9zsBqS%;`x8tCpTo#}zFnkYele z=$qmGhokV0<+K{E8KV9U$mz|j-wa5FO~*i`2$Q;nMmRO#GumJRg(lQi>Yy!SY@{ma zZxD1Ol*!omoNkLFTuZoYj_nqW5J!2V7$Cpi0Qq23gBweGIoG|>UU^_x3Y4^0QLr8J zk?YC-aE<=lA9y`-F|z0?`nQ#U$A*`lUE93nE+_aQ{%b95S94c#t1UYVEjyPVyVbI5 zt*PyUw(#=IU*xXkifvzlfY%RSKDgE@t+oynTFEJB9V#{rLAvXQ?>Ir^6FX>rLWJ*7 z@wtXH0(ZW1)W!d3q;6!N{pOGx^_%;|QPKH6??k;uyb0xP$8Y`bP#DVg*NHbAU&|r> zVga8Qm~aXZd6EnqWl-aUNl9vtk@xnBy?E|=54e^;OJu0y@-*uj;SS%K_-so zYef81eF?1exzw-Yq>_qPqg0SY>2CBJeyHxXs_-!DBJs>o76Tnq)wF8JmZM5ZGdib; zgv*$ZxDf$-jr<=&t~L}a+~l_rD;h@B#!-~T>Hx&5B-q`Jw_Bvumi|IZ|MCmPmd6&3 zKx=O5UV35qY_Vw%B*)#qaB!_5wA#>JXy{&&iwzGIeGfr$-2I>46S?5#)j&@n&_e?o zKkzk_(9!t0)`R<;_m4>Y7mqUPv(ou*L(O1Cboi$o-r*sOTc&Nj$ z^gQB!h^<$`gcfYHGC?2$x>_0`Km;6t;wxcB6+zrH1i6*_?@&z!H$uE~PNE1YkOaW= zr~-sd^J3ZlGI;~m8wguTA{YyJU(Q7#zGIOq2Vq#mS3^ERLhMw-00bzfloUdf1e%GT z3B)7mDJ8TZ)@tk*bXt_|UlMvocm<3y@)qzUW~b8d2~s_P{0cyOJX-~t5$++wz>I({ z#x-beRiTD$RCH32K+$KbY~O0MsJktNk!#;b;alC`1Qm^xi3yE-bu7KH|Kk3|&@FH0 zTFaKzmVrXc!17eFW%sIY_lj@#ZLgKdxaIA6U_`;UyJY8ly(s*9KK+6_V*|*aCdAT(Nzj@jiE*NYG`L6v~xAIyAay_ zZs@(zz)12WOy(^C&E9^Q>Q-(_+ zkJxW?^jCNEmqI>q&k|hN-JF6jiQsc{z4WLC^CvU4d z#xC=D?hlcX|6{vsmjzjT$8nuZF%BLEtpYdAa<--%bOGKtu@LV0H0If+CDU=HmUZAMWk zZme!cQ610U6s6rC1t(FH0c>xT4Ab{%D1qv8+|Px&wR&kOwB%VHTnT(>t?5f^!REEP z#{YJUqJyo~IL29r84Fsc-Bg{oQ;@f#5V&lU?a0|v7EV+g$iX=$Y_eFD!FQpRSKNxn z7;ntMD3+r$9baVdZ1@VmPraB=dAd5;r3h$smsV3WWn(^2}&5p9A`S$jwmBwDx7)rS1TO0vvN&UceGL?OEi?=7LuvWTNZ@x zdW{8y&9M#=EGAsEL9c?RJom*W_j-BuNrOQ+{dR3mW9kwDY#&c()i2#CD-$v7|6F4= zgXP9Q!7VlNJ+0`= z7MArJIH~t9tL~Xl(@A6LbIsMvSK8mk#Io3a>?j^DZut62s*)>|=!4xtKeBhUjJJPw!4hFFa${vc%@m2?uo4Oa_p zFk>S)WF@9R8MbfUUcuBxDNQ#_yUT-6PBVwiewCQ zbzgO`fGvhb%uCWa134VVMQ*VAjhmk{nF6sv)RB^I8VT5^Oa$O-H+nt}wyg!WtOj-# z0y}SopLkCwhR1#u7=s_=-+af80Y)(L8(lp>RC+U$JAl<%*;Bs?qF|k9GiJ%?sbqN#P{;7x zMY_C9#eD!SPi<7ZiJ$gu6c@OXjThS%rXN*u0lympsP<)NsRJT7s#0_bp2YI2C%mjLx}T7F^Wu|tJ{ z!}sWdEd^t)ZvY5>CWQnYz7#=f&HQqy5<7Yroa;`?9RpYyzQQpyspqNKM#U73aAfBw zS#7KgTPU_}Q&!{jdjPLmpno6ddNqTwM197Y{edVRHWv4fzx84`- z!gnzVEo^*U<);B#YX`8~gsagQ1y=O-jYd&s2alv^#@A@hsF6ltsdR?-jm$db*mVaJ zd5t*)x*LLgoMqY#Nh58+dJn;O7T<}9~^M_pBhn$<09##hbg&SGrMt;E^#s5cK|3}uc3qAetGb}IGmWU{V#q> Bh7 None: - self.dist = dist - self.reason = reason - - def __str__(self) -> str: - return f"Bad metadata in {self.dist} ({self.reason})" - - -class BasePath(Protocol): - """A protocol that various path objects conform. - - This exists because importlib.metadata uses both ``pathlib.Path`` and - ``zipfile.Path``, and we need a common base for type hints (Union does not - work well since ``zipfile.Path`` is too new for our linter setup). - - This does not mean to be exhaustive, but only contains things that present - in both classes *that we need*. - """ - - @property - def name(self) -> str: - raise NotImplementedError() - - @property - def parent(self) -> "BasePath": - raise NotImplementedError() - - -def get_info_location(d: importlib.metadata.Distribution) -> Optional[BasePath]: - """Find the path to the distribution's metadata directory. - - HACK: This relies on importlib.metadata's private ``_path`` attribute. Not - all distributions exist on disk, so importlib.metadata is correct to not - expose the attribute as public. But pip's code base is old and not as clean, - so we do this to avoid having to rewrite too many things. Hopefully we can - eliminate this some day. - """ - return getattr(d, "_path", None) - - -def get_dist_name(dist: importlib.metadata.Distribution) -> str: - """Get the distribution's project name. - - The ``name`` attribute is only available in Python 3.10 or later. We are - targeting exactly that, but Mypy does not know this. - """ - name = cast(Any, dist).name - if not isinstance(name, str): - raise BadMetadata(dist, reason="invalid metadata entry 'name'") - return name diff --git a/venv/lib/python3.12/site-packages/pip/_internal/metadata/importlib/_dists.py b/venv/lib/python3.12/site-packages/pip/_internal/metadata/importlib/_dists.py deleted file mode 100644 index 26370fa..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/metadata/importlib/_dists.py +++ /dev/null @@ -1,227 +0,0 @@ -import email.message -import importlib.metadata -import os -import pathlib -import zipfile -from typing import ( - Collection, - Dict, - Iterable, - Iterator, - Mapping, - Optional, - Sequence, - cast, -) - -from pip._vendor.packaging.requirements import Requirement -from pip._vendor.packaging.utils import NormalizedName, canonicalize_name -from pip._vendor.packaging.version import parse as parse_version - -from pip._internal.exceptions import InvalidWheel, UnsupportedWheel -from pip._internal.metadata.base import ( - BaseDistribution, - BaseEntryPoint, - DistributionVersion, - InfoPath, - Wheel, -) -from pip._internal.utils.misc import normalize_path -from pip._internal.utils.temp_dir import TempDirectory -from pip._internal.utils.wheel import parse_wheel, read_wheel_metadata_file - -from ._compat import BasePath, get_dist_name - - -class WheelDistribution(importlib.metadata.Distribution): - """An ``importlib.metadata.Distribution`` read from a wheel. - - Although ``importlib.metadata.PathDistribution`` accepts ``zipfile.Path``, - its implementation is too "lazy" for pip's needs (we can't keep the ZipFile - handle open for the entire lifetime of the distribution object). - - This implementation eagerly reads the entire metadata directory into the - memory instead, and operates from that. - """ - - def __init__( - self, - files: Mapping[pathlib.PurePosixPath, bytes], - info_location: pathlib.PurePosixPath, - ) -> None: - self._files = files - self.info_location = info_location - - @classmethod - def from_zipfile( - cls, - zf: zipfile.ZipFile, - name: str, - location: str, - ) -> "WheelDistribution": - info_dir, _ = parse_wheel(zf, name) - paths = ( - (name, pathlib.PurePosixPath(name.split("/", 1)[-1])) - for name in zf.namelist() - if name.startswith(f"{info_dir}/") - ) - files = { - relpath: read_wheel_metadata_file(zf, fullpath) - for fullpath, relpath in paths - } - info_location = pathlib.PurePosixPath(location, info_dir) - return cls(files, info_location) - - def iterdir(self, path: InfoPath) -> Iterator[pathlib.PurePosixPath]: - # Only allow iterating through the metadata directory. - if pathlib.PurePosixPath(str(path)) in self._files: - return iter(self._files) - raise FileNotFoundError(path) - - def read_text(self, filename: str) -> Optional[str]: - try: - data = self._files[pathlib.PurePosixPath(filename)] - except KeyError: - return None - try: - text = data.decode("utf-8") - except UnicodeDecodeError as e: - wheel = self.info_location.parent - error = f"Error decoding metadata for {wheel}: {e} in {filename} file" - raise UnsupportedWheel(error) - return text - - -class Distribution(BaseDistribution): - def __init__( - self, - dist: importlib.metadata.Distribution, - info_location: Optional[BasePath], - installed_location: Optional[BasePath], - ) -> None: - self._dist = dist - self._info_location = info_location - self._installed_location = installed_location - - @classmethod - def from_directory(cls, directory: str) -> BaseDistribution: - info_location = pathlib.Path(directory) - dist = importlib.metadata.Distribution.at(info_location) - return cls(dist, info_location, info_location.parent) - - @classmethod - def from_metadata_file_contents( - cls, - metadata_contents: bytes, - filename: str, - project_name: str, - ) -> BaseDistribution: - # Generate temp dir to contain the metadata file, and write the file contents. - temp_dir = pathlib.Path( - TempDirectory(kind="metadata", globally_managed=True).path - ) - metadata_path = temp_dir / "METADATA" - metadata_path.write_bytes(metadata_contents) - # Construct dist pointing to the newly created directory. - dist = importlib.metadata.Distribution.at(metadata_path.parent) - return cls(dist, metadata_path.parent, None) - - @classmethod - def from_wheel(cls, wheel: Wheel, name: str) -> BaseDistribution: - try: - with wheel.as_zipfile() as zf: - dist = WheelDistribution.from_zipfile(zf, name, wheel.location) - except zipfile.BadZipFile as e: - raise InvalidWheel(wheel.location, name) from e - except UnsupportedWheel as e: - raise UnsupportedWheel(f"{name} has an invalid wheel, {e}") - return cls(dist, dist.info_location, pathlib.PurePosixPath(wheel.location)) - - @property - def location(self) -> Optional[str]: - if self._info_location is None: - return None - return str(self._info_location.parent) - - @property - def info_location(self) -> Optional[str]: - if self._info_location is None: - return None - return str(self._info_location) - - @property - def installed_location(self) -> Optional[str]: - if self._installed_location is None: - return None - return normalize_path(str(self._installed_location)) - - def _get_dist_name_from_location(self) -> Optional[str]: - """Try to get the name from the metadata directory name. - - This is much faster than reading metadata. - """ - if self._info_location is None: - return None - stem, suffix = os.path.splitext(self._info_location.name) - if suffix not in (".dist-info", ".egg-info"): - return None - return stem.split("-", 1)[0] - - @property - def canonical_name(self) -> NormalizedName: - name = self._get_dist_name_from_location() or get_dist_name(self._dist) - return canonicalize_name(name) - - @property - def version(self) -> DistributionVersion: - return parse_version(self._dist.version) - - def is_file(self, path: InfoPath) -> bool: - return self._dist.read_text(str(path)) is not None - - def iter_distutils_script_names(self) -> Iterator[str]: - # A distutils installation is always "flat" (not in e.g. egg form), so - # if this distribution's info location is NOT a pathlib.Path (but e.g. - # zipfile.Path), it can never contain any distutils scripts. - if not isinstance(self._info_location, pathlib.Path): - return - for child in self._info_location.joinpath("scripts").iterdir(): - yield child.name - - def read_text(self, path: InfoPath) -> str: - content = self._dist.read_text(str(path)) - if content is None: - raise FileNotFoundError(path) - return content - - def iter_entry_points(self) -> Iterable[BaseEntryPoint]: - # importlib.metadata's EntryPoint structure sasitfies BaseEntryPoint. - return self._dist.entry_points - - def _metadata_impl(self) -> email.message.Message: - # From Python 3.10+, importlib.metadata declares PackageMetadata as the - # return type. This protocol is unfortunately a disaster now and misses - # a ton of fields that we need, including get() and get_payload(). We - # rely on the implementation that the object is actually a Message now, - # until upstream can improve the protocol. (python/cpython#94952) - return cast(email.message.Message, self._dist.metadata) - - def iter_provided_extras(self) -> Iterable[str]: - return self.metadata.get_all("Provides-Extra", []) - - def is_extra_provided(self, extra: str) -> bool: - return any( - canonicalize_name(provided_extra) == canonicalize_name(extra) - for provided_extra in self.metadata.get_all("Provides-Extra", []) - ) - - def iter_dependencies(self, extras: Collection[str] = ()) -> Iterable[Requirement]: - contexts: Sequence[Dict[str, str]] = [{"extra": e} for e in extras] - for req_string in self.metadata.get_all("Requires-Dist", []): - req = Requirement(req_string) - if not req.marker: - yield req - elif not extras and req.marker.evaluate({"extra": ""}): - yield req - elif any(req.marker.evaluate(context) for context in contexts): - yield req diff --git a/venv/lib/python3.12/site-packages/pip/_internal/metadata/importlib/_envs.py b/venv/lib/python3.12/site-packages/pip/_internal/metadata/importlib/_envs.py deleted file mode 100644 index 048dc55..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/metadata/importlib/_envs.py +++ /dev/null @@ -1,189 +0,0 @@ -import functools -import importlib.metadata -import logging -import os -import pathlib -import sys -import zipfile -import zipimport -from typing import Iterator, List, Optional, Sequence, Set, Tuple - -from pip._vendor.packaging.utils import NormalizedName, canonicalize_name - -from pip._internal.metadata.base import BaseDistribution, BaseEnvironment -from pip._internal.models.wheel import Wheel -from pip._internal.utils.deprecation import deprecated -from pip._internal.utils.filetypes import WHEEL_EXTENSION - -from ._compat import BadMetadata, BasePath, get_dist_name, get_info_location -from ._dists import Distribution - -logger = logging.getLogger(__name__) - - -def _looks_like_wheel(location: str) -> bool: - if not location.endswith(WHEEL_EXTENSION): - return False - if not os.path.isfile(location): - return False - if not Wheel.wheel_file_re.match(os.path.basename(location)): - return False - return zipfile.is_zipfile(location) - - -class _DistributionFinder: - """Finder to locate distributions. - - The main purpose of this class is to memoize found distributions' names, so - only one distribution is returned for each package name. At lot of pip code - assumes this (because it is setuptools's behavior), and not doing the same - can potentially cause a distribution in lower precedence path to override a - higher precedence one if the caller is not careful. - - Eventually we probably want to make it possible to see lower precedence - installations as well. It's useful feature, after all. - """ - - FoundResult = Tuple[importlib.metadata.Distribution, Optional[BasePath]] - - def __init__(self) -> None: - self._found_names: Set[NormalizedName] = set() - - def _find_impl(self, location: str) -> Iterator[FoundResult]: - """Find distributions in a location.""" - # Skip looking inside a wheel. Since a package inside a wheel is not - # always valid (due to .data directories etc.), its .dist-info entry - # should not be considered an installed distribution. - if _looks_like_wheel(location): - return - # To know exactly where we find a distribution, we have to feed in the - # paths one by one, instead of dumping the list to importlib.metadata. - for dist in importlib.metadata.distributions(path=[location]): - info_location = get_info_location(dist) - try: - raw_name = get_dist_name(dist) - except BadMetadata as e: - logger.warning("Skipping %s due to %s", info_location, e.reason) - continue - normalized_name = canonicalize_name(raw_name) - if normalized_name in self._found_names: - continue - self._found_names.add(normalized_name) - yield dist, info_location - - def find(self, location: str) -> Iterator[BaseDistribution]: - """Find distributions in a location. - - The path can be either a directory, or a ZIP archive. - """ - for dist, info_location in self._find_impl(location): - if info_location is None: - installed_location: Optional[BasePath] = None - else: - installed_location = info_location.parent - yield Distribution(dist, info_location, installed_location) - - def find_linked(self, location: str) -> Iterator[BaseDistribution]: - """Read location in egg-link files and return distributions in there. - - The path should be a directory; otherwise this returns nothing. This - follows how setuptools does this for compatibility. The first non-empty - line in the egg-link is read as a path (resolved against the egg-link's - containing directory if relative). Distributions found at that linked - location are returned. - """ - path = pathlib.Path(location) - if not path.is_dir(): - return - for child in path.iterdir(): - if child.suffix != ".egg-link": - continue - with child.open() as f: - lines = (line.strip() for line in f) - target_rel = next((line for line in lines if line), "") - if not target_rel: - continue - target_location = str(path.joinpath(target_rel)) - for dist, info_location in self._find_impl(target_location): - yield Distribution(dist, info_location, path) - - def _find_eggs_in_dir(self, location: str) -> Iterator[BaseDistribution]: - from pip._vendor.pkg_resources import find_distributions - - from pip._internal.metadata import pkg_resources as legacy - - with os.scandir(location) as it: - for entry in it: - if not entry.name.endswith(".egg"): - continue - for dist in find_distributions(entry.path): - yield legacy.Distribution(dist) - - def _find_eggs_in_zip(self, location: str) -> Iterator[BaseDistribution]: - from pip._vendor.pkg_resources import find_eggs_in_zip - - from pip._internal.metadata import pkg_resources as legacy - - try: - importer = zipimport.zipimporter(location) - except zipimport.ZipImportError: - return - for dist in find_eggs_in_zip(importer, location): - yield legacy.Distribution(dist) - - def find_eggs(self, location: str) -> Iterator[BaseDistribution]: - """Find eggs in a location. - - This actually uses the old *pkg_resources* backend. We likely want to - deprecate this so we can eventually remove the *pkg_resources* - dependency entirely. Before that, this should first emit a deprecation - warning for some versions when using the fallback since importing - *pkg_resources* is slow for those who don't need it. - """ - if os.path.isdir(location): - yield from self._find_eggs_in_dir(location) - if zipfile.is_zipfile(location): - yield from self._find_eggs_in_zip(location) - - -@functools.lru_cache(maxsize=None) # Warn a distribution exactly once. -def _emit_egg_deprecation(location: Optional[str]) -> None: - deprecated( - reason=f"Loading egg at {location} is deprecated.", - replacement="to use pip for package installation.", - gone_in="24.3", - issue=12330, - ) - - -class Environment(BaseEnvironment): - def __init__(self, paths: Sequence[str]) -> None: - self._paths = paths - - @classmethod - def default(cls) -> BaseEnvironment: - return cls(sys.path) - - @classmethod - def from_paths(cls, paths: Optional[List[str]]) -> BaseEnvironment: - if paths is None: - return cls(sys.path) - return cls(paths) - - def _iter_distributions(self) -> Iterator[BaseDistribution]: - finder = _DistributionFinder() - for location in self._paths: - yield from finder.find(location) - for dist in finder.find_eggs(location): - _emit_egg_deprecation(dist.location) - yield dist - # This must go last because that's how pkg_resources tie-breaks. - yield from finder.find_linked(location) - - def get_distribution(self, name: str) -> Optional[BaseDistribution]: - matches = ( - distribution - for distribution in self.iter_all_distributions() - if distribution.canonical_name == canonicalize_name(name) - ) - return next(matches, None) diff --git a/venv/lib/python3.12/site-packages/pip/_internal/metadata/pkg_resources.py b/venv/lib/python3.12/site-packages/pip/_internal/metadata/pkg_resources.py deleted file mode 100644 index bb11e5b..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/metadata/pkg_resources.py +++ /dev/null @@ -1,278 +0,0 @@ -import email.message -import email.parser -import logging -import os -import zipfile -from typing import Collection, Iterable, Iterator, List, Mapping, NamedTuple, Optional - -from pip._vendor import pkg_resources -from pip._vendor.packaging.requirements import Requirement -from pip._vendor.packaging.utils import NormalizedName, canonicalize_name -from pip._vendor.packaging.version import parse as parse_version - -from pip._internal.exceptions import InvalidWheel, NoneMetadataError, UnsupportedWheel -from pip._internal.utils.egg_link import egg_link_path_from_location -from pip._internal.utils.misc import display_path, normalize_path -from pip._internal.utils.wheel import parse_wheel, read_wheel_metadata_file - -from .base import ( - BaseDistribution, - BaseEntryPoint, - BaseEnvironment, - DistributionVersion, - InfoPath, - Wheel, -) - -__all__ = ["NAME", "Distribution", "Environment"] - -logger = logging.getLogger(__name__) - -NAME = "pkg_resources" - - -class EntryPoint(NamedTuple): - name: str - value: str - group: str - - -class InMemoryMetadata: - """IMetadataProvider that reads metadata files from a dictionary. - - This also maps metadata decoding exceptions to our internal exception type. - """ - - def __init__(self, metadata: Mapping[str, bytes], wheel_name: str) -> None: - self._metadata = metadata - self._wheel_name = wheel_name - - def has_metadata(self, name: str) -> bool: - return name in self._metadata - - def get_metadata(self, name: str) -> str: - try: - return self._metadata[name].decode() - except UnicodeDecodeError as e: - # Augment the default error with the origin of the file. - raise UnsupportedWheel( - f"Error decoding metadata for {self._wheel_name}: {e} in {name} file" - ) - - def get_metadata_lines(self, name: str) -> Iterable[str]: - return pkg_resources.yield_lines(self.get_metadata(name)) - - def metadata_isdir(self, name: str) -> bool: - return False - - def metadata_listdir(self, name: str) -> List[str]: - return [] - - def run_script(self, script_name: str, namespace: str) -> None: - pass - - -class Distribution(BaseDistribution): - def __init__(self, dist: pkg_resources.Distribution) -> None: - self._dist = dist - - @classmethod - def from_directory(cls, directory: str) -> BaseDistribution: - dist_dir = directory.rstrip(os.sep) - - # Build a PathMetadata object, from path to metadata. :wink: - base_dir, dist_dir_name = os.path.split(dist_dir) - metadata = pkg_resources.PathMetadata(base_dir, dist_dir) - - # Determine the correct Distribution object type. - if dist_dir.endswith(".egg-info"): - dist_cls = pkg_resources.Distribution - dist_name = os.path.splitext(dist_dir_name)[0] - else: - assert dist_dir.endswith(".dist-info") - dist_cls = pkg_resources.DistInfoDistribution - dist_name = os.path.splitext(dist_dir_name)[0].split("-")[0] - - dist = dist_cls(base_dir, project_name=dist_name, metadata=metadata) - return cls(dist) - - @classmethod - def from_metadata_file_contents( - cls, - metadata_contents: bytes, - filename: str, - project_name: str, - ) -> BaseDistribution: - metadata_dict = { - "METADATA": metadata_contents, - } - dist = pkg_resources.DistInfoDistribution( - location=filename, - metadata=InMemoryMetadata(metadata_dict, filename), - project_name=project_name, - ) - return cls(dist) - - @classmethod - def from_wheel(cls, wheel: Wheel, name: str) -> BaseDistribution: - try: - with wheel.as_zipfile() as zf: - info_dir, _ = parse_wheel(zf, name) - metadata_dict = { - path.split("/", 1)[-1]: read_wheel_metadata_file(zf, path) - for path in zf.namelist() - if path.startswith(f"{info_dir}/") - } - except zipfile.BadZipFile as e: - raise InvalidWheel(wheel.location, name) from e - except UnsupportedWheel as e: - raise UnsupportedWheel(f"{name} has an invalid wheel, {e}") - dist = pkg_resources.DistInfoDistribution( - location=wheel.location, - metadata=InMemoryMetadata(metadata_dict, wheel.location), - project_name=name, - ) - return cls(dist) - - @property - def location(self) -> Optional[str]: - return self._dist.location - - @property - def installed_location(self) -> Optional[str]: - egg_link = egg_link_path_from_location(self.raw_name) - if egg_link: - location = egg_link - elif self.location: - location = self.location - else: - return None - return normalize_path(location) - - @property - def info_location(self) -> Optional[str]: - return self._dist.egg_info - - @property - def installed_by_distutils(self) -> bool: - # A distutils-installed distribution is provided by FileMetadata. This - # provider has a "path" attribute not present anywhere else. Not the - # best introspection logic, but pip has been doing this for a long time. - try: - return bool(self._dist._provider.path) - except AttributeError: - return False - - @property - def canonical_name(self) -> NormalizedName: - return canonicalize_name(self._dist.project_name) - - @property - def version(self) -> DistributionVersion: - return parse_version(self._dist.version) - - def is_file(self, path: InfoPath) -> bool: - return self._dist.has_metadata(str(path)) - - def iter_distutils_script_names(self) -> Iterator[str]: - yield from self._dist.metadata_listdir("scripts") - - def read_text(self, path: InfoPath) -> str: - name = str(path) - if not self._dist.has_metadata(name): - raise FileNotFoundError(name) - content = self._dist.get_metadata(name) - if content is None: - raise NoneMetadataError(self, name) - return content - - def iter_entry_points(self) -> Iterable[BaseEntryPoint]: - for group, entries in self._dist.get_entry_map().items(): - for name, entry_point in entries.items(): - name, _, value = str(entry_point).partition("=") - yield EntryPoint(name=name.strip(), value=value.strip(), group=group) - - def _metadata_impl(self) -> email.message.Message: - """ - :raises NoneMetadataError: if the distribution reports `has_metadata()` - True but `get_metadata()` returns None. - """ - if isinstance(self._dist, pkg_resources.DistInfoDistribution): - metadata_name = "METADATA" - else: - metadata_name = "PKG-INFO" - try: - metadata = self.read_text(metadata_name) - except FileNotFoundError: - if self.location: - displaying_path = display_path(self.location) - else: - displaying_path = repr(self.location) - logger.warning("No metadata found in %s", displaying_path) - metadata = "" - feed_parser = email.parser.FeedParser() - feed_parser.feed(metadata) - return feed_parser.close() - - def iter_dependencies(self, extras: Collection[str] = ()) -> Iterable[Requirement]: - if extras: # pkg_resources raises on invalid extras, so we sanitize. - extras = frozenset(pkg_resources.safe_extra(e) for e in extras) - extras = extras.intersection(self._dist.extras) - return self._dist.requires(extras) - - def iter_provided_extras(self) -> Iterable[str]: - return self._dist.extras - - def is_extra_provided(self, extra: str) -> bool: - return pkg_resources.safe_extra(extra) in self._dist.extras - - -class Environment(BaseEnvironment): - def __init__(self, ws: pkg_resources.WorkingSet) -> None: - self._ws = ws - - @classmethod - def default(cls) -> BaseEnvironment: - return cls(pkg_resources.working_set) - - @classmethod - def from_paths(cls, paths: Optional[List[str]]) -> BaseEnvironment: - return cls(pkg_resources.WorkingSet(paths)) - - def _iter_distributions(self) -> Iterator[BaseDistribution]: - for dist in self._ws: - yield Distribution(dist) - - def _search_distribution(self, name: str) -> Optional[BaseDistribution]: - """Find a distribution matching the ``name`` in the environment. - - This searches from *all* distributions available in the environment, to - match the behavior of ``pkg_resources.get_distribution()``. - """ - canonical_name = canonicalize_name(name) - for dist in self.iter_all_distributions(): - if dist.canonical_name == canonical_name: - return dist - return None - - def get_distribution(self, name: str) -> Optional[BaseDistribution]: - # Search the distribution by looking through the working set. - dist = self._search_distribution(name) - if dist: - return dist - - # If distribution could not be found, call working_set.require to - # update the working set, and try to find the distribution again. - # This might happen for e.g. when you install a package twice, once - # using setup.py develop and again using setup.py install. Now when - # running pip uninstall twice, the package gets removed from the - # working set in the first uninstall, so we have to populate the - # working set again so that pip knows about it and the packages gets - # picked up and is successfully uninstalled the second time too. - try: - # We didn't pass in any version specifiers, so this can never - # raise pkg_resources.VersionConflict. - self._ws.require(name) - except pkg_resources.DistributionNotFound: - return None - return self._search_distribution(name) diff --git a/venv/lib/python3.12/site-packages/pip/_internal/models/__init__.py b/venv/lib/python3.12/site-packages/pip/_internal/models/__init__.py deleted file mode 100644 index 7855226..0000000 --- a/venv/lib/python3.12/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.12/site-packages/pip/_internal/models/__pycache__/__init__.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/models/__pycache__/__init__.cpython-312.pyc deleted file mode 100644 index 029b2f2218e1c27c1b802f56e46230ee2b5f90e5..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 276 zcmXv}F-`+95VS)CQKbCAZHl`Uq@h5d6Erl4n#MABtK1UDw(QMGmrqdA(()F5K+6XZ z=~CfS!bq!~nPPY5b2gibjQ8@DZu0&f#6RSb>?WDKiAFq$Ud~6`%Sr`Pugnq^w}w^i z9UF24gXrw?=ab*6RWYpp-TZaBYxf!41PqG`wlihi?&J4`F~ z0jk&;S5%Mp#jPdi&~;$x8A8vkcZ>4;0unJ6$1Di~1<>Reqcau`VL)exSnD$M`^i-{ aHx{qsX?{J_OGEpg6Dj5INXl^>XZZ&a&QXs5 diff --git a/venv/lib/python3.12/site-packages/pip/_internal/models/__pycache__/candidate.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/models/__pycache__/candidate.cpython-312.pyc deleted file mode 100644 index c5db2046532fe500f36690357fb104dbebdcecfe..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1915 zcmb7EO>Epm6rNfCtaqCa9ELR4^RR0QD!$8Z9PODYZotG)1Z;I`5dQRT!NuN}74a$qFC_vXDf zo;Tn7`LVmZh+y5(Z#tg~2>r%4*^*MBIS#@aB8XrYRj`@ET+X>dMKr}k7F?+!n=(c@ z^co`KG9nU{@4^50GV?WA%m2wm4aZVovyg%yPCMQ_@V*PQ_KF=+GU->qM&EF5I9`c+ zXG=+i=4BAxgGeYcF+paIU{jcbNIt`+NCYYo5k9z?$RuA@R!|ueWx31D6PZfo94Rb| zrjp7v-0T35SY|Y;GH<3N!Y*4JbB#vp-a=u|sfe{dmWU(X%ITkiyr2JX%6KeMeWs_X`gOPTqOzr-2cWyHeHf zO8091zH)Tuss6RWTZ8N8Kb`(~`tHfEv<+>$cl5#2ryCL~4DKSKP;A1#P$|thm(hN$ z5ZFL};%n{J#3jl2es!cOVE-rMSsz26+5s{QWJH{m*MBJVBVu`x0Woel8fi`*3xg@bkBPWD+boeTeN6Y9J zas1cb=a;4$q9PU7FEtRbyJr)&NfP#Lw9A!^J_#J2Ya(EcgIJoy>xchFoF^|zemtWo z@euT^4s*pLKGR!`48upy1`W?O>je@ICXQKi>#gS2lj+Q#7ax1vUX2_#OuZOyx8%kR x)ViHl?w&H%!f~8wu;nEka%36;#`qyR_Xj%l5WW1DJb-8M_A{q<5f_r<{{U51#_#|D diff --git a/venv/lib/python3.12/site-packages/pip/_internal/models/__pycache__/direct_url.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/models/__pycache__/direct_url.cpython-312.pyc deleted file mode 100644 index 080a3ebad18c802f5b98525e4801815844536224..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 11209 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 diff --git a/venv/lib/python3.12/site-packages/pip/_internal/models/__pycache__/format_control.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/models/__pycache__/format_control.cpython-312.pyc deleted file mode 100644 index d8a1e491c196efa12caa2ad3e7371e3e7b096ab9..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4237 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 ao~fW`K1JXE6dnDa>lDZN9wSyepZ_13PO%99 diff --git a/venv/lib/python3.12/site-packages/pip/_internal/models/__pycache__/index.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/models/__pycache__/index.cpython-312.pyc deleted file mode 100644 index c3d82094a53faa0d77b9f1080920249dbe0252d8..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1704 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 a_0>?{6ZGyA)cqS8`X{Uk@ihd%JO3Z=c_Q8b diff --git a/venv/lib/python3.12/site-packages/pip/_internal/models/__pycache__/link.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/models/__pycache__/link.cpython-312.pyc deleted file mode 100644 index c31209aef34011ac7a1c53982188d7ac9fe9d785..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 26012 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 BHW~l` diff --git a/venv/lib/python3.12/site-packages/pip/_internal/models/__pycache__/search_scope.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/models/__pycache__/search_scope.cpython-312.pyc deleted file mode 100644 index 18965902cb89585a6b7f8ba0857f2751784a5dd7..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 5098 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 Q(Z)adRb%5d0+G7?3;7HWApigX diff --git a/venv/lib/python3.12/site-packages/pip/_internal/models/__pycache__/target_python.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/models/__pycache__/target_python.cpython-312.pyc deleted file mode 100644 index 013387553e75551d25997bfe378ba84ca662d3f4..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4964 zcmcIn-EZ606~81UOQK{espHlknRFAUw$<5GV>ex!q}hTx8-fl_(56_ctzc=9wwX|* zc1byrVPk2L2N!5j2N>oA?NDdvLxyZX9{WG+MVdQU<2o$BI&9sOQWx0jr=4@D56f`} z>|wNZc|Q-&z2|q%`Q6`jcgqBx4ds3F{sBV%ijC$IYE-u0gvvV6i7r?qhi}mm3Sv$y zNI9tx%7qHyTv)(<$?7UZauHq+SfsL6=$PfL{bUiQJErl#!~tjG)~sbd?|gxOr0Y0q;(a}I;qMJ<0tn}=cB z^)$;Gr@C|1wj50#r-qkT_{>bye_Wk67Y$o2mOD-U%iuvfvbJq^w1$BLjH z$S=6Q++N`)+jVX_KdvreA&{ zv%mfJnn)sEqS?C)IMPFdqzU$xjPSAqI<=*TpoLoVXIX$&>kG?aXmLlyLB5yPmvo%j z`WkO_2Qml&w+d^g;TX8h5Gp5&8q*52WsH;bEVaPh5GSt300;mXMrQyX3Ozr^E92BP zG?rfgG=TwIqEK7|Du_DGqZ%`4%O&Y-nPV|uVhm6~-LmT$1%+M!fU>KmYmC#Yre$@A zn=@^FkIcMg(^-SgmP`wjv;%lIp#*bX*U$l}3cUpS86DDE%HelltyM-zO)$eUgu4!# zXXb1PL3$FUmmgKjcD%L@mXimkChnE_7d!lA%% z<0m_`Zun{=Siu5x8ty~Xb7;vm=$N6*EA&k`P-S;W`|-)CH{Q&&^+Me)Er5^X5iV$p z2DJ=(-dmu@$LZuaT6v0IT`+8n7K^5C=zPYA%GNN3`e+B&bgS)HY84ziP~UfpKI1{Gcz)tV%gjP#Ud&qNY_`ZV z#guYd00~siu^>?7mP*O}=yC^VBo<)y>qo)e8^$ z`qy8(`Pzs1kB2vYcAtGBR7Ov3rcQ14onDn69O_>Uy&J2g#!=W%ZQv+0duoHn;FYYU z73@7+?;^)fV6DG4^_|twAEJl1K?#y?L};uN%m+LN{1YlbV1yNjm6vg3&-2z%UA&Al z_dL3EgY3Uzn%ry5z1PeM5anU+KDh)kdU#oYvJ1x1mU|u;iNHuJ_P2-U#Q6~9n&`f| z#XvXlQ9WKE8F^{C<%r+s(SwIgp03BK?bs6-->K#WkuQkr7zrUQ>4mdG}z5l*wuVR4f4lDqA#k)IXtf<}N1*#}^jVnJ+9-JAPe9ofVMPQAA-o$~ z7Cr!2EsGzBzmyuA?QLyVoY@gx_%+E$>`4&fOIM7t9|m?)GF-$OxHI1}8->RIw%J!< zg`0t*x!HdCkHZriQ+LCkl&asoxazJNYsc4KT|572A_bf8m%nxqU2n?+!h4AUAO$>z zG4$QwFj`y+lubjgpKPF^N$q?Yv`01u%6Dk*Cw3cVY2X`eb`He4??C~9B1(qRtI1kC zxfLI&#z!jg$y(~jM+>(X9&)>lJhe4)wmNe5E414-5z{@Z7wR(U8Mt-qBjvVINn~o> zL$}mQVxrdFyLM^)^_#C(66sp^w{Ce`>B(w(vXYpp$HI@xt8zU-4)nf%?VW2NxnHgw zKLs-TWsrG5t`jjPv!kFShR1n_#1&r$#p&wzp=YaqtT$dowAaQKb(Y8aZ zh`Z_J{!S0Qm`V0L(Ay$;?V;a@_Zk6bMdEa_H3aip^>zh%H&c{2|VZQgeA z+(r7#LGc?~ZJirkV03@liLJTRc-oSQ+S*73$M z2Ta45Gk^`|fy5LXV4Xn+LoQ}A*W1Nj@FEy#q}Mh^{SdN&OeDyjn1~sYWQOQ&&*Ha& zOo$^nNVXWR{1EPlM*(oX!1w$lCnNk0$r;Mh;SK=r8GRkZxE2(E;RHz>*oqHT<3pAB zFl3|j@K);iYU=sb3$jjIgBf z?9E_sk7y2k1MC4l!jg6FnwIx~OapVJu2z6V(%^LMV;l#ztpprg$JAs!(|0xo5E>;%*xe_()eG21k3co3~rvfcLQmr{>dv16Q} z1jGc`QRa3`SL5kQeDt&7kqvKa^i*~9)aK|5o5N?&8kAdOxSAZUM2ERGGNBoGG6#?y z*>D1?>dUGM6slxlJ)x>UEooL`B%-RilZWn@s=AirxvI+0f(*^WlOe;H<4eHB*b(e| z8VkG_@*OiY9eWOoZ)1TGD@Ys|5EvF1FWfs&+#nA_QaJjh96Q)`{d|3pJf+l5JYPFD zRvR0C7#|Hk_n>#^*7Qd2?eo>%k$M<90J(!lH=evJ-F@Y5^iH-qFjkd-_;tEq0^kaTL z{s^DYB(VzI;w)Er^xhG~2aFVc|9&e9rkm&VouB5OW8R6L4lH|yy$BKzcxBme(kK3RC diff --git a/venv/lib/python3.12/site-packages/pip/_internal/models/__pycache__/wheel.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/models/__pycache__/wheel.cpython-312.pyc deleted file mode 100644 index 47b040568888ffaad9699cdaf00cb6623d5c75aa..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 5790 zcmcgwU2Gf25#IZuM4l+gwn$S_9s6P{k*P?eExAslxUv)5Dda|uVY^AH*kR7Rqj(B= z$L^i}2pKR^1F-=ocKRo$Z2$!=P#Q)N^-Tc^qz`>)(T9p*3MmHz4bTQ?-x$k45Xx5qK72SM^OTg!~;}yhp4I)=t1+o~UGusGQ1Y zxG@fTA;V{dF(E6CiCN#6k3*iAX~;H?HL|fUyX2-|2nGZfuXYzdE#oY%_9Kd}~X>`~d55Mr@8LRK? zBL|~>NJ5rN={XpUN^<4dy_<2*P3jqS_>B6(i+yL2e~?jgv$d~0Im$Wx9?7|kV%JDj z$!B8I>CD`jmHcEYH8l2C{tK+FwIfqqoKevKl;Du&)0r<~DkBC)&K3wO;jmT#!_afDKj+cyqr} zQq@`;NRqy`q-ykm7ldkhd!r-ds&G}j>Pw1glH||sCFHySGq-yDT7QI`m4Pb)x4lO7 zM!;HcD z&r4o-4N*n600{2~QbQQS217J?- zr5JrroEYgloYCV`nlTm6=;z|OSvzeS1F^mRaZ9(gzMPVLSsB-?cuvp76S@J}#85Kv ztf^`lE6$dW_EAJwC`MrbQdGt1z#x=TZ!y1M)ogSONUF5Logw@+Ocb;BU?wBk6do;g4y<$z7CQ$)UMI?Htu6Q6Qs|MD(B5Kb?;x zR180~kSc}yR>A|t@WA5XQur}oO0c_K-M@~%9sg9|JEby#X7z#XOZ(m%e0T6Rl2-RW z`bYII6Mvd;-$ssIIed+~w)dLy+S6sm54L;#9elqezSi>j9hAdP^beu^N5lSP1+KxW zgkY_L;kGse%{;NIJe9kMNuWMOzzlqjkelv+cz|+>MEU%_lPs&Sm||zz4aEm|o2+1! zVwu#|R5=3)39Apwrch~Eu`lQ{0HW9Wq4^HsSQ=sw!PWGtrJJ8}^BhMIB4){NglX;u zcN|L-5FO}TWH2t!VwNuZg96sWgta4`XF=` zTGiFTiEOZB{(&#ms29aVpt(T)(He#|3tjKTZp1za50+X7m;Hllz#@)_%CAf77|85= z4H&!%77f&$@gx|C?@XKy{u>Ysr@xheeI7j4Qf< z5@ClXRW({&7y)@&x6^Xggw^2+kkTlHpkmt8FIh=^&nlTo?I@)t9g;^@)ng0w#;du`0!^^_`>dGkykt^Xjt`gFn zUP#j(5CuUbV<%D!0*BKb&UV8Joe^wufkijP2+jAnQB+YF5(>ClBC8wsiRfXNZ^_Vn z=7w}+^iB1;vaoq+^OE|W@viay;M2e0ijmRJEv)u_u=PRiXN?bXQ4#XIHe)*h&6v!> zy~x&_=2MUj*(C{`)sbq3zriz2DIyw!qL(T#u=xub<|7-Zz6ZbEhk8Q(>l6YzZnZ^9 zk&yRPorWU>(2CpfJT775!- z!ATIx?dj>E2ytOM+rmj}?Qw+eboMu>n zcK~;Wrcl{R0u_>}B4-pjj$}8v-h+MrEdtfTye6UEMnkZ0#Y}RFnhfJm@%0A{Ckpyh z>{#6nLYZq*FcaFb24{74^eXsTJpF%x45PLV$l%&>9!z2DjbN%pNgYqW=P%Eevh;Xk-tS%7%1zjK&YM4~7*h>sXoyZ2-cm>J^>?cvP zU8vawa%U&m)V9WS>)rFt@f*jX7;Te)unCLWfJEWS2scM)ya!E#ze*VjIOB2Z`Y-?Y zAxNMM&(j!Jjb`Cft7L ztAl|U-tJidqzWe zgTgClBH>60@F#T=E|v)=m`HqoQpr>}jfsS6CV|Yum9r5I0tJrK`0UY>Pd;<%D8;)L zeFU3sZ1BGviV4WQLkg(=0er>7qIl*M(}p9SGtCS=itmT8!2@=)GXBFuvB5tTthb=K zNIn#|eiYh%?aBFLZyYQ0d|(G$!2(TJrOVP%sO;b5+p(Y)2Hw`o1cr-;*RU&hwfUsgQ2X_^H%7_=j`y&;-s1DWZDH>p z1%hinpqG1mzJcrM1?$ahnZR&Syn~&qIqDm2q9f4JW6(Ga_AI6YciXsQW*MgwZnUuk zRG_L!W9~H~@H{83H4skv8|f~R?vF{&$7Jx+h7%k&aGPMu1pOO?K)Xl) diff --git a/venv/lib/python3.12/site-packages/pip/_internal/models/candidate.py b/venv/lib/python3.12/site-packages/pip/_internal/models/candidate.py deleted file mode 100644 index 9184a90..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/models/candidate.py +++ /dev/null @@ -1,30 +0,0 @@ -from pip._vendor.packaging.version import parse as parse_version - -from pip._internal.models.link import Link -from pip._internal.utils.models import KeyBasedCompareMixin - - -class InstallationCandidate(KeyBasedCompareMixin): - """Represents a potential "candidate" for installation.""" - - __slots__ = ["name", "version", "link"] - - def __init__(self, name: str, version: str, link: Link) -> None: - self.name = name - self.version = parse_version(version) - self.link = link - - super().__init__( - key=(self.name, self.version, self.link), - defining_class=InstallationCandidate, - ) - - def __repr__(self) -> str: - return "".format( - self.name, - self.version, - self.link, - ) - - def __str__(self) -> str: - return f"{self.name!r} candidate (version {self.version} at {self.link})" diff --git a/venv/lib/python3.12/site-packages/pip/_internal/models/direct_url.py b/venv/lib/python3.12/site-packages/pip/_internal/models/direct_url.py deleted file mode 100644 index 0af884b..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/models/direct_url.py +++ /dev/null @@ -1,235 +0,0 @@ -""" PEP 610 """ -import json -import re -import urllib.parse -from typing import Any, Dict, Iterable, Optional, Type, TypeVar, Union - -__all__ = [ - "DirectUrl", - "DirectUrlValidationError", - "DirInfo", - "ArchiveInfo", - "VcsInfo", -] - -T = TypeVar("T") - -DIRECT_URL_METADATA_NAME = "direct_url.json" -ENV_VAR_RE = re.compile(r"^\$\{[A-Za-z0-9-_]+\}(:\$\{[A-Za-z0-9-_]+\})?$") - - -class DirectUrlValidationError(Exception): - pass - - -def _get( - d: Dict[str, Any], expected_type: Type[T], key: str, default: Optional[T] = None -) -> Optional[T]: - """Get value from dictionary and verify expected type.""" - if key not in d: - return default - value = d[key] - if not isinstance(value, expected_type): - raise DirectUrlValidationError( - f"{value!r} has unexpected type for {key} (expected {expected_type})" - ) - return value - - -def _get_required( - d: Dict[str, Any], expected_type: Type[T], key: str, default: Optional[T] = None -) -> T: - value = _get(d, expected_type, key, default) - if value is None: - raise DirectUrlValidationError(f"{key} must have a value") - return value - - -def _exactly_one_of(infos: Iterable[Optional["InfoType"]]) -> "InfoType": - infos = [info for info in infos if info is not None] - if not infos: - raise DirectUrlValidationError( - "missing one of archive_info, dir_info, vcs_info" - ) - if len(infos) > 1: - raise DirectUrlValidationError( - "more than one of archive_info, dir_info, vcs_info" - ) - assert infos[0] is not None - return infos[0] - - -def _filter_none(**kwargs: Any) -> Dict[str, Any]: - """Make dict excluding None values.""" - return {k: v for k, v in kwargs.items() if v is not None} - - -class VcsInfo: - name = "vcs_info" - - def __init__( - self, - vcs: str, - commit_id: str, - requested_revision: Optional[str] = None, - ) -> None: - self.vcs = vcs - self.requested_revision = requested_revision - self.commit_id = commit_id - - @classmethod - def _from_dict(cls, d: Optional[Dict[str, Any]]) -> Optional["VcsInfo"]: - if d is None: - return None - return cls( - vcs=_get_required(d, str, "vcs"), - commit_id=_get_required(d, str, "commit_id"), - requested_revision=_get(d, str, "requested_revision"), - ) - - def _to_dict(self) -> Dict[str, Any]: - return _filter_none( - vcs=self.vcs, - requested_revision=self.requested_revision, - commit_id=self.commit_id, - ) - - -class ArchiveInfo: - name = "archive_info" - - def __init__( - self, - hash: Optional[str] = None, - hashes: Optional[Dict[str, str]] = None, - ) -> None: - # set hashes before hash, since the hash setter will further populate hashes - self.hashes = hashes - self.hash = hash - - @property - def hash(self) -> Optional[str]: - return self._hash - - @hash.setter - def hash(self, value: Optional[str]) -> None: - if value is not None: - # Auto-populate the hashes key to upgrade to the new format automatically. - # We don't back-populate the legacy hash key from hashes. - try: - hash_name, hash_value = value.split("=", 1) - except ValueError: - raise DirectUrlValidationError( - f"invalid archive_info.hash format: {value!r}" - ) - if self.hashes is None: - self.hashes = {hash_name: hash_value} - elif hash_name not in self.hashes: - self.hashes = self.hashes.copy() - self.hashes[hash_name] = hash_value - self._hash = value - - @classmethod - def _from_dict(cls, d: Optional[Dict[str, Any]]) -> Optional["ArchiveInfo"]: - if d is None: - return None - return cls(hash=_get(d, str, "hash"), hashes=_get(d, dict, "hashes")) - - def _to_dict(self) -> Dict[str, Any]: - return _filter_none(hash=self.hash, hashes=self.hashes) - - -class DirInfo: - name = "dir_info" - - def __init__( - self, - editable: bool = False, - ) -> None: - self.editable = editable - - @classmethod - def _from_dict(cls, d: Optional[Dict[str, Any]]) -> Optional["DirInfo"]: - if d is None: - return None - return cls(editable=_get_required(d, bool, "editable", default=False)) - - def _to_dict(self) -> Dict[str, Any]: - return _filter_none(editable=self.editable or None) - - -InfoType = Union[ArchiveInfo, DirInfo, VcsInfo] - - -class DirectUrl: - def __init__( - self, - url: str, - info: InfoType, - subdirectory: Optional[str] = None, - ) -> None: - self.url = url - self.info = info - self.subdirectory = subdirectory - - def _remove_auth_from_netloc(self, netloc: str) -> str: - if "@" not in netloc: - return netloc - user_pass, netloc_no_user_pass = netloc.split("@", 1) - if ( - isinstance(self.info, VcsInfo) - and self.info.vcs == "git" - and user_pass == "git" - ): - return netloc - if ENV_VAR_RE.match(user_pass): - return netloc - return netloc_no_user_pass - - @property - def redacted_url(self) -> str: - """url with user:password part removed unless it is formed with - environment variables as specified in PEP 610, or it is ``git`` - in the case of a git URL. - """ - purl = urllib.parse.urlsplit(self.url) - netloc = self._remove_auth_from_netloc(purl.netloc) - surl = urllib.parse.urlunsplit( - (purl.scheme, netloc, purl.path, purl.query, purl.fragment) - ) - return surl - - def validate(self) -> None: - self.from_dict(self.to_dict()) - - @classmethod - def from_dict(cls, d: Dict[str, Any]) -> "DirectUrl": - return DirectUrl( - url=_get_required(d, str, "url"), - subdirectory=_get(d, str, "subdirectory"), - info=_exactly_one_of( - [ - ArchiveInfo._from_dict(_get(d, dict, "archive_info")), - DirInfo._from_dict(_get(d, dict, "dir_info")), - VcsInfo._from_dict(_get(d, dict, "vcs_info")), - ] - ), - ) - - def to_dict(self) -> Dict[str, Any]: - res = _filter_none( - url=self.redacted_url, - subdirectory=self.subdirectory, - ) - res[self.info.name] = self.info._to_dict() - return res - - @classmethod - def from_json(cls, s: str) -> "DirectUrl": - return cls.from_dict(json.loads(s)) - - def to_json(self) -> str: - return json.dumps(self.to_dict(), sort_keys=True) - - def is_local_editable(self) -> bool: - return isinstance(self.info, DirInfo) and self.info.editable diff --git a/venv/lib/python3.12/site-packages/pip/_internal/models/format_control.py b/venv/lib/python3.12/site-packages/pip/_internal/models/format_control.py deleted file mode 100644 index ccd1127..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/models/format_control.py +++ /dev/null @@ -1,78 +0,0 @@ -from typing import FrozenSet, Optional, Set - -from pip._vendor.packaging.utils import canonicalize_name - -from pip._internal.exceptions import CommandError - - -class FormatControl: - """Helper for managing formats from which a package can be installed.""" - - __slots__ = ["no_binary", "only_binary"] - - def __init__( - self, - no_binary: Optional[Set[str]] = None, - only_binary: Optional[Set[str]] = None, - ) -> None: - if no_binary is None: - no_binary = set() - if only_binary is None: - only_binary = set() - - self.no_binary = no_binary - self.only_binary = only_binary - - def __eq__(self, other: object) -> bool: - if not isinstance(other, self.__class__): - return NotImplemented - - if self.__slots__ != other.__slots__: - return False - - return all(getattr(self, k) == getattr(other, k) for k in self.__slots__) - - def __repr__(self) -> str: - return f"{self.__class__.__name__}({self.no_binary}, {self.only_binary})" - - @staticmethod - def handle_mutual_excludes(value: str, target: Set[str], other: Set[str]) -> None: - if value.startswith("-"): - raise CommandError( - "--no-binary / --only-binary option requires 1 argument." - ) - new = value.split(",") - while ":all:" in new: - 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: 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) -> None: - self.handle_mutual_excludes( - ":all:", - self.no_binary, - self.only_binary, - ) diff --git a/venv/lib/python3.12/site-packages/pip/_internal/models/index.py b/venv/lib/python3.12/site-packages/pip/_internal/models/index.py deleted file mode 100644 index b94c325..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/models/index.py +++ /dev/null @@ -1,28 +0,0 @@ -import urllib.parse - - -class PackageIndex: - """Represents a Package Index and provides easier access to endpoints""" - - __slots__ = ["url", "netloc", "simple_url", "pypi_url", "file_storage_domain"] - - def __init__(self, url: str, file_storage_domain: str) -> None: - super().__init__() - self.url = url - self.netloc = urllib.parse.urlsplit(url).netloc - self.simple_url = self._url_for_path("simple") - self.pypi_url = self._url_for_path("pypi") - - # 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: 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.12/site-packages/pip/_internal/models/installation_report.py b/venv/lib/python3.12/site-packages/pip/_internal/models/installation_report.py deleted file mode 100644 index b9c6330..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/models/installation_report.py +++ /dev/null @@ -1,56 +0,0 @@ -from typing import Any, Dict, Sequence - -from pip._vendor.packaging.markers import default_environment - -from pip import __version__ -from pip._internal.req.req_install import InstallRequirement - - -class InstallationReport: - def __init__(self, install_requirements: Sequence[InstallRequirement]): - self._install_requirements = install_requirements - - @classmethod - def _install_req_to_dict(cls, ireq: InstallRequirement) -> Dict[str, Any]: - assert ireq.download_info, f"No download_info for {ireq}" - res = { - # PEP 610 json for the download URL. download_info.archive_info.hashes may - # be absent when the requirement was installed from the wheel cache - # and the cache entry was populated by an older pip version that did not - # record origin.json. - "download_info": ireq.download_info.to_dict(), - # is_direct is true if the requirement was a direct URL reference (which - # includes editable requirements), and false if the requirement was - # downloaded from a PEP 503 index or --find-links. - "is_direct": ireq.is_direct, - # is_yanked is true if the requirement was yanked from the index, but - # was still selected by pip to conform to PEP 592. - "is_yanked": ireq.link.is_yanked if ireq.link else False, - # requested is true if the requirement was specified by the user (aka - # top level requirement), and false if it was installed as a dependency of a - # requirement. https://peps.python.org/pep-0376/#requested - "requested": ireq.user_supplied, - # PEP 566 json encoding for metadata - # https://www.python.org/dev/peps/pep-0566/#json-compatible-metadata - "metadata": ireq.get_dist().metadata_dict, - } - if ireq.user_supplied and ireq.extras: - # For top level requirements, the list of requested extras, if any. - res["requested_extras"] = sorted(ireq.extras) - return res - - def to_dict(self) -> Dict[str, Any]: - return { - "version": "1", - "pip_version": __version__, - "install": [ - self._install_req_to_dict(ireq) for ireq in self._install_requirements - ], - # https://peps.python.org/pep-0508/#environment-markers - # TODO: currently, the resolver uses the default environment to evaluate - # environment markers, so that is what we report here. In the future, it - # should also take into account options such as --python-version or - # --platform, perhaps under the form of an environment_override field? - # https://github.com/pypa/pip/issues/11198 - "environment": default_environment(), - } diff --git a/venv/lib/python3.12/site-packages/pip/_internal/models/link.py b/venv/lib/python3.12/site-packages/pip/_internal/models/link.py deleted file mode 100644 index 73041b8..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/models/link.py +++ /dev/null @@ -1,579 +0,0 @@ -import functools -import itertools -import logging -import os -import posixpath -import re -import urllib.parse -from dataclasses import dataclass -from typing import ( - TYPE_CHECKING, - Any, - Dict, - List, - Mapping, - NamedTuple, - Optional, - Tuple, - Union, -) - -from pip._internal.utils.deprecation import deprecated -from pip._internal.utils.filetypes import WHEEL_EXTENSION -from pip._internal.utils.hashes import Hashes -from pip._internal.utils.misc import ( - pairwise, - redact_auth_from_url, - split_auth_from_netloc, - splitext, -) -from pip._internal.utils.models import KeyBasedCompareMixin -from pip._internal.utils.urls import path_to_url, url_to_path - -if TYPE_CHECKING: - from pip._internal.index.collector import IndexContent - -logger = logging.getLogger(__name__) - - -# Order matters, earlier hashes have a precedence over later hashes for what -# we will pick to use. -_SUPPORTED_HASHES = ("sha512", "sha384", "sha256", "sha224", "sha1", "md5") - - -@dataclass(frozen=True) -class LinkHash: - """Links to content may have embedded hash values. This class parses those. - - `name` must be any member of `_SUPPORTED_HASHES`. - - This class can be converted to and from `ArchiveInfo`. While ArchiveInfo intends to - be JSON-serializable to conform to PEP 610, this class contains the logic for - parsing a hash name and value for correctness, and then checking whether that hash - conforms to a schema with `.is_hash_allowed()`.""" - - name: str - value: str - - _hash_url_fragment_re = re.compile( - # NB: we do not validate that the second group (.*) is a valid hex - # digest. Instead, we simply keep that string in this class, and then check it - # against Hashes when hash-checking is needed. This is easier to debug than - # proactively discarding an invalid hex digest, as we handle incorrect hashes - # and malformed hashes in the same place. - r"[#&]({choices})=([^&]*)".format( - choices="|".join(re.escape(hash_name) for hash_name in _SUPPORTED_HASHES) - ), - ) - - def __post_init__(self) -> None: - assert self.name in _SUPPORTED_HASHES - - @classmethod - @functools.lru_cache(maxsize=None) - def find_hash_url_fragment(cls, url: str) -> Optional["LinkHash"]: - """Search a string for a checksum algorithm name and encoded output value.""" - match = cls._hash_url_fragment_re.search(url) - if match is None: - return None - name, value = match.groups() - return cls(name=name, value=value) - - def as_dict(self) -> Dict[str, str]: - return {self.name: self.value} - - def as_hashes(self) -> Hashes: - """Return a Hashes instance which checks only for the current hash.""" - return Hashes({self.name: [self.value]}) - - def is_hash_allowed(self, hashes: Optional[Hashes]) -> bool: - """ - Return True if the current hash is allowed by `hashes`. - """ - if hashes is None: - return False - return hashes.is_hash_allowed(self.name, hex_digest=self.value) - - -@dataclass(frozen=True) -class MetadataFile: - """Information about a core metadata file associated with a distribution.""" - - hashes: Optional[Dict[str, str]] - - def __post_init__(self) -> None: - if self.hashes is not None: - assert all(name in _SUPPORTED_HASHES for name in self.hashes) - - -def supported_hashes(hashes: Optional[Dict[str, str]]) -> Optional[Dict[str, str]]: - # Remove any unsupported hash types from the mapping. If this leaves no - # supported hashes, return None - if hashes is None: - return None - hashes = {n: v for n, v in hashes.items() if n in _SUPPORTED_HASHES} - if not hashes: - return None - return hashes - - -def _clean_url_path_part(part: str) -> str: - """ - Clean a "part" of a URL path (i.e. after splitting on "@" characters). - """ - # We unquote prior to quoting to make sure nothing is double quoted. - return urllib.parse.quote(urllib.parse.unquote(part)) - - -def _clean_file_url_path(part: str) -> str: - """ - Clean the first part of a URL path that corresponds to a local - filesystem path (i.e. the first part after splitting on "@" characters). - """ - # We unquote prior to quoting to make sure nothing is double quoted. - # Also, on Windows the path part might contain a drive letter which - # should not be quoted. On Linux where drive letters do not - # exist, the colon should be quoted. We rely on urllib.request - # to do the right thing here. - return urllib.request.pathname2url(urllib.request.url2pathname(part)) - - -# percent-encoded: / -_reserved_chars_re = re.compile("(@|%2F)", re.IGNORECASE) - - -def _clean_url_path(path: str, is_local_path: bool) -> str: - """ - Clean the path portion of a URL. - """ - if is_local_path: - clean_func = _clean_file_url_path - else: - clean_func = _clean_url_path_part - - # Split on the reserved characters prior to cleaning so that - # revision strings in VCS URLs are properly preserved. - parts = _reserved_chars_re.split(path) - - cleaned_parts = [] - for to_clean, reserved in pairwise(itertools.chain(parts, [""])): - cleaned_parts.append(clean_func(to_clean)) - # Normalize %xx escapes (e.g. %2f -> %2F) - cleaned_parts.append(reserved.upper()) - - return "".join(cleaned_parts) - - -def _ensure_quoted_url(url: str) -> str: - """ - Make sure a link is fully quoted. - For example, if ' ' occurs in the URL, it will be replaced with "%20", - and without double-quoting other characters. - """ - # Split the URL into parts according to the general structure - # `scheme://netloc/path;parameters?query#fragment`. - result = urllib.parse.urlparse(url) - # If the netloc is empty, then the URL refers to a local filesystem path. - is_local_path = not result.netloc - path = _clean_url_path(result.path, is_local_path=is_local_path) - return urllib.parse.urlunparse(result._replace(path=path)) - - -class Link(KeyBasedCompareMixin): - """Represents a parsed link from a Package Index's simple URL""" - - __slots__ = [ - "_parsed_url", - "_url", - "_hashes", - "comes_from", - "requires_python", - "yanked_reason", - "metadata_file_data", - "cache_link_parsing", - "egg_fragment", - ] - - def __init__( - self, - url: str, - comes_from: Optional[Union[str, "IndexContent"]] = None, - requires_python: Optional[str] = None, - yanked_reason: Optional[str] = None, - metadata_file_data: Optional[MetadataFile] = None, - cache_link_parsing: bool = True, - hashes: Optional[Mapping[str, str]] = None, - ) -> None: - """ - :param url: url of the resource pointed to (href of the link) - :param comes_from: instance of IndexContent where the link was found, - or string. - :param requires_python: String containing the `Requires-Python` - metadata field, specified in PEP 345. This may be specified by - 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. - :param metadata_file_data: the metadata attached to the file, or None if - no such metadata is provided. This argument, if not None, indicates - that a separate metadata file exists, and also optionally supplies - hashes for that file. - :param cache_link_parsing: A flag that is used elsewhere to determine - whether resources retrieved from this link should be cached. PyPI - URLs should generally have this set to False, for example. - :param hashes: A mapping of hash names to digests to allow us to - determine the validity of a download. - """ - - # The comes_from, requires_python, and metadata_file_data arguments are - # only used by classmethods of this class, and are not used in client - # code directly. - - # url can be a UNC windows share - if url.startswith("\\\\"): - 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 - - link_hash = LinkHash.find_hash_url_fragment(url) - hashes_from_link = {} if link_hash is None else link_hash.as_dict() - if hashes is None: - self._hashes = hashes_from_link - else: - self._hashes = {**hashes, **hashes_from_link} - - self.comes_from = comes_from - self.requires_python = requires_python if requires_python else None - self.yanked_reason = yanked_reason - self.metadata_file_data = metadata_file_data - - super().__init__(key=url, defining_class=Link) - - self.cache_link_parsing = cache_link_parsing - self.egg_fragment = self._egg_fragment() - - @classmethod - def from_json( - cls, - file_data: Dict[str, Any], - page_url: str, - ) -> Optional["Link"]: - """ - Convert an pypi json document from a simple repository page into a Link. - """ - file_url = file_data.get("url") - if file_url is None: - return None - - url = _ensure_quoted_url(urllib.parse.urljoin(page_url, file_url)) - pyrequire = file_data.get("requires-python") - yanked_reason = file_data.get("yanked") - hashes = file_data.get("hashes", {}) - - # PEP 714: Indexes must use the name core-metadata, but - # clients should support the old name as a fallback for compatibility. - metadata_info = file_data.get("core-metadata") - if metadata_info is None: - metadata_info = file_data.get("dist-info-metadata") - - # The metadata info value may be a boolean, or a dict of hashes. - if isinstance(metadata_info, dict): - # The file exists, and hashes have been supplied - metadata_file_data = MetadataFile(supported_hashes(metadata_info)) - elif metadata_info: - # The file exists, but there are no hashes - metadata_file_data = MetadataFile(None) - else: - # False or not present: the file does not exist - metadata_file_data = None - - # The Link.yanked_reason expects an empty string instead of a boolean. - if yanked_reason and not isinstance(yanked_reason, str): - yanked_reason = "" - # The Link.yanked_reason expects None instead of False. - elif not yanked_reason: - yanked_reason = None - - return cls( - url, - comes_from=page_url, - requires_python=pyrequire, - yanked_reason=yanked_reason, - hashes=hashes, - metadata_file_data=metadata_file_data, - ) - - @classmethod - def from_element( - cls, - anchor_attribs: Dict[str, Optional[str]], - page_url: str, - base_url: str, - ) -> Optional["Link"]: - """ - Convert an anchor element's attributes in a simple repository page to a Link. - """ - href = anchor_attribs.get("href") - if not href: - return None - - url = _ensure_quoted_url(urllib.parse.urljoin(base_url, href)) - pyrequire = anchor_attribs.get("data-requires-python") - yanked_reason = anchor_attribs.get("data-yanked") - - # PEP 714: Indexes must use the name data-core-metadata, but - # clients should support the old name as a fallback for compatibility. - metadata_info = anchor_attribs.get("data-core-metadata") - if metadata_info is None: - metadata_info = anchor_attribs.get("data-dist-info-metadata") - # The metadata info value may be the string "true", or a string of - # the form "hashname=hashval" - if metadata_info == "true": - # The file exists, but there are no hashes - metadata_file_data = MetadataFile(None) - elif metadata_info is None: - # The file does not exist - metadata_file_data = None - else: - # The file exists, and hashes have been supplied - hashname, sep, hashval = metadata_info.partition("=") - if sep == "=": - metadata_file_data = MetadataFile(supported_hashes({hashname: hashval})) - else: - # Error - data is wrong. Treat as no hashes supplied. - logger.debug( - "Index returned invalid data-dist-info-metadata value: %s", - metadata_info, - ) - metadata_file_data = MetadataFile(None) - - return cls( - url, - comes_from=page_url, - requires_python=pyrequire, - yanked_reason=yanked_reason, - metadata_file_data=metadata_file_data, - ) - - def __str__(self) -> str: - if self.requires_python: - rp = f" (requires-python:{self.requires_python})" - else: - rp = "" - if self.comes_from: - return f"{redact_auth_from_url(self._url)} (from {self.comes_from}){rp}" - else: - return redact_auth_from_url(str(self._url)) - - def __repr__(self) -> str: - return f"" - - @property - def url(self) -> str: - return self._url - - @property - def filename(self) -> str: - path = self.path.rstrip("/") - name = posixpath.basename(path) - if not name: - # Make sure we don't leak auth information if the netloc - # includes a username and password. - netloc, user_pass = split_auth_from_netloc(self.netloc) - return netloc - - name = urllib.parse.unquote(name) - assert name, f"URL {self._url!r} produced no filename" - return name - - @property - def file_path(self) -> str: - return url_to_path(self.url) - - @property - def scheme(self) -> str: - return self._parsed_url.scheme - - @property - def netloc(self) -> str: - """ - This can contain auth information. - """ - return self._parsed_url.netloc - - @property - def path(self) -> str: - return urllib.parse.unquote(self._parsed_url.path) - - def splitext(self) -> Tuple[str, str]: - return splitext(posixpath.basename(self.path.rstrip("/"))) - - @property - def ext(self) -> str: - return self.splitext()[1] - - @property - def url_without_fragment(self) -> str: - scheme, netloc, path, query, fragment = self._parsed_url - return urllib.parse.urlunsplit((scheme, netloc, path, query, "")) - - _egg_fragment_re = re.compile(r"[#&]egg=([^&]*)") - - # Per PEP 508. - _project_name_re = re.compile( - r"^([A-Z0-9]|[A-Z0-9][A-Z0-9._-]*[A-Z0-9])$", re.IGNORECASE - ) - - def _egg_fragment(self) -> Optional[str]: - match = self._egg_fragment_re.search(self._url) - if not match: - return None - - # An egg fragment looks like a PEP 508 project name, along with - # an optional extras specifier. Anything else is invalid. - project_name = match.group(1) - if not self._project_name_re.match(project_name): - deprecated( - reason=f"{self} contains an egg fragment with a non-PEP 508 name", - replacement="to use the req @ url syntax, and remove the egg fragment", - gone_in="25.0", - issue=11617, - ) - - return project_name - - _subdirectory_fragment_re = re.compile(r"[#&]subdirectory=([^&]*)") - - @property - def subdirectory_fragment(self) -> Optional[str]: - match = self._subdirectory_fragment_re.search(self._url) - if not match: - return None - return match.group(1) - - def metadata_link(self) -> Optional["Link"]: - """Return a link to the associated core metadata file (if any).""" - if self.metadata_file_data is None: - return None - metadata_url = f"{self.url_without_fragment}.metadata" - if self.metadata_file_data.hashes is None: - return Link(metadata_url) - return Link(metadata_url, hashes=self.metadata_file_data.hashes) - - def as_hashes(self) -> Hashes: - return Hashes({k: [v] for k, v in self._hashes.items()}) - - @property - def hash(self) -> Optional[str]: - return next(iter(self._hashes.values()), None) - - @property - def hash_name(self) -> Optional[str]: - return next(iter(self._hashes), None) - - @property - def show_url(self) -> str: - return posixpath.basename(self._url.split("#", 1)[0].split("?", 1)[0]) - - @property - def is_file(self) -> bool: - return self.scheme == "file" - - def is_existing_dir(self) -> bool: - return self.is_file and os.path.isdir(self.file_path) - - @property - def is_wheel(self) -> bool: - return self.ext == WHEEL_EXTENSION - - @property - def is_vcs(self) -> bool: - from pip._internal.vcs import vcs - - return self.scheme in vcs.all_schemes - - @property - def is_yanked(self) -> bool: - return self.yanked_reason is not None - - @property - def has_hash(self) -> bool: - return bool(self._hashes) - - def is_hash_allowed(self, hashes: Optional[Hashes]) -> bool: - """ - Return True if the link has a hash and it is allowed by `hashes`. - """ - if hashes is None: - return False - return any(hashes.is_hash_allowed(k, v) for k, v in self._hashes.items()) - - -class _CleanResult(NamedTuple): - """Convert link for equivalency check. - - This is used in the resolver to check whether two URL-specified requirements - likely point to the same distribution and can be considered equivalent. This - equivalency logic avoids comparing URLs literally, which can be too strict - (e.g. "a=1&b=2" vs "b=2&a=1") and produce conflicts unexpecting to users. - - Currently this does three things: - - 1. Drop the basic auth part. This is technically wrong since a server can - serve different content based on auth, but if it does that, it is even - impossible to guarantee two URLs without auth are equivalent, since - the user can input different auth information when prompted. So the - practical solution is to assume the auth doesn't affect the response. - 2. Parse the query to avoid the ordering issue. Note that ordering under the - same key in the query are NOT cleaned; i.e. "a=1&a=2" and "a=2&a=1" are - still considered different. - 3. Explicitly drop most of the fragment part, except ``subdirectory=`` and - hash values, since it should have no impact the downloaded content. Note - that this drops the "egg=" part historically used to denote the requested - project (and extras), which is wrong in the strictest sense, but too many - people are supplying it inconsistently to cause superfluous resolution - conflicts, so we choose to also ignore them. - """ - - parsed: urllib.parse.SplitResult - query: Dict[str, List[str]] - subdirectory: str - hashes: Dict[str, str] - - -def _clean_link(link: Link) -> _CleanResult: - parsed = link._parsed_url - netloc = parsed.netloc.rsplit("@", 1)[-1] - # According to RFC 8089, an empty host in file: means localhost. - if parsed.scheme == "file" and not netloc: - netloc = "localhost" - fragment = urllib.parse.parse_qs(parsed.fragment) - if "egg" in fragment: - logger.debug("Ignoring egg= fragment in %s", link) - try: - # If there are multiple subdirectory values, use the first one. - # This matches the behavior of Link.subdirectory_fragment. - subdirectory = fragment["subdirectory"][0] - except (IndexError, KeyError): - subdirectory = "" - # If there are multiple hash values under the same algorithm, use the - # first one. This matches the behavior of Link.hash_value. - hashes = {k: fragment[k][0] for k in _SUPPORTED_HASHES if k in fragment} - return _CleanResult( - parsed=parsed._replace(netloc=netloc, query="", fragment=""), - query=urllib.parse.parse_qs(parsed.query), - subdirectory=subdirectory, - hashes=hashes, - ) - - -@functools.lru_cache(maxsize=None) -def links_equivalent(link1: Link, link2: Link) -> bool: - return _clean_link(link1) == _clean_link(link2) diff --git a/venv/lib/python3.12/site-packages/pip/_internal/models/scheme.py b/venv/lib/python3.12/site-packages/pip/_internal/models/scheme.py deleted file mode 100644 index f51190a..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/models/scheme.py +++ /dev/null @@ -1,31 +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. -""" - - -SCHEME_KEYS = ["platlib", "purelib", "headers", "scripts", "data"] - - -class Scheme: - """A Scheme holds paths which are used as the base directories for - artifacts associated with a Python package. - """ - - __slots__ = SCHEME_KEYS - - def __init__( - self, - platlib: str, - purelib: str, - headers: str, - scripts: str, - data: str, - ) -> None: - self.platlib = platlib - self.purelib = purelib - self.headers = headers - self.scripts = scripts - self.data = data diff --git a/venv/lib/python3.12/site-packages/pip/_internal/models/search_scope.py b/venv/lib/python3.12/site-packages/pip/_internal/models/search_scope.py deleted file mode 100644 index fe61e81..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/models/search_scope.py +++ /dev/null @@ -1,132 +0,0 @@ -import itertools -import logging -import os -import posixpath -import urllib.parse -from typing import List - -from pip._vendor.packaging.utils import canonicalize_name - -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 - -logger = logging.getLogger(__name__) - - -class SearchScope: - - """ - Encapsulates the locations that pip is configured to search. - """ - - __slots__ = ["find_links", "index_urls", "no_index"] - - @classmethod - def create( - cls, - find_links: List[str], - index_urls: List[str], - no_index: bool, - ) -> "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: 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, - no_index=no_index, - ) - - def __init__( - self, - find_links: List[str], - index_urls: List[str], - no_index: bool, - ) -> None: - self.find_links = find_links - self.index_urls = index_urls - self.no_index = no_index - - def get_formatted_locations(self) -> str: - lines = [] - redacted_index_urls = [] - if self.index_urls and self.index_urls != [PyPI.simple_url]: - for url in self.index_urls: - redacted_index_url = redact_auth_from_url(url) - - # Parse the URL - purl = urllib.parse.urlsplit(redacted_index_url) - - # URL is generally invalid if scheme and netloc is missing - # there are issues with Python and URL parsing, so this test - # is a bit crude. See bpo-20271, bpo-23505. Python doesn't - # always parse invalid URLs correctly - it should raise - # exceptions for malformed URLs - if not purl.scheme and not purl.netloc: - logger.warning( - 'The index url "%s" seems invalid, please provide a scheme.', - redacted_index_url, - ) - - redacted_index_urls.append(redacted_index_url) - - lines.append( - "Looking in indexes: {}".format(", ".join(redacted_index_urls)) - ) - - if self.find_links: - lines.append( - "Looking in links: {}".format( - ", ".join(redact_auth_from_url(url) for url in self.find_links) - ) - ) - return "\n".join(lines) - - def get_index_urls_locations(self, project_name: str) -> List[str]: - """Returns the locations found via self.index_urls - - Checks the url_name on the main (first in the list) index and - use this url_name to produce all locations - """ - - def mkurl_pypi_url(url: 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.12/site-packages/pip/_internal/models/selection_prefs.py b/venv/lib/python3.12/site-packages/pip/_internal/models/selection_prefs.py deleted file mode 100644 index 977bc4c..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/models/selection_prefs.py +++ /dev/null @@ -1,51 +0,0 @@ -from typing import Optional - -from pip._internal.models.format_control import FormatControl - - -class SelectionPreferences: - """ - Encapsulates the candidate selection preferences for downloading - and installing files. - """ - - __slots__ = [ - "allow_yanked", - "allow_all_prereleases", - "format_control", - "prefer_binary", - "ignore_requires_python", - ] - - # Don't include an allow_yanked default value to make sure each call - # site considers whether yanked releases are allowed. This also causes - # that decision to be made explicit in the calling code, which helps - # people when reading the code. - def __init__( - self, - allow_yanked: bool, - allow_all_prereleases: bool = False, - format_control: Optional[FormatControl] = None, - prefer_binary: bool = False, - ignore_requires_python: Optional[bool] = None, - ) -> None: - """Create a SelectionPreferences object. - - :param allow_yanked: Whether files marked as yanked (in the sense - 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.12/site-packages/pip/_internal/models/target_python.py b/venv/lib/python3.12/site-packages/pip/_internal/models/target_python.py deleted file mode 100644 index 67ea5da..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/models/target_python.py +++ /dev/null @@ -1,122 +0,0 @@ -import sys -from typing import List, Optional, Set, Tuple - -from pip._vendor.packaging.tags import Tag - -from pip._internal.utils.compatibility_tags import get_supported, version_info_to_nodot -from pip._internal.utils.misc import normalize_version_info - - -class TargetPython: - - """ - Encapsulates the properties of a Python interpreter one is targeting - for a package install, download, etc. - """ - - __slots__ = [ - "_given_py_version_info", - "abis", - "implementation", - "platforms", - "py_version", - "py_version_info", - "_valid_tags", - "_valid_tags_set", - ] - - def __init__( - self, - platforms: Optional[List[str]] = None, - py_version_info: Optional[Tuple[int, ...]] = None, - abis: Optional[List[str]] = None, - implementation: Optional[str] = None, - ) -> None: - """ - :param platforms: A list of strings or None. If None, searches for - packages that are supported by the current system. Otherwise, will - find packages that can be built on the platforms 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 abis: A list of strings or None. This is passed to - compatibility_tags.py's get_supported() function as is. - :param implementation: A string or None. This is passed to - compatibility_tags.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.abis = abis - self.implementation = implementation - self.platforms = platforms - self.py_version = py_version - self.py_version_info = py_version_info - - # This is used to cache the return value of get_(un)sorted_tags. - self._valid_tags: Optional[List[Tag]] = None - self._valid_tags_set: Optional[Set[Tag]] = None - - def format_given(self) -> str: - """ - Format the given, non-None attributes for display. - """ - display_version = None - if self._given_py_version_info is not None: - display_version = ".".join( - str(part) for part in self._given_py_version_info - ) - - key_values = [ - ("platforms", self.platforms), - ("version_info", display_version), - ("abis", self.abis), - ("implementation", self.implementation), - ] - return " ".join( - f"{key}={value!r}" for key, value in key_values if value is not None - ) - - def get_sorted_tags(self) -> 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, - platforms=self.platforms, - abis=self.abis, - impl=self.implementation, - ) - self._valid_tags = tags - - return self._valid_tags - - def get_unsorted_tags(self) -> Set[Tag]: - """Exactly the same as get_sorted_tags, but returns a set. - - This is important for performance. - """ - if self._valid_tags_set is None: - self._valid_tags_set = set(self.get_sorted_tags()) - - return self._valid_tags_set diff --git a/venv/lib/python3.12/site-packages/pip/_internal/models/wheel.py b/venv/lib/python3.12/site-packages/pip/_internal/models/wheel.py deleted file mode 100644 index a5dc12b..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/models/wheel.py +++ /dev/null @@ -1,92 +0,0 @@ -"""Represents a wheel file and provides access to the various parts of the -name that have meaning. -""" -import re -from typing import Dict, Iterable, List - -from pip._vendor.packaging.tags import Tag - -from pip._internal.exceptions import InvalidWheelFilename - - -class Wheel: - """A wheel file""" - - wheel_file_re = re.compile( - r"""^(?P(?P[^\s-]+?)-(?P[^\s-]*?)) - ((-(?P\d[^-]*?))?-(?P[^\s-]+?)-(?P[^\s-]+?)-(?P[^\s-]+?) - \.whl|\.dist-info)$""", - re.VERBOSE, - ) - - def __init__(self, filename: str) -> None: - """ - :raises InvalidWheelFilename: when the filename is invalid for a wheel - """ - wheel_info = self.wheel_file_re.match(filename) - if not wheel_info: - raise InvalidWheelFilename(f"{filename} is not a valid wheel filename.") - 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) -> 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: 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. - """ - try: - return next(i for i, t in enumerate(tags) if t in self.file_tags) - except StopIteration: - raise ValueError() - - def find_most_preferred_tag( - self, tags: List[Tag], tag_to_priority: Dict[Tag, int] - ) -> int: - """Return the priority of the most preferred tag that one of the wheel's file - tag combinations achieves in the given list of supported tags using the given - tag_to_priority mapping, where lower priorities are more-preferred. - - This is used in place of support_index_min in some cases in order to avoid - an expensive linear scan of a large list of tags. - - :param tags: the PEP 425 tags to check the wheel against. - :param tag_to_priority: a mapping from tag to priority of that tag, where - lower is more preferred. - - :raises ValueError: If none of the wheel's file tags match one of - the supported tags. - """ - return min( - tag_to_priority[tag] for tag in self.file_tags if tag in tag_to_priority - ) - - def supported(self, tags: Iterable[Tag]) -> bool: - """Return whether the wheel is compatible with one of the given tags. - - :param tags: the PEP 425 tags to check the wheel against. - """ - return not self.file_tags.isdisjoint(tags) diff --git a/venv/lib/python3.12/site-packages/pip/_internal/network/__init__.py b/venv/lib/python3.12/site-packages/pip/_internal/network/__init__.py deleted file mode 100644 index b51bde9..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/network/__init__.py +++ /dev/null @@ -1,2 +0,0 @@ -"""Contains purely network-related utilities. -""" diff --git a/venv/lib/python3.12/site-packages/pip/_internal/network/__pycache__/__init__.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/network/__pycache__/__init__.cpython-312.pyc deleted file mode 100644 index 862fcbc94398303f8cd7265d053054885e0abf44..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 264 zcmXw!F-`+95Jl|}K@=%>*fv7DBSMRiqNJfg)M+dekH}~p+p=dj+FXK?mX@<{gS1=# zkuDWpDf!L(H^t2V-;>E$WPMieG|Tg+hl}Ld97oxF2qRXalheWecHtdsa;XSSMB5b( zdFNwYX3&hLXqYT9VXDT@Q+c>i%J{WXU*gzbJk_xATZE_$xj@l3dst$s*$0@%R=aZk z@>DJ?L5r>hORo?*-gtLk-OV5oV;S_i)^C^~Pyj`aF*hUn%vCf3KvJe*-CpahUNRU_nj6 diff --git a/venv/lib/python3.12/site-packages/pip/_internal/network/__pycache__/auth.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/network/__pycache__/auth.cpython-312.pyc deleted file mode 100644 index b443e49c5786b6ddb162e648ac8a55093aac6107..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 22006 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Ⓢ{M}!)ZqLQ-(Qa6k%}%uUsjN0GA(S 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 diff --git a/venv/lib/python3.12/site-packages/pip/_internal/network/__pycache__/lazy_wheel.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/network/__pycache__/lazy_wheel.cpython-312.pyc deleted file mode 100644 index 4fdb20b36faa864828bc2e80bcc98b0e5c9d5129..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 11673 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 U@4sEWP|}zwY5WyODTWpQAH&v?a{vGU diff --git a/venv/lib/python3.12/site-packages/pip/_internal/network/__pycache__/utils.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/network/__pycache__/utils.cpython-312.pyc deleted file mode 100644 index e60cccfc7739e445f30bf1328be9aedb49d4f9e1..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2263 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 TzZu^fIkP)*=3Dqe2=o45q|e;6 diff --git a/venv/lib/python3.12/site-packages/pip/_internal/network/auth.py b/venv/lib/python3.12/site-packages/pip/_internal/network/auth.py deleted file mode 100644 index 94a82fa..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/network/auth.py +++ /dev/null @@ -1,561 +0,0 @@ -"""Network Authentication Helpers - -Contains interface (MultiDomainBasicAuth) and associated glue code for -providing credentials in the context of network requests. -""" -import logging -import os -import shutil -import subprocess -import sysconfig -import typing -import urllib.parse -from abc import ABC, abstractmethod -from functools import lru_cache -from os.path import commonprefix -from pathlib import Path -from typing import Any, Dict, List, NamedTuple, Optional, Tuple - -from pip._vendor.requests.auth import AuthBase, HTTPBasicAuth -from pip._vendor.requests.models import Request, Response -from pip._vendor.requests.utils import get_netrc_auth - -from pip._internal.utils.logging import getLogger -from pip._internal.utils.misc import ( - ask, - ask_input, - ask_password, - remove_auth_from_url, - split_auth_netloc_from_url, -) -from pip._internal.vcs.versioncontrol import AuthInfo - -logger = getLogger(__name__) - -KEYRING_DISABLED = False - - -class Credentials(NamedTuple): - url: str - username: str - password: str - - -class KeyRingBaseProvider(ABC): - """Keyring base provider interface""" - - has_keyring: bool - - @abstractmethod - def get_auth_info(self, url: str, username: Optional[str]) -> Optional[AuthInfo]: - ... - - @abstractmethod - def save_auth_info(self, url: str, username: str, password: str) -> None: - ... - - -class KeyRingNullProvider(KeyRingBaseProvider): - """Keyring null provider""" - - has_keyring = False - - def get_auth_info(self, url: str, username: Optional[str]) -> Optional[AuthInfo]: - return None - - def save_auth_info(self, url: str, username: str, password: str) -> None: - return None - - -class KeyRingPythonProvider(KeyRingBaseProvider): - """Keyring interface which uses locally imported `keyring`""" - - has_keyring = True - - def __init__(self) -> None: - import keyring - - self.keyring = keyring - - def get_auth_info(self, url: str, username: Optional[str]) -> Optional[AuthInfo]: - # Support keyring's get_credential interface which supports getting - # credentials without a username. This is only available for - # keyring>=15.2.0. - if hasattr(self.keyring, "get_credential"): - logger.debug("Getting credentials from keyring for %s", url) - cred = self.keyring.get_credential(url, username) - if cred is not None: - return cred.username, cred.password - return None - - if username is not None: - logger.debug("Getting password from keyring for %s", url) - password = self.keyring.get_password(url, username) - if password: - return username, password - return None - - def save_auth_info(self, url: str, username: str, password: str) -> None: - self.keyring.set_password(url, username, password) - - -class KeyRingCliProvider(KeyRingBaseProvider): - """Provider which uses `keyring` cli - - Instead of calling the keyring package installed alongside pip - we call keyring on the command line which will enable pip to - use which ever installation of keyring is available first in - PATH. - """ - - has_keyring = True - - def __init__(self, cmd: str) -> None: - self.keyring = cmd - - def get_auth_info(self, url: str, username: Optional[str]) -> Optional[AuthInfo]: - # This is the default implementation of keyring.get_credential - # https://github.com/jaraco/keyring/blob/97689324abcf01bd1793d49063e7ca01e03d7d07/keyring/backend.py#L134-L139 - if username is not None: - password = self._get_password(url, username) - if password is not None: - return username, password - return None - - def save_auth_info(self, url: str, username: str, password: str) -> None: - return self._set_password(url, username, password) - - def _get_password(self, service_name: str, username: str) -> Optional[str]: - """Mirror the implementation of keyring.get_password using cli""" - if self.keyring is None: - return None - - cmd = [self.keyring, "get", service_name, username] - env = os.environ.copy() - env["PYTHONIOENCODING"] = "utf-8" - res = subprocess.run( - cmd, - stdin=subprocess.DEVNULL, - stdout=subprocess.PIPE, - env=env, - ) - if res.returncode: - return None - return res.stdout.decode("utf-8").strip(os.linesep) - - def _set_password(self, service_name: str, username: str, password: str) -> None: - """Mirror the implementation of keyring.set_password using cli""" - if self.keyring is None: - return None - env = os.environ.copy() - env["PYTHONIOENCODING"] = "utf-8" - subprocess.run( - [self.keyring, "set", service_name, username], - input=f"{password}{os.linesep}".encode("utf-8"), - env=env, - check=True, - ) - return None - - -@lru_cache(maxsize=None) -def get_keyring_provider(provider: str) -> KeyRingBaseProvider: - logger.verbose("Keyring provider requested: %s", provider) - - # keyring has previously failed and been disabled - if KEYRING_DISABLED: - provider = "disabled" - if provider in ["import", "auto"]: - try: - impl = KeyRingPythonProvider() - logger.verbose("Keyring provider set: import") - return impl - except ImportError: - pass - except Exception as exc: - # In the event of an unexpected exception - # we should warn the user - msg = "Installed copy of keyring fails with exception %s" - if provider == "auto": - msg = msg + ", trying to find a keyring executable as a fallback" - logger.warning(msg, exc, exc_info=logger.isEnabledFor(logging.DEBUG)) - if provider in ["subprocess", "auto"]: - cli = shutil.which("keyring") - if cli and cli.startswith(sysconfig.get_path("scripts")): - # all code within this function is stolen from shutil.which implementation - @typing.no_type_check - def PATH_as_shutil_which_determines_it() -> str: - path = os.environ.get("PATH", None) - if path is None: - try: - path = os.confstr("CS_PATH") - except (AttributeError, ValueError): - # os.confstr() or CS_PATH is not available - path = os.defpath - # bpo-35755: Don't use os.defpath if the PATH environment variable is - # set to an empty string - - return path - - scripts = Path(sysconfig.get_path("scripts")) - - paths = [] - for path in PATH_as_shutil_which_determines_it().split(os.pathsep): - p = Path(path) - try: - if not p.samefile(scripts): - paths.append(path) - except FileNotFoundError: - pass - - path = os.pathsep.join(paths) - - cli = shutil.which("keyring", path=path) - - if cli: - logger.verbose("Keyring provider set: subprocess with executable %s", cli) - return KeyRingCliProvider(cli) - - logger.verbose("Keyring provider set: disabled") - return KeyRingNullProvider() - - -class MultiDomainBasicAuth(AuthBase): - def __init__( - self, - prompting: bool = True, - index_urls: Optional[List[str]] = None, - keyring_provider: str = "auto", - ) -> None: - self.prompting = prompting - self.index_urls = index_urls - self.keyring_provider = keyring_provider # type: ignore[assignment] - self.passwords: Dict[str, AuthInfo] = {} - # When the user is prompted to enter credentials and keyring is - # available, we will offer to save them. If the user accepts, - # this value is set to the credentials they entered. After the - # request authenticates, the caller should call - # ``save_credentials`` to save these. - self._credentials_to_save: Optional[Credentials] = None - - @property - def keyring_provider(self) -> KeyRingBaseProvider: - return get_keyring_provider(self._keyring_provider) - - @keyring_provider.setter - def keyring_provider(self, provider: str) -> None: - # The free function get_keyring_provider has been decorated with - # functools.cache. If an exception occurs in get_keyring_auth that - # cache will be cleared and keyring disabled, take that into account - # if you want to remove this indirection. - self._keyring_provider = provider - - @property - def use_keyring(self) -> bool: - # We won't use keyring when --no-input is passed unless - # a specific provider is requested because it might require - # user interaction - return self.prompting or self._keyring_provider not in ["auto", "disabled"] - - def _get_keyring_auth( - self, - url: Optional[str], - username: Optional[str], - ) -> Optional[AuthInfo]: - """Return the tuple auth for a given url from keyring.""" - # Do nothing if no url was provided - if not url: - return None - - try: - return self.keyring_provider.get_auth_info(url, username) - except Exception as exc: - logger.warning( - "Keyring is skipped due to an exception: %s", - str(exc), - ) - global KEYRING_DISABLED - KEYRING_DISABLED = True - get_keyring_provider.cache_clear() - return None - - def _get_index_url(self, url: str) -> Optional[str]: - """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 - - url = remove_auth_from_url(url).rstrip("/") + "/" - parsed_url = urllib.parse.urlsplit(url) - - candidates = [] - - for index in self.index_urls: - index = index.rstrip("/") + "/" - parsed_index = urllib.parse.urlsplit(remove_auth_from_url(index)) - if parsed_url == parsed_index: - return index - - if parsed_url.netloc != parsed_index.netloc: - continue - - candidate = urllib.parse.urlsplit(index) - candidates.append(candidate) - - if not candidates: - return None - - candidates.sort( - reverse=True, - key=lambda candidate: commonprefix( - [ - parsed_url.path, - candidate.path, - ] - ).rfind("/"), - ) - - return urllib.parse.urlunsplit(candidates[0]) - - def _get_new_credentials( - self, - original_url: str, - *, - allow_netrc: bool = True, - allow_keyring: bool = False, - ) -> AuthInfo: - """Find and return credentials for the specified URL.""" - # Split the credentials and netloc from the url. - url, netloc, url_user_password = split_auth_netloc_from_url( - 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 - # fmt: off - kr_auth = ( - self._get_keyring_auth(index_url, username) or - self._get_keyring_auth(netloc, username) - ) - # fmt: on - if kr_auth: - logger.debug("Found credentials in keyring for %s", netloc) - return kr_auth - - return username, password - - def _get_url_and_credentials( - self, original_url: str - ) -> Tuple[str, Optional[str], Optional[str]]: - """Return the credentials to use for the provided URL. - - If allowed, netrc and keyring may be used to obtain the - 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) - - # Try to get credentials from original url - username, password = self._get_new_credentials(original_url) - - # If credentials not found, use any stored credentials for this netloc. - # Do this if either the username or the password is missing. - # This accounts for the situation in which the user has specified - # the username in the index url, but the password comes from keyring. - if (username is None or password is None) and netloc in self.passwords: - un, pw = self.passwords[netloc] - # It is possible that the cached credentials are for a different username, - # in which case the cache should be ignored. - if username is None or username == un: - username, password = un, pw - - if username is not None or password is not None: - # Convert the username and password if they're None, so that - # 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) - # Credentials were not found - or (username is None and password is None) - ), f"Could not load credentials from url: {original_url}" - - return url, username, password - - def __call__(self, req: Request) -> Request: - # 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: str - ) -> Tuple[Optional[str], Optional[str], bool]: - username = ask_input(f"User for {netloc}: ") if self.prompting else None - if not username: - return None, None, False - if self.use_keyring: - auth = self._get_keyring_auth(netloc, username) - if auth and auth[0] is not None and auth[1] is not None: - return auth[0], auth[1], False - password = ask_password("Password: ") - return username, password, True - - # Factored out to allow for easy patching in tests - def _should_save_password_to_keyring(self) -> bool: - if ( - not self.prompting - or not self.use_keyring - or not self.keyring_provider.has_keyring - ): - return False - return ask("Save credentials to keyring [y/N]: ", ["y", "n"]) == "y" - - def handle_401(self, resp: Response, **kwargs: Any) -> Response: - # We only care about 401 responses, anything else we want to just - # pass through the actual response - if resp.status_code != 401: - return resp - - username, password = None, None - - # Query the keyring for credentials: - if self.use_keyring: - username, password = self._get_new_credentials( - resp.url, - allow_netrc=False, - allow_keyring=True, - ) - - # We are not able to prompt the user so simply return the response - if not self.prompting and not username and not password: - return resp - - parsed = urllib.parse.urlparse(resp.url) - - # Prompt the user for a new username and password - save = False - if not username and not 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 = Credentials( - url=parsed.netloc, - username=username, - password=password, - ) - - # Consume content and release the original connection to allow our new - # request to reuse the same one. - # The result of the assignment isn't used, it's just needed to consume - # the content. - _ = resp.content - resp.raw.release_conn() - - # Add our new username and password to the request - 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: Response, **kwargs: Any) -> None: - """Response callback to warn about incorrect credentials.""" - if resp.status_code == 401: - logger.warning( - "401 Error, Credentials not correct for %s", - resp.request.url, - ) - - def save_credentials(self, resp: Response, **kwargs: Any) -> None: - """Response callback to save credentials on success.""" - assert ( - self.keyring_provider.has_keyring - ), "should never reach here without keyring" - - creds = self._credentials_to_save - self._credentials_to_save = None - if creds and resp.status_code < 400: - try: - logger.info("Saving credentials to keyring") - self.keyring_provider.save_auth_info( - creds.url, creds.username, creds.password - ) - except Exception: - logger.exception("Failed to save credentials") diff --git a/venv/lib/python3.12/site-packages/pip/_internal/network/cache.py b/venv/lib/python3.12/site-packages/pip/_internal/network/cache.py deleted file mode 100644 index 4d0fb54..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/network/cache.py +++ /dev/null @@ -1,106 +0,0 @@ -"""HTTP cache implementation. -""" - -import os -from contextlib import contextmanager -from datetime import datetime -from typing import BinaryIO, Generator, Optional, Union - -from pip._vendor.cachecontrol.cache import SeparateBodyBaseCache -from pip._vendor.cachecontrol.caches import SeparateBodyFileCache -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 - - -def is_from_cache(response: Response) -> bool: - return getattr(response, "from_cache", False) - - -@contextmanager -def suppressed_cache_errors() -> Generator[None, None, None]: - """If we can't access the cache then we can just skip caching and process - requests as if caching wasn't enabled. - """ - try: - yield - except OSError: - pass - - -class SafeFileCache(SeparateBodyBaseCache): - """ - A file based cache which is safe to use even when the target directory may - not be accessible or writable. - - There is a race condition when two processes try to write and/or read the - same entry at the same time, since each entry consists of two separate - files (https://github.com/psf/cachecontrol/issues/324). We therefore have - additional logic that makes sure that both files to be present before - returning an entry; this fixes the read side of the race condition. - - For the write side, we assume that the server will only ever return the - same data for the same URL, which ought to be the case for files pip is - downloading. PyPI does not have a mechanism to swap out a wheel for - another wheel, for example. If this assumption is not true, the - CacheControl issue will need to be fixed. - """ - - def __init__(self, directory: str) -> None: - assert directory is not None, "Cache directory must not be None." - super().__init__() - self.directory = directory - - def _get_cache_path(self, name: 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 = SeparateBodyFileCache.encode(name) - parts = list(hashed[:5]) + [hashed] - return os.path.join(self.directory, *parts) - - def get(self, key: str) -> Optional[bytes]: - # The cache entry is only valid if both metadata and body exist. - metadata_path = self._get_cache_path(key) - body_path = metadata_path + ".body" - if not (os.path.exists(metadata_path) and os.path.exists(body_path)): - return None - with suppressed_cache_errors(): - with open(metadata_path, "rb") as f: - return f.read() - - def _write(self, path: str, data: bytes) -> None: - with suppressed_cache_errors(): - ensure_dir(os.path.dirname(path)) - - with adjacent_tmp_file(path) as f: - f.write(data) - - replace(f.name, path) - - def set( - self, key: str, value: bytes, expires: Union[int, datetime, None] = None - ) -> None: - path = self._get_cache_path(key) - self._write(path, value) - - def delete(self, key: str) -> None: - path = self._get_cache_path(key) - with suppressed_cache_errors(): - os.remove(path) - with suppressed_cache_errors(): - os.remove(path + ".body") - - def get_body(self, key: str) -> Optional[BinaryIO]: - # The cache entry is only valid if both metadata and body exist. - metadata_path = self._get_cache_path(key) - body_path = metadata_path + ".body" - if not (os.path.exists(metadata_path) and os.path.exists(body_path)): - return None - with suppressed_cache_errors(): - return open(body_path, "rb") - - def set_body(self, key: str, body: bytes) -> None: - path = self._get_cache_path(key) + ".body" - self._write(path, body) diff --git a/venv/lib/python3.12/site-packages/pip/_internal/network/download.py b/venv/lib/python3.12/site-packages/pip/_internal/network/download.py deleted file mode 100644 index d1d4354..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/network/download.py +++ /dev/null @@ -1,186 +0,0 @@ -"""Download files with progress indicators. -""" -import email.message -import logging -import mimetypes -import os -from typing import Iterable, Optional, Tuple - -from pip._vendor.requests.models import CONTENT_CHUNK_SIZE, Response - -from pip._internal.cli.progress_bars import get_download_progress_renderer -from pip._internal.exceptions import NetworkConnectionError -from pip._internal.models.index import PyPI -from pip._internal.models.link import Link -from pip._internal.network.cache import is_from_cache -from pip._internal.network.session import PipSession -from pip._internal.network.utils import HEADERS, raise_for_status, response_chunks -from pip._internal.utils.misc import format_size, redact_auth_from_url, splitext - -logger = logging.getLogger(__name__) - - -def _get_http_response_size(resp: Response) -> Optional[int]: - try: - return int(resp.headers["content-length"]) - except (ValueError, KeyError, TypeError): - return None - - -def _prepare_download( - resp: Response, - link: Link, - progress_bar: str, -) -> 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 = f"{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 - - renderer = get_download_progress_renderer(bar_type=progress_bar, size=total_length) - return renderer(chunks) - - -def sanitize_content_filename(filename: str) -> str: - """ - Sanitize the "filename" value from a Content-Disposition header. - """ - return os.path.basename(filename) - - -def parse_content_disposition(content_disposition: str, default_filename: str) -> str: - """ - Parse the "filename" value from a Content-Disposition header, and - return the default filename if the result is empty. - """ - m = email.message.Message() - m["content-type"] = content_disposition - filename = m.get_param("filename") - if filename: - # We need to sanitize the filename to prevent directory traversal - # in case the filename contains ".." path parts. - filename = sanitize_content_filename(str(filename)) - return filename or default_filename - - -def _get_http_response_filename(resp: Response, link: Link) -> str: - """Get an ideal filename from the given HTTP response, falling back to - the link filename if not provided. - """ - filename = link.filename # fallback - # Have a look at the Content-Disposition header for a better guess - content_disposition = resp.headers.get("content-disposition") - if content_disposition: - filename = parse_content_disposition(content_disposition, filename) - ext: Optional[str] = splitext(filename)[1] - 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: PipSession, link: Link) -> Response: - target_url = link.url.split("#", 1)[0] - resp = session.get(target_url, headers=HEADERS, stream=True) - raise_for_status(resp) - return resp - - -class Downloader: - def __init__( - self, - session: PipSession, - progress_bar: str, - ) -> None: - self._session = session - self._progress_bar = progress_bar - - def __call__(self, link: Link, location: str) -> Tuple[str, str]: - """Download the file given by link into location.""" - try: - resp = _http_get_download(self._session, link) - except NetworkConnectionError as e: - assert e.response is not None - logger.critical( - "HTTP error %s while getting %s", e.response.status_code, link - ) - raise - - filename = _get_http_response_filename(resp, link) - filepath = os.path.join(location, filename) - - chunks = _prepare_download(resp, link, self._progress_bar) - with open(filepath, "wb") as content_file: - for chunk in chunks: - content_file.write(chunk) - content_type = resp.headers.get("Content-Type", "") - return filepath, content_type - - -class BatchDownloader: - def __init__( - self, - session: PipSession, - progress_bar: str, - ) -> None: - self._session = session - self._progress_bar = progress_bar - - def __call__( - self, links: Iterable[Link], location: str - ) -> Iterable[Tuple[Link, Tuple[str, str]]]: - """Download the files given by links into location.""" - for link in links: - try: - resp = _http_get_download(self._session, link) - except NetworkConnectionError as e: - assert e.response is not None - logger.critical( - "HTTP error %s while getting %s", - e.response.status_code, - link, - ) - raise - - filename = _get_http_response_filename(resp, link) - filepath = os.path.join(location, filename) - - chunks = _prepare_download(resp, link, self._progress_bar) - with open(filepath, "wb") as content_file: - for chunk in chunks: - content_file.write(chunk) - content_type = resp.headers.get("Content-Type", "") - yield link, (filepath, content_type) diff --git a/venv/lib/python3.12/site-packages/pip/_internal/network/lazy_wheel.py b/venv/lib/python3.12/site-packages/pip/_internal/network/lazy_wheel.py deleted file mode 100644 index 82ec50d..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/network/lazy_wheel.py +++ /dev/null @@ -1,210 +0,0 @@ -"""Lazy ZIP over HTTP""" - -__all__ = ["HTTPRangeRequestUnsupported", "dist_from_wheel_url"] - -from bisect import bisect_left, bisect_right -from contextlib import contextmanager -from tempfile import NamedTemporaryFile -from typing import Any, Dict, Generator, List, Optional, Tuple -from zipfile import BadZipFile, ZipFile - -from pip._vendor.packaging.utils import canonicalize_name -from pip._vendor.requests.models import CONTENT_CHUNK_SIZE, Response - -from pip._internal.metadata import BaseDistribution, MemoryWheel, get_wheel_distribution -from pip._internal.network.session import PipSession -from pip._internal.network.utils import HEADERS, raise_for_status, response_chunks - - -class HTTPRangeRequestUnsupported(Exception): - pass - - -def dist_from_wheel_url(name: str, url: str, session: PipSession) -> BaseDistribution: - """Return a distribution object from the given wheel URL. - - This uses HTTP range requests to only fetch the portion of the wheel - containing metadata, just enough for the object to be constructed. - If such requests are not supported, HTTPRangeRequestUnsupported - is raised. - """ - with LazyZipOverHTTP(url, session) as zf: - # For read-only ZIP files, ZipFile only needs methods read, - # seek, seekable and tell, not the whole IO protocol. - wheel = MemoryWheel(zf.name, zf) # type: ignore - # After context manager exit, wheel.name - # is an invalid file by intention. - return get_wheel_distribution(wheel, canonicalize_name(name)) - - -class LazyZipOverHTTP: - """File-like object mapped to a ZIP file over HTTP. - - This uses HTTP range requests to lazily fetch the file's content, - which is supposed to be fed to ZipFile. If such requests are not - supported by the server, raise HTTPRangeRequestUnsupported - during initialization. - """ - - def __init__( - self, url: str, session: PipSession, chunk_size: int = CONTENT_CHUNK_SIZE - ) -> None: - head = session.head(url, headers=HEADERS) - raise_for_status(head) - assert head.status_code == 200 - self._session, self._url, self._chunk_size = session, url, chunk_size - self._length = int(head.headers["Content-Length"]) - self._file = NamedTemporaryFile() - self.truncate(self._length) - self._left: List[int] = [] - self._right: List[int] = [] - if "bytes" not in head.headers.get("Accept-Ranges", "none"): - raise HTTPRangeRequestUnsupported("range request is not supported") - self._check_zip() - - @property - def mode(self) -> str: - """Opening mode, which is always rb.""" - return "rb" - - @property - def name(self) -> str: - """Path to the underlying file.""" - return self._file.name - - def seekable(self) -> bool: - """Return whether random access is supported, which is True.""" - return True - - def close(self) -> None: - """Close the file.""" - self._file.close() - - @property - def closed(self) -> bool: - """Whether the file is closed.""" - return self._file.closed - - def read(self, size: int = -1) -> bytes: - """Read up to size bytes from the object and return them. - - As a convenience, if size is unspecified or -1, - all bytes until EOF are returned. Fewer than - size bytes may be returned if EOF is reached. - """ - download_size = max(size, self._chunk_size) - start, length = self.tell(), self._length - stop = length if size < 0 else min(start + download_size, length) - start = max(0, stop - download_size) - self._download(start, stop - 1) - return self._file.read(size) - - def readable(self) -> bool: - """Return whether the file is readable, which is True.""" - return True - - def seek(self, offset: int, whence: int = 0) -> int: - """Change stream position and return the new absolute position. - - Seek to offset relative position indicated by whence: - * 0: Start of stream (the default). pos should be >= 0; - * 1: Current position - pos may be negative; - * 2: End of stream - pos usually negative. - """ - return self._file.seek(offset, whence) - - def tell(self) -> int: - """Return the current position.""" - return self._file.tell() - - def truncate(self, size: Optional[int] = None) -> int: - """Resize the stream to the given size in bytes. - - If size is unspecified resize to the current position. - The current stream position isn't changed. - - Return the new file size. - """ - return self._file.truncate(size) - - def writable(self) -> bool: - """Return False.""" - return False - - def __enter__(self) -> "LazyZipOverHTTP": - self._file.__enter__() - return self - - def __exit__(self, *exc: Any) -> None: - self._file.__exit__(*exc) - - @contextmanager - def _stay(self) -> Generator[None, None, None]: - """Return a context manager keeping the position. - - At the end of the block, seek back to original position. - """ - pos = self.tell() - try: - yield - finally: - self.seek(pos) - - def _check_zip(self) -> None: - """Check and download until the file is a valid ZIP.""" - end = self._length - 1 - for start in reversed(range(0, end, self._chunk_size)): - self._download(start, end) - with self._stay(): - try: - # For read-only ZIP files, ZipFile only needs - # methods read, seek, seekable and tell. - ZipFile(self) # type: ignore - except BadZipFile: - pass - else: - break - - def _stream_response( - self, start: int, end: int, base_headers: Dict[str, str] = HEADERS - ) -> Response: - """Return HTTP response to a range request from start to end.""" - headers = base_headers.copy() - headers["Range"] = f"bytes={start}-{end}" - # TODO: Get range requests to be correctly cached - headers["Cache-Control"] = "no-cache" - return self._session.get(self._url, headers=headers, stream=True) - - def _merge( - self, start: int, end: int, left: int, right: int - ) -> Generator[Tuple[int, int], None, None]: - """Return a generator of intervals to be fetched. - - Args: - start (int): Start of needed interval - end (int): End of needed interval - left (int): Index of first overlapping downloaded data - right (int): Index after last overlapping downloaded data - """ - lslice, rslice = self._left[left:right], self._right[left:right] - i = start = min([start] + lslice[:1]) - end = max([end] + rslice[-1:]) - for j, k in zip(lslice, rslice): - if j > i: - yield i, j - 1 - i = k + 1 - if i <= end: - yield i, end - self._left[left:right], self._right[left:right] = [start], [end] - - def _download(self, start: int, end: int) -> None: - """Download bytes from start to end inclusively.""" - with self._stay(): - left = bisect_left(self._right, start) - right = bisect_right(self._left, end) - for start, end in self._merge(start, end, left, right): - response = self._stream_response(start, end) - response.raise_for_status() - self.seek(start) - for chunk in response_chunks(response, self._chunk_size): - self._file.write(chunk) diff --git a/venv/lib/python3.12/site-packages/pip/_internal/network/session.py b/venv/lib/python3.12/site-packages/pip/_internal/network/session.py deleted file mode 100644 index f17efc5..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/network/session.py +++ /dev/null @@ -1,520 +0,0 @@ -"""PipSession and supporting code, containing all pip-specific -network request configuration and behavior. -""" - -import email.utils -import io -import ipaddress -import json -import logging -import mimetypes -import os -import platform -import shutil -import subprocess -import sys -import urllib.parse -import warnings -from typing import ( - TYPE_CHECKING, - Any, - Dict, - Generator, - List, - Mapping, - Optional, - Sequence, - Tuple, - Union, -) - -from pip._vendor import requests, urllib3 -from pip._vendor.cachecontrol import CacheControlAdapter as _BaseCacheControlAdapter -from pip._vendor.requests.adapters import DEFAULT_POOLBLOCK, BaseAdapter -from pip._vendor.requests.adapters import HTTPAdapter as _BaseHTTPAdapter -from pip._vendor.requests.models import PreparedRequest, Response -from pip._vendor.requests.structures import CaseInsensitiveDict -from pip._vendor.urllib3.connectionpool import ConnectionPool -from pip._vendor.urllib3.exceptions import InsecureRequestWarning - -from pip import __version__ -from pip._internal.metadata import get_default_environment -from pip._internal.models.link import Link -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 -from pip._internal.utils.glibc import libc_ver -from pip._internal.utils.misc import build_url_from_netloc, parse_netloc -from pip._internal.utils.urls import url_to_path - -if TYPE_CHECKING: - from ssl import SSLContext - - from pip._vendor.urllib3.poolmanager import PoolManager - - -logger = logging.getLogger(__name__) - -SecureOrigin = Tuple[str, str, Optional[Union[int, str]]] - - -# Ignore warning raised when using --trusted-host. -warnings.filterwarnings("ignore", category=InsecureRequestWarning) - - -SECURE_ORIGINS: List[SecureOrigin] = [ - # 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", "*", "*"), -] - - -# 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() -> 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() -> str: - """ - Return a string representing the user agent. - """ - data: Dict[str, Any] = { - "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": - pypy_version_info = sys.pypy_version_info # type: ignore - if pypy_version_info.releaselevel == "final": - pypy_version_info = pypy_version_info[:3] - data["implementation"]["version"] = ".".join( - [str(x) for x in pypy_version_info] - ) - elif data["implementation"]["name"] == "Jython": - # 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 - - linux_distribution = distro.name(), distro.version(), distro.codename() - distro_infos: Dict[str, Any] = dict( - filter( - lambda x: x[1], - zip(["name", "version", "id"], linux_distribution), - ) - ) - libc = dict( - filter( - lambda x: x[1], - zip(["lib", "version"], libc_ver()), - ) - ) - if libc: - distro_infos["libc"] = libc - if distro_infos: - 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_dist = get_default_environment().get_distribution("setuptools") - if setuptools_dist is not None: - data["setuptools_version"] = str(setuptools_dist.version) - - if shutil.which("rustc") is not None: - # If for any reason `rustc --version` fails, silently ignore it - try: - rustc_output = subprocess.check_output( - ["rustc", "--version"], stderr=subprocess.STDOUT, timeout=0.5 - ) - except Exception: - pass - else: - if rustc_output.startswith(b"rustc "): - # The format of `rustc --version` is: - # `b'rustc 1.52.1 (9bc8c42bb 2021-05-09)\n'` - # We extract just the middle (1.52.1) part - data["rustc_version"] = rustc_output.split(b" ")[1].decode() - - # Use None rather than False so as not to give the impression that - # pip knows it is not being run under CI. Rather, it is a null or - # inconclusive result. Also, we include some value rather than no - # 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: PreparedRequest, - stream: bool = False, - timeout: Optional[Union[float, Tuple[float, float]]] = None, - verify: Union[bool, str] = True, - cert: Optional[Union[str, Tuple[str, str]]] = None, - proxies: Optional[Mapping[str, str]] = None, - ) -> Response: - pathname = url_to_path(request.url) - - resp = Response() - resp.status_code = 200 - resp.url = request.url - - try: - stats = os.stat(pathname) - except OSError as exc: - # format the exception raised as a io.BytesIO object, - # to return a better error message: - resp.status_code = 404 - resp.reason = type(exc).__name__ - resp.raw = io.BytesIO(f"{resp.reason}: {exc}".encode("utf8")) - else: - modified = email.utils.formatdate(stats.st_mtime, usegmt=True) - content_type = mimetypes.guess_type(pathname)[0] or "text/plain" - resp.headers = CaseInsensitiveDict( - { - "Content-Type": content_type, - "Content-Length": stats.st_size, - "Last-Modified": modified, - } - ) - - resp.raw = open(pathname, "rb") - resp.close = resp.raw.close - - return resp - - def close(self) -> None: - pass - - -class _SSLContextAdapterMixin: - """Mixin to add the ``ssl_context`` constructor argument to HTTP adapters. - - The additional argument is forwarded directly to the pool manager. This allows us - to dynamically decide what SSL store to use at runtime, which is used to implement - the optional ``truststore`` backend. - """ - - def __init__( - self, - *, - ssl_context: Optional["SSLContext"] = None, - **kwargs: Any, - ) -> None: - self._ssl_context = ssl_context - super().__init__(**kwargs) - - def init_poolmanager( - self, - connections: int, - maxsize: int, - block: bool = DEFAULT_POOLBLOCK, - **pool_kwargs: Any, - ) -> "PoolManager": - if self._ssl_context is not None: - pool_kwargs.setdefault("ssl_context", self._ssl_context) - return super().init_poolmanager( # type: ignore[misc] - connections=connections, - maxsize=maxsize, - block=block, - **pool_kwargs, - ) - - -class HTTPAdapter(_SSLContextAdapterMixin, _BaseHTTPAdapter): - pass - - -class CacheControlAdapter(_SSLContextAdapterMixin, _BaseCacheControlAdapter): - pass - - -class InsecureHTTPAdapter(HTTPAdapter): - def cert_verify( - self, - conn: ConnectionPool, - url: str, - verify: Union[bool, str], - cert: Optional[Union[str, Tuple[str, str]]], - ) -> None: - super().cert_verify(conn=conn, url=url, verify=False, cert=cert) - - -class InsecureCacheControlAdapter(CacheControlAdapter): - def cert_verify( - self, - conn: ConnectionPool, - url: str, - verify: Union[bool, str], - cert: Optional[Union[str, Tuple[str, str]]], - ) -> None: - super().cert_verify(conn=conn, url=url, verify=False, cert=cert) - - -class PipSession(requests.Session): - timeout: Optional[int] = None - - def __init__( - self, - *args: Any, - retries: int = 0, - cache: Optional[str] = None, - trusted_hosts: Sequence[str] = (), - index_urls: Optional[List[str]] = None, - ssl_context: Optional["SSLContext"] = None, - **kwargs: Any, - ) -> None: - """ - :param trusted_hosts: Domains not to emit warnings for when not using - HTTPS. - """ - super().__init__(*args, **kwargs) - - # Namespace the attribute with "pip_" just in case to prevent - # possible conflicts with the base class. - self.pip_trusted_origins: 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 502 may be a transient error from a CDN like CloudFlare or CloudFront - # A 520 or 527 - may indicate transient error in CloudFlare - status_forcelist=[500, 502, 503, 520, 527], - # Add a small amount of back off between failed requests in - # order to prevent hammering the service. - backoff_factor=0.25, - ) # type: ignore - - # Our Insecure HTTPAdapter disables HTTPS validation. It does not - # support caching so we'll use it for all http:// URLs. - # If caching is disabled, we will also use it for - # https:// hosts that we've marked as ignoring - # TLS errors for (trusted-hosts). - insecure_adapter = InsecureHTTPAdapter(max_retries=retries) - - # We want to _only_ cache responses on securely fetched origins or when - # the host is specified as trusted. We do this because - # we can't validate the response of an insecurely/untrusted 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, - ssl_context=ssl_context, - ) - self._trusted_host_adapter = InsecureCacheControlAdapter( - cache=SafeFileCache(cache), - max_retries=retries, - ) - else: - secure_adapter = HTTPAdapter(max_retries=retries, ssl_context=ssl_context) - self._trusted_host_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 update_index_urls(self, new_index_urls: List[str]) -> None: - """ - :param new_index_urls: New index urls to update the authentication - handler with. - """ - self.auth.index_urls = new_index_urls - - def add_trusted_host( - self, host: str, source: Optional[str] = None, suppress_logging: bool = False - ) -> 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 = f"adding trusted host: {host!r}" - if source is not None: - msg += f" (from {source})" - logger.info(msg) - - parsed_host, parsed_port = parse_netloc(host) - if parsed_host is None: - raise ValueError(f"Trusted host URL must include a host part: {host!r}") - if (parsed_host, parsed_port) not in self.pip_trusted_origins: - self.pip_trusted_origins.append((parsed_host, parsed_port)) - - self.mount( - build_url_from_netloc(host, scheme="http") + "/", self._trusted_host_adapter - ) - self.mount(build_url_from_netloc(host) + "/", self._trusted_host_adapter) - if not parsed_port: - self.mount( - build_url_from_netloc(host, scheme="http") + ":", - self._trusted_host_adapter, - ) - # Mount wildcard ports for the same host. - self.mount(build_url_from_netloc(host) + ":", self._trusted_host_adapter) - - def iter_secure_origins(self) -> Generator[SecureOrigin, None, None]: - yield from SECURE_ORIGINS - for host, port in self.pip_trusted_origins: - yield ("*", host, "*" if port is None else port) - - def is_secure_origin(self, location: Link) -> bool: - # Determine if this url used a secure transport mechanism - parsed = urllib.parse.urlparse(str(location)) - origin_protocol, origin_host, origin_port = ( - parsed.scheme, - parsed.hostname, - parsed.port, - ) - - # 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(origin_host or "") - network = ipaddress.ip_network(secure_host) - except ValueError: - # We don't have both a valid address or a valid network, so - # we'll check this origin against hostnames. - if ( - origin_host - and origin_host.lower() != secure_host.lower() - and secure_host != "*" - ): - 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: str, url: str, *args: Any, **kwargs: Any) -> Response: - # Allow setting a default timeout on a session - kwargs.setdefault("timeout", self.timeout) - # Allow setting a default proxies on a session - kwargs.setdefault("proxies", self.proxies) - - # Dispatch the actual request - return super().request(method, url, *args, **kwargs) diff --git a/venv/lib/python3.12/site-packages/pip/_internal/network/utils.py b/venv/lib/python3.12/site-packages/pip/_internal/network/utils.py deleted file mode 100644 index 134848a..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/network/utils.py +++ /dev/null @@ -1,96 +0,0 @@ -from typing import Dict, Generator - -from pip._vendor.requests.models import CONTENT_CHUNK_SIZE, Response - -from pip._internal.exceptions import NetworkConnectionError - -# The following comments and HTTP headers were originally added by -# Donald Stufft in git commit 22c562429a61bb77172039e480873fb239dd8c03. -# -# 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, adding 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: Dict[str, str] = {"Accept-Encoding": "identity"} - - -def raise_for_status(resp: Response) -> None: - http_error_msg = "" - if isinstance(resp.reason, bytes): - # We attempt to decode utf-8 first because some servers - # choose to localize their reason strings. If the string - # isn't utf-8, we fall back to iso-8859-1 for all other - # encodings. - try: - reason = resp.reason.decode("utf-8") - except UnicodeDecodeError: - reason = resp.reason.decode("iso-8859-1") - else: - reason = resp.reason - - if 400 <= resp.status_code < 500: - http_error_msg = ( - f"{resp.status_code} Client Error: {reason} for url: {resp.url}" - ) - - elif 500 <= resp.status_code < 600: - http_error_msg = ( - f"{resp.status_code} Server Error: {reason} for url: {resp.url}" - ) - - if http_error_msg: - raise NetworkConnectionError(http_error_msg, response=resp) - - -def response_chunks( - response: Response, chunk_size: int = CONTENT_CHUNK_SIZE -) -> Generator[bytes, None, None]: - """Given a requests Response, provide the data chunks.""" - try: - # Special case for urllib3. - for chunk in response.raw.stream( - 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.12/site-packages/pip/_internal/network/xmlrpc.py b/venv/lib/python3.12/site-packages/pip/_internal/network/xmlrpc.py deleted file mode 100644 index 22ec8d2..0000000 --- a/venv/lib/python3.12/site-packages/pip/_internal/network/xmlrpc.py +++ /dev/null @@ -1,62 +0,0 @@ -"""xmlrpclib.Transport implementation -""" - -import logging -import urllib.parse -import xmlrpc.client -from typing import TYPE_CHECKING, Tuple - -from pip._internal.exceptions import NetworkConnectionError -from pip._internal.network.session import PipSession -from pip._internal.network.utils import raise_for_status - -if TYPE_CHECKING: - from xmlrpc.client import _HostType, _Marshallable - - from _typeshed import SizedBuffer - -logger = logging.getLogger(__name__) - - -class PipXmlrpcTransport(xmlrpc.client.Transport): - """Provide a `xmlrpclib.Transport` implementation via a `PipSession` - object. - """ - - def __init__( - self, index_url: str, session: PipSession, use_datetime: bool = False - ) -> None: - super().__init__(use_datetime) - index_parts = urllib.parse.urlparse(index_url) - self._scheme = index_parts.scheme - self._session = session - - def request( - self, - host: "_HostType", - handler: str, - request_body: "SizedBuffer", - verbose: bool = False, - ) -> Tuple["_Marshallable", ...]: - assert isinstance(host, str) - parts = (self._scheme, host, handler, None, None, None) - url = urllib.parse.urlunparse(parts) - try: - headers = {"Content-Type": "text/xml"} - response = self._session.post( - url, - data=request_body, - headers=headers, - stream=True, - ) - raise_for_status(response) - self.verbose = verbose - return self.parse_response(response.raw) - except NetworkConnectionError as exc: - assert exc.response - logger.critical( - "HTTP error %s while getting %s", - exc.response.status_code, - url, - ) - raise diff --git a/venv/lib/python3.12/site-packages/pip/_internal/operations/__init__.py b/venv/lib/python3.12/site-packages/pip/_internal/operations/__init__.py deleted file mode 100644 index e69de29..0000000 diff --git a/venv/lib/python3.12/site-packages/pip/_internal/operations/__pycache__/__init__.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/operations/__pycache__/__init__.cpython-312.pyc deleted file mode 100644 index 7057c91b9bdcd1392bcd131640ade6e79f8b5b85..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 207 zcmZ9FK?=e!5JeNKAVLq~q8-$&2t_w;#2bXD!46H6kfeor372l&dKQo238cHOOtyab z^WS_1=AEW967-)9^o-@E Z8>Z`8Um7Vkb`svxU>D(=P)cnQ=m##rIIREx diff --git a/venv/lib/python3.12/site-packages/pip/_internal/operations/__pycache__/check.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/operations/__pycache__/check.cpython-312.pyc deleted file mode 100644 index f51200bd6d3c086a7716e1b37e3d60175d05eb3f..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 7589 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 diff --git a/venv/lib/python3.12/site-packages/pip/_internal/operations/__pycache__/freeze.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/operations/__pycache__/freeze.cpython-312.pyc deleted file mode 100644 index b750a01d624f28d51b2a135e09f66bda726139c7..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 10127 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 Kj}VC!rT!mxttgEE diff --git a/venv/lib/python3.12/site-packages/pip/_internal/operations/__pycache__/prepare.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/operations/__pycache__/prepare.cpython-312.pyc deleted file mode 100644 index 4ad3e0541e9c66b2d4bd0f5335127a2ef6720e4e..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 25757 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 PU*H3q{g8(i3uOKV@^aHD diff --git a/venv/lib/python3.12/site-packages/pip/_internal/cli/__pycache__/status_codes.cpython-312.pyc b/venv/lib/python3.12/site-packages/pip/_internal/cli/__pycache__/status_codes.cpython-312.pyc deleted file mode 100644 index 26c18e5b3de33d3deac790899e9fced57b733209..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 385 zcmXw!F;Bu!6op?Y1;jK$#6Tjm2?M;St1+oFUI0!p7ulz%zXJ+~nMx+%HkA0;Z4No13utlP~|`_GZ&&<{c1V1H#!HDcA+V z+dL`SMIzY3qSPs`^XNK1SQm2eIf^-&45(Ae%BCgDs%d6|Y8bkai59v?`Xj=-wK39+ zp(XWIG{Q(9;#=K9O4b?}>PXWq6W>@`U%`rI?DI9G;|FOd->K#<`w2Fz32Z0uC74ne zImGotHwtF2P@(Z82|_4EbI0#W1Fb82E}T<;4n6k?hKuAS@GpDk7ch1c+6|rY#CfJM z4BZf7*H38VJ02Xfn>cZjS&YX4p>Z! 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: Optional[str] = None - 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 = not current.startswith("-") and subcommand_name in [ - "show", - "uninstall", - ] - if should_list_installed: - env = get_default_environment() - lc = current.lower() - installed = [ - dist.canonical_name - for dist in env.iter_installed_distributions(local_only=True) - if dist.canonical_name.startswith(lc) - and dist.canonical_name not in cwords[1:] - ] - # if there are no dists installed, fall back to option completion - if installed: - for dist in installed: - print(dist) - sys.exit(1) - - should_list_installables = ( - not current.startswith("-") and subcommand_name == "install" - ) - if should_list_installables: - for path in auto_complete_paths(current, "path"): - print(path) - sys.exit(1) - - subcommand = create_command(subcommand_name) - - for opt in subcommand.parser.option_list_all: - if opt.help != optparse.SUPPRESS_HELP: - options += [ - (opt_str, opt.nargs) for opt_str in opt._long_opts + opt._short_opts - ] - - # 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 - # ````, ``